/*
Theme Name: Green Peace School
Theme URI: https://greenpeaceschool.example
Author: Green Peace School
Author URI: https://greenpeaceschool.example
Description: Ultra-premium cinematic theme for Green Peace School Karachi. Fully customizable via Appearance → Customize — every image, color, headline, stat, program, testimonial, contact detail, and footer element can be edited or removed without touching code.
Version: 1.0.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: greenpeace
Tags: education, school, custom-logo, custom-colors, custom-background, custom-header, full-width-template, theme-options, footer-widgets
*/

/* ============ Design tokens ============ */
:root{
  --emerald-deep:#1a5d3a;
  --emerald:#2a8b5b;
  --emerald-glow:#4fc28a;
  --navy-deep:#0b1224;
  --navy:#142146;
  --gold:#d6b454;
  --gold-soft:#ecd58a;
  --ivory:#f8f5ea;
  --bg:#f8f5ea;
  --fg:#0b1224;
  --muted:#5a6175;
  --card:#ffffff;
  --border:#e3e6ea;
  --gradient-hero:linear-gradient(135deg,#0b1224 0%,#102047 40%,#1a5a55 75%,#2a8b5b 100%);
  --gradient-emerald:linear-gradient(135deg,#1a5d3a 0%,#2a8b5b 100%);
  --gradient-gold:linear-gradient(135deg,#d6b454,#ecd58a);
  --shadow-glow:0 0 60px rgba(42,139,91,.35),0 0 120px rgba(79,194,138,.18);
  --shadow-elegant:0 24px 60px -20px rgba(11,18,36,.35);
  --shadow-card:0 10px 40px -10px rgba(11,18,36,.18);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;line-height:1.55}
h1,h2,h3,h4{font-family:'Fraunces','Cormorant Garamond',Georgia,serif;letter-spacing:-.02em;margin:0;line-height:1.1}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--emerald-deep)}
.eyebrow:before{content:"";display:inline-block;width:32px;height:1px;background:rgba(26,93,58,.5)}
.eyebrow.light{color:var(--gold-soft)}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:14px 28px;font-weight:500;font-size:15px;transition:.3s;cursor:pointer;border:0}
.btn-gold{background:var(--gold);color:var(--navy-deep);box-shadow:0 0 40px rgba(214,180,84,.45)}
.btn-gold:hover{filter:brightness(1.1)}
.btn-glass{background:rgba(255,255,255,.1);color:var(--ivory);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(20px)}
.btn-glass:hover{background:rgba(255,255,255,.18)}
.glass{background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.04));backdrop-filter:blur(20px) saturate(160%);border:1px solid rgba(255,255,255,.15)}
.glass-dark{background:linear-gradient(135deg,rgba(11,18,36,.55),rgba(11,18,36,.25));backdrop-filter:blur(24px) saturate(160%);border:1px solid rgba(255,255,255,.1)}
.gradient-text-gold{background:var(--gradient-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.gradient-text-emerald{background:linear-gradient(135deg,var(--emerald-glow),var(--gold-soft));-webkit-background-clip:text;background-clip:text;color:transparent}
.section{padding:112px 24px}
.section-dark{background:var(--navy-deep);color:var(--ivory)}
.section-soft{background:rgba(42,139,91,.06)}

/* ============ Nav ============ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;padding:16px 24px;transition:.5s}
.site-header.scrolled{padding:8px 24px}
.nav-wrap{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-radius:999px;transition:.5s}
.site-header.scrolled .nav-wrap{background:linear-gradient(135deg,rgba(11,18,36,.55),rgba(11,18,36,.25));backdrop-filter:blur(24px) saturate(160%);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-elegant)}
.brand{display:flex;align-items:center;gap:12px;color:var(--ivory)}
.brand-mark{width:40px;height:40px;border-radius:50%;background:var(--gradient-emerald);display:grid;place-items:center;box-shadow:var(--shadow-glow);color:#fff;font-size:18px}
.brand-text{font-family:'Fraunces',serif;font-size:18px;font-weight:600;line-height:1}
.brand-sub{display:block;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-top:2px}
.brand img{height:44px;width:auto}
.primary-menu{display:none;gap:28px;list-style:none;margin:0;padding:0}
.primary-menu a{color:rgba(248,245,234,.85);font-size:14px;transition:.2s}
.primary-menu a:hover{color:var(--gold)}
.nav-cta{display:none}
.menu-toggle{background:none;border:0;color:var(--ivory);cursor:pointer;font-size:24px;line-height:1}
@media(min-width:1024px){.primary-menu,.nav-cta{display:flex}.menu-toggle{display:none}}
.mobile-menu{position:fixed;inset:0;z-index:60;background:rgba(11,18,36,.97);backdrop-filter:blur(20px);display:none;flex-direction:column;padding:24px}
.mobile-menu.open{display:flex}
.mobile-menu .close{align-self:flex-end;background:none;border:0;color:var(--ivory);font-size:28px;cursor:pointer}
.mobile-menu ul{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:0}
.mobile-menu a{color:var(--ivory);font-family:'Fraunces',serif;font-size:24px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.08);display:block}

/* ============ Hero ============ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:140px 24px 80px;overflow:hidden;background:var(--gradient-hero);color:var(--ivory)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;mix-blend-mode:luminosity}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(11,18,36,.7),rgba(11,18,36,.55),var(--navy-deep))}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.orb-1{top:25%;left:40px;width:288px;height:288px;background:rgba(42,139,91,.3);animation:floatSlow 10s ease-in-out infinite}
.orb-2{bottom:40px;right:40px;width:384px;height:384px;background:rgba(214,180,84,.15);animation:floatSlow 10s ease-in-out infinite 2s}
.hero-inner{position:relative;max-width:1200px;margin:0 auto;width:100%}
.hero-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:999px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-soft)}
.hero-title{font-size:clamp(2.6rem,7vw,5.6rem);font-weight:600;margin-top:24px;max-width:900px}
.hero-title em{font-style:italic;font-weight:600}
.hero-sub{margin-top:24px;max-width:640px;font-size:clamp(1rem,2vw,1.25rem);color:rgba(248,245,234,.75)}
.hero-ctas{margin-top:40px;display:flex;flex-wrap:wrap;gap:16px}
.hero-stats{margin-top:56px;display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:720px}
@media(min-width:640px){.hero-stats{grid-template-columns:repeat(4,1fr)}}
.hero-stats .k{font-family:'Fraunces',serif;font-size:clamp(1.6rem,4vw,2.5rem)}
.hero-stats .v{font-size:12px;color:rgba(248,245,234,.6);margin-top:4px}
.float-icon{position:absolute;width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.04));backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);display:none;align-items:center;justify-content:center;animation:floatY 6s ease-in-out infinite;font-size:18px;color:var(--gold)}
@media(min-width:768px){.float-icon{display:flex}}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-18px) rotate(3deg)}}
@keyframes floatSlow{0%,100%{transform:translateY(0)}50%{transform:translateY(-30px)}}
@keyframes rise{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.animate-rise{animation:rise .9s cubic-bezier(.22,1,.36,1) both}

/* ============ Stats strip ============ */
.stats-strip{position:relative;margin:-64px auto 0;max-width:1200px;padding:0 24px;z-index:10}
.stats-strip-inner{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:32px;border-radius:24px;background:linear-gradient(135deg,rgba(11,18,36,.85),rgba(11,18,36,.6));backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-elegant);color:var(--ivory)}
@media(min-width:1024px){.stats-strip-inner{grid-template-columns:repeat(4,1fr);padding:40px}}
.stat-row{display:flex;align-items:center;gap:16px}
.stat-ic{width:48px;height:48px;border-radius:16px;background:var(--gradient-emerald);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-glow);flex-shrink:0}
.stat-row .k{font-family:'Fraunces',serif;font-size:24px}
.stat-row .v{font-size:12px;color:rgba(248,245,234,.65);line-height:1.3}

/* ============ Generic grids ============ */
.split{display:grid;grid-template-columns:1fr;gap:64px;align-items:center;max-width:1200px;margin:0 auto}
@media(min-width:1024px){.split{grid-template-columns:1fr 1fr}}
.section h2{font-size:clamp(2rem,4vw,3rem);font-weight:600;margin-top:16px}
.section p.lead{margin-top:24px;font-size:18px;color:var(--muted);line-height:1.7}
.check-list{list-style:none;padding:0;margin:32px 0 0}
.check-list li{display:flex;gap:12px;padding:8px 0}
.check-list li:before{content:"✓";color:var(--emerald);font-weight:bold;flex-shrink:0}
.media-card{position:relative}
.media-card .frame{border-radius:32px;overflow:hidden;box-shadow:var(--shadow-elegant);border:1px solid rgba(42,139,91,.1)}
.media-card .frame img{width:100%;height:520px;object-fit:cover}
.badge-float{position:absolute;bottom:-24px;left:-24px;display:flex;gap:12px;align-items:center;padding:16px;border-radius:16px;background:linear-gradient(135deg,rgba(11,18,36,.85),rgba(11,18,36,.6));backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-elegant);color:var(--ivory)}
.badge-float .ic{width:40px;height:40px;border-radius:50%;background:var(--gold);display:grid;place-items:center;color:var(--navy-deep)}
.badge-float .t{font-family:'Fraunces',serif;font-size:18px}
.badge-float .s{font-size:11px;color:rgba(248,245,234,.7)}

/* ============ Principal ============ */
.principal-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center;max-width:1200px;margin:0 auto}
@media(min-width:1024px){.principal-grid{grid-template-columns:1fr 2fr}}
.principal-img{position:relative;max-width:400px;margin:0 auto}
.principal-img:before{content:"";position:absolute;inset:-12px;border-radius:24px;background:linear-gradient(135deg,var(--gold),var(--emerald));opacity:.4;filter:blur(32px)}
.principal-img img{position:relative;width:100%;height:460px;object-fit:cover;border-radius:24px;border:1px solid rgba(214,180,84,.3)}
.quote-mark{font-size:64px;color:var(--gold);font-family:'Fraunces',serif;line-height:.5;display:block;margin-top:24px}
.principal-quote{margin-top:16px;font-family:'Fraunces',serif;font-size:clamp(1.4rem,2.5vw,1.85rem);line-height:1.4}
.principal-author{margin-top:32px}
.principal-author .name{font-family:'Fraunces',serif;font-size:20px}
.principal-author .role{font-size:13px;color:rgba(248,245,234,.65)}

/* ============ Programs ============ */
.programs-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:1200px;margin:56px auto 0}
@media(min-width:640px){.programs-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.programs-grid{grid-template-columns:repeat(4,1fr)}}
.program-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:24px;padding:28px;transition:.5s;overflow:hidden}
.program-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant)}
.program-card .ic{width:48px;height:48px;border-radius:16px;background:var(--gradient-emerald);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-glow);font-size:20px}
.program-card .year{margin-top:20px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--emerald-deep)}
.program-card h3{margin-top:8px;font-size:22px}
.program-card p{margin-top:12px;font-size:14px;color:var(--muted);line-height:1.6}

/* ============ Timeline ============ */
.timeline{position:relative;margin:64px auto 0;max-width:1200px}
.timeline:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,var(--emerald),transparent);display:none}
@media(min-width:768px){.timeline:before{display:block}}
.tl-item{margin:40px 0}
@media(min-width:768px){.tl-item{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}}
.tl-card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:28px;box-shadow:var(--shadow-card)}
.tl-year{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--emerald-deep)}
.tl-card h3{font-size:22px;margin-top:8px}
.tl-card p{color:var(--muted);margin-top:8px}
.tl-item.right .tl-card{margin-left:0}
@media(min-width:768px){
  .tl-item.left .tl-card{margin-right:32px}
  .tl-item.right{direction:rtl}
  .tl-item.right .tl-card{direction:ltr;margin-left:32px}
}

/* ============ Facilities ============ */
.facilities-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:1200px;margin:56px auto 0}
@media(min-width:768px){.facilities-grid{grid-template-columns:repeat(3,1fr)}.facilities-grid .fac:first-child{grid-column:span 2}}
.fac{position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow-card)}
.fac img{aspect-ratio:16/10;object-fit:cover;width:100%;transition:.7s}
.fac:hover img{transform:scale(1.05)}
.fac-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,18,36,.85),transparent 60%);display:flex;align-items:flex-end;padding:28px;color:var(--ivory)}
.fac-overlay h3{font-size:22px}
.fac-overlay p{margin-top:8px;font-size:13px;color:rgba(248,245,234,.8);max-width:420px}

/* ============ Life clubs ============ */
.clubs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:56px}
@media(min-width:640px){.clubs-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.clubs-grid{grid-template-columns:repeat(4,1fr)}}
.club{padding:20px;border-radius:16px;background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.04));backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;gap:12px;transition:.3s}
.club:hover{background:rgba(255,255,255,.15)}
.club .ic{width:40px;height:40px;border-radius:12px;background:rgba(214,180,84,.2);display:grid;place-items:center;color:var(--gold)}

/* ============ Eco ============ */
.eco-stats{margin-top:32px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.eco-stat{padding:16px;border-radius:16px;background:rgba(42,139,91,.08);text-align:center}
.eco-stat .k{font-family:'Fraunces',serif;font-size:28px;color:var(--emerald-deep)}
.eco-stat .v{font-size:12px;color:var(--muted);margin-top:4px}

/* ============ Achievements ============ */
.ach-grid{display:grid;grid-template-columns:1fr;gap:20px;max-width:1200px;margin:56px auto 0}
@media(min-width:768px){.ach-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.ach-grid{grid-template-columns:repeat(3,1fr)}}
.ach{display:flex;gap:16px;background:var(--card);border:1px solid var(--border);border-radius:24px;padding:24px;transition:.3s}
.ach:hover{box-shadow:var(--shadow-elegant)}
.ach .ic{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--gold),var(--gold-soft));display:grid;place-items:center;color:var(--navy-deep);box-shadow:0 0 30px rgba(214,180,84,.3);flex-shrink:0}
.ach .y{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--emerald-deep)}
.ach .t{font-family:'Fraunces',serif;font-size:18px;margin-top:4px;line-height:1.3}

/* ============ Testimonials ============ */
.tst-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:1200px;margin:56px auto 0}
@media(min-width:768px){.tst-grid{grid-template-columns:repeat(3,1fr)}}
.tst{position:relative;background:var(--card);border:1px solid var(--border);border-radius:24px;padding:32px;box-shadow:var(--shadow-card)}
.tst blockquote{font-family:'Fraunces',serif;font-size:20px;line-height:1.4;margin:0}
.tst .author{display:flex;align-items:center;gap:12px;margin-top:24px}
.tst .av{width:40px;height:40px;border-radius:50%;background:var(--gradient-emerald);display:grid;place-items:center;color:#fff;font-family:'Fraunces',serif}
.tst .nm{font-weight:500}
.tst .rl{font-size:12px;color:var(--muted)}

/* ============ Admissions ============ */
.adm-section{position:relative;overflow:hidden;background:var(--gradient-hero);color:var(--ivory)}
.adm-grid{display:grid;grid-template-columns:1fr;gap:56px;max-width:1200px;margin:0 auto;position:relative}
@media(min-width:1024px){.adm-grid{grid-template-columns:1fr 1fr}}
.adm-step{display:flex;gap:20px;margin-top:24px}
.adm-step .n{font-family:'Fraunces',serif;font-size:36px;color:var(--gold);width:56px;flex-shrink:0}
.adm-step h3{font-family:'Fraunces',serif;font-size:20px}
.adm-step p{color:rgba(248,245,234,.7);margin-top:4px}
.adm-form{padding:32px;border-radius:24px;background:linear-gradient(135deg,rgba(11,18,36,.55),rgba(11,18,36,.25));backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-elegant)}
.adm-form h3{font-family:'Fraunces',serif;font-size:24px}
.adm-form label{display:block;margin-top:16px}
.adm-form label span{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(248,245,234,.6)}
.adm-form input,.adm-form textarea{width:100%;margin-top:8px;padding:14px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15);border-radius:12px;color:var(--ivory);font-family:inherit;font-size:15px;outline:none;transition:.2s}
.adm-form input:focus,.adm-form textarea:focus{border-color:var(--gold);box-shadow:0 0 0 4px rgba(214,180,84,.2)}
.adm-row{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.adm-row{grid-template-columns:1fr 1fr}}

/* ============ Contact ============ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:1200px;margin:0 auto}
@media(min-width:1024px){.contact-grid{grid-template-columns:repeat(3,1fr)}}
.contact-card{padding:32px;background:var(--card);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-card);transition:.3s;display:flex;flex-direction:column}
.contact-card:hover{box-shadow:var(--shadow-elegant)}
.contact-card .ic{width:48px;height:48px;border-radius:16px;background:var(--gradient-emerald);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-glow)}
.contact-card h3{font-family:'Fraunces',serif;font-size:22px;margin-top:20px}
.contact-card .lines{margin-top:8px;color:var(--muted)}
.contact-card .lines div{padding:2px 0}
.contact-cta{margin-top:24px;color:var(--emerald-deep);font-weight:500;font-size:14px;display:inline-flex;align-items:center;gap:4px}

/* ============ Footer ============ */
.site-footer{position:relative;color:var(--ivory);padding:80px 24px 40px;background:var(--navy-deep);overflow:hidden}
.footer-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.15}
.footer-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(11,18,36,.85),var(--navy-deep))}
.footer-inner{position:relative;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:768px){.footer-inner{grid-template-columns:2fr 1fr 1fr}}
.footer-brand p{color:rgba(248,245,234,.7);max-width:420px;margin-top:24px}
.footer-col h4{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-soft);font-family:'Inter',sans-serif;font-weight:600;margin-bottom:16px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.footer-col a{color:rgba(248,245,234,.75);font-size:14px;transition:.2s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{max-width:1200px;margin:48px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:12px;color:rgba(248,245,234,.5);position:relative}

/* ============ Floating actions ============ */
.float-actions{position:fixed;bottom:24px;right:24px;z-index:40;display:flex;flex-direction:column;gap:12px}
.float-actions a{display:grid;place-items:center;border-radius:50%;transition:.2s;color:#fff;text-decoration:none}
.fa-wa{width:56px;height:56px;background:var(--gradient-emerald);box-shadow:var(--shadow-glow);position:relative}
.fa-wa:before{content:"";position:absolute;inset:0;border-radius:50%;background:rgba(79,194,138,.4);animation:pulseRing 2.5s cubic-bezier(.4,0,.6,1) infinite}
.fa-call{width:48px;height:48px;background:var(--gold);color:var(--navy-deep);box-shadow:0 0 30px rgba(214,180,84,.4)}
.float-actions a:hover{transform:scale(1.1)}
@keyframes pulseRing{0%{transform:scale(.9);opacity:.8}100%{transform:scale(2.2);opacity:0}}

/* WP admin bar offset */
.admin-bar .site-header{top:32px}
@media(max-width:782px){.admin-bar .site-header{top:46px}}
