:root{
  --bg:#070809; --panel:#0d0e12; --panel-2:#101218; --raise:#171a21;
  --line:rgba(255,255,255,.07); --line-strong:rgba(255,255,255,.12); --line-glow:rgba(255,255,255,.18);
  --text:#f1f3f7; --text-dim:#9aa3b1; --text-faint:#5b6470;
  --accent:#2dd4d4; --accent-bright:#5ff0f0; --accent-deep:#0ea5b5;
  --accent-glow:rgba(45,212,212,.4); --accent-soft:rgba(45,212,212,.1);
  --amber:#f5c451; --amber-soft:rgba(245,196,81,.12);
  --green:#4ade80; --green-soft:rgba(74,222,128,.12);
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-pill:100px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --side-w:248px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--text);font-family:'Inter',system-ui,sans-serif;font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow:hidden}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;letter-spacing:-.01em;font-weight:600;line-height:1.15}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
.logo-lockup{display:inline-flex;align-items:center;gap:10px}
.logo-mark{height:22px;width:auto}
.logo-word{font-family:'Orbitron',sans-serif;font-weight:700;font-size:14px;letter-spacing:.16em;color:var(--text);padding-top:2px}

/* buttons */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;padding:11px 20px;border-radius:var(--r-pill);transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s;white-space:nowrap}
.btn::before{content:"";position:absolute;inset:0;border-radius:inherit;border-top:1px solid rgba(255,255,255,.35);-webkit-mask:linear-gradient(180deg,#000,transparent 55%);mask:linear-gradient(180deg,#000,transparent 55%)}
.btn:hover{transform:scale(1.03)}.btn:active{transform:scale(.98)}
.btn-primary{background:linear-gradient(180deg,var(--accent-bright),var(--accent));color:#021416;box-shadow:0 2px 10px rgba(45,212,212,.2)}
.btn-primary::before{border-top-color:rgba(255,255,255,.6)}
.btn-ghost{background:rgba(255,255,255,.04);border:1px solid var(--line-strong);color:var(--text)}
.btn-ghost::before{border-top-color:rgba(255,255,255,.18)}
.btn-sm{padding:8px 15px;font-size:13px}

/* ============ LOGIN ============ */
#loginView{height:100%;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto}
.login-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:38px 34px;position:relative;overflow:hidden}
.login-card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-glow),transparent)}
.login-card .logo-lockup{margin-bottom:28px}
.login-card h1{font-size:24px;margin-bottom:6px}
.login-card .sub{color:var(--text-dim);font-size:14px;margin-bottom:26px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;color:var(--text-dim);margin-bottom:7px}
.field input{width:100%;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:12px 14px;color:var(--text);font-size:14px;font-family:inherit;transition:border-color .25s}
.field input:focus{outline:none;border-color:var(--accent)}
.login-card .btn-primary{width:100%;margin-top:6px}
.demo-accounts{margin-top:26px;border-top:1px solid var(--line);padding-top:20px}
.demo-accounts .lbl{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin-bottom:12px}
.demo-row{display:flex;gap:8px;flex-wrap:wrap}
.demo-chip{flex:1;min-width:120px;text-align:left;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:11px 13px;transition:border-color .25s,transform .25s}
.demo-chip:hover{border-color:var(--accent);transform:translateY(-2px)}
.demo-chip .nm{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:7px}
.demo-chip .rl{font-size:11.5px;color:var(--text-faint);margin-top:2px}
.dotc{width:8px;height:8px;border-radius:50%;background:var(--accent)}

/* ============ APP SHELL — cohesive frame, edge to edge ============ */
#appView{display:none;height:100%}
.shell{display:grid;grid-template-columns:var(--side-w) 1fr;height:100%}

/* sidebar */
.side{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100%;overflow:hidden}
.side-top{padding:18px 16px 14px}
.side .logo-lockup{padding:4px 6px 0}
.cust-picker{margin-top:18px}
.cust-picker .plabel{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px;padding-left:2px}
.cust-picker .pwrap{position:relative}
/* small avatar dot to the left, chevron to the right, pill-like feel */
.cust-picker .pwrap::before{content:"";position:absolute;left:13px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);pointer-events:none;z-index:1}
.cust-picker select{width:100%;background:linear-gradient(180deg,var(--raise),var(--panel-2));border:1px solid var(--line-strong);border-radius:var(--r-pill);color:var(--text);
  padding:11px 36px 11px 30px;font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:600;cursor:pointer;appearance:none;
  transition:border-color .2s,box-shadow .2s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232dd4d4' stroke-width='2.2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center}
.cust-picker select:hover{border-color:rgba(45,212,212,.4)}
.cust-picker select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.cust-picker option{background:var(--panel);color:var(--text);font-weight:500}
.side-nav{padding:8px 12px;display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--line);margin-top:14px;padding-top:14px}
.side .navitem{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--r-md);color:var(--text-dim);font-size:14px;font-weight:500;transition:background .2s,color .2s;cursor:pointer}
.side .navitem svg{width:18px;height:18px;flex:none}
.side .navitem:hover{background:var(--panel-2);color:var(--text)}
.side .navitem.active{background:var(--accent-soft);color:var(--accent)}
.side .spacer{flex:1}
.side .who{border-top:1px solid var(--line);padding:14px}
.who-id{display:flex;align-items:center;gap:10px;min-width:0}
.who-avatar{width:36px;height:36px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,var(--accent-bright),var(--accent-deep));color:#021416;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px}
.who-meta{min-width:0}
.who-meta .nm{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.who-meta .rl{font-size:11.5px;color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.who-actions{display:flex;align-items:center;gap:8px;margin-top:12px}
.who-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:12.5px;font-weight:500;
  color:var(--text-dim);background:rgba(255,255,255,.04);border:1px solid var(--line-strong);border-radius:var(--r-sm);
  padding:8px 10px;cursor:pointer;transition:border-color .2s,color .2s,background .2s}
.who-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.who-btn svg{width:15px;height:15px;flex:none}
.who-btn.icon{flex:none;width:36px;padding:8px}

/* main content area — fills fully, scrolls internally */
.content{position:relative;display:flex;flex-direction:column;height:100%;min-width:0;overflow:hidden}
.content::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(800px 500px at 85% -5%,rgba(45,212,212,.06),transparent 60%)}
.cbar,.cscroll{position:relative;z-index:1}
.cbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 28px;height:60px;border-bottom:1px solid var(--line);flex:none;background:var(--panel)}
.cbar .crumb{font-size:12.5px;color:var(--text-faint);letter-spacing:.03em}
.cbar h2{font-size:18px}
.cbar .ttl{display:flex;flex-direction:column;gap:2px;min-width:0}
.cscroll{flex:1;overflow-y:auto;min-height:0}
.cpad{padding:28px}

/* section blocks (cohesive — subtle separators, not floating cards) */
.block{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);overflow:hidden}
.block::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-glow),transparent);z-index:1}
.block + .block{margin-top:16px}
.block-head{padding:14px 20px;border-bottom:1px solid var(--line);font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-family:'Space Grotesk',sans-serif}
.block-body{padding:6px 20px 8px}

/* stat strip */
.stats{position:relative;display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--panel);margin-bottom:16px}
.stats::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-glow),transparent);z-index:1}
.stat{padding:18px 20px;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .lbl{font-size:12px;color:var(--text-faint);margin-bottom:6px;letter-spacing:.03em}
.stat .v{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:600}
.stat .v small{font-size:14px;color:var(--text-dim);font-weight:500}
.stat.accent{position:relative}
.stat.accent::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(120px 80px at 30% 0%,var(--accent-soft),transparent 70%)}
.stat.accent .v{color:var(--accent);position:relative}

.ov-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.ov-grid .block + .block{margin-top:0}
.proj-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line)}
.proj-row:last-child{border-bottom:0}
.proj-row .pn{font-weight:600;font-size:15px}
.proj-row .pm{font-size:12.5px;color:var(--text-faint);margin-top:3px}
.progress{height:5px;background:var(--raise);border-radius:5px;overflow:hidden;width:120px;margin-top:8px}
.progress>i{display:block;height:100%;background:linear-gradient(90deg,var(--accent-deep),var(--accent-bright))}
.pill{font-size:11.5px;padding:4px 11px;border-radius:var(--r-pill);font-weight:600;font-family:'Space Grotesk',sans-serif;white-space:nowrap}
.pill.active{color:var(--accent);background:var(--accent-soft)}
.pill.done{color:var(--green);background:var(--green-soft)}
.pill.hold{color:var(--amber);background:var(--amber-soft)}
.deliverable{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);font-size:14px}
.deliverable:last-child{border-bottom:0}
.deliverable .ic{width:34px;height:34px;border-radius:var(--r-sm);background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent);flex:none}
.deliverable .meta{color:var(--text-faint);font-size:12px;margin-top:2px}
.deliverable .dl{margin-left:auto;color:var(--text-faint);cursor:pointer}
.deliverable .dl:hover{color:var(--accent)}
.activity{display:flex;gap:12px;padding:11px 0}
.activity .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:6px;flex:none;box-shadow:0 0 8px var(--accent-glow)}
.activity .txt{font-size:13.5px}.activity .txt b{font-weight:600}
.activity .when{font-size:12px;color:var(--text-faint);margin-top:2px}
.row-cust{color:var(--accent);font-weight:500}

/* ============ KANBAN ============ */
.hint{font-size:12.5px;color:var(--text-faint);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.hint svg{width:15px;height:15px;color:var(--accent)}
.kanban-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.ktb-search{display:flex;align-items:center;gap:8px;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-pill);padding:8px 14px;flex:1;min-width:200px;max-width:380px;transition:border-color .2s}
.ktb-search:focus-within{border-color:var(--accent)}
.ktb-search svg{width:15px;height:15px;color:var(--text-faint);flex:none}
.ktb-search input{background:none;border:0;color:var(--text);font-family:inherit;font-size:13.5px;width:100%;outline:none}
.ktb-filter{flex:none}
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}
.col{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:12px;min-height:160px;transition:border-color .25s,background .25s}
.col.dragover{border-color:var(--accent);background:rgba(45,212,212,.04)}
.col-head{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 12px}
.col-head .ct{display:flex;align-items:center;gap:9px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px}
.col-head .count{font-size:12px;color:var(--text-faint);background:var(--raise);border-radius:var(--r-pill);padding:2px 9px}
.marker{width:9px;height:9px;border-radius:50%}
.m-req{background:var(--text-faint)}.m-prog{background:var(--accent)}.m-done{background:var(--green)}
.task{background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:13px;margin-bottom:9px;position:relative;transition:border-color .25s,transform .2s,box-shadow .25s}
.task[draggable="true"]{cursor:grab}
.task[draggable="true"]:hover{border-color:rgba(45,212,212,.35);box-shadow:0 8px 24px -16px var(--accent-glow)}
.task.dragging{opacity:.4}
.task .tt{font-weight:600;font-size:14px;margin-bottom:6px}
.task .td{font-size:12.5px;color:var(--text-dim);margin-bottom:10px}
.task .tf{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tag{font-size:11px;padding:3px 9px;border-radius:var(--r-pill);background:var(--panel);border:1px solid var(--line-strong);color:var(--text-dim)}
.tag.est{color:var(--accent);border-color:rgba(45,212,212,.3);background:var(--accent-soft)}
.tag.prio-high{color:var(--amber);border-color:rgba(245,196,81,.35);background:var(--amber-soft)}
.tag.prio-low{color:var(--text-faint)}
/* priority segmented picker (modal + task panel) */
.prio-pick{display:inline-flex;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-pill);padding:3px;gap:2px}
.prio-pick button{padding:6px 14px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;font-family:'Space Grotesk',sans-serif;color:var(--text-faint);transition:background .15s,color .15s}
.prio-pick button.on{background:var(--panel);color:var(--text)}
.prio-pick button[data-v="high"].on{color:var(--amber);background:var(--amber-soft)}
.prio-pick button[data-v="low"].on{color:var(--text-dim)}
.add-task{width:100%;text-align:left;padding:10px 12px;border-radius:var(--r-md);border:1px dashed var(--line-strong);color:var(--text-faint);font-size:13px;transition:border-color .25s,color .25s}
.add-task:hover{border-color:var(--accent);color:var(--accent)}
.cust-tag{position:absolute;top:11px;right:11px;font-size:10.5px;color:var(--text-faint);background:var(--panel);border:1px solid var(--line-strong);padding:2px 8px;border-radius:var(--r-pill)}

/* ============ ROADMAP / FÄRDPLAN ============ */
.roadmap{max-width:820px}
.rm-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px}
.rm-title{font-size:18px}
.rm-sub{font-size:13px;color:var(--text-faint);margin-top:3px}
.rm-empty{color:var(--text-faint);font-size:14px;padding:32px 0;text-align:center}
.rm-timeline{display:flex;flex-direction:column}
.phase{position:relative;display:flex;gap:16px;padding-bottom:14px}
.phase::before{content:"";position:absolute;left:16px;top:34px;bottom:-2px;width:2px;background:var(--line)}
.phase:last-child::before{display:none}
.phase-node{width:34px;height:34px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;border:2px solid var(--line-strong);background:var(--panel);color:var(--text-faint);z-index:1;cursor:pointer;transition:border-color .2s,color .2s,box-shadow .2s,background .2s}
.phase-node.active{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.phase-node.done{border-color:var(--green);color:var(--green);background:var(--green-soft)}
.phase-body{flex:1;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:13px 15px;min-width:0}
.phase.active .phase-body{border-color:rgba(45,212,212,.3)}
.phase-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.phase-title{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px}
.phase-status{font-size:11px;padding:3px 10px;border-radius:var(--r-pill);font-weight:600;font-family:'Space Grotesk',sans-serif;cursor:pointer;background:var(--raise);color:var(--text-faint);border:1px solid var(--line-strong)}
.phase-status.active{color:var(--accent);background:var(--accent-soft);border-color:rgba(45,212,212,.3)}
.phase-status.done{color:var(--green);background:var(--green-soft);border-color:rgba(74,222,128,.3)}
.phase-actions{margin-left:auto;display:flex;gap:2px;align-items:center}
.rm-ico{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--text-faint);transition:background .15s,color .15s}
.rm-ico:hover:not(:disabled){background:var(--raise);color:var(--text)}
.rm-ico:disabled{opacity:.25;cursor:default}
.rm-ico.danger:hover{color:#ff8d8d;background:rgba(255,90,90,.1)}
.phase-desc{font-size:13px;color:var(--text-dim);margin-top:6px;line-height:1.5}

/* ============ TID / TIDSREGISTRERING ============ */
.time-head{margin-bottom:18px}
.tf-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:4px}
.field textarea{width:100%;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:11px 13px;color:var(--text);font-family:inherit;font-size:14px;resize:vertical;min-height:64px}
.field textarea:focus{outline:none;border-color:var(--accent)}
.time-rows-head,.time-owner-head{display:flex;align-items:center;justify-content:space-between;gap:10px;text-transform:none;letter-spacing:0}
.time-rows-sum{display:inline-flex;align-items:center;gap:10px;color:var(--text-dim);font-family:'Space Grotesk',sans-serif;font-weight:600}
.time-owner-stat{color:var(--accent);font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:0;text-transform:none}
.time-table{width:100%;border-collapse:collapse;font-size:13.5px}
.time-table th{text-align:left;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);font-family:'Space Grotesk',sans-serif;padding:10px 16px;border-bottom:1px solid var(--line)}
.time-table td{padding:11px 16px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--text-dim)}
.time-table tr:last-child td{border-bottom:0}
.time-table .te-date{white-space:nowrap;color:var(--text)}
.time-table .te-h{text-align:right;white-space:nowrap;color:var(--accent);font-family:'Space Grotesk',sans-serif;font-weight:600}
.time-table .te-desc{line-height:1.45}
.time-table .te-act{text-align:right;width:36px}
.time-table .m-remove{color:var(--text-faint);cursor:pointer;display:inline-flex;padding:3px;border-radius:6px}
.time-table .m-remove:hover{color:#ff8d8d;background:rgba(255,90,90,.1)}
.time-rate-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.time-rate-row label{font-size:12.5px;color:var(--text-faint)}
.time-rate-row input{width:120px;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-sm);color:var(--text);padding:8px 12px;font-family:inherit;font-size:13.5px}
.time-rate-row input:focus{outline:none;border-color:var(--accent)}
.time-grand{margin-top:16px;text-align:right;font-size:15px;color:var(--text)}
.time-grand b{font-family:'Space Grotesk',sans-serif;color:var(--accent)}
@media(max-width:640px){ .tf-grid{grid-template-columns:1fr 1fr} }

/* ============ KNOWLEDGE BASE — cohesive split, edge to edge ============ */
.kb{display:flex;align-items:stretch;height:100%;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--panel)}
.kb-list{flex:1;min-width:0;overflow-y:auto}
.kb-table{width:100%;border-collapse:collapse}
.kb-table th{text-align:left;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-family:'Space Grotesk',sans-serif;font-weight:600;padding:16px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel);z-index:1}
.kb-row{cursor:pointer;transition:background .18s}
.kb-row td{padding:13px 22px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
.kb-row:hover{background:var(--panel-2)}
.kb-row.sel{background:var(--accent-soft)}
.kb-row.sel td:first-child{box-shadow:inset 3px 0 0 var(--accent)}
.kb-file{display:flex;align-items:center;gap:11px}
.kb-file .fic{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex:none;font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:500}
.fic.md{background:rgba(45,212,212,.13);color:var(--accent)}
.fic.html{background:rgba(245,196,81,.13);color:var(--amber)}
.fic.txt{background:rgba(163,172,186,.13);color:var(--text-dim)}
.kb-file .fn{font-weight:500}
.kb-file .fd{font-size:12px;color:var(--text-faint);margin-top:1px}
.kb-when{color:var(--text-faint);font-size:13px;white-space:nowrap}
.kb.reading .kb-when,.kb.reading th.col-when{display:none}
.kb.reading .kb-file .fd{display:none}

.kb-split{display:none;width:1px;flex:none;cursor:col-resize;background:var(--line);position:relative}
.kb.reading .kb-split{display:block}
.kb-split::after{content:"";position:absolute;inset:0 -5px;cursor:col-resize}
.kb-split:hover,.kb-split.active{background:var(--accent)}
body.col-resizing{cursor:col-resize;user-select:none}

.kb-reader{display:none;flex:none;flex-basis:560px;min-width:340px;flex-direction:column;background:var(--panel-2);overflow:hidden}
.kb.reading .kb-reader{display:flex}
.kb-reader-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 12px 0 18px;height:52px;border-bottom:1px solid var(--line);background:var(--panel);flex:none}
.kb-reader-head .ti{display:flex;align-items:center;gap:10px;min-width:0}
.kb-reader-head .eye{color:var(--text-faint);display:flex}
.kb-reader-head .fn{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kb-reader-head .typebadge{font-size:10px;font-family:'JetBrains Mono',monospace;padding:2px 7px;border-radius:5px;border:1px solid var(--line-strong);color:var(--text-faint);flex:none;text-transform:uppercase}
.kb-tools{display:flex;align-items:center;gap:3px;flex:none}
.kb-toggle{display:flex;background:var(--raise);border:1px solid var(--line-strong);border-radius:8px;padding:2px;margin-right:4px}
.kb-toggle button{width:30px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-faint);transition:background .2s,color .2s}
.kb-toggle button.on{background:var(--accent-soft);color:var(--accent)}
.kb-toggle button:hover:not(.on){color:var(--text)}
.kb-iconbtn{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-dim);transition:background .2s,color .2s}
.kb-iconbtn:hover{background:var(--raise);color:var(--text)}
.kb-iconbtn.copied{color:var(--green)}
.kb-content{padding:26px 32px 40px;overflow-y:auto;flex:1}
.kb-content.code-view{padding:0}
.kb-code{margin:0;font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.6;color:var(--text-dim);padding:20px 24px;white-space:pre-wrap;word-break:break-word}
.kb-code .tok-tag{color:var(--accent)}.kb-code .tok-hd{color:var(--accent-bright)}.kb-code .tok-em{color:var(--amber)}

/* prose */
.prose{color:var(--text-dim);font-size:15px;line-height:1.7;max-width:680px}
.prose h1,.prose h2,.prose h3{color:var(--text);font-family:'Space Grotesk',sans-serif;margin:1.3em 0 .5em;line-height:1.2}
.prose h1{font-size:26px;margin-top:0}.prose h2{font-size:20px;border-bottom:1px solid var(--line);padding-bottom:8px}.prose h3{font-size:16px}
.prose p{margin:0 0 1em}.prose ul,.prose ol{margin:0 0 1em 1.3em}.prose li{margin:.3em 0}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.prose strong{color:var(--text);font-weight:600}
.prose code{font-family:'JetBrains Mono',monospace;font-size:.88em;background:var(--raise);border:1px solid var(--line-strong);border-radius:6px;padding:2px 6px;color:var(--accent)}
.prose pre{background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:16px;overflow-x:auto;margin:0 0 1em}
.prose pre code{background:none;border:0;padding:0;color:var(--text-dim)}
.prose blockquote{border-left:3px solid var(--accent);background:var(--accent-soft);padding:10px 16px;border-radius:0 var(--r-sm) var(--r-sm) 0;margin:0 0 1em;color:var(--text-dim)}
.prose table{border-collapse:collapse;width:100%;margin:0 0 1em;font-size:14px}
.prose th,.prose td{border:1px solid var(--line-strong);padding:8px 12px;text-align:left}
.prose th{background:var(--raise);color:var(--text);font-family:'Space Grotesk',sans-serif}
.prose hr{border:0;border-top:1px solid var(--line);margin:1.6em 0}
.prose.plain{font-family:'JetBrains Mono',monospace;font-size:13.5px;white-space:pre-wrap;color:var(--text-dim);line-height:1.65;max-width:none}

/* modal */
.modal-bg{display:none;position:fixed;inset:0;z-index:100;background:rgba(2,4,8,.7);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex}
.modal{width:100%;max-width:440px;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);padding:26px;position:relative}
.modal::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-glow),transparent)}
.modal h3{font-size:19px;margin-bottom:18px}
.modal textarea{width:100%;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:12px;color:var(--text);font-family:inherit;font-size:14px;resize:vertical;min-height:80px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.modal .field input{width:100%;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:12px 14px;color:var(--text);font-size:14px;font-family:inherit;transition:border-color .25s}
.modal .field input:focus{outline:none;border-color:var(--accent)}
/* drag handle — only shown when modal is a bottom-sheet (mobile) */
.sheet-handle{display:none}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@media(max-width:640px){
  .modal-bg{align-items:flex-end;padding:0}
  .modal{max-width:none;width:100%;border-radius:var(--r-lg) var(--r-lg) 0 0;padding:14px 20px calc(22px + env(safe-area-inset-bottom));animation:sheetUp .32s var(--ease);will-change:transform}
  .modal.dragging{transition:none}
  .modal .actions{margin-top:20px}
  .modal .actions .btn{flex:1}
  .sheet-handle{display:block;width:42px;height:4px;border-radius:3px;background:var(--line-strong);margin:2px auto 14px;touch-action:none}
}

.hidden{display:none!important}
@media(max-width:860px){
  body{overflow:auto}
  .shell{grid-template-columns:1fr;height:auto}
  .side{height:auto}.side .spacer{display:none}
  .stats{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2){border-right:0}
  .ov-grid{grid-template-columns:1fr}.ov-grid .block + .block{margin-top:16px}
  .kanban{grid-template-columns:1fr}
  .kb{height:auto;flex-direction:column}.kb.reading .kb-list{display:none}.kb.reading .kb-split{display:none}
  .kb-reader{flex-basis:auto}
}

/* ============ TASK CARDS: thumb + thread badge ============ */
.card-thumb{margin-left:auto;width:34px;height:26px;border-radius:6px;background-size:cover;background-position:center;border:1px solid var(--line-strong);position:relative;flex:none}
.card-thumb .thumb-n{position:absolute;right:-5px;top:-5px;background:var(--accent);color:#021416;font-size:9px;font-weight:700;border-radius:8px;padding:0 5px;line-height:14px;font-family:'Space Grotesk',sans-serif}
.thread-badge{display:inline-flex;align-items:center;gap:4px;color:var(--text-dim)}
.thread-badge svg{opacity:.8}
.task{cursor:pointer}

/* ============ UPLOAD widgets ============ */
.upload-btn{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--accent);background:var(--accent-soft);border:1px solid rgba(45,212,212,.3);border-radius:var(--r-sm);padding:8px 13px;cursor:pointer;transition:background .2s}
.upload-btn:hover{background:rgba(45,212,212,.18)}
.upload-btn.sm{padding:5px 10px;font-size:12px}
.up-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.up-thumb{width:48px;height:48px;border-radius:var(--r-sm);background-size:cover;background-position:center;border:1px solid var(--line-strong)}
.up-thumb.big{width:84px;height:84px;cursor:pointer;transition:transform .2s,border-color .2s}
.up-thumb.big:hover{transform:scale(1.04);border-color:var(--accent)}

/* ============ TASK DETAIL PANEL (slide-in) ============ */
.task-backdrop{position:fixed;inset:0;z-index:90;background:rgba(2,4,8,.5);opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.task-backdrop.open{opacity:1;pointer-events:auto}
.task-panel{position:fixed;top:0;right:0;height:100%;width:min(480px,92vw);z-index:91;background:var(--panel);border-left:1px solid var(--line-strong);
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:-20px 0 60px -20px rgba(0,0,0,.6)}
.task-panel.open{transform:none}
.task-panel::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-glow),transparent);z-index:2}
.tp-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);flex:none}
.tp-meta{display:flex;align-items:center;gap:10px;min-width:0}
.tp-cust{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;color:var(--text)}
.tp-status{font-size:11px}
.tp-body{flex:1;overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column}
.tp-title-input{background:none;border:0;color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:20px;padding:0 0 8px;width:100%}
.tp-title-input:focus{outline:none}
.tp-desc-input{background:var(--raise);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text-dim);font-family:inherit;font-size:14px;padding:11px 13px;resize:vertical;min-height:64px;width:100%;line-height:1.55}
.tp-desc-input:focus{outline:none;border-color:var(--accent)}
.tp-field-row{display:flex;align-items:center;gap:12px;margin-top:14px}
.tp-lbl{font-size:12px;color:var(--text-faint);letter-spacing:.04em}
.tp-est-input{background:var(--raise);border:1px solid var(--line);border-radius:var(--r-pill);color:var(--accent);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;padding:6px 14px;width:90px;text-align:center}
.tp-est-input:focus{outline:none;border-color:var(--accent)}
.tp-section{margin-top:22px}
.tp-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-family:'Space Grotesk',sans-serif}
.tp-empty{font-size:13px;color:var(--text-faint);padding:6px 0}
.tp-thread-wrap{display:flex;flex-direction:column;flex:1;min-height:0}
.tp-thread{display:flex;flex-direction:column;gap:12px;padding:4px 0}
.msg{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);padding:11px 13px;max-width:90%;align-self:flex-start}
.msg.me-admin{align-self:flex-end;background:var(--accent-soft);border-color:rgba(45,212,212,.25)}
.msg-head{display:flex;align-items:baseline;gap:8px;margin-bottom:5px}
.msg-head b{font-size:13px;font-weight:600;font-family:'Space Grotesk',sans-serif}
.msg-head span{font-size:11px;color:var(--text-faint)}
.msg-text{font-size:13.5px;color:var(--text-dim);line-height:1.5}
.msg-img{display:block;margin-top:8px;width:160px;height:110px;border-radius:var(--r-sm);background-size:cover;background-position:center;border:1px solid var(--line-strong);cursor:pointer}
.tp-compose{flex:none;display:flex;align-items:center;gap:8px;padding:12px 14px;border-top:1px solid var(--line);background:var(--panel-2);position:relative}
.tp-attach{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:var(--text-dim);cursor:pointer;flex:none;transition:background .2s,color .2s}
.tp-attach:hover{background:var(--raise);color:var(--accent)}
.tp-msg-input{flex:1;background:var(--raise);border:1px solid var(--line-strong);border-radius:var(--r-pill);color:var(--text);font-family:inherit;font-size:14px;padding:10px 16px}
.tp-msg-input:focus{outline:none;border-color:var(--accent)}
.tp-msg-img{position:absolute;left:14px;bottom:54px;width:54px;height:54px;border-radius:var(--r-sm);background-size:cover;background-position:center;border:1px solid var(--accent)}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(2,4,8,.85);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:40px;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:90%;max-height:90%;border-radius:var(--r-md);border:1px solid var(--line-strong)}

@media(max-width:860px){.task-panel{width:100%}}

/* ============ SKELETON LOADERS ============ */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.sk{position:relative;border-radius:6px;background:linear-gradient(90deg,var(--raise) 0px,#22262f 200px,var(--raise) 400px);background-size:800px 100%;animation:shimmer 1.3s infinite linear}
.sk-line{height:12px;margin:7px 0}
.sk-row{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.sk-stat{padding:18px 20px;border-right:1px solid var(--line)}
.sk-stat:last-child{border-right:0}
.sk-card{background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:14px;margin-bottom:9px}
.sk-circle{width:34px;height:34px;border-radius:var(--r-sm);flex:none}
.sk-w40{width:40%}.sk-w60{width:60%}.sk-w25{width:25%}.sk-w80{width:80%}.sk-w100{width:100%}

/* ============ CUSTOM DROPDOWN (kundväljare) ============ */
.dd{position:relative}
.dd-toggle{width:100%;display:flex;align-items:center;gap:9px;background:linear-gradient(180deg,var(--raise),var(--panel-2));border:1px solid var(--line-strong);border-radius:var(--r-pill);
  color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:600;padding:11px 14px;cursor:pointer;transition:border-color .2s,box-shadow .2s;text-align:left}
.dd-toggle:hover{border-color:rgba(45,212,212,.4)}
.dd.open .dd-toggle{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.dd-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);flex:none}
.dd-dot.amber{background:var(--amber);box-shadow:0 0 8px rgba(245,196,81,.5)}
.dd-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dd-chev{flex:none;color:var(--accent);transition:transform .25s var(--ease)}
.dd.open .dd-chev{transform:rotate(180deg)}
.dd-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:30;
  background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-md);padding:6px;
  box-shadow:0 20px 50px -16px rgba(0,0,0,.7);
  opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease);transform-origin:top}
.dd-menu::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-glow),transparent)}
.dd.open .dd-menu{opacity:1;transform:none;pointer-events:auto}
.dd-opt{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r-sm);font-size:13.5px;color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s}
.dd-opt:hover{background:var(--panel-2);color:var(--text)}
.dd-opt.sel{background:var(--accent-soft);color:var(--accent);font-weight:600}
.dd-opt .dd-check{margin-left:auto;opacity:0;color:var(--accent)}
.dd-opt.sel .dd-check{opacity:1}
.dd-opt .o-dot{width:7px;height:7px;border-radius:50%;background:var(--text-faint);flex:none}
.dd-opt.sel .o-dot,.dd-opt:hover .o-dot{background:var(--accent)}
.dd-sep{height:1px;background:var(--line);margin:5px 2px}
