/* =========================================================
   Caballoria Graphics — premium static rebuild
   Cinematic luxury · editorial · warm brown + gold
   Style: exaggerated minimalism · Cormorant Garamond + Outfit
   ========================================================= */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Outfit:wght@300;400;500;600;700&display=swap");

:root{
  --brown:#231b11;
  --brown-2:#2e2416;
  --brown-3:#3d3020;
  --brown-soft:#4a3c2a;
  --gold:#d6b46a;
  --gold-2:#e7d09a;
  --gold-deep:#b8952a;
  --gold-soft:#fbf3df;
  --cream:#f7f2e9;
  --cream-2:#efe7d7;
  --ink:#241f17;
  --muted:#6b6253;
  --line:rgba(36,31,23,.12);
  --line-gold:rgba(214,180,106,.45);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Outfit",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --wrap:1240px;
  --header-h:78px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --slant:3.4vw;
  --slant-cap:64px;
  --script:"Pinyon Script","Cormorant Garamond",cursive;
}

*{box-sizing:border-box}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.06;letter-spacing:.005em;margin:0}
p{margin:0}
::selection{background:var(--gold);color:#241f16}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}

/* subtle film grain over the whole page for a tactile, premium feel */
body::after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--sans);font-weight:600;font-size:.86rem;letter-spacing:.04em;text-transform:uppercase;
  padding:.95rem 1.9rem;border-radius:10px;border:0;cursor:pointer;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),color .3s var(--ease),background .3s var(--ease)}
.btn--gold{background:var(--gold);color:#241f16;box-shadow:0 10px 30px -12px rgba(184,149,42,.6)}
.btn--gold:hover{background:var(--gold-2);transform:translateY(-3px);box-shadow:0 18px 40px -14px rgba(184,149,42,.75)}
.btn--ghost{background:transparent;color:var(--gold);border:1.5px solid var(--line-gold)}
.btn--ghost:hover{background:var(--gold);color:#241f16;transform:translateY(-3px);border-color:var(--gold)}

/* ---------- header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);
  display:flex;align-items:center;background:linear-gradient(180deg,rgba(20,15,9,.55),rgba(20,15,9,0));
  transition:background .35s var(--ease),box-shadow .35s var(--ease),height .35s var(--ease)}
.site-header.scrolled{background:rgba(28,21,13,.94);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line-gold)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand img{height:46px;width:auto;transition:height .35s var(--ease)}
.site-header.scrolled .brand img{height:40px}
.nav{display:flex;align-items:center;gap:1.5rem}
.nav>a{position:relative;color:#efe3cf;font-size:.86rem;font-weight:500;letter-spacing:.04em;
  text-transform:uppercase;transition:color .25s;white-space:nowrap}
.nav>a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--gold);transition:width .3s var(--ease)}
.nav>a:hover{color:var(--gold-2)}
.nav>a:hover::after{width:100%}
.nav>a[aria-current="page"]{color:var(--gold-2)}
.nav>a[aria-current="page"]::after{width:100%}
.nav__group{position:relative}
.nav__toggle{background:none;border:0;color:#efe3cf;font:inherit;font-size:.86rem;font-weight:500;
  letter-spacing:.04em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;padding:0}
.nav__toggle:hover{color:var(--gold-2)}
.nav__toggle svg{width:13px;height:13px;transition:transform .3s var(--ease)}
.nav__group.open .nav__toggle svg{transform:rotate(180deg)}
.nav__mega{position:absolute;top:calc(100% + 16px);left:0;right:auto;transform:translateY(10px);
  background:#fffdf9;border:1px solid var(--line);border-radius:13px;box-shadow:0 34px 80px -30px rgba(20,15,9,.6);
  padding:1.1rem;width:min(700px,90vw);opacity:0;visibility:hidden;transition:.28s var(--ease)}
.nav__group.open .nav__mega{opacity:1;visibility:visible;transform:translateY(0)}
.nav__mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}
.mm-item{display:flex;gap:.85rem;align-items:flex-start;padding:.8rem .9rem;border-radius:13px;transition:background .2s,transform .2s}
.mm-item:hover{background:var(--gold-soft)}
.mm-ic{width:40px;height:40px;flex:none;border-radius:11px;background:var(--gold-soft);display:grid;place-items:center;transition:background .2s}
.mm-item:hover .mm-ic{background:#fff}
.mm-item b{display:block;color:var(--ink);font-size:.92rem;font-weight:600;font-family:var(--sans)}
.mm-item small{display:block;color:var(--muted);font-size:.79rem;line-height:1.35;margin-top:.15rem}
.nav__mega-foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  margin-top:.8rem;padding:1rem .9rem 0;border-top:1px solid var(--line)}
.nav__mega-foot span{color:var(--muted);font-size:1.02rem;font-style:italic;font-family:var(--serif)}
.nav__mega-foot .btn{padding:.6rem 1.2rem;font-size:.74rem}
.nav-burger{display:none;background:none;border:0;cursor:pointer;padding:6px;flex-direction:column;gap:5px}
.nav-burger span{display:block;width:26px;height:2px;background:#efe3cf;border-radius:2px;transition:.3s var(--ease)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;
  text-align:center;color:#fff;overflow:hidden;background:#1f180f}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero__overlay{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(25,18,10,.55) 0,rgba(25,18,10,.35) 40%,rgba(18,13,7,.9) 100%),
    radial-gradient(125% 80% at 50% 38%,transparent 0,rgba(20,14,8,.6) 100%)}
.hero__slides{position:relative;z-index:2;max-width:1000px;padding:130px 28px 110px}
.hero__kicker{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--sans);font-size:.72rem;
  font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-2);margin-bottom:1.6rem}
.hero__kicker::before,.hero__kicker::after{content:"";width:30px;height:1px;background:var(--line-gold)}
.hero__slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:0 24px;opacity:0;visibility:hidden;transform:translateY(22px) scale(.99);
  transition:opacity .9s var(--ease),transform .9s var(--ease),visibility .9s}
.hero__slide.active{position:relative;opacity:1;visibility:visible;transform:none}
.hero__sub{font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2.3vw,1.7rem);
  color:var(--gold-2);max-width:30ch;margin:0 auto 1.2rem;font-weight:500;line-height:1.3}
.hero__title{font-family:var(--serif);font-size:clamp(2.9rem,8.5vw,6.4rem);color:#f8efdc;
  text-transform:uppercase;letter-spacing:.01em;line-height:.98;margin:0;font-weight:600;
  text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:3;margin-top:2.6rem}
.hero__dots{position:absolute;bottom:46px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:.6rem}
.hero__dots button{width:9px;height:9px;border-radius:50%;border:0;cursor:pointer;padding:0;
  background:rgba(247,238,218,.32);transition:.3s var(--ease)}
.hero__dots button.active{background:var(--gold);width:30px;border-radius:6px}
.hero__scroll{position:absolute;bottom:42px;right:36px;z-index:3;color:rgba(247,238,218,.55);font-size:.66rem;
  letter-spacing:.28em;text-transform:uppercase;writing-mode:vertical-rl}
.hero__scroll::after{content:"";display:block;width:1px;height:42px;background:linear-gradient(var(--gold),transparent);margin:10px auto 0}

/* ---------- generic section ---------- */
.section{padding:clamp(80px,11vw,150px) 0}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.72rem;font-weight:700;
  letter-spacing:.26em;text-transform:uppercase;color:var(--gold-deep);font-family:var(--sans)}
.eyebrow::before{content:"";width:30px;height:1.5px;background:var(--gold)}
.section__head{max-width:720px}
.section__head.center{margin:0 auto;text-align:center}
.section__head h2{font-size:clamp(2.3rem,5vw,4rem);color:var(--ink);margin:.8rem 0 .9rem;letter-spacing:-.01em}
.section__head p{color:var(--muted);font-size:1.12rem;line-height:1.6}
.section__head.center .eyebrow{justify-content:center}

/* ---------- what we build ---------- */
.build{background:var(--cream);position:relative}
.build__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3.2rem}
.build__card{position:relative;background:#fffdf9;border:1px solid var(--line);border-radius:13px;
  padding:2.2rem 2rem;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.build__card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-deep));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.build__card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -28px rgba(36,28,16,.5);border-color:var(--line-gold)}
.build__card:hover::before{transform:scaleX(1)}
.build__card .ic{width:60px;height:60px;border-radius:12px;background:var(--gold-soft);display:grid;place-items:center;margin-bottom:1.4rem}
.build__card h3{font-size:1.85rem;color:var(--ink);margin-bottom:.6rem}
.build__card p{color:var(--muted);font-size:1rem}

/* ---------- how we work (editorial numerals) ---------- */
.how{background:var(--brown);color:#f1e6d4;position:relative;overflow:hidden}
.how::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(60% 50% at 85% 0,rgba(214,180,106,.12),transparent 70%)}
.how .wrap{position:relative}
.how .section__head h2{color:#f8efdc}
.how .section__head p{color:#cdbda3}
.how__steps{display:grid;grid-template-columns:repeat(2,1fr);gap:2.4rem 4rem;margin-top:3.6rem;counter-reset:step}
.how__step{position:relative;padding-left:5rem;counter-increment:step;padding-bottom:.5rem}
.how__step::before{content:"0" counter(step);position:absolute;left:0;top:-.8rem;
  font-family:var(--serif);font-size:3.4rem;color:var(--gold);opacity:.7;font-weight:500;line-height:1}
.how__step::after{content:"";position:absolute;left:1.15rem;top:2.6rem;bottom:-2rem;width:1px;
  background:linear-gradient(var(--line-gold),transparent)}
.how__step h3{font-size:1.6rem;color:#f8efdc;margin-bottom:.55rem}
.how__step p{color:#cdbda3;font-size:.98rem}
.how__step ul{margin:.6rem 0 0;padding-left:1.1rem;color:#bfae92;font-size:.92rem;line-height:1.7}

/* ---------- featured work (carousel) ---------- */
.fw{background:var(--cream-2)}
.fw__stage{display:grid;grid-template-columns:1.55fr 1fr auto;gap:2.6rem;align-items:center;margin-top:3.4rem}
.fw__preview{position:relative;border-radius:14px;overflow:hidden;background:#fff;border:1px solid var(--line);
  box-shadow:0 40px 80px -36px rgba(36,28,16,.55);aspect-ratio:16/11;display:grid;place-items:center}
.fw__preview::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(255,255,255,.4);border-radius:14px;pointer-events:none}
.fw__preview img{width:100%;height:100%;object-fit:cover;transition:opacity .35s var(--ease),transform 6s var(--ease)}
.fw__preview:hover img{transform:scale(1.04)}
.fw__info .fw__sub{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold-deep);margin-bottom:.6rem}
.fw__title{font-size:clamp(2.1rem,3.6vw,3rem);color:var(--ink);margin-bottom:.9rem;line-height:1.05}
.fw__desc{color:var(--muted);font-size:1.04rem;margin-bottom:1.7rem;min-height:5em;line-height:1.6}
.fw__rail{display:flex;flex-direction:column;gap:.8rem;max-height:470px;overflow:auto;padding:.3rem;scrollbar-width:thin}
.fw__thumb{position:relative;width:142px;border:2px solid transparent;border-radius:14px;overflow:hidden;
  background:#fff;cursor:pointer;padding:0;transition:.3s var(--ease);flex:none}
.fw__thumb img{width:100%;height:90px;object-fit:cover;display:block;opacity:.62;transition:opacity .3s,transform .4s var(--ease)}
.fw__thumb:hover img{opacity:1;transform:scale(1.05)}
.fw__thumb.is-active{border-color:var(--gold);box-shadow:0 14px 30px -14px rgba(36,28,16,.55)}
.fw__thumb.is-active img{opacity:1}
.fw__tag{position:absolute;top:7px;right:7px;background:var(--gold);color:#241f16;font-size:.58rem;
  font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .5rem;border-radius:10px;opacity:0;transition:.25s}
.fw__thumb.is-active .fw__tag{opacity:1}

/* ---------- featured / cta band shared ---------- */

/* =========================================================
   Reused clean blocks (profession cards + pricing) — cb-*
   ========================================================= */
.cb-sec{font-family:var(--sans);padding:clamp(80px,11vw,150px) 0}
.cb-wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.cb-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.72rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-deep)}
.cb-eyebrow::before{content:"";width:30px;height:1.5px;background:var(--gold)}
.cb-sec h2{font-family:var(--serif);font-size:clamp(2.3rem,5vw,4rem);font-weight:600;letter-spacing:-.01em;color:var(--ink);margin:.8rem 0 .6rem}
.cb-lead{color:var(--muted);font-size:1.12rem;max-width:62ch;margin:0;line-height:1.6}
.cb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:3rem}
.cb-card{position:relative;background:#fffdf9;border:1px solid var(--line);border-radius:13px;padding:1.7rem;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;color:inherit;display:block}
.cb-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-deep));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.cb-card:hover{transform:translateY(-8px);box-shadow:0 28px 56px -26px rgba(36,28,16,.5);border-color:var(--line-gold)}
.cb-card:hover::before{transform:scaleX(1)}
.cb-ic{width:56px;height:56px;border-radius:15px;background:var(--gold-soft);display:grid;place-items:center;margin-bottom:1.1rem;transition:transform .35s var(--ease)}
.cb-card:hover .cb-ic{transform:scale(1.08) rotate(-3deg)}
.cb-card h3{font-family:var(--sans);font-size:1.18rem;font-weight:700;color:var(--ink);margin-bottom:.45rem}
.cb-card p{font-size:.92rem;color:var(--muted);margin-bottom:.9rem;line-height:1.5}
.cb-card ul{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
.cb-card li{display:flex;gap:.5rem;font-size:.86rem;color:#4a4133}
.cb-more{display:inline-flex;align-items:center;gap:.3rem;margin-top:1rem;font-weight:600;font-size:.84rem;color:var(--gold-deep);transition:gap .25s var(--ease)}
.cb-card:hover .cb-more{gap:.6rem}
.cb-incl{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;margin-top:2rem}
.cb-incl span{display:inline-flex;align-items:center;gap:.4rem;font-size:.84rem;font-weight:500;color:#4a4133;background:#fffdf9;border:1px solid var(--line);border-radius:10px;padding:.48rem .95rem}
.cb-plans{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.2rem}
.cb-plan{position:relative;background:#fffdf9;border:1px solid var(--line);border-radius:13px;padding:1.8rem 1.6rem;display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.cb-plan:hover{transform:translateY(-6px);box-shadow:0 26px 54px -26px rgba(36,28,16,.45)}
.cb-plan.feat{border-color:var(--gold);box-shadow:0 26px 60px -26px rgba(184,149,42,.5);background:linear-gradient(180deg,#fffdf8,#fff9ec)}
.cb-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg,var(--gold),var(--gold-deep));color:#241f16;font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .9rem;border-radius:10px;white-space:nowrap;box-shadow:0 8px 20px -8px rgba(184,149,42,.6)}
.cb-plan h3{font-family:var(--sans);font-size:1.25rem;font-weight:700;color:var(--ink)}
.cb-price{font-family:var(--serif);font-size:2.6rem;font-weight:600;color:var(--gold-deep);margin:.3rem 0 0;line-height:1}
.cb-per{font-size:.8rem;color:var(--muted);margin-bottom:1.1rem}
.cb-plan ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem;font-size:.86rem;color:#4a4133;flex:1}
.cb-plan li{display:flex;gap:.45rem}
.cb-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;margin-top:1.4rem;font-weight:600;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;padding:.8rem 1.3rem;border-radius:10px;background:var(--gold);color:#241f16;transition:.3s var(--ease)}
.cb-btn:hover{background:var(--gold-deep);color:#fff;transform:translateY(-2px)}
.cb-plan.feat .cb-btn{box-shadow:0 12px 28px -12px rgba(184,149,42,.6)}
.cb-addon{margin-top:1.8rem;background:linear-gradient(120deg,#332a1c,#1c160e);color:#fff;border-radius:14px;padding:2rem 2.2rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem;text-align:left;position:relative;overflow:hidden}
.cb-addon::before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(214,180,106,.18),transparent 70%)}
.cb-addon h3{font-family:var(--sans);color:#fff;font-size:1.3rem;font-weight:700}
.cb-addon p{color:#d8cdb8;font-size:.92rem;max-width:62ch;margin-top:.35rem}
.cb-pill{color:var(--gold);font-family:var(--serif);font-size:2.2rem;font-weight:600;white-space:nowrap;position:relative}
.cb-note{font-size:.88rem;color:var(--muted);margin-top:1.6rem;text-align:center}

/* ---------- testimonials marquee ---------- */
.tm{background:var(--brown-2);color:#f1e6d4;overflow:hidden}
.tm .section__head{text-align:center;margin:0 auto}
.tm .section__head h2{color:#f8efdc}
.tm__track-wrap{margin-top:3.4rem;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.tm__track{display:flex;gap:1.6rem;width:max-content;animation:tm-scroll 52s linear infinite}
.tm__track-wrap:hover .tm__track{animation-play-state:paused}
@keyframes tm-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tm__card{position:relative;width:400px;flex:none;background:rgba(255,255,255,.045);border:1px solid rgba(214,180,106,.22);
  border-radius:13px;padding:2.4rem 1.9rem 1.8rem}
.tm__card::before{content:"\201C";position:absolute;top:.1rem;left:1.2rem;font-family:var(--serif);font-size:5rem;
  color:var(--gold);opacity:.35;line-height:1}
.tm__stars{color:var(--gold);font-size:.95rem;letter-spacing:.12em;margin-bottom:.8rem}
.tm__card p{color:#e9deca;font-size:.97rem;line-height:1.6;position:relative}
.tm__card cite{display:block;margin-top:1.1rem;font-style:normal;font-weight:600;color:var(--gold);font-size:.88rem;letter-spacing:.02em}

/* ---------- quiz section: light, to break the run of dark sections ---------- */
.cabq-section{background:linear-gradient(180deg,#f7f2e9,#efe6d5)!important;color:var(--ink)!important}
.cabq-eyebrow{color:var(--gold-deep)!important}
.cabq-head h2{font-family:var(--serif)!important;font-weight:600!important;color:var(--ink)!important}
.cabq-head p{color:var(--muted)!important}
.cabq-side{color:var(--muted)!important}
.cabq-side a{color:var(--gold-deep)!important}

/* ---------- final CTA ---------- */
.cta{background:radial-gradient(120% 120% at 50% 0,#4a3a25,#1f1810);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;opacity:.4;background:radial-gradient(50% 60% at 50% 0,rgba(214,180,106,.18),transparent 70%)}
.cta .wrap{position:relative}
.cta h2{font-size:clamp(2.6rem,6vw,4.6rem);color:#f8efdc;margin-bottom:1.1rem;line-height:1.02}
.cta p{color:#dccdb1;max-width:56ch;margin:0 auto 2.4rem;font-size:1.15rem}
.cta__row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
.footer{background:#181109;color:#cdbda3;padding:80px 0 32px;font-size:.94rem}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(214,180,106,.16)}
.footer__brand img{height:50px;margin-bottom:1.2rem}
.footer__brand p{max-width:40ch;color:#a3957d;line-height:1.7}
.footer__contact{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:.6rem}
.footer__contact li{display:flex;align-items:center;gap:.6rem;color:#cdbda3}
.footer__contact svg{width:17px;height:17px;flex:none;stroke:var(--gold);fill:none}
.footer__contact a{transition:color .2s}
.footer__contact a:hover{color:var(--gold)}
.footer h4{font-family:var(--sans);color:var(--gold);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:1.1rem;font-weight:700}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.65rem}
.footer ul a{transition:color .2s,padding-left .2s var(--ease)}
.footer ul a:hover{color:var(--gold);padding-left:4px}
.footer__bottom{padding-top:1.8rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;color:#766a58;font-size:.85rem}
.footer__bottom a:hover{color:var(--gold)}

/* ---------- whatsapp float ---------- */
.wa-float{position:fixed;right:24px;bottom:24px;z-index:90;width:60px;height:60px;border-radius:50%;
  background:#25d366;display:grid;place-items:center;box-shadow:0 12px 34px -8px rgba(0,0,0,.5);
  transition:transform .25s var(--ease),box-shadow .25s}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:wa-pulse 2.4s var(--ease) infinite}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:31px;height:31px;fill:#fff;position:relative}

/* =========================================================
   Subpages: inner hero, stats, compare, prose, contact
   ========================================================= */
.subhero{position:relative;overflow:hidden;color:#fff;text-align:center;
  padding:calc(var(--header-h) + clamp(70px,10vw,120px)) 0 clamp(60px,8vw,100px);
  background:radial-gradient(120% 110% at 50% 0,#4a3a25 0,#241b10 55%,#170f08 100%)}
.subhero::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(50% 70% at 50% 0,rgba(214,180,106,.16),transparent 70%)}
.subhero .wrap{position:relative;max-width:920px}
.subhero .eyebrow{justify-content:center;color:var(--gold-2)}
.subhero h1{font-family:var(--serif);font-size:clamp(2.6rem,6.5vw,5rem);color:#f8efdc;line-height:1.02;margin:1rem 0 0;text-transform:uppercase;letter-spacing:.01em}
.subhero .subhero__tag{color:#dccdb1;font-size:clamp(1.05rem,2vw,1.35rem);max-width:46ch;margin:1.2rem auto 2rem;font-family:var(--serif);font-style:italic}
.subhero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.breadcrumb{position:relative;z-index:2;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#a3957d}
.breadcrumb a:hover{color:var(--gold)}

.lead-block{max-width:760px;margin:0 auto;text-align:center}
.lead-block h2{font-size:clamp(2rem,4vw,3.1rem);color:var(--ink);margin-bottom:1rem}
.lead-block p{color:var(--muted);font-size:1.15rem;line-height:1.65}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.stat{background:#fffdf9;border:1px solid var(--line);border-radius:13px;padding:2rem 1.4rem;text-align:center}
.stat b{display:block;font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.4rem);color:var(--gold-deep);line-height:1}
.stat span{display:block;margin-top:.5rem;color:var(--muted);font-size:.92rem;font-weight:500}

.compare{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:3rem}
.compare__col{border-radius:13px;padding:2rem;border:1px solid var(--line)}
.compare__col--bad{background:#fbf6f3;border-color:#e9d3c8}
.compare__col--good{background:#f5f8f1;border-color:#cfe0c2}
.compare__col h3{font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1rem;font-weight:700}
.compare__col--bad h3{color:#b4684a}
.compare__col--good h3{color:#5a7d3c}
.compare__col ul{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.compare__col li{display:flex;gap:.6rem;font-size:.95rem;color:#4a4133;align-items:flex-start}
.compare__col li svg{flex:none;margin-top:3px}

/* prose (legal pages) */
.prose-wrap{max-width:820px;margin:0 auto}
.prose{color:var(--ink);font-size:1.02rem;line-height:1.75}
.prose h2{font-size:1.7rem;margin:2.4rem 0 .8rem;color:var(--ink)}
.prose h3{font-family:var(--sans);font-size:1.05rem;font-weight:700;margin:1.6rem 0 .5rem}
.prose p,.prose li{color:#4a4133}
.prose p{margin:0 0 1rem}
.prose ul{margin:0 0 1rem;padding-left:1.3rem;display:grid;gap:.4rem}
.prose a{color:var(--gold-deep);font-weight:600}
.prose strong{color:var(--ink)}
.prose__updated{color:var(--muted);font-size:.9rem;font-style:italic;margin-bottom:2rem}
.callout{background:var(--gold-soft);border:1px solid var(--line-gold);border-radius:14px;padding:1.2rem 1.4rem;margin:1.4rem 0;font-size:.95rem;color:#4a4133}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:2.6rem;align-items:start}
.contact-cards{display:grid;gap:1rem}
.contact-card{display:flex;gap:1rem;align-items:flex-start;background:#fffdf9;border:1px solid var(--line);border-radius:12px;padding:1.4rem 1.5rem;transition:border-color .25s,transform .25s var(--ease)}
.contact-card:hover{border-color:var(--line-gold);transform:translateY(-3px)}
.contact-card .ic{width:46px;height:46px;flex:none;border-radius:12px;background:var(--gold-soft);display:grid;place-items:center}
.contact-card h3{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:.25rem}
.contact-card a,.contact-card p{font-size:1.05rem;color:var(--ink);font-weight:500}
.contact-card a:hover{color:var(--gold-deep)}

/* =========================================================
   Reveal on scroll
   ========================================================= */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .tm__track,.wa-float::after,.fw__preview:hover img{animation:none}
  html{scroll-behavior:auto}
  *{transition-duration:.01ms!important}
}

/* =========================================================
   Responsive
   ========================================================= */
@media(max-width:1150px){
  .nav{position:fixed;top:var(--header-h);left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:#1c150d;padding:.5rem 1.1rem 1.6rem;border-bottom:1px solid rgba(214,180,106,.16);
    transform:translateY(-135%);transition:transform .4s var(--ease);max-height:calc(100svh - var(--header-h));overflow:auto}
  .nav.open{transform:translateY(0)}
  .nav>a,.nav__toggle{padding:.9rem .4rem;border-bottom:1px solid rgba(214,180,106,.1);width:100%;text-align:left}
  .nav>a::after{display:none}
  .nav__group{width:100%}
  .nav__mega{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:0;background:transparent;width:auto;padding:0 0 .4rem .6rem;display:none}
  .nav__group.open .nav__mega{display:block;transform:none}
  .nav__mega-grid{grid-template-columns:1fr}
  .mm-item{padding:.6rem .4rem}
  .mm-item b{color:#efe3cf}
  .mm-item small{color:#a3957d}
  .nav__mega-foot{border-color:rgba(214,180,106,.16);flex-direction:column;align-items:flex-start}
  .nav__mega-foot span{color:#cdbda3}
  .nav-burger{display:flex}
}
@media(max-width:980px){
  .cb-grid,.cb-plans{grid-template-columns:1fr 1fr}
  .build__grid{grid-template-columns:1fr}
  .how__steps{grid-template-columns:1fr;gap:1.8rem}
  .how__step::after{display:none}
  .footer__top{grid-template-columns:1fr 1fr}
  .fw__stage{grid-template-columns:1fr;gap:2rem}
  .fw__info{order:-1}
  .fw__desc{min-height:0}
  .fw__rail{flex-direction:row;max-height:none;overflow-x:auto;padding-bottom:.8rem}
  .fw__thumb{width:160px}
  .compare{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:600px){
  .wrap,.cb-wrap{padding:0 20px}
  .cb-grid,.cb-plans{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .tm__card{width:300px}
  .stats{grid-template-columns:1fr}
  .hero__video{display:none}
  .hero{background:radial-gradient(120% 90% at 50% 0,#4a3a25 0,#241b10 60%,#170f08 100%)}
}

/* ---------- clients / trusted-by portfolio strip ---------- */
.clients{background:var(--cream)}
.clients__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:3rem}
.clients__item{position:relative;border-radius:12px;overflow:hidden;background:#fff;border:1px solid var(--line);
  aspect-ratio:768/600;box-shadow:0 14px 38px -26px rgba(36,28,16,.5);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.clients__item:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(36,28,16,.55)}
.clients__item img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .6s var(--ease)}
.clients__item:hover img{transform:scale(1.05)}
.clients__item span{position:absolute;inset:auto 0 0 0;padding:.7rem .9rem;color:#fff;font-size:.82rem;font-weight:600;
  letter-spacing:.04em;background:linear-gradient(to top,rgba(20,15,9,.9),transparent);min-height:62px;display:flex;align-items:flex-end}
@media(max-width:980px){.clients__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.clients__grid{grid-template-columns:1fr 1fr;gap:.7rem}}

/* ============ mega-menu: profession images + wider panel ============ */
.nav__mega--wide{width:min(780px,92vw)}
.mm-item--img{align-items:center}
.mm-img{width:96px;height:66px;flex:none;border-radius:10px;overflow:hidden;box-shadow:0 8px 18px -10px rgba(36,28,16,.55);background:var(--gold-soft)}
.mm-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease)}
.mm-item--img:hover .mm-img img{transform:scale(1.08)}
@media(max-width:1150px){
  .nav__mega--wide{width:auto}
  .mm-img{width:64px;height:46px}
}

/* ============ featured projects — auto-rotating carousel ============ */
.fwc{position:relative;margin-top:3.2rem}
.fwc__viewport{position:relative}
.fwc__slide{position:absolute;inset:0;display:grid;grid-template-columns:1.15fr .85fr;gap:2.6rem;align-items:center;
  opacity:0;visibility:hidden;transform:translateX(34px);transition:opacity .7s var(--ease),transform .7s var(--ease),visibility .7s}
.fwc__slide.is-active{position:relative;opacity:1;visibility:visible;transform:none}
.fwc__media{border-radius:13px;overflow:hidden;background:#fff;border:1px solid var(--line);
  box-shadow:0 34px 80px -34px rgba(36,28,16,.6);aspect-ratio:16/10}
.fwc__media img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform 6s var(--ease)}
.fwc__slide.is-active .fwc__media img{transform:scale(1.05)}
.fwc__eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}
.fwc__title{font-family:var(--serif);font-size:clamp(2rem,3.6vw,3rem);color:var(--ink);margin:.55rem 0 .9rem;line-height:1.05}
.fwc__desc{color:var(--muted);font-size:1.06rem;line-height:1.65;margin-bottom:1.7rem}
.fwc__dots{display:flex;gap:.55rem;justify-content:center;margin-top:2.2rem}
.fwc__dots button{width:9px;height:9px;border:0;border-radius:10px;background:rgba(36,28,16,.22);cursor:pointer;transition:.3s var(--ease);padding:0}
.fwc__dots button.active{background:var(--gold-deep);width:30px}
.fwc__nav{position:absolute;top:34%;transform:translateY(-50%);z-index:3;width:48px;height:48px;border-radius:10px;
  border:1px solid var(--line);background:rgba(255,255,255,.92);color:var(--ink);font-size:1.4rem;cursor:pointer;
  display:grid;place-items:center;transition:.25s var(--ease);box-shadow:0 10px 24px -12px rgba(36,28,16,.4)}
.fwc__nav:hover{background:var(--gold);color:#241f16;border-color:var(--gold)}
.fwc__prev{left:-12px}.fwc__next{right:-12px}
@media(max-width:880px){
  .fwc__slide{grid-template-columns:1fr;gap:1.3rem}
  .fwc__media{order:-1}
  .fwc__nav{top:auto;bottom:-4px;width:42px;height:42px}
  .fwc__prev{left:auto;right:58px}.fwc__next{right:8px}
  .fwc__dots{justify-content:flex-start}
}

/* featured carousel: CTA row + live-site link */
.fwc__cta{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.fwc__visit{display:inline-flex;align-items:center;gap:.4rem;color:var(--gold-deep);font-weight:600;font-size:.9rem;
  letter-spacing:.02em;transition:gap .2s var(--ease),color .2s}
.fwc__visit:hover{color:var(--ink);gap:.6rem}

/* word-logo + "Graphics" tagline */
.brand{display:inline-flex;flex-direction:column;align-items:center;line-height:1;text-decoration:none}
.brand__tag{font-family:var(--sans);font-size:.58rem;font-weight:600;letter-spacing:.46em;text-transform:uppercase;
  color:var(--gold);margin-top:1px;padding-left:.46em;transition:height .35s var(--ease)}
.site-header.scrolled .brand__tag{font-size:.54rem}

/* ---------- FAQ accordion ---------- */
.faq{background:var(--cream-2)}
.faq__list{max-width:820px;margin:2.8rem auto 0;display:grid;gap:.8rem}
.faq__item{background:#fffdf9;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:border-color .25s,box-shadow .25s}
.faq__item[open]{border-color:var(--line-gold);box-shadow:0 16px 40px -28px rgba(36,28,16,.4)}
.faq__item summary{list-style:none;cursor:pointer;padding:1.1rem 1.4rem;font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--sans);font-size:1.5rem;font-weight:400;color:var(--gold-deep);transition:transform .3s var(--ease);flex:none}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{padding:0 1.4rem 1.2rem;color:var(--muted);line-height:1.65;margin:0;font-size:1rem}

/* ---------- subpage hero: split (text + visual) ---------- */
.subhero--split{text-align:left}
.subhero--split .wrap{max-width:var(--wrap)}
.subhero--split .subhero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:3.2rem;align-items:center;margin-top:1.4rem}
.subhero--split .eyebrow{justify-content:flex-start}
.subhero--split h1{margin-top:.9rem}
.subhero--split .subhero__tag{margin:1.1rem 0 1.9rem;max-width:42ch}
.subhero--split .subhero__cta{justify-content:flex-start}
.subhero__media{border-radius:13px;overflow:hidden;border:1px solid rgba(255,255,255,.14);
  box-shadow:0 44px 100px -40px rgba(0,0,0,.75);aspect-ratio:16/11;transform:translateZ(0)}
.subhero__media img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform 7s var(--ease)}
.subhero--split:hover .subhero__media img{transform:scale(1.06)}
@media(max-width:880px){
  .subhero--split{text-align:center}
  .subhero--split .subhero__inner{grid-template-columns:1fr;gap:1.8rem}
  .subhero--split .eyebrow,.subhero--split .subhero__cta{justify-content:center}
  .subhero--split .subhero__tag{margin-left:auto;margin-right:auto}
  .subhero__media{order:-1;max-width:560px;margin:0 auto;width:100%}
}

/* ---------- About / Über mich ---------- */
.about{background:var(--cream)}
.about__inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:3.4rem;align-items:center}
.about__media{position:relative;border-radius:14px;overflow:hidden;background:linear-gradient(160deg,var(--gold-soft),#efe6d5);
  aspect-ratio:4/5;box-shadow:0 40px 90px -38px rgba(36,28,16,.55);border:1px solid var(--line)}
.about__media img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform 7s var(--ease)}
.about:hover .about__media img{transform:scale(1.05)}
.about__badge{position:absolute;left:18px;bottom:18px;background:rgba(28,21,13,.86);backdrop-filter:blur(6px);
  color:#f6edda;border:1px solid var(--line-gold);border-radius:11px;padding:.55rem .9rem;text-align:center;line-height:1}
.about__badge b{font-family:var(--serif);font-size:1.7rem;color:var(--gold-2);display:block}
.about__badge small{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:#cdbda3}
.about__text h2{font-size:clamp(2rem,4vw,3.1rem);margin:.6rem 0 1.1rem}
.about__lead{font-size:1.18rem;color:var(--ink);line-height:1.6;margin-bottom:1rem}
.about__text p{color:var(--muted);line-height:1.7;margin-bottom:1rem}
.about__points{list-style:none;margin:1.4rem 0 1.8rem;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.about__points li{display:flex;gap:.55rem;align-items:center;font-size:.95rem;color:#4a4133;font-weight:500}
@media(max-width:880px){
  .about__inner{grid-template-columns:1fr;gap:2rem}
  .about__media{max-width:420px;margin:0 auto;aspect-ratio:4/5}
  .about__points{grid-template-columns:1fr}
}

/* =========================================================
   CINEMATIC-EDITORIAL UPGRADE
   diagonal dividers · vertical labels · cinematic hero ·
   script accent · oversized numerals · reveal polish
   ========================================================= */
html,body{overflow-x:hidden}

/* ---- #work flipped to a dark gallery band ---- */
.fw{background:var(--brown-2);color:#f1e6d4;position:relative;overflow:hidden}
.fw .section__head h2{color:#f8efdc}
.fw .section__head p{color:#cdbda3}
.fw .eyebrow{color:var(--gold-2)}
.fwc__eyebrow{color:var(--gold-2)}
.fwc__title{color:#f8efdc}
.fwc__desc{color:#cdbda3}
.fwc__dots button{background:rgba(247,238,218,.25)}
.fwc__dots button.active{background:var(--gold)}
.fwc__nav{background:rgba(28,21,13,.85);color:#f1e6d4;border-color:rgba(214,180,106,.3)}
.fwc__nav:hover{background:var(--gold);color:#241f16;border-color:var(--gold)}
.fwc__visit{color:var(--gold-2)}
.fwc__visit:hover{color:#fff}

/* ---- Diagonal section dividers (pseudo-element wedge, +1px overlap) ---- */
.slant-top{position:relative;isolation:isolate}
.slant-top::before{content:"";position:absolute;left:0;right:0;top:-1px;
  height:clamp(26px,var(--slant),var(--slant-cap));z-index:2;pointer-events:none;
  background:var(--slant-from,var(--cream));
  clip-path:polygon(0 0,100% 0,100% 0,0 100%)}
.slant-top.slant-up::before{clip-path:polygon(0 0,100% 0,100% 100%,0 0)}
@media(max-width:600px){.slant-top::before{height:20px}}

/* ---- Rotated vertical section labels (editorial) ---- */
.has-vlabel{position:relative}
.vlabel{position:absolute;top:clamp(90px,12vw,160px);z-index:4;
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(.8rem,1vw,.96rem);letter-spacing:.34em;text-transform:lowercase;
  color:var(--gold-deep);opacity:.55;white-space:nowrap;pointer-events:none;user-select:none;
  display:flex;align-items:center;gap:.9rem;transition:opacity .4s var(--ease),color .4s var(--ease)}
.vlabel::before{content:"";width:1px;height:46px;background:linear-gradient(var(--gold-deep),transparent)}
.vlabel--left{left:max(14px,calc((100vw - var(--wrap))/2 - 30px));writing-mode:vertical-rl;transform:rotate(180deg)}
.vlabel--right{right:max(14px,calc((100vw - var(--wrap))/2 - 30px));writing-mode:vertical-rl}
.how .vlabel,.fw .vlabel,.tm .vlabel{color:var(--gold-2);opacity:.5}
.how .vlabel::before,.fw .vlabel::before,.tm .vlabel::before{background:linear-gradient(var(--gold-2),transparent)}
.has-vlabel:hover .vlabel{opacity:.85}
@media(max-width:1150px){.vlabel{display:none}}

/* ---- Hero — cinematic title card ---- */
.hero__video{filter:saturate(.72) contrast(1.05) brightness(.84)}
.hero__overlay{background:
  radial-gradient(120% 80% at 50% 32%,transparent 0,rgba(20,14,8,.5) 60%,rgba(15,10,5,.92) 100%),
  linear-gradient(180deg,rgba(20,14,8,.58) 0,rgba(20,14,8,.26) 42%,rgba(13,9,5,.95) 100%)}
.hero__kicker{font-size:.68rem;letter-spacing:.42em;margin-bottom:1.1rem;opacity:.9}
.hero__sub{font-size:clamp(1rem,1.9vw,1.4rem);opacity:.82;margin:0 auto .9rem}
.hero__title{font-size:clamp(3rem,9.5vw,7.2rem);line-height:.96;letter-spacing:.005em;font-weight:700;
  color:var(--gold-soft);text-shadow:0 4px 60px rgba(0,0,0,.5)}
.hero__explore{position:absolute;left:50%;bottom:84px;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;text-decoration:none;
  color:rgba(247,238,218,.62);font-family:var(--sans);font-size:.64rem;font-weight:600;
  letter-spacing:.34em;text-transform:uppercase;transition:color .3s var(--ease)}
.hero__explore:hover{color:var(--gold-2)}
.hero__explore svg{width:18px;height:18px;stroke:var(--gold);stroke-width:1.6;fill:none;animation:hero-bob 2.4s var(--ease) infinite}
@keyframes hero-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
.hero__scroll{display:none}
@media(max-width:600px){.hero__explore{bottom:70px}}

/* ---- Script accent (Pinyon Script) ---- */
.script-accent{font-family:var(--script);font-weight:400;font-style:normal;
  font-size:clamp(1.9rem,4vw,3rem);line-height:1;letter-spacing:.01em;text-transform:none;
  color:var(--gold-deep);display:block;margin:.1rem 0 -.1rem}
.script-accent--light{color:var(--gold-2)}

/* ---- Oversized editorial numerals (#how) ---- */
.how .wrap::before{content:"01";position:absolute;top:clamp(40px,6vw,90px);right:-1vw;z-index:0;
  font-family:var(--serif);font-weight:700;font-style:italic;line-height:.8;
  font-size:clamp(11rem,30vw,26rem);color:var(--gold);opacity:.05;
  letter-spacing:-.04em;pointer-events:none;user-select:none;white-space:nowrap}
.how .section__head,.how__steps{position:relative;z-index:1}
.how__step::before{font-size:clamp(2.9rem,5vw,4.6rem);opacity:.6;color:var(--gold);font-weight:600;font-style:italic}
@media(max-width:600px){.how .wrap::before{font-size:clamp(7rem,40vw,12rem);opacity:.045;right:-3vw}}

/* ---- Reveal & micro-interaction upgrade (transform/opacity only) ---- */
.reveal{opacity:0;transform:translateY(38px) scale(.99);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal .build__card,.reveal .cb-card,.reveal .how__step{opacity:0;transform:translateY(24px);
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in .build__card,.reveal.in .cb-card,.reveal.in .how__step{opacity:1;transform:none}
.reveal.in .build__card:nth-child(2),.reveal.in .cb-card:nth-child(2),.reveal.in .how__step:nth-child(2){transition-delay:.08s}
.reveal.in .build__card:nth-child(3),.reveal.in .cb-card:nth-child(3),.reveal.in .how__step:nth-child(3){transition-delay:.16s}
.reveal.in .cb-card:nth-child(4),.reveal.in .how__step:nth-child(4){transition-delay:.24s}
.reveal.in .cb-card:nth-child(n+5),.reveal.in .how__step:nth-child(n+5){transition-delay:.32s}
.fwc__slide.is-active .fwc__media img{animation:ken 14s var(--ease) infinite alternate}
@keyframes ken{0%{transform:scale(1.03)}100%{transform:scale(1.09) translate3d(-1.5%,-1%,0)}}
.build__card:hover,.cb-card:hover{box-shadow:0 34px 64px -26px rgba(184,149,42,.42),0 30px 60px -28px rgba(36,28,16,.5)}

@media(prefers-reduced-motion:reduce){
  .hero__explore svg{animation:none}
  .reveal,.reveal .build__card,.reveal .cb-card,.reveal .how__step{opacity:1;transform:none;transition:none}
  .fwc__slide.is-active .fwc__media img{animation:none}
}

/* ---- Unified centered section heads (script kicker everywhere) ---- */
.cb-center{text-align:center}
.cb-center .cb-lead{margin-left:auto;margin-right:auto}
.cb-center .cb-grid,.cb-center .cb-plans{text-align:left}
.section__head .script-accent{margin-bottom:.2rem}
.cb-sec .script-accent{margin-bottom:.1rem}
.cabq-head .script-accent{margin-bottom:.2rem}

/* ---- Hero gold-foil shimmer ---- */
.hero__title{
  background:linear-gradient(100deg,var(--gold-soft) 0%,#e8ce8e 22%,#fff7e6 40%,var(--gold-2) 56%,var(--gold-soft) 80%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;text-shadow:none;
  filter:drop-shadow(0 6px 34px rgba(0,0,0,.5));animation:goldsweep 7.5s linear infinite}
@keyframes goldsweep{0%{background-position:210% 0}100%{background-position:-20% 0}}

/* ---- About founder drop-cap ---- */
.about__lead::first-letter{font-family:var(--serif);font-size:3.4em;line-height:.78;float:left;margin:.06em .14em -.06em 0;color:var(--gold-deep);font-weight:600}

/* ---- Coverage / trust band (marquee + count-up) ---- */
.coverage{background:var(--brown);color:#e9dcc2;padding:0 0 clamp(42px,6vw,72px);position:relative;overflow:hidden}
.coverage__marquee{overflow:hidden;border-top:1px solid rgba(214,180,106,.18);border-bottom:1px solid rgba(214,180,106,.18);padding:.95rem 0;margin-bottom:clamp(42px,6vw,72px);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.coverage__track{display:inline-flex;align-items:center;gap:1.7rem;white-space:nowrap;animation:cmarq 36s linear infinite;font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,2vw,1.55rem);color:var(--gold-soft)}
.coverage__track i{color:var(--gold-deep);font-style:normal}
.coverage:hover .coverage__track{animation-play-state:paused}
@keyframes cmarq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.coverage__stats{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.6rem;text-align:center}
.coverage__stats .stat{flex:1 1 130px;display:flex;flex-direction:column;gap:.35rem}
.stat__num{font-family:var(--serif);font-size:clamp(2.1rem,4.4vw,3.3rem);font-weight:600;color:var(--gold);line-height:1;font-variant-numeric:tabular-nums}
.stat__label{font-family:var(--sans);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:#b9aa92}
@media(prefers-reduced-motion:reduce){.coverage__track{animation:none}.hero__title{animation:none;background-position:0 0}}
@media(max-width:600px){.coverage__stats .stat{flex:1 1 42%}}

/* ---- Self-drawing horseshoe motif (#6) ---- */
.hshoe{display:flex;justify-content:center;margin:0 auto .8rem}
.hshoe__svg{width:clamp(46px,6vw,72px);height:auto;overflow:visible}
.hshoe__svg path{fill:none;stroke:var(--gold);stroke-width:3.2;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset 1.7s var(--ease) .15s}
.hshoe.in .hshoe__svg path{stroke-dashoffset:0}
.hshoe__svg circle{fill:var(--gold);opacity:0;transition:opacity .5s var(--ease) 1.15s}
.hshoe.in .hshoe__svg circle{opacity:.85}
@media(prefers-reduced-motion:reduce){.hshoe__svg path{stroke-dashoffset:0;transition:none}.hshoe__svg circle{opacity:.85;transition:none}}

/* ---- Pricing: recommended plan pulse on reveal (#13) ---- */
@keyframes featpulse{0%,100%{box-shadow:0 26px 60px -26px rgba(184,149,42,.5)}42%{box-shadow:0 26px 74px -18px rgba(184,149,42,.85),0 0 0 3px rgba(214,180,106,.4)}}
.reveal.in .cb-plan.feat{animation:featpulse 1.7s var(--ease) .35s 1}
@media(prefers-reduced-motion:reduce){.reveal.in .cb-plan.feat{animation:none}}
