/* ===== Second Season — shared stylesheet ===== */
:root{
  --char:#1E1E1E; --black:#111111; --champ:#B8A082; --champd:#9A7E5E;
  --ivory:#F5F0E8; --faint:#EFE7DB; --stone:#D9CDBF; --walnut:#6A5B46; --muted:#7D7163;
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Inter',Arial,sans-serif;
  --mx:clamp(1.4rem,6vw,7rem);
  --px:max(clamp(1.4rem,6vw,7rem),calc((100vw - 1240px)/2));
}
::selection{background:var(--champ);color:var(--char)}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--char);background:var(--ivory);line-height:1.65;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.1}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.kicker{font-family:var(--sans);font-size:.7rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--champd)}
html.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.22,.61,.36,1),transform .8s cubic-bezier(.22,.61,.36,1)}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none;transition:none}}
.wrap{max-width:1280px;margin:0 auto;padding:0 var(--mx)}

/* ---- media / image system (replace background with url('assets/…') to add photos) ---- */
.media{position:relative;overflow:hidden;background:linear-gradient(135deg,#2c2825,#1c1c1c 70%);background-size:cover;background-position:center}
.media::after{content:"2S";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:600;font-size:clamp(4rem,12vw,9rem);letter-spacing:-.06em;color:rgba(184,160,130,.10)}
.media.m-champ{background:linear-gradient(135deg,#c9b59a,#9a7e5e)}
.media.m-stone{background:linear-gradient(135deg,#e7ddcd,#cdbfa9)}
.media.m-char{background:linear-gradient(160deg,#33302b,#161616)}
.media.m-walnut{background:linear-gradient(135deg,#7c6a52,#4f4334)}
.media.m-champ::after,.media.m-stone::after{color:rgba(30,30,30,.10)}
.media.nomark::after{content:none}
.photo{background-size:cover;background-position:center;background-repeat:no-repeat;filter:saturate(.92) brightness(.98)}
.media.warm{filter:brightness(.74) saturate(1.12) sepia(.22) contrast(1.05)}

/* ---- nav ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:1.05rem var(--px);transition:background .4s,padding .4s}
nav.scrolled{background:rgba(17,17,17,.94);backdrop-filter:blur(8px);padding:.65rem var(--px)}
nav.solid{background:var(--char)}
.brand{display:flex;align-items:center;gap:.65rem;color:#fff}
.brand .m{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:-.08em;color:var(--champ)}
.brand .w{font-family:var(--serif);font-size:1rem;letter-spacing:.26em;color:#fff}
.logomark{height:30px;width:auto;display:block;flex:none}
.hero-logo{width:auto;height:clamp(150px,22vw,205px);margin-bottom:1.3rem;display:block}
.navlinks{display:flex;gap:1.9rem;align-items:center}
.navlinks a{font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;color:var(--stone);opacity:.9;transition:color .3s}
.navlinks a:hover,.navlinks a.active{color:var(--champ);opacity:1}
.btn{display:inline-block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:.7rem 1.5rem;border:1px solid var(--champ);color:var(--champ);transition:all .35s;cursor:pointer}
.btn:hover{background:var(--champ);color:var(--char)}
.btn-solid{background:var(--champ);color:var(--char);border:1px solid var(--champ)}
.btn-solid:hover{background:transparent;color:var(--champ)}
.btn-dark{background:var(--char);color:var(--ivory);border:1px solid var(--char)}
.btn-dark:hover{background:transparent;color:var(--char)}
.menu-toggle{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;z-index:70}

/* ---- page hero ---- */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;color:#fff;padding:8rem var(--px) 3.5rem}
.phero .media{position:absolute;inset:0;z-index:-1}
.phero::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(17,17,17,.92) 8%,rgba(17,17,17,.38));z-index:-1}
.phero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:500;max-width:16ch;letter-spacing:-.01em;text-wrap:balance}
.phero .kicker{color:var(--champ);margin-bottom:1rem}
.phero p{color:#E6DFD1;margin-top:1rem;max-width:48ch;font-size:1.05rem}

/* home cinematic hero */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;color:#fff;padding:7rem var(--mx) 4rem}
.hero .media{position:absolute;inset:0;z-index:-1}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(17,17,17,.9),rgba(17,17,17,.45));z-index:-1}
.hero .mark{font-family:var(--serif);font-size:clamp(3rem,8vw,5rem);font-weight:600;letter-spacing:-.07em;color:var(--champ);line-height:1;margin-bottom:1.2rem}
.hero h1{font-size:clamp(2.6rem,6.2vw,5.2rem);font-weight:500;max-width:17ch}
.hero h1 em{font-style:italic;color:var(--champ)}
.hero .tag{font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,3vw,2rem);color:var(--stone);margin-top:1.2rem}
.hero .sub{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);opacity:.8;margin-top:1.5rem}
.hero .cta{margin-top:2.3rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero{text-align:center;align-items:center}
.hero .hero-logo{margin-left:auto;margin-right:auto}
.hero h1{margin-left:auto;margin-right:auto}
.hero .cta{justify-content:center}
.scrollcue{position:absolute;bottom:1.7rem;left:var(--mx);font-size:.64rem;letter-spacing:.25em;text-transform:uppercase;color:var(--stone);opacity:.7}

/* ---- cinematic homepage intro ---- */
.cine{position:relative;height:200vh;height:200svh}
.cine-stage{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;background:linear-gradient(160deg,#262320,#141414 72%);color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 var(--mx)}
.cine-mark{transform-origin:center center;will-change:transform}
.cine-mark img{height:clamp(140px,20vw,205px);width:auto;display:block;margin:0 auto}
.cine-word{font-family:var(--serif);font-size:clamp(1.05rem,2.3vw,1.45rem);letter-spacing:.42em;color:#fff;margin-top:1.1rem;padding-left:.42em}
.cine-copy{position:absolute;left:0;right:0;bottom:11vh;padding:0 var(--mx);text-align:center;will-change:opacity,transform}
.cine-copy .kicker{display:block;color:var(--champ);margin-bottom:1rem}
.cine-copy h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.5rem,6.2vw,5.4rem);line-height:1.03;color:#fff;max-width:18ch;margin:0 auto}
.cine-copy h1 em{font-style:italic;color:var(--champ)}
.cine-copy .tag{font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2.6vw,1.8rem);color:var(--stone);margin-top:1rem}
.cine-copy .sub{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);opacity:.85;margin-top:1.2rem}
.cine-copy .cta{margin-top:1.9rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.cine-cue{position:absolute;bottom:1.5rem;left:0;right:0;text-align:center;font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
@media(max-width:680px){.cine-copy h1{font-size:2.3rem}.cine-mark img{height:125px}.cine-copy{bottom:9vh}}

/* ---- sections ---- */
section{padding:clamp(4.5rem,9vw,8.5rem) var(--px)}
.sec-head{max-width:780px;margin-bottom:3rem}
.sec-head h2{font-size:clamp(2.1rem,5vw,3.6rem);margin-top:.7rem;letter-spacing:-.012em;text-wrap:balance}
.lead{font-size:clamp(1.3rem,2.5vw,1.95rem);font-family:var(--serif);line-height:1.42;max-width:60ch}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.duo .sec-head{margin-bottom:0}
.lead .b{color:var(--champd);font-style:italic}
.muted{color:var(--muted)}
.dark{background:var(--char);color:#fff}
.dark .sec-head h2,.dark h2,.dark h3{color:#fff}
.dark .kicker{color:var(--champ)}
.dark p{color:var(--stone)}

/* editorial band: image + text */
.band{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.band.rev .b-media{order:2}
.b-media{aspect-ratio:4/5;border-radius:2px;transition:transform 1.4s cubic-bezier(.22,.61,.36,1)}
.band:hover .b-media,.founder:hover .b-media{transform:scale(1.02)}
.band h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:1rem}
.band p{color:var(--muted);margin-bottom:1rem}
.band.dark p{color:var(--stone)}

/* grids & cards */
.grid{display:grid;gap:1.6rem}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.grid>.reveal:nth-child(2){transition-delay:.07s}
.grid>.reveal:nth-child(3){transition-delay:.14s}
.grid>.reveal:nth-child(4){transition-delay:.21s}
.grid>.reveal:nth-child(5){transition-delay:.28s}
.grid>.reveal:nth-child(6){transition-delay:.35s}
.card{position:relative;padding:2.6rem 2rem 2.4rem;background:#fff;transition:transform .5s ease,box-shadow .5s ease}
.card::before{content:"";position:absolute;top:0;left:2rem;width:36px;height:1px;background:var(--champ);transition:width .5s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(30,30,30,.09)}
.card:hover::before{width:72px}
.card .num{font-family:var(--serif);font-size:2.3rem;color:var(--champd);line-height:1}
.card h3{font-size:1.42rem;margin:.7rem 0 .6rem}
.card p{font-size:.95rem;color:var(--muted);line-height:1.7}
.dark .card{background:#262320}
.dark .card h3{color:#fff}
.dark .card p{color:#b8b0a3}

/* service detail pages */
a.card{display:block;color:inherit}
.card .more{display:inline-block;margin-top:1.1rem;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--champd);transition:color .3s}
.card:hover .more{color:var(--char)}
.dark .card:hover .more{color:#fff}
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;max-width:1040px}
.facts .f h4{font-size:1.15rem;margin-bottom:.35rem}
.facts .f p{font-size:.92rem;color:var(--muted)}
.xlinks{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:2.4rem}
.xlinks a{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--stone);padding:.55rem 1.1rem;color:var(--walnut);transition:all .3s}
.xlinks a:hover{border-color:var(--champd);color:var(--champd)}
@media(max-width:880px){.facts{grid-template-columns:1fr}}

/* journey steps */
.steps{display:grid;gap:0;counter-reset:step;max-width:940px}
.step{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:start;padding:2rem 0;border-top:1px solid #E3D9C9}
.steps .step:last-child{border-bottom:1px solid #E3D9C9}
.step .n{font-family:var(--serif);font-size:2.4rem;color:var(--champd);line-height:1}
.step h3{font-size:1.5rem;margin-bottom:.4rem}
.step p{color:var(--muted);max-width:58ch}

/* stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;text-align:center}
.stat .v{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--champ);line-height:1}
.stat .l{font-size:.85rem;color:var(--stone);margin-top:.6rem;letter-spacing:.04em}

/* testimonials */
.quote{max-width:62ch;margin:0 auto;text-align:center}
.quote p{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,3.2vw,2.1rem);line-height:1.4;color:#f1ece2}
.quote .who{font-family:var(--sans);font-style:normal;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--champ);margin-top:1.4rem}

/* founder note */
.founder{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.founder .b-media{aspect-ratio:4/5}
.founder .sig{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--champd);margin-top:1.2rem}

/* CTA band */
.cta-band{text-align:center}
.cta-band h2{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:1.2rem}
.cta-band p{color:var(--stone);max-width:46ch;margin:0 auto 2rem}

/* forms */
form{display:grid;gap:1.05rem}
.field{display:flex;flex-direction:column;gap:.4rem}
label{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--walnut)}
input,select,textarea{font-family:var(--sans);font-size:1rem;font-weight:300;padding:.82rem .9rem;border:1px solid #c3b6a3;background:var(--ivory);color:var(--char);transition:border-color .3s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--walnut)}
textarea{resize:vertical;min-height:130px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1.05rem}
.hp{position:absolute;left:-9999px}

/* footer */
footer{background:var(--black);color:var(--muted);padding:3.6rem var(--px) 2.4rem}
.foot-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:2rem;border-bottom:1px solid #2b2b2b;padding-bottom:2rem}
.foot-brand{display:flex;align-items:center;gap:.6rem}
.foot-brand .m{font-family:var(--serif);font-size:1.9rem;font-weight:600;letter-spacing:-.08em;color:var(--champ)}
.foot-brand .w{font-family:var(--serif);font-size:1.2rem;letter-spacing:.22em;color:#fff}
.foot-tag{font-style:italic;font-family:var(--serif);color:var(--stone);margin-top:.5rem;font-size:1.05rem}
.foot-cols{display:flex;gap:3.5rem;flex-wrap:wrap}
.foot-col h4{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--champ);margin-bottom:.8rem;font-weight:500}
.foot-col a,.foot-col p{font-size:.9rem;color:#b8b0a3;display:block;margin-bottom:.35rem}
.foot-col a:hover{color:#fff}
.foot-bottom{margin-top:2rem;font-size:.72rem;letter-spacing:.05em;color:#6a655c;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}

/* responsive */
@media(max-width:980px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:1fr}
  .duo{grid-template-columns:1fr;gap:1.6rem}
  .band,.founder{grid-template-columns:1fr}
  .band.rev .b-media{order:0}
  .stats{grid-template-columns:1fr;gap:2.2rem}
}
/* nav collapses early enough that six links never overflow */
@media(max-width:900px){
  .navlinks{position:fixed;inset:0 0 0 min(38%,260px);background:rgba(17,17,17,.97);backdrop-filter:blur(8px);flex-direction:column;justify-content:center;align-items:flex-start;gap:1.9rem;transform:translateX(100%);transition:transform .4s;padding:2.4rem;z-index:65}
  .navlinks a{font-size:.95rem;letter-spacing:.15em;padding:.2rem 0}
  .navlinks .btn{margin-top:.6rem;padding:.8rem 1.6rem}
  .navlinks.open{transform:none}
  .menu-toggle{display:block}
}
@media(max-width:680px){
  .navlinks{inset:0 0 0 22%}
  .brand .w{display:none}
  .g2,.g4{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .step{gap:1.1rem;padding:1.6rem 0}
  .step .n{font-size:1.9rem}
  .card{padding:2rem 1.5rem 1.9rem}
  .card::before{left:1.5rem}
  .phero{min-height:56vh;padding-top:6.5rem}
  .cta-band .btn{width:100%;max-width:320px}
  .xlinks a{padding:.7rem 1.1rem}
  .facts{gap:1.2rem}
  footer{padding-top:2.8rem}
  .foot-cols{gap:2rem}
}
