/* ═══════════════════════════════════════════════════════
   THEMES
═══════════════════════════════════════════════════════ */
:root {
  --bg:           #0A0E21;
  --bg-grad:      linear-gradient(160deg,#0A0E21 0%,#0d1230 100%);
  --glass-bg:     rgba(22,27,51,0.55);
  --glass-border: rgba(255,255,255,0.08);
  --glass-shadow: 0 8px 32px rgba(0,0,0,0.45);
  --glass-inner:  inset 0 1px 0 rgba(255,255,255,0.06);
  --surface:      #111827;
  --surface2:     #1a2233;
  --border:       #1f2937;
  --text:         #e5e7eb;
  --muted:        #6b7280;
  --accent:       #00D2FF;
  --accent-deep:  #0061FF;
  --accent-grad:  linear-gradient(135deg,#0061FF 0%,#00D2FF 100%);
  --accent-glow:  0 0 20px rgba(0,210,255,0.35);

  --tag-termin:  #daa520;
  --tag-work:    #fb923c;
  --tag-privat:  #87ceeb;
  --tag-mscel:   #22d3ee;
  --tag-mx:      #4ade80;
  --tag-wartung: #f87171;
  --tag-marc:    #facc15;
  --tag-mj:      #f472b6;
  --tag-aj:      #f87171;

  --topbar-h: 54px;
  --tabbar-h: 66px;
}

[data-theme="light"] {
  --bg:           #dde6f0;
  --bg-grad:      linear-gradient(160deg,#dde6f0 0%,#cdd8ea 100%);
  --glass-bg:     rgba(255,255,255,0.60);
  --glass-border: rgba(255,255,255,0.85);
  --glass-shadow: 0 8px 32px rgba(31,38,135,0.10);
  --glass-inner:  inset 0 1px 0 rgba(255,255,255,0.9);
  --surface:      rgba(255,255,255,0.75);
  --surface2:     rgba(240,244,248,0.8);
  --border:       rgba(200,215,230,0.7);
  --text:         #1e293b;
  --muted:        #64748b;
  --accent:       #0061FF;
  --accent-deep:  #004ecb;
  --accent-glow:  0 0 20px rgba(0,97,255,0.25);

  --tag-termin:  #b8860b;
  --tag-work:    #ea580c;
  --tag-privat:  #0284c7;
  --tag-mscel:   #0891b2;
  --tag-mx:      #16a34a;
  --tag-wartung: #dc2626;
  --tag-marc:    #ca8a04;
  --tag-mj:      #db2777;
  --tag-aj:      #dc2626;
}

/* ═══════════════════════════════════════════════════════
   RESET / BASE
═══════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg-grad);color:var(--text);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  font-size:14px;transition:background .3s,color .2s}

/* ═══════════════════════════════════════════════════════
   THEME TOGGLE
═══════════════════════════════════════════════════════ */
.theme-toggle{background:var(--glass-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--glass-border);border-radius:50%;width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:var(--muted);flex-shrink:0;transition:color .2s,box-shadow .2s}
.theme-toggle:hover{color:var(--accent)}
.theme-toggle svg{width:18px;height:18px}

/* ═══════════════════════════════════════════════════════
   LOGIN
═══════════════════════════════════════════════════════ */
.login-screen{display:flex;align-items:center;justify-content:center;
  min-height:100vh;position:relative;padding:24px}
.login-theme-btn{position:absolute;top:20px;right:20px}
.login-card{width:min(360px,100%);border-radius:28px;padding:36px 28px 32px;
  display:grid;gap:14px;
  background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);box-shadow:var(--glass-shadow),var(--glass-inner)}
.login-sphere{width:56px;height:56px;border-radius:16px;margin:0 auto 4px;
  background:rgba(0,210,255,.08);border:1px solid var(--glass-border);
  display:flex;align-items:center;justify-content:center;color:var(--accent)}
.login-title{font-size:28px;font-weight:800;text-align:center;letter-spacing:6px;
  color:var(--text)}
.login-sub{text-align:center;font-size:12px;color:var(--muted);
  letter-spacing:.3px;margin-top:-6px}
.login-sub{text-align:center;font-size:12px;color:var(--muted);letter-spacing:.5px;margin-top:-6px}
.login-card input{width:100%;background:var(--surface2);border:1px solid var(--glass-border);
  color:var(--text);border-radius:12px;padding:14px 16px;outline:none;font-size:16px;
  transition:border-color .2s,box-shadow .2s}
.login-card input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,210,255,.15)}
.login-card button[type="submit"],button[type="submit"]{width:100%;
  background:var(--accent-grad);color:#fff;border:none;border-radius:12px;
  padding:14px;font-size:15px;font-weight:600;cursor:pointer;
  transition:opacity .15s,transform .15s}
.login-card button[type="submit"]:hover,button[type="submit"]:hover{opacity:.88}
.login-card button[type="submit"]:active,button[type="submit"]:active{
  transform:scale(.98);opacity:.85}
.field-error{color:#f87171;font-size:13px;text-align:center}

/* ═══════════════════════════════════════════════════════
   APP LAYOUT
═══════════════════════════════════════════════════════ */
#app{display:flex;flex-direction:column;height:100vh;padding-bottom:var(--tabbar-h)}

.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;height:var(--topbar-h);
  background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--glass-border);flex-shrink:0;z-index:10}
.topbar-title{font-size:17px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--text)}

.tab-content{flex:1;overflow-y:auto;padding:14px 14px 8px}
.tab-content.hidden{display:none}

.tabbar{display:flex;background:var(--glass-bg);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);
  height:var(--tabbar-h);box-shadow:0 -4px 24px rgba(0,0,0,.2);
  position:fixed;bottom:0;left:0;right:0;z-index:400}
.tab{flex:1;background:none;border:none;color:var(--muted);font-size:10px;
  font-weight:600;cursor:pointer;letter-spacing:.5px;display:flex;
  flex-direction:column;align-items:center;justify-content:center;
  gap:4px;transition:color .2s;padding:8px 0 10px}
.tab svg{width:22px;height:22px}
.tab.active{color:var(--accent)}
.tab.active svg{filter:none}
.tab--capture svg{width:28px;height:28px}

/* ═══════════════════════════════════════════════════════
   DASHBOARD
═══════════════════════════════════════════════════════ */
.dash-header{padding:6px 2px 18px}
.dash-greeting{font-size:22px;font-weight:700;letter-spacing:.3px}
.dash-date{font-size:13px;color:var(--muted);margin-top:2px}

.tile-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.tile{background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);box-shadow:var(--glass-shadow),var(--glass-inner);
  border-radius:24px;padding:18px 16px 16px;cursor:pointer;
  display:flex;flex-direction:column;min-height:148px;
  transition:transform .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}
.tile:hover{transform:scale(1.035);
  box-shadow:var(--glass-shadow),var(--glass-inner),0 0 0 1px rgba(255,255,255,.12)}
.tile:active{transform:scale(.97)}
.tile--disabled{opacity:.45;cursor:default;pointer-events:none}
.mx-action-row{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.mx-action-btn{flex:1;min-width:120px}
.btn-secondary{background:var(--glass-bg);color:var(--text);border:1px solid var(--glass-border);
  border-radius:12px;padding:14px;font-size:14px;font-weight:600;cursor:pointer;
  backdrop-filter:blur(10px);transition:opacity .15s,transform .15s}
.btn-secondary:hover{opacity:.88}
.btn-secondary:active{transform:scale(.98)}

.tile-label{font-size:13px;font-weight:700;color:var(--text);
  margin-bottom:4px;line-height:1.3}
.tile-sub{font-size:11px;color:var(--muted);margin-top:auto}

/* ── Tile Icons ── */
.tile-icon{width:44px;height:44px;border-radius:12px;margin-bottom:12px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tile-icon svg{width:24px;height:24px}

.icon--agenda  {background:rgba(218,165,32,.12); color:var(--tag-termin)}
.icon--mx      {background:rgba(74,222,128,.12);  color:var(--tag-mx)}
.icon--wartung-aj{background:rgba(248,113,113,.12);color:var(--tag-aj)}
.icon--wartung-mj{background:rgba(244,114,182,.12);color:var(--tag-mj)}
.icon--stunden {background:rgba(0,210,255,.12);   color:var(--accent)}
.icon--buecher {background:rgba(139,92,246,.12);  color:#a78bfa}
.icon--material{background:rgba(59,130,246,.12);  color:#60a5fa}
.icon--life    {background:rgba(244,114,182,.12);  color:#f472b6}

/* ═══════════════════════════════════════════════════════
   AGENDA
═══════════════════════════════════════════════════════ */
.agenda-day{margin-bottom:20px}
.agenda-day-header{font-size:11px;font-weight:700;letter-spacing:1px;
  text-transform:uppercase;color:var(--muted);padding:4px 0 6px;
  border-bottom:1px solid var(--glass-border);margin-bottom:8px}
.agenda-day-header.today{color:var(--accent)}
.agenda-empty{color:var(--muted);font-size:12px;padding:4px 0}

.agenda-event{display:flex;gap:10px;align-items:baseline;padding:9px 12px;
  border-radius:14px;margin-bottom:6px;
  background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-left:3px solid var(--glass-border);
  border-top:1px solid var(--glass-border);
  border-right:1px solid var(--glass-border);
  border-bottom:1px solid var(--glass-border);
  box-shadow:0 2px 12px rgba(0,0,0,.2)}
.agenda-event.termin  {border-left-color:var(--tag-termin)}
.agenda-event.work    {border-left-color:var(--tag-work)}
.agenda-event.privat  {border-left-color:var(--tag-privat)}
.agenda-event.mscel   {border-left-color:var(--tag-mscel)}
.agenda-event.mx      {border-left-color:var(--tag-mx)}
.agenda-event.wartung {border-left-color:var(--tag-wartung)}
.agenda-time{font-size:12px;color:var(--muted);min-width:42px;font-variant-numeric:tabular-nums}
.agenda-title{flex:1;font-size:14px}
.agenda-event.termin  .agenda-title{color:var(--tag-termin);font-weight:600}
.agenda-event.work    .agenda-title{color:var(--tag-work)}
.agenda-event.privat  .agenda-title{color:var(--tag-privat)}
.agenda-event.mscel   .agenda-title{color:var(--tag-mscel)}
.agenda-event.mx      .agenda-title{color:var(--tag-mx)}
.agenda-tags{font-size:10px;color:var(--muted)}

.section-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:var(--muted);padding:14px 0 8px;border-bottom:1px solid var(--glass-border);
  margin-bottom:10px}

.todo-item{display:flex;gap:8px;align-items:baseline;padding:9px 12px;
  border-radius:14px;margin-bottom:6px;
  background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--glass-border);box-shadow:0 2px 12px rgba(0,0,0,.2)}
.todo-item.overdue{border-left:3px solid #f87171;background:rgba(127,29,29,.25)}
[data-theme="light"] .todo-item.overdue{background:rgba(254,226,226,.7)}
.todo-date{font-size:11px;color:var(--muted);min-width:56px;font-variant-numeric:tabular-nums}
.todo-item.overdue .todo-date{color:#f87171}
.todo-title{flex:1;font-size:13px}
.todo-tags{font-size:10px;color:var(--muted)}
.todo-check{background:none;border:none;padding:0 2px;font-size:16px;cursor:pointer;
  color:var(--muted);line-height:1;flex-shrink:0;align-self:center;transition:color .15s}
.todo-check:disabled{opacity:.5}
.todo-check:not(:disabled):hover{color:var(--accent)}
@keyframes todoDone{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(30px)}}
.todo-done-anim{animation:todoDone .35s ease forwards;pointer-events:none}
.todo-actions{display:flex;gap:4px;margin-left:auto;flex-shrink:0;align-self:center}
.todo-action-btn{background:none;border:none;padding:2px 5px;font-size:12px;cursor:pointer;color:var(--muted);line-height:1;border-radius:4px;transition:color .15s,background .15s}
.todo-action-btn:hover{color:var(--accent);background:var(--glass)}
.todo-del:hover{color:#f87171!important}

.section-divider{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:var(--accent);padding:18px 0 6px;margin-bottom:4px;opacity:.8}
.agenda-section-empty{color:var(--muted);font-size:12px;padding:6px 0 14px}

/* Today timeline */
.today-focus{margin-bottom:12px}
.agenda-slot{display:flex;align-items:center;gap:8px;padding:2px 0;opacity:.35}
.aslot-time{font-size:11px;font-variant-numeric:tabular-nums;font-family:monospace;
  color:var(--muted);min-width:40px;text-align:right}
.aslot-line{font-size:11px;color:var(--muted);letter-spacing:1px;overflow:hidden;white-space:nowrap}
.agenda-now{display:flex;align-items:center;gap:8px;padding:3px 0;margin:2px 0}
.agenda-now .aslot-time{color:var(--accent);opacity:1;font-weight:700}
.anow-text{font-size:11px;color:var(--accent);letter-spacing:2px;opacity:.8}
.agenda-untimed-sep{height:1px;background:var(--glass-border);margin:10px 0 8px}
.today-focus .agenda-event{margin-left:48px}

/* ═══════════════════════════════════════════════════════
   CAPTURE TAB
═══════════════════════════════════════════════════════ */
.cap-header{display:flex;align-items:center;gap:12px;padding:12px 0 8px;position:relative}
.cap-menu-btn{background:none;border:none;padding:6px 8px;cursor:pointer;color:var(--text);
  border-radius:8px;display:flex;align-items:center;transition:background .15s}
.cap-menu-btn:hover{background:var(--glass)}
.cap-menu-btn svg{width:22px;height:22px}
.cap-current-label{font-size:17px;font-weight:700;color:var(--text)}
.cap-menu-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:50;
  background:var(--surface);border:1px solid var(--glass-border);border-radius:14px;
  padding:6px;box-shadow:0 8px 32px rgba(0,0,0,.35);min-width:180px}
.cap-menu-dropdown.hidden{display:none}
.cap-menu-item{display:block;width:100%;background:none;border:none;text-align:left;
  padding:10px 14px;font-size:14px;font-weight:500;color:var(--text);cursor:pointer;
  border-radius:8px;transition:background .12s,color .12s}
.cap-menu-item:hover{background:var(--glass)}
.cap-menu-item.active{color:var(--accent);font-weight:700}
#tab-capture{position:relative}

.cap-panel.hidden{display:none}

.sub-types{display:flex;gap:8px;margin-bottom:14px}
.sub-type{flex:1;background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:10px;padding:9px 8px;font-size:12px;font-weight:700;
  color:var(--muted);cursor:pointer;text-align:center;
  transition:color .15s,border-color .15s}
.sub-type.active{color:var(--accent);border-color:var(--accent)}

.glass-card{background:var(--glass-bg);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);
  box-shadow:var(--glass-shadow),var(--glass-inner)}
.form-card{border-radius:20px;padding:16px;margin-bottom:16px;display:grid;gap:10px}

input,textarea{width:100%;background:rgba(255,255,255,.05);
  border:1px solid var(--glass-border);color:var(--text);border-radius:12px;
  padding:11px 14px;outline:none;font-family:inherit;font-size:14px;
  transition:border-color .2s,box-shadow .2s}
[data-theme="light"] input,[data-theme="light"] textarea{
  background:rgba(255,255,255,.7);border-color:rgba(200,215,230,.8)}
input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,210,255,.12)}
[data-theme="light"] input:focus,[data-theme="light"] textarea:focus{
  box-shadow:0 0 0 3px rgba(0,97,255,.1)}
textarea{min-height:80px;resize:vertical}

.input-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}


.file-label{background:rgba(255,255,255,.05);border:1px solid var(--glass-border);
  border-radius:12px;padding:11px 14px;cursor:pointer;color:var(--muted);display:block}
[data-theme="light"] .file-label{background:rgba(255,255,255,.7)}
.file-label input[type="file"]{display:none}

.status{font-size:13px;padding:4px 0}
.status.ok{color:#4ade80}
.status.error{color:#f87171}

/* ═══════════════════════════════════════════════════════
   LIFE TAB
═══════════════════════════════════════════════════════ */
.life-item{background:var(--glass-bg);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);
  box-shadow:0 4px 16px rgba(0,0,0,.2);border-radius:18px;padding:13px;margin-bottom:12px}
.life-meta{font-size:11px;color:var(--muted);margin-bottom:4px}
.life-title{font-weight:700;margin-bottom:4px}
.life-excerpt{font-size:13px;color:var(--muted)}
.life-item img{margin-top:10px;max-width:100%;border-radius:12px;
  border:1px solid var(--glass-border)}

/* ═══════════════════════════════════════════════════════
   BOTTOM SHEET
═══════════════════════════════════════════════════════ */
.sheet-overlay{position:fixed;top:0;right:0;bottom:var(--tabbar-h);left:0;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  z-index:100;display:flex;align-items:flex-end}
.sheet-overlay.hidden{display:none}

.sheet{width:100%;max-height:85vh;overflow-y:auto;
  background:var(--glass-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--glass-border);border-bottom:none;
  border-radius:24px 24px 0 0;padding:10px 16px 32px;
  animation:slideUp .28s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}

.sheet-handle{width:36px;height:4px;background:var(--muted);border-radius:2px;
  margin:0 auto 16px;opacity:.35}
.sheet-head{display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:16px;gap:12px}
.sheet-title{font-size:18px;font-weight:800;color:var(--text)}
.sheet-subtitle{font-size:12px;color:var(--muted);margin-top:2px}
.sheet-close-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px;
  flex-shrink:0}
.sheet-close-btn svg{width:22px;height:22px}

/* Machine Status */
.machine-status{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px}
.ms-item{background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:14px;padding:11px 13px}
.ms-label{font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.5px;color:var(--muted);margin-bottom:4px}
.ms-value{font-size:16px;font-weight:700;color:var(--text)}
.ms-value.warn{color:#fb923c}
.ms-value.ok  {color:#4ade80}
.ms-value.due {color:#f87171}
.ms-sub{font-size:10px;color:var(--muted);margin-top:2px}

/* Wartung Record List */
.wartung-rec{background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:14px;padding:12px 14px;margin-bottom:8px;cursor:pointer;
  transition:transform .15s,box-shadow .15s}
.wartung-rec:hover{transform:scale(1.02);box-shadow:var(--glass-shadow)}
.wartung-rec-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.wartung-bh{font-size:15px;font-weight:700;color:var(--text)}
.wartung-date{font-size:12px;color:var(--muted);flex:1}
.wartung-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:100px}
.wartung-badge.done{background:rgba(74,222,128,.15);color:#4ade80}
.wartung-badge.todo{background:rgba(251,146,60,.15);color:#fb923c}
.wartung-prog-bar{height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.wartung-prog-fill{height:100%;background:var(--accent-grad);border-radius:2px;
  transition:width .4s ease}

.btn-primary{width:100%;background:var(--accent-grad);color:#fff;border:none;
  border-radius:12px;padding:14px;font-size:15px;font-weight:600;cursor:pointer;
  transition:opacity .15s,transform .15s}
.btn-primary:hover{opacity:.88}
.btn-primary:active{transform:scale(.98);opacity:.85}

/* ═══════════════════════════════════════════════════════
   FULL SCREEN OVERLAY
═══════════════════════════════════════════════════════ */
.full-overlay{position:fixed;top:0;right:0;bottom:var(--tabbar-h);left:0;
  background:var(--bg-grad);z-index:200;display:flex;flex-direction:column}
.full-overlay.hidden{display:none}
/* Slide in from right when shown */
.full-overlay:not(.hidden){animation:slideRight .28s ease}
@keyframes slideRight{from{transform:translateX(100%)}to{transform:translateX(0)}}

.overlay-header{display:flex;align-items:center;padding:0 12px;height:var(--topbar-h);
  background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--glass-border);flex-shrink:0;gap:10px}
.overlay-back{background:none;border:none;color:var(--muted);cursor:pointer;
  padding:4px;display:flex;align-items:center}
.overlay-x{background:none;border:none;color:var(--muted);cursor:pointer;
  padding:4px;display:flex;align-items:center;flex-shrink:0}
.overlay-x svg{width:22px;height:22px}
.overlay-back svg{width:22px;height:22px}
.overlay-back:hover{color:var(--text)}
.overlay-title{flex:1;font-size:16px;font-weight:700;color:var(--text)}
.btn-small{background:var(--accent-grad);color:#fff;border:none;border-radius:100px;
  padding:8px 18px;font-size:13px;font-weight:700;cursor:pointer;
  box-shadow:0 2px 12px rgba(0,97,255,.35);transition:opacity .15s}
.btn-small:hover{opacity:.9}
.btn-cancel{background:none;color:var(--muted);box-shadow:none;font-weight:500}
.btn-cancel:hover{color:var(--text);opacity:1}

.overlay-body{flex:1;overflow-y:auto;padding:14px}

/* ── Checklist (Wartung Form) ── */
.form-field-label{font-size:11px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--muted)}

.checklist-section{margin-bottom:10px;border-radius:18px;overflow:hidden;
  background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--glass-border)}
.cl-sec-header{display:flex;align-items:center;padding:13px 14px;cursor:pointer;
  user-select:none;-webkit-tap-highlight-color:transparent}
.cl-sec-title{flex:1;font-size:13px;font-weight:700;color:var(--text)}
.cl-sec-progress{font-size:11px;color:var(--muted);margin-right:8px}
.cl-chevron{width:16px;height:16px;color:var(--muted);transition:transform .2s;flex-shrink:0}
.checklist-section.open .cl-chevron{transform:rotate(180deg)}

.cl-items{padding:0 14px 12px}
.cl-items.collapsed{display:none}

.cl-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;
  -webkit-tap-highlight-color:transparent}
.cl-item:last-child{border-bottom:none}
.cl-item input[type="checkbox"]{display:none}
.cl-mark{width:22px;height:22px;border-radius:7px;border:2px solid var(--glass-border);
  flex-shrink:0;margin-top:1px;transition:background .15s,border-color .15s;
  display:flex;align-items:center;justify-content:center}
.cl-item input:checked + .cl-mark{background:var(--accent);border-color:var(--accent)}
.cl-item input:checked + .cl-mark::after{content:"✓";color:#fff;font-size:13px;font-weight:700}
.cl-label{font-size:13px;line-height:1.45;flex:1}
.cl-item input:checked ~ .cl-label{color:var(--muted);text-decoration:line-through}

/* ── Wartung Detail (Read-only) ── */
.ro-section{margin-bottom:12px;background:var(--glass-bg);backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);
  border-radius:18px;overflow:hidden}
.ro-sec-header{padding:12px 14px;font-size:13px;font-weight:700;
  border-bottom:1px solid var(--glass-border)}
.ro-item{display:flex;align-items:flex-start;gap:10px;padding:8px 14px;
  border-bottom:1px solid rgba(255,255,255,.04)}
.ro-item:last-child{border-bottom:none}
.ro-check{width:18px;height:18px;border-radius:5px;border:2px solid var(--glass-border);
  flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center}
.ro-check.done{background:rgba(74,222,128,.25);border-color:#4ade80}
.ro-check.done::after{content:"✓";color:#4ade80;font-size:11px;font-weight:700}
.ro-text{font-size:13px;color:var(--muted);line-height:1.4}
.ro-text.done{color:var(--text)}

/* ═══════════════════════════════════════════════════════
   SKELETON LOADER
═══════════════════════════════════════════════════════ */
.skeleton{padding:4px 0}
.skel-row{height:14px;border-radius:7px;margin-bottom:12px;
  background:linear-gradient(90deg,var(--glass-bg) 25%,rgba(255,255,255,.06) 50%,var(--glass-bg) 75%);
  background-size:200% 100%;animation:shimmer 1.4s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ═══════════════════════════════════════════════════════
   EMPTY STATES
═══════════════════════════════════════════════════════ */
.empty-state{display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:48px 24px;gap:10px;text-align:center}
.empty-icon{font-size:40px;line-height:1}
.empty-text{font-size:15px;font-weight:600;color:var(--text)}
.empty-sub{font-size:13px;color:var(--muted);max-width:260px;line-height:1.5}

/* ═══════════════════════════════════════════════════════
   BÜCHER
═══════════════════════════════════════════════════════ */
.buch-item{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;
  padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:opacity .15s}
.buch-item:active{opacity:.7}
.buch-status{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px}
.buch-active{color:var(--accent)}
.buch-done{color:#4ade80}
.buch-cancel{color:var(--muted)}
.buch-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:2px}
.buch-author{font-size:12px;color:var(--muted)}
.buch-section{margin-bottom:14px}
.buch-sec-headrow{display:flex;align-items:center;gap:6px;cursor:pointer;
  padding-top:4px;border-top:1px solid var(--glass-border);user-select:none}
.buch-sec-headrow:active{opacity:.7}
.buch-chevron{color:var(--muted);flex-shrink:0;transition:transform .2s;display:flex}
.buch-chevron.open{transform:rotate(90deg)}
.buch-sec-title{font-size:14px;font-weight:700;color:var(--text);flex:1}
.buch-sec-body{font-size:13px;color:var(--muted);line-height:1.6;white-space:pre-wrap;
  overflow:hidden;max-height:2000px;transition:max-height .25s ease,padding .2s;padding-bottom:8px}
.buch-sec-body.collapsed{max-height:0;padding-bottom:0}
.buch-edit-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;
  flex-shrink:0;opacity:.6;transition:opacity .15s}
.buch-edit-btn:active{opacity:1}
.buch-status-btn{flex:1;padding:8px 0;border:none;border-radius:10px;font-size:13px;
  font-weight:600;cursor:pointer;transition:opacity .15s}
.buch-status-btn:disabled{opacity:.5}
.buch-status-done{background:#16a34a;color:#fff}
.buch-status-cancel{background:rgba(127,29,29,.5);color:#fca5a5}
[data-theme="light"] .buch-status-cancel{background:#fee2e2;color:#991b1b}
.buch-sec-body{font-size:13px;color:var(--muted);line-height:1.6;white-space:pre-wrap}

/* ═══════════════════════════════════════════════════════
   AGENDA SUCHE
═══════════════════════════════════════════════════════ */
.agenda-search-wrap{padding:10px 0 4px}
.agenda-search-wrap input{width:100%;box-sizing:border-box;padding:9px 14px;
  border-radius:12px;border:1px solid var(--glass-border);background:var(--glass-bg);
  color:var(--text);font-size:14px;outline:none}
.agenda-search-wrap input:focus{border-color:var(--accent)}

/* ═══════════════════════════════════════════════════════
   LAGER
═══════════════════════════════════════════════════════ */
.lager-warn-banner{background:rgba(220,38,38,.2);border:1px solid rgba(220,38,38,.4);
  border-radius:12px;padding:10px 14px;font-size:13px;font-weight:600;
  color:#fca5a5;margin-bottom:14px}
[data-theme="light"] .lager-warn-banner{background:#fee2e2;border-color:#fca5a5;color:#991b1b}
.lager-category{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  color:var(--accent);padding:14px 0 4px;opacity:.8}
.lager-item{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;
  padding:10px 14px;margin-bottom:6px}
.lager-item.lager-low{border-left:3px solid #f87171;background:rgba(127,29,29,.2)}
.lager-name{font-size:13px;font-weight:600;margin-bottom:3px}
.lager-meta{display:flex;gap:10px;align-items:center;font-size:11px;color:var(--muted)}
.lager-bestand{font-weight:700;color:var(--text)}
.lager-badge{background:#dc2626;color:#fff;padding:1px 6px;border-radius:6px;
  font-size:10px;font-weight:700;letter-spacing:.3px}
.lager-notiz{font-size:11px;color:var(--muted);margin-top:3px}

/* ═══════════════════════════════════════════════════════
   NOTIZEN & IDEEN
═══════════════════════════════════════════════════════ */
.ni-tabs{display:flex;gap:6px;padding:10px 16px 0;border-bottom:1px solid var(--glass-border);background:var(--surface)}
.ni-tab{background:none;border:none;padding:8px 14px;font-size:13px;font-weight:600;
  color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}
.ni-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.ni-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;
  padding:12px 14px;margin-bottom:8px}
.ni-card-head{display:flex;align-items:flex-start;gap:8px;margin-bottom:4px}
.ni-card-title{flex:1;font-size:14px;font-weight:600;line-height:1.3}
.ni-card-meta{font-size:11px;color:var(--muted);margin-bottom:4px}
.ni-card-text{font-size:13px;color:var(--text-secondary,var(--muted));white-space:pre-wrap;line-height:1.5;margin-top:4px}
.ni-card-actions{display:flex;gap:4px;flex-shrink:0;margin-left:auto}
.ni-edit-btn,.ni-del-btn{background:none;border:none;padding:2px 5px;font-size:13px;cursor:pointer;
  color:var(--muted);border-radius:4px;transition:color .15s,background .15s;line-height:1}
.ni-edit-btn:hover{color:var(--accent);background:var(--glass)}
.ni-del-btn:hover{color:#f87171;background:rgba(248,113,113,.1)}
.icon--notizen{background:linear-gradient(135deg,#6366f1,#8b5cf6)}

/* ═══════════════════════════════════════════════════════
   MISC
═══════════════════════════════════════════════════════ */
.error{color:#f87171;font-size:13px}
[hidden]{display:none !important}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}

/* ═══════════════════════════════════════════════════════
   KANBAN
═══════════════════════════════════════════════════════ */
.task-new-form {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
}
.task-new-form input,
.task-new-form textarea,
.task-new-form select {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--glass-border);
  color: var(--text);
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 14px;
  outline: none;
  transition: border-color .2s;
}
.task-new-form input:focus,
.task-new-form textarea:focus { border-color: var(--accent); }
.task-new-row {
  display: flex;
  gap: 8px;
}
.task-new-row select { flex: 1; }
.task-new-row button {
  background: var(--accent-grad);
  color: #fff;
  border: none;
  border-radius: 12px;
  padding: 12px 18px;
  font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
}

.kanban-tabs {
  display: flex;
  overflow-x: auto;
  gap: 6px;
  margin-bottom: 12px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 2px;
}
.kanban-tabs::-webkit-scrollbar { display: none; }
.ktab {
  flex-shrink: 0;
  background: var(--glass-bg);
  color: var(--muted);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: 7px 14px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  cursor: pointer;
  backdrop-filter: blur(8px);
  transition: color .2s, border-color .2s;
}
.ktab.active {
  color: var(--accent);
  border-color: var(--accent);
}

.task-card {
  margin-bottom: 10px;
  padding: 14px;
}
.task-header {
  margin-bottom: 6px;
}
.task-category {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 2px 7px;
  border-radius: 6px;
  opacity: 0.85;
}
.cat-privat  { background: #5b4fcf33; color: #a89cf7; }
.cat-work    { background: #1a73e833; color: #7ab4f5; }
.cat-mscel   { background: #e8711a33; color: #f5a96a; }
.cat-inbox   { background: #1ae86333; color: #6af5b0; }
.cat-tasks   { background: #88888833; color: var(--muted); }
.task-title {
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 4px;
}
.task-body {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 10px;
  white-space: pre-wrap;
}
.state-select {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--glass-border);
  color: var(--text);
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 13px;
  cursor: pointer;
}
.kanban-empty {
  color: var(--muted);
  font-size: 14px;
  text-align: center;
  padding: 32px 0;
}
