/* boligglans.dk — design system (fokuseret vedligeholds-site) */
@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700&family=Schibsted+Grotesk:wght@600;700;800&display=swap');

:root{
  --blue:#0e7d74; --blue-d:#0a5e57; --blue-2:#2bb3a6; --blue-l:#e3f4f1; --blue-tint:#f2faf8;
  --ink:#14201e; --muted:#566460; --line:#e0e8e6; --bg:#ffffff; --soft:#f5f9f8;
  --amber:#f2a900; --radius:16px; --radius-lg:22px; --max:1080px;
  --shadow:0 1px 2px rgba(0,0,0,.04),0 10px 30px rgba(14,125,116,.08);
  --shadow-lg:0 20px 50px rgba(14,125,116,.15);
  --body:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --head:'Schibsted Grotesk','Hanken Grotesk',sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
.narrow{max-width:760px}
a{color:var(--blue-d);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--head);line-height:1.12;letter-spacing:-.02em;margin:0 0 .5em;font-weight:800}
h1{font-size:clamp(2rem,4.5vw,3rem)}
h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-top:1.5em}
h3{font-size:1.2rem;font-weight:700}
p{margin:0 0 1em}
img{max-width:100%;height:auto}
.eyebrow{font-family:var(--head);font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);margin-bottom:.4em}
.logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--head);font-weight:800;font-size:1.22rem;color:var(--ink);letter-spacing:-.03em}
.logo .mark{width:34px;height:34px;border-radius:9px;background:var(--blue);display:grid;place-items:center;color:#fff;font-size:1rem;flex:0 0 auto}
.logo b{color:var(--blue);font-weight:800}
.logo:hover{text-decoration:none}
header.site{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.nav nav a{margin-left:20px;color:var(--ink);font-weight:600;font-size:.95rem}
.nav nav a:hover{color:var(--blue)}
@media(max-width:760px){.nav nav a{margin-left:12px;font-size:.8rem}}
.hero{background:radial-gradient(120% 100% at 0% 0%,var(--blue-l),#fff 70%);padding:72px 0 56px;border-bottom:1px solid var(--line)}
.hero .lead{font-size:1.22rem;color:var(--muted);max-width:640px}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0 0}
.badge{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 15px;font-size:.85rem;font-weight:600;color:var(--blue-d)}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;font-family:var(--head);font-weight:700;padding:15px 28px;border-radius:999px;border:0;cursor:pointer;font-size:1rem;box-shadow:var(--shadow);transition:transform .12s,background .12s}
.btn:hover{background:var(--blue-d);text-decoration:none;transform:translateY(-1px)}
.btn.amber{background:var(--amber);color:#14201e}
.btn.ghost{background:#fff;color:var(--blue-d);border:1.5px solid var(--blue);box-shadow:none}
.btn.lg{padding:17px 34px;font-size:1.08rem}
.grid{display:grid;gap:18px;grid-template-columns:repeat(3,1fr);margin:28px 0}
@media(max-width:820px){.grid{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s;display:block}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none}
.tile{width:54px;height:54px;border-radius:14px;background:var(--blue-l);display:grid;place-items:center;font-size:1.6rem;margin-bottom:14px}
.card h3{margin:0 0 6px;color:var(--ink)}
.card p{color:var(--muted);font-size:.95rem;margin:0}
.card .more{color:var(--blue);font-weight:700;font-size:.92rem;display:inline-block;margin-top:14px}
section{padding:10px 0}
.soft{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:48px 0;margin-top:48px}
.two{display:grid;grid-template-columns:1.25fr 1fr;gap:40px;align-items:center}
@media(max-width:820px){.two{grid-template-columns:1fr}}
.leadbox{background:linear-gradient(150deg,var(--blue-l),var(--blue-tint));border:1px solid #cae8e2;border-radius:var(--radius);padding:28px;margin:30px 0}
.leadbox h3{margin-top:0}
.leadbox .sub{color:var(--muted);font-size:.95rem;margin-bottom:16px}
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0}
@media(max-width:820px){.trust{grid-template-columns:1fr}}
.trust .item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.trust .item h4{font-family:var(--head);margin:0 0 6px;font-size:1.05rem}
.trust .item p{color:var(--muted);font-size:.92rem;margin:0}
table{width:100%;border-collapse:collapse;margin:18px 0;font-size:.95rem}
th,td{text-align:left;padding:12px 13px;border-bottom:1px solid var(--line)}
th{background:var(--soft);font-weight:700;font-family:var(--head)}
tr:hover td{background:var(--blue-tint)}
.faq details{border:1px solid var(--line);border-radius:12px;padding:2px 18px;margin-bottom:10px;background:#fff}
.faq summary{cursor:pointer;font-weight:700;font-family:var(--head);padding:15px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';float:right;color:var(--blue);font-weight:700}
.faq details[open] summary::after{content:'–'}
.faq p{color:var(--muted);padding-bottom:6px}
.crumb{font-size:.85rem;color:var(--muted);padding:18px 0 0}.crumb a{color:var(--muted)}
.disclosure{font-size:.84rem;color:var(--muted);background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:12px 16px;margin:20px 0}
ul.checklist{list-style:none;padding:0;margin:16px 0}
ul.checklist li{padding:8px 0 8px 30px;position:relative;color:var(--ink)}
ul.checklist li::before{content:'✓';position:absolute;left:0;top:8px;color:var(--blue);font-weight:800}
footer.site{background:var(--ink);color:#c5d4d0;padding:46px 0;margin-top:60px;font-size:.92rem}
footer.site a{color:#fff}footer.site a:hover{color:var(--blue-2)}
footer.site .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
@media(max-width:820px){footer.site .cols{grid-template-columns:1fr}}
footer.site .logo{color:#fff}footer.site .logo b{color:var(--blue-2)}
footer.site .fine{border-top:1px solid #2a3a37;margin-top:26px;padding-top:18px;color:#8aa39d;font-size:.83rem}
/* tool */
.tool-hero{background:linear-gradient(160deg,var(--blue-l),#fff);border-bottom:1px solid var(--line);padding:30px 0}
.tool-head{display:flex;align-items:center;gap:14px}
.tool-head .mark{width:48px;height:48px;border-radius:13px;background:var(--blue);display:grid;place-items:center;color:#fff;font-size:1.4rem}
.tool-head .tt{font-family:var(--head);font-weight:800;font-size:1.3rem;letter-spacing:.02em}
.tool-head .tt b{color:var(--blue)}
.tool-head .sub{color:var(--muted);font-size:.9rem;margin:0}
.steplabel{display:flex;justify-content:space-between;font-family:var(--head);font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin:22px 0 8px}
.steplabel .of{color:var(--muted)}
.prog{height:7px;background:#cfe6e1;border-radius:99px;overflow:hidden}
.prog>i{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--blue-2));width:14%;transition:width .35s}
.quiz{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:30px;margin:22px 0 40px}
.step{display:none}.step.active{display:block;animation:fade .25s}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.q{font-family:var(--head);font-size:1.5rem;font-weight:800;margin:.1em 0 .2em}
.qsub{color:var(--muted);margin-bottom:18px}
.opt{display:flex;align-items:center;gap:16px;width:100%;text-align:left;border:1.5px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:12px;cursor:pointer;background:#fff;transition:.12s}
.opt:hover{border-color:var(--blue);background:var(--blue-tint)}
.opt.sel{border-color:var(--blue);background:var(--blue-l)}
.opt .oi{width:48px;height:48px;border-radius:12px;background:var(--blue-l);display:grid;place-items:center;font-size:1.4rem;flex:0 0 auto}
.opt .ol{flex:1}.opt .ol b{font-family:var(--head);font-weight:700;display:block}.opt .ol span{color:var(--muted);font-size:.9rem}
.opt .radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--line);flex:0 0 auto}
.opt.sel .radio{border-color:var(--blue);background:var(--blue);box-shadow:inset 0 0 0 4px #fff}
.qnav{display:flex;justify-content:space-between;margin-top:18px}
.report-hero{background:linear-gradient(150deg,var(--blue),var(--blue-d));color:#fff;border-radius:var(--radius-lg);padding:30px;text-align:center;margin-bottom:18px}
.report-hero .big{font-family:var(--head);font-weight:800;font-size:clamp(2.2rem,7vw,3.2rem);line-height:1.05;margin:.1em 0}
.report-hero .lbl{opacity:.85;font-size:.95rem}
.rec{border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin:14px 0;box-shadow:var(--shadow)}
.rec .rh{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.rec .rh .oi{width:44px;height:44px;border-radius:11px;background:var(--blue-l);display:grid;place-items:center;font-size:1.3rem}
.rec h3{margin:0}
.rec .prio{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:99px;background:var(--blue-l);color:var(--blue-d);margin-left:auto}
.rec .prio.hot{background:#fde9c8;color:#8a5a00}
