/*
Theme Name: Explore More Academy
Theme URI: https://exploremoreacademy.com
Author: Explore More Academy LLC
Author URI: https://exploremoreacademy.com
Description: Custom theme for Explore More Academy LLC — Wild Minds, Bold Hearts, Limitless Futures. Features an animated nature-themed design with a hero slider, scroll reveals, ambient background animations, an Expedition Logbook progress tracker, and a first-visit Gate modal.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.6
Text Domain: explore-more-academy
*/

:root{
  --forest-dark:#143622; --forest-medium:#215c38; --forest-light:#37965b; --forest-mint:#eef7f2;
  --orange:#e65f2b; --orange-light:#ffedd5; --orange-hover:#c94917;
  --sky-blue:#0284c7; --sky-light:#e0f2fe;
  --earth-brown:#3e2723; --earth-medium:#5d4037;
  --sand-light:#fdfbf7; --sand-dark:#f0ebd9;
  --sunset-yellow:#f59e0b; --slate-dark:#1e293b; --slate-light:#f8fafc;
  --shadow-sm:0 1px 2px 0 rgba(0,0,0,.05);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
  --font-sans:"Inter",sans-serif;
  --font-heading:"Outfit",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);color:var(--earth-medium);background:var(--sand-light);line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-heading);color:var(--forest-dark);line-height:1.2}
h1{font-weight:800;font-size:clamp(2rem,5vw,3.75rem)}
h2{font-weight:800;font-size:clamp(1.75rem,3.5vw,2.5rem)}
h3{font-weight:700;font-size:1.35rem}
p{font-size:1rem}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ===== HEADER ===== */
.header{position:sticky;top:0;left:0;right:0;z-index:1000;background:var(--forest-dark);transition:all .3s ease;box-shadow:none}
.header.scrolled{box-shadow:var(--shadow-lg)}
.header-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:18px 24px;transition:padding .3s ease}
.header.scrolled .header-inner{padding:10px 24px}
.logo{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--font-heading);font-weight:800;font-size:1.25rem;letter-spacing:.3px}
.logo-emblem{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--forest-light),var(--sunset-yellow));display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:var(--shadow-md)}
.nav{display:flex;gap:28px;align-items:center}
.nav a{color:#fff;font-weight:500;font-size:.95rem;position:relative;padding:6px 2px;transition:color .2s}
.nav a:hover{color:var(--forest-light)}
.nav a.active{color:var(--orange)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:3px;background:var(--orange);border-radius:2px}
.cta-btn{background:var(--orange);color:#fff;font-family:var(--font-heading);font-weight:700;padding:12px 24px;border-radius:50px;border:none;cursor:pointer;transition:all .25s;font-size:.95rem}
.cta-btn:hover{background:var(--orange-hover);transform:scale(1.04)}
.hamburger{display:none;background:transparent;border:none;color:#fff;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.hamburger span{width:26px;height:3px;background:#fff;border-radius:3px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

@media(max-width:960px){
  .nav,.header-cta{display:none}
  .hamburger{display:flex}
  .nav.mobile-open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--forest-dark);padding:20px 24px;gap:18px;box-shadow:var(--shadow-lg);animation:slideDown .3s ease}
  .nav.mobile-open a{font-size:1.05rem}
  .nav.mobile-open .cta-btn{display:inline-block;align-self:flex-start}
  .nav.mobile-open{display:flex}
}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}

/* ===== PAGES ===== */
.page{display:block;position:relative;z-index:10;animation:fadeIn .55s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
section.block{padding:80px 0}
@media(max-width:720px){section.block{padding:56px 0}}

/* ===== HERO ===== */
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--forest-dark),var(--forest-medium));color:#fff;padding:110px 0 120px;text-align:center}
.hero h1{color:#fff;margin:18px 0 18px}
.hero p.lead{color:rgba(255,255,255,.85);max-width:760px;margin:0 auto 32px;font-size:1.1rem}
.hero-badge{display:inline-block;background:rgba(255,255,255,.12);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 18px;border-radius:50px;font-weight:600;font-size:.9rem}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.btn{display:inline-block;border:none;cursor:pointer;font-family:var(--font-heading);font-weight:700;padding:14px 32px;border-radius:50px;font-size:1rem;transition:all .25s;text-align:center}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-hover);transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-lg)}
.btn-secondary{background:var(--forest-light);color:#fff}
.btn-secondary:hover{background:var(--forest-medium);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border:2px solid #fff}
.btn-outline:hover{background:#fff;color:var(--forest-dark)}

/* particles */
.particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.particle{position:absolute;border-radius:50%;opacity:.4;animation:float linear infinite}
@keyframes float{
  0%{transform:translateY(100vh) translateX(0) rotate(0);opacity:0}
  10%{opacity:.5}
  90%{opacity:.5}
  100%{transform:translateY(-10vh) translateX(40px) rotate(360deg);opacity:0}
}
.scroll-indicator{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:1.5rem;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ===== SECTION HEADINGS ===== */
.section-head{text-align:center;max-width:760px;margin:0 auto 48px}
.section-head h2{margin-bottom:14px}
.section-head .underline{width:60px;height:3px;background:var(--orange);margin:14px auto 18px;border-radius:2px}
.section-head p{color:var(--earth-medium)}
.dark-bg .section-head h2,.dark-bg h2,.dark-bg h3{color:#fff}
.dark-bg .section-head p,.dark-bg p{color:rgba(255,255,255,.85)}

/* ===== BACKGROUNDS ===== */
.bg-light{background:var(--sand-light)}
.bg-mint{background:var(--forest-mint)}
.bg-dark{background:var(--forest-dark);color:#fff}
.bg-dark p{color:rgba(255,255,255,.85)}
.bg-warm{background:var(--sand-dark)}

/* ===== CARDS ===== */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:960px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-3,.grid-4,.grid-2{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--sand-dark);border-radius:16px;padding:28px;box-shadow:var(--shadow-md);transition:all .3s ease}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.card .emoji{font-size:2.4rem;display:block;margin-bottom:14px}
.card h3{color:var(--forest-dark);margin-bottom:10px}
.card p{color:var(--earth-medium)}
.badge{display:inline-block;padding:5px 14px;border-radius:50px;font-weight:600;font-size:.8rem;margin-top:14px}
.badge-program{background:var(--orange-light);color:var(--orange)}
.badge-category{background:var(--forest-mint);color:var(--forest-medium)}
.badge-highlight{background:var(--sunset-yellow);color:var(--earth-brown)}
.badge-info{background:var(--sky-light);color:var(--sky-blue)}

/* ===== MISSION BANNER ===== */
.mission-banner{background:linear-gradient(135deg,var(--forest-medium),var(--forest-light));color:#fff;text-align:center;padding:60px 24px}
.mission-banner p{color:#fff;font-family:var(--font-heading);font-weight:700;font-size:clamp(1.2rem,2.4vw,1.7rem);max-width:1000px;margin:0 auto;line-height:1.5}

/* ===== CHARACTER SCROLL ===== */
.character-row{display:flex;gap:24px;overflow-x:auto;padding:10px 4px 24px;scroll-snap-type:x mandatory;scrollbar-width:thin}
.character-card{flex:0 0 240px;background:#fff;border-radius:20px;padding:24px;text-align:center;box-shadow:var(--shadow-md);scroll-snap-align:start;transition:transform .3s}
.character-card:hover{transform:translateY(-6px)}
.avatar{width:110px;height:110px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff;box-shadow:var(--shadow-md)}
.avatar-liam{background:linear-gradient(135deg,var(--forest-medium),var(--forest-light))}
.avatar-maya{background:linear-gradient(135deg,var(--sky-blue),var(--forest-light))}
.avatar-oliver{background:linear-gradient(135deg,var(--orange),var(--sunset-yellow))}
.avatar-jayden{background:linear-gradient(135deg,var(--forest-dark),var(--forest-medium))}
.avatar-zoey{background:linear-gradient(135deg,var(--forest-light),var(--sky-blue))}
.character-card h3{color:var(--forest-dark);margin-bottom:6px}
.character-card .role{display:inline-block;background:var(--orange-light);color:var(--orange);font-size:.78rem;padding:4px 12px;border-radius:50px;font-weight:600;margin-bottom:10px}

/* ===== CHECKLIST ===== */
.checklist{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:960px){.checklist{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.checklist{grid-template-columns:1fr}}
.check-item{display:flex;align-items:center;gap:12px;background:#fff;padding:18px;border-radius:14px;border:1px solid var(--sand-dark);box-shadow:var(--shadow-sm);color:var(--slate-dark);font-weight:500}
.check-item::before{content:"✓";color:#fff;background:var(--forest-light);width:28px;height:28px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}

/* ===== EVENT BADGES (home preview) ===== */
.event-row{display:flex;gap:18px;overflow-x:auto;padding:10px 4px 20px}
.event-pill{flex:0 0 280px;background:#fff;border:2px solid var(--sand-dark);border-radius:18px;padding:22px;text-align:center;font-weight:600;color:var(--forest-dark);position:relative;animation:pulseBorder 2.5s infinite}
@keyframes pulseBorder{0%,100%{border-color:var(--sand-dark)}50%{border-color:var(--orange)}}
.event-pill .emoji{font-size:2rem;display:block;margin-bottom:10px}

/* ===== CTA SECTION ===== */
.cta-section{background:linear-gradient(135deg,var(--forest-dark),var(--forest-medium));color:#fff;text-align:center;padding:80px 24px}
.cta-section h2{color:#fff;margin-bottom:18px}
.cta-section p{color:rgba(255,255,255,.85);max-width:720px;margin:0 auto 24px}
.cta-contact{margin-top:30px;color:rgba(255,255,255,.85);font-size:.95rem;line-height:2}
.cta-contact div{display:inline-block;margin:0 14px}
.tagline{font-family:var(--font-heading);font-weight:700;color:var(--sunset-yellow);letter-spacing:2px;margin-top:18px}

/* ===== FOOTER ===== */
footer{background:var(--forest-dark);color:rgba(255,255,255,.75);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1.2fr;gap:40px}
@media(max-width:960px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
footer h4{color:var(--sunset-yellow);font-family:var(--font-heading);font-weight:700;margin-bottom:18px;font-size:1.05rem}
footer ul{list-style:none}
footer ul li{margin-bottom:10px}
footer ul a,footer .col p,footer .col{color:rgba(255,255,255,.75);font-size:.92rem;transition:color .2s;cursor:pointer}
footer ul a:hover{color:var(--forest-light)}
.social-row{display:flex;gap:10px;margin-top:14px}
.social-icon{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .25s}
.social-icon:hover{background:var(--forest-light);transform:translateY(-3px)}
.footer-bottom{background:var(--earth-brown);color:rgba(255,255,255,.5);text-align:center;padding:18px 24px;margin-top:50px;font-size:.85rem}
.footer-bottom .tagline{display:inline-block;margin-left:18px;color:var(--sunset-yellow)}

/* ===== ABOUT - STORY ===== */
.story-block{background:#fff;border-left:6px solid var(--orange);padding:38px;border-radius:16px;box-shadow:var(--shadow-md);font-size:1.05rem;line-height:1.85;position:relative}
.story-block::before{content:"\201C";position:absolute;top:-18px;left:24px;font-size:5rem;color:var(--orange-light);font-family:Georgia,serif;line-height:1}
.story-block p{color:var(--earth-medium)}
.story-block p + p{margin-top:16px}

/* mission/vision cards */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:760px){.mv-grid{grid-template-columns:1fr}}
.mv-card{padding:40px;border-radius:20px;color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.mv-mission{background:var(--forest-dark);border-top:6px solid var(--forest-light)}
.mv-vision{background:var(--orange);border-top:6px solid var(--orange-hover)}
.mv-card h3{color:#fff;font-size:1.6rem;margin-bottom:16px}
.mv-card .icon{font-size:2.5rem;margin-bottom:10px;display:block}
.mv-card p{color:rgba(255,255,255,.92)}

/* program pills */
.program-pills{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.program-pill{background:#fff;color:var(--forest-dark);border:2px solid var(--forest-mint);padding:12px 22px;border-radius:50px;font-weight:600;font-family:var(--font-heading);transition:all .25s;cursor:pointer}
.program-pill:hover{background:var(--forest-light);color:#fff;border-color:var(--forest-light);transform:translateY(-3px)}

/* founder */
.founder{display:flex;gap:32px;align-items:center;background:linear-gradient(135deg,var(--forest-mint),var(--sand-dark));padding:48px;border-radius:24px;box-shadow:var(--shadow-md)}
@media(max-width:720px){.founder{flex-direction:column;text-align:center;padding:32px}}
.founder-avatar{width:160px;height:160px;border-radius:50%;background:linear-gradient(135deg,var(--forest-dark),var(--forest-light));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:800;font-size:3.5rem;flex-shrink:0;box-shadow:var(--shadow-lg)}
.founder-info h3{font-size:1.8rem;margin-bottom:4px}
.founder-info .title{color:var(--orange);font-weight:600;margin-bottom:14px}
.founder-info p{color:var(--earth-medium);font-style:italic;line-height:1.8}

/* ===== PROGRAMS PAGE ===== */
.feature-program{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;background:#fff;padding:48px;border-radius:24px;box-shadow:var(--shadow-md);border:1px solid var(--sand-dark)}
@media(max-width:860px){.feature-program{grid-template-columns:1fr;padding:32px}}
.feature-program .visual{background:linear-gradient(135deg,var(--forest-mint),var(--sky-light));border-radius:18px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:8rem;box-shadow:inset 0 0 40px rgba(0,0,0,.05)}
.subject-pills{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0 24px}
.subject-pill{background:var(--forest-mint);color:var(--forest-medium);padding:8px 16px;border-radius:50px;font-weight:600;font-size:.88rem}

.program-detail{display:grid;grid-template-columns:80px 1fr auto;gap:28px;align-items:center;background:#fff;padding:32px;border-radius:20px;box-shadow:var(--shadow-md);border:1px solid var(--sand-dark);transition:all .3s;margin-bottom:20px}
.program-detail:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--orange-light)}
.program-detail .big-emoji{font-size:3.5rem;text-align:center}
@media(max-width:720px){.program-detail{grid-template-columns:1fr;text-align:center}}

.homeschool-band{background:linear-gradient(135deg,var(--sunset-yellow),var(--orange));color:#fff;padding:60px 40px;border-radius:24px;text-align:center}
.homeschool-band h2{color:#fff;margin-bottom:16px}
.homeschool-band p{color:rgba(255,255,255,.95);max-width:780px;margin:0 auto 24px;font-size:1.05rem}

/* ===== BOOKSTORE ===== */
.category-card{background:#fff;border:1px solid var(--sand-dark);border-radius:18px;padding:28px;text-align:center;cursor:pointer;transition:all .3s;box-shadow:var(--shadow-sm)}
.category-card:hover{transform:scale(1.03);box-shadow:var(--shadow-lg);border-color:var(--orange)}
.category-card .emoji{font-size:3rem;display:block;margin-bottom:14px;transition:transform .3s}
.category-card:hover .emoji{transform:scale(1.15)}
.category-card h3{margin-bottom:8px}

.product-card{background:#fff;border:2px solid var(--sand-dark);border-radius:18px;overflow:hidden;transition:all .3s;display:flex;flex-direction:column}
.product-card:hover{transform:translateY(-6px);border-color:var(--orange);box-shadow:var(--shadow-lg)}
.product-cover{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:4.5rem;background:linear-gradient(135deg,var(--forest-mint),var(--sky-light));position:relative;transition:transform .4s}
.product-card:nth-child(2n) .product-cover{background:linear-gradient(135deg,var(--orange-light),var(--sunset-yellow))}
.product-card:nth-child(3n) .product-cover{background:linear-gradient(135deg,var(--sky-light),var(--forest-mint))}
.product-card:nth-child(4n) .product-cover{background:linear-gradient(135deg,var(--sand-dark),var(--orange-light))}
.product-card:hover .product-cover{transform:scale(1.08)}
.price-badge{position:absolute;top:14px;right:14px;background:var(--sunset-yellow);color:var(--earth-brown);font-weight:700;padding:6px 14px;border-radius:50px;font-size:.85rem}
.product-body{padding:20px;display:flex;flex-direction:column;flex:1}
.product-body h3{font-size:1.1rem;margin-bottom:8px}
.product-body p{font-size:.92rem;flex:1;margin-bottom:14px}
.add-cart{background:var(--forest-light);color:#fff;border:none;font-family:var(--font-heading);font-weight:700;padding:11px 18px;border-radius:50px;cursor:pointer;transition:all .25s;margin-top:auto}
.add-cart:hover{background:var(--forest-medium);transform:scale(1.04)}

.notice-band{background:var(--sky-light);border:2px solid var(--sky-blue);border-radius:20px;padding:40px;text-align:center}
.notice-band p{color:var(--slate-dark);margin-bottom:20px;font-size:1.05rem}

/* ===== ADVENTURES ===== */
.filter-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.filter-pill{background:var(--sand-dark);color:var(--earth-medium);border:none;padding:10px 22px;border-radius:50px;font-family:var(--font-heading);font-weight:600;cursor:pointer;transition:all .25s}
.filter-pill:hover,.filter-pill.active{background:var(--forest-dark);color:#fff}

.adventure-card{background:#fff;border:2px solid var(--sand-dark);border-radius:20px;padding:28px;box-shadow:var(--shadow-md);transition:all .3s;display:flex;flex-direction:column}
.adventure-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);animation:pulseBorder 1.8s infinite}
.adventure-card .emoji{font-size:3rem;margin-bottom:14px;display:block}
.adventure-card h3{margin-bottom:10px}
.adventure-card p{flex:1;margin-bottom:14px}
.cat-outdoor{background:var(--forest-light);color:#fff}
.cat-stem{background:var(--sky-blue);color:#fff}
.cat-field{background:var(--orange);color:#fff}
.cat-leadership{background:var(--sunset-yellow);color:var(--earth-brown)}
.cat-camps{background:var(--forest-medium);color:#fff}
.cat-community{background:var(--earth-medium);color:#fff}
.cat-family{background:var(--forest-light);color:#fff}

/* ===== ENROLL ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
@media(max-width:860px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--sand-dark);border-radius:18px;padding:28px 22px;text-align:center;box-shadow:var(--shadow-md);position:relative}
.step-num{width:54px;height:54px;border-radius:50%;background:var(--orange);color:#fff;font-family:var(--font-heading);font-weight:800;font-size:1.4rem;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:var(--shadow-md)}
.step .emoji{font-size:2rem;display:block;margin-bottom:10px}
.step h3{font-size:1.1rem;margin-bottom:8px}
.step p{font-size:.92rem}
@media(min-width:861px){
  .step:not(:last-child)::after{content:"";position:absolute;top:50px;right:-16px;width:32px;border-top:2px dashed var(--sand-dark);animation:dashMove 2s linear infinite}
}
@keyframes dashMove{from{background-position:0}to{background-position:20px}}

.quick-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:760px){.quick-pick{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.quick-pick{grid-template-columns:1fr}}
.pick{background:#fff;border:2px solid var(--sand-dark);border-radius:16px;padding:24px;text-align:center;cursor:pointer;font-family:var(--font-heading);font-weight:700;color:var(--forest-dark);transition:all .25s}
.pick:hover,.pick.selected{border-color:var(--orange);background:var(--orange-light);transform:translateY(-3px)}
.pick .emoji{font-size:2rem;display:block;margin-bottom:8px}

.form-card{background:#fff;border-radius:24px;padding:40px;box-shadow:var(--shadow-lg);border:1px solid var(--sand-dark);max-width:880px;margin:0 auto}
.form-card h3{margin-bottom:24px;text-align:center;color:var(--forest-dark)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1 / -1}
.field label{font-family:var(--font-heading);color:var(--forest-dark);font-weight:600;font-size:.92rem}
.field input,.field textarea,.field select{background:#fff;border:2px solid var(--sand-dark);border-radius:12px;padding:13px 16px;font-family:var(--font-sans);font-size:.95rem;color:var(--slate-dark);transition:border-color .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--forest-light)}
.field input::placeholder,.field textarea::placeholder{color:rgba(0,0,0,.35)}
.form-card .note{text-align:center;margin-top:18px;color:var(--earth-medium);font-size:.9rem}

.contact-card{background:#fff;border:1px solid var(--sand-dark);border-radius:18px;padding:32px;text-align:center;box-shadow:var(--shadow-md);transition:transform .3s}
.contact-card:hover{transform:translateY(-4px)}
.contact-card .emoji{font-size:2.2rem;display:block;margin-bottom:12px}
.contact-card h3{margin-bottom:10px}

.portal-band{background:var(--forest-dark);color:#fff;border-radius:24px;padding:48px;text-align:center}
.portal-band h2{color:#fff;margin-bottom:24px}
.portal-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.portal-buttons .btn{min-width:200px}
.btn-parent{background:var(--orange);color:#fff}
.btn-parent:hover{background:var(--orange-hover)}
.btn-student{background:var(--forest-light);color:#fff}
.btn-student:hover{background:var(--forest-medium)}
.btn-staff{background:var(--sky-blue);color:#fff}
.btn-staff:hover{background:#026aa5}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* utility */
.center{text-align:center}
.mt-32{margin-top:32px}
.lead{font-size:1.05rem}

/* ===== AMBIENT BACKGROUND ANIMATIONS ===== */
.ambient-layer{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.ambient-cloud{position:absolute;background:radial-gradient(ellipse at center,rgba(255,255,255,.85),rgba(255,255,255,0) 70%);border-radius:50%;filter:blur(2px);opacity:.55}
.a-cloud-1{width:260px;height:90px;top:8%;left:-300px;animation:cloudDrift 70s linear infinite}
.a-cloud-2{width:340px;height:110px;top:22%;left:-400px;animation:cloudDrift 95s linear infinite;animation-delay:-30s;opacity:.4}
.a-cloud-3{width:200px;height:70px;top:14%;left:-250px;animation:cloudDrift 55s linear infinite;animation-delay:-15s;opacity:.5}
@keyframes cloudDrift{from{transform:translateX(0)}to{transform:translateX(calc(100vw + 500px))}}

.firefly{position:absolute;width:6px;height:6px;border-radius:50%;background:#fff7a8;box-shadow:0 0 12px 4px rgba(255,239,120,.7);opacity:0}
.ff-1{top:60%;left:10%;animation:fireflyFloat 9s ease-in-out infinite}
.ff-2{top:75%;left:25%;animation:fireflyFloat 11s ease-in-out infinite;animation-delay:-2s}
.ff-3{top:65%;left:45%;animation:fireflyFloat 8s ease-in-out infinite;animation-delay:-4s}
.ff-4{top:80%;left:65%;animation:fireflyFloat 12s ease-in-out infinite;animation-delay:-1s}
.ff-5{top:55%;left:80%;animation:fireflyFloat 10s ease-in-out infinite;animation-delay:-6s}
.ff-6{top:70%;left:92%;animation:fireflyFloat 9s ease-in-out infinite;animation-delay:-3s}
@keyframes fireflyFloat{0%,100%{transform:translate(0,0);opacity:0}25%{opacity:.9}50%{transform:translate(40px,-60px);opacity:.6}75%{opacity:.9}}

.swaying-tree{position:absolute;width:90px;height:260px;opacity:.18;fill:#143622;stroke:#143622;transform-origin:bottom center;animation:treeSway 8s ease-in-out infinite}
.tree-left-1{bottom:0;left:1%;animation-delay:-1s}
.tree-left-2{bottom:0;left:6%;height:200px;width:70px;animation-delay:-3s;opacity:.13}
.tree-right-1{bottom:0;right:1%;animation-delay:-2s}
.tree-right-2{bottom:0;right:7%;height:210px;width:75px;animation-delay:-5s;opacity:.13}
@keyframes treeSway{0%,100%{transform:rotate(-1.5deg)}50%{transform:rotate(1.5deg)}}

.soaring-eagle{position:absolute;width:42px;height:18px;left:-60px;background:radial-gradient(ellipse at center,#3e2723 30%,transparent 70%);clip-path:polygon(0 50%,30% 30%,50% 50%,70% 30%,100% 50%,70% 70%,50% 50%,30% 70%);opacity:.55;animation:eagleSoar 45s linear infinite}
.eagle-2{animation-duration:60s;animation-delay:-20s;opacity:.4;transform:scale(.8)}
@keyframes eagleSoar{0%{transform:translate(0,0)}50%{transform:translate(50vw,40px)}100%{transform:translate(calc(100vw + 80px),0)}}

.bounding-deer{position:absolute;width:50px;height:32px;left:-80px;background:#8b5a2b;border-radius:30% 60% 40% 20%;opacity:0;animation:deerBound 35s linear infinite}
.bounding-deer::before{content:"";position:absolute;right:-6px;top:-10px;width:14px;height:18px;background:#8b5a2b;border-radius:50% 60% 30% 40%}
.deer-2{animation-duration:50s;animation-delay:-15s}
@keyframes deerBound{0%{transform:translate(0,0);opacity:0}5%{opacity:.5}50%{transform:translate(50vw,-15px)}95%{opacity:.5}100%{transform:translate(calc(100vw + 100px),0);opacity:0}}

/* Cursor trail canvas */
#cursorCanvas{position:fixed;inset:0;pointer-events:none;z-index:9998;mix-blend-mode:screen}

/* Mouse parallax glow follower */
.mouse-glow{position:fixed;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.18),rgba(55,150,91,.08) 40%,transparent 70%);pointer-events:none;z-index:2;transform:translate(-50%,-50%);transition:transform .12s ease-out;filter:blur(20px)}

/* Make page content sit above ambient */
.header,main,footer{position:relative;z-index:10}

/* ===== GALLERY ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:30px}
.gallery-item{position:relative;aspect-ratio:1/1;border-radius:18px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-md);transition:transform .3s,box-shadow .3s;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.4)}
.gallery-item:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-lg)}
.gallery-item::after{content:attr(data-caption);position:absolute;left:0;right:0;bottom:0;padding:14px 16px;background:linear-gradient(transparent,rgba(0,0,0,.75));color:#fff;font-family:var(--font-heading);font-weight:700;font-size:.92rem;text-shadow:none;opacity:0;transition:opacity .3s;text-align:left}
.gallery-item:hover::after{opacity:1}
.gallery-item.size-tall{aspect-ratio:1/1.4}
.gallery-item.size-wide{aspect-ratio:1.6/1;grid-column:span 2}
.g-1{background:linear-gradient(135deg,#37965b,#143622)}
.g-2{background:linear-gradient(135deg,#e65f2b,#f59e0b)}
.g-3{background:linear-gradient(135deg,#0284c7,#37965b)}
.g-4{background:linear-gradient(135deg,#5d4037,#8b5a2b)}
.g-5{background:linear-gradient(135deg,#f59e0b,#e65f2b)}
.g-6{background:linear-gradient(135deg,#215c38,#37965b)}
.g-7{background:linear-gradient(135deg,#3e2723,#5d4037)}
.g-8{background:linear-gradient(135deg,#0284c7,#1e293b)}
.g-9{background:linear-gradient(135deg,#37965b,#f59e0b)}
.gallery-filter{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:12px}

/* ===== PORTAL ===== */
.portal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:36px}
.portal-tile{background:#fff;border-radius:24px;padding:34px 28px;text-align:center;box-shadow:var(--shadow-md);transition:transform .3s,box-shadow .3s;border-top:6px solid var(--forest-light)}
.portal-tile:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.portal-tile.parent{border-color:var(--orange)}
.portal-tile.student{border-color:var(--sky-blue)}
.portal-tile.staff{border-color:var(--forest-light)}
.portal-tile .emoji{font-size:3.4rem;display:block;margin-bottom:14px}
.portal-tile h3{margin-bottom:10px}
.portal-login{max-width:440px;margin:50px auto 0;background:#fff;padding:36px;border-radius:24px;box-shadow:var(--shadow-lg)}
.portal-login h3{text-align:center;margin-bottom:20px}
.portal-login input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;margin-bottom:14px;font-family:inherit;transition:border .2s}
.portal-login input:focus{outline:none;border-color:var(--forest-light)}
.portal-login .btn{width:100%}
.portal-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:30px}
.portal-feature{padding:18px;background:var(--forest-mint);border-radius:14px;text-align:center}
.portal-feature .emoji{font-size:2rem;display:block;margin-bottom:8px}

/* ===== HERO SLIDER (rounded card, ref-style) ===== */
.hero-slider-wrap{padding:28px 24px 40px;max-width:1280px;margin:0 auto}
.hero-slider{position:relative;border-radius:28px;overflow:hidden;min-height:520px;box-shadow:0 20px 50px -20px rgba(20,54,34,.4);border:1px solid rgba(0,0,0,.05)}
.hs-slide{position:absolute;inset:0;display:flex;align-items:center;padding:60px 80px;opacity:0;transition:opacity .8s ease;pointer-events:none;background-size:cover;background-position:center}
.hs-slide.active{opacity:1;pointer-events:auto}
.hs-slide::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(20,54,34,.55),rgba(2,132,199,.45))}
.hs-slide[data-theme="stem"]::before{background:linear-gradient(135deg,rgba(20,54,34,.7) 0%,rgba(55,150,91,.55) 40%,rgba(2,132,199,.65) 100%)}
.hs-slide[data-theme="survival"]::before{background:linear-gradient(135deg,rgba(94,30,15,.7),rgba(230,95,43,.65))}
.hs-slide[data-theme="leadership"]::before{background:linear-gradient(135deg,rgba(30,41,59,.7),rgba(2,132,199,.6))}
.hs-slide[data-theme="creative"]::before{background:linear-gradient(135deg,rgba(124,45,18,.6),rgba(245,158,11,.6))}
.hs-slide[data-theme="field"]::before{background:linear-gradient(135deg,rgba(20,54,34,.7),rgba(245,158,11,.55))}
.hs-slide[data-theme="tutor"]::before{background:linear-gradient(135deg,rgba(15,23,42,.75),rgba(55,150,91,.5))}
.hs-content{position:relative;z-index:2;max-width:640px;color:#fff}
.hs-title{font-family:var(--font-heading);font-weight:800;font-size:clamp(2rem,4.6vw,3.4rem);color:#fff;line-height:1.05;margin-bottom:14px;text-shadow:0 2px 20px rgba(0,0,0,.25)}
.hs-sub{font-family:var(--font-heading);font-weight:700;color:var(--sunset-yellow);font-size:clamp(1.05rem,2vw,1.45rem);margin-bottom:18px}
.hs-desc{color:rgba(255,255,255,.92);font-size:1.05rem;max-width:560px;margin-bottom:28px;line-height:1.6}
.hs-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hs-ctas .btn{padding:13px 26px;font-size:.95rem;box-shadow:0 6px 18px -6px rgba(0,0,0,.4)}
.btn-ghost-dark{background:rgba(20,54,34,.85);color:#fff}
.btn-ghost-dark:hover{background:var(--forest-dark)}
.hs-character{position:absolute;right:5%;top:50%;transform:translateY(-50%);width:clamp(180px,26vw,320px);z-index:2;filter:drop-shadow(0 12px 24px rgba(0,0,0,.35));animation:floatChar 5s ease-in-out infinite}
@keyframes floatChar{0%,100%{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 14px))}}
.hs-character .ring{aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.95) 0%,rgba(255,255,255,.7) 60%,transparent 75%);display:flex;align-items:center;justify-content:center;font-size:clamp(80px,14vw,180px)}
.hs-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;width:48px;height:48px;border-radius:50%;font-size:28px;cursor:pointer;z-index:5;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .2s}
.hs-arrow:hover{background:var(--orange);transform:translateY(-50%) scale(1.08)}
.hs-prev{left:18px}.hs-next{right:18px}
.hs-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:5}
.hs-dots button{width:10px;height:10px;border-radius:50%;border:none;background:rgba(255,255,255,.45);cursor:pointer;padding:0;transition:all .25s}
.hs-dots button.active{background:var(--orange);width:28px;border-radius:6px}
@media(max-width:760px){
  .hs-slide{padding:40px 28px;align-items:flex-start;padding-top:56px}
  .hs-character{display:none}
  .hero-slider{min-height:460px}
}

/* ===== ENGAGEMENT WIDGET (bottom-right) ===== */
.eng-widget{position:fixed;right:22px;bottom:22px;z-index:9998;font-family:var(--font-sans)}
.eng-fab{width:68px;height:68px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#8b5a2b,#5a3a1c);color:#ffd98a;border:4px solid #c98a4b;box-shadow:0 12px 30px -6px rgba(0,0,0,.45),inset 0 0 0 2px rgba(255,217,138,.25);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:30px;transition:transform .25s;position:relative;animation:fabPulse 2.4s ease-in-out infinite}
.eng-fab:hover{transform:scale(1.08) rotate(10deg)}
@keyframes fabPulse{0%,100%{box-shadow:0 12px 30px -6px rgba(0,0,0,.45),inset 0 0 0 2px rgba(255,217,138,.25),0 0 0 0 rgba(230,95,43,.55)}50%{box-shadow:0 12px 30px -6px rgba(0,0,0,.45),inset 0 0 0 2px rgba(255,217,138,.25),0 0 0 14px rgba(230,95,43,0)}}
.eng-badge{position:absolute;top:-6px;right:-6px;background:var(--orange);color:#fff;font-weight:800;font-size:.75rem;padding:4px 9px;border-radius:50px;border:2px solid #fff;min-width:30px;text-align:center;box-shadow:0 4px 10px rgba(230,95,43,.4)}
.eng-panel{position:absolute;bottom:84px;right:0;width:360px;background:#f5ead4;border-radius:18px;box-shadow:0 24px 60px -15px rgba(0,0,0,.35);overflow:hidden;transform-origin:bottom right;transform:scale(.85);opacity:0;pointer-events:none;transition:all .28s cubic-bezier(.4,1.5,.6,1);border:1px solid rgba(0,0,0,.08);background-image:radial-gradient(circle at 1px 1px,rgba(139,90,43,.12) 1px,transparent 0);background-size:14px 14px}
.eng-panel.open{transform:scale(1);opacity:1;pointer-events:auto}
.eng-head{padding:18px 22px 14px;background:#f5ead4;border-bottom:1px solid rgba(139,90,43,.18)}
.eng-head-row{display:flex;align-items:center;gap:10px;justify-content:space-between;margin-bottom:14px}
.eng-head-title{display:flex;align-items:center;gap:10px}
.eng-head-title .badge-ico{width:34px;height:34px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#c98a4b,#7a4a1f);color:#ffd98a;display:flex;align-items:center;justify-content:center;font-size:18px;border:2px solid #7a4a1f}
.eng-head-title h4{color:var(--forest-dark);font-family:var(--font-heading);font-size:1.05rem;margin:0;letter-spacing:.04em;border-bottom:2px solid var(--orange);padding-bottom:3px}
.eng-close{background:none;border:none;font-size:1.3rem;color:#5a3a1c;cursor:pointer;line-height:1;padding:4px}
.eng-progress-label{display:flex;justify-content:space-between;font-size:.9rem;font-weight:700;color:var(--forest-dark);margin-bottom:6px}
.eng-progress{height:8px;background:rgba(139,90,43,.18);border-radius:50px;overflow:hidden}
.eng-progress-bar{height:100%;background:var(--orange);width:0;transition:width .6s ease;border-radius:50px}
.eng-list{padding:12px;max-height:360px;overflow-y:auto;display:flex;flex-direction:column;gap:10px}
.eng-item{display:flex;align-items:flex-start;gap:12px;padding:14px 14px;border-radius:14px;background:#fff;border:1.5px solid rgba(139,90,43,.18);cursor:pointer;transition:all .2s;text-align:left}
.eng-item:hover{transform:translateY(-1px);box-shadow:0 6px 14px -6px rgba(0,0,0,.15)}
.eng-item.visited{background:#e6efd9;border-color:#a3c47a}
.eng-check{width:22px;height:22px;border-radius:6px;background:#fff;border:2px solid #b8a37f;color:#2e7d32;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex-shrink:0;margin-top:2px;transition:all .3s}
.eng-item.visited .eng-check{background:#2e7d32;border-color:#2e7d32;color:#fff}
.eng-item-body{flex:1;min-width:0}
.eng-item-title{font-family:var(--font-heading);font-weight:800;color:var(--forest-dark);font-size:.98rem;margin-bottom:3px;letter-spacing:.01em}
.eng-item.visited .eng-item-title{text-decoration:line-through;color:#4a6e35}
.eng-item-desc{font-size:.82rem;color:#6b5a40;line-height:1.4;margin:0}
.eng-foot{padding:12px;background:#f5ead4;border-top:1px solid rgba(139,90,43,.18)}
.eng-reset{width:100%;background:#fff;border:1.5px solid rgba(139,90,43,.25);color:var(--forest-dark);font-weight:700;cursor:pointer;font-size:.85rem;padding:10px;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}
.eng-reset:hover{background:#ede1c6}

/* ===== GATE MODAL ===== */
.gate-overlay{position:fixed;inset:0;z-index:10000;background:repeating-linear-gradient(0deg,#3e2723 0px,#3e2723 60px,#2c1a17 60px,#2c1a17 64px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .4s}
.gate-overlay.open{opacity:1;pointer-events:auto}
.gate-overlay::before,.gate-overlay::after{content:"";position:absolute;width:30px;height:30px;border-radius:50%;background:radial-gradient(circle,#37965b,#143622);box-shadow:60px 80px 0 #37965b,180px 30px 0 #37965b,calc(100vw - 60px) 100px 0 #37965b,calc(100vw - 140px) 220px 0 #37965b,90px 380px 0 #37965b,calc(100vw - 90px) 420px 0 #37965b;opacity:.85;animation:fireflyFloat 6s ease-in-out infinite}
.gate-card{background:var(--sand-light);border-radius:28px;padding:44px 36px 32px;max-width:440px;width:100%;text-align:center;box-shadow:0 30px 80px -20px rgba(0,0,0,.5);border:3px dashed var(--forest-light);position:relative;z-index:2;animation:gateIn .5s cubic-bezier(.4,1.6,.6,1)}
@keyframes gateIn{from{transform:scale(.85) translateY(20px);opacity:0}to{transform:scale(1);opacity:1}}
.gate-logo{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--forest-light),var(--sunset-yellow));margin:0 auto 18px;display:flex;align-items:center;justify-content:center;font-size:42px;box-shadow:var(--shadow-lg)}
.gate-card h2{font-size:1.85rem;margin-bottom:8px;color:var(--forest-dark)}
.gate-tag{color:var(--orange);font-family:var(--font-heading);font-weight:700;letter-spacing:2px;font-size:.85rem;margin-bottom:14px}
.gate-card p{color:var(--earth-medium);font-size:.95rem;margin-bottom:24px}
.gate-compass{width:74px;height:74px;border-radius:50%;border:3px solid var(--orange);margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--orange);cursor:pointer;transition:all .3s;animation:compassSpin 8s linear infinite}
.gate-compass:hover{transform:scale(1.1);background:var(--orange-light)}
@keyframes compassSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.gate-hint{font-size:.7rem;color:#94a3b8;letter-spacing:2px;margin-bottom:22px;font-weight:600}
.gate-cta{width:100%;background:linear-gradient(135deg,var(--orange),var(--orange-hover));color:#fff;border:none;padding:16px 24px;border-radius:14px;font-family:var(--font-heading);font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 8px 20px -6px rgba(230,95,43,.6);transition:transform .2s}
.gate-cta:hover{transform:translateY(-2px)}
.gate-skip{background:none;border:none;color:var(--earth-medium);text-decoration:underline;font-size:.85rem;margin-top:14px;cursor:pointer}
.gate-skip:hover{color:var(--orange)}

/* ===== SCREEN-READER TEXT (WordPress core class) ===== */
.screen-reader-text{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link.screen-reader-text{z-index:100000;position:fixed;left:6px;top:6px;background:var(--forest-dark);color:#fff;padding:12px 18px;border-radius:8px}
.skip-link.screen-reader-text:focus{clip:auto;width:auto;height:auto}
