:root{--bg:#f4f6f8;--panel:#ffffff;--text:#16202a;--muted:#667085;--line:#e5e7eb;--primary:#111827;--danger:#b42318;--success:#047857;--shadow:0 12px 30px rgba(15,23,42,.08);--radius:18px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}a{color:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{width:280px;background:#0f172a;color:#fff;padding:22px;display:flex;flex-direction:column;gap:18px;position:fixed;inset:0 auto 0 0;overflow:auto}.brand{display:flex;align-items:center;gap:12px}.brand.centered{justify-content:center;margin-bottom:22px}.brand-mark{width:42px;height:42px;border-radius:14px;background:#fff;color:#0f172a;display:grid;place-items:center;font-weight:800}.brand span{display:block;font-size:13px;color:#cbd5e1;margin-top:2px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar nav a,.logout{padding:10px 13px;border-radius:12px;text-decoration:none;color:#dbeafe;font-size:14px}.sidebar nav a:hover,.sidebar nav a.active{background:rgba(255,255,255,.1);color:#fff}.logout{margin-top:auto;color:#fecaca}.content{margin-left:280px;padding:28px;width:calc(100% - 280px)}.topbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px;gap:16px}.topbar h1{margin:0;font-size:30px;letter-spacing:-.03em}.topbar p{margin:6px 0 0;color:var(--muted)}.badge,.pill{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;padding:5px 10px;background:#fff;color:var(--muted);font-size:12px}.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;overflow:auto}.card h2{margin:0 0 16px;font-size:18px}.card.stat span{display:block;color:var(--muted);font-size:13px}.card.stat strong{display:block;margin-top:8px;font-size:24px;letter-spacing:-.03em}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:minmax(380px,.9fr) minmax(500px,1.2fr)}.narrow{max-width:980px}table{width:100%;border-collapse:collapse}th,td{padding:12px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em}.right{text-align:right}.actions{white-space:nowrap;display:flex;gap:8px;flex-wrap:wrap}.muted{color:var(--muted)}hr{border:0;border-top:1px solid var(--line);margin:18px 0}form label{display:flex;flex-direction:column;gap:7px;font-size:14px;color:#344054}input,select,textarea{width:100%;border:1px solid #d0d5dd;border-radius:12px;padding:11px 12px;font:inherit;background:#fff;color:var(--text)}textarea{min-height:90px;resize:vertical}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid hr,.full-row{grid-column:1/-1}.button{border:0;border-radius:12px;padding:11px 14px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font:inherit;background:#eef2f7;color:#111827;font-weight:650}.button.primary{background:var(--primary);color:#fff}.button.ghost{background:#fff;border:1px solid var(--line)}.button.small{padding:7px 10px;font-size:12px}.button.full{width:100%}.export-buttons{display:flex;gap:12px;flex-wrap:wrap}.alert{padding:13px 15px;border-radius:14px;margin:0 0 16px;background:#ecfdf3;color:#027a48;border:1px solid #abefc6}.alert.danger{background:#fef3f2;color:var(--danger);border-color:#fecdca}.login-body{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(160deg,#0f172a 0%,#1e293b 45%,#f4f6f8 45%)}.login-card{width:min(440px,100%);background:#fff;border-radius:24px;padding:28px;box-shadow:0 20px 50px rgba(2,6,23,.25)}.setup-card{width:min(760px,100%)}.login-card form{display:grid;gap:14px}.line-editor{border:1px solid var(--line);border-radius:16px;padding:12px;background:#fafafa}.line-header,.line-row{display:grid;grid-template-columns:2fr .6fr .8fr .6fr 44px;gap:8px;align-items:center;margin-bottom:8px}.line-header{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.toolbar{margin-bottom:16px;display:flex;gap:10px}.paper{background:#fff;border:1px solid var(--line);border-radius:8px;padding:36px;max-width:950px;margin:auto;box-shadow:var(--shadow)}.paper-head{display:flex;justify-content:space-between;gap:24px;border-bottom:2px solid #111827;padding-bottom:22px;margin-bottom:22px}.paper h2{font-size:36px;margin:0;letter-spacing:-.04em}.doc-number{font-size:18px;color:var(--muted);margin:6px 0 0}.company{text-align:right;line-height:1.6}.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}.doc-grid h3{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 8px}.doc-table tfoot td{border-bottom:0}.payment-note{background:#f8fafc;border-radius:12px;padding:14px}.paper-footer{border-top:1px solid var(--line);margin-top:24px;padding-top:14px;color:var(--muted);font-size:13px}@media(max-width:1150px){.cards{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.two{grid-template-columns:1fr}}@media(max-width:850px){.sidebar{position:static;width:auto}.app-shell{display:block}.content{margin-left:0;width:auto;padding:18px}.cards{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.line-header{display:none}.line-row{grid-template-columns:1fr 1fr}.line-row input:first-child{grid-column:1/-1}.paper-head,.doc-grid{grid-template-columns:1fr;display:grid}.company{text-align:left}}@media print{body{background:#fff}.sidebar,.topbar,.no-print,.alert{display:none!important}.content{margin:0;padding:0;width:100%}.paper{box-shadow:none;border:0;border-radius:0;max-width:none}.app-shell{display:block}a{text-decoration:none}}

.settings-heading{margin:18px 0 4px;padding-top:12px;border-top:1px solid rgba(255,255,255,.12);font-size:1rem}

.grid.preview-grid{grid-template-columns:minmax(420px,1.1fr) minmax(420px,.9fr);align-items:start}.invoice-preview{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#f8fafc}.preview-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line);background:#fff}.invoice-preview iframe{width:100%;height:72vh;min-height:560px;border:0;background:#fff}.invoice-preview img{display:block;max-width:100%;height:auto;margin:auto}.raw-text{margin-top:14px}.raw-text pre{white-space:pre-wrap;max-height:260px;overflow:auto;background:#0f172a;color:#e5e7eb;border-radius:12px;padding:12px;font-size:12px}.alert.info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}@media(max-width:1150px){.grid.preview-grid{grid-template-columns:1fr}.invoice-preview iframe{height:60vh;min-height:420px}}

.danger-text{color:#b91c1c;font-weight:600;}


.product-search-box{border:1px solid var(--line);border-radius:16px;padding:14px;background:#f8fafc;margin-bottom:14px}.product-search-box h3{margin:0 0 6px}.product-search-controls{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}.product-search-results{display:grid;gap:10px;margin-top:12px;max-height:460px;overflow:auto}.product-result{display:grid;grid-template-columns:72px 1fr 140px;gap:12px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px}.product-result-main small,.product-result-price small{display:block;color:var(--muted);margin-top:4px}.product-result-price{text-align:right;display:grid;gap:5px;justify-items:end}.product-result-img,.product-thumb{width:64px;height:64px;object-fit:contain;border:1px solid var(--line);border-radius:12px;background:#fff}.product-result-img.placeholder,.product-thumb.placeholder{display:grid;place-items:center;text-align:center;color:var(--muted);font-size:11px;background:#f1f5f9}.product-cell{display:flex;gap:12px;align-items:flex-start}.small-link{font-size:12px;color:#1d4ed8;text-decoration:none}.small-link:hover{text-decoration:underline}@media(max-width:850px){.product-search-controls{grid-template-columns:1fr}.product-result{grid-template-columns:56px 1fr}.product-result-price{grid-column:1/-1;text-align:left;justify-items:start}.product-result-img,.product-thumb{width:52px;height:52px}}

.brand-logo-wrap{display:flex;align-items:center;justify-content:center;background:transparent;border-radius:14px;padding:0;min-width:54px;min-height:54px}.brand-logo{display:block;max-height:62px;width:auto;object-fit:contain}.sidebar-logo{max-height:62px}.login-logo{max-height:96px}.doc-logo{display:block;max-height:105px;width:auto;margin:0 0 16px}.logo-settings{border:1px solid var(--line);border-radius:16px;padding:14px;background:#f8fafc}.logo-settings h3{margin:0 0 10px}.logo-preview-box{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:12px}.logo-preview{display:block;max-height:110px;width:auto;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:8px}.checkbox-label input{width:auto}.paper-head .doc-logo+h2{margin-top:0}
.button.danger{background:#fef3f2;border:1px solid #fecdca;color:#b42318}.button.danger:hover{background:#fee4e2}.toolbar{flex-wrap:wrap}.checkbox-label{flex-direction:row;align-items:center}.checkbox-label input{width:auto}

.unit-price-box{background:#fff7ed;border-color:#fed7aa}.unit-price-icon{width:64px;height:64px;border-radius:14px;background:#0f172a;color:#fff;display:grid;place-items:center;font-weight:800;font-size:22px}.unit-price-result .product-result-price{gap:6px}.inline-form select{min-width:180px}@media(max-width:850px){.unit-price-icon{width:52px;height:52px}}

.quick-list-panel{border-color:#bfdbfe;background:#eff6ff}.quick-list-actions{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0}.quick-list-preview{margin-top:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;max-height:260px;overflow:auto}.quick-list-preview ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}.quick-list-preview li{border-bottom:1px solid var(--line);padding-bottom:8px}.quick-list-preview li:last-child{border-bottom:0;padding-bottom:0}.quick-list-preview small{display:block;color:var(--muted);margin-top:3px}.quick-list-import{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0 0 12px;padding:12px;border:1px solid var(--line);border-radius:16px;background:#eff6ff}.quick-list-toast{position:fixed;right:24px;bottom:24px;background:#111827;color:#fff;border-radius:14px;padding:12px 16px;box-shadow:0 16px 40px rgba(15,23,42,.25);opacity:0;transform:translateY(12px);transition:.2s ease;z-index:9999;pointer-events:none}.quick-list-toast.show{opacity:1;transform:translateY(0)}@media(max-width:850px){.quick-list-import,.quick-list-actions{display:grid;grid-template-columns:1fr}.quick-list-toast{left:18px;right:18px;bottom:18px}}
.code-box{background:#f6f7fb;border:1px solid #dfe3ee;border-radius:12px;padding:14px;margin:12px 0;word-break:break-all}.code-box code{font-size:16px;letter-spacing:1px}

/* v4.7 mobiel + app-layout */
.button.danger{background:#b42318;color:#fff}.button.danger.ghost{background:#fff;color:#b42318;border:1px solid #fecdca}.subtle-card{box-shadow:none;background:#f8fafc;margin:14px 0}.mobile-menu-button,.mobile-nav-close,.mobile-nav-overlay{display:none}.topbar-title{min-width:0}.trust-device-check{margin-top:-4px;background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:10px 12px;color:#344054}.trust-device-check input{width:auto}.mobile-nav-close{margin-left:auto;width:38px;height:38px;border:0;border-radius:12px;background:rgba(255,255,255,.1);color:#fff;font-size:28px;line-height:1;cursor:pointer}.mobile-menu-button{width:44px;height:44px;border:1px solid var(--line);background:#fff;border-radius:14px;align-items:center;justify-content:center;flex-direction:column;gap:5px;box-shadow:0 8px 18px rgba(15,23,42,.06);flex:0 0 auto}.mobile-menu-button span{display:block;width:20px;height:2px;background:#111827;border-radius:999px}.mobile-nav-overlay{position:fixed;inset:0;background:rgba(2,6,23,.48);z-index:45;opacity:0;pointer-events:none;transition:opacity .18s ease}.product-result{border:1px solid var(--line);border-radius:16px;padding:12px;display:grid;grid-template-columns:76px 1fr auto;gap:12px;align-items:center;margin:10px 0;background:#fff}.product-result-img{width:72px;height:72px;object-fit:contain;border:1px solid var(--line);border-radius:12px;background:#f8fafc}.product-result-img.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;text-align:center}.product-result-main strong,.product-result-main small{display:block}.product-result-main small{color:var(--muted);margin-top:4px}.product-result-price{display:flex;align-items:flex-end;gap:8px;flex-direction:column}.unit-price-icon{width:56px;height:56px;border-radius:16px;background:#eef2f7;display:grid;place-items:center;font-weight:800;color:#111827}.quick-list-toast{position:fixed;right:18px;bottom:18px;background:#111827;color:#fff;border-radius:14px;padding:12px 14px;box-shadow:0 16px 36px rgba(2,6,23,.22);z-index:80;opacity:0;transform:translateY(12px);pointer-events:none;transition:.18s}.quick-list-toast.show{opacity:1;transform:translateY(0)}

@media(max-width:850px){
  body.nav-open{overflow:hidden}.app-shell{display:block;min-height:100dvh}.mobile-menu-button{display:inline-flex}.mobile-nav-close{display:inline-grid;place-items:center}.mobile-nav-overlay{display:block}.nav-open .mobile-nav-overlay{opacity:1;pointer-events:auto}.sidebar{position:fixed;inset:0 auto 0 0;width:min(86vw,330px);height:100dvh;z-index:60;transform:translateX(-104%);transition:transform .2s ease;box-shadow:18px 0 45px rgba(2,6,23,.28);border-radius:0;padding:18px}.nav-open .sidebar{transform:translateX(0)}.sidebar nav a,.logout{font-size:16px;padding:13px 14px}.brand{align-items:center}.brand-logo{max-width:150px;height:auto}.content{margin-left:0;width:100%;padding:14px}.topbar{position:sticky;top:0;z-index:35;background:rgba(244,246,248,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);margin:-14px -14px 16px;padding:12px 14px;align-items:center}.topbar h1{font-size:21px;line-height:1.1}.topbar p{display:none}.badge{font-size:11px;padding:4px 8px}.card{border-radius:16px;padding:14px;margin-bottom:14px;box-shadow:0 8px 22px rgba(15,23,42,.06)}.card h2{font-size:17px}.cards{grid-template-columns:1fr;gap:12px}.grid.two,.grid{grid-template-columns:1fr!important;gap:14px}.form-grid{grid-template-columns:1fr!important;gap:12px}.toolbar,.export-buttons,.actions{gap:8px}.actions{white-space:normal}.actions .button{flex:1 1 auto}.button{min-height:42px}.button.small{min-height:36px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:680px}th,td{padding:10px 8px}.line-editor{padding:10px}.line-row{grid-template-columns:1fr 1fr!important;gap:8px;padding:10px 0;border-bottom:1px solid var(--line)}.line-row:last-child{border-bottom:0}.line-row input:first-child{grid-column:1/-1}.line-row button{width:100%}.product-result{grid-template-columns:64px 1fr;align-items:start}.product-result-img{width:60px;height:60px}.product-result-price{grid-column:1/-1;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap}.product-result-price .button{flex:1 1 120px}.paper{padding:18px;border-radius:14px}.paper h2{font-size:26px}.paper-head,.doc-grid{display:grid;grid-template-columns:1fr}.company{text-align:left}.login-body{padding:16px}.login-card{padding:20px;border-radius:20px}.login-logo{max-height:76px}.brand.centered{flex-direction:column;text-align:center}.quick-list-toast{left:12px;right:12px;bottom:12px;text-align:center}
}

/* v4.8 compacte mobiele weergave - alleen actief op telefoon/tablet */
@media(max-width:850px){
  :root{--radius:14px}
  .content{padding:10px}.topbar{margin:-10px -10px 10px;padding:9px 10px;gap:9px}.topbar h1{font-size:18px}.mobile-menu-button{width:40px;height:40px;border-radius:12px}.badge{display:none}.card{padding:10px;border-radius:13px;margin-bottom:10px}.card h2{font-size:15px;margin-bottom:10px}.card p{margin-top:6px;margin-bottom:8px}.muted{font-size:12px;line-height:1.35}

  /* Dashboard/BTW-cijfers als compacte tegels in plaats van enorme blokken */
  .cards{grid-template-columns:repeat(auto-fit,minmax(118px,1fr))!important;gap:8px;margin-bottom:10px}.card.stat{padding:9px 10px;min-height:70px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.card.stat span{font-size:11px;line-height:1.15;white-space:normal}.card.stat strong{font-size:17px;line-height:1.1;margin-top:5px;letter-spacing:-.02em;word-break:break-word}

  /* Formulieren compacter: korte velden naast elkaar, lange velden volledige breedte */
  .form-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px}.form-grid .full-row,.form-grid hr,.form-grid label.full-row,.form-grid label:has(textarea),.form-grid label:has(input[type=file]){grid-column:1/-1}form label{gap:4px;font-size:12px}input,select,textarea{padding:8px 9px;border-radius:10px;font-size:14px}textarea{min-height:72px}.button{min-height:36px;padding:8px 10px;border-radius:10px;font-size:13px}.button.small{min-height:30px;padding:6px 8px}.toolbar,.export-buttons{gap:6px;margin-bottom:10px}.actions{gap:6px}.actions .button{flex:0 1 auto}

  /* Offerte-/factuurregels compacter */
  .line-editor{padding:8px;border-radius:12px}.line-row{grid-template-columns:1.4fr .55fr .75fr .65fr 32px!important;gap:5px;align-items:end;padding:7px 0}.line-row input:first-child{grid-column:auto}.line-row input,.line-row select{font-size:13px;padding:7px 8px}.line-row .button,.line-row button{min-height:32px;padding:6px 8px}.line-header{display:none}

  /* Zoekresultaten/producten minder hoog */
  .product-search-box{padding:10px;border-radius:13px;margin-bottom:10px}.product-search-box h3{font-size:15px;margin-bottom:4px}.product-search-controls{gap:6px}.product-search-results{gap:6px;margin-top:8px;max-height:58vh}.product-result{grid-template-columns:46px 1fr auto!important;gap:8px;padding:8px;border-radius:12px;margin:6px 0}.product-result-img,.product-thumb{width:44px;height:44px;border-radius:9px}.product-result-main strong{font-size:13px;line-height:1.25}.product-result-main small{font-size:11px;line-height:1.25;margin-top:2px}.product-result-price{grid-column:auto!important;align-items:flex-end;justify-content:center;gap:4px;min-width:88px}.product-result-price strong{font-size:13px}.product-result-price small{font-size:10px}.product-result-price .button{min-height:30px;padding:6px 8px;font-size:12px;flex:0 0 auto}.unit-price-icon{width:44px;height:44px;border-radius:12px;font-size:14px}

  /* Tabellen en lijsten iets rustiger op mobiel */
  th,td{padding:8px 6px;font-size:13px}th{font-size:10px}.table-wrap{border:1px solid var(--line);border-radius:12px;background:#fff}table{min-width:580px}.quick-list-import{padding:9px;border-radius:12px;margin-bottom:8px}.quick-list-preview{padding:9px;max-height:180px}.alert{padding:9px 10px;border-radius:12px;font-size:13px;margin-bottom:10px}.grid.two,.grid{gap:10px!important}
}

@media(max-width:420px){
  .cards{grid-template-columns:repeat(2,minmax(0,1fr))!important}.card.stat strong{font-size:15px}.form-grid{grid-template-columns:1fr 1fr!important}.line-row{grid-template-columns:1fr 62px 76px 62px 30px!important}.line-row input,.line-row select{font-size:12px;padding:6px}.product-result{grid-template-columns:40px 1fr!important}.product-result-price{grid-column:1/-1!important;display:grid;grid-template-columns:1fr auto;align-items:center;width:100%;min-width:0}.product-result-img,.product-thumb{width:38px;height:38px}.product-result-price .button{justify-self:end}
}

/* v5.2 gebruikers + werkbonnen */
.workorder-list{display:grid;gap:.75rem}
.workorder-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1rem;align-items:center;border:1px solid rgba(148,163,184,.18);border-radius:18px;padding:1rem;background:rgba(15,23,42,.42)}
.workorder-card h3{margin:.1rem 0 .25rem;font-size:1rem}
.workorder-card p{margin:.2rem 0}
.workorder-actions{display:flex;align-items:center;justify-content:flex-end;gap:.4rem;flex-wrap:wrap}
.workorder-detail-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.75rem;margin:1rem 0}
.workorder-detail-grid>div{border:1px solid rgba(148,163,184,.16);border-radius:14px;padding:.75rem;background:rgba(15,23,42,.35);min-height:70px}
.preline{white-space:pre-line}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.5rem;margin-top:.75rem}
.photo-grid a{display:block;border:1px solid rgba(148,163,184,.18);border-radius:12px;padding:.65rem;background:rgba(15,23,42,.35);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pill.success{background:rgba(34,197,94,.14);color:#bbf7d0;border-color:rgba(34,197,94,.35)}
.pill.danger{background:rgba(239,68,68,.14);color:#fecaca;border-color:rgba(239,68,68,.35)}
.checkbox-label{display:flex!important;gap:.55rem;align-items:center;justify-content:flex-start;min-height:44px}
.checkbox-label input[type=checkbox]{width:auto;min-width:18px;height:18px}
@media (max-width: 900px){
  .workorder-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}
  .workorder-detail-grid>div{padding:.6rem;min-height:auto}
  .workorder-card{grid-template-columns:1fr;padding:.75rem;border-radius:14px;gap:.6rem}
  .workorder-actions{justify-content:flex-start}
  .workorder-card h3{font-size:.95rem}
  .photo-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 560px){
  .workorder-detail-grid{grid-template-columns:1fr 1fr}
  .workorder-detail-grid strong{display:block;font-size:.78rem;color:#94a3b8;margin-bottom:.15rem}
  .workorder-card .button.small{padding:.45rem .55rem;font-size:.78rem}
  .photo-grid{grid-template-columns:1fr}
}

/* v5.3 klantportaal */
.customer-portal-stats .stat strong { font-size: clamp(1.4rem, 5vw, 2.1rem); }
.customer-portal-stats { margin-bottom: 1rem; }
@media (max-width: 720px) {
  .customer-portal-stats.cards { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .55rem; }
  .customer-portal-stats .card.stat { padding: .75rem; min-height: auto; }
  .customer-portal-stats .stat span { font-size: .78rem; }
  .customer-portal-stats .stat strong { font-size: 1.25rem; }
}

/* v5.4 planning + routes */
.planning-filter{align-items:end;margin-bottom:.8rem}.planning-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin:.75rem 0 1rem}.planning-map{border:1px solid rgba(148,163,184,.2);border-radius:18px;overflow:hidden;background:rgba(15,23,42,.35);height:260px;margin:.85rem 0}.planning-map iframe{width:100%;height:100%;border:0;filter:saturate(.92)}.route-list{display:grid;gap:.65rem;margin:1rem 0}.route-stop{display:grid;grid-template-columns:42px minmax(0,1fr) auto;gap:.75rem;align-items:center;border:1px solid rgba(148,163,184,.18);border-radius:16px;padding:.8rem;background:rgba(15,23,42,.42)}.route-stop-number{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:rgba(59,130,246,.18);color:#dbeafe;font-weight:800}.route-stop h3{margin:.05rem 0 .2rem;font-size:1rem}.route-stop p{margin:.15rem 0}.route-stop-actions{display:flex;gap:.4rem;align-items:center;justify-content:flex-end;flex-wrap:wrap}.planning-note{border-left:3px solid rgba(56,189,248,.55);padding-left:.55rem;color:#bae6fd;font-size:.92rem}
@media(max-width:720px){.planning-filter.form-grid{grid-template-columns:1fr 1fr!important}.planning-actions .button{flex:1 1 46%;justify-content:center}.planning-map{height:190px;border-radius:14px}.route-stop{grid-template-columns:34px minmax(0,1fr);gap:.55rem;padding:.65rem;border-radius:14px}.route-stop-number{width:28px;height:28px;font-size:.85rem}.route-stop-actions{grid-column:1/-1;justify-content:flex-start}.route-stop h3{font-size:.92rem}.route-stop p,.planning-note{font-size:.82rem}.route-stop-actions .button.small{padding:.42rem .55rem;font-size:.76rem}}
@media(max-width:420px){.planning-filter.form-grid{grid-template-columns:1fr!important}.planning-actions .button{flex:1 1 100%}.planning-map{height:170px}}

/* v5.5 werkbonnen / monteur registratie */
.workorder-timer-card .workorder-quick-actions,
.workorder-quick-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: .65rem;
  align-items: stretch;
}
.workorder-quick-actions form { margin: 0; }
.workorder-quick-actions .button { width: 100%; justify-content: center; min-height: 44px; }
.button.success { background: #16a34a; color: #fff; border-color: #16a34a; }
.workorder-time-log { margin-top: 1rem; }
.workorder-materials-box {
  border: 1px solid var(--border, #d8dde8);
  border-radius: 16px;
  padding: 1rem;
  background: rgba(15, 23, 42, .025);
}
.workorder-material-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .5rem;
  margin-bottom: .75rem;
}
.workorder-product-results {
  display: grid;
  gap: .5rem;
  margin-bottom: .75rem;
}
.workorder-product-result {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .5rem;
  align-items: center;
  border: 1px solid var(--border, #d8dde8);
  border-radius: 12px;
  padding: .6rem .7rem;
  background: #fff;
}
.workorder-material-table input {
  width: 100%;
  min-width: 0;
}
.workorder-material-table th,
.workorder-material-table td {
  vertical-align: middle;
}
@media (max-width: 760px) {
  .workorder-timer-card .workorder-quick-actions,
  .workorder-quick-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .45rem;
  }
  .workorder-material-search { grid-template-columns: 1fr; }
  .workorder-product-result { grid-template-columns: 1fr; }
  .workorder-product-result .button { width: 100%; }
  .workorder-materials-box { padding: .7rem; border-radius: 12px; }
  .workorder-material-table th:nth-child(4),
  .workorder-material-table td:nth-child(4) { display: none; }
}

/* v5.6 werkboncontrole */
.workorder-review-actions .button { margin-right: .4rem; }
.workorder-detail-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:.75rem; }
.preline { white-space:pre-line; }
@media (max-width: 760px){
  .workorder-detail-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); gap:.5rem; }
  .workorder-detail-grid div{ font-size:.9rem; }
}

/* v5.7 serviceverzoeken / openbaar meldformulier */
.service-request-list{display:grid;gap:1rem}
.service-request-card{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem;border:1px solid var(--border);border-radius:18px;padding:1rem;background:rgba(255,255,255,.02)}
.service-request-main h3{margin:.1rem 0 .25rem}
.service-request-actions{display:grid;gap:.75rem;align-content:start}
.service-request-actions form{background:rgba(15,23,42,.035);border:1px solid var(--border);border-radius:14px;padding:.75rem;display:grid;gap:.55rem}
.service-request-actions h4{margin:.1rem 0 .25rem;font-size:.95rem}
.section-title.compact{align-items:flex-start;margin-bottom:.6rem}
.workorder-detail-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr));gap:.6rem;margin:.65rem 0}
.service-attachments{margin-top:.75rem}
.public-service-page{min-height:100vh;background:radial-gradient(circle at top left,#0f365f 0,#020617 38%,#020617 100%);color:#e5e7eb}
.public-service-shell{min-height:100vh;display:grid;place-items:center;padding:1rem}
.public-service-card{width:min(920px,100%);background:rgba(15,23,42,.94);border:1px solid rgba(148,163,184,.22);border-radius:26px;padding:1.25rem;box-shadow:0 24px 80px rgba(0,0,0,.38)}
.public-service-brand{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}
.public-service-brand h1{margin:0;font-size:clamp(1.45rem,4vw,2.1rem);color:#fff}
.public-service-brand p{margin:.25rem 0 0;color:#cbd5e1}
.public-service-card label{color:#e5e7eb}
.public-service-card input,.public-service-card textarea,.public-service-card select{background:#fff;color:#0f172a;border-color:#334155}
.public-service-card .button.ghost{border-color:rgba(148,163,184,.55);color:#e5e7eb}
.public-service-form{margin-top:.5rem}
@media (max-width: 850px){
  .service-request-card{grid-template-columns:1fr;padding:.8rem}
  .workorder-detail-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}
  .service-request-actions form{padding:.65rem}
}
@media (max-width: 560px){
  .public-service-shell{padding:.6rem;place-items:start center}
  .public-service-card{border-radius:18px;padding:.9rem}
  .public-service-brand{align-items:flex-start;gap:.75rem}
  .public-service-brand .brand-logo-wrap{max-width:95px}
}
