/* ============================================================
   brobjerg.com — professionel portefølje / digitalt værksted
   Mørk, redaktionel æstetik i familie med brobjerg.dk (/einstein, /ritt).
   Selvhostede skrifter (Fraunces + Spectral). Ingen eksterne afhængigheder.
   ============================================================ */

/* ---------- skrifter ---------- */
@font-face{font-family:"Fraunces";font-style:normal;font-weight:100 900;font-display:swap;src:url(fonts/fraunces-roman.woff2) format("woff2")}
@font-face{font-family:"Fraunces";font-style:italic;font-weight:100 900;font-display:swap;src:url(fonts/fraunces-italic.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:normal;font-weight:400;font-display:swap;src:url(fonts/spectral-normal-400.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:italic;font-weight:400;font-display:swap;src:url(fonts/spectral-italic-400.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:normal;font-weight:500;font-display:swap;src:url(fonts/spectral-normal-500.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:normal;font-weight:600;font-display:swap;src:url(fonts/spectral-normal-600.woff2) format("woff2")}

:root{
  --bg:        #14110d;
  --bg-2:      #100d0a;
  --surface:   #1c1813;
  --surface-2: #221d16;
  --ink:       #f4efe6;
  --ink-soft:  #cabfae;
  --ink-faint: #8b8170;
  --line:        rgba(255,255,255,0.075);
  --line-strong: rgba(255,255,255,0.16);
  --gold:      #c7a86d;
  --gold-soft: rgba(199,168,109,0.14);
  --radius: 18px;
  --maxw: 1120px;

  --display: "Fraunces", "Iowan Old Style", Palatino, Georgia, serif;
  --serif:   "Spectral", Georgia, Cambria, "Times New Roman", serif;
  --sans:    system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:84px; }
body{
  margin:0; min-height:100vh;
  background:var(--bg); color:var(--ink);
  font-family:var(--serif); line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; border-radius:6px; }
.sr-only{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ---------- atmosfære ---------- */
.ambient{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(1100px 620px at 50% -8%, rgba(199,168,109,0.11), transparent 62%),
    radial-gradient(900px 600px at 12% 12%, rgba(120,140,180,0.05), transparent 60%),
    radial-gradient(1000px 760px at 92% 98%, rgba(170,120,90,0.06), transparent 60%),
    var(--bg);
}
.grain{
  position:fixed; inset:-50%; z-index:-1; pointer-events:none; opacity:0.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- scroll-progress ---------- */
.scroll-prog{
  position:fixed; top:0; left:0; height:2px; width:0%; z-index:60;
  background:linear-gradient(90deg, var(--gold), #e6cd96);
  box-shadow:0 0 12px rgba(199,168,109,0.5); transition:width .08s linear;
}

/* ---------- topbar ---------- */
.topbar{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:1rem;
  padding:.85rem clamp(1.1rem,4vw,2.4rem);
  backdrop-filter:saturate(140%) blur(10px);
  background:linear-gradient(180deg, rgba(20,17,13,0.86), rgba(20,17,13,0.55));
  border-bottom:1px solid transparent; transition:border-color .3s ease, background .3s ease;
}
.topbar.is-stuck{ border-bottom-color:var(--line); background:rgba(16,13,10,0.92); }
.brand{
  font-family:var(--display); font-weight:600; font-size:1.16rem; letter-spacing:.01em;
  display:inline-flex; align-items:center; gap:.6rem; color:var(--ink);
}
.brand .mark{
  width:26px; height:26px; flex:none; border-radius:7px;
  background:conic-gradient(from 210deg, var(--gold), #6b5a37, var(--gold));
  display:grid; place-items:center; color:#15120d; font-weight:800; font-size:.85rem;
  font-family:var(--sans); box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
.topnav{ margin-left:auto; display:flex; align-items:center; gap:clamp(.7rem,2vw,1.7rem); }
.topnav a{
  font-family:var(--sans); font-size:.86rem; color:var(--ink-soft);
  letter-spacing:.01em; transition:color .25s ease;
}
.topnav a:hover{ color:var(--ink); }
.topnav .nav-cta{
  border:1px solid var(--line-strong); border-radius:999px; padding:.42rem .95rem;
  color:var(--ink); transition:border-color .25s, background .25s, color .25s;
}
.topnav .nav-cta:hover{ background:var(--gold); border-color:var(--gold); color:#15120d; }
@media (max-width:620px){ .topnav .nav-link{ display:none; } }

/* ---------- ramme ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 clamp(1.1rem,4vw,2.4rem); }
.eyebrow{
  font-family:var(--sans); font-size:.72rem; font-weight:600;
  letter-spacing:.32em; text-transform:uppercase; color:var(--gold);
}

/* ---------- hero ---------- */
.hero{ padding:clamp(4rem,12vw,8.5rem) 0 clamp(2.5rem,7vw,5rem); max-width:920px; }
.hero .eyebrow{ display:block; margin-bottom:1.3rem; }
.hero h1{
  font-family:var(--display); font-weight:520;
  font-size:clamp(3rem,11vw,7rem); line-height:.96; letter-spacing:-0.022em;
  margin:0 0 1.4rem; text-wrap:balance;
}
.hero h1 .soft{ color:var(--ink-faint); }
.hero .lede{
  font-size:clamp(1.18rem,2.6vw,1.6rem); line-height:1.5; color:var(--ink-soft);
  margin:0; max-width:34ch; text-wrap:balance;
}
.hero .lede strong{ color:var(--ink); font-weight:500; }
.hero .lede em{ font-style:italic; color:var(--ink); }
.hero-meta{
  display:flex; flex-wrap:wrap; gap:.7rem 1.6rem; margin-top:clamp(2rem,5vw,3rem);
  font-family:var(--sans); font-size:.84rem; color:var(--ink-faint);
}
.hero-meta span{ display:inline-flex; align-items:center; gap:.5rem; }
.hero-meta .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); }
.scrollcue{
  margin-top:clamp(2.4rem,6vw,3.6rem); display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--sans); font-size:.76rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint);
}
.scrollcue svg{ width:18px; height:18px; animation:bob 2.2s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(5px); } }

/* ---------- sektions-titler ---------- */
.sec-head{ margin:0 0 clamp(1.8rem,4vw,2.6rem); max-width:60ch; }
.sec-head .eyebrow{ display:block; margin-bottom:.9rem; }
.sec-head h2{
  font-family:var(--display); font-weight:540; letter-spacing:-0.012em;
  font-size:clamp(1.8rem,4vw,2.7rem); line-height:1.08; margin:0; text-wrap:balance;
}
.sec-head p{ margin:.9rem 0 0; color:var(--ink-soft); font-size:1.07rem; max-width:54ch; }

/* ---------- metode / manifesto ---------- */
.method{ padding:clamp(2.5rem,6vw,4.5rem) 0; border-top:1px solid var(--line); }
.method-lede{
  font-family:var(--display); font-weight:420; font-style:italic;
  font-size:clamp(1.35rem,3.2vw,2.1rem); line-height:1.35; color:var(--ink);
  margin:0 0 clamp(2rem,5vw,3rem); max-width:30ch; text-wrap:balance;
}
.method-lede .hl{ font-style:normal; color:var(--gold); }
.principles{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2.4vw,2rem);
}
.principles li{ position:relative; padding-top:1.2rem; border-top:1px solid var(--line-strong); }
.principles .pn{ font-family:var(--display); color:var(--gold); font-size:.95rem; opacity:.7; }
.principles h3{ font-family:var(--sans); font-size:1.02rem; font-weight:600; margin:.5rem 0 .4rem; letter-spacing:.01em; }
.principles p{ margin:0; font-size:.96rem; color:var(--ink-soft); line-height:1.5; }
@media (max-width:740px){ .principles{ grid-template-columns:1fr; gap:1.4rem; } }

/* ---------- case-rail (scroll-spy) ---------- */
.case-rail-wrap{ position:sticky; top:54px; z-index:40; padding:.5rem 0; }
.case-rail{
  display:flex; gap:.4rem; padding:.4rem; margin:0 auto; width:max-content; max-width:100%;
  border:1px solid var(--line); border-radius:999px;
  background:linear-gradient(180deg, rgba(28,24,19,.92), rgba(16,13,10,.92));
  backdrop-filter:blur(8px); overflow:auto; scrollbar-width:none;
}
.case-rail::-webkit-scrollbar{ display:none; }
.case-rail a{
  white-space:nowrap; font-family:var(--sans); font-size:.82rem; font-weight:600;
  letter-spacing:.02em; color:var(--ink-faint);
  padding:.5rem .95rem; border-radius:999px; display:inline-flex; align-items:center; gap:.5rem;
  transition:color .25s ease, background .25s ease;
}
.case-rail a .rn{ font-family:var(--display); opacity:.7; }
.case-rail a:hover{ color:var(--ink-soft); }
.case-rail a.active{ color:#15120d; background:var(--gold); }
.case-rail a.active .rn{ opacity:.85; }

/* ---------- cases ---------- */
.cases{ padding:clamp(2rem,5vw,3.5rem) 0 clamp(1rem,3vw,2rem); }
.case{
  --c:var(--gold);
  display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center; padding:clamp(2.5rem,7vw,5.5rem) 0;
  border-top:1px solid var(--line);
}
.case:nth-child(even) .case-frame{ order:2; }
.case-body{ min-width:0; }
.case-kicker{
  display:flex; align-items:center; gap:.8rem; margin-bottom:1.1rem;
  font-family:var(--sans); font-size:.74rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-faint);
}
.case-kicker .num{ font-family:var(--display); font-size:1.5rem; letter-spacing:0; color:var(--c); opacity:.85; }
.case-kicker .cat{ display:inline-flex; align-items:center; gap:.5rem; }
.case-kicker .cat .dot{ width:7px; height:7px; border-radius:50%; background:var(--c); }
.case-body h2{
  font-family:var(--display); font-weight:540; letter-spacing:-0.014em;
  font-size:clamp(1.9rem,4.4vw,2.9rem); line-height:1.04; margin:0 0 .7rem; text-wrap:balance;
}
.case-desc{ font-size:clamp(1.02rem,1.7vw,1.14rem); color:var(--ink-soft); line-height:1.55; margin:0 0 1.5rem; max-width:46ch; }
.case-desc strong{ color:var(--ink); font-weight:500; }

.case-meta{ display:grid; grid-template-columns:repeat(2,1fr); gap:.9rem 1.4rem; margin:0 0 1.6rem; }
.case-meta div{ border-top:1px solid var(--line); padding-top:.55rem; }
.case-meta dt{ font-family:var(--sans); font-size:.68rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); }
.case-meta dd{ margin:.25rem 0 0; font-size:.95rem; color:var(--ink); }

.case-stats{ display:flex; flex-wrap:wrap; gap:1.6rem 2.2rem; margin:0 0 1.6rem; }
.case-stats .stat{ }
.case-stats .stat .v{ font-family:var(--display); font-weight:560; font-size:clamp(1.7rem,3.2vw,2.3rem); line-height:1; color:var(--c); letter-spacing:-0.01em; }
.case-stats .stat .l{ display:block; margin-top:.35rem; font-family:var(--sans); font-size:.74rem; letter-spacing:.06em; color:var(--ink-faint); text-transform:uppercase; }

.case-feats{ list-style:none; margin:0 0 1.8rem; padding:0; display:flex; flex-wrap:wrap; gap:.5rem; }
.case-feats li{
  font-family:var(--sans); font-size:.8rem; color:var(--ink-soft);
  border:1px solid var(--line-strong); border-radius:999px; padding:.4rem .8rem;
  display:inline-flex; align-items:center; gap:.45rem; transition:border-color .25s, color .25s;
}
.case-feats li::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--c); flex:none; }
.case:hover .case-feats li{ border-color:color-mix(in srgb, var(--c) 30%, transparent); }

.case-cta{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--sans); font-size:.92rem; font-weight:600; color:var(--ink);
  border-bottom:1px solid var(--line-strong); padding-bottom:.35rem;
  transition:gap .3s cubic-bezier(.2,.7,.2,1), border-color .3s, color .3s;
}
.case-cta .ar{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; border:1px solid var(--line-strong); transition:background .3s, color .3s, border-color .3s, transform .3s; }
.case-cta .ar svg{ width:15px; height:15px; }
.case-cta:hover{ color:var(--c); gap:.95rem; border-color:transparent; }
.case-cta:hover .ar{ background:var(--c); border-color:var(--c); color:#15120d; transform:translate(2px,-2px); }

/* ---------- browser-mockup ---------- */
.case-frame{ perspective:1400px; min-width:0; }
.browser{
  position:relative; border-radius:14px; overflow:hidden;
  border:1px solid var(--line-strong);
  background:linear-gradient(180deg, var(--surface), var(--bg-2));
  box-shadow:0 40px 80px -40px rgba(0,0,0,.9), 0 8px 24px -16px rgba(0,0,0,.7);
  transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease;
  will-change:transform;
}
.browser::after{
  content:""; position:absolute; inset:0; border-radius:14px; pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
  background:radial-gradient(600px circle at var(--mx,80%) var(--my,0%), color-mix(in srgb, var(--c) 16%, transparent), transparent 60%);
  opacity:0; transition:opacity .4s ease;
}
.case-frame:hover .browser::after{ opacity:1; }
.browser-bar{
  display:flex; align-items:center; gap:.6rem; padding:.6rem .85rem;
  background:rgba(255,255,255,.03); border-bottom:1px solid var(--line);
}
.browser-bar .dots{ display:flex; gap:.4rem; }
.browser-bar .dots i{ width:10px; height:10px; border-radius:50%; background:var(--line-strong); }
.browser-bar .dots i:nth-child(1){ background:#c0866a; }
.browser-bar .dots i:nth-child(2){ background:#c7a86d; }
.browser-bar .dots i:nth-child(3){ background:#8fa6bf; }
.browser-bar .addr{
  margin-left:.4rem; flex:1; min-width:0;
  font-family:var(--sans); font-size:.74rem; color:var(--ink-faint);
  background:rgba(0,0,0,.25); border:1px solid var(--line); border-radius:999px;
  padding:.32rem .8rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  display:flex; align-items:center; gap:.45rem;
}
.browser-bar .addr svg{ width:12px; height:12px; flex:none; color:var(--c); }
.browser-view{
  position:relative; aspect-ratio:1120/700; overflow:hidden; background:#0c0a08;
}
.browser-view img{
  position:absolute; top:0; left:0; width:100%; height:auto;
  transform:translateY(var(--pan,0px)); will-change:transform;
}
.browser-view::after{ /* nederste blød fade så panorering ser naturlig ud */
  content:""; position:absolute; inset:0; pointer-events:none;
  box-shadow:inset 0 -40px 50px -40px rgba(12,10,8,.9), inset 0 40px 40px -40px rgba(12,10,8,.7);
}
.browser-tag{
  position:absolute; left:.85rem; bottom:.85rem; z-index:2;
  font-family:var(--sans); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); background:rgba(16,13,10,.7); backdrop-filter:blur(4px);
  border:1px solid var(--line-strong); border-radius:999px; padding:.32rem .7rem;
}
@media (max-width:840px){
  .case{ grid-template-columns:1fr; gap:1.8rem; }
  .case:nth-child(even) .case-frame{ order:0; }
}

/* ---------- capabilities ---------- */
.caps{ padding:clamp(3rem,7vw,5rem) 0; border-top:1px solid var(--line); }
.caps-grid{ list-style:none; margin:1.5rem 0 0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.caps-grid li{ background:var(--bg); padding:clamp(1.2rem,2.4vw,1.7rem); }
.caps-grid h3{ font-family:var(--sans); font-size:.95rem; font-weight:600; margin:0 0 .4rem; color:var(--ink); }
.caps-grid p{ margin:0; font-size:.88rem; color:var(--ink-faint); line-height:1.5; }
.caps-grid .ci{ width:24px; height:24px; color:var(--gold); margin-bottom:.7rem; }
@media (max-width:900px){ .caps-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .caps-grid{ grid-template-columns:1fr; } }
.stack-line{ margin-top:clamp(1.6rem,4vw,2.4rem); display:flex; flex-wrap:wrap; gap:.5rem; }
.stack-line span{ font-family:var(--sans); font-size:.78rem; color:var(--ink-soft); border:1px solid var(--line); border-radius:6px; padding:.32rem .65rem; background:var(--surface); }

/* ---------- kontakt ---------- */
.contact{ padding:clamp(3.5rem,8vw,6rem) 0 clamp(2rem,5vw,3rem); border-top:1px solid var(--line); }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.contact-intro h2{ font-family:var(--display); font-weight:540; font-size:clamp(2rem,4.6vw,3rem); line-height:1.05; margin:0 0 1rem; letter-spacing:-0.014em; text-wrap:balance; }
.contact-intro p{ color:var(--ink-soft); font-size:1.06rem; max-width:42ch; margin:0 0 1.6rem; }
.contact-direct{ display:flex; flex-direction:column; gap:.7rem; font-family:var(--sans); }
.contact-direct a{ display:inline-flex; align-items:center; gap:.7rem; color:var(--ink-soft); font-size:.96rem; transition:color .25s; }
.contact-direct a:hover{ color:var(--gold); }
.contact-direct svg{ width:18px; height:18px; color:var(--gold); }
@media (max-width:740px){ .contact-grid{ grid-template-columns:1fr; gap:2rem; } }

/* ---------- footer ---------- */
.site-foot{
  border-top:1px solid var(--line); margin-top:clamp(2rem,5vw,3.5rem);
  padding:clamp(2rem,5vw,3rem) 0 clamp(2.5rem,6vw,4rem);
  display:flex; flex-wrap:wrap; gap:1.2rem 2rem; align-items:center;
}
.site-foot .f-brand{ font-family:var(--display); font-size:1.1rem; color:var(--ink); }
.foot-links{ margin-left:auto; display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; }
.foot-links a{ font-family:var(--sans); font-size:.9rem; color:var(--ink-soft); display:inline-flex; align-items:center; gap:.5rem; border-bottom:1px solid transparent; padding-bottom:2px; transition:color .25s, border-color .25s; }
.foot-links a:hover{ color:var(--gold); border-color:var(--gold-soft); }
.foot-links svg{ width:16px; height:16px; }
.colophon{ width:100%; font-family:var(--sans); font-size:.78rem; color:var(--ink-faint); margin:0; letter-spacing:.01em; }
.colophon a{ color:var(--ink-faint); border-bottom:1px solid var(--line); }
.colophon a:hover{ color:var(--gold); }

/* ============================================================
   App-chrome (kontaktformular, dashboard, login, editor) — mørk
   Bevarer .app-*-klassenavne som webmoduler-editoren/dashboardet bruger.
   ============================================================ */
.app-form{ display:flex; flex-direction:column; gap:1rem; }
.app-field{ display:block; }
.app-field span{ display:block; font-family:var(--sans); font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:.5rem; }
.app-field input, .app-field textarea{
  width:100%; padding:.85rem .95rem; font:inherit; color:var(--ink);
  background:var(--surface); border:1px solid var(--line-strong); border-radius:10px;
  transition:border-color .25s, background .25s;
}
.app-field input:focus, .app-field textarea:focus{ outline:none; border-color:var(--gold); background:var(--surface-2); }
.app-field textarea{ resize:vertical; min-height:120px; }
.app-hp{ position:absolute; left:-9999px; width:1px; height:1px; }
.app-btn{
  display:inline-flex; align-items:center; gap:.6rem; cursor:pointer;
  font-family:var(--sans); font-size:.95rem; font-weight:600;
  background:var(--gold); color:#15120d; border:1px solid var(--gold); border-radius:999px;
  padding:.8rem 1.5rem; text-decoration:none; transition:transform .2s, box-shadow .25s, background .25s;
}
.app-btn svg{ width:18px; height:18px; flex:none; }
.app-btn:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -16px rgba(199,168,109,.7); }
.app-btn:hover svg{ transform:translateX(3px); transition:transform .25s; }
.app-btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-strong); }
.app-btn-ghost:hover{ border-color:var(--gold); color:var(--gold); box-shadow:none; }
.app-err{ list-style:none; margin:0 0 1rem; padding:.85rem 1rem; color:#f0b9ad; background:rgba(192,76,47,.12); border:1px solid rgba(192,76,47,.4); border-radius:10px; }
.app-err li{ font-family:var(--sans); font-size:.9rem; }
.app-ok{ color:#a8d8b0; font-family:var(--sans); font-weight:600; }
.app-editbtn{ position:fixed; right:1rem; bottom:1rem; z-index:60; }

/* Dashboard/login (bag login, noindex) — enkel mørk tabel */
.app-card{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:clamp(1.3rem,3vw,2rem); margin:1.4rem 0; }
.app-card h1, .app-card h2{ font-family:var(--display); font-weight:540; }
.app-card table{ width:100%; border-collapse:collapse; font-family:var(--sans); font-size:.86rem; margin-top:1rem; }
.app-card th, .app-card td{ text-align:left; padding:.6rem .7rem; border-bottom:1px solid var(--line); vertical-align:top; }
.app-card th{ color:var(--ink-faint); font-weight:600; letter-spacing:.04em; }
.app-kpis{ display:flex; flex-wrap:wrap; gap:1rem; margin:1rem 0; }
.app-kpi{ background:var(--surface-2); border:1px solid var(--line); border-radius:10px; padding:.9rem 1.2rem; }
.dash-main{ max-width:1000px; margin:0 auto; padding:2rem clamp(1.1rem,4vw,2.4rem) 4rem; }

/* ---------- animationer ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }

@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .browser, .browser-view img, .scrollcue svg{ transition:none!important; animation:none!important; transform:none!important; }
}
