/* ============================================================
   CHRISTELL ON PINE GROUP — Built From Legacy. Curating Culture.
   Culture-driven consultancy · beauty · fashion · entertainment · retail
   Palette: warm black · deep burgundy · rich wine · soft cream · muted gold · rust
   Type: Fraunces (editorial display) + Jost (refined sans)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,300;1,9..144,400;1,9..144,500&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --black:#0c0709;
  --wine:#5a1626;
  --wine-2:#6f1f31;
  --burgundy:#3a0e1b;
  --burgundy-2:#240810;
  --cream:#f4ead7;
  --cream-2:#ece0c9;
  --gold:#c79a4c;
  --gold-soft:#e0c184;
  --rust:#b1532b;
  --blue:#7e8ea0;
  --ink:#f4ead7;              /* text on dark */
  --ink-dk:#2c0f18;           /* text on cream */
  --muted:rgba(244,234,215,.62);
  --muted-dk:rgba(44,15,24,.66);
  --line:rgba(199,154,76,.32);
  --line-soft:rgba(244,234,215,.13);
  --line-dk:rgba(44,15,24,.16);
  --ease:cubic-bezier(.2,.7,.2,1);
  --maxw:1300px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  background:var(--black);color:var(--ink);
  font-family:'Jost',system-ui,sans-serif;font-weight:300;line-height:1.62;
  overflow-x:hidden;letter-spacing:.01em;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--black)}

/* grain overlay */
body::after{
  content:"";position:fixed;inset:-150%;z-index:2;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(6) infinite;
}
@keyframes grain{0%,100%{transform:translate(0,0)}25%{transform:translate(-5%,3%)}50%{transform:translate(4%,-4%)}75%{transform:translate(-3%,5%)}}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,68px);position:relative;z-index:3}

/* section themes */
.dark{background:radial-gradient(130% 100% at 75% 0%, var(--wine) 0%, var(--burgundy) 42%, var(--black) 100%);color:var(--ink)}
.darker{background:linear-gradient(var(--black),var(--burgundy-2));color:var(--ink)}
.light{background:var(--cream);color:var(--ink-dk)}
.light .eyebrow{color:var(--rust)}
.light .muted{color:var(--muted-dk)}
section{position:relative;z-index:3}
.sec{padding:clamp(86px,12vw,158px) 0}

/* type helpers */
.eyebrow{font-family:'Jost';font-weight:400;font-size:clamp(11px,1.05vw,13px);letter-spacing:.4em;text-transform:uppercase;color:var(--gold)}
.display{font-family:'Fraunces';font-weight:300;line-height:.96;letter-spacing:-.015em;font-optical-sizing:auto}
.it{font-style:italic}

/* ============================================================ HEADER */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:clamp(15px,2.3vw,26px) clamp(20px,5vw,68px);transition:all .5s var(--ease);border-bottom:1px solid transparent;
}
.site-head.scrolled{padding-top:13px;padding-bottom:13px;background:rgba(12,7,9,.78);backdrop-filter:blur(16px) saturate(130%);border-bottom:1px solid var(--line-soft)}
.brand{display:flex;align-items:center;gap:13px}
.brand .mark{width:48px;height:48px;flex:0 0 auto;display:grid;place-items:center;transition:transform .6s var(--ease)}
.brand:hover .mark{transform:rotate(-5deg) scale(1.05)}
.brand .mark img{width:100%;height:100%;object-fit:contain;mix-blend-mode:screen}
.brand .mark .mono{display:none;font-family:'Fraunces';font-size:22px;color:var(--gold-soft)}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-family:'Fraunces';font-weight:400;font-size:18px;letter-spacing:.01em;color:var(--ink)}
.brand .wm span{font-family:'Jost';font-weight:400;font-size:8.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-top:5px}
.nav{display:flex;align-items:center;gap:clamp(18px,2.5vw,38px)}
.nav a{font-family:'Jost';font-weight:400;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);opacity:.85;position:relative;padding:6px 0;transition:opacity .3s}
.nav a:hover{opacity:1}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .4s var(--ease)}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav a.active{color:var(--gold-soft)}
.nav-cta{border:1px solid var(--line);padding:10px 20px !important;border-radius:40px;transition:all .4s var(--ease)}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--gold);color:var(--black) !important;border-color:var(--gold)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:61}
.burger span{width:26px;height:1.5px;background:var(--ink);transition:.4s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ============================================================ BUTTONS */
.btn{font-family:'Jost';font-weight:500;font-size:12px;letter-spacing:.22em;text-transform:uppercase;padding:17px 34px;border-radius:40px;cursor:pointer;position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:10px;border:1px solid var(--gold);background:transparent;color:var(--ink);transition:color .45s var(--ease),border-color .45s}
.btn .lbl{position:relative;z-index:2}.btn .arr{position:relative;z-index:2;transition:transform .4s var(--ease)}
.btn::before{content:"";position:absolute;inset:0;z-index:1;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.btn:hover::before{transform:scaleX(1);transform-origin:left}
.btn:hover{color:var(--black);border-color:var(--gold)}
.btn:hover .arr{transform:translateX(5px)}
.btn.solid{background:var(--gold);color:var(--black)}
.btn.solid::before{background:var(--rust)}
.btn.solid:hover{color:var(--cream);border-color:var(--rust)}
.light .btn{color:var(--ink-dk)}
.light .btn:hover{color:var(--cream)}
.light .btn::before{background:var(--wine)}
.light .btn{border-color:var(--wine)}
.light .btn.solid{background:var(--wine);color:var(--cream);border-color:var(--wine)}
.light .btn.solid::before{background:var(--gold)}
.light .btn.solid:hover{color:var(--ink-dk)}
.cta-row{display:flex;gap:15px;flex-wrap:wrap}

/* ============================================================ PHOTO TREATMENT (duotone) */
.ph{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--wine),var(--burgundy-2))}
.ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(.45) contrast(1.05) brightness(.82) sepia(.1);transition:filter 1s var(--ease),transform 1.4s var(--ease)}
.ph::after{content:"";position:absolute;inset:0;background:linear-gradient(170deg,rgba(58,14,27,.35),rgba(90,22,38,.62));mix-blend-mode:multiply;transition:opacity .9s var(--ease)}
.ph:hover img{filter:grayscale(0) contrast(1.02) brightness(.95);transform:scale(1.05)}
.ph:hover::after{opacity:.35}

/* ============================================================ HERO */
.hero{min-height:100svh;display:flex;align-items:center;padding:150px 0 70px;overflow:hidden;position:relative}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(30px,5vw,70px);align-items:center;width:100%}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:30px;flex-wrap:wrap}
.hero-eyebrow .ln{height:1px;width:48px;background:var(--gold);transform-origin:left}
.hero h1{font-size:clamp(52px,8.4vw,128px);color:var(--ink);margin-bottom:8px}
.hero h1 .row{display:block;overflow:hidden}
.hero h1 .row i{display:inline-block;font-style:normal}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .sub{font-size:clamp(15px,1.45vw,18px);color:var(--muted);max-width:48ch;margin:30px 0 40px}
.hero-visual{position:relative;min-height:clamp(380px,56vw,600px)}
.hero-visual .ph{position:absolute;inset:0;border-radius:6px;box-shadow:0 40px 90px -40px rgba(0,0,0,.8)}
.hero-visual .frame{position:absolute;inset:-14px -14px auto auto;width:70%;height:auto;aspect-ratio:1;border:1px solid var(--line);border-radius:6px;z-index:2;pointer-events:none}
.hero-visual .logo-float{position:absolute;left:-26px;bottom:-26px;width:46%;z-index:4;filter:drop-shadow(0 18px 40px rgba(0,0,0,.6));animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero-visual .tag{position:absolute;right:18px;bottom:18px;z-index:4;font-family:'Jost';font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream);background:rgba(12,7,9,.55);backdrop-filter:blur(6px);border:1px solid var(--line-soft);padding:9px 14px;border-radius:30px}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);font-family:'Jost';font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:9px;z-index:4}
.scroll-cue .bar{width:1px;height:40px;background:linear-gradient(var(--gold),transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(.2);transform-origin:bottom}}

/* ============================================================ MARQUEE */
.marquee{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:24px 0;overflow:hidden;white-space:nowrap;background:var(--burgundy-2);position:relative;z-index:3}
.marquee .track{display:inline-flex;animation:slide 26s linear infinite;will-change:transform}
.marquee:hover .track{animation-play-state:paused}
.marquee span{font-family:'Fraunces';font-weight:300;font-size:clamp(22px,3vw,40px);color:var(--ink);display:inline-flex;align-items:center}
.marquee b{font-weight:300;font-style:italic;color:var(--gold-soft);padding:0 28px}
.marquee .st{color:var(--rust);font-size:.55em;padding:0 4px}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================ STATEMENT (light) */
.statement{padding:clamp(90px,13vw,180px) 0;text-align:center}
.statement .big{font-family:'Fraunces';font-weight:300;font-size:clamp(30px,5.4vw,72px);line-height:1.08;letter-spacing:-.01em;max-width:20ch;margin:26px auto 0}
.statement .big em{font-style:italic;color:var(--rust)}
.statement .lead{color:var(--muted-dk);max-width:54ch;margin:34px auto 0;font-size:clamp(15px,1.5vw,18px)}

/* ============================================================ SECTION HEAD */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:64px;flex-wrap:wrap}
.sec-head .left{max-width:60ch}
.sec-head h2{font-size:clamp(34px,5.2vw,72px);margin-top:16px}
.sec-head h2 em{font-style:italic;color:var(--gold-soft)}
.light .sec-head h2 em{color:var(--rust)}
.sec-head p{color:var(--muted);max-width:44ch;font-size:clamp(15px,1.4vw,17px)}
.idx{font-family:'Fraunces';font-style:italic;font-size:clamp(34px,5vw,80px);color:rgba(199,154,76,.3);line-height:1}

/* ============================================================ SERVICE PILLARS */
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.pillar{background:var(--burgundy-2);padding:clamp(32px,4vw,56px);position:relative;overflow:hidden;transition:background .5s var(--ease)}
.pillar::before{content:"";position:absolute;inset:0;background:radial-gradient(130% 130% at 100% 0%,rgba(177,83,43,.16),transparent 55%);opacity:0;transition:opacity .6s}
.pillar:hover{background:#2c0a14}
.pillar:hover::before{opacity:1}
.pillar .no{font-family:'Fraunces';font-style:italic;font-size:18px;color:var(--gold);display:block;margin-bottom:26px}
.pillar h3{font-family:'Fraunces';font-weight:400;font-size:clamp(24px,2.7vw,34px);margin-bottom:14px;line-height:1.05}
.pillar > p{color:var(--muted);font-size:15px;max-width:40ch;margin-bottom:24px}
.pillar ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px}
.pillar ul li{font-family:'Jost';font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);border:1px solid var(--line);border-radius:30px;padding:7px 13px}
.pillar .arrow{position:absolute;top:30px;right:30px;width:24px;opacity:.4;transition:.5s var(--ease)}
.pillar:hover .arrow{opacity:1;transform:translate(4px,-4px)}

/* ============================================================ CLIENTS / LOGO WALL (light) */
.clients-head{text-align:center;margin-bottom:60px}
.clients-head h2{font-family:'Fraunces';font-weight:300;font-size:clamp(30px,4.6vw,60px);margin-top:14px}
.clients-head h2 em{font-style:italic;color:var(--rust)}
.logo-wall{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line-dk);border:1px solid var(--line-dk)}
.logo-wall .lg{background:var(--cream);display:grid;place-items:center;padding:34px 18px;text-align:center;font-family:'Fraunces';font-weight:400;font-size:clamp(15px,1.5vw,19px);color:var(--ink-dk);letter-spacing:.01em;transition:background .4s,color .4s,transform .4s var(--ease)}
.logo-wall .lg:hover{background:var(--wine);color:var(--cream)}
.retail-row{margin-top:44px;text-align:center}
.retail-row .lbl{font-family:'Jost';font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--rust);margin-bottom:20px}
.retail-row .names{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 30px}
.retail-row .names span{font-family:'Jost';font-weight:400;font-size:clamp(14px,1.5vw,18px);color:var(--muted-dk);letter-spacing:.04em}

/* ============================================================ FOUNDER (split, dark) */
.founder{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(34px,6vw,90px);align-items:center}
.founder .vis{position:relative;min-height:clamp(360px,46vw,560px)}
.founder .vis .ph{position:absolute;inset:0;border-radius:6px}
.founder .vis .badge{position:absolute;left:-22px;bottom:28px;z-index:3;background:var(--gold);color:var(--black);font-family:'Jost';font-weight:500;font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:14px 22px;border-radius:4px;box-shadow:0 18px 40px -16px rgba(0,0,0,.7)}
.founder h2{font-size:clamp(36px,5vw,68px);margin-bottom:8px}
.founder .role{font-family:'Jost';font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:26px}
.founder p{color:var(--muted);font-size:clamp(15px,1.45vw,17px);margin-bottom:18px;max-width:50ch}
.founder p .em{font-family:'Fraunces';font-style:italic;color:var(--ink)}

/* ============================================================ PHILOSOPHY (light) */
.philo{padding:clamp(100px,14vw,200px) 0;text-align:center}
.philo .q{font-family:'Fraunces';font-weight:300;font-size:clamp(28px,4.8vw,62px);line-height:1.18;max-width:24ch;margin:0 auto}
.philo .q em{font-style:italic;color:var(--rust)}
.philo .q .g{color:var(--gold)}
.philo .by{margin-top:36px;display:inline-flex;align-items:center;gap:14px;font-family:'Jost';font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--wine)}
.philo .by .ln{width:40px;height:1px;background:var(--wine)}

/* ============================================================ CTA BAND */
.cta-band{margin:0 clamp(20px,5vw,68px);border-radius:8px;overflow:hidden;position:relative;background:radial-gradient(120% 140% at 50% -20%,var(--wine),var(--burgundy) 55%,var(--black));border:1px solid var(--line);padding:clamp(60px,9vw,120px) clamp(30px,6vw,90px);text-align:center}
.cta-band h2{font-family:'Fraunces';font-weight:300;font-size:clamp(34px,5.4vw,72px);margin:20px auto 14px;max-width:18ch;line-height:1.04}
.cta-band h2 em{font-style:italic;color:var(--gold-soft)}
.cta-band p{color:var(--muted);max-width:46ch;margin:0 auto 38px}

/* ============================================================ FOOTER */
.foot{background:var(--burgundy-2);padding:clamp(70px,9vw,120px) 0 38px;border-top:1px solid var(--line-soft)}
.foot .tagline{font-family:'Fraunces';font-weight:300;font-size:clamp(30px,5vw,64px);line-height:1.02;margin-bottom:18px}
.foot .tagline em{font-style:italic;color:var(--gold-soft)}
.foot .chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:60px}
.foot .chips span{font-family:'Jost';font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);border:1px solid var(--line);border-radius:30px;padding:8px 16px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:50px;margin-bottom:56px}
.foot h5{font-family:'Jost';font-weight:500;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.foot ul{list-style:none;display:grid;gap:12px}
.foot ul a{color:var(--muted);font-size:14.5px;transition:color .3s}
.foot ul a:hover{color:var(--ink)}
.foot .bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--line-soft)}
.foot .bottom span{font-family:'Jost';font-size:12px;color:var(--muted)}

/* ============================================================ SUBPAGE HERO */
.page-hero{padding:185px 0 64px;position:relative;overflow:hidden}
.page-hero .eyebrow{margin-bottom:22px}
.page-hero h1{font-size:clamp(46px,8.4vw,132px);line-height:.92}
.page-hero h1 em{font-style:italic;color:var(--gold-soft)}
.page-hero .intro{color:var(--muted);font-size:clamp(16px,1.6vw,20px);max-width:52ch;margin-top:28px}

/* prose */
.lead{font-family:'Fraunces';font-weight:300;font-size:clamp(22px,2.6vw,30px);line-height:1.4;margin-bottom:34px}
.lead em{font-style:italic;color:var(--gold-soft)}
.dark .lead em{color:var(--gold-soft)}
.light .lead em{color:var(--rust)}
.prose{max-width:62ch}
.prose p{color:var(--muted);font-size:clamp(15px,1.45vw,17.5px);margin-bottom:22px}
.light .prose p{color:var(--muted-dk)}
.prose p .em{font-family:'Fraunces';font-style:italic;color:var(--ink)}
.light .prose p .em{color:var(--ink-dk)}

/* services detail rows */
.srow{display:grid;grid-template-columns:auto 1.3fr 1fr;gap:clamp(24px,5vw,64px);align-items:start;padding:clamp(40px,5vw,64px) 0;border-top:1px solid var(--line-soft)}
.srow:last-of-type{border-bottom:1px solid var(--line-soft)}
.srow .sn{font-family:'Fraunces';font-style:italic;font-size:clamp(28px,4vw,56px);color:rgba(199,154,76,.4);line-height:1}
.srow h3{font-family:'Fraunces';font-weight:400;font-size:clamp(28px,3.4vw,46px);margin-bottom:16px;line-height:1.04}
.srow .d{color:var(--muted);font-size:clamp(15px,1.4vw,16.5px);max-width:52ch}
.srow ul{list-style:none;display:grid;gap:11px;align-self:center}
.srow ul li{display:flex;align-items:flex-start;gap:12px;font-size:14.5px;color:var(--ink)}
.srow ul li::before{content:"";flex:0 0 auto;margin-top:8px;width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(199,154,76,.13)}

/* values */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);margin-top:18px}
.value{background:var(--burgundy-2);padding:clamp(30px,3.6vw,48px)}
.value .vk{font-family:'Fraunces';font-style:italic;color:var(--gold);font-size:18px}
.value h4{font-family:'Fraunces';font-weight:400;font-size:clamp(21px,2.3vw,27px);margin:14px 0 12px}
.value p{color:var(--muted);font-size:14.5px;max-width:40ch}

/* media row */
.seen{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px 44px}
.seen span{font-family:'Fraunces';font-weight:400;font-size:clamp(16px,1.8vw,24px);color:var(--muted);letter-spacing:.02em}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.field{margin-bottom:26px}
.field label{display:block;font-family:'Jost';font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.field input,.field textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);color:var(--ink);font-family:'Jost';font-weight:300;font-size:16px;padding:12px 0;transition:border-color .4s var(--ease)}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--gold)}
.field input::placeholder,.field textarea::placeholder{color:rgba(244,234,215,.28)}
.contact-info{display:grid;gap:32px}
.contact-info .ci h5{font-family:'Jost';font-weight:500;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.contact-info .ci a{font-family:'Fraunces';font-weight:300;font-size:clamp(20px,2.2vw,26px);color:var(--ink)}
.contact-info .ci a:hover{color:var(--gold-soft)}
.contact-info .ci p{color:var(--muted);font-size:15px}
.socials{display:flex;gap:14px;flex-wrap:wrap}
.socials a{font-family:'Jost';font-size:12px;letter-spacing:.2em;text-transform:uppercase;border:1px solid var(--line);border-radius:30px;padding:11px 20px;transition:all .4s var(--ease)}
.socials a:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}
.form-note{font-size:13px;color:var(--muted);margin-top:6px}

/* ============================================================ REVEAL / LOAD */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}
.load{opacity:0;transform:translateY(40px)}
.loaded .load{animation:rise 1.1s var(--ease) forwards}
.loaded .l1{animation-delay:.1s}.loaded .l2{animation-delay:.24s}.loaded .l3{animation-delay:.38s}.loaded .l4{animation-delay:.52s}.loaded .l5{animation-delay:.66s}.loaded .l6{animation-delay:.8s}
@keyframes rise{to{opacity:1;transform:none}}
.loaded .hero-eyebrow .ln{animation:lineGrow 1s var(--ease) .3s forwards;transform:scaleX(0)}
@keyframes lineGrow{to{transform:scaleX(1)}}
@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}.reveal,.load{opacity:1 !important;transform:none !important}}

/* ============================================================ RESPONSIVE */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .hero-visual{min-height:64vw;order:-1}
  .pillars{grid-template-columns:1fr}
  .logo-wall{grid-template-columns:repeat(2,1fr)}
  .founder{grid-template-columns:1fr;gap:40px}
  .founder .vis{order:-1;min-height:70vw}
  .foot-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .srow{grid-template-columns:auto 1fr}
  .srow ul{grid-column:1/-1;grid-template-columns:repeat(2,1fr);display:grid}
}
@media(max-width:680px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);flex-direction:column;justify-content:center;align-items:flex-start;gap:28px;background:rgba(12,7,9,.97);backdrop-filter:blur(20px);padding:60px;transform:translateX(110%);transition:transform .6s var(--ease);border-left:1px solid var(--line);z-index:59}
  .nav.open{transform:none}
  .nav a{font-size:18px}.nav-cta{padding:12px 22px !important}
  .burger{display:flex}
  .brand .wm{display:none}
  .foot-grid{grid-template-columns:1fr}
  .logo-wall{grid-template-columns:repeat(2,1fr)}
  .sec-head{flex-direction:column;align-items:flex-start}
  .srow ul{grid-template-columns:1fr}
}

/* ============================================================ LOGO STRIPS (scrolling marquee)
   Reusable, JS-free brand/retailer/press strips. Each tile renders the brand
   name in Fraunces; if assets/logos/{slug}.png exists it masks the text and
   shows the logo instead (img onerror reveals the text fallback).
   Two duplicated tracks inside an overflow-hidden rail are translated -50%
   for a seamless, continuous loop; pause on hover. */
.logo-strip{background:var(--burgundy-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:clamp(34px,5vw,58px) 0;position:relative;z-index:3;overflow:hidden}
.logo-strip .strip-head{text-align:center;margin-bottom:clamp(22px,3vw,40px)}
.logo-rail{overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.logo-flow{display:flex;width:max-content;animation:logoScroll var(--logo-dur,48s) linear infinite;will-change:transform}
.logo-strip:hover .logo-flow{animation-play-state:paused}
.logo-track{display:flex;flex:0 0 auto}
.brand-tile{position:relative;flex:0 0 auto;width:clamp(150px,18vw,212px);height:clamp(66px,8vw,92px);display:grid;place-items:center;text-align:center;padding:0 clamp(14px,2vw,26px);border-right:1px solid var(--line-soft)}
.brand-tile span{font-family:'Fraunces';font-weight:400;font-size:clamp(15px,1.6vw,21px);letter-spacing:.01em;line-height:1.1;color:rgba(244,234,215,.62);filter:grayscale(1);transition:color .4s var(--ease)}
.brand-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:clamp(14px,1.8vw,24px) clamp(18px,2.4vw,30px);background:var(--burgundy-2);filter:grayscale(1) brightness(1.6) opacity(.78);transition:filter .4s var(--ease)}
.logo-strip:hover .brand-tile span{color:var(--gold-soft)}
.logo-strip:hover .brand-tile img{filter:grayscale(0) brightness(1) opacity(1)}
@keyframes logoScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:680px){
  .brand-tile{width:clamp(132px,42vw,170px)}
}
@media (prefers-reduced-motion:reduce){.logo-flow{animation:none;transform:none}}
