*{box-sizing:border-box;margin:0;padding:0}
:root{
  --orange:#E07020;
  --font:'Montserrat';
  --orange-light:#f5a05a;
  --orange-bg:#fff4eb;
  --navy:#1a3a5c;
  --navy-dark:#0f2035;
  --navy-mid:#254d78;
  --navy-light:#3a6ea8;
  --grey:#6b7280;
  --grey-light:#f4f5f7;
  --grey-mid:#e5e7eb;
  --grey-border:#d1d5db;
  --white:#ffffff;
  --green:#1a7a4a;
  --green-light:#e6f7ee;
  --yellow:#b45309;
  --yellow-light:#fef3c7;
  --red:#dc2626;
  --red-light:#fee2e2;
  --blue-light:#eff6ff;
  --sidebar:248px;
  --topbar:58px;
  --text-xs:.72rem;
  --text-sm:.83rem;
  --text-base:.94rem;
  --text-lg:1.1rem;
  --text-xl:1.33rem;
  --text-2xl:1.67rem;
}
body{font-family:'Montserrat',sans-serif;background:var(--grey-light);color:var(--navy-dark);min-height:100vh;overflow-x:hidden;font-size:var(--text-base)}
/* ═══════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════ */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar);background:var(--navy-dark);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;z-index:100}
.main{margin-left:var(--sidebar);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{height:var(--topbar);background:var(--white);border-bottom:2px solid var(--grey-mid);display:flex;align-items:center;padding:0 28px;gap:14px;position:sticky;top:0;z-index:50}
.content{flex:1;padding:30px 32px;max-width:1500px}
/* ═══════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════ */
.sidebar-logo{padding:22px 22px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
.logo-brand{font-size:.72rem;font-weight:900;letter-spacing:2.5px;color:var(--orange);text-transform:uppercase;line-height:1.2}
.logo-sub{font-size:.55rem;font-weight:600;letter-spacing:1.5px;color:rgba(255,255,255,.35);margin-top:3px;text-transform:uppercase}
.logo-version{display:inline-block;background:var(--orange);color:#fff;font-size:.5rem;font-weight:700;padding:1px 5px;border-radius:3px;margin-top:6px;letter-spacing:.5px}
.sidebar-user{padding:14px 22px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px;cursor:pointer}
.sidebar-user:hover{background:rgba(255,255,255,.04)}
.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:#fff;flex-shrink:0;border:2px solid rgba(255,255,255,.15)}
.user-name{font-size:.75rem;font-weight:700;color:#fff;line-height:1.2}
.user-role{font-size:.6rem;color:rgba(255,255,255,.4);margin-top:1px}
.user-chevron{margin-left:auto;color:rgba(255,255,255,.3);font-size:.75rem}
.nav-section{padding:16px 22px 6px;font-size:.52rem;font-weight:700;letter-spacing:2px;color:rgba(255,255,255,.25);text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 22px;cursor:pointer;transition:all .15s;border-left:3px solid transparent;margin:1px 0;text-decoration:none}
.nav-item:hover{background:rgba(255,255,255,.06)}
.nav-item.active{background:rgba(224,112,32,.12);border-left-color:var(--orange)}
.nav-icon{font-size:.95rem;width:18px;text-align:center;opacity:.7}
.nav-item.active .nav-icon{opacity:1}
.nav-label{font-size:.81rem;font-weight:600;color:rgba(255,255,255,.6);letter-spacing:.2px}
.nav-item.active .nav-label,.nav-item:hover .nav-label{color:#fff}
.nav-badge{margin-left:auto;background:var(--orange);color:#fff;font-size:.52rem;font-weight:700;padding:2px 7px;border-radius:10px;min-width:20px;text-align:center}
.nav-badge.red{background:var(--red)}
.nav-badge.yellow{background:var(--yellow)}
.sidebar-bottom{margin-top:auto;padding:16px 22px;border-top:1px solid rgba(255,255,255,.07)}
.sidebar-status{font-size:.58rem;color:rgba(255,255,255,.25);line-height:1.6}
.sidebar-status span{color:rgba(255,255,255,.45);font-weight:600}
/* ═══════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════ */
.topbar-title{font-size:.9rem;font-weight:800;color:var(--navy-dark);letter-spacing:.2px}
.topbar-breadcrumb{font-size:.7rem;color:var(--grey);margin-left:2px}
.topbar-spacer{flex:1}
.search-wrap{display:flex;align-items:center;gap:8px;background:var(--grey-light);border:1px solid var(--grey-border);border-radius:7px;padding:7px 13px;width:240px}
.search-wrap input{border:none;background:none;font-family:'Montserrat',sans-serif;font-size:.81rem;color:var(--navy-dark);width:100%;outline:none}
.search-wrap input::placeholder{color:var(--grey)}
.topbar-btn{background:var(--orange);color:#fff;border:none;padding:8px 18px;border-radius:7px;font-family:'Montserrat',sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;letter-spacing:.3px;transition:opacity .15s}
.topbar-btn:hover{opacity:.88}
.topbar-btn.secondary{background:transparent;border:1.5px solid var(--grey-border);color:var(--navy);padding:7px 15px}
.topbar-btn.secondary:hover{background:var(--grey-light)}
.icon-btn{width:36px;height:36px;border-radius:7px;border:1px solid var(--grey-border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;position:relative;transition:all .15s}
.icon-btn:hover{background:var(--grey-light);border-color:var(--grey)}
.notif-dot{width:7px;height:7px;background:var(--orange);border-radius:50%;position:absolute;top:7px;right:7px;border:2px solid #fff}
/* ═══════════════════════════════════════════
   PANELS
═══════════════════════════════════════════ */
.panel{display:none}
.panel.active{display:block}
/* ═══════════════════════════════════════════
   SHARED COMPONENTS
═══════════════════════════════════════════ */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.section-title{font-size:var(--text-xl);font-weight:800;color:var(--navy-dark);letter-spacing:-.3px}
.section-sub{font-size:var(--text-sm);color:var(--grey);margin-top:2px;font-weight:500}
.card{background:#fff;border-radius:10px;border:1px solid var(--grey-mid);overflow:hidden}
.card-header{padding:18px 22px 14px;border-bottom:1px solid var(--grey-mid);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:.91rem;font-weight:700;color:var(--navy-dark)}
.card-sub{font-size:.65rem;color:var(--grey);margin-top:1px}
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:5px;font-size:.69rem;font-weight:700;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}
.badge-green{background:var(--green-light);color:var(--green)}
.badge-orange{background:var(--orange-bg);color:var(--orange)}
.badge-red{background:var(--red-light);color:var(--red)}
.badge-yellow{background:var(--yellow-light);color:var(--yellow)}
.badge-navy{background:var(--blue-light);color:var(--navy)}
.badge-grey{background:var(--grey-light);color:var(--grey)}
.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:.6rem;font-weight:600}
.tag-wp{background:#e8f4fd;color:#1565c0}
.tag-pellet{background:#fde8d8;color:#8b3a0f}
.tag-pv{background:#e8fdf0;color:#1a7a4a}
.tag-wallbox{background:#f0e8fd;color:#6a1a9a}
.tag-schaltschrank{background:#fdf5e8;color:#7a5a1a}
.tag-bad{background:#e8f0fd;color:#1a3a9a}
.tag-knx{background:#fde8e8;color:#9a1a1a}
.tag-speicher{background:#e8fdf5;color:#1a7a5a}
table{width:100%;border-collapse:collapse}
thead tr{background:var(--grey-light)}
th{padding:10px 16px;text-align:left;font-size:.72rem;font-weight:700;color:var(--grey);letter-spacing:.8px;text-transform:uppercase;border-bottom:1px solid var(--grey-mid);white-space:nowrap}
td{padding:11px 16px;font-size:.86rem;color:var(--navy-dark);border-bottom:1px solid var(--grey-mid);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .1s;cursor:pointer}
tbody tr:hover{background:#fafbfc}
.link{color:var(--navy);font-weight:600;cursor:pointer;text-decoration:none;transition:color .15s}
.link:hover{color:var(--orange)}
.link-orange{color:var(--orange);font-weight:600;cursor:pointer}
.link-orange:hover{color:var(--orange-light)}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:6px;font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .15s;border:1.5px solid transparent;letter-spacing:.2px}
.btn-primary{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-primary:hover{opacity:.88}
.btn-secondary{background:#fff;color:var(--navy);border-color:var(--grey-border)}
.btn-secondary:hover{background:var(--grey-light)}
.btn-danger{background:var(--red-light);color:var(--red);border-color:var(--red-light)}
.btn-sm{padding:5px 10px;font-size:.72rem}
.divider{height:1px;background:var(--grey-mid);margin:20px 0}
/* ═══════════════════════════════════════════
   DASHBOARD
═══════════════════════════════════════════ */
.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}
.kpi{background:#fff;border-radius:10px;padding:20px 22px;border:1px solid var(--grey-mid);position:relative;overflow:hidden;height:220px;display:flex;flex-direction:column}
.kpi::after{content:'';position:absolute;top:0;right:0;width:3px;height:100%;border-radius:0 10px 10px 0}
.kpi.k-orange::after{background:var(--orange)}
.kpi.k-green::after{background:var(--green)}
.kpi.k-red::after{background:var(--red)}
.kpi.k-yellow::after{background:var(--yellow)}
.kpi.k-navy::after{background:var(--navy)}
.kpi-label{font-size:.63rem;font-weight:700;color:var(--grey);letter-spacing:.8px;text-transform:uppercase;margin-bottom:8px}
.kpi-value{font-size:1.7rem;font-weight:900;color:var(--navy-dark);letter-spacing:-1px;line-height:1}
.kpi-value.money{font-size:1.4rem}
.kpi-sub{font-size:.65rem;color:var(--grey);margin-top:6px;display:flex;align-items:center;gap:4px}
.kpi-trend-up{color:var(--green);font-weight:700}
.kpi-trend-dn{color:var(--red);font-weight:700}
.kpi-icon{position:absolute;top:18px;right:18px;font-size:1.4rem;opacity:.3}
.dash-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:20px}
.dash-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-bottom:20px}
/* Chart bars */
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:90px;padding:0 4px}.kpi-entries{margin-top:auto;border-top:1px solid var(--grey-mid);padding-top:8px;flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.kpi-entry{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.68rem;cursor:pointer;border-radius:4px;transition:background .15s}.kpi-entry:hover{background:var(--orange-bg)}.kpi-entry-name{color:var(--navy-dark);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:65%}.kpi-entry-value{color:var(--grey);font-weight:700;font-size:.65rem;white-space:nowrap}.dash-row-label{font-size:.6rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey);margin-bottom:4px;margin-top:8px}
.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar{width:100%;border-radius:4px 4px 0 0;background:var(--navy-mid);min-height:4px;transition:height .3s;position:relative;cursor:pointer}
.bar:hover{background:var(--orange)}
.bar.current{background:var(--orange)}
.bar-label{font-size:.58rem;color:var(--grey);font-weight:600}
.bar-val{font-size:.58rem;color:var(--grey);font-weight:600}
/* Activity feed */
.activity-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--grey-mid)}
.activity-item:last-child{border-bottom:none}
.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.activity-dot.orange{background:var(--orange)}
.activity-dot.green{background:var(--green)}
.activity-dot.navy{background:var(--navy)}
.activity-dot.red{background:var(--red)}
.activity-dot.yellow{background:var(--yellow)}
.activity-text{font-size:.75rem;color:var(--navy-dark);line-height:1.4}
.activity-text strong{font-weight:700}
.activity-time{font-size:.62rem;color:var(--grey);margin-top:2px}
/* Wartungs-ampel */
.wartung-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--grey-mid)}
.wartung-item:last-child{border-bottom:none}
.wartung-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.wartung-info{flex:1}
.wartung-name{font-size:.75rem;font-weight:600;color:var(--navy-dark)}
.wartung-detail{font-size:.63rem;color:var(--grey);margin-top:1px}
.wartung-days{font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:5px}
/* Liquidität */
.liq-bar{display:flex;height:10px;border-radius:5px;overflow:hidden;margin:10px 0 4px;gap:2px}
.liq-seg{height:100%;border-radius:3px;transition:width .3s}
.liq-legend{display:flex;gap:14px;flex-wrap:wrap}
.liq-legend-item{display:flex;align-items:center;gap:5px;font-size:.62rem;color:var(--grey)}
.liq-dot{width:8px;height:8px;border-radius:50%}
/* ═══════════════════════════════════════════
   KUNDEN
═══════════════════════════════════════════ */
.filter-bar{display:flex;gap:10px;margin-bottom:20px;align-items:center;flex-wrap:wrap}
.filter-btn{padding:6px 14px;border-radius:6px;border:1.5px solid var(--grey-border);background:#fff;font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:600;color:var(--grey);cursor:pointer;transition:all .15s}
.filter-btn.active,.filter-btn:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.filter-btn.active-orange{background:var(--orange);border-color:var(--orange);color:#fff}
.filter-input{padding:7px 13px;border-radius:7px;border:1.5px solid var(--grey-border);font-family:'Montserrat',sans-serif;font-size:.81rem;color:var(--navy-dark);outline:none;background:#fff;min-width:200px}
.filter-input:focus{border-color:var(--orange)}
.filter-spacer{flex:1}
/* Sort-Buttons */
.sort-bar{display:flex;gap:6px;margin-bottom:20px;align-items:center;flex-wrap:wrap}
.sort-btn{padding:4px 11px;border-radius:6px;border:1.5px solid var(--grey-border);background:#fff;font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:600;color:var(--grey);cursor:pointer;transition:all .15s}
.sort-btn:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.sort-btn.active-orange{background:var(--orange);border-color:var(--orange);color:#fff}
/* Global Search Dropdown */
.search-outer{position:relative}
.search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--grey-border);border-radius:8px;box-shadow:0 6px 24px rgba(0,0,0,.13);z-index:500;display:none;overflow:hidden}
.search-dropdown.open{display:block}
.sd-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--grey-mid)}
.sd-item:last-child{border-bottom:none}
.sd-item:hover{background:var(--grey-light)}
.sd-type{font-size:.57rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:4px;flex-shrink:0;white-space:nowrap}
.sd-type.kunde{background:var(--navy);color:#fff}
.sd-type.angebot{background:var(--orange);color:#fff}
.sd-type.auftrag{background:var(--green);color:#fff}
.sd-label{font-size:.8rem;font-weight:700;color:var(--navy-dark)}
.sd-sub{font-size:.68rem;color:var(--grey);margin-left:auto;white-space:nowrap}
.sd-empty{padding:14px;text-align:center;color:var(--grey);font-size:.78rem}
/* Kunden-Detailansicht */
.detail-layout{display:grid;grid-template-columns:320px 1fr;gap:20px}
.detail-sidebar .card{margin-bottom:16px}
.detail-main .card{margin-bottom:16px}
/* Katalog Panel — fixed rechts, responsive */
#katalogPanel{position:fixed;right:0;top:58px;height:calc(100vh - 58px);width:360px;border-radius:12px 0 0 12px;box-shadow:-4px 0 16px rgba(0,0,0,.10);display:none;flex-direction:column;background:var(--white);z-index:820;overflow:hidden}
#katalogPanel.open{display:flex}
#katalogPanel .kat-drag-handle{display:none}
body.katalog-open #angebote,body.katalog-open #projekte{padding-right:372px;transition:padding-right .25s ease}
#katalogPinBadge{display:none;align-items:center;gap:5px;background:#1a3a5c;color:#fff;font-size:.68rem;font-weight:700;padding:4px 10px;border-radius:20px;cursor:pointer;letter-spacing:.3px}
#katalogPinBadge.visible{display:flex}
@media(max-width:1024px){
  #katalogPanel{width:300px}
  body.katalog-open #angebote,body.katalog-open #projekte{padding-right:312px}
}
@media(max-width:768px){
  #katalogPanel{width:100%;right:0;left:0;top:auto;bottom:0;height:90vh;border-radius:16px 16px 0 0;box-shadow:0 -4px 16px rgba(0,0,0,.12)}
  #katalogPanel .kat-drag-handle{display:block;width:40px;height:4px;background:var(--grey-mid);border-radius:2px;margin:10px auto 4px;flex-shrink:0}
  body.katalog-open #angebote,body.katalog-open #projekte{padding-right:0}
}
/* Artikel-Karten */
.kat-artikel-card{background:var(--white);min-height:64px;border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.08);border:1px solid var(--border);padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;margin:6px 10px;transition:box-shadow .15s}
.kat-artikel-card:hover{box-shadow:0 3px 10px rgba(0,0,0,.13)}
#katalogListe{padding-top:12px}
.kat-add-btn{width:32px;height:32px;border-radius:50%;background:#16a34a;color:#fff;border:none;font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1;transition:background .15s}
.kat-add-btn:hover{background:#15803d}
/* Positionstabelle */
#angDetPosTable{table-layout:fixed;width:100%;border-collapse:collapse;font-size:.78rem}
.pos-bez-cell{white-space:normal;word-break:break-word}
.customer-header{padding:22px;text-align:center;border-bottom:1px solid var(--grey-mid)}
.customer-avatar{width:56px;height:56px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;color:#fff;margin:0 auto 12px}
.customer-name{font-size:1rem;font-weight:800;color:var(--navy-dark)}
.customer-nr{font-size:.63rem;font-family:'DM Mono',monospace;color:var(--grey);margin-top:2px}
.info-row{display:flex;padding:10px 22px;border-bottom:1px solid var(--grey-mid)}
.info-row:last-child{border-bottom:none}
.info-label{font-size:.65rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px;width:100px;flex-shrink:0;margin-top:1px}
.info-value{font-size:.78rem;color:var(--navy-dark);font-weight:500;flex:1}
.timeline{padding:16px 22px}
.tl-item{display:flex;gap:12px;position:relative;padding-bottom:20px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:'';position:absolute;left:10px;top:20px;bottom:0;width:1px;background:var(--grey-mid)}
.tl-item:last-child::before{display:none}
.tl-dot{width:20px;height:20px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;z-index:1}
.tl-dot.done{background:var(--green);color:#fff}
.tl-dot.active{background:var(--orange);color:#fff}
.tl-dot.open{background:var(--grey-mid);color:var(--grey)}
.tl-content{flex:1}
.tl-title{font-size:.75rem;font-weight:700;color:var(--navy-dark)}
.tl-date{font-size:.63rem;color:var(--grey);margin-top:1px}
.tl-note{font-size:.7rem;color:var(--grey);margin-top:3px}
/* Projekt-Tab im Kunden-Detail */
.project-card{border:1px solid var(--grey-mid);border-radius:8px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .15s}
.project-card:hover{border-color:var(--orange);background:var(--orange-bg)}
.project-card-title{font-size:.82rem;font-weight:700;color:var(--navy-dark)}
.project-card-meta{display:flex;gap:10px;margin-top:6px;align-items:center;flex-wrap:wrap}
.project-card-vol{font-size:.75rem;font-weight:700;color:var(--orange)}
.project-progress{height:4px;background:var(--grey-mid);border-radius:2px;margin-top:10px}
.project-progress-bar{height:100%;border-radius:2px;background:var(--orange);transition:width .3s}
/* ═══════════════════════════════════════════
   PROJEKTE
═══════════════════════════════════════════ */
.projekt-header{background:#fff;border-radius:10px;padding:22px;border:1px solid var(--grey-mid);margin-bottom:20px;display:grid;grid-template-columns:1fr auto;gap:20px}
.projekt-title{font-size:1.1rem;font-weight:800;color:var(--navy-dark);margin-bottom:4px}
.projekt-nr{font-family:'DM Mono',monospace;font-size:.7rem;color:var(--grey)}
.projekt-meta{display:flex;gap:16px;margin-top:10px;flex-wrap:wrap}
.projekt-meta-item{font-size:.72rem;color:var(--grey);display:flex;align-items:center;gap:5px}
.projekt-meta-item strong{color:var(--navy-dark);font-weight:700}
/* status-steps entfernt — ersetzt durch status-chain v4.5 */
.status-step{flex:1;text-align:center;position:relative;z-index:1}
.status-step-dot{width:24px;height:24px;border-radius:50%;margin:0 auto 6px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;border:2px solid var(--grey-mid);background:#fff;transition:all .2s}
.status-step.done .status-step-dot{background:var(--green);border-color:var(--green);color:#fff}
.status-step.active .status-step-dot{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 0 0 4px var(--orange-bg)}
.status-step.open .status-step-dot{background:#fff;border-color:var(--grey-mid);color:var(--grey)}
.status-step-label{font-size:.58rem;font-weight:600;color:var(--grey);letter-spacing:.3px}
.status-step.active .status-step-label{color:var(--orange);font-weight:700}
.status-step.done .status-step-label{color:var(--green)}
.projekt-tabs{display:flex;gap:0;border-bottom:2px solid var(--grey-mid);margin-bottom:20px}
.projekt-tab{padding:10px 20px;font-size:.75rem;font-weight:600;color:var(--grey);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}
.projekt-tab:hover{color:var(--navy-dark)}
.projekt-tab.active{color:var(--orange);border-bottom-color:var(--orange);font-weight:700}
/* ═══════════════════════════════════════════
   ANGEBOTE
═══════════════════════════════════════════ */
.angebot-header{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:16px;margin-bottom:20px}
.pos-table td:last-child{text-align:right;font-family:'DM Mono',monospace}
.pos-table th:last-child{text-align:right}
.pos-ek{font-size:.65rem;color:var(--grey);display:block}
.pos-marge{font-size:.62rem;font-weight:700}
.pos-marge.gut{color:var(--green)}
.pos-marge.ok{color:var(--yellow)}
.angebot-summe{background:var(--navy-dark);color:#fff;padding:16px 22px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;border-radius:0 0 10px 10px}
.angebot-summe-label{font-size:.72rem;color:rgba(255,255,255,.6)}
.angebot-summe-val{font-size:1.4rem;font-weight:900;color:var(--orange)}
.angebot-footer{font-size:.7rem;color:rgba(255,255,255,.5);margin-top:4px}
.angebot-hint{background:var(--orange-bg);border:1px solid var(--orange-light);border-radius:8px;padding:10px 14px;font-size:.72rem;color:var(--orange);display:flex;align-items:center;gap:8px;margin:12px 0}
/* ═══════════════════════════════════════════
   RECHNUNGEN
═══════════════════════════════════════════ */
.rechnung-ampel{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.ampel-card{background:#fff;border-radius:8px;padding:14px 18px;border:1px solid var(--grey-mid)}
.ampel-val{font-size:1.3rem;font-weight:900;margin-bottom:2px}
.ampel-label{font-size:.62rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px}
/* ═══════════════════════════════════════════
   KALENDER / PLANTAFEL
═══════════════════════════════════════════ */
.kalender-nav{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.kalender-nav-btn{width:32px;height:32px;border-radius:6px;border:1.5px solid var(--grey-border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .15s}
.kalender-nav-btn:hover{background:var(--grey-light)}
.kalender-week-title{font-size:.9rem;font-weight:800;color:var(--navy-dark)}
.plantafel{display:grid;grid-template-columns:80px 1fr 1fr;gap:0;border:1px solid var(--grey-mid);border-radius:10px;overflow:hidden}
.plantafel-header{background:var(--navy-dark);color:#fff;padding:12px 16px;font-size:.72rem;font-weight:700;border-bottom:1px solid rgba(255,255,255,.1)}
.plantafel-header.tech{background:var(--navy-mid)}
.plantafel-timecol{background:#fff}
.plantafel-time{height:56px;border-bottom:1px solid var(--grey-mid);display:flex;align-items:flex-start;justify-content:flex-end;padding:4px 10px 0 0;font-size:.62rem;font-family:'DM Mono',monospace;color:var(--grey)}
.plantafel-col{background:#fff;border-left:1px solid var(--grey-mid);position:relative}
.plantafel-slot{height:56px;border-bottom:1px solid var(--grey-mid)}
.plantafel-slot:hover{background:#fafbfc}
.termin-block{position:absolute;left:6px;right:6px;border-radius:5px;padding:4px 8px;cursor:pointer;transition:opacity .15s;z-index:2}
.termin-block:hover{opacity:.85}
.termin-block-title{font-size:.65rem;font-weight:700;line-height:1.3}
.termin-block-sub{font-size:.58rem;opacity:.85;line-height:1.3}
/* Termintyp-Farben */
.t-aufmass{background:#fff0e0;border-left:3px solid var(--orange);color:#7a3500}
.t-montage{background:#e0e8f5;border-left:3px solid var(--navy);color:#0f2035}
.t-wartung{background:#e0f5ec;border-left:3px solid var(--green);color:#0a3d20}
.t-entst{background:#fde8e8;border-left:3px solid var(--red);color:#7a0000}
.t-ibs{background:#e8f5e0;border-left:3px solid #4a9a20;color:#2a5a0a}
.t-buero{background:#f0f0f0;border-left:3px solid var(--grey);color:#333}
.kalender-legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.legend-item{display:flex;align-items:center;gap:6px;font-size:.65rem;font-weight:600;color:var(--grey)}
.legend-dot{width:10px;height:10px;border-radius:2px}
/* ═══════════════════════════════════════════
   ANLAGENREGISTER
═══════════════════════════════════════════ */
.anlage-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.anlage-card{background:#fff;border-radius:10px;border:1px solid var(--grey-mid);padding:0;overflow:hidden;cursor:pointer;transition:all .15s}
.anlage-card:hover{border-color:var(--orange);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.07)}
.anlage-card-top{padding:16px 18px 12px;border-bottom:1px solid var(--grey-mid)}
.anlage-card-bottom{padding:12px 18px}
.anlage-typ{font-size:.62rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--grey);margin-bottom:4px}
.anlage-name{font-size:.85rem;font-weight:700;color:var(--navy-dark)}
.anlage-kunde{font-size:.7rem;color:var(--grey);margin-top:2px}
.anlage-sn{font-family:'DM Mono',monospace;font-size:.62rem;color:var(--grey)}
.wartung-status{display:flex;align-items:center;gap:6px}
.wartung-ampel{width:10px;height:10px;border-radius:50%}
.wartung-ampel.gruen{background:var(--green)}
.wartung-ampel.gelb{background:var(--yellow)}
.wartung-ampel.rot{background:var(--red)}
.wartung-text{font-size:.7rem;font-weight:600}
.wartung-date{font-size:.62rem;color:var(--grey);margin-left:auto}
/* ═══════════════════════════════════════════
   FINANZDASHBOARD
═══════════════════════════════════════════ */
.fin-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:22px}
.fin-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px}
.mahnung-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--grey-mid)}
.mahnung-item:last-child{border-bottom:none}
.mahnung-badge{flex-shrink:0}
.mahnung-kunde{flex:1}
.mahnung-name{font-size:.75rem;font-weight:700;color:var(--navy-dark)}
.mahnung-betrag{font-size:.72rem;font-weight:700;color:var(--red);text-align:right}
.mahnung-days{font-size:.62rem;color:var(--red);text-align:right;margin-top:1px}
.foerder-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--grey-mid)}
.foerder-item:last-child{border-bottom:none}
.foerder-betrag{font-size:.78rem;font-weight:800;color:var(--green)}
.foerder-projekt{font-size:.7rem;font-weight:600;color:var(--navy-dark)}
.foerder-status{font-size:.62rem;color:var(--grey)}
/* ═══════════════════════════════════════════
   MISC UTILS
═══════════════════════════════════════════ */
.flex{display:flex}
.flex-col{display:flex;flex-direction:column}
.items-center{align-items:center}
.gap-2{gap:8px}
.gap-3{gap:12px}
.gap-4{gap:16px}
.justify-between{justify-content:space-between}
.mt-1{margin-top:4px}
.mt-2{margin-top:8px}
.mt-3{margin-top:12px}
.mt-4{margin-top:16px}
.mb-2{margin-bottom:8px}
.mb-3{margin-bottom:12px}
.mb-4{margin-bottom:16px}
.p-0{padding:0}
.text-right{text-align:right}
.text-grey{color:var(--grey)}
.text-navy{color:var(--navy-dark)}
.text-orange{color:var(--orange)}
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.font-mono{font-family:'DM Mono',monospace}
.font-bold{font-weight:700}
.font-black{font-weight:900}
.w-full{width:100%}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.empty-state{text-align:center;padding:40px 20px;color:var(--grey)}
.empty-state-icon{font-size:2.5rem;margin-bottom:12px}
.empty-state-text{font-size:.85rem;font-weight:600}
.empty-state-sub{font-size:.75rem;margin-top:4px}
/* Back button */
.back-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 0;font-size:.75rem;font-weight:700;color:var(--grey);cursor:pointer;margin-bottom:16px;transition:color .15s}
.back-btn:hover{color:var(--orange)}
/* Scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--grey-mid);border-radius:3px}
/* Tooltip */
.tooltip-wrap{position:relative;display:inline-block}
.tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--navy-dark);color:#fff;padding:5px 10px;border-radius:5px;font-size:.63rem;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:200}
.tooltip-wrap:hover .tooltip{opacity:1}
/* ═══════════════════════════════════════════
   PROTOKOLL / UPLOAD IN PROJEKTAKTE
═══════════════════════════════════════════ */
.proto-section-title{font-size:.62rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:1px;margin:16px 0 10px;display:flex;align-items:center;gap:8px}
.proto-section-title::after{content:'';flex:1;height:1px;background:var(--grey-mid)}
.foto-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.foto-card{border-radius:8px;overflow:hidden;position:relative;aspect-ratio:4/3;cursor:pointer}
.foto-card img,.foto-placeholder{width:100%;height:100%;object-fit:cover;display:block}
.foto-placeholder{background:var(--grey-light);border:2px dashed var(--grey-border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:all .15s;border-radius:8px}
.foto-placeholder:hover{border-color:var(--orange);background:var(--orange-bg)}
.foto-placeholder-icon{font-size:1.4rem}
.foto-placeholder-label{font-size:.6rem;font-weight:700;color:var(--grey);text-align:center;line-height:1.3}
.foto-card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.75));padding:6px 8px}
.foto-card-label{font-size:.6rem;font-weight:700;color:#fff;line-height:1.3}
.foto-card-time{font-size:.55rem;color:rgba(255,255,255,.7)}
.foto-kategorie{display:inline-flex;align-items:center;padding:2px 7px;border-radius:3px;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.fk-vorher{background:#e8f0fd;color:#1a3a9a}
.fk-waehrend{background:#fff0e0;color:#7a3500}
.fk-nachher{background:#e6f7ee;color:#1a7a4a}
.fk-detail{background:#f0f0f0;color:#444}
.upload-drop{border:2px dashed var(--grey-border);border-radius:8px;padding:20px;text-align:center;cursor:pointer;transition:all .15s;background:#fff}
.upload-drop:hover{border-color:var(--orange);background:var(--orange-bg)}
.upload-drop-icon{font-size:2rem;margin-bottom:8px}
.upload-drop-text{font-size:.75rem;font-weight:700;color:var(--navy-dark)}
.upload-drop-sub{font-size:.65rem;color:var(--grey);margin-top:3px}
.upload-types{display:flex;gap:6px;justify-content:center;margin-top:10px;flex-wrap:wrap}
.upload-type-badge{font-size:.58rem;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--grey-light);color:var(--grey)}
.messprotokoll{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mess-item{background:var(--grey-light);border-radius:7px;padding:12px 14px;border:1px solid var(--grey-mid)}
.mess-label{font-size:.62rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.mess-val{font-size:.95rem;font-weight:900;color:var(--navy-dark);font-family:'DM Mono',monospace}
.mess-unit{font-size:.65rem;color:var(--grey);margin-left:3px;font-weight:600}
.mess-status{font-size:.6rem;margin-top:2px;font-weight:700}
.mess-ok{color:var(--green)}
.mess-warn{color:var(--yellow)}
.mess-err{color:var(--red)}
.checkliste{display:flex;flex-direction:column;gap:6px}
.check-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;border:1px solid var(--grey-mid);background:#fff;cursor:pointer;transition:all .15s}
.check-item.done{background:var(--green-light);border-color:#9fd8bc}
.check-item.active{border-color:var(--orange);background:var(--orange-bg)}
.check-box{width:18px;height:18px;border-radius:4px;border:2px solid var(--grey-border);display:flex;align-items:center;justify-content:center;font-size:.7rem;flex-shrink:0;transition:all .15s}
.check-item.done .check-box{background:var(--green);border-color:var(--green);color:#fff}
.check-item.active .check-box{border-color:var(--orange)}
.check-text{font-size:.73rem;font-weight:600;flex:1}
.check-item.done .check-text{text-decoration:line-through;color:var(--grey)}
.check-who{font-size:.6rem;color:var(--grey)}
.notiz-item{background:var(--grey-light);border-radius:7px;padding:10px 12px;margin-bottom:8px;border-left:3px solid var(--orange)}
.notiz-text{font-size:.75rem;color:var(--navy-dark);line-height:1.5}
.notiz-meta{font-size:.62rem;color:var(--grey);margin-top:4px;display:flex;gap:8px}
.doc-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--grey-mid)}
.doc-item:last-child{border-bottom:none}
.doc-icon{font-size:1.1rem;flex-shrink:0}
.doc-name{font-size:.75rem;font-weight:600;color:var(--navy-dark)}
.doc-date{font-size:.62rem;color:var(--grey);margin-top:1px}
.doc-placeholder{opacity:.45;border:1.5px dashed var(--grey-border) !important;background:none !important}
.doc-dl{font-size:.75rem;cursor:pointer;padding:4px 8px;border-radius:5px;color:var(--navy);font-weight:700;transition:all .15s}
.doc-dl:hover{background:var(--grey-light);color:var(--orange)}
/* ═══════════════════════════════════════════
   MOBILE APP DEMO
═══════════════════════════════════════════ */
.mobile-demo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;align-items:start}
.mobile-frame-wrap{text-align:center}
.mobile-frame-label{font-size:.62rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
.mobile-frame{display:inline-block;background:var(--navy-dark);border-radius:36px;padding:10px;box-shadow:0 20px 60px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.05);position:relative}
.mobile-notch{width:80px;height:20px;background:var(--navy-dark);border-radius:0 0 14px 14px;margin:0 auto 8px;position:relative;z-index:10}
.mobile-screen{background:var(--grey-light);border-radius:28px;overflow:hidden;width:260px;min-height:480px;position:relative;display:flex;flex-direction:column}
.mobile-topbar-app{background:var(--navy-dark);padding:12px 16px;display:flex;align-items:center;gap:8px}
.mobile-back{color:rgba(255,255,255,.5);font-size:.8rem;cursor:pointer}
.mobile-title-app{font-size:.78rem;font-weight:700;color:#fff;line-height:1.2}
.mobile-sub-app{font-size:.58rem;color:rgba(255,255,255,.5);margin-top:1px}
.mobile-content-app{flex:1;padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:10px}
.mobile-bottom-nav{background:#fff;border-top:1px solid var(--grey-mid);display:flex;padding:8px 0 10px}
.mbn-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer}
.mbn-icon{font-size:1.1rem}
.mbn-label{font-size:.52rem;font-weight:700;color:var(--grey)}
.mbn-label.active{color:var(--orange)}
/* Mobile-Karten */
.m-card{background:#fff;border-radius:10px;padding:10px 12px;border:1px solid var(--grey-mid);font-size:.72rem}
.m-card-title{font-weight:700;color:var(--navy-dark);margin-bottom:4px;font-size:.75rem}
.m-chip{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:.58rem;font-weight:700;margin-right:4px;margin-bottom:4px}
.m-chip-orange{background:var(--orange-bg);color:var(--orange)}
.m-chip-navy{background:var(--blue-light);color:var(--navy)}
.m-chip-green{background:var(--green-light);color:var(--green)}
.m-foto-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin:6px 0}
.m-foto{border-radius:6px;aspect-ratio:1;overflow:hidden;position:relative}
.m-foto-img{width:100%;height:100%;object-fit:cover;display:block;background:var(--grey-mid)}
.m-foto-add{width:100%;aspect-ratio:1;border-radius:6px;border:1.5px dashed var(--grey-border);display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:var(--grey-light);cursor:pointer}
.m-foto-badge{position:absolute;top:3px;left:3px;font-size:.48rem;font-weight:700;padding:1px 5px;border-radius:3px}
.m-check{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--grey-mid)}
.m-check:last-child{border-bottom:none}
.m-checkbox{width:16px;height:16px;border-radius:3px;border:2px solid var(--grey-border);display:flex;align-items:center;justify-content:center;font-size:.6rem;flex-shrink:0}
.m-checkbox.checked{background:var(--green);border-color:var(--green);color:#fff}
.m-check-text{font-size:.68rem;font-weight:600}
.m-check-text.done{text-decoration:line-through;color:var(--grey)}
.m-mess-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.m-mess{background:var(--grey-light);border-radius:6px;padding:8px}
.m-mess-label{font-size:.55rem;color:var(--grey);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.m-mess-val{font-size:.85rem;font-weight:900;color:var(--navy-dark);font-family:'DM Mono',monospace;margin-top:2px}
.m-upload-area{border:1.5px dashed var(--orange);border-radius:8px;padding:14px;text-align:center;background:var(--orange-bg);cursor:pointer}
.m-upload-icon{font-size:1.5rem}
.m-upload-text{font-size:.65rem;font-weight:700;color:var(--orange);margin-top:4px}
.m-upload-sub{font-size:.58rem;color:var(--grey);margin-top:2px}
.m-btn{width:100%;padding:10px;background:var(--orange);color:#fff;border:none;border-radius:8px;font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;cursor:pointer;margin-top:6px}
.m-btn-secondary{background:#fff;color:var(--navy);border:1.5px solid var(--grey-border)}
/* SVG Foto-Illustrationen */
.foto-svg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem}
.foto-mock{width:100%;height:100%;position:relative;overflow:hidden}
.foto-mock-bg{position:absolute;inset:0}
.foto-mock-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}
/* Info-Banner */
.info-banner{background:var(--blue-light);border:1px solid #bfdbfe;border-radius:8px;padding:12px 16px;margin-bottom:20px;font-size:.75rem;color:var(--navy-dark);display:flex;gap:10px;align-items:flex-start;line-height:1.5}
.info-banner-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}
/* Signatur-Pad Mockup */
.sig-pad{border:1.5px solid var(--grey-border);border-radius:7px;height:70px;background:#fff;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.sig-line{position:absolute;bottom:12px;left:16px;right:16px;height:1px;background:var(--grey-mid)}
.sig-placeholder{font-size:.62rem;color:var(--grey);font-style:italic}
/* ═══════ V3 PLANTAFEL ═══════ */
.cal-week-tabs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.cal-week-tab{padding:7px 16px;border-radius:7px;border:1.5px solid var(--grey-border);background:#fff;font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:600;color:var(--grey);cursor:pointer;transition:all .15s}
.cal-week-tab:hover,.cal-week-tab.active{background:var(--navy-dark);border-color:var(--navy-dark);color:#fff}
.cal-tech-filters{display:flex;gap:6px;margin-left:auto}
.cal-tech-btn{padding:5px 12px;border-radius:20px;border:1.5px solid var(--grey-border);font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;cursor:pointer;transition:all .15s;background:#fff;color:var(--grey)}
.cal-tech-btn.on-ben{background:#fff4eb;border-color:var(--orange);color:var(--orange)}
.cal-tech-btn.on-tom{background:#eff6ff;border-color:var(--navy);color:var(--navy)}
.cal-tech-btn.on-pat{background:#e6f7ee;border-color:var(--green);color:var(--green)}
.cal-tech-btn.on-ann{background:#f3e8fd;border-color:#7c3aed;color:#7c3aed}
.cal-legend-bar{display:flex;gap:12px;flex-wrap:wrap;padding:10px 16px;background:#fff;border:1px solid var(--grey-mid);border-radius:8px;margin-bottom:14px}
.cal-legend-item{display:flex;align-items:center;gap:5px;font-size:.64rem;font-weight:600;color:var(--grey)}
.cal-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.pf-wrap{background:#fff;border:1px solid var(--grey-mid);border-radius:10px;overflow-x:auto}
.pf-inner{min-width:800px}
.pf-head{border-bottom:2px solid var(--grey-mid);background:var(--grey-light);display:grid}
.pf-col-time{width:52px;padding:8px 4px;border-right:1px solid var(--grey-mid);font-size:.58rem;color:var(--grey);text-align:center;font-weight:700}
.pf-col-day{padding:8px 6px;border-right:1px solid var(--grey-mid);text-align:center}
.pf-col-day:last-child{border-right:none}
.pf-day-name{font-size:.6rem;font-weight:600;color:var(--grey)}
.pf-day-date{font-size:.78rem;font-weight:800;color:var(--navy-dark)}
.pf-tech-chip{display:inline-block;font-size:.58rem;font-weight:700;padding:2px 7px;border-radius:10px;margin-top:3px}
.pf-body{display:flex}
.pf-times{width:52px;flex-shrink:0;border-right:1px solid var(--grey-mid)}
.pf-hour-lbl{height:44px;display:flex;align-items:flex-start;justify-content:center;font-size:.56rem;color:var(--grey);font-weight:600;padding-top:3px;border-bottom:1px solid var(--grey-mid)}
.pf-days{flex:1;display:grid}
.pf-day{border-right:1px solid var(--grey-mid);position:relative;min-width:90px}
.pf-day:last-child{border-right:none}
.pf-hr{height:44px;border-bottom:1px dashed #eee}
.pf-hr:nth-child(2n){background:rgba(0,0,0,.012)}
.pf-appt{position:absolute;left:3px;right:3px;border-radius:5px;padding:3px 6px;font-size:.62rem;font-weight:600;line-height:1.3;cursor:pointer;border-left:3px solid rgba(0,0,0,.2);box-shadow:0 1px 4px rgba(0,0,0,.1);overflow:hidden;transition:transform .1s,box-shadow .1s;z-index:2}
.pf-appt:hover{transform:translateX(1px);box-shadow:0 3px 10px rgba(0,0,0,.18);z-index:10}
.week-pf{display:none}
.week-pf.active{display:block}
/* ═══════ V3 KI ═══════ */
.ki-apikey-hint{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:10px 16px;margin-bottom:18px;font-size:.75rem;color:var(--navy-dark);display:flex;gap:8px;align-items:flex-start}
.ki-input-wrap{background:#fff;border:1.5px solid var(--grey-border);border-radius:10px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.ki-textarea{width:100%;min-height:110px;border:none;outline:none;resize:vertical;font-family:'Montserrat',sans-serif;font-size:.82rem;padding:16px;color:var(--navy-dark);background:transparent;line-height:1.6}
.ki-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-top:1px solid var(--grey-mid);background:var(--grey-light);flex-wrap:wrap}
.ki-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:7px;border:1.5px solid var(--grey-border);background:#fff;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .15s;color:var(--navy-dark)}
.ki-btn:hover{border-color:var(--orange);color:var(--orange)}
.ki-btn.ki-primary{background:var(--orange);color:#fff;border-color:var(--orange)}
.ki-btn.ki-primary:hover{opacity:.88}
.ki-btn.ki-rec{background:var(--red-light);border-color:var(--red);color:var(--red);animation:ki-pulse 1s infinite}
@keyframes ki-pulse{0%,100%{opacity:1}50%{opacity:.6}}
.ki-foto-strip{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--grey-mid);flex-wrap:wrap}
.ki-fw{position:relative;display:inline-block}
.ki-ft{width:64px;height:64px;border-radius:6px;object-fit:cover;border:2px solid var(--grey-mid);display:block}
.ki-fr{position:absolute;top:-6px;right:-6px;width:17px;height:17px;border-radius:50%;background:var(--red);color:#fff;border:none;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700}
.ki-spinner{display:inline-block;width:22px;height:22px;border:3px solid var(--grey-mid);border-top-color:var(--orange);border-radius:50%;animation:ki-spin .8s linear infinite;vertical-align:middle}
@keyframes ki-spin{to{transform:rotate(360deg)}}
.ki-result-card{margin-top:18px;background:#fff;border:1px solid var(--grey-mid);border-radius:10px;overflow:hidden}
.ki-rh{padding:14px 20px;background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy-mid) 100%);color:#fff;display:flex;align-items:center;gap:10px}
.ki-rh-title{font-size:.9rem;font-weight:800}
.ki-rh-sub{font-size:.68rem;opacity:.6;margin-left:auto}
.ki-rb{padding:18px 20px}
.ki-at{width:100%;border-collapse:collapse;font-size:.75rem}
.ki-at th{background:var(--navy-dark);color:#fff;padding:7px 10px;text-align:left;font-size:.65rem;font-weight:700}
.ki-at td{padding:7px 10px;border-bottom:1px solid var(--grey-mid)}
.ki-at tr:last-child td{border-bottom:none}
.ki-at .ep{text-align:right;font-weight:700;color:var(--navy-dark)}
.ki-at .gp{text-align:right;font-weight:800;color:var(--orange)}
.ki-summe td{background:var(--grey-light);font-weight:800;font-size:.82rem}
.ki-brutto td{background:#fff4eb;font-weight:900;font-size:.9rem}
.ki-foerder{margin-top:10px;padding:9px 14px;background:var(--green-light);border-radius:7px;border-left:3px solid var(--green);font-size:.75rem;color:var(--green)}
.ki-14a{margin-top:8px;padding:9px 14px;background:var(--blue-light);border-radius:7px;border-left:3px solid var(--navy);font-size:.75rem;color:var(--navy-dark)}
.ki-hint-box{font-size:.68rem;color:var(--grey);margin-top:8px;padding:8px 12px;background:var(--grey-light);border-radius:6px}
/* ════════════════ V4 CSS ════════════════ */
/* Modal System */
.v4-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:3000;align-items:center;justify-content:center}
.v4-overlay.open{display:flex}
.v4-modal{background:#fff;border-radius:12px;box-shadow:0 8px 48px rgba(0,0,0,.22);max-width:96vw;max-height:92vh;overflow-y:auto}
.v4-mh{padding:18px 22px;border-bottom:1px solid var(--grey-mid);display:flex;align-items:center;gap:10px}
.v4-mt{font-size:.95rem;font-weight:800;color:var(--navy-dark);flex:1}
.v4-mx{width:30px;height:30px;border-radius:50%;border:none;background:var(--grey-light);cursor:pointer;font-size:1rem;color:var(--grey);display:flex;align-items:center;justify-content:center}
.v4-mb{padding:20px 22px}
.v4-mf{padding:14px 22px;border-top:1px solid var(--grey-mid);display:flex;gap:8px;justify-content:flex-end}
/* Form */
.v4-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:13px}
.v4-row.full{grid-template-columns:1fr}
.v4-row.tri{grid-template-columns:1fr 1fr 1fr}
.v4-fg{display:flex;flex-direction:column;gap:4px}
.v4-lbl{font-size:.62rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px}
.v4-inp{padding:8px 11px;border:1.5px solid var(--grey-border);border-radius:7px;font-family:"Montserrat",sans-serif;font-size:.86rem;color:var(--navy-dark);background:var(--grey-light);outline:none;transition:border-color .15s;width:100%}
.v4-inp:focus{border-color:var(--orange);background:#fff}
/* Toast */
#v4toast{position:fixed;bottom:24px;right:24px;background:var(--navy-dark);color:#fff;padding:11px 18px;border-radius:8px;font-size:.78rem;font-weight:700;z-index:9999;box-shadow:0 4px 20px rgba(0,0,0,.28);transition:opacity .4s;opacity:0;pointer-events:none;font-family:"Montserrat",sans-serif}
/* Status Kette */
.status-chain{display:flex;gap:0;margin:16px 0;position:relative}
.status-chain::before{content:"";position:absolute;top:14px;left:5%;right:5%;height:2px;background:var(--grey-mid);z-index:0}
.sc-step{flex:1;text-align:center;position:relative;z-index:1;cursor:pointer}
.sc-dot{width:28px;height:28px;border-radius:50%;margin:0 auto 6px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;border:2px solid var(--grey-mid);background:#fff;transition:all .2s}
.sc-step.done .sc-dot{background:var(--green);border-color:var(--green);color:#fff}
.sc-step.active .sc-dot{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 0 0 3px rgba(224,112,32,.2)}
.sc-step.open .sc-dot{background:#fff;border-color:var(--grey-mid);color:var(--grey)}
.sc-lbl{font-size:.6rem;font-weight:700;color:var(--grey);white-space:nowrap}
.sc-step.active .sc-lbl{color:var(--orange);font-weight:800}
.sc-step.done .sc-lbl{color:var(--green)}
/* Positions-Tabelle Angebot */
.pos-editor{width:100%;border-collapse:collapse;font-size:.75rem}
.pos-editor th{background:var(--navy-dark);color:#fff;padding:7px 10px;text-align:left;font-size:.63rem;font-weight:700;white-space:nowrap}
.pos-editor td{padding:4px 5px;border-bottom:1px solid var(--grey-mid)}
.pos-editor tr:last-child td{border-bottom:none}
.pos-editor input{width:100%;padding:5px 7px;border:1.5px solid var(--grey-border);border-radius:5px;font-family:"Montserrat",sans-serif;font-size:.72rem;background:var(--grey-light)}
.pos-editor input:focus{border-color:var(--orange);background:#fff;outline:none}
.pos-editor .td-r{text-align:right}
.pos-editor .td-c{text-align:center}
/* Angebot Tabs */
.v4-tabs{display:flex;border-bottom:2px solid var(--grey-mid);margin-bottom:0}
.v4-tab{padding:10px 18px;font-size:.73rem;font-weight:700;cursor:pointer;color:var(--grey);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}
.v4-tab.active{color:var(--orange);border-bottom-color:var(--orange)}
.v4-tc{display:none;padding-top:14px}
.v4-tc.active{display:block}
/* Protokoll */
.proto-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--grey-mid)}
.proto-item:last-child{border-bottom:none}
.proto-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);margin-top:5px;flex-shrink:0}
.proto-meta{font-size:.62rem;color:var(--grey);margin-top:2px}
/* Mail Vorschau */
.mail-preview{border:1.5px solid var(--grey-border);border-radius:8px;overflow:hidden}
.mail-header{background:var(--grey-light);padding:12px 16px;border-bottom:1px solid var(--grey-mid)}
.mail-field{display:flex;gap:8px;align-items:center;margin-bottom:6px;font-size:.75rem}
.mail-field:last-child{margin-bottom:0}
.mail-field-lbl{font-size:.65rem;font-weight:700;color:var(--grey);width:50px;flex-shrink:0}
.mail-field-val{font-size:.75rem;color:var(--navy-dark);font-weight:600}
.mail-body-edit{width:100%;min-height:160px;border:none;outline:none;font-family:"Montserrat",sans-serif;font-size:.78rem;padding:14px;resize:vertical;line-height:1.6;color:var(--navy-dark)}
/* Rechnungen */
.rampel4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.ra4{background:#fff;border-radius:10px;border:1px solid var(--grey-mid);padding:14px;text-align:center;border-top:3px solid var(--grey-mid)}
.ra4-val{font-size:1.5rem;font-weight:900}
.ra4-lbl{font-size:.58rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.ra4-sub{font-size:.7rem;font-weight:700;color:var(--grey);margin-top:3px}
/* Freigabe Button */
.btn-freigabe{background:linear-gradient(135deg,var(--green),#40916c);color:#fff;border:none;padding:8px 18px;border-radius:7px;font-family:"Montserrat",sans-serif;font-size:.75rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:opacity .15s}
.btn-freigabe:hover{opacity:.88}
/* sevDesk Simulation */
.sevdesk-sim{background:linear-gradient(135deg,#1a3a5c,#254d78);border-radius:10px;padding:14px 18px;color:#fff;margin-top:12px}
.sevdesk-sim-title{font-size:.72rem;font-weight:700;opacity:.7;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.sevdesk-response{font-family:"DM Mono",monospace;font-size:.68rem;color:#7dd3fc;line-height:1.8}
/* Routenplaner */
.rstat4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.rs4{background:#fff;border:1px solid var(--grey-mid);border-radius:10px;padding:13px;text-align:center}
.rs4v{font-size:1.4rem;font-weight:900;color:var(--navy-dark)}
.rs4l{font-size:.58rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.rmap4{background:linear-gradient(135deg,#e8f0f8,#d4e4f0);border-radius:10px;border:1px solid var(--grey-mid);position:relative;overflow:hidden;height:340px}
.rmap4 canvas{position:absolute;inset:0;width:100%;height:100%}
.rtch4{display:flex;gap:8px;margin-bottom:14px}
.rtb4{padding:7px 16px;border-radius:20px;border:2px solid var(--grey-border);font-family:"Montserrat",sans-serif;font-size:.73rem;font-weight:700;cursor:pointer;transition:all .15s;background:#fff;color:var(--grey)}
.rtb4.rb{background:#fff4eb;border-color:var(--orange);color:var(--orange)}
.rtb4.rt{background:var(--blue-light);border-color:var(--navy);color:var(--navy)}
.rstop4{display:flex;align-items:center;gap:10px;padding:9px 13px;background:#fff;border:1px solid var(--grey-mid);border-radius:8px}
.rstop4-nr{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:#fff;flex-shrink:0}
.rstop4-conn{width:2px;height:8px;background:var(--grey-mid);margin:0 auto 0 18px}
/* Einstellungen */
.einst4-h{font-size:.63rem;font-weight:800;color:var(--grey);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;padding-bottom:7px;border-bottom:2px solid var(--grey-mid)}
.nc4{display:flex;align-items:center;gap:11px;padding:12px 15px;background:#fff;border:1px solid var(--grey-mid);border-radius:9px;margin-bottom:7px}
.na4{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:#fff;flex-shrink:0}
.nbak4{background:var(--green-light);color:var(--green);padding:2px 8px;border-radius:20px;font-size:.58rem;font-weight:700}
.nbpl4{background:var(--yellow-light);color:var(--yellow);padding:2px 8px;border-radius:20px;font-size:.58rem;font-weight:700}
/* API Key */
.apikey-wrap4{position:relative}
.apikey-wrap4 input{font-family:"DM Mono",monospace;font-size:.75rem;letter-spacing:.3px;padding-right:36px}
.apikey-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);cursor:pointer;font-size:.8rem;background:none;border:none;color:var(--grey)}
.ak-ok{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.63rem;font-weight:700;background:var(--green-light);color:var(--green)}
.ak-no{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.63rem;font-weight:700;background:var(--yellow-light);color:var(--yellow)}
/* Nachfass Ampel Dashboard */
.nachfass-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--grey-mid)}
.nachfass-item:last-child{border-bottom:none}
.nf-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.nf-info{flex:1}
.nf-name{font-size:.75rem;font-weight:700;color:var(--navy-dark)}
.nf-meta{font-size:.63rem;color:var(--grey);margin-top:1px}
.nf-badge{font-size:.65rem;font-weight:700;padding:3px 9px;border-radius:5px}
/* Kunde neu Flash */
@keyframes kflash{0%{background:var(--green-light)}100%{background:transparent}}
.knew4{animation:kflash 1.2s ease}
/* ════ V4.1 CSS ════ */
/* Anlage Karten klickbar */
.anlage-card{cursor:pointer;transition:all .18s}
.anlage-card:hover{border-color:var(--orange)!important;box-shadow:0 4px 16px rgba(224,112,32,.15);transform:translateY(-1px)}
/* Wartung Item klickbar */
.wartung-item{cursor:pointer;border-radius:7px;padding:8px 6px;transition:background .15s}
.wartung-item:hover{background:var(--orange-bg)}
/* Termin Modal */
.termin-typ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.termin-typ-btn{padding:10px 8px;border-radius:8px;border:2px solid var(--grey-border);background:#fff;cursor:pointer;text-align:center;transition:all .15s;font-family:"Montserrat",sans-serif}
.termin-typ-btn:hover{border-color:var(--orange)}
.termin-typ-btn.selected{border-color:var(--orange);background:var(--orange-bg)}
.termin-typ-btn .typ-icon{font-size:1.4rem;display:block;margin-bottom:4px}
.termin-typ-btn .typ-lbl{font-size:.65rem;font-weight:700;color:var(--navy-dark)}
/* Anlage Detail */
.anlage-detail-header{background:linear-gradient(135deg,var(--navy-dark),var(--navy-mid));border-radius:10px;padding:18px 22px;color:#fff;margin-bottom:16px}
.anlage-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.adb{background:var(--grey-light);border-radius:8px;padding:12px 14px}
.adb-lbl{font-size:.6rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.adb-val{font-size:.88rem;font-weight:800;color:var(--navy-dark)}
/* Wartungs-Timeline */
.wartungs-tl{display:flex;flex-direction:column;gap:0}
.wtl-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--grey-mid);cursor:pointer;transition:background .12s;border-radius:6px;padding:10px 8px}
.wtl-item:hover{background:var(--orange-bg)}
.wtl-item:last-child{border-bottom:none}
.wtl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}
/* Kunde bearbeiten badge */
.kunde-edit-btn{opacity:0;transition:opacity .15s;font-size:.65rem;padding:3px 9px}
tr:hover .kunde-edit-btn{opacity:1}
/* Aktivitäts-Feed Item neu */
.activity-item{cursor:default}
/* Termin in Plantafel - neu Button */
.pf-add-btn{position:absolute;top:4px;right:4px;background:var(--orange);color:#fff;border:none;border-radius:4px;font-size:.6rem;padding:2px 7px;cursor:pointer;opacity:0;transition:opacity .15s;z-index:5;font-family:"Montserrat",sans-serif;font-weight:700}
.pf-day:hover .pf-add-btn{opacity:1}
/* ═══════════════════════════════════════════
   LOGIN OVERLAY
═══════════════════════════════════════════ */
#loginOverlay{position:fixed;inset:0;background:var(--navy-dark);z-index:9999;display:flex;align-items:center;justify-content:center}
#loginOverlay.hidden{display:none}
.login-box{background:#fff;border-radius:14px;padding:44px 48px;width:420px;box-shadow:0 24px 80px rgba(0,0,0,.4)}
.login-logo{font-size:.75rem;font-weight:900;letter-spacing:2.5px;color:var(--orange);text-transform:uppercase;margin-bottom:4px}
.login-sub{font-size:.6rem;font-weight:600;letter-spacing:1.5px;color:var(--grey);text-transform:uppercase;margin-bottom:32px}
.login-title{font-size:1.3rem;font-weight:900;color:var(--navy-dark);margin-bottom:6px}
.login-hint{font-size:.72rem;color:var(--grey);margin-bottom:28px}
.login-label{font-size:.65rem;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:5px}
.login-input{width:100%;padding:11px 14px;border:1.5px solid var(--grey-border);border-radius:8px;font-family:'Montserrat',sans-serif;font-size:.82rem;color:var(--navy-dark);outline:none;margin-bottom:16px;transition:border-color .15s}
.login-input:focus{border-color:var(--orange)}
.login-btn{width:100%;padding:13px;background:var(--orange);color:#fff;border:none;border-radius:8px;font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:opacity .15s;margin-top:4px}
.login-btn:hover{opacity:.88}
.login-btn:disabled{opacity:.5;cursor:not-allowed}
.login-error{background:var(--red-light);color:var(--red);border-radius:7px;padding:10px 14px;font-size:.72rem;font-weight:600;margin-bottom:16px;display:none}
.login-error.show{display:block}
.login-footer{font-size:.6rem;color:var(--grey);text-align:center;margin-top:20px}

/* Auge-Icon Login-Feld */
#loginOverlay .apikey-wrap4 {
  position: relative;
  display: block;
}
#loginOverlay .apikey-eye {
  position: absolute;
  right: 12px;
  bottom: 8px;
  font-size: 1.1rem;
  opacity: 1;
  color: #1a3a5c;
  background: none;
  border: none;
  cursor: pointer;
  line-height: 1;
}
