/* =========================================================
   KKSN — Kalyanika Kendriya Shiksha Niketan
   Design tokens: forest greens of Amarkantak's sal woods,
   a saffron-gold heritage accent, and a tech-blue accent
   reserved for the Innovation / Robotics programme.
   ========================================================= */

:root{
  --bg:            #FAF6EC;
  --bg-soft:       #F1ECDB;
  --ink:           #182620;
  --ink-soft:      #4B5A50;
  --forest:        #0E3B2E;
  --forest-deep:   #0A2A21;
  --emerald:       #1F7A53;
  --emerald-light: #2E9C6B;
  --gold:          #D89A3A;
  --gold-light:    #F0C77E;
  --sky:           #2F6FED;
  --sky-light:     #6E9BFF;
  --white:         #FFFFFF;
  --line:          rgba(14,59,46,0.14);

  --font-display:  "Fraunces", "Georgia", serif;
  --font-body:     "Plus Jakarta Sans", "Segoe UI", sans-serif;
  --font-mono:     "JetBrains Mono", monospace;

  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --container: 1200px;
  --shadow-soft: 0 20px 50px -25px rgba(14,42,33,0.35);
  --shadow-deep: 0 30px 70px -30px rgba(10,30,24,0.45);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--font-display); margin:0 0 .5em; color:var(--forest-deep); line-height:1.15; font-weight:600; }
p{ margin:0 0 1em; }
.container{ max-width:var(--container); margin:0 auto; padding:0 24px; }
section{ position:relative; }

::selection{ background:var(--gold-light); color:var(--forest-deep); }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:3px solid var(--sky);
  outline-offset:2px;
  border-radius:6px;
}

/* ---------- Eyebrow / labels ---------- */
.eyebrow{
  font-family:var(--font-mono);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:12.5px;
  color:var(--emerald);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
  font-weight:600;
}
.eyebrow::before{
  content:"";
  width:22px;height:2px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.light{ color:var(--gold-light); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 26px;
  border-radius:999px;
  font-weight:600;
  font-size:15px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--gold); color:var(--forest-deep); }
.btn-primary:hover{ background:var(--gold-light); transform:translateY(-2px); box-shadow:0 14px 30px -10px rgba(216,154,58,0.5); }
.btn-outline{ background:transparent; border-color:rgba(255,255,255,0.55); color:#fff; }
.btn-outline:hover{ background:rgba(255,255,255,0.12); border-color:#fff; transform:translateY(-2px); }
.btn-dark{ background:var(--forest); color:#fff; }
.btn-dark:hover{ background:var(--forest-deep); transform:translateY(-2px); }
.btn-sky{ background:var(--sky); color:#fff; }
.btn-sky:hover{ background:#1f57c9; transform:translateY(-2px); }
.btn-sm{ padding:10px 18px; font-size:13.5px; }

/* =========================================================
   HEADER
   ========================================================= */
.topbar{
  background:var(--forest-deep);
  color:#cfe3d8;
  font-size:13px;
  font-family:var(--font-mono);
}
.topbar .container{
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 24px; flex-wrap:wrap; gap:8px;
}
.topbar a{ color:#cfe3d8; }
.topbar .topbar-links{ display:flex; gap:18px; align-items:center; }
.topbar .topbar-links span{ opacity:.55; }
.topbar .social-row{ display:flex; gap:14px; }
.topbar .social-row a{ opacity:.85; transition:opacity .2s; }
.topbar .social-row a:hover{ opacity:1; color:var(--gold-light); }

.site-header{
  position:sticky; top:0; z-index:500;
  background:rgba(250,246,236,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{
  width:50px;height:50px;border-radius:14px;
  background:linear-gradient(145deg,var(--emerald),var(--forest-deep));
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-light); font-family:var(--font-display); font-weight:700; font-size:20px;
  box-shadow:var(--shadow-soft);
  flex-shrink:0;
}
.brand-text h2{ font-size:17px; margin:0; line-height:1.2; letter-spacing:.01em;}
.brand-text span{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:var(--ink-soft); text-transform:uppercase; }

.main-nav{ display:flex; align-items:center; gap:4px; }
.main-nav > ul{ display:flex; align-items:center; gap:2px; }
.main-nav > ul > li{ position:relative; }
.main-nav > ul > li > a{
  display:flex; align-items:center; gap:5px;
  padding:10px 14px; font-weight:600; font-size:14.5px; color:var(--forest-deep);
  border-radius:999px; transition:background .2s, color .2s;
}
.main-nav > ul > li > a:hover, .main-nav > ul > li.active > a{ background:var(--forest); color:#fff; }
.main-nav .caret{ width:9px; height:9px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg); margin-top:-4px; opacity:.65;}

.dropdown{
  position:absolute; top:calc(100% + 10px); left:0; min-width:240px;
  background:#fff; border-radius:var(--radius-sm); box-shadow:var(--shadow-deep);
  padding:10px; opacity:0; visibility:hidden; transform:translateY(8px);
  transition:opacity .2s, transform .2s, visibility .2s;
  border:1px solid var(--line);
}
.main-nav li:hover .dropdown{ opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a{ display:block; padding:9px 14px; border-radius:8px; font-size:14px; color:var(--ink-soft); font-weight:500; }
.dropdown a:hover{ background:var(--bg-soft); color:var(--forest-deep); }

.nav-cta{ display:flex; align-items:center; gap:10px; }
.burger{ display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:8px; }
.burger span{ width:24px; height:2.5px; background:var(--forest-deep); border-radius:2px; transition:.25s; }

@media (max-width:1080px){
  .main-nav{ position:fixed; inset:0; top:0; background:var(--forest-deep); flex-direction:column;
    padding:90px 28px 40px; transform:translateX(100%); transition:transform .35s ease; overflow-y:auto; }
  .main-nav.open{ transform:translateX(0); }
  .main-nav > ul{ flex-direction:column; align-items:stretch; width:100%; gap:4px; }
  .main-nav > ul > li > a{ color:#fff; padding:14px 6px; border-radius:8px; justify-content:space-between; }
  .main-nav > ul > li > a:hover{ background:rgba(255,255,255,0.08); }
  .dropdown{ position:static; opacity:1; visibility:visible; transform:none; background:rgba(255,255,255,0.05); box-shadow:none; display:none; margin:4px 0 8px; }
  .main-nav li.dd-open .dropdown{ display:block; }
  .dropdown a{ color:#cfe3d8; }
  .dropdown a:hover{ background:rgba(255,255,255,0.08); color:#fff; }
  .burger{ display:flex; }
  .nav-cta .btn-dark{ display:none; }
  .topbar .topbar-links span:first-child{ display:none; }
}

/* =========================================================
   HERO SLIDER
   ========================================================= */
.hero{
  position:relative; height:92vh; min-height:600px; overflow:hidden;
  background:var(--forest-deep);
}
.hero-slides{ position:absolute; inset:0; }
.hero-slide{
  position:absolute; inset:0; opacity:0; transition:opacity 1.4s ease;
  background-size:cover; background-position:center;
}
.hero-slide.active{ opacity:1; }
.hero-slide::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,30,24,.55) 0%, rgba(10,30,24,.45) 40%, rgba(8,24,18,.92) 100%);
}
.hero-content{
  position:relative; z-index:5; height:100%;
  display:flex; flex-direction:column; justify-content:center;
  max-width:760px; padding:0 24px; margin:0 auto;
}
.hero-content .eyebrow{ color:var(--gold-light); }
.hero-content h1{
  color:#fff; font-size:clamp(36px,5.6vw,64px); margin-bottom:18px;
}
.hero-content h1 em{ font-style:italic; color:var(--gold-light); }
.hero-content p{ color:#e7eee9; font-size:18px; max-width:540px; margin-bottom:30px;}
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }

.hero-dots{
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%); z-index:6;
  display:flex; gap:9px;
}
.hero-dots button{
  width:10px;height:10px;border-radius:50%; border:1.5px solid rgba(255,255,255,.7);
  background:transparent; cursor:pointer; padding:0; transition:.25s;
}
.hero-dots button.active{ background:var(--gold); border-color:var(--gold); width:28px; border-radius:6px; }

.hero-arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:6;
  width:48px; height:48px; border-radius:50%; border:1.5px solid rgba(255,255,255,.4);
  background:rgba(255,255,255,0.06); color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center; font-size:18px;
  transition:.25s; backdrop-filter:blur(4px);
}
.hero-arrow:hover{ background:var(--gold); color:var(--forest-deep); border-color:var(--gold); }
.hero-arrow.prev{ left:24px; } .hero-arrow.next{ right:24px; }
@media (max-width:680px){ .hero-arrow{ display:none; } }

.hero-badge{
  position:absolute; right:5%; bottom:14%; z-index:6;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(10px); border-radius:18px; padding:14px 18px;
  display:flex; align-items:center; gap:12px; color:#fff;
  max-width:230px;
}
.hero-badge svg{ width:42px;height:42px; flex-shrink:0; }
.hero-badge strong{ display:block; font-size:13px; }
.hero-badge span{ font-size:11.5px; color:#cfe3d8; }
@media (max-width:900px){ .hero-badge{ display:none; } }

/* ---------- ticker / news strip ---------- */
.ticker{
  background:var(--gold); color:var(--forest-deep);
  display:flex; align-items:center; overflow:hidden; white-space:nowrap;
  font-weight:600; font-size:14px;
}
.ticker .ticker-label{
  background:var(--forest-deep); color:var(--gold-light); padding:12px 22px;
  font-family:var(--font-mono); font-size:12.5px; letter-spacing:.12em; text-transform:uppercase;
  flex-shrink:0; display:flex; align-items:center; gap:8px;
}
.ticker-track{ display:flex; gap:60px; padding:12px 0; animation:tick 28s linear infinite; }
.ticker:hover .ticker-track{ animation-play-state:paused; }
.ticker-track span{ display:flex; gap:60px; }
@keyframes tick{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* =========================================================
   SECTION HEADINGS / GENERIC
   ========================================================= */
.section{ padding:96px 0; }
.section.tight{ padding:64px 0; }
.section-head{ max-width:680px; margin-bottom:48px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head h2{ font-size:clamp(28px,3.4vw,42px); }
.section-head p{ color:var(--ink-soft); font-size:17px; }

.bg-forest{ background:var(--forest-deep); color:#e7eee9; }
.bg-forest h2, .bg-forest h3, .bg-forest h4{ color:#fff; }
.bg-forest .section-head p{ color:#bcd0c5; }
.bg-soft{ background:var(--bg-soft); }

/* river divider */
.river-divider{ display:block; width:100%; height:60px; margin-top:-1px; }

/* =========================================================
   WELCOME / SPLIT
   ========================================================= */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media (max-width:900px){ .split{ grid-template-columns:1fr; gap:36px; } }
.split-media{ position:relative; }
.split-media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-deep); width:100%; height:420px; object-fit:cover; }
.split-media .float-card{
  position:absolute; bottom:-26px; left:-26px; background:#fff; border-radius:var(--radius-md);
  padding:18px 22px; box-shadow:var(--shadow-soft); display:flex; align-items:center; gap:14px;
  border:1px solid var(--line); max-width:230px;
}
@media (max-width:560px){ .split-media .float-card{ left:10px; bottom:-20px; padding:14px 16px;} }
.float-card .num{ font-family:var(--font-display); font-size:26px; color:var(--emerald); font-weight:700; }
.float-card small{ display:block; font-size:12px; color:var(--ink-soft); }

/* =========================================================
   FEATURE / VALUE CARDS
   ========================================================= */
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px; }
@media (max-width:980px){ .grid-4{ grid-template-columns:repeat(2,1fr); } .grid-3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .grid-4, .grid-3, .grid-2{ grid-template-columns:1fr; } }

.feature-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-md);
  padding:30px 26px; transition:transform .3s ease, box-shadow .3s ease, border-color .3s;
}
.feature-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-soft); border-color:transparent; }
.feature-icon{
  width:54px; height:54px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:var(--bg-soft); color:var(--emerald); margin-bottom:18px;
}
.feature-icon svg{ width:28px; height:28px; }
.feature-card h3{ font-size:18.5px; margin-bottom:8px; }
.feature-card p{ color:var(--ink-soft); font-size:14.8px; margin-bottom:0; }

/* =========================================================
   STATS
   ========================================================= */
.stats-bar{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
@media (max-width:760px){ .stats-bar{ grid-template-columns:repeat(2,1fr); } }
.stat{ text-align:center; padding:20px 10px; border-left:1px solid rgba(255,255,255,0.15); }
.stat:first-child{ border-left:none; }
@media (max-width:760px){ .stat{ border-left:none; border-top:1px solid rgba(255,255,255,0.15); } .stat:nth-child(1),.stat:nth-child(2){ border-top:none; } }
.stat .num{ font-family:var(--font-display); font-size:44px; color:var(--gold-light); font-weight:700; }
.stat .label{ font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:#bcd0c5; margin-top:6px; }

/* =========================================================
   ROBOTICS / STEM SPOTLIGHT (signature section)
   ========================================================= */
.stem-section{
  background:linear-gradient(160deg,#0E2C3D 0%, #0A2A21 60%);
  color:#e8eef5; overflow:hidden; position:relative;
}
.stem-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:50px; align-items:center; }
@media (max-width:900px){ .stem-grid{ grid-template-columns:1fr; } }
.stem-section .eyebrow{ color:var(--sky-light); }
.stem-section .eyebrow::before{ background:var(--sky-light); }
.stem-section h2{ color:#fff; }
.stem-section p{ color:#c3d2e0; }
.stem-list{ display:flex; flex-direction:column; gap:14px; margin-top:24px; }
.stem-list li{ display:flex; gap:12px; align-items:flex-start; font-size:15px; color:#dbe5ef; }
.stem-list svg{ width:20px; height:20px; flex-shrink:0; margin-top:2px; color:var(--sky-light); }
.bot-stage{ position:relative; display:flex; justify-content:center; }
.bot-stage svg{ width:100%; max-width:340px; filter:drop-shadow(0 30px 40px rgba(0,0,0,.45)); }
.bot-orbit{
  position:absolute; inset:0; border:1px dashed rgba(110,155,255,.3); border-radius:50%;
  width:380px; height:380px; margin:auto; animation:spin 18s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.bot-dot{ position:absolute; width:8px; height:8px; border-radius:50%; background:var(--gold-light); top:0; left:50%; margin-left:-4px; box-shadow:0 0 14px var(--gold-light); }

/* =========================================================
   TESTIMONIAL / QUOTE
   ========================================================= */
.quote-block{
  background:var(--bg-soft); border-radius:var(--radius-lg); padding:56px;
  display:grid; grid-template-columns:auto 1fr; gap:36px; align-items:center;
}
@media (max-width:760px){ .quote-block{ grid-template-columns:1fr; padding:34px 24px; text-align:center;} }
.quote-block img{ width:140px; height:140px; border-radius:50%; object-fit:cover; border:6px solid #fff; box-shadow:var(--shadow-soft); margin:0 auto; }
.quote-block blockquote{ font-family:var(--font-display); font-size:clamp(19px,2.2vw,25px); color:var(--forest-deep); margin:0 0 14px; font-weight:500; }
.quote-block cite{ font-family:var(--font-mono); font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--emerald); }

/* =========================================================
   CARD: LEADER / STAFF
   ========================================================= */
.people-card{ text-align:center; background:#fff; border:1px solid var(--line); border-radius:var(--radius-md); overflow:hidden; transition:.3s; }
.people-card:hover{ box-shadow:var(--shadow-soft); transform:translateY(-6px); }
.people-card img{ width:100%; height:240px; object-fit:cover; }
.people-card .body{ padding:20px; }
.people-card h4{ font-size:16.5px; margin-bottom:2px; }
.people-card span{ font-size:13px; color:var(--ink-soft); font-family:var(--font-mono); }

/* =========================================================
   CTA banner
   ========================================================= */
.cta-banner{
  background:linear-gradient(120deg,var(--forest) 0%,var(--emerald) 100%);
  border-radius:var(--radius-lg); padding:56px; color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap;
  position:relative; overflow:hidden;
}
.cta-banner h3{ color:#fff; font-size:clamp(22px,2.6vw,32px); max-width:520px; margin-bottom:6px;}
.cta-banner p{ color:#d7e6dd; margin:0; max-width:520px; }

/* =========================================================
   PAGE HEADER (sub-pages)
   ========================================================= */
.page-header{
  background:var(--forest-deep); color:#fff; padding:140px 0 64px; position:relative; overflow:hidden;
}
.page-header::before{
  content:""; position:absolute; inset:0; opacity:.18; background-size:cover; background-position:center;
}
.page-header .container{ position:relative; z-index:2; }
.breadcrumb{ font-family:var(--font-mono); font-size:13px; color:var(--gold-light); display:flex; gap:8px; align-items:center; margin-bottom:14px;}
.breadcrumb a{ color:#cfe3d8; }
.page-header h1{ color:#fff; font-size:clamp(30px,4vw,48px); margin-bottom:10px; }
.page-header p{ color:#cfe3d8; max-width:560px; margin:0; }

/* =========================================================
   TABS (used on About / Academics)
   ========================================================= */
.tabs-nav{ display:flex; gap:8px; flex-wrap:wrap; border-bottom:1px solid var(--line); margin-bottom:40px; }
.tabs-nav button{
  background:none; border:none; padding:14px 18px; font-weight:600; font-size:14.5px; color:var(--ink-soft);
  cursor:pointer; border-bottom:2.5px solid transparent; font-family:var(--font-body);
}
.tabs-nav button.active{ color:var(--forest-deep); border-color:var(--gold); }
.tab-panel{ display:none; animation:fade .4s ease; }
.tab-panel.active{ display:block; }
@keyframes fade{ from{ opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;} }

/* =========================================================
   TIMELINE (history)
   ========================================================= */
.timeline{ position:relative; padding-left:36px; border-left:2px solid var(--line); }
.timeline-item{ position:relative; padding-bottom:36px; }
.timeline-item:last-child{ padding-bottom:0; }
.timeline-item::before{
  content:""; position:absolute; left:-44px; top:2px; width:16px; height:16px; border-radius:50%;
  background:var(--gold); border:3px solid var(--bg);
}
.timeline-item h4{ margin-bottom:4px; font-size:17px;}
.timeline-item span{ font-family:var(--font-mono); font-size:12px; color:var(--emerald); text-transform:uppercase; letter-spacing:.08em;}
.timeline-item p{ color:var(--ink-soft); margin-top:6px; font-size:15px; }

/* =========================================================
   TABLE (fee / academic)
   ========================================================= */
.data-table{ width:100%; border-collapse:collapse; background:#fff; border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-soft); }
.data-table th, .data-table td{ padding:14px 18px; text-align:left; border-bottom:1px solid var(--line); font-size:14.5px; }
.data-table th{ background:var(--forest-deep); color:#fff; font-family:var(--font-mono); font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; }
.data-table tr:last-child td{ border-bottom:none; }
.data-table tr:nth-child(even) td{ background:var(--bg-soft); }
.table-wrap{ overflow-x:auto; }
.note-box{
  background:#FFF7E8; border:1px solid var(--gold-light); border-radius:var(--radius-sm);
  padding:16px 20px; font-size:14px; color:#7a5414; margin-top:18px; display:flex; gap:10px;
}

/* =========================================================
   GALLERY
   ========================================================= */
.gallery-filters{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:36px; }
.gallery-filters button{
  border:1.5px solid var(--line); background:#fff; padding:9px 18px; border-radius:999px;
  font-size:13.5px; font-weight:600; cursor:pointer; color:var(--ink-soft); transition:.2s;
}
.gallery-filters button.active, .gallery-filters button:hover{ background:var(--forest-deep); color:#fff; border-color:var(--forest-deep); }

.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:980px){ .gallery-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:680px){ .gallery-grid{ grid-template-columns:repeat(2,1fr); } }
.gallery-item{
  position:relative; border-radius:var(--radius-sm); overflow:hidden; cursor:zoom-in;
  aspect-ratio:1/1; background:var(--bg-soft);
}
.gallery-item img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gallery-item:hover img{ transform:scale(1.08); }
.gallery-item .tag{
  position:absolute; bottom:10px; left:10px; background:rgba(10,30,24,.7); color:#fff;
  font-size:11px; padding:5px 10px; border-radius:999px; font-family:var(--font-mono); letter-spacing:.04em;
  opacity:0; transform:translateY(6px); transition:.25s;
}
.gallery-item:hover .tag{ opacity:1; transform:none; }
.gallery-item::after{
  content:"⤢"; position:absolute; top:10px; right:10px; width:30px;height:30px; border-radius:50%;
  background:rgba(255,255,255,.85); color:var(--forest-deep); display:flex; align-items:center; justify-content:center;
  font-size:14px; opacity:0; transition:.25s;
}
.gallery-item:hover::after{ opacity:1; }

/* lightbox */
.lightbox{
  position:fixed; inset:0; background:rgba(8,20,16,0.94); z-index:1000;
  display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden;
  transition:opacity .3s ease, visibility .3s ease; padding:30px;
}
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox-stage{ position:relative; max-width:92vw; max-height:86vh; overflow:hidden; cursor:zoom-in; border-radius:8px; }
.lightbox-stage img{ max-width:92vw; max-height:86vh; object-fit:contain; transition:transform .3s ease; transform-origin:center; cursor:zoom-in; }
.lightbox-stage.zoomed img{ cursor:grab; transform:scale(2); }
.lightbox-close, .lightbox-nav{
  position:absolute; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.3); color:#fff;
  border-radius:50%; width:46px; height:46px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:18px; transition:.2s; backdrop-filter:blur(6px);
}
.lightbox-close:hover, .lightbox-nav:hover{ background:var(--gold); color:var(--forest-deep); border-color:var(--gold); }
.lightbox-close{ top:24px; right:24px; }
.lightbox-nav.prev{ left:24px; top:50%; transform:translateY(-50%); }
.lightbox-nav.next{ right:24px; top:50%; transform:translateY(-50%); }
.lightbox-caption{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); color:#cfe3d8; font-family:var(--font-mono); font-size:12.5px; letter-spacing:.06em; }
.lightbox-hint{ position:absolute; top:24px; left:24px; color:#cfe3d8; font-size:12px; font-family:var(--font-mono); opacity:.7; }
@media (max-width:680px){ .lightbox-nav, .lightbox-hint{ display:none; } }

/* =========================================================
   FORMS
   ========================================================= */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:640px){ .form-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:6px; }
.field.full{ grid-column:1/-1; }
.field label{ font-size:13px; font-weight:600; color:var(--forest-deep); }
.field input, .field select, .field textarea{
  padding:13px 16px; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  font-family:var(--font-body); font-size:14.5px; background:#fff; color:var(--ink);
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--emerald); outline:none; }
.form-card{ background:#fff; border-radius:var(--radius-lg); padding:40px; box-shadow:var(--shadow-soft); border:1px solid var(--line); }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--forest-deep); color:#cfe3d8; padding:80px 0 0; }
.footer-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1.3fr; gap:40px; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,0.1); }
@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-grid h4{ color:#fff; font-size:15px; margin-bottom:18px; font-family:var(--font-body); letter-spacing:.03em; }
.footer-grid li{ margin-bottom:11px; font-size:14.5px; }
.footer-grid a:hover{ color:var(--gold-light); }
.footer-brand p{ color:#a9c0b3; font-size:14.5px; max-width:300px; }
.footer-social{ display:flex; gap:10px; margin-top:18px; }
.footer-social a{
  width:38px;height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.25);
  display:flex; align-items:center; justify-content:center; transition:.2s;
}
.footer-social a:hover{ background:var(--gold); color:var(--forest-deep); border-color:var(--gold); }
.footer-bottom{ display:flex; justify-content:space-between; padding:22px 0; font-size:13px; color:#8aa498; flex-wrap:wrap; gap:10px; }
.footer-bottom a{ color:#8aa498; }
.footer-bottom a:hover{ color:#fff; }

/* utility */
.mt-0{margin-top:0;} .mb-0{margin-bottom:0;}
.text-center{text-align:center;}
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
