/*
Theme Name: Arora Constructions
Theme URI: https://arorabuilds.in
Author: Shubh Narula
Author URI: https://arorabuilds.in
Description: Custom one-page theme for Arora Constructions, a pan-India construction company. Built as a single static landing page with scroll-reveal animations, animated stats, and a lead enquiry form.
Version: 1.0
Requires at least: 5.0
Requires PHP: 7.2
Text Domain: arora-constructions
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#0d1117;
  --ink-mid:#1c2535;
  --navy:#1e2a6e;
  --navy-glow:#2a3a8a;
  --gold:#c49a28;
  --gold-pale:#e8c96a;
  --gold-dim:rgba(196,154,40,0.18);
  --stone:#f5f1eb;
  --stone-dark:#ede8df;
  --white:#ffffff;
  --text:#1a1a1a;
  --muted:#74737a;
  --border:rgba(196,154,40,0.2);
  --glass:rgba(255,255,255,0.04);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',sans-serif;background:var(--ink);color:var(--white);overflow-x:hidden}
::selection{background:var(--gold);color:var(--ink)}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}

/* ─── CURSOR DOT ─── */
.cursor{position:fixed;width:8px;height:8px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.1s;mix-blend-mode:difference}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(196,154,40,0.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all 0.18s ease}

/* ─── NAV ─── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:0 3.5rem;
  height:72px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(13,17,23,0.72);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:background 0.3s;
}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-logo img{height:44px;width:44px;object-fit:contain;filter:brightness(0) invert(1);transition:filter 0.3s}
.nav-logo-words{display:flex;flex-direction:column;gap:1px}
.nav-logo-name{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--white);letter-spacing:0.04em;line-height:1}
.nav-logo-tag{font-size:9px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);line-height:1}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{color:rgba(255,255,255,0.55);text-decoration:none;font-size:12px;font-weight:500;letter-spacing:0.07em;text-transform:uppercase;transition:color 0.25s;position:relative;padding-bottom:2px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width 0.3s}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-phone{color:var(--gold);font-size:12.5px;font-weight:600;text-decoration:none;letter-spacing:0.04em;font-family:'DM Mono',monospace}
.nav-cta{background:transparent;color:var(--gold);border:1px solid var(--gold);padding:9px 22px;font-size:11.5px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;cursor:pointer;text-decoration:none;transition:all 0.25s;display:inline-block}
.nav-cta:hover{background:var(--gold);color:var(--ink)}

/* ─── HERO ─── */
.hero{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  padding:9rem 3.5rem 5rem;
  position:relative;
  overflow:hidden;
  background:var(--ink);
}
/* Architectural grid lines in background */
.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(196,154,40,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(196,154,40,0.04) 1px, transparent 1px);
  background-size:80px 80px;
  pointer-events:none;
}
/* Glowing orb */
.hero::after{
  content:'';
  position:absolute;
  top:-120px;right:-80px;
  width:600px;height:600px;
  background:radial-gradient(circle, rgba(30,42,110,0.6) 0%, transparent 70%);
  pointer-events:none;
}
.hero-left{position:relative;z-index:2}
.hero-kicker{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--gold-dim);
  border:1px solid var(--border);
  border-radius:2px;
  padding:6px 16px;
  margin-bottom:1.75rem;
  font-size:10.5px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-pale);
}
.hero-kicker::before{content:'';width:6px;height:6px;background:var(--gold);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.4)}}
.hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(48px,5.5vw,76px);
  font-weight:300;
  line-height:1.04;
  letter-spacing:-0.01em;
  margin-bottom:0.5rem;
  color:var(--white);
}
.hero h1 .line-gold{
  display:block;
  font-style:italic;
  color:transparent;
  -webkit-text-stroke:1px var(--gold);
  font-weight:300;
}
.hero-divider{width:56px;height:1px;background:var(--gold);margin:1.5rem 0}
.hero-sub{
  font-size:15px;font-weight:300;line-height:1.85;
  color:rgba(255,255,255,0.5);
  max-width:400px;margin-bottom:2.5rem;
}
.hero-sub strong{color:rgba(255,255,255,0.85);font-weight:500}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.btn-gold{
  background:var(--gold);color:var(--ink);
  padding:15px 34px;font-size:12px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  border:none;cursor:pointer;text-decoration:none;display:inline-block;
  transition:all 0.25s;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);
}
.btn-gold:hover{background:var(--gold-pale);transform:translateY(-1px)}
.btn-ghost{
  background:transparent;color:rgba(255,255,255,0.7);
  padding:14px 28px;font-size:12px;font-weight:500;
  letter-spacing:0.07em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,0.2);cursor:pointer;text-decoration:none;display:inline-block;
  transition:all 0.25s;
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.hero-right{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center}
/* Geometric logo frame */
.logo-frame{
  position:relative;width:320px;height:320px;
  display:flex;align-items:center;justify-content:center;
}
.logo-frame::before{
  content:'';position:absolute;inset:0;
  border:1px solid var(--border);
  transform:rotate(12deg);
  transition:transform 8s linear infinite;
  animation:spin-slow 20s linear infinite;
}
.logo-frame::after{
  content:'';position:absolute;inset:20px;
  border:1px solid rgba(196,154,40,0.1);
  transform:rotate(-12deg);
  animation:spin-slow-rev 25s linear infinite;
}
@keyframes spin-slow{to{transform:rotate(372deg)}}
@keyframes spin-slow-rev{to{transform:rotate(-372deg)}}
.hero-logo-img{width:200px;height:200px;object-fit:contain;filter:brightness(0) invert(1);position:relative;z-index:1;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-tagline-pill{
  margin-top:2rem;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:15px;
  color:var(--gold-pale);
  letter-spacing:0.04em;
  text-align:center;
  opacity:0.8;
}
/* India map dots ticker */
.india-ticker{
  margin-top:1.5rem;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;
}
.city-dot{
  font-size:9.5px;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(255,255,255,0.35);
  display:flex;align-items:center;gap:4px;
}
.city-dot::before{content:'';width:4px;height:4px;background:var(--gold);border-radius:50%;opacity:0.6}

/* ─── MARQUEE STRIP ─── */
.marquee-strip{
  background:var(--gold);
  padding:12px 0;overflow:hidden;
  border-top:1px solid rgba(255,255,255,0.1);
}
.marquee-inner{display:flex;gap:0;animation:marquee 28s linear infinite;white-space:nowrap;width:max-content}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{
  padding:0 2.5rem;
  font-size:10.5px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink);
  display:flex;align-items:center;gap:1.5rem;
}
.marquee-sep{color:rgba(13,17,23,0.35)}

/* ─── STATS ─── */
.stats-sec{
  padding:5rem 3.5rem;
  background:var(--ink-mid);
  border-bottom:1px solid var(--border);
}
.stats-inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-block{text-align:center;padding:2rem 1.5rem;position:relative}
.stat-block+.stat-block::before{content:'';position:absolute;left:0;top:25%;bottom:25%;width:1px;background:var(--border)}
.stat-number{font-family:'Cormorant Garamond',serif;font-size:64px;font-weight:300;color:var(--white);line-height:1;letter-spacing:-0.02em}
.stat-number span{color:var(--gold);font-size:40px;vertical-align:super}
.stat-label{font-size:10px;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* ─── SECTION UTIL ─── */
.sec{padding:6rem 3.5rem}
.sec-inner{max-width:1000px;margin:0 auto}
.kicker{display:flex;align-items:center;gap:10px;font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.kicker::after{content:'';flex:1;max-width:40px;height:1px;background:var(--gold)}
.sec-h{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,3.5vw,50px);font-weight:300;line-height:1.1;letter-spacing:-0.01em}
.sec-sub{font-size:14.5px;font-weight:300;line-height:1.85;color:rgba(255,255,255,0.45);max-width:500px;margin-top:0.75rem}
/* light sections */
.sec-light{background:var(--stone)}
.sec-light .sec-h{color:var(--ink)}
.sec-light .sec-sub{color:var(--muted)}
.sec-light .kicker{color:var(--navy)}
.sec-light .kicker::after{background:var(--navy)}

/* ─── ABOUT ─── */
.about-bg{background:var(--ink-mid)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-top:3rem}
.about-visual{position:relative}
.about-box{
  background:var(--ink);
  border:1px solid var(--border);
  aspect-ratio:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  position:relative;overflow:hidden;
}
.about-box::before{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.about-box-logo{width:110px;object-fit:contain;filter:brightness(0) invert(1)}
.about-box-sub{font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.3)}
/* corner accents */
.about-box .c{position:absolute;width:16px;height:16px;border-color:var(--gold);border-style:solid;border-width:0}
.about-box .c.tl{top:12px;left:12px;border-top-width:1px;border-left-width:1px}
.about-box .c.tr{top:12px;right:12px;border-top-width:1px;border-right-width:1px}
.about-box .c.bl{bottom:12px;left:12px;border-bottom-width:1px;border-left-width:1px}
.about-box .c.br{bottom:12px;right:12px;border-bottom-width:1px;border-right-width:1px}
.about-years-badge{
  position:absolute;bottom:-20px;right:-20px;
  width:100px;height:100px;
  background:var(--gold);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:2;
}
.about-years-badge .num{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:600;color:var(--ink);line-height:1}
.about-years-badge .lbl{font-size:8px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(13,17,23,0.6)}
.about-text p{font-size:15px;font-weight:300;line-height:1.9;color:rgba(255,255,255,0.55);margin-bottom:1rem}
.about-text p strong{color:rgba(255,255,255,0.9);font-weight:500}
.founder-strip{
  margin-top:2rem;
  padding:1.25rem 1.5rem;
  background:var(--gold-dim);
  border:1px solid var(--border);
  display:flex;align-items:center;gap:14px;
}
.f-avatar{
  width:50px;height:50px;min-width:50px;
  background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--ink);
}
.f-name{font-size:14px;font-weight:600;color:var(--white)}
.f-role{font-size:11px;color:var(--gold);letter-spacing:0.06em;margin-top:2px}

/* ─── SERVICES ─── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:3rem}
.svc{
  background:var(--ink-mid);
  padding:2.25rem 2rem;
  position:relative;overflow:hidden;
  transition:background 0.3s;
}
.svc:hover{background:var(--ink)}
.svc::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:2px;
  background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.4s ease;
}
.svc:hover::after{transform:scaleX(1)}
.svc-num{
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--gold);letter-spacing:0.12em;
  margin-bottom:1.25rem;opacity:0.7;
}
.svc-icon{font-size:26px;margin-bottom:1rem}
.svc h3{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--white);margin-bottom:0.6rem;line-height:1.2}
.svc p{font-size:13px;font-weight:300;color:rgba(255,255,255,0.45);line-height:1.75}

/* ─── INDIA COVERAGE ─── */
.india-sec{background:var(--ink);padding:6rem 3.5rem}
.india-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:center;margin-top:3rem}
.india-text .sec-sub{margin-bottom:2rem}
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:1.5rem}
.city-chip{
  background:var(--glass);
  border:1px solid var(--border);
  padding:8px 12px;
  font-size:11.5px;font-weight:500;
  color:rgba(255,255,255,0.6);
  letter-spacing:0.04em;
  transition:all 0.2s;
  text-align:center;
}
.city-chip:hover{background:var(--gold-dim);color:var(--gold-pale);border-color:var(--gold)}
.india-map-wrap{
  background:var(--ink-mid);
  border:1px solid var(--border);
  border-radius:0;
  padding:1rem;
  position:relative;
}
.india-map-svg{width:100%;height:auto;display:block}
/* Animated dots on map */
.map-dot{fill:var(--gold);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1;r:5}50%{opacity:0.3;r:3}}

/* ─── PROCESS ─── */
.process-sec{background:var(--stone)}
.process-row{display:grid;grid-template-columns:repeat(5,1fr);margin-top:4rem;position:relative}
.process-row::before{content:'';position:absolute;top:30px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--navy) 20%,var(--navy) 80%,transparent)}
.p-step{text-align:center;position:relative;z-index:1;padding:0 1rem}
.p-circle{
  width:60px;height:60px;
  background:var(--white);
  border:1.5px solid var(--navy);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.25rem;
  font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--navy);
  position:relative;z-index:1;
  transition:all 0.3s;
}
.p-step:hover .p-circle{background:var(--navy);color:white}
.p-step h4{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:5px}
.p-step p{font-size:11.5px;color:var(--muted);line-height:1.6}

/* ─── PROJECTS ─── */
.projects-sec{background:var(--ink)}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:3rem}
.proj{background:var(--ink-mid);position:relative;overflow:hidden;cursor:pointer}
.proj:hover .proj-overlay{opacity:1}
.proj-visual{
  height:180px;display:flex;align-items:center;justify-content:center;
  font-size:48px;position:relative;
  background:linear-gradient(135deg,var(--ink-mid),var(--ink));
}
.proj-overlay{
  position:absolute;inset:0;background:rgba(196,154,40,0.9);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity 0.3s;
  font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);
}
.proj-badge-top{
  position:absolute;top:12px;left:12px;
  background:var(--ink);color:var(--gold);
  font-size:9.5px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  padding:3px 10px;
}
.proj-body{padding:1.5rem 1.75rem}
.proj-type{font-size:9.5px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold);margin-bottom:0.5rem}
.proj h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:400;color:var(--white);margin-bottom:4px;line-height:1.2}
.proj-loc{font-size:12px;color:rgba(255,255,255,0.4);margin-bottom:0.75rem}
.proj-pills{display:flex;gap:6px;flex-wrap:wrap}
.proj-pill{font-size:10px;color:rgba(255,255,255,0.4);background:var(--glass);border:1px solid rgba(255,255,255,0.08);padding:2px 8px}

/* ─── TESTIMONIALS ─── */
.testi-sec{background:var(--stone)}
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:3rem}
.testi{
  background:var(--white);
  padding:2rem 2rem 1.5rem;
  border-top:3px solid var(--navy);
  position:relative;
}
.testi-stars{color:var(--gold);font-size:13px;margin-bottom:1rem;letter-spacing:2px}
.testi p{
  font-family:'Cormorant Garamond',serif;
  font-size:17px;font-style:italic;font-weight:300;
  color:var(--ink-mid);line-height:1.75;margin-bottom:1.5rem;
}
.testi-foot{display:flex;align-items:center;gap:12px}
.testi-av{
  width:40px;height:40px;min-width:40px;
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:14px;color:white;
}
.testi-name{font-size:13.5px;font-weight:600;color:var(--ink)}
.testi-city{font-size:11px;color:var(--muted)}

/* ─── CONTACT ─── */
.contact-sec{background:var(--ink-mid)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;margin-top:3rem;align-items:start}
.contact-items{display:flex;flex-direction:column;gap:1.75rem}
.c-item{display:flex;gap:16px;align-items:flex-start}
.c-icon{
  width:44px;height:44px;min-width:44px;
  background:var(--gold-dim);
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.c-label{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.c-val{font-size:14.5px;color:rgba(255,255,255,0.75);line-height:1.55}
.c-val a{color:rgba(255,255,255,0.75);text-decoration:none}
.c-val a:hover{color:var(--gold)}
.hours-box{
  margin-top:2rem;
  padding:1.25rem 1.5rem;
  background:var(--gold-dim);border:1px solid var(--border);
}
.hours-box h4{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.hours-box p{font-size:13.5px;color:rgba(255,255,255,0.6);line-height:1.7}
.map-box{border:1px solid var(--border);overflow:hidden}
.map-box iframe{width:100%;height:300px;border:none;display:block;filter:grayscale(30%)}
.map-footer{background:var(--ink);padding:10px 14px;font-size:11.5px;color:rgba(255,255,255,0.4);display:flex;align-items:center;gap:8px}

/* ─── CTA BAND ─── */
.cta-band{
  background:linear-gradient(135deg,var(--navy-glow),var(--navy));
  padding:6rem 3.5rem;text-align:center;position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(196,154,40,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(196,154,40,0.05) 1px,transparent 1px);
  background-size:60px 60px;
}
.cta-band::after{
  content:'"Excellence in Every Square Foot"';
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(60px,10vw,140px);font-weight:300;font-style:italic;
  color:rgba(255,255,255,0.03);
  position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);
  white-space:nowrap;pointer-events:none;
  letter-spacing:-0.02em;
}
.cta-inner{position:relative;z-index:2}
.cta-band h2{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,4vw,54px);font-weight:300;color:white;margin-bottom:0.75rem}
.cta-band p{font-size:15px;font-weight:300;color:rgba(255,255,255,0.6);margin-bottom:2.5rem}
.cta-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;max-width:700px;margin:0 auto}
.cta-form input,.cta-form textarea{
  padding:14px 18px;border:1px solid rgba(255,255,255,0.15);
  background:rgba(255,255,255,0.07);color:white;
  font-size:13.5px;font-family:'DM Sans',sans-serif;
  outline:none;transition:border-color 0.25s;
}
.cta-form input::placeholder,.cta-form textarea::placeholder{color:rgba(255,255,255,0.35)}
.cta-form input:focus,.cta-form textarea:focus{border-color:var(--gold)}
.cta-form input.f-name,.cta-form input.f-phone{flex:1;min-width:180px}
.cta-form textarea{width:100%;height:80px;resize:none}
.cta-submit{
  background:var(--gold);color:var(--ink);
  padding:14px 36px;border:none;cursor:pointer;
  font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);
  transition:all 0.25s;
  width:100%;
}
.cta-submit:hover{background:var(--gold-pale)}

/* ─── FOOTER ─── */
footer{background:var(--ink);border-top:1px solid var(--border);padding:4rem 3.5rem 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;max-width:1000px;margin:0 auto 3rem}
.f-brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:1.25rem}
.f-brand-logo img{width:40px;height:40px;object-fit:contain;filter:brightness(0) invert(1)}
.f-brand-logo-words .f-brand-name{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:600;color:white}
.f-brand-logo-words .f-brand-tag{font-size:9px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold)}
.f-brand p{font-size:12.5px;font-weight:300;line-height:1.8;color:rgba(255,255,255,0.38);margin-bottom:1.25rem}
.f-socials{display:flex;gap:8px}
.f-social{
  width:34px;height:34px;
  border:1px solid rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.4);font-size:13px;text-decoration:none;
  transition:all 0.2s;
}
.f-social:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.f-col h5{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:1.1rem}
.f-col ul{list-style:none}
.f-col ul li{margin-bottom:0.55rem}
.f-col ul a{font-size:13px;font-weight:300;color:rgba(255,255,255,0.45);text-decoration:none;transition:color 0.2s}
.f-col ul a:hover{color:var(--gold)}
.footer-bottom{
  max-width:1000px;margin:0 auto;
  padding-top:2rem;border-top:1px solid rgba(255,255,255,0.06);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
}
.footer-bottom p{font-size:11.5px;color:rgba(255,255,255,0.25)}
.f-badges{display:flex;gap:8px}
.f-badge{
  border:1px solid rgba(196,154,40,0.25);
  padding:3px 11px;font-size:10px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;
  color:rgba(196,154,40,0.6);
}

/* ─── SCROLL REVEAL ─── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:none}

/* ─── TOAST ─── */
.toast{
  position:fixed;bottom:2rem;right:2rem;z-index:1000;
  background:var(--gold);color:var(--ink);
  padding:14px 24px;font-size:13px;font-weight:700;
  transform:translateY(80px);opacity:0;
  transition:all 0.4s;
}
.toast.show{transform:none;opacity:1}
