/* ============================================================
   STONE EDGE YOUTH — Gen-Z sub-brand
   Bold, kinetic, sticker-culture energy on near-black.
   Acid lime + electric blue, oversized grotesque type,
   marquee tickers, glow, grain. Distinct from the main
   church look but uses the shared dark nav + footer.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,400;0,600;0,800;0,900;1,700&family=Space+Grotesk:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root {
  --yo-ink:    #0A0C0B;
  --yo-ink-2:  #121615;
  --yo-ink-3:  #1B201E;
  --yo-lime:   #C8FF35;   /* acid pop */
  --yo-lime-d: #A6E000;
  --yo-blue:   #4DA3FF;   /* electric */
  --yo-blue-d: #1E7BE6;
  --yo-violet: #9A7CFF;
  --yo-pink:   #FF5CA8;
  --yo-white:  #F2F6F4;
  --yo-fg-2:   #A6B0AC;
  --yo-line:   rgba(242,246,244,0.12);

  --yo-display: 'Archivo', system-ui, sans-serif;     /* heavy expanded */
  --yo-impact:  'Anton', 'Archivo', sans-serif;       /* condensed slam */
  --yo-sans:    'Space Grotesk', system-ui, sans-serif;
  --yo-mono:    'Space Mono', ui-monospace, monospace;

  --yo-maxw: 1280px;
  --yo-gutter: clamp(18px, 5vw, 72px);
  --yo-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

body.youth {
  margin: 0; background: var(--yo-ink); color: var(--yo-white);
  font-family: var(--yo-sans); font-size: 1.0625rem; line-height: 1.6;
  -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
.youth img { max-width: 100%; display: block; }
.youth a { color: inherit; text-decoration: none; }

/* film grain overlay */
.youth::before {
  content: ""; position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

.y-wrap { width: 100%; max-width: var(--yo-maxw); margin-inline: auto; padding-inline: var(--yo-gutter); position: relative; z-index: 2; }
.y-section { padding-block: clamp(56px, 9vw, 120px); position: relative; }

/* ---------- type ---------- */
.y-slam { font-family: var(--yo-impact); text-transform: uppercase; line-height: 0.84; letter-spacing: 0.01em; margin: 0; font-weight: 400; }
.y-display { font-family: var(--yo-display); font-weight: 900; line-height: 0.92; letter-spacing: -0.02em; margin: 0; }
.y-h2 { font-family: var(--yo-impact); text-transform: uppercase; font-size: clamp(2.5rem, 6vw, 5rem); line-height: 0.88; margin: 0; font-weight: 400; }
.y-h3 { font-family: var(--yo-display); font-weight: 800; font-size: 1.6rem; line-height: 1.05; margin: 0; }
.y-tag { font-family: var(--yo-mono); font-size: 0.8rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--yo-lime); margin: 0; }
.y-lead { font-size: clamp(1.1rem, 1.6vw, 1.45rem); line-height: 1.45; font-weight: 500; margin: 0; text-wrap: pretty; }
.y-body { color: var(--yo-fg-2); margin: 0; text-wrap: pretty; font-weight: 400; }

.y-lime { color: var(--yo-lime); }
.y-blue { color: var(--yo-blue); }
.y-outline { color: transparent; -webkit-text-stroke: 2px var(--yo-white); }
.y-outline-lime { color: transparent; -webkit-text-stroke: 2px var(--yo-lime); }

/* ---------- sticker chips ---------- */
.y-chip {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--yo-mono); font-size: 0.8rem; font-weight: 700;
  letter-spacing: 0.02em; text-transform: uppercase;
  padding: 8px 15px; border-radius: 999px; border: 1.5px solid var(--yo-line);
  background: var(--yo-ink-2); color: var(--yo-white); white-space: nowrap;
}
.y-chip--lime { background: var(--yo-lime); color: #0A0C0B; border-color: var(--yo-lime); }
.y-chip--blue { background: var(--yo-blue); color: #04121F; border-color: var(--yo-blue); }
.y-chip--outline { background: transparent; }

/* sticker = rotated chip */
.y-sticker { transform: rotate(var(--rot, -4deg)); transition: transform 0.25s var(--yo-ease); }
.y-sticker:hover { transform: rotate(0deg) scale(1.05); }

/* ---------- buttons ---------- */
.y-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--yo-display); font-weight: 800; font-size: 1.05rem;
  letter-spacing: -0.01em; padding: 15px 28px; border-radius: 14px;
  border: 0; cursor: pointer; transition: transform 0.2s var(--yo-ease), box-shadow 0.25s var(--yo-ease), background 0.2s;
}
.y-btn:hover { transform: translateY(-3px); }
.y-btn .a { transition: transform 0.3s var(--yo-ease); }
.y-btn:hover .a { transform: translateX(4px); }
.y-btn--lime { background: var(--yo-lime); color: #0A0C0B; box-shadow: 0 0 0 1px rgba(200,255,53,0.4), 0 12px 36px rgba(200,255,53,0.25); }
.y-btn--lime:hover { background: #d6ff5c; }
.y-btn--blue { background: var(--yo-blue); color: #04121F; }
.y-btn--ghost { background: transparent; color: var(--yo-white); box-shadow: inset 0 0 0 2px var(--yo-line); }
.y-btn--ghost:hover { box-shadow: inset 0 0 0 2px var(--yo-white); }

/* ============================================================
   HERO
   ============================================================ */
.y-hero { position: relative; overflow: hidden; padding-top: clamp(120px, 15vw, 180px); padding-bottom: 0; }
.y-hero__glow { position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(60% 50% at 78% 18%, rgba(77,163,255,0.22), transparent 70%),
    radial-gradient(55% 45% at 12% 80%, rgba(200,255,53,0.16), transparent 70%);
}
.y-hero__inner { position: relative; z-index: 2; }
.y-hero__stickers { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 26px; }
.y-hero__title { font-size: clamp(4.5rem, 19vw, 17rem); position: relative; }
.y-hero__title .l2 { display: block; }
.y-hero__sub { display: flex; flex-wrap: wrap; align-items: baseline; gap: 14px 22px; margin-top: 22px; }
.y-hero__when { font-family: var(--yo-display); font-weight: 900; font-size: clamp(1.5rem, 3vw, 2.4rem); color: var(--yo-lime); letter-spacing: -0.01em; }
.y-hero__desc { max-width: 46ch; margin-top: 20px; color: var(--yo-white); }
.y-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.y-hero__photo { margin-top: clamp(40px, 6vw, 72px); border-radius: 20px 20px 0 0; overflow: hidden; border: 1.5px solid var(--yo-line); border-bottom: 0; }
.y-hero__photo image-slot, .y-hero__photo img { width: 100%; height: clamp(280px, 38vw, 460px); object-fit: cover; }

/* ============================================================
   MARQUEE
   ============================================================ */
.y-marquee { background: var(--yo-lime); color: #0A0C0B; padding-block: 16px; overflow: hidden; white-space: nowrap; border-block: 2px solid #0A0C0B; }
.y-marquee--blue { background: var(--yo-blue); color: #04121F; }
.y-marquee__track { display: inline-flex; gap: 0; animation: y-scroll 26s linear infinite; will-change: transform; }
.y-marquee__track span { font-family: var(--yo-impact); text-transform: uppercase; font-size: clamp(1.4rem, 3vw, 2.4rem); padding-inline: 22px; display: inline-flex; align-items: center; gap: 22px; }
.y-marquee__track span::after { content: "✦"; font-size: 0.7em; }
@keyframes y-scroll { to { transform: translateX(-50%); } }
@keyframes y-scroll-rev { from { transform: translateX(-50%); } to { transform: translateX(0); } }
.y-marquee--blue .y-marquee__track { animation: y-scroll-rev 22s linear infinite; }
.y-marquee--right .y-marquee__track { animation: y-scroll-rev 26s linear infinite; }
@media (prefers-reduced-motion: reduce) { .y-marquee__track { animation: none; } }

/* ============================================================
   BENTO — "A NIGHT AT YOUTH"
   ============================================================ */
.y-bento-head { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: clamp(32px, 5vw, 56px); }
.y-bento { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; gap: 16px; }
.y-tile { position: relative; overflow: hidden; border-radius: 18px; border: 1.5px solid var(--yo-line); background: var(--yo-ink-2); padding: 26px; display: flex; flex-direction: column; justify-content: flex-end; transition: border-color 0.3s var(--yo-ease), transform 0.3s var(--yo-ease); }
.y-tile:hover { transform: translateY(-4px); }
.y-tile__n { position: absolute; top: 20px; right: 24px; font-family: var(--yo-mono); font-size: 0.85rem; color: var(--yo-fg-2); }
.y-tile h3 { font-family: var(--yo-impact); text-transform: uppercase; font-size: 2rem; line-height: 0.9; margin: 0 0 8px; }
.y-tile p { color: var(--yo-fg-2); font-size: 0.95rem; margin: 0; }
.y-tile--lg { grid-column: span 2; grid-row: span 2; }
.y-tile--wide { grid-column: span 2; }
.y-tile--worship { background: linear-gradient(160deg, rgba(77,163,255,0.18), var(--yo-ink-2) 60%); border-color: rgba(77,163,255,0.35); }
.y-tile--worship:hover { border-color: var(--yo-blue); }
.y-tile--word { background: linear-gradient(160deg, rgba(200,255,53,0.16), var(--yo-ink-2) 60%); border-color: rgba(200,255,53,0.32); }
.y-tile--word:hover { border-color: var(--yo-lime); }
.y-tile--groups:hover { border-color: var(--yo-violet); }
.y-tile--games:hover { border-color: var(--yo-pink); }
.y-tile__ico { width: 46px; height: 46px; }
.y-tile--lg h3 { font-size: clamp(2.5rem, 4vw, 3.5rem); }
.y-tile--lg p { font-size: 1.05rem; max-width: 32ch; }
.y-tile__cut { position: absolute; right: -8px; bottom: 0; height: 112%; width: auto; max-width: 62%; object-fit: contain; object-position: bottom right; z-index: 0; pointer-events: none; filter: saturate(1.05) contrast(1.05); -webkit-mask-image: linear-gradient(to left, #000 60%, transparent 100%); mask-image: linear-gradient(to left, #000 60%, transparent 100%); }
.y-tile--worship > *:not(.y-tile__cut) { position: relative; z-index: 1; }

/* brand band */
.y-brandband { width: 100%; line-height: 0; background: var(--yo-ink-2); border-block: 1.5px solid var(--yo-line); }
.y-brandband img { width: 100%; height: auto; display: block; }

/* ============================================================
   GRADES SPLIT
   ============================================================ */
.y-grades { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.y-grade { border-radius: 20px; padding: clamp(28px, 4vw, 48px); position: relative; overflow: hidden; min-height: 300px; display: flex; flex-direction: column; }
.y-grade--ms { background: var(--yo-blue); color: #04121F; }
.y-grade--hs { background: var(--yo-lime); color: #0A0C0B; }
.y-grade__label { font-family: var(--yo-mono); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.85rem; }
.y-grade h3 { font-family: var(--yo-impact); text-transform: uppercase; font-size: clamp(2.5rem, 5vw, 4rem); line-height: 0.86; margin: 14px 0 0; }
.y-grade__grades { font-family: var(--yo-display); font-weight: 900; font-size: clamp(3rem, 7vw, 6rem); line-height: 0.9; margin-top: auto; opacity: 0.9; }
.y-grade p { margin: 16px 0 0; font-weight: 500; max-width: 34ch; }
.y-grade--all { grid-column: 1 / -1; display: grid; grid-template-columns: 1.2fr 0.8fr; gap: clamp(20px,4vw,48px); align-items: center; }
.y-grade--all .y-grade__txt { display: flex; flex-direction: column; }
.y-grade--all .y-grade__grades { margin: 0; justify-self: end; font-size: clamp(5rem, 14vw, 12rem); line-height: 0.8; }
.y-grade--all h3 { font-size: clamp(2.5rem, 6vw, 5rem); }
@media (max-width: 640px){ .y-grade--all { grid-template-columns: 1fr; } .y-grade--all .y-grade__grades { justify-self: start; margin-top: 12px; } }

/* ============================================================
   GALLERY
   ============================================================ */
.y-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.y-gallery image-slot { width: 100%; height: clamp(160px, 20vw, 260px); border-radius: 14px; overflow: hidden; }
.y-gallery image-slot:nth-child(1) { grid-column: span 2; grid-row: span 2; height: 100%; min-height: clamp(332px, 41vw, 532px); }

/* ============================================================
   PARENTS / INFO
   ============================================================ */
.y-info { background: var(--yo-ink-2); }
.y-info__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(32px, 6vw, 80px); align-items: center; }
.y-checklist { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.y-check { display: flex; gap: 14px; align-items: flex-start; }
.y-check__tick { width: 28px; height: 28px; border-radius: 8px; background: var(--yo-lime); color: #0A0C0B; display: grid; place-items: center; flex-shrink: 0; font-weight: 800; font-family: var(--yo-display); }
.y-check b { font-family: var(--yo-display); font-weight: 700; }
.y-bigcard { background: var(--yo-ink-3); border: 1.5px solid var(--yo-line); border-radius: 20px; padding: clamp(28px, 4vw, 44px); }
.y-bigcard__row { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; padding-block: 16px; border-bottom: 1px solid var(--yo-line); }
.y-bigcard__row:last-child { border-bottom: 0; }
.y-bigcard__row .k { font-family: var(--yo-mono); text-transform: uppercase; font-size: 0.8rem; color: var(--yo-fg-2); letter-spacing: 0.04em; }
.y-bigcard__row .v { font-family: var(--yo-display); font-weight: 800; font-size: 1.3rem; }

/* ============================================================
   FAQ
   ============================================================ */
.y-faq { max-width: 820px; }
.y-faq__item { border-bottom: 1px solid var(--yo-line); }
.y-faq__q { width: 100%; text-align: left; background: none; border: 0; color: var(--yo-white); padding: 22px 0; display: flex; justify-content: space-between; align-items: center; gap: 20px; font-family: var(--yo-display); font-weight: 700; font-size: 1.3rem; cursor: pointer; }
.y-faq__q .ic { color: var(--yo-lime); font-size: 1.6rem; transition: transform 0.3s var(--yo-ease); flex-shrink: 0; line-height: 1; }
.y-faq__item.open .y-faq__q .ic { transform: rotate(45deg); }
.y-faq__a { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.y-faq__a p { padding-bottom: 22px; margin: 0; color: var(--yo-fg-2); max-width: 64ch; }

/* ============================================================
   CTA
   ============================================================ */
.y-cta { position: relative; overflow: hidden; text-align: center; padding-block: clamp(64px, 10vw, 140px); }
.y-cta__glow { position: absolute; inset: 0; z-index: 0; background: radial-gradient(50% 60% at 50% 40%, rgba(200,255,53,0.18), transparent 70%); pointer-events: none; }
.y-cta__inner { position: relative; z-index: 2; }
.y-cta__title { font-size: clamp(3rem, 12vw, 9rem); }
.y-cta__actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; margin-top: 32px; }

/* ============================================================
   ANIMATION + DECORATIVE STICKERS
   ============================================================ */
/* floating doodle stickers */
.y-deco { position: absolute; z-index: 1; pointer-events: none; will-change: transform; }
.y-deco svg { display: block; }

@media (prefers-reduced-motion: no-preference) {
  /* hero entrance */
  .y-hero__title { animation: y-rise 0.7s var(--yo-ease) both; }
  .y-hero__sub { animation: y-rise 0.7s var(--yo-ease) 0.12s both; }
  .y-hero__desc { animation: y-rise 0.7s var(--yo-ease) 0.2s both; }
  .y-hero__actions { animation: y-rise 0.7s var(--yo-ease) 0.28s both; }
  .y-hero__stickers .y-sticker { animation: y-pop 0.5s var(--yo-pop) both, y-stickwiggle 4.5s ease-in-out infinite; }
  .y-hero__stickers .y-sticker:nth-child(1) { animation-delay: 0.15s, 0.9s; }
  .y-hero__stickers .y-sticker:nth-child(2) { animation-delay: 0.28s, 1.4s; }
  .y-hero__stickers .y-sticker:nth-child(3) { animation-delay: 0.41s, 1.1s; }

  /* idle wiggle on hero stickers (after pop) */
  .y-hero__stickers .y-sticker { }
  .y-deco--float { animation: y-float 6s ease-in-out infinite; }
  .y-deco--float2 { animation: y-float 7.5s ease-in-out infinite; }
  .y-deco--spin { animation: y-spin 14s linear infinite; }
  .y-deco--wiggle { animation: y-wiggle 4s ease-in-out infinite; }
  .y-deco--bob { animation: y-bob 3.4s ease-in-out infinite; }

  .y-hero__when { animation: y-pulse 2.6s ease-in-out infinite; }
  .y-cta__title { animation: y-glowpulse 3s ease-in-out infinite; }

  /* scroll reveal */
  .yr { opacity: 0; transform: translateY(26px); transition: opacity 0.6s var(--yo-ease), transform 0.6s var(--yo-ease); }
  .yr.in { opacity: 1; transform: none; }
}

@keyframes y-rise { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
@keyframes y-pop { 0% { opacity: 0; transform: rotate(var(--rot,0deg)) scale(0.4); } 70% { transform: rotate(var(--rot,0deg)) scale(1.12); } 100% { opacity: 1; transform: rotate(var(--rot,0deg)) scale(1); } }
@keyframes y-stickwiggle { 0%,100% { transform: rotate(var(--rot,0deg)) translateY(0); } 25% { transform: rotate(calc(var(--rot,0deg) + 3deg)) translateY(-5px); } 75% { transform: rotate(calc(var(--rot,0deg) - 3deg)) translateY(3px); } }
@keyframes y-float { 0%,100% { transform: translateY(0) rotate(var(--drot,0deg)); } 50% { transform: translateY(-18px) rotate(var(--drot,0deg)); } }
@keyframes y-spin { to { transform: rotate(360deg); } }
@keyframes y-wiggle { 0%,100% { transform: rotate(-8deg); } 50% { transform: rotate(8deg); } }
@keyframes y-bob { 0%,100% { transform: translateY(0) rotate(var(--drot,-6deg)); } 50% { transform: translateY(-10px) rotate(calc(var(--drot,-6deg) + 6deg)); } }
@keyframes y-pulse { 0%,100% { text-shadow: 0 0 0 rgba(200,255,53,0); } 50% { text-shadow: 0 0 22px rgba(200,255,53,0.55); } }
@keyframes y-glowpulse { 0%,100% { filter: drop-shadow(0 0 0 rgba(200,255,53,0)); } 50% { filter: drop-shadow(0 0 26px rgba(200,255,53,0.45)); } }

:root { --yo-pop: cubic-bezier(0.34, 1.56, 0.64, 1); }

/* sticker hover kinetics on tiles */
.y-tile, .y-grade, .y-chip { will-change: transform; }
@media (prefers-reduced-motion: no-preference) {
  .y-btn--lime:hover { animation: y-jiggle 0.4s var(--yo-ease); }
}
@keyframes y-jiggle { 0%,100% { transform: translateY(-3px) rotate(0); } 25% { transform: translateY(-3px) rotate(-1.5deg); } 75% { transform: translateY(-3px) rotate(1.5deg); } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 940px) {
  .y-bento { grid-template-columns: 1fr 1fr; grid-auto-rows: 200px; }
  .y-tile--lg { grid-column: span 2; grid-row: span 1; min-height: 260px; }
  .y-grades { grid-template-columns: 1fr; }
  .y-info__grid { grid-template-columns: 1fr; }
  .y-gallery { grid-template-columns: 1fr 1fr; }
  .y-gallery image-slot:nth-child(1) { grid-column: span 2; grid-row: auto; min-height: clamp(220px,50vw,320px); }
}
@media (max-width: 560px) {
  .y-bento { grid-template-columns: 1fr; grid-auto-rows: 180px; }
  .y-tile--lg, .y-tile--wide { grid-column: auto; }
  .y-gallery { grid-template-columns: 1fr 1fr; }
}
