/* ============================================================
   Krampon Akademi — styles.css
   ============================================================ */

/* --- Tokens --- */
:root {
  interpolate-size: allow-keywords;
  --bg: #FAFAF5;
  --surface: #FFFFFF;
  --surface-2: #F2F1EC;
  --ink: #1A1A1A;
  --ink-soft: #5A5A58;
  --accent: #E84B1C;
  --accent-2: #1B6B3A;
  --line: rgba(26,26,26,0.12);
  --line-strong: rgba(26,26,26,0.25);
  --header-h: 72px;
  --container: 1320px;
  --radius: 10px;
  --radius-lg: 16px;
  --shadow-card: 0 2px 12px -4px rgba(26,26,26,0.08);
  --shadow-hover: 0 12px 32px -8px rgba(232,75,28,0.18);
  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.4,0,.2,1);
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html,body{overflow-x:hidden;max-width:100vw}
body{font-family:'Roboto',sans-serif;font-weight:400;font-size:16px;line-height:1.65;color:var(--ink);background:var(--bg)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:0;background:0;font:inherit;color:inherit}
ul,ol{list-style:none}
input,textarea,select{font:inherit;color:inherit}

/* --- Skip link --- */
.skip-link{position:absolute;top:-100%;left:16px;padding:8px 18px;background:var(--accent);color:#fff;border-radius:0 0 6px 6px;font-weight:500;z-index:10000;transition:top .2s}
.skip-link:focus{top:0}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6,.heading{font-family:'Bebas Neue',Impact,'Arial Narrow',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:0.04em;line-height:1.1;color:var(--ink)}
h1{font-size:clamp(2.6rem, 7vw, 4.5rem)}
h2{font-size:clamp(2rem,4.5vw,3.4rem)}
h3{font-size:clamp(1.4rem,3vw,2rem)}
h4{font-size:clamp(1.15rem,2vw,1.5rem)}
.eyebrow{font-family:'Roboto',sans-serif;font-size:0.82rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent)}
.sub{font-size:1.1rem;color:var(--ink-soft);max-width:540px;line-height:1.7}

/* --- Container --- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding-left:clamp(16px,4vw,32px);padding-right:clamp(16px,4vw,32px)}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:6px;font-family:'Bebas Neue',sans-serif;font-size:1.15rem;letter-spacing:0.06em;text-transform:uppercase;transition:background .24s var(--ease),color .24s var(--ease),transform .24s var(--ease),box-shadow .24s var(--ease);white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover,.btn-primary:focus-visible{background:#c93d12;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px -6px rgba(232,75,28,0.35)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong)}
.btn-ghost:hover,.btn-ghost:focus-visible{background:var(--surface);color:var(--ink);border-color:var(--accent);transform:translateY(-2px)}
.btn-secondary{background:var(--accent-2);color:#fff}
.btn-secondary:hover,.btn-secondary:focus-visible{background:#155a30;color:#fff;transform:translateY(-2px)}

/* --- Focus ring --- */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* --- Header (sticky-with-morph) --- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1080;background:rgba(250, 250, 245, 0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .24s ease,box-shadow .24s ease,padding .24s ease}
.site-header.scrolled{background:rgba(250,250,245,0.98);box-shadow:0 8px 24px -16px rgba(0,0,0,.18);backdrop-filter:none;-webkit-backdrop-filter:none}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:16px}

/* Logo */
.logo{display:flex;align-items:center;gap:10px;font-family:'Bebas Neue',sans-serif;font-size:1.45rem;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink);white-space:nowrap}
.logo svg{width:36px;height:36px;flex-shrink:0}
.logo:hover{color:var(--accent)}

/* Desktop nav */
.nav-desktop{display:none;align-items:center;gap:28px}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{position:relative;font-size:0.88rem;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink);transition:color .24s var(--ease)}
.nav-desktop a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent);transition:width .28s var(--ease)}
.nav-desktop a:hover::after,.nav-desktop a.is-active::after{width:100%}
.nav-desktop a:hover{color:var(--accent)}
.nav-desktop a.is-active{color:var(--accent)}
.nav-desktop .nav-cta{padding:10px 22px;background:var(--accent);color:#fff;border-radius:5px;font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:0.06em}
.nav-desktop .nav-cta::after{display:none}
.nav-desktop .nav-cta:hover{background:#c93d12;color:#fff}

/* Nav toggle (hamburger → X) */
.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;z-index:1100;position:relative}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-toggle span{display:block;width:100%;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .32s var(--ease),opacity .24s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* --- Drawer (outside header, solid bg) --- */
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.55);opacity:0;visibility:hidden;z-index:1040;transition:opacity .24s var(--ease),visibility .24s}
.drawer-backdrop.is-open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(360px,92vw);background:var(--surface);z-index:1050;transform:translateX(100%);transition:transform .32s cubic-bezier(.2,.7,.2,1);padding:calc(var(--header-h) + 24px) 28px 32px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.drawer.is-open{transform:translateX(0)}
.drawer nav{display:flex;flex-direction:column;gap:4px}
.drawer nav a{display:block;padding:14px 16px;font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:0.04em;text-transform:uppercase;border-radius:8px;transition:background .2s,color .2s}
.drawer nav a:hover,.drawer nav a.is-active{background:var(--surface-2);color:var(--accent)}
.drawer .drawer-cta{display:block;margin-top:20px;padding:16px;background:var(--accent);color:#fff;text-align:center;border-radius:8px;font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:0.06em;text-transform:uppercase;transition:background .24s}
.drawer .drawer-cta:hover{background:#c93d12;color:#fff}

/* --- Main offset for fixed header --- */
main{padding-top:var(--header-h)}

/* --- Section base --- */
.section{padding:clamp(48px,8vw,96px) 0}
.section--alt{background:var(--surface)}
.section--dark{background:var(--ink);color:#fff}
.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}
.section--dark .eyebrow{color:var(--accent)}
.section__head{text-align:center;margin-bottom:clamp(32px,5vw,56px)}
.section__head .sub{margin:12px auto 0}

/* --- Diagonal stripe accent --- */
.stripe-accent{position:relative}
.stripe-accent::before{content:'';position:absolute;top:0;left:-32px;width:6px;height:100%;background:repeating-linear-gradient(-45deg,var(--accent),var(--accent) 4px,transparent 4px,transparent 10px);border-radius:3px}

/* --- Football SVG icon (small corner decoration) --- */
.ball-corner{position:absolute;width:28px;height:28px;opacity:0.12}
.ball-corner--tl{top:12px;left:12px}
.ball-corner--br{bottom:12px;right:12px}

/* Ball spin animation */
@keyframes ball-spin{to{transform:rotate(360deg)}}
.ball-spin{animation:ball-spin 8s linear infinite}
@media(prefers-reduced-motion:reduce){.ball-spin{animation:none}}

/* --- HERO (#vitrin) --- */
.hero{position:relative;min-height:clamp(520px,75vh,780px);display:flex;align-items:center;overflow:hidden;background:linear-gradient(145deg,#1B6B3A 0%,#145a2e 35%,#0d4a24 100%)}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 30h60M30 0v60' stroke='%23ffffff' stroke-width='.4' opacity='.08'/%3E%3C/svg%3E");opacity:0.5;pointer-events:none}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:160px;background:linear-gradient(to top,var(--bg),transparent);pointer-events:none}
.hero__inner{position:relative;z-index:2;padding:clamp(40px,6vw,80px) 0}
.hero .eyebrow{color:rgba(255,255,255,0.75);margin-bottom:16px}
.hero__title{color:#fff;margin-bottom:20px;line-height:1.05}
.hero__title .letter{display:inline-block;opacity:0;transform:translateY(40px) rotate(6deg);transition:opacity 400ms var(--ease),transform 500ms var(--ease)}
.hero__title.is-ready .letter{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.hero__title .letter{opacity:1!important;transform:none!important;transition:none!important}}
html.no-js .hero__title .letter{opacity:1;transform:none}
.hero .sub{color:rgba(255,255,255,0.82);max-width:520px}
.hero__cta{margin-top:28px;display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.hero__cta .btn-primary{background:#fff;color:var(--accent)}
.hero__cta .btn-primary:hover{background:var(--accent);color:#fff}

/* Hero badges (replacing marquee) */
.hero__badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:36px;max-width:680px}
.hero__badges .badge{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.18);border-radius:40px;color:rgba(255,255,255,0.88);font-size:0.82rem;font-weight:500;letter-spacing:0.03em;backdrop-filter:blur(4px);transition:background .24s,border-color .24s,transform .24s}
.hero__badges .badge:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.35);transform:translateY(-2px)}
.hero__badges .badge svg{width:16px;height:16px;flex-shrink:0}

/* Hero diagonal stripe decoration */
.hero__stripe{position:absolute;right:clamp(20px,6vw,80px);top:50%;transform:translateY(-50%);width:clamp(40px,5vw,72px);height:clamp(200px,40vh,400px);background:repeating-linear-gradient(-45deg,var(--accent),var(--accent) 5px,transparent 5px,transparent 14px);opacity:0.3;border-radius:4px;pointer-events:none}

/* Hero trust strip */
.trust-strip{display:flex;flex-wrap:wrap;gap:16px;margin-top:32px}
.trust-strip__item{display:flex;align-items:center;gap:6px;font-size:0.78rem;color:rgba(255,255,255,0.65);letter-spacing:0.02em}
.trust-strip__item svg{width:14px;height:14px;opacity:0.6}

/* --- Program cards (#programlar) --- */
.programs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:1024px){.programs-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.programs-grid{grid-template-columns:1fr}}
.program-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,3vw,28px);overflow:hidden;transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.program-card:hover{transform:scale(1.03);box-shadow:var(--shadow-hover)}
.program-card__age{display:inline-block;padding:4px 12px;background:var(--accent);color:#fff;font-size:0.72rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;border-radius:40px;margin-bottom:14px}
.program-card__age--green{background:var(--accent-2)}
.program-card__title{font-family:'Bebas Neue',sans-serif;font-size:1.35rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:8px}
.program-card__meta{font-size:0.85rem;color:var(--ink-soft);margin-bottom:14px;line-height:1.6}
.program-card__meta span{display:block}
.program-card__price{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--accent);letter-spacing:0.02em}
.program-card__price small{font-family:'Roboto',sans-serif;font-size:0.7rem;font-weight:400;color:var(--ink-soft);letter-spacing:0}

/* Ball corner decoration on cards */
.program-card .ball-corner{fill:var(--ink);transition:fill .28s}
.program-card:hover .ball-corner{fill:var(--accent)}

/* --- Advantages (#avantajlar) --- */
.advantages-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:768px){.advantages-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:430px){.advantages-grid{grid-template-columns:1fr}}
.adv-box{text-align:center;padding:clamp(24px,3vw,36px) clamp(16px,2vw,24px);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.adv-box:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.adv-box__icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto 18px;background:rgba(232,75,28,0.08);border-radius:50%;transition:background .28s}
.adv-box:hover .adv-box__icon{background:rgba(232,75,28,0.15)}
.adv-box__icon svg{width:30px;height:30px;stroke:var(--accent);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.adv-box__title{font-family:'Bebas Neue',sans-serif;font-size:1.15rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:6px}
.adv-box__text{font-size:0.88rem;color:var(--ink-soft);line-height:1.6}

/* --- Stats (#rakamlar) --- */
.stats-band{background:var(--ink);padding:clamp(40px,6vw,72px) 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
@media(max-width:640px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}}
.stat__number{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.4rem,5vw,4rem);color:var(--accent);letter-spacing:0.02em;line-height:1}
.stat__label{font-size:0.85rem;color:rgba(255,255,255,0.6);margin-top:6px;text-transform:uppercase;letter-spacing:0.08em}

/* Counter-up */
@keyframes counter-fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* --- Process (Nasıl Çalışıyoruz) --- */
.process-timeline{position:relative;max-width:720px;margin:0 auto;padding-left:40px}
.process-timeline::before{content:'';position:absolute;left:15px;top:0;bottom:0;width:2px;background:var(--line)}
.process-step{position:relative;padding-bottom:clamp(28px,4vw,44px)}
.process-step:last-child{padding-bottom:0}
.process-step__marker{position:absolute;left:-40px;top:2px;width:32px;height:32px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:0.95rem;letter-spacing:0.02em;z-index:1}
.process-step__time{font-size:0.75rem;font-weight:500;color:var(--accent);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:4px}
.process-step__title{font-family:'Bebas Neue',sans-serif;font-size:1.25rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:4px}
.process-step__text{font-size:0.9rem;color:var(--ink-soft);line-height:1.65;max-width:560px}

/* --- Pricing (#fiyatlar) --- */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.pricing-card{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,36px);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.pricing-card--featured{border-color:var(--accent);position:relative}
.pricing-card--featured::before{content:'En Popüler';position:absolute;top:-12px;left:24px;padding:4px 16px;background:var(--accent);color:#fff;font-size:0.7rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;border-radius:20px}
.pricing-card__name{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:4px}
.pricing-card__age{font-size:0.82rem;color:var(--ink-soft);margin-bottom:16px}
.pricing-card__price{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--accent);letter-spacing:0.01em;margin-bottom:4px}
.pricing-card__price small{font-family:'Roboto',sans-serif;font-size:0.75rem;color:var(--ink-soft);font-weight:400}
.pricing-card__list{margin:20px 0 0;display:flex;flex-direction:column;gap:8px}
.pricing-card__list li{font-size:0.88rem;color:var(--ink-soft);padding-left:22px;position:relative;line-height:1.5}
.pricing-card__list li::before{content:'';position:absolute;left:0;top:7px;width:8px;height:8px;border-radius:50%}
.pricing-card__list .dahil::before{background:var(--accent-2)}
.pricing-card__list .haric::before{background:var(--line-strong)}
.pricing-card__list .haric{text-decoration:line-through;opacity:0.55}

/* --- Testimonials --- */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.testimonial-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,32px);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.testimonial-card__quote{font-size:0.95rem;line-height:1.75;color:var(--ink);font-style:italic;margin-bottom:18px;position:relative;padding-left:20px;border-left:3px solid var(--accent)}
.testimonial-card__author{font-weight:500;font-size:0.88rem}
.testimonial-card__meta{font-size:0.78rem;color:var(--ink-soft)}

/* --- FAQ (#sss) --- */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:2px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;padding:clamp(16px,2.5vw,22px) 0;font-family:'Bebas Neue',sans-serif;font-size:1.15rem;letter-spacing:0.04em;text-transform:uppercase;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none;transition:color .24s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none;content:''}
.faq-item summary:hover{color:var(--accent)}
.faq-item summary .faq-chevron{width:20px;height:20px;stroke:var(--ink-soft);stroke-width:2;fill:none;flex-shrink:0;transition:transform .36s var(--ease-out)}
.faq-item[open] summary .faq-chevron{transform:rotate(180deg)}
.faq-item .faq-body{height:0;padding:0 0;overflow:hidden;transition:height 360ms var(--ease-out),padding-block-end 360ms var(--ease-out)}
.faq-item[open] .faq-body{height:auto;padding-block-end:22px}
.faq-item .faq-body p{font-size:0.92rem;color:var(--ink-soft);line-height:1.75;max-width:640px}
@media(prefers-reduced-motion:reduce){.faq-item .faq-body{transition:none}}

/* --- News block (Akademi Haberleri) --- */
.news-list{display:flex;flex-direction:column;gap:16px;max-width:600px}
.news-item{display:flex;gap:14px;align-items:flex-start}
.news-item__date{flex-shrink:0;font-family:'Bebas Neue',sans-serif;font-size:0.95rem;color:var(--accent);letter-spacing:0.02em;min-width:100px}
.news-item__text{font-size:0.9rem;color:var(--ink-soft);line-height:1.55}

/* --- Contact form --- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.form-grid .field--full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:0.82rem;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-soft)}
.field input,.field textarea,.field select{padding:12px 16px;border:1.5px solid var(--line);border-radius:8px;background:var(--surface);transition:border-color .24s,box-shadow .24s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(232,75,28,0.1);outline:none}
.field textarea{min-height:120px;resize:vertical}
.field select{appearance:auto;-webkit-appearance:auto}

/* Checkbox */
.field-check{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.field-check input[type="checkbox"]{appearance:auto;-webkit-appearance:auto;width:18px;height:18px;min-width:18px;min-height:18px;padding:0;border:0;margin:2px 0 0;accent-color:var(--accent);cursor:pointer}
.field-check span{font-size:0.82rem;color:var(--ink-soft);line-height:1.5}

/* Honeypot */
.hp-field{position:absolute;left:-9999px;opacity:0}

/* --- Contact page cards --- */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:clamp(20px,3vw,24px);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.contact-card__icon{width:48px;height:48px;border-radius:50%;background:rgba(232,75,28,0.08);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.contact-card__icon svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.contact-card__label{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:4px}
.contact-card__value{font-size:0.92rem;color:var(--ink-soft);word-break:break-word;overflow-wrap:anywhere}
.contact-card__value a{color:var(--accent);transition:color .2s}
.contact-card__value a:hover{color:#c93d12}
.contact-card__sub{font-size:0.78rem;color:var(--ink-soft);margin-top:4px;opacity:0.7}

/* Hours mini grid */
.hours-grid{display:grid;grid-template-columns:1fr;gap:4px}
.hours-row{display:flex;justify-content:space-between;padding:6px 0;font-size:0.88rem;font-variant-numeric:tabular-nums;border-bottom:1px solid var(--line)}
.hours-row:last-child{border-bottom:0}
.hours-row--today{background:rgba(232,75,28,0.06);border-radius:4px;padding:6px 8px;font-weight:500;color:var(--accent)}

/* --- Table scroll wrapper --- */
.table-scroll{display:block;width:100%;max-width:100%;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:18px 0;border:1px solid var(--line);border-radius:6px}
.table-scroll>table{margin:0!important;min-width:480px;width:100%}
:where(*:has(>.table-scroll),*:has(>*>.table-scroll),*:has(>*>*>.table-scroll)){min-width:0}

/* --- Team --- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}
.team-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.team-card__photo{width:100%;height:240px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.team-card__photo img{width:100%;height:100%;object-fit:cover}
.team-card__photo .placeholder{font-size:0.82rem;color:var(--ink-soft);text-align:center;padding:20px}
.team-card__info{padding:clamp(18px,3vw,28px)}
.team-card__name{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:2px}
.team-card__role{font-size:0.82rem;color:var(--accent);font-weight:500;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:10px}
.team-card__bio{font-size:0.88rem;color:var(--ink-soft);line-height:1.65}

/* --- Reveal on scroll --- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 600ms var(--ease),transform 600ms var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[style*="--i"]{transition-delay:calc(var(--i) * 80ms)}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}
html.no-js .reveal{opacity:1;transform:none}

/* --- Parallax sub-layer --- */
.parallax-layer{will-change:transform;transition:transform 0s linear}

/* --- Niche-specific animations --- */

/* 1. Ball kick on CTA hover */
@keyframes kick-ball{0%{transform:translateX(0) rotate(0deg)}40%{transform:translateX(8px) rotate(-12deg)}100%{transform:translateX(0) rotate(0deg)}}
.btn-primary:hover .btn-ball{animation:kick-ball .4s var(--ease)}
.btn-ball{width:18px;height:18px;flex-shrink:0}
@media(prefers-reduced-motion:reduce){.btn-primary:hover .btn-ball{animation:none}}

/* 2. Field line draw */
@keyframes field-line-draw{from{stroke-dashoffset:400}to{stroke-dashoffset:0}}
.field-line-draw{stroke-dasharray:400;stroke-dashoffset:400}
.is-in .field-line-draw{animation:field-line-draw 1.2s var(--ease-out) forwards}
@media(prefers-reduced-motion:reduce){.is-in .field-line-draw,.field-line-draw{animation:none;stroke-dashoffset:0}}

/* 3. Goal net shimmer on stats */
@keyframes net-shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
.stat__number{background:linear-gradient(90deg,var(--accent) 0%,#ff7b4f 25%,var(--accent) 50%,#ff7b4f 75%,var(--accent) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat__number.is-in{animation:net-shimmer 6s linear infinite}
@media(prefers-reduced-motion:reduce){.stat__number{animation:none!important;-webkit-text-fill-color:var(--accent);background:none}}

/* 4. Grass sway in footer */
@keyframes grass-sway{0%,100%{transform:skewX(0deg)}25%{transform:skewX(1.5deg)}75%{transform:skewX(-1.5deg)}}
.footer-grass{animation:grass-sway 10s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.footer-grass{animation:none}}

/* 5. Whistle hover on nav-cta */
@keyframes whistle-shake{0%,100%{transform:rotate(0)}15%{transform:rotate(8deg)}30%{transform:rotate(-6deg)}45%{transform:rotate(4deg)}60%{transform:rotate(0)}}
.nav-cta:hover .whistle-icon{animation:whistle-shake .5s var(--ease)}
@media(prefers-reduced-motion:reduce){.nav-cta:hover .whistle-icon{animation:none}}

/* --- Footer --- */
.site-footer{background:var(--ink);color:rgba(255,255,255,0.7);padding:clamp(40px,6vw,72px) 0 0}
.footer__inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px,4vw,48px)}
@media(max-width:768px){.footer__inner{grid-template-columns:1fr 1fr;gap:24px}}
@media(max-width:430px){.footer__inner{grid-template-columns:1fr}}
.footer__col h4{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:0.06em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.footer__col p{font-size:0.85rem;line-height:1.7;margin-bottom:8px}
.footer__col a{font-size:0.85rem;display:block;padding:3px 0;transition:color .2s}
.footer__col a:hover{color:var(--accent)}
.footer__brand{margin-bottom:14px}
.footer__brand .logo{font-size:1.2rem;color:#fff}
.footer__bottom{margin-top:clamp(28px,4vw,48px);padding:20px 0;border-top:1px solid rgba(255,255,255,0.1);display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:0.78rem;color:rgba(255,255,255,0.4)}
.footer__bottom a{color:rgba(255,255,255,0.5);transition:color .2s}
.footer__bottom a:hover{color:var(--accent)}

/* --- Cookie banner --- */
.cookie-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:520px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(18px,3vw,24px);box-shadow:0 16px 48px -12px rgba(0,0,0,0.18);transform:translateY(140%);opacity:0;transition:transform 280ms var(--ease),opacity 240ms;z-index:9999}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
@media(min-width:768px){.cookie-banner{left:24px;right:auto;max-width:420px}}
.cookie-banner__title{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:8px}
.cookie-banner__text{font-size:0.82rem;color:var(--ink-soft);line-height:1.6;margin-bottom:16px}
.cookie-banner__actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cookie-banner__actions button{padding:12px 24px;border-radius:6px;font-size:0.88rem;font-weight:600;min-height:48px;min-width:48px;transition:background .24s var(--ease),color .24s var(--ease),transform .24s var(--ease),box-shadow .24s var(--ease)}
.cookie-btn--accept{background:var(--accent);color:#fff}
.cookie-btn--accept:hover{background:#c93d12;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px -2px rgba(232,75,28,0.3)}
.cookie-btn--reject{background:var(--surface-2);color:var(--ink)}
.cookie-btn--reject:hover{background:var(--line);color:var(--ink)}
.cookie-btn--settings{background:transparent;color:var(--ink-soft);text-decoration:underline;padding:12px 16px}
.cookie-btn--settings:hover{color:var(--ink)}

/* --- Smooth scroll nav offset --- */
:target{scroll-margin-top:calc(var(--header-h) + 24px)}
section[id]{scroll-margin-top:calc(var(--header-h) + 24px)}

/* --- Cancellation tiers --- */
.cancel-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.cancel-tier{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;text-align:center}
.cancel-tier__days{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;color:var(--accent);letter-spacing:0.02em}
.cancel-tier__rule{font-size:0.88rem;color:var(--ink-soft);margin-top:6px}

/* --- Policy pages --- */
.policy-content{max-width:780px;margin:0 auto}
.policy-content h2{margin-top:clamp(28px,4vw,44px);margin-bottom:12px;font-size:clamp(1.4rem,3vw,2rem)}
.policy-content h3{margin-top:20px;margin-bottom:8px;font-size:clamp(1.1rem,2vw,1.4rem)}
.policy-content p{font-size:0.92rem;color:var(--ink-soft);line-height:1.75;margin-bottom:14px}
.policy-content ul{margin:12px 0 18px 18px}
.policy-content ul li{font-size:0.92rem;color:var(--ink-soft);line-height:1.7;padding-left:8px;position:relative;margin-bottom:6px}
.policy-content ul li::before{content:'•';position:absolute;left:-12px;color:var(--accent)}

/* --- Thank-you page --- */
.thankyou{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:clamp(40px,8vw,80px) 0}
.thankyou__icon{width:72px;height:72px;margin:0 auto 24px;background:rgba(27,107,58,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center}
.thankyou__icon svg{width:36px;height:36px;stroke:var(--accent-2);fill:none;stroke-width:2}

/* --- 404 page --- */
.page-404{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:clamp(40px,8vw,80px) 0}
.page-404 h1{font-size:clamp(5rem, 15vw, 4.5rem);color:var(--accent);opacity:0.15;line-height:1}

/* --- Sitemap page --- */
.sitemap-list{columns:2;gap:40px}
@media(max-width:640px){.sitemap-list{columns:1}}
.sitemap-list li{break-inside:avoid;padding:6px 0}
.sitemap-list a{font-size:0.95rem;color:var(--ink);display:inline-flex;align-items:center;gap:6px;transition:color .2s}
.sitemap-list a:hover{color:var(--accent)}
.sitemap-list a::before{content:'→';color:var(--accent);font-size:0.8rem}

/* --- Two-col split (responsive) --- */
.split-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,48px);align-items:start}
@media(max-width:768px){.split-2{grid-template-columns:1fr}}

/* --- Diagonal stripe section divider --- */
.section-divider{height:6px;background:repeating-linear-gradient(-45deg,var(--accent),var(--accent) 5px,transparent 5px,transparent 14px);opacity:0.15}

/* --- Hero image (absolute background) --- */
.hero__image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;opacity:1;pointer-events:none}

/* --- Hamburger visibility (thicker bars + strong bg) --- */
.nav-toggle{background:rgba(26,26,26,0.10);border-radius:8px;transition:background .2s var(--ease);border:1.5px solid rgba(26,26,26,0.12)}
.nav-toggle:hover,.nav-toggle:focus-visible{background:rgba(26,26,26,0.18);border-color:rgba(26,26,26,0.22)}
.nav-toggle span{height:3px;border-radius:2px;background:var(--ink)}
@media(max-width:1023px){
  .nav-toggle{width:48px;height:48px;padding:12px;gap:5px}
}

/* --- Cookie banner — mobile bottom-sheet --- */
@media(max-width:767px){
  .cookie-banner{bottom:0;left:0;right:0;max-width:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding-bottom:calc(env(safe-area-inset-bottom,0px) + clamp(18px,3vw,24px))}
  .cookie-banner__actions{flex-direction:row;gap:10px}
  .cookie-banner__actions button{flex:1;text-align:center;justify-content:center;min-height:48px}
  .cookie-btn--settings{flex:0 0 auto}
}
.cookie-btn--reject{border:2px solid var(--ink);font-weight:600;background:var(--surface);font-size:0.88rem}
.cookie-btn--reject:hover{border-color:var(--accent);color:var(--accent);background:var(--surface);transform:translateY(-1px)}

/* --- Cookie banner footer clearance --- */
@media(max-width:767px){}

/* --- Football-themed micro-animations --- */

/* Program card — ball rolls on hover */
.program-card:hover .ball-corner{animation:ball-spin .8s var(--ease)}
@media(prefers-reduced-motion:reduce){.program-card:hover .ball-corner{animation:none}}

/* Advantage box — turf glow */
.adv-box:hover{box-shadow:0 12px 36px -8px rgba(27,107,58,0.2)}
.adv-box__icon{transition:background .28s var(--ease),transform .28s var(--ease)}
.adv-box:hover .adv-box__icon{transform:scale(1.1)}

/* Pricing card — stronger hover glow */
.pricing-card:hover{box-shadow:0 16px 40px -8px rgba(232,75,28,0.18)}

/* Testimonial card — accent border slide-in on hover */
.testimonial-card{border-left:3px solid transparent;transition:transform .28s var(--ease),box-shadow .28s var(--ease),border-color .28s var(--ease)}
.testimonial-card:hover{border-left-color:var(--accent)}

/* Contact card — icon glow on hover */
.contact-card:hover .contact-card__icon{background:rgba(232,75,28,0.18);transform:scale(1.08)}
.contact-card__icon{transition:background .28s var(--ease),transform .28s var(--ease)}

/* Team card — photo zoom on hover */
.team-card__photo img{transition:transform .5s var(--ease)}
.team-card:hover .team-card__photo img{transform:scale(1.06)}

/* Process step — marker pulse on reveal */
.process-step.is-in .process-step__marker{box-shadow:0 0 0 5px rgba(232,75,28,0.12);transition:box-shadow .6s var(--ease)}

/* FAQ chevron accent on hover */
.faq-item summary:hover .faq-chevron{stroke:var(--accent);transition:stroke .24s,transform .36s var(--ease-out)}

/* Hero CTA — subtle pulsing glow */
@keyframes cta-glow{0%,100%{box-shadow:0 0 0 0 rgba(232,75,28,0.25)}50%{box-shadow:0 0 0 10px rgba(232,75,28,0)}}
.hero__cta .btn-primary{animation:cta-glow 3s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.hero__cta .btn-primary{animation:none}}

/* Stats band — richer background */
.stats-band{background:linear-gradient(145deg,#1a1a1a 0%,#252525 50%,#1a1a1a 100%)}

/* Cancel tier hover lift */
.cancel-tier{transition:transform .24s var(--ease),box-shadow .24s var(--ease)}
.cancel-tier:hover{transform:translateY(-3px);box-shadow:var(--shadow-card)}

/* --- Policy pages — visual hierarchy --- */
.policy-content h2{padding-bottom:10px;border-bottom:2px solid var(--line);margin-top:clamp(32px,5vw,48px)}
.policy-content h3{color:var(--ink);position:relative;padding-left:14px}
.policy-content h3::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--accent);border-radius:2px}

/* --- Footer link hover --- */
.footer__col a:hover{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}

/* --- Smooth stagger for grid children --- */
.programs-grid .program-card:nth-child(1){transition-delay:0ms}
.programs-grid .program-card:nth-child(2){transition-delay:60ms}
.programs-grid .program-card:nth-child(3){transition-delay:120ms}
.programs-grid .program-card:nth-child(4){transition-delay:180ms}
.programs-grid .program-card:nth-child(5){transition-delay:240ms}
.programs-grid .program-card:nth-child(6){transition-delay:300ms}
.programs-grid .program-card:nth-child(7){transition-delay:360ms}
.programs-grid .program-card:nth-child(8){transition-delay:420ms}
.programs-grid .program-card:nth-child(9){transition-delay:480ms}
@media(prefers-reduced-motion:reduce){.programs-grid .program-card{transition-delay:0ms!important}}

/* --- Hero title mobile word-break fix --- */
@media(max-width:430px){.hero__title{font-size:2.3rem}}

/* --- Stagger animations: pricing grid --- */
.pricing-grid .pricing-card:nth-child(1){transition-delay:0ms}
.pricing-grid .pricing-card:nth-child(2){transition-delay:80ms}
.pricing-grid .pricing-card:nth-child(3){transition-delay:160ms}
.pricing-grid .pricing-card:nth-child(4){transition-delay:240ms}
@media(prefers-reduced-motion:reduce){.pricing-grid .pricing-card{transition-delay:0ms!important}}

/* --- Stagger animations: team grid --- */
.team-grid .team-card:nth-child(1){transition-delay:0ms}
.team-grid .team-card:nth-child(2){transition-delay:100ms}
.team-grid .team-card:nth-child(3){transition-delay:200ms}
@media(prefers-reduced-motion:reduce){.team-grid .team-card{transition-delay:0ms!important}}

/* --- Stagger animations: contact grid --- */
.contact-grid .contact-card:nth-child(1){transition-delay:0ms}
.contact-grid .contact-card:nth-child(2){transition-delay:60ms}
.contact-grid .contact-card:nth-child(3){transition-delay:120ms}
.contact-grid .contact-card:nth-child(4){transition-delay:180ms}
.contact-grid .contact-card:nth-child(5){transition-delay:240ms}
.contact-grid .contact-card:nth-child(6){transition-delay:300ms}
@media(prefers-reduced-motion:reduce){.contact-grid .contact-card{transition-delay:0ms!important}}

/* --- Section divider chalk-line pulse --- */
@keyframes chalk-pulse{0%,100%{opacity:.15}50%{opacity:.25}}
.section-divider{animation:chalk-pulse 4s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.section-divider{animation:none}}

/* --- Stats entrance pop (chained with existing net-shimmer) --- */
@keyframes stat-pop{0%{transform:scale(.8) translateY(8px);opacity:0}60%{transform:scale(1.04) translateY(0)}100%{transform:scale(1);opacity:1}}
.stat__number.is-in{animation:stat-pop .6s var(--ease) backwards,net-shimmer 6s linear .6s infinite}
@media(prefers-reduced-motion:reduce){.stat__number.is-in{animation:none!important}}

/* --- FAQ item open accent bg --- */
.faq-item[open]{background:rgba(232,75,28,0.02);border-radius:8px;margin:0 -12px;padding:0 12px}

/* --- Program card turf glow overlay on hover --- */
.program-card::after{content:'';position:absolute;top:0;right:0;width:60%;height:60%;background:radial-gradient(circle at top right,rgba(27,107,58,0.06),transparent 70%);opacity:0;transition:opacity .32s var(--ease);pointer-events:none;border-radius:0 var(--radius) 0 0}
.program-card:hover::after{opacity:1}

/* --- Testimonial card quote bar grow on hover --- */
.testimonial-card__quote{transition:border-color .28s var(--ease),padding-left .28s var(--ease)}
.testimonial-card:hover .testimonial-card__quote{border-left-width:4px;padding-left:22px}

/* --- Form field focus glow stronger --- */
.field input:focus,.field textarea:focus,.field select:focus{box-shadow:0 0 0 4px rgba(232,75,28,0.12)}

/* --- Print --- */
@media print{
  .site-header,.nav-toggle,.drawer,.drawer-backdrop,.cookie-banner,.skip-link{display:none!important}
  main{padding-top:0!important}
  body{font-size:11pt;color:#000;background:#fff}
  .reveal{opacity:1!important;transform:none!important}
  a[href]::after{content:" (" attr(href) ")";font-size:0.8em;color:#666}
}

.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:9998;transition:width 80ms linear;pointer-events:none}

/* hero btn-ghost contrast guard */
.hero .btn-ghost{color:#fff !important;border-color:rgba(255,255,255,.45) !important;background:transparent !important}
.hero .btn-ghost:hover,.hero .btn-ghost:focus-visible{background:rgba(255,255,255,.95) !important;color:var(--ink) !important;border-color:#fff !important}

/* hero readability overlay on top of full-opacity background image */
.hero__image-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,74,36,.35) 0%,rgba(13,74,36,.65) 60%,rgba(13,74,36,.85) 100%);z-index:1;pointer-events:none}
.hero__inner{z-index:3}
