/* PlayMakers marketing site styling (Plan 3). Tokens come from design-system.css. */

/* ── Header / nav ─────────────────────────────────────────────────────────── */
.pm-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(247, 241, 227, 0.92);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--pm-gray-300);
}
.pm-header-inner { display: flex; align-items: center; gap: 1rem; min-height: 64px; }
.pm-brand { display: inline-flex; flex-direction: column; text-decoration: none; line-height: 1; }
.pm-brand .pm-wordmark { font-size: 1.5rem; }
.pm-brand .pm-brand-sub { font-family: var(--pm-font-head); font-size: .62rem; letter-spacing: .22em; text-transform: uppercase; color: var(--pm-blue-deep); }
.pm-nav { margin-left: auto; display: flex; align-items: center; gap: .35rem; }
.pm-nav a { color: var(--pm-ink); text-decoration: none; font-weight: 600; padding: .55rem .7rem; border-radius: 999px; font-size: .95rem; }
.pm-nav a:hover { background: var(--pm-gray-100); }
.pm-nav a[aria-current="page"] { color: var(--pm-blue-deep); background: rgba(42,168,224,.12); }
.pm-nav .pm-btn { color: #fff; }
.pm-lang { background: #fff; border: 2px solid var(--pm-gray-300); border-radius: 999px; padding: .4rem .7rem; font-weight: 700; cursor: pointer; min-height: 40px; }
.pm-nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: .5rem; margin-left: auto; }
.pm-nav-toggle span { display: block; width: 24px; height: 3px; margin: 4px 0; background: var(--pm-ink); border-radius: 2px; }

@media (max-width: 860px) {
  .pm-nav-toggle { display: block; }
  .pm-nav { position: absolute; left: 0; right: 0; top: 100%; flex-direction: column; align-items: stretch;
    gap: 0; background: var(--pm-cream); border-bottom: 1px solid var(--pm-gray-300);
    padding: .5rem clamp(1rem,4vw,2rem) 1rem; display: none; }
  .pm-header.open .pm-nav { display: flex; }
  .pm-nav a, .pm-nav .pm-btn, .pm-nav .pm-lang { width: 100%; text-align: center; margin: .25rem 0; }
}

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.pm-hero { background:
    radial-gradient(120% 80% at 80% -10%, rgba(255,200,61,.18), transparent 60%),
    var(--pm-cream); }
.pm-hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; padding-block: clamp(2.5rem, 6vw, 5rem); }
.pm-hero h1 { font-family: var(--pm-font-poster); font-weight: 800;
  font-size: clamp(2.6rem, 1.8rem + 4vw, 4.5rem); margin: .1em 0 .25em; letter-spacing: -.01em; }
.pm-hero p.lede { font-size: clamp(1.05rem, 1rem + .4vw, 1.3rem); max-width: 46ch; color: #41464d; }
.pm-hero-cta { display: flex; flex-wrap: wrap; gap: .8rem; margin: 1.4rem 0 1.1rem; }
.pm-hero .pm-btn--gradient { background-image: var(--pm-gradient-ring); }
.pm-hero-meta { font-weight: 600; color: var(--pm-blue-deep); display: flex; flex-wrap: wrap; gap: .4rem 1rem; }
.pm-hero-figure { position: relative; }
.pm-hero-figure img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: var(--pm-radius); box-shadow: var(--pm-shadow-lg); background: var(--pm-gray-100); }
.pm-hero-sticker { position: absolute; top: -14px; right: -10px; transform: rotate(8deg);
  background-image: var(--pm-gradient-ring); color: #fff; font-family: var(--pm-font-head); font-weight: 700;
  padding: .7rem 1rem; border-radius: 999px; box-shadow: var(--pm-shadow); text-align: center; line-height: 1.05; }

@media (max-width: 760px) { .pm-hero-grid { grid-template-columns: 1fr; } .pm-hero-figure { order: -1; } }

/* ── Generic sections ─────────────────────────────────────────────────────── */
.pm-section { padding-block: clamp(2.5rem, 6vw, 4.5rem); }
.pm-section--cream { background: var(--pm-cream); }
.pm-section-head { max-width: 60ch; margin-bottom: 1.8rem; }
.pm-section-head h2 { font-size: clamp(1.6rem, 1.2rem + 2vw, 2.4rem); margin: .15em 0 .3em; }
.pm-section-head p { color: #41464d; }

/* ── Summer-camp week rail ────────────────────────────────────────────────── */
.pm-week-rail { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 1.1rem; }
.pm-week-card { --accent: var(--pm-accent-school); background: #fff; border-radius: var(--pm-radius);
  border: 1px solid var(--pm-gray-300); overflow: hidden; display: flex; flex-direction: column;
  box-shadow: var(--pm-shadow); transition: transform .14s ease, box-shadow .14s ease; }
.pm-week-card:hover { transform: translateY(-4px); box-shadow: var(--pm-shadow-lg); }
.pm-week-card .cap { background: var(--accent); color: #fff; padding: 1rem 1.1rem; }
.pm-week-card .cap .wk { font-family: var(--pm-font-head); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; font-size: .78rem; opacity: .92; }
.pm-week-card .cap h3 { color: #fff; margin: .2em 0 0; font-size: 1.35rem; }
.pm-week-card .body { padding: 1rem 1.1rem 1.2rem; display: flex; flex-direction: column; gap: .6rem; flex: 1; }
.pm-week-card .dates { font-weight: 700; color: var(--pm-ink); }
.pm-week-card .hook { color: #41464d; font-size: .95rem; flex: 1; }
.pm-week-card .price { font-family: var(--pm-font-head); font-weight: 600; }
.pm-week-card .pm-btn { width: 100%; text-align: center; }

/* ── Trust / nut-free strip ───────────────────────────────────────────────── */
.pm-trust { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.2rem; }
.pm-trust .item { background: #fff; border-radius: var(--pm-radius); padding: 1.2rem; box-shadow: var(--pm-shadow); }
.pm-trust .item .ico { font-size: 1.8rem; }
.pm-trust .item h3 { font-size: 1.1rem; margin: .4em 0 .2em; }

/* ── Programs teaser + gallery ────────────────────────────────────────────── */
.pm-cards2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.2rem; }
.pm-card { background: #fff; border-radius: var(--pm-radius); border: 1px solid var(--pm-gray-300); padding: 1.4rem; box-shadow: var(--pm-shadow); }
.pm-card h3 { font-size: 1.3rem; margin: 0 0 .4em; }
.pm-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: .8rem; }
.pm-gallery img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: var(--pm-radius-sm); background: var(--pm-gray-100); }
.pm-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem,4vw,3rem); align-items: center; }
.pm-split img { width: 100%; border-radius: var(--pm-radius); box-shadow: var(--pm-shadow-lg); object-fit: cover; }
@media (max-width: 760px) { .pm-split { grid-template-columns: 1fr; } }

/* ── Contact ──────────────────────────────────────────────────────────────── */
.pm-contact-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .9rem; }
.pm-contact-list a { color: var(--pm-blue-deep); font-weight: 600; }
.pm-map { width: 100%; aspect-ratio: 16/10; border: 0; border-radius: var(--pm-radius); box-shadow: var(--pm-shadow); }

/* ── Footer ───────────────────────────────────────────────────────────────── */
.pm-footer { background: var(--pm-ink); color: #EDE7DA; padding-block: 2.6rem; }
.pm-footer a { color: #EDE7DA; text-decoration: none; }
.pm-footer a:hover { text-decoration: underline; }
.pm-footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.6rem; }
.pm-footer .pm-wordmark { color: #fff; font-size: 1.4rem; }
.pm-footer h4 { font-family: var(--pm-font-head); margin: 0 0 .6em; }
.pm-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .4rem; }
.pm-footer-bottom { margin-top: 1.8rem; padding-top: 1.2rem; border-top: 1px solid rgba(255,255,255,.16); font-size: .85rem; opacity: .85; }

/* ── On-brand error pages ─────────────────────────────────────────────────── */
.pm-error { min-height: 70vh; display: grid; place-items: center; text-align: center; background:
  radial-gradient(120% 80% at 50% -10%, rgba(255,111,181,.18), transparent 60%), var(--pm-cream); }
.pm-error .pm-wordmark { font-size: clamp(2.4rem, 1.6rem + 4vw, 4rem); }
.pm-error .code { font-family: var(--pm-font-poster); font-weight: 800; font-size: clamp(3rem,2rem+6vw,6rem); background-image: var(--pm-gradient-ring); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ── Motion ───────────────────────────────────────────────────────────────── */
.pm-reveal { opacity: 0; transform: translateY(14px); transition: opacity .5s ease, transform .5s ease; }
.pm-reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .pm-week-card, .pm-reveal { transition: none !important; }
  .pm-reveal { opacity: 1; transform: none; }
  .pm-hero-sticker { transform: none; }
  * { scroll-behavior: auto !important; }
}

/* Testimonials */
.pm-testimonials { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.pm-testimonial { background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: 16px; padding: 1.25rem 1.4rem; box-shadow: 0 6px 20px rgba(0,0,0,.05); }
.pm-testimonial blockquote { margin: 0 0 .6rem; font-size: 1.02rem; line-height: 1.5; }
.pm-testimonial-en { margin: 0 0 .6rem; color: #555; font-size: .92rem; }
.pm-testimonial figcaption { font-weight: 600; color: var(--pm-blue-deep, #2b3a67); font-size: .9rem; }
/* FAQ */
.pm-faq { display: grid; gap: .75rem; max-width: 760px; }
.pm-faq .faq-item { background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: 14px; padding: 1rem 1.2rem; }
.pm-faq .faq-item h3 { margin: 0 0 .35rem; font-size: 1.02rem; }
.pm-faq .faq-item p { margin: 0; color: #444; }
