/* African Genius Academy - Al-Falah International School */
/* Ile-Ife, Osun State, Nigeria */
/* Website Stylesheet */

/* ===== RESET & VARIABLES ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --green:#1a6b3c;
  --green2:#238c50;
  --green-light:#e8f7ee;
  --gold:#d4a017;
  --gold2:#f5c430;
  --gold-light:#fef9e7;
  --sky:#e8f4fd;
  --cream:#fffdf7;
  --white:#ffffff;
  --dark:#0d2818;
  --text:#1e3a26;
  --muted:#5a7a62;
  --border:#d4e8da;
  --radius:16px;
  --radius-lg:24px;
  --shadow:0 4px 24px rgba(26,107,60,.10);
  --shadow-lg:0 12px 48px rgba(26,107,60,.15);
}
html{scroll-behavior:smooth}
body{font-family:'Nunito',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{display:block;width:100%;height:100%;object-fit:cover}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:#f0f0f0}
::-webkit-scrollbar-thumb{background:var(--green);border-radius:3px}

/* ===== NAVBAR ===== */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;height:70px;
  background:var(--white);
  box-shadow:0 2px 20px rgba(26,107,60,.1);
  transition:all .3s;
}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo-img{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid var(--gold2);flex-shrink:0}
.nav-logo-text{line-height:1.2}
.nav-logo-text strong{font-size:.95rem;font-weight:900;color:var(--green);display:block}
.nav-logo-text span{font-size:.68rem;color:var(--muted);font-weight:600}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  color:var(--text);font-size:.85rem;font-weight:700;
  padding:8px 14px;border-radius:50px;
  transition:background .2s,color .2s;
}
.nav-links a:hover{background:var(--green-light);color:var(--green)}
.nav-links .nav-enrol{
  background:var(--green);color:var(--white)!important;
  padding:9px 20px;border-radius:50px;font-weight:800;
  box-shadow:0 4px 14px rgba(26,107,60,.3);
  transition:transform .2s,box-shadow .2s!important;
}
.nav-links .nav-enrol:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(26,107,60,.4);background:var(--green)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:2.5px;background:var(--green);border-radius:2px;transition:.3s;display:block}

/* ===== TICKER ===== */
.ticker-wrap{background:var(--green);padding:9px 0;overflow:hidden;white-space:nowrap;margin-top:70px}
.ticker-inner{display:inline-flex;animation:ticker 35s linear infinite}
.ticker-inner span{
  margin:0 40px;font-size:.8rem;font-weight:700;color:var(--white);
  display:inline-flex;align-items:center;gap:8px;
}
.ticker-inner span::before{content:'★';color:var(--gold2)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== HERO ===== */
#hero{
  background:linear-gradient(135deg,#f0faf4 0%,#fffef5 40%,#e8f6ff 100%);
  padding:70px 5% 60px;
  display:flex;align-items:center;justify-content:center;
  min-height:calc(100vh - 70px);
  position:relative;overflow:hidden;
}
.hero-blob{
  position:absolute;border-radius:50%;pointer-events:none;z-index:0;
}
.hb1{width:500px;height:500px;background:radial-gradient(circle,rgba(26,107,60,.07),transparent 70%);top:-150px;right:-100px;animation:blobPulse 8s ease-in-out infinite alternate}
.hb2{width:350px;height:350px;background:radial-gradient(circle,rgba(212,160,23,.08),transparent 70%);bottom:-100px;left:-80px;animation:blobPulse 10s ease-in-out infinite alternate-reverse}
.hb3{width:200px;height:200px;background:radial-gradient(circle,rgba(26,107,60,.05),transparent 70%);top:30%;left:5%;animation:blobPulse 6s ease-in-out infinite alternate}
@keyframes blobPulse{from{transform:scale(1)}to{transform:scale(1.2)}}

.hero-content{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;max-width:1200px;width:100%;
}
.hero-left{}
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green-light);border:1.5px solid rgba(26,107,60,.2);
  color:var(--green);font-size:.75rem;font-weight:800;letter-spacing:.08em;
  padding:6px 16px;border-radius:50px;text-transform:uppercase;margin-bottom:20px;
  animation:slideUp .7s .1s both;
}
.hero-left h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,4vw,3.4rem);
  color:var(--dark);line-height:1.15;margin-bottom:18px;
  animation:slideUp .7s .2s both;
}
.hero-left h1 .highlight{
  color:var(--green);position:relative;display:inline-block;
}
.hero-left h1 .highlight::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--gold),var(--gold2));
  border-radius:2px;
}
.hero-left p{
  font-size:1rem;color:var(--muted);line-height:1.8;
  margin-bottom:28px;animation:slideUp .7s .3s both;
  max-width:480px;
}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;animation:slideUp .7s .4s both}
.btn-green{
  background:var(--green);color:var(--white);font-weight:800;font-size:.9rem;
  padding:14px 30px;border-radius:50px;
  box-shadow:0 4px 18px rgba(26,107,60,.3);
  transition:transform .2s,box-shadow .2s;
  display:inline-flex;align-items:center;gap:8px;
}
.btn-green:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(26,107,60,.4)}
.btn-white{
  background:var(--white);color:var(--green);font-weight:800;font-size:.9rem;
  padding:13px 28px;border-radius:50px;border:2px solid var(--green);
  transition:background .2s,color .2s;
  display:inline-flex;align-items:center;gap:8px;
}
.btn-white:hover{background:var(--green);color:var(--white)}

.hero-stats{
  display:flex;gap:24px;margin-top:36px;flex-wrap:wrap;
  animation:slideUp .7s .5s both;
}
.hstat{
  background:var(--white);border-radius:var(--radius);
  padding:14px 20px;text-align:center;
  box-shadow:var(--shadow);min-width:100px;
}
.hstat .n{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:900;color:var(--green);line-height:1}
.hstat .l{font-size:.72rem;color:var(--muted);font-weight:700;margin-top:4px}

/* Hero right — photo mosaic */
.hero-right{position:relative;animation:slideUp .7s .3s both}
.hero-mosaic{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:200px 160px 180px;
  gap:12px;
}
.hm-img{border-radius:var(--radius);overflow:hidden;position:relative}
.hm-img img{transition:transform .5s}
.hm-img:hover img{transform:scale(1.05)}
.hm-img.span2{grid-column:span 2}
.hm-img.tall{grid-row:span 2}
.hm-badge{
  position:absolute;bottom:12px;left:12px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border-radius:50px;padding:5px 12px;
  font-size:.72rem;font-weight:800;color:var(--green);
  box-shadow:0 2px 10px rgba(0,0,0,.1);
}

@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* ===== SECTION SHARED ===== */
section{padding:88px 5%}
.sec-label{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green-light);color:var(--green);
  font-size:.73rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 14px;border-radius:50px;margin-bottom:12px;
}
.sec-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.8rem,3vw,2.6rem);color:var(--dark);
  line-height:1.2;margin-bottom:12px;
}
.sec-sub{font-size:.97rem;color:var(--muted);line-height:1.75;max-width:520px}
.text-center{text-align:center}
.text-center .sec-sub{margin:0 auto}

/* ===== ABOUT ===== */
#about{background:var(--white)}
.about-wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-imgs{position:relative;height:480px}
.ab-main{
  position:absolute;top:0;left:0;width:75%;height:82%;
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);
}
.ab-accent{
  position:absolute;bottom:0;right:0;width:48%;height:50%;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);border:4px solid var(--white);
}
.ab-pill{
  position:absolute;top:44%;left:56%;transform:translate(-50%,-50%);
  background:var(--green);color:var(--white);border-radius:var(--radius);
  padding:16px 20px;text-align:center;box-shadow:0 8px 30px rgba(26,107,60,.35);z-index:2;
}
.ab-pill .big{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:900;color:var(--gold2)}
.ab-pill p{font-size:.68rem;color:rgba(255,255,255,.8);line-height:1.3;margin-top:2px}

.about-features{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.af{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--cream);border-radius:var(--radius);padding:16px;
  border:1px solid var(--border);transition:transform .2s,box-shadow .2s;
}
.af:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.af-icon{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:var(--green);display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;
}
.af h4{font-size:.92rem;font-weight:800;color:var(--dark);margin-bottom:3px}
.af p{font-size:.82rem;color:var(--muted);line-height:1.5}

/* ===== QURAN BANNER ===== */
.quran-banner{
  background:linear-gradient(135deg,var(--green) 0%,#0d3d20 100%);
  padding:60px 5%;text-align:center;position:relative;overflow:hidden;
}
.quran-banner::before{
  content:'بسم الله';font-family:'Amiri',serif;
  position:absolute;font-size:200px;color:rgba(255,255,255,.03);
  right:-20px;top:-40px;pointer-events:none;
}
.quran-arabic{
  font-family:'Amiri',serif;font-size:clamp(1.6rem,3.5vw,2.6rem);
  color:var(--gold2);margin-bottom:12px;line-height:1.5;
}
.quran-banner .trans{color:rgba(255,255,255,.7);font-size:.98rem;font-style:italic}
.quran-banner .source{color:var(--gold2);font-size:.8rem;margin-top:8px;font-weight:700}

/* ===== PROGRAMMES ===== */
#programmes{background:var(--cream)}
.prog-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px;margin-top:44px;
}
.prog-card{
  background:var(--white);border-radius:var(--radius-lg);
  padding:30px 24px;border:1.5px solid var(--border);
  position:relative;overflow:hidden;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.prog-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--green),var(--gold2));
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.prog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.prog-card:hover::before{transform:scaleX(1)}
.prog-card .p-icon{
  width:56px;height:56px;border-radius:16px;
  background:var(--green-light);display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;margin-bottom:18px;
}
.prog-card h3{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--dark);margin-bottom:10px}
.prog-card p{font-size:.85rem;color:var(--muted);line-height:1.7}
.prog-tag{
  display:inline-block;margin-top:16px;
  background:var(--green-light);color:var(--green);
  font-size:.7rem;font-weight:800;letter-spacing:.05em;
  padding:4px 12px;border-radius:50px;text-transform:uppercase;
}

/* ===== WHY US ===== */
#why{
  background:linear-gradient(135deg,#f0faf4 0%,#fffef5 100%);
}
.why-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;margin-top:44px;
}
.why-card{
  background:var(--white);border-radius:var(--radius-lg);
  padding:32px 22px;text-align:center;
  box-shadow:var(--shadow);
  transition:transform .25s,box-shadow .25s;
  position:relative;overflow:hidden;
}
.why-card::after{
  content:'';position:absolute;inset:0;border-radius:var(--radius-lg);
  border:2px solid transparent;transition:border-color .3s;
}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.why-card:hover::after{border-color:var(--green)}
.why-card .wi{
  width:60px;height:60px;border-radius:20px;
  background:linear-gradient(135deg,var(--green),var(--green2));
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin:0 auto 18px;
  box-shadow:0 6px 18px rgba(26,107,60,.25);
}
.why-card h3{font-size:1rem;font-weight:800;color:var(--dark);margin-bottom:8px}
.why-card p{font-size:.83rem;color:var(--muted);line-height:1.65}

/* ===== GALLERY ===== */
#gallery{background:var(--white)}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
  gap:12px;margin-top:36px;
}
.gi{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer}
.gi img{transition:transform .5s}
.gi:hover img{transform:scale(1.07)}
.gi.wide{grid-column:span 2}
.gi.tall{grid-row:span 2}
.gi-cap{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(13,40,24,.7) 0%,transparent 55%);
  display:flex;align-items:flex-end;padding:14px;
  opacity:0;transition:opacity .3s;
}
.gi:hover .gi-cap{opacity:1}
.gi-cap span{
  color:var(--white);font-size:.78rem;font-weight:800;
  background:rgba(26,107,60,.7);padding:4px 10px;border-radius:50px;
}

/* Lightbox */
#lightbox{
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.92);align-items:center;justify-content:center;
}
#lightbox.active{display:flex}
#lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius);width:auto;height:auto}
#lightbox-close{
  position:absolute;top:20px;right:24px;
  background:none;border:none;color:var(--white);font-size:2rem;
  cursor:pointer;line-height:1;opacity:.7;transition:opacity .2s;
}
#lightbox-close:hover{opacity:1}

/* ===== TRANSPORT ===== */
#transport{background:linear-gradient(135deg,#f5fff9 0%,#fffdf0 100%)}
.transport-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:40px}
.bus-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bus-img{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3}
.transport-points{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.tp{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--white);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);border-left:4px solid var(--green);
}
.tp-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.tp h4{font-size:.92rem;font-weight:800;color:var(--dark)}
.tp p{font-size:.82rem;color:var(--muted);margin-top:3px;line-height:1.5}

/* ===== TESTIMONIALS ===== */
#testimonials{
  background:linear-gradient(135deg,var(--green) 0%,#0d3d20 100%);
}
#testimonials .sec-label{background:rgba(255,255,255,.15);color:var(--gold2)}
#testimonials .sec-title{color:var(--white)}
#testimonials .sec-sub{color:rgba(255,255,255,.6)}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:44px}
.tc{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-lg);padding:28px 24px;
  transition:background .3s,transform .3s;
}
.tc:hover{background:rgba(255,255,255,.12);transform:translateY(-4px)}
.tc-stars{color:var(--gold2);font-size:.85rem;margin-bottom:12px;letter-spacing:2px}
.tc-quote{font-size:.9rem;color:rgba(255,255,255,.82);line-height:1.75;font-style:italic}
.tc-author{display:flex;align-items:center;gap:12px;margin-top:20px}
.tc-av{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:.9rem;color:var(--dark);
}
.tc-author h4{color:var(--white);font-size:.88rem;font-weight:800}
.tc-author span{color:rgba(255,255,255,.5);font-size:.75rem}

/* ===== LEADERSHIP ===== */
#leadership{background:var(--white)}
.leader-wrap{
  display:flex;gap:48px;align-items:center;
  background:linear-gradient(135deg,#f0faf4,#fffef5);
  border-radius:var(--radius-lg);padding:44px;
  border:1.5px solid var(--border);max-width:900px;margin:44px auto 0;
  box-shadow:var(--shadow);
}
.leader-av{
  width:140px;height:140px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--green),var(--green2));
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:2.8rem;font-weight:900;color:var(--white);
  border:4px solid var(--gold2);box-shadow:0 8px 28px rgba(26,107,60,.25);
}
.leader-body h3{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--dark);margin-bottom:4px}
.leader-title{color:var(--green);font-weight:800;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px}
.leader-body p{font-size:.93rem;color:var(--muted);line-height:1.8}
.leader-quote{
  margin-top:16px;padding:14px 18px;
  background:var(--white);border-left:4px solid var(--gold2);border-radius:0 var(--radius) var(--radius) 0;
  font-style:italic;color:var(--green);font-size:.9rem;font-weight:700;
}

/* ===== ADMISSIONS ===== */
#admissions{background:linear-gradient(135deg,#f0faf4 0%,#fffef5 100%)}
.adm-wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.adm-steps{margin-top:32px;display:flex;flex-direction:column;gap:0}
.adm-step{display:flex;gap:18px;position:relative;padding-bottom:28px}
.adm-step:last-child{padding-bottom:0}
.adm-step::after{
  content:'';position:absolute;left:17px;top:42px;bottom:0;
  width:2px;background:linear-gradient(180deg,var(--green),rgba(26,107,60,.1));
}
.adm-step:last-child::after{display:none}
.step-circle{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:var(--green);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:.88rem;box-shadow:0 4px 14px rgba(26,107,60,.3);
  position:relative;z-index:1;
}
.step-body h4{font-size:.95rem;font-weight:800;color:var(--dark);margin-bottom:4px}
.step-body p{font-size:.83rem;color:var(--muted);line-height:1.6}

.adm-form{
  background:var(--white);border-radius:var(--radius-lg);
  padding:36px 32px;box-shadow:var(--shadow-lg);
  border-top:5px solid var(--green);
}
.adm-form h3{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--dark);margin-bottom:4px}
.adm-form .sub{font-size:.84rem;color:var(--muted);margin-bottom:24px}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:.8rem;font-weight:800;color:var(--text);margin-bottom:5px}
.fg input,.fg select,.fg textarea{
  width:100%;padding:11px 14px;
  border:1.5px solid var(--border);border-radius:10px;
  font-family:'Nunito',sans-serif;font-size:.9rem;color:var(--text);
  background:#fafffe;outline:none;transition:border-color .2s,box-shadow .2s;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--green);box-shadow:0 0 0 3px rgba(26,107,60,.1);
}
.fg textarea{resize:vertical;min-height:80px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn-submit{
  width:100%;padding:14px;
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:var(--white);font-weight:800;font-size:.96rem;
  border:none;border-radius:50px;cursor:pointer;
  transition:transform .2s,box-shadow .2s;
  font-family:'Nunito',sans-serif;
  box-shadow:0 4px 18px rgba(26,107,60,.3);margin-top:6px;
}
.btn-submit:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(26,107,60,.4)}
.form-note{text-align:center;font-size:.75rem;color:var(--muted);margin-top:10px}
.success-msg{
  display:none;background:#e8f7ee;border:1.5px solid #a8dbb8;
  border-radius:12px;padding:16px;text-align:center;
  color:var(--green);font-weight:800;margin-top:14px;font-size:.9rem;
}

/* ===== CONTACT ===== */
#contact{background:var(--dark)}
#contact .sec-label{background:rgba(255,255,255,.12);color:var(--gold2)}
#contact .sec-title{color:var(--white)}
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:44px}
.contact-cards{display:flex;flex-direction:column;gap:14px}
.cc{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:18px 20px;
  display:flex;gap:14px;align-items:flex-start;
  transition:background .2s;
}
.cc:hover{background:rgba(255,255,255,.1)}
.cc-icon{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.cc-body h4{color:var(--white);font-size:.9rem;font-weight:800;margin-bottom:4px}
.cc-body p,.cc-body a{color:rgba(255,255,255,.58);font-size:.84rem;line-height:1.6}
.cc-body a:hover{color:var(--gold2)}
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;min-height:380px;border:2px solid rgba(255,255,255,.08)}
.map-wrap iframe{width:100%;height:100%;min-height:380px;border:none;display:block}

/* ===== FOOTER ===== */
footer{background:#060f0a;padding:64px 5% 0}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:44px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.07);
}
.fb-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.fb-logo img{width:46px;height:46px;border-radius:50%;border:2px solid var(--gold2)}
.fb-logo strong{font-family:'Playfair Display',serif;color:var(--white);font-size:1rem}
.fb-desc{font-size:.84rem;color:rgba(255,255,255,.45);line-height:1.75;max-width:250px;margin-bottom:18px}
.socials{display:flex;gap:10px}
.socials a{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.5);font-size:.78rem;font-weight:800;
  transition:all .2s;
}
.socials a:hover{background:var(--gold);color:var(--dark);border-color:var(--gold)}
.fc h4{color:var(--gold2);font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.fc ul li{margin-bottom:8px}
.fc ul li a{color:rgba(255,255,255,.48);font-size:.84rem;transition:color .2s}
.fc ul li a:hover{color:var(--gold2)}
.fc-contact p{display:flex;gap:8px;color:rgba(255,255,255,.48);font-size:.84rem;margin-bottom:11px;line-height:1.5}
.fc-contact a{color:rgba(255,255,255,.48);font-size:.84rem}
.fc-contact a:hover{color:var(--gold2)}
.footer-bottom{
  padding:18px 0;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:10px;
}
.footer-bottom p{color:rgba(255,255,255,.3);font-size:.77rem}
.footer-bottom a{color:var(--gold2)}

/* ===== WHATSAPP FLOAT ===== */
.wa{
  position:fixed;bottom:26px;right:26px;z-index:999;
  background:#25D366;width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 22px rgba(37,211,102,.45);
  transition:transform .25s,box-shadow .25s;
}
.wa:hover{transform:scale(1.12);box-shadow:0 8px 32px rgba(37,211,102,.55)}
.wa svg{width:26px;height:26px;fill:white}

/* ===== MOBILE DRAWER ===== */
.drawer{
  display:none;position:fixed;inset:0;z-index:9998;
  background:var(--white);flex-direction:column;
  padding:88px 8% 40px;gap:6px;
}
.drawer.open{display:flex}
.drawer a{
  color:var(--text);font-size:1.1rem;font-weight:700;
  padding:12px 16px;border-radius:var(--radius);
  transition:background .2s;
}
.drawer a:hover{background:var(--green-light);color:var(--green)}
.drawer .d-enrol{
  background:var(--green);color:var(--white)!important;
  text-align:center;margin-top:12px;padding:14px;border-radius:50px;font-weight:800;
}
.drawer-close{
  position:absolute;top:20px;right:5%;
  background:none;border:none;cursor:pointer;
  font-size:1.8rem;color:var(--muted);line-height:1;
}

/* ===== SCROLL REVEAL ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== BACK TO TOP ===== */
#back-top{
  position:fixed;bottom:96px;right:26px;z-index:998;
  width:42px;height:42px;border-radius:50%;
  background:var(--green);color:var(--white);border:none;cursor:pointer;
  font-size:1.1rem;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(26,107,60,.3);
  opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;
}
#back-top.show{opacity:1;pointer-events:all}
#back-top:hover{transform:translateY(-3px)}

/* ===== RESPONSIVE ===== */
@media(max-width:960px){
  .hero-content{grid-template-columns:1fr;gap:40px}
  .hero-mosaic{grid-template-rows:180px 140px 160px}
  #about .about-wrap,
  .adm-wrap,
  .transport-wrap,
  .contact-wrap{grid-template-columns:1fr}
  .about-imgs{height:320px}
  .leader-wrap{flex-direction:column;text-align:center;padding:32px 24px}
  .footer-top{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gi.wide{grid-column:span 1}
  .gi.tall{grid-row:span 1}
}
@media(max-width:640px){
  section{padding:64px 5%}
  .nav-links{display:none}
  .hamburger{display:flex}
  .footer-top{grid-template-columns:1fr}
  .fg-row{grid-template-columns:1fr}
  .hero-stats{gap:10px}
  .hstat{min-width:80px;padding:12px 14px}
  .about-imgs{height:260px}
  .gallery-grid{grid-template-columns:1fr}
  .leader-av{width:100px;height:100px;font-size:2rem}
}
.map-visual {
  width: 100%;
  height: 450px; 
}

.map-visual iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}