/* ============================================================
   BAHKO BYRÅ — Design System
   Modular premium agency stylesheet
   1. Tokens   2. Reset/base   3. Type   4. Utilities
   6. Progress   7. Preloader   8. Header
   9. Hero    10. Marquee    11. Stats     12. Services
   13. Process 14. Demo       15. Why       16. Audit
   17. CTA     18. Contact    19. Footer    20. Popup
   21. Responsive 22. Reduced-motion
   ============================================================ */

/* ── 1. TOKENS ───────────────────────────────────────────── */
:root{
  /* surfaces — light */
  --cream:#EDE8DF;
  --cream-2:#F4F0E8;
  --cream-3:#FBF8F3;
  /* surfaces — dark */
  --navy:#181C38;
  --navy-2:#12152E;
  --navy-3:#0D1023;
  /* metal */
  --gold:#C9A96E;
  --gold-lt:#E3C88E;
  --gold-dk:#B08F4D;
  /* ink (on cream) */
  --ink:#181C38;
  --ink-70:rgba(24,28,56,.72);
  --ink-55:rgba(24,28,56,.56);
  --ink-35:rgba(24,28,56,.35);
  --line:rgba(201,169,110,.24);
  --line-2:rgba(201,169,110,.72);
  /* paper (on navy) */
  --paper:#F5F2EB;
  --paper-70:rgba(245,242,235,.7);
  --paper-45:rgba(245,242,235,.62);
  --paper-22:rgba(245,242,235,.2);
  --paper-line:rgba(201,169,110,.2);
  /* type */
  --display:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Outfit',system-ui,-apple-system,sans-serif;
  /* rhythm */
  --gut:clamp(1.25rem,5vw,4.5rem);
  --section:clamp(5rem,12vw,12rem);
  --maxw:1280px;
  /* motion */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-io:cubic-bezier(.65,.05,.36,1);
  /* radius */
  --r:3px;
  --r-lg:6px;
}

/* ── 2. RESET / BASE ─────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{
  background:var(--cream);color:var(--ink);
  font-family:var(--sans);font-size:clamp(15px,.55vw + 13px,17px);
  line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  scroll-behavior:auto;
}
body{overflow-x:hidden;min-height:100vh}
/* Lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
img,video,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--gold);color:var(--navy)}

/* ── 3. TYPE ─────────────────────────────────────────────── */
.display{font-family:var(--display);font-weight:500;line-height:1;letter-spacing:-.015em}
em,.it{font-style:italic;font-weight:400}
.eyebrow{
  font-family:var(--sans);font-size:.66rem;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.7rem;color:var(--gold-dk);
}
.eyebrow::before{content:'';width:26px;height:1px;background:var(--gold);display:inline-block}
.eyebrow.center{justify-content:center}
.h2{font-family:var(--display);font-weight:500;font-size:clamp(2.3rem,5.6vw,5rem);line-height:1.04;letter-spacing:-.02em}
.lede{font-size:clamp(1rem,1.2vw,1.15rem);color:var(--ink-55);line-height:1.85;font-weight:300;max-width:46ch}

/* ── 4. UTILITIES ────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
section{padding-top:var(--section);padding-bottom:var(--section)}
.sec-head{max-width:760px;margin-bottom:clamp(2.5rem,6vw,5rem)}
.sec-head .h2{margin-top:1.1rem}
.dark{background:var(--navy);color:var(--paper)}
.dark .h2,.dark .display{color:var(--paper)}
.dark .lede{color:var(--paper-70)}
.dark .eyebrow{color:var(--gold-lt)}

/* line mask reveal — initial state only when JS active */
.js [data-lines] .line{overflow:hidden;display:block}
.js [data-lines] .line > *{display:block;will-change:transform}
.js [data-reveal]{opacity:0;will-change:transform,opacity}
.noscroll{overflow:hidden}

/* ── 6. SCROLL PROGRESS ──────────────────────────────────── */
.progress{position:fixed;top:0;left:0;height:2px;width:100%;z-index:300;transform:scaleX(0);transform-origin:0 50%;
  background:linear-gradient(90deg,var(--gold-dk),var(--gold-lt));}

/* ── 7. PRELOADER ────────────────────────────────────────── */
#preloader{position:fixed;inset:0;z-index:9999;background:var(--navy);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.2rem}
#preloader.done{pointer-events:none}
.pl-mark{display:flex;align-items:center;gap:1rem;opacity:0}
.pl-num{font-family:var(--display);font-style:italic;color:var(--paper);font-size:1.5rem;
  position:fixed;bottom:clamp(1.5rem,5vw,3rem);right:clamp(1.5rem,5vw,3rem)}
.pl-bar{width:min(260px,52vw);height:1px;background:var(--paper-22);position:relative;overflow:hidden}
.pl-bar > i{position:absolute;inset:0 100% 0 0;background:linear-gradient(90deg,var(--gold),var(--gold-lt))}

/* logo mark — gold square + serif B */
.mark{display:inline-flex;align-items:center;gap:.85rem}
.mark-box{width:46px;height:46px;border:1.5px solid var(--gold);display:grid;place-items:center;flex:none}
.mark-box span{font-family:var(--display);font-style:italic;font-weight:500;font-size:1.55rem;color:var(--gold);line-height:1;transform:translateY(.02em)}
.mark-word{font-family:var(--display);font-weight:500;font-size:1.5rem;letter-spacing:.01em;line-height:1;white-space:nowrap}
.mark-word em{font-style:italic;font-weight:400}
.mark.sm .mark-box{width:34px;height:34px}
.mark.sm .mark-box span{font-size:1.15rem}
.mark.sm .mark-word{font-size:1.15rem}

/* ── 8. HEADER ───────────────────────────────────────────── */
.hdr{position:fixed;top:0;left:0;right:0;z-index:200;padding:1.5rem var(--gut);
  display:flex;align-items:center;justify-content:space-between;
  transition:transform .5s var(--ease),background .5s,padding .5s,border-color .5s;
  border-bottom:1px solid transparent}
.hdr.up{transform:translateY(0)}
.hdr.down{transform:translateY(-101%)}
.hdr.scrolled{background:rgba(237,232,223,.82);backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);
  border-bottom:1px solid var(--line);padding-top:1rem;padding-bottom:1rem}
/* header sits over dark hero first → light text */
.hdr .mark-word,.hdr .mark-box span{color:var(--paper);transition:color .5s}
.hdr .mark-box{border-color:var(--gold-lt);transition:border-color .5s}
.hdr.scrolled .mark-word{color:var(--ink)}
.hdr.scrolled .mark-box span{color:var(--gold-dk)}
.hdr.scrolled .mark-box{border-color:var(--gold)}
.nav{display:flex;align-items:center;gap:2.2rem}
.nav a:not(.btn){font-size:.7rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--paper-70);position:relative;transition:color .3s}
.hdr.scrolled .nav a:not(.btn){color:var(--ink-55)}
.nav a:not(.btn)::after{content:'';position:absolute;left:0;bottom:-6px;height:1px;width:0;background:currentColor;transition:width .35s var(--ease)}
.nav a:not(.btn):hover{color:var(--gold-lt)}
.hdr.scrolled .nav a:not(.btn):hover{color:var(--gold-dk)}
.nav a:not(.btn):hover::after{width:100%}
.burger{display:none;flex-direction:column;gap:6px;padding:8px;margin:-8px;z-index:260}
.burger span{width:26px;height:1.5px;background:var(--paper);transition:.35s var(--ease)}
.hdr.scrolled .burger span{background:var(--ink)}
.burger.open span{background:var(--paper)}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobnav{position:fixed;inset:0;z-index:250;background:var(--navy);
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.4rem;
  padding:0 var(--gut);clip-path:inset(0 0 100% 0);transition:clip-path .7s var(--ease)}
.mobnav.open{clip-path:inset(0 0 0 0)}
.mobnav a{font-family:var(--display);font-size:clamp(2.2rem,9vw,4rem);font-weight:500;color:var(--paper);line-height:1.18}
.mobnav a em{color:var(--gold-lt)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--sans);font-size:.72rem;
  font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:.95rem 1.8rem;border-radius:var(--r);
  position:relative;overflow:hidden;transition:color .4s var(--ease),transform .25s,box-shadow .4s var(--ease);white-space:nowrap}
.btn svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn:active{transform:translateY(1px) scale(.985)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold::before{content:'';position:absolute;inset:0;background:var(--gold-lt);transform:scaleX(0);transform-origin:0 50%;transition:transform .45s var(--ease);z-index:0}
.btn-gold:hover::before{transform:scaleX(1)}
.btn-gold:hover{box-shadow:0 16px 34px -14px rgba(201,169,110,.65)}
.btn-gold span,.btn-gold svg{position:relative;z-index:1}
.btn-ghost{border:1px solid var(--paper-22);color:var(--paper-70)}
.btn-ghost:hover{color:var(--paper);border-color:var(--paper-45);box-shadow:0 14px 30px -18px rgba(0,0,0,.5)}
.btn-line{border:1px solid var(--line-2);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--cream);box-shadow:0 14px 30px -18px rgba(24,28,56,.45)}
.nav .btn{padding:.7rem 1.4rem}
.gratis{color:var(--gold-lt)!important;border:1px solid rgba(201,169,110,.4);position:relative}
.hdr.scrolled .gratis{color:var(--gold-dk)!important}
.gratis small{position:absolute;left:50%;bottom:-1.4rem;transform:translateX(-50%);font-size:.5rem;letter-spacing:.1em;opacity:.7;white-space:nowrap}

/* ── 9. HERO (VSL: rubrik → video → CTA) ─────────────────── */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding:8.5rem var(--gut) 6rem;overflow:hidden;background:var(--navy-3);color:var(--paper);text-align:center}
.hero-glow{position:absolute;left:50%;top:44%;transform:translate(-50%,-50%);width:min(95vw,1150px);aspect-ratio:1;
  background:radial-gradient(circle,rgba(201,169,110,.13),transparent 62%);pointer-events:none;z-index:0}
.hero-video{position:relative;width:min(820px,100%);margin:2.6rem auto 2.4rem;aspect-ratio:16/9;
  border:1px solid rgba(201,169,110,.35);border-radius:10px;overflow:hidden;background:#000;
  box-shadow:0 40px 90px -35px rgba(0,0,0,.75),0 0 60px -18px rgba(201,169,110,.35);will-change:transform,opacity}
.hero-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.hero-micro{margin-top:1.1rem;font-size:.62rem;font-weight:400;letter-spacing:.24em;text-transform:uppercase;color:var(--paper-45)}
.hero-grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:170px}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:.6rem;font-size:.6rem;font-weight:500;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold-lt);border:1px solid rgba(201,169,110,.32);
  background:rgba(201,169,110,.08);padding:.42rem 1rem;border-radius:30px;margin-bottom:2.4rem}
.hero-badge i{width:5px;height:5px;border-radius:50%;background:var(--gold-lt);animation:blink 2.4s var(--ease-io) infinite}
@keyframes blink{0%,100%{opacity:.25}50%{opacity:1}}
.hero-h1 .line{overflow:hidden;display:block}
.hero-h1 .line > *{display:block;will-change:transform}
.hero-h1{font-family:var(--display);font-weight:500;color:var(--paper);
  font-size:clamp(2.1rem,6.4vw,5.8rem);line-height:1.04;letter-spacing:-.02em;margin-bottom:1.5rem}
.hero-h1 .accent{font-style:italic;font-weight:400;
  background:linear-gradient(108deg,var(--gold-lt),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-lede{font-size:clamp(.95rem,1.2vw,1.12rem);color:var(--paper-70);line-height:1.85;font-weight:300;max-width:52ch;margin:0 auto}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.scrollcue{position:absolute;left:var(--gut);bottom:2.2rem;z-index:2;display:flex;align-items:center;gap:.8rem;color:var(--paper-45)}
.scrollcue .ln{width:54px;height:1px;background:var(--paper-22);position:relative;overflow:hidden}
.scrollcue .ln::after{content:'';position:absolute;inset:0 100% 0 0;background:var(--gold-lt);animation:cue 2.4s var(--ease-io) infinite}
@keyframes cue{0%{inset:0 100% 0 0}50%{inset:0 0 0 0}100%{inset:0 0 0 100%}}
.scrollcue span{font-size:.56rem;letter-spacing:.28em;text-transform:uppercase}
.scrollcue span:last-child{animation:scrollBounce 2.2s ease-in-out infinite}
@keyframes scrollBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ── 10. MARQUEE ─────────────────────────────────────────── */
.marquee{background:var(--navy);border-top:1px solid var(--paper-line);border-bottom:1px solid var(--paper-line);
  overflow:hidden;padding:1.1rem 0;display:flex;white-space:nowrap}
.marquee-track{display:flex;flex:none;will-change:transform}
.marquee-track span{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--paper-70);padding:0 1.6rem;display:inline-flex;align-items:center;gap:1.6rem}
.marquee-track span::after{content:'✦';font-size:.7rem;color:var(--gold);font-style:normal}

/* ── 11. STATS ───────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:var(--maxw);margin:0 auto}
.stat{padding:clamp(2rem,4vw,3.4rem) 2rem;border-right:1px solid var(--paper-line);text-align:center}
.stat:last-child{border-right:none}
.stat-v{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,6vw,4.6rem);line-height:1;letter-spacing:-.02em;
  background:linear-gradient(120deg,var(--gold-lt),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  will-change:transform;display:block}
.stat-l{font-size:.64rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--paper-70);margin-top:.7rem}

/* ── 12. SERVICES ────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;perspective:1200px}
.svc{background:var(--cream-3);padding:2.6rem 2rem;position:relative;overflow:hidden;transition:background .4s}
.svc::before{content:'';position:absolute;left:0;bottom:0;height:2px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-lt));transition:width .5s var(--ease)}
.svc:hover{background:var(--cream-2)}
.svc:hover::before{width:100%}
.svc-i{font-size:1.7rem;margin-bottom:1.4rem;display:block;transition:transform .5s var(--ease)}
.svc:hover .svc-i{transform:translateY(-6px) scale(1.1)}
.svc-n{font-family:var(--display);font-size:1.45rem;font-weight:500;margin-bottom:.5rem;transition:color .35s var(--ease)}
.svc:hover .svc-n{color:var(--gold-dk)}
.svc-d{font-size:.84rem;color:var(--ink-55);line-height:1.75;font-weight:300;margin-bottom:1rem}
.svc-tag{font-size:.6rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-dk)}

/* ── 13. PROCESS (pinned horizontal) ─────────────────────── */
.process{background:var(--cream-2);overflow:hidden}
.proc-pin{position:relative}
.proc-head{padding:0 var(--gut)}
.proc-track{display:flex;gap:clamp(1.5rem,3vw,2.5rem);padding:clamp(2.5rem,6vw,4rem) var(--gut);will-change:transform}
.pstep{flex:0 0 min(78vw,440px);background:var(--cream-3);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(2rem,4vw,3rem);display:flex;flex-direction:column;min-height:clamp(300px,40vw,400px);
  transition:border-color .4s var(--ease),box-shadow .4s var(--ease)}
.pstep:hover{border-color:var(--line-2);box-shadow:0 26px 55px -34px rgba(24,28,56,.45)}
.pstep:hover .pstep-n{color:var(--gold)}
.pstep-n{font-family:var(--display);font-style:italic;font-size:4.5rem;line-height:1;color:var(--line-2);margin-bottom:auto;transition:color .4s var(--ease)}
.pstep-t{font-family:var(--display);font-size:1.7rem;font-weight:500;margin:2rem 0 .7rem}
.pstep-d{font-size:.88rem;color:var(--ink-55);line-height:1.8;font-weight:300}
.proc-hint{padding:0 var(--gut) 0;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-35);display:flex;align-items:center;gap:.7rem}
.proc-hint .ln{width:40px;height:1px;background:var(--line-2)}

/* ── 14. DEMO ────────────────────────────────────────────── */
.demo .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:center}
/* Live demo-galleri */
.demo-inner{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.demo-head{max-width:640px;margin-bottom:clamp(2rem,5vw,3.2rem)}
.demo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2vw,1.6rem)}
.demo-card{display:block;border:1px solid var(--paper-line);border-radius:var(--r-lg);overflow:hidden;background:rgba(255,255,255,.02);
  transition:transform .35s cubic-bezier(.22,1,.36,1),border-color .35s,box-shadow .35s}
.demo-card:hover{transform:translateY(-5px);border-color:rgba(201,169,110,.45);box-shadow:0 24px 60px -24px rgba(0,0,0,.55)}
.demo-preview{position:relative;aspect-ratio:16/11;overflow:hidden;background:#0d0b09}
.demo-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.22,1,.36,1)}
.demo-card:hover .demo-preview img{transform:scale(1.05)}
.demo-shield{position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(13,11,9,.55) 100%);transition:background .35s}
.demo-card:hover .demo-shield{background:linear-gradient(180deg,transparent 40%,rgba(13,11,9,.35) 100%)}
.demo-card-meta{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.2rem;border-top:1px solid var(--paper-line)}
.demo-card-meta h3{font-size:1rem;font-weight:500;color:var(--paper);margin:0 0 .15rem}
.demo-card-meta span{font-size:.72rem;color:var(--paper-45);font-weight:300}
.demo-open{display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap;color:var(--gold-lt);font-size:.68rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;transition:gap .3s}
.demo-card:hover .demo-open{gap:.8rem}
.demo-open svg{width:13px;height:13px;stroke:currentColor;stroke-width:2;fill:none}
.demo-proof-center{text-align:center;margin-top:clamp(1.6rem,3vw,2.4rem)}
.demo-frame{border:1px solid var(--paper-line);border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/10;
  background:var(--navy-2);position:relative;box-shadow:0 40px 90px -40px rgba(13,16,35,.6);will-change:transform,opacity}
.demo-frame .glow{position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 40%,rgba(201,169,110,.16),transparent 70%)}
.demo-mock{position:absolute;inset:0;display:flex;flex-direction:column;gap:.6rem;align-items:center;justify-content:center;padding:2.5rem}
.demo-dots{display:flex;gap:.4rem;margin-bottom:1.2rem}
.demo-dots i{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.demo-dots i:nth-child(2){background:var(--paper-22);animation:dp 2s .3s infinite}
.demo-dots i:nth-child(3){background:var(--paper-22);animation:dp 2s .6s infinite}
.demo-dots i:nth-child(1){animation:dp 2s 0s infinite}
@keyframes dp{0%,100%{opacity:.25}50%{opacity:1}}
.demo-bar{height:1px;background:var(--paper-line)}
.demo-bar.a{width:62%}.demo-bar.b{width:88%}.demo-bar.c{width:48%}.demo-bar.d{width:72%}
.demo-lbl{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--paper-70);margin-top:1rem}
.demo-link{display:inline-flex;align-items:center;gap:.6rem;color:var(--gold-lt);font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;margin-top:2rem;transition:gap .3s}
.demo-link:hover{gap:1.1rem}
.demo-link svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none}
.demo-proof{margin-top:1.2rem;font-size:.8rem;color:var(--paper-45);font-weight:300}
.demo-proof a{color:var(--gold-lt);border-bottom:1px solid rgba(201,169,110,.35);padding-bottom:1px;transition:color .3s,border-color .3s}
.demo-proof a:hover{color:var(--gold);border-color:var(--gold)}

/* ── 15. WHY ─────────────────────────────────────────────── */
.why .wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.why-list{display:flex;flex-direction:column;gap:1.1rem}
.wi{display:flex;gap:1.3rem;padding:1.7rem;background:var(--cream-3);border:1px solid var(--line);border-radius:var(--r);
  transition:border-color .35s,transform .45s var(--ease),background .35s,box-shadow .45s var(--ease)}
.wi:hover{border-color:var(--line-2);transform:translateX(6px);background:var(--cream-2);box-shadow:0 18px 40px -28px rgba(24,28,56,.4)}
.wi-ck{width:34px;height:34px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;flex:none;margin-top:.1rem;transform-origin:center;will-change:transform,opacity}
.wi-ck svg{width:13px;height:13px;stroke:var(--gold-dk);stroke-width:2.4;fill:none}
.wi-t{font-family:var(--display);font-size:1.15rem;font-weight:500;margin-bottom:.3rem}
.wi-d{font-size:.84rem;color:var(--ink-55);line-height:1.7;font-weight:300}

/* ── 16. AUDIT BANNER ────────────────────────────────────── */
.audit-wrap{padding:0 var(--gut)}
.audit{max-width:var(--maxw);margin:0 auto;background:var(--navy);border:1px solid rgba(201,169,110,.28);
  border-radius:var(--r-lg);padding:clamp(2.2rem,4vw,3.4rem);display:grid;grid-template-columns:1fr auto;
  gap:2rem;align-items:center;position:relative;overflow:hidden;color:var(--paper)}
.audit::before{content:'';position:absolute;top:-60%;right:-8%;width:420px;height:420px;
  background:radial-gradient(circle,rgba(201,169,110,.1),transparent 65%);pointer-events:none}
.audit-tags{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:.9rem}
.audit-badge{font-size:.56rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-lt);
  background:rgba(201,169,110,.12);border:1px solid rgba(201,169,110,.3);border-radius:30px;padding:.32rem .8rem}
.audit-price{font-size:.72rem;font-weight:500;color:var(--paper-70)}
.audit-price s{opacity:.7}.audit-price b{color:var(--gold-lt)}
.audit h3{font-family:var(--display);font-size:clamp(1.4rem,3vw,2.1rem);font-weight:500;line-height:1.15;margin-bottom:.5rem}
.audit p{font-size:.86rem;color:var(--paper-70);line-height:1.7;max-width:54ch;font-weight:300}

/* ── 17. CTA BAND ────────────────────────────────────────── */
.cta{position:relative;text-align:center;overflow:hidden;background:var(--navy)}
.cta::before{content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(201,169,110,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(201,169,110,.05) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,#000,transparent 80%)}
.cta .glow{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:80vw;height:80vw;max-width:900px;max-height:900px;
  background:radial-gradient(circle,rgba(201,169,110,.1),transparent 60%);pointer-events:none;
  animation:glowPulse 6s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.75}50%{opacity:1}}
.cta-inner{position:relative;z-index:1;max-width:820px;margin:0 auto;padding:0 var(--gut)}
.cta h2{font-family:var(--display);font-weight:500;color:var(--paper);font-size:clamp(2.2rem,6vw,4.6rem);line-height:1.04;letter-spacing:-.02em;margin-bottom:1rem}
.cta h2 em{font-style:italic;background:linear-gradient(108deg,var(--gold-lt),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cta p{color:var(--paper-70);font-weight:300;margin-bottom:2.6rem;font-size:1.02rem}

/* ── 18. CONTACT ─────────────────────────────────────────── */
.contact{background:var(--cream-2);border-top:1px solid var(--line)}
.contact .wrap{max-width:660px;text-align:center}
.cform{display:flex;flex-direction:column;gap:1.1rem;margin-top:3rem;text-align:left}
.crow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{font-size:.64rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-35);display:block;margin-bottom:.5rem}
.field input,.field textarea{width:100%;background:var(--cream-3);border:1px solid var(--line);color:var(--ink);
  font-family:var(--sans);font-size:.92rem;font-weight:300;padding:.95rem 1.1rem;border-radius:var(--r);outline:none;
  transition:border-color .3s,background .3s;-webkit-appearance:none;appearance:none}
.field input:focus,.field textarea:focus{border-color:var(--line-2);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.cform .btn{align-self:flex-start}
.cok{text-align:center;padding:3.5rem 0;display:none}
.cok.show{display:block}
.cok .ic{width:54px;height:54px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;margin:0 auto 1.2rem;color:var(--gold-dk);font-size:1.4rem}
.cok h3{font-family:var(--display);font-size:1.8rem;font-weight:500;margin-bottom:.4rem}
.cok p{color:var(--ink-55);font-weight:300}

/* ── 19. FOOTER ──────────────────────────────────────────── */
.foot{background:var(--navy);color:var(--paper);padding:clamp(4rem,8vw,7rem) var(--gut) 2.5rem}
.foot-top{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem;
  padding-bottom:clamp(3rem,6vw,5rem);border-bottom:1px solid var(--paper-line)}
.foot-brand{font-family:var(--display);font-weight:500;font-size:clamp(3rem,11vw,9rem);line-height:.9;letter-spacing:-.02em;will-change:clip-path,opacity}
.foot-brand em{font-style:italic;color:var(--gold-lt)}
.foot-cta{text-align:right}
.foot-cta p{color:var(--paper-70);font-size:.8rem;margin-bottom:1rem;letter-spacing:.04em}
.foot-nl{max-width:var(--maxw);margin:2.4rem auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.4rem 2.5rem;
  padding:1.8rem 2rem;background:rgba(201,169,110,.06);border:1px solid var(--paper-line);border-radius:var(--r-lg)}
.foot-nl-copy h4{font-family:var(--display);font-size:1.35rem;font-weight:500;margin-bottom:.3rem}
.foot-nl-copy p{font-size:.78rem;color:var(--paper-70);font-weight:300;max-width:46ch;line-height:1.6}
.foot-nl-form{display:flex;gap:.7rem;flex-wrap:wrap;position:relative}
.foot-nl-form input[type="email"]{min-width:min(280px,70vw);background:rgba(245,242,235,.06);border:1px solid var(--paper-line);
  color:var(--paper);font-family:var(--sans);font-size:.9rem;font-weight:300;padding:.85rem 1.1rem;border-radius:var(--r);outline:none;
  transition:border-color .3s,background .3s;-webkit-appearance:none;appearance:none}
.foot-nl-form input[type="email"]:focus{border-color:rgba(201,169,110,.55);background:rgba(245,242,235,.1)}
.foot-nl-form input[type="email"]::placeholder{color:rgba(245,242,235,.28)}
.foot-nl-ok{display:none;font-size:.84rem;color:var(--gold-lt)}
.foot-nl.sent .foot-nl-form{display:none}
.foot-nl.sent .foot-nl-ok{display:block}
.foot-bottom{max-width:var(--maxw);margin:2rem auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.foot-bottom span{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-45)}
.foot-links{display:flex;gap:1.6rem}
.foot-links a{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-70);transition:color .3s}
.foot-links a:hover{color:var(--gold-lt)}

/* ── 20. POPUP ───────────────────────────────────────────── */
.pop{position:fixed;inset:0;z-index:9000;background:rgba(13,16,35,.78);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .4s}
.pop.show{opacity:1;pointer-events:auto}
.pop-card{background:var(--navy);border:1px solid rgba(201,169,110,.24);border-radius:var(--r-lg);
  padding:2.4rem 2.1rem;max-width:430px;width:100%;position:relative;color:var(--paper);
  transform:translateY(20px) scale(.98);transition:transform .5s var(--ease)}
.pop.show .pop-card{transform:translateY(0) scale(1)}
.pop-x{position:absolute;top:1rem;right:1.1rem;color:var(--paper-45);font-size:1.4rem;line-height:1;transition:color .3s}
.pop-x:hover{color:var(--paper)}
.pop-ey{font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:.9rem}
.pop-card h3{font-family:var(--display);font-style:italic;font-size:1.55rem;font-weight:500;line-height:1.2;margin-bottom:.7rem}
.pop-card p{font-size:.84rem;color:var(--paper-70);line-height:1.65;font-weight:300;margin-bottom:1.5rem}
.pop-prices{display:flex;align-items:center;gap:.9rem;margin-bottom:1.6rem}
.pop-prices .box{flex:1;text-align:center;border:1px solid rgba(201,169,110,.25);border-radius:var(--r);padding:.7rem;background:rgba(201,169,110,.07)}
.pop-prices .box b{font-size:1.1rem;color:var(--gold-lt);display:block}
.pop-prices .box.old b{text-decoration:line-through;opacity:.55}
.pop-prices .box small{font-size:.56rem;letter-spacing:.08em;color:var(--paper-45);text-transform:uppercase}
.pop-prices .arrow{color:var(--paper-22);font-size:1.2rem}
.pop-card .btn{width:100%;justify-content:center}
.pop-note{font-size:.66rem;color:var(--paper-45);text-align:center;margin-top:.8rem}

/* ── 21. RESPONSIVE ──────────────────────────────────────── */
@media(max-width:1024px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--paper-line)}
}
@media(max-width:860px){
  .nav{display:none}
  .burger{display:flex}
  /* Process: pinned horisontell scroll ersätts av nativ svepning med snap */
  .proc-track{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding-bottom:2.5rem}
  .proc-track::-webkit-scrollbar{display:none}
  .pstep{scroll-snap-align:center}
  .demo .wrap,.why .wrap{grid-template-columns:1fr}
  .demo-grid{grid-template-columns:1fr}
  .demo-preview{aspect-ratio:16/10}
  .audit{grid-template-columns:1fr}
  .foot-top{flex-direction:column;align-items:flex-start}
  .foot-cta{text-align:left}
}
@media(max-width:560px){
  .crow{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .hero{padding:6.5rem var(--gut) 5rem}
  .hero-badge{margin-bottom:1.6rem}
  .hero-video{margin:1.8rem auto 1.8rem;border-radius:8px}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{justify-content:center}
  .marquee-track span{font-size:1.15rem;padding:0 1rem}
  .scrollcue{display:none}
}

/* ── 22. REDUCED MOTION ──────────────────────────────────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .js [data-reveal]{opacity:1!important}
}
