:root{
  --bg:#f4f5f7; --panel:#fff; --line:#e2e8f0; --ink:#1e293b; --muted:#64748b;
  --brand:#2563eb; --brand2:#1d4ed8; --spec:#c2410c; --ok:#16a34a;
  --sidebar:#1e293b;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
body{margin:0;font:13.5px/1.5 "Inter",-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
h1{font-size:22px;margin:0} h3{margin:0 0 8px;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
h4{margin:18px 0 6px;font-size:15px} h4.spec{color:var(--spec)}
a{color:var(--brand2);text-decoration:none} a:hover{text-decoration:underline}
.muted{color:var(--muted)} .small{font-size:12.5px}
.row{display:flex;align-items:center} .between{justify-content:space-between} .gap{gap:8px} .end{justify-content:flex-end}
.spacer{flex:1}
button{font:inherit;border:1px solid var(--line);background:#fff;border-radius:8px;padding:7px 12px;cursor:pointer}
button:hover{border-color:#c3c9d2}
button.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
button.primary:hover{background:var(--brand2)}
button.ghost{background:transparent}
/* demo-läge: dölj alla priser/sälj-innehåll (#/dolj-pris … #/visa-pris) */
.hide-pricing .js-price{display:none !important}
button.danger{background:#c0392b;color:#fff;border-color:#c0392b}
button.danger:hover{background:#a93226;border-color:#a93226}
button:disabled{opacity:.6;cursor:wait}

body{display:flex;flex-direction:column;height:100vh;overflow:hidden}
#topbar{flex:none;display:flex;align-items:center;gap:12px;padding:9px 16px;background:var(--sidebar);border-bottom:1px solid #0f172a;z-index:5;color:#fff}
.brand{font-weight:700;color:#fff;cursor:pointer;display:flex;align-items:center;gap:9px}
.ebab-logo{color:#fff;display:block}
.brand-word{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:#cbd5e1}
#topbar button{color:#cbd5e1;border-color:#334155;background:transparent}
#topbar button:hover{background:#334155;color:#fff;border-color:#475569}
#topbar .company-name{color:#fff;font-weight:600}
main{flex:1;min-height:0;overflow:auto}
main > .auth, main > .projects{max-width:1280px;margin:0 auto;padding:18px}

/* ===== IDE-layout (projektvyn) ===== */
.ide{display:flex;flex-direction:column;height:100%;overflow:hidden}
.toolbar{flex:none;display:flex;align-items:center;gap:10px;padding:6px 12px;border-bottom:1px solid var(--line);background:#fff}
.toolbar h1{font-size:16px}
.icon-btn{border:none;background:none;font-size:16px;padding:4px 8px;color:var(--muted);cursor:pointer;border-radius:6px}
.icon-btn:hover{background:#eef2f7;color:var(--ink)}
.ide-body{flex:1;display:flex;min-height:0;overflow:hidden}

#sideBar{flex:none;width:300px;min-width:220px;border-right:1px solid var(--line);background:#fafbfc;display:flex;flex-direction:column;overflow:hidden}
#sideBar.hidden{display:none}
#sideBar .pane-c{overflow:auto;padding:10px}
#docsBody{flex:1;min-height:0}

.main-col{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}
.pane{display:flex;flex-direction:column;min-height:0;background:#fff}
.pane-h{flex:none;display:flex;align-items:center;gap:6px;height:30px;padding:0 10px;
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#57606a;
  background:#f3f4f6;border-bottom:1px solid var(--line);cursor:pointer;user-select:none}
.pane-h:hover{background:#ebedf0}
.pane-h .caret{width:11px;font-size:10px;color:var(--muted)}
/* utkast-rad: version-väljaren tar plats, knapparna grupperas tydligt */
#draftHeader{gap:8px;padding:6px 10px;height:auto;min-height:38px;flex-wrap:wrap}
#draftHeader #versionSelect{flex:1 1 140px;min-width:120px;max-width:340px;
  text-transform:none;font-weight:400;height:26px;padding:0 6px;border-radius:6px}
#draftHeader > span:nth-child(2){flex:none}
#draftHeader button{flex:none;text-transform:none;font-weight:500;
  height:26px;padding:3px 11px;white-space:nowrap;border-radius:6px}
/* primär åtgärd lyfts fram, exportknapparna hålls ihop som en grupp */
#draftHeader #priceBtn{background:var(--brand);color:#fff;border-color:var(--brand)}
#draftHeader #priceBtn:hover{background:var(--brand2)}
#draftHeader #xlsmBtn{font-weight:600}
#draftHeader #revertBtn{margin-left:auto}
.pane.collapsed .pane-c{display:none}
#draftPane{flex:1 1 0}
#draftPane .pane-c{flex:1;overflow:auto;padding:14px 18px}
#draftPane.collapsed{flex:0 0 auto}
#splitter{flex:none;height:5px;background:transparent;cursor:row-resize;border-top:1px solid var(--line)}
#splitter:hover,#splitter.drag{background:var(--brand2)}
#chatPane{flex:none;height:42%;min-height:0}
#chatPane .pane-c{flex:1;display:flex;flex-direction:column;min-height:0;padding:10px 14px}
#chatPane.collapsed{height:auto !important}
#chatPane.maxed{flex:1}

/* auth */
.auth{max-width:380px;margin:8vh auto;background:#fff;padding:28px;border:1px solid var(--line);border-radius:14px}
.auth .tabs{display:flex;gap:6px;margin:16px 0}
.auth .tabs button{flex:1} .auth .tabs button.active{background:var(--brand);color:#fff;border-color:var(--brand)}
form label{display:block;margin:10px 0;font-size:13px;color:var(--muted)}
/* enhetlig styling för ALLA textfält/select/textarea i appen (även utanför <form>) */
input:not([type=checkbox]):not([type=radio]):not([type=file]),textarea,select{
  font:inherit;padding:9px 11px;border:1px solid var(--line);border-radius:8px;color:var(--ink);
  background:#fff;box-sizing:border-box}
input:not([type=checkbox]):not([type=radio]):focus,textarea:focus,select:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(37,99,235,.15)}
form input,form textarea,select{width:100%}
.auth .primary[type=submit]{width:100%;margin-top:8px}
.error{color:#b91c1c;font-size:13px;min-height:18px}

/* projects */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:16px}
.card{display:flex;align-items:flex-start;gap:6px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px}
.card:hover{border-color:var(--brand2);text-decoration:none}
.card .card-main{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.card .card-acts{display:flex;gap:2px;opacity:0;transition:opacity .12s}
.card:hover .card-acts{opacity:1}
.card .card-del:hover{color:#c0392b;background:#fdecea}
.card-hidden{opacity:.7;border-style:dashed}
.card-hidden .card-acts{opacity:1}
.dolt-badge{display:inline-block;padding:1px 7px;border-radius:9px;background:#e8923a;color:#fff;
  font-size:11px;font-weight:600}

/* workspace */
.grid{display:grid;grid-template-columns:260px 1fr 360px;gap:14px;margin-top:14px;align-items:start}
.panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px}
.draft{min-height:60vh;overflow:auto}
.filelist{display:flex;flex-direction:column;gap:2px;margin-bottom:10px}
.dirrow{display:flex;align-items:center;gap:5px;font-size:13px;padding:3px 2px;border-radius:6px;cursor:pointer;user-select:none}
.dirrow:hover{background:#f3f6fa}
.dirrow .caret{width:12px;color:var(--muted);font-size:11px}
.dirrow .dirname{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.indent{margin-left:7px;border-left:1px solid var(--line);padding-left:9px;display:flex;flex-direction:column;gap:2px}
.inc{width:13px;height:13px;flex:none;accent-color:var(--brand);cursor:pointer;margin:0}
.fileitem.off a{color:var(--muted);text-decoration:line-through}
.fileitem.off .tag{opacity:.5}
.fileitem[draggable=true]{cursor:grab}
.chat.drag{outline:2px dashed var(--brand2);outline-offset:-4px;background:#f0f6fc}
.fileitem{display:flex;align-items:center;gap:6px;font-size:13px}
.fileitem a{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tag{font-size:11px;background:#eef2f7;color:var(--muted);padding:1px 6px;border-radius:6px}
.x{border:none;background:none;color:var(--muted);padding:0 4px;font-size:16px}
.upload{display:block;text-align:center;border:1px dashed #c3c9d2;border-radius:8px;padding:10px;cursor:pointer;color:var(--brand2);font-size:13px}
.upload:hover{background:#f8fafc}

/* draft tables */
table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:6px}
th,td{border-bottom:1px solid var(--line);padding:5px 7px;text-align:left;vertical-align:top}
thead th{color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase}
td.num,.num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
table.kv th{width:38%;color:var(--muted);font-weight:500}
.gsum{float:right;color:var(--brand);font-weight:600}

/* chat */
.chatlog{flex:1;overflow:auto;display:flex;flex-direction:column;gap:10px;margin-bottom:10px;min-height:0}
.msg{display:flex;flex-direction:column}
.msg.user{align-items:flex-end}
.bubble{max-width:90%;padding:8px 11px;border-radius:12px;white-space:pre-wrap;font-size:14px}
.msg.user .bubble{background:var(--brand);color:#fff;border-bottom-right-radius:3px}
.msg.assistant .bubble{background:#eef2f7;border-bottom-left-radius:3px}
.vtag{font-size:11px;color:var(--ok);margin-top:2px}
#chatForm{display:flex;gap:6px;align-items:flex-end;flex-wrap:wrap}
#chatForm textarea{flex:1;min-width:0;resize:vertical}
#chatForm button{flex:0 0 auto;width:auto}

/* inklistrade bilder i chatt */
#toChatForm{flex-wrap:wrap}
.img-strip{flex:0 0 100%;display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.img-thumb{position:relative;width:54px;height:54px;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:#f3f5f8}
.img-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.img-thumb .img-x{position:absolute;top:1px;right:1px;width:18px;height:18px;padding:0;line-height:1;
  border-radius:50%;border:none;background:rgba(0,0,0,.6);color:#fff;font-size:13px;cursor:pointer;
  display:flex;align-items:center;justify-content:center}
.img-thumb.uploading{opacity:.5}
.img-thumb.uploading::after{content:"";position:absolute;inset:0;margin:auto;width:18px;height:18px;
  border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}
.chat h3{display:flex;align-items:center;gap:6px}
.ai-icon{color:var(--brand2);flex:none}
#modelBadge{text-transform:none;letter-spacing:0;font-weight:500}

/* upload & dropzone */
.center{text-align:center}
#docsPanel .upload{flex:1}
#docsPanel.drag{outline:2px dashed var(--brand2);outline-offset:-4px;background:#f0f6fc}
#uploadStatus{min-height:16px;margin:4px 0}

/* modal fields */
.modal label{display:block}
.modal input,.modal textarea{width:100%;margin-top:6px;padding:9px;border:1px solid var(--line);border-radius:8px;font:inherit}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(20,25,35,.45);display:flex;align-items:center;justify-content:center;z-index:20}
.modal{background:#fff;border-radius:14px;padding:22px;width:360px;max-width:92vw;
  max-height:88vh;overflow:auto;display:flex;flex-direction:column;gap:10px}
/* bredare modaler på desktop (profil/företag) */
.modal.wide{width:560px}
@media(max-width:680px){.modal.wide{width:360px}}

/* visa/dölj lösenord */
.pw-wrap{position:relative}
.pw-toggle{position:absolute;right:6px;bottom:6px;border:none;background:none;
  color:var(--muted);padding:4px;cursor:pointer;border-radius:6px;line-height:0}
.pw-toggle:hover{color:var(--ink);background:#eef2f7}
.pw-wrap input[type=password],.pw-wrap input[type=text]{padding-right:38px}
.pw-toggle svg.lucide{width:18px;height:18px}

@media(max-width:1000px){.grid{grid-template-columns:1fr}}

/* admin */
.admin h2{font-size:15px;margin:26px 0 8px}
.mail-opened,.mail-clicked{background:#dcfce7;color:#15803d}
.mail-delivered{background:#e0f2fe;color:#0369a1}
.mail-bounced,.mail-failed,.mail-complained{background:#fee2e2;color:#b91c1c}

/* företag/admin-detaljer */
details.co{border:1px solid var(--line);border-radius:8px;padding:8px 12px;margin-bottom:8px;background:#fff}
details.co summary{cursor:pointer;font-size:13.5px}
details.co table{margin-top:8px}
.company h2{font-size:15px;margin:22px 0 8px}

/* ===== landningssida ===== */
.landing{max-width:1060px;margin:0 auto;padding:0 24px 60px}
.land-nav{display:flex;align-items:center;gap:10px;padding:16px 0}
.land-nav .brand{font-size:18px}
.hero{text-align:center;padding:56px 0 40px}
.hero h1{font-size:38px;line-height:1.15;margin-bottom:14px;color:var(--brand)}
.hero p{max-width:640px;margin:0 auto 26px;font-size:17px;color:var(--muted)}
.center-row{justify-content:center}
button.big{padding:11px 26px;font-size:16px;border-radius:10px}
.feats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:30px 0 50px}
.feat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px}
.feat h3{margin-bottom:6px}
.feat p{margin:0;font-size:13.5px;color:var(--muted)}
.center{text-align:center}
h2.center{font-size:26px;margin:10px 0 4px;color:var(--brand)}
.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:22px 0 36px}
.price-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:22px 18px;text-align:center}
.price-card .price{font-size:26px;font-weight:700;color:var(--brand);margin:8px 0 2px}
.cta-foot{padding-top:8px}
.cta-foot p{margin-top:10px}

/* notis för ej godkända konton */
.notice{background:#fff7ed;border:1px solid #fdba74;color:#9a3412;border-radius:10px;padding:12px 16px;margin-bottom:16px;font-size:14px}

/* ===== laddnings-overlay ===== */
#loadingOverlay{position:fixed;inset:0;background:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;z-index:100}
.spinner{width:42px;height:42px;border:4px solid rgba(31,78,120,.2);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* in/ut-sektioner i dokumentträdet */
.dirrow.tree-section{margin-top:6px}
.dirrow.tree-section strong{font-size:12.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}

/* ===== bli kund-sida ===== */
.auth.signup{max-width:680px}
.pricing.compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:14px 0 6px}
.pricing.compact .price-card{padding:14px 10px}
.pricing.compact .price-card h3{font-size:11.5px;margin-bottom:2px}
.pricing.compact .price{font-size:19px;margin:4px 0 2px}
.provided-by{margin-top:22px;border-top:1px solid var(--line);padding-top:12px}
.land-foot{margin-top:48px;border-top:1px solid var(--line);padding-top:16px}

/* villkor + godkännande */
.terms-list{padding-left:20px;display:flex;flex-direction:column;gap:10px;font-size:14px}
label.terms{display:flex;align-items:center;gap:8px;margin:4px 0}
label.terms input{width:auto}
svg.lucide{width:16px;height:16px;vertical-align:-3px}
.caret svg.lucide{width:14px;height:14px}
.icon-btn svg.lucide{width:17px;height:17px}
.ai-icon{color:var(--brand2)}

/* tre priskort på en rad */
.pricing{grid-template-columns:repeat(3,1fr)}
.pricing.compact{grid-template-columns:repeat(3,1fr)}
.offer-note{margin:0 0 18px}
@media (max-width:640px){.pricing,.pricing.compact{grid-template-columns:1fr}}

/* förslag på nästa steg i chatten */
.suggestions{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:6px 0 2px;padding:0 4px}
.chip{border:1px solid var(--brand2);color:var(--brand2);background:#fff;border-radius:999px;padding:4px 12px;font-size:12.5px;cursor:pointer}
.chip:hover{background:var(--brand2);color:#fff}

/* ===== profil & inbjudningar ===== */
.prof-grid{display:grid;grid-template-columns:auto 1fr;gap:5px 14px;align-items:center;margin:6px 0 4px}
.prof-h{margin:14px 0 6px;font-size:14px}
.prof-colleagues,.inv-colleagues{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow:auto}
.prof-col,.inv-col{padding:5px 8px;border:1px solid var(--line);border-radius:7px}
.inv-viewer{margin:8px 0;font-size:13px}
.inv-viewer input{width:auto}
.modal h4{margin:0}

/* granskningsläge */
.viewer-tag{background:#fff7ed;color:#9a3412;border:1px solid #fdba74;display:inline-flex;align-items:center;gap:4px}
.viewer-tag svg.lucide{width:13px;height:13px}

/* toast */
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:9px 16px;border-radius:9px;font-size:13.5px;z-index:200;box-shadow:0 4px 16px rgba(0,0,0,.2)}

/* chatt: metarad med författare + tid */
.msg-head{display:flex;gap:8px;align-items:baseline;margin-bottom:2px;padding:0 2px}
.msg-author{font-weight:600;color:var(--ink)}
.msg.user .msg-head{justify-content:flex-end}
.msg-time{font-size:11px}

/* väntar-på-aktivering-banner */
#pendingBanner{flex:none;background:#fff7ed;border-bottom:1px solid #fdba74;color:#9a3412;
  padding:9px 16px;font-size:13.5px;text-align:center}

/* medlemslista med ta-bort */
.mem-row{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:2px 0;font-size:13px}
.mem-row .x{flex:none;opacity:.6}
.mem-row:hover .x{opacity:1}
.mem-sub{font-style:italic;color:var(--muted);font-size:12px;margin-top:6px}
.mem-row .x svg.lucide{width:14px;height:14px}

/* företagsnamn i topbaren (endast desktop) */
.company-name{border:none;background:none;color:var(--muted);font-size:13px;cursor:pointer;
  padding:4px 8px;border-radius:6px;max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.company-name:hover{background:#eef2f7;color:var(--ink)}
.company-name::before{content:"·";margin-right:8px;color:var(--line)}
@media (max-width:680px){.company-name{display:none !important}}

/* bred modal: prof-grid får mer plats för värdet */
.modal.wide .prof-grid{grid-template-columns:160px 1fr;gap:8px 18px}

/* uppgraderingsmodal */
.upg-price{font-size:18px;color:var(--brand);margin:4px 0}

/* ===== mängdning (takeoff) ===== */
.takeoff .ide-body{display:flex}
.to-pdf{flex:0 0 52%;min-width:280px;border-right:1px solid var(--line);background:#525659;
  display:flex;flex-direction:column}
/* dölj ritningspanelen → mängdlistan får full bredd */
.takeoff.pdf-hidden #toPdfPane,
.takeoff.pdf-hidden #toSplitter{display:none}
.takeoff.pdf-hidden .to-right{flex:1 1 100%}
/* förhandsvisnings-flikar: original / aktuell mängdning / sparade versioner */
.to-tabs{flex:none;display:flex;gap:3px;padding:5px 6px 0;background:#2b2f33;overflow-x:auto}
.to-tab{flex:none;background:#3a3f44;color:#cfd4da;border:none;border-radius:7px 7px 0 0;
  padding:5px 12px;font-size:12px;cursor:pointer;white-space:nowrap}
.to-tab:hover{background:#474d53;color:#fff}
.to-tab.active{background:#fff;color:var(--brand);font-weight:600}
.to-frames{position:relative;flex:1;min-height:0}
.to-frames iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:none}
.to-frames iframe.active{display:block}
.vsplit{flex:none;width:5px;cursor:col-resize;background:transparent;border-right:1px solid var(--line)}
.vsplit:hover{background:var(--brand2)}
.to-right{flex:1;min-width:0}
.to-right #toListPane{flex:1 1 60%;min-height:0}
.to-right #toListPane .pane-c{overflow:auto;padding:8px 10px}
.to-right .to-chat{flex:0 0 38%;min-height:0;border-top:1px solid var(--line)}
.to-right .to-chat .pane-c{display:flex;flex-direction:column;min-height:0;padding:8px 10px}
.pane-h #toCount{margin-left:auto;text-transform:none;font-weight:400}
h4.to-room{margin:10px 0 3px;font-size:13px;color:var(--brand);position:sticky;top:0;background:#fff}
table.to-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
table.to-tbl th{font-size:10.5px;text-transform:uppercase;color:var(--muted);text-align:left;padding:2px 4px}
table.to-tbl td{padding:1px 3px;border-bottom:1px solid var(--line)}
.to-cell{width:100%;border:1px solid transparent;background:transparent;border-radius:4px;padding:3px 5px;font:inherit;font-size:12.5px}
.to-cell:hover{border-color:var(--line)} .to-cell:focus{border-color:var(--brand2);background:#fff;outline:none}
tr.to-off .to-cell{color:var(--muted);text-decoration:line-through}
#toChatForm{display:flex;gap:6px;align-items:flex-end;flex:none}
#toChatForm textarea{flex:1;min-width:0;resize:vertical}
#toChatForm button{flex:none}
.toolbar{flex-wrap:wrap}
.toolbar select.small{height:30px;width:auto;min-width:200px;max-width:360px;flex:0 1 auto;padding:4px 8px}

/* mängdning: arbetar/fel-tillstånd */
.to-working{display:flex;flex-direction:column;align-items:center;gap:8px;padding:36px 16px;text-align:center}
.to-working .spinner{width:34px;height:34px}
.to-working p{margin:0}

/* ===== guidad mängdning (steg) ===== */
#toStage{margin-bottom:8px}
.to-step{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.to-badge{display:inline-block;padding:2px 9px;border-radius:11px;font-size:12px;font-weight:600;
  background:var(--brand);color:#fff}
.to-badge.ok{background:#1c7c4a}
.to-interp{white-space:pre-wrap;font-size:13px;line-height:1.5;background:#fafbfc;
  border:1px solid var(--line);border-radius:8px;padding:10px 12px;max-height:46vh;overflow:auto}
.to-interp strong{color:var(--brand)}
.to-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px}
.to-page{width:5em;margin-left:4px}

/* ===== processteg i projektvyn ===== */
.steps{flex:none;display:flex;align-items:center;gap:10px;padding:7px 14px;
  border-bottom:1px solid var(--line);background:#fafbfc;font-size:13px}
.steps .step{display:flex;align-items:center;gap:6px;color:var(--muted)}
.steps .step-no{display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;border:1px solid currentColor;font-size:11px;font-weight:600}
.steps .step.active{color:var(--brand);font-weight:600}
.steps .step.active .step-no{background:var(--brand);color:#fff;border-color:var(--brand)}
.steps .step.done{color:var(--ok)}
.steps .step.done .step-no{background:var(--ok);color:#fff;border-color:var(--ok)}
.steps .step-arrow{color:var(--line)}
.steps #stepCta{flex:none}

/* ===== Prisdata / Referens (lagly-tabeller) ===== */
.topnav{color:#cbd5e1}
.pricedata, .referens{max-width:1100px}
.pd-search{display:block;width:100%;max-width:640px;margin:14px 0;padding:10px 14px;border:1px solid var(--line);border-radius:8px;font:inherit;box-sizing:border-box}
.ptable{width:100%;border-collapse:collapse;font-size:13px;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-top:6px}
.ptable th{text-align:left;padding:9px 12px;background:#f1f5f9;border-bottom:1px solid #cbd5e1;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:600}
.ptable td{padding:8px 12px;border-bottom:1px solid var(--line)}
.ptable .num{text-align:right;font-variant-numeric:tabular-nums}
.ptable tr.pd-row{cursor:pointer}
.ptable tr.pd-row:hover{background:#f8fafc}
.ptable.sub{border:none;margin:2px 0}
.ptable.sub th{background:#eef2f7}
.pd-src > td{background:#fbfcfe;padding:8px 12px 12px 28px}
.upload-ref .primary-like{display:inline-block;background:var(--brand);color:#fff;border-radius:8px;padding:8px 14px;cursor:pointer;font-size:13px;font-weight:500}
.upload-ref .primary-like:hover{background:var(--brand2)}
.ref-form{align-items:flex-end;gap:14px;margin:14px 0}
.ref-form label{display:flex;flex-direction:column;font-size:12px;color:var(--muted);gap:4px}
.ref-form input{width:170px}
.komm-warn{color:#b45309;font-weight:500}
.komm-ok{color:#15803d}

/* ===== Desktop-app: vänster sidofält istället för toppbar ===== */
body{flex-direction:row}
#topbar{flex-direction:column;align-items:stretch;width:218px;height:100vh;padding:0;gap:0;
  border-bottom:none;border-right:1px solid #0f172a;overflow-y:auto;flex:none}
#topbar .brand{padding:16px 18px;border-bottom:1px solid #0f172a}
#topbar .topnav{width:100%;text-align:left;border:none;border-radius:0;margin:0;
  padding:10px 18px 10px 15px;border-left:3px solid transparent;font-size:13.5px;font-weight:500}
#topbar .topnav:hover{background:#334155;border-left-color:#475569}
#topbar .topnav.active{background:#334155;color:#fff;border-left-color:var(--brand)}
#topbar .spacer{flex:1 1 auto}
#topbar #adminLink,#topbar #userEmail,#topbar #logoutBtn{width:100%;text-align:left;border:none;
  border-radius:0;padding:9px 18px;font-size:12.5px}
#topbar #userEmail{border-top:1px solid #0f172a}
main{height:100vh}
/* full desktop-bredd för listvyer; inloggning förblir centrerad */
main > .projects{max-width:none;padding:22px 28px}
.pricedata,.referens{max-width:none}
.ptable{max-width:1500px}
#pendingBanner{align-self:flex-start}

/* ===== Login (intern app) ===== */
main > .login-card{max-width:380px;margin:12vh auto;padding:36px 32px;border-radius:14px;
  box-shadow:0 8px 30px rgba(15,23,42,.10);border:1px solid var(--line)}
.login-brand{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.login-word{font-size:13px;font-weight:600;letter-spacing:2px;color:var(--muted)}
.login-sub{margin:0 0 22px;font-size:13px}
.login-card form label{font-weight:600;color:var(--ink);font-size:13px}
.login-card .primary{width:100%;margin-top:6px;padding:11px}

/* ===== Admin: feature-toggles ===== */
.feat-list{max-width:680px;border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:8px 0 22px}
.feat-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 16px;border-bottom:1px solid var(--line);background:#fff}
.feat-row:last-child{border-bottom:none}
.feat-name{font-weight:600}
.switch{position:relative;display:inline-block;width:42px;height:24px;flex:none}
.switch input{opacity:0;width:0;height:0}
.switch .slider{position:absolute;inset:0;background:#cbd5e1;border-radius:24px;transition:.15s;cursor:pointer}
.switch .slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.15s}
.switch input:checked + .slider{background:var(--brand)}
.switch input:checked + .slider:before{transform:translateX(18px)}

/* ===== Projektsummering ===== */
.summary-box{background:#eef6ff;border:1px solid #bfdbfe;border-radius:8px;padding:12px 14px;margin-bottom:14px}
.summary-box .sum-head{margin-bottom:6px}
.summary-box p{margin:0 0 8px}
.sum-facts{margin:0;padding-left:18px}
.sum-facts li{margin:2px 0;font-size:13px}

/* ===== CV-byggare ===== */
.cv-grid{display:grid;grid-template-columns:320px 1fr;gap:20px;margin-top:14px;align-items:start}
.cv-fields{padding:16px}
.cv-fields label{display:block;margin-bottom:12px;font-weight:600;font-size:13px}
.cv-foto-prev{width:96px;height:96px;object-fit:cover;border-radius:8px;border:1px solid var(--line);margin-top:6px}
.cv-projects h2{margin:0 0 10px}
.cv-row{display:flex;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:8px;margin-bottom:10px;background:#fff}
.cv-row.off{opacity:.5}
.cv-include{margin-top:3px;width:16px;height:16px;flex:none;accent-color:var(--brand)}
.cv-row-main{flex:1;min-width:0}
.cv-row-head{display:flex;align-items:center;gap:14px;margin-bottom:6px;flex-wrap:wrap}
.cv-row-head .lyft{color:var(--muted);font-weight:500}
.cv-ai{border:1px solid var(--brand);color:var(--brand);background:#fff;border-radius:6px;padding:3px 10px;cursor:pointer;font-size:12px}
.cv-text{width:100%;font:inherit}
.cv-fields input,.cv-fields textarea{width:100%;padding:9px;border:1px solid var(--line);border-radius:8px;font:inherit;margin-top:4px;color:var(--ink)}
.cv-fields label{font-weight:600;font-size:13px;color:var(--muted)}

/* ---- credits + chefsvy ---- */
.credit-pill{background:#eef2ff;color:var(--brand2);border:1px solid #c7d2fe;border-radius:999px;
  padding:4px 12px;font-weight:600;font-size:13px;cursor:pointer}
.credit-pill.low{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.cr-summary{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:8px 0 16px}
.cr-big{display:flex;align-items:baseline;gap:10px}
.cr-num{font-size:30px;font-weight:700;color:var(--brand2)}
.cr-h{font-size:14px;margin:14px 0 6px;color:var(--ink)}
.cr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-bottom:8px}
.cr-grid table{width:100%}
input.cr-cost{width:70px;text-align:right;padding:4px 6px;border:1px solid var(--line);border-radius:6px;font:inherit}
.sum-actions{margin-top:8px}
.sum-spec{margin-top:8px}
.sum-spec summary{cursor:pointer;font-weight:600;color:var(--brand2);font-size:13px}
.sum-spec p{margin-top:6px}
.credit-pill.over{background:#fffbeb;color:#b45309;border-color:#fde68a}
.cr-over{margin:6px 0;padding:8px 10px;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;color:#92400e;font-size:13px}

/* ---- användningstratt ---- */
.funnel{display:flex;flex-direction:column;gap:6px}
.fn-row{display:grid;grid-template-columns:150px 1fr 70px;align-items:center;gap:8px}
.fn-label{font-size:13px;color:var(--ink)}
.fn-bar{background:#eef2ff;border-radius:6px;height:18px;overflow:hidden}
.fn-fill{background:var(--brand);height:100%;border-radius:6px}
.fn-val{font-size:13px;text-align:right;font-weight:600;color:var(--ink)}

/* ---- AI-svarets kreditkostnad ---- */
.ctag{display:inline-block;margin-left:8px;font-size:11px;font-weight:600;color:var(--brand2);
  background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;padding:1px 8px;vertical-align:middle}

/* ---- sessionsuppspelning (overlay) ---- */
.replay-overlay{position:fixed;inset:0;background:rgba(15,23,42,.6);display:flex;align-items:center;
  justify-content:center;z-index:1000}
.replay-box{background:#fff;border-radius:12px;padding:16px;position:relative;max-width:95vw;max-height:95vh;overflow:auto}
.replay-close{position:absolute;top:8px;right:10px;border:none;background:none;font-size:18px;cursor:pointer;color:var(--muted)}

/* ---- backtest / acceptans-scorecard ---- */
.sc-targets{margin:6px 0 12px}
.sc-targets summary{cursor:pointer;font-weight:600;color:var(--brand2);font-size:13px}
.sc-tg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:10px}
.sc-tg{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:3px}
.sc-tg input{padding:5px 7px;border:1px solid var(--line);border-radius:6px;font:inherit;color:var(--ink)}
.sc-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:12px 0}
.sc-card{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:var(--panel)}
.sc-card.ok{border-color:#bbf7d0;background:#f0fdf4}
.sc-card.miss{border-color:#fecaca;background:#fef2f2}
.sc-val{font-size:26px;font-weight:700;color:var(--ink)}
.sc-lbl{font-size:13px;color:var(--ink);margin-top:2px}
.sc-detail td.sc-g{color:#16a34a;font-weight:600}
.sc-detail td.sc-r{color:#b91c1c;font-weight:600}
.sc-detail tr.sc-miss td{background:#fef2f2}

/* ---- mängdning: metodval ---- */
.to-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:8px}
.to-method{border:1px solid var(--line);border-radius:10px;padding:11px 12px;background:var(--panel);display:flex;flex-direction:column;gap:6px}
.to-method.rec{border-color:var(--brand);background:#eef2ff}
.to-method .tm-h{font-weight:700;color:var(--ink);font-size:13px}
.to-method .muted{flex:1}
.to-method button{align-self:flex-start}

/* ---- metodval direkt efter upload ---- */
.step-prompt{background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;padding:12px 14px;margin:8px 0}
.step-prompt .sp-head{font-weight:700;color:var(--brand2);font-size:13px;display:flex;align-items:center;gap:6px;margin-bottom:8px}
.step-prompt .sp-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-bottom:6px}
.step-prompt .sp-methods button{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;height:auto;padding:8px 10px}
.step-prompt .sp-methods button b{font-size:12.5px;color:var(--ink)}
.step-prompt .sp-methods button span{font-size:11px;color:var(--muted);font-weight:400}

/* ---- kostnad i metodval ---- */
.to-method .tm-cost{font-size:12px;font-weight:700;color:var(--brand2)}
.step-prompt .sp-methods button em{font-style:normal;font-weight:700;color:var(--brand2);font-size:11px;margin-top:2px}

/* ---- visa alla projekt-toggle ---- */
.all-toggle{display:inline-flex;align-items:center;gap:8px;margin-right:12px}

/* ---- AI-tydning av dokument ---- */
.tag.doc-type{background:#eef2ff;color:var(--brand2);border:1px solid #c7d2fe}

/* ---- felloggen (admin) ---- */
.err-table td{vertical-align:top;font-size:12.5px}
.err-detail{white-space:pre-wrap;font-size:11px;max-height:240px;overflow:auto;background:#0f172a;color:#e2e8f0;padding:8px;border-radius:6px;margin:4px 0 0}
#errClearBtn{margin-left:10px;font-size:12px;padding:2px 8px}

/* ---- admin-flikar ---- */
.admin-tabs{display:flex;gap:4px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin:14px 0 18px}
.admin-tab{border:none;background:none;padding:8px 14px;border-bottom:2px solid transparent;border-radius:0;color:var(--muted);font-weight:600;font-size:13px;cursor:pointer}
.admin-tab:hover{color:var(--ink);background:#f3f6fa}
.admin-tab.active{color:var(--brand2);border-bottom-color:var(--brand)}
.admin-pane > h2:first-child{margin-top:0}

/* ---- auto-fix (admin) ---- */
.err-table .fix-btn{white-space:nowrap}
.fix-panel{margin-top:16px;padding:14px 16px;border:1px solid var(--line);border-radius:10px;background:#fbfcfe}
.fix-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.fix-expl{white-space:pre-wrap;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin:8px 0;font-size:13px;line-height:1.5}
.fix-panel pre.diff{background:#0f172a;color:#cbd5e1;border-radius:8px;padding:12px;overflow:auto;font-size:12px;line-height:1.45;max-height:480px}
.fix-panel pre.diff .d-add{color:#86efac;display:block}
.fix-panel pre.diff .d-del{color:#fca5a5;display:block}
.fix-panel pre.diff .d-hunk{color:#7dd3fc;display:block}
.ok-tag{color:#15803d;font-weight:600;font-size:12px}
.bad-tag{color:#b91c1c;font-weight:600;font-size:12px}
