/* ===========================================================
   K-HILLS HERITAGE RESORTS & CONVENTION — "THE HILL ATLAS"
   Forest green + ivory + antique gold, editorial heritage.
   =========================================================== */

:root{
  --burgundy:#1E3A2F;
  --burgundy-deep:#0F2218;
  --burgundy-soft:#2D5040;
  --ivory:#F4ECD8;
  --ivory-warm:#EDE5CC;
  --paper:#FAF6ED;
  --brass:#B8924A;
  --brass-deep:#8A6A30;
  --ink:#141A16;
  --ink-soft:#222C24;
  --muted:#556659;
  --rule:rgba(20,26,22,.13);
  --rule-dark:rgba(244,236,216,.18);

  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter Tight','Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --mal:'Noto Serif Malayalam','Fraunces',serif;

  --maxw:1320px;
  --pad-x:clamp(20px,4vw,68px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

::selection{background:var(--burgundy);color:var(--ivory)}

/* ---------- Type scale ---------- */
.h-display{
  font-family:var(--serif);
  font-weight:380;
  font-variation-settings:"SOFT" 100,"opsz" 144;
  font-size:clamp(48px,8.5vw,128px);
  line-height:.94;
  letter-spacing:-.02em;
  margin:0;
}
.h-display em{
  font-style:italic;
  font-variation-settings:"SOFT" 100,"opsz" 144,"wght" 360;
  color:var(--brass);
}
.h-hero{
  font-family:var(--serif);
  font-weight:380;
  font-variation-settings:"SOFT" 80,"opsz" 144;
  font-size:clamp(40px,6vw,86px);
  line-height:1;
  letter-spacing:-.015em;
  margin:0;
}
.h-hero em{
  font-style:italic;
  color:var(--brass);
  font-variation-settings:"SOFT" 100,"opsz" 144,"wght" 340;
}
.h-section{
  font-family:var(--serif);
  font-weight:400;
  font-variation-settings:"SOFT" 60,"opsz" 120;
  font-size:clamp(32px,4.4vw,64px);
  line-height:1.04;
  letter-spacing:-.01em;
  margin:0;
}
.h-section em{font-style:italic;color:var(--brass)}
.h-card{
  font-family:var(--serif);
  font-weight:420;
  font-size:clamp(22px,2.3vw,34px);
  line-height:1.1;
  letter-spacing:-.005em;
  margin:0;
}

.lead{
  font-family:var(--sans);
  font-size:clamp(16px,1.3vw,21px);
  line-height:1.55;
  color:var(--ink-soft);
  max-width:62ch;
}
.body{
  font-size:16px;
  line-height:1.65;
  color:var(--ink-soft);
}
.kicker{
  font-family:var(--mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--brass-deep);
  font-weight:500;
}
.mal{
  font-family:var(--mal);
  font-weight:500;
  color:var(--brass);
  letter-spacing:-.005em;
}
.num{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  color:var(--muted);
  text-transform:uppercase;
}
.rule{
  height:1px;background:var(--rule);width:100%;
}
.rule-brass{
  height:1px;background:var(--brass);width:100%;
  position:relative;
}
.rule-brass::before{
  content:"◆";position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  color:var(--brass);background:var(--paper);
  padding:0 12px;font-size:10px;
}

/* ---------- Layout primitives ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.section{padding:clamp(72px,11vh,160px) 0}
.section-tight{padding:clamp(48px,7vh,96px) 0}
.section-dark{background:var(--burgundy-deep);color:var(--ivory)}
.section-burg{background:var(--burgundy);color:var(--ivory)}
.section-ivory{background:var(--ivory)}

.section-dark .lead,.section-burg .lead,.section-dark .body,.section-burg .body{color:rgba(244,236,221,.85)}
.section-dark .kicker,.section-burg .kicker{color:var(--brass)}
.section-dark .rule,.section-burg .rule{background:var(--rule-dark)}
.section-dark .rule-brass::before,.section-burg .rule-brass::before{background:var(--burgundy-deep)}
.section-burg .rule-brass::before{background:var(--burgundy)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.5vw,36px)}

.flex-bw{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:18px var(--pad-x);
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(251,246,236,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--rule);
  transition:background .3s ease,color .3s ease;
}
.nav.scrolled{background:rgba(251,246,236,.97)}
.nav-mark{
  font-family:var(--serif);
  font-weight:500;
  font-size:18px;
  letter-spacing:.04em;
  font-variation-settings:"SOFT" 60;
  display:flex;align-items:center;gap:10px;
}
.nav-mark .mono-tag{
  font-family:var(--mono);
  font-size:9px;letter-spacing:.2em;
  color:var(--brass-deep);
  border:1px solid var(--brass);
  padding:3px 6px;
  border-radius:2px;
}
.nav-links{display:flex;gap:32px;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.nav-links a{color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--burgundy)}
.nav-cta{
  background:var(--burgundy);color:var(--ivory);
  padding:11px 20px;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  border-radius:2px;
  transition:background .2s;
}
.nav-cta:hover{background:var(--burgundy-deep)}
.nav-burger{display:none;width:28px;height:18px;flex-direction:column;justify-content:space-between}
.nav-burger span{height:1.5px;background:var(--ink);width:100%}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 28px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  border-radius:2px;
  transition:transform .2s,background .2s,color .2s;
}
.btn-primary{background:var(--burgundy);color:var(--ivory)}
.btn-primary:hover{background:var(--burgundy-deep);transform:translateY(-1px)}
.btn-brass{background:var(--brass);color:var(--ink)}
.btn-brass:hover{background:var(--brass-deep);color:var(--ivory)}
.btn-ghost{border:1px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--ivory)}
.section-dark .btn-ghost,.section-burg .btn-ghost{border-color:var(--ivory);color:var(--ivory)}
.section-dark .btn-ghost:hover,.section-burg .btn-ghost:hover{background:var(--ivory);color:var(--burgundy-deep)}
.btn-arrow{font-size:14px}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  background:#1a0d12;
  color:var(--ivory);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.hero-photo{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.55) saturate(1.05);
  transform:scale(1.04);
  will-change:transform;
}
.hero-grain{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at top,transparent 0%,rgba(0,0,0,.55) 80%);
  pointer-events:none;
}
.hero-content{
  position:relative;z-index:2;
  flex:1;display:flex;flex-direction:column;justify-content:space-between;
  padding:140px var(--pad-x) 48px;
  max-width:var(--maxw);margin:0 auto;width:100%;
}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}
.hero-meta{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(244,236,221,.7);
  display:flex;gap:20px;flex-wrap:wrap;
}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta .dot{width:5px;height:5px;background:var(--brass);border-radius:50%}
.hero-main{margin-top:auto;display:grid;grid-template-columns:2fr 1fr;gap:48px;align-items:end}
.hero-title{
  font-family:var(--serif);font-weight:380;
  font-variation-settings:"SOFT" 100,"opsz" 144;
  font-size:clamp(52px,8.4vw,128px);line-height:.92;letter-spacing:-.022em;
  color:var(--ivory);
}
.hero-title em{
  font-style:italic;color:var(--brass);
  font-variation-settings:"SOFT" 100,"opsz" 144,"wght" 340;
}
.hero-side{display:flex;flex-direction:column;gap:24px}
.hero-side .lead{color:rgba(244,236,221,.78);max-width:30ch}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-bottom{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:48px;padding-top:24px;border-top:1px solid rgba(244,236,221,.18);
  gap:24px;flex-wrap:wrap;
}
.hero-bottom .kicker{color:var(--brass)}
.hero-bottom .mal{font-size:22px}

/* ---------- Brand strip ---------- */
.strip{
  background:var(--burgundy);color:var(--ivory);
  padding:18px var(--pad-x);
  display:flex;justify-content:center;align-items:center;gap:48px;
  overflow:hidden;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  flex-wrap:wrap;
}
.strip span{display:inline-flex;align-items:center;gap:14px;color:rgba(244,236,221,.85)}
.strip .mal{font-family:var(--mal);font-size:15px;letter-spacing:0;color:var(--brass);text-transform:none}
.strip .diamond{color:var(--brass);font-size:8px}

/* ---------- Halls intro grid ---------- */
.halls-intro{padding:clamp(80px,11vh,140px) 0 0}
.halls-head{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end;margin-bottom:64px}
.halls-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.hall-card{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  background:#000;
}
.hall-card .ph{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform .8s ease,filter .8s ease;
  filter:brightness(.7) saturate(1.05);
}
.hall-card:hover .ph{transform:scale(1.06);filter:brightness(.85) saturate(1.1)}
.hall-card .overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 35%,rgba(26,13,18,.85) 100%);
}
.hall-card .meta{
  position:absolute;left:24px;right:24px;bottom:24px;color:var(--ivory);
  display:flex;flex-direction:column;gap:8px;
}
.hall-card .meta .kicker{color:var(--brass);font-size:10px}
.hall-card .meta h3{
  font-family:var(--serif);font-weight:380;
  font-variation-settings:"SOFT" 80,"opsz" 144;
  font-size:38px;line-height:1;margin:0;
  letter-spacing:-.015em;
}
.hall-card .meta .cap{
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;
  color:rgba(244,236,221,.85);
  display:flex;gap:10px;align-items:center;margin-top:6px;
}
.hall-card .meta .cap .num-big{
  font-family:var(--serif);font-size:22px;color:var(--brass);font-style:italic;
  font-variation-settings:"SOFT" 100;
}
.hall-card .corner{
  position:absolute;top:18px;left:18px;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  color:var(--brass);
  border:1px solid var(--brass);
  padding:5px 8px;border-radius:2px;
}

/* ---------- Story spread ---------- */
.spread{padding:clamp(80px,12vh,160px) 0}
.spread-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(48px,7vw,96px);align-items:center}
.spread-photo{
  aspect-ratio:4/5;
  background-size:cover;background-position:center;
  position:relative;
}
.spread-photo::after{
  content:"";position:absolute;inset:14px;
  border:1px solid var(--brass);
  pointer-events:none;
}
.spread-copy h2{margin-bottom:24px}
.spread-copy .lead{margin-bottom:32px}
.dropcap::first-letter{
  font-family:var(--serif);font-weight:420;
  font-variation-settings:"SOFT" 100;
  font-style:italic;
  color:var(--burgundy);
  font-size:5.2em;
  float:left;line-height:.85;padding:8px 14px 0 0;
}

/* ---------- Stats band ---------- */
.stats{
  background:var(--burgundy-deep);color:var(--ivory);
  padding:clamp(48px,7vh,80px) 0;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stats-grid > div{
  padding:0 28px;
  border-left:1px solid rgba(244,236,221,.18);
}
.stats-grid > div:first-child{border-left:0;padding-left:0}
.stat-num{
  font-family:var(--serif);font-weight:380;
  font-variation-settings:"SOFT" 100;font-style:italic;
  font-size:clamp(48px,5vw,80px);
  line-height:1;color:var(--brass);
  margin-bottom:12px;
}
.stat-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(244,236,221,.75);
}

/* ---------- Ceremonies row ---------- */
.ceremonies{padding:clamp(72px,11vh,140px) 0}
.cer-head{margin-bottom:56px}
.cer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.cer-card{
  position:relative;
  aspect-ratio:4/5;
  background:#1a0d12;
  overflow:hidden;
}
.cer-card .ph{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(.6) saturate(1.05);
  transition:transform .8s ease;
}
.cer-card:hover .ph{transform:scale(1.05)}
.cer-card .grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(26,13,18,.9) 100%)}
.cer-card .label{
  position:absolute;left:22px;right:22px;bottom:22px;color:var(--ivory);
}
.cer-card .label .mal{color:var(--brass);font-size:18px;display:block;margin-bottom:6px}
.cer-card .label h3{
  font-family:var(--serif);font-weight:380;
  font-variation-settings:"SOFT" 80;
  font-size:30px;line-height:1.05;margin:0 0 10px;
}
.cer-card .label p{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(244,236,221,.78);margin:0;
}
.cer-card .num-tag{
  position:absolute;top:22px;left:22px;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  color:var(--brass);border:1px solid var(--brass);padding:4px 8px;border-radius:2px;
}

/* ---------- Amenities grid ---------- */
.amen{padding:clamp(72px,11vh,140px) 0;background:var(--ivory)}
.amen-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:48px}
.amen-list{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--rule)}
.amen-item{
  padding:32px 24px 32px 0;
  border-bottom:1px solid var(--rule);
  border-right:1px solid var(--rule);
  display:flex;flex-direction:column;gap:14px;
}
.amen-item:nth-child(4n){border-right:0}
.amen-item .num-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--brass-deep);
}
.amen-item h4{
  font-family:var(--serif);font-weight:420;font-size:22px;line-height:1.1;margin:0;
  letter-spacing:-.005em;
}
.amen-item p{font-size:14px;color:var(--ink-soft);margin:0;line-height:1.55}
.amen-svg{width:32px;height:32px;color:var(--burgundy);opacity:.9}

/* ---------- Food packages ---------- */
.food{padding:clamp(72px,11vh,140px) 0}
.food-head{margin-bottom:48px}
.food-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.food-card{
  padding:40px 32px;
  border-right:1px solid var(--rule);
  display:flex;flex-direction:column;gap:18px;
  position:relative;
  background:var(--paper);
}
.food-card:last-child{border-right:0}
.food-card.featured{background:var(--burgundy);color:var(--ivory)}
.food-card.featured .kicker{color:var(--brass)}
.food-card.featured h3{color:var(--ivory)}
.food-card.featured .body,.food-card.featured .list li{color:rgba(244,236,221,.85)}
.food-card.featured .rule{background:rgba(244,236,221,.2)}
.food-card.featured .price{color:var(--brass)}
.food-card h3{
  font-family:var(--serif);font-weight:420;
  font-variation-settings:"SOFT" 60;
  font-size:32px;line-height:1;margin:0;
}
.food-card .price{
  font-family:var(--serif);font-style:italic;color:var(--burgundy);
  font-variation-settings:"SOFT" 100;
  font-size:36px;line-height:1;
}
.food-card .price small{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;font-style:normal;
  color:var(--muted);text-transform:uppercase;display:block;margin-top:6px;
}
.food-card.featured .price small{color:rgba(244,236,221,.6)}
.list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.list li{
  font-size:14.5px;line-height:1.5;color:var(--ink-soft);
  display:flex;gap:10px;align-items:flex-start;
}
.list li::before{
  content:"◆";color:var(--brass);font-size:8px;margin-top:8px;flex-shrink:0;
}

/* ---------- Editorial quote ---------- */
.quote-block{
  padding:clamp(80px,12vh,140px) 0;
  background:var(--burgundy);color:var(--ivory);text-align:center;
}
.quote-block blockquote{
  font-family:var(--serif);font-weight:380;
  font-variation-settings:"SOFT" 100,"opsz" 144;font-style:italic;
  font-size:clamp(28px,3.6vw,52px);
  line-height:1.18;letter-spacing:-.01em;
  max-width:18ch;margin:0 auto 28px;
}
.quote-block blockquote::before,.quote-block blockquote::after{
  color:var(--brass);font-style:normal;
}
.quote-block blockquote::before{content:"«";margin-right:12px}
.quote-block blockquote::after{content:"»";margin-left:12px}
.quote-cite{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);
}

/* ---------- NRI booking strip ---------- */
.nri{
  padding:clamp(64px,9vh,120px) 0;
  background:var(--ink);color:var(--ivory);
  position:relative;overflow:hidden;
}
.nri-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
.nri h2{color:var(--ivory)}
.nri h2 em{color:var(--brass)}
.nri .lead{color:rgba(244,236,221,.78)}
.nri-points{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
.nri-points div{
  padding:18px;background:rgba(244,236,221,.04);
  border-left:2px solid var(--brass);
}
.nri-points h4{
  font-family:var(--serif);font-size:20px;font-weight:420;margin:0 0 6px;color:var(--ivory);
}
.nri-points p{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin:0}
.nri-cta{display:flex;flex-direction:column;gap:14px;align-items:flex-start}

/* ---------- Footer ---------- */
.footer{
  background:var(--burgundy-deep);color:var(--ivory);
  padding:clamp(64px,9vh,100px) 0 32px;
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(244,236,221,.18);
}
.foot-brand h3{
  font-family:var(--serif);font-weight:380;
  font-variation-settings:"SOFT" 100;
  font-size:32px;margin:0 0 16px;line-height:1;
}
.foot-brand h3 em{font-style:italic;color:var(--brass)}
.foot-brand p{font-size:14px;color:rgba(244,236,221,.7);line-height:1.6;max-width:38ch}
.foot-col h5{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin:0 0 18px;font-weight:500;
}
.foot-col a,.foot-col p{
  display:block;font-size:14px;color:rgba(244,236,221,.85);margin-bottom:10px;line-height:1.55;
}
.foot-col a:hover{color:var(--brass)}
.foot-bottom{
  padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(244,236,221,.55);
}
.foot-bottom .credit{color:var(--brass)}

/* ---------- Reveals (FALLBACK SAFE) ---------- */
.reveal{opacity:1;transform:none;transition:opacity .9s ease,transform .9s ease}
.reveal--hidden{opacity:0;transform:translateY(28px)}
.reveal--in{opacity:1;transform:none}

/* ---------- Mobile ---------- */
@media (max-width:1024px){
  .grid-3,.halls-cards,.cer-grid,.food-grid,.amen-list{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .hero-main{grid-template-columns:1fr}
  .spread-grid,.amen-head,.foot-grid,.nri-grid,.halls-head{grid-template-columns:1fr;gap:32px}
  .foot-grid{gap:32px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stats-grid > div{padding:18px 14px;border-left:0;border-top:1px solid rgba(244,236,221,.18)}
  .stats-grid > div:first-child{border-top:0}
}
@media (max-width:768px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-cta{padding:9px 14px;font-size:9px}
  .nav-mark .mono-tag{display:none}
  .halls-cards,.cer-grid,.food-grid,.amen-list{grid-template-columns:1fr}
  .food-card{border-right:0;border-bottom:1px solid var(--rule)}
  .food-card:last-child{border-bottom:0}
  .amen-item{border-right:0}
  .strip{gap:18px;font-size:9.5px}
  .hero-meta{font-size:9px;gap:12px}
  .hero-content{padding:120px 20px 32px}
  .hero-title{font-size:46px}
  .hero-bottom{flex-direction:column;align-items:flex-start;gap:14px}
  .h-display{font-size:42px}
  .h-section{font-size:32px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .nri-points{grid-template-columns:1fr}
}
@media (max-width:480px){
  .hero-title{font-size:38px}
  .h-section{font-size:26px}
  .food-card{padding:32px 22px}
  .hero-meta span:nth-child(n+3){display:none}
}

/* =====================================================================
   PREMIUM INTERACTION LAYER
   ===================================================================== */

/* Scroll progress bar */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:60;
  background:linear-gradient(90deg,var(--brass),var(--brass-deep));
  transform:scaleX(0);transform-origin:left center;
  transition:transform .1s linear;
}

/* Animated marquee strip (upgrade of .strip) */
.marquee{
  background:var(--burgundy);color:var(--ivory);
  padding:16px 0;overflow:hidden;position:relative;
  border-top:1px solid rgba(184,148,100,.25);
  border-bottom:1px solid rgba(184,148,100,.25);
}
.marquee__track{
  display:flex;gap:0;width:max-content;
  animation:marquee-scroll 38s linear infinite;
}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee__item{
  display:inline-flex;align-items:center;gap:18px;padding:0 30px;
  font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(244,236,221,.9);white-space:nowrap;
}
.marquee__item .mal{font-family:var(--mal);font-size:16px;letter-spacing:0;color:var(--brass);text-transform:none}
.marquee__item .dot{color:var(--brass);font-size:8px}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none;flex-wrap:wrap;justify-content:center}}

/* Stagger children */
[data-stagger]{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
[data-stagger].stagger--in{opacity:1;transform:none}
.reveal--hidden [data-stagger]{opacity:0}

/* Mobile menu overlay */
.mobile-menu{
  position:fixed;inset:0;z-index:70;
  background:linear-gradient(160deg,var(--burgundy-deep),var(--burgundy));
  color:var(--ivory);
  display:flex;flex-direction:column;justify-content:center;
  padding:48px var(--pad-x);
  opacity:0;visibility:hidden;transform:translateY(-12px);
  transition:opacity .35s ease,transform .35s ease,visibility .35s;
}
.mobile-menu.is-open{opacity:1;visibility:visible;transform:none}
.mobile-menu__close{
  position:absolute;top:24px;right:24px;
  font-size:40px;line-height:1;color:var(--ivory);font-weight:300;
}
.mobile-menu__links{display:flex;flex-direction:column;gap:6px}
.mobile-menu__links a{
  font-family:var(--serif);font-weight:380;
  font-variation-settings:"SOFT" 80,"opsz" 120;
  font-size:clamp(34px,9vw,52px);line-height:1.15;
  color:var(--ivory);letter-spacing:-.01em;
  border-bottom:1px solid rgba(244,236,221,.12);padding:10px 0;
  transition:color .2s,padding-left .2s;
}
.mobile-menu__links a:hover,.mobile-menu__links a:active{color:var(--brass);padding-left:10px}
.mobile-menu__foot{
  margin-top:40px;display:flex;flex-direction:column;gap:10px;
}
.mobile-menu__foot .mal{font-family:var(--mal);font-size:20px;color:var(--brass)}
.mobile-menu__foot a{
  font-family:var(--mono);font-size:13px;letter-spacing:.2em;color:rgba(244,236,221,.85);
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:80;
  background:rgba(20,10,14,.96);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s;
  padding:40px;
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__img{
  max-width:90vw;max-height:82vh;object-fit:contain;
  border:1px solid rgba(184,148,100,.4);
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.lightbox__close{
  position:absolute;top:24px;right:32px;font-size:42px;color:var(--ivory);font-weight:300;line-height:1;
}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  font-size:48px;color:var(--ivory);font-weight:300;
  width:64px;height:64px;display:flex;align-items:center;justify-content:center;
  background:rgba(184,148,100,.15);border-radius:50%;transition:background .2s;
}
.lightbox__nav:hover{background:rgba(184,148,100,.4)}
.lightbox__prev{left:24px}
.lightbox__next{right:24px}
.lightbox__caption{
  position:absolute;bottom:24px;left:0;right:0;text-align:center;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);
}
@media (max-width:768px){
  .lightbox__nav{width:48px;height:48px;font-size:32px}
  .lightbox__prev{left:8px}.lightbox__next{right:8px}
}

/* Real-photo gallery section */
.gallery{padding:clamp(72px,11vh,140px) 0;background:var(--burgundy-deep);color:var(--ivory)}
.gallery .kicker{color:var(--brass)}
.gallery-head{margin-bottom:48px}
.gallery-head h2{color:var(--ivory)}
.gallery-head h2 em{color:var(--brass)}
.gallery-head .lead{color:rgba(244,236,221,.82)}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;gap:10px;
}
.gallery-cell{
  position:relative;overflow:hidden;cursor:pointer;
  background:#1a0d12;
}
.gallery-cell img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s ease,filter .7s ease;
  filter:brightness(.82) saturate(1.05);
}
.gallery-cell:hover img{transform:scale(1.07);filter:brightness(1) saturate(1.1)}
.gallery-cell::after{
  content:"⊕";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.6);
  color:var(--ivory);font-size:28px;opacity:0;transition:opacity .3s,transform .3s;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.gallery-cell:hover::after{opacity:1;transform:translate(-50%,-50%) scale(1)}
.gallery-cell.tall{grid-row:span 2}
.gallery-cell.wide{grid-column:span 2}
@media (max-width:1024px){.gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}}
@media (max-width:560px){
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:140px}
  .gallery-cell.wide{grid-column:span 2}
  .gallery-cell.tall{grid-row:span 1}
}

/* Footer real-logo lockup */
.foot-logo{
  margin-top:22px;opacity:.85;max-width:180px;height:auto;
}

/* Smoother hall-card / cer-card hover lift */
.hall-card,.cer-card{transition:transform .4s ease}
