/* pages.css — page-specific layouts */

/* ---- Home hero ---- */
.hero {
  padding: clamp(40px, 6vw, 72px) 0 clamp(32px, 4vw, 48px);
  position: relative;
}
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(24px,4vw,48px); align-items: center; }
@media (max-width: 860px) { .hero-grid { grid-template-columns: 1fr; } }
.hero h1 { margin: 18px 0 16px; }
.hero h1 .grad { background: var(--grad-warm); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero .hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 28px 40px; margin-top: 34px; }

/* hero visual — CSS pitch + ball */
.hero-visual {
  position: relative; aspect-ratio: 1/1; max-width: 460px; margin-inline: auto; width: 100%;
}
.pitch {
  position: absolute; inset: 0; border-radius: var(--radius-l);
  background: linear-gradient(135deg, #2fd07a, #20c4e0 70%);
  box-shadow: var(--shadow-l); overflow: hidden;
}
.pitch::before {
  content:""; position:absolute; inset:0;
  background: repeating-linear-gradient(115deg, rgba(255,255,255,.0) 0 38px, rgba(255,255,255,.07) 38px 76px);
}
.pitch .lines { position:absolute; inset:8%; border: 3px solid rgba(255,255,255,.7); border-radius: 18px; }
.pitch .center { position:absolute; left:50%; top:50%; width: 34%; aspect-ratio:1; border:3px solid rgba(255,255,255,.7); border-radius:50%; transform: translate(-50%,-50%); }
.pitch .center::after { content:""; position:absolute; left:50%; top:0; width:3px; height:100%; background: rgba(255,255,255,.7); transform: translateX(-50%); }
.ball {
  position:absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  width: 96px; height: 96px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff, #e7e3f5 70%);
  box-shadow: 0 16px 30px rgba(0,0,0,.25), inset -8px -10px 20px rgba(0,0,0,.12);
  animation: float 5s ease-in-out infinite;
}
.ball svg { width: 100%; height: 100%; }
.float-chip {
  position: absolute; background: var(--c-card); border-radius: 16px; box-shadow: var(--shadow-m);
  padding: 10px 14px; display:flex; align-items:center; gap:10px; font-family: var(--font-head); font-weight:700; font-size:.85rem;
  animation: float 6s ease-in-out infinite;
}
.float-chip .dot { width: 30px; height:30px; border-radius:10px; display:grid; place-items:center; color:#fff; }
.float-chip .dot svg { width:18px; height:18px; }
.float-chip--1 { top: 6%; left: -6%; }
.float-chip--2 { bottom: 8%; right: -6%; animation-delay: -2s; }
.float-chip--3 { top: 44%; right: -10%; animation-delay: -3.5s; }
@media (max-width: 520px){ .float-chip--1{left:0} .float-chip--2{right:0} .float-chip--3{display:none} }
@keyframes float { 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-12px) } }

/* countdown / wc strip */
.wc-strip {
  background: #12102a; color:#fff; border-radius: var(--radius-l);
  padding: clamp(24px,3vw,36px); display:grid; grid-template-columns: 1fr auto; gap: 24px; align-items:center;
  position: relative; overflow:hidden;
}
.wc-strip::after { content:""; position:absolute; right:-60px; top:-60px; width:240px; height:240px; border-radius:50%; background: var(--grad-warm); opacity:.5; filter: blur(20px); }
.wc-strip h2 { color:#fff; position:relative; }
.wc-strip p { color: #cfc9ec; position: relative; }
.wc-count { display:flex; gap:14px; position:relative; }
.wc-count .unit { background: rgba(255,255,255,.08); border-radius:16px; padding:14px 16px; text-align:center; min-width:78px; }
.wc-count .u-num { font-family: var(--font-head); font-weight:800; font-size:1.9rem; line-height:1; }
.wc-count .u-lbl { font-size:.72rem; color:#a9a3d0; margin-top:6px; letter-spacing:.05em; text-transform:uppercase; }
@media (max-width:680px){ .wc-strip { grid-template-columns: 1fr; } }

/* section head */
.sec-head { display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-end; gap:16px; margin-bottom: 28px; }
.sec-head .lede { margin-top: 10px; }

/* about timeline */
.timeline { position: relative; padding-left: 28px; }
.timeline::before { content:""; position:absolute; left:7px; top:6px; bottom:6px; width:3px; background: var(--grad-hero); border-radius:3px; }
.tl-item { position: relative; padding: 0 0 26px; }
.tl-item::before { content:""; position:absolute; left:-25px; top:4px; width:15px; height:15px; border-radius:50%; background:#fff; border:3px solid var(--c-grape); }
.tl-item h3 { font-size:1.15rem; }
.tl-item .yr { font-family: var(--font-head); font-weight:800; color: var(--c-pink); font-size:.95rem; }

/* values grid icons */
.value-ic { width:48px;height:48px;border-radius:14px;display:grid;place-items:center;color:#fff;margin-bottom:14px; }
.value-ic svg{ width:24px;height:24px; }

/* contact two-col */
.contact-wrap { display:grid; grid-template-columns: 1fr .9fr; gap: clamp(24px,4vw,40px); align-items:start; }
@media (max-width: 820px){ .contact-wrap { grid-template-columns:1fr; } }
.map-card { border-radius: var(--radius-l); overflow:hidden; min-height: 320px; background: var(--grad-cool); position:relative; box-shadow: var(--shadow-m); }
.map-card .map-pin { position:absolute; left:50%; top:46%; transform:translate(-50%,-50%); width:64px;height:64px; }
.map-card::before { content:""; position:absolute; inset:0; background-image: linear-gradient(rgba(255,255,255,.16) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.16) 1px, transparent 1px); background-size: 40px 40px; }
.map-card .map-label { position:absolute; left:0; right:0; bottom:0; padding:18px 20px; color:#fff; background:linear-gradient(transparent,rgba(0,0,0,.35)); font-family:var(--font-head); font-weight:700; }

/* academies list */
.aca-row { display:grid; grid-template-columns: auto 1fr auto; gap:18px; align-items:center; padding:18px 0; border-bottom:1px solid var(--c-line); }
.aca-row:last-child { border-bottom:0; }
.aca-badge { width:54px;height:54px;border-radius:14px;display:grid;place-items:center;color:#fff;font-family:var(--font-head);font-weight:800; }
.aca-row h3 { font-size:1.1rem; }
.aca-row .meta { font-size:.88rem; color:var(--c-ink-soft); }
@media (max-width:560px){ .aca-row { grid-template-columns:auto 1fr; } .aca-row .badge { grid-column: 2; } }

/* legal page */
.legal { max-width: 78ch; }
.legal h2 { margin: 30px 0 10px; font-size: 1.4rem; }
.legal h3 { margin: 20px 0 6px; }
.legal p, .legal li { font-size: 1rem; }
.legal .updated { color: var(--c-ink-soft); font-size:.9rem; }

/* checklist */
.checklist { list-style:none; padding:0; }
.checklist li { display:flex; gap:12px; padding:10px 0; align-items:flex-start; }
.checklist li::before { content:""; flex:0 0 auto; width:24px;height:24px;border-radius:8px; background: var(--grad-cool); margin-top:2px;
  -webkit-mask: no-repeat center / 14px url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");
  mask: no-repeat center / 14px url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");
}

/* ---- Photos / media (added) ---- */
/* home hero background photo + scrim */
.hero { overflow: hidden; }
.hero .hero-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
}
.hero .hero-bg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero .hero-bg::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(105deg, rgba(13,11,33,.92) 0%, rgba(13,11,33,.80) 42%, rgba(13,11,33,.40) 100%);
}
.hero .hero-grid { position: relative; z-index: 1; }
.hero .eyebrow { background: rgba(255,255,255,.16); color:#fff; }
.hero .eyebrow::before { background:#fff; }
.hero h1, .hero .lede { color: #fff; }
.hero .lede { color: rgba(255,255,255,.9); }
.hero .stat .num { color:#fff; }
.hero .stat .lbl { color: rgba(255,255,255,.82); }
.hero .btn--ghost { background: rgba(255,255,255,.10); color:#fff; border-color: rgba(255,255,255,.32); }
.hero .btn--ghost:hover { background: rgba(255,255,255,.18); color:#fff; border-color:#fff; }

/* page-hero background photo + scrim */
.page-hero { isolation: isolate; }
.page-hero .ph-bg { position: absolute; inset: 0; z-index: -1; }
.page-hero .ph-bg img { width:100%; height:100%; object-fit: cover; display:block; }
.page-hero .ph-bg::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(120deg, rgba(13,11,33,.86), rgba(74,47,208,.62));
}
.page-hero .container { position: relative; z-index: 1; }

/* card media thumbnail */
.card-media {
  display:block; border-radius: var(--radius-m); overflow:hidden;
  aspect-ratio: 16/10; margin-bottom: 16px; background: var(--grad-hero);
}
.card-media img { width:100%; height:100%; object-fit: cover; display:block; transition: transform .4s ease; }
.card-link:hover .card-media img, .tile:hover .tile-media img { transform: scale(1.05); }

/* tile media (cover photo for feature tiles) */
.tile { position: relative; }
.tile-media { position:absolute; inset:0; z-index:0; }
.tile-media img { width:100%; height:100%; object-fit: cover; display:block; transition: transform .4s ease; }
.tile-media::after { content:""; position:absolute; inset:0; background: linear-gradient(160deg, rgba(13,11,33,.55), rgba(13,11,33,.78)); }
.tile.has-media > *:not(.tile-media) { position: relative; z-index: 1; }

/* mini gallery */
.gallery { display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.gallery figure { margin:0; }
.gallery .photo { aspect-ratio: 1/1; }
.gallery figcaption { font-size:.82rem; color: var(--c-ink-soft); margin-top: 8px; }
@media (max-width: 760px){ .gallery { grid-template-columns: repeat(2, 1fr); } }

/* feature image block (prose / generic) */
.feature-img { border-radius: var(--radius-l); overflow:hidden; box-shadow: var(--shadow-m); aspect-ratio: 16/10; background: var(--grad-hero); }
.feature-img img { width:100%; height:100%; object-fit: cover; display:block; }

/* faq */
.faq { border:1px solid var(--c-line); border-radius:var(--radius-m); overflow:hidden; background:var(--c-card); }
.faq details { border-bottom:1px solid var(--c-line); }
.faq details:last-child { border-bottom:0; }
.faq summary { cursor:pointer; padding:18px 22px; font-family:var(--font-head); font-weight:700; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:14px; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; font-size:1.4rem; color:var(--c-grape); transition:transform .2s; }
.faq details[open] summary::after { transform:rotate(45deg); }
.faq .faq-body { padding: 0 22px 20px; }
.faq .faq-body p { font-size:.98rem; }
