/* HighMedia AppDesk — app.css
   Basiert 1:1 auf dem Prototyp highmedia_portal_v5_colorpicker.html */

*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#0f1117;--surface:#181c25;--surface2:#1f2433;
  --border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.14);
  --text:#e8eaf0;--muted:#8a8fa0;
  --accent:#2dd4a0;--accent-dim:rgba(45,212,160,0.12);
  --danger:#f07070;--warn:#f0b060;
  --font:'DM Sans',system-ui,sans-serif;--mono:'DM Mono','Courier New',monospace;
}

/* ── Google Fonts lokal ──────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=DM+Sans:wght@300;400;500&display=swap');

html,body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;}

/* ── Login ───────────────────────────────────────────────────────────────── */
#login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;}
.login-logo{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:3px;margin-bottom:2.5rem;}
.login-logo span{color:var(--muted);}
.login-card{background:var(--surface);border:0.5px solid var(--border2);border-radius:12px;padding:2rem;width:100%;max-width:340px;}
.login-card h2{font-size:18px;font-weight:500;margin-bottom:6px;}
.login-card p{font-size:13px;color:var(--muted);margin-bottom:1.5rem;}
.field{margin-bottom:1rem;}
.field label{display:block;font-size:11px;color:var(--muted);margin-bottom:5px;font-family:var(--mono);letter-spacing:1px;}
.field input,.field select{width:100%;background:var(--surface2);border:0.5px solid var(--border2);border-radius:8px;padding:10px 12px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;}
.field input:focus,.field select:focus{border-color:var(--accent);}
.field select option{background:var(--surface2);}
.login-btn{width:100%;background:var(--accent);border:none;border-radius:8px;padding:11px;color:#0a1a14;font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;transition:opacity 0.15s;}
.login-btn:hover{opacity:0.88;}
.login-btn:disabled{opacity:0.5;cursor:not-allowed;}
.login-hint{font-size:11px;color:var(--muted);text-align:center;margin-top:1rem;font-family:var(--mono);}

/* ── Portal Layout ───────────────────────────────────────────────────────── */
#portal{display:none;flex-direction:column;min-height:100vh;}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0.7rem 1.2rem;border-bottom:0.5px solid var(--border);background:var(--surface);}
.topbar-logo{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:2px;}
.topbar-logo span{color:var(--muted);}
.topbar-right{display:flex;align-items:center;gap:10px;}
.topbar-user{font-size:12px;color:var(--muted);}
.topbar-user strong{color:var(--text);}
.icon-btn{font-size:11px;background:none;border:0.5px solid var(--border2);border-radius:6px;padding:4px 10px;cursor:pointer;font-family:var(--mono);color:var(--muted);transition:all 0.12s;}
.icon-btn:hover{color:var(--accent);border-color:var(--accent);}

/* ── Sidebar ─────────────────────────────────────────────────────────────── */
.portal-body{display:flex;flex:1;}
.sidebar{width:210px;border-right:0.5px solid var(--border);padding:0.75rem 0;background:var(--surface);flex-shrink:0;display:flex;flex-direction:column;overflow-y:auto;}
.sb-top{padding:0 0.75rem 0.5rem;display:flex;align-items:center;justify-content:space-between;}
.sb-top-label{font-size:10px;color:var(--muted);font-family:var(--mono);letter-spacing:2px;text-transform:uppercase;}
.add-m-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;line-height:1;opacity:0.55;transition:opacity 0.12s;padding:0 2px;}
.add-m-btn:hover{opacity:1;color:var(--accent);}
.m-row{display:flex;align-items:center;padding:0 6px;border-radius:6px;cursor:pointer;transition:background 0.12s;position:relative;}
.m-row:hover{background:var(--surface2);}
.m-chevron{width:20px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--muted);font-size:9px;transition:transform 0.18s;user-select:none;}
.m-chevron.open{transform:rotate(90deg);}
.m-avatar{width:20px;height:20px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:500;flex-shrink:0;margin-right:7px;}
.m-main{flex:1;min-width:0;font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:5px 0;}
.m-row:hover .m-main{color:var(--text);}
.m-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity 0.12s;}
.m-row:hover .m-actions{opacity:1;}
.m-act-btn{background:none;border:none;cursor:pointer;font-size:11px;padding:2px 4px;border-radius:4px;color:var(--muted);transition:all 0.12s;}
.m-act-btn:hover{color:var(--accent);}
.m-act-btn.del:hover{color:var(--danger);}
.m-children{overflow:hidden;max-height:0;transition:max-height 0.22s ease;}
.m-children.open{max-height:600px;}
.cat-row{display:flex;align-items:center;padding:0 6px 0 26px;border-radius:6px;cursor:pointer;transition:background 0.12s;}
.cat-row:hover{background:var(--surface2);}
.cat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-right:8px;}
.cat-label{flex:1;min-width:0;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:5px 0;}
.cat-row:hover .cat-label{color:var(--text);}
.cat-row.active .cat-label{color:var(--accent);}
.cat-row.active{background:var(--accent-dim);}
.cat-count{font-size:10px;font-family:var(--mono);background:var(--surface2);padding:1px 5px;border-radius:8px;color:var(--muted);flex-shrink:0;}
.cat-del{background:none;border:none;color:var(--danger);cursor:pointer;font-size:10px;padding:2px 3px;opacity:0;transition:opacity 0.12s;flex-shrink:0;}
.cat-row:hover .cat-del{opacity:0.6;}
.cat-del:hover{opacity:1!important;}
.cat-edit{background:none;border:none;color:var(--accent);cursor:pointer;font-size:10px;padding:2px 3px;opacity:0;transition:opacity 0.12s;flex-shrink:0;}
.cat-row:hover .cat-edit{opacity:0.75;}
.cat-edit:hover{opacity:1!important;}
.add-cat-row{display:flex;align-items:center;gap:6px;padding:4px 6px 4px 36px;border-radius:6px;cursor:pointer;font-size:11px;color:var(--muted);background:none;border:none;font-family:var(--font);transition:all 0.12s;width:100%;margin-bottom:4px;}
.add-cat-row:hover{color:var(--accent);}
.sb-spacer{flex:1;}
.sb-footer{padding:0.75rem 0.75rem 0.5rem;border-top:0.5px solid var(--border);margin-top:0.5rem;}
.phase-row{font-size:10px;color:var(--muted);font-family:var(--mono);padding:2px 0;opacity:0.4;}

/* ── Main Content ────────────────────────────────────────────────────────── */
.main{flex:1;padding:1.2rem;}
.phase-banner{background:var(--surface);border:0.5px solid var(--border);border-radius:8px;padding:8px 13px;display:flex;align-items:center;gap:10px;margin-bottom:1rem;}
.phase-tag{font-family:var(--mono);font-size:10px;background:rgba(108,142,255,0.15);color:#6c8eff;border:0.5px solid rgba(108,142,255,0.3);border-radius:4px;padding:2px 8px;white-space:nowrap;}
.phase-text{font-size:12px;color:var(--muted);}
.breadcrumb{font-size:11px;color:var(--muted);font-family:var(--mono);margin-bottom:0.75rem;}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.section-title{font-size:14px;font-weight:500;}
.add-btn{background:var(--accent-dim);border:0.5px solid var(--accent);border-radius:6px;padding:5px 12px;font-size:12px;color:var(--accent);cursor:pointer;font-family:var(--mono);transition:all 0.12s;}
.add-btn:hover{background:var(--accent);color:#0a1a14;}

/* ── App Grid ────────────────────────────────────────────────────────────── */
.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:10px;}
.app-card{background:var(--surface);border:0.5px solid var(--border);border-radius:10px;padding:12px 11px;cursor:pointer;transition:all 0.15s;position:relative;}
.app-card:hover{border-color:var(--border2);background:var(--surface2);}
.status-dot{position:absolute;top:9px;right:9px;width:7px;height:7px;border-radius:50%;}
.s-online{background:#2dd4a0;}.s-offline{background:var(--danger);}.s-warn{background:var(--warn);}.s-web{background:#6c8eff;}
.app-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;font-size:15px;}
.app-name{font-size:13px;font-weight:500;margin-bottom:2px;}
.app-cat-label{font-size:10px;color:var(--muted);font-family:var(--mono);}
.app-url{font-size:10px;color:var(--muted);margin-top:4px;font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.app-del{position:absolute;bottom:7px;right:7px;background:none;border:none;color:var(--danger);cursor:pointer;font-size:11px;opacity:0;transition:opacity 0.12s;}
.app-card:hover .app-del{opacity:0.6;}
.app-del:hover{opacity:1!important;}
.app-edit{position:absolute;bottom:7px;left:7px;background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;opacity:0;transition:opacity 0.12s;}
.app-card:hover .app-edit{opacity:0.75;}
.app-edit:hover{opacity:1!important;}
.empty-state{grid-column:1/-1;text-align:center;padding:2.5rem 1rem;color:var(--muted);font-size:13px;line-height:1.9;}

/* ── Modals ──────────────────────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.65);z-index:20;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:var(--surface);border:0.5px solid var(--border2);border-radius:12px;padding:1.5rem;width:340px;max-width:90vw;}
.modal h3{font-size:15px;font-weight:500;margin-bottom:1rem;}
.modal-btns{display:flex;gap:8px;margin-top:1rem;}
.modal-btns button{flex:1;padding:9px;border-radius:7px;font-size:13px;cursor:pointer;font-family:var(--font);font-weight:500;transition:all 0.12s;}
.btn-cancel{background:none;border:0.5px solid var(--border2);color:var(--muted);}
.btn-cancel:hover{border-color:var(--border2);color:var(--text);}
.btn-save{background:var(--accent);border:none;color:#0a1a14;}
.btn-save:hover{opacity:0.88;}

/* ── Color Picker ────────────────────────────────────────────────────────── */
.color-picker{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.swatch-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center;}
.color-swatch{width:22px;height:22px;border-radius:5px;cursor:pointer;border:2px solid transparent;transition:all 0.12s;flex-shrink:0;}
.color-swatch.sel{border-color:#fff;}
.swatch-custom{position:relative;width:22px;height:22px;border-radius:5px;cursor:pointer;border:2px solid var(--border2);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color 0.12s;}
.swatch-custom.sel{border-color:#fff;}
.swatch-custom input[type=color]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;border:none;padding:0;}
.swatch-custom-icon{font-size:11px;color:var(--muted);pointer-events:none;line-height:1;}
.hex-row{display:flex;align-items:center;gap:8px;}
.hex-preview{width:22px;height:22px;border-radius:5px;flex-shrink:0;border:0.5px solid var(--border2);}
.hex-input{flex:1;background:var(--surface2);border:0.5px solid var(--border2);border-radius:6px;padding:5px 8px;color:var(--text);font-family:var(--mono);font-size:12px;outline:none;letter-spacing:1px;}
.hex-input:focus{border-color:var(--accent);}
.hex-input.invalid{border-color:var(--danger);}

/* ── Ping-Animation ──────────────────────────────────────────────────────── */
@keyframes pulse {
  0%,100%{opacity:1;}
  50%{opacity:0.4;}
}
.s-checking{background:var(--muted);animation:pulse 1s infinite;}
