/* =========================================================
   ZAMBEZI CREATIVE — Design System
   Display: Anton (condensed) · Body: Hanken Grotesk · Label: Space Mono
   ========================================================= */

:root{
  /* palette sampled from brand assets */
  --paper:        #ffffff;
  --cream:        #f6f4ed;
  --cream-deep:   #efece1;
  --ink:          #1b2113;
  --ink-soft:     #404734;
  --muted:        #6a715c;

  --green:        #263018;   /* brand forest */
  --green-mid:    #3c4d27;
  --green-bright: #5c7232;
  --gold:         #f6a91a;
  --gold-deep:    #d98f08;
  --clay:         #c44b1c;

  --line:         rgba(27, 33, 19, 0.12);
  --line-soft:    rgba(27, 33, 19, 0.07);

  --display: "Anton", "Arial Narrow", sans-serif;
  --sans: "Hanken Grotesk", system-ui, sans-serif;
  --mono: "Space Mono", ui-monospace, monospace;

  --container: 1280px;
  --gutter: clamp(20px, 5vw, 80px);
  --radius: 18px;
  --radius-lg: 26px;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);

  --shadow-sm: 0 2px 8px rgba(27,33,19,.06), 0 1px 2px rgba(27,33,19,.04);
  --shadow-md: 0 18px 40px -18px rgba(27,33,19,.28), 0 4px 12px rgba(27,33,19,.06);
  --shadow-lg: 0 40px 90px -30px rgba(27,33,19,.42);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ 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(--green); }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(80px, 11vw, 168px); position:relative; }
.section--cream{ background:var(--cream); }
.section--ink{ background:var(--green); color:#f2efe5; }

/* ---------- type scale ---------- */
.kicker{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--clay);
  display:inline-flex;
  align-items:center;
  gap:.7em;
  font-weight:700;
}
.kicker::before{ content:""; width:30px; height:2px; background:var(--clay); display:inline-block; }
.kicker--center{ justify-content:center; }
.kicker--light{ color:var(--gold); }
.kicker--light::before{ background:var(--gold); }

.display{
  font-family:var(--display);
  font-weight:400;
  line-height:.92;
  letter-spacing:.005em;
  text-transform:uppercase;
}
h1.display{ font-size:clamp(48px, 7vw, 104px); }
h2.display{ font-size:clamp(40px, 6vw, 88px); }
h3.display{ font-size:clamp(30px, 4vw, 52px); }

.headline-sans{ font-family:var(--sans); font-weight:800; line-height:1.05; letter-spacing:-.02em; }
.lede{ font-size:clamp(17px, 1.5vw, 21px); color:var(--ink-soft); max-width:54ch; }
.text-gold{ color:var(--gold); }
.text-clay{ color:var(--clay); }
.text-green{ color:var(--green); }

/* gradient text accent */
.grad-text{
  background:linear-gradient(100deg, var(--clay) 0%, var(--gold) 55%, var(--green-bright) 100%);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}

/* underline highlight sweep */
.hl{ position:relative; white-space:nowrap; }
.hl::after{
  content:""; position:absolute; left:-2px; right:-2px; bottom:.06em; height:.34em;
  background:var(--gold); z-index:-1; border-radius:3px;
  transform:scaleX(0); transform-origin:left; transition:transform .7s var(--ease);
}
.hl.is-in::after{ transform:scaleX(1); }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--green); --fg:#fff;
  position:relative; display:inline-flex; align-items:center; gap:.65em;
  padding:17px 30px; border-radius:100px;
  font-weight:700; font-size:15px; letter-spacing:.01em;
  background:var(--bg); color:var(--fg);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s;
  will-change:transform; overflow:hidden; isolation:isolate;
}
.btn .btn__label{ position:relative; z-index:2; display:inline-flex; align-items:center; gap:.6em; }
.btn::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:var(--gold); border-radius:inherit;
  transform:translateY(102%); transition:transform .45s var(--ease);
}
.btn:hover::before{ transform:translateY(0); }
.btn:hover{ color:var(--green); box-shadow:var(--shadow-md); }
.btn--gold{ --bg:var(--gold); --fg:var(--green); }
.btn--gold::before{ background:var(--green); }
.btn--gold:hover{ color:#fff; }
.btn--ghost{ --bg:transparent; --fg:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line); }
.btn--ghost::before{ background:var(--green); }
.btn--ghost:hover{ color:#fff; box-shadow:inset 0 0 0 1.5px var(--green); }
.btn--light{ --bg:#fff; --fg:var(--green); }
.btn--light::before{ background:var(--gold); }
.btn .arrow{ transition:transform .35s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

.textlink{
  display:inline-flex; align-items:center; gap:.5em; font-weight:700; font-size:15px;
  padding-bottom:3px; background:linear-gradient(var(--clay),var(--clay)) left bottom / 0% 2px no-repeat;
  transition:background-size .4s var(--ease), color .3s;
}
.textlink:hover{ background-size:100% 2px; color:var(--clay); }
.textlink .arrow{ transition:transform .35s var(--ease); }
.textlink:hover .arrow{ transform:translate(3px,-3px); }

/* ---------- reveal animation ---------- */
[data-reveal]{
  opacity:0; transform:translateY(34px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
  transition-delay:var(--d, 0ms);
}
[data-reveal="left"]{ transform:translateX(-44px); }
[data-reveal="right"]{ transform:translateX(44px); }
[data-reveal="scale"]{ transform:scale(.94); }
[data-reveal].is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; }
}

/* clip-reveal for headlines (line by line) */
.line-mask{ display:block; overflow:hidden; }
.line-mask > span{ display:block; transform:translateY(105%); transition:transform .9s var(--ease); transition-delay:var(--d,0ms); }
.is-in .line-mask > span, .line-mask.is-in > span{ transform:none; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  padding-block:18px;
  transition:background .4s var(--ease-soft), box-shadow .4s, padding .4s var(--ease-soft);
}
.site-header.scrolled{
  background:rgba(255,255,255,.86); backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line-soft); padding-block:11px;
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:42px; width:auto; transition:height .4s var(--ease-soft); }
.scrolled .brand img{ height:36px; }
.nav{ display:flex; align-items:center; gap:6px; }
.nav a{
  position:relative; padding:9px 15px; font-weight:600; font-size:15px; color:var(--ink);
  border-radius:8px; transition:color .25s;
}
.nav a::after{
  content:""; position:absolute; left:15px; right:15px; bottom:4px; height:2px; background:var(--clay);
  transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.nav a:hover{ color:var(--clay); }
.nav a.active{ color:var(--clay); }
.nav a.active::after{ transform:scaleX(1); }
.nav a:hover::after{ transform:scaleX(1); }
.header-cta{ display:flex; align-items:center; gap:14px; }
.menu-toggle{ display:none; width:46px; height:46px; border-radius:10px; align-items:center; justify-content:center; }
.menu-toggle span{ display:block; width:22px; height:2px; background:var(--ink); position:relative; transition:.3s; }
.menu-toggle span::before,.menu-toggle span::after{ content:""; position:absolute; left:0; width:22px; height:2px; background:var(--ink); transition:.3s; }
.menu-toggle span::before{ top:-7px; } .menu-toggle span::after{ top:7px; }
body.menu-open .menu-toggle span{ background:transparent; }
body.menu-open .menu-toggle span::before{ top:0; transform:rotate(45deg); }
body.menu-open .menu-toggle span::after{ top:0; transform:rotate(-45deg); }

/* =========================================================
   HERO — full-bleed cinematic
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; background:var(--cream); }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-slide{
  position:absolute; inset:0; opacity:0;
  transition:opacity .7s var(--ease-soft);
  background-size:cover; background-position:right center; background-repeat:no-repeat;
}
.hero-slide.active{ opacity:1; }
.hero-scrim{ display:none; }

.hero-grid{
  position:relative; z-index:2; width:100%; max-width:var(--container);
  margin-inline:auto; padding-inline:var(--gutter);
  padding-top:120px; padding-bottom:96px;
}
.hero-copy{ max-width:clamp(380px,50vw,600px); }
.hero-eyebrow{ display:flex; align-items:center; gap:16px; margin-bottom:30px; }
.hero-pill{ width:54px; height:12px; border-radius:100px; background:var(--gold); flex:0 0 auto; }
.hero-text{ display:none; }
.hero-text.active{ display:block; }
.hero h1{ margin:0; max-width:13ch; font-size:clamp(38px,4.6vw,66px); line-height:1.0; }
.hero h1 .text-olive{ color:var(--green-bright); }
.hero-divider{ width:64px; height:2px; background:var(--line); margin:30px 0 26px; }
.hero-sub{ max-width:48ch; font-size:clamp(16px,1.35vw,19px); color:var(--ink-soft); }
.hero-sub strong{ color:var(--green); font-weight:700; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }

.hero-arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:4;
  width:54px; height:54px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.72); backdrop-filter:blur(6px); color:var(--green);
  box-shadow:var(--shadow-sm); transition:background .3s, color .3s, transform .3s;
}
.hero-arrow:hover{ background:var(--green); color:#fff; transform:translateY(-50%) scale(1.06); }
.hero-arrow.prev{ left:clamp(12px,2.2vw,30px); }
.hero-arrow.next{ right:clamp(12px,2.2vw,30px); }
@media (max-width:768px){ .hero-arrow{ display:none; } }

.hero-dots{ position:absolute; left:var(--gutter); bottom:30px; z-index:3; display:flex; gap:8px; }
.hero-dots button{ width:9px; height:9px; border-radius:50%; background:rgba(38,48,24,.22); transition:.3s; }
.hero-dots button.active{ background:var(--gold); width:26px; border-radius:6px; }

/* Hero text entrance — fires on slide change via .active toggle */
.hero-text{ animation-fill-mode:both; }
.hero-text.active h1{
  animation:heroTxtIn .9s cubic-bezier(.22,1,.36,1) both;
}
.hero-text.active .hero-divider{
  animation:heroTxtIn .9s .16s cubic-bezier(.22,1,.36,1) both;
}
.hero-text.active .hero-sub{
  animation:heroTxtIn .9s .28s cubic-bezier(.22,1,.36,1) both;
}
.hero-text.active .hero-actions{
  animation:heroTxtIn .9s .42s cubic-bezier(.22,1,.36,1) both;
}
@keyframes heroTxtIn{
  from{ opacity:0; transform:translateY(30px); }
  to{ opacity:1; transform:none; }
}
@media (prefers-reduced-motion:reduce){
  .hero-text.active h1,
  .hero-text.active .hero-divider,
  .hero-text.active .hero-sub,
  .hero-text.active .hero-actions{ animation:none; }
}

.scroll-cue{
  position:absolute; right:var(--gutter); bottom:26px; z-index:5;
  font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted);
  display:flex; flex-direction:column; align-items:center; gap:9px;
}
.scroll-cue .bar{ width:1px; height:42px; background:var(--line); position:relative; overflow:hidden; }
.scroll-cue .bar::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--clay); animation:scrolldown 1.9s var(--ease-soft) infinite; }
@keyframes scrolldown{ 0%{ top:-50%; } 60%,100%{ top:100%; } }

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{ overflow:hidden; border-block:1px solid var(--line); padding-block:26px; background:var(--paper); }
.marquee-track{ display:flex; gap:46px; white-space:nowrap; width:max-content; animation:marquee 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-item{ font-family:var(--display); text-transform:uppercase; font-size:34px; color:var(--ink); display:inline-flex; align-items:center; gap:46px; letter-spacing:.01em; }
.marquee-item .sep{ width:14px; height:14px; border-radius:50%; background:var(--gold); }
.marquee-item:nth-child(even) .sep{ background:var(--clay); }
.marquee-item.ghost{ color:transparent; -webkit-text-stroke:1.4px var(--line); }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }

/* =========================================================
   INTRO
   ========================================================= */
.intro-grid{ display:grid; grid-template-columns:0.95fr 1.05fr; gap:clamp(40px,6vw,96px); align-items:center; }
.intro-figure{ position:relative; }
.intro-figure .ph{ aspect-ratio:5/6; border-radius:var(--radius-lg); }
.intro-figure .badge{
  position:absolute; bottom:-26px; left:-26px; background:var(--green); color:#fff;
  border-radius:var(--radius); padding:22px 26px; box-shadow:var(--shadow-md); max-width:230px;
}
.intro-figure .badge .b-num{ font-family:var(--display); font-size:46px; line-height:.9; color:var(--gold); }
.intro-figure .badge .b-txt{ font-size:13px; color:#d7d8c8; margin-top:8px; line-height:1.4; }
.intro-copy h2{ margin:20px 0 26px; }
.intro-points{ display:grid; gap:18px; margin-top:30px; }
.intro-point{ display:flex; gap:16px; align-items:flex-start; }
.intro-point .ic{ flex:0 0 44px; height:44px; border-radius:12px; background:var(--cream); display:grid; place-items:center; color:var(--green); }
.section--ink .intro-point .ic{ background:rgba(255,255,255,.08); color:var(--gold); }
.intro-point h4{ font-size:17px; font-weight:800; letter-spacing:-.01em; }
.intro-point p{ font-size:15px; color:var(--muted); margin-top:3px; }
.section--ink .intro-point p{ color:#b9bbab; }

/* =========================================================
   PLACEHOLDER (striped image slots)
   ========================================================= */
.ph{
  position:relative; overflow:hidden; border-radius:var(--radius); background:var(--cream-deep);
  background-image:repeating-linear-gradient(135deg, rgba(27,33,19,.05) 0 2px, transparent 2px 11px);
  display:grid; place-items:center; isolation:isolate;
}
.ph.has-img{ background-image:none; }
.ph .ph-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ph .ph-label{
  font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted); background:rgba(255,255,255,.78); padding:7px 12px; border-radius:100px;
  border:1px solid var(--line); z-index:2; text-align:center; max-width:80%;
}

/* =========================================================
   WHY / TRUST CARDS
   ========================================================= */
.why-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:54px; }
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.why-card{
  position:relative; padding:38px 30px 40px; border-radius:var(--radius-lg);
  background:var(--paper); border:1px solid var(--line); overflow:hidden; text-align:center;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s;
}
.why-card::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:4px; background:var(--gold); transform:scaleX(0); transform-origin:center; transition:transform .5s var(--ease); }
.why-card:nth-child(2)::after{ background:var(--clay); }
.why-card:nth-child(3)::after{ background:var(--green-bright); }
.why-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); border-color:transparent; }
.why-card:hover::after{ transform:scaleX(1); }
.why-card .wc-num{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; color:var(--clay); }
.why-card .wc-ic{ width:56px; height:56px; border-radius:15px; background:var(--cream); display:grid; place-items:center; color:var(--green); margin:18px auto 22px; transition:transform .5s var(--ease); }
.why-card:hover .wc-ic{ transform:scale(1.08) rotate(-4deg); }
.why-card h3{ font-size:21px; font-weight:800; letter-spacing:-.015em; }
.why-card p{ margin-top:12px; color:var(--muted); font-size:15px; }

/* =========================================================
   PROCESS
   ========================================================= */
.process-head{ max-width:620px; margin-bottom:60px; }
.process-step{
  display:grid; grid-template-columns:120px 1fr auto; gap:clamp(20px,4vw,60px); align-items:center;
  padding-block:38px; border-top:1px solid var(--line); position:relative;
}
.process-step:last-child{ border-bottom:1px solid var(--line); }
.process-step .ps-num{ font-family:var(--display); font-size:clamp(48px,6vw,82px); line-height:.85; color:var(--cream-deep); transition:color .5s var(--ease), transform .5s var(--ease); -webkit-text-stroke:1px var(--line); }
.process-step:hover .ps-num{ color:var(--gold); -webkit-text-stroke:0; transform:translateX(8px); }
.process-step .ps-body{ max-width:560px; }
.process-step .ps-body h3{ font-size:clamp(22px,2.4vw,30px); font-weight:800; letter-spacing:-.02em; }
.process-step .ps-body p{ margin-top:10px; color:var(--muted); }
.process-step .ps-tags{ display:flex; flex-wrap:wrap; gap:8px; justify-content:flex-end; max-width:230px; }
.tag{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:7px 12px; border-radius:100px; border:1px solid var(--line); color:var(--ink-soft); white-space:nowrap; transition:.3s; }
.process-step:hover .tag{ border-color:var(--green); color:var(--green); }

/* =========================================================
   SHOWCASE (Marvel Tours)
   ========================================================= */
.showcase-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center; }
.browser{
  border-radius:16px; overflow:hidden; box-shadow:var(--shadow-lg); background:#fff; border:1px solid var(--line);
  transform:perspective(1600px) rotateY(-6deg) rotateX(2deg); transition:transform .8s var(--ease);
}
.browser:hover{ transform:perspective(1600px) rotateY(0) rotateX(0); }
.browser-bar{ display:flex; align-items:center; gap:14px; padding:13px 16px; background:var(--cream); border-bottom:1px solid var(--line); }
.browser-dots{ display:flex; gap:7px; }
.browser-dots i{ width:11px; height:11px; border-radius:50%; background:var(--line); }
.browser-dots i:nth-child(1){ background:var(--clay); } .browser-dots i:nth-child(2){ background:var(--gold); } .browser-dots i:nth-child(3){ background:var(--green-bright); }
.browser-url{ flex:1; background:#fff; border:1px solid var(--line); border-radius:100px; padding:7px 16px; font-family:var(--mono); font-size:12px; color:var(--muted); display:flex; align-items:center; gap:8px; }
.browser .ph{ border-radius:0; aspect-ratio:16/10.5; }
.showcase-meta{ display:flex; flex-wrap:wrap; gap:8px; margin:22px 0 28px; }
.showcase-results{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin:30px 0 32px; }
.showcase-results .r-num{ font-family:var(--display); font-size:clamp(32px,3.4vw,44px); color:var(--green); line-height:1; }
.showcase-results .r-lbl{ font-size:13px; color:var(--muted); margin-top:7px; }

/* =========================================================
   FAQ
   ========================================================= */
.faq-grid{ display:grid; grid-template-columns:0.8fr 1.2fr; gap:clamp(34px,5vw,80px); align-items:start; }
.faq-list{ border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:24px; padding:26px 4px; text-align:left; font-size:clamp(17px,1.7vw,20px); font-weight:700; letter-spacing:-.01em; color:var(--ink); transition:color .3s; }
.faq-q:hover{ color:var(--clay); }
.faq-icon{ flex:0 0 38px; height:38px; border-radius:50%; border:1.5px solid var(--line); display:grid; place-items:center; position:relative; transition:.4s var(--ease); }
.faq-icon::before,.faq-icon::after{ content:""; position:absolute; background:var(--ink); border-radius:2px; transition:.4s var(--ease); }
.faq-icon::before{ width:14px; height:2px; } .faq-icon::after{ width:2px; height:14px; }
.faq-item.open .faq-icon{ background:var(--green); border-color:var(--green); transform:rotate(90deg); }
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{ background:#fff; }
.faq-item.open .faq-icon::after{ transform:scaleY(0); }
.faq-a{ overflow:hidden; height:0; transition:height .5s var(--ease); }
.faq-a-inner{ padding:0 4px 28px; color:var(--muted); max-width:60ch; }

/* =========================================================
   CONSULTATION CTA — compact banner
   ========================================================= */
.cta-wrap{ padding-block:clamp(28px,4vw,52px) clamp(52px,8vw,104px); }
.cta-wrap .container{ max-width:1460px; }
.cta-banner{
  position:relative; overflow:hidden; border-radius:var(--radius-lg);
  background:linear-gradient(120deg, #f8c63f 0%, #f6b81f 100%);
  color:var(--green);
  display:flex; align-items:center; gap:clamp(28px,3.6vw,56px);
  padding:clamp(40px,4.6vw,64px) clamp(40px,5vw,76px);
  box-shadow:var(--shadow-md);
}
.cta-deco{
  position:absolute; top:50%; right:-110px; transform:translateY(-50%);
  width:430px; height:430px; border-radius:50%;
  background:radial-gradient(circle at 35% 40%, var(--green-mid), var(--green) 70%);
  filter:blur(2px); z-index:1; pointer-events:none;
}
.cta-banner > *:not(.cta-deco){ position:relative; z-index:2; }
.cta-icon{ flex:0 0 auto; width:82px; height:82px; display:grid; place-items:center; color:var(--green); }
.cta-icon svg{ width:44px; height:44px; }
.cta-rule{ flex:0 0 auto; width:1px; height:104px; background:rgba(38,48,24,.28); }
.cta-headings{ flex:0 0 auto; }
.cta-title{ font-family:var(--display); font-weight:400; text-transform:uppercase; font-size:clamp(34px,3.8vw,54px); line-height:.95; letter-spacing:.01em; color:var(--green); }
.cta-script{ display:block; font-family:"Caveat",cursive; font-weight:700; font-size:clamp(30px,3.3vw,46px); line-height:1; color:var(--green-bright); margin-top:4px; }
.cta-right{ margin-left:auto; max-width:480px; display:flex; flex-direction:column; gap:22px; }
.cta-support{ font-size:clamp(15px,1.15vw,17.5px); line-height:1.55; color:#5c5320; }
.cta-link{ display:inline-flex; align-items:center; gap:18px; width:max-content; }
.cta-circle{
  flex:0 0 auto; width:60px; height:60px; border-radius:50%; display:grid; place-items:center;
  background:var(--green); color:#f3f1e9; transition:transform .35s var(--ease), background .3s;
}
.cta-circle svg{ width:22px; height:22px; }
.cta-link:hover .cta-circle{ transform:translateX(4px); background:var(--green-mid); }
.cta-link-label{
  font-weight:800; font-size:clamp(13px,1vw,15px); letter-spacing:.13em; text-transform:uppercase; color:var(--green);
  padding-bottom:4px; background:linear-gradient(var(--green),var(--green)) left bottom / 0% 2px no-repeat; transition:background-size .4s var(--ease);
}
.cta-link:hover .cta-link-label{ background-size:100% 2px; }
@media (max-width:900px){
  .cta-banner{ flex-wrap:wrap; gap:20px 24px; }
  .cta-rule{ display:none; }
  .cta-right{ margin-left:0; flex-basis:100%; max-width:none; }
  .cta-deco{ right:-160px; }
}
@media (max-width:540px){
  .cta-icon{ width:52px; height:52px; }
}

/* =========================================================
   SERVICES PAGE
   ========================================================= */
.page-hero{ position:relative; padding-block:clamp(140px,15vw,206px) clamp(56px,7vw,92px); background:var(--cream); overflow:hidden; }
.page-hero .container{ position:relative; z-index:2; }
.page-hero-inner{ max-width:880px; }
.page-hero h1{ margin:22px 0 0; }
.page-hero .lede{ margin-top:26px; max-width:60ch; }
.page-hero-actions{ display:flex; gap:14px; margin-top:36px; flex-wrap:wrap; }
.crumb{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); display:flex; gap:11px; align-items:center; }
.crumb a{ transition:color .25s; }
.crumb a:hover{ color:var(--clay); }
.crumb .sep{ width:5px; height:5px; border-radius:50%; background:var(--line); }
.page-hero .p-ring{ position:absolute; border-radius:50%; z-index:1; pointer-events:none; }
.page-hero .p-ring--1{ width:210px; height:210px; border:24px solid var(--gold); opacity:.5; top:clamp(150px,20vh,220px); right:7%; }
.page-hero .p-ring--2{ width:120px; height:120px; background:var(--clay); opacity:.16; bottom:-30px; right:24%; }
.page-hero .p-dots{ position:absolute; z-index:1; display:grid; grid-template-columns:repeat(6,8px); gap:11px; bottom:18%; right:5%; }
.page-hero .p-dots i{ width:8px; height:8px; border-radius:50%; background:var(--green); opacity:.4; }

.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc-card{
  position:relative; display:flex; flex-direction:column;
  padding:36px 32px 34px; border-radius:var(--radius-lg);
  background:var(--paper); border:1px solid var(--line); overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s;
}
.svc-card::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:4px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.svc-card:nth-child(3n+2)::after{ background:var(--clay); }
.svc-card:nth-child(3n)::after{ background:var(--green-bright); }
.svc-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); border-color:transparent; }
.svc-card:hover::after{ transform:scaleX(1); }
.svc-num{ position:absolute; top:30px; right:30px; font-family:var(--display); font-size:34px; line-height:1; color:var(--cream-deep); -webkit-text-stroke:1px var(--line); }
.svc-ic{ width:58px; height:58px; border-radius:15px; background:var(--cream); display:grid; place-items:center; color:var(--green); margin-bottom:22px; transition:transform .5s var(--ease); }
.svc-card:hover .svc-ic{ transform:scale(1.08) rotate(-4deg); }
.svc-card h3{ font-size:22px; font-weight:800; letter-spacing:-.015em; }
.svc-card > p{ margin-top:12px; color:var(--muted); font-size:15px; }
.svc-list{ list-style:none; margin-top:24px; padding-top:22px; border-top:1px solid var(--line-soft); display:grid; gap:11px; }
.svc-list li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; color:var(--ink-soft); }
.svc-list li svg{ flex:0 0 auto; margin-top:3px; color:var(--clay); }

.svc-feature{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center; }
.svc-feature.rev .svc-feature-media{ order:2; }
.svc-feature + .svc-feature{ margin-top:clamp(54px,7vw,104px); }
.svc-feature-media .ph{ aspect-ratio:4/3.2; border-radius:var(--radius-lg); }
.svc-feature h3{ font-size:clamp(26px,3vw,40px); font-weight:800; letter-spacing:-.02em; margin:18px 0 0; line-height:1.05; }
.svc-feature p{ margin-top:18px; color:var(--muted); max-width:52ch; }
.svc-feature .svc-meta{ display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }

.includes-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; margin-top:54px; }
.include{ }
.include .ic{ width:50px; height:50px; border-radius:13px; background:rgba(255,255,255,.08); display:grid; place-items:center; color:var(--gold); margin-bottom:18px; }
.include h4{ font-size:17px; font-weight:800; color:#f2efe5; letter-spacing:-.01em; }
.include p{ margin-top:9px; font-size:14.5px; color:#b9bbab; line-height:1.55; }

@media (max-width:1024px){
  .svc-grid{ grid-template-columns:1fr 1fr; }
  .svc-feature{ grid-template-columns:1fr; }
  .svc-feature.rev .svc-feature-media{ order:0; }
  .includes-grid{ grid-template-columns:1fr 1fr; gap:30px 26px; }
}
@media (max-width:600px){
  .svc-grid{ grid-template-columns:1fr; }
  .includes-grid{ grid-template-columns:1fr; }
}

/* --- interactive services explorer (distinct from homepage) --- */
.svc-explorer{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:clamp(34px,5vw,82px); align-items:start; }
.svc-ex-aside{ position:sticky; top:108px; }
.svc-ex-aside h2{ margin:16px 0 28px; }
.svc-ex-nav{ list-style:none; display:flex; flex-direction:column; }
.svc-ex-tab{
  width:100%; display:flex; align-items:center; gap:16px; padding:19px 6px;
  border-top:1px solid var(--line); text-align:left; color:var(--muted);
  transition:color .3s var(--ease), padding .3s var(--ease);
}
.svc-ex-nav li:last-child .svc-ex-tab{ border-bottom:1px solid var(--line); }
.svc-ex-tab .n{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; transition:color .3s; }
.svc-ex-tab .t{ font-family:var(--display); text-transform:uppercase; font-size:clamp(19px,1.9vw,27px); line-height:1; color:inherit; flex:1; letter-spacing:.01em; }
.svc-ex-tab .ex-chev{ opacity:0; transform:translateX(-8px); transition:.35s var(--ease); color:var(--clay); }
.svc-ex-tab:hover{ color:var(--ink); padding-left:12px; }
.svc-ex-tab.active{ color:var(--green); padding-left:12px; }
.svc-ex-tab.active .n{ color:var(--clay); }
.svc-ex-tab.active .t{ color:var(--green); }
.svc-ex-tab.active .ex-chev{ opacity:1; transform:none; }
.svc-ex-hint{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-top:22px; }

.svc-ex-panels{ position:relative; min-height:440px; }
.svc-ex-panel{ display:none; }
.svc-ex-panel.active{ display:block; }
.svc-ex-panel.anim{ animation:svcPanelIn .55s var(--ease); }
@keyframes svcPanelIn{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .svc-ex-panel.anim{ animation:none; } }
.svc-ex-panel .ph{ aspect-ratio:16/8.4; border-radius:var(--radius-lg); margin-bottom:30px; }
.svc-ex-head{ display:flex; align-items:baseline; gap:16px; flex-wrap:wrap; }
.svc-ex-panel h3{ font-size:clamp(28px,3.2vw,42px); font-weight:800; letter-spacing:-.02em; line-height:1; }
.svc-ex-panel .p-num{ font-family:var(--mono); font-size:13px; color:var(--clay); letter-spacing:.1em; }
.svc-ex-panel .p-lead{ margin-top:18px; color:var(--ink-soft); max-width:58ch; font-size:clamp(16px,1.25vw,18px); }
.svc-deliver{ list-style:none; margin-top:30px; display:grid; grid-template-columns:1fr 1fr; gap:0 36px; }
.svc-deliver li{ display:flex; gap:12px; align-items:flex-start; font-size:15px; color:var(--ink-soft); padding:14px 0; border-top:1px solid var(--line-soft); }
.svc-deliver li svg{ flex:0 0 auto; margin-top:3px; color:var(--clay); }
.svc-panel-foot{ margin-top:30px; display:flex; gap:10px 24px; flex-wrap:wrap; align-items:center; }
.svc-panel-foot .svc-meta{ display:flex; flex-wrap:wrap; gap:8px; }
@media (max-width:900px){
  .svc-explorer{ grid-template-columns:1fr; gap:30px; overflow-x:clip; }
  .svc-ex-aside, .svc-ex-panels{ position:static; min-width:0; }
  .svc-ex-aside h2{ font-size:clamp(30px,8vw,44px); margin:14px 0 22px; }
  .svc-ex-aside h2 .d-br{ display:none; }
  .svc-ex-nav{ flex-direction:row; flex-wrap:wrap; gap:9px; max-width:100%; }
  .svc-ex-tab{ border:1.5px solid var(--line) !important; border-radius:100px; padding:11px 17px; width:auto; flex:0 0 auto; }
  .svc-ex-tab:hover, .svc-ex-tab.active{ padding-left:17px; }
  .svc-ex-tab .t{ font-family:var(--sans); font-size:14px; font-weight:700; text-transform:none; letter-spacing:0; }
  .svc-ex-tab .n, .svc-ex-tab .ex-chev{ display:none; }
  .svc-ex-tab.active{ background:var(--green); border-color:var(--green) !important; }
  .svc-ex-tab.active .t{ color:#fff; }
  .svc-ex-hint{ margin-top:18px; }
  .svc-ex-panels{ min-height:0; }
  .svc-deliver{ grid-template-columns:1fr; }
}

/* centered section header (services page) */
.head-center{ max-width:680px; margin:0 auto clamp(44px,6vw,66px); text-align:center; }
.head-center .lede{ margin:22px auto 0; }

/* =========================================================
   SERVICES — BOLD NUMBERED LAYOUT (popwebdesign style)
   ========================================================= */
.svc-hero-v2{
  position:relative; overflow:hidden;
  padding-block:clamp(72px,8vw,130px) clamp(40px,4vw,64px);
  background:#060a07;
}
.svc-hero-v2 .container{ position:relative; z-index:2; }
.svc-hero-v2 .crumb{ margin-bottom:clamp(18px,3vw,36px); }
.svh2-inner{ max-width:1100px; }
.svh2-title{
  font-size:clamp(40px,9vw,148px);
  line-height:.88; letter-spacing:-.01em;
  margin:clamp(14px,2vw,28px) 0 clamp(18px,2.5vw,36px);
}
.svh2-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:clamp(22px,3vw,40px); }
.svh2-jumps{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-top:clamp(24px,4vw,64px); padding-top:clamp(18px,3vw,48px);
  border-top:1px solid var(--line);
}
.svh2-jump{
  font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  padding:9px 16px; border-radius:100px; border:1.5px solid var(--line);
  color:var(--ink-soft); transition:border-color .3s, color .3s, background .3s;
}
.svh2-jump:hover{ border-color:var(--green); color:var(--green); background:rgba(38,48,24,.05); }

/* Decorative deco behind hero title */
.svc-hero-v2::before{
  content:""; position:absolute; right:-180px; top:50%; transform:translateY(-50%);
  width:clamp(340px,44vw,640px); height:clamp(340px,44vw,640px); border-radius:50%;
  border:1.5px dashed rgba(38,48,24,.1); pointer-events:none; z-index:1;
}
.svc-hero-v2::after{
  content:""; position:absolute; right:60px; top:45%; transform:translateY(-50%);
  width:clamp(180px,22vw,320px); height:clamp(180px,22vw,320px); border-radius:50%;
  border:1.5px dashed rgba(246,169,26,.14); pointer-events:none; z-index:1;
}

/* Dark hero text overrides */
.svc-hero-v2 .crumb,
.svc-hero-v2 .crumb a{ color:rgba(242,239,229,.45); }
.svc-hero-v2 .crumb a:hover{ color:var(--gold); }
.svc-hero-v2 .crumb .sep{ background:rgba(242,239,229,.22); }
.svc-hero-v2 .kicker{ color:var(--gold); }
.svc-hero-v2 .kicker::before{ background:var(--gold); }
.svc-hero-v2 .svh2-title{ color:#f2efe5; }
.svc-hero-v2 .lede{ color:rgba(242,239,229,.62); }
.svc-hero-v2 .svh2-jumps{ border-top-color:rgba(242,239,229,.10); }
.svc-hero-v2 .svh2-jump{ border-color:rgba(242,239,229,.14); color:rgba(242,239,229,.45); }
.svc-hero-v2 .svh2-jump:hover{ border-color:var(--gold); color:var(--gold); background:rgba(246,169,26,.08); }
.svc-hero-v2::before{ border-color:rgba(92,114,50,.12); }

/* Canvas background for services hero */
.svc-canvas{
  position:absolute; inset:0;
  width:100%; height:100%;
  z-index:0; pointer-events:none; display:block;
}

/* Individual service block */
.svc-row{
  position:relative; overflow:hidden;
  padding-block:clamp(88px,12vw,160px);
  border-bottom:1px solid var(--line);
  background:var(--paper);
}
.svc-row:nth-child(even){ background:var(--cream); }
.svc-row-inner{
  display:grid;
  grid-template-columns:clamp(100px,14vw,200px) 1fr;
  gap:clamp(40px,7vw,108px);
  align-items:start;
}
.svc-row-head{
  display:flex; flex-direction:column; gap:12px;
  padding-top:clamp(8px,1.5vw,20px);
  position:sticky; top:108px;
}
.svc-row-num{
  font-family:var(--display); font-size:clamp(64px,9vw,120px);
  line-height:.82; color:var(--cream-deep);
  -webkit-text-stroke:1.5px rgba(27,33,19,.18);
  transition:color .5s var(--ease), -webkit-text-stroke-color .5s;
}
.svc-row:hover .svc-row-num{ color:transparent; -webkit-text-stroke-color:var(--gold); }
.svc-row:nth-child(even) .svc-row-num{
  color:rgba(255,255,255,.0);
  -webkit-text-stroke-color:rgba(27,33,19,.16);
}

.svc-row-title{
  font-size:clamp(50px,8.5vw,116px);
  line-height:.86; margin:0 0 26px;
}
.svc-row-desc{ max-width:56ch; font-size:clamp(16px,1.3vw,19px); color:var(--ink-soft); line-height:1.7; }

.svc-row-feats{
  list-style:none; margin:30px 0 38px;
  display:grid; grid-template-columns:1fr 1fr; gap:0 clamp(20px,4vw,52px);
}
.svc-row-feats li{
  display:flex; gap:13px; align-items:flex-start;
  padding:14px 0; border-top:1px solid var(--line-soft);
  font-size:15px; color:var(--ink-soft);
}
.svc-row-feats li svg{ flex:0 0 auto; margin-top:3px; color:var(--clay); }

.svc-row-link{
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--display); font-size:clamp(18px,2vw,26px);
  text-transform:uppercase; letter-spacing:.02em; color:var(--green);
  transition:gap .4s var(--ease), color .3s;
}
.svc-row-link .arr-circle{
  width:52px; height:52px; border-radius:50%; border:2px solid var(--green);
  display:grid; place-items:center; transition:background .35s, transform .35s var(--ease);
  flex:0 0 auto;
}
.svc-row-link:hover{ gap:22px; color:var(--gold); }
.svc-row-link:hover .arr-circle{ background:var(--green); transform:rotate(45deg); }
.svc-row-link .arr-circle svg{ color:var(--green); transition:color .35s; }
.svc-row-link:hover .arr-circle svg{ color:#fff; }

/* Ghost number watermark */
.svc-row-ghost{
  position:absolute; right:-0.06em; bottom:-0.28em;
  font-family:var(--display); text-transform:uppercase;
  font-size:clamp(180px,30vw,460px); line-height:1;
  color:transparent; -webkit-text-stroke:1.5px rgba(27,33,19,.05);
  user-select:none; pointer-events:none; z-index:0; letter-spacing:-.02em;
}
.svc-row > .container{ position:relative; z-index:1; }

/* Stats bar between hero and service rows */
.svc-stats-bar{
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(242,239,229,.09); background:rgba(0,0,0,0); color:#f2efe5;
}
/* When inside the dark hero, inherit the canvas BG seamlessly */
.svc-hero-v2 .svc-stats-bar{
  position:relative; z-index:2;
}
.svc-stat-item{
  padding:clamp(26px,3.5vw,44px) 24px; text-align:center;
  border-right:1px solid rgba(255,255,255,.12);
}
.svc-stat-item:last-child{ border-right:none; }
.svc-stat-val{
  font-family:var(--display); font-size:clamp(38px,5.5vw,72px);
  line-height:.9; color:var(--gold); display:block;
}
.svc-stat-lbl{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:rgba(242,239,229,.6);
  display:block; margin-top:10px;
}

/* =========================================================
   SERVICES HERO v3 — light bg, text left / animated graphic right
   ========================================================= */
.svc-hero-v3{
  position:relative; overflow:hidden;
  background:#fff;
  padding-block:clamp(110px,12vw,160px) clamp(60px,6vw,90px);
}
.svc-h3-canvas{
  position:absolute; inset:0; width:100%; height:100%;
  z-index:0; display:block;
}
.svc-h3-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,80px); align-items:center;
  position:relative; z-index:1;
}
.svc-h3-copy .crumb{ margin-bottom:28px; }
.svc-h3-copy .kicker{ margin-bottom:20px; }
.svc-h3-title{
  font-size:clamp(44px,7vw,110px);
  line-height:.88; letter-spacing:-.02em;
  margin:16px 0 28px;
}
.svc-h3-copy .lede{ max-width:48ch; }
.svc-h3-copy .svh2-actions{ margin-top:32px; }
.svc-h3-copy .svh2-jumps{
  margin-top:clamp(24px,4vw,48px);
  padding-top:clamp(18px,2.5vw,32px);
}
.svc-h3-gfx{
  display:flex; align-items:center; justify-content:center;
}
.svc-hero-svg{ width:100%; max-width:520px; height:auto; }

/* Floating keyframes */
@keyframes svgFloatA{
  0%,100%{ transform:translateY(0px); }
  50%{ transform:translateY(-18px); }
}
@keyframes svgFloatB{
  0%,100%{ transform:translateY(0px) rotate(0deg); }
  50%{ transform:translateY(-12px) rotate(4deg); }
}
@keyframes svgFloatC{
  0%,100%{ transform:translateY(0px) translateX(0px); }
  33%{ transform:translateY(-10px) translateX(6px); }
  66%{ transform:translateY(-6px) translateX(-4px); }
}
@keyframes svgFloatD{
  0%,100%{ transform:translateX(0px); }
  50%{ transform:translateX(10px); }
}
@keyframes svgPulse{
  0%,100%{ transform:scale(1); opacity:.7; }
  50%{ transform:scale(1.08); opacity:1; }
}
@keyframes svgSpin{
  to{ transform:rotate(360deg); }
}
@keyframes svgSpinR{
  to{ transform:rotate(-360deg); }
}
.svg-fa{ animation:svgFloatA 4.2s ease-in-out infinite; }
.svg-fb{ animation:svgFloatB 5.6s ease-in-out infinite 0.8s; }
.svg-fc{ animation:svgFloatC 4s ease-in-out infinite 1.4s; }
.svg-fd{ animation:svgFloatD 4.8s ease-in-out infinite 0.4s; }
.svg-fe{ animation:svgFloatA 3.5s ease-in-out infinite 2s; }
.svg-ff{ animation:svgFloatB 6s ease-in-out infinite 1.2s; }
.svg-pulse{ animation:svgPulse 3.2s ease-in-out infinite; }
.svg-spin{ animation:svgSpin 22s linear infinite; }
.svg-spinr{ animation:svgSpinR 18s linear infinite; }

@media(max-width:860px){
  .svc-h3-grid{ grid-template-columns:1fr; }
  .svc-h3-gfx{ margin-top:32px; max-width:400px; margin-inline:auto; }
  .svc-h3-copy .svh2-jumps{ display:none; }
}
@media(max-width:540px){
  .svc-hero-v3{ padding-block:88px 40px; }
  .svc-h3-title{ font-size:clamp(36px,10vw,52px); }
  .svc-h3-gfx{ max-width:300px; }
}

/* =========================================================
   SERVICES v2 — popwebdesign full-width numbered layout
   ========================================================= */
.svc2-row{
  position:relative; overflow:hidden;
  padding-block:clamp(56px,7vw,100px);
  border-bottom:1px solid var(--line);
  background:var(--paper);
}
.svc2-row:nth-child(even){ background:var(--cream); }

/* Header band: number + full-width title */
.svc2-head{
  display:flex; align-items:flex-end;
  gap:clamp(14px,2vw,26px);
  padding-bottom:clamp(20px,2.5vw,36px);
  border-bottom:1.5px solid var(--line);
  margin-bottom:clamp(32px,4.5vw,60px);
}
.svc2-num{
  font-family:var(--mono); font-size:12px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-soft);
  padding-bottom:.3em; flex-shrink:0; line-height:1;
}
.svc2-title{
  font-family:var(--display); font-size:clamp(48px,8.5vw,132px);
  line-height:.86; letter-spacing:-.022em; text-transform:uppercase;
  color:var(--green); flex:1; word-break:break-word;
}

/* Two-column body */
.svc2-body{
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(28px,6vw,96px); align-items:start;
}
.svc2-desc{
  font-size:clamp(16px,1.3vw,19px); color:var(--ink-soft);
  line-height:1.72; max-width:52ch;
}
.svc2-link{
  display:inline-flex; align-items:center; gap:14px;
  margin-top:clamp(24px,3vw,40px);
  font-family:var(--display); font-size:clamp(15px,1.2vw,18px);
  text-transform:uppercase; letter-spacing:.04em; color:var(--green);
  transition:gap .3s;
}
.svc2-link:hover{ gap:22px; }
.svc2-link .arr-circle{ flex-shrink:0; }

/* Feature list */
.svc2-feats{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column;
}
.svc2-feats li{
  font-size:clamp(14px,1.1vw,16px); color:var(--ink);
  padding:13px 0; border-bottom:1px solid var(--line);
  display:flex; align-items:center; gap:14px; line-height:1.4;
}
.svc2-feats li:first-child{ border-top:1px solid var(--line); }
.svc2-feats li svg{ flex-shrink:0; color:var(--gold); }

/* Ghost watermark number */
.svc2-ghost{
  position:absolute; right:-0.08em; bottom:-0.12em;
  font-family:var(--display); font-size:clamp(200px,28vw,380px);
  line-height:1; text-transform:uppercase;
  color:transparent; -webkit-text-stroke:1.5px var(--line);
  pointer-events:none; z-index:0; user-select:none; opacity:.55;
}

/* Responsive */
@media(max-width:768px){
  .svc2-body{ grid-template-columns:1fr; }
  .svc2-title{ font-size:clamp(38px,9vw,72px); }
  .svc2-ghost{ font-size:clamp(120px,30vw,200px); }
}
@media(max-width:480px){
  .svc2-title{ font-size:clamp(32px,10vw,52px); }
}

/* Service-page-specific process + CTA */
.svc-process-v2{ background:var(--green); color:#f2efe5; }
.svc-process-v2 .kicker{ color:var(--gold); }
.svc-process-v2 .kicker::before{ background:var(--gold); }
.svc-process-v2 .process-step{ border-top-color:rgba(255,255,255,.12); }
.svc-process-v2 .process-step:last-child{ border-bottom-color:rgba(255,255,255,.12); }
.svc-process-v2 .process-step .ps-num{ color:rgba(255,255,255,.14); -webkit-text-stroke-color:rgba(255,255,255,.2); }
.svc-process-v2 .process-step:hover .ps-num{ color:var(--gold); -webkit-text-stroke:0; }
.svc-process-v2 .process-step .ps-body h3{ color:#f2efe5; }
.svc-process-v2 .process-step .ps-body p{ color:rgba(242,239,229,.6); }
.svc-process-v2 .tag{ border-color:rgba(255,255,255,.15); color:rgba(242,239,229,.65); }
.svc-process-v2 .process-step:hover .tag{ border-color:var(--gold); color:var(--gold); }

/* Responsive */
@media (max-width:960px){
  .svc-row-inner{ grid-template-columns:1fr; gap:30px; }
  .svc-row-head{ position:static; flex-direction:row; align-items:center; gap:20px; }
  .svc-row-num{ font-size:clamp(44px,8vw,80px); }
  .svc-stats-bar{ grid-template-columns:1fr 1fr; }
  .svc-stat-item:nth-child(2){ border-right:none; }
  .svc-stat-item:nth-child(1),.svc-stat-item:nth-child(2){ border-bottom:1px solid rgba(255,255,255,.12); }
  .svh2-title{ font-size:clamp(48px,9vw,88px); }
}
@media (max-width:600px){
  .svc-row-feats{ grid-template-columns:1fr; }
  .svc-row-ghost{ display:none; }
  .svc-stats-bar{ grid-template-columns:1fr 1fr; }
  .svc-hero-v2{ padding-block:80px 32px; }
  .svh2-title{ font-size:clamp(34px,9vw,48px); }
  .svh2-jumps{ display:none; }
  .svh2-actions{ gap:10px; }
}

/* =========================================================
   FINAL CTA
   ========================================================= */
.final{ position:relative; background:var(--green); color:#f2efe5; overflow:hidden; text-align:center; }
.final .container{ position:relative; z-index:2; }
.final h2{ margin:22px auto 0; max-width:16ch; }
.final p{ margin:24px auto 0; max-width:50ch; color:#c5c7b6; }
.final-actions{ display:flex; justify-content:center; gap:14px; margin-top:40px; flex-wrap:wrap; }
.final .glow{ position:absolute; width:620px; height:620px; border-radius:50%; filter:blur(20px); opacity:.5; z-index:1; }
.final .glow.g1{ background:radial-gradient(circle, rgba(246,169,26,.34), transparent 60%); top:-280px; left:-120px; }
.final .glow.g2{ background:radial-gradient(circle, rgba(196,75,28,.3), transparent 60%); bottom:-300px; right:-120px; }
.final .ring{ position:absolute; border-radius:50%; border:1px solid rgba(255,255,255,.12); z-index:1; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:#1a2012; color:#c5c7b6; padding-block:clamp(56px,7vw,84px) 0; }
.footer-top{ display:grid; grid-template-columns:1.7fr 1fr 1.15fr 1fr; gap:clamp(32px,5vw,64px); padding-bottom:46px; }
.footer-logo{ height:64px; width:auto; margin-bottom:26px; }
.footer-brand p{ max-width:38ch; font-size:15px; line-height:1.7; color:#a7ab9b; }
.footer-contact{ display:flex; flex-direction:column; gap:10px; margin-top:26px; }
.footer-contact a, .footer-contact span{ color:#c8cbbb; font-size:15px; width:max-content; transition:color .25s; }
.footer-contact a:hover{ color:var(--gold); }
.footer h5{ font-family:var(--sans); font-weight:800; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:#f3f1e9; margin-bottom:22px; }
.footer-col{ display:flex; flex-direction:column; gap:2px; }
.footer-col a{ color:#a7ab9b; font-size:15px; padding:7px 0; transition:color .25s, transform .25s; width:max-content; }
.footer-col a:hover{ color:#fff; transform:translateX(4px); }
.footer-bottom{
  display:flex; align-items:center; gap:16px; padding:22px 0 30px;
  border-top:1px solid rgba(255,255,255,.1); flex-wrap:wrap;
}
.footer-mark{ height:34px; width:auto; flex:0 0 auto; }
.footer-copy{ font-size:13.5px; color:#8a8d7e; }
.footer-tag{ font-size:13.5px; font-weight:700; color:var(--gold); }

.to-top{
  position:fixed; right:26px; bottom:26px; z-index:80;
  width:52px; height:52px; border-radius:50%; display:grid; place-items:center;
  background:var(--green); color:#f3f1e9; box-shadow:var(--shadow-md);
  opacity:0; visibility:hidden; transform:translateY(14px);
  transition:opacity .35s var(--ease), transform .35s var(--ease), background .3s, visibility .35s;
}
.to-top.show{ opacity:1; visibility:visible; transform:none; }
.to-top:hover{ background:var(--gold); color:var(--green); }
@media (max-width:768px){ .to-top{ right:16px; bottom:16px; } }


/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .hero-grid{ padding-top:140px; }
  .intro-grid, .showcase-grid, .faq-grid, .contact-grid{ grid-template-columns:1fr; }
  .why-grid{ grid-template-columns:1fr 1fr; }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1 / -1; }
  .intro-figure{ max-width:440px; }
}
@media (max-width:768px){
  .nav, .header-cta .btn{ display:none; }
  .hero-slide{ background-size:cover; background-position:72% center; }
  .hero-scrim{ background:linear-gradient(180deg, rgba(246,244,237,.92) 0%, rgba(246,244,237,.7) 42%, rgba(246,244,237,.86) 100%); }
  .menu-toggle{ display:flex; }
  .nav.open{
    display:flex; position:fixed; inset:0; flex-direction:column; justify-content:center; gap:14px;
    background:rgba(255,255,255,.97); backdrop-filter:blur(8px); z-index:90;
  }
  .nav.open a{ font-size:26px; font-family:var(--display); text-transform:uppercase; }
  .nav.open a::after{ display:none; }
  .why-grid{ grid-template-columns:1fr; }
  .process-step{ grid-template-columns:64px 1fr; }
  .process-step .ps-tags{ display:none; }
  .showcase-results{ grid-template-columns:repeat(3,1fr); gap:12px; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:34px 28px; }
  .hero-trust .t-div:last-of-type{ display:none; }
}
@media (max-width:540px){
  .footer-top{ grid-template-columns:1fr; gap:30px; }
  .footer-logo{ height:54px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:12px; padding:22px 0 26px; }
  .footer-tag{ order:-1; }
  .hero-actions .btn{ width:100%; justify-content:center; }
  .showcase-results{ grid-template-columns:1fr 1fr; }
}

/* =========================================================
   SHARED FORM STYLES — Contact + Brief
   ========================================================= */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px 22px; }
.field { display:flex; flex-direction:column; gap:7px; }
.field.full { grid-column:1/-1; }
.field label, .brief-legend { font-size:14px; font-weight:700; letter-spacing:-.01em; color:var(--ink); }
.field input, .field select, .field textarea {
  font-family:var(--sans); font-size:15.5px; color:var(--ink);
  background:var(--cream); border:1.5px solid var(--line);
  border-radius:11px; padding:14px 17px; outline:none;
  transition:border-color .3s var(--ease-soft), box-shadow .3s var(--ease-soft);
  width:100%; appearance:none; -webkit-appearance:none;
}
.field textarea { min-height:128px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  border-color:var(--green); box-shadow:0 0 0 3px rgba(38,48,24,.09);
}
.field input[aria-invalid="true"], .field select[aria-invalid="true"], .field textarea[aria-invalid="true"] {
  border-color:var(--clay);
}
.field.invalid label { color:var(--clay); }
.field select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236a715c' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:42px;
}
.form-note { font-size:12.5px; }
.form-note.err { color:var(--clay); }
.form-alert { padding:16px 22px; border-radius:var(--radius); font-size:15px; font-weight:600; margin-bottom:28px; }
.form-alert.success { background:#e8f5e8; color:#1a5c1a; border:1.5px solid #a8d5a8; }
.form-alert.error   { background:#fdf0ed; color:#a02b0c; border:1.5px solid #f5c4b3; }

/* =========================================================
   CONTACT PAGE
   ========================================================= */
.contact-layout { display:grid; grid-template-columns:1fr 1.55fr; gap:clamp(40px,6vw,80px); align-items:start; }
.contact-detail h5 { font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--clay); font-weight:700; margin-bottom:8px; }
.contact-detail a, .contact-detail p { font-size:17px; color:var(--ink-soft); transition:color .25s; }
.contact-detail a:hover { color:var(--clay); }
.contact-socials { display:flex; gap:10px; margin-top:10px; }
.c-social { width:42px; height:42px; border-radius:11px; border:1.5px solid var(--line); display:grid; place-items:center; color:var(--green); transition:.3s; }
.c-social:hover { background:var(--green); color:#fff; border-color:var(--green); }
.contact-form-wrap { background:var(--paper); border-radius:var(--radius-lg); padding:clamp(30px,4vw,52px); box-shadow:var(--shadow-sm); border:1px solid var(--line-soft); }

/* =========================================================
   ABOUT PAGE
   ========================================================= */
.about-mission { display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:54px; }
.mission-card { padding:36px 40px; background:rgba(255,255,255,.07); border-radius:var(--radius-lg); border:1px solid rgba(255,255,255,.12); }
.mission-card .mc-label { font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:16px; font-weight:700; }
.mission-card h3 { font-size:clamp(22px,2.2vw,30px); font-weight:800; color:#f2efe5; letter-spacing:-.02em; margin-bottom:16px; line-height:1.15; }
.mission-card p { color:#c5c7b6; font-size:16.5px; line-height:1.7; }

/* =========================================================
   BRIEF FORM
   ========================================================= */
.brief-intro-section { background:var(--cream); padding-block:clamp(100px,12vw,160px) clamp(48px,6vw,72px); }
.brief-intro { max-width:720px; margin:0 auto; text-align:center; }
.brief-intro-logo { height:52px; width:auto; margin:0 auto 30px; display:block; }
.brief-intro p { font-size:clamp(16px,1.35vw,19px); color:var(--muted); max-width:58ch; margin:0 auto; }
.brief-section-wrap { padding-block:clamp(48px,6vw,80px); }
.brief-wrap { max-width:840px; margin:0 auto; }
.brief-section { background:var(--paper); border-radius:var(--radius-lg); padding:clamp(28px,4vw,52px); border:1px solid var(--line); margin-bottom:24px; }
.wizard .brief-section { display:none; }
.wizard .brief-section.is-active { display:block; animation:svcPanelIn .45s var(--ease); }
.phase-head { padding-bottom:24px; border-bottom:1px solid var(--line); margin-bottom:30px; }
.phase-step-label { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.phase-title { font-size:clamp(20px,2.2vw,28px); font-weight:800; letter-spacing:-.02em; color:var(--ink); }
.phase-desc { margin-top:7px; color:var(--muted); font-size:15px; }
.phase-group { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--clay); font-weight:700; margin:30px 0 14px; }
.brief-legend { display:block; font-size:14px; font-weight:700; color:var(--ink); margin-bottom:12px; }
.field-intro { font-size:14px; color:var(--muted); margin-bottom:10px; line-height:1.55; }
.choice-grid { display:flex; flex-wrap:wrap; gap:9px; }
.choice { display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:100px; border:1.5px solid var(--line); cursor:pointer; font-size:14px; font-weight:600; color:var(--ink-soft); transition:border-color .25s, background .25s, color .25s; user-select:none; }
.choice:hover { border-color:var(--green-bright); color:var(--green); }
.choice input[type="checkbox"], .choice input[type="radio"] { position:absolute; opacity:0; width:0; height:0; }
.choice:has(input:checked) { background:var(--green); border-color:var(--green); color:#fff; }
.brief-nav { display:flex; align-items:center; justify-content:space-between; margin-top:30px; padding-top:24px; border-top:1px solid var(--line); gap:14px; flex-wrap:wrap; }
.brief-nav-right { display:flex; align-items:center; gap:14px; }
.brief-back { display:inline-flex; align-items:center; gap:7px; font-size:15px; font-weight:700; color:var(--muted); padding:10px 0; transition:color .25s; font-family:var(--sans); background:none; border:none; cursor:pointer; }
.brief-back:hover { color:var(--ink); }
.brief-send { display:inline-flex; align-items:center; justify-content:center; gap:9px; padding:16px 32px; border-radius:100px; background:var(--gold); color:var(--green); font-size:15px; font-weight:800; letter-spacing:.01em; transition:background .3s, transform .3s var(--ease), box-shadow .3s; cursor:pointer; border:none; font-family:var(--sans); }
.brief-send:hover { background:var(--gold-deep); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.brief-confirm { text-align:center; font-size:13.5px; color:var(--muted); margin-top:14px; }
/* Progress bar */
.phase-progress { position:sticky; top:72px; z-index:50; background:rgba(255,255,255,.94); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); margin-bottom:32px; }
.pp-steps { list-style:none; display:flex; overflow-x:auto; scrollbar-width:none; padding:0; }
.pp-steps::-webkit-scrollbar { display:none; }
.pp-step { flex:1; min-width:0; }
.pp-btn { width:100%; display:flex; flex-direction:column; align-items:center; gap:5px; padding:12px 6px; font-size:11px; color:var(--muted); background:none; border:none; cursor:pointer; transition:color .25s; font-family:var(--sans); }
.pp-btn:disabled { opacity:.35; cursor:not-allowed; }
.pp-marker { width:28px; height:28px; border-radius:50%; display:grid; place-items:center; font-size:12px; font-weight:800; background:var(--cream); color:var(--muted); transition:.3s; flex:0 0 auto; }
.pp-step.is-current .pp-btn { color:var(--green); }
.pp-step.is-current .pp-marker { background:var(--green); color:#fff; }
.pp-step.is-done .pp-marker { background:var(--clay); color:#fff; }
.pp-label { font-family:var(--mono); font-size:10px; letter-spacing:.07em; text-transform:uppercase; line-height:1.3; text-align:center; }
.pp-mobile { display:none; padding:10px 0; }

/* =========================================================
   404 PAGE
   ========================================================= */
.deco-circle { position:absolute; border-radius:50%; z-index:0; pointer-events:none; }
.deco-circle.c1 { width:500px; height:500px; background:radial-gradient(circle, rgba(246,169,26,.18), transparent 65%); top:-100px; right:-80px; }
.deco-circle.c2 { width:320px; height:320px; background:radial-gradient(circle, rgba(196,75,28,.14), transparent 65%); bottom:0; left:4%; }
.error-code { font-family:var(--display); font-size:clamp(120px,20vw,240px); line-height:.8; color:var(--cream-deep); -webkit-text-stroke:2px var(--line); display:block; margin:0 auto 18px; letter-spacing:-.02em; }

/* =========================================================
   RESPONSIVE ADDITIONS
   ========================================================= */
@media (max-width:1024px){
  .contact-layout { grid-template-columns:1fr; }
  .about-mission  { grid-template-columns:1fr; }
}
@media (max-width:700px){
  .pp-steps  { display:none; }
  .pp-mobile { display:block; }
  .pp-mobile-label { font-size:14px; font-weight:700; color:var(--ink); }
  .pp-mobile-bar   { height:4px; background:var(--cream-deep); border-radius:2px; margin-top:8px; overflow:hidden; }
  .pp-mobile-bar span { display:block; height:100%; background:var(--green); border-radius:2px; transition:width .4s var(--ease); width:16.67%; }
}
@media (max-width:640px){
  .form-grid { grid-template-columns:1fr; }
  .brief-nav { flex-direction:column-reverse; align-items:stretch; }
  .brief-nav-right { flex-direction:column; width:100%; }
  .brief-send, .brief-next { width:100%; justify-content:center; }
  .contact-form-wrap { padding:24px 18px; }
}

/* =========================================================
   SERVICES NEW — matches reference layout
   ========================================================= */

/* Shared kicker */
.sn-kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); margin-bottom:20px;
}

/* Gold italic emphasis — subtle shimmer pulse */
@keyframes snGoldGlow {
  0%,100% { color:var(--gold); text-shadow:none; }
  50%      { color:#f9c14a; text-shadow:0 0 22px rgba(246,169,26,.35); }
}
.sn-em{ font-style:normal; color:var(--gold); animation:snGoldGlow 3.2s ease-in-out infinite; }

/* ── HERO ── */
.sn-hero{
  background:var(--cream);
  padding-block: clamp(120px,14vw,180px) clamp(60px,7vw,100px);
  overflow:hidden;
}
.sn-hero__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,96px);
  align-items:center;
}
.sn-hero__h1{
  font-family:var(--display);
  font-size:clamp(40px,6vw,76px);
  line-height:1.05; letter-spacing:-.02em;
  color:var(--ink); margin:0 0 24px;
}
.sn-hero__sub{
  font-size:clamp(15px,1.5vw,17px); line-height:1.7;
  color:var(--ink); opacity:.72; max-width:44ch; margin:0 0 12px;
}
.sn-script{
  font-family:Georgia,'Times New Roman',serif;
  font-style:italic; font-size:clamp(18px,2.2vw,26px);
  color:var(--ink); opacity:.55; margin:16px 0 0; letter-spacing:.01em;
  display:inline-block; overflow:hidden; white-space:nowrap;
  width:0; border-right:2px solid rgba(38,48,24,.4);
  animation:snTypeIn 1.3s steps(27,end) 1s forwards,
            snCaretBlink .75s step-end 1s 4;
}
@keyframes snTypeIn   { to { width:100% } }
@keyframes snCaretBlink { 50% { border-right-color:transparent } }

/* Hero media */
.sn-hero__media{
  position:relative; height:480px;
}
.sn-brush{
  position:absolute; bottom:12%; right:-8%;
  width:90%; z-index:0; pointer-events:none;
}
.sn-hero__img-top{
  position:absolute; top:0; right:0;
  width:68%; height:73%;
  border-radius:20px; overflow:hidden;
  background:var(--green); z-index:2;
}
.sn-hero__img-top img{ width:100%; height:100%; object-fit:cover; opacity:.9; }
.sn-hero__img-bottom{
  position:absolute; bottom:0; left:0;
  width:58%; height:56%;
  border-radius:16px; overflow:hidden;
  z-index:3; box-shadow:0 12px 40px rgba(0,0,0,.18);
}
.sn-hero__img-bottom img{ width:100%; height:100%; object-fit:cover; }

/* Floating "Creative Meets Strategy" card */
.sn-float-card{
  position:absolute; right:-16px; top:42%;
  background:#fff; border-radius:12px;
  padding:10px 16px; z-index:10;
  font-size:12px; font-weight:700; color:var(--ink);
  box-shadow:0 8px 28px rgba(0,0,0,.13);
  white-space:nowrap; line-height:1.3;
}
.sn-float-card__plus{
  color:var(--gold); font-size:16px; font-weight:900;
}

/* Gold arrow box */
.sn-gold-box{
  position:absolute; bottom:4%; left:2%;
  width:52px; height:52px;
  background:var(--gold); border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:#fff; font-weight:700;
  z-index:10; box-shadow:0 6px 20px rgba(246,169,26,.4);
}

/* ── SERVICES LIST ── */
.sn-svc-list{
  background:var(--cream);
  padding-block:clamp(48px,6vw,80px);
}
.sn-svc-item{
  display:grid;
  grid-template-columns:72px 1fr 56px;
  align-items:center;
  gap:clamp(16px,2.5vw,32px);
  padding:clamp(20px,2.5vw,28px) 0;
  border-bottom:1px solid rgba(38,48,24,.1);
}
.sn-svc-item:first-child{ border-top:1px solid rgba(38,48,24,.1); }
.sn-svc-icon{
  width:60px; height:60px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.sn-svc-icon svg{ width:26px; height:26px; }
.sn-svc-icon--dark{ background:var(--green); }
.sn-svc-icon--gold{ background:var(--gold); }
.sn-svc-title{
  font-size:clamp(16px,1.6vw,20px); font-weight:700;
  color:var(--ink); margin:0 0 6px;
}
.sn-svc-desc{
  font-size:clamp(13px,1.2vw,15px); line-height:1.65;
  color:var(--ink); opacity:.65; margin:0; max-width:58ch;
}
.sn-svc-arr{
  width:48px; height:48px; border-radius:50%;
  background:var(--gold); color:#fff;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:transform .22s, background .22s;
  text-decoration:none;
}
.sn-svc-arr svg{ width:18px; height:18px; }
.sn-svc-arr:hover{ background:var(--green); transform:scale(1.08); }

/* ── CTA BANNER ── */
.sn-cta{
  background:var(--green);
  padding-block:clamp(60px,8vw,100px);
  overflow:hidden;
}
.sn-cta__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px);
  align-items:center;
}
.sn-cta__h2{
  font-family:var(--display);
  font-size:clamp(32px,4.5vw,60px);
  line-height:1.08; letter-spacing:-.02em;
  color:#fff; margin:0 0 20px;
}
.sn-cta__sub{
  font-size:clamp(14px,1.3vw,16px); line-height:1.7;
  color:rgba(255,255,255,.7); margin:0 0 32px;
}
.sn-cta__link{ color:var(--gold); text-decoration:none; font-weight:600; }
.sn-cta__link:hover{ text-decoration:underline; }
.sn-cta__btn{
  display:inline-flex; align-items:center; gap:10px;
  background:var(--gold); color:var(--green);
  font-weight:700; font-size:15px;
  padding:14px 28px; border-radius:8px;
  text-decoration:none; letter-spacing:.01em;
  transition:opacity .2s, transform .2s;
}
.sn-cta__btn:hover{ opacity:.88; transform:translateY(-1px); }

/* CTA media */
.sn-cta__media{
  position:relative; height:340px;
}
.sn-cta__ring{
  position:absolute; top:-30px; right:-30px;
  width:200px; height:200px; border-radius:50%;
  border:2px solid rgba(246,169,26,.25); z-index:0;
}
.sn-cta__img-back{
  position:absolute; top:0; right:0;
  width:75%; height:88%;
  border-radius:16px; overflow:hidden; z-index:1;
}
.sn-cta__img-back img{ width:100%; height:100%; object-fit:cover; }
.sn-cta__img-front{
  position:absolute; bottom:0; left:0;
  width:52%; height:56%;
  border-radius:12px; overflow:hidden;
  z-index:2; box-shadow:0 12px 36px rgba(0,0,0,.35);
}
.sn-cta__img-front img{ width:100%; height:100%; object-fit:cover; }

/* ── PROCESS ── */
.sn-process{
  background:var(--cream);
  padding-block:clamp(60px,8vw,100px);
}
.sn-process__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,96px);
  align-items:start;
}
.sn-process__h2{
  font-family:var(--display);
  font-size:clamp(32px,4.5vw,58px);
  line-height:1.08; letter-spacing:-.02em;
  color:var(--ink); margin:0 0 40px;
}
.sn-steps{ display:flex; flex-direction:column; }
.sn-step{
  display:grid; grid-template-columns:48px 1fr;
  gap:16px; padding:18px 0; position:relative;
}
.sn-step:not(:last-child)::after{
  content:''; position:absolute;
  left:22px; top:54px; bottom:-18px;
  width:1px; background:rgba(38,48,24,.15);
}
.sn-step__num{
  width:44px; height:44px; border-radius:50%;
  border:2px solid var(--green);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:800; color:var(--green);
  background:var(--cream); flex-shrink:0; z-index:1;
  font-family:var(--mono);
}
.sn-step__title{
  display:block; font-size:16px; font-weight:700;
  color:var(--ink); margin:0 0 4px;
}
.sn-step__text{
  font-size:14px; line-height:1.65; color:var(--ink);
  opacity:.65; margin:0;
}

/* Process media */
.sn-process__media{
  position:relative; height:480px;
}
.sn-process__img-top{
  position:absolute; top:0; right:0;
  width:72%; height:60%;
  border-radius:18px; overflow:hidden;
  z-index:1; box-shadow:0 10px 36px rgba(0,0,0,.14);
}
.sn-process__img-top img{ width:100%; height:100%; object-fit:cover; }
.sn-process__img-bottom{
  position:absolute; bottom:0; left:0;
  width:60%; height:52%;
  border-radius:16px; overflow:hidden;
  z-index:2; box-shadow:0 12px 40px rgba(0,0,0,.18);
}
.sn-process__img-bottom img{ width:100%; height:100%; object-fit:cover; }

/* Process floating cards */
.sn-proc-card{
  position:absolute; z-index:10;
  display:flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:10px;
  font-size:12px; font-weight:700; white-space:nowrap;
  box-shadow:0 6px 20px rgba(0,0,0,.14);
}
.sn-proc-card--dark{
  background:var(--green); color:#fff;
  top:52%; left:20%;
}
.sn-proc-card--gold{
  background:var(--gold); color:var(--green);
  bottom:6%; right:2%;
}

/* =========================================================
   SITEMAP PAGE
   ========================================================= */
.smap-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:clamp(24px,3vw,40px);
  margin-top:0;
}
.smap-group{
  background:var(--paper); border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,36px);
  box-shadow:0 2px 16px rgba(38,48,24,.07);
  border:1px solid rgba(38,48,24,.08);
}
.smap-group__head{
  display:flex; align-items:center; gap:14px;
  padding-bottom:20px; margin-bottom:20px;
  border-bottom:2px solid var(--gold);
}
.smap-icon{
  width:40px; height:40px; border-radius:10px;
  background:var(--green); color:var(--gold);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.smap-icon svg{ width:20px; height:20px; stroke:var(--gold); }
.smap-group__title{
  font-family:var(--sans); font-size:14px; font-weight:800;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink); margin:0;
}
.smap-list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.smap-item{ border-radius:8px; overflow:hidden; transition:background .2s; }
.smap-item:hover{ background:var(--cream); }
.smap-link{
  display:flex; align-items:center; justify-content:space-between;
  gap:8px; padding:10px 12px 4px;
  text-decoration:none; color:var(--ink);
}
.smap-link__title{ font-weight:700; font-size:15px; }
.smap-link__arr{
  width:16px; height:16px; flex-shrink:0;
  color:var(--gold); opacity:0;
  transition:opacity .2s, transform .25s;
}
.smap-item:hover .smap-link__arr{ opacity:1; transform:translateX(4px); }
.smap-link__desc{
  padding:0 12px 10px; margin:0;
  font-size:13px; line-height:1.6; color:var(--muted);
}

/* ── ANIMATIONS ── */

/* Floating card gentle bob */
@keyframes snBob {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-7px); }
}
.sn-float-card--anim{ animation:snBob 4.2s ease-in-out infinite; }
.sn-gold-box--anim  { animation:snBob 5s ease-in-out .6s infinite; }

/* Process step connector line draw-in */
.sn-step:not(:last-child)::after{
  transform-origin:top; transform:scaleY(0);
  transition:transform .55s cubic-bezier(.22,1,.36,1) .2s;
}
.sn-step.is-in:not(:last-child)::after{ transform:scaleY(1); }

/* Service title underline sweep on row reveal */
.sn-svc-title{ position:relative; display:inline-block; }
.sn-svc-title::after{
  content:''; position:absolute; left:0; bottom:-2px;
  width:100%; height:2px; background:var(--gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform .6s cubic-bezier(.22,1,.36,1) .15s;
}
.sn-svc-item.is-in .sn-svc-title::after{ transform:scaleX(1); }

/* CTA ring slow spin */
@keyframes snSpin { to { transform:rotate(360deg); } }
.sn-cta__ring{ animation:snSpin 18s linear infinite; }

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .sn-hero__grid,
  .sn-cta__grid,
  .sn-process__grid{ grid-template-columns:1fr; }

  .sn-hero__media{ height:360px; margin-top:24px; }
  .sn-cta__media{ height:280px; margin-top:32px; }
  .sn-process__media{ height:360px; margin-top:32px; }
  .sn-float-card{ right:8px; }
}
@media(max-width:600px){
  .sn-hero__media{ height:300px; }
  .sn-svc-item{ grid-template-columns:56px 1fr 44px; }
  .sn-svc-icon{ width:48px; height:48px; }
  .sn-svc-icon svg{ width:20px; height:20px; }
  .sn-svc-arr{ width:40px; height:40px; }
  .sn-cta__media{ display:none; }
  .sn-process__media{ height:300px; }
}
