/* ═══════════════════════════════════════════
   ZINGIBARI SECONDARY SCHOOL — SHARED STYLES
   Black + Silver Theme
═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&display=swap');

/* ── TOKENS ── */
:root {
  --white:     #ffffff;
  --off-white: #f4f8fd;
  --blue-50:   #e8f3fc;
  --blue-100:  #cce4f6;
  --blue-200:  #99c9ed;
  --blue-300:  #5aaee0;
  --blue-400:  #2a8ed4;
  --blue-500:  #1a72b8;
  --blue-600:  #145a94;
  --blue-700:  #0e4070;
  --blue-800:  #09294d;
  --blue-900:  #051929;
  --accent:    #f0a500;
  --accent-lt: #fde9b3;
  --text-dark: #0e2a42;
  --text-mid:  #3a5a7a;
  --text-light:#7a9ab8;
  --border:    #d0e4f4;
  --shadow:    0 4px 28px rgba(26,114,184,.10);
  --shadow-lg: 0 12px 55px rgba(26,114,184,.15);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--white);color:var(--text-dark);overflow-x:hidden}

/* â”€â”€ PROGRESS BAR â”€â”€ */
#prog{position:fixed;top:0;left:0;right:0;height:4px;background:var(--blue-50);z-index:9999}
#prog-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--blue-400),var(--blue-300),var(--accent));transition:width .1s linear;box-shadow:0 0 8px rgba(42,142,212,.4)}

/* â”€â”€ NAVIGATION â”€â”€ */
nav{
  position:fixed;top:4px;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 5vw;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 20px rgba(26,114,184,.07);
}
.nav-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.nav-logo{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .5s ease;
}
.nav-logo img{max-height:100%;max-width:100%;object-fit:contain}
.nav-brand:hover .nav-logo{transform:scale(1.05)}
.nav-logo svg{width:24px;height:24px}
.brand-name{font-family:'Playfair Display',serif;font-size:.98rem;font-weight:700;color:var(--blue-600);letter-spacing:.02em;line-height:1.1}
.brand-sub{font-family:'DM Mono',monospace;font-size:.54rem;color:var(--text-light);letter-spacing:.15em;text-transform:uppercase}
.nav-links{display:flex;gap:.2rem;list-style:none;align-items:center}
.nav-links li{display:flex;align-items:center}
.nav-links a{
  font-family:'DM Mono',monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-mid);text-decoration:none;padding:.45rem .85rem;border-radius:5px;transition:all .22s;
  display:inline-flex;align-items:center;justify-content:center;
}
.nav-links a:hover{background:var(--blue-50);color:var(--blue-500)}
.nav-links a.active{background:var(--blue-500);color:#fff}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:5px}
.hamburger span{width:22px;height:2px;background:var(--blue-500);display:block;transition:all .3s}
.mobile-menu{
  display:none;position:fixed;top:68px;left:0;right:0;
  background:var(--white);border-bottom:1px solid var(--border);
  padding:1rem 5vw;z-index:998;box-shadow:0 8px 30px rgba(26,114,184,.1);
  flex-direction:column;gap:.4rem;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  display:block;padding:.7rem 1rem;color:var(--text-mid);text-decoration:none;
  font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  border-radius:5px;transition:all .2s;
}
.mobile-menu a:hover{background:var(--blue-50);color:var(--blue-500)}

/* â”€â”€ LANGUAGE TOGGLE â”€â”€ */
.lang-toggle{
  position:fixed;top:68px;right:5vw;
  background:var(--white);border:1px solid var(--border);
  border-radius:6px;padding:.4rem .6rem;
  display:flex;align-items:center;gap:.4rem;
  box-shadow:0 4px 16px rgba(26,114,184,.08);
  z-index:999;cursor:pointer;transition:all .25s;
}
.lang-toggle:hover{border-color:var(--blue-400);box-shadow:0 6px 20px rgba(26,114,184,.12)}
.lang-toggle span{
  font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.08em;
  color:var(--text-mid);font-weight:600;padding:.2rem .4rem;border-radius:4px;
  transition:all .2s;
}
.lang-toggle span.active{background:var(--blue-500);color:#fff}
.lang-toggle span:not(.active):hover{background:var(--blue-50)}

/* â”€â”€ DROPDOWN MENU â”€â”€ */
.dropdown{position:relative;display:inline-block}
.dropdown-toggle{cursor:pointer;display:flex;align-items:center;gap:.3rem}
.dropdown-toggle::after{content:'▼';font-size:.5rem;transition:transform .3s}
.dropdown:hover .dropdown-toggle::after{transform:rotate(180deg)}
.dropdown-menu{
  position:absolute;top:100%;left:0;
  background:var(--white);border:1px solid var(--border);border-radius:0;
  padding:0;min-width:220px;box-shadow:0 8px 30px rgba(0,0,0,.15);
  opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s;z-index:1001;
  margin-top:0;
  display:flex;flex-direction:column;
}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{
  display:block;padding:.45rem .85rem;
  font-family:'DM Mono',monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  white-space:nowrap;
  color:var(--text-mid)!important;
  transition:all .2s;text-decoration:none;
  width:100%;
}
.dropdown-menu a:hover{background:var(--blue-50);color:var(--blue-500)!important}
.dropdown-menu a.active{background:var(--blue-500);color:#fff!important}

/* â”€â”€ PAGE HEADER (for inner pages) â”€â”€ */
.page-hero{
  padding:140px 5vw 80px;
  background:linear-gradient(135deg,var(--blue-600) 0%,var(--blue-800) 100%);
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;top:-40%;right:-10%;
  width:600px;height:600px;border-radius:50%;background:rgba(255,255,255,.04);
}
.page-hero::after{
  content:'';position:absolute;bottom:-30%;left:-5%;
  width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.03);
}
.ph-inner{max-width:1200px;margin:auto;position:relative;z-index:1}
.ph-breadcrumb{
  font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:1rem;
}
.ph-breadcrumb a{color:rgba(255,255,255,.55);text-decoration:none}
.ph-breadcrumb a:hover{color:#fff}
.ph-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.5rem);font-weight:900;color:#fff;margin-bottom:.75rem;line-height:1.08}
.ph-title em{font-style:italic;color:var(--blue-200)}
.ph-sub{color:rgba(255,255,255,.75);font-size:1rem;max-width:580px;line-height:1.8}

/* â”€â”€ SECTION UTILITIES â”€â”€ */
.sec-wrap{max-width:1200px;margin:auto;padding:90px 5vw}
.sec-eyebrow{
  font-family:'DM Mono',monospace;font-size:.64rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--blue-400);display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.75rem;
}
.sec-eyebrow::before{content:'';width:22px;height:1.5px;background:var(--blue-300)}
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(1.9rem,3.5vw,2.9rem);font-weight:900;line-height:1.1;color:var(--text-dark);margin-bottom:1rem}
.sec-title em{color:var(--blue-500);font-style:italic}
.sec-rule{width:48px;height:3px;background:var(--blue-400);border-radius:2px;margin-bottom:2.5rem}

/* â”€â”€ BUTTONS â”€â”€ */
.btn{
  display:inline-block;padding:.82rem 2rem;text-decoration:none;
  font-family:'DM Mono',monospace;font-size:.71rem;letter-spacing:.1em;text-transform:uppercase;
  border-radius:6px;cursor:pointer;border:none;position:relative;overflow:hidden;
  transition:transform .22s,box-shadow .22s;
}
.btn::after{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.18);transform:translateX(-110%) skewX(-20deg);transition:transform .4s;
}
.btn:hover::after{transform:translateX(110%) skewX(-20deg)}
.btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(26,114,184,.22)}
.btn-blue   {background:var(--blue-500);color:#fff}
.btn-blue:hover{background:var(--blue-600)}
.btn-outline{background:transparent;color:var(--blue-500);border:1.5px solid var(--blue-400)}
.btn-outline:hover{background:var(--blue-50)}
.btn-white  {background:#fff;color:var(--blue-700)}
.btn-ghost  {background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.2)}

/* â”€â”€ SCROLL REVEAL â”€â”€ */
.reveal,.reveal-l,.reveal-r{transition:opacity .8s,transform .8s;opacity:0}
.reveal  {transform:translateY(34px)}
.reveal-l{transform:translateX(-34px)}
.reveal-r{transform:translateX(34px)}
.reveal.vis,.reveal-l.vis,.reveal-r.vis{opacity:1;transform:translate(0)}

/* â”€â”€ KEYFRAMES â”€â”€ */
@keyframes fadeUp  {from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn  {from{opacity:0}to{opacity:1}}

/* â”€â”€ FOOTER â”€â”€ */
footer{background:var(--blue-900);color:rgba(255,255,255,.7);padding:60px 5vw 28px}
.footer-inner{max-width:1200px;margin:auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.6rem}
.footer-desc{font-size:.82rem;line-height:1.75;max-width:230px;color:rgba(255,255,255,.7)}
.footer-col{display:flex;flex-direction:column;gap:.5rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.footer-col h5{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:.5rem}
.footer-col a{color:rgba(255,255,255,.6);text-decoration:none;font-size:.83rem;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-grid h5{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:.9rem}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:.45rem}
.footer-grid a{color:rgba(255,255,255,.6);text-decoration:none;font-size:.83rem;transition:color .2s}
.footer-grid a:hover{color:#fff}
.footer-rule{height:1px;background:rgba(255,255,255,.08);margin-bottom:1.4rem}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.1em;color:rgba(255,255,255,.33)}
.footer-socials{display:flex;gap:.6rem}
.soc{
  width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;
  color:rgba(255,255,255,.5);text-decoration:none;transition:all .25s;
}
.soc:hover{background:var(--blue-500);border-color:var(--blue-500);color:#fff}

/* â”€â”€ RESPONSIVE â”€â”€ */
@media (max-width: 1024px) {
  nav { padding: 0.75rem 4vw; }
  .sec-wrap { padding: 70px 4vw; }
  .page-hero { padding: 120px 4vw 70px; }
}

@media (max-width: 960px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  nav { padding: 0.7rem 3vw; top: 0; }
  .mobile-menu { top: 64px; padding: 0.8rem 3vw; }
  .lang-toggle { top: 64px; right: 3vw; }
}

@media (max-width: 768px) {
  .sec-wrap, .page-hero { padding: 50px 3vw 40px; }
  .features, .news-section, .stats-band { padding: 50px 3vw !important; }
  footer { padding: 50px 3vw 24px; }
  .nav-brand { gap: 0.5rem; }
  .brand-name { font-size: 0.9rem; }
  .brand-sub { font-size: 0.5rem; }
  .nav-logo { width: 40px; height: 40px; }
  .nav-logo svg { width: 22px; height: 22px; }
  .nav-logo img { height: 36px; }
  .btn { padding: 0.7rem 1.6rem; font-size: 0.68rem; min-height: 44px; } /* Touch friendly */
  .sec-title { font-size: clamp(1.6rem, 5vw, 2.2rem) !important; }
  .ph-title { font-size: clamp(1.8rem, 6vw, 2.8rem) !important; }
  .sec-eyebrow { font-size: 0.58rem; letter-spacing: 0.2em; }
  .footer-grid { gap: 1.5rem; }
  .footer-brand { font-size: 1rem; }
  /* Grid adjustments */
  .feat-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
  .sb-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
  .news-grid { grid-template-columns: 1fr; }
  .news-img { height: 160px; font-size: 2.5rem; }
}

@media (max-width: 620px) {
  .footer-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .footer-bottom { flex-direction: column; gap: 1rem; text-align: center; }
}

@media (max-width: 480px) {
  nav, .mobile-menu { padding-left: 2vw; padding-right: 2vw; }
  .sec-wrap, .page-hero { padding: 50px 2.5vw; }
  footer { padding: 40px 2.5vw 20px; }
  .btn { 
    display: block; 
    width: 100%; 
    max-width: 280px; 
    margin: 0 auto 0.5rem; 
    text-align: center; 
    padding: 0.75rem 1.5rem; 
    font-size: 0.7rem; 
  }
  .hero-btns { flex-direction: column; align-items: center; gap: 0.75rem; }
  .sec-eyebrow::before { width: 18px; }
  .sec-rule { width: 40px; height: 2.5px; margin-bottom: 2rem; }
  body { font-size: 0.95rem; line-height: 1.65; }
  .ph-breadcrumb { font-size: 0.55rem; }
  .ph-sub { font-size: 0.92rem; }
  .hamburger span { width: 20px; height: 2.5px; }
}

@media (max-width: 360px) {
  .nav-logo { width: 36px; height: 36px; }
  .nav-logo img { height: 32px; }
  .brand-name { font-size: 0.85rem; }
  .brand-sub { font-size: 0.48rem; letter-spacing: 0.12em; }
  .sec-title, .ph-title { line-height: 1.15; }
}