*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --ci:#c6d43f;--ci-d:#a4b332;--ci-bg:rgba(198,212,63,.1);--ci-bd:rgba(198,212,63,.3);
  --text:#212529;--text-sub:#6c757d;--text-3:#adb5bd;
  --bg:#fff;--bg-alt:#faf9f1;--border:#dee2e6;--border-light:#e9ecef;
  --dark:#000;--r:20px;--r-sm:12px;
  --font-head:'Space Grotesk','Inter',sans-serif;
  --font-body:'Inter',sans-serif;
  --font-sub:'Plus Jakarta Sans',sans-serif;
}

body{font-family:var(--font-body);color:var(--text);background:var(--bg-alt);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;letter-spacing:-.03em;line-height:1.15}
a{color:inherit;text-decoration:none}

/* ---- App-Shell ---- */
.app{display:flex;min-height:100vh}

.sidebar{width:240px;flex-shrink:0;background:var(--dark);position:sticky;top:0;height:100vh;overflow-y:auto;padding:24px 0 20px;display:flex;flex-direction:column}
.sb-logo{padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.sb-logo-mark{width:32px;height:32px;border-radius:9px;background:var(--ci);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;color:#000}
.sb-logo-text{font-family:var(--font-head);font-weight:700;color:#fff;font-size:14px;line-height:1.2}
.sb-logo-text .sub{display:block;font-size:9.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.35);font-family:var(--font-sub)}

.sb-nav{padding:0 12px;flex:1}
.sb-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;color:rgba(255,255,255,.6);font-size:14px;font-weight:500;transition:.15s;margin-bottom:2px}
.sb-link:hover{background:var(--ci-bg);color:var(--ci)}
.sb-link.here{background:rgba(198,212,63,.15);color:var(--ci)}
.sb-link .icon{width:17px;height:17px;flex-shrink:0}
.sb-link.disabled{color:rgba(255,255,255,.25);cursor:default;pointer-events:none}
.sb-soon{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:rgba(255,255,255,.25);border:1px solid rgba(255,255,255,.15);border-radius:40px;padding:2px 7px;font-family:var(--font-sub)}

.sb-user{margin-top:auto;padding:14px 20px 0;border-top:1px solid rgba(255,255,255,.08)}
.sb-user-name{font-size:13px;font-weight:600;color:#fff}
.sb-user-logout{font-size:11.5px;color:rgba(255,255,255,.35);display:flex;align-items:center;gap:5px;margin-top:6px;transition:.15s}
.sb-user-logout:hover{color:rgba(255,255,255,.7)}

.main{flex:1;min-width:0;padding:32px 40px 60px}
.main-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.main-header h1{font-size:1.6rem}
.main-sub{font-size:13px;color:var(--text-sub);font-family:var(--font-sub);margin-top:2px}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:100px;font-size:13.5px;font-weight:600;font-family:var(--font-sub);border:1.5px solid transparent;cursor:pointer;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--ci);color:#000}
.btn-primary:hover{background:var(--ci-d)}
.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--ci-bd);color:var(--ci-d);background:var(--ci-bg)}
.btn-sm{padding:6px 14px;font-size:12.5px}
.btn .icon{width:15px;height:15px}

/* ---- Cards / Listen ---- */
.card{background:#fff;border:1.5px solid var(--border-light);border-radius:var(--r);padding:22px}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}

.filterbar{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.filterbar input[type=text],.filterbar select{font-family:var(--font-body);font-size:13.5px;padding:8px 14px;border:1.5px solid var(--border);border-radius:100px;background:#fff;color:var(--text)}
.filterbar input[type=text]{min-width:220px}

table.list{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r);overflow:hidden;border:1.5px solid var(--border-light)}
table.list th{text-align:left;font-family:var(--font-sub);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-sub);padding:12px 16px;background:var(--bg-alt);border-bottom:1.5px solid var(--border-light)}
table.list td{padding:13px 16px;font-size:13.5px;border-bottom:1px solid var(--border-light)}
table.list tr:last-child td{border-bottom:none}
table.list tr:hover td{background:var(--ci-bg)}

.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;letter-spacing:.3px;padding:3px 11px;border-radius:100px;font-family:var(--font-sub)}
.badge-aktiv{background:var(--ci-bg);color:var(--ci-d)}
.badge-lead{background:#e7f1ff;color:#3a7bd5}
.badge-pausiert{background:#fff3cd;color:#8a6d1f}
.badge-beendet{background:#f1f3f5;color:var(--text-sub)}

/* ---- Formulare ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:1/-1}
label{display:block;font-size:12.5px;font-weight:600;color:var(--text-sub);margin-bottom:5px;font-family:var(--font-sub)}
input[type=text],input[type=email],input[type=tel],input[type=password],input[type=date],select,textarea{
  width:100%;font-family:var(--font-body);font-size:14px;padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:#fff;color:var(--text)
}
textarea{resize:vertical;min-height:80px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ci-bd);box-shadow:0 0 0 3px var(--ci-bg)}
.form-actions{display:flex;gap:10px;margin-top:22px}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--dark)}
.login-card{width:340px;background:#fff;border-radius:var(--r);padding:36px 32px}
.login-card h1{font-size:1.3rem;margin-bottom:4px}
.login-card .main-sub{margin-bottom:24px}
.login-card .form-actions{margin-top:20px}
.login-card .btn-primary{width:100%;justify-content:center}
.login-error{background:#f8d7da;color:#721c24;font-size:13px;padding:10px 14px;border-radius:var(--r-sm);margin-bottom:16px;font-family:var(--font-sub)}

/* ---- Kanban ---- */
.kanban{display:grid;grid-template-columns:repeat(4,minmax(230px,1fr));gap:14px;overflow-x:auto;align-items:start}
.kanban-col{background:var(--bg-alt);border-radius:var(--r);padding:12px;min-height:120px}
.kanban-col.dragover{outline:2px dashed var(--ci-d);outline-offset:-2px}
.kanban-col-head{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 10px}
.kanban-col-title{font-family:var(--font-sub);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-sub)}
.kanban-col-count{font-size:11px;color:var(--text-3);background:#fff;border-radius:100px;padding:1px 8px}
.kanban-card{background:#fff;border:1.5px solid var(--border-light);border-radius:var(--r-sm);padding:11px 13px;margin-bottom:8px;cursor:grab;font-size:13px}
.kanban-card:active{cursor:grabbing}
.kanban-card.dragging{opacity:.4}
.kanban-card-title{font-weight:600;margin-bottom:4px}
.kanban-card-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-sub);font-family:var(--font-sub)}
.prio-hoch{color:#c0392b}
.prio-normal{color:var(--text-sub)}
.prio-niedrig{color:var(--text-3)}

@media (max-width:820px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;padding:16px 0}
  .main{padding:22px 18px 40px}
  .form-grid{grid-template-columns:1fr}
  .kanban{grid-template-columns:1fr}
}
