/* ============================================================
   THAAJUDDEEN SCHOOL – Shared Stylesheet + Animations
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --gold:         #F5B800;
  --gold-dark:    #C99200;
  --gold-deeper:  #8A6400;
  --gold-light:   #FFF8E1;
  --olive-nav:    #6b5a00;
  --olive-border: #8a7200;
  --dark:         #2C2000;
  --text:         #1a1200;
  --muted:        #6b5c1a;
  --border:       #e8d87a;
  --border-light: #f5e9a0;
  --bg:           #FFFDF0;
  --white:        #ffffff;
  --radius:       10px;
}

html { scroll-behavior: smooth; }
body { font-family: 'Segoe UI', Arial, sans-serif; color: var(--text); background: var(--bg); line-height: 1.6; overflow-x: hidden; }

/* ============================================================
   KEYFRAME ANIMATIONS
   ============================================================ */
@keyframes fadeUp    { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn    { from { opacity:0; } to { opacity:1; } }
@keyframes scaleIn   { from { opacity:0; transform:scale(0.92); } to { opacity:1; transform:scale(1); } }
@keyframes shimmer   { 0% { background-position:-200% center; } 100% { background-position:200% center; } }
@keyframes float     { 0%,100% { transform:translateY(0) rotate(0deg); } 50% { transform:translateY(-18px) rotate(2deg); } }
@keyframes pulseGold { 0%,100% { box-shadow:0 0 0 0 rgba(245,184,0,.35); } 50% { box-shadow:0 0 0 10px rgba(245,184,0,0); } }
@keyframes slideBar  { from { transform:scaleX(0); } to { transform:scaleX(1); } }
@keyframes countUp   { from { opacity:0; transform:translateY(14px); } to { opacity:1; transform:translateY(0); } }

/* ── SCROLL REVEAL ── */
.reveal        { opacity:0; transform:translateY(28px);  transition:opacity .65s ease, transform .65s ease; }
.reveal-left   { opacity:0; transform:translateX(-36px); transition:opacity .65s ease, transform .65s ease; }
.reveal-right  { opacity:0; transform:translateX(36px);  transition:opacity .65s ease, transform .65s ease; }
.reveal-scale  { opacity:0; transform:scale(.92);        transition:opacity .6s ease,  transform .6s ease;  }
.reveal.visible, .reveal-left.visible, .reveal-right.visible, .reveal-scale.visible { opacity:1; transform:none; }

.stagger > *:nth-child(1) { transition-delay:.05s; }
.stagger > *:nth-child(2) { transition-delay:.15s; }
.stagger > *:nth-child(3) { transition-delay:.25s; }
.stagger > *:nth-child(4) { transition-delay:.35s; }
.stagger > *:nth-child(5) { transition-delay:.45s; }
.stagger > *:nth-child(6) { transition-delay:.55s; }

/* ── TOP BAR ── */
.topbar { background:var(--dark); color:#f5d96b; font-size:13px; padding:6px 0; animation:fadeIn .5s ease; }
.topbar .inner { max-width:1160px; margin:auto; padding:0 24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:6px; }
.topbar a { color:#f5d96b; text-decoration:none; margin-left:16px; transition:color .2s; }
.topbar a:hover { color:#fff; }

/* ── HEADER ── */
header { background:var(--white); box-shadow:0 1px 6px rgba(0,0,0,.08); animation:fadeIn .6s ease; }
.header-inner { max-width:1160px; margin:auto; padding:0 24px; display:flex; align-items:center; height:84px; }
.logo { display:flex; align-items:center; gap:14px; text-decoration:none; }
.logo img { height:64px; width:auto; transition:transform .35s ease; }
.logo:hover img { transform:rotate(-6deg) scale(1.1); }
.logo-text .name { font-size:19px; font-weight:700; color:var(--dark); line-height:1.2; }
.logo-text .sub  { font-size:12px; color:var(--gold-dark); font-style:italic; font-weight:500; }

/* ── NAVBAR ── */
.navbar {
  background: var(--olive-nav);
  border-bottom: 2px solid var(--olive-border);
  position: sticky;
  top: 0;
  z-index: 200;
}

/* Desktop: navbar-top is hidden, nav is a horizontal flex row */
.navbar-top { display: none; }

nav {
  display: flex;
  align-items: center;
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 16px;
}

nav a {
  display: inline-block;
  padding: 13px 22px;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: .7px;
  color: #d4b84a;
  text-decoration: none;
  text-transform: uppercase;
  transition: background .2s, color .2s;
  white-space: nowrap;
  position: relative;
}
nav a::after {
  content: '';
  position: absolute;
  bottom: 6px; left: 22px;
  width: 0; height: 2px;
  background: var(--gold);
  transition: width .25s ease;
}
nav a:hover { color: #f5d96b; }
nav a:hover::after, nav a.active::after { width: calc(100% - 44px); }
nav a.active { color: #f5e070; background: rgba(255,255,255,.06); outline: 1px solid #c9a830; }

/* Hamburger — hidden on desktop */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 6px;
  cursor: pointer;
  padding: 12px 16px;
  margin-left: auto;
}
.hamburger span {
  display: block;
  width: 26px;
  height: 2px;
  background: #d4b84a;
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(6px, 6px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(6px, -6px); }



/* ── ANNOUNCEMENT ── */
.announcement { background:var(--gold); color:var(--dark); padding:9px 24px; text-align:center; font-size:13px; font-weight:500; position:relative; overflow:hidden; }
.announcement::before { content:''; position:absolute; top:0; left:-100%; width:60%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent); animation:shimmer 3s infinite; }
.announcement a { color:var(--dark); font-weight:700; margin-left:8px; text-decoration:underline; transition:opacity .2s; }
.announcement a:hover { opacity:.7; }

/* ── PAGE HERO ── */
.page-hero { background:var(--dark); color:#fff; padding:54px 24px; text-align:center; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%,rgba(245,184,0,.18) 0%,transparent 70%); pointer-events:none; }
.page-hero-inner { position:relative; z-index:1; max-width:760px; margin:auto; animation:fadeUp .8s ease; }
.page-hero .breadcrumb { font-size:12px; color:rgba(255,255,255,.5); margin-bottom:10px; }
.page-hero .breadcrumb a { color:var(--gold); text-decoration:none; }
.page-hero h1 { font-size:clamp(26px,4vw,42px); font-weight:800; color:#fff; line-height:1.15; }
.page-hero h1 em { color:var(--gold); font-style:normal; }
.page-hero p { margin-top:12px; font-size:16px; color:rgba(255,255,255,.75); }

/* ── MOTTO STRIP ── */
.motto-strip { background:var(--gold); padding:12px 24px; text-align:center; position:relative; overflow:hidden; }
.motto-strip::before { content:''; position:absolute; top:0; left:-100%; width:60%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent); animation:shimmer 2.5s infinite; }
.motto-strip .tagline { font-size:14px; font-weight:700; color:var(--dark); letter-spacing:2px; text-transform:uppercase; font-style:italic; position:relative; }

/* ── STATS ── */
.stats { background:var(--white); border-bottom:1px solid var(--border-light); }
.stats-inner { max-width:1160px; margin:auto; padding:0 24px; display:grid; grid-template-columns:repeat(4,1fr); }
.stat { text-align:center; padding:28px 16px; border-right:1px solid var(--border-light); transition:background .3s; }
.stat:hover { background:var(--gold-light); }
.stat:last-child { border-right:none; }
.stat .num { font-size:34px; font-weight:800; color:var(--gold-dark); display:block; }
.stat .label { font-size:13px; color:var(--muted); margin-top:3px; }

/* ── SECTION ── */
section { padding:64px 24px; }
.section-inner { max-width:1160px; margin:auto; }
.section-header { text-align:center; margin-bottom:44px; }
.section-header .tag { display:inline-block; font-size:11px; font-weight:700; color:var(--gold-dark); text-transform:uppercase; letter-spacing:1.5px; background:var(--gold-light); border:1px solid var(--border); border-radius:20px; padding:4px 14px; margin-bottom:12px; }
.section-header h2 { font-size:clamp(22px,3vw,34px); font-weight:800; color:var(--dark); margin-bottom:8px; }
.section-header p { color:var(--muted); max-width:540px; margin:auto; }
.gold-divider { width:52px; height:4px; background:var(--gold); border-radius:2px; margin:12px auto 0; }

/* ── NEWS CARDS ── */
.news-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.news-card { background:var(--white); border-radius:var(--radius); border:1px solid var(--border-light); overflow:hidden; transition:box-shadow .3s, transform .3s; cursor:pointer; }
.news-card:hover { box-shadow:0 14px 40px rgba(245,184,0,.22); transform:translateY(-7px); }
.news-thumb { height:170px; display:flex; align-items:center; justify-content:center; font-size:52px; position:relative; transition:filter .3s; }
.news-card:hover .news-thumb { filter:brightness(1.06); }
.news-thumb.t1 { background:linear-gradient(135deg,#FFF8E1,#FFF0A0); }
.news-thumb.t2 { background:linear-gradient(135deg,#fff8e1,#ffe57f); }
.news-thumb.t3 { background:linear-gradient(135deg,#fffde7,#fff176); }
.news-badge { position:absolute; top:12px; left:12px; background:var(--gold); color:var(--dark); font-size:10px; font-weight:700; padding:3px 10px; border-radius:12px; text-transform:uppercase; }
.news-body { padding:18px 20px; }
.news-body h3 { font-size:15px; font-weight:700; margin-bottom:8px; line-height:1.4; color:var(--dark); }
.news-body p { font-size:13px; color:var(--muted); line-height:1.55; }
.news-meta { font-size:12px; color:#b8970a; margin-top:10px; font-weight:500; }

/* ── QUICK LINKS ── */
.quicklinks { background:var(--dark); }
.ql-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:2px; }
.ql-item { background:rgba(245,184,0,.08); padding:28px 16px; text-align:center; color:#f5d96b; text-decoration:none; transition:background .25s, transform .25s, color .25s; }
.ql-item:hover { background:rgba(245,184,0,.2); color:var(--gold); transform:translateY(-5px); }
.ql-icon { font-size:28px; margin-bottom:10px; display:block; transition:transform .3s; }
.ql-item:hover .ql-icon { transform:scale(1.25) rotate(-8deg); }
.ql-label { font-size:13px; font-weight:600; }

/* ── NOTICE BOARD ── */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.notice-board { background:var(--white); border-radius:var(--radius); border:1px solid var(--border-light); overflow:hidden; }
.board-head { background:var(--dark); color:var(--gold); padding:14px 20px; font-weight:700; font-size:15px; display:flex; align-items:center; gap:9px; border-bottom:3px solid var(--gold); }
.notice-list { list-style:none; }
.notice-list li { padding:12px 20px; border-bottom:1px solid #faf3d0; display:flex; gap:12px; align-items:flex-start; transition:background .2s; }
.notice-list li:hover { background:var(--gold-light); }
.notice-list li:last-child { border-bottom:none; }
.notice-date { font-size:11px; color:var(--gold-dark); background:var(--gold-light); border:1px solid var(--border); border-radius:5px; padding:2px 8px; white-space:nowrap; margin-top:2px; flex-shrink:0; font-weight:600; }
.notice-title a { color:var(--dark); text-decoration:none; font-size:14px; line-height:1.45; display:block; transition:color .2s; }
.notice-title a:hover { color:var(--gold-dark); }
.event-item { display:flex; gap:14px; padding:13px 20px; border-bottom:1px solid #faf3d0; transition:background .2s; }
.event-item:hover { background:var(--gold-light); }
.event-item:last-child { border-bottom:none; }
.event-date-box { background:var(--gold); color:var(--dark); border-radius:9px; text-align:center; padding:7px 11px; min-width:46px; flex-shrink:0; transition:transform .2s, box-shadow .2s; }
.event-item:hover .event-date-box { transform:scale(1.1); box-shadow:0 4px 14px rgba(245,184,0,.45); }
.event-date-box .day { font-size:20px; font-weight:800; line-height:1; }
.event-date-box .mon { font-size:10px; font-weight:700; text-transform:uppercase; }
.event-info h4 { font-size:14px; font-weight:700; margin-bottom:3px; color:var(--dark); }
.event-info p { font-size:13px; color:var(--muted); }

/* ── GALLERY ── */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:14px; }
.gallery-item { border-radius:9px; height:160px; display:flex; align-items:center; justify-content:center; font-size:44px; cursor:pointer; transition:transform .3s ease, box-shadow .3s ease; border:2px solid transparent; overflow:hidden; position:relative; }
.gallery-item:hover { transform:scale(1.07); border-color:var(--gold); box-shadow:0 10px 28px rgba(245,184,0,.28); z-index:1; }
.gallery-item.g1  { background:linear-gradient(135deg,#fff8d6,#ffe57f); }
.gallery-item.g2  { background:linear-gradient(135deg,#fff0a0,#ffd740); }
.gallery-item.g3  { background:linear-gradient(135deg,#fffde7,#fff176); }
.gallery-item.g4  { background:linear-gradient(135deg,#fff8e1,#ffcc02); }
.gallery-item.g5  { background:linear-gradient(135deg,#fff3c4,#ffe082); }
.gallery-item.g6  { background:linear-gradient(135deg,#faeeda,#f5b800); }
.gallery-item.g7  { background:linear-gradient(135deg,#fff8d6,#ffd54f); }
.gallery-item.g8  { background:linear-gradient(135deg,#fff0a0,#ffca28); }
.gallery-item.g9  { background:linear-gradient(135deg,#fffde7,#ffe57f); }
.gallery-item.g10 { background:linear-gradient(135deg,#fff8e1,#ffd740); }
.gallery-item.g11 { background:linear-gradient(135deg,#fff3c4,#ffcc02); }
.gallery-item.g12 { background:linear-gradient(135deg,#faeeda,#ffca28); }
.gallery-caption { position:absolute; bottom:0; left:0; right:0; background:rgba(44,32,0,.82); color:var(--gold); font-size:12px; font-weight:600; text-align:center; padding:8px; transform:translateY(100%); transition:transform .3s ease; }
.gallery-item:hover .gallery-caption { transform:translateY(0); }

/* ── PROGRAMS ── */
.programs-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:24px; }
.program-card { background:var(--white); border:1px solid var(--border-light); border-radius:var(--radius); padding:28px 22px; border-top:5px solid var(--gold); transition:box-shadow .3s, transform .3s; }
.program-card:hover { box-shadow:0 12px 36px rgba(245,184,0,.2); transform:translateY(-6px); }
.program-icon { font-size:32px; margin-bottom:14px; display:block; transition:transform .3s; }
.program-card:hover .program-icon { transform:scale(1.18) rotate(-6deg); }
.program-card h3 { font-size:16px; font-weight:700; color:var(--dark); margin-bottom:8px; }
.program-card p { font-size:14px; color:var(--muted); line-height:1.55; }
.program-card .learn { display:inline-flex; align-items:center; gap:4px; margin-top:14px; font-size:13px; font-weight:700; color:var(--gold-dark); text-decoration:none; transition:gap .2s, color .2s; }
.program-card:hover .learn { gap:9px; color:var(--gold); }

/* ── TESTIMONIALS ── */
.testimonials { background:var(--dark); }
.testi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.testi-card { background:rgba(255,255,255,.05); border-radius:var(--radius); padding:26px; border:1px solid rgba(245,184,0,.2); transition:border-color .3s, background .3s, transform .3s; }
.testi-card:hover { border-color:rgba(245,184,0,.5); background:rgba(255,255,255,.08); transform:translateY(-5px); }
.testi-quote { font-size:15px; color:rgba(255,255,255,.85); line-height:1.65; margin-bottom:18px; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:12px; }
.avatar { width:40px; height:40px; border-radius:50%; background:var(--gold); color:var(--dark); display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:800; flex-shrink:0; transition:transform .3s; }
.testi-card:hover .avatar { transform:scale(1.15) rotate(6deg); }
.author-info .name { font-size:14px; font-weight:700; color:#fff; }
.author-info .role { font-size:12px; color:rgba(255,255,255,.5); }
.stars { color:var(--gold); font-size:14px; margin-bottom:12px; }

/* ── ABOUT ── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:stretch; }
.about-visual { border-radius:16px; border:2px solid var(--border); overflow:hidden; min-height:340px; }
.about-visual img { width:100%; height:100%; object-fit:cover; display:block; }
.value-chip { display:inline-block; background:var(--gold-light); border:1px solid var(--border); border-radius:20px; padding:6px 14px; font-size:13px; font-weight:600; color:var(--gold-deeper); margin:4px; transition:background .2s, transform .2s, color .2s; cursor:default; }
.value-chip:hover { background:var(--gold); color:var(--dark); transform:translateY(-3px); }

/* ── SERVICE CHARTER ── */
.charter-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:24px; }
.charter-card { background:var(--white); border-radius:var(--radius); border:1px solid var(--border-light); padding:28px 24px; border-left:5px solid var(--gold); transition:box-shadow .3s, transform .3s; }
.charter-card:hover { box-shadow:0 10px 32px rgba(245,184,0,.16); transform:translateY(-5px); }
.charter-card h3 { font-size:16px; font-weight:700; color:var(--dark); margin-bottom:12px; display:flex; align-items:center; gap:10px; }
.charter-card ul { list-style:none; }
.charter-card ul li { font-size:14px; color:var(--muted); padding:6px 0; border-bottom:1px solid #faf3d0; display:flex; align-items:flex-start; gap:9px; line-height:1.5; }
.charter-card ul li:last-child { border-bottom:none; }
.charter-card ul li::before { content:'✦'; color:var(--gold); font-size:10px; margin-top:4px; flex-shrink:0; }
.charter-pledge { background:var(--dark); color:#fff; border-radius:var(--radius); padding:36px 40px; text-align:center; margin-top:40px; }
.charter-pledge h3 { color:var(--gold); font-size:20px; margin-bottom:14px; }
.charter-pledge p { color:rgba(255,255,255,.78); font-size:15px; line-height:1.7; max-width:640px; margin:auto; }

/* ── CONTACT ── */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:40px; align-items:start; }
.contact-info-card { background:var(--dark); border-radius:var(--radius); padding:32px; color:#f5d96b; }
.contact-info-card h3 { color:var(--gold); font-size:18px; margin-bottom:22px; }
.contact-item { display:flex; gap:14px; margin-bottom:22px; align-items:flex-start; }
.contact-icon { width:42px; height:42px; background:rgba(245,184,0,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; transition:background .2s, transform .2s; }
.contact-item:hover .contact-icon { background:var(--gold); transform:scale(1.12) rotate(-5deg); }
.contact-item h4 { font-size:13px; color:rgba(255,255,255,.5); margin-bottom:3px; }
.contact-item p, .contact-item a { font-size:14px; color:#f5d96b; text-decoration:none; }
.contact-form-card { background:var(--white); border-radius:var(--radius); border:1px solid var(--border-light); padding:32px; }
.contact-form-card h3 { font-size:18px; font-weight:700; color:var(--dark); margin-bottom:22px; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:13px; font-weight:600; color:var(--muted); margin-bottom:6px; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:11px 14px; border:1px solid var(--border); border-radius:8px; font-size:14px; font-family:inherit; color:var(--text); background:var(--bg); outline:none; transition:border .2s, box-shadow .2s, background .2s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--gold-dark); background:var(--white); box-shadow:0 0 0 3px rgba(245,184,0,.15); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.btn-submit { background:var(--gold); color:var(--dark); border:none; padding:13px 32px; font-size:15px; font-weight:700; border-radius:28px; cursor:pointer; transition:background .2s, transform .2s, box-shadow .2s; width:100%; animation:pulseGold 2.5s infinite; }
.btn-submit:hover { background:var(--gold-dark); color:#fff; transform:translateY(-2px); box-shadow:0 8px 24px rgba(245,184,0,.45); animation:none; }
.map-embed { border-radius:var(--radius); overflow:hidden; border:2px solid var(--border-light); margin-top:32px; }

/* ── VIEW ALL ── */
.view-all { text-align:center; margin-top:32px; }
.view-all a { display:inline-block; padding:11px 28px; border:2px solid var(--gold-dark); color:var(--gold-dark); border-radius:26px; font-size:14px; font-weight:700; text-decoration:none; transition:all .25s; position:relative; overflow:hidden; z-index:0; }
.view-all a::before { content:''; position:absolute; inset:0; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .25s ease; z-index:-1; border-radius:26px; }
.view-all a:hover::before { transform:scaleX(1); }
.view-all a:hover { border-color:var(--gold); color:var(--dark); }

/* ── FOOTER ── */
footer { background:#0E0C00; color:#d4b84a; padding:52px 24px 28px; }
.footer-inner { max-width:1160px; margin:auto; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:36px; margin-bottom:40px; }
.footer-brand img { height:58px; margin-bottom:12px; transition:transform .3s; }
.footer-brand img:hover { transform:scale(1.06) rotate(-3deg); }
.footer-brand .fname { font-size:17px; font-weight:700; color:var(--gold); margin-bottom:8px; }
.footer-brand p { font-size:13px; opacity:.65; line-height:1.65; }
.footer-col h4 { font-size:12px; font-weight:700; color:var(--gold); text-transform:uppercase; letter-spacing:1px; margin-bottom:14px; }
.footer-col a { display:block; font-size:13px; color:#c4a43a; text-decoration:none; margin-bottom:9px; transition:color .2s, padding-left .2s; }
.footer-col a:hover { color:var(--gold); padding-left:6px; }
.footer-bottom { border-top:1px solid rgba(245,184,0,.12); padding-top:20px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:12px; opacity:.5; }
.social-row { display:flex; gap:10px; margin-top:16px; }
.social-btn { width:34px; height:34px; background:rgba(245,184,0,.12); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; color:var(--gold); cursor:pointer; font-weight:700; text-decoration:none; transition:background .2s, transform .2s; }
.social-btn:hover { background:var(--gold); color:var(--dark); transform:translateY(-4px) rotate(8deg); }

/* ── BACK TO TOP ── */
#back-to-top { position:fixed; bottom:28px; right:28px; width:46px; height:46px; background:var(--gold); color:var(--dark); border:none; border-radius:50%; font-size:20px; cursor:pointer; display:none; align-items:center; justify-content:center; z-index:999; box-shadow:0 4px 18px rgba(245,184,0,.45); transition:transform .2s, box-shadow .2s; font-weight:700; }
#back-to-top:hover { transform:translateY(-5px); box-shadow:0 10px 28px rgba(245,184,0,.55); }
#back-to-top.show { display:flex; animation:scaleIn .3s ease; }

/* ── FILTER BUTTONS (gallery) ── */
.filter-bar { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-bottom:36px; }
.filter-btn { padding:8px 20px; border-radius:22px; border:2px solid var(--border); background:var(--white); color:var(--muted); font-size:13px; font-weight:600; cursor:pointer; transition:all .2s; }
.filter-btn:hover, .filter-btn.active { background:var(--gold); border-color:var(--gold); color:var(--dark); transform:translateY(-2px); }

/* ── RESPONSIVE ── */
@media (max-width:860px) {
  /* Navbar: show hamburger bar, hide nav links by default */
  .navbar-top {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    background: var(--olive-nav);
    min-height: 46px;
  }
  .hamburger { display: flex; }

  /* Nav links: hidden by default, shown as full-width column when .open */
  nav {
    display: none;
    flex-direction: column;
    width: 100%;
    padding: 0;
    background: var(--olive-nav);
    border-top: 1px solid rgba(255,255,255,.1);
  }
  nav.open { display: flex; }
  nav a {
    display: block;
    width: 100%;
    padding: 15px 20px;
    font-size: 14px;
    letter-spacing: .4px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    text-align: left;
  }
  nav a::after { display: none; }
  nav a.active { outline: none; background: rgba(255,255,255,.1); border-left: 3px solid var(--gold); }

  /* Header */
  .header-inner { height:68px; }
  .logo img { height:50px; }
  .logo-text .name { font-size:16px; }
  .logo-text .sub { font-size:11px; }

  /* Topbar - hide on small screens */
  .topbar { display:none; }

  /* Hero */
  .hero-btns { flex-direction:column; align-items:center; gap:10px; }
  .hero-btns a { width:80%; text-align:center; }

  /* Stats — 3 cols become single column stacked */
  .stats-inner { grid-template-columns:1fr !important; }
  .stat { border-right:none !important; border-bottom:1px solid var(--border-light); }
  .stat:last-child { border-bottom:none; }

  /* Sections */
  section { padding:44px 16px; }
  .section-inner { padding:0; }

  /* About grid */
  .about-grid { grid-template-columns:1fr; gap:24px; }
  .about-visual { min-height:220px; }

  /* Two col */
  .two-col { grid-template-columns:1fr; }

  /* Contact */
  .contact-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }

  /* Programs */
  .programs-grid { grid-template-columns:1fr 1fr; gap:14px; }
  .program-card { padding:20px 16px; }

  /* Core values */
  .cv-grid { grid-template-columns:1fr 1fr 1fr; gap:12px; }

  /* Vision board */
  .vm-board { max-width:100%; }
  .spirit-box { padding:28px 22px; }

  /* Footer */
  .footer-grid { grid-template-columns:1fr 1fr; gap:24px; }

  /* Gallery */
  .photo-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .photo-card img { height:160px !important; }

  /* Charter */
  .charter-grid { grid-template-columns:1fr; }
  .charter-pledge { padding:24px 20px; }

  /* QR */
  .spirit-box { max-width:100%; }

  /* Testi */
  .testi-grid { grid-template-columns:1fr; }

  /* Key facts dark bar */
  .stats-inner > div { border-right:none !important; border-bottom:1px solid rgba(245,184,0,.1); }
}

@media (max-width:560px) {
  /* Single column everything */
  .programs-grid { grid-template-columns:1fr; }
  .cv-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .photo-grid { grid-template-columns:1fr 1fr; gap:8px; }
  .photo-card img { height:130px !important; }

  /* Hero text */
  .hero h1 { font-size:26px; }
  .hero p { font-size:15px; }
  .hero-btns a { width:90%; font-size:14px; padding:11px 20px; }

  /* Page hero */
  .page-hero { padding:36px 16px; }
  .page-hero h1 { font-size:24px; }

  /* Motto */
  .motto-strip .tagline { font-size:12px; letter-spacing:1px; }

  /* About section chipss */
  .value-chip { font-size:12px; padding:5px 10px; }

  /* Section headers */
  .section-header h2 { font-size:22px; }

  /* Spirit box */
  .spirit-row { font-size:16px; }
  .spirit-letter { font-size:22px; width:28px; }

  /* Footer */
  .footer-brand .fname { font-size:15px; }
  .footer-col h4 { margin-top:8px; }

  /* Back to top */
  #back-to-top { bottom:16px; right:16px; width:38px; height:38px; font-size:16px; }

  /* Contact info */
  .contact-info-card { padding:22px 18px; }
  .contact-form-card { padding:22px 18px; }

  /* Download cards in service charter */
  .spirit-box { padding:22px 16px; }
}

