/* Holly Springs Academy — modern preschool redesign (sample by Ape Studios) */
:root{
  --blue:#1f74b8; --blue-d:#14507f; --blue-l:#e9f3fb;
  --sun:#ffc23c; --coral:#ff6f61; --leaf:#54bd7e; --grape:#8a6fd4; --teal:#21b3a4;
  --ink:#21303f; --muted:#5d6e7e; --line:#e7edf2;
  --paper:#ffffff; --cream:#fbf9f4;
  --shadow:0 18px 40px -18px rgba(20,60,100,.28);
  --shadow-sm:0 8px 22px -12px rgba(20,60,100,.30);
  --r:22px; --r-sm:14px;
  --wrap:1180px;
  --head:'Fredoka',system-ui,sans-serif; --body:'Nunito',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--head);font-weight:600;line-height:1.12;margin:0 0 .4em;color:var(--ink);letter-spacing:-.2px}
h1{font-size:clamp(2.3rem,5vw,3.7rem);font-weight:700}
h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
h3{font-size:1.32rem}
p{margin:0 0 1.1em}
a{color:var(--blue);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--head);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.82rem;color:var(--blue);display:inline-flex;gap:.5em;align-items:center}
.section{padding:84px 0}
.section.tight{padding:60px 0}
.center{text-align:center}
.lead{font-size:1.18rem;color:var(--muted);max-width:680px}
.center .lead{margin-left:auto;margin-right:auto}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--head);font-weight:600;font-size:1.02rem;padding:14px 26px;border-radius:60px;border:2px solid transparent;cursor:pointer;transition:.18s transform,.18s box-shadow,.18s background;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-pri{background:var(--coral);color:#fff;box-shadow:0 12px 24px -10px rgba(255,111,97,.7)}
.btn-pri:hover{background:#ff5a4a;transform:translateY(-2px)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 12px 24px -10px rgba(31,116,184,.7)}
.btn-blue:hover{background:var(--blue-d);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--blue);border-color:#cfe3f3}
.btn-ghost:hover{background:var(--blue-l)}
.btn-lg{padding:17px 34px;font-size:1.1rem}

/* header */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--teal));display:grid;place-items:center;box-shadow:var(--shadow-sm);flex:0 0 auto}
.brand .mark svg{width:28px;height:28px}
.brand b{font-family:var(--head);font-weight:700;font-size:1.22rem;line-height:1;color:var(--ink);display:block}
.brand small{display:block;font-family:var(--head);font-weight:500;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--coral);margin-top:3px}
.menu{display:flex;align-items:center;gap:30px}
.menu a.lk{font-family:var(--head);font-weight:500;color:var(--ink);font-size:1.02rem;position:relative}
.menu a.lk:hover{color:var(--blue)}
.menu a.lk.active{color:var(--blue)}
.menu a.lk.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:3px;border-radius:3px;background:var(--sun)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:3px;border-radius:3px;background:var(--ink);margin:5px 0;transition:.2s}
#mobNav{display:none}

/* hero */
.hero{position:relative;overflow:hidden;min-height:clamp(560px,86vh,880px);display:flex;align-items:center;background:var(--blue-l)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(98deg,rgba(233,243,251,.98) 0%,rgba(233,243,251,.94) 32%,rgba(233,243,251,.70) 50%,rgba(233,243,251,.28) 66%,rgba(233,243,251,0) 84%),
    linear-gradient(180deg,rgba(255,255,255,0) 70%,rgba(255,255,255,.85) 100%)}
.hero-in{position:relative;z-index:2;padding-top:104px;padding-bottom:104px;width:100%}
.hero-copy{max-width:600px}
.hero h1 span{color:var(--blue)}
.hero .lead{margin-bottom:26px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:22px;flex-wrap:wrap;margin-top:34px}
.hero-badges div{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--blue-d);font-size:.96rem}
.hero-badges svg{width:22px;height:22px;flex:0 0 auto}
.wave-sep{display:block;width:100%;height:60px}

/* generic grid */
.grid{display:grid;gap:26px}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* program cards */
.prog{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;box-shadow:var(--shadow-sm);transition:.2s;position:relative;overflow:hidden}
.prog:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.prog .pic{height:7px;border-radius:7px;width:54px;margin-bottom:18px}
.prog .ic{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin-bottom:16px}
.prog .ic svg{width:32px;height:32px}
.prog .age{font-family:var(--head);font-weight:600;font-size:.8rem;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-bottom:4px}
.prog h3{margin-bottom:.4em}
.prog p{font-size:.99rem;color:var(--muted);margin:0}
.prog .tag{position:absolute;top:18px;right:18px;background:var(--leaf);color:#fff;font-family:var(--head);font-weight:600;font-size:.72rem;padding:4px 11px;border-radius:30px;letter-spacing:.03em}

/* feature row */
.feat{display:flex;gap:16px;align-items:flex-start}
.feat .fi{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;flex:0 0 auto;background:var(--blue-l)}
.feat .fi svg{width:28px;height:28px}
.feat h3{font-size:1.12rem;margin-bottom:.25em}
.feat p{font-size:.98rem;color:var(--muted);margin:0}

/* prek band */
.band{background:linear-gradient(120deg,var(--blue),var(--blue-d));color:#fff;border-radius:32px;padding:54px;position:relative;overflow:hidden}
.band h2{color:#fff}
.band .lead{color:rgba(255,255,255,.9)}
.band .free{position:absolute;font-family:var(--head);font-weight:700;opacity:.12;font-size:13rem;right:-10px;top:-40px;line-height:1;pointer-events:none}
.band .inner{position:relative;max-width:660px}

/* about split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.portrait{background:linear-gradient(150deg,var(--sun),var(--coral));border-radius:28px;min-height:380px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.portrait .emoji{position:absolute;inset:0;display:grid;place-items:center;font-size:9rem}
.portrait .quote{position:absolute;left:18px;right:18px;bottom:18px;background:#fff;border-radius:16px;padding:16px 18px;box-shadow:var(--shadow-sm);font-family:var(--head);font-weight:500;font-size:.98rem}
.portrait .quote b{display:block;font-family:var(--body);font-weight:800;color:var(--blue);margin-top:6px;font-size:.86rem}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stats .s b{display:block;font-family:var(--head);font-weight:700;font-size:2.6rem;color:var(--blue);line-height:1}
.stats .s span{color:var(--muted);font-weight:700;font-size:.92rem}

/* cta */
.cta{background:var(--cream);border-radius:32px;padding:60px;text-align:center;border:1px solid var(--line)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow-sm)}
.info-row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px dashed var(--line)}
.info-row:last-child{border-bottom:0}
.info-row .fi{width:44px;height:44px;border-radius:12px;background:var(--blue-l);display:grid;place-items:center;flex:0 0 auto}
.info-row .fi svg{width:22px;height:22px}
.info-row b{font-family:var(--head);font-weight:600;display:block}
.info-row a,.info-row span{color:var(--muted)}
form .fld{margin-bottom:16px}
label{font-family:var(--head);font-weight:500;font-size:.92rem;display:block;margin-bottom:6px}
input,select,textarea{width:100%;font-family:var(--body);font-size:1rem;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-l)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.map{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);min-height:280px}
.map iframe{width:100%;height:100%;min-height:280px;border:0;display:block}

/* footer */
footer{background:#13283a;color:#cfdcea;padding:64px 0 26px;margin-top:10px}
footer .fcols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}
footer h4{color:#fff;font-size:1.05rem;margin-bottom:.9em}
footer a{color:#cfdcea}footer a:hover{color:#fff}
footer .brand b{color:#fff}footer .brand small{color:var(--sun)}
footer ul{list-style:none;padding:0;margin:0;line-height:2.1}
footer .foot-bot{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:20px;font-size:.86rem;color:#8ba2b8}
.sample-tag{display:inline-flex;align-items:center;gap:7px;background:rgba(255,194,60,.16);color:var(--sun);border:1px solid rgba(255,194,60,.35);border-radius:30px;padding:5px 14px;font-weight:700;font-size:.8rem}

/* ===== real-photo components ===== */
.logo-mark{width:56px;height:56px;object-fit:contain;flex:0 0 auto;display:block}
@media(max-width:620px){.logo-mark{width:48px;height:48px}}

/* welcome photo */
.welcome-photo{position:relative;border-radius:28px;overflow:hidden;box-shadow:var(--shadow)}
.welcome-photo img{width:100%;display:block;aspect-ratio:5/4;object-fit:cover}
.welcome-photo .badge-float{position:absolute;left:-14px;bottom:22px;background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:13px 18px;display:flex;align-items:center;gap:11px;font-family:var(--head);font-weight:600}
.welcome-photo .badge-float b{font-size:1.5rem;color:var(--blue);line-height:1}
.welcome-photo .badge-float small{display:block;font-family:var(--body);font-weight:700;color:var(--muted);font-size:.72rem}

/* general age label */
.age{font-family:var(--head);font-weight:600;font-size:.78rem;letter-spacing:.05em;color:var(--blue);text-transform:uppercase;margin-bottom:5px}

/* photo program card (home grid) */
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);transition:.22s;position:relative}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pcard .ph{aspect-ratio:16/11;overflow:hidden}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:.55s ease}
.pcard:hover .ph img{transform:scale(1.06)}
.pcard .bd{padding:20px 22px 24px}
.pcard h3{margin:0 0 .35em}
.pcard p{font-size:.98rem;color:var(--muted);margin:0}
.pcard .tag{position:absolute;top:14px;right:14px;z-index:2;background:var(--leaf);color:#fff;font-family:var(--head);font-weight:600;font-size:.74rem;padding:5px 13px;border-radius:30px;letter-spacing:.04em;box-shadow:0 6px 14px -6px rgba(0,0,0,.4)}

/* photo program row (programs page) */
.prow{display:grid;grid-template-columns:400px 1fr;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);position:relative}
.prow .ph{overflow:hidden;min-height:250px}
.prow .ph img{width:100%;height:100%;object-fit:cover}
.prow .bd{padding:32px 38px;align-self:center}
.prow .bd h3{font-size:1.5rem}
.prow .bd p{margin:0;color:var(--muted)}
.prow .tag{position:absolute;top:16px;left:16px;z-index:2;background:var(--leaf);color:#fff;font-family:var(--head);font-weight:600;font-size:.74rem;padding:5px 13px;border-radius:30px;letter-spacing:.04em}
.prow.flip .ph{order:2}

/* about portrait now holds a real photo */
.portrait{background:var(--blue-l)}
.portrait img.pp{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

@media(max-width:900px){
  .prow{grid-template-columns:1fr}
  .prow .ph{min-height:0}
  .prow .ph img{aspect-ratio:16/10}
  .prow.flip .ph{order:0}
}

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

@media(max-width:900px){
  .split,.contact-grid{grid-template-columns:1fr}
  .hero{align-items:flex-start}
  .hero-in{padding-top:108px;padding-bottom:72px}
  .hero-copy{max-width:none}
  .hero-bg img{object-position:center 28%}
  .hero::after{background:linear-gradient(180deg,rgba(233,243,251,.96) 0%,rgba(233,243,251,.9) 46%,rgba(233,243,251,.52) 74%,rgba(233,243,251,.12) 100%)}
  .g3,.g4{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr;gap:26px}
  footer .fcols{grid-template-columns:1fr 1fr}
  .band,.cta{padding:40px 28px}
}
@media(max-width:620px){
  body{font-size:16px}
  .section{padding:60px 0}
  .menu{display:none}
  .burger{display:block}
  #mobNav.open{display:block;border-top:1px solid var(--line);background:#fff}
  #mobNav a{display:block;padding:15px 24px;font-family:var(--head);font-weight:500;border-bottom:1px solid var(--line);color:var(--ink)}
  .g3,.g4,.g2,.row2{grid-template-columns:1fr}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;justify-content:center}
  .hero-badges{gap:14px}
  .band .free{font-size:8rem}
  footer .fcols{grid-template-columns:1fr}
}
