:root{
  --ink:#101828; --text:#243042; --muted:#667085; --muted2:#98a2b3;
  --bg:#f5f7fb; --panel:#ffffff; --panel2:#f9fbfe; --line:#e4e9f2; --line2:#edf1f7;
  --blue:#0b5cad; --blue2:#084b8f; --blue3:#06365f; --sky:#eaf4ff; --sky2:#f2f8ff;
  --orange:#ff9f1c; --orange2:#f97316; --green:#16a34a; --red:#dc2626; --amber:#d97706;
  --greenSoft:#e7f8ee; --redSoft:#fff0f0; --amberSoft:#fff6dc; --blueSoft:#eaf4ff;
  --shadow:0 18px 48px rgba(16,24,40,.09); --shadowSoft:0 6px 18px rgba(16,24,40,.06);
  --radius:22px; --radius2:15px; --fieldH:46px; --sidebarW:286px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
.layout{display:flex;min-height:100vh;background:linear-gradient(135deg,#f7faff 0%,#eef4fb 52%,#f8fbff 100%)}
.sidebar{width:var(--sidebarW);min-width:var(--sidebarW);background:linear-gradient(180deg,#062e55 0%,#0a4f8c 50%,#062e55 100%);color:#eaf4ff;position:sticky;top:0;height:100vh;padding:0;display:flex;flex-direction:column;box-shadow:10px 0 30px rgba(8,55,99,.18);z-index:10}
.brand{padding:26px 22px 22px;border-bottom:1px solid rgba(255,255,255,.13);display:flex;gap:14px;align-items:center;background:rgba(0,0,0,.10)}
.brand img{width:42px;height:42px;border-radius:13px;background:#fff;object-fit:contain;padding:4px;box-shadow:0 6px 18px rgba(0,0,0,.15)}
.brand strong{display:block;font-size:24px;font-weight:900;letter-spacing:.1px;color:white}.brand small{display:block;font-size:12px;color:#bedcf7;margin-top:3px;font-weight:700}
.nav{padding:14px 12px;display:flex;flex-direction:column;gap:5px;overflow:auto}.nav::before{content:'Navigation';font-size:11px;text-transform:uppercase;letter-spacing:.11em;color:#94caf7;padding:10px 12px 7px;font-weight:900}
.nav a{display:flex;align-items:center;gap:11px;padding:12px 12px;border-radius:15px;color:#ddecfb;font-weight:800;border-left:3px solid transparent;transition:background .13s ease,transform .10s ease,color .13s ease,border-color .13s ease;min-height:45px}
.nav a span{width:25px;text-align:center;font-size:17px}.nav a:hover{background:rgba(255,255,255,.12);transform:translateX(2px);color:white}.nav a.active,.nav a[aria-current="page"]{background:#fff;color:#0b4c86;border-left-color:var(--orange);box-shadow:0 10px 24px rgba(0,0,0,.14)}
.main{flex:1;min-width:0;padding:28px 32px 36px}.page-shell{max-width:1480px;margin:0 auto}.footer-note{text-align:center;color:#98a2b3;font-size:12px;margin:30px 0 4px}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}.h1{font-size:32px;line-height:1.08;font-weight:900;letter-spacing:-.035em;color:var(--ink)}.sub{color:var(--muted);margin-top:7px}.page-actions,.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.messages{margin-bottom:16px}.msg{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0;padding:12px 15px;border-radius:14px;font-weight:800;box-shadow:var(--shadowSoft)}
.card{background:var(--panel);border:1px solid var(--line2);border-radius:var(--radius);box-shadow:var(--shadowSoft);padding:20px;margin-bottom:18px;overflow:auto}.card:hover{box-shadow:var(--shadow)}.card h2{margin:0 0 14px;font-size:19px;color:var(--ink);letter-spacing:-.02em}.section-title,.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(214px,1fr));gap:16px;margin:18px 0}.metric{font-size:34px;font-weight:900;letter-spacing:-.04em;color:var(--ink);line-height:1}.metric-label{font-size:13px;color:var(--muted);font-weight:800;margin-top:8px}.kpi-positive .metric{color:var(--green)}.kpi-danger .metric{color:var(--red)}.kpi-amber .metric{color:var(--amber)}
.btn,button.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:9px 14px;border-radius:14px;border:1px solid #dbe5f0;background:#fff;color:#172033;font-weight:850;cursor:pointer;box-shadow:0 4px 12px rgba(16,24,40,.04);transition:transform .08s ease,box-shadow .13s ease,background .13s ease,border-color .13s ease;white-space:nowrap;font-size:14px}.btn:hover,button.btn:hover{transform:translateY(-1px);box-shadow:var(--shadowSoft);border-color:#bcd0e8}.btn.primary{background:var(--blue);border-color:var(--blue);color:white}.btn.primary:hover{background:var(--blue2);border-color:var(--blue2)}.btn.accent{background:var(--orange);border-color:var(--orange);color:#111827}.btn.success{background:var(--greenSoft);border-color:#bbf7d0;color:#166534}.btn.danger{background:var(--redSoft);border-color:#fecaca;color:#991b1b}.btn.small{min-height:34px;padding:6px 10px;font-size:13px;border-radius:11px}.btn.ghost{background:#f8fafc;color:#344054}
input,select,textarea{width:100%;min-height:var(--fieldH);padding:10px 13px;border:1px solid #d7e0ea;border-radius:14px;background:#fff;color:#172033;font:inherit;outline:none;box-shadow:0 1px 2px rgba(16,24,40,.03);transition:border-color .13s ease,box-shadow .13s ease,background .13s ease}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(11,92,173,.11)}textarea{min-height:96px;resize:vertical}label{display:block;font-size:13px;color:#4b5563;font-weight:800;margin-bottom:6px}.hint{color:var(--muted);font-size:12px;margin-top:4px}.muted{color:var(--muted)}.warn{color:#a16207}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:14px 18px}.compact-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px 16px}.form-row{margin:0}.form-row.full{grid-column:1/-1}.form-row label{font-size:13px;color:#5b6473;font-weight:800}form p{margin:0 0 12px}form ul.errorlist{color:#b91c1c;font-size:13px;margin:5px 0 0;padding-left:18px}
.table-wrap{overflow:auto;border:1px solid var(--line2);border-radius:18px;background:#fff;box-shadow:var(--shadowSoft)}.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;min-width:760px}.table th{background:#f8fafc;color:#64748b;text-align:left;padding:13px 14px;border-bottom:1px solid var(--line);font-size:12px;letter-spacing:.06em;text-transform:uppercase}.table td{padding:13px 14px;border-bottom:1px solid #eef2f7;vertical-align:middle}.table tr:hover td{background:#f7fbff}.table tr:last-child td{border-bottom:0}.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:900;background:#eef2ff;color:#3730a3;border:1px solid #e0e7ff}.badge.green{background:var(--greenSoft);color:#166534;border-color:#bbf7d0}.badge.red{background:var(--redSoft);color:#991b1b;border-color:#fecaca}.badge.amber{background:var(--amberSoft);color:#92400e;border-color:#fde68a}.empty-state{padding:28px;text-align:center;color:var(--muted);background:#fff;border:1px dashed #cbd5e1;border-radius:18px}.split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}
/* WISO-inspirierte Arbeitsdialoge */.work-dialog{background:#fff;border:1px solid #e5ebf3;border-radius:24px;box-shadow:var(--shadow);overflow:hidden;margin-bottom:18px}.work-dialog-header{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 26px;border-bottom:1px solid #edf2f7;background:#fff}.work-title{display:flex;align-items:center;gap:16px}.work-icon{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:#dff0ff;color:var(--blue);font-size:24px}.work-title h1{margin:0;font-size:28px;letter-spacing:-.03em;color:var(--ink)}.work-close{width:44px;height:44px;border:1px solid #dbe5f0;border-radius:14px;display:grid;place-items:center;color:#64748b;background:#fff;font-size:25px}.work-body{padding:24px 26px;background:#fff}.work-section-title{font-size:19px;font-weight:900;color:#182235;margin:0 0 18px;border-top:1px solid #e9eef5;padding-top:20px}.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}.field-wide{grid-column:1/-1}.sticky-actions{position:sticky;bottom:0;display:flex;justify-content:flex-end;gap:12px;padding:16px 26px;border-top:1px solid #edf2f7;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);z-index:5}.item-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:15px;margin-bottom:12px}.item-title{font-weight:900;color:#334155;margin-bottom:10px}.info-card{border-left:5px solid var(--blue);background:var(--sky)}.action-card{display:block;background:#fff;border:1px solid #e7edf5;border-radius:22px;padding:26px;text-align:center;box-shadow:var(--shadowSoft);transition:.13s ease}.action-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#cddbea}.action-icon{width:70px;height:70px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;background:#fff7ed;color:var(--orange2);border:1px dashed #fdba74;font-size:30px}.action-card h2{margin:0 0 8px}.document-preview{max-width:920px;margin:0 auto;background:white}.doc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.doc-title{font-size:1.35rem;font-weight:900;color:#0f172a}.doc-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:28px}.mt{margin-top:22px}.sum-box{margin-left:auto;margin-top:18px;max-width:320px;border:1px solid #e2e8f0;border-radius:14px;padding:14px;background:#f8fafc}.sum-box div{display:flex;justify-content:space-between;margin:4px 0}.sum-box .gross{border-top:1px solid #cbd5e1;padding-top:8px;margin-top:8px;font-size:1.05rem}.grid.two-col{display:grid;grid-template-columns:minmax(340px,.9fr) minmax(440px,1.3fr);gap:18px;align-items:start}.stacked-form{display:flex;flex-direction:column;gap:12px}.stat-row{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.mini-stat{background:#f7f9fc;border:1px solid #e4e8f0;border-radius:14px;padding:12px 14px;min-width:130px}.mini-stat strong{display:block;font-size:25px;color:#0f172a}.mini-stat span{color:#64748b;font-size:12px}.service-box{display:grid;grid-template-columns:170px 1.5fr 90px 90px 130px;gap:8px;align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:10px;margin-bottom:8px}.check-line{display:flex;gap:8px;align-items:center;margin-top:8px}
/* Beta-1 Feinschliff */
.workspace-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.11em;color:var(--blue);font-weight:900;margin-bottom:7px}.focus-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:12px 0 20px}.focus-item{background:#fff;border:1px solid #e7edf5;border-radius:18px;padding:14px 16px;box-shadow:var(--shadowSoft)}.focus-item b{display:block;font-size:20px;color:var(--ink)}.focus-item span{font-size:12px;color:var(--muted);font-weight:750}.quickline{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.soft-panel{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid #e7edf5;border-radius:22px;padding:18px;box-shadow:var(--shadowSoft)}.form-card{background:#fbfdff;border:1px solid #e7edf5;border-radius:18px;padding:16px;margin-bottom:14px}.form-card-title{font-size:15px;font-weight:900;color:#172033;margin-bottom:12px;display:flex;align-items:center;gap:8px}.form-card-title::before{content:'';width:9px;height:9px;border-radius:50%;background:var(--blue);display:inline-block}.table-actions{display:flex;gap:6px;flex-wrap:wrap}.page-help{background:#f8fbff;border:1px solid #dceafe;border-radius:18px;padding:13px 15px;color:#475569;margin-bottom:16px}.page-help strong{color:#0b4c86}.drawer-title{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:#97c8f4;font-weight:900;padding:18px 12px 4px}.mobile-top{display:none}.compact-form input,.compact-form select{min-height:42px}.sticky-actions .btn{min-width:132px}
@media(max-width:1050px){.layout{display:block}.sidebar{position:relative;width:100%;height:auto;min-width:0}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.main{padding:18px}.work-grid,.form-grid,.split,.grid.two-col{grid-template-columns:1fr}.work-dialog-header{padding:18px}.work-body{padding:18px}.sticky-actions{padding:14px 18px}.service-box{grid-template-columns:1fr}.doc-grid{grid-template-columns:1fr}.mobile-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.brand{padding:18px 20px}.sidebar{box-shadow:none}.topbar{align-items:flex-start}.work-title h1{font-size:25px}}
@media(max-width:620px){.nav{grid-template-columns:1fr}.main{padding:12px}.topbar{display:block}.cards{grid-template-columns:1fr}.btn{width:100%}.page-actions,.toolbar{display:grid;grid-template-columns:1fr}.h1{font-size:26px}.work-title h1{font-size:24px}.sticky-actions{display:grid;grid-template-columns:1fr}.work-dialog{border-radius:18px}.card{border-radius:18px;padding:16px}.table{min-width:680px}}

.flow-steps{display:flex;gap:8px;margin:0 24px 12px 24px;flex-wrap:wrap}.flow-steps span{padding:9px 14px;border-radius:14px;background:#eef3fb;color:#465064;font-size:.9rem;font-weight:700}.flow-steps span.active{background:#1d75d8;color:#fff}.sticky-actions .success,.btn.success{background:#15a66a;color:#fff;border-color:#15a66a}.warning-card{background:#fff8e8;border-color:#ffd78a}.detail-actions{flex-wrap:wrap}.table-actions{display:flex;gap:6px;flex-wrap:wrap}.invoice-flow .form-card{scroll-margin-top:20px}.badge.yellow{background:#fff3cd;color:#946200;border:1px solid #ffe199}

/* v1.0 beta 2.2 · Sidebar-Cover-Effekt */
:root{--sidebarCollapsed:78px;--sidebarExpanded:286px;}
.sidebar-cover .layout{align-items:stretch;}
.sidebar-cover .sidebar{
  width:var(--sidebarCollapsed);
  min-width:var(--sidebarCollapsed);
  transition:width .22s ease,min-width .22s ease,box-shadow .22s ease;
  overflow:hidden;
}
.sidebar-cover .sidebar:hover,
.sidebar-cover.sidebar-locked .sidebar{
  width:var(--sidebarExpanded);
  min-width:var(--sidebarExpanded);
  box-shadow:16px 0 38px rgba(8,55,99,.22);
}
.sidebar-toggle{
  position:absolute;top:14px;right:14px;z-index:30;
  width:44px;height:44px;border:0;border-radius:14px;
  background:rgba(255,255,255,.14);color:#fff;font-size:20px;font-weight:900;
  cursor:pointer;display:grid;place-items:center;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
  transition:background .15s ease,transform .12s ease;
}
.sidebar-toggle:hover{background:rgba(255,255,255,.24);transform:translateY(-1px)}
.sidebar-cover .brand{height:94px;padding:22px 14px;justify-content:flex-start;gap:12px;white-space:nowrap;}
.sidebar-cover .brand img{width:48px;height:48px;min-width:48px;border-radius:16px;}
.sidebar-cover .brand-text{opacity:0;transform:translateX(-8px);width:0;overflow:hidden;transition:opacity .18s ease,transform .18s ease,width .18s ease;}
.sidebar-cover .sidebar:hover .brand-text,
.sidebar-cover.sidebar-locked .brand-text{opacity:1;transform:translateX(0);width:190px;}
.sidebar-cover .nav{padding:12px 9px;gap:6px;overflow-x:hidden;}
.sidebar-cover .nav::before{content:'';height:8px;padding:0;}
.sidebar-cover .nav a{
  position:relative;min-height:48px;padding:11px 12px;border-radius:17px;gap:12px;
  justify-content:flex-start;white-space:nowrap;
}
.sidebar-cover .nav a .nav-ico{
  width:32px;height:32px;min-width:32px;border-radius:12px;
  display:grid;place-items:center;font-size:18px;text-align:center;
  background:rgba(255,255,255,.10);
}
.sidebar-cover .nav a.active .nav-ico,
.sidebar-cover .nav a[aria-current="page"] .nav-ico{background:#eaf4ff;}
.sidebar-cover .nav-text{
  opacity:0;transform:translateX(-8px);max-width:0;overflow:hidden;
  transition:opacity .16s ease,transform .16s ease,max-width .18s ease;
}
.sidebar-cover .sidebar:hover .nav-text,
.sidebar-cover.sidebar-locked .nav-text{opacity:1;transform:translateX(0);max-width:210px;}
.sidebar-cover .drawer-title{
  height:12px;opacity:.42;padding:10px 0 0 0;margin:2px 0 0 0;border-top:1px solid rgba(255,255,255,.10);
  transition:height .18s ease,opacity .18s ease,padding .18s ease;
}
.sidebar-cover .drawer-title span{display:block;opacity:0;transform:translateX(-8px);transition:opacity .16s ease,transform .16s ease;}
.sidebar-cover .sidebar:hover .drawer-title,
.sidebar-cover.sidebar-locked .drawer-title{height:auto;opacity:1;padding:16px 12px 4px;}
.sidebar-cover .sidebar:hover .drawer-title span,
.sidebar-cover.sidebar-locked .drawer-title span{opacity:1;transform:translateX(0);}
.sidebar-cover .main{transition:padding .18s ease;}
.sidebar-cover .work-dialog,
.sidebar-cover .card{scroll-margin-left:var(--sidebarExpanded);}
@media(max-width:1050px){
  .sidebar-cover .layout{display:block;}
  .sidebar-cover .sidebar{
    position:fixed;left:0;top:0;bottom:0;height:100vh;width:var(--sidebarCollapsed);min-width:var(--sidebarCollapsed);z-index:1000;
  }
  .sidebar-cover.sidebar-locked .sidebar{width:var(--sidebarExpanded);min-width:var(--sidebarExpanded);}
  .sidebar-cover .sidebar:not(:hover):not(.open) .brand-text,
  .sidebar-cover .sidebar:not(:hover):not(.open) .nav-text{display:block;}
  .sidebar-cover .main{padding-left:calc(var(--sidebarCollapsed) + 18px);}
  .sidebar-cover.sidebar-locked .main{padding-left:calc(var(--sidebarCollapsed) + 18px);}
  .sidebar-cover .nav{display:flex;}
  .sidebar-cover .sidebar:hover{width:var(--sidebarCollapsed);min-width:var(--sidebarCollapsed);}
  .sidebar-cover.sidebar-locked .sidebar:hover{width:var(--sidebarExpanded);min-width:var(--sidebarExpanded);}
  .sidebar-cover .sidebar:hover .brand-text,
  .sidebar-cover .sidebar:hover .nav-text,
  .sidebar-cover .sidebar:hover .drawer-title span{opacity:0;max-width:0;}
  .sidebar-cover.sidebar-locked .sidebar .brand-text,
  .sidebar-cover.sidebar-locked .sidebar .nav-text,
  .sidebar-cover.sidebar-locked .sidebar .drawer-title span{opacity:1;max-width:210px;transform:translateX(0);}
  .sidebar-cover.sidebar-locked::after{content:'';position:fixed;inset:0;background:rgba(15,23,42,.22);z-index:900;pointer-events:none;}
}
@media(pointer:coarse){
  .sidebar-cover .sidebar:hover{width:var(--sidebarCollapsed);min-width:var(--sidebarCollapsed);}
  .sidebar-cover.sidebar-locked .sidebar{width:var(--sidebarExpanded);min-width:var(--sidebarExpanded);}
  .sidebar-cover .sidebar:hover .brand-text,
  .sidebar-cover .sidebar:hover .nav-text,
  .sidebar-cover .sidebar:hover .drawer-title span{opacity:0;max-width:0;}
  .sidebar-cover.sidebar-locked .sidebar .brand-text,
  .sidebar-cover.sidebar-locked .sidebar .nav-text,
  .sidebar-cover.sidebar-locked .sidebar .drawer-title span{opacity:1;max-width:210px;transform:translateX(0);}
}

/* v1.0 beta 2.4 · Sidebar-Cover Text-Fix
   Fix: Beschriftungen werden beim Hover zuverlässig sichtbar, auch bei schmaleren Browserfenstern. */
.sidebar-cover .nav a .nav-text,
.sidebar-cover .brand .brand-text,
.sidebar-cover .drawer-title span{
  display:inline-block !important;
  white-space:nowrap !important;
}
.sidebar-cover .sidebar:hover .nav-text,
.sidebar-cover.sidebar-locked .sidebar .nav-text{
  opacity:1 !important;
  transform:translateX(0) !important;
  max-width:230px !important;
  width:auto !important;
  overflow:visible !important;
}
.sidebar-cover .sidebar:hover .brand-text,
.sidebar-cover.sidebar-locked .sidebar .brand-text{
  opacity:1 !important;
  transform:translateX(0) !important;
  width:200px !important;
  max-width:200px !important;
  overflow:visible !important;
}
.sidebar-cover .sidebar:hover .drawer-title span,
.sidebar-cover.sidebar-locked .sidebar .drawer-title span{
  opacity:1 !important;
  transform:translateX(0) !important;
  max-width:220px !important;
  overflow:visible !important;
}
.sidebar-cover .sidebar:hover .drawer-title,
.sidebar-cover.sidebar-locked .sidebar .drawer-title{
  height:auto !important;
  opacity:1 !important;
  padding:16px 12px 4px !important;
}
/* Bei schmalem Desktop-Fenster Hover trotzdem erlauben. Nur echte Touch-Geräte nutzen den Menü-Button als Hauptsteuerung. */
@media(max-width:1050px) and (pointer:fine){
  .sidebar-cover .sidebar:hover{width:var(--sidebarExpanded) !important;min-width:var(--sidebarExpanded) !important;}
  .sidebar-cover .sidebar:hover .brand-text{opacity:1 !important;max-width:200px !important;width:200px !important;transform:translateX(0) !important;}
  .sidebar-cover .sidebar:hover .nav-text{opacity:1 !important;max-width:230px !important;width:auto !important;transform:translateX(0) !important;overflow:visible !important;}
  .sidebar-cover .sidebar:hover .drawer-title span{opacity:1 !important;max-width:220px !important;transform:translateX(0) !important;}
}

/* v1.0 beta 3 · Monatsrechnung und kompaktere Auswahlfelder */
.monthly-services{display:flex;flex-direction:column;gap:10px;margin:10px 0 14px}
.service-row{display:grid;grid-template-columns:175px minmax(180px,1.35fr) 92px 90px 130px;gap:8px;align-items:end;background:#f8fbff;border:1px solid #e3ecf6;border-radius:16px;padding:10px 12px;box-shadow:0 3px 10px rgba(16,24,40,.03)}
.service-check{display:flex;align-items:center;gap:8px;margin:0;font-weight:900;color:#172033;white-space:nowrap}.service-check input{width:auto;min-height:auto;box-shadow:none}
.monthly-services input,.compact-form input,.compact-form select{min-height:38px;padding:8px 10px;border-radius:11px;font-size:14px}.check-line{display:flex;align-items:center;gap:9px;margin:8px 0 2px;font-size:13px}.check-line input{width:auto;min-height:auto;box-shadow:none}.warning-card ul{margin:0;padding-left:20px;color:#92400e}.section-head form{margin:0}
@media(max-width:900px){.service-row{grid-template-columns:1fr 1fr}.service-check{grid-column:1/-1}}
/* v1.0_beta_3.1 Monatsrechnung: Tabs und Abo-Vorlagen */
.tabs-bar{display:flex;gap:.6rem;flex-wrap:wrap;margin:1rem 0 1.2rem}
.tab-chip{display:inline-flex;align-items:center;gap:.4rem;border:1px solid #dbe4f0;background:#fff;color:#334155;border-radius:999px;padding:.55rem .9rem;text-decoration:none;font-weight:700;font-size:.92rem;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.tab-chip:hover{background:#f8fafc;border-color:#b8c8dc}
.tab-chip.active{background:#eaf2ff;color:#174ea6;border-color:#b7cff5}
.abo-box{border:1px solid #dbe4f0;background:#f8fafc;border-radius:14px;padding:1rem;margin-top:1rem}
.mt-3{margin-top:1.2rem}
.btn.danger{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
.btn.danger:hover{background:#ffe4e6}


/* v1.0 beta 3.8 · Backup-Menü sichtbar im Systembereich */
.nav a.nav-backup { border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.08); }
.nav a.nav-backup:hover { background: rgba(255,255,255,.18); }
.nav a.nav-backup.active { background: #fff; color: #0b4c86; }
.sidebar .nav { padding-bottom: 28px; }
.sidebar-cover .nav { padding-bottom: 36px; }

/* v1.0 beta 3.9 · gezielter UI-Feinschliff: Details, Kundenakte, Monatsrechnung, Tabellen, iPad */
.detail-topbar{align-items:center}.detail-topbar .h1{font-size:34px}.detail-actions{max-width:920px;justify-content:flex-end}
.detail-hero{display:grid;grid-template-columns:minmax(260px,.95fr) 2fr;gap:16px;margin:0 0 18px;padding:22px;border-radius:26px;border:1px solid #dfe8f5;background:linear-gradient(135deg,#ffffff 0%,#eef6ff 58%,#fff8ec 100%);box-shadow:var(--shadowSoft);overflow:hidden;position:relative}.detail-hero:before{content:'';position:absolute;right:-80px;top:-110px;width:260px;height:260px;border-radius:999px;background:rgba(255,159,28,.18)}.hero-main,.hero-facts{position:relative;z-index:1}.hero-main h2{font-size:38px;line-height:1;margin:12px 0 6px;color:var(--ink);letter-spacing:-.04em}.hero-main p{margin:0;color:var(--muted);font-weight:750}.hero-facts{display:grid;grid-template-columns:repeat(3,minmax(140px,1fr));gap:12px;align-content:stretch}.hero-facts div{background:rgba(255,255,255,.78);border:1px solid rgba(215,224,234,.82);border-radius:18px;padding:15px;box-shadow:0 4px 14px rgba(16,24,40,.04)}.hero-facts span,.info-list span,.sum-row span{display:block;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.055em;margin-bottom:5px}.hero-facts strong,.info-list strong{display:block;color:var(--ink);font-size:16px;line-height:1.25}.detail-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.7fr);gap:18px}.info-card{overflow:visible}.info-list{display:grid;grid-template-columns:repeat(2,minmax(160px,1fr));gap:12px}.info-list.two{grid-template-columns:repeat(2,minmax(160px,1fr))}.info-list div,.address-box,.note-box,.notice-line{background:#f8fbff;border:1px solid #e7edf6;border-radius:16px;padding:13px 14px}.address-box{font-weight:800;color:#172033;margin-bottom:12px}.note-box,.notice-line{margin-top:12px}.totals-card{background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}.sum-row{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid #edf1f7;padding:13px 0}.sum-row strong{font-size:18px;color:var(--ink)}.sum-row.total{border-bottom:0;margin-top:6px;padding-top:16px}.sum-row.total strong{font-size:30px;letter-spacing:-.04em}.status-bezahlt,.badge.green{background:var(--greenSoft)!important;color:#166534!important;border:1px solid #bbf7d0}.status-storniert,.badge.red{background:var(--redSoft)!important;color:#991b1b!important;border:1px solid #fecaca}.status-entwurf,.status-teilbezahlt,.badge.yellow{background:var(--amberSoft)!important;color:#92400e!important;border:1px solid #fde68a}.status-erstellt,.status-versendet{background:var(--blueSoft)!important;color:#174ea6!important;border:1px solid #bfdbfe}.object-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.object-card{display:flex;flex-direction:column;gap:5px}.object-card span{color:var(--muted)}.empty-state.compact{padding:14px;border-radius:14px;margin:0}.table-modern{border-collapse:separate;border-spacing:0 7px;background:transparent}.table-modern th{background:transparent;color:#667085;font-size:12px;text-transform:uppercase;letter-spacing:.06em;border:0;padding:7px 12px}.table-modern td{background:#fff;border-top:1px solid #edf1f7;border-bottom:1px solid #edf1f7;padding:12px}.table-modern tr td:first-child{border-left:1px solid #edf1f7;border-radius:14px 0 0 14px}.table-modern tr td:last-child{border-right:1px solid #edf1f7;border-radius:0 14px 14px 0}.table-modern tr:hover td{background:#f8fbff;border-color:#dbeafe}.action-table .table-actions{justify-content:flex-start}.row-check{width:20px;min-height:20px;box-shadow:none}.process-strip{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 18px}.process-step,.process-strip span{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid #dfe8f5;border-radius:999px;padding:10px 14px;color:#465064;font-weight:850;box-shadow:0 2px 9px rgba(16,24,40,.04)}.process-step b{width:24px;height:24px;border-radius:999px;background:#eef4fb;color:#174ea6;display:grid;place-items:center}.process-step.active,.process-strip span.active{background:#eaf4ff;border-color:#bfdbfe;color:#174ea6}.monthly-card{overflow:visible}.monthly-card .section-head{align-items:flex-start}.service-panel{background:#f8fbff;border:1px solid #e7edf6;border-radius:18px;padding:10px}.sticky-runbar{position:sticky;bottom:14px;z-index:5;margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 14px;border-radius:18px;background:rgba(255,255,255,.92);border:1px solid #dbe5f0;box-shadow:0 14px 36px rgba(16,24,40,.11);backdrop-filter:blur(10px)}.sticky-runbar strong{display:block;color:var(--ink)}.sticky-runbar span{display:block;color:var(--muted);font-size:13px;font-weight:750}.table-actions{align-items:center}.table-actions .btn.primary + .btn.primary{background:#fff;color:#172033;border-color:#dbe5f0}.table-actions .btn{box-shadow:none}
@media(max-width:1180px){.detail-hero{grid-template-columns:1fr}.hero-facts{grid-template-columns:repeat(3,1fr)}.detail-grid{grid-template-columns:1fr}.detail-actions{justify-content:flex-start;max-width:100%}}
@media(max-width:900px){.hero-facts,.info-list,.info-list.two{grid-template-columns:1fr}.detail-hero{padding:18px;border-radius:20px}.hero-main h2{font-size:32px}.sticky-runbar{position:static;align-items:flex-start;flex-direction:column}.sticky-runbar .btn{width:100%}.table-modern{border-spacing:0}.table-modern tr{display:block;margin:0 0 12px;border:1px solid #edf1f7;border-radius:16px;overflow:hidden;background:#fff}.table-modern th{display:none}.table-modern td{display:flex;justify-content:space-between;gap:14px;border:0!important;border-radius:0!important;padding:10px 12px}.table-modern td:before{content:attr(data-label);font-weight:900;color:#667085}.table-modern td .table-actions{justify-content:flex-end}.action-table .table-actions{flex-direction:column;align-items:stretch}.action-table .table-actions .btn{width:100%}}
@media(min-width:768px) and (max-width:1180px){.main{padding:24px 24px 34px}.topbar{flex-direction:column}.page-actions,.toolbar{justify-content:flex-start}.card{padding:18px}.service-row{grid-template-columns:1fr 1fr}.service-check{grid-column:1/-1}.monthly-services input{min-height:44px}.btn{min-height:44px}.sidebar-cover .main{padding-left:calc(var(--sidebarCollapsed) + 22px)}}
@media(max-width:760px){.main{padding:18px 14px 28px}.sidebar-cover .main{padding-left:calc(var(--sidebarCollapsed) + 10px)}.detail-topbar .h1{font-size:27px}.detail-actions .btn{width:100%}.hero-main h2{font-size:28px}.process-strip{gap:7px}.process-step,.process-strip span{width:100%;border-radius:15px;justify-content:flex-start}.service-row{grid-template-columns:1fr}.split{grid-template-columns:1fr!important}}

/* v1.0 beta 3.9.1 · harmonischere Positionsmaske */
.invoice-flow .form-card{background:#fff;border-color:#e7edf5;box-shadow:0 10px 28px rgba(16,24,40,.035)}
.invoice-flow .form-card-title{font-size:18px;letter-spacing:-.01em}
.invoice-flow #position-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.invoice-flow .position-form{position:relative;margin:0;padding:16px 18px 17px;border-radius:20px;background:linear-gradient(180deg,#fbfdff 0%,#f7faff 100%);border:1px solid #e4ebf4;box-shadow:0 6px 18px rgba(16,24,40,.035)}
.invoice-flow .position-form .item-title{display:flex;align-items:center;gap:8px;margin:0 0 14px;color:#1f2937;font-size:15px;font-weight:950}.invoice-flow .position-form .item-title:before{content:'';width:8px;height:8px;border-radius:999px;background:#1d75d8;box-shadow:0 0 0 4px rgba(29,117,216,.11)}
.invoice-flow .position-form .compact-grid{display:grid;grid-template-columns:minmax(230px,2fr) minmax(90px,.65fr) minmax(90px,.65fr) minmax(125px,.85fr) minmax(130px,.9fr);gap:12px 14px;align-items:end;padding-right:42px}
.invoice-flow .position-form .compact-grid .form-row:nth-child(1){grid-column:span 1}.invoice-flow .position-form .compact-grid .form-row:nth-child(6){grid-column:span 1}.invoice-flow .position-form .compact-grid .form-row:nth-child(7){grid-column:span 2}
.invoice-flow .position-form label{font-size:12px;margin-bottom:5px;color:#5d6675}.invoice-flow .position-form input,.invoice-flow .position-form select{min-height:40px;border-radius:13px;background:#fff}.invoice-flow .position-form input:focus{background:#fff}
.invoice-flow .position-form .form-row:has(input[name$='-DELETE']){position:absolute;top:15px;right:16px;width:auto;margin:0;display:flex;align-items:center;justify-content:center}.invoice-flow .position-form .form-row:has(input[name$='-DELETE']) label{display:none}.invoice-flow .position-form input[name$='-DELETE']{appearance:none;-webkit-appearance:none;width:28px!important;height:28px!important;min-height:28px!important;padding:0!important;margin:0;border-radius:10px;border:1px solid #d3dce8;background:#fff;box-shadow:0 2px 6px rgba(16,24,40,.05);cursor:pointer;display:grid;place-items:center}.invoice-flow .position-form input[name$='-DELETE']:before{content:'×';font-size:20px;line-height:1;color:#94a3b8;font-weight:800;position:relative;top:-1px}.invoice-flow .position-form input[name$='-DELETE']:hover{border-color:#fecaca;background:#fff5f5}.invoice-flow .position-form input[name$='-DELETE']:hover:before{color:#b91c1c}.invoice-flow .position-form input[name$='-DELETE']:checked{background:#fee2e2;border-color:#fca5a5}.invoice-flow .position-form input[name$='-DELETE']:checked:before{color:#991b1b}
.invoice-flow .section-head{align-items:center;margin-bottom:8px}.invoice-flow .section-head .hint{margin:0;max-width:720px}.invoice-flow #add-position{border-radius:13px;min-height:38px;box-shadow:none;background:#fff}
.invoice-flow .abo-box{background:#fbfdff;border-color:#e4ebf4;border-radius:18px}.invoice-flow .sticky-actions{gap:10px}.invoice-flow .sticky-actions .btn{border-radius:13px}
@media(max-width:1240px){.invoice-flow .position-form .compact-grid{grid-template-columns:minmax(220px,1.5fr) minmax(90px,.7fr) minmax(90px,.7fr);}.invoice-flow .position-form .compact-grid .form-row:nth-child(7){grid-column:span 2}}
@media(max-width:820px){.invoice-flow .position-form{padding:15px}.invoice-flow .position-form .compact-grid{grid-template-columns:1fr;padding-right:0}.invoice-flow .position-form .compact-grid .form-row:nth-child(7){grid-column:auto}.invoice-flow .position-form .form-row:has(input[name$='-DELETE']){position:static;justify-content:flex-start;margin-top:2px}.invoice-flow .position-form .form-row:has(input[name$='-DELETE']) label{display:block;margin:0 8px 0 0}.invoice-flow .position-form input[name$='-DELETE']{width:22px!important;height:22px!important;min-height:22px!important;border-radius:7px}.invoice-flow .section-head{align-items:stretch;flex-direction:column}.invoice-flow #add-position{width:100%}}

/* v1.0 beta 3.9.2 · Positionsmaske tatsächlich harmonisiert */
.invoice-flow #position-list{gap:14px}
.invoice-flow .position-form{padding:14px 16px 16px;border-radius:18px;background:#fbfcff;border:1px solid #e6edf5;box-shadow:0 5px 14px rgba(16,24,40,.035)}
.invoice-flow .position-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.invoice-flow .position-form .item-title{margin:0;font-size:14px;font-weight:900;color:#263244;display:flex;align-items:center;gap:8px}
.invoice-flow .position-form .item-title:before{content:'';width:7px;height:7px;border-radius:50%;background:#1d75d8;box-shadow:0 0 0 4px rgba(29,117,216,.10)}
.invoice-flow .position-grid{display:grid;grid-template-columns:minmax(260px,2fr) 110px 110px 150px 150px;gap:11px 14px;align-items:end}
.invoice-flow .position-grid .pos-description{grid-column:span 1}
.invoice-flow .position-grid .pos-laid{grid-column:1 / span 1}
.invoice-flow .position-grid .pos-latext{grid-column:2 / span 2}
.invoice-flow .position-grid label{font-size:12px;color:#667085;margin-bottom:5px}
.invoice-flow .position-grid input,.invoice-flow .position-grid select{min-height:39px;border-radius:12px;background:#fff}
.invoice-flow .position-delete-field{display:none!important}
.invoice-flow .position-delete-toggle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:999px;border:1px solid #dde6f0;background:#fff;color:#94a3b8;font-size:20px;line-height:1;font-weight:800;margin:0;cursor:pointer;box-shadow:0 2px 7px rgba(16,24,40,.04);transition:.12s ease}
.invoice-flow .position-delete-toggle:hover{background:#fff1f1;border-color:#fecaca;color:#b91c1c;transform:translateY(-1px)}
.invoice-flow .position-delete-field input:checked + *{display:none}
.invoice-flow .position-form:has(.position-delete-field input:checked){opacity:.45;background:#fff5f5;border-color:#fecaca}
.invoice-flow .position-form:has(.position-delete-field input:checked) .position-delete-toggle{background:#fee2e2;color:#991b1b;border-color:#fca5a5}
@media(max-width:1180px){.invoice-flow .position-grid{grid-template-columns:minmax(240px,1.7fr) 110px 110px 150px}.invoice-flow .position-grid .pos-article{grid-column:span 1}.invoice-flow .position-grid .pos-laid{grid-column:auto}.invoice-flow .position-grid .pos-latext{grid-column:span 2}}
@media(max-width:820px){.invoice-flow .position-form{padding:13px}.invoice-flow .position-grid{grid-template-columns:1fr 1fr}.invoice-flow .position-grid .pos-description,.invoice-flow .position-grid .pos-latext{grid-column:1/-1}.invoice-flow .position-grid .pos-laid{grid-column:auto}.invoice-flow .position-card-head{margin-bottom:10px}}
@media(max-width:560px){.invoice-flow .position-grid{grid-template-columns:1fr}}

/* v1.0 beta 3.9.3: Angebots-Positionsmaske übernimmt die harmonische Rechnungsmaske */
.invoice-flow .offer-position-grid{grid-template-columns:minmax(260px,2fr) 110px 110px 150px 150px;}
@media(max-width:1180px){.invoice-flow .offer-position-grid{grid-template-columns:minmax(240px,1.7fr) 110px 110px 150px}.invoice-flow .offer-position-grid .pos-article{grid-column:span 1}}
@media(max-width:820px){.invoice-flow .offer-position-grid{grid-template-columns:1fr 1fr}.invoice-flow .offer-position-grid .pos-description{grid-column:1/-1}}
@media(max-width:560px){.invoice-flow .offer-position-grid{grid-template-columns:1fr}}

/* v1.0 beta 3.10 · Offene Posten, Zahlungsstatus, manuelle Zahlungserfassung */
.status-ueberfaellig,.status-gemahnt,.badge.amber{background:var(--amberSoft)!important;color:#92400e!important;border:1px solid #fde68a}.status-gemahnt{background:#fff1f2!important;color:#9f1239!important;border-color:#fecdd3}.row-warning td{background:#fffaf0!important;border-color:#fde68a!important}.open-items-filter{align-items:end}.open-items-filter input[type=search]{min-width:280px;flex:1}.row-actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap}.inline-form{display:inline;margin:0}.btn.small{min-height:30px;padding:6px 10px;border-radius:10px;font-size:12px}.btn.success{background:#ecfdf3;border-color:#bbf7d0;color:#166534}.btn.success:hover{background:#dcfce7}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:14px}.form-grid .field:last-of-type{grid-column:1/-1}.form-actions{grid-column:1/-1;display:flex;gap:10px;justify-content:flex-end}.field label{display:block;font-size:12px;font-weight:900;color:#667085;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.field-error{font-size:12px;color:#991b1b;margin-top:4px}.table-modern.action-table td:last-child{min-width:260px}.metric{letter-spacing:-.04em}@media(max-width:900px){.form-grid{grid-template-columns:1fr}.open-items-filter input[type=search]{min-width:0;width:100%}.row-actions{justify-content:flex-end}.table-modern.action-table td:last-child{min-width:0}.table-modern td:before{content:attr(data-label)}}
