/* ============================================================
   Next Chapter Art Studio — "Marker & Paint" design system
   Palette pulled straight from the studio's own camp flyers.
   ============================================================ */
:root{
  --paper:#FFFDF6;
  --ink:#2D2A32;
  --ink-soft:#55505c;
  --teal:#3FAEB5;
  --teal-deep:#2E8C92;
  --pink:#F25CA2;
  --pink-deep:#D9418A;
  --yellow:#FFC83D;
  --green:#6FBF73;
  --aqua:#E9F7F8;
  --blush:#FDEFF6;
  --butter:#FFF7E0;
  --shadow:0 10px 30px rgba(45,42,50,.12);
  --radius:18px;
  --font-display:"Caprasimo", "Georgia", serif;
  --font-hand:"Caveat", cursive;
  --font-body:"Nunito", "Segoe UI", sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--teal-deep)}
.container{max-width:1100px;margin:0 auto;padding:0 22px}

h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.15;letter-spacing:.01em}
h1{font-size:clamp(2.1rem,5.4vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.4rem)}
h3{font-size:1.35rem}
.hand{font-family:var(--font-hand);font-weight:700}

/* marker squiggle underline */
.squiggle{position:relative;display:inline-block}
.squiggle svg{position:absolute;left:0;bottom:-.38em;width:100%;height:.5em}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,253,246,.94);
  backdrop-filter:blur(8px);
  border-bottom:3px solid var(--ink);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0;gap:16px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand img{height:48px;width:auto}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{
  text-decoration:none;color:var(--ink);font-weight:800;font-size:.98rem;
  padding:4px 2px;border-bottom:3px solid transparent;
}
.nav-links a:hover,.nav-links a[aria-current="page"]{border-bottom-color:var(--pink)}
.nav-cta{
  background:var(--pink);color:#fff !important;border:2.5px solid var(--ink);
  border-radius:999px;padding:8px 18px !important;box-shadow:3px 3px 0 var(--ink);
  transition:transform .12s ease, box-shadow .12s ease;
}
.nav-cta:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink);border-bottom-color:var(--ink) !important}
.nav-toggle{display:none;background:none;border:2.5px solid var(--ink);border-radius:10px;padding:6px 10px;font-size:1.3rem;cursor:pointer;color:var(--ink)}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;text-decoration:none;font-weight:900;font-size:1.02rem;
  padding:13px 26px;border-radius:999px;border:2.5px solid var(--ink);
  box-shadow:4px 4px 0 var(--ink);transition:transform .12s ease, box-shadow .12s ease;
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}
.btn-pink{background:var(--pink);color:#fff}
.btn-teal{background:var(--teal);color:#fff}
.btn-yellow{background:var(--yellow);color:var(--ink)}
.btn-ghost{background:#fff;color:var(--ink)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden;color:#fff}
.hero video,.hero .hero-fallback{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
}
.hero::after{ /* legibility wash */
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(45,42,50,.55) 0%, rgba(45,42,50,.35) 45%, rgba(45,42,50,.62) 100%);
}
.hero-inner{position:relative;z-index:2;padding:90px 0 130px;max-width:760px}
.hero .eyebrow{
  display:inline-block;background:var(--yellow);color:var(--ink);font-weight:900;
  border:2.5px solid var(--ink);border-radius:999px;padding:6px 16px;font-size:.9rem;
  box-shadow:3px 3px 0 rgba(0,0,0,.35);margin-bottom:18px;letter-spacing:.02em;
}
.hero h1{text-shadow:0 3px 14px rgba(0,0,0,.45)}
.hero p.lede{font-size:1.2rem;margin:16px 0 28px;max-width:560px;text-shadow:0 2px 8px rgba(0,0,0,.5);font-weight:600}
.hero .btn-row{display:flex;gap:14px;flex-wrap:wrap}
/* paint-drip divider at hero bottom */
.drip{position:absolute;left:0;right:0;bottom:-2px;z-index:3;line-height:0}
.drip svg{width:100%;height:60px;display:block}

/* ---------- sections ---------- */
section{padding:72px 0}
.section-head{max-width:640px;margin-bottom:40px}
.section-head .kicker{
  font-family:var(--font-hand);font-size:1.5rem;color:var(--pink-deep);display:block;margin-bottom:4px;
}
.alt{background:var(--aqua)}
.alt-blush{background:var(--blush)}
.alt-butter{background:var(--butter)}

/* ---------- camp cards: flyers taped to the page ---------- */
.camps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.camp-card{
  background:#fff;border:2.5px solid var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:visible;position:relative;
  display:flex;flex-direction:column;
  transition:transform .18s ease;
}
.camp-card:nth-child(1){transform:rotate(-1.2deg)}
.camp-card:nth-child(2){transform:rotate(.8deg)}
.camp-card:nth-child(3){transform:rotate(-.6deg)}
.camp-card:hover{transform:rotate(0deg) translateY(-6px)}
.tape{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%) rotate(-3deg);
  width:110px;height:30px;background:rgba(255,200,61,.85);
  border-left:2px dashed rgba(45,42,50,.25);border-right:2px dashed rgba(45,42,50,.25);
  z-index:2;
}
.camp-card.t2 .tape{background:rgba(63,174,181,.75);transform:translateX(-50%) rotate(2deg)}
.camp-card.t3 .tape{background:rgba(242,92,162,.7);transform:translateX(-50%) rotate(-2deg)}
.camp-card img{border-radius:15px 15px 0 0;width:100%;height:auto}
.camp-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.camp-body h3{font-size:1.3rem}
.badge{
  display:inline-block;font-size:.8rem;font-weight:900;letter-spacing:.04em;
  background:var(--green);color:#fff;border:2px solid var(--ink);border-radius:999px;
  padding:3px 12px;width:max-content;
}
.badge.soon{background:var(--pink)}
.meta-list{list-style:none;font-weight:700;color:var(--ink-soft);font-size:.95rem}
.meta-list li{display:flex;gap:8px;align-items:baseline}
.meta-list .dot{color:var(--pink);font-weight:900}
.camp-body .btn{margin-top:auto;text-align:center}

/* ---------- why parents love it ---------- */
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.perk{
  background:#fff;border:2.5px solid var(--ink);border-radius:var(--radius);
  padding:22px;box-shadow:4px 4px 0 var(--ink);
}
.perk .ico{font-size:1.9rem;line-height:1;margin-bottom:10px;display:block}
.perk h3{font-size:1.08rem;font-family:var(--font-body);font-weight:900;margin-bottom:6px}
.perk p{font-size:.93rem;color:var(--ink-soft)}

/* ---------- gallery: taped polaroids ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.polaroid{
  background:#fff;padding:10px 10px 34px;border:1px solid #e7e2d8;
  box-shadow:var(--shadow);position:relative;
}
.polaroid:nth-child(odd){transform:rotate(-2deg)}
.polaroid:nth-child(even){transform:rotate(1.6deg)}
.polaroid figcaption{
  font-family:var(--font-hand);font-size:1.15rem;text-align:center;
  position:absolute;bottom:4px;left:0;right:0;color:var(--ink-soft);
}
.polaroid::before{
  content:"";position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-2deg);
  width:84px;height:24px;background:rgba(233,247,248,.9);border:1px dashed rgba(45,42,50,.18);
}

/* ---------- teacher ---------- */
.teacher{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:center}
.teacher .photo-frame{
  border:2.5px solid var(--ink);border-radius:var(--radius);overflow:hidden;
  box-shadow:8px 8px 0 var(--teal);transform:rotate(-1.5deg);
}

/* ---------- FAQ ---------- */
.faq details{
  background:#fff;border:2.5px solid var(--ink);border-radius:14px;
  margin-bottom:14px;box-shadow:3px 3px 0 var(--ink);overflow:hidden;
}
.faq summary{
  cursor:pointer;font-weight:900;padding:16px 20px;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--pink);font-weight:400;flex-shrink:0}
.faq details[open] summary::after{content:"–"}
.faq .answer{padding:0 20px 18px;color:var(--ink-soft)}

/* ---------- big CTA band ---------- */
.cta-band{
  background:var(--teal);color:#fff;text-align:center;
  border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);
}
.cta-band h2{color:#fff;margin-bottom:10px}
.cta-band p{max-width:560px;margin:0 auto 26px;font-weight:600}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#d9d4cf;padding:54px 0 32px;font-size:.95rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:34px}
.site-footer h4{color:#fff;font-family:var(--font-body);font-weight:900;margin-bottom:12px;font-size:1rem;letter-spacing:.03em;text-transform:uppercase}
.site-footer a{color:var(--yellow);text-decoration:none}
.site-footer a:hover{text-decoration:underline}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:8px}
.fb-link{display:inline-flex;align-items:center;gap:8px;font-weight:800}
.copyright{border-top:1px solid #4a4651;padding-top:20px;font-size:.85rem;color:#a39e98;text-align:center}

/* ---------- camp detail pages ---------- */
.camp-hero{padding:64px 0 56px}
.camp-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.camp-hero .flyer-frame{
  border:2.5px solid var(--ink);border-radius:var(--radius);overflow:hidden;
  box-shadow:10px 10px 0 var(--pink);transform:rotate(1.4deg);max-width:430px;justify-self:center;
}
.camp-hero.theme-teal .flyer-frame{box-shadow:10px 10px 0 var(--teal)}
.camp-hero.theme-green .flyer-frame{box-shadow:10px 10px 0 var(--green)}
.fact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:26px 0}
.fact{
  background:#fff;border:2.5px solid var(--ink);border-radius:14px;padding:14px 16px;
  box-shadow:3px 3px 0 var(--ink);
}
.fact .label{font-size:.78rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--pink-deep)}
.fact .value{font-weight:900;font-size:1.08rem}
.make-list{list-style:none;display:grid;gap:12px;margin:20px 0}
.make-list li{
  background:#fff;border:2px solid var(--ink);border-radius:12px;padding:12px 16px;
  font-weight:700;display:flex;gap:10px;align-items:baseline;
}
.make-list .star{color:var(--yellow);-webkit-text-stroke:1px var(--ink)}
.countdown-pill{
  display:inline-block;background:var(--yellow);border:2.5px solid var(--ink);
  border-radius:999px;padding:6px 16px;font-weight:900;margin-bottom:14px;
  box-shadow:3px 3px 0 var(--ink);font-size:.92rem;
}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .camps-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .perks{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .teacher,.camp-hero-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--paper);border-bottom:3px solid var(--ink);
    flex-direction:column;padding:18px 22px;gap:16px;align-items:flex-start;
  }
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .hero-inner{padding:70px 0 110px}
  .perks{grid-template-columns:1fr}
  section{padding:54px 0}
}

/* ---------- forms (register page) ---------- */
.form-layout{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start}
.form-card{
  background:#fff;border:2.5px solid var(--ink);border-radius:var(--radius);
  padding:30px 28px;box-shadow:6px 6px 0 var(--teal);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1 / -1}
.field label{font-weight:900;font-size:.92rem}
.field label .req{color:var(--pink-deep)}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:1rem;color:var(--ink);
  border:2.5px solid var(--ink);border-radius:12px;padding:11px 14px;background:var(--paper);
  transition:box-shadow .12s ease;width:100%;
}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;box-shadow:3px 3px 0 var(--pink);background:#fff;
}
.form-card .btn{width:100%;text-align:center;margin-top:22px;font-size:1.1rem}
.form-note{font-size:.85rem;color:var(--ink-soft);margin-top:14px;text-align:center}
.contact-aside .fact{margin-bottom:14px}
.contact-aside h3{margin-bottom:14px}
@media (max-width:920px){
  .form-layout{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}
