/* ════════════════════════════════════════════════════════════════
   BLUEHORSE — Creative Media Studio
   Design system v4.0 · "Editorial Midnight Luxe"
   Shared stylesheet for every page (home + sub-pages + journal)
   Type: Fraunces (display) · Manrope (body) · Space Mono (labels)
   Palette: Midnight ink + champagne gold + warm bone
════════════════════════════════════════════════════════════════ */

/* ── TOKENS ──────────────────────────────────────────────────── */
:root{
  --ink:      #0a1622;
  --ink-2:    #0f2030;
  --ink-3:    #16293b;
  --ink-line: rgba(244,241,234,.12);
  --bone:     #f5f2ea;
  --bone-2:   #ece6d9;
  --paper:    #fbfaf6;
  --gold:     #c29a45;
  --gold-2:   #d8b96b;
  --gold-3:   #efdca4;
  --gold-deep:#9c7a2f;
  --text:     #182530;
  --muted:    #5e6671;
  --muted-2:  #8b919b;
  --line:     #e3ddd0;
  --on-dark:  rgba(245,242,234,.72);
  --on-dark-2:rgba(245,242,234,.5);

  --maxw: 1240px;
  --gut:  clamp(1.25rem, 4vw, 2.75rem);
  --r:    14px;
  --r-lg: 24px;
  --r-sm: 9px;

  --sh-1: 0 2px 14px rgba(10,22,34,.06);
  --sh-2: 0 18px 50px rgba(10,22,34,.14);
  --sh-3: 0 40px 90px rgba(10,22,34,.26);
  --gold-glow: 0 10px 34px rgba(194,154,69,.32);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --tr: .4s var(--ease);

  --fs-display: clamp(2.9rem, 7.5vw, 7rem);
  --fs-h1: clamp(2.4rem, 5.5vw, 4.6rem);
  --fs-h2: clamp(1.9rem, 4vw, 3.3rem);
  --fs-h3: clamp(1.25rem, 2vw, 1.7rem);
}

/* ── RESET ───────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--bone);
  color:var(--text);
  line-height:1.62;
  font-size:16px;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{
  font-family:'Fraunces',Georgia,serif;
  font-weight:480;
  line-height:1.02;
  letter-spacing:-.018em;
  font-optical-sizing:auto;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img,svg,video{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
::selection{background:var(--gold);color:var(--ink)}

/* film-grain overlay above everything (fixed, non-scrolling) */
body::before{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}

/* ── LAYOUT PRIMITIVES ───────────────────────────────────────── */
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);width:100%}
.container-wide{max-width:1480px;margin:0 auto;padding:0 var(--gut);width:100%}
.sec{padding:clamp(4rem,9vw,8.5rem) 0;position:relative}
.sec-tight{padding:clamp(3rem,6vw,5rem) 0}
.sec-ink{background:var(--ink);color:var(--bone)}
.sec-ink h1,.sec-ink h2,.sec-ink h3,.sec-ink h4{color:var(--bone)}
.sec-bone{background:var(--bone)}
.sec-paper{background:var(--paper)}
.hidden{display:none!important}
.center{text-align:center}

/* ── KICKER / EYEBROW LABELS ─────────────────────────────────── */
.label,.kicker{
  font-family:'Space Mono',monospace;
  font-size:.72rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-deep);display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1.4rem;
}
.label::before,.kicker::before{content:"";width:26px;height:1px;background:var(--gold);display:inline-block}
.label-light,.kicker-light{color:var(--gold-2)}
.kicker-plain::before{display:none}

/* ── HEADINGS ────────────────────────────────────────────────── */
.title{font-size:var(--fs-h2);margin-bottom:1.3rem}
.title-lg{font-size:var(--fs-h1)}
.title-xl{font-size:var(--fs-display);line-height:.98}
.title em,.accent{font-style:italic;color:var(--gold);font-weight:420}
.lede{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--muted);max-width:42ch;line-height:1.6}
.sec-ink .lede{color:var(--on-dark)}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:1rem 1.9rem;border-radius:100px;font-weight:600;font-size:.93rem;
  letter-spacing:.01em;transition:var(--tr);position:relative;overflow:hidden;
  will-change:transform;line-height:1;
}
.btn svg{transition:transform .4s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-2);transform:translateY(-3px);box-shadow:var(--gold-glow)}
.btn-ink{background:var(--ink);color:var(--bone)}
.btn-ink:hover{background:var(--ink-3);transform:translateY(-3px);box-shadow:var(--sh-2)}
.btn-line{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:var(--bone)}
.btn-line:hover{border-color:var(--gold);color:var(--gold)}
.btn-line-ink{background:transparent;border:1.5px solid var(--ink);color:var(--ink)}
.btn-line-ink:hover{background:var(--ink);color:var(--bone);transform:translateY(-3px)}
.btn-wa{background:#1eaf57;color:#fff}
.btn-wa:hover{background:#199a4c;transform:translateY(-3px)}
.btn-lg{padding:1.15rem 2.3rem;font-size:1rem}

/* text link with animated underline */
.link-u{position:relative;color:var(--gold-deep);font-weight:600;display:inline-flex;gap:.45rem;align-items:center}
.link-u::after{content:"";position:absolute;left:0;bottom:-3px;height:1.5px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.link-u:hover::after{transform:scaleX(1);transform-origin:left}
.sec-ink .link-u{color:var(--gold-2)}

/* ── CUSTOM CURSOR ───────────────────────────────────────────── */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;mix-blend-mode:difference}
.cursor-dot{width:7px;height:7px;background:var(--gold-3);transform:translate(-50%,-50%)}
.cursor-ring{width:38px;height:38px;border:1px solid rgba(239,220,164,.7);transform:translate(-50%,-50%);transition:width .3s,height .3s,background .3s,border-color .3s}
.cursor-ring.is-hover{width:62px;height:62px;background:rgba(239,220,164,.12);border-color:transparent}
@media(hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}

/* scroll progress bar */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold-2));z-index:1200;transition:width .12s linear}

/* ════════════════════════════════════════════════════════════════
   NAV
════════════════════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:76px;display:flex;align-items:center;
  background:rgba(10,22,34,.55);backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid rgba(245,242,234,.08);transition:background .4s,height .4s,box-shadow .4s;
}
.nav.scrolled{background:rgba(10,22,34,.93);height:66px;box-shadow:0 10px 40px rgba(0,0,0,.3)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.nav-logo{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.nav-logo img{height:40px;width:auto;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:.15rem}
.nav-link{
  color:rgba(245,242,234,.78);padding:.55rem .95rem;border-radius:100px;font-size:.86rem;font-weight:500;
  transition:color .3s,background .3s;position:relative;
}
.nav-link:hover,.nav-link.active{color:var(--gold-2)}
.nav-cta{
  background:var(--gold);color:var(--ink);padding:.65rem 1.35rem;border-radius:100px;font-size:.84rem;
  font-weight:700;margin-left:.6rem;transition:var(--tr);
}
.nav-cta:hover{background:var(--gold-2);transform:translateY(-2px);box-shadow:var(--gold-glow)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;z-index:1001}
.hamburger span{width:24px;height:2px;background:var(--bone);border-radius:2px;transition:var(--tr)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{
  display:flex;position:fixed;inset:0;z-index:1000;background:var(--ink);
  flex-direction:column;justify-content:center;gap:.35rem;padding:5rem var(--gut) 2rem;
  transform:translateY(-100%);transition:transform .55s var(--ease-out);visibility:hidden;
}
.mobile-nav.open{transform:translateY(0);visibility:visible}
.mobile-link{
  color:var(--bone);font-family:'Fraunces',serif;font-size:2rem;padding:.55rem 0;
  border-bottom:1px solid var(--ink-line);transition:color .3s,padding-left .3s;
}
.mobile-link:hover{color:var(--gold-2);padding-left:.6rem}
.mobile-cta-btn{margin-top:1.6rem;background:var(--gold);color:var(--ink);padding:1.05rem;border-radius:100px;font-weight:700;text-align:center;font-size:1rem}

/* ════════════════════════════════════════════════════════════════
   HERO (home)
════════════════════════════════════════════════════════════════ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink);padding-bottom:clamp(2.5rem,6vw,5rem)}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media video,.hero-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-slide{opacity:0;transition:opacity 1.6s var(--ease),transform 7s linear;transform:scale(1.08)}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero-scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,22,34,.72) 0%,rgba(10,22,34,.4) 35%,rgba(10,22,34,.55) 70%,rgba(10,22,34,.92) 100%);
}
.hero-grid-lines{position:absolute;inset:0;z-index:1;opacity:.5;
  background-image:linear-gradient(rgba(245,242,234,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(245,242,234,.05) 1px,transparent 1px);
  background-size:7vw 7vw;
}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.hero-badge{
  display:inline-flex;align-items:center;gap:.6rem;background:rgba(245,242,234,.08);
  border:1px solid rgba(245,242,234,.18);color:var(--gold-2);padding:.5rem 1.1rem;border-radius:100px;
  font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.8rem;
}
.hero-badge-dot{width:7px;height:7px;background:var(--gold);border-radius:50%;animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(194,154,69,.5)}50%{opacity:.6;box-shadow:0 0 0 7px rgba(194,154,69,0)}}
.hero-title{font-size:var(--fs-display);color:var(--bone);font-weight:430;letter-spacing:-.025em;max-width:16ch}
.hero-title em{color:var(--gold);font-style:italic;font-weight:380}
.hero-sub{color:var(--on-dark);font-size:clamp(1.05rem,1.6vw,1.35rem);max-width:50ch;margin:1.8rem 0 2.4rem;line-height:1.6}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.hero-play{display:inline-flex;align-items:center;gap:.8rem;color:var(--bone);font-weight:600;font-size:.92rem}
.hero-play .ring{width:52px;height:52px;border-radius:50%;border:1.5px solid rgba(245,242,234,.4);display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.hero-play:hover .ring{background:var(--gold);border-color:var(--gold);transform:scale(1.06)}
.hero-play:hover .ring svg{fill:var(--ink)}
.hero-meta{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-top:clamp(2.5rem,5vw,4rem);padding-top:1.8rem;border-top:1px solid rgba(245,242,234,.14);flex-wrap:wrap}
.hero-locs{font-family:'Space Mono',monospace;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-dark-2);max-width:40ch;line-height:2}
.hero-scroll-hint{display:inline-flex;align-items:center;gap:.6rem;font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-dark)}
.hero-scroll-hint .bar{width:1px;height:34px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.hero-scroll-hint .bar::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--gold);animation:scrolldrop 1.8s var(--ease) infinite}
@keyframes scrolldrop{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* ── MARQUEE ─────────────────────────────────────────────────── */
.marquee{background:var(--ink-2);border-top:1px solid var(--ink-line);border-bottom:1px solid var(--ink-line);overflow:hidden;padding:1.5rem 0}
.marquee-bone{background:var(--bone-2);border-color:var(--line)}
.marquee-track{display:inline-flex;white-space:nowrap;animation:marquee 38s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;gap:1.5rem;padding:0 1.5rem;
  font-family:'Fraunces',serif;font-size:clamp(1.3rem,2.6vw,2.1rem);font-style:italic;color:var(--on-dark-2);font-weight:380}
.marquee-bone .marquee-item{color:var(--muted-2)}
.marquee-star{color:var(--gold);font-style:normal;font-size:.9em}
@keyframes marquee{to{transform:translateX(-50%)}}

/* logos strip */
.logos{display:flex;align-items:center;justify-content:center;gap:clamp(2rem,5vw,4.5rem);flex-wrap:wrap}
.logo-word{font-family:'Fraunces',serif;font-size:clamp(1.1rem,2vw,1.6rem);letter-spacing:.02em;color:var(--muted-2);opacity:.7;transition:var(--tr);font-weight:500}
.logo-word:hover{opacity:1;color:var(--ink)}

/* ── SECTION HEADER (shared editorial) ───────────────────────── */
.sec-head{display:grid;grid-template-columns:1fr;gap:1.2rem;margin-bottom:clamp(2.5rem,5vw,4rem);max-width:60ch}
.sec-head-split{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:end;margin-bottom:clamp(2.5rem,5vw,4rem)}
.sec-head-split .lede{justify-self:end;text-align:left}
.idx{font-family:'Space Mono',monospace;font-size:.78rem;color:var(--gold-deep);letter-spacing:.12em}

/* ════════════════════════════════════════════════════════════════
   SERVICES (capabilities) — editorial list
════════════════════════════════════════════════════════════════ */
.svc-list{border-top:1px solid var(--ink-line)}
.svc-row{display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem 2.5rem;align-items:center;
  padding:clamp(1.6rem,3vw,2.6rem) 0;border-bottom:1px solid var(--ink-line);position:relative;transition:padding .4s var(--ease)}
.svc-row .svc-no{font-family:'Space Mono',monospace;font-size:.85rem;color:var(--gold-2);align-self:start;padding-top:.5rem}
.svc-row h3{font-size:clamp(1.6rem,3.4vw,2.7rem);color:var(--bone);font-weight:420;transition:color .4s,transform .4s var(--ease)}
.svc-row:hover h3{color:var(--gold);transform:translateX(12px)}
.svc-row .svc-desc{color:var(--on-dark-2);font-size:.95rem;max-width:46ch;line-height:1.6;align-self:center}
.svc-row .svc-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.7rem}
.svc-tag{font-family:'Space Mono',monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--on-dark-2);border:1px solid var(--ink-line);padding:.25rem .65rem;border-radius:100px}
.svc-arrow{width:48px;height:48px;border-radius:50%;border:1px solid var(--ink-line);display:flex;align-items:center;justify-content:center;color:var(--gold-2);transition:var(--tr);flex-shrink:0}
.svc-row:hover .svc-arrow{background:var(--gold);border-color:var(--gold);color:var(--ink);transform:rotate(-45deg)}

/* service cards (sub-page) */
.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1rem,2vw,1.6rem)}
.scard{grid-column:span 4;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:var(--tr)}
.scard:hover{transform:translateY(-6px);box-shadow:var(--sh-2);border-color:var(--gold)}
.scard.wide{grid-column:span 6}
.scard.feature{grid-column:span 6;background:var(--ink);border-color:var(--ink)}
.scard-img{position:relative;overflow:hidden;aspect-ratio:16/10}
.scard-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.scard:hover .scard-img img{transform:scale(1.07)}
.scard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,34,.55),transparent 55%)}
.scard-no{position:absolute;top:1rem;left:1.2rem;z-index:2;font-family:'Space Mono',monospace;color:var(--gold-3);font-size:.75rem;letter-spacing:.12em}
.scard-badge{position:absolute;top:1rem;right:1.2rem;z-index:2;background:var(--gold);color:var(--ink);font-family:'Space Mono',monospace;font-size:.62rem;font-weight:700;padding:.3rem .8rem;border-radius:100px;text-transform:uppercase;letter-spacing:.1em}
.scard-body{padding:clamp(1.4rem,2.4vw,2rem);display:flex;flex-direction:column;gap:.85rem;flex:1}
.scard-name{font-size:var(--fs-h3);color:var(--ink)}
.scard.feature .scard-name{color:var(--bone)}
.scard-desc{font-size:.92rem;color:var(--muted);line-height:1.65;flex:1}
.scard.feature .scard-desc{color:var(--on-dark)}
.scard-bens{display:flex;flex-direction:column;gap:.45rem;margin-top:.3rem}
.scard-ben{font-size:.86rem;color:var(--muted);display:flex;gap:.6rem;align-items:flex-start}
.scard-ben::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);margin-top:.5rem;flex-shrink:0}
.scard.feature .scard-ben{color:var(--on-dark)}

/* ════════════════════════════════════════════════════════════════
   STATS COUNTER
════════════════════════════════════════════════════════════════ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink-line);border:1px solid var(--ink-line);border-radius:var(--r-lg);overflow:hidden}
.stat{background:var(--ink);padding:clamp(1.8rem,3.5vw,3rem) clamp(1.2rem,2.5vw,2rem)}
.stat-num{font-family:'Fraunces',serif;font-size:clamp(2.6rem,5.5vw,4.4rem);color:var(--gold-2);font-weight:430;line-height:1;letter-spacing:-.02em}
.stat-num .suffix{color:var(--bone);font-size:.5em;vertical-align:super}
.stat-label{margin-top:.7rem;font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark-2);line-height:1.6}

/* ════════════════════════════════════════════════════════════════
   WORK / PORTFOLIO
════════════════════════════════════════════════════════════════ */
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.1rem,2.5vw,2rem)}
.work{grid-column:span 6;position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--ink-2);display:block;transition:transform .6s var(--ease)}
.work.tall{grid-column:span 6}
.work.full{grid-column:span 12}
.work-media{position:relative;overflow:hidden;aspect-ratio:4/3}
.work.full .work-media{aspect-ratio:21/9}
.work-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .6s}
.work:hover .work-media img{transform:scale(1.06)}
.work-media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,34,.85) 0%,rgba(10,22,34,.1) 55%);opacity:.9;transition:opacity .5s}
.work-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(1.4rem,3vw,2.4rem)}
.work-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.8rem}
.work-tag{font-family:'Space Mono',monospace;font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);background:var(--gold-3);padding:.25rem .7rem;border-radius:100px}
.work-title{font-size:clamp(1.4rem,2.6vw,2.2rem);color:var(--bone);font-weight:430;line-height:1.05}
.work-client{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);margin-top:.5rem;display:flex;align-items:center;gap:.6rem}
.work-client::after{content:"\2192";opacity:0;transform:translateX(-6px);transition:var(--tr)}
.work:hover .work-client::after{opacity:1;transform:translateX(0)}

/* ── BEFORE / AFTER SLIDER ───────────────────────────────────── */
.ba{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/10;user-select:none;cursor:ew-resize;box-shadow:var(--sh-2);touch-action:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-tag{position:absolute;bottom:1rem;z-index:3;font-family:'Space Mono',monospace;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone);background:rgba(10,22,34,.65);backdrop-filter:blur(6px);padding:.4rem .9rem;border-radius:100px;pointer-events:none}
.ba-tag.l{left:1rem}.ba-tag.r{right:1rem}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--gold-3);z-index:4;transform:translateX(-50%);pointer-events:none}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:0 6px 20px rgba(0,0,0,.35)}

/* ════════════════════════════════════════════════════════════════
   PROCESS TIMELINE
════════════════════════════════════════════════════════════════ */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.2rem,2.5vw,2.2rem);counter-reset:step}
.step{position:relative;padding-top:2.4rem;border-top:1px solid var(--ink-line)}
.step::before{counter-increment:step;content:"0" counter(step);position:absolute;top:1.2rem;left:0;font-family:'Space Mono',monospace;font-size:.8rem;color:var(--gold-2)}
.step-dot{position:absolute;top:-5px;left:0;width:9px;height:9px;border-radius:50%;background:var(--gold)}
.step h3{font-size:1.35rem;color:var(--bone);margin-bottom:.6rem;font-weight:440}
.step p{color:var(--on-dark-2);font-size:.9rem;line-height:1.6}

/* ════════════════════════════════════════════════════════════════
   SPLIT FEATURE / APPROACH
════════════════════════════════════════════════════════════════ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split-rev .split-text{order:2}
.split-media{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--sh-3)}
.split-media img{width:100%;height:100%;object-fit:cover}
.split-badge{position:absolute;bottom:1.4rem;left:1.4rem;right:1.4rem;background:rgba(10,22,34,.78);backdrop-filter:blur(12px);border:1px solid var(--ink-line);border-left:2px solid var(--gold);padding:1.2rem 1.4rem;border-radius:0 var(--r) var(--r) 0}
.split-badge p{font-family:'Fraunces',serif;font-style:italic;color:var(--bone);font-size:1.05rem;line-height:1.45}
.split-badge cite{font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);margin-top:.6rem;display:block;font-style:normal}
.feat-list{display:flex;flex-direction:column;gap:1.3rem;margin-top:2rem}
.feat-item{display:flex;gap:1.2rem;align-items:flex-start}
.feat-num{font-family:'Space Mono',monospace;font-size:.85rem;color:var(--gold-deep);flex-shrink:0;padding-top:.2rem}
.feat-item h4{font-size:1.15rem;color:var(--ink);margin-bottom:.3rem;font-weight:500;letter-spacing:-.01em}
.sec-ink .feat-item h4{color:var(--bone)}
.feat-item p{font-size:.9rem;color:var(--muted);line-height:1.6}
.sec-ink .feat-item p{color:var(--on-dark-2)}

/* ── AI / capabilities chips ─────────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2rem}
.chip{display:inline-flex;align-items:center;gap:.55rem;border:1px solid var(--ink-line);border-radius:100px;padding:.6rem 1.15rem;font-size:.85rem;color:var(--on-dark);transition:var(--tr)}
.chip:hover{border-color:var(--gold);color:var(--gold-2)}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}

/* ════════════════════════════════════════════════════════════════
   TESTIMONIALS
════════════════════════════════════════════════════════════════ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.1rem,2vw,1.6rem)}
.tcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.6rem,2.6vw,2.3rem);display:flex;flex-direction:column;transition:var(--tr)}
.tcard:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.tcard.feature{background:var(--ink);border-color:var(--ink)}
.tcard-stars{color:var(--gold);letter-spacing:.18em;font-size:.82rem;margin-bottom:1.1rem}
.tcard-text{font-family:'Fraunces',serif;font-size:1.18rem;line-height:1.5;color:var(--text);font-weight:380;flex:1}
.tcard.feature .tcard-text{color:var(--bone)}
.tcard-auth{display:flex;align-items:center;gap:.85rem;margin-top:1.8rem;padding-top:1.3rem;border-top:1px solid var(--line)}
.tcard.feature .tcard-auth{border-color:var(--ink-line)}
.tcard-av{width:44px;height:44px;border-radius:50%;background:var(--gold);color:var(--ink);font-family:'Space Mono',monospace;font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tcard-name{font-weight:700;font-size:.9rem;color:var(--ink);display:block}
.tcard.feature .tcard-name{color:var(--bone)}
.tcard-role{font-size:.78rem;color:var(--muted-2)}

/* ════════════════════════════════════════════════════════════════
   INSIGHTS / JOURNAL CARDS  (legacy .ucard kept compatible)
════════════════════════════════════════════════════════════════ */
.updates-grid,.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.1rem,2vw,1.7rem)}
.updates-grid .ucard.featured{grid-column:span 1}
.ucard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:var(--tr);display:flex;flex-direction:column}
.ucard:hover{transform:translateY(-6px);box-shadow:var(--sh-2);border-color:var(--gold)}
.ucard-img{position:relative;overflow:hidden;aspect-ratio:3/2}
.ucard-img img{width:100%!important;height:100%!important;object-fit:cover;transition:transform .9s var(--ease)}
.ucard:hover .ucard-img img{transform:scale(1.06)}
.ucard-cat{position:absolute;top:1rem;left:1rem;background:rgba(10,22,34,.7);backdrop-filter:blur(6px);color:var(--gold-2);font-family:'Space Mono',monospace;font-size:.62rem;font-weight:700;padding:.32rem .8rem;border-radius:100px;letter-spacing:.1em;text-transform:uppercase;z-index:2}
.ucard-img-overlay{display:none}
.ucard-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.ucard-title{font-size:1.2rem;color:var(--ink);margin-bottom:.6rem;line-height:1.2;font-weight:480}
.ucard-excerpt{font-size:.88rem;color:var(--muted);line-height:1.6;margin-bottom:1rem;flex:1}
.ucard-meta{display:flex;gap:.7rem;align-items:center;font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2)}
.ucard-meta-dot{width:3px;height:3px;background:var(--muted-2);border-radius:50%}

/* ════════════════════════════════════════════════════════════════
   FEATURED PROPERTY CARDS
════════════════════════════════════════════════════════════════ */
.props-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.1rem,2vw,1.7rem)}
.pcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:var(--tr);display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--sh-2);border-color:var(--gold)}
.pcard-img{position:relative;overflow:hidden;aspect-ratio:3/2}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.pcard:hover .pcard-img img{transform:scale(1.06)}
.pcard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,34,.45) 0%,rgba(10,22,34,0) 45%)}
.pcard-badge{position:absolute;top:1rem;left:1rem;z-index:2;background:rgba(10,22,34,.7);backdrop-filter:blur(6px);color:var(--gold-2);font-family:'Space Mono',monospace;font-size:.62rem;font-weight:700;padding:.32rem .8rem;border-radius:100px;letter-spacing:.1em;text-transform:uppercase}
.pcard-price{position:absolute;bottom:1rem;left:1rem;z-index:2;background:var(--gold);color:var(--ink);font-family:'Space Mono',monospace;font-size:.78rem;font-weight:700;padding:.4rem .9rem;border-radius:100px;letter-spacing:.02em}
.pcard-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.pcard-name{font-size:1.25rem;color:var(--ink);margin-bottom:.5rem;line-height:1.2;font-weight:480}
.pcard-loc{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--muted);margin-bottom:1rem}
.pcard-loc svg{color:var(--gold-deep);flex-shrink:0}
.pcard-specs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.1rem}
.pcard-spec{font-family:'Space Mono',monospace;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text);background:var(--bone-2);padding:.35rem .75rem;border-radius:100px}
.pcard-roi{font-size:.85rem;color:var(--muted);margin-bottom:1.2rem;padding-top:1rem;border-top:1px solid var(--line)}
.pcard-roi strong{color:var(--gold-deep);font-weight:700}
.pcard-btn{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;align-self:flex-start;padding:.65rem 1.3rem;border-radius:100px;font-size:.82rem;font-weight:700;background:var(--ink);color:var(--bone);transition:var(--tr)}
.pcard-btn:hover{background:var(--gold);color:var(--ink);transform:translateX(4px)}

/* filter pills */
.filter-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-btn{padding:.55rem 1.2rem;border-radius:100px;font-size:.82rem;font-weight:600;background:transparent;color:var(--muted);border:1px solid var(--line);transition:var(--tr)}
.filter-btn:hover,.filter-btn.active{background:var(--ink);color:var(--bone);border-color:var(--ink)}

/* ════════════════════════════════════════════════════════════════
   PAGE HERO (sub-pages)
════════════════════════════════════════════════════════════════ */
.page-hero{position:relative;background:var(--ink);padding:clamp(8rem,14vw,12rem) 0 clamp(3.5rem,7vw,6rem);overflow:hidden}
.page-hero-bg{position:absolute;inset:0;opacity:.22}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-overlay{position:absolute;inset:0;background:radial-gradient(120% 100% at 80% 0%,rgba(194,154,69,.12),transparent 50%),linear-gradient(180deg,rgba(10,22,34,.8),rgba(10,22,34,.96))}
.page-hero-grid{position:absolute;inset:0;opacity:.4;background-image:linear-gradient(rgba(245,242,234,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(245,242,234,.05) 1px,transparent 1px);background-size:7vw 7vw}
.page-hero-content{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.page-hero-content h1{color:var(--bone);font-size:var(--fs-h1);max-width:18ch}
.page-hero-content p{color:var(--on-dark);font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:54ch;margin-top:1.3rem;line-height:1.6}

/* ════════════════════════════════════════════════════════════════
   ABOUT / STORY
════════════════════════════════════════════════════════════════ */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:center}
.story-imgs{position:relative;aspect-ratio:1/1}
.story-img-main{position:absolute;top:0;left:0;width:74%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--sh-3)}
.story-img-sub{position:absolute;bottom:0;right:0;width:52%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--sh-3);border:5px solid var(--bone)}
.story-badge{position:absolute;top:8%;right:0;background:var(--gold);color:var(--ink);padding:1.2rem 1.5rem;border-radius:var(--r);box-shadow:var(--sh-2);z-index:3}
.story-badge .n{font-family:'Fraunces',serif;font-size:2.2rem;line-height:1;font-weight:500}
.story-badge .l{font-family:'Space Mono',monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;margin-top:.3rem}
.story-text p{color:var(--muted);line-height:1.8;margin-bottom:1.1rem;font-size:1.02rem}
.sec-ink .story-text p{color:var(--on-dark)}
.story-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:2rem}
.sstat{background:var(--bone);padding:1.3rem 1.4rem}
.sstat .n{font-family:'Fraunces',serif;font-size:1.9rem;color:var(--ink);line-height:1;font-weight:500}
.sstat .l{font-family:'Space Mono',monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-top:.4rem}

.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink-line);border:1px solid var(--ink-line);border-radius:var(--r-lg);overflow:hidden}
.vcard{background:var(--ink);padding:clamp(1.6rem,3vw,2.4rem);transition:background .4s}
.vcard:hover{background:var(--ink-3)}
.vcard .vno{font-family:'Space Mono',monospace;font-size:.78rem;color:var(--gold-2);margin-bottom:1.2rem}
.vcard h3{font-size:1.3rem;color:var(--bone);margin-bottom:.6rem;font-weight:460}
.vcard p{font-size:.9rem;color:var(--on-dark-2);line-height:1.65}

.gallery-strip{display:flex;height:clamp(180px,28vw,340px);gap:6px}
.gallery-strip img{flex:1;object-fit:cover;transition:flex .7s var(--ease),filter .5s;filter:grayscale(.3) brightness(.85)}
.gallery-strip img:hover{flex:2.6;filter:none}

/* ════════════════════════════════════════════════════════════════
   CTA BANNER
════════════════════════════════════════════════════════════════ */
.cta{position:relative;background:var(--ink);overflow:hidden;padding:clamp(4rem,9vw,8rem) 0;text-align:center}
.cta-glow{position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 120%,rgba(194,154,69,.22),transparent 60%)}
.cta-inner{position:relative;z-index:2;max-width:30ch;margin:0 auto}
.cta h2{font-size:var(--fs-h1);color:var(--bone);margin-bottom:1.4rem}
.cta p{color:var(--on-dark);font-size:1.1rem;margin-bottom:2.4rem;max-width:48ch;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── NEWSLETTER ──────────────────────────────────────────────── */
.newsletter{display:flex;align-items:center;justify-content:space-between;gap:2.5rem;flex-wrap:wrap;
  background:var(--ink);border-radius:var(--r-lg);padding:clamp(2rem,4vw,3.5rem);box-shadow:var(--sh-2)}
.newsletter h3{font-size:clamp(1.6rem,3vw,2.3rem);color:var(--bone);margin-bottom:.5rem}
.newsletter p{color:var(--on-dark-2);font-size:.95rem}
.newsletter form{display:flex;gap:.6rem;flex-wrap:wrap}
.newsletter input{padding:1rem 1.3rem;border:1px solid var(--ink-line);background:rgba(245,242,234,.06);color:var(--bone);border-radius:100px;font-size:.92rem;width:280px;transition:var(--tr)}
.newsletter input::placeholder{color:var(--on-dark-2)}
.newsletter input:focus{outline:none;border-color:var(--gold);background:rgba(245,242,234,.1)}

/* ════════════════════════════════════════════════════════════════
   FORMS  (book / contact)
════════════════════════════════════════════════════════════════ */
.form-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.form-aside h3{font-size:var(--fs-h3);color:var(--ink);margin-bottom:1.5rem}
.expect-list{display:flex;flex-direction:column}
.expect-item{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--text)}
.expect-item .n{font-family:'Space Mono',monospace;color:var(--gold-deep);font-size:.82rem;flex-shrink:0;padding-top:.15rem}
.direct{margin-top:1.8rem;padding:1.6rem;background:var(--ink);border-radius:var(--r-lg)}
.direct h4{font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);margin-bottom:1rem}
.direct a{color:var(--bone);font-weight:600;font-size:.95rem;display:block;margin-bottom:.5rem;transition:color .3s}
.direct a:hover{color:var(--gold-2)}
.form-wrap{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.6rem);box-shadow:var(--sh-1)}
.form-title{font-size:var(--fs-h3);color:var(--ink);margin-bottom:1.8rem}
.fg{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.15rem}
.fg label{font-family:'Space Mono',monospace;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.fg input,.fg select,.fg textarea{padding:.95rem 1.1rem;border:1px solid var(--line);border-radius:var(--r-sm);font-size:.95rem;color:var(--text);background:var(--bone);transition:var(--tr)}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,154,69,.16);background:#fff}
.fg textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-note{font-family:'Space Mono',monospace;font-size:.7rem;color:var(--muted-2);text-align:center;margin-top:.9rem;letter-spacing:.04em}
.hp{position:absolute;left:-9999px}
.success-box{text-align:center;padding:clamp(2.5rem,5vw,4rem) 1.5rem}
.success-ring{width:70px;height:70px;border-radius:50%;background:rgba(194,154,69,.14);border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--gold-deep)}
.success-box h3{font-size:var(--fs-h3);color:var(--ink);margin-bottom:.75rem}
.success-box p{color:var(--muted);margin-bottom:1.8rem;max-width:38ch;margin-left:auto;margin-right:auto}

/* contact */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-item{display:flex;gap:1.1rem;align-items:flex-start;margin-bottom:1.8rem}
.contact-ico{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold-deep);flex-shrink:0}
.contact-label{font-family:'Space Mono',monospace;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.25rem}
.contact-val a,.contact-val p{color:var(--ink);font-weight:600;font-size:1rem}
.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:1.2rem}
.social-link{display:flex;align-items:center;gap:.7rem;padding:.85rem 1.1rem;border:1px solid var(--line);border-radius:100px;font-size:.85rem;font-weight:600;color:var(--ink);transition:var(--tr)}
.social-link:hover{background:var(--ink);color:var(--bone);border-color:var(--ink);transform:translateY(-2px)}
.map-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2);border:1px solid var(--line)}
.map-wrap iframe{display:block;filter:grayscale(.4) contrast(1.05)}

/* ════════════════════════════════════════════════════════════════
   VIDEOS
════════════════════════════════════════════════════════════════ */
.videos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.1rem,2vw,1.7rem)}
.videos-loading{grid-column:1/-1;text-align:center;padding:3rem 0;color:var(--muted);font-family:'Space Mono',monospace;font-size:.8rem;letter-spacing:.08em}
.videos-spinner{width:34px;height:34px;border:2px solid var(--line);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}
@keyframes spin{to{transform:rotate(360deg)}}
.videos-empty,.videos-page-channel{text-align:center;padding:2.5rem 0;color:var(--muted);font-size:.95rem}
.videos-page-channel{margin-top:2.5rem}
.videos-page-channel p{margin-bottom:1.2rem}
.videos-subtitle{color:var(--muted);font-size:1rem;max-width:54ch;margin-bottom:2.5rem}
.sec-ink .videos-subtitle{color:var(--on-dark)}
.vid-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:var(--tr)}
.vid-card:hover{transform:translateY(-6px);box-shadow:var(--sh-2);border-color:var(--gold)}
.vid-card-thumb{position:relative;width:100%;padding-top:56.25%;overflow:hidden;background:var(--ink)}
.vid-card-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.vid-card:hover .vid-card-thumb img{transform:scale(1.07)}
.vid-card-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,22,34,.35);opacity:0;transition:var(--tr)}
.vid-card:hover .vid-card-play{opacity:1}
.vid-card-play-icon{width:58px;height:58px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(0,0,0,.35)}
.vid-card-play-icon svg{margin-left:3px;fill:var(--ink)}
.vid-card-body{padding:1.1rem 1.3rem 1.4rem}
.vid-card-title{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:460;line-height:1.25;color:var(--ink);margin-bottom:.6rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.vid-card-meta{font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.06em;color:var(--muted-2);display:flex;align-items:center;gap:.4rem}
.vid-card-date{display:flex;align-items:center;gap:.4rem}

.video-modal-overlay{position:fixed;inset:0;background:rgba(5,11,18,.9);z-index:2000;display:none;align-items:center;justify-content:center;padding:1.5rem;backdrop-filter:blur(8px)}
.video-modal-overlay.active{display:flex}
.video-modal{background:var(--ink);border-radius:var(--r-lg);overflow:hidden;width:100%;max-width:960px;box-shadow:var(--sh-3);position:relative}
.video-modal-close{position:absolute;top:1rem;right:1rem;z-index:2001;width:44px;height:44px;border-radius:50%;background:rgba(245,242,234,.14);color:var(--bone);font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.video-modal-close:hover{background:var(--gold);color:var(--ink);transform:rotate(90deg)}
.video-modal-player{position:relative;width:100%;padding-top:56.25%}
.video-modal-player iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-modal-title{padding:1.1rem 1.5rem;color:var(--bone);font-family:'Fraunces',serif;font-size:1.15rem;font-weight:460}

/* ════════════════════════════════════════════════════════════════
   BLOG POST
════════════════════════════════════════════════════════════════ */
.post-wrap{max-width:760px;margin:0 auto;padding:clamp(8rem,12vw,10rem) var(--gut) 4rem}
.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--gold-deep);font-weight:600;font-size:.88rem;margin-bottom:2rem;transition:var(--tr)}
.back-link:hover{gap:.8rem}
.post-hero-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9;margin-bottom:2rem;box-shadow:var(--sh-2)}
.post-hero-img img{width:100%;height:100%;object-fit:cover}
.post-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem;font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2)}
.post-cat{background:var(--ink);color:var(--gold-2);padding:.32rem .85rem;border-radius:100px;letter-spacing:.1em}
.post-title{font-size:clamp(1.9rem,4.5vw,3.2rem);color:var(--ink);margin-bottom:2rem;line-height:1.05}
.post-body p{color:var(--text);line-height:1.85;margin-bottom:1.4rem;font-size:1.08rem}
.post-body h3{font-family:'Fraunces',serif;color:var(--ink);font-size:1.6rem;margin:2.4rem 0 .9rem;font-weight:480}
.post-body strong{color:var(--ink);font-weight:700}
.post-cta{margin-top:3.5rem;background:var(--ink);border-radius:var(--r-lg);padding:clamp(2rem,4vw,3rem);text-align:center;position:relative;overflow:hidden}
.post-cta h3{color:var(--bone);font-size:1.7rem;margin-bottom:.6rem}
.post-cta p{color:var(--on-dark);margin-bottom:1.6rem}

/* ════════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════════ */
footer{background:var(--ink);padding:clamp(3.5rem,7vw,6rem) 0 0;position:relative;overflow:hidden}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(2rem,4vw,3rem);padding-bottom:3rem;border-bottom:1px solid var(--ink-line)}
.footer-brand-logo img{height:42px;width:auto;margin-bottom:1.1rem}
.footer-tagline{font-family:'Fraunces',serif;font-style:italic;font-size:1.15rem;color:var(--on-dark);margin-bottom:1.6rem;max-width:32ch;line-height:1.4}
.footer-socials{display:flex;gap:.55rem}
.footer-soc{width:40px;height:40px;border:1px solid var(--ink-line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--bone);transition:var(--tr)}
.footer-soc:hover{background:var(--gold);color:var(--ink);border-color:var(--gold);transform:translateY(-3px)}
.footer-col h5{font-family:'Space Mono',monospace;font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);margin-bottom:1.2rem}
.footer-col ul li{margin-bottom:.7rem}
.footer-col a,.footer-col p{font-size:.9rem;color:var(--on-dark-2);transition:color .3s;line-height:1.5}
.footer-col a:hover{color:var(--gold-2)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.8rem 0;font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.06em;color:var(--on-dark-2);flex-wrap:wrap;gap:.6rem}

/* ── FLOATING WHATSAPP + SOCIAL RAIL ─────────────────────────── */
.wa-float{position:fixed;bottom:1.6rem;right:1.6rem;width:56px;height:56px;background:#1eaf57;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(30,175,87,.4);z-index:900;color:#fff;transition:var(--tr)}
.wa-float:hover{transform:scale(1.08) rotate(6deg)}
.social-sidebar{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:900;display:flex;flex-direction:column;gap:3px}
.sidebar-soc{display:flex;align-items:center;width:42px;overflow:hidden;height:42px;color:#fff;font-family:'Space Mono',monospace;font-size:.72rem;font-weight:700;letter-spacing:.05em;transition:width .35s var(--ease);border-radius:0 8px 8px 0;padding:0 12px;gap:11px;white-space:nowrap;box-shadow:2px 2px 14px rgba(0,0,0,.22)}
.sidebar-soc svg{flex-shrink:0}
.sidebar-soc:hover{width:140px}
.sidebar-label{opacity:0;transition:opacity .25s ease .08s}
.sidebar-soc:hover .sidebar-label{opacity:1}
.sidebar-instagram{background:linear-gradient(135deg,#e1306c,#833ab4,#fd1d1d)}
.sidebar-linkedin{background:#0a66c2}
.sidebar-tiktok{background:#111}
.sidebar-youtube{background:#FF0000}
@media(max-width:860px){.social-sidebar{display:none}}

/* ════════════════════════════════════════════════════════════════
   ANIMATIONS
════════════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.reveal-d4{transition-delay:.4s}
.clip-rise{clip-path:inset(0 0 100% 0);transition:clip-path 1s var(--ease-out)}
.clip-rise.visible{clip-path:inset(0 0 0 0)}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .svc-grid .scard,.svc-grid .scard.wide,.svc-grid .scard.feature{grid-column:span 6}
  .work,.work.tall{grid-column:span 6}
  .testi-grid{grid-template-columns:1fr 1fr}
  .testi-grid .tcard:nth-child(3){grid-column:span 2}
  .process{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .updates-grid,.blog-grid,.videos-grid,.props-grid{grid-template-columns:1fr 1fr}
  .form-layout,.contact-grid{grid-template-columns:1fr}
  .sec-head-split{grid-template-columns:1fr}
  .sec-head-split .lede{justify-self:start}
}
@media(max-width:760px){
  .hamburger{display:flex}
  .nav-links{display:none}
  .nav{height:64px}
  .hero{align-items:center;padding-top:64px}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:1.2rem}
  .hero-scroll-hint{display:none}
  .split,.story-grid{grid-template-columns:1fr;gap:2.5rem}
  .split-rev .split-text{order:0}
  .scard,.scard.wide,.scard.feature,.work,.work.tall,.work.full{grid-column:span 12!important}
  .testi-grid,.updates-grid,.blog-grid,.videos-grid,.props-grid{grid-template-columns:1fr}
  .testi-grid .tcard:nth-child(3){grid-column:span 1}
  .stats,.values-grid{grid-template-columns:1fr 1fr}
  .process{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .newsletter{flex-direction:column;align-items:flex-start}
  .newsletter input{width:100%}
  .svc-row{grid-template-columns:auto 1fr;gap:.6rem 1.2rem}
  .svc-row .svc-arrow{display:none}
  .story-stats{grid-template-columns:1fr 1fr}
}
@media(max-width:460px){
  .stats,.values-grid,.footer-grid,.story-stats,.social-grid{grid-template-columns:1fr}
  .hero-title{font-size:clamp(2.3rem,11vw,3rem)}
  .marquee-item{font-size:1.2rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal,.clip-rise{opacity:1!important;transform:none!important;clip-path:none!important}
  .hero-slide{transition:opacity .4s ease!important;transform:none!important}
}
