:root{
  --bg:#f5f5f4; --card:#ffffff; --ink:#0f172a; --text:#334155;
  --muted:#78716c; --border:#e7e5e4; --teal:#0f766e; --teal-dark:#115e59;
}
*{box-sizing:border-box}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{color:var(--teal);text-decoration:none}

/* Knappar */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--teal);color:#fff;border:none;border-radius:8px;padding:11px 16px;font-size:14px;font-weight:500;cursor:pointer;width:100%}
.btn:hover{background:var(--teal-dark)}
.btn-inline{display:inline-flex;align-items:center;gap:8px;background:var(--teal);color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:500;cursor:pointer;text-decoration:none}
.btn-inline:hover{background:var(--teal-dark)}
.btn-sec{display:inline-flex;align-items:center;gap:6px;background:#fff;color:#475569;border:1px solid #d6d3d1;border-radius:8px;padding:9px 14px;font-size:14px;cursor:pointer;text-decoration:none}
.btn-sec:hover{background:#f5f5f4}
.btn-danger{display:inline-flex;align-items:center;gap:6px;background:#fff;color:#be123c;border:1px solid #fecdd3;border-radius:8px;padding:9px 14px;font-size:14px;cursor:pointer}
.btn-danger:hover{background:#fff1f2}
.btn-sm{padding:6px 12px;font-size:13px}

/* Fält */
.input{width:100%;padding:10px 12px;border:1px solid #d6d3d1;border-radius:8px;font-size:14px;outline:none;font-family:inherit;background:#fff}
.input:focus{border-color:var(--teal)}
label.field{display:block;font-size:14px;color:var(--text);margin:0 0 6px}
.fld{display:block}
.fld>span{display:block;font-size:14px;color:var(--text);margin:0 0 6px}
.chk{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text)}
.mb{margin-bottom:16px}

/* Meddelanden */
.fel{background:#fff1f2;border:1px solid #fecdd3;color:#be123c;font-size:14px;padding:10px 12px;border-radius:8px;margin-bottom:16px}
.ok{background:#ecfdf5;border:1px solid #a7f3d0;color:#047857;font-size:14px;padding:10px 12px;border-radius:8px;margin-bottom:20px}
.warn{background:#fffbeb;border:1px solid #fde68a;color:#92400e;font-size:14px;padding:12px 14px;border-radius:8px;margin-bottom:16px}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:#efeeec}
.login-card{width:100%;max-width:400px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.login-title{font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.01em;margin:0}
.login-sub{font-size:14px;color:#a8a29e;margin:2px 0 24px}
.hint{font-size:12px;color:#a8a29e;text-align:center;margin-top:16px}

/* App-skal */
.app{display:flex;min-height:100vh}
.sidebar{width:240px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column}
.brand{padding:20px;border-bottom:1px solid #f5f5f4;display:flex;align-items:center;justify-content:space-between;gap:8px}
.brand-titel h1{font-size:18px;font-weight:600;color:var(--ink);margin:0;letter-spacing:-.01em}
.brand-titel span{font-size:12px;color:#a8a29e}
.hamburger{display:none;background:#fff;border:1px solid #d6d3d1;border-radius:8px;font-size:20px;line-height:1;padding:6px 12px;cursor:pointer;color:#475569}
.meny-innehall{display:flex;flex-direction:column;flex:1}
.nav{flex:1;padding:12px}
.nav a{display:block;padding:10px 12px;border-radius:8px;color:#475569;font-size:14px;margin-bottom:4px}
.nav a:hover{background:#f5f5f4}
.nav a.active{background:var(--teal);color:#fff}
.nav a.soon{color:#b8b3ad;cursor:default}
.nav a.soon:hover{background:transparent}
.sidefoot{padding:12px;border-top:1px solid #f5f5f4}
.sidefoot .who{padding:8px 12px;font-size:14px;color:#334155}
.sidefoot a{display:block;padding:10px 12px;border-radius:8px;color:#64748b;font-size:14px}
.sidefoot a:hover{background:#f5f5f4}
.main{flex:1;overflow:auto}
.container{max-width:920px;margin:0 auto;padding:32px}
.h-title{font-size:24px;font-weight:600;color:var(--ink);margin:0 0 4px;letter-spacing:-.01em}
.h-sub{font-size:14px;color:var(--muted);margin:0 0 24px}
.back{display:inline-block;color:#78716c;font-size:14px;margin-bottom:8px}

/* Kort */
.card{background:var(--card);border:1px solid var(--border);border-radius:14px}
.pad{padding:24px}
.cardhead{padding:14px 20px;border-bottom:1px solid #f5f5f4;font-size:14px;font-weight:600;color:#334155}
.cardhead.rowtop{display:flex;align-items:center;justify-content:space-between}
.tag{display:inline-block;font-size:12px;background:#ecfdf5;color:#047857;border:1px solid #a7f3d0;border-radius:999px;padding:2px 10px}
.muted{color:var(--muted);font-size:14px}
.list{margin:12px 0 0;padding-left:18px;color:#475569;font-size:14px;line-height:1.8}
.rowtop{display:flex;align-items:center;justify-content:space-between;gap:8px}

/* Statistik */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:8px 0 24px}
.statval{font-size:26px;font-weight:600;color:var(--ink);margin-top:4px}
.statval.red,.red{color:#be123c}
.rod{color:#be123c;font-weight:500}

/* Översiktens radlänkar */
.rowlink{display:flex;align-items:center;gap:16px;padding:12px 20px;border-bottom:1px solid #f5f5f4;color:#475569}
.rowlink:last-child{border-bottom:none}
.rowlink:hover{background:#fafaf9}
.rl-nr{font-weight:600;color:#334155;width:72px}
.rl-kund{flex:1}
.rl-datum{color:#a8a29e;font-size:13px;width:110px}
.rl-belopp{width:120px;text-align:right}

/* Statusmärken */
.badge{display:inline-block;font-size:12px;border-radius:999px;padding:2px 10px;border:1px solid}
.rowlink .badge{width:92px;text-align:center}
.status-sel{font-size:13px;border-radius:999px;padding:5px 12px;border:1px solid #d6d3d1;cursor:pointer;outline:none}
.b-utkast{background:#f5f5f4;color:#57534e;border-color:#e7e5e4}
.b-skickad{background:#f0f9ff;color:#0369a1;border-color:#bae6fd}
.b-betald{background:#ecfdf5;color:#047857;border-color:#a7f3d0}
.b-forfallen{background:#fff1f2;color:#be123c;border-color:#fecdd3}
.b-krediterad{background:#faf5ff;color:#7e22ce;border-color:#e9d5ff}

/* Formulär */
.formcard{margin-bottom:24px}
.formtitle{font-size:16px;font-weight:600;color:var(--ink);margin:0 0 16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:640px){.grid2{grid-template-columns:1fr}}
.toolbar{display:flex;gap:10px;align-items:center}

/* Logotyp */
.logo-thumb{max-height:48px;max-width:160px;object-fit:contain;border:1px solid var(--border);border-radius:6px;padding:4px;background:#fff;display:block}
.logo-edit{display:flex;align-items:center;gap:14px;margin:6px 0 8px}

/* Kortrutnät */
.grid-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
@media(max-width:640px){.grid-cards{grid-template-columns:1fr}}
.cardtitle{font-weight:600;color:var(--ink)}
.chip{font-size:12px;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:999px;padding:2px 10px;white-space:nowrap}
.kv{display:grid;grid-template-columns:auto 1fr;gap:4px 16px;margin-top:12px;font-size:14px}
.kv span:nth-child(odd){color:var(--muted)}
.kv span:nth-child(even){color:#475569}
.brk{word-break:break-all}
.actions{display:flex;gap:8px;align-items:center;margin-top:16px}
.actions form{margin:0}

/* Tabell */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-weight:500;color:#a8a29e;font-size:12px;text-transform:uppercase;letter-spacing:.03em;padding:12px 16px;border-bottom:1px solid var(--border)}
.tbl td{padding:12px 16px;border-bottom:1px solid #f5f5f4;color:#475569;vertical-align:top}
.tbl tr:last-child td{border-bottom:none}
.tbl .r{text-align:right}
.tbl .nowrap{white-space:nowrap}
.tbl .nowrap form{display:inline}

/* Fakturarader */
.radtabell td{padding:8px 16px;vertical-align:top}
.radtabell .rad-artikel{margin-top:4px;font-size:12px;color:var(--teal);border:none;background:transparent;cursor:pointer;outline:none}
.radbort{background:none;border:none;color:#a8a29e;font-size:20px;cursor:pointer;line-height:1}
.radbort:hover{color:#be123c}
.nrvarning{display:block;margin-top:6px;font-size:12px;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:6px 8px}
.summa{padding:16px 20px;border-top:1px solid #f5f5f4;display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:14px}
.summa>div{display:flex;justify-content:space-between;width:240px;color:#475569}
.summa-total{border-top:1px solid var(--border);margin-top:6px;padding-top:6px;font-weight:600;color:var(--ink)}

/* Språkväljare */
.langtoggle{display:inline-flex;border:1px solid #d6d3d1;border-radius:8px;overflow:hidden}
.langtoggle a{padding:7px 12px;font-size:13px;color:#475569}
.langtoggle a.akt{background:var(--teal);color:#fff}
.visa-topp{margin-bottom:16px}

/* Fakturadokument */
.doc{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18mm;color:#1f2937;box-shadow:0 1px 3px rgba(0,0,0,.04);width:210mm;min-height:297mm;margin:0 auto;box-sizing:border-box;display:flex;flex-direction:column}
.doc-sida{text-align:right;font-size:12px;color:#a8a29e}
.doc-head{display:flex;justify-content:space-between;align-items:flex-start}
.doc-logo img{max-height:64px;max-width:240px;object-fit:contain}
.wordmark{font-size:30px;font-weight:300;color:#0f172a;letter-spacing:-.02em}
.wordmark span{background:#0f172a;color:#fff;padding:2px 6px;margin-left:2px}
.wordmark2{font-size:22px;font-weight:600;color:#0f172a}
.doc-titel{text-align:right}
.doc-titel .dt{font-size:24px;font-weight:700;color:#0f172a;margin-bottom:8px}
.doc-titel table{margin-left:auto;font-size:14px}
.doc-titel td{padding:1px 0;text-align:left}
.doc-titel td:first-child{color:#78716c;padding-right:24px}
.doc-mottagare{margin-top:40px;font-size:14px;line-height:1.5}
.doc-meta{margin-top:28px;display:grid;grid-template-columns:1fr 1fr;gap:24px;font-size:14px;border-bottom:1pt solid #000;padding-bottom:12px}
.doc-meta>div:first-child,.meta-h>div{display:flex;gap:24px;padding:1px 0}
.doc-meta>div:first-child>span:first-child,.meta-h>div>span:first-child{color:#78716c;min-width:130px;display:inline-block}
.doc-table{width:100%;border-collapse:collapse;font-size:14px;margin-top:16px;table-layout:fixed}
.doc-table th:nth-child(1),.doc-table td:nth-child(1){width:50%}
.doc-table th:nth-child(2),.doc-table td:nth-child(2){width:10%}
.doc-table th:nth-child(3),.doc-table td:nth-child(3){width:10%}
.doc-table th:nth-child(4),.doc-table td:nth-child(4){width:15%}
.doc-table th:nth-child(5),.doc-table td:nth-child(5){width:15%}
.doc-table th{text-align:left;color:#78716c;font-weight:400;border-bottom:1pt solid #000;padding:8px 0 3px}
.doc-table td{padding:8px 0;overflow-wrap:break-word}
.doc-table .r{text-align:right}
.doc-fyll{min-height:120px}
.doc-band{display:grid;grid-template-columns:1fr 1fr 1fr;border-top:1pt solid #000;padding-top:12px;font-size:14px}
.doc-band .mid{text-align:center}
.doc-band .hg{text-align:right}
.doc-band .bl{color:#78716c}
.doc-band .bv{margin-top:4px;color:#334155}
.doc-band .b{font-weight:700;color:#0f172a}
.doc-varav{text-align:right;font-size:12px;color:#a8a29e;margin-top:4px}
.doc-iban{border-top:1pt solid #000;margin-top:12px;padding-top:8px;text-align:right;font-size:14px;color:#334155}
.doc-not{margin-top:14px;font-size:12px;color:#78716c}
.doc-foot{margin-top:auto;border-top:1px solid #d6d3d1;padding-top:14px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;font-size:13px;color:#475569}
.doc-foot .fl{color:#a8a29e;font-size:12px}

/* Mobil */
@media(max-width:860px){
  .app{flex-direction:column}
  .sidebar{width:100%;flex-shrink:0;border-right:none;border-bottom:1px solid var(--border)}
  .hamburger{display:block}
  .meny-innehall{display:none}
  .sidebar.open .meny-innehall{display:flex}
  .container{padding:18px 16px}
  .stats{grid-template-columns:1fr;gap:12px}
  .grid-cards{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .rowtop{flex-wrap:wrap}
  .toolbar{flex-wrap:wrap}
  .main .card{overflow-x:auto !important}
  .rl-datum{display:none}
  .doc{padding:24px 20px;overflow-x:auto;width:auto;min-height:0;display:block}
  .doc-foot{margin-top:28px}
  .doc-head{flex-direction:column;gap:16px}
  .doc-titel{text-align:left}
  .doc-titel table{margin-left:0}
  .doc-meta{grid-template-columns:1fr;gap:8px}
  .doc-band{grid-template-columns:1fr;gap:8px}
  .doc-band .mid,.doc-band .hg{text-align:left}
  .doc-varav,.doc-iban{text-align:left}
  .doc-foot{grid-template-columns:1fr 1fr}
}

/* Utskrift */
@media print{
  @page{size:A4;margin:18mm}
  .sidebar,.noprint,.visa-topp{display:none !important}
  .main,.container{display:block;overflow:visible}
  .container{max-width:none;padding:0;margin:0}
  .doc{border:none;box-shadow:none;border-radius:0;padding:0;width:auto;min-height:auto;display:block}
  .doc-foot{margin-top:40px}
  body{background:#fff}
}
