:root{--bg: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--ink: #0f172a;--ink-2: #334155;--ink-3: #64748b;--amber: #f59e0b;--amber-ink: #b45309;--amber-on-dark: #fbbf24;--amber-bg: #fffbeb;--amber-border: #fde68a;--amber-bg-strong: #fef3c7;--ok: #15803d;--ok-bg: #dcfce7;--danger: #b91c1c;--text-on-dark: #e2e8f0;--topbar-h: 64px;--radius: 8px;--radius-s: 6px;--shadow: 0 1px 2px rgba(15, 23, 42, .05);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .25);--font: "Inter", system-ui, sans-serif;color-scheme:light}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink-2);font-family:var(--font);font-size:14px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.btn{border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:var(--radius-s);padding:8px 14px;font:inherit;font-weight:600;cursor:pointer}.btn-primary{background:var(--ink);border-color:var(--ink);color:#fff}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-s);padding:7px 10px;font:inherit;width:100%}.price{color:var(--amber-ink);font-weight:700}.topbar{display:flex;align-items:center;gap:16px;height:var(--topbar-h);padding:0 16px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:relative;z-index:10}.logo b{letter-spacing:.1em;font-size:16px;color:var(--ink)}.logo b span{color:var(--amber)}.topbar-meta{color:var(--ink-3);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.account-page{max-width:560px;margin:0 auto;padding:24px 16px}.account-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.account-title{margin:0;font-size:20px;color:var(--ink)}.account-card{padding:16px;display:flex;flex-direction:column;gap:10px}.account-card+.account-card{margin-top:16px}.account-h2{font-size:14px;font-weight:700;color:var(--ink);margin:0 0 10px}.field{display:flex;flex-direction:column;gap:4px}.field>span{font-size:12px;font-weight:600;color:var(--ink-3)}.field textarea{resize:vertical}.logo-upload{display:flex;align-items:center;gap:10px}.logo-upload input[type=file]{display:none}.logo-preview{max-width:120px;max-height:40px;object-fit:contain}.logo-placeholder{color:var(--ink-3);font-size:12px}.logo-upload-actions{display:flex;gap:6px}.toast-stack{position:fixed;right:16px;bottom:16px;z-index:100;display:flex;flex-direction:column;gap:8px}.toast{max-width:340px;padding:10px 14px;border-radius:var(--radius-s);color:#fff;cursor:pointer;box-shadow:var(--shadow-lg)}.toast-info{background:var(--ink)}.toast-error{background:var(--danger)}.app-grid{display:grid;grid-template-columns:1fr 1.35fr .9fr;gap:12px;padding:12px;min-height:calc(100vh - var(--topbar-h));align-items:stretch}.bottom-bar{display:none}@media (max-width: 1199px){.app-grid{grid-template-columns:1fr 1.2fr;padding-bottom:var(--topbar-h)}.summary-col{display:none}.bottom-bar{display:flex;position:fixed;left:0;right:0;bottom:0;background:var(--ink);color:var(--text-on-dark);padding:10px 16px;justify-content:space-between;align-items:center}}@media (max-width: 799px){.app-grid{grid-template-columns:1fr}.canvas-col{position:sticky;top:0;z-index:5;max-height:40vh}.canvas-col .canvas-wrap{overflow:hidden}}.canvas-col{display:flex;flex-direction:column;gap:10px;padding:12px;min-width:0}.canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.door-canvas{display:block;max-width:100%;max-height:100%;touch-action:none;cursor:default}.door-canvas.draw-mode{cursor:crosshair}.roedes-toolbar{display:flex;flex-direction:column;gap:6px}.roedes-hint{font-size:11px;color:var(--ink-3)}.curve-btns{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.tool-btn{border:1px solid var(--border);background:var(--surface);color:var(--ink-2);border-radius:var(--radius-s);padding:6px 8px;font:inherit;font-size:11px;cursor:pointer;white-space:nowrap}.tool-btn.active{background:var(--ink);border-color:var(--ink);color:#fff}.roedes-actions{display:flex;gap:6px;flex-wrap:wrap}.config-col{display:flex;flex-direction:column;gap:8px;padding:10px}.acc{border:1px solid var(--border);border-radius:var(--radius-s);background:var(--bg)}.acc-open{background:var(--surface);border-left:3px solid var(--amber)}.acc-head{all:unset;display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;padding:8px 10px;cursor:pointer}.acc-head b{color:var(--ink)}.acc-summary{color:var(--ink-3);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.acc-body{padding:4px 10px 12px;display:flex;flex-direction:column;gap:10px}.field-row{display:flex;gap:10px}.field-row>.field{flex:1}.field-row .field-qty{flex:0 0 90px}.base-price-tag{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-s);padding:7px 10px;font-weight:600;color:var(--ink)}.sys-indicator{background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius-s);padding:7px 10px;color:var(--ink-3);font-size:12px}.double-info{background:var(--amber-bg);border:1px solid var(--amber-border);border-radius:var(--radius-s);padding:8px 10px;font-size:12px;color:var(--amber-ink)}.double-info strong{display:block;margin-bottom:2px}.config-footer{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:4px}.add-item-btn{width:100%;padding:11px 14px}.add-item-row{display:flex;gap:8px}.add-item-row .add-item-btn{flex:1;width:auto}.add-item-cancel{padding:11px 14px}.opts-list{display:flex;flex-direction:column;gap:2px}.opts-empty{color:var(--ink-3);font-size:12px;padding:4px 0}.opt-group-header{margin-top:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}.opt-row{display:flex;align-items:flex-start;gap:8px;padding:4px 6px;border-radius:var(--radius-s)}.opt-row.active{background:var(--bg)}.opt-row.locked{opacity:.7}.opt-row>input[type=checkbox]{margin:3px 0 0;accent-color:var(--ink)}.opt-body{flex:1;min-width:0}.opt-top{display:flex;align-items:baseline;gap:8px}.opt-name{flex:1;cursor:pointer}.opt-row.locked .opt-name{cursor:default}.opt-price{white-space:nowrap;font-size:12px;font-weight:700;color:var(--amber-ink)}.opt-price.free{color:var(--ok)}.opt-price.aanvraag{color:var(--ink-3);font-weight:400;font-style:italic}.opt-qty{display:inline-flex;align-items:center;gap:4px}.oq-btn{border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:4px;width:20px;height:20px;line-height:1;padding:0;font:inherit;font-size:12px;cursor:pointer}.oq-val{min-width:14px;text-align:center;font-weight:600;color:var(--ink)}.opt-subnote{font-size:11px;color:var(--ink-3);margin-top:2px}.opt-sub{margin-top:4px}.lock-note{font-size:11px;font-style:normal;color:var(--ink-3)}.lock-note-required{color:var(--amber-ink)}.sliding-banner{background:var(--amber-bg);border:1px solid var(--amber-border);border-radius:var(--radius-s);padding:6px 8px;margin:2px 0;font-size:12px;color:var(--amber-ink)}.uitv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.uitv-btn{border:1px solid var(--border);background:var(--surface);color:var(--ink-3);border-radius:var(--radius-s);padding:6px 4px 4px;font:inherit;font-size:11px;font-weight:600;text-align:center;cursor:pointer}.uitv-btn.selected{border-color:var(--amber);box-shadow:0 0 0 1px var(--amber);color:var(--ink)}.uitv-img-wrap{display:block;height:44px;margin-bottom:2px}.uitv-img-wrap img,.uitv-img-wrap svg{width:100%;height:100%;object-fit:contain;display:block}.handle-group{display:flex;flex-direction:column;gap:10px}.handle-row{display:flex;align-items:center;gap:12px;border:1px dashed var(--border);border-radius:var(--radius-s);background:var(--bg);padding:10px}.handle-row.has-handle{border-style:solid;background:var(--surface)}.handle-row-img{width:48px;height:48px;object-fit:contain}.handle-row-placeholder{font-size:22px;opacity:.4}.handle-row-text{display:flex;flex-direction:column;gap:2px;min-width:0}.handle-row-name{font-weight:600;color:var(--ink)}.handle-row-sub{font-size:12px;color:var(--ink-3)}.handle-row-effect{font-size:12px;color:var(--ok)}.handle-row-height{all:unset;cursor:pointer;font-size:12px;color:var(--amber-ink);text-decoration:underline;text-underline-offset:2px}.handle-group-actions{display:flex;gap:8px}.handle-clear-btn{color:var(--danger)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:720px;max-width:100%;max-height:90vh;display:flex;flex-direction:column}.modal-narrow{width:400px}.confirm-actions{display:flex;justify-content:flex-end;gap:8px;padding:16px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-title{font-weight:700;color:var(--ink)}.modal-close{all:unset;cursor:pointer;font-size:20px;line-height:1;color:var(--ink-3);padding:2px 6px}.modal-close:hover{color:var(--ink)}.modal-filters{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:10px 18px;border-bottom:1px solid var(--border)}.modal-filters-label{font-size:12px;color:var(--ink-3)}.filter-btn{border:1px solid var(--border);background:var(--surface);color:var(--ink-2);border-radius:999px;padding:3px 10px;font:inherit;font-size:12px;cursor:pointer}.filter-btn.active{background:var(--ink);border-color:var(--ink);color:#fff}.modal-body{padding:14px 18px;overflow-y:auto}.handle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.modal-empty{grid-column:1 / -1;color:var(--ink-3);padding:16px 0;text-align:center}.handle-card{border:1px solid var(--border);background:var(--bg);border-radius:var(--radius-s);padding:8px 6px;font:inherit;cursor:pointer;text-align:center;display:flex;flex-direction:column;align-items:center;gap:3px}.handle-card.selected{border-color:var(--amber);box-shadow:0 0 0 1px var(--amber);background:var(--surface)}.handle-img-wrap{display:block;height:56px}.handle-img-wrap img{height:100%;width:100%;object-fit:contain;display:block}.handle-code{font-weight:700;color:var(--ink)}.handle-cat{font-size:11px;color:var(--ink-3)}.handle-price-tag{font-size:10px;font-weight:600;border-radius:999px;padding:1px 6px}.handle-price-tag.incl{background:var(--ok-bg);color:var(--ok)}.handle-price-tag.paid{background:var(--amber-bg-strong);color:var(--amber-ink)}.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;border-top:1px solid var(--border)}.modal-sel-info{display:flex;align-items:center;gap:10px;min-width:0}.modal-sel-img{width:36px;height:36px;object-fit:contain}.modal-sel-code{font-weight:700;color:var(--ink)}.modal-sel-meta{font-size:12px;color:var(--ink-3)}.modal-btns{display:flex;gap:8px}.height-opts{display:flex;flex-direction:column;gap:10px;padding:16px 18px}.height-modal-text{margin:0;font-size:12px;color:var(--ink-3)}.height-opt-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border);background:var(--bg);border-radius:var(--radius-s);padding:10px 12px;font:inherit;cursor:pointer;text-align:left}.height-opt-btn.selected{border-color:var(--amber);box-shadow:0 0 0 1px var(--amber);background:var(--surface)}.height-opt-label{font-weight:600;color:var(--ink)}.height-opt-sub{font-style:normal;font-weight:400;font-size:12px;color:var(--ink-3)}.height-opt-price{white-space:nowrap;font-size:12px;font-weight:700;color:var(--amber-ink)}.height-opt-price.free{color:var(--ok)}.summary-body{display:flex;flex-direction:column;gap:12px;padding:12px;height:100%}.customer-row{border:1px solid var(--border);border-radius:var(--radius-s);background:var(--bg);padding:8px 10px;display:flex;flex-direction:column;gap:8px}.customer-row-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.customer-row-head{font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-toggle{all:unset;cursor:pointer;color:var(--ink-3);padding:2px 6px;border-radius:4px}.edit-toggle:hover{color:var(--ink);background:var(--border)}.edit-toggle:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.customer-fields{display:flex;flex-direction:column;gap:8px}.btw-radio{border:1px solid var(--border);border-radius:var(--radius-s);padding:6px 10px 8px;display:flex;gap:14px}.btw-radio legend{font-size:12px;font-weight:600;color:var(--ink-3);padding:0 4px}.btw-radio label{display:inline-flex;align-items:center;gap:5px}.btw-radio input,.mail-copy-check input{accent-color:var(--ink)}.mail-copy-check{display:flex;align-items:center;gap:6px}.summary-items{flex:1;display:flex;flex-direction:column;gap:4px;min-height:0;overflow-y:auto}.summary-empty{color:var(--ink-3);font-size:12px}.summary-item-line{font-size:13px;color:var(--ink-2);padding:4px 0;border-bottom:1px dashed var(--border);display:flex;align-items:center;gap:6px}.summary-item-line.editing{background:var(--amber-bg)}.summary-item-text{flex:1;min-width:0}.editing-badge{font-size:11px;font-weight:700;color:var(--amber-ink);background:var(--amber-bg-strong);border:1px solid var(--amber-border);border-radius:999px;padding:1px 8px;white-space:nowrap}.item-edit-btn,.item-dupe-btn{font:inherit;font-size:12px;font-weight:600;cursor:pointer;padding:3px 9px;border-radius:4px;line-height:1.4;white-space:nowrap}.item-edit-btn{background:var(--amber-bg);color:var(--amber-ink);border:1px solid var(--amber-border)}.item-edit-btn:hover{background:var(--amber-bg-strong)}.item-dupe-btn{background:transparent;color:var(--ink-3);border:1px solid var(--border)}.item-dupe-btn:hover{background:var(--bg);color:var(--ink);border-color:var(--ink-3)}.item-edit-btn:focus-visible,.item-dupe-btn:focus-visible,.del-btn:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.totals-block{border-top:1px solid var(--border);padding-top:8px;display:flex;flex-direction:column;gap:4px}.total-row{display:flex;justify-content:space-between;gap:12px;font-size:13px}.total-amount{font-weight:600;color:var(--ink)}.total-amount.transport-free{color:var(--ok)}.total-row-big{margin-top:4px;padding-top:6px;border-top:1px solid var(--border);font-size:15px;font-weight:700;color:var(--ink)}.totals-footnote{font-size:11px;color:var(--ink-3);margin-top:4px}.bottom-bar{gap:12px;cursor:pointer;z-index:20}.bottom-bar-meta{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bottom-bar .price{color:var(--amber-on-dark);white-space:nowrap}.bottom-bar-cta{background:var(--amber);border-color:var(--amber);color:var(--ink);white-space:nowrap}.review{padding:12px;display:flex;flex-direction:column;gap:12px;max-width:1200px;margin:0 auto;width:100%}.review-header{display:flex;align-items:center;gap:16px;padding:12px 16px;flex-wrap:wrap}.review-title{margin:0;font-size:17px;color:var(--ink);flex:1;white-space:nowrap}.review-dates{display:flex;align-items:flex-end;gap:10px}.review-dates-text{color:var(--ink-3);font-size:13px}.review-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:12px;align-items:start}.review-left,.review-right{padding:14px;display:flex;flex-direction:column;gap:16px}@media (max-width: 799px){.review-grid{grid-template-columns:1fr}}.items-empty{color:var(--ink-3);font-size:13px}.items-table{width:100%;border-collapse:collapse;font-size:13px}.items-table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);padding:4px 8px;border-bottom:1px solid var(--border)}.items-table td{padding:8px;border-bottom:1px solid var(--border);vertical-align:top}.item-snapshot{height:110px;border-radius:var(--radius-s);border:1px solid var(--border);background:var(--bg);display:block;margin:2px 0 6px}.item-name{font-weight:600;color:var(--ink)}.item-opt-line{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--ink-2);margin-top:2px}.item-opt-cost{white-space:nowrap;font-weight:600;color:var(--amber-ink)}.item-opt-cost.aanvraag{color:var(--ink-3);font-weight:400;font-style:italic}.item-opt-subnote{font-size:11px;color:var(--ink-3);margin-left:14px}.item-dims{white-space:nowrap;color:var(--ink-2)}.item-amount{white-space:nowrap;color:var(--ink)}.item-amount-total{font-weight:700}.qty-ctrl{display:inline-flex;align-items:center;gap:6px}.qty-btn{border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:4px;width:22px;height:22px;line-height:1;padding:0;font:inherit;cursor:pointer}.qty-val{min-width:16px;text-align:center;font-weight:600;color:var(--ink)}.del-btn{all:unset;cursor:pointer;padding:2px 4px;border-radius:4px;color:var(--ink-3)}.del-btn:hover{color:var(--danger);background:var(--bg)}.install-section{display:flex;flex-direction:column;gap:8px}.install-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.install-head b{color:var(--ink)}.install-row{display:flex;align-items:center;gap:8px}.install-amount{flex:0 0 110px}.install-total{font-size:12px;color:var(--ink-3);text-align:right}.notes-fields{display:flex;flex-direction:column;gap:10px}.send-buttons{display:flex;flex-direction:column;gap:8px}.send-primary{padding:11px 14px}.auth-splash{display:flex;align-items:center;justify-content:center;min-height:60vh;color:var(--ink-3)}.auth-stage{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;padding:48px 16px}.auth-card{width:320px;padding:28px 26px}.auth-logo{text-align:center;letter-spacing:.1em;font-size:16px;color:var(--ink)}.auth-logo span{color:var(--amber)}.auth-sub{text-align:center;color:var(--ink-3);font-size:12px;margin-bottom:20px}.auth-h{font-size:15px;font-weight:700;color:var(--ink);margin:0 0 14px}.auth-h2{font-size:13px;font-weight:700;color:var(--ink);margin:16px 0 8px}.auth-submit{width:100%;margin-top:16px}.auth-link{display:block;margin:14px auto 0;background:none;border:none;color:var(--ink-3);font:inherit;font-size:12px;text-decoration:underline;cursor:pointer}.auth-note{color:var(--ink-3);font-size:11px;margin-top:4px}.auth-banner-ok{background:var(--ok-bg);color:var(--ok);border-radius:var(--radius-s);padding:8px 10px;font-size:12px;margin:10px 0 6px}.auth-banner-bad{background:#fef2f2;color:var(--danger);border-radius:var(--radius-s);padding:8px 10px;font-size:12px;margin:10px 0 6px}.history-page{max-width:760px;margin:0 auto;padding:24px 16px}.history-card{padding:16px}.history-empty{color:var(--ink-3);margin:4px}.history-table{width:100%;border-collapse:collapse;font-size:13px}.history-table th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);padding:6px 8px;border-bottom:1px solid var(--border)}.history-table td{padding:8px;border-bottom:1px solid #f1f5f9}.history-total{display:flex;justify-content:space-between;padding:10px 8px 2px;font-weight:700;color:var(--ink)}.link-btn{background:none;border:none;color:var(--ink-3);font:inherit;font-size:12px;text-decoration:underline;cursor:pointer}.user-menu{position:relative}.user-menu-dd{position:absolute;right:0;top:calc(100% + 6px);min-width:185px;padding:6px;z-index:30;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.user-menu-dd hr{border:none;border-top:1px solid var(--border);margin:5px 0;width:100%}.user-menu-item{display:block;width:100%;text-align:left;padding:8px 10px;border:none;background:none;border-radius:var(--radius-s);color:var(--ink-2);font:inherit;font-size:13px;cursor:pointer}.user-menu-item:hover{background:var(--bg);color:var(--ink)}.admin-page{max-width:920px;margin:0 auto;padding:24px 16px}.admin-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border)}.admin-tab{padding:8px 14px;font:inherit;font-weight:600;color:var(--ink-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer}.admin-tab.on{color:var(--ink);border-bottom-color:var(--amber)}.admin-card{padding:16px}.admin-card+.admin-card{margin-top:14px}.admin-invite-form{display:flex;gap:10px;align-items:center}.admin-invite-form .input{flex:1}.admin-actions{white-space:nowrap}.admin-actions .link-btn{margin-right:8px}.admin-filter{max-width:320px;margin-bottom:12px}.admin-payload{background:var(--bg);border-radius:var(--radius-s);padding:10px;font-size:11px;overflow:auto;max-height:60vh}.muted{color:var(--ink-3)}.pill{display:inline-block;border-radius:99px;padding:2px 9px;font-size:11px;font-weight:600}.pill-open{background:var(--amber-bg);color:var(--amber-ink);border:1px solid var(--amber-border)}.pill-used{background:var(--ok-bg);color:var(--ok)}.pill-expired,.pill-revoked{background:#f1f5f9;color:var(--ink-3)}.pill-admin{background:var(--ink);color:#fff}.pill-dealer{background:#f1f5f9;color:var(--ink-2)}.pill-off{background:#fef2f2;color:var(--danger)}.u-center{text-align:center}.u-right{text-align:right}
