:root{
  --bg:#0a0c0e; --surface:#14171d; --surface-2:#1b1f27; --line:#252b35;
  --txt:#e8ecf2; --muted:#8b94a3; --faint:#5b6573;
  --accent:#5b8cff; --cyan:#22d3ee; --grad:linear-gradient(90deg,#2f53e6,#22d3ee);
  --ok:#34d399; --warn:#fbbf24; --bad:#f87171;
  --r:14px; --r-sm:10px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg); color:var(--txt);
  font-family:"Source Sans 3",system-ui,-apple-system,sans-serif;
  font-size:15px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand-name,.brand-product{font-family:"Schibsted Grotesk",sans-serif;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
.mono{font-family:"JetBrains Mono",monospace;font-size:.85em}

/* Topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(10,12,14,.85);backdrop-filter:blur(8px);z-index:10}
.brand{display:flex;align-items:center;gap:9px;font-weight:600}
.brand-mark{width:22px;height:22px;border-radius:6px;background:var(--grad)}
.brand-name{font-weight:700}
.brand-sep,.brand-product{color:var(--muted);font-weight:600}
.brand-product{color:var(--cyan)}
.topbar-right{display:flex;align-items:center;gap:14px}
.topbar-user{color:var(--muted);font-size:.9em}

/* Shell + sidebar */
.shell{display:flex;min-height:calc(100vh - 53px)}
.sidebar{width:230px;flex:0 0 230px;border-right:1px solid var(--line);padding:22px 14px;display:flex;flex-direction:column;gap:6px}
.side-tenant{padding:6px 10px 16px}
.side-tenant-name{font-family:"Schibsted Grotesk";font-weight:700;font-size:1.05em}
.side-tenant-meta{color:var(--muted);font-size:.82em;margin-top:5px;display:flex;align-items:center;gap:7px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.on{background:var(--ok);box-shadow:0 0 8px var(--ok)}
.dot.off{background:var(--faint)}
.side-nav{display:flex;flex-direction:column;gap:2px}
.side-nav a{padding:9px 12px;border-radius:var(--r-sm);color:var(--muted);font-weight:500;transition:.12s}
.side-nav a:hover{background:var(--surface);color:var(--txt)}
.side-nav a.active{background:var(--surface-2);color:var(--txt);box-shadow:inset 2px 0 0 var(--accent)}
.side-back{margin-top:auto;color:var(--faint);font-size:.85em;padding:8px 12px}
.side-back:hover{color:var(--muted)}
.content{flex:1;padding:30px 36px;max-width:1100px}

/* Headings */
.page-head{margin-bottom:24px}
.page-head h1{margin:0 0 4px;font-size:1.5em}
.page-head p{margin:0;color:var(--muted)}

/* Cards / grid */
.grid{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px}
.card h3{margin:0 0 12px;font-size:1.02em}
.stat{display:flex;flex-direction:column;gap:6px}
.stat .num{font-family:"Schibsted Grotesk";font-weight:700;font-size:2em;line-height:1}
.stat .lbl{color:var(--muted);font-size:.85em}
.stat .num.accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* Tenant cards (admin home) */
.tcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;transition:.14s;display:block}
.tcard:hover{border-color:var(--accent);transform:translateY(-2px)}
.tcard .t-name{font-family:"Schibsted Grotesk";font-weight:700;font-size:1.15em;margin-bottom:6px}
.tcard .t-meta{color:var(--muted);font-size:.85em;display:flex;align-items:center;gap:7px;margin-bottom:14px}
.tcard .t-stats{display:flex;gap:18px;border-top:1px solid var(--line);padding-top:12px}
.tcard .t-stats div span{display:block;font-family:"Schibsted Grotesk";font-weight:700;font-size:1.3em}
.tcard .t-stats div small{color:var(--muted);font-size:.78em}

/* Chips / badges */
.chip{font-size:.74em;padding:3px 9px;border-radius:999px;border:1px solid var(--line);color:var(--muted);font-weight:600}
.chip-admin{border-color:var(--accent);color:var(--accent)}
.lvl{font-size:.74em;padding:3px 9px;border-radius:999px;font-weight:600;background:rgba(91,140,255,.12);color:var(--accent);border:1px solid rgba(91,140,255,.3)}

/* Forms */
label{display:block;color:var(--muted);font-size:.85em;font-weight:600;margin:0 0 6px}
.field{margin-bottom:18px}
input[type=text],input[type=password],input[type=email],textarea,select{
  width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);
  color:var(--txt);padding:10px 12px;font:inherit;font-size:.95em}
textarea{min-height:90px;resize:vertical;line-height:1.55}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(91,140,255,.15)}
.hint{color:var(--faint);font-size:.8em;margin-top:5px}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--grad);color:#04060a;border:0;
  border-radius:var(--r-sm);padding:10px 18px;font:inherit;font-weight:700;cursor:pointer}
.btn:hover{filter:brightness(1.08)}
.btn-ghost{color:var(--muted);border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 14px;font-weight:600;font-size:.88em}
.btn-ghost:hover{color:var(--txt);border-color:var(--muted)}
.btn-danger{background:none;border:1px solid var(--line);color:var(--faint);border-radius:8px;padding:5px 10px;font-size:.8em;cursor:pointer}
.btn-danger:hover{color:var(--bad);border-color:var(--bad)}

/* Tables */
table{width:100%;border-collapse:collapse;font-size:.92em}
th{text-align:left;color:var(--muted);font-weight:600;font-size:.8em;text-transform:uppercase;letter-spacing:.04em;padding:10px 12px;border-bottom:1px solid var(--line)}
td{padding:12px;border-bottom:1px solid var(--line);vertical-align:top}
tr:hover td{background:var(--surface)}
.kind{font-size:.75em;padding:2px 8px;border-radius:6px;background:var(--surface-2);color:var(--muted);font-weight:600}
.kind.lead,.kind.devis{color:var(--cyan)}
.kind.sav{color:var(--warn)}

/* Misc */
.toast{background:rgba(52,211,153,.12);border:1px solid rgba(52,211,153,.35);color:var(--ok);padding:10px 14px;border-radius:var(--r-sm);margin-bottom:18px;font-size:.9em}
.empty{color:var(--faint);text-align:center;padding:48px 0}
.row{display:flex;gap:16px;flex-wrap:wrap}
.row>*{flex:1;min-width:220px}
.section-gap{margin-top:28px}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:34px 30px}
.login-card .brand{justify-content:center;margin-bottom:8px;font-size:1.2em}
.login-card .sub{text-align:center;color:var(--muted);margin:0 0 24px;font-size:.9em}
.login-card .btn{width:100%;justify-content:center;margin-top:6px}
.login-err{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.35);color:var(--bad);padding:9px 12px;border-radius:var(--r-sm);font-size:.85em;margin-bottom:16px;text-align:center}

@media(max-width:760px){
  .shell{flex-direction:column}
  .sidebar{width:auto;flex:none;border-right:0;border-bottom:1px solid var(--line);flex-direction:row;flex-wrap:wrap;align-items:center}
  .side-nav{flex-direction:row;flex-wrap:wrap}
  .content{padding:22px}
}
