/* NordicWebFlow v2 — Premium Agency */
/* Inter font self-hosted — no external font requests, GDPR-clean */
@font-face{font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;src:url('/fonts/inter-variable.woff2') format('woff2-variations');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

:root {
  --orange:#E84400;
  --orange-dim:#E84400;
  --orange-light:#FFF3EE;
  --orange-mid:#FFD5C0;
  --orange-glow:rgba(232,68,0,.15);
  --bg:#FAFAF8;
  --bg2:#F4F1EC;
  --card:#FFFFFF;
  --border:#E5E0D8;
  --border-strong:#CCC7BC;
  --border-orange:rgba(232,68,0,.25);
  --heading:#0E0D0B;
  --text:#3D3830;
  --muted:#6B6560;
  --muted2:#5A544E;
  --green:#16A34A;
  --blue:#000000;
  --purple:#7C3AED;
  --font-display:'Inter',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --radius:10px;
  --radius-lg:18px;
  --radius-xl:28px;
  --shadow:0 1px 4px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.05);
  --shadow-lg:0 8px 32px rgba(0,0,0,.10);
  --shadow-orange:0 8px 32px rgba(232,68,0,.28);
  --t:.3s cubic-bezier(.4,0,.2,1);
  --max:1160px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
em,i{font-style:normal}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--font-body);background:var(--bg);color:var(--text);
  font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}

/* Sparkles canvas sits at z-index:0; raise content above it */
main,footer{position:relative;z-index:1}

/* TYPOGRAPHY */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.05;color:var(--heading);letter-spacing:-.03em}
h1{font-size:clamp(2.4rem,6vw,5rem)}
h2{font-size:clamp(1.8rem,4vw,3.2rem)}
h3{font-size:clamp(1.1rem,2vw,1.5rem);font-weight:700}
h4{font-size:1rem;font-weight:700;letter-spacing:-.01em}
p{color:var(--text);line-height:1.75}
.lead{font-size:1.1rem;color:var(--muted);line-height:1.8}

.container{max-width:var(--max);margin:0 auto;padding:0 32px;width:100%}
section{padding:96px 0}
@media(max-width:860px){section{padding:72px 0}}
@media(max-width:640px){section{padding:52px 0}.container{padding:0 18px}}

/* SCROLL REVEAL — enhanced with scale + blur */
.reveal{opacity:0;transform:translateY(32px) scale(.97);filter:blur(4px);transition:opacity .8s ease,transform .8s ease,filter .8s ease}
.reveal.visible{opacity:1;transform:translateY(0) scale(1);filter:none}
.reveal-left{opacity:0;transform:translateX(-32px) scale(.97);filter:blur(4px);transition:opacity .8s ease,transform .8s ease,filter .8s ease}
.reveal-left.visible{opacity:1;transform:translateX(0) scale(1);filter:none}
.reveal-right{opacity:0;transform:translateX(32px) scale(.97);filter:blur(4px);transition:opacity .8s ease,transform .8s ease,filter .8s ease}
.reveal-right.visible{opacity:1;transform:translateX(0) scale(1);filter:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* NAV — frosted glass */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:0;transition:background .4s ease,box-shadow .4s ease,backdrop-filter .4s ease;
}
nav.scrolled,
.page-inner nav{
  background:rgba(250,250,248,.7);backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  box-shadow:0 1px 0 rgba(0,0,0,.06),0 4px 24px rgba(0,0,0,.04);
}
nav:has(.mobile-menu.open){background:var(--bg);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:0 1px 0 rgba(0,0,0,.08)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo-icon{
  width:36px;height:36px;background:var(--orange);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:#fff;
  transition:transform var(--t);
}
.nav-logo:hover .nav-logo-icon{transform:rotate(-8deg) scale(1.05)}
.nav-logo-text{font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:var(--heading)}
.nav-logo-text span{color:var(--orange)}
.nav-left-group{display:flex;align-items:center;gap:12px;flex-shrink:0}
/* iPhone-style pill toggle — sun left (light), moon right (dark) */
.nav-theme-icon{
  width:52px;height:28px;border-radius:14px;
  background:#C8C2BA;border:none;outline:none;
  cursor:pointer;flex-shrink:0;padding:0;
  position:relative;display:inline-block;
  transition:background .3s ease;
}
/* Sliding knob */
.nav-theme-icon::after{
  content:'';position:absolute;
  top:3px;left:3px;width:22px;height:22px;
  border-radius:50%;background:#fff;
  box-shadow:0 1px 4px rgba(0,0,0,.25);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  z-index:1;
}
/* Dark mode */
[data-theme="dark"] .nav-theme-icon{background:var(--orange)}
[data-theme="dark"] .nav-theme-icon::after{transform:translateX(24px)}
.nav-links{display:flex;align-items:center;gap:4px;margin-right:8px}
.nav-links a{padding:7px 14px;border-radius:8px;font-size:.88rem;font-weight:500;color:var(--muted);transition:all var(--t);background:rgba(250,250,248,.72);backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2)}
.nav-links a:hover{color:var(--heading);background:var(--bg2);backdrop-filter:none;-webkit-backdrop-filter:none}
nav.scrolled .nav-links a:not(.nav-cta){background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}
nav.scrolled .nav-links a:not(.nav-cta):hover{background:var(--bg2)}
/* page-inner: only strip bg when scrolled, keep pills on initial load */
.page-inner nav.scrolled .nav-links a:not(.nav-cta){background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}
.page-inner nav.scrolled .nav-links a:not(.nav-cta):hover{background:var(--bg2)}
.dropdown{position:relative;z-index:300}
.dropdown-menu{
  display:none;position:absolute;top:100%;left:0;
  padding-top:8px;
  background:transparent;
  min-width:220px;z-index:300;
}
.dropdown-menu-inner{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:8px;box-shadow:0 12px 40px rgba(0,0,0,.12),0 0 0 1px rgba(0,0,0,.04);
  backdrop-filter:blur(20px);
}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:10px 14px;border-radius:10px;color:var(--text);font-size:.85rem;font-weight:500;transition:all var(--t)}
.dropdown-menu a:hover{color:var(--orange);background:var(--orange-light)}
.nav-cta{
  background:var(--orange)!important;color:#fff!important;
  border-radius:10px!important;font-weight:600!important;
  padding:9px 20px!important;font-family:var(--font-display)!important;
  font-size:.88rem!important;letter-spacing:-.01em!important;
  transition:all var(--t)!important;
}
.nav-cta:hover{background:var(--orange-dim)!important;transform:translateY(-1px)!important;box-shadow:var(--shadow-orange)!important}
.nav-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.hamburger span{display:block;width:22px;height:2px;background:var(--heading);border-radius:2px;transition:var(--t)}
.mobile-menu{
  display:none;flex-direction:column;
  border-top:1px solid var(--border);background:var(--bg);
  max-height:85vh;overflow-y:auto;
}
.mobile-menu.open{display:flex}
/* top-level links */
.mobile-menu>a{
  padding:0 20px;color:var(--text);font-size:1rem;font-weight:500;
  border-bottom:1px solid var(--border);display:flex;align-items:center;
  gap:12px;min-height:52px;transition:color var(--t),background var(--t);
}
.mobile-menu>a:hover{color:var(--orange);background:var(--orange-light)}
/* section labels */
.mobile-menu-cat{
  font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--muted);padding:14px 20px 6px;
}
/* icon for ydelser items */
.mm-icon{font-size:1rem;width:28px;text-align:center;flex-shrink:0}
/* CTA button at bottom */
.mobile-menu-cta{
  margin:16px 20px 24px!important;
  background:var(--orange)!important;color:#fff!important;
  border-radius:12px!important;padding:16px 20px!important;
  justify-content:center!important;font-weight:700!important;
  font-size:1rem!important;border:none!important;min-height:52px!important;
  border-bottom:none!important;
}
.mobile-menu-cta:hover{background:var(--orange-dim)!important;color:#fff!important}
@media(max-width:900px){.nav-links{display:none}.hamburger{display:flex}}

/* ydelser 2-col grid in mobile menu */
.mobile-menu-ydelser{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--border);
}
.mobile-menu-ydelser a{
  padding:14px 16px;color:var(--text);font-size:.88rem;font-weight:500;
  border-bottom:1px solid var(--border);display:flex;align-items:center;min-height:48px;
  gap:8px;transition:color var(--t),background var(--t);
}
.mobile-menu-ydelser a:hover{color:var(--orange);background:var(--orange-light)}
.mobile-menu-ydelser a:nth-child(odd){border-right:1px solid var(--border)}
/* nav CTA group — cart + button flush together */
.nav-cta-group{display:flex;align-items:center;gap:10px}
.nav-cta-group .nav-cta{border-radius:10px!important;padding:9px 20px!important}
@media(max-width:900px){.nav-cta-group .nav-cta{display:none!important}}
/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 28px;border-radius:12px;font-weight:600;font-size:.95rem;
  transition:all .35s cubic-bezier(.4,0,.2,1);line-height:1.2;font-family:var(--font-display);
  white-space:nowrap;min-height:48px;letter-spacing:-.01em;
  position:relative;overflow:hidden;
}
.btn-primary{background:var(--orange);color:#fff}
/* Shimmer sweep on primary buttons */
.btn-primary::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transition:none;
}
.btn-primary:hover::after{left:120%;transition:left .6s ease}
.btn-primary:hover{background:var(--orange-dim);transform:translateY(-2px);box-shadow:var(--shadow-orange)}
.btn-ghost{background:transparent;color:var(--heading);border:1.5px solid var(--border-strong);backdrop-filter:blur(4px)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-light);transform:translateY(-2px)}
.btn-sm{padding:9px 18px;font-size:.84rem;min-height:38px}
.btn-lg{padding:16px 32px;font-size:1.05rem}

/* HERO CTA DROPDOWN */
.hero-cta-dropdown{position:static;display:inline-block}
.hero-cta-arrow{display:inline-block;transition:transform .25s ease;margin-left:4px}
.hero-cta-dropdown.open .hero-cta-arrow{transform:rotate(180deg)}
.hero-cta-panel{
  display:none;
  position:fixed;
  background:#fff;border:1.5px solid var(--border-strong);border-radius:var(--radius-lg);
  box-shadow:0 20px 60px rgba(0,0,0,.18),0 4px 16px rgba(0,0,0,.08);
  width:320px;z-index:9999;padding:6px;
}
.hero-cta-dropdown.open .hero-cta-panel{
  display:block;
  animation:dropdown-in .2s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes dropdown-in{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}
.hero-cta-option{
  display:flex;align-items:center;gap:12px;padding:11px 13px;
  border-radius:10px;text-decoration:none;color:var(--text);
  transition:background var(--t);
}
.hero-cta-option:hover{background:var(--orange-light)}
.hero-cta-opt-icon{
  width:38px;height:38px;border-radius:9px;background:var(--bg2);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;
  transition:background var(--t),border-color var(--t);
}
.hero-cta-option:hover .hero-cta-opt-icon{background:var(--orange-light);border-color:var(--border-orange)}
.hero-cta-opt-body{flex:1;min-width:0}
.hero-cta-opt-title{font-family:var(--font-display);font-weight:700;font-size:.88rem;color:var(--heading);line-height:1.2}
.hero-cta-option:hover .hero-cta-opt-title{color:var(--orange)}
.hero-cta-opt-sub{font-size:.72rem;color:var(--muted);margin-top:1px}
.hero-cta-opt-arr{color:var(--muted);font-size:.85rem;transition:transform var(--t),color var(--t);flex-shrink:0}
.hero-cta-option:hover .hero-cta-opt-arr{transform:translateX(3px);color:var(--orange)}
.hero-cta-divider{height:1px;background:var(--border);margin:4px 6px}
/* dark mode panel */
[data-theme="dark"] .hero-cta-panel{background:var(--card);border-color:var(--border-strong)}
[data-theme="dark"] .hero-cta-opt-icon{background:var(--bg2);border-color:var(--border)}
[data-theme="dark"] .hero-cta-option:hover .hero-cta-opt-icon{background:rgba(232,68,0,.12)}

/* BADGE */
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-family:var(--font-body)}
.badge-orange{background:var(--orange-light);color:var(--orange);border:1px solid var(--orange-mid)}
.badge-white{background:var(--bg2);color:var(--muted);border:1px solid var(--border)}
.badge-dark{background:var(--heading);color:#fff}
[data-theme="dark"] .badge-dark{background:var(--bg2);color:var(--heading);border:1px solid var(--border)}

/* HERO */
.hero{
  min-height:auto;display:flex;align-items:center;
  padding-top:68px;position:relative;overflow:hidden;
  background:var(--bg);
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 40%,rgba(232,68,0,.08) 0%,transparent 60%),
    radial-gradient(ellipse 40% 40% at 20% 80%,rgba(232,68,0,.05) 0%,transparent 50%);
}
/* Animated aurora orbs */
.hero-bg::before,.hero-bg::after{
  content:'';position:absolute;border-radius:50%;filter:blur(120px);
  animation:aurora 12s ease-in-out infinite alternate;will-change:transform;
}
.hero-bg::before{
  width:600px;height:600px;top:10%;right:5%;
  background:radial-gradient(circle,rgba(232,68,0,.07),transparent 70%);
}
.hero-bg::after{
  width:400px;height:400px;bottom:10%;left:20%;
  background:radial-gradient(circle,rgba(232,68,0,.04),transparent 70%);
  animation-delay:-6s;animation-duration:15s;
}
@keyframes aurora{
  0%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-20px) scale(1.05)}
  66%{transform:translate(-20px,15px) scale(.95)}
  100%{transform:translate(15px,-10px) scale(1.02)}
}
/* Noise/grain overlay */
.hero::after{
  content:'';position:absolute;inset:0;z-index:0;opacity:.35;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:180px;
}
.hero-grid-lines{
  position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(to right,rgba(0,0,0,.035) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(0,0,0,.035) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);
}
.hero-inner{position:relative;z-index:1;width:100%;padding:56px 0 64px}
.hero-tag{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:4px 10px 4px 6px;margin-bottom:20px;box-shadow:var(--shadow)}
.hero-tag-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
.hero-tag span{font-size:.72rem;font-weight:600;color:var(--heading);font-family:var(--font-body)}
.hero h1{
  margin-bottom:24px;
  line-height:1.15;
}
.hero h1 em{
  font-style:normal;color:var(--orange);
  position:relative;display:inline-block;
}
.hero h1 em::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:3px;
  background:var(--orange);border-radius:2px;
  transform:scaleX(0);transform-origin:left;
  animation:underline-in 1s .8s ease forwards;
}
@keyframes underline-in{to{transform:scaleX(1)}}
.hero-sub{font-size:1.15rem;color:var(--muted);max-width:540px;margin-bottom:36px;line-height:1.75}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:56px}
.hero-proof{
  display:flex;gap:32px;flex-wrap:wrap;
  padding-top:40px;border-top:1px solid var(--border);
}
.proof-item{display:flex;flex-direction:column}
.proof-num{font-family:var(--font-display);font-weight:800;font-size:2.2rem;color:var(--heading);letter-spacing:-.04em;line-height:1}
.proof-num.o{color:var(--orange)}.proof-num.g{color:var(--green)}.proof-num.b{color:var(--blue)}.proof-num.p{color:var(--purple)}
.proof-lbl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-weight:600}
.hero-visual-col{position:relative}
.hero-mockup{
  background:#fff;border-radius:20px;border:1px solid var(--border);
  box-shadow:0 20px 60px rgba(232,68,0,.12),0 8px 24px rgba(0,0,0,.08);
  overflow:hidden;
  transform:perspective(1000px) rotateY(-5deg) rotateX(2deg);
  transition:transform .6s cubic-bezier(.4,0,.2,1),box-shadow .6s ease;
}
.hero-mockup:hover{
  transform:perspective(1000px) rotateY(0deg) rotateX(0deg) scale(1.02);
  box-shadow:0 32px 80px rgba(232,68,0,.18),0 12px 32px rgba(0,0,0,.1);
}
.mockup-bar{background:var(--bg2);padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.mockup-dots{display:flex;gap:5px}
.mockup-dots span{width:10px;height:10px;border-radius:50%;background:var(--border-strong)}
.mockup-dots span:nth-child(1){background:#FF5F57}
.mockup-dots span:nth-child(2){background:#FFBD2E}
.mockup-dots span:nth-child(3){background:#28C940}
.mockup-url{flex:1;background:#fff;border-radius:6px;border:1px solid var(--border);padding:4px 10px;font-size:.72rem;color:var(--muted);font-family:var(--font-body)}
.mockup-img{width:100%;aspect-ratio:16/10;object-fit:cover}
.hero-float{
  position:absolute;background:rgba(255,255,255,.85);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.5);
  border-radius:14px;padding:12px 16px;
  box-shadow:0 8px 32px rgba(0,0,0,.08),0 0 0 1px rgba(255,255,255,.3) inset;
  animation:float-enhanced 5s ease-in-out infinite;
  z-index:10;
  transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s ease;
  cursor:default;
}
.hero-float:hover{
  transform:scale(1.06) translateY(-4px)!important;
  box-shadow:0 16px 48px rgba(0,0,0,.16),0 0 0 1px rgba(255,255,255,.5) inset;
  animation-play-state:paused;
}
@keyframes float-enhanced{
  0%,100%{transform:translateY(0) rotate(0deg)}
  25%{transform:translateY(-6px) rotate(.5deg)}
  50%{transform:translateY(-12px) rotate(0deg)}
  75%{transform:translateY(-4px) rotate(-.5deg)}
}
.hero-float-1{top:-36px;right:-20px;animation-delay:0s}
.hero-float-2{bottom:-36px;left:-16px;animation-delay:2s}
.float-score{font-family:var(--font-display);font-weight:800;font-size:2rem;color:var(--orange);line-height:1;letter-spacing:-.04em}
.float-lbl{font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-top:2px}
.float-stars{color:#F59E0B;font-size:.9rem;margin-bottom:3px}
.float-txt{font-size:.72rem;color:var(--text);max-width:130px;line-height:1.4}
@media(max-width:900px){
  .hero-inner{padding:40px 0 48px}
  .hero-mockup{transform:none}
  .hero-float-1{right:0;top:-24px}
  .hero-float-2{left:0;bottom:-24px}
}
@media(max-width:860px){
  /* single-column hero: text above, mockup below */
  .hero-inner{padding:32px 0 40px}
  .hero-inner .grid-2{gap:32px!important}
  .hero-visual-col{position:relative}
  .hero-float-1{top:-20px;right:8px}
  .hero-float-2{bottom:-20px;left:8px}
}
@media(max-width:640px){
  .hero-inner{padding:24px 0 32px}
  .hero-inner .grid-2{gap:24px!important}
  .hero h1{font-size:clamp(2rem,9vw,2.8rem);margin-bottom:14px}
  .hero-sub{font-size:1rem;margin-bottom:20px}
  .hero-actions{margin-bottom:28px;gap:10px}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-proof{gap:14px;padding-top:24px}
  .proof-num{font-size:1.6rem}
  /* mockup: hide 3d perspective floats on small screens to avoid overflow */
  .hero-float{display:none}
}

/* TICKER — enhanced with edge fades */
.ticker-wrap{
  background:var(--heading);border:none;outline:none;
  padding:22px 0;overflow:hidden;width:100%;
  position:relative;
}
.ticker-wrap::before,.ticker-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.ticker-wrap::before{left:0;background:linear-gradient(to right,var(--heading),transparent)}
.ticker-wrap::after{right:0;background:linear-gradient(to left,var(--heading),transparent)}
.ticker-track{display:flex;animation:ticker 30s linear infinite;width:max-content}
.ticker-item{
  display:flex;align-items:center;gap:14px;padding:0 28px;
  font-family:var(--font-display);font-weight:700;font-size:.78rem;
  color:rgba(255,255,255,.5);white-space:nowrap;letter-spacing:.06em;text-transform:uppercase;
}
.ticker-dot{width:4px;height:4px;background:var(--orange);border-radius:50%;flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* SECTION HEADER */
.section-header{text-align:left;margin-bottom:56px}
.section-header .badge{margin-bottom:14px}
.section-header h2{margin-bottom:14px}
.section-header p{max-width:520px;margin:0;color:var(--muted);font-size:1rem}
.section-header h2 span{color:var(--orange)}

/* TILT CARDS — Glass + gradient border */
a.card{display:block;text-decoration:none;color:inherit}
.card{
  background:rgba(255,255,255,.8);backdrop-filter:blur(12px);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:28px;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow);
  transform-style:preserve-3d;position:relative;overflow:hidden;
}
.card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(232,68,0,.08) 0%,transparent 60%);pointer-events:none;
  opacity:0;transition:opacity .4s;
}
/* Animated border gradient on hover */
.card::after{
  content:'';position:absolute;inset:-1px;border-radius:var(--radius-lg);z-index:-1;
  background:conic-gradient(from 0deg,var(--orange),#333333,#000000,var(--orange));
  opacity:0;transition:opacity .4s;
  animation:spin-border 4s linear infinite;
}
@keyframes spin-border{to{filter:hue-rotate(360deg)}}
.card:hover::before{opacity:1}
.card:hover::after{opacity:.3}
.card:hover{
  border-color:transparent;
  box-shadow:0 8px 40px rgba(232,68,0,.12),0 2px 8px rgba(0,0,0,.06);
  transform:translateY(-6px);
}
.card-icon{
  width:46px;height:46px;background:var(--orange-light);border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;
  margin-bottom:16px;border:1px solid var(--orange-mid);
}
/* Illustration image variant — replaces emoji icon */
.card-icon.card-icon-img{
  width:100%;height:280px;
  background:var(--orange-light);border:1px solid var(--orange-mid);
  border-radius:16px;padding:16px 16px 0;margin-bottom:16px;
  display:flex;align-items:flex-end;justify-content:center;overflow:hidden;
}
.card-icon.card-icon-img img{
  width:auto;height:260px;max-width:100%;
  object-fit:contain;object-position:bottom center;
  display:block;
}
@media(max-width:640px){
  .card-icon.card-icon-img{height:220px;padding:12px 12px 0}
  .card-icon.card-icon-img img{height:200px}
}
.card h3{margin-bottom:10px}
.card p{font-size:.9rem;color:var(--muted)}
.card-link{color:var(--orange);font-size:.85rem;margin-top:14px;display:inline-flex;align-items:center;gap:4px;font-weight:600;transition:gap var(--t)}
.card-link:hover{gap:8px}

/* FEATURES GRID */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:960px)and(min-width:640px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.features-grid{grid-template-columns:1fr}}

/* SEO CTA BLOCK */
.seo-cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:760px){.seo-cta-grid{grid-template-columns:1fr;gap:28px;padding:28px 20px!important}}

/* PROCESS — horizontal timeline with glow */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.process-grid::before{
  content:'';position:absolute;top:36px;left:28px;right:calc(12.5%);
  height:2px;
  background:linear-gradient(to right,transparent,var(--orange),var(--orange),transparent);
  z-index:0;
  box-shadow:0 0 12px rgba(232,68,0,.3);
}
.process-step{
  padding:24px 20px 24px 0;text-align:left;position:relative;z-index:1;
  transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.process-step:hover{transform:translateY(-6px)}
.process-num-wrap{
  width:56px;height:56px;border-radius:50%;
  background:#fff;border:2px solid var(--border-orange);
  display:flex;align-items:center;justify-content:center;
  margin:0 0 18px;position:relative;
  box-shadow:0 0 0 6px var(--bg),0 0 20px rgba(232,68,0,.1);
  transition:box-shadow .3s ease,border-color .3s ease;
}
.process-step:hover .process-num-wrap{
  border-color:var(--orange);
  box-shadow:0 0 0 6px var(--bg),0 0 24px rgba(232,68,0,.25);
}
.process-num{font-family:var(--font-display);font-weight:800;font-size:1.2rem;color:var(--orange);line-height:1}
.process-step h3{font-size:.95rem;margin-bottom:8px;color:var(--heading)}
.process-step p{font-size:.82rem;color:var(--muted);line-height:1.6}
@media(max-width:760px){
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid::before{display:none}
}
@media(max-width:480px){.process-grid{grid-template-columns:1fr}}

/* CASE STUDY SHOWCASE */
.case-showcase-card{
  display:grid;grid-template-columns:1.1fr 0.9fr;gap:0;
  background:linear-gradient(135deg,var(--heading) 0%,#1a160f 100%);
  border-radius:var(--radius-xl);overflow:hidden;
  border:1px solid rgba(232,68,0,.12);
  box-shadow:0 24px 64px rgba(0,0,0,.2),0 0 0 1px rgba(232,68,0,.06);
}
.case-mockup-col{padding:40px 0 40px 40px;display:flex;align-items:center}
.case-site-mockup{transform:none!important;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.5)!important;width:100%}
.case-site-mockup .mockup-img{object-fit:contain;background:#f5f5f5;aspect-ratio:16/10}
.case-client-col{
  padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:28px;
  border-left:1px solid rgba(255,255,255,.07);
}
.case-client-photo-wrap{display:flex;align-items:center;gap:16px}
.case-client-photo{
  width:72px;height:72px;border-radius:50%;object-fit:cover;object-position:center top;
  border:3px solid var(--orange);flex-shrink:0;
  box-shadow:0 0 0 6px rgba(232,68,0,.12);
}
.case-client-logo{
  width:48px;height:48px;border-radius:10px;object-fit:contain;
  background:#fff;padding:4px;flex-shrink:0;
  border:1px solid var(--border);
}
.case-client-info .case-stars{color:#F59E0B;font-size:.9rem;margin-bottom:6px}
.case-client-name{font-family:var(--font-display);font-weight:700;color:#fff;font-size:.95rem}
.case-client-role{font-size:.78rem;color:rgba(255,255,255,.45);margin-top:2px}
.case-client-site{font-size:.78rem;color:var(--orange);margin-top:4px;text-decoration:underline;display:inline-block}
.case-quote{
  font-size:.95rem;color:rgba(255,255,255,.7);line-height:1.8;
  border-left:3px solid var(--orange);padding-left:18px;
  font-style:italic;margin:0;
}
.case-metrics-row{display:flex;gap:24px}
.case-metric-val{font-family:var(--font-display);font-weight:800;font-size:1.9rem;letter-spacing:-.04em;line-height:1}
.case-metric-val.o{color:var(--orange)}.case-metric-val.g{color:var(--green)}.case-metric-val.p{color:var(--purple)}
.case-metric-lbl{font-size:.65rem;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-weight:600}
.case-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.case-showcase-card--reverse{grid-template-columns:0.9fr 1.1fr}
.case-mockup-col--right{padding:40px 40px 40px 0;display:flex;align-items:center}
.case-showcase-card--reverse .case-client-col{border-left:none;border-right:1px solid rgba(255,255,255,.07)}
@media(max-width:900px){
  .case-showcase-card{grid-template-columns:1fr}
  .case-mockup-col{padding:32px 32px 0}
  .case-client-col{padding:32px;border-left:none;border-top:1px solid rgba(255,255,255,.07)}
  .case-showcase-card--reverse{grid-template-columns:1fr}
  .case-showcase-card--reverse .case-client-col{border-right:none;border-bottom:1px solid rgba(255,255,255,.07);order:1}
  .case-showcase-card--reverse .case-mockup-col--right{padding:32px 32px 0;order:0}
}
@media(max-width:640px){
  .case-mockup-col{padding:24px 24px 0}
  .case-client-col{padding:24px;gap:20px}
  .case-metrics-row{gap:16px}
  .case-metric-val{font-size:1.5rem}
}

/* CTA SECTION — animated border glow */
.cta-section{
  background:linear-gradient(135deg,var(--heading) 0%,#1a1208 100%);
  border-radius:var(--radius-xl);padding:72px 48px;text-align:left;
  position:relative;overflow:hidden;
  border:1px solid rgba(232,68,0,.2);
}
.cta-section::before{
  content:'';position:absolute;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,68,0,.25),transparent 70%);
  top:-250px;left:0;transform:translateX(-20%);
  animation:cta-glow 6s ease-in-out infinite alternate;
}
@keyframes cta-glow{
  0%{opacity:.6;transform:translateX(-20%) scale(1)}
  100%{opacity:1;transform:translateX(-20%) scale(1.15)}
}
/* Animated gradient sweep at bottom */
.cta-section::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--orange),var(--blue),var(--orange),transparent);
  background-size:200% 100%;
  animation:gradient-sweep 3s linear infinite;
}
@keyframes gradient-sweep{to{background-position:-200% 0}}
.cta-section h2{color:#fff;margin-bottom:14px;position:relative}
.cta-section>p{color:rgba(255,255,255,.6);max-width:500px;margin:0 0 32px;position:relative}
.cta-actions{display:flex;justify-content:flex-start;gap:12px;flex-wrap:wrap;position:relative}
.cta-section .btn-ghost{border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.8)}
.cta-section .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1);color:#fff}
@media(max-width:640px){.cta-section{padding:40px 20px;border-radius:var(--radius-lg)}.cta-actions .btn{width:100%;justify-content:center}}

/* FAQ */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  width:100%;text-align:left;padding:20px 0;
  font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--heading);
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  background:none;cursor:pointer;min-height:44px;transition:color var(--t);
}
.faq-q:hover{color:var(--orange)}
.faq-icon{
  flex-shrink:0;width:24px;height:24px;background:var(--orange-light);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);font-size:.9rem;font-weight:700;transition:transform var(--t),background var(--t);
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--orange);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding-bottom:20px;color:var(--muted);font-size:.92rem;line-height:1.8}
.faq-item.open .faq-a{max-height:500px}

/* INDUSTRY GRID */
.industry-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.industry-link{
  position:relative;overflow:hidden;border-radius:var(--radius);
  aspect-ratio:3/2;display:flex;align-items:flex-end;padding:14px 12px;
  border:1px solid var(--border);box-shadow:var(--shadow);
  transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s ease,border-color .4s ease;
  text-decoration:none;
}
.industry-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform .5s ease;z-index:0;
}
.industry-link::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(14,13,11,.88) 0%,rgba(14,13,11,.3) 55%,transparent 100%);
  transition:background .4s ease;
}
.industry-link:hover .industry-img{transform:scale(1.06)}
.industry-link:hover::after{background:linear-gradient(to top,rgba(232,68,0,.82) 0%,rgba(14,13,11,.25) 60%,transparent 100%)}
.industry-link:hover{border-color:var(--orange);transform:translateY(-3px);box-shadow:var(--shadow-lg),0 0 0 1px var(--orange)}
.industry-name{
  position:relative;z-index:2;color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:.9rem;letter-spacing:-.01em;
}
.industry-link-more{
  background:var(--bg2);border:2px dashed var(--border);
  align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:600;font-size:.88rem;
  color:var(--muted);
}
.industry-link-more::after{display:none}
.industry-link-more:hover{background:var(--orange-light);border-color:var(--orange);color:var(--orange)}
@media(max-width:860px){.industry-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.industry-grid{grid-template-columns:repeat(2,1fr);gap:8px}}
@media(max-width:360px){.industry-grid{grid-template-columns:1fr;gap:8px}}

/* STATS ROW */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px}
@media(max-width:720px){.stats-row{grid-template-columns:repeat(2,1fr)}}
.s-val{font-family:var(--font-display);font-weight:800;font-size:2.2rem;color:var(--heading);letter-spacing:-.04em}
.s-val.o{color:var(--orange)}.s-val.g{color:var(--green)}.s-val.b{color:var(--blue)}.s-val.p{color:var(--purple)}
.s-lbl{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-weight:600}

/* FOOTER */
footer{background:var(--heading);padding:72px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand p{font-size:.84rem;margin-top:12px;max-width:240px;line-height:1.7;color:rgba(255,255,255,.65)}
.footer-col h4{font-family:var(--font-display);font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.6);margin-bottom:16px}
.footer-col a{display:block;color:rgba(255,255,255,.75);font-size:.84rem;padding:5px 0;transition:color var(--t)}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.77rem;color:rgba(255,255,255,.6)}
.footer-logo{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.footer-logo-icon{width:32px;height:32px;background:var(--orange);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:.95rem;color:#fff}
.footer-logo-text{font-family:var(--font-display);font-weight:800;color:#fff;font-size:1rem}
.footer-logo-text span{color:var(--orange)}

/* PARTNER SECTION */
.partner-card{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:20px}
.partner-section-bg{background:var(--heading)}
.partner-section-bg h2{color:#fff}
.partner-section-bg h2 span{color:var(--orange)}
.partner-section-bg .lead{color:rgba(255,255,255,.6)}
.partner-section-bg .stats-row{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}
.partner-section-bg .s-lbl{color:rgba(255,255,255,.4)}
.partner-section-bg .s-val:not(.o):not(.g):not(.b):not(.p){color:#fff}

/* SEO BLOCK */
.seo-block{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;margin-top:48px}
.seo-block h3{font-size:1rem;margin-bottom:10px;color:var(--heading)}
.seo-block p{font-size:.85rem;margin-bottom:10px;color:#4A4440}
.internal-links{border-top:1px solid var(--border);padding-top:16px;margin-top:16px;display:flex;flex-wrap:wrap;gap:6px}
.internal-links a{color:#E84400;font-size:.77rem;padding:4px 12px;border:1px solid var(--border-orange);border-radius:999px;transition:all var(--t)}
.internal-links a:hover{background:var(--orange-light);color:#E84400}

/* GRID HELPERS */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:860px){.grid-2{grid-template-columns:1fr}}

/* PAGE HERO */
.page-hero{padding:140px 0 64px;background:linear-gradient(150deg,var(--bg) 55%,var(--orange-light) 100%);position:relative;overflow:hidden}
.page-hero h1 span{color:var(--orange)}
.page-hero .lead{max-width:580px;margin-top:14px}
.page-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}

/* FORM */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.83rem;font-weight:600;color:var(--heading);margin-bottom:6px}
.form-input,.form-textarea,.form-select{width:100%;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--heading);font-family:var(--font-body);font-size:16px;transition:border-color var(--t);outline:none}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--orange)}
.form-textarea{min-height:120px;resize:vertical}

/* PROSE */
.prose h2{margin:36px 0 12px;font-size:1.5rem;color:var(--heading)}
.prose h3{margin:24px 0 10px;font-size:1.15rem;color:var(--heading)}
.prose p{margin-bottom:14px;font-size:.94rem;color:var(--text)}
.prose ul{margin:12px 0 14px 20px;list-style:disc}
.prose ul li{margin-bottom:7px;font-size:.94rem;color:var(--text)}
.prose a{color:var(--orange);text-decoration:underline}
.prose strong{color:var(--heading);font-weight:600}

/* PRICING */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
@media(max-width:960px){.pricing-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}}
.pricing-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-xl);padding:32px;position:relative;transition:all var(--t);box-shadow:var(--shadow)}
.pricing-card:hover{border-color:rgba(232,68,0,.3);box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.pricing-card.featured{border-color:var(--orange);box-shadow:0 0 0 4px var(--orange-light),var(--shadow-lg)}
.pricing-popular{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--orange);color:#fff;padding:4px 18px;border-radius:999px;font-size:.7rem;font-weight:700;white-space:nowrap;font-family:var(--font-display)}
.pricing-label{font-size:.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.pricing-name{font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:var(--heading);margin-bottom:4px}
.pricing-price-row{display:flex;align-items:baseline;gap:6px;margin:14px 0 4px}
.pricing-old{font-size:.9rem;color:var(--muted2);text-decoration:line-through}
.pricing-price{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--heading);letter-spacing:-.04em}
.pricing-currency{font-size:.9rem;color:var(--muted)}
.pricing-desc{font-size:.84rem;color:var(--muted);margin-bottom:22px;line-height:1.6}
.pricing-feature{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem;color:var(--text)}
.pricing-feature:last-child{border-bottom:none}
.check{color:var(--green);flex-shrink:0;margin-top:2px;font-weight:700}
.pricing-note{font-size:.71rem;color:var(--muted2);margin-top:12px;line-height:1.5}

/* MISC */
.divider{border:none;border-top:1px solid var(--border);margin:0}
.text-orange{color:var(--orange)}.text-muted{color:var(--muted)}.text-center{text-align:center}
.mt-4{margin-top:16px}.mt-8{margin-top:32px}.mt-12{margin-top:48px}
.mb-4{margin-bottom:16px}.mb-8{margin-bottom:32px}
.notfound{text-align:left;padding:160px 0 80px}
.notfound .big-num{font-family:var(--font-display);font-weight:800;font-size:clamp(5rem,18vw,12rem);color:transparent;-webkit-text-stroke:2px var(--border);line-height:1;margin-bottom:20px}
.tak-page{text-align:left;padding:160px 0 80px}
.tak-icon{font-size:3.5rem;margin-bottom:20px}

/* COMPARISON TABLE */
.comparison-table{width:100%;border-collapse:collapse;margin:24px 0}
.comparison-table th{padding:12px 14px;text-align:left;font-family:var(--font-display);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:2px solid var(--border)}
.comparison-table th.hl{color:var(--orange)}
.comparison-table td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:.86rem;color:var(--text)}
.comparison-table td.hl{color:var(--orange);font-weight:600}
.yes{color:var(--green);font-weight:600}.no{color:var(--muted2)}
.comparison-table tr:hover td{background:var(--bg2)}
@media(max-width:640px){.comparison-table{display:block;overflow-x:auto}}

/* ACCESSIBILITY */
a:focus-visible,button:focus-visible{outline:2px solid var(--orange);outline-offset:2px;border-radius:4px}

/* ACCESSIBILITY FIXES */
a[href*="linkedin.com"] span{color:#fff!important}

/* ============================================================
   DARK / LIGHT MODE TOGGLE
   ============================================================ */

/* Toggle button — iOS pill style */
/* Old toggle-btn kept for legacy compat but hidden — nav-theme-icon used instead */
.theme-toggle-btn{display:none!important}

/* ── CSS custom property overrides ── */
[data-theme="dark"]{
  color-scheme:dark;
  --bg:#0F0E0C;
  --bg2:#191714;
  --card:#1D1B17;
  --border:#2C2922;
  --border-strong:#3D3A30;
  --border-orange:rgba(232,68,0,.35);
  --heading:#F2EDE7;
  --text:#C0BAB2;
  --muted:#7A756E;
  --muted2:#5E5A54;
  --orange-light:rgba(232,68,0,.13);
  --orange-mid:rgba(232,68,0,.28);
  --orange-glow:rgba(232,68,0,.22);
  --shadow:0 1px 4px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.3);
  --shadow-lg:0 8px 32px rgba(0,0,0,.5);
  --shadow-orange:0 8px 32px rgba(232,68,0,.4);
}

/* ── Nav ── */
[data-theme="dark"] nav.scrolled,
[data-theme="dark"] .page-inner nav{background:rgba(12,11,9,.9)}
[data-theme="dark"] .nav-links a:not(.nav-cta){background:rgba(12,11,9,.6)}
[data-theme="dark"] nav.scrolled .nav-links a:not(.nav-cta){background:transparent}
[data-theme="dark"] nav.scrolled .nav-links a:not(.nav-cta):hover{background:var(--bg2)}
[data-theme="dark"] .dropdown-menu-inner{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .dropdown-menu a{color:var(--text)}
[data-theme="dark"] .mobile-menu{background:var(--bg);border-color:var(--border)}
[data-theme="dark"] .mobile-menu a{border-color:var(--border)}
[data-theme="dark"] .nav-logo-text{color:var(--heading)}
[data-theme="dark"] .hamburger span{background:var(--heading)}

/* ── Hero ── */
[data-theme="dark"] .hero-tag{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .hero-float{
  background:rgba(25,23,18,.92);
  border-color:rgba(255,255,255,.08);
}
[data-theme="dark"] .hero-grid-lines{
  background-image:
    linear-gradient(to right,rgba(255,255,255,.028) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,255,255,.028) 1px,transparent 1px);
}

/* ── Cards ── */
[data-theme="dark"] .card{background:var(--card);border-color:var(--border)}

/* ── Process ── */
[data-theme="dark"] .process-num-wrap{background:var(--card)}

/* ── Page hero (inner pages) ── */
[data-theme="dark"] .page-hero{
  background:linear-gradient(150deg,var(--bg) 55%,rgba(232,68,0,.07) 100%);
}

/* ── Pricing ── */
[data-theme="dark"] .pricing-card{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .pricing-card.featured{border-color:var(--orange)}

/* ── SEO CTA widget (inline background:#fff) ── */
[data-theme="dark"] .seo-cta-grid>div:last-child{
  background:var(--card)!important;border-color:var(--border)!important;
}

/* ── SEO block ── */
[data-theme="dark"] .seo-block p{color:var(--muted)!important}

/* ── Always-dark sections stay near-black in dark mode
      (footer/partner/ticker use var(--heading) which flips to off-white) ── */
[data-theme="dark"] footer,
[data-theme="dark"] .partner-section-bg{background:#080705}
[data-theme="dark"] .ticker-wrap{background:#070604}
[data-theme="dark"] .ticker-wrap::before{background:linear-gradient(to right,#070604,transparent)}
[data-theme="dark"] .ticker-wrap::after{background:linear-gradient(to left,#070604,transparent)}


/* ── Smooth switching transition (added/removed by JS) ── */
html.switching,html.switching *{
  transition:background-color .22s ease,color .22s ease,border-color .22s ease!important;
}

/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .ticker-track{animation:none}
  .hero-mockup{transform:none}
}

/* PRINT */
@media print{nav,footer,.cta-section,.ticker-wrap{display:none}}

/* ============================================================
   CART ICON IN NAV
   ============================================================ */
.nav-cart-link{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  padding:7px 10px!important;color:var(--muted)!important;
  background:none!important;border:none!important;border-radius:0!important;
  transition:color var(--t)!important;
}
.nav-cart-link:hover{color:var(--heading)!important}
.nav-cart-badge{
  position:absolute;top:1px;right:2px;min-width:16px;height:16px;padding:0 4px;
  background:var(--orange);color:#fff;border-radius:999px;font-size:.6rem;
  font-weight:700;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);line-height:1;
  transition:transform .2s cubic-bezier(.4,0,.2,1);
}
.nav-cart-badge.hidden{display:none}
.nav-cart-badge.pop{animation:badge-pop .3s cubic-bezier(.4,0,.2,1)}
@keyframes badge-pop{0%{transform:scale(1.6)}100%{transform:scale(1)}}

/* ============================================================
   CALCULATOR SECTION — BEREGN DIN PRIS
   ============================================================ */
.calc-section{padding:96px 0;background:var(--bg)}
@media(max-width:860px){.calc-section{padding:72px 0}}
@media(max-width:640px){.calc-section{padding:64px 0 52px}}

/* Product category tabs */
.calc-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.calc-tab{
  display:inline-flex;align-items:center;gap:8px;padding:10px 18px;
  border-radius:12px;border:1.5px solid var(--border);background:var(--card);
  font-size:.88rem;font-weight:600;color:var(--muted);cursor:pointer;
  transition:all var(--t);font-family:var(--font-display);
}
.calc-tab:hover{border-color:var(--orange);color:var(--heading);background:var(--orange-light)}
.calc-tab.active{
  border-color:var(--orange);background:var(--orange);color:#fff;
  box-shadow:var(--shadow-orange);
}
.calc-tab-icon{font-size:1rem}
@media(max-width:640px){
  .calc-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .calc-tab{justify-content:center;padding:10px 12px;font-size:.82rem}
  .calc-tabs .calc-tab:last-child:nth-child(odd){grid-column:1/-1}
}

/* Main two-column layout */
.calc-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;
}
@media(max-width:920px){.calc-grid{grid-template-columns:1fr}}

/* Left column — controls */
.calc-controls{
  background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-xl);
  padding:32px;box-shadow:var(--shadow);
}

/* Product panel (shown/hidden based on tab) */
.calc-product-panel{display:none}
.calc-product-panel.active{display:block}

/* Slider row */
.calc-slider-wrap{margin-bottom:28px}
.calc-slider-label{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:10px;
}
.calc-slider-label span{font-size:.83rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.calc-slider-label strong{
  font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:var(--orange);
}
.calc-slider{
  width:100%;height:5px;appearance:none;-webkit-appearance:none;
  background:linear-gradient(to right,var(--orange) var(--val,10%),var(--border) var(--val,10%));
  border-radius:99px;outline:none;cursor:pointer;
}
.calc-slider::-webkit-slider-thumb{
  appearance:none;-webkit-appearance:none;
  width:20px;height:20px;background:var(--orange);border-radius:50%;border:3px solid #fff;
  box-shadow:0 0 0 1px var(--orange),0 4px 8px rgba(232,68,0,.3);cursor:grab;
}
.calc-slider::-moz-range-thumb{
  width:20px;height:20px;background:var(--orange);border-radius:50%;border:3px solid #fff;
  box-shadow:0 0 0 1px var(--orange),0 4px 8px rgba(232,68,0,.3);cursor:grab;
}

/* Section label */
.calc-section-label{
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border);
}

/* Add-on checkboxes */
.calc-addons{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.calc-addon{
  display:flex;align-items:flex-start;gap:12px;padding:12px 14px;
  border:1.5px solid var(--border);border-radius:12px;cursor:pointer;
  transition:all var(--t);position:relative;
}
.calc-addon:hover{border-color:var(--orange);background:var(--orange-light)}
.calc-addon.checked{border-color:var(--orange);background:var(--orange-light)}
.calc-addon input[type=checkbox]{
  width:18px;height:18px;flex-shrink:0;margin-top:1px;
  accent-color:var(--orange);cursor:pointer;
}
.calc-addon-info{flex:1}
.calc-addon-name{font-weight:600;font-size:.88rem;color:var(--heading);line-height:1.3}
.calc-addon-desc{font-size:.75rem;color:var(--muted);margin-top:2px;line-height:1.4}
.calc-addon-price{
  font-family:var(--font-display);font-weight:700;font-size:.88rem;
  color:var(--orange);white-space:nowrap;flex-shrink:0;margin-top:1px;
}
/* mutually exclusive radio-style addon groups */
.calc-exclusive-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.calc-exclusive-option{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  border:1.5px solid var(--border);border-radius:12px;cursor:pointer;transition:all var(--t);
}
.calc-exclusive-option:hover{border-color:var(--orange);background:var(--orange-light)}
.calc-exclusive-option.selected{border-color:var(--orange);background:var(--orange-light)}
.calc-exclusive-option input[type=radio]{accent-color:var(--orange);cursor:pointer}
.calc-exclusive-name{font-weight:600;font-size:.88rem;color:var(--heading);flex:1}
.calc-exclusive-price{
  font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--orange);
  white-space:nowrap;
}
.calc-exclusive-monthly{font-size:.7rem;color:var(--muted);font-weight:500}

/* Price box at bottom of left column */
.calc-price-box{
  background:#111008;border-radius:var(--radius-lg);padding:24px;
  margin-top:24px;text-align:left;position:sticky;bottom:20px;
}
.calc-price-label{font-size:.72rem;font-weight:700;color:rgba(255,255,255,.5);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.calc-price-total{
  font-family:var(--font-display);font-weight:800;font-size:2.8rem;color:#fff;
  letter-spacing:-.04em;line-height:1;margin-bottom:4px;
}
.calc-price-total .currency{font-size:1.2rem;font-weight:600;margin-left:4px}
.calc-price-note{font-size:.72rem;color:rgba(255,255,255,.45);margin-bottom:20px;line-height:1.4}
.calc-add-cart{
  width:100%;padding:14px 24px;border-radius:12px;
  background:var(--orange);color:#fff;font-weight:700;font-size:1rem;
  font-family:var(--font-display);letter-spacing:-.01em;cursor:pointer;border:none;
  transition:all var(--t);display:flex;align-items:center;justify-content:center;gap:8px;
  position:relative;overflow:hidden;
}
.calc-add-cart::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
}
.calc-add-cart:hover::after{left:120%;transition:left .6s ease}
.calc-add-cart:hover{background:var(--orange-dim);transform:translateY(-1px);box-shadow:var(--shadow-orange)}
.calc-quote-link{
  display:inline-block;margin-top:12px;font-size:.8rem;color:rgba(255,255,255,.5);
  text-align:left;text-decoration:underline;text-underline-offset:3px;transition:color var(--t);
}
.calc-quote-link:hover{color:rgba(255,255,255,.8)}

/* Right column — live preview */
.calc-preview-col{position:sticky;top:88px}
@media(max-width:920px){.calc-preview-col{display:none}}
.calc-preview-browser{
  background:#fff;border-radius:16px;border:1.5px solid var(--border);
  box-shadow:0 20px 60px rgba(232,68,0,.1),0 8px 24px rgba(0,0,0,.07);
  overflow:hidden;transition:box-shadow .4s ease;
}
.calc-preview-browser:hover{box-shadow:0 28px 80px rgba(232,68,0,.15),0 12px 32px rgba(0,0,0,.09)}
.calc-browser-bar{
  background:var(--bg2);padding:10px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.calc-browser-dots{display:flex;gap:5px}
.calc-browser-dots span{width:9px;height:9px;border-radius:50%}
.calc-browser-dots span:nth-child(1){background:#FF5F57}
.calc-browser-dots span:nth-child(2){background:#FFBD2E}
.calc-browser-dots span:nth-child(3){background:#28C940}
.calc-browser-url{
  flex:1;background:#fff;border:1px solid var(--border);border-radius:6px;
  padding:4px 10px;font-size:.68rem;color:var(--muted);
}

/* Site preview inside browser */
.calc-site-preview{font-size:.6rem;min-height:320px;background:var(--bg);overflow:hidden}
.site-nav-bar{
  display:flex;align-items:center;gap:6px;padding:6px 10px;
  background:#fff;border-bottom:1px solid var(--border);flex-wrap:wrap;
}
.site-nav-logo{font-weight:800;font-size:.75rem;color:var(--heading);font-family:var(--font-display)}
.site-nav-logo span{color:var(--orange)}
.site-nav-links{display:flex;gap:4px;flex:1;justify-content:flex-end;flex-wrap:wrap}
.site-nav-link{
  padding:2px 5px;font-size:.55rem;color:var(--muted);border-radius:4px;
  font-weight:500;transition:opacity .3s;
}
.site-nav-link.fade-in{animation:nav-fade-in .4s ease forwards}
@keyframes nav-fade-in{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}

/* Hero section preview */
.site-hero-section{
  padding:14px 10px;background:linear-gradient(135deg,var(--bg) 60%,var(--orange-light));
  position:relative;min-height:80px;
}
.site-hero-headline{font-weight:800;font-size:.85rem;color:var(--heading);margin-bottom:4px;font-family:var(--font-display)}
.site-hero-sub{font-size:.6rem;color:var(--muted);line-height:1.4;max-width:140px}
.site-hero-btn{
  display:inline-block;margin-top:6px;padding:3px 9px;background:var(--orange);
  color:#fff;border-radius:5px;font-size:.6rem;font-weight:700;font-family:var(--font-display);
}
/* Badges */
.site-badge{
  position:absolute;top:6px;right:8px;padding:2px 7px;border-radius:999px;
  font-size:.5rem;font-weight:700;font-family:var(--font-display);
  opacity:0;transition:opacity .4s ease,transform .4s ease;transform:scale(.8);
}
.site-badge.visible{opacity:1;transform:scale(1)}
.site-badge-seo{background:#d1fae5;color:#065f46}
.site-badge-ads{background:var(--orange-light);color:var(--orange)}
.site-badge-analytics{background:#ede9fe;color:#5b21b6}
/* Dark background sections — forces headings/paragraphs to inherit white from parent instead of dark CSS defaults */
.dark-bg h1,.dark-bg h2,.dark-bg h3,.dark-bg h4,.dark-bg h5,.dark-bg h6,.dark-bg p{color:inherit}
/* Services preview */
.site-services{padding:8px 10px;background:#fff;border-top:1px solid var(--border)}
.site-services-title{font-weight:700;font-size:.65rem;color:var(--heading);margin-bottom:5px;font-family:var(--font-display)}
.site-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.site-service-card{background:var(--bg2);border-radius:4px;padding:4px 5px;border:1px solid var(--border)}
.site-service-card .s-icon{font-size:.75rem;margin-bottom:2px}
.site-service-card .s-title{font-size:.5rem;font-weight:600;color:var(--heading)}
/* Footer preview */
.site-footer-preview{
  padding:6px 10px;background:var(--heading);display:flex;align-items:center;gap:6px;
}
.site-footer-txt{font-size:.5rem;color:rgba(255,255,255,.5);flex:1}
.site-footer-analytics{
  display:flex;align-items:center;gap:3px;opacity:0;transition:opacity .4s ease;
}
.site-footer-analytics.visible{opacity:1}
.site-footer-analytics span{font-size:.5rem;color:rgba(255,255,255,.5)}

/* Phone mockup for app development */
.calc-phone-mockup{
  width:60px;height:100px;background:var(--heading);border-radius:10px;
  border:2px solid var(--border-strong);position:absolute;right:-12px;bottom:-12px;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
  opacity:0;transition:opacity .5s ease,transform .5s ease;transform:translateX(10px) rotate(5deg);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding:6px 4px;overflow:hidden;
}
.calc-phone-mockup.visible{opacity:1;transform:translateX(0) rotate(2deg)}
.phone-notch{width:18px;height:4px;background:var(--border-strong);border-radius:99px;margin-bottom:4px}
.phone-screen-content{width:100%;background:var(--bg2);border-radius:4px;padding:3px;flex:1}
.phone-screen-hero{background:var(--orange);border-radius:3px;height:16px;margin-bottom:3px;display:flex;align-items:center;justify-content:center}
.phone-screen-hero span{font-size:.35rem;color:#fff;font-weight:700}

.calc-preview-col-inner{position:relative}

/* Upsell cards below calculator */
.calc-upsells{margin-top:32px;display:flex;flex-direction:column;gap:10px}
.upsell-heading{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;padding-top:4px}
.upsell-card{
  display:flex;align-items:center;gap:14px;padding:14px 18px;
  background:var(--card);border:1.5px solid var(--border);border-radius:14px;
  transition:all var(--t);margin-bottom:8px;
}
.upsell-card:hover{border-color:var(--orange);background:var(--orange-light)}
.upsell-icon{font-size:1.4rem;flex-shrink:0}
.upsell-body{flex:1}
.upsell-title{font-weight:700;font-size:.9rem;color:var(--heading);margin-bottom:2px}
.upsell-sub{font-size:.78rem;color:var(--muted)}
.upsell-action{font-size:.8rem;font-weight:600;color:var(--orange);white-space:nowrap;flex-shrink:0}
.upsell-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.upsell-price{font-size:.8rem;font-weight:700;color:var(--heading);white-space:nowrap}
.upsell-add-btn{background:var(--orange);color:#fff;border:none;border-radius:8px;padding:6px 12px;font-size:.75rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:opacity var(--t);text-decoration:none;display:inline-block}
.upsell-add-btn:hover{opacity:.85}

/* Added-to-cart toast */
.cart-toast{
  position:fixed;bottom:24px;right:24px;z-index:10000;
  background:var(--heading);color:#fff;border-radius:14px;padding:14px 20px;
  display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);
  font-size:.9rem;font-weight:600;font-family:var(--font-display);
  opacity:0;transform:translateY(10px);transition:opacity .3s ease,transform .3s ease;
  pointer-events:none;
}
.cart-toast.visible{opacity:1;transform:translateY(0)}

/* dark mode */
[data-theme="dark"] .calc-controls{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .calc-tab{background:var(--card);border-color:var(--border);color:var(--muted)}
[data-theme="dark"] .calc-addon,.calc-exclusive-option{border-color:var(--border)}
[data-theme="dark"] .calc-preview-browser{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .calc-browser-url{background:var(--bg2);border-color:var(--border)}
[data-theme="dark"] .site-nav-bar{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .site-service-card{background:var(--bg);border-color:var(--border)}
[data-theme="dark"] .upsell-card{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .calc-site-preview{background:var(--bg2)}
[data-theme="dark"] .site-services{background:var(--card);border-color:var(--border)}

/* ============================================================
   CART PAGE — /kurv
   ============================================================ */
.cart-page{padding:140px 0 96px}
.cart-page h1{margin-bottom:8px}
.cart-empty{text-align:center;padding:80px 0;color:var(--muted)}
.cart-empty-icon{font-size:3rem;margin-bottom:16px}
.cart-empty-title{font-family:var(--font-display);font-weight:800;font-size:1.8rem;color:var(--heading);margin-bottom:8px}
.cart-table{width:100%;border-collapse:collapse;margin:32px 0}
.cart-table th{
  text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--muted);padding:12px 16px;
  border-bottom:2px solid var(--border);
}
.cart-table td{
  padding:16px;border-bottom:1px solid var(--border);vertical-align:top;
  font-size:.9rem;color:var(--text);
}
.cart-item-name{font-weight:700;font-size:.95rem;color:var(--heading);margin-bottom:4px}
.cart-item-meta{font-size:.78rem;color:var(--muted);line-height:1.6}
.cart-item-price{
  font-family:var(--font-display);font-weight:800;font-size:1.1rem;
  color:var(--heading);white-space:nowrap;
}
.cart-remove{
  color:var(--muted);background:none;border:none;cursor:pointer;
  font-size:1rem;padding:4px 8px;border-radius:6px;transition:all var(--t);
}
.cart-remove:hover{color:#ffffff;background:#fee2e2}
.cart-summary{
  border-top:2px solid var(--border);margin-top:24px;padding-top:24px;
  display:flex;flex-direction:column;align-items:flex-end;gap:12px;
}
.cart-subtotal{
  display:flex;align-items:baseline;gap:10px;
}
.cart-subtotal-label{font-size:.85rem;color:var(--muted);font-weight:600}
.cart-subtotal-val{
  font-family:var(--font-display);font-weight:800;font-size:2rem;
  color:var(--heading);letter-spacing:-.03em;
}
.cart-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;margin-top:8px}
@media(max-width:640px){
  .cart-table th:nth-child(2),.cart-table td:nth-child(2){display:none}
  .cart-actions{justify-content:stretch}
  .cart-actions .btn{width:100%;justify-content:center}
}

/* ============================================================
   CHECKOUT PAGE — /betaling
   ============================================================ */
.checkout-page{padding:140px 0 96px}
.checkout-grid{display:grid;grid-template-columns:1fr 400px;gap:48px;align-items:start}
@media(max-width:960px){.checkout-grid{grid-template-columns:1fr;gap:32px}}
.checkout-form-col{}
.checkout-summary-col{
  background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-xl);
  padding:28px;position:sticky;top:88px;box-shadow:var(--shadow);
}
@media(max-width:960px){.checkout-summary-col{position:static}}
.checkout-summary-title{
  font-family:var(--font-display);font-weight:800;font-size:1.1rem;
  color:var(--heading);margin-bottom:20px;padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.checkout-item{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:12px;padding:12px 0;border-bottom:1px solid var(--border);
}
.checkout-item:last-of-type{border-bottom:none}
.checkout-item-name{font-size:.88rem;font-weight:600;color:var(--heading);line-height:1.4}
.checkout-item-meta{font-size:.72rem;color:var(--muted);margin-top:2px}
.checkout-item-price{
  font-family:var(--font-display);font-weight:700;font-size:.9rem;color:var(--heading);
  white-space:nowrap;flex-shrink:0;
}
.checkout-total-row{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-top:16px;padding-top:16px;border-top:2px solid var(--border);
}
.checkout-total-label{font-size:.88rem;font-weight:700;color:var(--heading)}
.checkout-total-val{
  font-family:var(--font-display);font-weight:800;font-size:1.8rem;
  color:var(--orange);letter-spacing:-.03em;
}
.checkout-submit{
  width:100%;margin-top:20px;padding:16px;background:var(--orange);color:#fff;
  border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;
  font-family:var(--font-display);transition:all var(--t);position:relative;overflow:hidden;
}
.checkout-submit::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
}
.checkout-submit:hover::after{left:120%;transition:left .6s ease}
.checkout-submit:hover{background:var(--orange-dim);transform:translateY(-1px);box-shadow:var(--shadow-orange)}
.checkout-note{font-size:.72rem;color:var(--muted);text-align:center;margin-top:10px;line-height:1.5}
[data-theme="dark"] .checkout-summary-col{background:var(--card);border-color:var(--border)}

/* APP PAGES — mobile responsive */
@media(max-width:760px){
  .page-hero .container[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important;gap:28px!important}
  .page-hero [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important;gap:28px!important}
  [style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  .process-grid[style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  .comparison-table{font-size:.78rem}
  .comparison-table th,.comparison-table td{padding:8px 6px}
}
@media(max-width:480px){
  .process-grid[style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:1fr!important}
}


/* ── Cookie Banner ── */
@keyframes cookieFadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.cookie-banner{display:none;position:fixed;bottom:24px;left:24px;z-index:9999;width:360px;max-width:calc(100vw - 48px);background:#fff;border-radius:20px;box-shadow:0 8px 40px rgba(0,0,0,.16),0 2px 8px rgba(0,0,0,.06);font-family:system-ui,sans-serif;animation:cookieFadeUp .3s cubic-bezier(.4,0,.2,1) both}
.cookie-banner-inner{padding:24px}
.cookie-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.cookie-emoji{font-size:1.5rem;line-height:1}
.cookie-title{font-size:.95rem;font-weight:700;color:#111008;margin:0}
.cookie-body{font-size:.8rem;color:#6A6360;line-height:1.6;margin:0 0 16px}
.cookie-link{color:#E84400;text-decoration:underline}
.cookie-checks{display:flex;flex-direction:column;gap:0;margin-bottom:18px;background:#FAF8F5;border-radius:12px;overflow:hidden;border:1px solid #EDE7DF}
.cookie-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px}
.cookie-toggle-row+.cookie-toggle-row{border-top:1px solid #EDE7DF}
.cookie-toggle-info{display:flex;flex-direction:column;gap:2px}
.cookie-toggle-name{font-size:.83rem;font-weight:600;color:#1A1714}
.cookie-toggle-desc{font-size:.73rem;color:#9A948D}
.cookie-always-on{font-size:.72rem;font-weight:600;color:#16A34A;background:#DCFCE7;padding:3px 10px;border-radius:20px;white-space:nowrap}
.cookie-switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}
.cookie-switch input{opacity:0;width:0;height:0;position:absolute}
.cookie-switch-track{position:absolute;inset:0;background:#D0C8BE;border-radius:24px;cursor:pointer;transition:background .2s}
.cookie-switch-track::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.cookie-switch input:checked+.cookie-switch-track{background:#E84400}
.cookie-switch input:checked+.cookie-switch-track::before{transform:translateX(18px)}
.cookie-switch input:focus-visible+.cookie-switch-track{outline:2px solid #E84400;outline-offset:2px}
.cookie-btns{display:flex;gap:8px}
.cookie-btn{flex:1;padding:10px 8px;border-radius:10px;font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit;border:none;transition:background .15s,transform .1s;min-height:40px}
.cookie-btn:active{transform:scale(.97)}
.cookie-btn-ghost{background:#F0EBE5;color:#3A3530}
.cookie-btn-ghost:hover{background:#E8E0D8}
.cookie-btn-primary{background:#E84400;color:#fff}
.cookie-btn-primary:hover{background:#D03D00}
/* Floating cookie button */
.cookie-float-btn{position:fixed;bottom:20px;right:20px;z-index:9998;width:44px;height:44px;border-radius:50%;background:#fff;border:1.5px solid #D0C8BE;box-shadow:0 2px 12px rgba(0,0,0,.12);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:box-shadow .2s,transform .2s}
.cookie-float-btn:hover{transform:scale(1.08);box-shadow:0 4px 20px rgba(0,0,0,.18)}
/* Dark mode */
[data-theme="dark"] .cookie-banner{background:#1D1B17;box-shadow:0 8px 40px rgba(0,0,0,.5),0 2px 8px rgba(0,0,0,.3)}
[data-theme="dark"] .cookie-title{color:#F2EDE7}
[data-theme="dark"] .cookie-body{color:#9A948D}
[data-theme="dark"] .cookie-link{color:#FF7A33}
[data-theme="dark"] .cookie-checks{background:#252219;border-color:#3D3A30}
[data-theme="dark"] .cookie-toggle-row+.cookie-toggle-row{border-color:#3D3A30}
[data-theme="dark"] .cookie-toggle-name{color:#F2EDE7}
[data-theme="dark"] .cookie-toggle-desc{color:#6A6360}
[data-theme="dark"] .cookie-switch-track{background:#3D3A30}
[data-theme="dark"] .cookie-btn-ghost{background:#2C2922;color:#C0BAB2}
[data-theme="dark"] .cookie-btn-ghost:hover{background:#3D3A30}
[data-theme="dark"] .cookie-float-btn{background:#1D1B17;border-color:#3D3A30;box-shadow:0 2px 12px rgba(0,0,0,.4)}
@media(max-width:480px){.cookie-banner{bottom:0;left:0;right:0;max-width:100%;border-radius:20px 20px 0 0}}

/* ============================================================
   WIZARD CALCULATOR
   ============================================================ */
.wiz-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-xl);padding:40px 32px;box-shadow:var(--shadow);max-width:640px;margin:0 auto;overflow:hidden}
@media(max-width:640px){.wiz-card{padding:28px 18px 28px}}
.wiz-indicator{display:flex;align-items:center;justify-content:center;max-width:280px;margin:0 auto 6px}
.wiz-dot{width:34px;height:34px;border-radius:50%;border:2px solid var(--border);background:var(--bg);color:var(--muted);font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .25s ease;font-family:var(--font-display)}
.wiz-dot.active{border-color:var(--orange);background:var(--orange);color:#fff;box-shadow:0 0 0 4px rgba(232,68,0,.14)}
.wiz-dot.done{border-color:#22c55e;background:#22c55e;color:#fff}
.wiz-connector{height:2px;flex:1;max-width:72px;background:var(--border);transition:background .25s}
.wiz-connector.done{background:#22c55e}
.wiz-step-labels{display:flex;justify-content:space-between;max-width:280px;margin:0 auto 36px;font-size:.68rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.wiz-panel{animation:wiz-in .22s ease}
@keyframes wiz-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.wiz-question{font-size:clamp(1.1rem,2.5vw,1.4rem);font-weight:800;color:var(--heading);margin-bottom:24px;text-align:center}
.wiz-back{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;color:var(--muted);border:none;background:none;cursor:pointer;padding:0;margin-bottom:16px;transition:color var(--t);font-family:inherit}
.wiz-back:hover{color:var(--heading)}
.wiz-product-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:540px;margin:0 auto}
.wiz-product-card{display:flex;flex-direction:column;align-items:center;padding:24px 16px;border:1.5px solid var(--border);border-radius:var(--radius-xl);background:var(--bg);cursor:pointer;transition:all .2s ease;font-family:inherit;text-align:center;gap:7px;box-shadow:var(--shadow)}
.wiz-product-card:hover{border-color:var(--orange);background:var(--orange-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,68,0,.12)}
.wiz-card-icon{font-size:2rem;line-height:1}
.wiz-card-title{font-weight:700;font-size:.92rem;color:var(--heading)}
.wiz-card-sub{font-size:.72rem;color:var(--muted);font-weight:500}
.wiz-plan-grid{display:flex;flex-direction:column;gap:10px;max-width:520px;margin:0 auto 24px}
.wiz-plan-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1.5px solid var(--border);border-radius:14px;background:var(--bg);cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:var(--shadow)}
.wiz-plan-card:hover{border-color:var(--orange);background:var(--orange-light)}
.wiz-plan-card.selected{border-color:var(--orange);background:var(--orange-light);box-shadow:0 0 0 3px rgba(232,68,0,.15)}
.wiz-plan-radio{width:19px;height:19px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;transition:all .2s;position:relative}
.wiz-plan-card.selected .wiz-plan-radio{border-color:var(--orange);background:var(--orange)}
.wiz-plan-card.selected .wiz-plan-radio::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:7px;height:7px;border-radius:50%;background:#fff}
.wiz-plan-info{flex:1;text-align:left}
.wiz-plan-name{font-weight:700;font-size:.9rem;color:var(--heading);display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.wiz-plan-sub{font-size:.72rem;color:var(--muted);margin-top:2px}
.wiz-plan-price{font-family:var(--font-display);font-weight:800;font-size:1rem;color:var(--orange);white-space:nowrap;text-align:right;flex-shrink:0}
.wiz-plan-monthly{font-size:.65rem;color:var(--muted);font-weight:500}
.wiz-plan-tag{background:var(--orange);color:#fff;font-size:.58rem;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.02em;white-space:nowrap}
.wiz-next-btn{display:block;margin:0 auto;min-width:180px}
.wiz-addons-grid{display:flex;flex-direction:column;gap:9px;max-width:520px;margin:0 auto 24px}
.wiz-addon-toggle{display:flex;align-items:flex-start;gap:12px;padding:13px 15px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);cursor:pointer;transition:all .2s;user-select:none;box-shadow:var(--shadow)}
.wiz-addon-toggle:hover{border-color:var(--orange);background:var(--orange-light)}
.wiz-addon-toggle.active{border-color:var(--orange);background:var(--orange-light)}
.wiz-addon-check{width:20px;height:20px;border-radius:5px;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-top:1px;font-size:.7rem;font-weight:700;color:#fff}
.wiz-addon-toggle.active .wiz-addon-check{border-color:var(--orange);background:var(--orange)}
.wiz-addon-toggle.active .wiz-addon-check::after{content:'✓'}
.wiz-addon-info{flex:1}
.wiz-addon-name{font-weight:600;font-size:.86rem;color:var(--heading);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.wiz-addon-desc{font-size:.72rem;color:var(--muted);margin-top:2px}
.wiz-addon-price{font-family:var(--font-display);font-weight:700;font-size:.86rem;color:var(--orange);white-space:nowrap;flex-shrink:0}
.wiz-rec-tag{background:var(--orange);color:#fff;font-size:.56rem;font-weight:700;padding:2px 6px;border-radius:4px}
.wiz-price-bar{background:#111008;border-radius:var(--radius-lg);padding:20px 24px;display:flex;align-items:center;gap:20px;max-width:520px;margin:0 auto;flex-wrap:wrap}
.wiz-price-info{flex:1}
.wiz-price-lbl{font-size:.65rem;font-weight:700;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px}
.wiz-price-amt{font-family:var(--font-display);font-weight:800;font-size:1.9rem;color:#fff;line-height:1;letter-spacing:-.03em}
.wiz-price-note{font-size:.65rem;color:rgba(255,255,255,.35);margin-top:3px}
.wiz-cta-btn{flex-shrink:0;white-space:nowrap}
@media(max-width:480px){.wiz-price-bar{flex-direction:column;align-items:flex-start;gap:14px}.wiz-cta-btn{width:100%;justify-content:center}}

/* ============================================================
   CHECKOUT PROGRESS
   ============================================================ */
.co-progress{display:flex;align-items:center;gap:0;margin-bottom:32px;max-width:420px}
.co-step{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--muted);flex:1}
.co-step.active{color:var(--heading)}
.co-step.done{color:#22c55e}
.co-step-num{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;transition:all .25s}
.co-step.active .co-step-num{border-color:var(--orange);background:var(--orange);color:#fff}
.co-step.done .co-step-num{border-color:#22c55e;background:#22c55e;color:#fff}
.co-connector{height:2px;width:32px;background:var(--border);flex-shrink:0;margin:0 4px;transition:background .25s}
.co-connector.done{background:#22c55e}

/* ============================================================
   BRIEFING FORM (tak.html)
   ============================================================ */
.brief-section{padding:80px 0 60px}
.brief-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-xl);padding:36px 32px;box-shadow:var(--shadow);max-width:600px;margin:0 auto}
@media(max-width:640px){.brief-card{padding:24px 18px}}
.brief-step{animation:wiz-in .22s ease}
.brief-q{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px}
.brief-progress{height:4px;background:var(--border);border-radius:2px;margin-bottom:28px;overflow:hidden}
.brief-progress-fill{height:100%;background:var(--orange);border-radius:2px;transition:width .3s ease}
.brief-opt-grid{display:flex;flex-direction:column;gap:8px}
.brief-opt{display:flex;align-items:center;gap:12px;padding:13px 16px;border:1.5px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;font-size:.9rem;color:var(--heading);font-weight:500;background:var(--bg)}
.brief-opt:hover{border-color:var(--orange);background:var(--orange-light)}
.brief-opt.selected{border-color:var(--orange);background:var(--orange-light)}
.brief-opt-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;transition:all .2s;position:relative}
.brief-opt.selected .brief-opt-radio{border-color:var(--orange);background:var(--orange)}
.brief-opt.selected .brief-opt-radio::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:7px;height:7px;border-radius:50%;background:#fff}
.brief-textarea{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;font-size:.9rem;color:var(--heading);font-family:inherit;outline:none;resize:vertical;min-height:90px;transition:border-color var(--t);box-sizing:border-box}
.brief-textarea:focus{border-color:var(--orange)}
.brief-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:11px 14px;font-size:.9rem;color:var(--heading);font-family:inherit;outline:none;transition:border-color var(--t);box-sizing:border-box}
.brief-input:focus{border-color:var(--orange)}
.brief-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;gap:12px}
.brief-nav-back{font-size:.84rem;color:var(--muted);border:none;background:none;cursor:pointer;padding:0;font-family:inherit;transition:color var(--t)}
.brief-nav-back:hover{color:var(--heading)}
.brief-skip{font-size:.8rem;color:var(--muted);text-decoration:underline;cursor:pointer;border:none;background:none;font-family:inherit}
.brief-success{text-align:center;padding:20px 0}
.brief-success-icon{font-size:3.5rem;margin-bottom:16px}
.brief-success-title{font-size:1.5rem;font-weight:800;color:var(--heading);margin-bottom:10px}
.brief-success-sub{color:var(--muted);line-height:1.65;max-width:400px;margin:0 auto}

/* ─────────────────────────────────────────────────────────
   PREMIUM DESIGN-SYSTEM UPGRADE (v3)
   Inspired by modern SaaS dark/light hybrid pages.
   Refines: typography rhythm, cards, buttons, dark sections,
   hover states, mobile-first refinements.
   Loaded last so it overrides legacy rules.
   ───────────────────────────────────────────────────────── */

:root {
  --hero-dark: #0E0D0B;
  --hero-dark-2: #1A1614;
  --ring-orange: 0 0 0 1px rgba(232,68,0,0.35), 0 8px 24px -10px rgba(232,68,0,0.55);
  --ring-soft: 0 0 0 1px rgba(0,0,0,0.06), 0 12px 40px -16px rgba(14,13,11,0.18);
  --grad-orange: linear-gradient(180deg, #FF5A1A 0%, #E84400 100%);
  --grad-orange-soft: linear-gradient(180deg, #FFF3EE 0%, #FFE3D2 100%);
  --grad-text-orange: linear-gradient(95deg, #E84400 0%, #FF7A2E 50%, #FFB266 100%);
}

/* ── Body typography & rendering refinements ── */
body {
  font-feature-settings: "ss01","ss02","cv01","cv02";
  text-rendering: optimizeLegibility;
}
h1,h2,h3,h4 { text-wrap: balance; }
p { text-wrap: pretty; }

/* Section header rhythm */
.section-header { margin-bottom: clamp(32px, 5vw, 56px); text-align: center; }
.section-header h2 { margin-top: 14px; }
.section-header p { margin: 16px auto 0; max-width: 60ch; color: var(--muted); font-size: clamp(.98rem, 1.6vw, 1.1rem); }

/* ── Premium card upgrade ── */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(20px, 3vw, 28px);
  transition:
    transform .35s cubic-bezier(.4,0,.2,1),
    box-shadow .35s cubic-bezier(.4,0,.2,1),
    border-color .25s ease;
  box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, var(--ring-soft);
  position: relative;
}
.card:hover {
  transform: translateY(-3px);
  border-color: var(--border-orange);
  box-shadow: 0 1px 0 rgba(255,255,255,0.7) inset, 0 0 0 1px rgba(232,68,0,0.18), 0 22px 50px -22px rgba(14,13,11,0.22);
}

/* ── Premium button refinements (light theme primary) ── */
.btn { transition: transform .25s cubic-bezier(.4,0,.2,1), box-shadow .25s, background .2s, color .2s; min-height: 44px; }
.btn-primary {
  background: var(--grad-orange);
  color: #fff;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 8px 22px -6px rgba(232,68,0,0.45);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.28) inset,
    0 14px 32px -8px rgba(232,68,0,0.6);
}
.btn-ghost {
  background: transparent;
  color: var(--heading);
  border: 1px solid var(--border-strong);
}
.btn-ghost:hover {
  background: var(--bg2);
  border-color: var(--orange);
  color: var(--orange);
  transform: translateY(-2px);
}
.btn-lg { min-height: 52px; padding: 0 26px; font-size: 1rem; }

/* ── Badge refinement ── */
.badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .8rem; font-weight: 600;
  padding: 7px 14px; border-radius: 999px;
  letter-spacing: -.005em;
  border: 1px solid transparent;
}
.badge-orange {
  background: var(--orange-light);
  color: var(--orange);
  border-color: var(--border-orange);
}
.badge-white {
  background: var(--card);
  color: var(--muted2);
  border-color: var(--border);
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

/* ── Dark section utility (for visual rhythm) ── */
.section-dark {
  background: var(--hero-dark);
  color: #fff;
  position: relative;
  isolation: isolate;
}
.section-dark::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(60% 50% at 80% 0%, rgba(232,68,0,0.18), transparent 60%),
    radial-gradient(45% 40% at 0% 100%, rgba(232,68,0,0.10), transparent 60%);
  pointer-events: none; z-index: -1;
}
.section-dark h2, .section-dark h3, .section-dark h4 { color: #fff; }
.section-dark p, .section-dark .lead { color: rgba(255,255,255,0.7); }
.section-dark .badge-white {
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.78);
  border-color: rgba(255,255,255,0.10);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
.section-dark .card {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.10);
  color: #fff;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset;
}
.section-dark .card:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(232,68,0,0.45);
  box-shadow: 0 1px 0 rgba(255,255,255,0.10) inset, 0 22px 50px -22px rgba(0,0,0,0.5), 0 0 0 1px rgba(232,68,0,0.25);
}
.section-dark .card p { color: rgba(255,255,255,0.65); }

/* Process steps inside dark section */
.section-dark .process-step h3 { color: #fff; }
.section-dark .process-step p { color: rgba(255,255,255,0.65); }
.section-dark .process-num-wrap {
  background: rgba(255,255,255,0.06);
  border-color: rgba(232,68,0,0.5);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.02), 0 0 24px rgba(232,68,0,0.18);
}
.section-dark .process-step:hover .process-num-wrap {
  border-color: var(--orange);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.04), 0 0 30px rgba(232,68,0,0.35);
}
.section-dark .process-num { color: #FFB266; }

/* Pillar router cards: inner text colors (orange price line stays, but force white headings/paragraphs) */
.section-dark .card h3 { color: #fff; }
.section-dark .card > p[style*="color:var(--muted)"] { color: rgba(255,255,255,0.65) !important; }

/* ── Container padding tightens on mobile ── */
@media (max-width: 640px) {
  .container { padding: 0 16px; }
  section { padding: 56px 0; }
}
@media (max-width: 420px) {
  .container { padding: 0 14px; }
}

/* ── Make all touch targets at least 44px ── */
a.btn, button.btn, .hero-cta, .nav-cta, .mobile-menu-cta {
  min-height: 44px;
}

/* ── Mobile nav refinements ── */
@media (max-width: 860px) {
  nav { backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
}

/* ── No horizontal scroll guard ── */
html, body { max-width: 100vw; overflow-x: hidden; }
img, video, iframe { max-width: 100%; }

/* ── Refined link underlines in prose ── */
.prose a, p a {
  color: var(--orange);
  text-decoration: underline;
  text-decoration-color: rgba(232,68,0,0.35);
  text-underline-offset: 3px;
  transition: text-decoration-color .2s ease, color .2s ease;
}
.prose a:hover, p a:hover { text-decoration-color: var(--orange); }

/* ── Hero stat hover (subtle lift) ── */
.hero-stat { transition: transform .3s ease, background .2s ease, border-color .2s ease; }
.hero-stat:hover { transform: translateY(-2px); background: rgba(255,255,255,0.07); border-color: rgba(232,68,0,0.35); }

/* ─────────────────────────────────────────────────────────
   NAV — works over BOTH dark hero (default) and light scroll-state
   ───────────────────────────────────────────────────────── */

/* Default (over hero, dark) */
#main-nav,
body > nav {
  background: rgba(14,13,11,0.55) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  backdrop-filter: blur(18px) saturate(1.4);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 1px 0 rgba(255,255,255,0.04);
}
#main-nav .nav-logo-text,
#main-nav .nav-logo-text span { color: #fff; }
#main-nav .nav-logo-icon { background: var(--orange); color: #fff; }
#main-nav .nav-links a {
  color: rgba(255,255,255,0.78) !important;
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
#main-nav .nav-links a:hover { color: #fff !important; background: rgba(255,255,255,0.08) !important; }
/* Dropdown panel — target inner because outer is just a positioning wrapper */
#main-nav .dropdown-menu { background: transparent !important; }
#main-nav .dropdown-menu-inner {
  background: rgba(20,18,16,0.96) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  backdrop-filter: blur(20px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.4) !important;
  box-shadow: 0 24px 50px -16px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.04) !important;
}
#main-nav .dropdown-menu a,
#main-nav .dropdown-menu-inner a { color: rgba(255,255,255,0.82) !important; background: transparent !important; }
#main-nav .dropdown-menu a:hover,
#main-nav .dropdown-menu-inner a:hover { color: #fff !important; background: rgba(232,68,0,0.18) !important; }
#main-nav .nav-cta {
  background: linear-gradient(180deg, #FF5A1A 0%, #E84400 100%) !important;
  color: #fff !important;
  border: 0 !important;
  font-weight: 600 !important;
  letter-spacing: -.005em !important;
  padding: 10px 20px !important;
  border-radius: 10px !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 8px 22px -6px rgba(232,68,0,0.55),
    0 0 0 1px rgba(232,68,0,0.4) !important;
  transition: transform .25s cubic-bezier(.4,0,.2,1), box-shadow .25s !important;
}
#main-nav .nav-cta:hover {
  transform: translateY(-2px) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.28) inset,
    0 14px 32px -8px rgba(232,68,0,0.7),
    0 0 0 1px rgba(232,68,0,0.5) !important;
}
/* Scrolled state on homepage: same orange CTA, just slightly more grounded */
body:not(.page-inner) #main-nav.scrolled .nav-cta {
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 10px 26px -8px rgba(232,68,0,0.6),
    0 0 0 1px rgba(232,68,0,0.5) !important;
}
#main-nav .nav-cart-link { color: rgba(255,255,255,0.78) !important; }
#main-nav .nav-cart-link:hover { color: #fff !important; }
#main-nav .hamburger {
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  border-radius: 10px;
  color: #fff;
  transition: background .2s ease, border-color .2s ease;
}
#main-nav .hamburger:hover { background: rgba(232,68,0,0.14); border-color: rgba(232,68,0,0.5); }
#main-nav .hamburger span { background: #fff !important; }

/* Override legacy `nav:has(.mobile-menu.open)` rule on the dark homepage
   so the nav stays dark when the drawer is open */
body:not(.page-inner) nav:has(.mobile-menu.open) {
  background: rgba(14,13,11,0.97) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) !important;
  border-bottom-color: rgba(255,255,255,0.08) !important;
}
body:not(.page-inner) nav:has(.mobile-menu.open) .nav-logo-text,
body:not(.page-inner) nav:has(.mobile-menu.open) .nav-logo-text span { color: #fff; }
body:not(.page-inner) nav:has(.mobile-menu.open) .hamburger {
  background: rgba(232,68,0,0.14);
  border-color: rgba(232,68,0,0.5);
}

/* Scrolled state on homepage: STAYS dark — overrides legacy nav.scrolled rule
   with maximum specificity (body + id + class) */
html body:not(.page-inner) nav#main-nav.scrolled,
html body:not(.page-inner) > nav.scrolled {
  background: rgba(10,9,8,0.92) !important;
  border-bottom: 1px solid rgba(255,255,255,0.10) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06), 0 8px 32px rgba(0,0,0,0.45) !important;
  backdrop-filter: blur(20px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.4) !important;
}
html body:not(.page-inner) nav#main-nav.scrolled .nav-logo-text,
html body:not(.page-inner) nav#main-nav.scrolled .nav-logo-text span { color: #fff !important; }
html body:not(.page-inner) nav#main-nav.scrolled .nav-links a { color: rgba(255,255,255,0.82) !important; background: transparent !important; }
html body:not(.page-inner) nav#main-nav.scrolled .nav-links a:hover { color: #fff !important; background: rgba(255,255,255,0.08) !important; }
html body:not(.page-inner) nav#main-nav.scrolled .hamburger { background: rgba(255,255,255,0.06) !important; border-color: rgba(255,255,255,0.18) !important; }
html body:not(.page-inner) nav#main-nav.scrolled .hamburger span { background: #fff !important; }
html body:not(.page-inner) nav#main-nav.scrolled .nav-cart-link { color: rgba(255,255,255,0.78) !important; }

/* Inner pages: scrolled state = light glass (existing behaviour) */
body.page-inner #main-nav.scrolled {
  background: rgba(250,250,248,0.85) !important;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 1px 0 rgba(0,0,0,0.06), 0 4px 24px rgba(0,0,0,0.04);
}
body.page-inner #main-nav.scrolled .nav-logo-text { color: var(--heading); }
body.page-inner #main-nav.scrolled .nav-logo-text span { color: var(--orange); }
body.page-inner #main-nav.scrolled .nav-links a { color: var(--muted2) !important; }
body.page-inner #main-nav.scrolled .nav-links a:hover { color: var(--heading) !important; background: var(--bg2) !important; }
body.page-inner #main-nav.scrolled .dropdown-menu {
  background: #fff !important;
  border: 1px solid var(--border) !important;
}
body.page-inner #main-nav.scrolled .dropdown-menu a { color: var(--text) !important; }
body.page-inner #main-nav.scrolled .dropdown-menu a:hover { color: var(--orange) !important; background: var(--orange-light) !important; }
body.page-inner #main-nav.scrolled .nav-cart-link { color: var(--muted2) !important; }
body.page-inner #main-nav.scrolled .nav-cart-link:hover { color: var(--heading) !important; }
body.page-inner #main-nav.scrolled .hamburger { color: var(--heading); border-color: var(--border); background: var(--bg2); }
body.page-inner #main-nav.scrolled .hamburger span { background: var(--heading); }

/* Pages OTHER than homepage (which have .page-inner on body) — keep light always */
body.page-inner > nav,
body.page-inner #main-nav {
  background: rgba(250,250,248,0.85) !important;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
body.page-inner #main-nav .nav-logo-text { color: var(--heading); }
body.page-inner #main-nav .nav-logo-text span { color: var(--orange); }
body.page-inner #main-nav .nav-links a { color: var(--muted2) !important; background: transparent !important; }
body.page-inner #main-nav .nav-links a:hover { color: var(--heading) !important; background: var(--bg2) !important; }
body.page-inner #main-nav .dropdown-menu { background: #fff !important; border: 1px solid var(--border) !important; }
body.page-inner #main-nav .dropdown-menu a { color: var(--text) !important; }
body.page-inner #main-nav .nav-cart-link { color: var(--muted2) !important; }
body.page-inner #main-nav .hamburger { color: var(--heading); border-color: var(--border); background: var(--bg2); }
body.page-inner #main-nav .hamburger span { background: var(--heading); }

/* Mobile menu panel — readable on both states */
#main-nav .mobile-menu {
  background: rgba(14,13,11,0.97) !important;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  color: #fff;
  border-top: 1px solid rgba(255,255,255,0.08);
}
#main-nav .mobile-menu > a,
#main-nav .mobile-menu-ydelser a {
  color: rgba(255,255,255,0.85) !important;
  border-bottom-color: rgba(255,255,255,0.06) !important;
}
#main-nav .mobile-menu > a:hover,
#main-nav .mobile-menu-ydelser a:hover {
  color: #fff !important;
  background: rgba(232,68,0,0.12) !important;
}
#main-nav .mobile-menu-cat {
  color: rgba(255,255,255,0.45) !important;
  border-bottom-color: rgba(255,255,255,0.08) !important;
}
#main-nav .mobile-menu-ydelser a:nth-child(odd) {
  border-right-color: rgba(255,255,255,0.06) !important;
}
#main-nav .mobile-menu-cta {
  background: var(--grad-orange) !important;
  color: #fff !important;
}

/* On scrolled state with mobile menu open, still keep dark drawer for legibility */
body.page-inner #main-nav .mobile-menu {
  background: rgba(14,13,11,0.97) !important;
  color: #fff;
}

/* ─────────────────────────────────────────────────────────
   COUNT-UP ANIMATION — used on stats and KPI numbers
   ───────────────────────────────────────────────────────── */
.count-up {
  font-variant-numeric: tabular-nums;
  display: inline-block;
}
.count-up:not(.counted) { opacity: 0.9; }
.count-up.counted { opacity: 1; }

/* ─────────────────────────────────────────────────────────
   GLOBAL HEADING ACCENT — every .section-header h2 > span
   now picks up the brand gradient clip
   ───────────────────────────────────────────────────────── */
.section-header h2 span,
h2 .accent-grad {
  background: var(--grad-text-orange);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  padding-bottom: 0.05em;
  display: inline-block;
}

/* ─────────────────────────────────────────────────────────
   KPI BAND — animated stat row (light theme)
   ───────────────────────────────────────────────────────── */
.kpi-band {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin: clamp(28px, 4vw, 44px) auto 0;
  max-width: 1000px;
}
@media (min-width: 720px) { .kpi-band { grid-template-columns: repeat(4, 1fr); gap: 16px; } }
.kpi-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: clamp(20px, 3vw, 28px) clamp(16px, 2.5vw, 24px);
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform .3s ease, border-color .25s ease, box-shadow .3s ease;
  box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, var(--ring-soft);
}
.kpi-card:hover {
  transform: translateY(-3px);
  border-color: var(--border-orange);
  box-shadow: 0 1px 0 rgba(255,255,255,0.7) inset, 0 0 0 1px rgba(232,68,0,0.18), 0 22px 50px -22px rgba(14,13,11,0.22);
}
.kpi-card::after {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--grad-orange);
  opacity: 0;
  transition: opacity .25s ease;
}
.kpi-card:hover::after { opacity: 1; }
.kpi-num {
  display: block;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  letter-spacing: -.035em;
  line-height: 1.05;
  color: var(--heading);
}
.kpi-num .num-accent {
  background: var(--grad-text-orange);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.kpi-label {
  display: block;
  margin-top: 10px;
  font-size: clamp(.78rem, 1.4vw, .9rem);
  color: var(--muted);
  line-height: 1.4;
  text-wrap: balance;
}

/* KPI band variant on dark sections */
.section-dark .kpi-card {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.10);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset;
}
.section-dark .kpi-num { color: #fff; }
.section-dark .kpi-label { color: rgba(255,255,255,0.6); }

/* ─────────────────────────────────────────────────────────
   HOMEPAGE GLOBAL DARK THEME
   Scoped to homepage only (body without .page-inner class).
   Every section inherits the dark hero aesthetic with
   subtle gradient blobs varied per-section for rhythm.
   ───────────────────────────────────────────────────────── */

body:not(.page-inner) {
  background: #0E0D0B;
  color: rgba(255,255,255,0.78);
}
body:not(.page-inner) main { background: #0E0D0B; }

/* Every section: transparent bg so the body color shows through,
   plus a subtle radial orange glow positioned differently per section */
body:not(.page-inner) section {
  background: transparent !important;
  color: rgba(255,255,255,0.78);
  position: relative;
  border-color: rgba(255,255,255,0.06) !important;
}
body:not(.page-inner) section > * { position: relative; z-index: 2; }
body:not(.page-inner) section:not(.hero):not(.section-dark)::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(45% 35% at 85% 10%, rgba(232,68,0,0.08), transparent 65%),
    radial-gradient(35% 30% at 8% 85%, rgba(232,68,0,0.05), transparent 65%);
}
/* Alternate blob positions for visual rhythm */
body:not(.page-inner) section:not(.hero):nth-of-type(even)::before {
  background:
    radial-gradient(45% 35% at 12% 12%, rgba(232,68,0,0.07), transparent 65%),
    radial-gradient(35% 30% at 90% 88%, rgba(255,140,60,0.05), transparent 65%);
}

/* Subtle section divider */
body:not(.page-inner) section + section {
  border-top: 1px solid rgba(255,255,255,0.05);
}

/* Typography on dark */
body:not(.page-inner) h1,
body:not(.page-inner) h2,
body:not(.page-inner) h3,
body:not(.page-inner) h4 { color: #fff; }
body:not(.page-inner) p { color: rgba(255,255,255,0.65); }
body:not(.page-inner) .lead { color: rgba(255,255,255,0.72); }
body:not(.page-inner) .section-header p { color: rgba(255,255,255,0.6); }

/* Inline-styled text in some sections (override grey colors) */
body:not(.page-inner) section [style*="color:var(--muted)"],
body:not(.page-inner) section [style*="color: var(--muted)"] {
  color: rgba(255,255,255,0.62) !important;
}
body:not(.page-inner) section [style*="color:var(--heading)"],
body:not(.page-inner) section [style*="color: var(--heading)"] {
  color: #fff !important;
}

/* Cards on dark — glass treatment */
body:not(.page-inner) .card {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.10) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 12px 30px -16px rgba(0,0,0,0.5);
}
body:not(.page-inner) .card h3,
body:not(.page-inner) .card h4 { color: #fff; }
body:not(.page-inner) .card p { color: rgba(255,255,255,0.65) !important; }
body:not(.page-inner) .card:hover {
  border-color: rgba(232,68,0,0.40) !important;
  background: rgba(255,255,255,0.06) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,0.10) inset, 0 22px 50px -22px rgba(0,0,0,0.6), 0 0 0 1px rgba(232,68,0,0.25);
}

/* Badges */
body:not(.page-inner) .badge-white {
  background: rgba(255,255,255,0.06) !important;
  color: rgba(255,255,255,0.82) !important;
  border-color: rgba(255,255,255,0.12) !important;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
body:not(.page-inner) .badge-orange {
  background: rgba(232,68,0,0.12) !important;
  color: #FFB266 !important;
  border-color: rgba(232,68,0,0.35) !important;
}
body:not(.page-inner) .badge-dark {
  background: rgba(255,255,255,0.08) !important;
  color: #fff !important;
  border-color: rgba(255,255,255,0.15) !important;
}

/* FAQ on dark */
body:not(.page-inner) .faq-item,
body:not(.page-inner) .faq-list .faq-item {
  background: rgba(255,255,255,0.03) !important;
  border-color: rgba(255,255,255,0.08) !important;
}
body:not(.page-inner) .faq-q { color: #fff !important; }
body:not(.page-inner) .faq-a,
body:not(.page-inner) .faq-a-inner { color: rgba(255,255,255,0.7) !important; }
body:not(.page-inner) .faq-icon { color: #FFB266 !important; }

/* Process steps on dark (no .section-dark wrapper needed now) */
body:not(.page-inner) .process-step h3 { color: #fff; }
body:not(.page-inner) .process-step p { color: rgba(255,255,255,0.65); }
body:not(.page-inner) .process-num-wrap {
  background: rgba(255,255,255,0.06);
  border-color: rgba(232,68,0,0.5);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.02), 0 0 24px rgba(232,68,0,0.18);
}
body:not(.page-inner) .process-num { color: #FFB266; }

/* SEO block at footer */
body:not(.page-inner) .seo-block {
  background: rgba(255,255,255,0.02) !important;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
body:not(.page-inner) .seo-block h3 { color: #fff; }
body:not(.page-inner) .seo-block p { color: rgba(255,255,255,0.7) !important; }
body:not(.page-inner) .seo-block .internal-links a {
  color: #FFB266 !important;
  border-color: rgba(232,68,0,0.35) !important;
}

/* Calculator wizard card — KEEP LIGHT for legibility (white card on dark bg) */
body:not(.page-inner) .calc-section .wiz-card {
  background: #FAFAF8 !important;
  color: var(--text);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.05) inset,
    0 30px 60px -20px rgba(0,0,0,0.5),
    0 0 0 1px rgba(232,68,0,0.18);
}
body:not(.page-inner) .calc-section .wiz-card h1,
body:not(.page-inner) .calc-section .wiz-card h2,
body:not(.page-inner) .calc-section .wiz-card h3,
body:not(.page-inner) .calc-section .wiz-card h4 { color: var(--heading); }
body:not(.page-inner) .calc-section .wiz-card p { color: var(--muted); }
body:not(.page-inner) .calc-section .wiz-card label,
body:not(.page-inner) .calc-section .wiz-card span:not(.num-accent) { color: var(--text); }

/* KPI band still legible */
body:not(.page-inner) .kpi-card {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.10);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset;
}
body:not(.page-inner) .kpi-num { color: #fff; }
body:not(.page-inner) .kpi-label { color: rgba(255,255,255,0.6); }

/* Partner section bg + profile card */
body:not(.page-inner) .partner-section-bg {
  background: transparent !important;
}
body:not(.page-inner) .partner-section-bg [style*="background:var(--card)"] {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.10) !important;
}

/* Inline-styled white / --card cards inside dark homepage — flip to glass */
body:not(.page-inner) [style*="background:#fff"],
body:not(.page-inner) [style*="background: #fff"],
body:not(.page-inner) [style*="background:#FFFFFF"],
body:not(.page-inner) [style*="background: #FFFFFF"],
body:not(.page-inner) [style*="background:var(--card)"],
body:not(.page-inner) [style*="background: var(--card)"] {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.10) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 12px 30px -16px rgba(0,0,0,0.5);
}
/* Force inline-styled small grey/dark labels inside these flipped cards to readable colors */
body:not(.page-inner) [style*="background:#fff"] [style*="color:var(--muted)"],
body:not(.page-inner) [style*="background: #fff"] [style*="color:var(--muted)"] {
  color: rgba(255,255,255,0.65) !important;
}
body:not(.page-inner) [style*="background:#fff"] [style*="color:var(--muted2)"],
body:not(.page-inner) [style*="background: #fff"] [style*="color:var(--muted2)"] {
  color: rgba(255,255,255,0.55) !important;
}
/* The green "✓" checkmark stays green — high contrast already */
body:not(.page-inner) [style*="background:#fff"] [style*="color:var(--green)"] {
  color: #4ADE80 !important;
}

/* Btn-ghost legibility on dark */
body:not(.page-inner) .btn-ghost {
  background: rgba(255,255,255,0.04);
  color: #fff;
  border-color: rgba(255,255,255,0.18);
}
body:not(.page-inner) .btn-ghost:hover {
  background: rgba(232,68,0,0.10);
  border-color: var(--orange);
  color: #fff;
}

/* Process num-wrap halo on dark — kill the white box-shadow ring */
body:not(.page-inner) .process-step:hover .process-num-wrap {
  border-color: var(--orange);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.04), 0 0 30px rgba(232,68,0,0.35);
}

/* ─────────────────────────────────────────────────────────
   SEO PROSE BLOCK — long-form keyword content
   ───────────────────────────────────────────────────────── */
.seo-prose-section { padding: clamp(56px, 8vw, 96px) 0; }
.seo-prose {
  max-width: 760px;
  margin: 0 auto;
}
.seo-prose .badge { margin-bottom: 18px; }
.seo-prose h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 18px;
  line-height: 1.1;
  letter-spacing: -.03em;
}
.seo-prose h2 span {
  background: var(--grad-text-orange);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  padding-bottom: 0.05em;
}
.seo-prose .lead {
  font-size: clamp(1.05rem, 1.8vw, 1.2rem);
  line-height: 1.7;
  margin-bottom: 32px;
}
.seo-prose h3 {
  font-size: clamp(1.15rem, 2vw, 1.4rem);
  margin: 36px 0 12px;
  letter-spacing: -.02em;
}
.seo-prose p {
  margin-bottom: 18px;
  line-height: 1.8;
  font-size: 1rem;
}
.seo-prose a {
  color: #FFB266;
  text-decoration: underline;
  text-decoration-color: rgba(255,178,102,0.35);
  text-underline-offset: 3px;
  transition: text-decoration-color .2s ease, color .2s ease;
}
.seo-prose a:hover { color: #fff; text-decoration-color: #FFB266; }
.seo-prose strong { color: #fff; font-weight: 600; }

/* ─────────────────────────────────────────────────────────
   FOUNDER CARD (replaces React profile-card)
   ───────────────────────────────────────────────────────── */
.founder-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(36px, 6vw, 64px);
  align-items: center;
}
@media (min-width: 880px) {
  .founder-grid { grid-template-columns: minmax(0,1.1fr) minmax(0,0.9fr); }
}
.founder-actions { display: flex; flex-wrap: wrap; gap: 12px; }

.founder-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 24px;
  padding: 8px 8px 24px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 30px 60px -20px rgba(0,0,0,0.55);
  overflow: hidden;
  transition: transform .35s cubic-bezier(.4,0,.2,1), border-color .25s ease;
}
.founder-card:hover { transform: translateY(-4px); border-color: rgba(232,68,0,0.45); }
.founder-card::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(60% 40% at 50% 0%, rgba(232,68,0,0.30), transparent 70%),
    radial-gradient(40% 30% at 0% 100%, rgba(232,68,0,0.10), transparent 65%);
  pointer-events: none;
  z-index: 0;
}
.founder-card > * { position: relative; z-index: 1; }

.founder-card-img-wrap {
  position: relative;
  border-radius: 18px;
  padding: 6px;
  background: linear-gradient(135deg, rgba(232,68,0,0.55), rgba(255,255,255,0.05) 50%, rgba(232,68,0,0.30));
  margin-bottom: 18px;
}
.founder-card-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 14px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.founder-card-meta { padding: 0 16px; text-align: left; }
.founder-card-name {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.3rem, 2.2vw, 1.6rem);
  color: #fff;
  letter-spacing: -.025em;
  margin-bottom: 4px;
}
.founder-card-role { font-size: .9rem; color: rgba(255,255,255,0.65); margin-bottom: 16px; }

.founder-card-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 18px; }
.founder-tag {
  display: inline-flex; align-items: center;
  font-size: .76rem;
  color: rgba(255,255,255,0.78);
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
}

.founder-card-contact {
  display: flex; flex-direction: column; gap: 8px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.founder-contact-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .88rem;
  color: rgba(255,255,255,0.85);
  font-weight: 500;
  transition: color .2s ease;
  text-decoration: none;
}
.founder-contact-link:hover { color: #FFB266; }
.founder-contact-link span { color: #FFB266; }

/* ─────────────────────────────────────────────────────────
   PREMIUM CARD UPGRADES — Why-Us, Pillar Router, etc.
   Add gradient icon containers + top accent line on hover
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .card {
  position: relative;
  overflow: hidden;
}
body:not(.page-inner) .card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-orange);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .4s cubic-bezier(.4,0,.2,1);
  z-index: 2;
}
body:not(.page-inner) .card:hover::before { transform: scaleX(1); }

/* Card icon — wrap in gradient orb */
body:not(.page-inner) .card .card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  font-size: 1.6rem !important;
  margin-bottom: 18px !important;
  background: linear-gradient(135deg, rgba(232,68,0,0.25), rgba(232,68,0,0.06));
  border: 1px solid rgba(232,68,0,0.35);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.04) inset, 0 8px 24px -10px rgba(232,68,0,0.5);
  position: relative;
}

/* Card hover — slight inner glow tint */
body:not(.page-inner) .card:hover {
  background: rgba(232,68,0,0.06) !important;
  border-color: rgba(232,68,0,0.4) !important;
}

/* Pillar router pricing line — keep orange */
body:not(.page-inner) .card p[style*="color:var(--orange)"] {
  color: #FFB266 !important;
  font-weight: 700;
}

/* ─────────────────────────────────────────────────────────
   FAQ UPGRADE — premium accordion
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .faq-list { display: flex; flex-direction: column; gap: 10px; }
body:not(.page-inner) .faq-item {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 14px !important;
  overflow: hidden;
  transition: border-color .25s ease, background .25s ease;
}
body:not(.page-inner) .faq-item:hover {
  border-color: rgba(232,68,0,0.30) !important;
  background: rgba(255,255,255,0.05) !important;
}
body:not(.page-inner) .faq-q {
  padding: 18px 22px !important;
  font-size: clamp(.95rem, 1.6vw, 1.05rem);
  font-weight: 600;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  width: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
}
body:not(.page-inner) .faq-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: 8px;
  background: rgba(232,68,0,0.15);
  border: 1px solid rgba(232,68,0,0.35);
  color: #FFB266 !important;
  font-weight: 600;
  font-size: 1rem;
  flex-shrink: 0;
  transition: transform .3s cubic-bezier(.4,0,.2,1);
}
body:not(.page-inner) .faq-item.open .faq-icon { transform: rotate(45deg); }
body:not(.page-inner) .faq-a-inner {
  padding: 0 22px 20px !important;
  line-height: 1.7;
}

/* ─────────────────────────────────────────────────────────
   PRICING CARDS UPGRADE — highlight middle tier
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .price-card,
body:not(.page-inner) [class*="pricing-card"],
body:not(.page-inner) .grid-3 > .card {
  position: relative;
}
body:not(.page-inner) .price-card.featured,
body:not(.page-inner) [class*="pricing"] .featured {
  border-color: rgba(232,68,0,0.5) !important;
  background: linear-gradient(180deg, rgba(232,68,0,0.10), rgba(255,255,255,0.04)) !important;
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -20px rgba(232,68,0,0.35), 0 0 0 1px rgba(232,68,0,0.4);
}
body:not(.page-inner) .price-card.featured::after,
body:not(.page-inner) [class*="pricing"] .featured::after {
  content: "Mest populær";
  position: absolute;
  top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--grad-orange);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 999px;
  box-shadow: 0 6px 16px -4px rgba(232,68,0,0.5);
}

/* ─────────────────────────────────────────────────────────
   BLOG TEASER CARDS — premium hover
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .blog-teaser-card,
body:not(.page-inner) section[class*="blog"] .card {
  transition: transform .35s cubic-bezier(.4,0,.2,1), border-color .25s ease, background .25s ease;
}
body:not(.page-inner) section[class*="blog"] .card:hover,
body:not(.page-inner) .blog-teaser-card:hover {
  transform: translateY(-4px);
}

/* ─────────────────────────────────────────────────────────
   CASE STUDY CARDS — make screenshots pop on dark
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .case-site-mockup {
  border-radius: 14px !important;
  overflow: hidden;
  box-shadow: 0 30px 70px -20px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.08) !important;
}
body:not(.page-inner) .case-site-mockup .mockup-img {
  background: #f5f5f5 !important; /* keep image bg clean */
}
body:not(.page-inner) .case-site-mockup .mockup-bar {
  background: rgba(20,18,16,0.85) !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}
body:not(.page-inner) .case-site-mockup .mockup-url {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.10) !important;
  color: rgba(255,255,255,0.7) !important;
}
/* Case avatar gets a brighter ring on dark */
body:not(.page-inner) [style*="border:2px solid var(--orange)"] {
  border-color: #FFB266 !important;
  box-shadow: 0 0 0 4px rgba(232,68,0,0.15) !important;
}
/* Case blockquote on dark */
body:not(.page-inner) blockquote[style*="color:var(--text)"] {
  color: rgba(255,255,255,0.85) !important;
  border-left-color: #FFB266 !important;
}

/* ─────────────────────────────────────────────────────────
   PROCESS STEPS — make number orbs pop with gradient + glow
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .process-num-wrap {
  background: linear-gradient(135deg, rgba(232,68,0,0.25), rgba(232,68,0,0.05)) !important;
  border: 1px solid rgba(232,68,0,0.5) !important;
  box-shadow: 0 0 0 6px rgba(255,255,255,0.02), 0 12px 28px -6px rgba(232,68,0,0.35) !important;
  position: relative;
}
body:not(.page-inner) .process-num-wrap::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(232,68,0,0.55), transparent 60%);
  z-index: -1;
  filter: blur(8px);
  opacity: 0.6;
}
body:not(.page-inner) .process-num {
  font-size: 1.4rem !important;
  background: var(--grad-text-orange);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent !important;
  font-weight: 800 !important;
}

/* ─────────────────────────────────────────────────────────
   SECTION HEADER BADGE — uniform premium pill
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .section-header .badge {
  margin-bottom: 14px;
  padding: 6px 14px;
}

/* ─────────────────────────────────────────────────────────
   KILL legacy partner-section-bg that fights the dark theme
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .partner-section-bg {
  background: transparent !important;
  position: relative;
}
body:not(.page-inner) .partner-section-bg::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(50% 40% at 50% 0%, rgba(232,68,0,0.10), transparent 70%),
    radial-gradient(40% 30% at 0% 100%, rgba(232,68,0,0.08), transparent 65%);
}
body:not(.page-inner) .partner-section-bg > * { position: relative; z-index: 1; }
body:not(.page-inner) .partner-section-bg h2 span { background: var(--grad-text-orange); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ─────────────────────────────────────────────────────────
   PILLAR ROUTER (Hvad kan vi bygge for dig?) — premium cards
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .section-dark .grid-3 > a.card {
  padding: clamp(28px, 3.5vw, 40px) !important;
  border-radius: 22px !important;
  position: relative;
  transition: transform .4s cubic-bezier(.4,0,.2,1), border-color .25s ease, background .25s ease;
}
body:not(.page-inner) .section-dark .grid-3 > a.card:hover {
  transform: translateY(-8px);
}
body:not(.page-inner) .section-dark .grid-3 > a.card .card-icon {
  font-size: 2.2rem !important;
  width: 64px;
  height: 64px;
  border-radius: 18px;
}
body:not(.page-inner) .section-dark .grid-3 > a.card h3 {
  font-size: clamp(1.15rem, 2vw, 1.4rem) !important;
  margin-bottom: 12px !important;
}
body:not(.page-inner) .section-dark .grid-3 > a.card p[style*="margin: 12px"],
body:not(.page-inner) .section-dark .grid-3 > a.card p[style*="margin:12px"] {
  font-size: 1.15rem !important;
  color: #FFB266 !important;
  font-family: var(--font-display);
  letter-spacing: -.02em;
}
body:not(.page-inner) .section-dark .grid-3 > a.card .btn {
  margin-top: 14px;
  background: var(--grad-orange) !important;
  color: #fff !important;
  box-shadow: 0 6px 18px -6px rgba(232,68,0,0.5) !important;
  border: 0 !important;
  transform: translateX(0);
  transition: transform .3s ease, box-shadow .3s ease;
}
body:not(.page-inner) .section-dark .grid-3 > a.card:hover .btn {
  transform: translateX(4px);
  box-shadow: 0 10px 24px -6px rgba(232,68,0,0.7) !important;
}

/* ─────────────────────────────────────────────────────────
   "Et digitalt bureau" 4-card USP grid — beefier presence
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .features-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 720px) { body:not(.page-inner) .features-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { body:not(.page-inner) .features-grid { grid-template-columns: repeat(4, 1fr); } }

body:not(.page-inner) .features-grid .card {
  padding: clamp(26px, 3vw, 34px) !important;
  border-radius: 20px !important;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  position: relative;
}
body:not(.page-inner) .features-grid .card::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(160deg, rgba(232,68,0,0.30), rgba(255,255,255,0.06) 40%, transparent);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0.5;
  pointer-events: none;
  transition: opacity .3s ease;
}
body:not(.page-inner) .features-grid .card:hover::after { opacity: 1; }
body:not(.page-inner) .features-grid .card h3 {
  font-size: clamp(1.05rem, 1.7vw, 1.2rem) !important;
  margin-top: 6px !important;
  margin-bottom: 10px !important;
}

/* ─────────────────────────────────────────────────────────
   "Gennemsigtige priser" trust cards — image illustrations
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .card-icon-img {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 84px !important;
  height: 84px !important;
  border-radius: 20px;
  margin-bottom: 22px !important;
  background: linear-gradient(135deg, rgba(232,68,0,0.18), rgba(232,68,0,0.04));
  border: 1px solid rgba(232,68,0,0.30);
  padding: 12px;
  position: relative;
  overflow: hidden;
}
body:not(.page-inner) .card-icon-img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.10), transparent 60%);
  pointer-events: none;
}
body:not(.page-inner) .card-icon-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(232,68,0,0.45));
}
body:not(.page-inner) .card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  color: #FFB266 !important;
  font-weight: 600;
  font-size: .9rem;
  text-decoration: none;
  transition: transform .25s ease, color .2s ease;
}
body:not(.page-inner) .card-link:hover {
  color: #fff !important;
  transform: translateX(4px);
}

/* ─────────────────────────────────────────────────────────
   FOUNDER section refinements — make sure CSS wins
   ───────────────────────────────────────────────────────── */
body:not(.page-inner) .founder-grid {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: clamp(36px, 6vw, 64px);
  align-items: center;
}
@media (min-width: 880px) {
  body:not(.page-inner) .founder-grid { grid-template-columns: minmax(0,1.1fr) minmax(0,0.9fr) !important; }
}
body:not(.page-inner) .founder-actions { display: flex; flex-wrap: wrap; gap: 12px; }
body:not(.page-inner) .founder-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 24px;
  padding: 8px 8px 28px;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 30px 60px -20px rgba(0,0,0,0.6) !important;
  overflow: hidden;
  max-width: 420px;
  margin: 0 auto;
  width: 100%;
}
body:not(.page-inner) .founder-card::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(70% 40% at 50% 0%, rgba(232,68,0,0.32), transparent 70%),
    radial-gradient(40% 30% at 0% 100%, rgba(232,68,0,0.12), transparent 65%);
  pointer-events: none; z-index: 0;
}
body:not(.page-inner) .founder-card > * { position: relative; z-index: 1; }

/* ─────────────────────────────────────────────────────────
   INLINE CTA BAND — strategic conversion stops
   ───────────────────────────────────────────────────────── */
.cta-band {
  margin: clamp(48px, 8vw, 88px) auto;
  max-width: 920px;
  padding: clamp(28px, 4vw, 44px);
  border-radius: 24px;
  background:
    radial-gradient(60% 80% at 80% 50%, rgba(232,68,0,0.28), transparent 70%),
    rgba(255,255,255,0.03);
  border: 1px solid rgba(232,68,0,0.30);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 30px 70px -20px rgba(0,0,0,0.55), 0 0 0 1px rgba(232,68,0,0.15);
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
@media (min-width: 720px) { .cta-band { grid-template-columns: 1.2fr auto; gap: 28px; } }
.cta-band::before {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 24px 24px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
  opacity: 0.4;
  pointer-events: none;
}
.cta-band > * { position: relative; z-index: 1; }
.cta-band h3 {
  font-size: clamp(1.3rem, 2.5vw, 1.9rem);
  color: #fff;
  margin-bottom: 6px;
  letter-spacing: -.025em;
}
.cta-band h3 span {
  background: var(--grad-text-orange);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.cta-band p {
  color: rgba(255,255,255,0.7);
  margin: 0;
  font-size: clamp(.92rem, 1.5vw, 1rem);
}
.cta-band-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.cta-band .btn-primary {
  background: var(--grad-orange) !important;
  color: #fff !important;
  border: 0 !important;
  font-weight: 600 !important;
  padding: 14px 26px !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 0 rgba(255,255,255,0.22) inset, 0 12px 30px -10px rgba(232,68,0,0.7), 0 0 0 1px rgba(232,68,0,0.4) !important;
  font-size: 1rem !important;
}

/* ─────────────────────────────────────────────────────────
   TIER-CARD GRID — Hvad kan vi bygge for dig? (pricing-table style)
   ───────────────────────────────────────────────────────── */
.tier-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: clamp(32px, 5vw, 56px);
  align-items: stretch;
}
@media (min-width: 720px) { .tier-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; } }
@media (min-width: 1080px) { .tier-grid { grid-template-columns: repeat(3, 1fr); gap: 24px; } }

.tier-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: clamp(28px, 3.2vw, 38px) clamp(24px, 2.8vw, 32px);
  border-radius: 22px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 20px 50px -22px rgba(0,0,0,0.55);
  transition: transform .4s cubic-bezier(.4,0,.2,1), border-color .25s ease, background .25s ease;
  overflow: hidden;
}
.tier-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(50% 40% at 50% 0%, rgba(232,68,0,0.12), transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.tier-card > * { position: relative; z-index: 1; }
.tier-card:hover {
  transform: translateY(-6px);
  border-color: rgba(232,68,0,0.40);
  background: rgba(255,255,255,0.05);
}

/* Featured tier — Webshop */
.tier-card-featured {
  background: linear-gradient(180deg, rgba(232,68,0,0.10), rgba(255,255,255,0.03));
  border-color: rgba(232,68,0,0.50);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.10) inset,
    0 30px 60px -20px rgba(232,68,0,0.40),
    0 0 0 1px rgba(232,68,0,0.30);
}
@media (min-width: 1080px) {
  .tier-card-featured {
    transform: translateY(-12px);
    z-index: 2;
  }
  .tier-card-featured:hover { transform: translateY(-18px); }
}
.tier-card-featured::before {
  background: radial-gradient(60% 50% at 50% 0%, rgba(232,68,0,0.30), transparent 70%);
}
.tier-ribbon {
  position: absolute;
  top: 16px; right: 16px;
  z-index: 3;
  background: var(--grad-orange);
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  box-shadow: 0 6px 16px -4px rgba(232,68,0,0.5);
}

/* Tier head */
.tier-head { margin-bottom: 22px; }
.tier-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(232,68,0,0.30), rgba(232,68,0,0.06));
  border: 1px solid rgba(232,68,0,0.40);
  font-size: 1.6rem;
  margin-bottom: 18px;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05) inset, 0 8px 24px -10px rgba(232,68,0,0.55);
}
.tier-name {
  font-size: clamp(1.4rem, 2.5vw, 1.7rem);
  font-weight: 800;
  letter-spacing: -.03em;
  color: #fff;
  margin: 0 0 4px;
}
.tier-tag { font-size: .85rem; color: rgba(255,255,255,0.55); margin: 0; }

/* Price block */
.tier-price {
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  margin-bottom: 22px;
  text-align: left;
}
.tier-price-from {
  display: block;
  font-size: .78rem;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}
.tier-price-amount {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 3.6vw, 2.6rem);
  font-weight: 800;
  letter-spacing: -.035em;
  line-height: 1.05;
  background: var(--grad-text-orange);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.tier-price-meta {
  display: block;
  margin-top: 6px;
  font-size: .78rem;
  color: rgba(255,255,255,0.50);
}

/* Features list */
.tier-features {
  list-style: none;
  padding: 0;
  margin: 0 0 26px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.tier-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .92rem;
  color: rgba(255,255,255,0.78);
  line-height: 1.5;
  padding-left: 0;
}
.tier-features li::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(232,68,0,0.18);
  border: 1px solid rgba(232,68,0,0.45);
  color: #FFB266;
  font-size: .76rem;
  font-weight: 700;
  margin-top: 1px;
}
.tier-card-featured .tier-features li::before {
  background: rgba(232,68,0,0.30);
  border-color: rgba(232,68,0,0.6);
  color: #fff;
}

/* CTAs */
.tier-cta-wrap { display: flex; flex-direction: column; gap: 10px; margin-top: auto; }
.tier-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 50px;
  padding: 0 24px;
  border-radius: 12px;
  background: rgba(255,255,255,0.06);
  color: #fff;
  font-weight: 600;
  font-size: .98rem;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.14);
  transition: transform .25s ease, background .2s ease, border-color .2s ease, box-shadow .25s ease;
}
.tier-cta:hover {
  background: rgba(232,68,0,0.16);
  border-color: rgba(232,68,0,0.55);
  transform: translateY(-2px);
}
.tier-cta-primary,
.tier-card-featured .tier-cta:first-of-type {
  background: linear-gradient(180deg, #FF5A1A 0%, #E84400 100%);
  border: 0;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 10px 26px -8px rgba(232,68,0,0.55),
    0 0 0 1px rgba(232,68,0,0.40);
}
.tier-cta-primary:hover,
.tier-card-featured .tier-cta:first-of-type:hover {
  box-shadow:
    0 1px 0 rgba(255,255,255,0.28) inset,
    0 16px 36px -8px rgba(232,68,0,0.7),
    0 0 0 1px rgba(232,68,0,0.50);
}
.tier-cta-link {
  text-align: center;
  font-size: .85rem;
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  padding: 4px 0;
  transition: color .2s ease;
}
.tier-cta-link:hover { color: #FFB266; }

/* ─────────────────────────────────────────────────────────
   MOBILE POLISH — final pass to match desktop premium
   ───────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  /* Hero spacing tightens */
  .hero { padding: 90px 0 56px; }
  .hero h1 { line-height: 1.08; }
  .hero-sub { font-size: 1rem; margin-top: 18px; }
  .hero-image-wrap { margin-top: 36px; }
  .hero-platforms { gap: 8px 14px; padding-top: 22px; }
  .hero-platforms-label { width: 100%; text-align: center; margin-bottom: 4px; }

  /* Section header on mobile — smaller h2 */
  .section-header h2 { font-size: clamp(1.7rem, 7vw, 2.4rem); }
  .section-header p { font-size: .98rem; }
  .section-header { margin-bottom: clamp(24px, 6vw, 36px); }

  /* Founder grid stacks; card centered */
  .founder-grid { gap: 32px; }
  body:not(.page-inner) .founder-card { max-width: 360px; }
  .founder-actions .btn { flex: 1; min-width: 0; }

  /* Pillar tiers stack with featured first */
  .tier-card-featured { order: -1; }

  /* CTA bands — tighter padding */
  .cta-band { padding: 24px; border-radius: 18px; }
  .cta-band h3 { font-size: 1.4rem; }
  .cta-band .btn-primary { width: 100%; padding: 14px 20px !important; }
  .cta-band-actions { width: 100%; }
  .cta-band-actions .btn { width: 100%; }

  /* SEO prose — readable line length */
  .seo-prose h2 { font-size: clamp(1.7rem, 6.5vw, 2.4rem); }
  .seo-prose .lead { font-size: 1.02rem; }
  .seo-prose h3 { font-size: 1.1rem; margin-top: 28px; }
  .seo-prose p { font-size: .98rem; line-height: 1.75; }

  /* Case study cards stack with reduced padding */
  body:not(.page-inner) .case-site-mockup { margin-top: 20px; }

  /* KPI band stays 2-col */
  .kpi-band { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .kpi-card { padding: 18px 12px; }

  /* Process steps stack */
  body:not(.page-inner) .process-num-wrap { width: 48px; height: 48px; }

  /* Features grid stacks on mobile (already 1-col, but tighten padding) */
  body:not(.page-inner) .features-grid .card { padding: 22px !important; }

  /* Trust cards (Gennemsigtige priser) — keep image orbs */
  body:not(.page-inner) .card-icon-img { width: 72px !important; height: 72px !important; }

  /* FAQ mobile */
  body:not(.page-inner) .faq-q { padding: 16px 18px !important; font-size: .98rem; }
  body:not(.page-inner) .faq-a-inner { padding: 0 18px 18px !important; }

  /* Hero stats: keep 3-col but smaller */
  .hero-stats { gap: 10px; }
  .hero-stat { padding: 18px 10px; }
  .hero-stat-num { font-size: clamp(1rem, 4vw, 1.4rem); white-space: nowrap; }
  .hero-stat-label { font-size: .7rem; margin-top: 8px; }
}
/* Very narrow screens — stack stats so the 15M number breathes */
@media (max-width: 460px) {
  .hero-stats { grid-template-columns: 1fr; gap: 10px; }
  .hero-stat { padding: 18px 20px; text-align: left; display: flex; align-items: baseline; gap: 14px; }
  .hero-stat-num { font-size: 1.5rem; }
  .hero-stat-label { margin-top: 0; flex: 1; }
}

/* ─────────────────────────────────────────────────────────
   COOKIE CONSENT MODAL — full-screen, premium dark glass
   ───────────────────────────────────────────────────────── */
.cookie-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 99999;
  align-items: center;
  justify-content: center;
  padding: 16px;
  opacity: 0;
  transition: opacity .25s ease;
}
.cookie-modal.is-open { opacity: 1; }
.cookie-modal[aria-hidden="false"] { display: flex; }
.cookie-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.72);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.cookie-modal-card {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 540px;
  max-height: calc(100vh - 32px);
  overflow-y: auto;
  padding: clamp(24px, 4vw, 36px);
  border-radius: 22px;
  background: linear-gradient(180deg, #1A1614 0%, #100D0B 100%);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.06) inset,
    0 40px 80px -20px rgba(0,0,0,0.7),
    0 0 0 1px rgba(232,68,0,0.18);
  color: rgba(255,255,255,0.85);
  transform: translateY(12px) scale(.98);
  transition: transform .3s cubic-bezier(.4,0,.2,1);
}
.cookie-modal.is-open .cookie-modal-card { transform: translateY(0) scale(1); }
.cookie-modal-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(60% 50% at 50% 0%, rgba(232,68,0,0.16), transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.cookie-modal-card > * { position: relative; z-index: 1; }

.cookie-modal-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.cookie-modal-emoji {
  font-size: 1.8rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(232,68,0,0.30), rgba(232,68,0,0.06));
  border: 1px solid rgba(232,68,0,0.40);
  box-shadow: 0 8px 24px -10px rgba(232,68,0,0.5);
}
.cookie-modal-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.4rem, 2.5vw, 1.8rem);
  color: #fff;
  margin: 0;
  letter-spacing: -.03em;
  line-height: 1.1;
}
.cookie-modal-body {
  font-size: .98rem;
  line-height: 1.65;
  color: rgba(255,255,255,0.72);
  margin: 0 0 22px;
}
.cookie-modal-link {
  color: #FFB266;
  text-decoration: underline;
  text-decoration-color: rgba(255,178,102,0.4);
  text-underline-offset: 3px;
}
.cookie-modal-link:hover { color: #fff; }

.cookie-modal-toggles {
  display: flex;
  flex-direction: column;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 22px;
  max-height: 0;
  opacity: 0;
  transform: translateY(-6px);
  transition: max-height .35s ease, opacity .25s ease, transform .25s ease, margin .25s ease;
}
.cookie-modal-toggles.is-visible {
  max-height: 500px;
  opacity: 1;
  transform: translateY(0);
}

.cookie-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
}
.cookie-toggle-row + .cookie-toggle-row { border-top: 1px solid rgba(255,255,255,0.08); }
.cookie-toggle-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.cookie-toggle-name {
  font-size: .92rem;
  font-weight: 600;
  color: #fff;
}
.cookie-toggle-desc {
  font-size: .8rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.45;
}
.cookie-always-on {
  font-size: .72rem;
  font-weight: 700;
  color: #4ADE80;
  background: rgba(74,222,128,0.12);
  border: 1px solid rgba(74,222,128,0.30);
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
  letter-spacing: .02em;
}

.cookie-switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 26px;
  flex-shrink: 0;
}
.cookie-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.cookie-switch-track {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 24px;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease;
}
.cookie-switch-track::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform .2s ease, background .2s ease;
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
.cookie-switch input:checked + .cookie-switch-track {
  background: linear-gradient(180deg, #FF5A1A, #E84400);
  border-color: rgba(232,68,0,0.6);
}
.cookie-switch input:checked + .cookie-switch-track::before { transform: translateX(18px); }
.cookie-switch input:focus-visible + .cookie-switch-track {
  outline: 2px solid #FFB266;
  outline-offset: 2px;
}

/* Datatilsynet 2025 compliant action layout — EQUAL prominence for all choice buttons.
   No "highlighted Accept" — Reject and Accept must look identical. */
.cookie-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 18px;
}
.cookie-modal-actions .cookie-btn:not(.cookie-btn-text) {
  flex: 1 1 140px;
  min-width: 0;
}
.cookie-modal-actions .cookie-btn-text {
  flex: 1 1 100%;
  order: 99;            /* always after the choice buttons */
  text-align: center;
}

.cookie-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 12px;
  font-weight: 600;
  font-size: .92rem;
  cursor: pointer;
  border: 1px solid transparent;
  font-family: inherit;
  transition: background .2s ease, border-color .2s ease, color .2s ease, transform .15s ease;
  white-space: nowrap;
  letter-spacing: -.005em;
}
.cookie-btn:focus-visible { outline: 2px solid #FFB266; outline-offset: 2px; }

/* IDENTICAL styling for Reject / Save / Accept — required for GDPR compliance.
   Single neutral dark-glass treatment with subtle white border. */
.cookie-btn-primary,
.cookie-btn-ghost {
  background: rgba(255,255,255,0.05);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 1px 0 rgba(255,255,255,0.04) inset;
}
.cookie-btn-primary:hover,
.cookie-btn-ghost:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.30);
}
.cookie-btn-primary:active,
.cookie-btn-ghost:active { transform: translateY(1px); }

.cookie-btn-text {
  background: transparent;
  color: rgba(255,255,255,0.55);
  border: none;
  font-weight: 500;
  font-size: .85rem;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(255,255,255,0.20);
  min-height: auto;
  padding: 6px 8px;
}
.cookie-btn-text:hover { color: rgba(255,255,255,0.85); text-decoration-color: rgba(255,255,255,0.45); }

.cookie-modal-foot {
  font-size: .78rem;
  color: rgba(255,255,255,0.50);
  text-align: center;
  margin: 0;
  line-height: 1.55;
}

/* Float button (re-open) — sticky bottom-right, dark glass with orange ring on hover.
   Hidden while the modal is open to avoid stacking. */
.cookie-float-btn {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 9998;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(180deg, #1A1614 0%, #100D0B 100%);
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.06) inset,
    0 10px 24px -8px rgba(0,0,0,0.55),
    0 0 0 1px rgba(232,68,0,0.20);
  transition: transform .25s cubic-bezier(.4,0,.2,1),
              border-color .25s ease,
              box-shadow .25s ease;
}
.cookie-float-btn::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(232,68,0,0.30), transparent 65%);
  z-index: -1;
  opacity: 0;
  filter: blur(8px);
  transition: opacity .25s ease;
}
.cookie-float-btn:hover {
  transform: translateY(-2px) scale(1.06);
  border-color: rgba(232,68,0,0.55);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.10) inset,
    0 14px 32px -8px rgba(232,68,0,0.45),
    0 0 0 1px rgba(232,68,0,0.45);
}
.cookie-float-btn:hover::after { opacity: 1; }
.cookie-float-btn:focus-visible {
  outline: 2px solid #FFB266;
  outline-offset: 4px;
}
.cookie-float-btn svg { width: 22px; height: 22px; }

/* Hide the float button while the modal is open */
.cookie-modal.is-open ~ .cookie-float-btn,
.cookie-modal[aria-hidden="false"] ~ .cookie-float-btn { opacity: 0; pointer-events: none; transform: scale(0.85); }

/* Mobile: nudge button up + smaller, keep clear of system gesture bar */
@media (max-width: 640px) {
  .cookie-float-btn {
    bottom: 16px;
    right: 16px;
    width: 44px;
    height: 44px;
  }
  .cookie-float-btn svg { width: 20px; height: 20px; }
}

/* On phones where a mobile-sticky-cta is present (inner pages), lift the button so it doesn't overlap */
@media (max-width: 860px) {
  body:has(.mobile-sticky-cta) .cookie-float-btn { bottom: 92px; }
}

/* Lock background scroll while modal is open (also enforced via JS) */
html:has(.cookie-modal.is-open) { overflow: hidden; }

/* ── Reduced motion respect ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}

.brief-input-err{border-color:#ef4444!important}

/* ============================================================
   MOBILE OPTIMISATION — WIZARD + CHECKOUT + BRIEF
   ============================================================ */

/* Prevent iOS keyboard zoom — all custom inputs must be ≥ 16px */
.brief-input,.brief-textarea{font-size:16px!important}
#coupon-input{font-size:16px!important;-webkit-text-size-adjust:100%}

/* Wizard — tighten on very small screens */
@media(max-width:400px){
  .wiz-product-grid{grid-template-columns:1fr 1fr;gap:10px}
  .wiz-product-card{padding:18px 10px}
  .wiz-card-icon{font-size:1.6rem}
  .wiz-card-title{font-size:.82rem}
  .wiz-step-labels{font-size:.6rem;letter-spacing:.04em}
}

/* Wizard price bar — sticky bottom on mobile so CTA is always reachable */
@media(max-width:640px){
  .wiz-price-bar{
    position:sticky;bottom:0;
    border-radius:0;
    margin:16px -18px 0;   /* bleed to card edges, flush bottom */
    padding:16px 20px;
    z-index:50;
    box-shadow:0 -4px 20px rgba(0,0,0,.12);
  }
  .wiz-price-amt{font-size:1.5rem}
  .wiz-cta-btn{width:100%;justify-content:center;padding:14px 20px;font-size:1rem}
  .wiz-addon-toggle{min-height:56px}
  .wiz-plan-card{min-height:64px}
}

/* Checkout page — reduce top gap, add room for sticky footer */
@media(max-width:640px){
  .checkout-page{padding:90px 0 100px}

  /* Stack email/phone on small screens */
  .co-email-grid{grid-template-columns:1fr!important;gap:0!important}

  /* Progress labels shorter */
  .co-step>span{font-size:.72rem}
  .co-step-num{width:24px;height:24px;font-size:.7rem}
  .co-connector{width:20px}

  /* Hide sidebar on mobile — order info shown inline */
  .checkout-summary-col{display:none}

  /* Full-width primary buttons */
  #co-form-1 .btn-primary{width:100%;justify-content:center;font-size:1rem;padding:16px}
  #stripe-btn{font-size:1rem;padding:16px}

  /* Coupon section tighter */
  #coupon-section{padding:12px}

  /* Larger tap targets on brief nav */
  .brief-nav-back{min-height:44px;padding:10px 4px}
  .brief-skip{min-height:44px;padding:10px 6px}
}

/* Sticky "Betal sikkert" footer bar — shows only on mobile when step 2 active */
.co-sticky-pay{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  background:var(--bg);border-top:1px solid var(--border);
  padding:12px 20px;z-index:9990;
  box-shadow:0 -4px 20px rgba(0,0,0,.1);
}
@media(max-width:640px){.co-sticky-pay.visible{display:block}}

/* Brief card — always has room for sticky price bar */
@media(max-width:640px){
  .brief-card{overflow:visible}
  .brief-opt{min-height:54px;align-items:center;line-height:1.3}
  .brief-opt-radio{flex-shrink:0}
  .brief-q{font-size:.7rem}
  .brief-section{padding:60px 0 40px}
  /* Full-width next button on brief */
  .brief-nav .btn{width:100%;justify-content:center}
  .brief-nav{flex-direction:column-reverse;gap:8px;align-items:stretch}
  .brief-nav>div{display:flex;flex-direction:column;gap:8px}
}

/* Mobile inline mini-summary inside step 2 */
.co-mini-summary{display:none}
@media(max-width:640px){.co-mini-summary{display:block;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:20px}}
.co-mini-summary-item{display:flex;justify-content:space-between;font-size:.84rem;padding:4px 0;color:var(--heading)}
.co-mini-summary-total{display:flex;justify-content:space-between;font-weight:800;font-size:1rem;padding-top:10px;margin-top:8px;border-top:1px solid var(--border)}
.co-mini-summary-total-price{color:var(--orange)}
