/* === CSS extrahiert aus fahrerplanung.html (extrahiert 2026-04-26) === */
  @import url('/shared/fonts/inter.css');
  *{margin:0;padding:0;box-sizing:border-box}
  :root{--bg:linear-gradient(145deg,#eef2f7 0%,#e4ecf4 25%,#dfe8f0 50%,#e8eef5 75%,#f0f4f8 100%);--nav-bg:rgba(255,255,255,0.55);--nav-border:rgba(255,255,255,0.5);--card-bg:rgba(255,255,255,0.45);--card-border:rgba(255,255,255,0.6);--card-hover-bg:rgba(255,255,255,0.65);--card-shadow:0 2px 16px rgba(0,0,0,0.04);--card-hover-shadow:0 12px 44px rgba(0,0,0,0.08);--text-primary:#1c1c1e;--text-secondary:#636366;--text-tertiary:#8e8e93;--badge-bg:rgba(4,179,214,0.1);--badge-color:#04b3d6;--toggle-bg:rgba(0,0,0,0.06);--toggle-knob:#fff}
  [data-theme="dark"]{--bg:linear-gradient(145deg,#0a0a1a 0%,#0f1528 20%,#151022 40%,#1a0f1e 60%,#12111a 80%,#0d1318 100%);--nav-bg:rgba(255,255,255,0.05);--nav-border:rgba(255,255,255,0.09);--card-bg:rgba(255,255,255,0.06);--card-border:rgba(255,255,255,0.1);--card-hover-bg:rgba(255,255,255,0.1);--card-shadow:0 2px 16px rgba(0,0,0,0.2);--card-hover-shadow:0 12px 44px rgba(0,0,0,0.3);--text-primary:#f5f5f7;--text-secondary:#a1a1a6;--text-tertiary:#636366;--badge-bg:rgba(4,179,214,0.15);--badge-color:#2cc5e4;--toggle-bg:rgba(255,255,255,0.1);--toggle-knob:#1c1c1e}
  body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;background:var(--bg);background-size:400% 400%;animation:gs 20s ease infinite;-webkit-font-smoothing:antialiased}
  @keyframes gs{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

  nav{position:sticky;top:0;z-index:200;background:var(--nav-bg);backdrop-filter:blur(44px) saturate(180%);-webkit-backdrop-filter:blur(44px) saturate(180%);border-bottom:1px solid var(--nav-border);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}
  .nav-left{display:flex;align-items:center;gap:10px}
  .nav-logo{height:28px}[data-theme="dark"] .nav-logo{filter:brightness(2.2) contrast(0.85)}
  .nav-brand{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px}
  .nav-divider{width:1px;height:18px;background:var(--nav-border);margin:0 2px}
  .nav-subtitle{font-size:12px;color:var(--text-secondary);font-weight:500}
  .nav-right{display:flex;align-items:center;gap:12px}
  .nav-back{font-size:13px;font-weight:500;color:var(--badge-color);text-decoration:none;padding:5px 10px;border-radius:8px}
  .nav-back:hover{background:var(--badge-bg)}
  .user-info{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}
  .user-dot{width:7px;height:7px;border-radius:50%;background:#30d158}
  .logout-btn{display:flex;align-items:center;gap:5px;padding:6px 10px;border-radius:8px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s}
  .logout-btn:hover{background:var(--card-hover-bg);color:var(--text-primary)}
  .theme-toggle{display:flex;align-items:center;gap:6px;cursor:pointer}
  .toggle-icon{font-size:14px;line-height:1}
  .toggle-track{width:44px;height:26px;border-radius:13px;background:var(--toggle-bg);backdrop-filter:blur(20px);border:1px solid var(--card-border);position:relative}
  .toggle-knob{width:20px;height:20px;border-radius:10px;background:var(--toggle-knob);position:absolute;top:2px;left:3px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px rgba(0,0,0,.15)}
  [data-theme="dark"] .toggle-knob{left:21px;background:#f5f5f7}

  .container{max-width:1200px;margin:0 auto;padding:28px 24px 80px}
  .page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
  .page-header h1{font-size:22px;font-weight:700;color:var(--text-primary)}
  .page-header-actions{display:flex;gap:8px;flex-wrap:wrap}
  .btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:12px;border:none;background:linear-gradient(135deg,#04b3d6,#0090b0);color:#fff;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}
  .btn-primary:hover{opacity:.88;transform:translateY(-1px)}
  .btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s}
  .btn-secondary:hover{background:var(--card-hover-bg);color:var(--text-primary)}

  /* Matrix */
  .matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:16px;border:1px solid var(--card-border);background:var(--card-bg);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%)}
  .matrix{width:100%;border-collapse:collapse;min-width:700px}
  .matrix th{padding:12px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);border-bottom:1px solid var(--card-border);text-align:left;white-space:nowrap;position:sticky;top:0;background:var(--card-bg)}
  .matrix td{padding:8px 10px;border-bottom:1px solid var(--card-border);vertical-align:top;min-width:120px}
  .matrix tr:last-child td{border-bottom:none}
  .matrix .fahrer-cell{font-weight:600;color:var(--text-primary);font-size:13.5px;min-width:140px;white-space:nowrap}
  .fahrer-sub{font-size:11px;font-weight:400;color:var(--text-tertiary);margin-top:2px}
  .fahrer-sum{font-size:11px;font-weight:500;color:var(--text-tertiary);margin-top:4px}
  .fahrer-sum.warn{color:#ff9f0a}
  .fahrer-sum.danger{color:#ff453a}

  .cell-btn{width:100%;padding:8px 10px;border-radius:10px;border:1px dashed var(--card-border);background:transparent;color:var(--text-tertiary);font-size:12px;cursor:pointer;transition:all .15s;font-family:inherit;text-align:left;min-height:52px}
  .cell-btn:hover{background:var(--card-hover-bg);border-style:solid;color:var(--text-secondary)}
  .cell-btn.filled{border-style:solid;border-color:var(--card-border);color:var(--text-primary);background:var(--toggle-bg)}
  .cell-tour{font-weight:600;font-size:12.5px;display:flex;align-items:center;gap:5px}
  .cell-tour-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
  .cell-meta{font-size:11px;color:var(--text-secondary);margin-top:3px}
  .cell-dauer{font-size:10.5px;margin-top:2px}
  .cell-dauer.ok{color:#30d158}
  .cell-dauer.warn{color:#ff9f0a}
  .cell-dauer.danger{color:#ff453a}
  .cell-frei{color:var(--text-tertiary);font-size:11px;text-align:center;padding:16px 0}
  .matrix-kw{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:10px;letter-spacing:-.2px}
  .kw-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
  .kw-label{font-size:16px;font-weight:700;color:var(--text-primary);min-width:60px;text-align:center}
  .kw-range{font-size:12px;color:var(--text-tertiary);font-weight:400}
  .kw-badge{font-size:10px;padding:2px 6px;border-radius:5px;background:var(--badge-bg);color:var(--badge-color);font-weight:600;margin-left:4px}
  .kw-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit;transition:all .15s}
  .kw-btn:hover{background:var(--card-hover-bg);color:var(--text-primary)}

  /* Fahrzeitsummary */
  .fahrzeit-wrap{margin-top:16px;border-radius:16px;border:1px solid var(--card-border);background:var(--card-bg);backdrop-filter:blur(40px);overflow-x:auto}
  .fahrzeit-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;padding:14px 16px 0}
  .fahrzeit-table{width:100%;border-collapse:collapse;min-width:500px}
  .fahrzeit-table th{padding:8px 10px;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--card-border);text-align:center}
  .fahrzeit-table th:first-child{text-align:left}
  .fahrzeit-table td{padding:6px 10px;font-size:12.5px;color:var(--text-secondary);text-align:center;border-bottom:1px solid var(--card-border)}
  .fahrzeit-table td:first-child{text-align:left;font-weight:600;color:var(--text-primary)}
  .fahrzeit-table tr:last-child td{border-bottom:none}
  .fz-ok{color:#30d158}
  .fz-warn{color:#ff9f0a;font-weight:600}
  .fz-danger{color:#ff453a;font-weight:600}
  .fz-status{font-size:11px;padding:2px 8px;border-radius:6px;font-weight:600}
  .fz-status.ok{background:rgba(48,209,88,.1);color:#30d158}
  .fz-status.warn{background:rgba(255,159,10,.1);color:#ff9f0a}
  .fz-status.danger{background:rgba(255,69,58,.1);color:#ff453a}

  /* Änderungsmarker */
  .cell-change{position:absolute;top:3px;right:3px;font-size:10px;padding:2px 7px;border-radius:5px;font-weight:700;line-height:1.4;z-index:2;letter-spacing:.3px}
  .cell-change.new{background:#30d158;color:#fff}
  .cell-change.changed{background:#ff9f0a;color:#fff}
  .cell-change.removed{background:#ff453a;color:#fff}
  .cell-prev{font-size:10px;color:#ff9f0a;margin-top:3px;font-style:italic}
  .cell-btn{position:relative}

  /* Empty State */
  .empty-state{text-align:center;padding:60px 20px}
  .empty-icon{font-size:48px;margin-bottom:14px}
  .empty-title{font-size:17px;font-weight:600;color:var(--text-primary);margin-bottom:6px}
  .empty-sub{font-size:13.5px;color:var(--text-tertiary);line-height:1.5;max-width:400px;margin:0 auto 20px}

  /* Modal */
  .modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:500;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .2s}
  .modal-overlay.show{display:flex}
  .modal-overlay.visible{opacity:1}
  .modal{background:var(--nav-bg);backdrop-filter:blur(60px) saturate(180%);-webkit-backdrop-filter:blur(60px) saturate(180%);border:1px solid var(--nav-border);border-radius:20px;width:100%;max-width:440px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;transform:scale(.96) translateY(8px);transition:transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 24px 80px rgba(0,0,0,.2)}
  .modal-overlay.visible .modal{transform:scale(1) translateY(0)}
  .modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 16px;border-bottom:1px solid var(--nav-border)}
  .modal-title{font-size:16px;font-weight:600;color:var(--text-primary)}
  .modal-close{width:28px;height:28px;border-radius:7px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit}
  .modal-close:hover{background:var(--card-hover-bg);color:var(--text-primary)}
  .modal-body{padding:20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:14px}
  .form-group{display:flex;flex-direction:column;gap:6px}
  .form-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}
  .form-input,.form-select{padding:9px 12px;border-radius:10px;border:1px solid var(--card-border);background:var(--toggle-bg);color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;width:100%}
  .form-input:focus,.form-select:focus{border-color:var(--badge-color)}
  .modal-footer{padding:14px 20px;border-top:1px solid var(--nav-border);display:flex;gap:10px;justify-content:flex-end}
  .btn-cancel{padding:9px 16px;border-radius:10px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);font-size:13.5px;font-weight:500;font-family:inherit;cursor:pointer}
  .btn-save{padding:9px 16px;border-radius:10px;border:none;background:linear-gradient(135deg,#04b3d6,#0090b0);color:#fff;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer}
  .btn-delete{padding:9px 16px;border-radius:10px;border:1px solid rgba(255,69,58,.3);background:rgba(255,69,58,.08);color:#ff453a;font-size:13.5px;font-weight:500;font-family:inherit;cursor:pointer;margin-right:auto}

  /* Toast */
  #toast-container{position:fixed;bottom:20px;right:20px;z-index:9000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
  .toast{padding:12px 16px;border-radius:12px;font-size:13.5px;font-weight:500;color:#fff;backdrop-filter:blur(20px);box-shadow:0 4px 20px rgba(0,0,0,.2);transform:translateX(100px);opacity:0;transition:all .3s;max-width:300px;pointer-events:all}
  .toast.show{transform:translateX(0);opacity:1}
  .toast.success{background:rgba(48,209,88,.9)}
  .toast.error{background:rgba(255,69,58,.9)}

  /* Print */
  @page{size:A4 landscape;margin:15mm 14mm}
  @media print{
    nav,.page-header-actions,.kw-nav button,.cell-btn:not(.filled),.rudi-chat-fab,.cell-change{display:none!important}
    body{background:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
    .container{padding:0;max-width:100%}
    .matrix-wrap{border:1px solid #ccc;border-radius:0;backdrop-filter:none;box-shadow:none}
    .matrix{min-width:0}
    .matrix th{font-size:10px;padding:6px 8px;background:#f5f5f5!important;border:1px solid #ccc;position:static}
    .matrix td{padding:5px 7px;border:1px solid #ccc;min-width:0}
    .cell-btn.filled{background:#f0f0f0!important;border:none;padding:4px 6px;min-height:auto}
    .cell-tour{font-size:11px}
    .cell-meta,.cell-prev{font-size:9px}
    .fahrer-cell{font-size:11px;min-width:auto}
    .fahrer-sub{font-size:9px}
    .matrix-kw{font-size:12px;margin-top:16px!important}
    .kw-badge{display:none}
    .fahrzeit-wrap{border:1px solid #ccc;border-radius:0;backdrop-filter:none;box-shadow:none;page-break-inside:avoid}
    .fahrzeit-title{font-size:11px}
    .fahrzeit-table th,.fahrzeit-table td{font-size:10px;padding:4px 6px;border:1px solid #ccc}
    h1{font-size:16px!important}
    .kw-nav{display:flex!important}
    .kw-label{font-size:14px}
    .kw-range{font-size:10px}
  }

  /* Responsive */
  @media(max-width:600px){
    nav{padding:0 12px}.nav-subtitle,.nav-divider{display:none}.user-info{display:none}.logout-text{display:none}.logout-btn{padding:6px}
    .container{padding:20px 14px 60px}.page-header h1{font-size:18px}.page-header-actions{width:100%}.btn-primary,.btn-secondary{flex:1;justify-content:center}
    .modal{max-width:100%}
  }


/* === Auto-generierte Klassen aus inline style="..." (fahrerplanung.html, 4 unique) === */
.s-d8da43 { display:flex;align-items:center;gap:16px;flex-wrap:wrap; }
.s-d42764 { font-size:12px;padding:6px 10px; }
.s-7f45a6 { max-width:640px; }
.s-163849 { max-height:70vh;overflow-y:auto; }


/* === Auto-Klassen aus inline style="..." in fahrerplanung.js (25 unique) === */
.s-496e09 { display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px;padding:0 4px; }
.s-9a1793 { display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-secondary); }
.s-47133f { width:10px;height:10px;border-radius:3px;background:' + farbe.color + ';flex-shrink:0; }
.s-e1378e { display:flex;align-items:center;gap:8px;margin-top:' + (isCurrent ? '0' : '24px') + '; }
.s-02f7ca { font-weight:400;color:var(--text-tertiary); }
.s-090c37 { opacity:0.7; }
.s-9bbcf7 { background:' + esc(t.farbe) + ';display:inline-block;vertical-align:middle;margin-right:4px; }
.s-422abc { margin-left:6px;padding:2px 6px;border:1px solid var(--card-border);background:var(--card-bg);border-radius:6px;cursor:pointer;font-size:11px;color:var(--text-secondary);font-family:inherit; }
.s-9129b7 { color:#ff453a;font-weight:600; }
.s-ac930a { color:var(--badge-color);font-weight:600; }
.s-d5df99 { background:' + farbe.bg + ';border-color:' + farbe.border + '; }
.s-91bbe6 { color:' + farbe.color + '; }
.s-e55f66 { font-style:italic; }
.s-b30e2c { margin-bottom:8px; }
.s-3e51bd { padding:40px;text-align:center;color:var(--text-secondary); }
.s-b09be2 { padding:20px;color:#ff453a; }
.s-77b4dc { padding:16px 20px;background:var(--card-bg);border-bottom:1px solid var(--card-border);font-size:13px; }
.s-632c2a { color:#30d158; }
.s-c61c4c { padding:8px 0; }
.s-5164e0 { padding:10px 20px;border-bottom:1px solid var(--card-border);background:' + hlColor + '; }
.s-0bf9f2 { display:flex;justify-content:space-between;align-items:flex-start;gap:10px; }
.s-bc7fd6 { text-align:right;font-size:12px;color:var(--text-secondary); }
.s-f36b91 { margin-top:6px;font-size:12px;color:var(--text-secondary); }
.s-8191d0 { margin-top:6px;font-size:12px;color:var(--text-tertiary); }
.s-a62ee4 { margin-top:6px;font-size:12px;color:#ff453a; }

/* CSP-Helper */
.row-feiertag { background: rgba(255,69,58,0.04); }
