/* ============================================================
   CCM Dashboard — zentrales Design-System (Single Source of Truth)
   Farben, Schriften & Komponenten EINMAL definiert.
   Jede Seite lädt diese Datei → Design kann nicht mehr abweichen.
   ============================================================ */

:root{
  --orange:#FF7B00;
  --bg:#000;
  --card:rgba(255,255,255,0.03);
  --card2:rgba(255,255,255,0.02);
  --border:rgba(255,255,255,0.07);
  --white:#fff;
  --muted:#666;
  --light:#CCCCCC;
  --green:#22c55e;
  --red:#ef4444;
  --side-w:250px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{min-height:100%;overflow-x:hidden;background:#000}
body{background:transparent;color:var(--white);font-family:'Inter',sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;top:-330px;left:50%;transform:translateX(-50%);width:1200px;height:820px;background:radial-gradient(ellipse,rgba(255,255,255,0.28) 0%,rgba(255,255,255,0.10) 42%,transparent 72%);filter:blur(34px);pointer-events:none;z-index:0}

/* ---- ambient background ---- */
.ghost-wall{position:fixed;left:-220px;top:0;height:100vh;width:auto;opacity:.13;pointer-events:none;mix-blend-mode:screen;z-index:0;filter:grayscale(100%) contrast(1.2)}
.glut{position:fixed;left:0;right:0;bottom:0;height:32vh;z-index:0;pointer-events:none;background:radial-gradient(120% 100% at 50% 132%,rgba(255,110,0,.18),rgba(255,70,0,.04) 46%,transparent 72%)}

/* ---- app shell ---- */
.app{display:grid;grid-template-columns:var(--side-w) 1fr;min-height:100vh;position:relative;z-index:1}

/* ---- sidebar (injiziert via nav.js) ---- */
.side{border-right:1px solid var(--border);padding:14px 16px 22px;display:flex;flex-direction:column;gap:3px;position:sticky;top:0;height:100vh;background:rgba(0,0,0,.2);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.side .brand{display:block;width:100%;height:auto;object-fit:contain;margin:2px 0 6px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08)}
.mlabel{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.16em;margin:8px 14px 4px}
.nav{display:flex;flex-direction:column;gap:4px}
.nav a{display:flex;align-items:center;gap:13px;padding:10px 14px;border-radius:12px;color:var(--muted);font-size:14px;font-weight:700;cursor:pointer;transition:.15s;text-decoration:none}
.nav a svg{width:19px;height:19px;stroke-width:1.8;flex:0 0 auto}
.nav a.on{background:rgba(255,123,0,.10);color:var(--orange);border:1px solid rgba(255,123,0,.35)}
.nav a:hover:not(.on){background:var(--card);color:var(--white)}
.nav .badge{font-size:8px;font-weight:900;letter-spacing:.08em;background:rgba(255,123,0,.18);color:var(--orange);padding:2px 6px;border-radius:6px;margin-left:auto}
.nav .sub{display:flex;flex-direction:column;gap:2px;margin:2px 0 4px 24px;padding-left:10px;border-left:1px solid var(--border)}
.nav .sub a{display:flex;align-items:center;padding:7px 12px;font-size:13px;border-radius:9px}
.nav .sub a.on{background:rgba(255,123,0,.10);color:var(--orange);border:0}
.nav .navdiv{height:1px;background:var(--border);margin:8px 8px}
/* Dropdown-Gruppen */
.nav .grp{display:flex;align-items:center;gap:13px;padding:10px 14px;border-radius:12px;color:var(--muted);font-size:14px;font-weight:700;cursor:pointer;transition:.15s;user-select:none}
.nav .grp:hover{background:var(--card);color:var(--white)}
.nav .grp .ico{width:19px;height:19px;stroke-width:1.8;flex:0 0 auto}
.nav .grp.active{color:#fff}
.nav .grp .chev{margin-left:auto;width:14px;height:14px;opacity:.6;transition:transform .18s}
.nav .group.open>.grp .chev{transform:rotate(180deg)}
.nav .group>.sub{display:none}
.nav .group.open>.sub{display:flex}
.side .foot{margin-top:auto;display:flex;flex-direction:column;gap:8px}
.legal-links{display:flex;flex-wrap:wrap;gap:4px 10px;padding:2px 6px}
.legal-links a{font-size:10px;color:var(--muted);text-decoration:none;font-weight:600}
.legal-links a:hover{color:var(--orange)}
.side .me{display:flex;align-items:center;gap:11px;padding:11px;border:1px solid var(--border);border-radius:14px;background:var(--card)}
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;color:#160a00;background:var(--orange);flex:0 0 auto;width:36px;height:36px;font-size:12px}
.side .me b{font-size:14px}.side .me small{color:var(--green);font-size:12px;display:flex;align-items:center;gap:5px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}

/* ---- main / header ---- */
.main{padding:22px 32px 70px;min-width:0}
.crumb{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted);font-weight:700;margin-bottom:14px}
.crumb b{color:var(--white)}.crumb svg{width:14px;height:14px;opacity:.5}
.head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.head h1{font-size:25px;font-weight:900;letter-spacing:-.02em}
.head h1 span{color:var(--muted);font-weight:700;font-size:13px;display:block;margin-top:3px}
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.toolbar .spacer{flex:1}

/* ---- controls ---- */
.ctrl{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:11px;padding:9px 13px;font-size:13px;font-weight:700;color:var(--light);cursor:pointer;transition:.15s;font-family:inherit}
.ctrl:hover{border-color:rgba(255,255,255,.18)}
.ctrl svg{width:15px;height:15px;opacity:.8}
select.ctrl{appearance:none;-webkit-appearance:none;padding-right:30px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2.4'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:13px}
.seg{display:inline-flex;background:var(--card);border:1px solid var(--border);border-radius:11px;padding:3px}
.seg button{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:800;color:var(--muted);padding:7px 13px;border-radius:8px;cursor:pointer;border:0;background:none;font-family:inherit;transition:.15s}
.seg button svg{width:15px;height:15px}
.seg button.on{background:rgba(255,123,0,.14);color:var(--orange)}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#160a00;border:0;box-shadow:0 0 20px rgba(255,123,0,.28);font-weight:900;font-size:13px;padding:11px 18px;border-radius:11px;cursor:pointer;transition:.2s;font-family:inherit}
.btn:hover{filter:brightness(1.08);box-shadow:0 0 26px rgba(255,123,0,.4)}
.btn svg{width:15px;height:15px}
.btn.ghost{background:rgba(255,123,0,.10);color:var(--orange);border:1.5px solid rgba(255,123,0,.6);box-shadow:none}
.btn.line{background:var(--card);color:var(--light);border:1px solid var(--border);box-shadow:none;font-weight:700}
.btn.line:hover{filter:none;border-color:rgba(255,255,255,.2)}
.btn.sm{padding:8px 14px;font-size:12px;box-shadow:none}

/* ---- cards / grid ---- */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px;position:relative;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.card h3{font-size:10px;font-weight:800;color:var(--orange);text-transform:uppercase;letter-spacing:.14em;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.tag{font-size:10px;font-weight:800;color:var(--orange);background:rgba(255,123,0,.12);padding:4px 9px;border-radius:99px;letter-spacing:.04em}
.c3{grid-column:span 3}.c4{grid-column:span 4}.c6{grid-column:span 6}.c8{grid-column:span 8}.c12{grid-column:span 12}
.kpi .v{font-size:30px;font-weight:900;letter-spacing:-.02em}
.kpi .s{font-size:12px;color:var(--muted);margin-top:4px}

/* ---- table ---- */
.panel{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;backdrop-filter:blur(4px)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;color:var(--muted);font-weight:800;padding:13px 16px;border-bottom:1px solid var(--border);font-size:11px;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
tbody td{padding:14px 16px;border-bottom:1px solid var(--border)}
tbody tr:last-child td{border-bottom:0}
tbody tr.trow{cursor:pointer;transition:.12s}tbody tr.trow:hover{background:rgba(255,255,255,.025)}

/* ---- bits ---- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:8px;font-size:12px;font-weight:800}
.chip.l{background:rgba(34,197,94,.14);color:var(--green)}.chip.s{background:rgba(239,68,68,.14);color:var(--red)}
.tags{display:flex;gap:6px;flex-wrap:wrap}
.tagx{font-size:11px;font-weight:700;color:var(--light);background:var(--card2);border:1px solid var(--border);padding:2px 8px;border-radius:7px}
.pos{color:var(--green);font-weight:900}.neg{color:var(--red);font-weight:900}.muted{color:var(--muted)}
.empty{text-align:center;color:var(--muted);padding:48px 20px;font-size:14px}

/* ---- modal ---- */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:50;display:none;align-items:center;justify-content:center;padding:20px}
.overlay.open{display:flex}
.modal{width:100%;max-width:560px;background:#0b0b0b;border:1px solid var(--border);border-radius:20px;padding:28px;position:relative}
.modal .x{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:50%;background:var(--card);border:1px solid var(--border);color:var(--light);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center}
.modal h2{font-size:20px;font-weight:900;text-align:center}
.modal .subt{text-align:center;color:var(--muted);font-size:13px;margin:4px 0 22px}

/* ---- Info-Button (global) ---- */
.info-btn{position:fixed;bottom:22px;right:22px;z-index:45;width:36px;height:36px;border-radius:50%;background:rgba(255,123,0,.14);color:var(--orange);border:1.5px solid rgba(255,123,0,.55);font-weight:900;font-size:16px;cursor:pointer;font-family:inherit;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.info-btn:hover{background:rgba(255,123,0,.24)}
.info-pop{position:fixed;bottom:66px;right:22px;z-index:45;width:300px;background:#0d0d0d;border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:none;box-shadow:0 12px 36px rgba(0,0,0,.55)}
.info-pop.open{display:block}
.info-pop b{display:block;font-size:10px;font-weight:800;color:var(--orange);text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px}
.info-pop p{font-size:13px;color:var(--light);line-height:1.6}

/* ---- Mülleimer-Button (global, einheitlich) ---- */
.icon-del{width:30px;height:30px;border-radius:8px;background:transparent;border:1px solid transparent;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;transition:.12s;padding:0}
.icon-del svg{width:15px;height:15px}
.icon-del:hover{color:var(--red);border-color:rgba(239,68,68,.5);background:rgba(239,68,68,.1)}

/* ---- Undo-Toast (global) ---- */
.ccm-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);z-index:60;background:#161616;border:1px solid var(--border);border-radius:12px;padding:11px 12px 11px 18px;display:flex;align-items:center;gap:16px;box-shadow:0 14px 36px rgba(0,0,0,.6);opacity:0;pointer-events:none;transition:.18s;font-size:13px;font-weight:600;color:var(--light)}
.ccm-toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.ccm-toast button{background:rgba(255,123,0,.14);color:var(--orange);border:1px solid rgba(255,123,0,.45);border-radius:8px;padding:7px 13px;font-weight:800;font-size:12px;cursor:pointer;font-family:inherit;white-space:nowrap}
.ccm-toast button:hover{background:rgba(255,123,0,.24)}

/* ---- responsive ---- */
@media(max-width:980px){
  .app{grid-template-columns:1fr}
  .side{display:none}
  .c3,.c4,.c6,.c8{grid-column:span 12}
}
