/* ============================================================
   HOMEPAGE SECTIONS — reference "Forged in Austin" layout on live tokens.
   Tokens + nav + footer + buttons live in site.css.
   ============================================================ */

/* ===================== HERO CAROUSEL ===================== */
.hero{position:relative;background:var(--ink);color:var(--bone);overflow:hidden}
.carousel{position:relative;height:min(82vh,720px);min-height:520px}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .9s var(--ease);display:grid;grid-template-columns:1.05fr .95fr;align-items:center}
.slide.active{opacity:1}
.slide-text{padding:0 8% 0 max(28px,calc((100vw - var(--maxw))/2 + 28px));position:relative;z-index:3}
.slide-text .kicker{color:var(--orange-bright);display:block;margin-bottom:18px}
.slide-text h1{font-size:clamp(3.4rem,8vw,6.6rem);color:var(--bone)}
.slide-text h1 em{font-style:normal;color:var(--orange-bright)}
.slide-text p{max-width:34ch;margin:20px 0 30px;font-size:1.12rem;color:rgba(242,237,228,.78)}
.slide-cta{display:flex;gap:14px;flex-wrap:wrap}
.slide-visual{position:relative;height:100%;overflow:hidden}
.slide-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,var(--ink) 0%,rgba(26,26,28,.5) 32%,rgba(26,26,28,0) 62%)}
.slide-visual img{width:100%;height:100%;object-fit:cover;filter:saturate(1.02) contrast(1.06) brightness(.9)}
.slide-tag{position:absolute;right:26px;bottom:26px;z-index:4;background:var(--orange);color:#fff;font-family:var(--font-display);font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;padding:8px 14px;border-radius:2px}
.car-dots{position:absolute;left:max(28px,calc((100vw - var(--maxw))/2 + 28px));bottom:34px;z-index:5;display:flex;gap:10px}
.car-dots button{width:34px;height:4px;border:0;background:rgba(242,237,228,.28);cursor:pointer;transition:.3s;border-radius:2px;padding:0}
.car-dots button.on{background:var(--orange-bright);width:54px}
.car-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:48px;height:48px;border:1px solid var(--line);background:rgba(26,26,28,.4);color:var(--bone);font-size:1.4rem;cursor:pointer;display:grid;place-items:center;border-radius:50%;transition:.25s}
.car-arrow:hover{background:var(--orange);border-color:var(--orange)}
.car-arrow.prev{left:18px}.car-arrow.next{right:18px}
.ticker{background:var(--orange);color:#fff;overflow:hidden;white-space:nowrap;font-family:var(--font-display);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.85rem;padding:11px 0}
.ticker span{display:inline-block;padding-left:100%;animation:scroll 22s linear infinite}
@keyframes scroll{to{transform:translateX(-100%)}}
@media (prefers-reduced-motion:reduce){.ticker span{animation:none;padding-left:0}}

/* ===================== MISSION ===================== */
.mission{background:var(--surface);position:relative}
.mission .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.mission .kicker{color:var(--orange-bright);display:block;margin-bottom:16px}
.mission h2{font-size:clamp(2.4rem,4.4vw,3.6rem);color:var(--bone)}
.mission h2 em{font-style:normal;color:var(--orange-bright)}
.mission p{margin-top:18px;color:var(--ash);max-width:46ch}
.pillars{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.pillars .p{flex:1;min-width:120px;border:1px solid var(--line);border-radius:5px;padding:18px;transition:.3s var(--ease)}
.pillars .p:hover{border-color:rgba(212,104,26,.4);background:rgba(43,74,45,.12)}
.pillars .p .pt{font-family:var(--font-display);font-weight:800;font-size:1.6rem;color:var(--orange-bright);text-transform:uppercase}
.pillars .p .pd{font-size:.84rem;color:var(--ash);margin-top:4px}
.mission-quote{border-left:4px solid var(--orange);padding:8px 0 8px 26px}
.mission-quote .big{font-family:var(--font-display);font-weight:800;font-size:clamp(3rem,6vw,5rem);color:var(--bone);line-height:.86;text-transform:uppercase}
.mission-quote .sub{font-family:var(--font-display);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.85rem;color:var(--ash);margin-top:12px}

/* ===================== MERCH ===================== */
.merch{background:var(--ink)}
.rail{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 4px 26px;scrollbar-width:thin}
.rail::-webkit-scrollbar{height:6px}
.rail::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:4px}
.card{flex:0 0 300px;scroll-snap-align:start;background:var(--surface-2);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.3s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 44px -22px rgba(0,0,0,.8);border-color:rgba(212,104,26,.4)}
.card .ph{aspect-ratio:1/1;position:relative;overflow:hidden;background:#000}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}
.card:hover .ph img{transform:scale(1.06)}
.card .badge{position:absolute;top:12px;left:12px;background:var(--orange);color:#fff;font-family:var(--font-display);font-weight:600;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 10px;border-radius:2px}
.card .body{padding:18px 18px 20px}
.card .body h3{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:1.18rem;line-height:1.1;color:var(--bone)}
.card .price{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--orange-bright);margin-top:4px}
.card .body .btn{width:100%;justify-content:center;margin-top:14px;padding:11px}
.embed-slot{margin-top:40px;border:2px dashed var(--orange);border-radius:6px;padding:34px;text-align:center;background:rgba(191,90,0,.07)}
.embed-slot .kicker{color:var(--orange-bright);display:block;margin-bottom:8px}
.embed-slot h3{font-size:1.7rem;margin-bottom:8px;color:var(--bone)}
.embed-slot p{color:var(--ash);max-width:62ch;margin:0 auto;font-size:.95rem}
.embed-slot code{background:#000;color:var(--sand);padding:2px 7px;border-radius:3px;font-size:.82rem;font-family:ui-monospace,monospace}
.rail-loading{padding:48px 8px;color:var(--ash);font-family:var(--font-display);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.95rem}
.rail-loading a{color:var(--orange-bright)}
.merch-cta{margin-top:24px;text-align:center}

/* ===================== EVENTS ===================== */
.events{background:var(--surface)}
.next-event{display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:center;background:linear-gradient(110deg,var(--orange),var(--orange-bright));color:#fff;padding:30px 34px;border-radius:6px;margin-bottom:34px}
.next-event .when{text-align:center;border-right:2px solid rgba(255,255,255,.4);padding-right:30px}
.next-event .when .d{font-family:var(--font-display);font-weight:800;font-size:3.6rem;line-height:.8}
.next-event .when .m{font-family:var(--font-display);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.85rem}
.next-event .info .lbl{font-family:var(--font-display);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.75rem;opacity:.9}
.next-event .info h3{font-size:2.1rem;margin:2px 0 4px}
.next-event .info .meta{font-weight:600}
.next-event .count{text-align:center;font-family:var(--font-display);font-weight:800}
.next-event .count .n{font-size:2.6rem;line-height:.8;display:block}
.next-event .count .l{font-family:var(--font-display);font-weight:600;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}
.ev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.ev-card{border:1px solid var(--line);border-radius:5px;padding:24px;transition:.3s var(--ease);background:var(--ink)}
.ev-card:hover{border-color:var(--orange-bright);background:rgba(212,104,26,.07)}
.ev-card .date{display:flex;align-items:baseline;gap:8px;color:var(--orange-bright);font-family:var(--font-display);font-weight:800;font-size:1.9rem}
.ev-card .date small{font-family:var(--font-display);font-weight:600;font-size:.78rem;letter-spacing:.16em}
.ev-card h3{font-size:1.7rem;color:var(--bone);margin:8px 0 6px}
.ev-card .meta{font-size:.92rem;color:var(--ash)}
.ev-card .type{display:inline-block;margin-top:14px;font-family:var(--font-display);font-weight:600;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--forest);padding:4px 11px;border-radius:20px}
.events-empty{text-align:center;color:var(--ash);border:1px dashed var(--line);border-radius:6px;padding:48px 24px}
.events-empty a{color:var(--orange-bright)}

/* ===================== WOD ===================== */
.wod{background:var(--ink);position:relative;overflow:hidden}
.wod::before{content:"WOD";position:absolute;right:-2%;top:-8%;font-family:var(--font-display);font-weight:900;font-size:34vw;color:rgba(242,237,228,.03);line-height:1;pointer-events:none}
.wod-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start;position:relative;z-index:2}
.wod-intro .kicker{color:var(--orange-bright);display:block;margin-bottom:14px}
.wod-intro h2{font-size:clamp(2.8rem,5vw,4.6rem);color:var(--bone)}
.wod-intro .stamp{display:inline-flex;align-items:center;gap:9px;margin-top:18px;font-family:var(--font-display);font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:.85rem;color:var(--bone);background:rgba(242,237,228,.06);padding:9px 16px;border-radius:30px;border:1px solid var(--line)}
.wod-intro .stamp .dot{width:9px;height:9px;border-radius:50%;background:#5ad17a;box-shadow:0 0 0 0 rgba(90,209,122,.6);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 9px rgba(90,209,122,0)}100%{box-shadow:0 0 0 0 rgba(90,209,122,0)}}
@media (prefers-reduced-motion:reduce){.wod-intro .stamp .dot{animation:none}}
.wod-intro p{margin-top:20px;color:var(--ash);max-width:38ch}
.wod-card{background:var(--bone);color:#1a1a1a;border-radius:8px;overflow:hidden;box-shadow:0 30px 60px -30px rgba(0,0,0,.8)}
.wod-card .top{background:var(--orange);color:#fff;padding:20px 26px;display:flex;justify-content:space-between;align-items:center;gap:14px}
.wod-card .top .ttl{font-family:var(--font-display);font-weight:800;font-size:2.1rem;line-height:.9;text-transform:uppercase}
.wod-card .top .date{font-family:var(--font-display);font-weight:600;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;text-align:right;opacity:.95}
.wod-card .focus{font-family:var(--font-display);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.8rem;color:var(--orange);padding:18px 26px 0}
.wod-block{padding:14px 26px}
.wod-block:last-of-type{padding-bottom:26px}
.wod-block .bh{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;border-bottom:2px solid rgba(26,26,26,.14);padding-bottom:7px;margin-bottom:10px;display:flex;justify-content:space-between}
.wod-block .bh span{color:var(--orange);font-weight:600;font-size:.85rem}
.wod-block ul{list-style:none}
.wod-block li{padding:5px 0 5px 22px;position:relative;font-size:.98rem}
.wod-block li::before{content:"";position:absolute;left:0;top:13px;width:8px;height:8px;background:var(--orange);transform:rotate(45deg)}
.wod-card .foot{background:var(--ink);color:var(--bone);padding:16px 26px;font-size:.86rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.wod-card .foot .btn{padding:9px 16px;font-size:.78rem}
.wod-rest{padding:40px 26px;text-align:center}
.wod-rest .rt{font-family:var(--font-display);font-weight:800;font-size:2.2rem;text-transform:uppercase;color:#1a1a1a}
.wod-rest p{color:rgba(26,26,26,.7);margin-top:8px}
/* Whiteboard (free-text WOD) */
.wod-whiteboard{padding:16px 26px 8px;color:#1a1a1a}
.wod-whiteboard .wb-head{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:1.05rem;color:var(--orange);border-bottom:2px solid rgba(26,26,26,.14);padding-bottom:6px;margin:18px 0 8px}
.wod-whiteboard .wb-head:first-child{margin-top:2px}
.wod-whiteboard .wb-line{font-size:1rem;line-height:1.6;color:#1a1a1a}
.wod-whiteboard .wb-gap{height:10px}

/* ===================== JOIN (warm band) ===================== */
.join{background:var(--bone);color:#1a1a1a;text-align:center}
.join .kicker{color:var(--orange);display:block;margin-bottom:14px}
.join h2{font-size:clamp(2.8rem,6vw,5rem);color:#1a1a1a}
.join p{max-width:52ch;margin:16px auto 28px;font-size:1.1rem;color:rgba(26,26,26,.74)}
.join-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;max-width:560px;margin:0 auto}
.join-form input{flex:1;min-width:200px;padding:15px 16px;border:2px solid rgba(26,26,26,.18);background:#fff;color:#1a1a1a;border-radius:3px;font-family:var(--font-body);font-size:1rem}
.join-form input:focus{outline:none;border-color:var(--orange)}
.join-msg{min-height:1.4em;margin-top:14px;font-family:var(--font-display);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.9rem;color:var(--orange)}
.join-alt{margin-top:6px}
.join-alt a{color:rgba(26,26,26,.6);font-family:var(--font-display);font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.85rem;border-bottom:1px solid currentColor;padding-bottom:2px}
.join-alt a:hover{color:var(--orange)}
.stats{display:flex;gap:50px;justify-content:center;margin-top:48px;flex-wrap:wrap}
.stats .s .n{font-family:var(--font-display);font-weight:800;font-size:3.4rem;color:var(--orange);line-height:.8}
.stats .s .l{font-family:var(--font-display);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.78rem;color:rgba(26,26,26,.7)}

/* ===================== RESPONSIVE ===================== */
@media(max-width:900px){
  .slide{grid-template-columns:1fr}
  .slide-visual{position:absolute;inset:0;opacity:.32}
  .slide-text{padding:0 28px}
  .wod-grid,.mission .wrap{grid-template-columns:1fr;gap:34px}
  .next-event{grid-template-columns:1fr;text-align:center}
  .next-event .when{border-right:0;border-bottom:2px solid rgba(255,255,255,.4);padding:0 0 16px}
}
@media(max-width:680px){
  .car-arrow{display:none}
}
