/* ── CSS Variables / Theme (matcher hydraulikkteknikk.no) ───── */
/*
   THEME-KONTRAKT — alle temaer (light/dark/+) MÅ definere disse:

     OVERFLATER:    --bg, --bg2, --bg3
     TEKST:         --tx, --tx2, --tx3
     BORDERS:       --brd, --brd2
     ACCENT:        --acc, --acc-dark, --acc-hover, --acc-soft, --acc-line
     ACCENT-RGB:    --acc-rgb       (kommaseparert "r,g,b" for rgba())
     ON-ACC:        --on-acc        (forgrunn til bruk PÅ --acc / --acc-dark)
     HEADER:        --hdr-bg, --hdr-tx, --hdr-tx2

   For å legge til et nytt tema:
     [data-theme=mitttema]{ ... overskriv alle variablene over ... }

   WCAG AA-mål (tekstkontrast 4.5:1, store/fete 3:1):
     - --tx, --tx2 mot --bg/--bg2/--bg3
     - --on-acc mot --acc og --acc-dark
     - --hdr-tx mot --hdr-bg
     - --acc mot --bg2 (for lenker/aktiv-tilstand)
*/
/* Font loaded via <link rel="preload"> in HTML — not @import (removes render-blocking) */

:root{
  --bg:#f0f2f5;--bg2:#fff;--bg3:#f8f9fb;
  --tx:#1a1a2e;--tx2:#555;--tx3:#6c6c6c;     /* tx3 strammet for AA mot bg3 */
  --brd:#dde;
  --brd2:#c4c8d2;       /* litt mørkere border, til konnektorer/piler */
  --acc:#2c622c;        /* primær grønn (hydraulikkteknikk.no) — 7.05:1 mot #fff */
  --acc-dark:#234923;   /* mørk grønn for hover/pri — 9.0:1 mot #fff */
  --acc-hover:#8fbf8f;  /* lys grønn border-hover (kun til borders, ikke bg+tekst) */
  --acc-soft:#e6f0e6;   /* myk grønn bakgrunn */
  --acc-line:#c7d9c7;   /* subtil grønn border */
  --acc-rgb:44,98,44;   /* rgba() shadows */
  --on-acc:#ffffff;     /* tekst PÅ --acc/--acc-dark — gir 7.05/9.0:1 */
  --hdr-bg:#1a1a2e;--hdr-tx:#fff;--hdr-tx2:#8892b0;
  /* Typografi-system (5 steg) */
  --fs-xl:17px;--fs-lg:14px;--fs-md:12px;--fs-sm:11px;--fs-xs:10px;
}
[data-theme=dark]{
  --bg:#18181b;--bg2:#27272a;--bg3:#1f1f23;
  --tx:#fafafa;--tx2:#a1a1aa;--tx3:#a1a1a8; /* tx3 lysnet for AA mot bg2 */
  --brd:#3f3f46;
  --brd2:#52525b;
  --acc:#6ba36b;        /* lysere grønn for dark — 4.81:1 mot bg2 */
  --acc-dark:#4a8a4a;
  --acc-hover:#8ec08e;
  --acc-soft:#1f2d1f;
  --acc-line:#2f4a2f;
  --acc-rgb:107,163,107;
  --on-acc:#0f0f12;     /* tekst PÅ --acc i dark — gir 5.67:1 (#fff ville gitt 3.03 = AA-FAIL) */
  --hdr-bg:#0f0f12;--hdr-tx:#fafafa;--hdr-tx2:#a1a1aa; /* hdr-tx2 lysnet for AA */
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;font-size:var(--fs-md);background:var(--bg);color:var(--tx);min-height:100vh}

/* HEADER */
.app-header,#hdr{background:var(--hdr-bg);color:var(--hdr-tx);padding:10px 18px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.app-header .title,#hdr .title{font-size:var(--fs-xl);font-weight:700;letter-spacing:.3px}
.app-header .sub,#hdr .sub{font-size:var(--fs-sm);color:var(--hdr-tx2);margin-left:4px}
.hdr-home{color:var(--hdr-tx);text-decoration:none;font-size:18px;opacity:.7;transition:.15s}
.hdr-home:hover{opacity:1}
.hdr-title{display:flex;flex-direction:column;gap:0}
.hdr-controls{display:flex;gap:4px;margin-left:4px}
.hdr-btn{padding:5px 10px;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:transparent;color:var(--hdr-tx);cursor:pointer;font-size:12px;transition:.15s}
.hdr-btn:hover{background:rgba(255,255,255,.1)}
.size-btns{display:flex;gap:6px;margin-left:auto}
.size-btn{padding:5px 14px;border-radius:4px;border:1.5px solid var(--acc-hover);background:transparent;color:var(--acc-hover);cursor:default;font-weight:600;font-size:12px;transition:.15s}
.size-btn.active{background:var(--acc);color:var(--on-acc)}
.size-btn.disabled{border-color:#444;color:#555;cursor:not-allowed}
.user-badge{font-size:11px;color:var(--hdr-tx2);white-space:nowrap}

/* GLOBAL CONFIG BAR */
#gcfg{background:var(--bg2);border-bottom:1px solid var(--brd);padding:8px 18px;display:flex;flex-wrap:wrap;align-items:center;gap:14px}
.gcfg-group{display:flex;align-items:center;gap:6px}
/* alle "active" pri-buttons med accent-bg bruker nå --on-acc for AA */

/* MAIN */
#main{display:flex;gap:0;min-height:calc(100vh - 170px)}

/* STACK PANEL */
#stack-col{width:280px;min-width:240px;background:var(--bg3);border-right:1px solid var(--brd);padding:12px 10px;overflow-y:auto;flex-shrink:0}
#stack-col h3{font-size:11px;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:10px;padding-left:4px}

.sec-card{margin-bottom:5px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:.12s;overflow:hidden;user-select:none;background:var(--bg2)}
.sec-card:hover{border-color:var(--acc-hover)}
.sec-card.selected{border-color:var(--acc);box-shadow:0 0 0 2px rgba(var(--acc-rgb),.15)}
.sec-card.sec-error{border-color:#ef4444;box-shadow:0 0 0 2px rgba(239,68,68,.15)}
.sec-card.sec-error.selected{border-color:#ef4444;box-shadow:0 0 0 2px rgba(239,68,68,.25)}

.sec-inner{padding:7px 10px;display:flex;align-items:center;gap:8px}
.sec-color{width:6px;height:38px;border-radius:3px;flex-shrink:0}
.col-inlet{background:#2563eb}
.col-comp{background:#0d9488}    /* teal — distinkt fra brand-grønn (#2c622c) */
.col-nocomp{background:#d97706}
.col-end{background:#6b7280}

.sec-text{flex:1;min-width:0}
.sec-name{font-weight:600;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--tx)}
.sec-code{font-size:10px;color:var(--tx3);font-family:monospace;margin-top:1px}

.sec-actions{display:flex;flex-direction:column;gap:2px}
.sec-btn{width:22px;height:18px;border:none;background:none;cursor:pointer;color:var(--tx3);font-size:12px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:.1s}
.sec-btn svg{pointer-events:none}
.sec-btn:hover{background:var(--bg);color:var(--tx)}
.sec-btn.del{color:#dc2626}
.sec-btn.del:hover{background:rgba(220,38,38,.1)}

.add-sec-btn{width:100%;margin-top:4px;padding:7px;border:2px dashed var(--brd);border-radius:6px;background:none;cursor:pointer;color:var(--tx3);font-size:12px;font-weight:600;transition:.12s;display:flex;align-items:center;justify-content:center;gap:5px}
.add-sec-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--bg2)}
.add-sec-btn.disabled{opacity:.4;cursor:not-allowed}

/* VIEW TOGGLE */
.view-toggle{display:flex;gap:2px;background:var(--bg);border-radius:5px;padding:2px}
.vt-btn{padding:3px 8px;border:none;border-radius:4px;background:transparent;cursor:pointer;font-size:11px;font-weight:600;color:var(--tx3);transition:.12s;display:flex;align-items:center;gap:3px}
.vt-btn.active{background:var(--bg2);color:var(--tx);box-shadow:0 1px 3px rgba(0,0,0,.1)}
.vt-btn svg{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* OPTION CARDS (box view) */
.opt-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;width:100%}
.opt-card{border:2px solid var(--brd);border-radius:10px;padding:0;cursor:pointer;transition:.2s;background:var(--bg2);position:relative;overflow:hidden;width:170px;flex-shrink:0}
.opt-card:hover{border-color:var(--acc-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.opt-card.active{border-color:var(--acc);box-shadow:0 0 0 3px rgba(var(--acc-rgb),.15)}
.opt-card .oc-code{font-family:monospace;font-size:10px;color:var(--tx3);margin-bottom:2px}
.opt-card .oc-body{padding:8px 10px}
.opt-card .oc-name{font-size:11px;font-weight:700;color:var(--tx);line-height:1.3}
.opt-card .oc-detail{font-size:10px;color:var(--tx2);margin-top:3px;line-height:1.4}
.opt-card .oc-img{width:100%;height:70px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--tx3);font-size:10px;font-family:monospace;border-bottom:1px solid var(--brd)}
.opt-card:not(:has(.oc-img)) .oc-body{padding-top:10px}
.opt-card .oc-img img{width:100%;height:100%;object-fit:contain;padding:4px}
.opt-card.active .oc-check{position:absolute;top:6px;right:8px;color:var(--on-acc);background:var(--acc);width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;z-index:2}

/* Compact pills for many-option lists */
.opt-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.opt-pill{border:1.5px solid var(--brd);border-radius:4px;padding:4px 10px;cursor:pointer;transition:.12s;font-size:11px;font-weight:600;color:var(--tx);background:var(--bg3);white-space:nowrap}
.opt-pill:hover{border-color:var(--acc-hover);background:var(--bg2)}
.opt-pill.active{border-color:var(--acc);background:var(--bg2);color:var(--acc)}

/* CONFIG PANEL */
#config-col{flex:1;padding:16px 20px;overflow-y:auto;min-width:0}
#config-col h2{font-size:var(--fs-lg);font-weight:700;margin-bottom:14px;color:var(--tx);border-bottom:2px solid var(--brd);padding-bottom:8px}

.empty-hint{color:var(--tx3);font-size:13px;padding:30px;text-align:center}

.cfg-section{background:var(--bg2);border:1px solid var(--brd);border-radius:8px;padding:14px 16px;margin-bottom:12px}
.cfg-section h4{font-size:var(--fs-sm);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);margin-bottom:10px}
.cfg-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}
.cfg-row label{font-size:12px;font-weight:600;color:var(--tx);min-width:160px;flex-shrink:0}
.cfg-row select,.cfg-row input[type=text],.cfg-row input[type=number]{border:1.5px solid var(--brd);border-radius:4px;padding:5px 8px;font-size:12px;min-width:200px;flex:1;max-width:100%;background:var(--bg3);color:var(--tx)}
.cfg-row select{font-family:inherit;letter-spacing:.2px}
.cfg-row select:focus,.cfg-row input:focus{outline:none;border-color:var(--acc);background:var(--bg2)}

/* Dropdown summary line (shows description + tags below truncated select) */
.sel-summary{font-size:var(--fs-xs);color:var(--tx2);margin-top:3px;line-height:1.4;padding-left:2px}

.warning{background:#fef3c7;border:1px solid #fcd34d;border-radius:5px;padding:6px 10px;font-size:11px;color:#92400e;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.info{background:#dbeafe;border:1px solid #93c5fd;border-radius:5px;padding:6px 10px;font-size:11px;color:#1e40af;margin-bottom:8px}
[data-theme=dark] .warning{background:#422006;border-color:#854d0e;color:#fde68a}
[data-theme=dark] .info{background:#1e3a5f;border-color:#2563eb;color:#93c5fd}

/* BOM */
#bom-area{background:var(--bg2);border-top:2px solid var(--brd);padding:14px 20px}
#bom-area h3{font-size:13px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:10px;color:var(--tx)}
.bom-tabs{display:flex;align-items:center;gap:4px;padding:0 20px;border-bottom:2px solid var(--brd)}
.bom-tab{padding:10px 18px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:700;color:var(--tx3);border-bottom:2px solid transparent;margin-bottom:-2px;transition:.15s}
.bom-tab:hover{color:var(--tx)}
.bom-tab.active{color:var(--acc);border-bottom-color:var(--acc)}
.bom-actions{display:flex;gap:8px;margin-left:auto;padding:6px 0}
.bom-btn{padding:5px 14px;border:1.5px solid var(--acc);border-radius:4px;background:var(--acc);color:var(--on-acc);cursor:pointer;font-size:12px;font-weight:600;transition:.12s}
.bom-btn:hover{filter:brightness(.9)}
.bom-btn.sec{background:var(--bg2);color:var(--acc)}
.bom-btn.sec:hover{background:var(--bg3)}

#bom-table{width:100%;border-collapse:collapse;font-size:12px}
#bom-table th{background:var(--bg3);padding:6px 10px;text-align:left;font-weight:700;color:var(--tx);border-bottom:2px solid var(--brd);white-space:nowrap}
#bom-table td{padding:5px 10px;border-bottom:1px solid var(--bg3);vertical-align:top}
#bom-table tr:hover td{background:var(--bg3)}
.bom-code{font-family:monospace;font-weight:700;color:var(--tx);white-space:nowrap}
.bom-empty{text-align:center;color:var(--tx3);padding:20px}
/* Part info tags (inline in cards/dropdowns) */
.ptag{display:inline-block;font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;margin-left:4px;vertical-align:middle;line-height:1.4}
.ptag-price{background:#dbeafe;color:#1d4ed8}
[data-theme=dark] .ptag-price{background:#1e3a5f;color:#93c5fd}
.ptag-stock{background:#dcfce7;color:#15803d}
[data-theme=dark] .ptag-stock{background:#14532d;color:#86efac}
.ptag-nostock{background:#fee2e2;color:#b91c1c}
[data-theme=dark] .ptag-nostock{background:#450a0a;color:#fca5a5}
/* Mini cards (for small option sets in card mode) */
.mini-card{border:2px solid var(--brd);border-radius:8px;padding:6px 10px;cursor:pointer;transition:.15s;background:var(--bg2);position:relative;min-width:80px;text-align:center}
.mini-card:hover{border-color:var(--acc-hover);background:var(--bg3)}
.mini-card.active{border-color:var(--acc);box-shadow:0 0 0 2px rgba(var(--acc-rgb),.12)}
.mini-check{position:absolute;top:3px;right:5px;color:var(--acc);font-size:11px;font-weight:700}
.mini-img{width:100%;height:40px;object-fit:contain;margin-bottom:4px}
.mini-code{font-family:monospace;font-size:9px;color:var(--tx3);margin-bottom:2px}
.mini-label{font-size:10px;font-weight:600;color:var(--tx);line-height:1.3}
.mini-tags{margin-top:3px}

.oc-tags{display:flex;gap:3px;margin-top:3px;flex-wrap:wrap}

.bom-price{text-align:right;font-family:monospace;font-size:11px;color:var(--tx2);white-space:nowrap}
.bom-stock{text-align:center;font-size:11px;font-weight:600}
.bom-stock-yes{color:#16a34a}
.bom-stock-no{color:#dc2626}
.bom-total td{border-top:2px solid var(--brd);padding-top:8px}

/* ── SPEC SHEET ─────────────────────────────────────── */
.ss{padding:20px;max-width:1000px;margin:0 auto;font-size:12px}
.ss-title{font-size:16px;font-weight:700;color:var(--tx);padding:14px 0 6px;border-bottom:3px solid #1a1a2e}
[data-theme=dark] .ss-title{border-bottom-color:var(--acc)}
.ss-title span{font-size:12px;font-weight:400;color:var(--tx2)}

.ss-info{width:100%;margin:10px 0;border-collapse:collapse}
.ss-info td{padding:3px 8px}
.ss-info .ss-lbl{font-weight:600;color:var(--tx2);font-size:11px;white-space:nowrap}
.ss-info .ss-val{font-weight:600;color:var(--tx)}

.ss-gen{width:100%;margin:6px 0 14px;border-collapse:collapse;border:1px solid var(--brd)}
.ss-gen td{padding:4px 8px;border:1px solid var(--brd)}
.ss-gen .ss-rom{font-weight:700;color:var(--tx3);text-align:center;width:30px;font-size:11px}
.ss-gen .ss-lbl{font-size:11px;color:var(--tx2);white-space:nowrap}
.ss-gen .ss-val{font-weight:600;color:var(--tx)}

.ss-tbl{width:100%;border-collapse:collapse;border:1px solid var(--brd)}
.ss-tbl th{background:var(--hdr-bg);color:var(--hdr-tx);padding:6px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(255,255,255,.1);white-space:nowrap}
.ss-tbl td{padding:4px 8px;border:1px solid var(--brd);vertical-align:middle}
.ss-num{font-weight:700;text-align:center;width:30px;font-size:13px;color:var(--tx)}
.ss-code{font-family:'Consolas','Courier New',monospace;font-size:11px;font-weight:600;color:var(--tx);background:var(--bg3);padding:1px 5px;border-radius:3px;white-space:nowrap;display:inline-block}
.ss-code.ss-sm{font-size:10px}
.ss-desc{font-size:11px;color:var(--tx2)}
.ss-hint{font-size:10px;color:var(--tx3);font-style:italic}
.ss-note{font-size:11px;color:var(--tx);font-weight:600;text-align:center}

.ss-inlet td{background:#e8f5e9}
[data-theme=dark] .ss-inlet td{background:#1b3a1b}
.ss-sec-a td{background:#fff9e6}
[data-theme=dark] .ss-sec-a td{background:#2a2517}
.ss-sec-b td{background:#f3f4f6}
[data-theme=dark] .ss-sec-b td{background:#25252a}
.ss-sub td{padding:2px 8px}
.ss-end td{background:#fde8d8}
[data-theme=dark] .ss-end td{background:#3a2517}

.ss-footer{text-align:center;padding:12px;font-size:10px;color:var(--tx3);font-style:italic;border-top:1px solid var(--brd);margin-top:8px}

.filter-toggle{padding:4px 10px;border:1.5px solid var(--brd);border-radius:4px;background:var(--bg3);color:var(--tx2);cursor:pointer;font-size:11px;font-weight:600;transition:.15s}
.filter-toggle:hover{border-color:var(--acc);color:var(--acc)}
.filter-toggle.active{border-color:var(--acc);background:var(--acc);color:var(--on-acc)}

/* Info buttons on options */
.info-btn{width:22px;height:22px;border:1.5px solid var(--brd);border-radius:50%;background:var(--bg3);color:var(--tx2);cursor:pointer;font-size:11px;font-weight:700;font-style:italic;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.12s}
.info-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--bg2)}
.pill-info{font-size:9px;font-weight:700;font-style:italic;width:14px;height:14px;border-radius:50%;border:1px solid var(--brd);display:inline-flex;align-items:center;justify-content:center;margin-left:4px;cursor:pointer;color:var(--tx3);flex-shrink:0}
.pill-info:hover{border-color:var(--acc);color:var(--acc)}
.oc-info-btn{position:absolute;top:4px;left:6px;font-size:9px;font-weight:700;font-style:italic;width:16px;height:16px;border-radius:50%;border:1px solid var(--brd);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx3);background:var(--bg2);z-index:2}
.oc-info-btn:hover{border-color:var(--acc);color:var(--acc)}

/* Part detail modal */
.detail-gallery{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.detail-img-wrap{position:relative;width:120px;height:90px;border:1px solid var(--brd);border-radius:6px;overflow:hidden;background:var(--bg3)}
.detail-img{width:100%;height:100%;object-fit:contain;cursor:pointer;transition:.2s}
.detail-img.detail-img-zoom{position:fixed;top:5%;left:5%;width:90%;height:90%;z-index:1000;background:rgba(0,0,0,.9);object-fit:contain;border-radius:0;border:none;padding:20px}
.detail-img-del{position:absolute;top:2px;right:2px;width:18px;height:18px;border:none;border-radius:50%;background:rgba(220,38,38,.8);color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:.15s}
.detail-img-wrap:hover .detail-img-del{opacity:1}
.detail-upload-btn{display:inline-block;padding:5px 12px;border:1.5px dashed var(--acc);border-radius:5px;color:var(--acc);font-size:11px;font-weight:600;cursor:pointer;transition:.12s}
.detail-upload-btn:hover{background:var(--bg3);border-style:solid}
.paste-zone{padding:6px 14px;border:1.5px dashed var(--brd);border-radius:5px;color:var(--tx3);font-size:11px;cursor:pointer;transition:.15s;outline:none;min-width:160px;text-align:center}
.paste-zone:focus{border-color:var(--acc);color:var(--acc);background:var(--bg3)}
.paste-zone:hover{border-color:var(--tx2)}
.detail-table{width:100%;border-collapse:collapse;font-size:11px;margin-bottom:12px}
.detail-table td{padding:4px 8px;border-bottom:1px solid var(--brd)}
.detail-table td:first-child{font-weight:600;color:var(--tx2);width:120px;white-space:nowrap}
.detail-comments{margin-bottom:8px}
.detail-comment{padding:6px 8px;border:1px solid var(--brd);border-radius:4px;margin-bottom:4px;position:relative;background:var(--bg3)}
.detail-comment-del{position:absolute;top:4px;right:4px;border:none;background:none;color:var(--tx3);cursor:pointer;font-size:14px}
.detail-comment-del:hover{color:#dc2626}

.cat-info-btn{width:18px;height:18px;border:1.5px solid var(--brd);border-radius:50%;background:var(--bg3);color:var(--tx3);cursor:pointer;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-left:6px;transition:.12s;vertical-align:middle;flex-shrink:0}
.cat-info-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--bg2)}
.cfg-section h4 .cat-info-btn{margin-left:6px}

.overstyr-btn{padding:2px 10px;border:1px solid var(--brd);border-radius:3px;background:var(--bg3);color:var(--tx2);cursor:pointer;font-size:10px;font-weight:600;margin-left:8px;transition:.12s}
.overstyr-btn:hover{border-color:var(--acc);color:var(--acc)}

.ss-c-num{width:30px}
.ss-c-act{min-width:110px}
.ss-c-pdw{min-width:110px}
.ss-c-spool{min-width:110px}
.ss-c-pls{min-width:100px}
.ss-c-note{min-width:80px}

/* TOOLBAR */
.toolbar{display:flex;gap:5px;align-items:center;margin-left:8px}
.tb-sep{width:1px;height:20px;background:rgba(255,255,255,.15);margin:0 4px}
.tb-btn{padding:4px 10px;border:1.5px solid rgba(255,255,255,.18);border-radius:4px;background:rgba(255,255,255,.07);color:#b0bec5;cursor:pointer;font-size:var(--fs-sm);font-weight:600;transition:.15s;display:flex;align-items:center;gap:4px;white-space:nowrap}
.tb-btn:hover{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.3)}
.tb-btn:disabled{opacity:.25;cursor:not-allowed;background:none}
.tb-btn svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* TRANSITION PLATE */
.transition-plate{display:flex;align-items:center;gap:6px;padding:2px 10px;margin:2px 0}
.tp-line{flex:1;height:2px;background:linear-gradient(90deg,transparent,#f59e0b,transparent)}
.tp-label{font-size:9px;font-weight:700;color:#d97706;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;background:#fffbeb;border:1px solid #fcd34d;border-radius:3px;padding:2px 8px}
[data-theme=dark] .tp-label{color:#fbbf24;background:#422006;border-color:#854d0e}

/* DASHBOARD */
#dashboard{background:linear-gradient(135deg,#1e293b,#334155);color:#e2e8f0;padding:8px 18px;display:flex;flex-wrap:wrap;align-items:center;gap:14px;font-size:12px;border-bottom:1px solid #475569}
.dash-stat{display:flex;flex-direction:column;align-items:center;padding:5px 14px;background:rgba(255,255,255,.06);border-radius:6px;min-width:76px}
.dash-stat .val{font-size:18px;font-weight:800;color:#fff;line-height:1.1}
.dash-stat .lbl{font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:#94a3b8;margin-top:2px}
.dash-warnings{flex:1;min-width:180px}
.dash-error{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);border-radius:4px;padding:3px 8px;font-size:11px;color:#f87171;margin:2px 0;display:flex;align-items:center;gap:5px}
.dash-error:hover{background:rgba(239,68,68,.25)}
.dash-warn{background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.25);border-radius:4px;padding:3px 8px;font-size:11px;color:#fbbf24;margin:2px 0;display:flex;align-items:center;gap:5px}
.dash-warn:hover{background:rgba(251,191,36,.2)}
.dash-info{background:rgba(96,165,250,.12);border:1px solid rgba(96,165,250,.25);border-radius:4px;padding:3px 8px;font-size:11px;color:#60a5fa;margin:2px 0;display:flex;align-items:center;gap:5px}
.dash-info:hover{background:rgba(96,165,250,.2)}
.dash-ok{color:#4ade80;font-size:11px;display:flex;align-items:center;gap:5px}

/* DIAGRAM */
#diagram-toggle{cursor:pointer;padding:5px 18px;background:var(--bg3);border-bottom:1px solid var(--brd);font-size:10px;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.6px;display:flex;align-items:center;gap:6px;user-select:none;transition:.1s}
#diagram-toggle:hover{background:var(--bg);color:var(--tx)}
#diagram-toggle .arrow{transition:.2s;display:inline-block}
#diagram-toggle.open .arrow{transform:rotate(90deg)}
#diagram-area{background:var(--bg2);border-bottom:2px solid var(--brd);padding:16px 18px;overflow-x:auto;display:none}
#diagram-area.open{display:block}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:.2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg2);border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.3);width:520px;max-width:95vw;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;color:var(--tx)}
.modal-hdr{padding:14px 18px;border-bottom:1px solid var(--brd);display:flex;align-items:center}
.modal-hdr h3{font-size:15px;font-weight:700;flex:1}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--tx3);padding:4px 8px;border-radius:4px}
.modal-close:hover{color:var(--tx);background:var(--bg3)}
.modal-body{padding:14px 18px;overflow-y:auto;flex:1}
.modal-foot{padding:10px 18px;border-top:1px solid var(--brd);display:flex;gap:8px;justify-content:flex-end}
.m-btn{padding:7px 18px;border-radius:5px;border:1.5px solid var(--acc);font-size:12px;font-weight:600;cursor:pointer;transition:.12s}
.m-btn.pri{background:var(--acc);color:var(--on-acc)}.m-btn.pri:hover{background:var(--acc-dark)}
.m-btn.sec{background:var(--bg2);color:var(--acc)}.m-btn.sec:hover{background:var(--bg3)}
.m-btn.dan{border-color:#dc2626;color:#dc2626;background:var(--bg2)}.m-btn.dan:hover{background:var(--bg3)}
.save-input{width:100%;padding:8px 12px;border:1.5px solid #d1d5db;border-radius:5px;font-size:13px;margin:8px 0}
.save-input:focus{outline:none;border-color:var(--acc)}
.cfg-list{list-style:none;margin:8px 0}
.cfg-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:5px;margin-bottom:4px;cursor:pointer;transition:.1s}
.cfg-item:hover{background:var(--bg3);border-color:var(--acc-hover)}
.cfg-item .c-name{font-weight:600;font-size:13px;flex:1}
.cfg-item .c-meta{font-size:10px;color:var(--tx3)}
.cfg-item .c-del{background:none;border:none;color:#dc2626;cursor:pointer;font-size:14px;padding:2px 6px;border-radius:3px}
.cfg-item .c-del:hover{background:rgba(220,38,38,.1)}

/* TOAST */
#toast{position:fixed;bottom:20px;right:20px;background:var(--hdr-bg);color:var(--hdr-tx);padding:10px 18px;border-radius:8px;font-size:12px;font-weight:600;z-index:300;transform:translateY(80px);opacity:0;transition:.3s;box-shadow:0 4px 12px rgba(0,0,0,.3);pointer-events:none}
#toast.show{transform:translateY(0);opacity:1}
#toast.success{border-left:4px solid #4ade80}
#toast.error{border-left:4px solid #f87171}

/* INTRO CARD — brand-aligned (mørk grønn → brand-dark gradient) */
.col-intro{background:linear-gradient(135deg,var(--acc-dark),var(--hdr-bg))}
.sec-card.intro-card{border:2px solid var(--acc-line);background:linear-gradient(135deg,var(--acc-soft),var(--bg2))}
.sec-card.intro-card.selected{border-color:var(--acc);box-shadow:0 0 0 2px rgba(var(--acc-rgb),.18)}
.intro-icon{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,var(--acc),var(--acc-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;flex-shrink:0}

/* INTRO CONFIG — hero-panel i samme tone som dashboard, men varmere */
.intro-hero{background:linear-gradient(135deg,var(--hdr-bg),var(--acc-dark));border-radius:10px;padding:20px 22px;color:#fff;margin-bottom:16px;box-shadow:0 1px 0 rgba(0,0,0,.05) inset}
.intro-hero h2{font-size:18px;font-weight:800;margin-bottom:4px;letter-spacing:.2px;color:#fff!important;border:none!important;padding-bottom:0!important}
.intro-hero p{font-size:12px;color:var(--acc-line);line-height:1.5;opacity:.9}
.tag-blue{background:#dbeafe;color:#1d4ed8}
.tag-green{background:#dcfce7;color:#15803d}
.tag-amber{background:#fef3c7;color:#92400e}
[data-theme=dark] .tag-amber{background:#422006;color:#fde68a}

/* DUPLICATE BTN */
.sec-btn.dup{color:var(--acc)}
.sec-btn.dup:hover{background:#dbeafe}

/* ── MOBILE HAMBURGER MENU (hidden on desktop) ─────── */
.mob-menu-btn{display:none}
.mob-menu{display:none}
.hdr-active-id-m{display:none!important}
.mob-sel-pill{display:none}

/* ── MOBILE RESPONSIVE ──────────────────────────────── */
@media (max-width: 900px) {
  #main{flex-direction:column}
  #stack-col{width:100%;min-width:0;max-height:200px;border-right:none;border-bottom:1px solid var(--brd);padding:8px;overflow-x:auto;overflow-y:hidden;display:flex;flex-direction:row;gap:6px;flex-shrink:0}
  #stack-col h3{display:none}
  .sec-card{min-width:120px;flex-shrink:0;margin-bottom:0}
  .sec-drag{display:none}
  .add-sec-btn{min-width:80px;flex-shrink:0;white-space:nowrap;font-size:11px;padding:5px}
  #config-col{padding:10px 12px;min-height:50vh}
  .cfg-row{flex-direction:column;align-items:flex-start;gap:4px}
  .cfg-row label{min-width:0}
  .cfg-row select,.cfg-row input[type=text],.cfg-row input[type=number]{min-width:0;max-width:100%;width:100%}
  .opt-card{width:140px}
  .opt-pills{gap:3px}
  .opt-pill{padding:6px 10px;font-size:10px;min-height:36px}
  .ss-tbl{font-size:10px}
  .ss-code{font-size:9px}
  .modal{width:95vw!important;max-height:85vh!important}
  .modal-body{-webkit-overflow-scrolling:touch}
  .info-btn,.cat-info-btn,.pill-info{min-width:32px;min-height:32px;font-size:13px}
  .overstyr-btn{min-height:32px;padding:4px 10px}
}

@media (max-width: 600px) {
  /* ═══ HEADER: minimal — title + active-ID + hamburger ═══ */
  .app-header{padding:0 12px;gap:0;flex-wrap:nowrap;height:48px}
  .hdr-home{display:none}
  .app-header .sub{display:none}
  .app-header .title{font-size:15px}
  .hdr-title{margin-right:auto}
  .size-btns{display:none}
  .toolbar{display:none!important}
  .hdr-controls{display:none!important}
  .user-badge{display:none}
  .hdr-active-id-m{
    display:inline-flex!important;
    font-family:ui-monospace,monospace;font-weight:700;
    background:var(--acc);color:var(--on-acc);
    padding:4px 10px;border-radius:5px;font-size:11px;
    letter-spacing:.05em;cursor:pointer;white-space:nowrap;
    margin-right:8px;
  }
  .mob-menu-btn{
    display:flex;align-items:center;justify-content:center;
    width:44px;height:44px;border:none;background:none;
    color:var(--hdr-tx);cursor:pointer;flex-shrink:0;
    border-radius:6px;transition:background .15s;
  }
  .mob-menu-btn:hover,.mob-menu-btn:active{background:rgba(255,255,255,.1)}

  /* ═══ HAMBURGER SLIDE-DOWN ═══ */
  .mob-menu{
    display:none;position:absolute;top:48px;left:0;right:0;
    background:var(--bg2);border-bottom:2px solid var(--brd);
    box-shadow:0 8px 30px rgba(0,0,0,.25);z-index:150;
    padding:8px 0;max-height:calc(100vh - 48px);overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .mob-menu.open{display:block}
  .mob-menu-section{padding:4px 0;border-bottom:1px solid var(--brd)}
  .mob-menu-section:last-child{border-bottom:none}
  .mob-menu-item{
    display:flex;align-items:center;gap:10px;
    width:100%;padding:14px 20px;border:none;background:none;
    color:var(--tx);font-size:14px;font-weight:500;
    cursor:pointer;font-family:inherit;text-align:left;
    text-decoration:none;transition:background .1s;
  }
  .mob-menu-item:hover,.mob-menu-item:active{background:var(--bg3)}
  .mob-menu-item svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
  .mob-menu-item.sm{justify-content:center;min-width:56px;padding:12px 16px;font-size:16px}
  .mob-menu-row{display:flex;gap:6px;padding:8px 16px}
  .mob-menu-toggle{
    flex:1;padding:10px 12px;border:1.5px solid var(--brd);border-radius:6px;
    background:var(--bg3);color:var(--tx2);font-size:12px;font-weight:600;
    cursor:pointer;font-family:inherit;text-align:center;transition:.15s;
  }
  .mob-menu-toggle.active{border-color:var(--acc);background:var(--acc);color:var(--on-acc)}

  /* ═══ Stack panel: vertical collapsible on mobile ═══ */
  #main{flex-direction:column}
  #stack-col{
    width:100%;max-height:none;overflow:visible;
    display:flex;flex-direction:column;gap:0;
    padding:0;border-right:none;border-bottom:1px solid var(--brd);
    background:var(--bg2);
  }
  #stack-col h3{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 14px;margin:0;font-size:11px;cursor:pointer;
    background:var(--bg3);
  }
  #stack-col h3::after{content:'▾';font-size:14px;color:var(--tx3)}
  #stack-list{
    max-height:0;overflow:hidden;transition:max-height .25s ease;
    padding:0 8px;
  }
  #stack-col.mob-stack-open #stack-list{max-height:600px;padding:6px 8px}
  #stack-col.mob-stack-open h3::after{content:'▴'}
  #stack-col.mob-stack-open .mob-sel-pill{display:none!important}
  /* Show selected section as a pill below h3 when collapsed */
  .mob-sel-pill{
    display:flex!important;align-items:center;gap:8px;
    padding:8px 14px;font-size:12px;font-weight:600;
    color:var(--tx);cursor:pointer;border-bottom:1px solid var(--brd);
  }
  .mob-sel-pill .sec-color{width:4px;height:20px;border-radius:2px;flex-shrink:0}
  .mob-sel-pill .mob-sel-name{flex:1}
  .mob-sel-pill .mob-sel-code{font-size:10px;color:var(--tx3);font-family:monospace}
  .sec-card{min-width:0;flex-shrink:initial;margin-bottom:4px}
  .sec-inner{padding:6px 10px;gap:6px}
  .sec-name{font-size:11px}
  .sec-code{font-size:9px}
  .sec-color{width:4px;height:28px}
  /* Compact actions: single row, small */
  .sec-actions{flex-direction:row;gap:2px}
  .sec-btn{min-width:30px;min-height:30px;font-size:12px}
  .sec-error-msg{font-size:9px;padding:3px 8px}
  .add-sec-btn{margin:4px 0 6px;min-width:0;font-size:11px;padding:8px}

  /* ═══ Hide diagram toggle on mobile ═══ */
  #diagram-toggle,#diagram-area{display:none!important}

  /* ═══ Config panel full width ═══ */
  #config-col{padding:10px 12px;min-height:auto}

  /* ═══ HIDE GCFG on mobile (filters are in hamburger) ═══ */
  #gcfg{display:none!important}
  /* ═══ DASHBOARD: hide stats, keep only warnings in avansert ═══ */
  #dashboard{padding:4px 12px;gap:4px}
  #dashboard .dash-stat{display:none}
  #dashboard .web-quote-banner{display:flex!important}
  body.enkel-mode #dashboard{display:none!important}

  /* ═══ HIDE BOM in enkel-mode steps 1-4, show on step 5 ═══ */
  body.enkel-mode #bom-area{display:none}
  body.enkel-mode.enkel-final #bom-area{display:block}

  /* ═══ COMPACT STEPPER — single row, iOS-style circles + lines ═══ */
  .ew-stepper{
    gap:0;margin:16px 16px 18px;justify-content:center;
    flex-wrap:nowrap;align-items:flex-start;
  }
  .ew-step{
    flex-direction:column;gap:4px;padding:0;
    border:none;background:none;border-radius:0;
    font-size:9px;min-width:0;flex:0 0 auto;
    width:34px;align-items:center;
    color:var(--tx3);
  }
  .ew-step .ew-step-label{display:none}
  .ew-step.active .ew-step-label{display:block}
  .ew-step.active{width:auto;min-width:42px}
  .ew-step .n{
    width:30px;height:30px;font-size:12px;
    border:2px solid var(--brd);
  }
  .ew-step.active{background:none;box-shadow:none;color:var(--acc);font-weight:700}
  .ew-step.active .n{
    width:34px;height:34px;font-size:13px;
    background:var(--acc);color:var(--on-acc);
    border-color:var(--acc);
    box-shadow:0 2px 8px rgba(var(--acc-rgb),.3);
  }
  .ew-step.done{background:none;color:var(--acc)}
  .ew-step.done .n{width:30px;height:30px;border-color:var(--acc)}
  .ew-step-arrow{
    flex:1;font-size:0;height:2px;min-width:12px;max-width:30px;
    background:var(--brd);align-self:flex-start;margin-top:15px;
  }

  /* ═══ WIZARD PANELS ═══ */
  #enkel-wizard{padding:8px 12px}
  .ew-panel{padding:16px 14px;border-radius:8px}
  .ew-panel h2{font-size:16px}
  .ew-grid{grid-template-columns:1fr;gap:8px}
  .ew-grid.ew-actions-secondary{grid-template-columns:1fr}
  .ew-choice{padding:12px 14px}
  .ew-choice .t{font-size:13px}
  .ew-choice.ew-primary-action{padding:16px 18px}
  .ew-choice.ew-primary-action .t{font-size:15px}
  .ew-sec{padding:14px 12px}
  .ew-fgrid{grid-template-columns:1fr}
  .ew-stack{padding:10px 8px;gap:0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .ew-sb{min-width:90px;font-size:10px;padding:8px 6px}

  /* ═══ BOM as vertical cards on mobile ═══ */
  #bom-area{padding:8px;border-top:none;background:var(--bg)}
  .bom-tabs{padding:0 8px;gap:0}
  .bom-tab{padding:8px 14px;font-size:12px}
  .bom-actions{gap:6px;padding:6px 8px;justify-content:flex-start}
  .bom-btn{font-size:11px;padding:6px 10px;min-height:36px}
  /* Card-based BOM rows */
  #bom-table{min-width:0;font-size:12px}
  #bom-table thead{display:none}
  #bom-table tbody tr{
    display:flex;flex-wrap:wrap;gap:2px 8px;
    padding:8px 10px;border-bottom:1px solid var(--brd);
    align-items:baseline;
  }
  #bom-table tbody tr:hover td{background:none}
  /* Section header rows (has colspan) */
  #bom-table tbody tr:has(td[colspan]){
    padding:6px 10px 2px;border-bottom:none;
  }
  #bom-table tbody tr:has(td[colspan]) td{
    display:block;width:100%;padding:0;
    font-size:10px;font-weight:700;color:var(--tx3);
    text-transform:uppercase;letter-spacing:.5px;
    background:none;
  }
  /* Data row cells */
  #bom-table tbody td:nth-child(1){display:none}
  #bom-table tbody td:nth-child(2){
    font-family:monospace;font-weight:700;font-size:11px;
    padding:0;order:1;flex:0 0 auto;
    color:var(--tx);
  }
  #bom-table tbody td:nth-child(3){
    flex:1 1 100%;order:3;padding:0;
    font-size:11px;color:var(--tx2);line-height:1.3;
  }
  #bom-table tbody td:nth-child(4){
    order:2;padding:0;font-size:11px;margin-left:auto;
  }
  #bom-table tbody td:nth-child(5){
    order:4;padding:0;font-size:10px;
  }
  #bom-table tbody td:nth-child(6){
    order:5;padding:0;font-size:10px;font-weight:600;
  }
  .bom-total td{display:block!important;padding:4px 0!important}
  .bom-total td:first-child{display:none!important}

  /* ═══ Hide inlet technical details on mobile (only pump type matters) ═══ */
  .ew-inlet-detail{display:none}

  /* ═══ Restore-banner compact on mobile ═══ */
  .pdv-restore-banner{
    top:52px;left:8px;right:8px;transform:none;
    max-width:none;padding:8px 12px;font-size:.8rem;
    gap:8px;border-radius:6px;flex-wrap:wrap;
  }
  .pdv-restore-banner span{flex:1 1 100%}
  .pdv-restore-banner button{padding:6px 14px;font-size:.78rem}
  @keyframes pdvRestoreSlide{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

  /* ═══ MISC mobile polish ═══ */
  .sec-error-msg{font-size:9px;padding:3px 8px}
  .tb-dd-menu{right:0;min-width:220px}
}

@media print{
  .app-header,#hdr,#gcfg,#dashboard,.sec-btn,.add-sec-btn,.bom-actions,#config-col,#diagram-toggle,.modal-overlay,#toast,.toolbar,.hdr-controls{display:none!important}
  /* Enkel-wizard: skjul stepper + handlingskort ved utskrift, behold bare oppsummering + BOM */
  .ew-stepper,.ew-row,.ew-sec-head .rm,.ew-sec-head .ew-sec-ctrl,.ew-notice,.ew-no-print{display:none!important}
  .ew-print-only{display:block!important}
  #enkel-wizard .ew-panel>h2:not(:first-of-type),#enkel-wizard .lead{display:none!important}
  #enkel-wizard .ew-choice{break-inside:avoid}
  .ew-sb.clickable{cursor:default}
  #main{display:block}
  #stack-col{display:none}
  #enkel-wizard{max-width:none;padding:0}
  .ew-panel{border:none;box-shadow:none;padding:0;background:none}
  .ew-sec{break-inside:avoid;page-break-inside:avoid}
  .ew-stack{break-inside:avoid;page-break-inside:avoid;margin-bottom:14px}
  #bom-area{border:none;padding:10px;break-before:auto}
  body{background:#fff;font-size:11px;color:#000}
  #diagram-area{display:block!important;border:none;padding:10px 0}
  #bom-table th{background:#eee!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .print-header{display:block!important;padding:10px 0;border-bottom:2px solid #000;margin-bottom:10px}
  .print-header h1{font-size:16px;margin-bottom:4px}
  .print-header p{font-size:11px;color:#555}
  /* Skjul pris på utskrift i public-mode */
  body.pdv-public .ptag-price,body.pdv-public .ew-tag-price{display:none!important}
  body.pdv-public #bom-table thead th:nth-child(4),body.pdv-public #bom-table tbody td:nth-child(4){display:none!important}
}
.print-header{display:none}

/* ── Public-mode BOM: skjul intern-only elementer ───── */
body.pdv-public #tab-spec,
body.pdv-public #act-monitor,
body.pdv-public #act-update,
body.pdv-public #act-export,
body.pdv-public #act-copy,
body.pdv-public #act-group{display:none!important}
/* Skjul pris-kolonne i BOM på skjerm i public */
body.pdv-public #bom-table thead th:nth-child(4),
body.pdv-public #bom-table tbody td:nth-child(4){display:none}

/* ═══ ENKEL WIZARD ═══ */
#enkel-wizard{display:none;max-width:1100px;margin:0 auto;padding:24px 20px}
body.enkel-mode #main{display:none}
body.enkel-mode #dashboard{display:none}
body.enkel-mode #enkel-wizard{display:block}
body.enkel-mode #diagram-toggle,body.enkel-mode #diagram-area{display:none}
.ew-stepper{display:flex;align-items:center;justify-content:center;gap:6px;margin:8px 0 20px;flex-wrap:wrap}
.ew-step{display:flex;align-items:center;gap:7px;padding:7px 13px;border-radius:99px;background:var(--bg2);border:1px solid var(--brd);font-size:12px;color:var(--tx2);font-weight:500;transition:all .2s}
.ew-step .n{width:20px;height:20px;border-radius:50%;background:var(--bg3);color:var(--tx2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.ew-step.active{background:var(--acc);border-color:var(--acc);color:#fff;box-shadow:0 2px 6px rgba(var(--acc-rgb),.25)}
.ew-step.active .n{background:rgba(255,255,255,.28);color:#fff}
.ew-step.done{background:rgba(var(--acc-rgb),.1);border-color:var(--acc-line);color:var(--acc)}
.ew-step.done .n{background:var(--acc);color:var(--on-acc)}
.ew-step-arrow{color:var(--brd2);font-size:14px}
.ew-panel{background:var(--bg);border:1px solid var(--brd);border-radius:10px;padding:24px;margin-bottom:14px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.ew-panel h2{font-size:17px;font-weight:700;margin:0 0 6px;letter-spacing:-.01em}
.ew-panel .lead{color:var(--tx2);margin:0 0 18px;font-size:13px}
.ew-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.ew-grid.narrow{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.ew-choice{position:relative;border:2px solid var(--brd);border-radius:10px;padding:15px 18px;background:var(--bg);cursor:pointer;transition:all .2s;text-align:left;font-family:inherit;font-size:13px;color:var(--tx)}
.ew-choice:hover{border-color:var(--acc);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.ew-choice.sel{border-color:var(--acc);background:rgba(var(--acc-rgb),.08);box-shadow:0 3px 10px rgba(var(--acc-rgb),.12)}
.ew-choice.sel::after{content:'\2713';position:absolute;top:10px;right:12px;width:22px;height:22px;border-radius:50%;background:var(--acc);color:var(--on-acc);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.ew-choice .t{font-weight:600;font-size:14px;margin-bottom:3px}
.ew-choice .s{font-size:12px;color:var(--tx2);line-height:1.4}
.ew-choice .c{font-family:ui-monospace,monospace;font-size:11px;color:var(--tx3);margin-top:6px;padding-top:6px;border-top:1px dashed var(--brd)}
.ew-choice .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.ew-tag{font-size:10px;font-weight:600;padding:2px 8px;border-radius:99px}
.ew-tag-price{background:rgba(var(--acc-rgb),.08);color:var(--acc)}
.ew-tag-stock{background:rgba(var(--acc-rgb),.12);color:var(--acc)}
.ew-tag-nostock{background:rgba(220,38,38,.1);color:#dc2626}
.ew-row{display:flex;gap:10px;margin-top:18px;padding-top:16px;border-top:1px solid var(--brd);flex-wrap:wrap;align-items:center}
.ew-row .sp{flex:1}
.ew-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border:1px solid var(--brd);border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;background:var(--bg2);color:var(--tx);font-family:inherit;transition:all .15s}
.ew-btn:hover{background:var(--bg3)}
.ew-btn.pri{background:var(--acc);border-color:var(--acc);color:#fff;box-shadow:0 2px 6px rgba(var(--acc-rgb),.18)}
.ew-btn.pri:hover{background:var(--acc-dark)}
.ew-btn.gh{background:transparent;border-color:transparent;color:var(--tx2)}
.ew-btn.gh:hover{background:var(--bg2)}
.ew-sec{border:1px solid var(--brd);border-radius:10px;padding:18px 20px;background:var(--bg);margin-bottom:10px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.ew-sec-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.ew-sec-num{width:26px;height:26px;border-radius:50%;background:var(--acc);color:var(--on-acc);font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center}
.ew-sec-head h3{font-size:14px;font-weight:600;flex:1;margin:0}
.ew-sec-head input{flex:1;padding:7px 10px;font-size:13px;border:1px solid var(--brd);border-radius:5px;background:var(--bg2);color:var(--tx);font-family:inherit}
.ew-sec-head .rm{background:transparent;border:none;color:var(--tx3);font-size:18px;cursor:pointer;width:26px;height:26px;border-radius:50%}
.ew-sec-head .rm:hover{background:rgba(220,38,38,.1);color:#dc2626}
.ew-sec-head .ew-sec-ctrl{background:var(--bg2);border:1px solid var(--brd);color:var(--tx2);font-size:11px;cursor:pointer;width:26px;height:26px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;padding:0}
.ew-sec-head .ew-sec-ctrl:hover:not(:disabled){background:var(--bg3);color:var(--tx)}
.ew-sec-head .ew-sec-ctrl:disabled{opacity:.35;cursor:not-allowed}
.ew-fgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:600px){.ew-fgrid{grid-template-columns:1fr}}
.ew-f{margin-bottom:10px}
.ew-f label{display:block;font-size:11px;color:var(--tx2);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:4px}
.ew-f select,.ew-f input[type=text],.ew-f input[type=number]{width:100%;padding:9px 11px;font-size:12px;border:1px solid var(--brd);border-radius:5px;background:var(--bg2);color:var(--tx);font-family:inherit}
.ew-f select:focus,.ew-f input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(var(--acc-rgb),.12)}
.ew-f .hint{font-size:10px;color:var(--tx3);margin-top:3px;font-family:ui-monospace,monospace}
.ew-stack{display:flex;align-items:stretch;gap:0;background:var(--bg2);border:1px solid var(--brd);border-radius:10px;padding:14px 16px;margin-bottom:16px;overflow-x:auto}
.ew-sb{min-width:110px;flex:1;border:2px solid var(--brd);border-radius:6px;padding:10px 8px;background:var(--bg);font-size:11px;text-align:center}
.ew-sb+.ew-sb{margin-left:-1px}
.ew-sb.inlet{border-color:#1e5599;background:linear-gradient(180deg,rgba(30,85,153,.08),var(--bg))}
.ew-sb.work{border-color:var(--acc);background:linear-gradient(180deg,rgba(var(--acc-rgb),.08),var(--bg))}
.ew-sb.end{border-color:var(--tx3);background:linear-gradient(180deg,var(--bg2),var(--bg))}
.ew-sb.trans{min-width:70px;flex:0 0 auto;border-color:#b45309;background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(245,158,11,.03));border-style:dashed;padding:8px 6px}
.ew-sb.trans .tag{color:#b45309}
.ew-sb.trans .body{font-size:11px}
.ew-sb.illegal{border-color:#dc2626 !important;background:linear-gradient(135deg,rgba(220,38,38,.18),rgba(220,38,38,.04)) !important;color:#dc2626;border-style:solid;animation:ewIllegalPulse 1.6s ease-in-out infinite}
.ew-sb.illegal .tag,.ew-sb.illegal .body,.ew-sb.illegal .meta{color:#dc2626 !important}
/* Status-badges (delt intern+admin) */
.q-tab{background:var(--bg2);border:1px solid var(--brd);color:var(--tx2);padding:6px 12px;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:.15s}
.q-tab:hover{background:var(--bg3)}
.q-tab.active{background:var(--acc);border-color:var(--acc);color:#fff;font-weight:600}
.q-status{font-size:10px;font-weight:700;padding:3px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.05em;display:inline-block}
.q-status-ny{background:#dc2626;color:#fff;border:1px solid #991b1b}
.q-status-sett_av_kunde{background:#d97706;color:#fff;border:1px solid #92400e}
.q-status-tilbud_sendt{background:#1e5599;color:#fff;border:1px solid #1e3a8a}
.q-status-akseptert{background:var(--acc);color:var(--on-acc);border:1px solid #14532d}
.q-status-avslatt{background:#525862;color:#fff;border:1px solid #374151}
.q-status-arkivert{background:#9ca3af;color:#1f2937;border:1px solid #6b7280}
.q-act-btn{padding:5px 10px;border:1px solid var(--brd);border-radius:4px;background:var(--bg2);color:var(--tx);font-size:11px;font-weight:500;cursor:pointer;font-family:inherit;transition:.15s}
.q-act-btn:hover{background:var(--bg3)}
.q-act-btn.pri{background:var(--acc);border-color:var(--acc);color:#fff}
.q-act-btn.pri:hover{background:var(--acc-dark)}
.ew-sb.clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}
.ew-sb.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1);z-index:2}
.ew-sec.highlighted{animation:ewHighlightSec 1.5s ease-out}
@keyframes ewHighlightSec{0%{box-shadow:0 0 0 3px rgba(var(--acc-rgb),.4);background:rgba(var(--acc-rgb),.05)}100%{box-shadow:0 1px 2px rgba(0,0,0,.04);background:var(--bg)}}
@keyframes ewIllegalPulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.35)}50%{box-shadow:0 0 0 6px rgba(220,38,38,0)}}
.ew-sb .tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.8;margin-bottom:3px}
.ew-sb .body{font-weight:600;font-size:12px;margin:3px 0}
.ew-sb .meta{font-size:10px;color:var(--tx3);margin-top:4px;padding-top:4px;border-top:1px dashed var(--brd)}
.ew-notice{padding:11px 14px;border-radius:6px;margin-bottom:12px;font-size:12px;display:flex;gap:8px;align-items:flex-start}
.ew-notice-warn{background:rgba(245,158,11,.1);color:#b45309;border-left:3px solid #f59e0b}
.ew-notice-info{background:rgba(30,85,153,.08);color:#1e5599;border-left:3px solid #1e5599}
.ew-connector{width:14px;display:flex;align-items:center;justify-content:center;color:var(--brd2);flex-shrink:0}

/* ── Custom confirm/load modals (erstatter native confirm/prompt) ─────── */
.pdv-confirm-overlay{
  position:fixed;inset:0;background:rgba(15,23,33,.5);
  display:flex;align-items:center;justify-content:center;z-index:10001;padding:20px;
}
.pdv-confirm-modal{
  background:var(--bg2);border-radius:10px;
  max-width:440px;width:100%;padding:24px;
  box-shadow:0 20px 60px rgba(0,0,0,.3);
  font-family:inherit;color:var(--tx);
}
.pdv-confirm-modal h3{margin:0 0 8px;font-size:1.15rem;font-weight:700}
.pdv-confirm-modal .lead{color:var(--tx2);margin:0 0 12px;font-size:.88rem}
.pdv-confirm-modal .reset-list{
  margin:0 0 14px;padding:10px 14px 10px 28px;background:var(--bg3);
  border-radius:6px;font-size:.85rem;color:var(--tx);
}
.pdv-confirm-modal .reset-list li{margin:2px 0}
.pdv-confirm-modal .warn{
  font-size:.8rem;color:#b91c1c;margin:0 0 14px;
  display:flex;align-items:center;gap:6px;
}
.pdv-confirm-modal .warn::before{content:'⚠';font-size:1rem}
.pdv-confirm-modal .field{margin:0 0 12px}
.pdv-confirm-modal label{display:block;font-size:.78rem;font-weight:600;margin-bottom:4px;color:var(--tx2)}
.pdv-confirm-modal input{
  width:100%;padding:9px 10px;
  border:1.5px solid var(--brd);border-radius:5px;
  font-family:inherit;font-size:.95rem;color:var(--tx);
  letter-spacing:.06em;text-transform:lowercase;
}
.pdv-confirm-modal input:focus{outline:none;border-color:var(--acc);background:var(--bg2)}
.pdv-confirm-modal .hint{font-size:.75rem;color:var(--tx3);margin:4px 0 0}
.pdv-confirm-modal .err{font-size:.78rem;color:#b91c1c;margin:6px 0 0;display:none}
.pdv-confirm-modal .err.show{display:block}
.pdv-confirm-modal .actions{display:flex;gap:10px;margin-top:6px;align-items:center}
.pdv-confirm-modal .actions .spacer{flex:1}
.pdv-confirm-modal .btn{
  padding:9px 16px;border:none;border-radius:5px;
  font-weight:600;font-size:.88rem;cursor:pointer;
  font-family:inherit;
}
.pdv-confirm-modal .btn-cancel{background:var(--bg3);color:var(--tx)}
.pdv-confirm-modal .btn-cancel:hover{background:var(--brd)}
.pdv-confirm-modal .btn-primary{background:var(--acc);color:var(--on-acc)}
.pdv-confirm-modal .btn-primary:hover{background:var(--acc-dark)}
.pdv-confirm-modal .btn-primary:disabled{opacity:.5;cursor:not-allowed}
.pdv-confirm-modal .btn-danger{background:#dc2626;color:#fff}
.pdv-confirm-modal .btn-danger:hover{background:#b91c1c}

/* ── Disabled state for primary CTA (header "Be om tilbud") ───────────── */

/* ── Autosave indikator i header ─────────────────────────────────────── */
.pdv-autosave-pill{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.72rem;color:rgba(255,255,255,.55);
  padding:4px 10px;border-radius:99px;
  background:rgba(255,255,255,.04);
  font-family:inherit;
  transition:opacity .2s,color .2s;
}
.pdv-autosave-pill::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--acc-hover);
  box-shadow:0 0 6px rgba(var(--acc-rgb),.6);
}
.pdv-autosave-pill.saving{color:rgba(255,255,255,.85)}
.pdv-autosave-pill.saving::before{background:#fbbf24;animation:pdvSavePulse 1s infinite}
@keyframes pdvSavePulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── Restore-banner når sesjon gjenopprettes ─────────────────────────── */
.pdv-restore-banner{
  position:fixed;top:80px;left:50%;transform:translateX(-50%);
  background:var(--acc);color:var(--on-acc);
  padding:10px 16px;border-radius:8px;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  font-size:.88rem;display:flex;align-items:center;gap:14px;
  z-index:9999;max-width:90vw;
  animation:pdvRestoreSlide .3s ease-out;
}
.pdv-restore-banner button{
  background:rgba(255,255,255,.2);color:var(--on-acc);
  border:none;padding:5px 12px;border-radius:4px;
  font-weight:600;cursor:pointer;font-family:inherit;font-size:.82rem;
}
.pdv-restore-banner button:hover{background:rgba(255,255,255,.3)}
.pdv-restore-banner .close{
  background:transparent;color:var(--on-acc);
  width:24px;height:24px;padding:0;border-radius:50%;
  font-size:18px;line-height:1;
}
@keyframes pdvRestoreSlide{from{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%,0)}}

/* ── Stack-card "Endre" affordance (tydeliggjøre klikkbarhet) ─────────── */
.ew-sb.clickable{position:relative}
.ew-sb.clickable::after{
  content:'✏ Endre';
  position:absolute;bottom:4px;right:6px;
  font-size:9px;color:var(--tx3);
  opacity:.6;font-weight:600;letter-spacing:.02em;
  transition:opacity .15s,color .15s;
}
.ew-sb.clickable:hover::after{opacity:1;color:var(--acc)}

/* ── Tydeligere stepper-tilstander (active fyllt, done check uten tall) ─ */
.ew-step.done .n{font-size:0;width:18px;height:18px;background:var(--acc);color:var(--on-acc);position:relative}
.ew-step.done .n::after{content:'✓';font-size:11px;font-weight:700;position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.ew-step.active .n{background:var(--on-acc);color:var(--acc);border:1.5px solid var(--on-acc);font-weight:700}

/* ── Primær handlingskort i steg 5 (full bredde, dominerer) ───────────── */
.ew-grid.ew-actions-secondary{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.ew-choice.ew-primary-action{
  grid-column:1/-1;
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;
  background:var(--acc);border-color:var(--acc);
  box-shadow:0 4px 14px rgba(var(--acc-rgb),.25);
}
.ew-choice.ew-primary-action:hover{
  background:var(--acc-dark);border-color:var(--acc-dark);
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(var(--acc-rgb),.35);
}
.ew-choice.ew-primary-action .t{color:var(--on-acc);font-size:17px;margin-bottom:2px}
.ew-choice.ew-primary-action .s{color:rgba(255,255,255,.9);font-size:13px}
.ew-actions-label-secondary{
  font-size:11px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--tx3);font-weight:600;margin:18px 0 8px;
}

/* ── Drag handle for section reorder ───────────────────── */
.sec-drag{
  width:16px;flex-shrink:0;cursor:grab;color:var(--tx3);
  font-size:14px;line-height:1;opacity:.4;transition:opacity .15s;
  display:flex;align-items:center;justify-content:center;
  user-select:none;-webkit-user-select:none;
}
.sec-drag:hover{opacity:.8;color:var(--tx)}
.sec-drag:active{cursor:grabbing}
.sec-card.sec-dragging{opacity:.4;border-style:dashed}
.sec-card.sec-dragover{border-color:var(--acc);box-shadow:0 0 0 2px rgba(var(--acc-rgb),.2)}

/* ── sec-error inline message ──────────────────────────── */
.sec-error-msg{
  padding:4px 10px 6px;font-size:10px;font-weight:600;
  color:#dc2626;background:rgba(239,68,68,.06);
  border-top:1px solid rgba(239,68,68,.15);
  cursor:pointer;display:flex;align-items:center;gap:4px;
}
.sec-error-msg::before{content:'\26A0';font-size:11px}
[data-theme=dark] .sec-error-msg{background:rgba(239,68,68,.08);color:#f87171}

/* ── Toolbar dropdown (Spec) ───────────────────────────── */
.tb-dropdown{position:relative}
.tb-dd-menu{
  display:none;position:absolute;top:calc(100% + 4px);right:0;
  background:var(--bg2);border:1px solid var(--brd);border-radius:6px;
  box-shadow:0 8px 24px rgba(0,0,0,.2);z-index:150;
  min-width:240px;padding:4px 0;
}
.tb-dd-menu.open{display:block}
.tb-dd-item{
  display:flex;align-items:center;gap:8px;width:100%;
  padding:8px 14px;border:none;background:none;
  color:var(--tx);font-size:12px;font-weight:500;
  cursor:pointer;font-family:inherit;text-align:left;
  transition:background .1s;white-space:nowrap;
}
.tb-dd-item:hover{background:var(--bg3)}
.tb-dd-sep{height:1px;background:var(--brd);margin:4px 8px}

/* ── Loading / skeleton states ─────────────────────────── */
.bom-skeleton{padding:16px 10px}
.skeleton-pulse{
  height:12px;border-radius:4px;margin-bottom:8px;
  background:linear-gradient(90deg,var(--bg3) 25%,var(--brd) 50%,var(--bg3) 75%);
  background-size:200% 100%;
  animation:skeletonShimmer 1.5s ease-in-out infinite;
}
@keyframes skeletonShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.pdv-loading{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:16px;font-size:12px;color:var(--tx2);
}
.pdv-spinner{
  width:16px;height:16px;border:2px solid var(--brd);
  border-top-color:var(--acc);border-radius:50%;
  animation:pdvSpin .6s linear infinite;
}
@keyframes pdvSpin{to{transform:rotate(360deg)}}
