:root{
  --bg:#f4f5f7; --panel:#fff; --line:#e2e5ea; --ink:#1f2430; --muted:#6b7280;
  --brand:#1f4e78; --brand2:#2f6fb0; --spec:#c2410c; --ok:#15803d;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
body{margin:0;font:15px/1.5 -apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink)}
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:7px 14px;background:#fff;border-bottom:1px solid var(--line);z-index:5}
.brand{font-weight:700;color:var(--brand);cursor:pointer}
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: select krymper, knappar håller plats */
#draftHeader #versionSelect{flex:1 1 auto;min-width:80px;max-width:100%;
  text-transform:none;font-weight:400;height:22px;padding:0 4px}
#draftHeader button{flex:none;text-transform:none;font-weight:500;
  height:22px;padding:2px 8px;white-space:nowrap}
#draftHeader > span:nth-child(2){flex:none}
#draftHeader{gap:5px;padding:0 8px}
.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)}
form input,form textarea,select{width:100%;padding:9px;border:1px solid var(--line);border-radius:8px;font:inherit;color:var(--ink)}
.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}
