@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700;800&family=Inter:wght@400;500;600;700&display=swap');
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Inter","Segoe UI",Roboto,-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;color:#1e2a3a;line-height:1.7;background:#fdfcf9;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:#0b2a54;text-decoration:none;transition:color .2s}
a:hover{text-decoration:underline}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
h1,h2,h3,h4{font-family:"Playfair Display",Georgia,"Times New Roman",serif;color:#0b2a54;line-height:1.2;margin:0 0 .55em;letter-spacing:-.01em;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem);margin-top:1.2em}
h3{font-size:1.25rem;letter-spacing:0}
p{margin:0 0 1em}
.eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;color:#e94e1b;margin-bottom:12px}
.section-title{text-align:center;margin-bottom:14px}
.section-title h2{margin:0 0 10px}
.section-title .rule{width:60px;height:3px;background:linear-gradient(90deg,#e94e1b,#ffb84d);margin:0 auto 18px;border-radius:2px}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(10px);-webkit-backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid rgba(11,42,84,.08);box-shadow:0 4px 20px -12px rgba(11,42,84,.25)}
.header-inner{display:flex;align-items:center;gap:20px;padding:12px 24px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:54px;width:auto;transition:transform .3s}
.brand:hover img{transform:rotate(-4deg) scale(1.05)}
.brand span{display:flex;flex-direction:column;line-height:1.1}
.brand strong{color:#0b2a54;font-size:1.08rem;font-weight:700;letter-spacing:.01em}
.brand small{color:#6b7684;font-size:.76rem;letter-spacing:.06em;text-transform:uppercase}

.header-cta{margin-left:auto;order:2}
.header-cta .btn-primary{box-shadow:0 8px 20px -8px rgba(233,78,27,.6);position:relative;overflow:hidden}
.header-cta .btn-primary::before{content:"❤";margin-right:8px}

.menu-toggle{background:linear-gradient(135deg,#0b2a54,#12407a);color:#fff;border:none;border-radius:8px;font-size:1.3rem;padding:6px 14px;cursor:pointer;order:3;box-shadow:0 4px 12px -4px rgba(11,42,84,.5)}

.site-nav{order:4;width:100%;display:none}
body.nav-open .site-nav{display:block;animation:slideDown .3s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

.nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.nav-item{position:relative}
.nav-item>a{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;color:#22303c;font-size:.95rem;font-weight:600;border-radius:8px;transition:.2s;letter-spacing:.01em}
.nav-item>a:hover{background:#f0f4fa;color:#0b2a54;text-decoration:none}
.nav-item.active>a{background:linear-gradient(135deg,#0b2a54,#12407a);color:#fff}
.nav-item .caret{font-size:.7rem;opacity:.6;transition:transform .2s}
.nav-item:hover .caret,.nav-item:focus-within .caret{transform:rotate(180deg)}

.submenu{list-style:none;padding:6px 0 6px 20px;margin:2px 0 6px;display:none;border-left:2px solid #e94e1b}
.submenu li a{display:block;padding:8px 12px;font-size:.9rem;color:#4b5763;border-radius:6px;font-weight:500}
.submenu li a:hover{background:#fff5f0;color:#e94e1b;text-decoration:none}
.nav-item.has-sub:hover>.submenu,.nav-item.has-sub:focus-within>.submenu,.nav-item.has-sub.open>.submenu{display:block}

@media(min-width:1040px){
  .header-inner{padding:14px 28px;flex-wrap:nowrap}
  .menu-toggle{display:none}
  .site-nav{display:block;order:2;width:auto;flex:1}
  .nav-list{flex-direction:row;justify-content:center;gap:4px;flex-wrap:wrap}
  .nav-item>a{padding:10px 14px;font-size:.9rem;position:relative}
  .nav-item>a::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:#e94e1b;border-radius:2px;transform:scaleX(0);transform-origin:center;transition:transform .25s}
  .nav-item:hover>a::after,.nav-item.active>a::after{transform:scaleX(1)}
  .nav-item.active>a{background:transparent;color:#0b2a54}
  .nav-item:hover>a{background:transparent;color:#e94e1b}

  .submenu{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(6px);min-width:220px;background:#fff;border:1px solid #eef1f5;border-radius:12px;padding:8px;box-shadow:0 20px 40px -12px rgba(11,42,84,.25);border-left:none;opacity:0;visibility:hidden;transition:.22s;display:block;margin:0}
  .submenu::before{content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);width:12px;height:12px;background:#fff;border-left:1px solid #eef1f5;border-top:1px solid #eef1f5}
  .nav-item.has-sub:hover>.submenu,.nav-item.has-sub:focus-within>.submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .submenu li a{padding:9px 12px;font-size:.88rem;white-space:nowrap}
  .submenu li a:hover{background:linear-gradient(135deg,#fff5f0,#ffe8dc);color:#e94e1b;padding-left:16px}
}

/* buttons */
.btn{display:inline-block;padding:11px 22px;border-radius:6px;font-weight:600;font-size:.92rem;transition:.2s;border:2px solid transparent;cursor:pointer}
.btn-primary{background:#e94e1b;color:#fff;border-color:#e94e1b}
.btn-primary:hover{background:#cd3f10;text-decoration:none;color:#fff}
.btn-outline{background:transparent;color:#0b2a54;border-color:#0b2a54;margin-left:8px}
.btn-outline:hover{background:#0b2a54;color:#fff;text-decoration:none}

/* hero */
.page-hero{background-size:cover;background-position:center;color:#fff;padding:110px 0;text-align:center;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:auto 0 0 0;height:80px;background:linear-gradient(to top,#fdfcf9,transparent);pointer-events:none}
.page-hero h1{color:#fff;margin-bottom:.3em;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.page-hero p{color:#f0f4fa;max-width:760px;margin:0 auto;font-size:1.1rem}

/* home cinematic slider */
.hero-slider{position:relative;height:min(88vh,760px);min-height:520px;overflow:hidden;background:#0b1e3d}
.hero-slider .slide{position:absolute;inset:0;background-size:cover;background-position:center 20%;opacity:0;animation:heroFade 32s infinite}
.hero-slider .slide::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,30,61,.85) 0%,rgba(11,30,61,.55) 45%,rgba(11,30,61,.2) 100%)}
.hero-slider .slide:nth-child(1){animation-delay:0s}
.hero-slider .slide:nth-child(2){animation-delay:8s}
.hero-slider .slide:nth-child(3){animation-delay:16s}
.hero-slider .slide:nth-child(4){animation-delay:24s}
@keyframes heroFade{0%,3%{opacity:0;transform:scale(1.08)}6%,25%{opacity:1;transform:scale(1.02)}28%,100%{opacity:0;transform:scale(1)}}
.hero-content{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:0 24px;height:100%;display:flex;flex-direction:column;justify-content:center;color:#fff}
.hero-content .eyebrow{color:#ffb84d;background:rgba(255,184,77,.12);padding:6px 14px;border-radius:999px;border:1px solid rgba(255,184,77,.3);align-self:flex-start}
.hero-content h1{color:#fff;font-size:clamp(2.4rem,6vw,4.4rem);max-width:780px;text-shadow:0 4px 30px rgba(0,0,0,.4);line-height:1.1}
.hero-content .kicker{max-width:640px;font-size:clamp(1rem,1.4vw,1.2rem);color:#e8eef8;margin:18px 0 32px}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{position:absolute;bottom:36px;left:24px;right:24px;z-index:3;display:flex;gap:36px;flex-wrap:wrap;color:#fff;font-family:"Playfair Display",serif}
.hero-stats div{border-left:3px solid #ffb84d;padding-left:14px}
.hero-stats strong{display:block;font-size:2rem;color:#fff;font-weight:700}
.hero-stats span{font-size:.8rem;color:#c9d3e3;text-transform:uppercase;letter-spacing:.14em;font-family:"Inter",sans-serif}
@media(max-width:640px){.hero-stats{gap:18px;bottom:20px}.hero-stats strong{font-size:1.4rem}}

/* sections */
.page-content{padding:72px 20px}
.lede{font-size:1.15rem;color:#5a6674;text-align:center;max-width:780px;margin:0 auto 48px;line-height:1.75}
.section{padding:64px 0}
.section-tint{background:linear-gradient(180deg,#fff,#f4f0e8)}

.offer-grid{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:24px}
.offer{background:#fff;border:1px solid #eef1f5;border-radius:18px;padding:28px 22px;text-align:center;transition:.3s cubic-bezier(.2,.9,.3,1);box-shadow:0 2px 10px rgba(11,42,84,.05);position:relative;overflow:hidden}
.offer::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#e94e1b,#ffb84d);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.offer:hover{transform:translateY(-6px);box-shadow:0 20px 40px -12px rgba(11,42,84,.18);border-color:#e94e1b33}
.offer:hover::before{transform:scaleX(1)}
.offer img{margin:0 auto 14px;max-height:76px;width:auto;transition:transform .3s}
.offer:hover img{transform:scale(1.08) rotate(-4deg)}
.offer h3{margin:0 0 8px}
.offer p{color:#5a6674;font-size:.94rem}
.offer a{color:#e94e1b;font-weight:600;font-size:.9rem;display:inline-block;margin-top:6px}
.offer a:hover{text-decoration:none;transform:translateX(4px);display:inline-block}

/* awards showcase */
.awards-showcase{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:36px 0}
.award-card{position:relative;border-radius:16px;overflow:hidden;background:#0b1e3d;box-shadow:0 10px 30px -12px rgba(11,42,84,.3);transition:.4s cubic-bezier(.2,.9,.3,1);cursor:pointer;display:flex;flex-direction:column}
.award-card img{width:100%;height:auto;max-height:460px;object-fit:contain;background:#0b1e3d;display:block;transition:transform .6s}
.award-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -12px rgba(11,42,84,.4)}
.award-card:hover img{transform:scale(1.03)}
.award-card .caption{padding:18px 20px 20px;background:linear-gradient(180deg,#0b1e3d,#0a1830);color:#fff}
.award-card .caption .year{display:inline-block;background:#e94e1b;color:#fff;padding:3px 10px;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.1em;margin-bottom:8px}
.award-card .caption h4{color:#fff;font-family:"Playfair Display",serif;margin:0;font-size:1.05rem;line-height:1.3}
.award-card.tall{}
@media(min-width:900px){.awards-showcase{grid-template-columns:repeat(3,1fr);grid-auto-flow:dense}}

.cta-band{background:linear-gradient(135deg,#0b2a54,#12407a);color:#fff;text-align:center;padding:44px 20px;border-radius:16px;margin:48px 0}
.cta-band h2{color:#fff;margin:0 0 18px}
.cta-band{background:linear-gradient(135deg,#0b2a54 0%,#12407a 50%,#1a5a9e 100%);position:relative;overflow:hidden;padding:60px 24px}
.cta-band::before{content:"";position:absolute;top:-50%;right:-10%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(255,184,77,.15),transparent 70%);pointer-events:none}
.cta-band h2{position:relative;z-index:1;font-size:clamp(1.5rem,2.6vw,2.2rem)}
.cta-band .btn{position:relative;z-index:1}

.pillars{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin:40px 0}
.pillar{padding:26px;background:#fff;border-radius:14px;border-left:4px solid #e94e1b;box-shadow:0 4px 16px rgba(11,42,84,.05);transition:.25s}
.pillar:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(11,42,84,.1);border-left-width:6px}
.pillar h3{color:#0b2a54;margin-top:0}

.stats{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));background:linear-gradient(135deg,#0b1e3d,#0b2a54);color:#fff;padding:48px 24px;border-radius:16px;text-align:center;margin:56px 0;position:relative;overflow:hidden;box-shadow:0 20px 40px -20px rgba(11,42,84,.5)}
.stats::before{content:"";position:absolute;inset:0;background:url('../img/uploads/student-portrait.jpg') center/cover;opacity:.12;filter:grayscale(1)}
.stats>div{position:relative;z-index:1}
.stats strong{display:block;font-size:2.6rem;color:#ffb84d;font-family:"Playfair Display",serif;font-weight:700}
.stats span{font-size:.85rem;color:#dbe4f2;text-transform:uppercase;letter-spacing:.14em}

.about-strip{display:grid;grid-template-columns:1fr;gap:28px;align-items:center;margin:48px 0}
.about-strip img{border-radius:16px;box-shadow:0 20px 40px -20px rgba(11,42,84,.35)}
@media(min-width:820px){.about-strip{grid-template-columns:1fr 1fr}}
.about-strip.reverse img{order:2}

.two-col{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:32px}
@media(min-width:820px){.two-col{grid-template-columns:1fr 1fr}}

.contact-form,.donate-form{background:#f7f9fc;padding:26px;border-radius:12px;display:flex;flex-direction:column;gap:14px}
.contact-form label,.donate-form label{display:flex;flex-direction:column;font-size:.88rem;color:#3a4652;font-weight:600;gap:6px}
.contact-form input,.contact-form textarea,.donate-form input,.donate-form textarea{padding:11px;border:1px solid #d7dde5;border-radius:6px;font:inherit;background:#fff}
.donate-form .row{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.donate-form .row{grid-template-columns:1fr 1fr}}
.note{font-size:.85rem;color:#6b7684}

.donate-hero{text-align:center;margin-bottom:36px}
.donate-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:40px}
.donate-card{background:#fff;border:1px solid #eef1f5;border-radius:12px;padding:22px;display:flex;flex-direction:column;gap:10px;box-shadow:0 2px 8px rgba(11,42,84,.05)}
.donate-card .amt{font-size:1.4rem;font-weight:700;color:#e94e1b;margin:6px 0 12px}
.donate-card .btn{margin-top:auto;align-self:flex-start}

.info-card{background:#f7f9fc;padding:22px;border-radius:12px;border-left:4px solid #0b2a54;margin:20px 0}
.info-card p{margin:.4em 0}

.prose h2{margin-top:1.6em}
.prose h3{margin-top:1.4em;color:#12407a}
.prose img{border-radius:12px;margin:20px 0}
.prose li{margin:.3em 0 .3em 1.2em;list-style:disc}

/* footer */
.site-footer{background:#0b1e3d;color:#c9d3e3;padding:56px 0 0;margin-top:60px}
.footer-grid{display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));padding:0 20px}
.site-footer h4{color:#fff;margin:0 0 12px;font-size:1rem;letter-spacing:.02em;text-transform:uppercase}
.site-footer a{color:#c9d3e3}
.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin:.35em 0}
.footer-logo{background:#fff;padding:8px;border-radius:8px;max-width:120px;margin-bottom:16px}
.copy{text-align:center;padding:22px;border-top:1px solid rgba(255,255,255,.08);margin-top:40px;font-size:.85rem;color:#8fa0be}