/* ===========================================================
   RUTOIS INTERNATIONAL REALTY — Design System
   Luxury editorial aesthetic (inspired by kevinrutois.com)
   =========================================================== */

:root{
  --ink:#161514;
  --ink-soft:#3a3733;
  --muted:#7c766e;
  --line:#e6e1d8;
  --cream:#f7f4ee;
  --cream-2:#efe9df;
  --white:#ffffff;
  --gold:#b08d57;
  --gold-deep:#9a774180;
  --gold-solid:#9a7741;
  --charcoal:#1b1a18;
  --shadow:0 18px 50px -24px rgba(20,18,15,.35);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost','Helvetica Neue',Arial,sans-serif;
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--white);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s ease}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;color:var(--ink)}
h1{font-size:clamp(2.8rem,6vw,5.2rem);letter-spacing:-.5px}
h2{font-size:clamp(2.1rem,4vw,3.4rem)}
h3{font-size:clamp(1.5rem,2.4vw,2rem)}
.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:500;
  color:var(--gold-solid);
  display:inline-block;
  margin-bottom:1.1rem;
}
.lede{font-size:1.18rem;color:var(--ink-soft);max-width:62ch}
p{color:var(--ink-soft)}
p + p{margin-top:1.1rem}
.serif-accent{font-family:var(--serif);font-style:italic}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.section{padding:clamp(64px,9vw,130px) 0}
.section.tight{padding:clamp(48px,6vw,80px) 0}
.bg-cream{background:var(--cream)}
.bg-ink{background:var(--charcoal);color:#efeae1}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}
.bg-ink p{color:#cabfb0}
.center{text-align:center}
.center .lede{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.74rem;
  font-weight:500;
  padding:16px 34px;
  border:1px solid var(--ink);
  color:var(--ink);
  background:transparent;
  cursor:pointer;
  transition:all .3s ease;
}
.btn:hover{background:var(--ink);color:#fff}
.btn-gold{border-color:var(--gold-solid);color:var(--gold-solid)}
.btn-gold:hover{background:var(--gold-solid);color:#fff}
.btn-light{border-color:#fff;color:#fff}
.btn-light:hover{background:#fff;color:var(--ink)}
.btn-solid{background:var(--ink);color:#fff}
.btn-solid:hover{background:var(--gold-solid);border-color:var(--gold-solid)}

/* ---------- Header / Nav ---------- */
.topbar{
  background:var(--charcoal);
  color:#cdc4b6;
  font-size:.74rem;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:18px}
.topbar a:hover{color:#fff}
.topbar .lang a{margin-left:14px;opacity:.7}
.topbar .lang a.active,.topbar .lang a:hover{opacity:1;color:var(--gold)}

.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-size:1.45rem;letter-spacing:.5px}
.brand .mark{
  width:42px;height:42px;border:1px solid var(--gold-solid);color:var(--gold-solid);
  display:grid;place-items:center;font-size:1.2rem;font-weight:600;border-radius:2px;
}
.brand small{display:block;font-family:var(--sans);font-size:.58rem;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.menu{display:flex;align-items:center;gap:30px;list-style:none}
.menu a{
  font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);font-weight:500;
  position:relative;padding:4px 0;
}
.menu a:hover,.menu a.active{color:var(--ink)}
.menu a.active::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:var(--gold-solid)}
.nav-cta{margin-left:8px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:var(--ink);transition:transform .3s ease,opacity .3s ease}
.burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero .slides{position:absolute;inset:0}
.hero .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.08);transition:opacity 1.6s ease, transform 7s ease}
.hero .slide.on{opacity:1;transform:scale(1)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,10,8,.62) 0%,rgba(11,10,8,.5) 38%,rgba(11,10,8,.92) 100%);z-index:1}
.hero .wrap{position:relative;z-index:2;padding-bottom:clamp(50px,8vw,100px);width:100%}
.hero h1{color:#fff;max-width:16ch;text-shadow:0 2px 22px rgba(0,0,0,.45)}
.hero .eyebrow{color:var(--gold)}
.hero .lede{color:#ffffff;max-width:52ch;margin-top:1.4rem;text-shadow:0 1px 14px rgba(0,0,0,.5)}
.hero .hero-actions{margin-top:2.2rem;display:flex;gap:16px;flex-wrap:wrap}
.hero .scroll-meta{position:absolute;left:0;right:0;bottom:22px;z-index:2;text-align:center;font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;color:#ece2d1;text-shadow:0 1px 10px rgba(0,0,0,.5)}

/* page hero (interior) */
.page-hero{position:relative;min-height:52vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--charcoal)}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.55}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,14,12,.4),rgba(15,14,12,.75))}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{color:#fff;max-width:18ch}
.page-hero .eyebrow{color:var(--gold)}
.page-hero p{color:#e7ddcd;max-width:60ch;margin-top:1rem}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.stats .stat{background:var(--white);padding:34px 24px;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center}
.bg-ink .stats{background:rgba(255,255,255,.12)}
.bg-ink .stats .stat{background:var(--charcoal)}
.stat .num{font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.3rem);color:var(--gold-solid);line-height:1}
.bg-ink .stat .num{color:var(--gold)}
.stat .lab{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);margin-top:.7rem}
.stat .lab.producer{font-size:.66rem;letter-spacing:.12em;line-height:1.85}
.bg-ink .stat .lab{color:#b3a690}

/* ---------- Split / Feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.split.reverse .split-media{order:2}
.split-media img{width:100%;height:100%;object-fit:cover;box-shadow:var(--shadow)}
.split-media{position:relative;aspect-ratio:4/5;overflow:hidden}
.split-media .badge{position:absolute;left:0;bottom:0;background:var(--charcoal);color:#fff;padding:18px 26px;font-family:var(--serif);font-size:1.3rem}
.split-media .badge span{display:block;font-family:var(--sans);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}

/* ---------- Cards ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.card{background:var(--white);border:1px solid var(--line);transition:transform .35s ease,box-shadow .35s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .card-body{padding:30px 28px}
.card .ic{width:46px;height:46px;color:var(--gold-solid);margin-bottom:16px}
.card h3{margin-bottom:10px}
.card p{font-size:.96rem}
.card-img{aspect-ratio:3/2;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .card-img img{transform:scale(1.06)}

/* value list */
.value-list{list-style:none;display:grid;gap:0}
.value-list li{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.value-list li:last-child{border-bottom:none}
.value-list .vn{font-family:var(--serif);font-size:1.6rem;color:var(--gold-solid);line-height:1;min-width:48px}
.value-list h4{font-family:var(--sans);font-size:1rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.value-list p{font-size:.95rem;margin:0}

/* ---------- Press / As Seen In ---------- */
.press-strip{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,60px);align-items:center;justify-content:center;opacity:.8}
.press-strip span{font-family:var(--serif);font-size:1.4rem;letter-spacing:.02em;color:var(--ink-soft)}
.press-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.press-card{display:flex;flex-direction:column;border:1px solid var(--line);background:#fff;padding:34px 32px;transition:.3s}
.press-card:hover{border-color:var(--gold-solid);box-shadow:var(--shadow);transform:translateY(-4px)}
.press-card .outlet{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-solid);font-weight:600;margin-bottom:14px}
.press-card h3{font-size:1.4rem;margin-bottom:14px;line-height:1.2}
.press-card p{font-size:.95rem;margin-bottom:20px;flex:1}
.press-card .readmore{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--gold-solid);padding-bottom:3px;align-self:flex-start}
.press-card .readmore:hover{color:var(--gold-solid)}

/* quote */
.quote{max-width:30ch;margin:0 auto;text-align:center}
.quote blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.8rem,3.4vw,2.8rem);line-height:1.25;color:var(--ink)}
.bg-ink .quote blockquote{color:#fff}
.quote .by{margin-top:1.6rem;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-solid)}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.team-card .photo{aspect-ratio:3/4;overflow:hidden;background:var(--cream-2)}
.team-card .photo img{width:100%;height:100%;object-fit:cover}
.team-card h3{margin-top:18px;font-size:1.5rem}
.team-card .role{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-solid);margin-top:4px}
.team-card p{font-size:.92rem;margin-top:10px}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:14px}
.gallery a{overflow:hidden;display:block}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery a:hover img{transform:scale(1.07)}
.gallery .tall{grid-row:span 2}
.gallery .wide{grid-column:span 2}

/* video */
.video-wrap{position:relative;aspect-ratio:16/9;background:var(--charcoal);overflow:hidden}
.video-wrap video,.video-wrap iframe{width:100%;height:100%;object-fit:cover;border:0}

/* ---------- CTA band ---------- */
.cta-band{position:relative;color:#fff;text-align:center;overflow:hidden;background:var(--charcoal)}
.cta-band .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.32}
.cta-band::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(15,14,12,.55),rgba(15,14,12,.75))}
.cta-band .wrap{position:relative;z-index:2}
.cta-band h2{color:#fff;max-width:20ch;margin:0 auto}
.cta-band p{color:#ddd2c1;max-width:54ch;margin:1rem auto 2rem}

/* ---------- Forms ---------- */
.form{display:grid;gap:18px;max-width:640px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px}
.form input,.form select,.form textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:.95rem;color:var(--ink);
}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--gold-solid)}
.form textarea{min-height:130px;resize:vertical}

/* contact info */
.contact-info{display:grid;gap:28px}
.contact-info .item .k{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-solid);margin-bottom:6px}
.contact-info .item .v{font-family:var(--serif);font-size:1.35rem}

/* ---------- Footer ---------- */
.footer{background:var(--charcoal);color:#b9ad9c;padding:72px 0 30px;font-size:.9rem}
.footer a{color:#cabfb0}
.footer a:hover{color:#fff}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .brand{color:#fff;margin-bottom:18px}
.footer .brand small{color:#9a8f7e}
.footer h5{color:#fff;font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
.footer ul{list-style:none;display:grid;gap:10px;font-size:.9rem}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:24px;font-size:.78rem;color:#8c8273}
.socials{display:flex;gap:14px}
.socials a{width:36px;height:36px;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;border-radius:50%}
.socials a:hover{border-color:var(--gold);color:var(--gold)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .footer-top{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .grid-3,.team-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .menu{
    position:fixed;inset:84px 0 auto 0;background:#fff;flex-direction:column;align-items:flex-start;
    gap:0;padding:10px 24px 24px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s ease;height:auto;
  }
  .menu.open{transform:none}
  .menu li{width:100%;border-bottom:1px solid var(--line)}
  .menu a{display:block;padding:16px 0;width:100%}
  .menu .nav-cta{display:none}
  .burger{display:flex}
  .split,.grid-2,.press-grid,.form .row{grid-template-columns:1fr}
  .split.reverse .split-media{order:0}
  .grid-3,.team-grid{grid-template-columns:1fr}
  .topbar .wrap{font-size:.66rem}
  .topbar .phones{display:none}
}

/* ---------- Press logo wall ---------- */
.logo-wall{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(26px,5vw,62px)}
.logo-wall img{height:38px;width:auto;max-width:150px;object-fit:contain;filter:grayscale(1);opacity:.6;transition:filter .3s ease,opacity .3s ease}
.logo-wall img:hover{filter:grayscale(0);opacity:1}
.press-card .outlet-logo{height:30px;width:auto;max-width:140px;object-fit:contain;margin-bottom:16px;filter:grayscale(1);opacity:.85}
.press-card:hover .outlet-logo{filter:grayscale(0);opacity:1}

/* ---------- Team card contact ---------- */
.team-card .card-contact{margin-top:14px;display:flex;flex-direction:column;gap:4px;font-size:.86rem}
.team-card .card-contact a{color:var(--gold-solid);letter-spacing:.01em}
.team-card .card-contact a:hover{color:var(--ink);text-decoration:underline}

/* ---------- Brand logo (nav + footer) ---------- */
.brand-logo{height:42px;width:auto;display:block}
.nav .brand{gap:0}
.footer .brand-logo{height:50px;margin-bottom:18px}
@media(max-width:760px){ .brand-logo{height:34px} }


/* ---------- Home welcome media (compact, horizontal) ---------- */
.split-media.media-wide{aspect-ratio:16/11;align-self:center;max-height:440px}
.split-media.media-wide img{object-position:center}
.btn-center{display:block;width:fit-content;margin-left:auto;margin-right:auto;text-align:center}
.h2-spaced{margin-bottom:1.6rem}

.page-hero.hero-dark::after{background:linear-gradient(180deg,rgba(11,10,8,.6),rgba(11,10,8,.82))}

/* ---------- Listings slideshow ---------- */
.slideshow{position:relative;max-width:1040px;margin:0 auto;aspect-ratio:16/9;overflow:hidden;background:#0d0c0a;box-shadow:var(--shadow)}
.slideshow .ss-slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease}
.slideshow .ss-slide.on{opacity:1}
.slideshow .ss-slide img{width:100%;height:100%;object-fit:cover;display:block}
.slideshow .ss-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:52px;height:52px;border:none;background:rgba(13,12,10,.45);color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .25s ease;backdrop-filter:blur(4px)}
.slideshow .ss-btn:hover{background:var(--gold-solid)}
.slideshow .ss-prev{left:14px}
.slideshow .ss-next{right:14px}
.slideshow .ss-dots{position:absolute;left:0;right:0;bottom:16px;z-index:3;display:flex;gap:9px;justify-content:center}
.slideshow .ss-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.5);cursor:pointer;padding:0;transition:background .25s ease,transform .25s ease}
.slideshow .ss-dots button.on{background:#fff;transform:scale(1.25)}
.slideshow .ss-count{position:absolute;top:16px;right:18px;z-index:3;color:#fff;font-size:.74rem;letter-spacing:.18em;background:rgba(13,12,10,.45);padding:5px 12px;backdrop-filter:blur(4px)}
@media(max-width:600px){ .slideshow{aspect-ratio:4/3} .slideshow .ss-btn{width:42px;height:42px;font-size:1.4rem} }

/* ---------- About intro: compact horizontal media ---------- */
.split-media.media-compact{aspect-ratio:3/2;max-height:360px;align-self:center}

/* ---------- About: founder small photo left, text right ---------- */
.split-founder{display:grid;grid-template-columns:minmax(0,290px) 1fr;gap:clamp(28px,5vw,64px);align-items:start}
.split-founder .founder-photo{aspect-ratio:3/4;overflow:hidden;box-shadow:var(--shadow)}
.split-founder .founder-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
@media(max-width:760px){ .split-founder{grid-template-columns:1fr;max-width:300px} }

/* ---------- About: family legacy photo zoomed out (full image) ---------- */
.split-media.media-contain{aspect-ratio:4/3;background:#100f0d}
.split-media.media-contain img{object-fit:contain}

/* ---------- About: keep team as one row of three ---------- */
.team-grid{grid-template-columns:repeat(3,1fr)}
@media(max-width:600px){ .team-grid{grid-template-columns:1fr} }

/* ---------- About founder: heading + rule on top, text left, photo right ---------- */
.founder-head{border-bottom:1px solid var(--line);padding-bottom:20px;margin-bottom:42px}
.founder-layout{display:grid;grid-template-columns:1.45fr 1fr;gap:clamp(34px,5vw,68px);align-items:start}
.founder-layout .founder-img{aspect-ratio:3/4;overflow:hidden;box-shadow:var(--shadow)}
.founder-layout .founder-img img{width:100%;height:100%;object-fit:cover;object-position:center top}
@media(max-width:760px){ .founder-layout{grid-template-columns:1fr} }

/* ---------- Home hero centered ---------- */
.hero .wrap{text-align:center}
.hero h1{margin-left:auto;margin-right:auto}
.hero .lede{margin-left:auto;margin-right:auto}
.hero .hero-actions{justify-content:center}

/* ---------- Media: three videos side by side ---------- */
.media-videos{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start;max-width:1180px;margin:0 auto}
.media-videos video{width:100%;aspect-ratio:9/16;object-fit:cover;background:#000;box-shadow:var(--shadow);display:block}
.media-videos .ig{width:100%;background:#000;box-shadow:var(--shadow);overflow:hidden}
.media-videos .ig iframe{width:100%;height:640px;border:0;display:block;background:#fff}
@media(max-width:860px){ .media-videos{grid-template-columns:1fr;max-width:400px} .media-videos .ig iframe{height:600px} }

/* ---------- Media: Instagram click-to-play with custom cover ---------- */
.media-videos .ig-facade{position:relative;width:100%;aspect-ratio:9/16;border:0;cursor:pointer;background-size:cover;background-position:center;box-shadow:var(--shadow);display:block;padding:0}
.media-videos .ig-facade::after{content:"";position:absolute;inset:0;background:rgba(13,12,10,.28);transition:background .3s ease}
.media-videos .ig-facade:hover::after{background:rgba(13,12,10,.12)}
.media-videos .ig-facade .ig-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:66px;height:66px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--ink);display:grid;place-items:center;font-size:1.5rem;padding-left:5px;transition:transform .25s ease}
.media-videos .ig-facade:hover .ig-play{transform:translate(-50%,-50%) scale(1.08)}
.media-videos .ig-loaded iframe{width:100%;height:640px;border:0;display:block;background:#fff;box-shadow:var(--shadow)}
@media(max-width:860px){ .media-videos .ig-loaded iframe{height:600px} }

/* ===========================================================
   MOBILE RESPONSIVE REFINEMENTS
   =========================================================== */

/* Collapse the nav earlier so the menu never crowds on tablets */
@media(max-width:900px){
  .nav .wrap{height:72px}
  .burger{display:flex}
  .menu{
    position:fixed;inset:72px 0 auto 0;background:#fff;flex-direction:column;align-items:flex-start;
    gap:0;padding:6px 24px 20px;border-bottom:1px solid var(--line);
    transform:translateY(-135%);transition:transform .35s ease;height:auto;
    box-shadow:0 26px 44px -28px rgba(20,18,15,.45);
    max-height:calc(100vh - 72px);overflow-y:auto;
  }
  .menu.open{transform:none}
  .menu li{width:100%;border-bottom:1px solid var(--line)}
  .menu li:last-child{border-bottom:none}
  .menu a{display:block;padding:15px 2px;width:100%;font-size:.82rem}
  .menu a.active::after{display:none}
  .menu .nav-cta{display:none}
  .brand-logo{height:36px}
}

/* Tablets / large phones */
@media(max-width:760px){
  .hero{min-height:80vh}
  .footer-top{grid-template-columns:1fr 1fr;gap:34px 28px}
  .footer-top > div:first-child{grid-column:1 / -1}
}

/* Phones */
@media(max-width:600px){
  body{font-size:16px}
  .section{padding:52px 0}
  .section.tight{padding:38px 0}

  /* Hero */
  .hero{min-height:78vh}
  .hero h1{font-size:2.35rem;line-height:1.12}
  .hero .lede{font-size:1.02rem;margin-top:1.1rem}
  .hero .hero-actions{flex-direction:column;align-items:stretch;gap:12px;width:100%;margin-top:1.7rem}
  .hero .hero-actions .btn{width:100%;text-align:center}
  .scroll-meta{font-size:.58rem;letter-spacing:.22em;padding:0 16px;bottom:16px}

  /* Interior page heroes */
  .page-hero{min-height:46vh !important}
  .page-hero p{font-size:1rem}

  h2{font-size:1.95rem}
  .lede{font-size:1.06rem}

  /* Stats — keep two across, tighten */
  .stats{grid-template-columns:1fr 1fr}
  .stat{padding:24px 14px}
  .stat .lab.producer{font-size:.6rem;line-height:1.7}

  /* Buttons a touch smaller */
  .btn{padding:14px 26px;font-size:.7rem}

  /* Cards / press */
  .card .card-body{padding:26px 22px}
  .press-grid{gap:20px}
  .press-card{padding:26px 22px}
  .press-card h3{font-size:1.28rem}

  /* Team */
  .team-card h3{font-size:1.4rem}

  /* Contact: map renders as a usable square-ish block, not a thin sliver */
  .bg-cream .video-wrap{aspect-ratio:4/3 !important}
  .contact-info{gap:22px}
  .contact-info .item .v{font-size:1.2rem}

  /* Gallery single column */
  .gallery{grid-template-columns:1fr;grid-auto-rows:210px}

  /* Quote */
  .quote blockquote{font-size:1.7rem}

  /* Footer */
  .footer{padding:54px 0 26px}
  .footer-bottom{justify-content:center;text-align:center}
}

/* Small phones */
@media(max-width:430px){
  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-top > div:first-child{grid-column:auto}
  .stats{grid-template-columns:1fr}
  .stat{padding:22px 14px}
  .topbar .wrap{justify-content:center}
  .hero h1{font-size:2.1rem}
  h1{font-size:2.4rem}
}
