/* =========================================================
   Modern English School — Theme
   Developed by Webthropic
   Palette: deep navy + warm gold + cream  | Fraunces + Mulish
   ========================================================= */
:root{
  --navy:#0e2a47;
  --navy-2:#143656;
  --navy-deep:#091d33;
  --gold:#e8a33d;
  --gold-2:#f5b955;
  --maroon:#9c2b2b;
  --cream:#fbf7ef;
  --ink:#1c2b3a;
  --muted:#5d6b7a;
  --line:#e7e0d3;
  --white:#ffffff;
  --shadow:0 18px 50px -22px rgba(14,42,71,.35);
  --shadow-sm:0 8px 24px -14px rgba(14,42,71,.3);
  --radius:16px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Mulish',system-ui,sans-serif;
}
*{box-sizing:border-box}
body{font-family:var(--sans);color:var(--ink);background:var(--white);margin:0;line-height:1.65;font-size:16px}
h1,h2,h3,h4,h5,.serif{font-family:var(--serif);color:var(--navy);font-weight:600;line-height:1.15}
a{text-decoration:none;color:var(--navy)}
img{max-width:100%}
.container{max-width:1200px}
section{position:relative}

/* Buttons */
.btn-accent{background:var(--gold);border:none;color:#3a2606;font-weight:700;border-radius:40px;transition:.25s}
.btn-accent:hover{background:var(--gold-2);color:#3a2606;transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(232,163,61,.7)}
.btn-navy{background:var(--navy);border:none;color:#fff;font-weight:700;border-radius:40px;transition:.25s}
.btn-navy:hover{background:var(--navy-2);color:#fff;transform:translateY(-2px)}
.btn-outline-navy{border:1.5px solid var(--navy);color:var(--navy);font-weight:700;border-radius:40px;background:transparent;transition:.25s}
.btn-outline-navy:hover{background:var(--navy);color:#fff}

/* ---------------- Top bar ---------------- */
.topbar{background:var(--navy-deep);color:#cdd9e6;font-size:.84rem;padding:8px 0}
.topbar a{color:#cdd9e6;transition:.2s}
.topbar a:hover{color:var(--gold-2)}
.topbar i{color:var(--gold)}
.topbar-rating{color:var(--gold-2);font-weight:700}
.topbar-social a{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.18);border-radius:50%}
.topbar-social a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy-deep)}

/* ---------------- Navbar ---------------- */
.main-nav{background:rgba(255,255,255,.96);backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line);padding:.5rem 0;box-shadow:0 4px 24px -18px rgba(14,42,71,.5);z-index:1030}
.brand-badge{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:var(--gold-2);font-family:var(--serif);font-weight:700;border-radius:12px;letter-spacing:.5px;box-shadow:var(--shadow-sm)}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-family:var(--serif);font-weight:700;color:var(--navy);font-size:1.18rem}
.brand-tag{font-size:.66rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:700}
.main-nav .nav-link{color:var(--navy);font-weight:600;font-size:.95rem;padding:.5rem .85rem;position:relative}
.main-nav .nav-link::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.25rem;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:.25s}
.main-nav .nav-link:hover::after,.main-nav .nav-link.active::after{transform:scaleX(1)}
.main-nav .nav-link.active{color:var(--maroon)}

/* ---------------- Notice ticker ---------------- */
.notice-ticker{background:linear-gradient(90deg,var(--gold),var(--gold-2));color:var(--navy-deep);overflow:hidden;font-weight:600}
.notice-ticker .container{height:42px;overflow:hidden}
.ticker-label{background:var(--navy-deep);color:var(--gold-2);font-weight:700;padding:0 16px;height:42px;display:flex;align-items:center;gap:6px;margin-right:14px;white-space:nowrap;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}
.ticker-track{overflow:hidden;flex:1}
.ticker-move{display:inline-flex;white-space:nowrap;animation:ticker 40s linear infinite}
.ticker-move a{color:var(--navy-deep);font-size:.9rem;margin-right:8px;display:inline-flex;align-items:center}
.ticker-move a:hover{color:var(--maroon)}
.notice-ticker:hover .ticker-move{animation-play-state:paused}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---------------- Hero carousel ---------------- */
.hero-carousel .carousel-item{height:88vh;min-height:560px;max-height:820px}
.hero-carousel .hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-carousel .hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(9,29,51,.88) 0%,rgba(9,29,51,.55) 45%,rgba(9,29,51,.2) 100%)}
.hero-caption{position:absolute;inset:0;display:flex;align-items:center;z-index:3}
.hero-caption .container{color:#fff}
.hero-eyebrow{display:inline-block;background:rgba(232,163,61,.18);border:1px solid rgba(232,163,61,.5);color:var(--gold-2);padding:.35rem 1rem;border-radius:40px;font-size:.78rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:1.1rem}
.hero-title{font-size:clamp(2.2rem,5vw,4rem);color:#fff;font-weight:600;max-width:760px;text-shadow:0 4px 30px rgba(0,0,0,.3)}
.hero-sub{font-size:clamp(1rem,1.6vw,1.3rem);color:#e3ecf5;max-width:560px;margin:1rem 0 1.8rem}
.hero-carousel .carousel-indicators{bottom:24px;z-index:4}
.hero-carousel .carousel-indicators [data-bs-target]{width:34px;height:4px;border-radius:4px;background:rgba(255,255,255,.5)}
.hero-carousel .carousel-indicators .active{background:var(--gold)}
.hero-carousel .carousel-control-prev,.hero-carousel .carousel-control-next{width:6%;z-index:4;opacity:.8}
.play-badge{position:absolute;top:18px;right:18px;background:rgba(0,0,0,.5);color:#fff;padding:.3rem .8rem;border-radius:40px;font-size:.8rem;font-weight:700;z-index:3}

/* ---------------- Quick highlight strip ---------------- */
.quick-strip{margin-top:-58px;position:relative;z-index:10}
.quick-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;height:100%;border-bottom:4px solid var(--gold);transition:.3s}
.quick-card:hover{transform:translateY(-6px)}
.quick-card .qc-icon{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:var(--gold-2);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:14px}
.quick-card h5{margin:0 0 6px;font-size:1.15rem}
.quick-card p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------------- Section helpers ---------------- */
.sec{padding:84px 0}
.sec-cream{background:var(--cream)}
.sec-navy{background:var(--navy-deep);color:#cfe}
.sec-eyebrow{color:var(--gold);font-weight:800;letter-spacing:2px;text-transform:uppercase;font-size:.8rem;display:block;margin-bottom:.5rem}
.sec-title{font-size:clamp(1.8rem,3.2vw,2.6rem);margin-bottom:.6rem}
.sec-navy .sec-title{color:#fff}
.sec-lead{color:var(--muted);max-width:640px}
.sec-navy .sec-lead{color:#aebfd0}
.divider{width:64px;height:4px;background:var(--gold);border-radius:4px;margin:14px 0 0}
.text-center .divider{margin-left:auto;margin-right:auto}

/* ---------------- About / principal ---------------- */
.about-img-wrap{position:relative}
.about-img-wrap img{border-radius:var(--radius);box-shadow:var(--shadow)}
.about-badge{position:absolute;right:-18px;bottom:-18px;background:var(--gold);color:var(--navy-deep);border-radius:var(--radius);padding:18px 24px;box-shadow:var(--shadow);text-align:center}
.about-badge .num{font-family:var(--serif);font-size:2.2rem;font-weight:700;line-height:1}
.about-badge .lbl{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.check-list{list-style:none;padding:0;margin:18px 0 0}
.check-list li{padding:7px 0 7px 32px;position:relative;color:var(--ink)}
.check-list li::before{content:"\F26B";font-family:"bootstrap-icons";position:absolute;left:0;color:var(--gold);font-size:1.1rem}

/* ---------------- Stats ---------------- */
.stat-item{text-align:center;padding:10px}
.stat-num{font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:700;color:var(--gold-2);line-height:1}
.stat-lbl{color:#bcd;font-size:.95rem;margin-top:6px;letter-spacing:.5px}

/* ---------------- Facilities ---------------- */
.facility-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;height:100%;transition:.3s}
.facility-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-5px)}
.facility-card i{font-size:2rem;color:var(--maroon);background:var(--cream);width:60px;height:60px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.facility-card h5{font-size:1.12rem;margin-bottom:6px}
.facility-card p{color:var(--muted);font-size:.9rem;margin:0}

/* ---------------- Faculty cards ---------------- */
.teacher-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s;height:100%}
.teacher-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.teacher-card .t-photo{aspect-ratio:1/1;overflow:hidden;background:var(--cream)}
.teacher-card .t-photo img{width:100%;height:100%;object-fit:cover;transition:.4s}
.teacher-card:hover .t-photo img{transform:scale(1.06)}
.teacher-card .t-body{padding:18px;text-align:center}
.teacher-card .t-name{font-family:var(--serif);font-weight:600;color:var(--navy);font-size:1.12rem;margin:0}
.teacher-card .t-role{color:var(--maroon);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}
.teacher-card .t-sub{color:var(--muted);font-size:.85rem;margin-top:4px}

/* ---------------- Notices/events lists ---------------- */
.notice-row{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:12px;padding:18px 20px;transition:.25s;margin-bottom:14px}
.notice-row:hover{box-shadow:var(--shadow-sm);transform:translateX(4px)}
.notice-date{flex:0 0 64px;text-align:center;background:var(--navy);color:#fff;border-radius:10px;padding:8px 4px}
.notice-date .d{font-family:var(--serif);font-size:1.5rem;font-weight:700;line-height:1}
.notice-date .m{font-size:.7rem;text-transform:uppercase;letter-spacing:1px}
.notice-cat{display:inline-block;background:var(--cream);color:var(--maroon);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:.15rem .6rem;border-radius:20px;margin-bottom:4px}
.notice-row h6{margin:0;font-family:var(--serif);font-size:1.08rem}
.pin-flag{color:var(--maroon);font-size:.85rem}

/* Event cards */
.event-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);height:100%;transition:.3s}
.event-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.event-card .e-img{aspect-ratio:16/10;overflow:hidden}
.event-card .e-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.event-card:hover .e-img img{transform:scale(1.07)}
.event-card .e-body{padding:18px}
.event-date-chip{display:inline-flex;align-items:center;gap:6px;background:var(--cream);color:var(--maroon);font-weight:700;font-size:.8rem;padding:.25rem .7rem;border-radius:20px;margin-bottom:8px}
.event-card h5{font-size:1.15rem;margin-bottom:6px}
.event-card p{color:var(--muted);font-size:.9rem;margin:0}

/* ---------------- Gallery ---------------- */
.gallery-grid{column-count:3;column-gap:16px}
.gallery-grid .g-item{break-inside:avoid;margin-bottom:16px;border-radius:14px;overflow:hidden;position:relative;cursor:pointer;box-shadow:var(--shadow-sm)}
.gallery-grid .g-item img{width:100%;display:block;transition:.4s}
.gallery-grid .g-item:hover img{transform:scale(1.07)}
.gallery-grid .g-cap{position:absolute;inset:auto 0 0 0;background:linear-gradient(transparent,rgba(9,29,51,.85));color:#fff;padding:26px 14px 12px;font-weight:600;font-size:.9rem;opacity:0;transition:.3s}
.gallery-grid .g-item:hover .g-cap{opacity:1}
@media(max-width:992px){.gallery-grid{column-count:2}}
@media(max-width:576px){.gallery-grid{column-count:1}}

/* ---------------- Testimonials ---------------- */
.testi-card{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);height:100%;border-top:4px solid var(--gold)}
.testi-card .stars{color:var(--gold);margin-bottom:10px}
.testi-card .quote{font-family:var(--serif);font-style:italic;color:var(--ink);font-size:1.02rem}
.testi-card .who{font-weight:800;color:var(--navy);margin-top:14px}
.testi-card .role{color:var(--muted);font-size:.85rem}

/* ---------------- CTA band ---------------- */
.cta-band{background:linear-gradient(120deg,var(--navy),var(--navy-2));border-radius:24px;padding:48px;color:#fff;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;background:radial-gradient(circle,rgba(232,163,61,.35),transparent 70%)}
.cta-band h2{color:#fff}

/* ---------------- Page banner ---------------- */
.page-banner{background:linear-gradient(rgba(9,29,51,.82),rgba(9,29,51,.82)),url('https://images.unsplash.com/photo-1523050854058-8df90110c9f1?auto=format&fit=crop&w=1920&q=80') center/cover;color:#fff;padding:70px 0 56px;text-align:center}
.page-banner h1{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.page-banner .crumb{color:#bcd;font-size:.9rem}
.page-banner .crumb a{color:var(--gold-2)}

/* ---------------- Forms ---------------- */
.form-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:32px}
.form-control,.form-select{border-radius:10px;border:1.5px solid var(--line);padding:.7rem .9rem}
.form-control:focus,.form-select:focus{border-color:var(--gold);box-shadow:0 0 0 .2rem rgba(232,163,61,.18)}
.form-label{font-weight:700;color:var(--navy);font-size:.9rem}

/* ---------------- Footer ---------------- */
.site-footer{background:var(--navy-deep);color:#a9bccf;padding-top:64px;margin-top:0}
.footer-brand-name{font-family:var(--serif);color:#fff;font-size:1.2rem;font-weight:700}
.footer-about{color:#9fb2c6;font-size:.92rem}
.footer-head{color:#fff;font-family:var(--serif);font-size:1.05rem;margin-bottom:16px;position:relative;padding-bottom:10px}
.footer-head::after{content:"";position:absolute;left:0;bottom:0;width:34px;height:3px;background:var(--gold)}
.footer-links,.footer-contact{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:9px}
.footer-links a{color:#9fb2c6;font-size:.92rem;transition:.2s}
.footer-links a:hover{color:var(--gold-2);padding-left:5px}
.footer-contact li{margin-bottom:12px;font-size:.9rem;display:flex;gap:10px}
.footer-contact i{color:var(--gold)}
.footer-contact a{color:#9fb2c6}
.footer-contact a:hover{color:var(--gold-2)}
.footer-social a{width:36px;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.07);color:#cfe;transition:.25s}
.footer-social a:hover{background:var(--gold);color:var(--navy-deep);transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding:18px 0;font-size:.85rem;color:#8aa0b6}
.dev-credit a{color:var(--gold-2);font-weight:700}

/* ---------------- Floating buttons ---------------- */
.float-btn{position:fixed;right:18px;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;box-shadow:var(--shadow);z-index:1040;border:none;transition:.25s}
.float-wa{bottom:80px;background:#25d366}
.float-call{bottom:142px;background:var(--maroon)}
.float-top{bottom:18px;background:var(--navy);opacity:0;visibility:hidden}
.float-top.show{opacity:1;visibility:visible}
.float-btn:hover{transform:scale(1.08);color:#fff}

/* ---------------- Reveal on scroll ---------------- */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------------- Responsive ---------------- */
@media(max-width:991px){
  .main-nav .navbar-collapse{background:#fff;margin-top:10px;padding:14px;border-radius:14px;box-shadow:var(--shadow)}
  .hero-carousel .carousel-item{height:auto;min-height:480px}
  .quick-strip{margin-top:24px}
  .about-badge{right:12px;bottom:-14px}
}
@media(max-width:576px){
  .sec{padding:56px 0}
  .cta-band{padding:30px}
  body{font-size:15px}
}
