:root{
  --blue:#1D4ED8;
  --blue-soft:#EFF6FF;
  --blue-accent:#3B82F6;
  --blue-light:#DBEAFE;
  --blue-border:#93C5FD;
  --green:#059669;
  --green-soft:#ECFDF5;
  --orange:#EA580C;
  --orange-soft:#FEF3C7;
  --orange-dark:#92400E;
  --red:#DC2626;
  --red-soft:#FEF2F2;
  --red-dark:#7F1D1D;
  --dark:#0F172A;
  --muted:#64748B;
  --border:#E2E8F0;
  --bg:#F1F5F9;
  --surface-soft:#F8FAFC;
  --nav-muted:#94A3B8;
  --info-dark:#1E3A8A;
  --upload-bg:#FAFBFD;
  --card:#FFFFFF;
  --shadow:0 8px 30px rgba(15,23,42,.07);
  --shadow-soft:0 2px 12px rgba(15,23,42,.05);
  --pdf-head:#1A3A5C;
  --pdf-blue:#1A74D4;
  --pdf-text:#1F1F2E;
  --pdf-muted:#737373;
  --pdf-info:#EDF5FF;
  --radius:16px;
  --radius-sm:12px;
  --sidebar:280px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--dark);font-family:'Nunito',system-ui,sans-serif;font-weight:700}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.hidden{display:none!important}
.brand-row{display:flex;align-items:center;gap:10px;font-family:'Sora',sans-serif;font-weight:900;font-size:24px}
.brand-row.compact{font-size:20px}
.brand-mark{width:34px;height:34px;border-radius:10px;background:var(--blue);color:#fff;display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:900;box-shadow:0 8px 20px rgba(29,78,216,.22)}
.eyebrow{margin:0 0 8px;color:var(--blue);font-size:12px;text-transform:uppercase;letter-spacing:.5px;font-weight:900}
.lead{font-size:18px;line-height:1.7;color:var(--muted);max-width:720px}
.login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.1fr) 430px;gap:48px;align-items:center;padding:48px;max-width:1240px;margin:0 auto}
.login-hero h1{font-family:'Sora',sans-serif;font-size:54px;line-height:1.05;margin:24px 0 18px;letter-spacing:0}
.trust-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.trust-grid span,.banner-badges span,.service-pill{background:#fff;border:2px solid var(--border);border-radius:999px;padding:9px 14px;color:var(--dark);font-size:13px;font-weight:900;box-shadow:0 2px 10px rgba(15,23,42,.04)}
.login-card{background:#fff;border:1px solid var(--border);border-radius:24px;padding:34px;box-shadow:var(--shadow)}
.auth-brand{font-family:'Sora',sans-serif;font-size:32px;font-weight:900;text-align:center}
.auth-subtitle{text-align:center;color:var(--muted);font-size:16px;margin:6px 0 28px;font-weight:900}
.field{display:block;margin-bottom:16px}
.field span{display:block;font-size:12px;font-weight:900;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.field input,.field select,.field textarea{width:100%;border:2px solid var(--border);border-radius:12px;padding:14px 16px;background:#fff;color:var(--dark);outline:none}
.field textarea{min-height:96px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.1)}
.btn{border:0;border-radius:12px;padding:12px 18px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;transition:.2s}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(29,78,216,.22)}
.btn-secondary{background:#F1F5F9;color:var(--dark);border:2px solid var(--border)}
.btn-danger{background:var(--red);color:#fff}
.form-message{min-height:20px;color:var(--red);font-size:13px;text-align:center}
.test-login-box{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface-soft);border:2px solid var(--border);border-radius:12px;padding:12px 14px;margin:4px 0 16px}
.test-login-box b{display:block;font-size:12px;font-weight:900;color:var(--dark);margin-bottom:2px}
.test-login-box span{display:block;font-size:12px;color:var(--muted);font-weight:800}
.demo-login-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}
.app-shell{min-height:100vh}
.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar);background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:20;box-shadow:4px 0 24px rgba(15,23,42,.05)}
.sidebar-header{padding:24px 20px;border-bottom:1px solid var(--border)}
.sidebar .brand-row{color:var(--dark)}
.sidebar-user{font-size:13px;color:var(--muted);margin-top:6px}
.nav-list{padding:14px 0;overflow:auto;flex:1}
.nav-section{padding:14px 20px 6px;font-size:10.5px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px}
.nav-section:first-child{padding-top:6px}
.nav-item{width:100%;border:0;background:#fff;text-align:left;padding:11px 20px;display:flex;align-items:center;gap:12px;color:var(--nav-muted);font-weight:900;font-size:13.5px;transition:.2s;position:relative}
.nav-item:hover{background:var(--blue-soft);color:var(--blue)}
.nav-item.active{background:var(--blue-soft);color:var(--blue);border-right:3px solid var(--blue)}
.nav-item.active::before{content:"";width:7px;height:7px;border-radius:999px;background:var(--blue);box-shadow:0 0 0 4px rgba(29,78,216,.12)}
.sidebar-footer{padding:20px;border-top:1px solid var(--border)}
.sidebar .service-pill{background:#fff;border-color:var(--border);color:var(--info-dark);box-shadow:0 2px 10px rgba(15,23,42,.04)}
.main{margin-left:var(--sidebar);min-height:100vh}
.topbar{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);z-index:10;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:18px;box-shadow:0 1px 0 rgba(15,23,42,.02)}
.topbar h2{margin:0;font-family:'Sora',sans-serif;font-size:26px}
.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.topbar-btn{width:42px;height:42px;border:2px solid var(--border);background:var(--surface-soft);border-radius:10px;font-weight:900;color:var(--muted)}
.topbar-btn:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.user-chip{border:2px solid var(--border);border-radius:999px;padding:9px 14px;background:#fff;font-size:13px;font-weight:900}
.content{padding:20px 32px 32px}
.ops-banner{background:#fff;border:1px solid var(--border);border-radius:20px;padding:24px;box-shadow:var(--shadow-soft);display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px}
.ops-banner h1{font-family:'Sora',sans-serif;font-size:26px;margin:0}
.banner-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin:0 0 18px}
.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.search{min-width:260px;border:2px solid var(--border);border-radius:12px;padding:12px 14px;outline:none;background:#fff}
.search:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.1)}
.tile-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.tile{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow-soft);transition:.2s;text-align:left}
.tile:hover{transform:translateY(-3px);border-color:var(--blue-border);box-shadow:var(--shadow)}
.tile-value{font-family:'Sora',sans-serif;font-size:32px;font-weight:900;color:var(--blue)}
.tile-label{font-size:13px;color:var(--muted);font-weight:900;margin-top:4px;line-height:1.35}

/* Bucket-Dashboard */
.bucket-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:16px;margin-top:8px}
.bucket{background:#fff;border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:12px;border-top:4px solid var(--blue)}
.bucket.bucket-inbox{border-top-color:var(--blue)}
.bucket.bucket-active{border-top-color:#7C3AED}
.bucket.bucket-waiting{border-top-color:var(--orange)}
.bucket.bucket-done{border-top-color:var(--green)}
.bucket.bucket-issues{border-top-color:var(--red)}
.bucket-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.bucket-title{font-family:'Sora',sans-serif;font-size:16px;font-weight:900;display:flex;align-items:center;gap:8px}
.bucket-title .bucket-icon{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--blue-soft);color:var(--blue);font-size:14px}
.bucket-inbox .bucket-icon{background:var(--blue-soft);color:var(--blue)}
.bucket-active .bucket-icon{background:#F3E8FF;color:#7C3AED}
.bucket-waiting .bucket-icon{background:var(--orange-soft);color:var(--orange-dark)}
.bucket-done .bucket-icon{background:var(--green-soft);color:var(--green)}
.bucket-issues .bucket-icon{background:var(--red-soft);color:var(--red-dark)}
.bucket-total{font-family:'Sora',sans-serif;font-size:30px;font-weight:900;color:var(--dark);line-height:1}
.bucket-rows{display:flex;flex-direction:column;gap:6px}
.bucket-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;border-radius:10px;background:var(--surface-soft);border:1px solid var(--border);cursor:pointer;transition:.15s;text-align:left;border:0;border-bottom:1px solid var(--border)}
.bucket-row:hover{background:var(--blue-soft);border-color:var(--blue-border)}
.bucket-row .bucket-row-label{font-size:13px;font-weight:900;color:var(--dark);line-height:1.3}
.bucket-row .bucket-row-value{font-family:'Sora',sans-serif;font-size:18px;font-weight:900;color:var(--blue);min-width:30px;text-align:right}
.bucket.bucket-issues .bucket-row-value{color:var(--red-dark)}
.bucket.bucket-waiting .bucket-row-value{color:var(--orange-dark)}
.bucket.bucket-done .bucket-row-value{color:var(--green)}
.bucket.bucket-active .bucket-row-value{color:#7C3AED}
.bucket-row.zero{opacity:.45}
.bucket-row.zero:hover{background:var(--surface-soft)}

/* Quick-Actions oben im Dashboard */
.quick-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.quick-action{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border:1px solid var(--border);border-radius:12px;font-weight:900;font-size:13px;color:var(--dark);text-decoration:none;cursor:pointer;transition:.2s}
.quick-action:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px)}
.quick-action .qa-icon{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:var(--blue-soft);color:var(--blue);font-size:16px}
.quick-action.danger .qa-icon{background:var(--red-soft);color:var(--red)}
.quick-action.warn .qa-icon{background:var(--orange-soft);color:var(--orange-dark)}
.quick-action .qa-count{margin-left:auto;background:var(--blue);color:#fff;border-radius:999px;padding:3px 9px;font-size:11px}
.quick-action.danger .qa-count{background:var(--red)}
.quick-action.warn .qa-count{background:var(--orange)}

/* Worklist (Heute-zu-erledigen) */
.worklist-group{margin-top:18px}
.worklist-group h3{font-family:'Sora',sans-serif;font-size:16px;margin:0 0 10px;display:flex;align-items:center;gap:8px}
.worklist-group h3 .wl-pill{background:var(--blue);color:#fff;border-radius:999px;padding:2px 9px;font-size:11px}
.worklist-group.urgent h3 .wl-pill{background:var(--red)}
.worklist-group.warn h3 .wl-pill{background:var(--orange)}
@media (max-width:1100px){
  .bucket-grid{grid-template-columns:1fr}
}

/* === Werkstatt: Dashboard === */
.ws-hero{background:linear-gradient(135deg,#1D4ED8 0%,#3B82F6 100%);color:#fff;border-radius:20px;padding:32px 36px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:center;margin-bottom:22px;box-shadow:0 14px 40px rgba(29,78,216,.25)}
.ws-hero .eyebrow{color:#DBEAFE}
.ws-hero h1{font-family:'Sora',sans-serif;font-size:36px;margin:6px 0 10px;line-height:1.1;letter-spacing:-.5px}
.ws-hero-sub{margin:0;font-size:15px;line-height:1.55;color:#DBEAFE;font-weight:800;max-width:680px}
.ws-hero-cta{background:#fff;color:var(--blue);min-width:220px;font-size:15px;padding:16px 24px}
.ws-hero-cta:hover{background:#F8FAFC;color:var(--blue);box-shadow:0 8px 22px rgba(0,0,0,.18)}
.ws-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:6px}
.ws-stat{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px 20px;text-align:left;cursor:pointer;transition:.18s;border-top:4px solid var(--blue)}
.ws-stat:not(.ws-stat-static):hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--blue-border)}
.ws-stat.ws-stat-static{cursor:default}
.ws-stat-blue{border-top-color:var(--blue)}
.ws-stat-purple{border-top-color:#7C3AED}
.ws-stat-orange{border-top-color:var(--orange)}
.ws-stat-green{border-top-color:var(--green)}
.ws-stat-num{font-family:'Sora',sans-serif;font-size:34px;font-weight:900;line-height:1;color:var(--dark)}
.ws-stat-label{font-size:13px;font-weight:900;color:var(--dark);margin-top:6px}
.ws-stat-sub{font-size:12px;color:var(--muted);margin-top:3px;font-weight:900}
.ws-section-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px}
.ws-section-row h3{margin:0}

.ga-hero{background:linear-gradient(135deg,#7C3AED 0%,#A855F7 100%);box-shadow:0 14px 40px rgba(124,58,237,.25)}
.ga-hero .ws-hero-cta{color:#7C3AED}
.ga-hero .ws-hero-cta:hover{color:#7C3AED}

.ga-terms .ws-reg-icon{background:#7C3AED;color:#fff}
.ga-terms-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:6px;font-size:13px}
.ga-terms-grid b{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900}
@media (max-width:900px){
  .ga-terms-grid{grid-template-columns:1fr}
}

/* === Werkstatt: Auftragsboerse-Filter === */
.ws-filter-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.ws-filter-tabs{display:flex;gap:6px;flex-wrap:wrap;background:#fff;border:1px solid var(--border);border-radius:14px;padding:5px}
.ws-filter-tab{border:0;background:transparent;border-radius:10px;padding:10px 14px;font-weight:900;font-size:13px;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.ws-filter-tab:hover{background:var(--surface-soft);color:var(--dark)}
.ws-filter-tab.active{background:var(--blue);color:#fff;box-shadow:0 4px 12px rgba(29,78,216,.22)}
.ws-filter-count{background:var(--surface-soft);color:var(--muted);border-radius:999px;padding:1px 8px;font-size:11px;font-weight:900}
.ws-filter-tab.active .ws-filter-count{background:rgba(255,255,255,.22);color:#fff}
.ws-filter-sort{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:900;color:var(--muted)}
.ws-filter-sort select{border:1px solid var(--border);border-radius:10px;padding:9px 12px;font-weight:900;background:#fff;outline:none;color:var(--dark);cursor:pointer}
.ws-filter-sort select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.1)}

@media (max-width:1100px){
  .ws-hero{grid-template-columns:1fr}
  .ws-hero-cta{width:100%}
  .ws-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* === Reports / Auswertungen === */
.reports-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.reports-toolbar-left h2{font-family:'Sora',sans-serif;font-size:24px;margin:0}
.reports-toolbar-left .doc-meta{margin-top:4px}
.reports-toolbar-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.reports-period{display:flex;gap:4px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:4px}
.reports-period-btn{border:0;background:transparent;padding:9px 14px;font-weight:900;font-size:13px;color:var(--muted);cursor:pointer;border-radius:8px;transition:.15s}
.reports-period-btn:hover{color:var(--dark);background:var(--surface-soft)}
.reports-period-btn.active{background:var(--blue);color:#fff;box-shadow:0 3px 10px rgba(29,78,216,.22)}
.reports-download{position:relative;display:flex;gap:8px}
.reports-dl-menu{position:relative}
.reports-dl-list{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;display:none;min-width:200px;z-index:30}
.reports-dl-list.open{display:flex;flex-direction:column}
.reports-dl-list a{padding:9px 12px;color:var(--dark);text-decoration:none;font-weight:900;font-size:13px;border-radius:8px}
.reports-dl-list a:hover{background:var(--blue-soft);color:var(--blue)}

.reports-tabs{margin-bottom:18px;overflow-x:auto;flex-wrap:nowrap}
.reports-content{display:flex;flex-direction:column;gap:18px}
.report-section{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px 22px;box-shadow:var(--shadow-soft)}
.report-section h3{font-family:'Sora',sans-serif;font-size:16px;margin:0 0 14px;color:var(--dark)}
.report-section .doc-meta{margin-top:-8px;margin-bottom:12px}
.report-twocol{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center}

.report-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.report-kpi{background:var(--surface-soft);border:1px solid var(--border);border-radius:12px;padding:14px;border-left:4px solid var(--blue)}
.report-kpi.tone-blue{border-left-color:var(--blue);background:linear-gradient(180deg,#EFF6FF, var(--surface-soft))}
.report-kpi.tone-green{border-left-color:var(--green);background:linear-gradient(180deg,var(--green-soft), var(--surface-soft))}
.report-kpi.tone-orange{border-left-color:var(--orange);background:linear-gradient(180deg,#FFFBEB, var(--surface-soft))}
.report-kpi.tone-red{border-left-color:var(--red);background:linear-gradient(180deg,var(--red-soft), var(--surface-soft))}
.report-kpi-label{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900;margin-bottom:6px}
.report-kpi-value{font-family:'Sora',sans-serif;font-size:22px;font-weight:900;color:var(--dark);line-height:1.1}
.report-kpi-sub{font-size:11.5px;color:var(--muted);font-weight:800;margin-top:4px}
.report-kpi-cmp{display:inline-flex;align-items:center;gap:5px;margin-top:8px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:900;letter-spacing:.3px}
.report-kpi-cmp.cmp-up{background:var(--green-soft);color:var(--green)}
.report-kpi-cmp.cmp-down{background:var(--red-soft);color:var(--red-dark)}
.report-kpi-cmp.cmp-flat{background:var(--surface-soft);color:var(--muted)}

/* Heatmap */
.chart-heatmap{display:flex;flex-direction:column;gap:2px;overflow-x:auto}
.hm-row{display:grid;grid-template-columns:36px repeat(24,1fr);gap:2px;align-items:center;min-width:680px}
.hm-row-label{font-size:11px;font-weight:900;color:var(--muted);text-align:right;padding-right:6px}
.hm-cell{aspect-ratio:1;border-radius:3px;min-height:22px;transition:.15s}
.hm-cell:hover{transform:scale(1.4);box-shadow:0 4px 10px rgba(0,0,0,.15);z-index:2;position:relative}
.hm-cell-header{font-size:10px;font-weight:900;color:var(--muted);text-align:center}
.hm-header{margin-bottom:3px}
.hm-legend{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:11px;color:var(--muted);font-weight:900;justify-content:flex-end}
.hm-scale{width:120px;height:10px;background:linear-gradient(90deg,#F1F5F9,rgba(29,78,216,.3),rgba(29,78,216,1));border-radius:3px}

/* Suggestions */
.suggestion-list{display:flex;flex-direction:column;gap:10px}
.suggestion-card{display:grid;grid-template-columns:48px 1fr auto;gap:14px;align-items:center;padding:14px 16px;background:#fff;border:1px solid var(--border);border-left:4px solid var(--blue);border-radius:12px;transition:.18s}
.suggestion-card.prio-high{border-left-color:var(--red);background:var(--red-soft)}
.suggestion-card.prio-medium{border-left-color:var(--orange);background:#FFFBEB}
.suggestion-card.prio-low{border-left-color:var(--blue);background:var(--blue-soft)}
.suggestion-icon{width:42px;height:42px;border-radius:50%;background:#fff;border:2px solid currentColor;display:grid;place-items:center;font-family:'Sora',sans-serif;font-size:18px;font-weight:900}
.suggestion-card.prio-high .suggestion-icon{color:var(--red)}
.suggestion-card.prio-medium .suggestion-icon{color:var(--orange)}
.suggestion-card.prio-low .suggestion-icon{color:var(--blue)}
.suggestion-title{font-family:'Sora',sans-serif;font-size:15px;font-weight:900;color:var(--dark)}
.suggestion-action{font-size:13px;color:var(--muted);margin-top:3px;font-weight:900}

/* Idle */
.idle-warn{color:var(--orange-dark)}
.idle-bad{color:var(--red-dark)}

/* Print-Styles für PDF-Export */
@media print {
  body{background:#fff !important}
  .sidebar, .topbar, .reports-toolbar-right, .nav-section, .nav-item{display:none !important}
  .main{margin-left:0 !important}
  .content{padding:12px !important}
  .reports-tabs{display:none !important}
  .reports-toolbar-left h2::after{content:" — VerifyRepair Auswertung";color:#64748B;font-size:14px;font-weight:600}
  .report-section{break-inside:avoid;border:1px solid #E2E8F0 !important;page-break-inside:avoid}
  .table-wrap{break-inside:avoid}
  .chart-line, .chart-heatmap{break-inside:avoid}
  a{color:#1D4ED8 !important;text-decoration:none}
  .btn,.mini-btn{display:none !important}
  .report-kpi{break-inside:avoid}
}


/* Bar-Chart */
.chart-bars{display:flex;flex-direction:column;gap:7px}
.chart-bar-row{display:grid;grid-template-columns:minmax(120px,30%) 1fr 90px;gap:10px;align-items:center;font-size:13px}
.chart-bar-label{font-weight:900;color:var(--dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chart-bar-track{background:var(--surface-soft);border:1px solid var(--border);border-radius:6px;height:18px;overflow:hidden;position:relative}
.chart-bar-fill{background:linear-gradient(90deg,var(--blue),var(--blue-accent));height:100%;border-radius:5px;transition:width .4s}
.chart-bar-value{text-align:right;font-weight:900;font-family:'Sora',sans-serif;color:var(--dark)}

/* Donut */
.chart-donut-wrap{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.chart-donut-legend{display:flex;flex-direction:column;gap:7px;min-width:240px}
.chart-donut-item{display:grid;grid-template-columns:14px 1fr auto;gap:10px;align-items:center;font-size:13px;font-weight:900}
.chart-donut-dot{width:12px;height:12px;border-radius:3px;display:inline-block}
.chart-donut-label{color:var(--dark)}
.chart-donut-value{color:var(--muted);font-size:12px}

/* Line-Chart */
.chart-line{display:block;background:var(--surface-soft);border:1px solid var(--border);border-radius:10px;padding:6px}

/* Stars-Chart */
.chart-stars{display:flex;flex-direction:column;gap:7px}
.chart-stars-row{display:grid;grid-template-columns:120px 1fr 60px;gap:10px;align-items:center;font-size:13px}
.chart-stars-label{font-family:'Sora',sans-serif;font-size:16px;color:#FBBF24;letter-spacing:1px}

/* Funnel */
.report-funnel{display:flex;flex-direction:column;gap:8px}
.funnel-step{display:flex;flex-direction:column;gap:5px}
.funnel-step-label{font-size:13px;font-weight:900}
.funnel-step-ratio{color:var(--green);font-weight:900;font-size:12px;margin-left:6px}
.funnel-step-bar{background:linear-gradient(90deg,var(--blue),var(--blue-accent));height:36px;border-radius:8px;display:flex;align-items:center;padding:0 14px;color:#fff;font-family:'Sora',sans-serif;font-weight:900;font-size:15px;transition:width .4s;min-width:80px}
.funnel-step-bar span{text-shadow:0 1px 2px rgba(0,0,0,.15)}

/* Boards-Karten in Reports */
.report-board-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.report-board-card{background:#fff;border:1px solid var(--border);border-top:4px solid var(--blue);border-radius:14px;padding:18px}
.report-board-card h4{font-family:'Sora',sans-serif;font-size:15px;margin:0 0 12px}
.report-board-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.report-board-stats > div{background:var(--surface-soft);border:1px solid var(--border);border-radius:8px;padding:8px 10px}
.report-board-stats span{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900}
.report-board-stats b{font-family:'Sora',sans-serif;font-size:15px;font-weight:900}

@media (max-width:900px){
  .report-twocol{grid-template-columns:1fr}
  .chart-bar-row{grid-template-columns:1fr;gap:4px}
  .chart-bar-label{font-size:12px}
  .chart-bar-value{text-align:left}
}

/* === Admin: Registrierungs-Stats + Trend === */
.reg-stats{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-bottom:14px}
.reg-stat{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow-soft);text-align:left;border-top:4px solid var(--border)}
.reg-stat-primary{border-top-color:var(--blue)}
.reg-stat-total{border-top-color:#7C3AED}
.reg-stat-success{border-top-color:var(--green)}
.reg-stat-warn{border-top-color:var(--orange)}
.reg-stat-num{font-family:'Sora',sans-serif;font-size:26px;font-weight:900;color:var(--dark);line-height:1}
.reg-stat-primary .reg-stat-num{color:var(--blue)}
.reg-stat-total .reg-stat-num{color:#7C3AED}
.reg-stat-success .reg-stat-num{color:var(--green)}
.reg-stat-warn .reg-stat-num{color:var(--orange-dark)}
.reg-stat-label{font-size:12px;color:var(--muted);font-weight:900;margin-top:5px}

.reg-trend{display:flex;gap:6px;align-items:flex-end;height:160px;padding:8px 4px}
.reg-trend-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:30px;position:relative}
.reg-trend-fill{width:100%;background:linear-gradient(180deg,var(--blue) 0%,var(--blue-accent) 100%);border-radius:6px 6px 0 0;min-height:4px;transition:.2s}
.reg-trend-bar:hover .reg-trend-fill{background:linear-gradient(180deg,var(--blue-accent) 0%,var(--blue) 100%);transform:scaleY(1.04);transform-origin:bottom}
.reg-trend-count{position:absolute;top:-18px;font-size:11px;font-weight:900;color:var(--dark)}
.reg-trend-day{font-size:10px;color:var(--muted);font-weight:900;margin-top:2px}

/* === Kategorie-Tabs === */
.cat-tabs{display:flex;gap:6px;flex-wrap:wrap;background:#fff;border:1px solid var(--border);border-radius:14px;padding:6px;box-shadow:var(--shadow-soft)}
.cat-tab{border:0;background:transparent;border-radius:10px;padding:11px 14px;font-weight:900;font-size:13px;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:.15s}
.cat-tab:hover{background:var(--surface-soft);color:var(--dark)}
.cat-tab.active{background:var(--blue);color:#fff;box-shadow:0 4px 12px rgba(29,78,216,.22)}
.cat-tab-count{background:var(--surface-soft);color:var(--muted);border-radius:999px;padding:2px 9px;font-size:11px;font-weight:900;min-width:24px;text-align:center}
.cat-tab.active .cat-tab-count{background:rgba(255,255,255,.22);color:#fff}

/* === Globale Suche === */
.search-bar{display:flex;gap:10px;margin-bottom:14px}
.search-bar-input{flex:1;font-size:15px;padding:14px 16px}
.search-result-meta{font-size:13px;color:var(--muted);font-weight:900;margin-bottom:14px}
.search-list{display:flex;flex-direction:column;gap:6px}
.search-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;background:#fff;border:1px solid var(--border);border-radius:10px;transition:.15s}
.search-row:hover{border-color:var(--blue);background:var(--blue-soft)}
.search-row-main{flex:1;min-width:0}
.search-row-title{font-family:'Sora',sans-serif;font-size:14px;font-weight:900}
.search-row-sub{font-size:12.5px;color:var(--muted);margin-top:3px;font-weight:900;overflow-wrap:anywhere}

@media (max-width:1100px){
  .reg-stats{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:600px){
  .reg-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .reg-trend{height:120px}
}

/* === Acceptance-Box im Fall-Detail === */
.acceptance-box{background:linear-gradient(135deg,#ECFDF5,#F0FDF4);border:1px solid #A7F3D0;border-radius:14px;padding:14px 18px;margin-top:18px}
.acceptance-box .card-title{margin-top:0;color:#065F46}
.acceptance-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid rgba(167,243,208,.5)}
.acceptance-row:last-child{border-bottom:0}
.acceptance-role{display:inline-block;background:var(--green);color:#fff;border-radius:999px;padding:3px 10px;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;font-weight:900;margin-bottom:5px}
.acceptance-name{font-family:'Sora',sans-serif;font-size:15px;font-weight:900;color:var(--dark)}
.acceptance-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}

/* === Admin: Vermittlungs-Pool === */
.mediation-list{display:flex;flex-direction:column;gap:14px}
.mediation-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px 20px;box-shadow:var(--shadow-soft);display:grid;grid-template-columns:minmax(0,1.2fr) 220px;gap:18px;align-items:start;border-left:4px solid var(--blue);transition:.18s}
.mediation-card.mediation-warn{border-left-color:var(--orange);background:#FFFBEB}
.mediation-card.mediation-expired{border-left-color:var(--red);background:var(--red-soft)}
.mediation-h{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.mediation-token{font-size:11px;font-weight:900;color:var(--muted);letter-spacing:.4px;text-transform:uppercase}
.mediation-h h3{font-family:'Sora',sans-serif;font-size:18px;margin:4px 0 0;line-height:1.2}
.mediation-role-pill{background:var(--blue-soft);color:var(--blue);border-radius:999px;padding:5px 12px;font-size:11px;font-weight:900;white-space:nowrap}
.mediation-role-werkstatt{background:var(--blue-soft);color:var(--blue)}
.mediation-role-gutachter{background:#F3E8FF;color:#7C3AED}
.mediation-role-kalkulator{background:#FEF3C7;color:#92400E}
.mediation-role-rechtsanwalt{background:#FCE7F3;color:#9D174D}
.mediation-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.mediation-meta > div{background:var(--surface-soft);border:1px solid var(--border);border-radius:10px;padding:9px 12px}
.mediation-meta span{display:block;font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900}
.mediation-meta b{font-family:'Sora',sans-serif;font-size:14px;font-weight:900}
.mediation-timer-block{grid-column:2;grid-row:1/span 3;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-soft);border:1px solid var(--border);border-radius:14px;padding:16px;text-align:center}
.mediation-card.mediation-warn .mediation-timer-block{background:var(--orange-soft);border-color:var(--orange)}
.mediation-card.mediation-expired .mediation-timer-block{background:#fff;border-color:var(--red)}
.mediation-timer-label{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:900;margin-bottom:6px}
.mediation-timer{font-family:'Sora',sans-serif;font-size:26px;font-weight:900;color:var(--blue);font-variant-numeric:tabular-nums;line-height:1}
.mediation-card.mediation-warn .mediation-timer{color:var(--orange-dark)}
.mediation-card.mediation-expired .mediation-timer{color:var(--red-dark)}
.mediation-timer-hint{font-size:11px;color:var(--muted);margin-top:6px;font-weight:900;line-height:1.3}
.mediation-actions{grid-column:1;display:flex;flex-direction:column;gap:10px;margin-top:6px}
.mediation-assign{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.mediation-assign .field{flex:1;min-width:200px}
.mediation-secondary{display:flex;gap:8px;flex-wrap:wrap}

.board-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;max-width:520px}
.board-direct{margin-top:14px;padding:10px 12px;background:#fff;border:1px dashed var(--border);border-radius:10px}
.board-direct summary{cursor:pointer;font-size:12.5px;color:var(--muted);font-weight:900}
.board-direct summary:hover{color:var(--dark)}

@media (max-width:900px){
  .mediation-card{grid-template-columns:1fr}
  .mediation-timer-block{grid-column:1;grid-row:auto}
  .mediation-meta{grid-template-columns:1fr}
  .board-row{grid-template-columns:1fr}
}

/* === Admin: Partnerverwaltung === */
.partner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px}
.partner-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:.18s}
.partner-card:hover{border-color:var(--blue-border);box-shadow:var(--shadow);transform:translateY(-2px)}
.partner-card-h{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.partner-type{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--blue);font-weight:900;margin-bottom:3px}
.partner-card-h h3{font-family:'Sora',sans-serif;font-size:17px;margin:0;line-height:1.25}
.partner-meta{font-size:13px;font-weight:900;color:var(--dark);display:flex;flex-direction:column;gap:3px}
.partner-terms{display:flex;gap:14px;flex-wrap:wrap;background:var(--surface-soft);border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:12px;font-weight:900}
.partner-terms span{color:var(--muted)}
.partner-terms b{color:var(--blue);font-family:'Sora',sans-serif;font-size:14px}
.partner-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;border-top:1px solid var(--border);padding-top:12px;margin-top:auto}

/* Partner-Formular */
.partner-form{display:flex;flex-direction:column;gap:14px}
.partner-form-section{background:var(--surface-soft);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.partner-form-section h4{font-family:'Sora',sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);margin:0 0 10px}

/* Börsen-Aktion in Fallakte */
.board-actions{background:var(--surface-soft);border:1px solid var(--border);border-radius:14px;padding:16px 18px;margin-top:18px}
.board-actions .card-title{margin-top:0}
.board-actions .field{max-width:280px;margin-bottom:14px}
.board-action-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:6px}
.board-btn{background:#fff;border:2px solid var(--border);border-radius:14px;padding:16px 12px;display:flex;flex-direction:column;align-items:flex-start;gap:6px;cursor:pointer;transition:.18s;text-align:left}
.board-btn:hover{border-color:var(--blue);background:var(--blue-soft);transform:translateY(-1px)}
.board-btn:disabled{opacity:.6;cursor:wait}
.board-btn.is-active{background:var(--green-soft);border-color:var(--green)}
.board-btn-icon{font-size:18px;color:var(--blue);font-weight:900}
.board-btn.is-active .board-btn-icon{color:var(--green)}
.board-btn-label{font-family:'Sora',sans-serif;font-size:14px;font-weight:900}
.board-btn-state{font-size:11.5px;color:var(--muted);font-weight:900}
.board-btn.is-active .board-btn-state{color:var(--green)}

@media (max-width:900px){
  .board-action-buttons{grid-template-columns:1fr}
}

/* === Serviceberatung: Start-Screen === */
.sb-home{display:grid;grid-template-columns:minmax(0,1.1fr) 320px;gap:24px;align-items:start;max-width:1080px}
.sb-home-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:36px 36px 32px;box-shadow:var(--shadow)}
.sb-home-card h2{font-family:'Sora',sans-serif;font-size:32px;margin:6px 0 14px;line-height:1.15}
.sb-home-text{color:var(--muted);font-size:15px;line-height:1.6;margin:0 0 26px;font-weight:800}
.sb-start-btn{padding:18px 28px;font-size:16px;border-radius:14px;box-shadow:0 12px 30px rgba(29,78,216,.25)}
.sb-start-btn:hover{box-shadow:0 16px 34px rgba(29,78,216,.32)}
.sb-steps-preview{background:#fff;border:1px solid var(--border);border-radius:20px;padding:20px 18px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:6px}
.sb-step-preview{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;font-weight:900;font-size:13px;color:var(--muted)}
.sb-step-num{width:28px;height:28px;border-radius:50%;background:var(--surface-soft);color:var(--blue);display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:900;font-size:13px;border:2px solid var(--blue-border);flex-shrink:0}
.sb-step-text{color:var(--dark)}

/* === Serviceberatung: Wizard (kompakt, no-scroll) === */
.sb-wizard{max-width:880px;display:flex;flex-direction:column;gap:10px}
.sb-tracker{display:flex;align-items:center;gap:4px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:10px 14px;box-shadow:var(--shadow-soft)}
.sb-tracker-step{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.sb-tracker-circle{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:900;font-size:12px;background:var(--surface-soft);color:var(--muted);border:2px solid var(--border);transition:.2s;flex-shrink:0}
.sb-tracker-label{font-size:11.5px;font-weight:900;color:var(--muted);white-space:nowrap}
.sb-tracker-step.active .sb-tracker-circle{background:var(--blue);color:#fff;border-color:var(--blue)}
.sb-tracker-step.active .sb-tracker-label{color:var(--blue)}
.sb-tracker-step.done .sb-tracker-circle{background:var(--green);color:#fff;border-color:var(--green)}
.sb-tracker-step.done .sb-tracker-label{color:var(--green)}
.sb-tracker-line{flex:1;height:2px;background:var(--border);min-width:8px}
.sb-wizard-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow-soft)}
.sb-wizard-head{margin-bottom:12px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.sb-wizard-step{display:inline-block;background:var(--blue-soft);color:var(--blue);border-radius:999px;padding:3px 10px;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;font-weight:900}
.sb-wizard-head h2{font-family:'Sora',sans-serif;font-size:18px;margin:0;line-height:1.2}
.sb-step-form{gap:10px}
.sb-step-form .field{margin-bottom:0}
.sb-step-form .field span{font-size:11.5px;margin-bottom:4px}
.sb-step-form .field input,.sb-step-form .field select,.sb-step-form .field textarea{padding:10px 12px;border-radius:10px}
.sb-step-form textarea{min-height:60px}
.sb-wizard-footer{background:#fff;border:1px solid var(--border);border-radius:14px;padding:10px 14px;box-shadow:var(--shadow-soft);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.sb-wizard-nav{display:flex;gap:8px}
.sb-wizard-footer .btn{padding:10px 18px;font-size:13px}

/* Upload + Summary (kompakt) */
.sb-upload{display:block;border:2px dashed var(--blue-border);border-radius:10px;padding:12px 14px;background:var(--blue-soft);cursor:pointer;transition:.18s;margin-top:4px}
.sb-upload:hover{border-color:var(--blue);background:#fff}
.sb-upload.selected{border-style:solid;border-color:var(--green);background:var(--green-soft)}
.sb-upload-inner{display:flex;align-items:center;gap:12px}
.sb-upload-icon{width:32px;height:32px;border-radius:8px;background:var(--blue);color:#fff;display:grid;place-items:center;font-family:'Sora',sans-serif;font-size:15px;font-weight:900;flex-shrink:0}
.sb-upload.selected .sb-upload-icon{background:var(--green)}
.sb-upload b{display:block;font-size:13px;font-weight:900}
.sb-upload span{display:block;font-size:11.5px;color:var(--muted);font-weight:900;margin-top:2px}
.sb-summary-card{background:var(--surface-soft);border:1px solid var(--border);border-radius:10px;padding:10px 14px;margin-top:4px}
.sb-summary-card h4{font-family:'Sora',sans-serif;font-size:11.5px;margin:0 0 6px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.sb-summary-card ul{margin:0;padding-left:16px;font-size:12.5px;line-height:1.55}

.sb-form-message{margin:0;font-weight:900;font-size:13px}
.sb-form-message.success{color:var(--green);background:var(--green-soft);border:1px solid #A7F3D0;border-radius:10px;padding:12px 14px}
.sb-form-message.error{color:var(--red);background:var(--red-soft);border:1px solid #FECACA;border-radius:10px;padding:12px 14px}

@media (max-width:1000px){
  .sb-home{grid-template-columns:1fr}
}
@media (max-width:700px){
  .sb-tracker{overflow-x:auto;flex-wrap:nowrap}
  .sb-tracker-label{display:none}
  .sb-wizard-footer{flex-direction:column;align-items:stretch}
  .sb-wizard-footer .btn{width:100%}
  .sb-wizard-nav{flex-direction:column-reverse}
}
@media (max-width:600px){
  .ws-stats{grid-template-columns:1fr}
  .ws-filter-bar{flex-direction:column;align-items:stretch}
}

/* === Werkstatt-Oberflaeche (reduziert) === */
.ws-page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:20px}
.ws-page-head h2{font-family:'Sora',sans-serif;font-size:24px;margin:0}
.ws-page-head .doc-meta{margin-top:4px}
.btn-block{width:100%;justify-content:center;padding:13px}

/* Auftragsboerse: luftige Karten */
.ws-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:20px}
.ws-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:26px 26px 22px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:22px;transition:.18s;min-height:340px}
.ws-card:hover{border-color:var(--blue-border);box-shadow:var(--shadow);transform:translateY(-2px)}
.ws-card-h{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.ws-card-h h3{font-family:'Sora',sans-serif;font-size:22px;margin:0;line-height:1.25;letter-spacing:-.2px}
.ws-pill{background:var(--blue-soft);color:var(--blue);border-radius:999px;padding:6px 14px;font-size:12px;font-weight:900;white-space:nowrap;flex-shrink:0}
.ws-pill-haftpflicht{background:#FEF3C7;color:#92400E}
.ws-pill-selbstzahler{background:#F3E8FF;color:#7C3AED}
.ws-pill-teilkasko{background:#E0F2FE;color:#075985}
.ws-card-list{margin:0;padding:0;display:flex;flex-direction:column;gap:0;flex:1}
.ws-card-list > div{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}
.ws-card-list > div:first-child{border-top:1px solid var(--border)}
.ws-card-list > div.hl{background:linear-gradient(90deg,#FFF7ED,#FFFBEB);margin:6px -26px 0;padding:16px 26px;border-top:1px solid #FCD34D;border-bottom:1px solid #FCD34D;border-radius:0}
.ws-card-list dt{font-size:13px;color:var(--muted);font-weight:900;margin:0;letter-spacing:.2px}
.ws-card-list dd{font-family:'Sora',sans-serif;font-size:18px;font-weight:900;margin:0;color:var(--dark)}
.ws-card-list > div.hl dd{color:var(--orange-dark);font-size:20px}
.ws-card .btn-block{padding:15px;font-size:15px;border-radius:12px}

/* Annahme-Dialog */
.ws-accept-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:14px 0}
.ws-accept-summary > div{background:var(--surface-soft);border:1px solid var(--border);border-radius:12px;padding:12px}
.ws-accept-summary > div.alert{background:#FFF7ED;border-color:var(--orange);color:var(--orange-dark)}
.ws-accept-summary span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.4px;font-weight:900;color:var(--muted);margin-bottom:4px}
.ws-accept-summary b{font-family:'Sora',sans-serif;font-size:18px;font-weight:900}
.ws-accept-info{background:var(--blue-soft);border:1px solid var(--blue-border);border-radius:12px;padding:14px;font-size:13px}
.ws-accept-info p{margin:0 0 8px}
.ws-accept-info ul{margin:0;padding-left:20px}
.ws-accept-info li{margin:4px 0;line-height:1.5}

/* Sektionen + Listenzeilen (Historie) */
.ws-section{margin-top:24px}
.ws-section:first-of-type{margin-top:8px}
.ws-section-title{font-family:'Sora',sans-serif;font-size:16px;margin:0 0 12px;display:flex;align-items:center;gap:10px}
.ws-section-count{background:var(--surface-soft);border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:2px 10px;font-size:12px}
.ws-list{display:flex;flex-direction:column;gap:8px}
.ws-row{display:grid;grid-template-columns:minmax(0,2fr) 130px 140px 24px;gap:14px;align-items:center;padding:14px 16px;border:1px solid var(--border);border-radius:12px;background:#fff;text-align:left;cursor:pointer;transition:.15s;width:100%}
.ws-row:hover{border-color:var(--blue);background:var(--blue-soft)}
.ws-row-title{font-family:'Sora',sans-serif;font-size:15px;font-weight:900}
.ws-row-sub{font-size:12.5px;color:var(--muted);margin-top:3px;font-weight:900}
.ws-row-amount{font-family:'Sora',sans-serif;font-size:15px;font-weight:900;text-align:right}
.ws-row-status{display:flex;justify-content:center}
.ws-row-arrow{font-size:22px;color:var(--muted);text-align:right;line-height:1}

/* Rechnungen-Bereich */
.ws-invoice-list{display:flex;flex-direction:column;gap:10px}
.ws-invoice-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px;border:1px solid var(--border);border-radius:14px;background:#fff;flex-wrap:wrap}
.ws-invoice-main{flex:1;min-width:200px}
.ws-invoice-upload{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:var(--blue);color:#fff;border-radius:12px;padding:14px 24px;font-weight:900;cursor:pointer;transition:.2s;min-width:230px;text-align:center}
.ws-invoice-upload:hover{background:var(--blue-accent);transform:translateY(-1px);box-shadow:0 10px 26px rgba(29,78,216,.25)}
.ws-invoice-upload-text{font-size:14px}
.ws-invoice-upload-hint{font-size:11px;font-weight:800;opacity:.85}
.ws-invoice-upload.uploading{background:var(--orange)}
.ws-invoice-upload.done{background:var(--green)}
.ws-invoice-done{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--border);border-radius:12px;background:var(--surface-soft)}

/* Pflicht-ToDos im Auftragsdetail */
.ws-todo{background:linear-gradient(135deg,#FFFBEB,#FEF3C7);border:2px solid #FCD34D;border-radius:16px;padding:18px 20px;margin:14px 0 18px}
.ws-todo-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}
.ws-todo-eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.5px;font-weight:900;color:#92400E}
.ws-todo-progress{background:#fff;border:1px solid #FCD34D;color:#92400E;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:900}
.ws-todo-list{display:flex;flex-direction:column;gap:10px}
.ws-todo-item{display:flex;align-items:center;gap:14px;padding:12px 14px;background:#fff;border:1px solid #FCD34D;border-radius:12px}
.ws-todo-item.done{background:var(--green-soft);border-color:#A7F3D0}
.ws-todo-check{width:36px;height:36px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;font-family:'Sora',sans-serif;font-size:16px;font-weight:900;flex-shrink:0}
.ws-todo-item.done .ws-todo-check{background:var(--green)}
.ws-todo-text{flex:1;display:flex;flex-direction:column;gap:2px}
.ws-todo-text b{font-size:14px;font-weight:900}
.ws-todo-text span{font-size:12.5px;color:var(--muted);font-weight:900}
.ws-todo-item.done .ws-todo-text span{color:var(--green)}
.ws-todo-btn{background:var(--blue);color:#fff;border:0;border-radius:10px;padding:10px 16px;font-weight:900;font-size:13px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.ws-todo-btn:hover{background:var(--blue-accent);transform:translateY(-1px)}

/* Regulierungs-Hinweis */
.ws-reg{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;border-radius:14px;margin-bottom:18px}
.ws-reg-ins{background:var(--blue-soft);border:1px solid var(--blue-border)}
.ws-reg-self{background:#F3E8FF;border:1px solid #D8B4FE}
.ws-reg-icon{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-weight:900;flex-shrink:0;font-size:14px}
.ws-reg-ins .ws-reg-icon{background:var(--blue);color:#fff}
.ws-reg-self .ws-reg-icon{background:#7C3AED;color:#fff}
.ws-reg b{display:block;font-size:14px;margin-bottom:3px}
.ws-reg-text{font-size:13px;line-height:1.5;color:var(--dark);font-weight:800}

/* Werkstattauftrag-Sektion */
.ws-order-card{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px;border:1px solid var(--border);border-radius:14px;background:var(--surface-soft);flex-wrap:wrap}
.ws-order-info{flex:1;min-width:240px}
.ws-order-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.ws-order-actions .mini-btn{cursor:pointer}
.ws-order-actions label.mini-btn{display:inline-flex}

/* Rechnungs-Sektion (Buchhaltung) */
.ws-invoice-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.ws-inv-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:10px}
.ws-inv-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.ws-inv-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900;line-height:1.3}
.ws-inv-amount{font-family:'Sora',sans-serif;font-size:20px;font-weight:900;color:var(--dark);white-space:nowrap}
.ws-inv-meta{font-size:12.5px;color:var(--muted);font-weight:900}

/* Auftragsdetail-Modal */
.ws-detail-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0 4px}
.ws-detail-summary > div{background:var(--surface-soft);border:1px solid var(--border);border-radius:12px;padding:12px}
.ws-detail-summary > div.alert{background:#FFF7ED;border-color:var(--orange);color:var(--orange-dark)}
.ws-detail-summary span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.4px;font-weight:900;color:var(--muted);margin-bottom:4px}
.ws-detail-summary b{font-family:'Sora',sans-serif;font-size:18px;font-weight:900}
.ws-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:14px}
.ws-detail-grid section{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px}

@media (max-width:1100px){
  .ws-detail-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .ws-detail-grid{grid-template-columns:1fr}
  .ws-invoice-summary{grid-template-columns:1fr}
}
@media (max-width:900px){
  .ws-row{grid-template-columns:1fr;gap:6px}
  .ws-row-amount,.ws-row-status,.ws-row-arrow{text-align:left;justify-content:flex-start}
  .ws-accept-summary{grid-template-columns:1fr}
  .ws-invoice-upload{width:100%}
}
.card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-soft);padding:18px;margin-top:18px}
.card-title{font-family:'Sora',sans-serif;font-size:18px;font-weight:900;margin:0 0 14px}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:14px;background:#fff}
table{border-collapse:collapse;width:100%;min-width:920px}
th,td{padding:13px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
th{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;background:var(--surface-soft);font-weight:900;white-space:nowrap}
td{font-size:13px}
tr:last-child td{border-bottom:0}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:900;background:#F1F5F9;color:var(--dark);white-space:nowrap}
.badge.blue{background:var(--blue-soft);color:var(--blue)}
.badge.green{background:var(--green-soft);color:var(--green)}
.badge.orange{background:var(--orange-soft);color:var(--orange-dark)}
.badge.red{background:var(--red-soft);color:var(--red-dark)}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}
.mini-btn{border:2px solid var(--border);background:#fff;color:var(--dark);border-radius:10px;padding:8px 11px;font-size:12px;font-weight:900}
.mini-btn:hover{border-color:var(--blue);color:var(--blue)}
.mini-btn.primary-action{background:var(--blue);border-color:var(--blue);color:#fff}
.mini-btn.primary-action:hover{background:var(--blue-accent);border-color:var(--blue-accent);color:#fff}
.mini-btn.danger-action{background:#fff;border-color:var(--red-soft);color:var(--red)}
.mini-btn.danger-action:hover{background:var(--red-soft);border-color:var(--red);color:var(--red-dark)}
.tabs{display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:16px}
.tab{border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--muted);padding:8px 12px;font-size:12px;font-weight:900}
.tab.active{background:var(--blue);border-color:var(--blue);color:#fff}
.detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.kv{background:var(--surface-soft);border:1px solid var(--border);border-radius:12px;padding:12px}
.kv-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900;margin-bottom:3px}
.kv-value{font-weight:900;overflow-wrap:anywhere}
.doc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.doc-card{border:1px solid var(--border);border-radius:12px;background:#fff;padding:14px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.doc-title{font-weight:900;overflow-wrap:anywhere}
.doc-meta{font-size:12px;color:var(--muted);margin-top:3px}
.auction-list{display:grid;gap:12px}
.auction-row{background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px;display:grid;grid-template-columns:minmax(0,1.2fr) repeat(3,minmax(120px,.6fr)) auto;gap:14px;align-items:center;box-shadow:var(--shadow-soft)}
.auction-value{font-family:'Sora',sans-serif;font-size:18px;font-weight:900;color:var(--dark)}
.auction-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900;margin-bottom:3px}
.service-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.service-form .field.full{grid-column:1/-1}
.modal{position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:50;display:flex;align-items:flex-start;justify-content:center;padding:32px}
.modal-panel{background:#fff;border-radius:20px;box-shadow:0 24px 90px rgba(15,23,42,.28);width:min(1180px,100%);max-height:92vh;overflow:auto;padding:24px;position:relative}
.modal-close{position:absolute;right:16px;top:12px;border:0;background:#fff;width:42px;height:42px;border-radius:12px;font-size:30px;color:var(--muted)}
.modal-close:hover{background:#F1F5F9;color:var(--dark)}
.case-head{padding-right:48px;margin-bottom:18px}
.case-head h2{font-family:'Sora',sans-serif;font-size:28px;margin:0 0 6px}
.case-sub{color:var(--muted);font-size:14px}
.split{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:18px}
.side-panel{background:var(--surface-soft);border:1px solid var(--border);border-radius:14px;padding:16px}
.empty-state{background:#fff;border:2px dashed var(--border);border-radius:16px;padding:34px;text-align:center;color:var(--muted)}
.empty-icon{font-size:34px;margin-bottom:8px}
.empty-text{font-weight:900}
.modal-panel-narrow{width:min(720px,100%)}
.stage-tracker{display:flex;align-items:stretch;gap:6px;flex-wrap:wrap;background:var(--surface-soft);border:1px solid var(--border);border-radius:14px;padding:14px;margin:14px 0}
.stage-step{flex:1;min-width:120px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px;position:relative;overflow:hidden}
.stage-step.passed{border-color:var(--green);background:var(--green-soft)}
.stage-step.current{border-color:var(--blue);background:var(--blue-soft);box-shadow:0 4px 14px rgba(29,78,216,.18)}
.stage-step.future{opacity:.55}
.stage-step .stage-num{font-family:'Sora',sans-serif;font-size:18px;font-weight:900;color:var(--blue)}
.stage-step.passed .stage-num{color:var(--green)}
.stage-step .stage-key{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:900;margin-top:3px}
.stage-step .stage-label{font-size:13px;font-weight:900;line-height:1.3;margin-top:4px}
.summary-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}
.summary-cell{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow-soft)}
.summary-cell .summary-label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;font-weight:900;color:var(--muted)}
.summary-cell .summary-value{font-family:'Sora',sans-serif;font-size:22px;font-weight:900;color:var(--dark);margin-top:4px}
.summary-cell.alert{border-color:var(--orange);background:#FFF7ED}
.summary-cell.alert .summary-value{color:var(--orange-dark)}
.summary-cell.danger{border-color:var(--red);background:var(--red-soft)}
.summary-cell.danger .summary-value{color:var(--red-dark)}
.summary-cell.success{border-color:var(--green);background:var(--green-soft)}
.summary-cell.success .summary-value{color:var(--green)}
.folder-browser{display:grid;grid-template-columns:240px minmax(0,1fr);gap:14px;margin-top:8px}
.folder-tree{background:var(--surface-soft);border:1px solid var(--border);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:4px}
.folder-tree-item{border:0;background:transparent;text-align:left;padding:9px 10px;border-radius:8px;font-weight:900;font-size:13px;color:var(--dark);cursor:pointer}
.folder-tree-item:hover{background:#fff}
.folder-tree-item.active{background:var(--blue);color:#fff}
.folder-list{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:auto}
.folder-row{display:grid;grid-template-columns:30px minmax(0,1fr) 110px 160px auto;gap:10px;padding:11px 14px;border-bottom:1px solid var(--border);align-items:center;font-size:13px}
.folder-row:last-child{border-bottom:0}
.folder-row .folder-icon{font-size:18px}
.folder-row .folder-name{font-weight:900;overflow-wrap:anywhere}
.folder-row .folder-meta{font-size:12px;color:var(--muted)}
.folder-actions{display:flex;gap:8px}
.upload-zone{border:2px dashed var(--border);border-radius:12px;padding:18px;text-align:center;background:var(--upload-bg);margin-top:10px}
.upload-zone input{margin-top:8px}
.master-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.master-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:6px}
.master-card .master-title{font-family:'Sora',sans-serif;font-size:16px;font-weight:900}
.master-card .master-meta{font-size:12px;color:var(--muted)}
.master-card .master-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.invoice-row{display:grid;grid-template-columns:160px minmax(0,1fr) 110px 110px 130px 110px auto;gap:10px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);background:#fff;font-size:13px}
.invoice-row:first-child{border-top:1px solid var(--border)}
.invoice-row b{font-weight:900}
.invoice-row.overdue{background:#FEF2F2}
.invoice-row.paid{background:#ECFDF5}
.bridge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.bridge-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px}
.bridge-card pre{margin:8px 0 0;background:var(--surface-soft);border:1px solid var(--border);border-radius:8px;padding:10px;font-size:11.5px;overflow:auto;max-height:240px;white-space:pre-wrap;word-break:break-word}
.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.report-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--shadow-soft)}
.report-card h4{font-family:'Sora',sans-serif;margin:0 0 10px;font-size:15px}
.report-bar{display:flex;align-items:center;gap:8px;margin:5px 0;font-size:13px;font-weight:900}
.report-bar .report-bar-fill{height:8px;border-radius:999px;background:var(--blue);min-width:4px}
.report-bar .report-bar-track{flex:1;background:var(--surface-soft);border-radius:999px;overflow:hidden}
.report-bar .report-label{min-width:100px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;font-size:11px}
.report-bar .report-value{min-width:50px;text-align:right;color:var(--dark)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid .field.full{grid-column:1/-1}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}
.case-actions-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.bridge-empty{padding:18px;text-align:center;color:var(--muted);font-weight:900}
.timeline-events{display:flex;flex-direction:column;gap:6px}
.timeline-event{display:grid;grid-template-columns:160px minmax(0,1fr);gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.timeline-event:last-child{border-bottom:0}
.timeline-event .ev-time{font-size:11px;text-transform:uppercase;color:var(--muted);font-weight:900;letter-spacing:.4px}
.timeline-event .ev-text{font-weight:900}
.section-heading{display:flex;align-items:center;justify-content:space-between;margin-top:18px;margin-bottom:6px}
.section-heading h3{margin:0;font-family:'Sora',sans-serif;font-size:18px}
@media (max-width:1100px){
  .folder-browser{grid-template-columns:1fr}
  .summary-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .invoice-row{grid-template-columns:1fr 1fr;font-size:12.5px}
  .bridge-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}
@media (max-width:1100px){
  .tile-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split{grid-template-columns:1fr}
}
@media (max-width:820px){
  .login-shell{grid-template-columns:1fr;padding:24px}
  .login-hero h1{font-size:38px}
  .demo-login-grid{grid-template-columns:1fr}
  .sidebar{position:static;width:100%;min-height:auto}
  .app-shell{display:block}
  .main{margin-left:0}
  .topbar{position:static;padding:16px;align-items:flex-start;flex-direction:column}
  .content{padding:18px 16px 40px}
  .ops-banner{align-items:flex-start;flex-direction:column}
  .tile-grid,.detail-grid,.doc-grid{grid-template-columns:1fr}
  .auction-row{grid-template-columns:1fr}
  .service-form{grid-template-columns:1fr}
  .search{min-width:0;width:100%}
}
