/* basal energi — PWA styles. Recreated from the Claude Design handoff. */
:root{
  --accent:#0066FF;
  --green:#00A862;
  --amber:#E8A300;
  --red:#E5484D;
  --on-accent:#ffffff;
  --radius-lg:20px;
  --radius-md:16px;
  --maxw:480px;
  --nav-h:72px;
}
/* Light (default) */
:root,[data-theme="light"]{
  --bg:#ffffff;
  --bg-page:#ffffff;
  --text:#111111;
  --muted:#86868b;
  --muted-2:#6e6e73;
  --faint:#b4b4b9;
  --card:#f5f5f7;
  --card-2:#f0f0f3;
  --border:rgba(0,0,0,0.06);
  --border-strong:rgba(0,0,0,0.10);
  --nav-bg:rgba(255,255,255,0.92);
  --nav-border:rgba(0,0,0,0.07);
  --nav-inactive:#b4b4b9;
  --btn-shadow:none;
  --ring-track:#e6e6ea;
  --green-soft:rgba(0,168,98,0.08);
  --green-ink:#1a6e4a;
  --accent-soft:rgba(0,102,255,0.08);
  --shadow-card:0 1px 3px rgba(0,0,0,0.05);
  --mitid-blue:#0060e6;
  --color-scheme:light;
}
[data-theme="dark"]{
  --bg:radial-gradient(135% 92% at 50% 0%, rgba(0,92,224,0.30) 0%, rgba(8,11,18,0) 46%), #0b0e14;
  --bg-page:#0b0e14;
  --text:#ffffff;
  --muted:rgba(255,255,255,0.55);
  --muted-2:rgba(255,255,255,0.42);
  --faint:#8a8a90;
  --card:#1c1c1e;
  --card-2:#26262b;
  --border:rgba(255,255,255,0.08);
  --border-strong:rgba(255,255,255,0.14);
  --nav-bg:rgba(18,19,24,0.82);
  --nav-border:rgba(255,255,255,0.08);
  --nav-inactive:#8a8a90;
  --btn-shadow:0 10px 34px rgba(0,102,255,0.5);
  --ring-track:#26262b;
  --green-soft:rgba(0,168,98,0.16);
  --green-ink:#3ddc97;
  --accent-soft:rgba(0,102,255,0.18);
  --shadow-card:0 1px 3px rgba(0,0,0,0.4);
  --mitid-blue:#4aa0ff;
  --color-scheme:dark;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;height:100%;}
body{
  font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--bg-page);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  color-scheme:var(--color-scheme);
  overscroll-behavior-y:none;
}
a{color:inherit;}
button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit;}
img{display:block;}

#app{
  max-width:var(--maxw);
  margin:0 auto;
  min-height:100%;
  position:relative;
  background:var(--bg);
  background-attachment:fixed;
  display:flex;
  flex-direction:column;
}

/* ---------- Views / screens ---------- */
.view{flex:1;display:flex;flex-direction:column;}
.screen{display:none;flex-direction:column;}
.screen.active{display:flex;animation:fade .22s ease;}
@keyframes fade{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}

.scroll{
  flex:1;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:calc(env(safe-area-inset-top) + 14px) 0 calc(var(--nav-h) + env(safe-area-inset-bottom) + 24px);
}
.pad{padding-left:24px;padding-right:24px;}

/* ---------- Typography ---------- */
.h1{font-size:26px;font-weight:700;letter-spacing:-0.03em;margin:0;}
.sub{font-size:14px;color:var(--muted);margin-top:3px;}
.eyebrow{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;}
.wordmark{font-size:19px;font-weight:700;letter-spacing:-0.02em;}
.wordmark .dot{color:var(--accent);}

/* ---------- Top bar ---------- */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:2px 24px 0;min-height:34px;}
.iconbtn{width:38px;height:38px;border-radius:50%;background:var(--card-2);display:flex;align-items:center;justify-content:center;color:var(--text);}

/* ---------- Pills / badges ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;border-radius:980px;padding:6px 12px;font-size:13px;font-weight:700;}
.pill .dot{width:7px;height:7px;border-radius:50%;}
.pill-green{background:var(--green-soft);color:var(--green);}
.pill-green .dot{background:var(--green);}
.pill-amber{background:rgba(232,163,0,0.14);color:var(--amber);}
.pill-amber .dot{background:var(--amber);}
.pill-red{background:rgba(229,72,77,0.14);color:var(--red);}
.pill-red .dot{background:var(--red);}

/* ---------- Segmented control ---------- */
.seg{display:flex;background:var(--card-2);border-radius:12px;padding:3px;}
.seg button{flex:1;text-align:center;font-size:13px;font-weight:600;padding:8px 0;border-radius:9px;color:var(--muted);transition:.18s;}
.seg button.active{font-weight:700;color:var(--text);background:var(--bg-page);box-shadow:0 1px 3px rgba(0,0,0,0.12);}
[data-theme="dark"] .seg button.active{color:#fff;background:var(--accent);box-shadow:none;}

/* ---------- Big number ---------- */
.bignum{display:flex;align-items:baseline;gap:6px;}
.bignum .val{font-size:46px;font-weight:700;letter-spacing:-0.03em;line-height:1;}
.bignum .unit{font-size:17px;color:var(--muted);font-weight:600;}

/* ---------- Charts ---------- */
.bars{display:flex;align-items:flex-end;gap:2px;}
.bars .bar{flex:1;min-height:4px;border-radius:3px 3px 0 0;opacity:.85;}
.bar-green{background:var(--green);}
.bar-amber{background:var(--amber);}
.bar-red{background:var(--red);}
.bar-blue{background:var(--accent);opacity:.9;}
.xaxis{display:flex;gap:2px;margin-top:7px;}
.xaxis span{flex:1;text-align:center;font-size:9px;color:var(--muted-2);font-weight:600;}
.legend{display:flex;gap:18px;justify-content:center;}
.legend span{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-weight:600;}
.legend i{width:9px;height:9px;border-radius:50%;display:inline-block;}

/* ---------- Cards ---------- */
.card{background:var(--card);border-radius:var(--radius-lg);padding:16px;}
.card-row{display:flex;align-items:center;gap:14px;}
.stat{flex:1;background:var(--card);border-radius:var(--radius-md);padding:14px 16px;}
.stat .label{font-size:13px;color:var(--muted);font-weight:600;}
.stat .num{font-size:26px;font-weight:700;letter-spacing:-0.02em;margin-top:4px;}
.stat .num small{font-size:14px;color:var(--muted);font-weight:600;}
.glyph{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}

/* ---------- Buttons ---------- */
.btn{display:block;width:100%;text-align:center;font-size:17px;font-weight:600;color:var(--on-accent);background:var(--accent);border-radius:980px;padding:17px;box-shadow:var(--btn-shadow);}
.btn:active{transform:scale(.99);}
.btn-sm{border-radius:12px;padding:11px;font-size:14px;font-weight:700;}
.btn-ghost{background:var(--card-2);color:var(--muted);font-weight:600;border-radius:12px;padding:11px 18px;font-size:14px;}

/* ---------- List rows ---------- */
.list{background:var(--card);border-radius:18px;overflow:hidden;}
.row{display:flex;align-items:center;gap:14px;padding:16px;}
.row + .row{border-top:1px solid var(--border);}
.row .grow{flex:1;font-size:16px;font-weight:600;}
.row svg{flex-shrink:0;}

/* ---------- Toggle switch ---------- */
.switch{width:50px;height:30px;border-radius:15px;background:var(--accent);position:relative;flex-shrink:0;transition:.2s;}
.switch::after{content:"";position:absolute;top:3px;right:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:.2s;}
.switch.off{background:#e2e2e7;}
[data-theme="dark"] .switch.off{background:#3a3a3c;}
.switch.off::after{right:auto;left:3px;}

/* ---------- Bottom nav ---------- */
#tabbar{
  position:fixed;left:50%;transform:translateX(-50%);bottom:0;
  width:100%;max-width:var(--maxw);
  height:calc(var(--nav-h) + env(safe-area-inset-bottom));
  padding:9px 6px env(safe-area-inset-bottom);
  background:var(--nav-bg);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  border-top:1px solid var(--nav-border);
  display:flex;z-index:50;
}
#tabbar.hidden{display:none;}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--nav-inactive);padding-top:2px;}
.tab span{font-size:10px;font-weight:600;}
.tab.active{color:var(--accent);}
.tab.active span{font-weight:700;}
.tab .avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;opacity:.8;}
.tab.active .avatar{opacity:1;box-shadow:0 0 0 2px var(--accent);}

/* ---------- Onboarding ---------- */
#onboard{position:fixed;inset:0;max-width:var(--maxw);margin:0 auto;background:var(--bg);background-attachment:fixed;z-index:100;display:none;flex-direction:column;}
#onboard.active{display:flex;}
.ob-screen{display:none;flex-direction:column;height:100%;overflow-y:auto;}
.ob-screen.active{display:flex;}

/* search input */
.searchbox{display:flex;align-items:center;gap:10px;background:var(--card-2);border-radius:14px;padding:14px 16px;}
.searchbox input{flex:1;border:none;background:none;font-size:16px;font-weight:500;color:var(--text);outline:none;}
.caret{width:1.5px;height:18px;background:var(--accent);animation:blink 1s steps(1) infinite;}
@keyframes blink{50%{opacity:0;}}

/* map */
.map{position:relative;overflow:hidden;height:268px;}
.map.light{background:#e4eaf0;background-image:repeating-linear-gradient(0deg,transparent 0 38px,rgba(140,150,165,.35) 38px 39px),repeating-linear-gradient(90deg,transparent 0 46px,rgba(140,150,165,.35) 46px 47px),linear-gradient(118deg,transparent 0 47%,rgba(120,170,140,.45) 47% 53%,transparent 53%);}
[data-theme="dark"] .map{background:#12151c;background-image:repeating-linear-gradient(0deg,transparent 0 38px,rgba(255,255,255,.05) 38px 39px),repeating-linear-gradient(90deg,transparent 0 46px,rgba(255,255,255,.05) 46px 47px),linear-gradient(118deg,transparent 0 47%,rgba(40,90,60,.5) 47% 53%,transparent 53%);}
.map .road{position:absolute;height:14px;background:#c9d3dd;}
[data-theme="dark"] .map .road{background:#262b35;}
.map .pin-halo{position:absolute;top:96px;left:50%;transform:translate(-50%,-50%);width:90px;height:90px;border-radius:50%;background:rgba(0,102,255,.14);}
.map .pin{position:absolute;top:96px;left:50%;transform:translate(-50%,-50%);width:22px;height:22px;border-radius:50%;background:var(--accent);border:4px solid var(--bg-page);box-shadow:0 3px 12px rgba(0,102,255,.6);}
.map .label{position:absolute;top:96px;left:50%;transform:translate(-50%,-100%);background:#111;color:#fff;font-size:11px;font-weight:600;padding:5px 10px;border-radius:8px;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.3);}
[data-theme="dark"] .map .label{background:#1c1c1e;}

.addr-row{display:flex;align-items:center;gap:14px;padding:16px 24px;border-bottom:1px solid var(--border);cursor:pointer;}

/* MitID card */
.mitid-card{margin:0 24px;border:1px solid var(--border-strong);border-radius:22px;padding:28px 24px;background:var(--card);}
[data-theme="light"] .mitid-card{background:#fff;box-shadow:0 4px 20px rgba(0,0,0,0.04);}
[data-theme="dark"] .mitid-card{box-shadow:0 0 30px rgba(0,102,255,0.12);}
.mitid-logo{font-size:22px;font-weight:800;letter-spacing:-0.02em;color:var(--text);}
.mitid-logo b{color:var(--mitid-blue);font-weight:800;}
.mitid-field{margin-top:8px;border:1.5px solid var(--mitid-blue);border-radius:12px;padding:14px 16px;display:flex;align-items:center;}
.mitid-field span{font-size:17px;font-weight:500;}
.mitid-field .caret{background:var(--mitid-blue);height:20px;}
.mitid-btn{background:var(--mitid-blue);border-radius:12px;}

/* energy ring */
.ring{position:relative;width:168px;height:168px;border-radius:50%;}
.ring .hole{position:absolute;inset:22px;background:var(--bg-page);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.mixbar{display:flex;height:12px;border-radius:6px;overflow:hidden;gap:1px;}
.src-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);}
.src-row i{width:12px;height:12px;border-radius:4px;flex-shrink:0;}
.src-row .name{flex:1;font-size:15px;font-weight:600;}
.src-row .pct{font-size:15px;font-weight:700;}

/* Lima cards */
.lima-card{background:var(--card);border-radius:20px;padding:13px;box-shadow:var(--shadow-card);transition:.25s;}
.lima-card.removing{opacity:0;transform:scale(.94);height:0;padding:0;margin:0;overflow:hidden;}
.lima-head{display:flex;align-items:center;gap:10px;margin-bottom:11px;}
.lima-head img{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 0 0 2px rgba(0,102,255,0.25);}
.lima-tag{font-size:11px;font-weight:800;letter-spacing:0.06em;}
.lima-when{margin-left:auto;font-size:12px;color:var(--muted-2);}
.lima-title{font-size:16px;font-weight:700;letter-spacing:-0.01em;line-height:1.25;}
.lima-desc{font-size:13px;color:var(--muted);margin-top:5px;line-height:1.4;}
.lima-actions{display:flex;gap:10px;margin-top:14px;}
.lima-avatar-lg{width:46px;height:46px;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 0 0 3px rgba(0,102,255,0.2),0 6px 22px rgba(0,102,255,0.3);}

/* Planlæg dark hero card (always dark) */
.window-card{background:#111;color:#fff;border-radius:20px;padding:20px;}
.window-card .tag{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#7db0ff;}
.window-card .tag .dot{width:7px;height:7px;border-radius:50%;background:#00C875;}
.window-card .big{font-size:32px;font-weight:700;letter-spacing:-0.02em;margin-top:10px;}
.window-card .meta{font-size:14px;color:rgba(255,255,255,0.6);margin-top:4px;}
.device-row{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--border-strong);border-radius:18px;}
.device-row .dglyph{width:44px;height:44px;border-radius:13px;background:var(--card-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text);}
.device-row .dname{font-size:16px;font-weight:700;}
.device-row .dstatus{font-size:13px;font-weight:600;margin-top:2px;}

/* Profil */
.avatar-init{width:60px;height:60px;border-radius:50%;background:var(--accent);color:#fff;font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}

/* toast */
#toast{position:fixed;left:50%;transform:translateX(-50%) translateY(20px);bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 16px);background:#111;color:#fff;padding:12px 18px;border-radius:14px;font-size:14px;font-weight:600;opacity:0;pointer-events:none;transition:.3s;z-index:200;box-shadow:0 8px 30px rgba(0,0,0,0.35);max-width:300px;text-align:center;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
[data-theme="dark"] #toast{background:#1c1c1e;border:1px solid var(--border-strong);}

/* install banner */
#installbar{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 12px);width:calc(100% - 32px);max-width:448px;background:var(--card);border:1px solid var(--border-strong);border-radius:16px;padding:12px 14px;display:none;align-items:center;gap:12px;z-index:60;box-shadow:0 10px 40px rgba(0,0,0,0.18);}
#installbar.show{display:flex;}
#installbar img{width:38px;height:38px;border-radius:10px;}
.mt8{margin-top:8px;}.mt10{margin-top:10px;}.mt12{margin-top:12px;}.mt14{margin-top:14px;}.mt16{margin-top:16px;}.mt18{margin-top:18px;}.mt20{margin-top:20px;}.mt22{margin-top:22px;}.mt26{margin-top:26px;}
.flex{display:flex;}.between{justify-content:space-between;}.center{justify-content:center;}.items-center{align-items:center;}.gap12{gap:12px;}.col{flex-direction:column;}.grow{flex:1;}
