/* =========================================================================
   KASHI ON WEB — DIGITAL KASHI CARD
   style.css

   Design tokens live at the top under :root. Change colors/type there —
   every component below references the variables, nothing is hard-coded.
   ========================================================================= */

:root{
  /* ---- Palette, drawn from the KOW brand mark ---- */
  --navy:        #16305C;
  --navy-deep:   #0D1F3D;
  --navy-light:  #2C4E8A;
  --gold:        #D99A3D;
  --gold-light:  #F0C878;
  --gold-deep:   #B87A22;
  --rust:        #A6421F;
  --rust-light:  #C7623E;
  --cream:       #F5EDDB;
  --cream-deep:  #EADFC2;
  --white:       #FFFFFF;
  --ink:         #2B2116;
  --ink-soft:    #6B5A47;
  --whatsapp:    #25D366;

  /* ---- Surfaces (swap in dark mode) ---- */
  --bg: var(--cream);
  --bg-alt: var(--cream-deep);
  --surface: #FFFFFF;
  --text: var(--ink);
  --text-soft: var(--ink-soft);
  --border: rgba(43,33,22,0.12);
  --glass-bg: rgba(255,255,255,0.55);
  --glass-border: rgba(255,255,255,0.35);

  /* ---- Type ---- */
  --font-display: 'Marcellus', 'Georgia', serif;
  --font-body: 'Poppins', -apple-system, sans-serif;
  --font-devanagari: 'Noto Serif Devanagari', serif;

  /* ---- Misc ---- */
  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --shadow-sm: 0 4px 14px rgba(22,48,92,0.08);
  --shadow-md: 0 14px 34px rgba(22,48,92,0.14);
  --shadow-gold: 0 10px 26px rgba(217,154,61,0.35);
  --ease: cubic-bezier(.22,1,.36,1);
  --header-h: 76px;
}

[data-theme="dark"]{
  --bg: #0D1B33;
  --bg-alt: #122443;
  --surface: #142A4D;
  --text: #F2E9D6;
  --text-soft: #C7B99D;
  --border: rgba(242,233,214,0.12);
  --glass-bg: rgba(20,42,77,0.55);
  --glass-border: rgba(217,154,61,0.18);
  --cream: #0D1B33;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .4s var(--ease), color .4s var(--ease);
}

h1,h2,h3,h4{ font-family:var(--font-display); color:var(--navy); margin:0 0 .4em; font-weight:400; letter-spacing:.01em; }
[data-theme="dark"] h1,[data-theme="dark"] h2,[data-theme="dark"] h3,[data-theme="dark"] h4{ color:var(--gold-light); }
p{ margin:0 0 1em; color:var(--text-soft); }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
input,select,textarea{ font-family:inherit; font-size:1rem; }
img{ max-width:100%; display:block; }

.section{ max-width:960px; margin:0 auto; padding:64px 22px; position:relative; }
.section-head{ text-align:center; margin-bottom:36px; }
.eyebrow{
  display:inline-block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--rust); font-weight:600; margin-bottom:8px;
}
.section-head h2{ font-size:clamp(1.7rem,4vw,2.4rem); }

.glass{
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border:1px solid var(--glass-border);
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 26px; border-radius:999px; font-weight:600; font-size:.95rem;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  white-space:nowrap;
}
.btn:active{ transform:scale(.96); }
.btn-gold{ background:linear-gradient(135deg,var(--gold-light),var(--gold-deep)); color:var(--navy-deep); box-shadow:var(--shadow-gold); }
.btn-gold:hover{ transform:translateY(-3px); box-shadow:0 16px 34px rgba(217,154,61,.42); }
.btn-whatsapp{ background:var(--whatsapp); color:#fff; box-shadow:0 10px 24px rgba(37,211,102,.35); }
.btn-whatsapp:hover{ transform:translateY(-3px); }
.btn-outline{ border:1.5px solid var(--navy); color:var(--navy); }
[data-theme="dark"] .btn-outline{ border-color:var(--gold-light); color:var(--gold-light); }
.btn-outline:hover{ background:var(--navy); color:#fff; }
.btn-ghost{ color:var(--rust); font-weight:600; }

.icon-btn{
  width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.14); color:inherit; transition:background .2s;
}
.icon-btn:hover{ background:rgba(217,154,61,.25); }

/* =========================================================================
   SPLASH SCREEN — Sanskrit welcome + bell
   ========================================================================= */
.splash{
  position:fixed; inset:0; z-index:999;
  background:radial-gradient(circle at 50% 30%, var(--navy-light), var(--navy-deep) 70%);
  display:flex; align-items:center; justify-content:center; text-align:center;
  transition:opacity .8s var(--ease), visibility .8s var(--ease);
  overflow:hidden;
}
.splash.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.splash-glow{
  position:absolute; width:140vmax; height:140vmax; border-radius:50%;
  background:radial-gradient(circle, rgba(217,154,61,.18), transparent 60%);
  animation:pulse-glow 6s ease-in-out infinite;
}
@keyframes pulse-glow{ 0%,100%{ transform:scale(1); opacity:.7;} 50%{ transform:scale(1.15); opacity:1;} }
.splash-content{ position:relative; z-index:2; padding:20px; animation:splash-in 1.2s var(--ease); }
@keyframes splash-in{ from{ opacity:0; transform:translateY(24px);} to{ opacity:1; transform:none;} }
.splash-om{
  font-family:var(--font-devanagari); font-size:4.4rem; color:var(--gold-light);
  text-shadow:0 0 40px rgba(240,200,120,.6);
  animation:om-breathe 3.2s ease-in-out infinite;
}
@keyframes om-breathe{ 0%,100%{ transform:scale(1); opacity:.9;} 50%{ transform:scale(1.08); opacity:1;} }
.splash-shlok{ font-family:var(--font-devanagari); font-size:1.8rem; color:#fff; margin:6px 0 2px; }
.splash-translit{ color:var(--gold-light); letter-spacing:.08em; font-size:.85rem; text-transform:uppercase; margin-bottom:4px; }
.splash-translation{ color:rgba(255,255,255,.7); font-size:.9rem; max-width:320px; margin:0 auto 26px; }
.splash-btn{ animation:btn-glow 2.4s ease-in-out infinite; }
@keyframes btn-glow{ 0%,100%{ box-shadow:0 0 0 0 rgba(217,154,61,.5);} 50%{ box-shadow:0 0 0 14px rgba(217,154,61,0);} }

/* =========================================================================
   GANGA THREAD — signature scroll-progress element
   ========================================================================= */
.ganga-thread{
  position:fixed; top:0; left:0; width:100%; height:4px; z-index:500;
  background:rgba(217,154,61,.15);
}
.ganga-thread-fill{
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--rust),var(--gold),var(--gold-light));
  transition:width .1s linear;
}
.ganga-boat{
  position:absolute; top:-8px; left:0%; transform:translateX(-50%);
  width:20px; height:20px; border-radius:50%; background:var(--navy);
  color:var(--gold-light); display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.3); transition:left .1s linear;
}

/* =========================================================================
   HEADER
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:400; padding-top:4px;
  background:var(--glass-bg); backdrop-filter:blur(14px) saturate(140%); -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--glass-border);
  transition:background .3s;
}
.header-bar{
  max-width:960px; margin:0 auto; height:var(--header-h);
  display:flex; align-items:center; justify-content:space-between; padding:0 18px;
}
.brand{ display:flex; align-items:center; gap:10px; }
.brand-mark{
  font-family:var(--font-display); font-weight:400; font-size:1.3rem; color:var(--navy);
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  border:2px solid var(--navy); flex-shrink:0;
}
.brand-mark.small{ width:38px; height:38px; font-size:1.05rem; }
.brand-text{ display:flex; flex-direction:column; line-height:1.2; }
.brand-text strong{ font-family:var(--font-display); font-size:1.02rem; color:var(--navy); }
[data-theme="dark"] .brand-text strong{ color:var(--gold-light); }
.brand-text em{ font-style:normal; font-size:.66rem; color:var(--rust); letter-spacing:.04em; }
.header-actions{ display:flex; align-items:center; gap:8px; }
.nav-toggle{ display:none; flex-direction:column; gap:5px; padding:8px; }
.nav-toggle span{ width:20px; height:2px; background:var(--navy); border-radius:2px; transition:.3s; }
[data-theme="dark"] .nav-toggle span{ background:var(--gold-light); }

.site-nav{
  display:flex; justify-content:center; gap:26px; padding:10px 18px 14px;
  font-size:.86rem; font-weight:500; overflow-x:auto;
}
.site-nav a{ color:var(--text-soft); white-space:nowrap; position:relative; padding-bottom:3px; }
.site-nav a:hover{ color:var(--rust); }
.site-nav a::after{ content:''; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--gold); transition:width .25s var(--ease); }
.site-nav a:hover::after{ width:100%; }

@media (max-width:720px){
  .nav-toggle{ display:flex; }
  .site-nav{
    display:none; flex-direction:column; align-items:center; gap:14px; padding:14px 18px 22px;
    background:var(--surface); border-top:1px solid var(--border);
  }
  .site-nav.open{ display:flex; animation:nav-drop .3s var(--ease); }
}
@keyframes nav-drop{ from{ opacity:0; transform:translateY(-8px);} to{ opacity:1; transform:none;} }

/* =========================================================================
   FEATURED VIDEO
   ========================================================================= */
.featured-video{ max-width:960px; margin:18px auto 0; padding:0 18px; }
.fv-frame{
  position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:16/8.5;
  background:linear-gradient(135deg,var(--navy-deep),var(--navy));
  box-shadow:var(--shadow-md); display:flex; align-items:center; justify-content:center;
}
.fv-frame video, .fv-frame iframe{ width:100%; height:100%; object-fit:cover; border:0; }
.fv-placeholder{
  color:#fff; text-align:center; display:flex; flex-direction:column; align-items:center; gap:10px; padding:20px;
  cursor:pointer;
}
.fv-placeholder svg{ background:rgba(217,154,61,.85); border-radius:50%; padding:16px; box-shadow:0 0 0 10px rgba(217,154,61,.15); }
.fv-placeholder p{ color:#fff; font-family:var(--font-display); font-size:1.15rem; margin:0; }
.fv-note{ color:rgba(255,255,255,.55); font-size:.75rem; }

/* =========================================================================
   HERO
   ========================================================================= */
.hero{
  position:relative; text-align:center; padding:56px 20px 70px; overflow:hidden;
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
}
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(circle at 15% 15%, rgba(217,154,61,.25), transparent 45%),
    radial-gradient(circle at 85% 25%, rgba(166,66,31,.18), transparent 45%),
    linear-gradient(180deg, var(--cream-deep), var(--cream));
}
.hero-float{ position:absolute; border-radius:50%; filter:blur(2px); opacity:.5; animation:float-y 7s ease-in-out infinite; }
.f1{ width:70px; height:70px; background:var(--gold-light); top:12%; left:8%; animation-delay:0s; }
.f2{ width:40px; height:40px; background:var(--rust-light); top:60%; right:10%; animation-delay:1.4s; }
.f3{ width:26px; height:26px; background:var(--navy-light); top:20%; right:20%; animation-delay:2.6s; }
@keyframes float-y{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-18px);} }

.hero-content{ position:relative; z-index:1; max-width:560px; margin:0 auto; }
.hero-logo-mark{
  display:inline-flex; align-items:center; justify-content:center;
  width:88px; height:88px; border-radius:50%; font-family:var(--font-display); font-size:2rem;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  border:3px solid var(--navy); color:var(--navy); box-shadow:var(--shadow-gold);
  animation:logo-in .8s var(--ease);
}
@keyframes logo-in{ from{ opacity:0; transform:scale(.6) rotate(-10deg);} to{ opacity:1; transform:none;} }
.hero-title{ font-size:clamp(2.2rem,7vw,3.2rem); margin:22px 0 4px; color:var(--rust); }
.hero-sub{ font-size:1.05rem; color:var(--navy); font-weight:500; margin-bottom:6px; }
[data-theme="dark"] .hero-sub{ color:var(--gold-light); }
.hero-strap{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-soft); margin-bottom:30px; }

.hero-quick-connect{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:22px; }
.qc-btn{
  display:flex; flex-direction:column; align-items:center; gap:6px; padding:14px 20px; border-radius:var(--radius-md);
  background:var(--surface); box-shadow:var(--shadow-sm); font-size:.78rem; font-weight:600; min-width:88px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.qc-btn:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.qc-call svg{ color:var(--navy); }
.qc-whatsapp svg{ color:var(--whatsapp); }
.qc-share svg{ color:var(--rust); }

.hero-social{ display:flex; gap:14px; justify-content:center; }
.hero-social a{
  width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:var(--navy); color:var(--gold-light); transition:transform .25s var(--ease), background .25s;
}
.hero-social a:hover{ transform:translateY(-4px) scale(1.08); background:var(--rust); }

/* =========================================================================
   WHATSAPP CAPTURE
   ========================================================================= */
.wa-capture{ max-width:760px; margin:-34px auto 0; padding:0 20px; position:relative; z-index:2; }
.wa-capture-card{
  border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow-md);
  display:grid; gap:14px; text-align:center;
}
.wa-capture-card svg{ color:var(--whatsapp); margin:0 auto; }
.wa-capture-text h3{ font-size:1.1rem; margin-bottom:2px; }
.wa-capture-text p{ font-size:.86rem; margin:0; }
.wa-form{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.wa-form input{
  flex:1; min-width:180px; padding:13px 16px; border-radius:999px; border:1.5px solid var(--border);
  background:var(--surface); color:var(--text); outline:none; transition:border-color .2s;
}
.wa-form input:focus{ border-color:var(--gold); }
.wa-form-note{ font-size:.78rem; color:var(--whatsapp); font-weight:600; min-height:1em; margin:0; }

/* =========================================================================
   FREE SERVICES
   ========================================================================= */
.services-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.service-card{
  background:var(--surface); border-radius:var(--radius-md); padding:26px 18px; text-align:center;
  box-shadow:var(--shadow-sm); border:1px solid var(--border);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.service-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); border-color:var(--gold); }
.service-icon{
  width:56px; height:56px; margin:0 auto 14px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--gold-light),var(--gold)); color:var(--navy-deep);
}
.service-card h3{ font-size:1.05rem; margin-bottom:6px; }
.service-card p{ font-size:.85rem; margin:0; }
.free-tag{ display:inline-block; margin-top:12px; font-size:.68rem; font-weight:700; letter-spacing:.06em; color:var(--rust); text-transform:uppercase; }

@media (max-width:720px){ .services-grid{ grid-template-columns:1fr; } }

/* =========================================================================
   SPONSORED ADS
   ========================================================================= */
.ads-track-wrap{ overflow:hidden; }
.ads-track{ display:flex; gap:16px; animation:ads-scroll 22s linear infinite; width:max-content; }
.ads-track:hover{ animation-play-state:paused; }
@keyframes ads-scroll{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
.ad-card{
  min-width:240px; padding:18px 20px; border-radius:var(--radius-md); background:linear-gradient(135deg,var(--navy),var(--navy-light));
  color:#fff; box-shadow:var(--shadow-sm);
}
.ad-card span.tag{ font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-light); font-weight:700; }
.ad-card h4{ color:#fff; font-size:1rem; margin:6px 0 2px; }
.ad-card p{ color:rgba(255,255,255,.75); font-size:.8rem; margin:0; }

/* =========================================================================
   ABOUT
   ========================================================================= */
.about-body{ text-align:center; max-width:680px; margin:0 auto 30px; }
.about-mv{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:30px; }
.mv-card{ background:var(--surface); border-radius:var(--radius-md); padding:20px; border-left:4px solid var(--gold); box-shadow:var(--shadow-sm); }
.mv-card h4{ font-size:.95rem; color:var(--rust); margin-bottom:6px; font-family:var(--font-body); font-weight:700; }
.mv-card p{ font-size:.86rem; margin:0; }
.why-us{ background:var(--bg-alt); border-radius:var(--radius-md); padding:22px; margin-bottom:30px; }
.why-us h4{ text-align:center; font-size:.95rem; color:var(--navy); margin-bottom:14px; font-family:var(--font-body); font-weight:700; }
[data-theme="dark"] .why-us h4{ color:var(--gold-light); }
.why-us ul{ display:grid; gap:10px; max-width:460px; margin:0 auto; }
.why-us li{ display:flex; align-items:flex-start; gap:10px; font-size:.88rem; color:var(--text-soft); }
.why-us li::before{ content:'✓'; color:var(--whatsapp); font-weight:700; }

.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; text-align:center; }
.stat-card{ background:var(--surface); border-radius:var(--radius-md); padding:20px 10px; box-shadow:var(--shadow-sm); }
.stat-num{ font-family:var(--font-display); font-size:1.7rem; color:var(--rust); display:block; }
.stat-label{ font-size:.72rem; color:var(--text-soft); text-transform:uppercase; letter-spacing:.05em; }
@media (max-width:720px){ .about-mv,.stats-grid{ grid-template-columns:1fr 1fr; } }

/* =========================================================================
   INSTAGRAM
   ========================================================================= */
.insta-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.insta-tile{
  aspect-ratio:1; border-radius:var(--radius-sm); position:relative; overflow:hidden;
  background:linear-gradient(135deg,var(--rust),var(--gold));
  display:flex; align-items:flex-end; padding:10px; transition:transform .3s var(--ease);
}
.insta-tile:hover{ transform:scale(1.04); }
.insta-tile span{ color:#fff; font-size:.7rem; font-weight:600; text-shadow:0 1px 4px rgba(0,0,0,.4); }
.insta-tile::before{ content:''; position:absolute; inset:0; background:rgba(22,48,92,.15); }
@media (max-width:520px){ .insta-grid{ grid-template-columns:repeat(3,1fr); gap:6px; } }

/* =========================================================================
   REVIEWS
   ========================================================================= */
.reviews-summary{ text-align:center; margin-bottom:28px; }
.rs-score{ font-family:var(--font-display); font-size:2.6rem; color:var(--gold-deep); }
.rs-stars{ color:var(--gold); display:flex; justify-content:center; gap:2px; margin:4px 0; }
.rs-count{ font-size:.82rem; color:var(--text-soft); }
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:26px; }
.review-card{ background:var(--surface); border-radius:var(--radius-md); padding:18px; box-shadow:var(--shadow-sm); }
.review-stars{ color:var(--gold); font-size:.8rem; margin-bottom:8px; }
.review-card p{ font-size:.86rem; margin-bottom:10px; }
.review-name{ font-size:.8rem; font-weight:600; color:var(--navy); }
[data-theme="dark"] .review-name{ color:var(--gold-light); }
.reviews-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
@media (max-width:720px){ .reviews-grid{ grid-template-columns:1fr; } }

/* =========================================================================
   DIRECTION
   ========================================================================= */
.map-frame{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); margin-bottom:20px; }
.map-frame iframe{ width:100%; height:320px; border:0; display:block; }
.direction-btn{ display:flex; width:fit-content; margin:0 auto; }

/* =========================================================================
   DONATIONS
   ========================================================================= */
.donate-card{
  background:linear-gradient(160deg,var(--surface),var(--bg-alt));
  border-radius:var(--radius-lg); padding:32px 22px; text-align:center; max-width:420px; margin:0 auto;
  box-shadow:var(--shadow-md); border:1px solid var(--border);
}
.donate-icon{
  width:60px; height:60px; margin:0 auto 12px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:var(--rust); color:#fff;
}
.donate-body{ font-size:.88rem; }
.donate-qr{ width:170px; height:170px; margin:16px auto; border-radius:var(--radius-sm); background:#fff; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-sm); border:1px dashed var(--border); }
.qr-placeholder{ color:var(--text-soft); font-size:.8rem; }
.upi-row{ display:flex; align-items:center; justify-content:center; gap:8px; font-weight:600; margin-bottom:14px; font-size:.9rem; }
.donate-apps{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-bottom:18px; }
.donate-apps span{ font-size:.68rem; padding:5px 10px; border-radius:999px; background:var(--bg-alt); color:var(--text-soft); }

/* =========================================================================
   VISITOR COUNTER
   ========================================================================= */
.visitor-card{
  max-width:420px; margin:0 auto; display:flex; align-items:center; justify-content:center; gap:26px;
  background:var(--navy); color:#fff; border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow-md);
}
.visitor-stat{ text-align:center; }
.v-num{ display:block; font-family:var(--font-display); font-size:1.9rem; color:var(--gold-light); }
.v-label{ font-size:.68rem; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.65); }
.visitor-divider{ width:1px; height:36px; background:rgba(255,255,255,.2); }

/* =========================================================================
   ENQUIRY FORM
   ========================================================================= */
.enquiry-form{ display:grid; gap:16px; border-radius:var(--radius-lg); padding:28px 22px; box-shadow:var(--shadow-md); }
.field{ display:flex; flex-direction:column; gap:6px; text-align:left; }
.field label{ font-size:.78rem; font-weight:600; color:var(--navy); }
[data-theme="dark"] .field label{ color:var(--gold-light); }
.field input, .field select, .field textarea{
  padding:12px 14px; border-radius:var(--radius-sm); border:1.5px solid var(--border); background:var(--surface); color:var(--text); outline:none;
  transition:border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--gold); }
.field-error{ font-size:.72rem; color:var(--rust); min-height:1em; }
.enquiry-submit{ justify-self:center; margin-top:6px; }
.enquiry-note{ text-align:center; font-size:.82rem; color:var(--whatsapp); font-weight:600; min-height:1em; margin:0; }

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.testi-track-wrap{ overflow:hidden; }
.testi-track{ display:flex; gap:18px; transition:transform .5s var(--ease); }
.testi-card{
  min-width:100%; background:var(--surface); border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow-sm);
  text-align:center;
}
.testi-stars{ color:var(--gold); margin-bottom:10px; }
.testi-card p{ font-size:.95rem; font-style:italic; margin-bottom:14px; }
.testi-name{ font-weight:700; color:var(--navy); font-size:.9rem; }
[data-theme="dark"] .testi-name{ color:var(--gold-light); }
.testi-role{ font-size:.76rem; color:var(--text-soft); }
.testi-dots{ display:flex; justify-content:center; gap:8px; margin-top:16px; }
.testi-dots span{ width:8px; height:8px; border-radius:50%; background:var(--border); cursor:pointer; transition:background .25s, transform .25s; }
.testi-dots span.active{ background:var(--gold); transform:scale(1.3); }

@media (min-width:720px){
  .testi-card{ min-width:calc(50% - 9px); }
}

/* =========================================================================
   PHOTO GALLERY
   ========================================================================= */
.photo-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.photo-tile{
  aspect-ratio:1; border-radius:var(--radius-sm); overflow:hidden; position:relative; cursor:pointer;
  background:linear-gradient(135deg,var(--navy-light),var(--navy));
  display:flex; align-items:center; justify-content:center; transition:transform .3s var(--ease);
}
.photo-tile:hover{ transform:scale(1.04); }
.photo-tile img{ width:100%; height:100%; object-fit:cover; }
.photo-tile .ph-fallback{ color:rgba(255,255,255,.7); text-align:center; padding:8px; }
.photo-tile .ph-fallback span{ display:block; font-size:.62rem; margin-top:6px; }
@media (max-width:520px){ .photo-grid{ gap:6px; } }

/* =========================================================================
   VIDEO GALLERY
   ========================================================================= */
.video-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.video-tile{
  border-radius:var(--radius-md); overflow:hidden; cursor:pointer; box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease);
}
.video-tile:hover{ transform:translateY(-5px); }
.video-thumb{
  aspect-ratio:16/10; background:linear-gradient(135deg,var(--rust),var(--navy)); display:flex; align-items:center; justify-content:center; position:relative;
}
.video-thumb svg{ background:rgba(255,255,255,.9); border-radius:50%; padding:12px; color:var(--rust); }
.video-title{ padding:10px 12px; font-size:.8rem; font-weight:600; background:var(--surface); }
@media (max-width:720px){ .video-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .video-grid{ grid-template-columns:1fr; } }

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{
  background:var(--navy-deep); color:rgba(255,255,255,.8); padding:40px 22px 100px; text-align:center;
}
.footer-brand{ display:flex; align-items:center; gap:12px; justify-content:center; margin-bottom:18px; }
.footer-brand strong{ color:#fff; font-family:var(--font-display); font-size:1.1rem; display:block; }
.footer-brand p{ font-size:.76rem; color:rgba(255,255,255,.55); margin:2px 0 0; max-width:280px; text-align:left; }
.footer-social{ display:flex; gap:12px; justify-content:center; margin-bottom:18px; }
.footer-social a{ width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; color:var(--gold-light); transition:background .2s; }
.footer-social a:hover{ background:var(--rust); }
.footer-copy{ font-size:.74rem; color:rgba(255,255,255,.45); margin:0; }

/* =========================================================================
   STICKY BOTTOM BAR
   ========================================================================= */
.sticky-bar{
  position:fixed; bottom:0; left:0; right:0; z-index:300;
  display:flex; background:var(--surface); box-shadow:0 -6px 24px rgba(0,0,0,.12);
  border-top:1px solid var(--border);
}
.sticky-btn{
  flex:1; display:flex; flex-direction:column; align-items:center; gap:2px; padding:10px 4px;
  font-size:.65rem; font-weight:600; color:var(--text-soft); transition:color .2s, background .2s;
}
.sticky-btn svg{ color:var(--navy); }
.sticky-whatsapp svg{ color:var(--whatsapp); }
.sticky-btn:hover{ background:var(--bg-alt); color:var(--rust); }

/* =========================================================================
   BACK TO TOP
   ========================================================================= */
.back-to-top{
  position:fixed; right:16px; bottom:76px; z-index:290; width:44px; height:44px; border-radius:50%;
  background:var(--navy); color:var(--gold-light); display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-md); opacity:0; transform:translateY(10px) scale(.8); pointer-events:none;
  transition:opacity .3s, transform .3s;
}
.back-to-top.show{ opacity:1; transform:none; pointer-events:auto; }

/* =========================================================================
   CHATBOT
   ========================================================================= */
.chatbot{ position:fixed; right:16px; bottom:130px; z-index:295; }
.chatbot-fab{
  width:56px; height:56px; border-radius:50%; background:linear-gradient(135deg,var(--rust),var(--gold-deep));
  color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-gold);
  animation:fab-bob 3s ease-in-out infinite;
}
@keyframes fab-bob{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-6px);} }
.chatbot-panel{
  position:absolute; bottom:70px; right:0; width:min(320px,86vw); max-height:440px;
  background:var(--surface); border-radius:var(--radius-lg); box-shadow:var(--shadow-md); border:1px solid var(--border);
  display:flex; flex-direction:column; overflow:hidden;
  opacity:0; transform:translateY(16px) scale(.95); pointer-events:none; transition:.3s var(--ease);
}
.chatbot-panel.open{ opacity:1; transform:none; pointer-events:auto; }
.chatbot-head{ background:var(--navy); color:#fff; padding:12px 16px; display:flex; justify-content:space-between; align-items:center; font-weight:600; font-size:.9rem; }
.chatbot-body{ flex:1; overflow-y:auto; padding:14px; display:flex; flex-direction:column; gap:10px; max-height:220px; }
.chat-msg{ padding:9px 13px; border-radius:14px; font-size:.82rem; max-width:85%; line-height:1.4; }
.chat-msg.bot{ background:var(--bg-alt); align-self:flex-start; border-bottom-left-radius:4px; }
.chat-msg.user{ background:var(--gold); color:var(--navy-deep); align-self:flex-end; border-bottom-right-radius:4px; font-weight:600; }
.chatbot-quick{ display:flex; gap:6px; padding:0 12px 10px; flex-wrap:wrap; }
.chatbot-quick button{ font-size:.68rem; padding:6px 10px; border-radius:999px; background:var(--bg-alt); color:var(--text-soft); }
.chatbot-quick button:hover{ background:var(--gold-light); }
.chatbot-input{ display:flex; border-top:1px solid var(--border); }
.chatbot-input input{ flex:1; border:0; padding:12px 14px; background:transparent; color:var(--text); outline:none; }
.chatbot-input button{ padding:0 16px; color:var(--rust); }

/* =========================================================================
   LIGHTBOX + VIDEO MODAL
   ========================================================================= */
.lightbox, .video-modal{
  position:fixed; inset:0; z-index:900; background:rgba(13,27,51,.94);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .3s, visibility .3s;
}
.lightbox.open, .video-modal.open{ opacity:1; visibility:visible; }
.lightbox-content{ max-width:92vw; max-height:80vh; text-align:center; }
.lightbox-content img{ max-width:92vw; max-height:74vh; border-radius:var(--radius-md); margin:0 auto; }
.lightbox-caption{ color:#fff; margin-top:12px; font-size:.9rem; }
.lightbox-close, .video-modal-close{ position:absolute; top:20px; right:20px; color:#fff; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; }
.lightbox-nav{ position:absolute; top:50%; transform:translateY(-50%); color:#fff; font-size:2.4rem; padding:10px 16px; background:rgba(255,255,255,.08); border-radius:12px; }
.lightbox-nav.prev{ left:14px; } .lightbox-nav.next{ right:14px; }
.video-modal-content{ width:min(880px,92vw); aspect-ratio:16/9; border-radius:var(--radius-lg); overflow:hidden; background:var(--navy-deep); display:flex; align-items:center; justify-content:center; }
.video-modal-content iframe, .video-modal-content video{ width:100%; height:100%; border:0; }
.video-modal-placeholder{ color:rgba(255,255,255,.65); text-align:center; padding:20px; font-size:.9rem; }

/* =========================================================================
   TOAST
   ========================================================================= */
.toast{
  position:fixed; left:50%; bottom:96px; transform:translate(-50%,20px); z-index:960;
  background:var(--navy); color:#fff; padding:12px 22px; border-radius:999px; font-size:.85rem; font-weight:600;
  box-shadow:var(--shadow-md); opacity:0; pointer-events:none; transition:.3s var(--ease);
}
.toast.show{ opacity:1; transform:translate(-50%,0); }

/* =========================================================================
   SCROLL REVEAL
   ========================================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* =========================================================================
   RESPONSIVE — small polish
   ========================================================================= */
@media (max-width:480px){
  .section{ padding:48px 16px; }
  .hero{ padding:44px 16px 60px; }
}
