@font-face{font-family:'Space Grotesk';src:url('fonts/space-grotesk-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('fonts/space-grotesk-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Archivo';src:url('fonts/archivo-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Archivo';src:url('fonts/archivo-600.woff2') format('woff2');font-weight:600;font-display:swap}

:root{
  --bg:#070a12; --bg2:#0a0f1c; --surface:#101728; --surface2:#161f33; --surface3:#1e2a44;
  --line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.13);
  --text:#e9eef9; --muted:#8b95ac; --faint:#5b6478;
  --accent:#3a7bff; --accent2:#6aa3ff; --ink:#cfe0ff; --glow:rgba(58,123,255,.38);
  --ok:#34d39a; --warn:#f5b23b; --danger:#f26d6d; --info:#5b93ff;
  --r:16px; --r2:12px; --r3:9px;
  --sh1:0 1px 2px rgba(0,0,0,.35); --sh2:0 16px 40px -18px rgba(0,0,0,.7);
  --tab:"tnum" 1; font-feature-settings:"tnum" 1;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg); color:var(--text);
  font-family:'Archivo',system-ui,-apple-system,sans-serif; font-size:14.5px; line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(820px 460px at 14% -8%,rgba(58,123,255,.18),transparent 60%),
    radial-gradient(680px 420px at 96% 4%,rgba(58,123,255,.07),transparent 55%);}
h1,h2,h3,h4,.disp{font-family:'Space Grotesk',sans-serif;letter-spacing:-.02em}
.num{font-variant-numeric:tabular-nums}
a{color:var(--accent2);text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:rgba(58,123,255,.32)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:8px;border:2px solid var(--bg)}

/* ---------- layout ---------- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh;position:relative;z-index:1}
.sidebar{
  background:linear-gradient(180deg,#0b1120,#080c16);border-right:1px solid var(--line);
  padding:20px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh;overflow:hidden}
.sidebar::before{content:'';position:absolute;top:-60px;left:-40px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,123,255,.22),transparent 65%);pointer-events:none}
.brand{display:flex;align-items:center;gap:12px;padding:8px 10px 22px;position:relative}
.brand .mark{width:36px;height:36px;flex:0 0 36px;filter:drop-shadow(0 4px 12px var(--glow))}
.brand b{font-family:'Space Grotesk';font-size:21px;font-weight:700;display:block;line-height:1}
.brand small{display:block;color:var(--muted);font-size:11px;letter-spacing:.4px;margin-top:3px}
.nav{display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r3);
  color:var(--muted);font-weight:600;font-size:13.5px;transition:.16s;position:relative}
.nav a svg{width:18px;height:18px;opacity:.8;flex:0 0 18px}
.nav a:hover{background:var(--surface);color:var(--text)}
.nav a:hover svg{opacity:1}
.nav a.active{background:linear-gradient(90deg,rgba(58,123,255,.22),rgba(58,123,255,.05));color:#fff}
.nav a.active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--accent);box-shadow:0 0 12px var(--glow)}
.nav a.active svg{opacity:1;color:var(--accent2)}
.sidebar .foot{margin-top:auto;color:var(--faint);font-size:11.5px;padding:10px;line-height:1.7;border-top:1px solid var(--line)}
.logout{color:var(--muted);text-decoration:none;border-bottom:1px solid transparent}
.logout:hover{color:var(--danger);border-color:var(--danger)}

.main{padding:30px 36px 80px;max-width:1240px;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.page-head h1{font-size:28px;font-weight:700}
.page-head p{color:var(--muted);margin-top:4px;font-size:13.5px}
.head-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:10px;
  border:1px solid var(--line2);background:var(--surface2);color:var(--text);font-weight:600;font-size:13.5px;
  transition:.16s;white-space:nowrap}
.btn:hover{background:var(--surface3);border-color:rgba(58,123,255,.5);transform:translateY(-1px)}
.btn:active{transform:none}
.btn svg{width:16px;height:16px}
.btn.primary{background:linear-gradient(180deg,var(--accent2),var(--accent));border-color:transparent;color:#fff;box-shadow:0 8px 24px -10px var(--glow)}
.btn.primary:hover{box-shadow:0 12px 30px -8px var(--glow);filter:brightness(1.07)}
.btn.ghost{background:transparent}
.btn.danger{color:var(--danger)}.btn.danger:hover{border-color:var(--danger);background:rgba(242,109,109,.08)}
.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:8px}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}

/* ---------- cards / kpis ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--sh1)}
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}
.kpi{position:relative;overflow:hidden;background:linear-gradient(165deg,var(--surface2),var(--surface));
  border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;transition:.18s}
.kpi:hover{transform:translateY(-2px);border-color:var(--line2)}
.kpi .label{color:var(--muted);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px}
.kpi .value{font-family:'Space Grotesk';font-size:31px;font-weight:700;margin-top:9px;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.kpi .sub{color:var(--faint);font-size:12px;margin-top:4px}
.kpi::after{content:'';position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(58,123,255,.12),transparent 70%)}
.kpi.accent{border-color:rgba(58,123,255,.32)} .kpi.accent .value{color:var(--accent2)}
.kpi.ok .value{color:var(--ok)} .kpi.warn .value{color:var(--warn)}
.section-title{font-size:15px;font-weight:700;margin-bottom:14px}

/* ---------- table ---------- */
.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;
  padding:13px 16px;border-bottom:1px solid var(--line);background:var(--bg2)}
td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr{transition:.12s}
tbody tr:last-child td{border-bottom:none}
.row-click{cursor:pointer}
tbody tr.row-click:hover{background:var(--surface2)}
.t-amount{font-variant-numeric:tabular-nums;font-weight:600}

/* ---------- badges ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}
.badge::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}
.s-neu{color:#9aa6c4;background:rgba(154,166,196,.13)}
.s-kontaktiert{color:var(--info);background:rgba(91,147,250,.15)}
.s-termin{color:var(--warn);background:rgba(245,178,59,.15)}
.s-kunde{color:var(--ok);background:rgba(52,211,154,.15)}
.s-kein_interesse{color:var(--danger);background:rgba(242,109,109,.13)}
.s-entwurf{color:#9aa6c4;background:rgba(154,166,196,.13)}
.s-versendet{color:var(--info);background:rgba(91,147,250,.15)}
.s-bezahlt{color:var(--ok);background:rgba(52,211,154,.15)}
.s-storniert{color:var(--danger);background:rgba(242,109,109,.13)}
.s-geplant{color:var(--info);background:rgba(91,147,250,.15)}
.s-erledigt{color:var(--ok);background:rgba(52,211,154,.15)}
.s-abgesagt{color:var(--danger);background:rgba(242,109,109,.13)}

/* ---------- toolbar / forms ---------- */
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.toolbar .spacer{flex:1}
input,select,textarea{background:var(--surface2);border:1px solid var(--line2);color:var(--text);
  padding:10px 13px;border-radius:10px;font-family:inherit;font-size:13.5px;width:100%;transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(58,123,255,.18)}
input::placeholder,textarea::placeholder{color:var(--faint)}
textarea{resize:vertical;min-height:74px;line-height:1.55}
.field{margin-bottom:15px}
.field label{display:block;color:var(--muted);font-size:12.5px;font-weight:600;margin-bottom:6px}
.field .hint{color:var(--faint);font-size:11.5px;margin-top:5px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.check{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--text);cursor:pointer}
.check input{width:auto}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:7px 14px;border-radius:999px;background:var(--surface2);border:1px solid var(--line2);color:var(--muted);font-size:13px;font-weight:600;transition:.14s}
.chip:hover{color:var(--text)}
.chip.active{background:rgba(58,123,255,.18);border-color:var(--accent);color:#fff}

/* ---------- modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(4,7,13,.74);backdrop-filter:blur(5px);z-index:50;
  display:flex;align-items:flex-start;justify-content:center;padding:42px 20px;overflow:auto}
.modal{background:var(--surface);border:1px solid var(--line2);border-radius:20px;width:100%;max-width:640px;
  box-shadow:0 40px 90px -24px rgba(0,0,0,.75);animation:pop .2s cubic-bezier(.2,.8,.2,1)}
.modal.wide{max-width:880px}
@keyframes pop{from{transform:translateY(14px) scale(.985);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line)}
.modal-head h3{font-size:18px}
.modal-body{padding:24px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;align-items:center;padding:16px 24px;border-top:1px solid var(--line);flex-wrap:wrap}
.x{background:none;border:none;color:var(--muted);font-size:24px;line-height:1;padding:4px 8px;border-radius:8px}
.x:hover{background:var(--surface2);color:#fff}

/* ---------- toast ---------- */
#toast{position:fixed;top:22px;right:22px;z-index:80;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--surface3);border:1px solid var(--line2);border-left:4px solid var(--accent);padding:13px 18px;
  border-radius:11px;min-width:240px;max-width:380px;box-shadow:var(--sh2);animation:slide .26s ease;font-size:13.5px}
.toast.ok{border-left-color:var(--ok)} .toast.err{border-left-color:var(--danger)} .toast.info{border-left-color:var(--info)}
@keyframes slide{from{transform:translateX(34px);opacity:0}to{transform:none;opacity:1}}

/* ---------- skript module ---------- */
.skript-wrap{display:grid;grid-template-columns:222px 1fr;gap:24px;align-items:start}
.skript-nav{position:sticky;top:24px;display:flex;flex-direction:column;gap:4px;max-height:calc(100vh - 48px);overflow:auto}
.skript-nav button{display:block;width:100%;text-align:left;padding:9px 13px;border-radius:9px;background:transparent;border:1px solid transparent;color:var(--muted);font-weight:600;font-size:13px}
.skript-nav button:hover{background:var(--surface)}
.skript-nav button.active{background:rgba(58,123,255,.16);border-color:rgba(58,123,255,.3);color:#fff}
.skript-nav .grp{color:var(--faint);font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;padding:14px 13px 5px}
.script-block{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;margin-bottom:16px;scroll-margin-top:20px}
.script-block .nr{display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;font-family:'Space Grotesk';font-weight:700;font-size:13px;width:25px;height:25px;border-radius:8px;margin-right:10px}
.script-block h3{display:flex;align-items:center;font-size:18px;margin-bottom:10px}
.script-block .regie{color:var(--warn);font-size:12.5px;font-style:italic;margin-bottom:12px}
.script-block .speech{font-size:16.5px;line-height:1.74;white-space:pre-wrap;border-left:3px solid var(--accent);padding:4px 0 4px 16px;color:#f2f6fd}
.script-block .speech .ph{color:var(--accent2);font-weight:600}
.script-block .speech .cue{color:var(--muted);font-style:italic;font-size:14px}
.script-block .warum{color:var(--muted);font-size:13px;margin-top:14px;padding-top:13px;border-top:1px solid var(--line)}
.einwand{background:var(--surface);border:1px solid var(--line);border-radius:var(--r2);padding:16px 18px;margin-bottom:11px;scroll-margin-top:20px}
.einwand .q{font-weight:600;color:var(--warn);font-size:14.5px;margin-bottom:7px}
.einwand .a{white-space:pre-wrap;line-height:1.65;color:#eef2fa}
.mindset li{margin:8px 0 8px 18px;line-height:1.6}

/* ---------- calendar ---------- */
.cal-top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.cal-title{font-family:'Space Grotesk';font-size:20px;font-weight:700;min-width:170px}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:38px;height:38px;display:grid;place-items:center;border-radius:10px;background:var(--surface2);border:1px solid var(--line2);color:var(--text);font-size:18px}
.cal-nav button:hover{border-color:var(--accent)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cal-dow{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;text-align:center;padding:2px 0 6px}
.cal-cell{min-height:104px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:8px;
  cursor:pointer;transition:.14s;display:flex;flex-direction:column;gap:4px;overflow:hidden}
.cal-cell:hover{border-color:var(--accent);background:var(--surface2)}
.cal-cell.other{opacity:.38}
.cal-cell.today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.cal-cell .d{font-size:12.5px;font-weight:700;color:var(--muted);font-variant-numeric:tabular-nums}
.cal-cell.today .d{color:var(--accent2)}
.cal-ev{background:rgba(58,123,255,.18);border:1px solid rgba(58,123,255,.32);color:#dce8ff;border-radius:6px;
  padding:2px 7px;font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-ev .tm{color:var(--accent2)}
.agenda-item{display:flex;gap:14px;align-items:center;padding:13px 16px;border-bottom:1px solid var(--line);cursor:pointer}
.agenda-item:hover{background:var(--surface2)}
.agenda-item:last-child{border-bottom:none}
.agenda-date{font-family:'Space Grotesk';text-align:center;min-width:52px}
.agenda-date .day{font-size:21px;font-weight:700;line-height:1}
.agenda-date .mon{font-size:11px;color:var(--muted);text-transform:uppercase}

/* ---------- finanzen ---------- */
.bars{display:flex;align-items:flex-end;gap:14px;height:190px;padding-top:12px}
.bars .bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%}
.bars .bar .col{width:100%;max-width:56px;background:linear-gradient(180deg,var(--accent2),rgba(58,123,255,.22));border-radius:8px 8px 0 0;margin-top:auto;min-height:3px;transition:.5s cubic-bezier(.2,.8,.2,1)}
.bars .bar .m{color:var(--muted);font-size:11.5px}.bars .bar .v{font-size:11px;color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}

/* ---------- misc ---------- */
.empty{text-align:center;color:var(--muted);padding:52px 20px}
.muted{color:var(--muted)} .right{text-align:right} .center{text-align:center}
.tag{font-size:11.5px;color:var(--faint);background:var(--surface2);padding:3px 9px;border-radius:7px}
.items-table input{padding:8px 9px}
.items-table td{padding:5px 6px;border:none}
.items-table th{background:transparent;padding:4px 6px}
.sum-line{display:flex;justify-content:flex-end;gap:24px;font-family:'Space Grotesk';font-size:20px;font-weight:700;padding:14px 6px 4px;color:var(--accent2);font-variant-numeric:tabular-nums}
.linkrow{display:flex;gap:8px}.linkrow input{flex:1}

/* ---------- auth ---------- */
.auth-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{position:relative;z-index:1;background:var(--surface);border:1px solid var(--line2);border-radius:20px;padding:36px 32px;width:100%;max-width:390px;text-align:center;box-shadow:var(--sh2)}
.auth-card img{margin-bottom:12px;filter:drop-shadow(0 6px 16px var(--glow))}
.auth-card h1{font-family:'Space Grotesk';font-size:25px;font-weight:700}
.auth-sub{color:var(--muted);font-size:13.5px;margin:5px 0 22px}
.auth-card .field{text-align:left}
.auth-err{background:rgba(242,109,109,.13);border:1px solid rgba(242,109,109,.32);color:#f7a8a8;border-radius:10px;padding:10px 13px;font-size:13px;margin-bottom:15px}
.auth-ok{background:rgba(52,211,154,.13);border:1px solid rgba(52,211,154,.32);color:#7eecc4;border-radius:10px;padding:10px 13px;font-size:13px;margin-bottom:15px}

/* ---------- mobile ---------- */
.mobile-bar{display:none;align-items:center;gap:12px;margin:-30px -36px 18px;padding:14px 18px;
  background:rgba(10,15,28,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.mobile-bar b{font-family:'Space Grotesk';font-size:16px}
.mobile-bar button{background:var(--surface2);border:1px solid var(--line2);color:#fff;border-radius:10px;padding:8px 12px;font-size:16px}
.scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:39}

@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;z-index:40;transform:translateX(-100%);transition:transform .25s ease;width:262px}
  .sidebar.open{transform:none;box-shadow:var(--sh2)}
  .scrim.show{display:block}
  .main{padding:0 18px 90px}
  .mobile-bar{display:flex}
  .skript-wrap{grid-template-columns:1fr}
  .skript-nav{position:static;flex-direction:row;flex-wrap:wrap;max-height:none}
  .skript-nav .grp{width:100%;padding:8px 4px 2px}
}
@media(max-width:680px){
  .page-head h1{font-size:23px}
  .row2{grid-template-columns:1fr}
  .modal-bg{padding:0;align-items:flex-end}
  .modal{max-width:100%;border-radius:20px 20px 0 0;animation:up .26s ease}
  @keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
  .modal-foot{justify-content:stretch}.modal-foot .btn{flex:1;justify-content:center}
  .modal-foot .spacer,.modal-foot [style*="flex:1"]{display:none}
  /* Tabellen -> Karten */
  .table-wrap thead{display:none}
  .table-wrap table,.table-wrap tbody,.table-wrap tr,.table-wrap td{display:block;width:100%}
  .table-wrap tr{padding:13px 16px;border-bottom:1px solid var(--line)}
  .table-wrap td{border:none;padding:4px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;text-align:right}
  .table-wrap td::before{content:attr(data-label);color:var(--muted);font-size:12px;font-weight:600;text-align:left}
  .table-wrap td:first-child{font-size:16px;padding-bottom:7px}
  .table-wrap td:first-child::before{display:none}
  .table-wrap td:last-child{display:none}
  .cal-cell{min-height:62px;padding:5px;border-radius:9px}
  .cal-cell .d{font-size:11px}
  .cal-ev{padding:1px 4px;font-size:9.5px}
  .cal-grid{gap:5px}
  .kpis{grid-template-columns:1fr 1fr}
  .kpi .value{font-size:26px}
  .grid[style*="1.4fr"],.grid[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
