:root{
  --bg:#0f1115;--panel:#171a21;--panel2:#1e222b;--line:#2a2f3a;
  --txt:#e8eaed;--mut:#8b929f;--acc:#d4a04c;--acc2:#5b8def;
  --green:#4caf7d;--red:#e06b6b;--yellow:#d4a04c;--blue:#5b8def;--purple:#a978e0;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--txt);font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;line-height:1.5}
.wrap{max-width:1500px;margin:0 auto;padding:24px 28px 80px}
header{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:24px;border-bottom:1px solid var(--line);padding-bottom:20px}
h1{font-family:Georgia,serif;font-size:28px;font-weight:600;letter-spacing:-.5px}
h1 .sub{color:var(--acc);font-style:italic}
.tag{color:var(--mut);font-size:13px}
.who{display:flex;align-items:center;gap:12px}
.badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge.admin{background:rgba(212,160,76,.2);color:var(--acc)}
.badge.saljare{background:rgba(91,141,239,.2);color:var(--blue)}
.badge.superadmin{background:rgba(169,120,224,.2);color:var(--purple)}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px 18px}
.kpi .v{font-size:24px;font-weight:600;font-variant-numeric:tabular-nums}
.kpi .l{color:var(--mut);font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}
.kpi .v.g{color:var(--green)}.kpi .v.r{color:var(--red)}.kpi .v.a{color:var(--acc)}
.tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tab{padding:10px 20px;cursor:pointer;color:var(--mut);border-bottom:2px solid transparent;font-weight:500;user-select:none}
.tab.on{color:var(--txt);border-bottom-color:var(--acc)}
.tab:hover{color:var(--txt)}
.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
input,select,textarea{background:var(--panel2);border:1px solid var(--line);color:var(--txt);padding:9px 12px;border-radius:8px;font-size:14px;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--acc2)}
#search{min-width:260px;flex:1;max-width:420px}
.btn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);padding:9px 14px;border-radius:8px;cursor:pointer;font-size:13px}
.btn:hover{border-color:var(--acc)}
.btn.acc{background:var(--acc);color:#1a1a1a;border-color:var(--acc);font-weight:600}
.btn.sm{padding:5px 10px;font-size:12px}
.count{color:var(--mut);font-size:13px;margin-left:auto}
.tablewrap{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:auto;max-height:66vh}
table{width:100%;border-collapse:collapse;font-size:13px}
th{position:sticky;top:0;background:var(--panel2);text-align:left;padding:11px 14px;font-weight:600;color:var(--mut);font-size:12px;text-transform:uppercase;letter-spacing:.4px;cursor:pointer;white-space:nowrap;border-bottom:1px solid var(--line);user-select:none}
th:hover{color:var(--txt)}
th .ar{opacity:.4;font-size:10px}
th.sorted .ar{opacity:1;color:var(--acc)}
td{padding:10px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
tr:hover td{background:var(--panel2)}
td.num{text-align:right;font-variant-numeric:tabular-nums}
.pill{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}
.pill.Betalad{background:rgba(76,175,125,.15);color:var(--green)}
.pill.Krediterad{background:rgba(224,107,107,.15);color:var(--red)}
.pill.Delbetald{background:rgba(212,160,76,.15);color:var(--yellow)}
.pill.Forfallen{background:rgba(91,141,239,.15);color:var(--blue)}
.pill.Aktiv{background:rgba(76,175,125,.15);color:var(--green)}
.pill.Prospekt{background:rgba(91,141,239,.15);color:var(--blue)}
.pill.Pausad{background:rgba(212,160,76,.15);color:var(--yellow)}
.pill.Vilande{background:rgba(139,146,159,.18);color:var(--mut)}
.pill.Forlorad{background:rgba(224,107,107,.15);color:var(--red)}
.kund-link{color:var(--acc2);cursor:pointer}.kund-link:hover{text-decoration:underline}
.pos{color:var(--green)}.neg{color:var(--red)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:flex-start;justify-content:center;padding:40px 20px;z-index:100;overflow:auto}
.modal.on{display:flex}
.modal-box{background:var(--panel);border:1px solid var(--line);border-radius:12px;max-width:1100px;width:100%;padding:28px}
.modal-box h2{font-family:Georgia,serif;font-size:22px;margin-bottom:4px}
.close{float:right;cursor:pointer;color:var(--mut);font-size:22px;line-height:1}.close:hover{color:var(--txt)}
.mini-kpis{display:flex;gap:24px;flex-wrap:wrap;margin:16px 0 20px;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.mini-kpis div .v{font-size:20px;font-weight:600;font-variant-numeric:tabular-nums}
.mini-kpis div .l{color:var(--mut);font-size:11px;text-transform:uppercase;letter-spacing:.4px}
.pg{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:14px;color:var(--mut)}
.pg button{background:var(--panel2);border:1px solid var(--line);color:var(--txt);padding:6px 12px;border-radius:6px;cursor:pointer}
.pg button:disabled{opacity:.4;cursor:default}
.foot{color:var(--mut);font-size:12px;text-align:center;margin-top:30px}
#login{max-width:420px;margin:8vh auto;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:36px}
#login h1{text-align:center;margin-bottom:6px}
#login .tag{text-align:center;margin-bottom:24px}
#login label{display:block;font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;margin:14px 0 6px}
#login input{width:100%}
#login .btn{width:100%;margin-top:20px;padding:12px}
#login .switch{text-align:center;margin-top:16px;color:var(--mut);font-size:13px}
#login .switch a{color:var(--acc2);cursor:pointer}
.err{background:rgba(224,107,107,.12);color:var(--red);padding:10px 12px;border-radius:8px;margin-top:14px;font-size:13px;display:none}
.ok{background:rgba(76,175,125,.12);color:var(--green);padding:10px 12px;border-radius:8px;margin-top:14px;font-size:13px;display:none}
.field{margin-bottom:12px}.field label{display:block;font-size:12px;color:var(--mut);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hidden{display:none!important}
.spanbar{display:flex;gap:24px;flex-wrap:wrap;align-items:flex-end;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 18px;margin-bottom:16px}
.spangroup{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.spangroup .spanlbl{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut);margin-right:4px}
.spangroup input{width:120px}
.spangroup input[type=date]{width:150px}
.spangroup .dash{color:var(--mut)}
.spangroup .hint{font-size:11px;color:var(--mut)}
#tbody tr.sel td{background:rgba(91,141,239,.12)}
#tbody tr[data-kund]{cursor:pointer}
.rowchk,#checkAll{width:16px;height:16px;cursor:pointer;accent-color:var(--acc)}
.given{display:inline-flex;align-items:center;gap:8px;font-weight:600}
.givenrole{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:1px 7px;border-radius:20px}
.givenrole.saljare{background:rgba(91,141,239,.2);color:var(--blue)}
.givenrole.admin{background:rgba(212,160,76,.2);color:var(--acc)}
.givenrole.superadmin{background:rgba(169,120,224,.2);color:var(--purple)}
.bulkbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 16px}
.bulkbar select{min-width:200px}
.msf{position:relative;display:inline-block}
.msf>button{background:var(--panel2);border:1px solid var(--line);color:var(--txt);padding:9px 12px;border-radius:8px;cursor:pointer;font-size:14px;font-family:inherit;white-space:nowrap;max-width:230px;overflow:hidden;text-overflow:ellipsis}
.msf>button:hover{border-color:var(--acc)}
.msf>button.active{border-color:var(--acc2);color:var(--acc2)}
.msf .caret{opacity:.6;margin-left:6px}
.msf-pop{position:absolute;top:calc(100% + 4px);left:0;z-index:60;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:6px;min-width:230px;max-height:320px;overflow:auto;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none}
.msf-pop.on{display:block}
.msf-pop .opt{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:6px;cursor:pointer;font-size:13px;white-space:nowrap}
.msf-pop .opt:hover{background:var(--panel2)}
.msf-pop .opt input{width:15px;height:15px;accent-color:var(--acc);cursor:pointer}
.msf-pop .msf-tools{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);margin-bottom:4px;padding:2px 4px 6px}
.msf-pop .msf-tools a{color:var(--acc2);cursor:pointer;font-size:12px}
.chatt{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:10px;max-height:30vh;overflow:auto;margin-bottom:8px}
.msg{margin-bottom:10px;padding:8px 11px;border-radius:9px;background:var(--panel);border:1px solid var(--line);max-width:85%}
.msg.mine{background:rgba(91,141,239,.1);border-color:rgba(91,141,239,.3);margin-left:auto}
.msg-head{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:3px}
.msg-head .tag{font-size:11px}
.msg-del{color:var(--red);cursor:pointer;margin-left:auto;opacity:.5;font-size:11px}
.msg-del:hover{opacity:1}
.msg-text{font-size:13px;white-space:pre-wrap;word-break:break-word}
.chatt-input{display:flex;gap:8px}
.chatt-input input{flex:1}
.statbar{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.statfokus{color:var(--acc);font-size:13px}
.msg.tagged{border-left:3px solid var(--purple)}
.mention{color:var(--acc2);font-weight:600;background:rgba(91,141,239,.12);border-radius:4px;padding:0 3px}
.mention-pop{position:absolute;bottom:calc(100% + 4px);left:0;background:var(--panel);border:1px solid var(--line);border-radius:9px;min-width:200px;max-height:200px;overflow:auto;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none;z-index:130}
.mention-pop.on{display:block}
.mention-opt{padding:8px 11px;cursor:pointer;font-size:13px}
.mention-opt:hover{background:var(--panel2)}
.levchip{display:inline-block;background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:1px 9px;font-size:11px;color:var(--txt)}
.pill.Attgora{background:rgba(139,146,159,.18);color:var(--mut)}
.pill.Pratamedkund{background:rgba(91,141,239,.15);color:var(--blue)}
.pill.Klarforfakturering{background:rgba(212,160,76,.18);color:var(--acc)}
.pill.Fakturerad{background:rgba(76,175,125,.15);color:var(--green)}
.deskhead{display:flex;justify-content:space-between;align-items:center;margin:6px 0 14px}
.deskhead h3{font-size:14px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut)}
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1000px){.kanban{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.kanban{grid-template-columns:1fr}}
.kcol{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px;min-height:120px}
.kcolhead{display:flex;justify-content:space-between;align-items:center;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--mut);margin-bottom:10px;font-weight:600}
.kbadge{background:var(--panel2);border-radius:20px;padding:1px 9px;font-size:11px}
.kcards{display:flex;flex-direction:column;gap:10px}
.kcard{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:11px 12px}
.kcard-titel{font-weight:600;margin-bottom:3px}
.kcard-kund{font-size:12px;color:var(--acc2);margin-bottom:6px}
.kcard-belopp{font-size:13px;font-variant-numeric:tabular-nums;margin-bottom:4px}
.kcard-besk{font-size:12px;color:var(--mut);margin-bottom:8px;white-space:normal}
.kcard-foot{display:flex;justify-content:space-between;align-items:center;gap:6px}
.kcard-foot .btn.sm{padding:3px 9px}
.setup{background:rgba(212,160,76,.08);border:1px solid var(--acc);border-radius:10px;padding:18px;margin-bottom:20px;font-size:13px;line-height:1.6}
.setup code{background:var(--panel2);padding:2px 6px;border-radius:4px}
.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
@media(max-width:900px){.statgrid{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px}
.card h3{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut);margin-bottom:14px}
.bar{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.bar .lbl{width:160px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar .track{flex:1;background:var(--panel2);border-radius:6px;height:18px;overflow:hidden}
.bar .fill{height:100%;background:var(--acc2);border-radius:6px}
.bar .val{width:54px;text-align:right;font-variant-numeric:tabular-nums;font-size:12px;color:var(--mut)}

/* =====================================================================
   Nya vyer för MPA-versionen. Använder originalets CSS-variabler
   (--bg, --panel, --line, --txt, --mut, --acc) så dark theme bevaras.
   ===================================================================== */

/* Auth-sidor (login, byt-losenord, setup) */
.auth-page { background: var(--bg); min-height: 100vh; display: grid; place-items: center; color: var(--txt); }
.auth-box  { width: 380px; max-width: 92vw; background: var(--panel); border: 1px solid var(--line); padding: 32px; border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,.4); }
.auth-box h1 { margin: 0 0 16px; font-family: 'Playfair Display', Georgia, serif; }
.auth-box p { color: var(--mut); margin: 8px 0 16px; }
.auth-box .error { background: rgba(224,107,107,.12); color: var(--red); border: 1px solid rgba(224,107,107,.3); padding: 10px 14px; border-radius: 8px; margin-bottom: 14px; }
.auth-box .info  { background: rgba(91,141,239,.10); color: var(--acc2); border: 1px solid rgba(91,141,239,.3); padding: 10px 14px; border-radius: 8px; margin-bottom: 14px; }
.auth-box label  { display: block; margin: 14px 0; color: var(--mut); font-size: 12px; text-transform: uppercase; letter-spacing: .5px; }
.auth-box input  { display: block; width: 100%; margin-top: 6px; padding: 10px 12px; background: var(--panel2); border: 1px solid var(--line); border-radius: 8px; color: var(--txt); font-size: 14px; box-sizing: border-box; }
.auth-box input:focus { outline: none; border-color: var(--acc); }
.auth-box button { width: 100%; margin-top: 16px; padding: 12px; background: var(--acc); color: #1a1a1a; border: 0; border-radius: 8px; cursor: pointer; font-weight: 600; font-size: 14px; }
.auth-box button:hover { filter: brightness(1.05); }
.creds { background: var(--panel2); border: 1px solid var(--line); padding: 14px; border-radius: 8px; margin: 12px 0; }
.creds code { font-family: 'JetBrains Mono', Consolas, monospace; background: var(--bg); padding: 2px 6px; border-radius: 4px; color: var(--acc); }

/* Layout chrome — topbar + content */
.topbar { display: flex; align-items: center; gap: 24px; padding: 14px 28px; background: var(--panel); border-bottom: 1px solid var(--line); }
.topbar .brand { font-family: 'Playfair Display', Georgia, serif; font-weight: 700; font-size: 22px; text-decoration: none; color: var(--txt); }
.topbar .navlinks { list-style: none; display: flex; gap: 22px; margin: 0; padding: 0; flex: 1; }
.topbar .navlinks a { color: var(--mut); text-decoration: none; font-size: 14px; padding: 4px 0; border-bottom: 2px solid transparent; transition: color .15s, border-color .15s; }
.topbar .navlinks a:hover { color: var(--txt); border-bottom-color: var(--acc); }
.topbar .userbox { display: flex; align-items: center; gap: 12px; }
.topbar .username { color: var(--mut); font-size: 13px; }
.topbar .badge { font-size: 11px; padding: 3px 10px; border-radius: 4px; background: var(--panel2); color: var(--mut); text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.topbar .badge.admin { background: rgba(212,160,76,.18); color: var(--acc); }
.topbar .badge.superadmin { background: rgba(169,120,224,.18); color: var(--purple); }
.topbar button.link { background: none; border: 0; color: var(--mut); cursor: pointer; padding: 0; font-size: 13px; }
.topbar button.link:hover { color: var(--acc); }
.content { padding: 28px; max-width: 1500px; margin: 0 auto; }

/* KPI-rutor på dashboard + statistik — matchar originalets stil */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: 12px; margin-bottom: 24px; }
.kpi-grid .kpi { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 16px 18px; }
.kpi-grid .kpi .num { font-size: 24px; font-weight: 600; font-variant-numeric: tabular-nums; color: var(--txt); }
.kpi-grid .kpi .lbl { color: var(--mut); font-size: 12px; text-transform: uppercase; letter-spacing: .5px; margin-top: 4px; }

/* Kanban (Min desk) */
.kanban { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.kanban-col { background: var(--panel2); border: 1px solid var(--line); padding: 10px; border-radius: 10px; min-height: 220px; }
.kanban-col h3 { margin: 4px 0 12px; font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: var(--mut); }
.kanban-card { background: var(--panel); border: 1px solid var(--line); padding: 10px; border-radius: 8px; margin-bottom: 10px; }
.kanban-card strong { color: var(--txt); }
.kanban-card .actions { margin-top: 8px; display: flex; gap: 6px; }
.kanban-card .arrow { background: var(--panel2); border: 1px solid var(--line); color: var(--txt); border-radius: 4px; padding: 3px 10px; cursor: pointer; font-size: 14px; }
.kanban-card .arrow:hover { border-color: var(--acc); color: var(--acc); }

/* Chatt-panel (kundkort) */
.chatt-lista { max-height: 340px; overflow-y: auto; padding-right: 4px; }
.chatt-rad   { padding: 10px 0; border-bottom: 1px solid var(--line); }
.chatt-rad strong { color: var(--txt); }
.chatt-rad time   { margin-left: 10px; color: var(--mut); font-size: 12px; }
.chatt-rad p { margin: 6px 0 0; color: var(--txt); }
#chatt-input { width: 100%; min-height: 60px; padding: 10px; background: var(--panel2); border: 1px solid var(--line); border-radius: 8px; color: var(--txt); box-sizing: border-box; margin-top: 10px; }
#chatt-form button { margin-top: 8px; background: var(--acc); color: #1a1a1a; border: 0; border-radius: 6px; padding: 8px 16px; cursor: pointer; font-weight: 600; }
