/* ======================================================
   ASHOKRAO MANE — OFFICIAL LEADERSHIP PLATFORM
   Premium Political Branding Stylesheet
   ====================================================== */

:root{
  --ink:#0c0d11;
  --charcoal:#151821;
  --graphite:#1e222d;
  --slate:#2a2f3c;
  --mute:#6b6f7a;
  --line:#e4dfd4;
  --bone:#f4efe6;
  --ivory:#faf7f1;
  --paper:#ffffff;
  --gold:#c9a961;
  --gold-deep:#a8863f;
  --gold-soft:#e4cf9a;
  --saffron:#e8833a;
  --saffron-deep:#c66a24;
  --ember:#b04a1b;
  --green:#3f5c3a;
  --shadow-sm:0 4px 18px rgba(15,17,25,.06);
  --shadow-md:0 18px 50px rgba(15,17,25,.12);
  --shadow-lg:0 40px 90px rgba(15,17,25,.22);
  --ease:cubic-bezier(.2,.7,.2,1);
  --serif:"Cormorant Garamond", "Playfair Display", Georgia, serif;
  --display:"Fraunces", "Cormorant Garamond", Georgia, serif;
  --sans:"Inter", "Manrope", system-ui, -apple-system, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  color:var(--charcoal);
  background:var(--ivory);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"ss01","cv11";
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

::selection{background:var(--gold);color:var(--ink)}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:500;letter-spacing:-.02em;color:var(--ink);line-height:1.08}
h1{font-size:clamp(2.6rem,6vw,5.8rem)}
h2{font-size:clamp(2rem,4vw,3.6rem)}
h3{font-size:clamp(1.4rem,2.4vw,2rem)}
h4{font-size:clamp(1.1rem,1.6vw,1.3rem)}
p{color:var(--slate)}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.32em;
  font-weight:600;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:.8rem;
}
.eyebrow::before{
  content:"";width:28px;height:1px;background:var(--gold);display:inline-block;
}
.eyebrow.center::before{display:none}

.display{
  font-family:var(--display);
  font-weight:400;
  font-style:italic;
  letter-spacing:-.015em;
}

.mono-tag{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}

/* ---------- CONTAINER ---------- */
.wrap{max-width:1360px;margin:0 auto;padding:0 32px}
.wrap-slim{max-width:1160px;margin:0 auto;padding:0 32px}
.wrap-wide{max-width:1560px;margin:0 auto;padding:0 32px}

section{position:relative}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.75rem;
  padding:1rem 1.9rem;
  font-size:.8rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  border-radius:2px;
  transition:all .5s var(--ease);
  position:relative;
  overflow:hidden;
  white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--ivory)}
.btn-primary:hover{background:var(--saffron-deep);transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);color:var(--ink)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-outline{border:1px solid var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--ivory)}
.btn-ghost{color:var(--ivory);border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:var(--ivory);color:var(--ink);border-color:var(--ivory)}
.btn .arrow{display:inline-block;transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- NAVIGATION ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.2rem 0;
  transition:all .45s var(--ease);
  background:rgba(250,247,241,.0);
}
.nav.scrolled{
  background:rgba(250,247,241,.96);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid rgba(15,17,25,.08);
  padding:.8rem 0;
}
.nav.dark{color:var(--ivory)}
.nav.dark.scrolled{background:rgba(12,13,17,.92);border-bottom-color:rgba(255,255,255,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:center;gap:.9rem;font-family:var(--display);font-weight:500}
.brand-mark{
  width:44px;height:44px;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);
  display:grid;place-items:center;
  color:var(--ink);
  font-family:var(--display);font-weight:700;font-size:1.15rem;
  letter-spacing:-.02em;
  border-radius:2px;
  position:relative;
}
.brand-mark::after{
  content:"";position:absolute;inset:3px;
  border:1px solid rgba(12,13,17,.25);
  border-radius:1px;pointer-events:none;
}
.brand-text{line-height:1.05}
.brand-text .name{font-size:1.1rem;font-weight:500;letter-spacing:-.01em}
.brand-text .sub{font-family:var(--sans);font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);font-weight:600;margin-top:2px}
.nav.dark .brand-text .sub{color:rgba(255,255,255,.55)}

.menu{display:flex;align-items:center;gap:2.2rem}
.menu a{
  position:relative;
  font-size:.76rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:.5rem 0;
}
.menu a::after{
  content:"";position:absolute;bottom:0;left:0;
  width:0;height:1px;background:currentColor;
  transition:width .4s var(--ease);
}
.menu a:hover::after,.menu a.active::after{width:100%}
.menu a.active{color:var(--gold-deep)}
.nav.dark .menu a.active{color:var(--gold)}

.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-cta .badge{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mute);
  padding:.45rem .8rem;border:1px solid rgba(15,17,25,.15);border-radius:2px;
}
.nav.dark .nav-cta .badge{color:rgba(255,255,255,.55);border-color:rgba(255,255,255,.2)}

.burger{display:none;width:42px;height:42px;position:relative;z-index:200}
.burger span{
  position:absolute;left:10px;width:22px;height:1.5px;background:currentColor;
  transition:all .4s var(--ease);
}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:22px;width:16px}
.burger span:nth-child(3){top:28px}
.burger.open span:nth-child(1){top:22px;transform:rotate(45deg);width:22px}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:22px;transform:rotate(-45deg);width:22px}

.mobile-menu{
  position:fixed;inset:0;z-index:99;
  background:var(--ink);color:var(--ivory);
  padding:120px 32px 40px;
  transform:translateY(-100%);
  transition:transform .6s var(--ease);
  display:flex;flex-direction:column;justify-content:space-between;
  overflow-y:auto;
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu ul li{border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-menu ul li a{
  display:block;padding:1.4rem 0;
  font-family:var(--display);font-size:2rem;letter-spacing:-.01em;
  transition:padding .3s var(--ease);
}
.mobile-menu ul li a:hover{padding-left:1rem;color:var(--gold)}
.mobile-menu .mm-foot{padding-top:2rem;color:rgba(255,255,255,.5);font-size:.8rem}

@media (max-width:1080px){
  .menu,.nav-cta .badge{display:none}
  .burger{display:block}
}

/* ---------- PASSWORD GATE ---------- */
.gate{
  position:fixed;inset:0;
  background:#0a0b0e;
  color:var(--ivory);
  overflow:hidden;
  display:grid;place-items:center;
}
.gate-bg{
  position:absolute;inset:0;
  background-image:url("../images/iAshokraoKondiramMane9587.jpg");
  background-size:cover;background-position:center 15%;
  filter:grayscale(100%) brightness(.38) contrast(1.1);
  transform:scale(1.05);
  animation:breathe 14s var(--ease) infinite alternate;
}
@keyframes breathe{to{transform:scale(1.12)}}
.gate::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(1200px 600px at 50% 40%,rgba(201,169,97,.18),transparent 60%),
    linear-gradient(180deg,rgba(10,11,14,.6) 0%,rgba(10,11,14,.88) 100%);
}
.gate::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.015) 0,rgba(255,255,255,.015) 1px,transparent 1px,transparent 3px);
}
.gate-inner{position:relative;z-index:2;width:min(520px,92vw);padding:0 24px;text-align:center}
.gate-crest{
  width:78px;height:78px;margin:0 auto 2rem;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  display:grid;place-items:center;
  color:var(--ink);
  font-family:var(--display);font-weight:700;font-size:1.8rem;
  border-radius:2px;
  position:relative;
  box-shadow:0 0 0 6px rgba(201,169,97,.12),0 0 60px rgba(201,169,97,.35);
}
.gate-crest::after{content:"";position:absolute;inset:5px;border:1px solid rgba(12,13,17,.35);border-radius:1px}
.gate h1{
  font-size:clamp(2.2rem,4.2vw,3.4rem);
  color:var(--ivory);
  margin-bottom:1rem;
  font-weight:400;
  letter-spacing:-.02em;
}
.gate h1 em{color:var(--gold);font-family:var(--display)}
.gate .tag{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold-soft);margin-bottom:.8rem;
}
.gate .sub{color:rgba(255,255,255,.64);font-size:.95rem;margin-bottom:2.4rem;max-width:360px;margin-inline:auto}
.gate-form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(20px);
  padding:2rem;border-radius:4px;
  box-shadow:var(--shadow-lg);
}
.gate-field{
  display:flex;align-items:center;gap:.6rem;
  background:rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.12);
  border-radius:2px;
  padding:.3rem;
  margin-bottom:1rem;
  transition:border-color .3s var(--ease);
}
.gate-field:focus-within{border-color:var(--gold)}
.gate-field svg{width:18px;height:18px;margin-left:.9rem;color:var(--gold-soft);flex:none}
.gate-field input{
  flex:1;background:transparent;border:none;outline:none;
  padding:.95rem .5rem;color:var(--ivory);font-family:var(--sans);
  font-size:.95rem;letter-spacing:.12em;
}
.gate-field input::placeholder{color:rgba(255,255,255,.35);letter-spacing:.1em}
.gate-eye{padding:.7rem;color:rgba(255,255,255,.5);cursor:pointer}
.gate-eye:hover{color:var(--gold)}
.gate button[type=submit]{
  width:100%;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  color:var(--ink);
  padding:1.05rem;
  font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:.78rem;
  border-radius:2px;
  transition:all .4s var(--ease);
}
.gate button[type=submit]:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(201,169,97,.35)}
.gate-error{
  color:#ff9e7a;font-size:.8rem;margin-top:1rem;
  letter-spacing:.08em;opacity:0;transition:opacity .3s var(--ease);
  display:flex;align-items:center;gap:.5rem;justify-content:center;
}
.gate-error.show{opacity:1;animation:shake .5s var(--ease)}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-6px)}
  40%,80%{transform:translateX(6px)}
}
.gate-footer{
  position:absolute;bottom:28px;left:0;right:0;z-index:2;
  text-align:center;
  color:rgba(255,255,255,.4);
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
}
.gate-marks{
  position:absolute;top:32px;left:0;right:0;z-index:2;
  display:flex;justify-content:space-between;padding:0 44px;
  color:rgba(255,255,255,.5);font-family:var(--mono);font-size:.65rem;
  letter-spacing:.22em;text-transform:uppercase;
}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100vh;
  background:var(--ink);color:var(--ivory);
  overflow:hidden;
  padding:140px 0 80px;
  display:flex;align-items:center;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center 18%;
  filter:grayscale(40%) brightness(.55) contrast(1.05);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(105deg,rgba(12,13,17,.95) 0%,rgba(12,13,17,.6) 55%,rgba(12,13,17,.15) 100%),
    linear-gradient(0deg,rgba(12,13,17,.6) 0%,transparent 50%);
}
.hero-grain{
  position:absolute;inset:0;opacity:.3;pointer-events:none;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .25 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.4fr .8fr;gap:5rem;align-items:center;
  width:100%;
}
.hero-meta{
  display:flex;align-items:center;gap:1.4rem;margin-bottom:2rem;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.26em;
  text-transform:uppercase;color:rgba(255,255,255,.55);
}
.hero-meta .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 5px rgba(201,169,97,.18);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 10px rgba(201,169,97,0)}}
.hero h1{
  color:var(--ivory);
  font-size:clamp(3rem,7vw,6.8rem);
  line-height:.98;letter-spacing:-.03em;
  margin-bottom:1.8rem;
  font-weight:400;
}
.hero h1 em{color:var(--gold);font-family:var(--display);display:block}
.hero h1 .cut{
  display:block;overflow:hidden;
}
.hero h1 .cut span{display:inline-block;transform:translateY(100%);animation:riseIn 1.2s var(--ease) forwards}
.hero h1 .cut:nth-child(2) span{animation-delay:.15s}
.hero h1 .cut:nth-child(3) span{animation-delay:.3s}
@keyframes riseIn{to{transform:translateY(0)}}

.hero .lede{
  font-size:1.15rem;max-width:560px;
  color:rgba(255,255,255,.72);line-height:1.7;margin-bottom:2.5rem;
}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-aside{
  position:relative;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  backdrop-filter:blur(20px);
  padding:2.4rem;border-radius:3px;
}
.hero-aside::before{
  content:"";position:absolute;top:-1px;left:-1px;width:40px;height:40px;
  border-top:2px solid var(--gold);border-left:2px solid var(--gold);
}
.hero-aside::after{
  content:"";position:absolute;bottom:-1px;right:-1px;width:40px;height:40px;
  border-bottom:2px solid var(--gold);border-right:2px solid var(--gold);
}
.hero-aside .tag{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold-soft);margin-bottom:1rem;
}
.hero-aside h3{color:var(--ivory);font-style:italic;font-weight:400;margin-bottom:1.4rem;font-size:1.5rem;line-height:1.3}
.hero-aside p{color:rgba(255,255,255,.65);font-size:.92rem;line-height:1.7;margin-bottom:1.4rem}
.hero-aside .sig{
  display:flex;align-items:center;gap:1rem;
  padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.1);
}
.hero-aside .sig .ini{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  display:grid;place-items:center;color:var(--ink);font-family:var(--display);font-weight:600;
}
.hero-aside .sig .n{font-weight:600;color:var(--ivory);font-size:.9rem;letter-spacing:.04em}
.hero-aside .sig .t{font-size:.7rem;color:rgba(255,255,255,.5);letter-spacing:.15em;text-transform:uppercase;margin-top:2px}

.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:.8rem;
  color:rgba(255,255,255,.5);font-family:var(--mono);font-size:.62rem;
  letter-spacing:.28em;text-transform:uppercase;
}
.hero-scroll .line{width:1px;height:40px;background:linear-gradient(180deg,var(--gold),transparent);animation:slide 2.4s infinite}
@keyframes slide{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:3rem}
  .hero{padding:120px 0 60px}
}

/* Alt page heroes */
.page-hero{
  position:relative;min-height:70vh;
  background:var(--ink);color:var(--ivory);
  padding:160px 0 80px;
  overflow:hidden;
  display:flex;align-items:center;
}
.page-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center 20%;
  filter:grayscale(35%) brightness(.5) contrast(1.05);
}
.page-hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,13,17,.85),rgba(12,13,17,.95)),
    linear-gradient(90deg,rgba(12,13,17,.7) 0%,transparent 50%,rgba(12,13,17,.7) 100%);
}
.page-hero-inner{position:relative;z-index:2;max-width:900px}
.page-hero .mono-tag{color:var(--gold-soft)}
.page-hero h1{
  color:var(--ivory);font-size:clamp(2.6rem,5.6vw,5.4rem);
  margin:1.2rem 0 1.4rem;line-height:1.02;font-weight:400;
}
.page-hero h1 em{color:var(--gold);font-family:var(--display)}
.page-hero p{color:rgba(255,255,255,.7);font-size:1.12rem;max-width:620px;line-height:1.7}
.breadcrumb{
  display:flex;gap:.7rem;align-items:center;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1rem;
}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:rgba(255,255,255,.25)}

/* ---------- MARQUEE TICKER ---------- */
.ticker{
  background:var(--ink);color:var(--ivory);
  padding:1.1rem 0;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.ticker-track{
  display:flex;gap:3rem;align-items:center;white-space:nowrap;
  animation:tick 48s linear infinite;
}
@keyframes tick{to{transform:translateX(-50%)}}
.ticker-item{
  display:inline-flex;align-items:center;gap:1rem;
  font-family:var(--display);font-style:italic;font-size:1.3rem;
  color:rgba(255,255,255,.7);
}
.ticker-item .dot{width:6px;height:6px;background:var(--gold);border-radius:50%}

/* ---------- COUNTERS ---------- */
.stats{padding:6rem 0;background:var(--bone);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{
  padding:2rem;
  position:relative;
}
.stat:not(:last-child){border-right:1px solid rgba(15,17,25,.08)}
.stat .num{
  font-family:var(--display);font-size:clamp(3rem,5vw,4.6rem);
  font-weight:500;letter-spacing:-.03em;color:var(--ink);line-height:1;
  display:flex;align-items:flex-start;
}
.stat .num .plus{font-size:.5em;margin-top:.4em;color:var(--gold-deep);margin-left:.1em}
.stat .label{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);margin-top:1rem;
}
.stat .desc{margin-top:.6rem;font-size:.92rem;color:var(--slate);max-width:230px}
@media (max-width:900px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:not(:last-child){border-right:0}
  .stat{border-bottom:1px solid rgba(15,17,25,.08)}
}
@media (max-width:520px){.stats-grid{grid-template-columns:1fr}}

/* ---------- SECTION HEADS ---------- */
.sec-head{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:4rem;align-items:end}
.sec-head h2{max-width:18ch}
.sec-head p{color:var(--slate);max-width:460px;font-size:1.04rem;line-height:1.75}
.sec-head .side{display:flex;justify-content:flex-end}
@media (max-width:800px){.sec-head{grid-template-columns:1fr;gap:1.4rem}}

/* ---------- PRIORITIES / FEATURED ---------- */
.priorities{padding:7rem 0;background:var(--ivory)}
.prio-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.4rem}
.prio{
  grid-column:span 4;
  background:var(--paper);
  border:1px solid var(--line);
  padding:2.4rem;
  position:relative;
  transition:all .5s var(--ease);
  overflow:hidden;
  min-height:320px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.prio.feat{grid-column:span 8;background:var(--ink);color:var(--ivory);border-color:var(--ink);min-height:400px}
.prio.feat h3{color:var(--ivory)}
.prio.feat p{color:rgba(255,255,255,.7)}
.prio::before{
  content:"";position:absolute;top:0;left:0;height:3px;width:0;
  background:var(--gold);transition:width .6s var(--ease);
}
.prio:hover::before{width:100%}
.prio:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.prio .num{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.28em;
  color:var(--gold-deep);text-transform:uppercase;margin-bottom:1.2rem;
}
.prio.feat .num{color:var(--gold-soft)}
.prio h3{font-size:1.7rem;margin-bottom:.9rem;line-height:1.2}
.prio p{color:var(--slate);font-size:.95rem;line-height:1.75;margin-bottom:1.4rem}
.prio .more{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink);
  align-self:flex-start;margin-top:auto;
}
.prio.feat .more{color:var(--gold)}
.prio .more::after{content:"→";transition:transform .3s var(--ease)}
.prio:hover .more::after{transform:translateX(4px)}

@media (max-width:900px){.prio,.prio.feat{grid-column:span 12;min-height:auto}}

/* ---------- QUOTE / MESSAGE ---------- */
.quote-sec{
  padding:8rem 0;
  background:
    linear-gradient(180deg,transparent,rgba(201,169,97,.06)),
    var(--bone);
  text-align:center;
  position:relative;
}
.quote-sec::before{
  content:"\201C";position:absolute;top:40px;left:50%;transform:translateX(-50%);
  font-family:var(--display);font-size:14rem;color:rgba(201,169,97,.16);line-height:.7;font-style:italic;
}
.quote-sec blockquote{
  max-width:900px;margin:0 auto;
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(1.6rem,3vw,2.8rem);line-height:1.35;
  color:var(--ink);letter-spacing:-.01em;position:relative;
}
.quote-sec .by{
  margin-top:2.4rem;display:inline-flex;align-items:center;gap:1rem;
}
.quote-sec .by .line{width:40px;height:1px;background:var(--gold)}
.quote-sec .by .txt{font-family:var(--mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--mute)}

/* ---------- LATEST UPDATES ---------- */
.updates{padding:7rem 0}
.up-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.up{
  padding:2rem 1.8rem 2rem 0;
  border-bottom:1px solid var(--line);
  transition:all .4s var(--ease);
  cursor:pointer;
}
.up:not(:last-child){border-right:1px solid var(--line);padding-right:1.8rem}
.up:nth-child(2){padding-left:1.8rem;padding-right:1.8rem}
.up:nth-child(3){padding-left:1.8rem;padding-right:0}
.up:hover{background:rgba(201,169,97,.04)}
.up .meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.4rem;font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute)}
.up .meta .cat{color:var(--gold-deep)}
.up h3{font-size:1.35rem;margin-bottom:1rem;line-height:1.3;transition:color .3s}
.up:hover h3{color:var(--saffron-deep)}
.up p{color:var(--slate);font-size:.95rem}
.up .read{margin-top:1.4rem;font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);display:inline-flex;gap:.5rem}
@media (max-width:900px){
  .up-grid{grid-template-columns:1fr}
  .up,.up:not(:last-child),.up:nth-child(2),.up:nth-child(3){border-right:0;padding:2rem 0}
}

/* ---------- INTRO SPLIT ---------- */
.split{padding:8rem 0;background:var(--ivory)}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.split-img{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:2px}
.split-img img{width:100%;height:100%;object-fit:cover;object-position:center 15%}
.split-img::after{
  content:"";position:absolute;bottom:-30px;right:-30px;width:140px;height:140px;
  background:var(--gold);z-index:-1;
}
.split-content .eyebrow{margin-bottom:1.4rem}
.split-content h2{margin-bottom:1.8rem}
.split-content p{font-size:1.02rem;line-height:1.8;margin-bottom:1.2rem;color:var(--slate)}
.split-cta{margin-top:2rem}
.split-sig{display:flex;align-items:center;gap:1.2rem;margin-top:2.6rem;padding-top:2rem;border-top:1px solid var(--line)}
.split-sig .script{font-family:var(--display);font-style:italic;font-size:1.9rem;color:var(--ink);line-height:1}
.split-sig .who{font-size:.8rem;color:var(--mute);letter-spacing:.14em;text-transform:uppercase}
@media (max-width:900px){.split-grid{grid-template-columns:1fr;gap:3rem}}

/* ---------- TIMELINE (journey) ---------- */
.timeline-sec{padding:7rem 0;background:var(--ivory)}
.tl{position:relative;max-width:1000px;margin:0 auto;padding:2rem 0}
.tl::before{
  content:"";position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:1px;background:linear-gradient(180deg,transparent,var(--line) 10%,var(--line) 90%,transparent);
}
.tl-item{
  display:grid;grid-template-columns:1fr 80px 1fr;gap:0;
  margin-bottom:4rem;align-items:center;position:relative;
}
.tl-item:nth-child(even) .tl-card{grid-column:3;text-align:left;padding-left:2rem}
.tl-item:nth-child(even) .tl-side{grid-column:1;text-align:right;padding-right:2rem}
.tl-card{
  grid-column:1;text-align:right;padding-right:2rem;
  background:var(--paper);padding:2rem;border:1px solid var(--line);border-radius:2px;
  text-align:left;
}
.tl-item:nth-child(odd) .tl-card{grid-column:1;margin-right:2rem}
.tl-item:nth-child(even) .tl-card{grid-column:3;margin-left:2rem}
.tl-item:nth-child(odd) .tl-side{grid-column:3;padding-left:2rem}
.tl-item:nth-child(even) .tl-side{grid-column:1;padding-right:2rem;text-align:right}
.tl-node{
  grid-column:2;width:16px;height:16px;border-radius:50%;
  background:var(--gold);
  justify-self:center;
  box-shadow:0 0 0 6px var(--ivory),0 0 0 7px var(--gold),0 0 30px rgba(201,169,97,.6);
  z-index:2;
}
.tl-year{font-family:var(--display);font-size:3.8rem;color:var(--gold-deep);font-weight:500;line-height:1;letter-spacing:-.02em}
.tl-phase{font-family:var(--mono);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--mute);margin-top:.6rem}
.tl-card h3{font-size:1.4rem;margin-bottom:.8rem}
.tl-card p{color:var(--slate);font-size:.95rem;line-height:1.75}
.tl-card .tag{display:inline-block;padding:.3rem .7rem;background:rgba(201,169,97,.12);color:var(--gold-deep);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin-bottom:.9rem;border-radius:2px}
@media (max-width:800px){
  .tl::before{left:24px}
  .tl-item{grid-template-columns:48px 1fr;gap:1rem}
  .tl-item:nth-child(odd) .tl-card,.tl-item:nth-child(even) .tl-card{
    grid-column:2;margin:0;text-align:left;padding-right:0;padding-left:0;
  }
  .tl-item:nth-child(odd) .tl-side,.tl-item:nth-child(even) .tl-side{
    grid-column:2;text-align:left;padding:0;margin-bottom:.8rem
  }
  .tl-node{grid-column:1;justify-self:start;margin-left:17px}
  .tl-year{font-size:2.2rem}
}

/* ---------- ACHIEVEMENTS ---------- */
.progress{padding:7rem 0;background:var(--ivory)}
.progress-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid var(--line);
}
.pr{
  padding:2.4rem 2rem;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--paper);
  transition:all .4s var(--ease);
  position:relative;
  overflow:hidden;
  min-height:280px;
  display:flex;flex-direction:column;
}
.pr:nth-child(3n){border-right:0}
.pr:nth-last-child(-n+3){border-bottom:0}
.pr::before{
  content:"";position:absolute;inset:0;background:var(--ink);z-index:0;
  transform:translateY(101%);transition:transform .5s var(--ease);
}
.pr:hover::before{transform:translateY(0)}
.pr:hover *{color:var(--ivory);position:relative;z-index:1}
.pr:hover .pr-icon{background:var(--gold);color:var(--ink)}
.pr:hover .pr-stat{color:var(--gold)}
.pr-icon{
  width:56px;height:56px;border-radius:2px;
  background:rgba(201,169,97,.14);color:var(--gold-deep);
  display:grid;place-items:center;margin-bottom:1.4rem;
  transition:all .4s var(--ease);position:relative;z-index:1;
}
.pr-icon svg{width:26px;height:26px}
.pr h3{font-size:1.3rem;margin-bottom:.8rem;position:relative;z-index:1}
.pr p{color:var(--slate);font-size:.92rem;line-height:1.7;position:relative;z-index:1;margin-bottom:1.4rem}
.pr-stat{font-family:var(--display);font-size:1.9rem;color:var(--gold-deep);line-height:1;margin-top:auto;position:relative;z-index:1;font-weight:500}
.pr-stat small{display:block;font-family:var(--mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-top:.4rem;font-weight:400}
.pr:hover .pr-stat small{color:rgba(255,255,255,.55)}
@media (max-width:900px){
  .progress-grid{grid-template-columns:repeat(2,1fr)}
  .pr:nth-child(3n){border-right:1px solid var(--line)}
  .pr:nth-child(2n){border-right:0}
  .pr:nth-last-child(-n+3){border-bottom:1px solid var(--line)}
  .pr:nth-last-child(-n+2){border-bottom:0}
}
@media (max-width:560px){
  .progress-grid{grid-template-columns:1fr}
  .pr,.pr:nth-child(3n),.pr:nth-child(2n){border-right:0}
  .pr{border-bottom:1px solid var(--line)!important}
}

/* ---------- CONSTITUENCY ---------- */
.const-hero{padding:7rem 0;background:var(--ivory)}
.const-split{display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center}
.const-img{position:relative;aspect-ratio:4/4;overflow:hidden}
.const-img img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.const-img .frame{
  position:absolute;inset:14px;border:1px solid rgba(255,255,255,.3);pointer-events:none;z-index:2;
}
.const-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;margin-top:2rem;background:var(--line)}
.const-meta .m{background:var(--paper);padding:1.4rem}
.const-meta .m .k{font-family:var(--mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
.const-meta .m .v{font-family:var(--display);font-size:1.7rem;color:var(--ink);margin-top:.4rem;line-height:1.1}

.const-pillars{padding:7rem 0;background:var(--bone)}
.pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.pill{
  background:var(--paper);padding:2rem 1.6rem;border:1px solid var(--line);
  transition:all .5s var(--ease);min-height:240px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.pill:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.pill .n{font-family:var(--mono);font-size:.65rem;letter-spacing:.28em;color:var(--gold-deep);text-transform:uppercase;margin-bottom:1.2rem}
.pill h4{font-size:1.15rem;margin-bottom:.8rem}
.pill p{color:var(--slate);font-size:.88rem;line-height:1.7}
@media (max-width:900px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.pillars-grid{grid-template-columns:1fr}}

/* ---------- GALLERY ---------- */
.gallery-sec{padding:5rem 0 7rem;background:var(--ivory)}
.gallery-tabs{display:flex;gap:.5rem;margin-bottom:3rem;flex-wrap:wrap;justify-content:center}
.gallery-tab{
  padding:.8rem 1.6rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  border:1px solid var(--line);background:var(--paper);color:var(--slate);border-radius:2px;
  transition:all .3s var(--ease);cursor:pointer;
}
.gallery-tab:hover{border-color:var(--ink);color:var(--ink)}
.gallery-tab.active{background:var(--ink);color:var(--ivory);border-color:var(--ink)}

.masonry{
  column-count:3;column-gap:1rem;
}
.masonry .item{
  break-inside:avoid;margin-bottom:1rem;
  position:relative;overflow:hidden;cursor:pointer;
  border-radius:2px;
  transition:transform .5s var(--ease);
}
.masonry .item:hover{transform:translateY(-4px)}
.masonry .item img{
  width:100%;height:auto;display:block;
  transition:transform .7s var(--ease),filter .5s var(--ease);
}
.masonry .item:hover img{transform:scale(1.04);filter:brightness(.85)}
.masonry .item .cap{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.4rem;color:#fff;
  background:linear-gradient(180deg,transparent 40%,rgba(12,13,17,.92) 100%);
  opacity:0;transition:opacity .4s var(--ease);
}
.masonry .item:hover .cap{opacity:1}
.masonry .item .cap .t{font-family:var(--display);font-size:1.2rem;margin-bottom:.3rem;line-height:1.2}
.masonry .item .cap .s{font-family:var(--mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft)}
.masonry .item .ico{
  position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.9);color:var(--ink);display:grid;place-items:center;
  opacity:0;transform:translateY(-10px);transition:all .4s var(--ease);
}
.masonry .item:hover .ico{opacity:1;transform:translateY(0)}
@media (max-width:900px){.masonry{column-count:2}}
@media (max-width:560px){.masonry{column-count:1}}

/* Aligned scenes grid (preview on constituency page) */
.scenes-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
}
.scene{
  background:var(--paper);
  border:1px solid var(--line);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.scene:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.scene-img{
  position:relative;width:100%;
  aspect-ratio:4/5;
  overflow:hidden;background:var(--bone);
}
.scene-img img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 20%;
  display:block;
  transition:transform .8s var(--ease);
}
.scene:hover .scene-img img{transform:scale(1.03)}
.scene figcaption{
  padding:1.4rem 1.6rem 1.8rem;
  border-top:1px solid var(--line);
  background:var(--paper);
}
.scene figcaption .s{
  font-family:var(--mono);
  font-size:.65rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:block;
  margin-bottom:.6rem;
}
.scene figcaption h4{
  font-size:1.3rem;
  line-height:1.25;
  color:var(--ink);
  font-weight:500;
}
@media (max-width:900px){
  .scenes-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
}
@media (max-width:600px){
  .scenes-grid{grid-template-columns:1fr}
  .scene-img{aspect-ratio:4/5}
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(8,9,12,.96);
  display:none;align-items:center;justify-content:center;
  padding:5vh 4vw;cursor:zoom-out;
  backdrop-filter:blur(10px);
}
.lightbox.open{display:flex;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox .close{position:absolute;top:30px;right:40px;color:#fff;font-size:1.8rem;cursor:pointer;z-index:2}
.lightbox .caption{position:absolute;bottom:30px;left:0;right:0;text-align:center;color:rgba(255,255,255,.75);font-family:var(--mono);font-size:.75rem;letter-spacing:.22em;text-transform:uppercase}

/* ---------- VISION ---------- */
.vision-hero{padding:7rem 0;background:var(--ivory)}
.vision-intro{display:grid;grid-template-columns:.7fr 1fr;gap:5rem;align-items:flex-start}
.vision-intro h2{font-size:clamp(2.4rem,4.4vw,4rem)}
.vision-intro p{font-size:1.05rem;line-height:1.85;color:var(--slate);margin-bottom:1.2rem}
@media (max-width:900px){.vision-intro{grid-template-columns:1fr;gap:2rem}}

.vision-pillars{padding:6rem 0;background:var(--ink);color:var(--ivory)}
.vp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.vp{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);
  padding:2.2rem 1.8rem;min-height:300px;
  display:flex;flex-direction:column;transition:all .5s var(--ease);
  position:relative;overflow:hidden;
}
.vp:hover{background:rgba(201,169,97,.08);border-color:var(--gold);transform:translateY(-4px)}
.vp .big{
  font-family:var(--display);font-size:3.8rem;line-height:.9;color:var(--gold);
  letter-spacing:-.03em;font-weight:500;margin-bottom:1.4rem;
}
.vp h4{color:var(--ivory);margin-bottom:.8rem;font-size:1.25rem}
.vp p{color:rgba(255,255,255,.65);font-size:.9rem;line-height:1.7}
.vp .tag{
  margin-top:auto;padding-top:1.4rem;font-family:var(--mono);
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-soft);
}
@media (max-width:1000px){.vp-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.vp-grid{grid-template-columns:1fr}}

.vision-cta{padding:7rem 0;background:var(--bone);text-align:center}
.vision-cta h2{margin-bottom:1.4rem;max-width:20ch;margin-inline:auto}
.vision-cta p{max-width:560px;margin:0 auto 2.4rem;font-size:1.05rem;color:var(--slate)}

/* ---------- CONTACT ---------- */
.contact-sec{padding:7rem 0;background:var(--ivory)}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem}
.contact-info{background:var(--ink);color:var(--ivory);padding:3rem;position:relative;overflow:hidden}
.contact-info::before{
  content:"";position:absolute;top:-80px;right:-80px;width:240px;height:240px;
  border-radius:50%;background:radial-gradient(circle,rgba(201,169,97,.3),transparent 70%);
}
.contact-info h3{color:var(--ivory);font-size:2rem;margin-bottom:1rem}
.contact-info > p{color:rgba(255,255,255,.65);margin-bottom:2.4rem;font-size:.95rem;line-height:1.75}
.c-item{padding:1.4rem 0;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:1.2rem;align-items:flex-start;position:relative;z-index:1}
.c-item:last-child{border-bottom:1px solid rgba(255,255,255,.08)}
.c-ico{
  width:42px;height:42px;border-radius:2px;
  background:rgba(201,169,97,.14);color:var(--gold);
  display:grid;place-items:center;flex:none;
}
.c-ico svg{width:20px;height:20px}
.c-item .k{font-family:var(--mono);font-size:.65rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:.3rem}
.c-item a,.c-item .v{color:var(--ivory);font-size:1rem;transition:color .3s;display:block;line-height:1.5}
.c-item a:hover{color:var(--gold)}

.contact-form{background:var(--paper);padding:3rem;border:1px solid var(--line)}
.contact-form h3{margin-bottom:.6rem;font-size:2rem}
.contact-form .intro{color:var(--slate);margin-bottom:2rem;font-size:.95rem}
.field{margin-bottom:1.2rem;position:relative}
.field label{
  display:block;font-family:var(--mono);font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);margin-bottom:.6rem;
}
.field input,.field textarea,.field select{
  width:100%;padding:.95rem 0;border:none;border-bottom:1px solid var(--line);
  font-family:var(--sans);font-size:1rem;color:var(--ink);background:transparent;
  transition:border-color .3s var(--ease);outline:none;
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--gold-deep)}
.field textarea{resize:vertical;min-height:120px}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.form-btn{width:100%;margin-top:1rem;padding:1.1rem;background:var(--ink);color:var(--ivory);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;transition:all .4s var(--ease)}
.form-btn:hover{background:var(--saffron-deep);transform:translateY(-2px)}
@media (max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:1rem}
  .contact-info,.contact-form{padding:2rem}
  .row-2{grid-template-columns:1fr}
}

/* ---------- CTA BAND ---------- */
.cta-band{
  padding:5rem 0;
  background:linear-gradient(135deg,var(--ink) 0%,var(--charcoal) 100%);
  color:var(--ivory);position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;top:50%;right:-10%;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,169,97,.12),transparent 70%);transform:translateY(-50%);
}
.cta-band .wrap{display:grid;grid-template-columns:1.4fr .6fr;gap:3rem;align-items:center;position:relative;z-index:1}
.cta-band h2{color:var(--ivory);margin-bottom:1rem;max-width:16ch}
.cta-band p{color:rgba(255,255,255,.7);max-width:520px}
.cta-band .ctab{display:flex;justify-content:flex-end}
@media (max-width:800px){.cta-band .wrap{grid-template-columns:1fr}.cta-band .ctab{justify-content:flex-start}}

/* ---------- FOOTER ---------- */
footer{background:#07080b;color:rgba(255,255,255,.7);padding:5rem 0 2rem;position:relative;overflow:hidden}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.foot-top{display:grid;grid-template-columns:1.4fr .7fr .7fr 1.2fr;gap:3rem;margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand .brand{color:var(--ivory);margin-bottom:1.2rem}
.foot-brand .brand-text .sub{color:rgba(255,255,255,.5)}
.foot-brand p{color:rgba(255,255,255,.55);font-size:.9rem;line-height:1.7;max-width:300px;margin-bottom:1.4rem}
.foot-col h5{color:var(--ivory);font-family:var(--mono);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;margin-bottom:1.2rem;font-weight:600}
.foot-col ul li{margin-bottom:.7rem}
.foot-col ul li a{font-size:.88rem;color:rgba(255,255,255,.55);transition:color .3s,padding .3s}
.foot-col ul li a:hover{color:var(--gold);padding-left:4px}
.foot-contact a{display:block;color:rgba(255,255,255,.75);margin-bottom:.5rem;font-size:.9rem;transition:color .3s}
.foot-contact a:hover{color:var(--gold)}
.foot-contact .k{font-family:var(--mono);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:1rem;margin-bottom:.4rem}
.foot-contact .k:first-child{margin-top:0}
.socials{display:flex;gap:.7rem;margin-top:1.4rem}
.socials a{
  width:38px;height:38px;border:1px solid rgba(255,255,255,.15);border-radius:50%;
  display:grid;place-items:center;color:rgba(255,255,255,.65);
  transition:all .3s var(--ease);
}
.socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink);transform:translateY(-2px)}
.socials svg{width:15px;height:15px}

.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:rgba(255,255,255,.42);letter-spacing:.06em}
.foot-bottom a{color:var(--gold-soft)}
.foot-bottom a:hover{color:var(--gold)}
.foot-credit{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}
@media (max-width:900px){.foot-top{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:560px){.foot-top{grid-template-columns:1fr}.foot-bottom{flex-direction:column;text-align:center}}

/* ---------- REVEAL ANIMATION ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}
.reveal.d4{transition-delay:.4s}
.reveal.d5{transition-delay:.5s}

/* ---------- UTILITIES ---------- */
.mt-xl{margin-top:4rem}
.text-center{text-align:center}
.divider{height:1px;background:var(--line);margin:5rem 0}
.kicker{font-family:var(--display);font-style:italic;color:var(--gold-deep);font-size:1.2rem}

/* Preloader */
.preload{
  position:fixed;inset:0;z-index:300;background:var(--ink);color:var(--ivory);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .6s var(--ease),visibility .6s;
}
.preload.hide{opacity:0;visibility:hidden}
.preload .ring{width:44px;height:44px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--gold);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Smoothness tweak */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
}
