/* =========================================================
   ARCAVA — Royal / Classic Elegant stylesheet
   ========================================================= */
:root{
  --navy:#142544;
  --navy-deep:#0c1730;
  --navy-soft:#1d3258;
  --bordeaux:#5e1a26;
  --bordeaux-soft:#7a2531;
  --gold:#c2a24c;
  --gold-light:#dcc684;
  --gold-deep:#9c7f33;
  --cream:#f7f2e8;
  --paper:#fffdf8;
  --ink:#22242b;
  --muted:#5d5f68;
  --line:rgba(194,162,76,.45);
  --shadow:0 18px 50px rgba(12,23,48,.16);
  --serif:'Cormorant Garamond', Georgia, serif;
  --display:'Playfair Display', Georgia, serif;
  --body:'EB Garamond', Georgia, serif;
  --sans:'Mukta', system-ui, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);
  background:var(--paper);font-size:20px;line-height:1.72;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--bordeaux);text-decoration:none}
a:hover{color:var(--gold-deep)}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.18;color:var(--navy);margin:0 0 .5em}
h2{font-size:2.3rem}
h3{font-size:1.5rem;font-family:var(--serif);font-weight:600;letter-spacing:.2px}
p{margin:0 0 1.15em}
.wrap{max-width:1140px;margin:0 auto;padding:0 28px}
.narrow{max-width:820px;margin-left:auto;margin-right:auto}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;font-weight:600;color:var(--gold-deep)}
.center{text-align:center}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:60;background:rgba(12,23,48,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid rgba(194,162,76,.28)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--display);color:#fff;font-size:1.5rem;letter-spacing:.42em;
  font-weight:600;padding-left:.42em}
.brand small{display:block;font-family:var(--sans);font-size:.52rem;letter-spacing:.34em;
  color:var(--gold-light);margin-top:2px;padding-left:.1em}
nav.main{display:flex;gap:26px;align-items:center}
nav.main a{font-family:var(--sans);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;
  color:#e9e3d4;font-weight:500;position:relative;padding:6px 0}
nav.main a:hover,nav.main a.active{color:var(--gold-light)}
nav.main a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--gold)}
.nav-cta{border:1px solid var(--gold);border-radius:2px;padding:9px 18px !important;color:var(--gold-light) !important}
.nav-cta:hover{background:var(--gold);color:var(--navy-deep) !important}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2px;background:var(--gold-light);margin:5px 0;transition:.3s}

/* ---------- hero ---------- */
.hero{position:relative;min-height:82vh;display:flex;align-items:center;
  color:#fff;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,23,48,.62),rgba(12,23,48,.78));z-index:1}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .wrap{position:relative;z-index:2;padding-top:60px;padding-bottom:60px}
.hero .eyebrow{color:var(--gold-light)}
.hero h1{color:#fff;font-size:clamp(2.6rem,6vw,4.6rem);margin:.25em 0 .35em;
  text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero .lede{font-family:var(--serif);font-size:clamp(1.3rem,2.6vw,1.9rem);
  font-style:italic;color:#f3ecdb;max-width:760px;margin:0 auto 1.6em}
.crest{width:54px;height:54px;margin:0 auto 18px;opacity:.95}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-family:var(--sans);font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;font-weight:600;padding:14px 30px;border-radius:2px;cursor:pointer;
  transition:.25s;border:1px solid transparent}
.btn-gold{background:var(--gold);color:var(--navy-deep)}
.btn-gold:hover{background:var(--gold-light);color:var(--navy-deep)}
.btn-ghost{border-color:var(--gold-light);color:var(--gold-light)}
.btn-ghost:hover{background:rgba(255,255,255,.08);color:#fff}
.btn-dark{background:var(--bordeaux);color:#fff}
.btn-dark:hover{background:var(--bordeaux-soft);color:#fff}
.btn+.btn{margin-left:12px}

/* ---------- sections ---------- */
section{padding:92px 0}
section.tight{padding:64px 0}
.section-cream{background:var(--cream)}
.section-navy{background:var(--navy);color:#ece6d6}
.section-navy h2,.section-navy h3{color:#fff}
.section-navy .eyebrow{color:var(--gold-light)}
.section-navy a{color:var(--gold-light)}
.lead{font-size:1.28rem;font-family:var(--serif);color:var(--muted)}
.section-navy .lead{color:#cfd6e4}
.divider{width:70px;height:2px;background:var(--gold);border:0;margin:22px auto}
.divider.left{margin-left:0}

/* ornamental heading block */
.sec-head{text-align:center;margin-bottom:54px}
.sec-head .divider{margin:18px auto 0}

/* ---------- pull quote ---------- */
.pullquote{font-family:var(--serif);font-style:italic;font-size:1.7rem;line-height:1.5;
  color:var(--navy);border-left:3px solid var(--gold);padding:6px 0 6px 30px;margin:38px 0}
.section-navy .pullquote{color:#fff;border-color:var(--gold)}
.pullquote cite{display:block;font-style:normal;font-family:var(--sans);font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);margin-top:14px}
.section-navy .pullquote cite{color:var(--gold-light)}
.banner-quote{text-align:center;max-width:880px;margin:0 auto}
.banner-quote .q{font-family:var(--display);font-size:clamp(1.6rem,3.4vw,2.5rem);
  font-style:italic;line-height:1.4}

/* ---------- grids ---------- */
.grid{display:grid;gap:34px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.wide-text{grid-template-columns:1.15fr .85fr}

/* figure / framed image */
.framed{position:relative;border-radius:3px;overflow:hidden;box-shadow:var(--shadow)}
.framed img{width:100%;height:100%;object-fit:cover}
.framed.tall img{aspect-ratio:3/4}
.framed.wide img{aspect-ratio:4/3}
figure{margin:0}
figcaption{font-family:var(--sans);font-size:.78rem;color:var(--muted);
  letter-spacing:.03em;margin-top:10px;text-align:center}
.section-navy figcaption{color:#aeb7c7}

/* ---------- cards ---------- */
.card{background:var(--paper);border:1px solid rgba(20,37,68,.1);border-top:3px solid var(--gold);
  padding:34px 30px;border-radius:3px;box-shadow:0 8px 28px rgba(12,23,48,.07);height:100%}
.section-cream .card{background:#fff}
.card h3{margin-top:0}
.card .ico{font-family:var(--display);font-size:1.6rem;color:var(--gold-deep);margin-bottom:6px}

/* ---------- stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .num{font-family:var(--display);font-size:2.9rem;color:var(--gold-light);line-height:1}
.stat .lbl{font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:#c4ccda;margin-top:10px}

/* ---------- timeline ---------- */
.timeline{position:relative;max-width:860px;margin:0 auto;padding-left:34px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--gold),rgba(194,162,76,.15))}
.tl{position:relative;padding:0 0 40px 30px}
.tl::before{content:"";position:absolute;left:-31px;top:6px;width:14px;height:14px;border-radius:50%;
  background:var(--paper);border:3px solid var(--gold)}
.tl .yr{font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--bordeaux);font-weight:600}
.tl h3{margin:.1em 0 .25em}
.tl p{margin:0;color:var(--muted);font-size:1.02rem}

/* ---------- people ---------- */
.person{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start;margin-bottom:30px}
.person .framed{align-self:stretch}
.role{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;margin-bottom:6px}

/* ---------- video ---------- */
.videos{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.vid{position:relative;padding-bottom:56.25%;height:0;border-radius:3px;overflow:hidden;
  box-shadow:var(--shadow);border:1px solid rgba(194,162,76,.3)}
.vid iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery .framed img{aspect-ratio:4/3}

/* ---------- release covers ---------- */
.covers{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.cover figure img{aspect-ratio:1/1;object-fit:cover;border-radius:3px;box-shadow:var(--shadow)}
.cover figcaption{margin-top:12px}
.cover .ttl{display:block;font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--navy)}
.section-navy .cover .ttl{color:#fff}

/* ---------- list ---------- */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{position:relative;padding:10px 0 10px 34px;border-bottom:1px solid rgba(20,37,68,.08)}
.checklist li::before{content:"✦";position:absolute;left:4px;top:10px;color:var(--gold-deep)}
.checklist li b{color:var(--navy)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--bordeaux);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band .lead{color:#f0d9dc}

/* ---------- footer ---------- */
footer{background:var(--navy-deep);color:#aab3c4;padding:64px 0 30px;font-size:.96rem}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
footer .brand{font-size:1.4rem;color:#fff;padding-left:0}
footer h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-light);margin:0 0 16px}
footer a{color:#c2cad8;display:block;margin-bottom:9px;font-size:.96rem}
footer a:hover{color:var(--gold-light)}
footer .fineprint{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;text-align:center;
  font-family:var(--sans);font-size:.76rem;letter-spacing:.04em;color:#7e879a;line-height:1.8}

/* ---------- reveal anim (content visible by default; animates only when JS active) ---------- */
.reveal{transition:opacity .8s ease,transform .8s ease}
.js .reveal{opacity:0;transform:translateY(22px)}
.js .reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:960px){
  body{font-size:18px}
  h2{font-size:1.9rem}
  .split,.split.wide-text{grid-template-columns:1fr;gap:34px}
  .g3,.g4,.videos,.covers{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr;gap:36px 20px}
  .person{grid-template-columns:1fr;gap:22px;max-width:480px;margin:0 auto 44px}
  .gallery{grid-template-columns:1fr 1fr}
  nav.main{position:fixed;inset:74px 0 auto 0;flex-direction:column;background:var(--navy-deep);
    gap:0;padding:10px 0;transform:translateY(-130%);transition:.35s;border-bottom:1px solid var(--line)}
  nav.main.open{transform:none}
  nav.main a{padding:14px 28px;width:100%;border-bottom:1px solid rgba(255,255,255,.06)}
  nav.main a.active::after{display:none}
  .nav-cta{margin:12px 28px;text-align:center}
  .burger{display:block}
}
@media(max-width:560px){
  .g2,.g3,.g4,.videos,.covers,.gallery,.stats{grid-template-columns:1fr}
  section{padding:64px 0}
  .wrap{padding:0 20px}
  .brand{font-size:1.25rem;letter-spacing:.3em}
}
