/* ===================================================================
   RMG ENTERPRISSES — Earth Mover, Housing & Land Developers
   Aesthetic: Peacock green + antique gold (Lord Murugan inspired)
   Fonts: Fraunces (display) + Catamaran (body / Tamil)
   =================================================================== */

/* ---------- Design Tokens ---------- */
:root{
  --green-950:#052420;
  --green-900:#06302c;
  --green-800:#0a463f;
  --green-700:#0d5c54;   /* peacock green — primary */
  --green-600:#127a6e;
  --green-500:#199b8a;

  --gold-600:#a67c2e;
  --gold-500:#c9a24b;    /* antique gold — accent */
  --gold-400:#d8b863;
  --gold-300:#ecd9a4;

  --peacock:#15708a;     /* peacock blue */
  --rust:#b23b2e;        /* RMG logo red */

  --cream:#f7f2e8;
  --cream-2:#efe6d4;
  --paper:#fffdf8;
  --ink:#1b2422;
  --ink-soft:#3c4a47;
  --muted:#6c7b77;

  --shadow-sm:0 2px 10px rgba(6,48,44,.08);
  --shadow-md:0 14px 40px -12px rgba(6,48,44,.28);
  --shadow-lg:0 30px 70px -20px rgba(6,48,44,.45);

  --r-sm:10px;
  --r-md:18px;
  --r-lg:28px;

  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --ff-display:"Fraunces",Georgia,serif;
  --ff-body:"Catamaran","Segoe UI",sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
section{position:relative}

/* subtle paper grain on the whole page */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:600;line-height:1.08;color:var(--green-900)}
h1{font-size:clamp(2.6rem,6vw,5rem);letter-spacing:-.01em}
h2{font-size:clamp(2rem,4.2vw,3.3rem);letter-spacing:-.01em}
h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
p{color:var(--ink-soft)}
.tamil{font-family:var(--ff-body);font-weight:600}

.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px);position:relative;z-index:1}

/* Eyebrow / kicker */
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-600);
}
.kicker::before{content:"";width:30px;height:2px;background:var(--gold-500)}
.kicker.center{justify-content:center}
.kicker.light{color:var(--gold-400)}

.section{padding:clamp(70px,9vw,130px) 0}
.section-head{max-width:640px;margin-bottom:clamp(36px,5vw,64px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head p{margin-top:18px;font-size:1.08rem}

/* gold rule divider with vel motif */
.vel-divider{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--gold-500);margin:0 auto}
.vel-divider::before,.vel-divider::after{content:"";height:1px;width:60px;background:linear-gradient(90deg,transparent,var(--gold-500))}
.vel-divider::after{background:linear-gradient(90deg,var(--gold-500),transparent)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;border-radius:999px;font-weight:700;font-size:.95rem;
  letter-spacing:.01em;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--green-700);color:#fff;box-shadow:0 12px 28px -10px rgba(13,92,84,.7)}
.btn-primary:hover{transform:translateY(-3px);background:var(--green-800);box-shadow:0 20px 36px -12px rgba(13,92,84,.8)}
.btn-gold{background:linear-gradient(135deg,var(--gold-400),var(--gold-600));color:var(--green-950)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 34px -12px rgba(166,124,46,.7)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.45);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-3px)}
.btn-outline{border:1.5px solid var(--green-700);color:var(--green-800)}
.btn-outline:hover{background:var(--green-700);color:#fff;transform:translateY(-3px)}

/* ===================================================================
   HEADER
   =================================================================== */
.topbar{
  background:var(--green-950);color:var(--gold-300);
  font-size:.82rem;letter-spacing:.04em;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:38px;padding-block:6px}
.topbar .blessing{display:flex;align-items:center;gap:9px;font-weight:600}
.topbar .blessing .om{color:var(--gold-500);font-size:1rem}
.topbar .tb-right{display:flex;gap:20px;align-items:center}
.topbar a{display:inline-flex;gap:7px;align-items:center;transition:color .25s}
.topbar a:hover{color:#fff}
.topbar svg{width:14px;height:14px;opacity:.85}

header.site{
  position:sticky;top:0;z-index:100;
  background:rgba(247,242,232,.86);backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(166,124,46,.18);
  transition:padding .35s var(--ease),box-shadow .35s var(--ease),background .35s;
}
header.site.scrolled{box-shadow:var(--shadow-sm);background:rgba(247,242,232,.96)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0;transition:padding .35s var(--ease)}
header.site.scrolled .nav{padding:9px 0}

/* logo */
.logo{display:flex;align-items:center;gap:13px}
.logo .mark{width:52px;height:52px;flex:0 0 auto;transition:transform .4s var(--ease)}
.logo:hover .mark{transform:rotate(-4deg) scale(1.05)}
/* Murugan image as brand mark — circular with gold ring */
.logo img.mark{
  border-radius:50%;object-fit:cover;object-position:center top;
  border:2.5px solid var(--gold-500);
  box-shadow:0 4px 14px -3px rgba(6,48,44,.45),0 0 0 4px rgba(201,162,75,.12);
  background:var(--green-700);
}
footer.site .logo img.mark{border-color:var(--gold-400)}
.logo .txt{line-height:1}
.logo .txt .name{font-family:var(--ff-display);font-weight:700;font-size:1.35rem;color:var(--green-800);letter-spacing:.02em}
.logo .txt .name b{color:var(--rust)}
.logo .txt .sub{display:block;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-600);font-weight:700;margin-top:3px}

.menu{display:flex;align-items:center;gap:6px}
.menu a{
  position:relative;padding:9px 15px;font-weight:600;font-size:.95rem;color:var(--ink-soft);
  border-radius:999px;transition:color .25s;
}
.menu a::after{
  content:"";position:absolute;left:15px;right:15px;bottom:4px;height:2px;
  background:var(--gold-500);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);
}
.menu a:hover,.menu a.active{color:var(--green-800)}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}

.nav-cta{display:flex;align-items:center;gap:12px}

/* language switch */
.lang-switch{display:inline-flex;align-items:center;border:1.5px solid rgba(166,124,46,.45);border-radius:999px;overflow:hidden;background:rgba(255,253,248,.7)}
.lang-btn{padding:7px 13px;font-family:var(--ff-body);font-weight:800;font-size:.8rem;line-height:1;color:var(--ink-soft);transition:background .25s,color .25s}
.lang-btn+.lang-btn{border-left:1.5px solid rgba(166,124,46,.3)}
.lang-btn.active{background:var(--green-700);color:#fff}
.lang-btn:not(.active):hover{background:rgba(13,92,84,.1)}
body.lang-ta{font-size:16.5px}
body.lang-ta h1,body.lang-ta h2,body.lang-ta h3,body.lang-ta h4{font-family:var(--ff-body);font-weight:800;line-height:1.26;font-style:normal}
body.lang-ta .hero h1 .accent{font-style:normal}
body.lang-ta .hero h1,body.lang-ta h1{letter-spacing:0}
/* Tamil text must NOT use wide letter-spacing or uppercase (it breaks conjuncts) */
body.lang-ta .kicker,
body.lang-ta .hero-stats .l,
body.lang-ta .stats-grid .l,
body.lang-ta .proj .ov .tag,
body.lang-ta .person .role,
body.lang-ta .info-row .l,
body.lang-ta .marquee .track,
body.lang-ta .topbar{
  letter-spacing:normal;
  text-transform:none;
}
body.lang-ta .kicker{font-weight:700}
body.lang-ta .hero-stats .l,
body.lang-ta .stats-grid .l{font-size:.92rem}
.burger{display:none;width:46px;height:46px;border-radius:12px;background:var(--green-700);position:relative}
.burger span{position:absolute;left:12px;right:12px;height:2.5px;background:#fff;border-radius:2px;transition:.3s var(--ease)}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:22px}
.burger span:nth-child(3){top:28px}
body.nav-open .burger span:nth-child(1){top:22px;transform:rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){top:22px;transform:rotate(-45deg)}

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  background:
    radial-gradient(120% 120% at 85% 0%,rgba(21,112,138,.45),transparent 55%),
    radial-gradient(90% 90% at 10% 100%,rgba(18,122,110,.5),transparent 60%),
    linear-gradient(160deg,var(--green-900),var(--green-800) 55%,var(--green-950));
  color:#fff;overflow:hidden;
  padding:clamp(70px,12vw,150px) 0 clamp(80px,12vw,140px);
}
.hero .container{display:grid;grid-template-columns:1.15fr .85fr;gap:50px;align-items:center}
.hero-copy{position:relative;z-index:3}
.hero h1{color:#fff;margin:18px 0 0}
.hero h1 .accent{
  color:transparent;background:linear-gradient(120deg,var(--gold-400),var(--gold-300));
  -webkit-background-clip:text;background-clip:text;font-style:italic;
}
.hero .lead{margin:26px 0 34px;font-size:1.18rem;color:rgba(255,255,255,.82);max-width:34ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}

/* hero stats */
.hero-stats{display:flex;gap:30px;margin-top:46px;flex-wrap:wrap}
.hero-stats .stat .n{font-family:var(--ff-display);font-size:2.1rem;color:var(--gold-400);font-weight:600;line-height:1}
.hero-stats .stat .l{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:6px}

/* hero art — peacock feather + earth mover scene */
.hero-art{position:relative;z-index:2;min-height:380px}
/* Vel (divine spear) animated centerpiece */
.hero-art .vel-scene{position:absolute;right:0;top:-40px;width:100%;max-width:460px;height:auto;overflow:visible}
.hero-art .vel-scene .vel{animation:velFloat 6s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
@keyframes velFloat{0%,100%{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-14px) rotate(1.5deg)}}
.hero-art .vel-scene .glow{animation:velGlow 4.5s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
@keyframes velGlow{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:.95;transform:scale(1.1)}}
.hero-art .vel-scene .rays{transform-box:fill-box;transform-origin:center}
.hero-art .vel-scene .r1{animation:raySpin 44s linear infinite}
.hero-art .vel-scene .r2{animation:raySpinR 34s linear infinite}
@keyframes raySpin{to{transform:rotate(360deg)}}
@keyframes raySpinR{to{transform:rotate(-360deg)}}
.hero-art .vel-scene .spark{transform-box:fill-box;transform-origin:center;animation:velSpark 3.2s ease-in-out infinite}
.hero-art .vel-scene .s1{animation-delay:0s}
.hero-art .vel-scene .s2{animation-delay:.8s}
.hero-art .vel-scene .s3{animation-delay:1.5s}
.hero-art .vel-scene .s4{animation-delay:2.1s}
@keyframes velSpark{0%,100%{opacity:0;transform:translateY(6px) scale(.5)}50%{opacity:1;transform:translateY(-8px) scale(1.1)}}
.hero-art .card{
  position:absolute;background:rgba(255,253,248,.96);color:var(--ink);
  border-radius:var(--r-md);padding:18px 22px;box-shadow:var(--shadow-lg);
  display:flex;gap:14px;align-items:center;backdrop-filter:blur(6px);
}
.hero-art .card .ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--green-700);color:var(--gold-300);flex:0 0 auto}
.hero-art .card .ico svg{width:24px;height:24px}
.hero-art .card b{font-family:var(--ff-display);font-size:1.05rem;color:var(--green-800);display:block}
.hero-art .card small{color:var(--muted);font-weight:600}
.hero-art .card.c1{top:18%;left:-6%;animation:float 5s ease-in-out infinite}
.hero-art .card.c2{bottom:8%;right:-2%;animation:float 5s ease-in-out infinite .8s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* curved bottom edge */
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:70px;
  background:var(--cream);
  -webkit-mask:radial-gradient(120% 70px at 50% 100%,transparent 99%,#000) ;
  mask:radial-gradient(120% 70px at 50% 100%,transparent 99%,#000);
}

/* marquee of services under hero */
.marquee{background:var(--green-950);color:var(--gold-300);overflow:hidden;border-top:1px solid rgba(201,162,75,.2)}
.marquee .track{display:flex;gap:48px;white-space:nowrap;padding:16px 0;animation:scroll 28s linear infinite;font-family:var(--ff-display);font-size:1.15rem;letter-spacing:.02em}
.marquee .track span{display:inline-flex;align-items:center;gap:48px}
.marquee .track span::after{content:"✦";color:var(--gold-500)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===================================================================
   FEATURE / SERVICE CARDS
   =================================================================== */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:26px}
.card-service{
  background:var(--paper);border:1px solid rgba(166,124,46,.16);border-radius:var(--r-lg);
  padding:34px 30px;position:relative;overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s;
}
.card-service::before{
  content:"";position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity .45s;
  background:linear-gradient(160deg,rgba(13,92,84,.05),rgba(201,162,75,.08));
}
.card-service:hover{transform:translateY(-10px);box-shadow:var(--shadow-md);border-color:rgba(201,162,75,.5)}
.card-service:hover::before{opacity:1}
.card-service .ico{
  width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin-bottom:22px;
  background:linear-gradient(150deg,var(--green-700),var(--green-900));color:var(--gold-300);
  box-shadow:0 12px 24px -10px rgba(13,92,84,.6);position:relative;z-index:1;
}
.card-service .ico svg{width:32px;height:32px}
.card-service h3{position:relative;z-index:1;margin-bottom:10px}
.card-service p{position:relative;z-index:1;font-size:.98rem}
.card-service .more{position:relative;z-index:1;display:inline-flex;gap:7px;align-items:center;margin-top:18px;font-weight:700;color:var(--gold-600);font-size:.9rem;letter-spacing:.03em}
.card-service .more svg{width:16px;height:16px;transition:transform .3s}
.card-service:hover .more svg{transform:translateX(5px)}
.card-service .num{position:absolute;top:22px;right:26px;font-family:var(--ff-display);font-size:2.4rem;color:rgba(166,124,46,.16);font-weight:600}

/* ===================================================================
   ABOUT / SPLIT
   =================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.split.reverse .split-media{order:2}
.about-bg{background:var(--paper)}
.split-copy p{margin-top:18px}
.feature-list{margin-top:28px;display:grid;gap:16px}
.feature-list li{display:flex;gap:14px;align-items:flex-start}
.feature-list .tick{
  flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  background:var(--gold-500);color:var(--green-950);margin-top:2px;
}
.feature-list .tick svg{width:16px;height:16px}
.feature-list b{color:var(--green-800);font-family:var(--ff-display);font-weight:600}

/* media block (SVG illustration framed) */
.media-frame{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(160deg,var(--green-800),var(--green-950));
  box-shadow:var(--shadow-lg);aspect-ratio:4/3.4;display:grid;place-items:center;
  border:1px solid rgba(201,162,75,.3);
}
.media-frame .scene{width:100%;height:100%}
.media-frame .badge{
  position:absolute;left:24px;bottom:24px;background:rgba(255,253,248,.95);
  border-radius:14px;padding:14px 20px;box-shadow:var(--shadow-md);
}
.media-frame .badge .n{font-family:var(--ff-display);font-size:1.8rem;color:var(--green-800);font-weight:600;line-height:1}
.media-frame .badge .l{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700}

/* ===================================================================
   STATS STRIP
   =================================================================== */
.stats-strip{background:linear-gradient(135deg,var(--green-900),var(--green-800));color:#fff;overflow:hidden}
.stats-strip::before{
  content:"";position:absolute;inset:0;opacity:.12;
  background-image:radial-gradient(circle at 1px 1px,var(--gold-400) 1px,transparent 0);background-size:26px 26px;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stats-grid .item .n{font-family:var(--ff-display);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--gold-400);font-weight:600;line-height:1}
.stats-grid .item .l{margin-top:10px;font-size:.9rem;letter-spacing:.06em;color:rgba(255,255,255,.78);text-transform:uppercase;font-weight:600}
.stats-grid .item .l .ta{display:block;font-size:.78rem;color:var(--gold-300);text-transform:none;letter-spacing:0;margin-top:3px}

/* ===================================================================
   PROCESS / WHY
   =================================================================== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;counter-reset:step}
.step{position:relative;background:var(--paper);border-radius:var(--r-md);padding:32px 26px 28px;border:1px solid rgba(166,124,46,.16);transition:transform .4s var(--ease)}
.step:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.step .s-num{counter-increment:step;font-family:var(--ff-display);font-size:1.1rem;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:var(--green-700);color:var(--gold-300);margin-bottom:18px}
.step .s-num::before{content:"0" counter(step)}
.step h3{font-size:1.2rem;margin-bottom:8px}
.step p{font-size:.95rem}

/* ===================================================================
   GALLERY / PROJECTS
   =================================================================== */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.proj{
  position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3.2;
  box-shadow:var(--shadow-sm);transition:transform .5s var(--ease),box-shadow .5s var(--ease);
  border:1px solid rgba(166,124,46,.16);
}
.proj:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.proj .scene{position:absolute;inset:0;width:100%;height:100%}
.proj .ov{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;color:#fff;
  background:linear-gradient(to top,rgba(5,36,32,.88),rgba(5,36,32,.15) 55%,transparent);
}
.proj .ov .tag{align-self:flex-start;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--green-950);background:var(--gold-400);padding:5px 12px;border-radius:999px;margin-bottom:auto}
.proj .ov h3{color:#fff;font-size:1.3rem}
.proj .ov p{color:rgba(255,255,255,.82);font-size:.9rem;margin-top:4px}

.note-photos{margin-top:30px;text-align:center;font-size:.9rem;color:var(--muted)}

/* ===================================================================
   TEAM / CONTACT PEOPLE
   =================================================================== */
.people{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px}
.person{
  background:var(--paper);border-radius:var(--r-md);padding:28px 26px;text-align:center;
  border:1px solid rgba(166,124,46,.16);transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.person:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.person .ava{
  width:78px;height:78px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;
  font-family:var(--ff-display);font-size:1.7rem;color:var(--green-950);font-weight:600;
  background:linear-gradient(150deg,var(--gold-300),var(--gold-500));box-shadow:0 10px 22px -10px rgba(166,124,46,.7);
}
.person h3{font-size:1.2rem;margin-bottom:4px}
.person .role{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-600);font-weight:700;margin-bottom:14px}
.person a.phone{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:var(--green-800);padding:9px 18px;border-radius:999px;background:rgba(13,92,84,.07);transition:.3s}
.person a.phone:hover{background:var(--green-700);color:#fff}
.person a.phone svg{width:16px;height:16px}

/* ===================================================================
   CONTACT PAGE
   =================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
.info-card{background:var(--paper);border:1px solid rgba(166,124,46,.16);border-radius:var(--r-lg);padding:clamp(26px,4vw,40px)}
.info-row{display:flex;gap:16px;padding:18px 0;border-bottom:1px dashed rgba(108,123,119,.25)}
.info-row:last-child{border-bottom:none}
.info-row .ico{flex:0 0 auto;width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:var(--green-700);color:var(--gold-300)}
.info-row .ico svg{width:22px;height:22px}
.info-row .l{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}
.info-row .v{font-family:var(--ff-display);font-size:1.12rem;color:var(--green-800);margin-top:2px}
.info-row .v a:hover{color:var(--gold-600)}

form .field{margin-bottom:18px}
form label{display:block;font-weight:700;font-size:.85rem;color:var(--green-800);margin-bottom:7px;letter-spacing:.02em}
form input,form select,form textarea{
  width:100%;padding:14px 16px;border:1.5px solid rgba(108,123,119,.28);border-radius:12px;
  font-family:inherit;font-size:1rem;color:var(--ink);background:var(--paper);transition:border-color .25s,box-shadow .25s;
}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--green-600);box-shadow:0 0 0 4px rgba(18,122,110,.12)}
form textarea{resize:vertical;min-height:120px}
.form-note{font-size:.85rem;color:var(--muted);margin-top:10px}
.form-msg{margin-top:14px;padding:14px 18px;border-radius:12px;font-weight:600;display:none}
.form-msg.show{display:block}
.form-msg.ok{background:rgba(18,122,110,.12);color:var(--green-800)}

.map-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid rgba(166,124,46,.2);line-height:0}
.map-wrap iframe{width:100%;height:420px;border:0;filter:saturate(1.05)}

/* ===================================================================
   PAGE HERO (interior pages)
   =================================================================== */
.page-hero{
  background:
    radial-gradient(100% 120% at 90% 0%,rgba(21,112,138,.4),transparent 55%),
    linear-gradient(160deg,var(--green-900),var(--green-950));
  color:#fff;padding:clamp(70px,11vw,130px) 0 clamp(60px,8vw,90px);overflow:hidden;
}
.page-hero .feather-bg{position:absolute;right:-40px;top:-30px;width:340px;opacity:.16;pointer-events:none}
.page-hero h1{color:#fff;margin-top:14px}
.page-hero p{color:rgba(255,255,255,.8);max-width:60ch;margin-top:16px;font-size:1.1rem}
.crumb{display:flex;gap:8px;align-items:center;font-size:.85rem;color:var(--gold-300);font-weight:600;margin-top:24px}
.crumb a{opacity:.85}.crumb a:hover{opacity:1;color:#fff}

/* ===================================================================
   CTA BANNER
   =================================================================== */
.cta{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:var(--green-950)}
.cta::before{content:"";position:absolute;inset:0;opacity:.18;background-image:radial-gradient(circle at 2px 2px,var(--green-900) 1.5px,transparent 0);background-size:24px 24px}
.cta .container{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-block:clamp(50px,7vw,80px)}
.cta h2{color:var(--green-950);max-width:18ch}
.cta .sub{font-weight:600;color:var(--green-900);margin-top:10px}
.cta .btn-primary{background:var(--green-900)}
.cta .btn-primary:hover{background:var(--green-950)}

/* ===================================================================
   FOOTER
   =================================================================== */
footer.site{background:var(--green-950);color:rgba(255,255,255,.72);padding-top:clamp(60px,8vw,90px);position:relative}
footer.site .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:50px}
footer.site .logo .name{color:#fff}
footer.site .logo .name b{color:var(--gold-400)}
footer.site .f-about{margin-top:18px;font-size:.95rem;line-height:1.7}
footer.site .f-blessing{margin-top:18px;color:var(--gold-400);font-weight:600;display:inline-flex;gap:8px;align-items:center}
footer.site h4{color:#fff;font-family:var(--ff-display);font-size:1.15rem;margin-bottom:18px}
footer.site ul li{margin-bottom:11px}
footer.site ul a{font-size:.95rem;transition:color .25s,padding-left .25s}
footer.site ul a:hover{color:var(--gold-400);padding-left:5px}
footer.site .f-contact li{display:flex;gap:11px;font-size:.95rem;margin-bottom:14px;align-items:flex-start}
footer.site .f-contact svg{width:17px;height:17px;color:var(--gold-400);flex:0 0 auto;margin-top:3px}
footer.site .f-contact a:hover{color:var(--gold-400)}
footer.site .bottom{border-top:1px solid rgba(255,255,255,.12);padding:24px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.85rem}
footer.site .bottom .made{color:var(--gold-400)}

/* floating call button (mobile) */
.fab{
  position:fixed;right:18px;bottom:18px;z-index:90;width:60px;height:60px;border-radius:50%;
  background:var(--green-700);color:#fff;display:none;place-items:center;box-shadow:var(--shadow-lg);
  animation:pulse 2.2s infinite;
}
.fab svg{width:26px;height:26px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(18,122,110,.5)}70%{box-shadow:0 0 0 16px rgba(18,122,110,0)}100%{box-shadow:0 0 0 0 rgba(18,122,110,0)}}

/* ===================================================================
   SCROLL REVEAL
   =================================================================== */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:980px){
  .hero .container{grid-template-columns:1fr;gap:30px}
  .hero-art{min-height:300px;margin-top:20px}
  .split{grid-template-columns:1fr;gap:36px}
  .split.reverse .split-media{order:0}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:36px 20px}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  footer.site .top{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .topbar .tb-right .tb-hide{display:none}
  .menu{
    position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:var(--green-900);
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:6px;
    padding:90px 24px 30px;transform:translateX(105%);transition:transform .4s var(--ease);
    z-index:99;box-shadow:var(--shadow-lg);
  }
  body.nav-open .menu{transform:translateX(0)}
  .menu a{color:rgba(255,255,255,.85);padding:14px 16px;border-radius:12px;font-size:1.05rem}
  .menu a::after{display:none}
  .menu a:hover,.menu a.active{background:rgba(255,255,255,.08);color:#fff}
  .burger{display:block}
  .nav-cta .btn{display:none}
  .fab{display:grid}
  .nav-overlay{position:fixed;inset:0;background:rgba(5,36,32,.5);opacity:0;visibility:hidden;transition:.35s;z-index:98}
  body.nav-open .nav-overlay{opacity:1;visibility:visible}
}
@media (max-width:480px){
  body{font-size:16px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:30px 16px}
  footer.site .top{grid-template-columns:1fr}
  .hero-stats{gap:22px}
  .cta .container{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  [data-reveal]{opacity:1;transform:none}
}
