/* ============================================================
   International Spa Awards 2026
   main.css — Design: Refined Luxury — Deep Noir + Liquid Gold
   Typography: Readable size pass applied throughout
   ============================================================ */

:root {
  --g:  #C8A96A;
  --g2: #E8D5A0;
  --g3: #8C6B2A;
  --g4: #F5ECD6;
  --n0: #070709;
  --n1: #0E0E12;
  --n2: #14141A;
  --n3: #1C1C24;
  --n4: #242430;
  --n5: #2E2E3C;
  --w: #FFFFFF;
  --t1: #EDE9E2;
  --t2: #AAA59E;
  --t3: #706C66;
  --t4: #4A4742;
  --teal: #3ECDC8;
  --r: 3px;
  --ease: cubic-bezier(.4,0,.2,1);
  --tr: all .28s var(--ease);
  --sh: 0 24px 64px rgba(0,0,0,.5);
  --gsh: 0 0 40px rgba(200,169,106,.18);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; -webkit-font-smoothing:antialiased; }
body {
  font-family:'DM Sans', sans-serif;
  background: var(--n1);
  color: var(--t1);
  overflow-x: hidden;
  line-height: 1.6;
}
img { display:block; max-width:100%; }
a { text-decoration:none; color:inherit; transition:var(--tr); }
button { font-family:'DM Sans', sans-serif; cursor:pointer; border:none; transition:var(--tr); }
h1,h2,h3,h4,h5 { font-family:'Cormorant Garamond', serif; font-weight:500; line-height:1.15; }
input,select,textarea { font-family:'DM Sans', sans-serif; }
::selection { background:rgba(200,169,106,.25); }

/* ===== TOP GOLD LINE ===== */
body::before {
  content:'';
  position:fixed; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent 0%, var(--g) 30%, var(--g2) 50%, var(--g) 70%, transparent 100%);
  z-index:10000;
  pointer-events:none;
}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--n2); }
::-webkit-scrollbar-thumb { background:var(--g3); border-radius:3px; }

/* ===== NAVIGATION ===== */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  background:rgba(7,7,9,.96);
  backdrop-filter:blur(28px) saturate(180%);
  border-bottom:1px solid rgba(200,169,106,.1);
  transition:var(--tr);
}
.nav-inner {
  max-width:1500px; margin:0 auto; padding:0 48px;
  display:flex; align-items:center; justify-content:space-between;
  height:74px;
}
.nav-brand { display:flex; align-items:center; cursor:pointer; }
.nav-brand-name { font-family:'Cormorant Garamond',serif; font-size:1.65rem; font-weight:600; color:var(--g); letter-spacing:.5px; line-height:1.05; }
.nav-brand-sub { display:none; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nl { padding:9px 13px; font-size:.92rem; font-weight:500; color:var(--t1); border-radius:var(--r); cursor:pointer; white-space:nowrap; transition:var(--tr); letter-spacing:.2px; }
.nl:hover, .nl.on { color:var(--g); background:rgba(200,169,106,.1); }
.nav-cta { margin-left:12px; padding:11px 24px; background:linear-gradient(135deg,var(--g) 0%,var(--g3) 100%); color:var(--n0); font-size:.88rem; font-weight:700; letter-spacing:.8px; text-transform:uppercase; border-radius:var(--r); }
.nav-cta:hover { transform:translateY(-1px); box-shadow:var(--gsh); }
.ham { display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer; }
.ham span { display:block; width:22px; height:1.5px; background:var(--g); border-radius:1px; transition:var(--tr); }
.ham.on span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.ham.on span:nth-child(2) { opacity:0; transform:scaleX(0); }
.ham.on span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* ===== PAGE SYSTEM ===== */
.pg { display:none; padding-top:74px; min-height:100vh; }
.pg.on { display:block; animation:pgIn .38s var(--ease) both; }
@keyframes pgIn { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }

/* ===== BUTTONS ===== */
.btn { display:inline-flex; align-items:center; gap:8px; padding:14px 32px; font-size:.88rem; font-weight:500; letter-spacing:.8px; text-transform:uppercase; border-radius:var(--r); cursor:pointer; transition:var(--tr); white-space:nowrap; }
.btn-g { background:linear-gradient(135deg,var(--g) 0%,var(--g3) 100%); color:var(--n0); }
.btn-g:hover { transform:translateY(-2px); box-shadow:0 14px 40px rgba(200,169,106,.35); }
.btn-o { border:1px solid rgba(200,169,106,.45); color:var(--g); background:transparent; }
.btn-o:hover { background:rgba(200,169,106,.08); border-color:var(--g); }
.btn-d { background:var(--n3); color:var(--t1); border:1px solid rgba(255,255,255,.07); }
.btn-d:hover { background:var(--n4); }
.btn-lg { padding:16px 40px; font-size:.92rem; }
.btn-sm { padding:9px 20px; font-size:.78rem; }

/* ===== LAYOUT ===== */
.wrap { max-width:1500px; margin:0 auto; padding:0 48px; }
.sec { padding:96px 0; }
.g2 { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }

/* ===== TYPOGRAPHY ===== */
.eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:.65rem; font-weight:600; letter-spacing:3.5px; text-transform:uppercase; color:var(--g); margin-bottom:16px; }
.eyebrow::before { content:''; width:24px; height:1px; background:var(--g); flex-shrink:0; }
.heading { font-size:clamp(2rem,3.5vw,3.2rem); color:var(--w); margin-bottom:16px; }
.heading em { font-style:italic; color:var(--g); }
.subheading { font-size:1.15rem; color:var(--t2); max-width:620px; line-height:1.85; font-weight:300; }
.ctr { text-align:center; }
.ctr .subheading { margin:0 auto; }
.gold { color:var(--g); }

/* ===== HERO ===== */
.hero { position:relative; min-height:calc(100vh - 74px); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.hero-bg { position:absolute; inset:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; object-position: top; }
.hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(112deg,rgba(7,7,9,.92) 0%,rgba(7,7,9,.75) 45%,rgba(7,7,9,.4) 100%); }
.hero-fade { position:absolute; bottom:0; left:0; right:0; height:280px; background:linear-gradient(to top,var(--n1),transparent); z-index:1; }
.hero-body { position:relative; z-index:2; max-width:820px; }
/* Ensure hero's wrap spans the full viewport so hero-body can be 80% with 10% gutters */
.hero > .wrap { width:100%; max-width:100%; padding:0; }

/* Make hero content span 80% of the viewport and center it */
.hero .hero-body { width:80%; max-width:none; margin:0 auto; }
.hero-pill { display:inline-flex; align-items:center; gap:10px; background:rgba(200,169,106,.1); border:1px solid rgba(200,169,106,.28); border-radius:40px; padding:6px 16px 6px 8px; font-size:.72rem; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; color:var(--g); margin-bottom:32px; }
.hero-pill-dot { width:8px; height:8px; background:var(--g); border-radius:50%; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.7)} }
.hero h1 { font-size:clamp(2.6rem,5.5vw,5rem); color:var(--w); margin-bottom:24px; letter-spacing:-.5px; line-height:1.06; font-weight:400; }
.hero h1 em { color:var(--g); font-style:italic; }
.hero-desc { font-size:1.15rem; color:var(--t2); max-width:560px; line-height:1.85; font-weight:300; margin-bottom:40px; }
.hero-btns { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:60px; }
.hero-stats { display:flex; border-top:1px solid rgba(200,169,106,.14); padding-top:36px; }
.hs { flex:1; padding:0 30px 0 0; border-right:1px solid rgba(200,169,106,.1); }
.hs:first-child { padding-left:0; }
.hs:last-child { border-right:none; }
.hs-n { font-family:'Cormorant Garamond',serif; font-size:2.8rem; color:var(--g); font-weight:600; line-height:1; letter-spacing:-.5px; }
.hs-l { font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--t3); margin-top:6px; }
.hero-scroll { position:absolute; bottom:36px; right:52px; z-index:2; display:flex; flex-direction:column; align-items:center; gap:10px; font-size:.62rem; letter-spacing:3px; text-transform:uppercase; color:var(--t3); }
.hero-scroll::after { content:''; width:1px; height:56px; background:linear-gradient(to bottom,var(--g3),transparent); }

/* ===== TICKER ===== */
.ticker { background:var(--n2); border-top:1px solid rgba(200,169,106,.08); border-bottom:1px solid rgba(200,169,106,.08); padding:14px 0; overflow:hidden; }
.ticker-wrap { display:flex; animation:tick 32s linear infinite; white-space:nowrap; }
.ticker-item { font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--t3); padding:0 32px; display:flex; align-items:center; gap:16px; flex-shrink:0; }
.ticker-item::after { content:"◆"; color:var(--g); font-size:.4rem; }
@keyframes tick { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ===== STATS BAR ===== */
.stats-bar { background:var(--n2); padding:52px 0; }
.stats-grid { display:grid; grid-template-columns:repeat(5,1fr); }
.stat { text-align:center; padding:20px; border-right:1px solid rgba(200,169,106,.08); }
.stat:last-child { border-right:none; }
.stat-n { font-family:'Cormorant Garamond',serif; font-size:2.8rem; color:var(--g); font-weight:600; line-height:1; }
.stat-l { font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--t3); margin-top:9px; line-height:1.5; }

/* ===== ABOUT ===== */
.about-img { position:relative; }
.about-img img { width:100%; height:580px; object-fit:cover; border-radius:var(--r); }
.about-badge { position:absolute; bottom:-26px; right:-26px; background:linear-gradient(135deg,var(--g),var(--g3)); padding:28px 26px; text-align:center; border-radius:var(--r); }
.ab-big { font-family:'Cormorant Garamond',serif; font-size:3rem; color:var(--n0); font-weight:700; line-height:1; }
.ab-sm { font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:rgba(7,7,9,.65); margin-top:5px; }
.about-feats { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:28px; }
.af { padding:22px 20px; background:var(--n3); border:1px solid rgba(255,255,255,.04); border-radius:var(--r); transition:var(--tr); }
.af:hover { border-color:rgba(200,169,106,.18); transform:translateY(-2px); }
.af-ico { font-size:1.5rem; margin-bottom:10px; }
.af h4 { font-size:1.05rem; font-weight:600; margin-bottom:7px; }
.af p { font-size:1rem; color:var(--t2); line-height:1.65; font-weight:300; }

/* ===== CATEGORIES ===== */
.cats-bg { background:var(--n2); }
.cat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:3px; margin-top:52px; }
.cat-card { background:var(--n3); padding:32px 26px; position:relative; overflow:hidden; transition:var(--tr); cursor:pointer; border:1px solid transparent; }
.cat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--g),var(--g3)); transform:scaleX(0); transition:var(--tr); transform-origin:left; }
.cat-card:hover { background:var(--n4); border-color:rgba(200,169,106,.14); transform:translateY(-3px); }
.cat-card:hover::before { transform:scaleX(1); }
.cat-num { position:absolute; top:14px; right:16px; font-family:'Cormorant Garamond',serif; font-size:2.2rem; color:rgba(200,169,106,.06); font-weight:700; line-height:1; }
.cat-ico { width:52px; height:52px; background:rgba(200,169,106,.08); border:1px solid rgba(200,169,106,.14); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:18px; }
.cat-card h3 { font-size:1.15rem; font-weight:600; margin-bottom:10px; color:var(--t1); }
.cat-card p { font-size:1rem; color:var(--t2); line-height:1.7; font-weight:300; }

/* ===== WHY ENTER ===== */
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:52px; }
.why-card { padding:38px 30px; border-left:2px solid rgba(200,169,106,.2); transition:var(--tr); }
.why-card:hover { border-left-color:var(--g); transform:translateX(4px); }
.why-num { font-family:'Cormorant Garamond',serif; font-size:3.5rem; color:rgba(200,169,106,.08); font-weight:700; line-height:1; margin-bottom:8px; }
.why-card h4 { font-size:1.05rem; font-weight:600; letter-spacing:.3px; color:var(--g); margin-bottom:12px; text-transform:uppercase; }
.why-card p { font-size:1.02rem; color:var(--t2); line-height:1.8; font-weight:300; }

/* ===== PROCESS ===== */
.proc { display:flex; margin-top:60px; position:relative; }
.proc::before { content:''; position:absolute; top:27px; left:0; right:0; height:1px; background:linear-gradient(90deg,var(--g),rgba(200,169,106,.1)); }
.proc-step { flex:1; text-align:center; position:relative; z-index:1; padding:0 14px; }
.proc-dot { width:54px; height:54px; border-radius:50%; background:linear-gradient(135deg,var(--g),var(--g3)); color:var(--n0); font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:700; display:flex; align-items:center; justify-content:center; margin:0 auto 20px; box-shadow:0 0 0 5px var(--n1),0 0 0 6px rgba(200,169,106,.2); }
.proc-step h4 { font-size:1rem; font-weight:600; letter-spacing:.3px; text-transform:uppercase; margin-bottom:9px; }
.proc-step p { font-size:1rem; color:var(--t2); line-height:1.65; font-weight:300; }

/* ===== BENEFITS ===== */
.ben-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-top:52px; }
.ben-card { background:var(--n3); padding:34px 26px; text-align:center; transition:var(--tr); }
.ben-card:hover { background:var(--n4); }
.ben-ico { font-size:2.2rem; margin-bottom:18px; }
.ben-card h4 { font-size:1rem; font-weight:600; letter-spacing:.3px; text-transform:uppercase; color:var(--g); margin-bottom:10px; }
.ben-card p { font-size:1rem; color:var(--t2); line-height:1.7; font-weight:300; }

/* ===== GALA VIDEO SECTION ===== */
.gvs { background:var(--n2); padding:96px 0; }
.gv-tabs { display:flex; gap:4px; margin-bottom:18px; flex-wrap:wrap; }
.gv-tab { padding:11px 20px; font-size:.8rem; font-weight:500; letter-spacing:.5px; border-radius:var(--r); cursor:pointer; border:1px solid rgba(255,255,255,.07); color:var(--t2); background:var(--n3); transition:var(--tr); white-space:nowrap; }
.gv-tab.on, .gv-tab:hover { background:linear-gradient(135deg,var(--g),var(--g3)); color:var(--n0); border-color:transparent; }
.gv-player { border-radius:var(--r); overflow:hidden; border:1px solid rgba(200,169,106,.14); aspect-ratio:16/9; background:var(--n3); }
.gv-player iframe { width:100%; height:100%; display:block; border:none; }
.gv-meta { padding:22px 24px; background:var(--n3); border:1px solid rgba(200,169,106,.1); border-top:none; border-radius:0 0 var(--r) var(--r); }
.gv-badge { font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--g); margin-bottom:8px; display:block; }
.gv-meta h3 { font-size:1.2rem; margin-bottom:8px; }
.gv-meta p { font-size:1.02rem; color:var(--t2); line-height:1.75; font-weight:300; }
.gv-thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:5px; margin-top:6px; }
.gv-th { position:relative; background:var(--n3); border:1px solid rgba(255,255,255,.06); border-radius:var(--r); overflow:hidden; cursor:pointer; transition:var(--tr); aspect-ratio:16/9; }
.gv-th:hover { border-color:rgba(200,169,106,.35); transform:translateY(-2px); }
.gv-th.on { border-color:var(--g); box-shadow:0 0 20px rgba(200,169,106,.2); }
.gv-th img { width:100%; height:100%; object-fit:cover; filter:brightness(.58); transition:.3s; display:block; }
.gv-th:hover img, .gv-th.on img { filter:brightness(.38); }
.gv-th-ov { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; }
.gv-play { width:42px; height:42px; background:linear-gradient(135deg,var(--g),var(--g3)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.88rem; color:var(--n0); transition:.3s; }
.gv-th:hover .gv-play, .gv-th.on .gv-play { transform:scale(1.15); box-shadow:var(--gsh); }
.gv-th-lbl { font-size:.68rem; font-weight:500; letter-spacing:1px; text-transform:uppercase; color:var(--g2); }
.gv-th-n { position:absolute; top:7px; right:9px; font-size:.65rem; font-weight:600; color:var(--g); }

/* ===== PAGE VIDEO (compact) ===== */
.pvs { background:var(--n3); padding:72px 0; border-top:1px solid rgba(200,169,106,.08); border-bottom:1px solid rgba(200,169,106,.08); }
.pv-inner { display:grid; grid-template-columns:1.3fr 1fr; gap:48px; align-items:center; }
.pv-tabs { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:14px; }
.pv-tab { padding:9px 16px; font-size:.78rem; font-weight:500; border-radius:var(--r); cursor:pointer; border:1px solid rgba(255,255,255,.07); color:var(--t2); background:var(--n2); transition:var(--tr); }
.pv-tab.on, .pv-tab:hover { background:rgba(200,169,106,.12); border-color:rgba(200,169,106,.35); color:var(--g); }
.pv-frame { border-radius:var(--r); overflow:hidden; border:1px solid rgba(200,169,106,.14); aspect-ratio:16/9; }
.pv-frame iframe { width:100%; height:100%; display:block; border:none; }
.pv-minis { display:grid; grid-template-columns:1fr 1fr; gap:5px; margin-top:6px; }
.pv-mini { position:relative; border-radius:var(--r); overflow:hidden; cursor:pointer; aspect-ratio:16/9; border:1px solid rgba(255,255,255,.06); }
.pv-mini img { width:100%; height:100%; object-fit:cover; filter:brightness(.52); transition:.3s; display:block; }
.pv-mini:hover img { filter:brightness(.3); }
.pv-mini-ov { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.pv-mini-play { width:34px; height:34px; background:linear-gradient(135deg,var(--g),var(--g3)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.78rem; color:var(--n0); transition:.3s; }
.pv-mini:hover .pv-mini-play { transform:scale(1.2); box-shadow:var(--gsh); }
.pv-text .eyebrow { margin-bottom:12px; }
.pv-text h3 { font-size:1.8rem; margin-bottom:14px; }
.pv-text p { font-size:1.05rem; color:var(--t2); line-height:1.85; font-weight:300; margin-bottom:22px; }
.pv-facts { display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.pv-fact { display:flex; gap:11px; align-items:center; font-size:1.02rem; color:var(--t2); }
.pv-fact-ic { color:var(--g); }

/* ===== GALLERY MASONRY ===== */
.gal-masonry { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:220px; gap:4px; margin-top:52px; }
.gal-item { overflow:hidden; position:relative; cursor:pointer; }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:.55s var(--ease); }
.gal-item:hover img { transform:scale(1.08); }
.gal-item-ov { position:absolute; inset:0; background:linear-gradient(to top,rgba(7,7,9,.7) 0%,transparent 55%); opacity:0; transition:.3s; display:flex; align-items:flex-end; padding:14px; }
.gal-item:hover .gal-item-ov { opacity:1; }
.gal-item-lbl { font-size:.72rem; letter-spacing:1px; text-transform:uppercase; color:var(--g2); transform:translateY(6px); transition:.3s; }
.gal-item:hover .gal-item-lbl { transform:translateY(0); }
.gal-item:nth-child(1) { grid-column:1/3; grid-row:1/3; }
.gal-item:nth-child(6) { grid-column:3/5; grid-row:2/4; }

/* ===== FULL GALLERY ===== */
.gal-full { display:grid; grid-template-columns:repeat(4,1fr); gap:4px; }
.gf { overflow:hidden; cursor:pointer; position:relative; }
.gf img { width:100%; height:230px; object-fit:cover; transition:.5s; display:block; }
.gf:hover img { transform:scale(1.07); }
.gf:nth-child(7n+1) { grid-column:span 2; }
.gf:nth-child(7n+1) img { height:464px; }
.year-tabs { display:flex; gap:4px; }
.yt-btn { padding:10px 22px; border-radius:var(--r); font-size:.8rem; font-weight:500; cursor:pointer; border:1px solid rgba(255,255,255,.07); color:var(--t2); background:transparent; transition:var(--tr); }
.yt-btn.on, .yt-btn:hover { background:rgba(200,169,106,.1); border-color:rgba(200,169,106,.3); color:var(--g); }

/* ===== THUMB STRIP ===== */
.ts { display:flex; gap:4px; overflow-x:auto; padding-bottom:4px; scrollbar-width:none; }
.ts::-webkit-scrollbar { display:none; }
.ts-item { flex:0 0 196px; height:122px; overflow:hidden; cursor:pointer; border-radius:var(--r); border:1px solid rgba(255,255,255,.06); }
.ts-item img { width:100%; height:100%; object-fit:cover; transition:.4s; }
.ts-item:hover img { transform:scale(1.07); }

/* ===== CTA PHOTO BAR ===== */
.cta-bar { position:relative; overflow:hidden; min-height:480px; display:flex; align-items:center; }
.cta-bar-bg { position:absolute; inset:0; display:grid; grid-template-columns:repeat(3,1fr); gap:3px; }
.cta-bar-bg img { width:100%; height:100%; object-fit:cover; filter:brightness(.22) saturate(.5); }
.cta-bar-ov { position:absolute; inset:0; background:linear-gradient(135deg,rgba(7,7,9,.82),rgba(7,7,9,.6),rgba(7,7,9,.78)); }
.cta-bar-body { position:relative; z-index:2; text-align:center; padding:76px 40px; max-width:820px; margin:0 auto; width:100%; }
.cta-bar-body h2 { font-size:clamp(2rem,4vw,3.2rem); margin-bottom:16px; }
.cta-bar-body p { font-size:1.15rem; color:var(--t2); max-width:540px; margin:0 auto 28px; line-height:1.85; font-weight:300; }
.cta-mini-gal { display:flex; gap:8px; justify-content:center; margin-bottom:34px; flex-wrap:wrap; }
.cta-mini-img { width:66px; height:66px; object-fit:cover; border-radius:50%; border:2px solid rgba(200,169,106,.35); cursor:pointer; transition:.3s; }
.cta-mini-img:hover { border-color:var(--g); transform:scale(1.1); box-shadow:var(--gsh); }

/* ===== TESTIMONIALS ===== */
.testi-head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:44px; flex-wrap:wrap; gap:16px; }
.vt-tabs { display:flex; gap:6px; flex-wrap:wrap; }
.vt-tab { padding:9px 18px; font-size:.8rem; font-weight:500; border-radius:20px; cursor:pointer; border:1px solid rgba(255,255,255,.08); color:var(--t2); background:transparent; transition:var(--tr); }
.vt-tab.on, .vt-tab:hover { background:rgba(200,169,106,.1); border-color:rgba(200,169,106,.3); color:var(--g); }
.vf-grid { display:grid; grid-template-columns:2fr 1fr; gap:18px; }
.vf-main { background:var(--n2); border-radius:var(--r); overflow:hidden; border:1px solid rgba(200,169,106,.1); }
.vf-main iframe { width:100%; height:360px; display:block; border:none; }
.vf-meta { padding:22px; }
.vf-tag { font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--g); margin-bottom:8px; display:block; }
.vf-meta h3 { font-size:1.2rem; margin-bottom:8px; }
.vf-meta p { font-size:1.02rem; color:var(--t2); line-height:1.7; font-weight:300; }
.vs { display:flex; flex-direction:column; gap:10px; }
.vth { background:var(--n2); border:1px solid rgba(255,255,255,.05); border-radius:var(--r); overflow:hidden; cursor:pointer; transition:var(--tr); }
.vth:hover { border-color:rgba(200,169,106,.25); }
.vth iframe { width:100%; height:118px; border:none; pointer-events:none; display:block; }
.vth-meta { padding:11px 14px; }
.vth-meta span { font-size:.65rem; letter-spacing:1px; text-transform:uppercase; color:var(--g); }
.vth-meta h4 { font-size:1rem; font-weight:500; margin-top:4px; }

/* ===== COVERAGE ===== */
.cov-bg { background:var(--n2); }
.cov-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-top:52px; }
.cov-card { background:var(--n3); padding:32px 26px; transition:var(--tr); border-bottom:3px solid transparent; }
.cov-card:hover { background:var(--n4); border-bottom-color:var(--g); }
.cov-ico { font-size:2rem; margin-bottom:14px; }
.cov-card h4 { font-family:'Cormorant Garamond',serif; font-size:1.3rem; margin-bottom:10px; color:var(--g); }
.cov-card p { font-size:1rem; color:var(--t2); line-height:1.75; font-weight:300; }

/* ===== GALA SECTION ===== */
.gala-section { background:linear-gradient(135deg,var(--n2),var(--n3)); }
.gala-grid { display:grid; grid-template-columns:1fr 1fr; gap:76px; align-items:center; }
.gala-img { width:100%; height:550px; object-fit:cover; border-radius:var(--r); }
.gala-dets { margin-top:34px; }
.gd { display:flex; align-items:flex-start; gap:18px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.gd:last-child { border-bottom:none; }
.gd-ico { width:44px; height:44px; background:rgba(200,169,106,.08); border:1px solid rgba(200,169,106,.14); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.gd-txt h4 { font-size:1.05rem; font-weight:500; margin-bottom:4px; }
.gd-txt p { font-size:1rem; color:var(--t2); font-weight:300; }

/* ===== FAQ ===== */
.faq-bg { background:var(--n2); }
.faq-wrap { max-width:860px; margin:50px auto 0; }
.faq-item { border-bottom:1px solid rgba(255,255,255,.06); }
.faq-q { display:flex; justify-content:space-between; align-items:center; padding:24px 0; cursor:pointer; }
.faq-q h4 { font-family:'Cormorant Garamond',serif; font-size:1.35rem; font-weight:400; line-height:1.4; padding-right:22px; }
.faq-tog { width:32px; height:32px; background:rgba(200,169,106,.08); border:1px solid rgba(200,169,106,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:1.1rem; color:var(--g); transition:var(--tr); }
.faq-item.on .faq-tog { transform:rotate(45deg); background:var(--g); color:var(--n0); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .42s var(--ease); }
.faq-ain { padding-bottom:22px; font-size:1.05rem; color:var(--t2); line-height:1.88; font-weight:300; }
.faq-item.on .faq-a { max-height:400px; }

/* ===== BLOG ===== */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:52px; }
.bc { background:var(--n2); border-radius:var(--r); overflow:hidden; border:1px solid rgba(255,255,255,.05); transition:var(--tr); }
.bc:hover { border-color:rgba(200,169,106,.2); transform:translateY(-5px); box-shadow:var(--sh); }
.bc-img { height:210px; overflow:hidden; }
.bc-img img { width:100%; height:100%; object-fit:cover; transition:.5s; }
.bc:hover .bc-img img { transform:scale(1.07); }
.bc-body { padding:28px 24px; }
.blog-tag { display:inline-block; font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--g); background:rgba(200,169,106,.08); border:1px solid rgba(200,169,106,.14); border-radius:20px; padding:5px 13px; margin-bottom:13px; }
.bc h3 { font-size:1.25rem; margin-bottom:12px; line-height:1.4; }
.bc p { font-size:1.02rem; color:var(--t2); line-height:1.78; font-weight:300; margin-bottom:18px; }
.blog-read { font-size:.78rem; font-weight:500; letter-spacing:1px; text-transform:uppercase; color:var(--g); display:inline-flex; align-items:center; gap:6px; cursor:pointer; }
.blog-read::after { content:"→"; transition:.3s; }
.bc:hover .blog-read::after { transform:translateX(4px); }

/* ===== FINAL CTA ===== */
.fcta { background:linear-gradient(135deg,var(--n3),var(--n2)); border-top:1px solid rgba(200,169,106,.1); border-bottom:1px solid rgba(200,169,106,.1); }
.fcta-in { text-align:center; padding:96px 40px; max-width:740px; margin:0 auto; }
.fcta-in h2 { font-size:clamp(2rem,4vw,3.4rem); margin-bottom:18px; }
.fcta-in p { font-size:1.15rem; color:var(--t2); line-height:1.85; margin-bottom:36px; font-weight:300; }
.fcta-btns { display:flex; justify-content:center; flex-wrap:wrap; gap:14px; }

/* ===== RELATED ===== */
.rel-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:52px; }
.rel-card { padding:30px 24px; border:1px solid rgba(255,255,255,.06); border-radius:var(--r); text-align:center; cursor:pointer; transition:var(--tr); }
.rel-card:hover { border-color:rgba(200,169,106,.3); background:rgba(200,169,106,.03); transform:translateY(-3px); }
.rel-ico { font-size:2rem; margin-bottom:13px; }
.rel-card h4 { font-size:1.05rem; font-weight:500; margin-bottom:8px; }
.rel-card p { font-size:1rem; color:var(--t2); line-height:1.65; font-weight:300; }

.ih { padding:60px 0; position:relative; overflow:hidden; border-bottom:1px solid rgba(200,169,106,.08); }
.ih::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(200,169,106,.04),transparent 70%); }
/* Inner-page hero default — Final-Photos/Hero/ */
.ih { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__(116).webp"); background-size:cover; background-position:center 35%; }

/* Utility classes to swap inner-hero images per page (round-robin across Final-Photos/Hero/) */
.ih.gala-2 { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__(467).webp"); }
.ih.gala-3 { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__(53).webp"); }
.ih.gala-4 { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__(65).webp"); }
.ih.gala-5 { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__(89).webp"); }
.ih.gala-6 { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__BV1A7493.webp"); }
.ih.gala-7 { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__BV1A7499.webp"); }
.ih.gala-8 { background-image: linear-gradient(135deg, rgba(20,20,26,.6), rgba(28,28,36,.6)), url("../Final-Photos/Hero/banner__BV1A7511.webp"); }

/* ===== CTA NOMINATE ===== */
.cta-nominate { position:relative; min-height:360px; display:flex; align-items:center; overflow:hidden; }
.cta-nominate-bg { position:absolute; inset:0; }
.cta-nominate-bg img { width:100%; height:100%; object-fit:cover; filter:brightness(.32) saturate(.6); }
.cta-nominate-ov { position:absolute; inset:0; background:linear-gradient(135deg,rgba(7,7,9,.6),rgba(7,7,9,.45)); }
.cta-nominate-body { position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:46px 48px; display:flex; align-items:center; gap:28px; }
.cta-nominate-body h2 { font-size:clamp(1.6rem,2.8vw,2.6rem); margin-bottom:6px; }
.cta-nominate-body p { font-size:1.05rem; color:var(--t2); line-height:1.7; font-weight:300; margin:0; }
.cta-nominate-left { flex:1; }
.cta-nominate-right { display:flex; gap:12px; align-items:center; }
.cta-nominate .btn { padding:14px 28px; }
@media(max-width:768px) {
  .cta-nominate { min-height:260px; }
  .cta-nominate-body { flex-direction:column; text-align:center; padding:34px 28px; }
  .cta-nominate-right { width:100%; justify-content:center; }
}
.breadcrumb { font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--t3); margin-bottom:18px; display:flex; align-items:center; gap:7px; }
.breadcrumb span { color:var(--g); }
.ih h1 { font-size:clamp(2rem,4vw,3.4rem); margin-bottom:14px; }
.ih p { font-size:1.15rem; color:var(--t2); max-width:620px; line-height:1.85; font-weight:300; }

/* ===== WINNERS ===== */
.wg { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:52px; }
.wcard { background:var(--n2); border:1px solid rgba(255,255,255,.05); border-radius:var(--r); padding:28px 24px; transition:var(--tr); }
.wcard:hover { border-color:rgba(200,169,106,.22); transform:translateY(-3px); }
.wcard-cat { font-size:.68rem; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--g); margin-bottom:10px; display:block; }
.wcard h4 { font-size:1.1rem; font-weight:500; margin-bottom:6px; }
.wco { font-size:1rem; color:var(--t3); }

/* ===== JUDGES ===== */
.jg { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:52px; }
.jcard { background:var(--n2); border:1px solid rgba(255,255,255,.05); border-radius:var(--r); padding:32px 24px; text-align:center; transition:var(--tr); }
.jcard:hover { border-color:rgba(200,169,106,.2); transform:translateY(-3px); }
.jav { width:76px; height:76px; background:linear-gradient(135deg,var(--g3),var(--n3)); border-radius:50%; margin:0 auto 18px; display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:1.7rem; color:var(--g); border:2px solid rgba(200,169,106,.2); }
.jcard h4 { font-size:1.05rem; font-weight:500; margin-bottom:6px; }
.jt { font-size:.88rem; color:var(--g); display:block; margin-bottom:11px; letter-spacing:.3px; }
.jcard p { font-size:1rem; color:var(--t2); line-height:1.7; font-weight:300; }

/* ===== INFO ===== */
.info-g { display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-top:52px; }
.ib { background:var(--n2); border:1px solid rgba(255,255,255,.05); border-radius:var(--r); padding:38px; }
.ib h3 { font-size:1.6rem; margin-bottom:22px; }
.ib p { font-size:1.05rem; color:var(--t2); line-height:1.85; font-weight:300; margin-bottom:14px; }
.ilist { list-style:none; display:flex; flex-direction:column; gap:9px; }
.ilist li { display:flex; gap:11px; font-size:1.02rem; color:var(--t2); line-height:1.65; font-weight:300; }
.ilist li::before { content:"◆"; color:var(--g); font-size:.45rem; flex-shrink:0; margin-top:5px; }
.crit-g { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:28px; }
.crit { background:var(--n3); border:1px solid rgba(255,255,255,.04); border-radius:var(--r); padding:30px 24px; transition:var(--tr); }
.crit:hover { border-color:rgba(200,169,106,.18); transform:translateY(-2px); }
.crit h4 { font-size:1rem; font-weight:600; text-transform:uppercase; color:var(--g); margin-bottom:11px; letter-spacing:.3px; }
.crit p { font-size:1rem; color:var(--t2); line-height:1.75; font-weight:300; }

/* ===== SCHEDULE ===== */
.tl { max-width:860px; margin:0 auto; padding-top:52px; }
.tl-item { display:flex; gap:28px; padding-bottom:44px; position:relative; }
.tl-item::after { content:''; position:absolute; left:22px; top:46px; bottom:0; width:1px; background:rgba(200,169,106,.12); }
.tl-item:last-child::after { display:none; }
.tl-dot { width:46px; height:46px; background:linear-gradient(135deg,var(--g),var(--g3)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:.95rem; font-weight:700; color:var(--n0); flex-shrink:0; box-shadow:0 0 0 4px var(--n1),0 0 0 5px rgba(200,169,106,.2); }
.tl-c { flex:1; padding-top:7px; }
.tl-dt { font-size:.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--g); margin-bottom:10px; display:block; }
.tl-c h3 { font-size:1.25rem; margin-bottom:10px; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.tl-c p { font-size:1.02rem; color:var(--t2); line-height:1.85; font-weight:300; }
.st-badge { display:inline-block; padding:4px 12px; border-radius:20px; font-size:.65rem; font-weight:600; letter-spacing:1px; text-transform:uppercase; font-family:'DM Sans',sans-serif; }
.st-open { background:rgba(62,205,200,.12); color:var(--teal); border:1px solid rgba(62,205,200,.25); }
.st-soon { background:rgba(200,169,106,.1); color:var(--g); border:1px solid rgba(200,169,106,.25); }
.st-fut { background:rgba(255,255,255,.05); color:var(--t3); border:1px solid rgba(255,255,255,.08); }

/* ===== NOM FORM ===== */
.nom-lay { display:grid; grid-template-columns:1.35fr 1fr; gap:56px; align-items:start; padding-top:52px; }
.nom-box { background:var(--n2); border:1px solid rgba(200,169,106,.12); border-radius:var(--r); padding:44px 40px; }
.nom-title { font-size:2rem; margin-bottom:8px; }
.nom-sub { font-size:1.05rem; color:var(--t2); margin-bottom:32px; font-weight:300; line-height:1.7; }
.fg { margin-bottom:18px; }
.fg label { display:block; font-size:.7rem; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--t3); margin-bottom:8px; }
.fg input, .fg select, .fg textarea { width:100%; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); color:var(--t1); padding:13px 16px; font-size:1rem; border-radius:var(--r); transition:var(--tr); font-family:'DM Sans',sans-serif; font-weight:300; }
.fg input:focus, .fg select:focus, .fg textarea:focus { outline:none; border-color:rgba(200,169,106,.4); background:rgba(200,169,106,.03); }
.fg select option { background:var(--n1); }
.fg textarea { min-height:120px; resize:vertical; }
.fr2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.nb-grid { display:flex; flex-direction:column; }
.nb { display:flex; gap:15px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.nb:last-of-type { border-bottom:none; }
.nb-ico { width:44px; height:44px; background:rgba(200,169,106,.08); border:1px solid rgba(200,169,106,.12); border-radius:var(--r); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:1rem; }
.nb-t h4 { font-size:1.02rem; font-weight:500; margin-bottom:4px; }
.nb-t p { font-size:1rem; color:var(--t2); line-height:1.65; font-weight:300; }

/* ===== CONTACT ===== */
.con-lay { display:grid; grid-template-columns:1fr 1.3fr; gap:56px; align-items:start; padding-top:52px; }
.con-info h3 { font-size:1.8rem; margin-bottom:18px; }
.con-info p { font-size:1.05rem; color:var(--t2); line-height:1.85; font-weight:300; margin-bottom:32px; }
.ci { display:flex; gap:15px; margin-bottom:22px; }
.ci-ico { width:46px; height:46px; background:rgba(200,169,106,.08); border:1px solid rgba(200,169,106,.12); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.ci-t h4 { font-size:1.02rem; font-weight:500; margin-bottom:4px; }
.ci-t p { font-size:1rem; color:var(--t2); font-weight:300; }

/* ===== FOOTER ===== */
.footer { background:var(--n0); padding:72px 0 32px; border-top:1px solid rgba(200,169,106,.08); }
.fgrid { display:grid; grid-template-columns:2.1fr 1fr 1fr 1.2fr; gap:56px; margin-bottom:56px; }
.fl-desc { font-size:1rem; color:var(--t3); line-height:1.85; max-width:290px; font-weight:300; margin-top:18px; }
.fsoc { display:flex; gap:8px; margin-top:22px; }
.fsoc-btn { width:38px; height:38px; border:1px solid rgba(200,169,106,.14); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:.85rem; color:var(--t3); cursor:pointer; transition:var(--tr); }
.fsoc-btn:hover { border-color:var(--g); color:var(--g); background:rgba(200,169,106,.06); }
.fc h5 { font-size:.65rem; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--g); margin-bottom:22px; }
.fc li { margin-bottom:11px; }
.fc a, .fc span { font-size:1rem; color:var(--t3); cursor:pointer; transition:var(--tr); font-weight:300; }
.fc a:hover, .fc span:hover { color:var(--g); }
.fci { display:flex; gap:10px; margin-bottom:16px; }
.fci-ico { width:32px; height:32px; background:rgba(200,169,106,.06); border:1px solid rgba(200,169,106,.1); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:.8rem; flex-shrink:0; }
.fci-t { font-size:1rem; color:var(--t3); font-weight:300; line-height:1.5; }
.fci-t strong { display:block; color:var(--t2); font-weight:500; font-size:.9rem; margin-bottom:1px; }
.fblog-row { border-top:1px solid rgba(200,169,106,.08); padding:28px 0 32px; margin-bottom:8px; }
.fblog-row h5 { font-size:.65rem; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--g); margin-bottom:18px; }
.fblog-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:9px 24px; }
.fblog-grid a { font-size:.9rem; color:var(--t3); text-decoration:none; font-weight:300; transition:var(--tr); line-height:1.5; }
.fblog-grid a:hover { color:var(--g); }
.fbot { border-top:1px solid rgba(255,255,255,.05); padding-top:28px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; }
.fbot p { font-size:.9rem; color:var(--t4); font-weight:300; }
.fleg { display:flex; gap:22px; }
.fleg a { font-size:.88rem; color:var(--t4); cursor:pointer; transition:var(--tr); }
.fleg a:hover { color:var(--g); }

/* ===== STICKY BAR ===== */
.sbar { position:fixed; bottom:0; left:0; right:0; z-index:9998; background:linear-gradient(90deg,var(--n3),var(--n4)); border-top:2px solid var(--g); padding:14px 48px; display:flex; justify-content:space-between; align-items:center; transform:translateY(100%); transition:.5s var(--ease); gap:20px; }
.sbar.on { transform:translateY(0); }
.sbar p { font-size:1rem; font-weight:400; color:var(--t1); flex:1; }
.sbar strong { color:var(--g); }
.sbar-x { background:none; border:none; color:var(--t3); font-size:1.2rem; cursor:pointer; padding:3px; line-height:1; }
.sbar-x:hover { color:var(--w); }

/* ===== IMAGE MODAL ===== */
.imgm { display:none; position:fixed; inset:0; z-index:99999; background:rgba(0,0,0,.95); align-items:center; justify-content:center; }
.imgm.on { display:flex; animation:pgIn .28s ease; }
.imgm-img { max-width:92vw; max-height:90vh; object-fit:contain; border-radius:var(--r); }
.imgm-x { position:absolute; top:22px; right:28px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); color:var(--w); width:44px; height:44px; border-radius:50%; font-size:1.2rem; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:var(--tr); }
.imgm-x:hover { background:rgba(200,169,106,.2); border-color:var(--g); color:var(--g); }

/* ===== INLINE OVERRIDES (body text in inline styles) ===== */
/* These selectors handle font-size set inline in the HTML */
.sec p[style*="font-size:.8"], .sec p[style*="font-size:.81"],
.sec p[style*="font-size:.82"], .sec p[style*="font-size:.83"],
.sec p[style*="font-size:.84"], .sec p[style*="font-size:.85"],
.sec p[style*="font-size:.86"], .sec p[style*="font-size:.87"],
.sec p[style*="font-size:.88"], .sec p[style*="font-size:.9"], .sec p[style*="font-size:.92"], .sec p[style*="font-size:.95"] {
  font-size:1.05rem !important;
}

/* ===== RESPONSIVE ===== */
@media(max-width:1280px) {
  .cat-grid { grid-template-columns:repeat(3,1fr); }
  .fgrid { grid-template-columns:1.5fr 1fr 1fr; }
  .fgrid .fc:last-child { grid-column:1/-1; }
}
@media(max-width:1024px) {
  .wrap { padding:0 28px; }
  .nav-inner { padding:0 24px; }
  .g2,.gala-grid,.nom-lay,.con-lay,.info-g,.pv-inner { grid-template-columns:1fr; }
  .gv-thumbs { grid-template-columns:1fr 1fr; }
  .about-img img { height:400px; }
  .about-badge { bottom:-18px; right:-10px; }
  .gala-img { height:380px; }
  .fgrid { grid-template-columns:1fr 1fr; }
  .jg { grid-template-columns:1fr 1fr; }
  .gal-masonry { grid-auto-rows:185px; }
  .gal-item:nth-child(1), .gal-item:nth-child(6) { grid-column:auto; grid-row:auto; }
  .stats-grid { grid-template-columns:repeat(3,1fr); }
}
@media(max-width:768px) {
  .nav-links { display:none; position:fixed; top:74px; left:0; right:0; background:rgba(7,7,9,.99); backdrop-filter:blur(24px); flex-direction:column; padding:20px; gap:3px; border-bottom:1px solid rgba(200,169,106,.1); }
  .nav-links.on { display:flex; }
  .nl { padding:13px 14px; font-size:1rem; }
  .ham { display:flex; }
  .sec { padding:66px 0; }
  .hero .hero-body { width:100%; max-width:820px; }
  .hero > .wrap { padding:0 28px; }
  .hero-stats { flex-direction:column; gap:18px; border-top:none; padding-top:22px; }
  .hs { padding:0; border-right:none; }
  .why-grid, .ben-grid { grid-template-columns:1fr 1fr; }
  .cov-grid, .cat-grid, .wg, .rel-grid, .blog-grid { grid-template-columns:1fr 1fr; }
  .proc { flex-direction:column; gap:24px; }
  .proc::before { display:none; }
  .gal-full { grid-template-columns:1fr 1fr; }
  .gf:nth-child(7n+1) { grid-column:auto; }
  .gf:nth-child(7n+1) img { height:230px; }
  .vf-grid { grid-template-columns:1fr; }
  .fgrid { grid-template-columns:1fr; }
  .fr2 { grid-template-columns:1fr; }
  .sbar { flex-direction:column; gap:10px; padding:14px 18px; }
  .testi-head { flex-direction:column; }
  .crit-g { grid-template-columns:1fr; }
  .gv-thumbs { grid-template-columns:1fr 1fr; }
  .pv-minis { grid-template-columns:1fr 1fr; }
  .about-feats { grid-template-columns:1fr; }
}
@media(max-width:480px) {
  .cat-grid, .wg, .cov-grid, .rel-grid, .why-grid, .ben-grid, .blog-grid, .jg { grid-template-columns:1fr; }
  .hero h1 { font-size:2.2rem; }
  .hero-btns { flex-direction:column; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .stat:nth-child(5) { grid-column:span 2; }
  .fblog-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:768px) {
  .fblog-grid { grid-template-columns:repeat(2,1fr); }
}

/* ====================================================================
   GLOBAL IMAGE POLICY — Final-Photos/ system
   Hero / About / Thumbnail rules apply to every page.
==================================================================== */

/* All images: fluid, no overflow, no layout shift */
img { max-width:100%; height:auto; display:block; vertical-align:middle; }

/* Hero/banner images — fill container, intelligent crop centered, preserve faces */
.hero-bg img,
.blog-hero .bh-img img,
.cta-bar-bg img,
.cta-nominate-bg img,
.gala-img,
.about-img img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: top;
}

/* Card / thumbnail images — uniform aspect ratio, no distortion */
.cat-card img,
.bc-img img,
.gv-th img,
.pv-mini img,
.ts-item img,
.gal-item img,
.gf img,
.fblog-card img,
.rel-card img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: top;
}

/* Editorial content (blog body) images — proportional, never aggressively cropped */
.art-img img,
.art-main img:not(.no-fit) {
  width:100%;
  height:auto;
  max-height:560px;
  object-fit:cover;
  object-position: top;
  border-radius:var(--r);
}

/* CTA + About sections alternate layout — Image Left/Right per section */
.art-img:nth-of-type(even) { margin-left:auto; margin-right:auto; }

/* Responsive image heights — desktop / tablet / mobile */
@media (max-width:1024px) {
  .about-img img { height:480px; }
  .gala-img { height:440px; }
  .art-img img { max-height:460px; }
}
@media (max-width:768px) {
  .about-img img { height:380px; }
  .gala-img { height:340px; }
  .art-img img { max-height:380px; }
}
@media (max-width:480px) {
  .about-img img { height:300px; }
  .gala-img { height:260px; }
  .art-img img { max-height:300px; }
}

/* Prevent any empty image container — collapse if no source */
img[src=""] { display:none; }
img:not([src]) { display:none; }

/* ====================================================================
   Floating WhatsApp button — fixed bottom-right on every page.
==================================================================== */
.wa-fab {
  position: fixed;
  right: 22px;
  bottom: 22px;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #25D366;
  color: #fff !important;
  border-radius: 50%;
  box-shadow: 0 6px 18px rgba(0,0,0,.32);
  text-decoration: none;
  z-index: 10000;
  transition: transform .25s ease, box-shadow .25s ease;
}
.wa-fab:hover { transform: scale(1.07); box-shadow: 0 10px 28px rgba(0,0,0,.42); }
.wa-fab svg { width: 30px; height: 30px; fill: #fff; }
@media (max-width: 480px) {
  .wa-fab { right: 16px; bottom: 16px; width: 52px; height: 52px; }
  .wa-fab svg { width: 26px; height: 26px; }
}

/* ====================================================================
   GLOBAL IMAGE ANCHOR — preserve the top of every image
   Whenever object-fit:cover crops, the TOP stays anchored. Faces,
   headers, logos and signage in the upper portion of any photograph
   are never sliced off. Scoped to img only so background-image
   declarations (which use background-position) are unaffected.
==================================================================== */
img { object-position: top; }


