/* ===================================================================
   Sahada — Kadın Futsal Akademisi
   =================================================================== */

/* --- RESET & BASE ------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html,body{overflow-x:hidden;max-width:100vw;margin:0}
body{font-family:'Lato',sans-serif;font-weight:400;letter-spacing:-0.015em;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}
input,button,textarea,select{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;background:none;border:none}

:root{
  interpolate-size:allow-keywords;
  --bg:#F5F0EB;
  --surface:#FFFFFF;
  --surface-2:#FAF8F5;
  --ink:#1C1C2A;
  --ink-soft:#5A5A6E;
  --accent:#8B4DCC;
  --accent-2:#E85D75;
  --line:rgba(28,28,42,0.12);
  --line-strong:rgba(28,28,42,0.25);
  --header-h:72px;
  --container-max:1180px;
  --container-pad:clamp(16px,4vw,32px);
  --radius:12px;
  --radius-sm:8px;
  --shadow-card:0 4px 24px -8px rgba(28,28,42,0.10);
  --shadow-hover:0 12px 32px -8px rgba(139,77,204,0.22);
  --ease-out:cubic-bezier(.2,.7,.2,1);
  --ease-in-out:cubic-bezier(.4,0,.2,1);
}

/* --- TYPOGRAPHY --------------------------------------------------- */
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,'Times New Roman',serif;font-weight:700;font-style:italic;line-height:1.1;color:var(--ink)}
h1{font-size:clamp(2.8rem, 8vw, 4.5rem);letter-spacing:-0.012em;line-height:1.05}
h2{font-size:clamp(2rem,5vw,3.2rem);line-height:1.15}
h3{font-size:clamp(1.4rem,3vw,1.9rem);line-height:1.25}
h4{font-size:clamp(1.1rem,2vw,1.35rem);line-height:1.3}
p{margin-bottom:1em;max-width:68ch}
.eyebrow{font-family:'Lato',sans-serif;font-weight:700;font-style:normal;font-size:0.85rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:0.75rem}
.section-sub{font-size:1.1rem;color:var(--ink-soft);max-width:52ch;margin:0.5rem auto 0}
.accent-underline{position:relative;display:inline-block}
.accent-underline::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:3px;background:var(--accent);border-radius:2px}

/* --- LAYOUT ------------------------------------------------------- */
.container{width:100%;max-width:var(--container-max);margin:0 auto;padding-inline:var(--container-pad)}
main{padding-top:var(--header-h)}
section[id]{scroll-margin-top:calc(var(--header-h) + 16px)}
section{padding:clamp(3.5rem,8vw,6rem) 0}
.text-center{text-align:center}

/* --- SKIP LINK ---------------------------------------------------- */
.skip-link{position:absolute;top:-100%;left:16px;z-index:10000;padding:12px 24px;background:var(--accent);color:#fff;border-radius:0 0 var(--radius-sm) var(--radius-sm);font-weight:700;font-size:0.9rem;transition:top 200ms}
.skip-link:focus{top:0}

/* --- HEADER (sticky-with-morph) ----------------------------------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1080;background:rgba(245, 240, 235, 0.92);transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease}
.site-header.scrolled{background:rgba(245,240,235,0.98);box-shadow:0 8px 24px -16px rgba(0,0,0,.18)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);transition:height 240ms ease}
.site-header.scrolled .header-inner{height:60px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-weight:700;font-style:italic;font-size:1.4rem;color:var(--ink);z-index:1100;transition:color 240ms ease}
.logo:hover{color:var(--accent)}
.logo-icon{width:32px;height:32px;color:var(--accent);flex-shrink:0}

/* --- NAV DESKTOP -------------------------------------------------- */
.nav-desktop{display:none;align-items:center;gap:clamp(18px,2.5vw,32px)}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{font-size:0.92rem;font-weight:400;color:var(--ink);position:relative;padding:6px 0;transition:color 240ms ease}
.nav-desktop a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);border-radius:1px;transition:width 320ms cubic-bezier(.16,.84,.44,1)}
.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);font-weight:700}
.nav-desktop .nav-cta{background:var(--ink);color:var(--surface);padding:10px 22px;border-radius:var(--radius-sm);font-weight:700;font-size:0.88rem;letter-spacing:0.02em;transition:background 280ms ease,color 240ms ease,transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms ease}
.nav-desktop .nav-cta::after{display:none}
.nav-desktop .nav-cta:hover{background:var(--accent);color:var(--surface);transform:translateY(-2px);box-shadow:0 6px 18px -4px rgba(139,77,204,0.35)}
.nav-desktop .nav-cta.is-active{background:var(--accent);color:var(--surface)}

/* --- NAV TOGGLE (hamburger → X) ----------------------------------- */
.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:6px;width:48px;height:48px;min-width:48px;min-height:48px;z-index:1100;padding:10px;border-radius:var(--radius-sm);border:2px solid transparent;transition:background 240ms ease,border-color 240ms ease}
.nav-toggle:hover{background:rgba(28,28,42,0.08);border-color:var(--line)}
.nav-toggle:focus-visible{border-color:var(--accent)}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-toggle span{display:block;width:100%;height:3px;background:var(--ink);border-radius:2px;transition:transform 320ms var(--ease-out),opacity 240ms ease,width 280ms var(--ease-out)}
.nav-toggle span:nth-child(2){width:70%}
.nav-toggle:hover span:nth-child(2){width:100%}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;width:100%}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* --- DRAWER (mobile nav) ------------------------------------------ */
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(360px,92vw);background:var(--surface);z-index:1050;transform:translateX(100%);transition:transform 380ms cubic-bezier(.2,.7,.2,1);padding:calc(var(--header-h) + 24px) 32px 32px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;box-shadow:-8px 0 32px rgba(0,0,0,0)}
.drawer.is-open{transform:translateX(0);box-shadow:-8px 0 32px rgba(0,0,0,0.15)}
.drawer nav{display:flex;flex-direction:column;gap:4px}
.drawer a{font-size:1.15rem;padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink);transition:color 240ms ease,padding-left 280ms cubic-bezier(.16,.84,.44,1)}
.drawer a:hover{color:var(--accent);padding-left:8px}
.drawer a.is-active{color:var(--accent);font-weight:700}
.drawer .nav-cta{margin-top:16px;background:var(--accent);color:#fff;text-align:center;border-radius:var(--radius-sm);padding:16px;border:0;font-weight:700}
.drawer .nav-cta:hover{background:var(--ink);color:var(--surface)}
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:1040;opacity:0;pointer-events:none;transition:opacity 240ms ease}
.drawer-backdrop.is-visible{opacity:1;pointer-events:auto}

/* --- BUTTONS ------------------------------------------------------ */
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--surface);padding:16px 36px;border-radius:var(--radius-sm);font-weight:700;font-size:1rem;letter-spacing:0.02em;transition:background 280ms cubic-bezier(.2,.7,.2,1),color 240ms ease,transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms ease;border:none;cursor:pointer;position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.12) 50%,transparent 70%);transform:translateX(-100%);transition:transform 600ms ease}
.btn-primary:hover::after{transform:translateX(100%)}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--accent);color:var(--surface);transform:translateY(-3px);box-shadow:0 10px 28px -6px rgba(139,77,204,0.4)}
.btn-primary:active{transform:translateY(-1px);box-shadow:0 4px 16px -6px rgba(139,77,204,0.3)}
.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn-primary .btn-icon{transition:transform 180ms var(--ease-out)}
.btn-primary:hover .btn-icon{animation:ballBounce 700ms cubic-bezier(.2,.7,.2,1) 2}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--ink);padding:14px 28px;border-radius:var(--radius-sm);font-weight:700;font-size:0.95rem;border:2px solid var(--line-strong);transition:background 280ms ease,color 280ms ease,border-color 280ms ease,transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms ease}
.btn-ghost:hover,.btn-ghost:focus-visible{background:var(--surface);color:var(--accent);border-color:var(--accent);transform:translateY(-3px);box-shadow:0 6px 20px -6px rgba(139,77,204,0.2)}
.btn-ghost:active{transform:translateY(-1px)}
.btn-ghost:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* --- HERO --------------------------------------------------------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#1C1C2A 0%,#3a2057 50%,#1C1C2A 100%);margin-top:calc(-1 * var(--header-h))}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;animation:heroZoom 8s ease-out both;will-change:transform}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,28,42,0.55) 0%,rgba(139,77,204,0.18) 40%,rgba(28,28,42,0.65) 100%);z-index:1}
.hero__content{position:relative;z-index:2;text-align:center;color:#fff;padding:0 var(--container-pad)}
.hero__content .eyebrow{color:rgba(255,255,255,0.85);margin-bottom:1.2rem;animation:fadeSlideUp 800ms cubic-bezier(.2,.7,.2,1) 200ms both}
.hero__content h1{color:#fff;margin-bottom:1rem;max-width:12ch;margin-left:auto;margin-right:auto}
.hero__sub{font-size:clamp(1.05rem,2.5vw,1.3rem);color:rgba(255,255,255,0.88);max-width:42ch;margin:0 auto 2.5rem;line-height:1.6}
.hero .reveal{opacity:1;transform:none}
.hero .mask-reveal{clip-path:inset(0 0 0 0);animation:heroClipReveal 900ms cubic-bezier(.16,.84,.44,1) 400ms both}
.hero .reveal[style*="--i"]{animation:fadeSlideUp 700ms cubic-bezier(.2,.7,.2,1) both;animation-delay:calc(300ms + var(--i,0) * 150ms)}
@keyframes heroClipReveal{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
.trust-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 24px;margin-top:2rem}
.trust-strip span{display:inline-flex;align-items:center;gap:6px;font-size:0.82rem;font-weight:700;letter-spacing:0.04em;color:rgba(255,255,255,0.8);padding:8px 16px;border:1px solid rgba(255,255,255,0.2);border-radius:999px;backdrop-filter:blur(2px);background:rgba(255,255,255,0.06);transition:background 280ms ease,border-color 280ms ease,transform 280ms var(--ease-out)}
.trust-strip span:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.35);transform:translateY(-2px)}
.trust-strip span::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent-2);flex-shrink:0}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* --- COURT DIVIDER (theme signature) ------------------------------ */
.court-divider{position:relative;height:60px;display:flex;align-items:center;justify-content:center;margin:0 auto;max-width:600px;color:var(--accent);opacity:0.35;overflow:visible}
.court-divider svg{width:100%;height:100%}
.court-line-base{transition:opacity 600ms var(--ease-out)}
.court-center-circle,.court-penalty-arc,.court-corner-arc{stroke-dasharray:var(--dash-total);stroke-dashoffset:var(--dash-total);transition:stroke-dashoffset 1.2s var(--ease-out)}
.court-divider.is-in .court-center-circle,.court-divider.is-in .court-penalty-arc,.court-divider.is-in .court-corner-arc{stroke-dashoffset:0}
.court-center-dot{opacity:0;transition:opacity 400ms 600ms ease}
.court-divider.is-in .court-center-dot{opacity:1}

/* --- STORY SECTION ------------------------------------------------ */
.story{background:var(--surface)}
.story__inner{display:grid;gap:clamp(2rem,5vw,4rem);align-items:center}
@media(min-width:768px){.story__inner{grid-template-columns:1fr 1fr}}
.story__photo{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5}
.story__photo img{width:100%;height:100%;object-fit:cover;transition:transform 700ms cubic-bezier(.16,.84,.44,1)}
.story__photo:hover img{transform:scale(1.04)}
.story__photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(139,77,204,0.15) 100%);pointer-events:none}
.story__text h2{margin-bottom:1.5rem}
.story__text p{color:var(--ink-soft);font-size:1.05rem}
.story__text .quote{font-family:'Playfair Display',serif;font-style:italic;font-size:1.3rem;color:var(--ink);border-left:3px solid var(--accent);padding-left:1.2rem;margin:1.5rem 0;line-height:1.5}

/* --- STATS SECTION ------------------------------------------------ */
.stats{background:var(--ink);color:#fff;padding:clamp(2.5rem,5vw,4rem) 0}
.stats__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:clamp(1.5rem,3vw,2.5rem);text-align:center}
.stat-item{padding:1.5rem}
.stat-number{font-family:'Playfair Display',serif;font-weight:700;font-style:italic;font-size:clamp(2.5rem,6vw,3.8rem);color:var(--accent);line-height:1;margin-bottom:0.5rem;letter-spacing:-0.02em}
.stat-number .stat-suffix{font-size:0.6em;opacity:0.8}
.stat-label{font-size:0.9rem;color:rgba(255,255,255,0.7);font-weight:400;letter-spacing:0.04em}

/* --- PROGRAM / TIMELINE ------------------------------------------- */
.program{background:var(--bg)}
.program .section-header{text-align:center;margin-bottom:clamp(3rem,6vw,5rem)}
.timeline{position:relative;max-width:780px;margin:0 auto}
.timeline::before{content:'';position:absolute;left:28px;top:0;bottom:0;width:2px;background:var(--line)}
@media(min-width:768px){.timeline::before{left:50%;transform:translateX(-1px)}}
.timeline-item{position:relative;padding:0 0 clamp(2.5rem,5vw,3.5rem) 72px}
@media(min-width:768px){
  .timeline-item{padding:0 0 clamp(2.5rem,5vw,3.5rem) 0;width:50%}
  .timeline-item:nth-child(odd){margin-left:auto;padding-left:48px}
  .timeline-item:nth-child(even){padding-right:48px;text-align:right}
}
.timeline-marker{position:absolute;left:14px;top:0;width:30px;height:30px;border-radius:50%;background:var(--surface);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;z-index:2}
@media(min-width:768px){
  .timeline-marker{left:auto;right:-15px}
  .timeline-item:nth-child(odd) .timeline-marker{left:-15px;right:auto}
}
.timeline-marker svg{width:16px;height:16px;color:var(--accent)}
.timeline-marker .marker-num{font-family:'Lato',sans-serif;font-weight:700;font-size:0.75rem;color:var(--accent)}
.timeline-card{position:relative;overflow:hidden;background:var(--surface);border-radius:var(--radius);padding:clamp(1.2rem,3vw,1.8rem);box-shadow:var(--shadow-card);border:1px solid transparent;transition:transform 400ms cubic-bezier(.16,.84,.44,1),box-shadow 400ms ease,border-color 400ms ease}
.timeline-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:rgba(139,77,204,0.15)}
.timeline-card .step-eyebrow{font-family:'Lato',sans-serif;font-size:0.78rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);margin-bottom:0.5rem;font-style:normal}
.timeline-card h3{margin-bottom:0.6rem;font-size:1.2rem}
.timeline-card p{color:var(--ink-soft);font-size:0.95rem;margin-bottom:0}
.timeline-card .time-badge{display:inline-block;margin-top:0.8rem;font-size:0.78rem;font-weight:700;padding:4px 12px;background:rgba(139,77,204,0.08);color:var(--accent);border-radius:999px}

/* --- PRICING ------------------------------------------------------ */
.pricing{background:var(--surface)}
.pricing .section-header{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.pricing-grid{display:grid;gap:clamp(1.2rem,3vw,2rem);max-width:980px;margin:0 auto}
@media(min-width:768px){.pricing-grid{grid-template-columns:repeat(3,1fr)}}
.pricing-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem);display:flex;flex-direction:column;transition:transform 400ms cubic-bezier(.16,.84,.44,1),box-shadow 400ms ease,border-color 400ms ease}
.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:rgba(139,77,204,0.2)}
.pricing-card.is-featured{border-color:var(--accent);position:relative;background:var(--surface)}
.pricing-card.is-featured::before{content:'Popüler';position:absolute;top:-12px;right:20px;background:var(--accent-2);color:#fff;font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:4px 14px;border-radius:999px}
.pricing-card__name{font-family:'Playfair Display',serif;font-weight:700;font-style:italic;font-size:1.3rem;margin-bottom:0.5rem}
.pricing-card__sessions{font-size:0.88rem;color:var(--ink-soft);margin-bottom:1.2rem}
.pricing-card__price{font-family:'Playfair Display',serif;font-weight:700;font-style:italic;font-size:clamp(2rem,4vw,2.6rem);color:var(--ink);margin-bottom:0.3rem;letter-spacing:-0.01em}
.pricing-card__price .currency{font-size:0.5em;font-style:normal;font-family:'Lato',sans-serif;font-weight:400;vertical-align:super;margin-left:4px}
.pricing-card__list{flex:1;margin:1.2rem 0;padding:0}
.pricing-card__list li{font-size:0.92rem;color:var(--ink-soft);padding:6px 0 6px 24px;position:relative}
.pricing-card__list li::before{content:'';position:absolute;left:0;top:12px;width:14px;height:14px}
.pricing-card__list .included::before{background:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 8.5l3 3 7-7' stroke='%238B4DCC' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat}
.pricing-card__list .excluded{color:var(--ink-soft);opacity:0.55;text-decoration:line-through}
.pricing-card__list .excluded::before{background:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 4l8 8M12 4l-8 8' stroke='%23E85D75' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat}
.pricing-card .btn-primary,.pricing-card .btn-ghost{width:100%;justify-content:center;margin-top:auto}
.pricing-disclaimer{text-align:center;margin-top:1.5rem;font-size:0.82rem;color:var(--ink-soft);font-style:italic}

/* --- TESTIMONIALS / VOICES ---------------------------------------- */
.voices{background:var(--bg);position:relative;overflow:hidden}
.voices::before{content:'';position:absolute;top:-40px;left:-40px;width:160px;height:160px;border:2px solid var(--accent);border-radius:50%;opacity:0.08;pointer-events:none}
.voices .section-header{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.voices-grid{display:grid;gap:clamp(1.5rem,3vw,2rem)}
@media(min-width:768px){.voices-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.voices-grid{grid-template-columns:1fr 1fr 1fr}}
.voice-card{background:var(--surface);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem);border:1px solid var(--line);position:relative;transition:transform 400ms cubic-bezier(.16,.84,.44,1),box-shadow 400ms ease,border-color 400ms ease}
.voice-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:rgba(139,77,204,0.15)}
.voice-card::before{content:'\201C';position:absolute;top:12px;right:20px;font-family:'Playfair Display',serif;font-size:4rem;color:var(--accent);opacity:0.12;line-height:1}
.voice-card__text{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(1.05rem,2vw,1.2rem);line-height:1.55;color:var(--ink);margin-bottom:1.2rem}
.voice-card__author{display:flex;align-items:center;gap:12px}
.voice-card__avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:0.85rem;font-family:'Lato',sans-serif;flex-shrink:0}
.voice-card__meta{font-size:0.85rem;color:var(--ink-soft);line-height:1.4}
.voice-card__meta strong{color:var(--ink);font-weight:700;display:block}

/* --- FAQ ---------------------------------------------------------- */
.faq{background:var(--surface)}
.faq .section-header{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:clamp(1rem,2.5vw,1.4rem) 0;cursor:pointer;font-family:'Playfair Display',serif;font-weight:700;font-style:italic;font-size:clamp(1rem,2vw,1.15rem);color:var(--ink);transition:color 240ms ease;list-style:none}
.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:24px;height:24px;flex-shrink:0;color:var(--accent);transition:transform 400ms cubic-bezier(.16,.84,.44,1)}
.faq-item[open] summary .faq-chevron{transform:rotate(180deg)}
.faq-item .faq-answer{height:0;padding:0 clamp(18px,3vw,28px);overflow:hidden;transition:height 400ms cubic-bezier(.16,.84,.44,1),padding-block-end 400ms cubic-bezier(.16,.84,.44,1)}
.faq-item[open] .faq-answer{height:auto;padding-block-end:26px}
.faq-answer p{color:var(--ink-soft);font-size:0.95rem;line-height:1.75;margin-bottom:0}
.faq-item summary{transition:color 240ms ease,padding-left 240ms ease,border-color 240ms ease}
@media(prefers-reduced-motion:reduce){.faq-item .faq-answer{transition:none}.faq-item summary{transition:none}}

/* --- CTA SECTION -------------------------------------------------- */
.cta-section{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-80px;right:-80px;width:300px;height:300px;border:2px solid rgba(255,255,255,0.1);border-radius:50%;pointer-events:none}
.cta-section::after{content:'';position:absolute;bottom:-120px;left:-60px;width:400px;height:400px;border:2px solid rgba(255,255,255,0.06);border-radius:50%;pointer-events:none}
.cta-section h2{color:#fff;margin-bottom:1rem}
.cta-section p{color:rgba(255,255,255,0.88);max-width:48ch;margin:0 auto 2rem;font-size:1.1rem}
.cta-section .btn-primary{background:#fff;color:var(--accent);font-size:1.05rem;padding:18px 42px}
.cta-section .btn-primary:hover{background:var(--ink);color:#fff;transform:translateY(-3px);box-shadow:0 12px 32px -8px rgba(0,0,0,0.3);animation:none}

/* --- PROCESS SECTION ---------------------------------------------- */
.process{background:var(--bg)}
.process .section-header{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.process-grid{display:grid;gap:clamp(1.5rem,3vw,2rem);max-width:900px;margin:0 auto}
@media(min-width:640px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.process-grid{grid-template-columns:repeat(3,1fr)}}
.process-card{background:var(--surface);border-radius:var(--radius);padding:clamp(1.3rem,3vw,1.8rem);border:1px solid var(--line);position:relative;transition:transform 400ms cubic-bezier(.16,.84,.44,1),box-shadow 400ms ease,border-color 400ms ease}
.process-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:rgba(139,77,204,0.2)}
.process-card__icon{transition:transform 400ms cubic-bezier(.16,.84,.44,1),background 400ms ease}
.process-card:hover .process-card__icon{transform:scale(1.1);background:rgba(139,77,204,0.16)}
.process-card__num{position:absolute;top:16px;right:16px;font-family:'Playfair Display',serif;font-weight:700;font-style:italic;font-size:2.2rem;color:var(--accent);opacity:0.12;line-height:1}
.process-card__icon{width:48px;height:48px;border-radius:50%;background:rgba(139,77,204,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.process-card__icon svg{width:22px;height:22px;color:var(--accent)}
.process-card h4{font-size:1.1rem;margin-bottom:0.5rem}
.process-card p{font-size:0.9rem;color:var(--ink-soft);margin-bottom:0}

/* --- FOOTER ------------------------------------------------------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,0.75);padding:clamp(3rem,6vw,4.5rem) 0 0}
.footer-grid{display:grid;gap:clamp(2rem,4vw,3rem)}
@media(min-width:640px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1.5fr}}
.footer-col h4{color:#fff;font-size:1rem;margin-bottom:1rem}
.footer-brand .logo{color:#fff;margin-bottom:1rem}
.footer-brand p{font-size:0.9rem;max-width:32ch;line-height:1.6}
.footer-col a{display:block;font-size:0.9rem;padding:4px 0;transition:color 240ms ease,padding-left 280ms cubic-bezier(.16,.84,.44,1)}
.footer-col a:hover{color:var(--accent);padding-left:4px}
.footer-contact-item{display:flex;gap:10px;align-items:flex-start;font-size:0.88rem;margin-bottom:10px}
.footer-contact-item svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--accent)}
.footer-contact-item a{display:inline;padding:0}
.footer-bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:1.5rem 0;margin-top:clamp(2rem,4vw,3rem);border-top:1px solid rgba(255,255,255,0.1);font-size:0.8rem;color:rgba(255,255,255,0.45)}
.footer-bottom a{color:rgba(255,255,255,0.55);transition:color 240ms ease}
.footer-bottom a:hover{color:var(--accent)}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 20px}
.footer-vkn{font-size:0.78rem;color:rgba(255,255,255,0.35);margin-top:4px}

/* --- FORM --------------------------------------------------------- */
.form-grid{display:grid;gap:clamp(1rem,2vw,1.5rem)}
@media(min-width:640px){.form-grid--2col{grid-template-columns:1fr 1fr}.form-grid--2col .field--full{grid-column:1/-1}}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:0.88rem;font-weight:700;color:var(--ink);letter-spacing:0.02em}
.field input[type="text"],.field input[type="email"],.field input[type="tel"],.field select,.field textarea{width:100%;padding:12px 16px;border:2px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);font-size:0.95rem;transition:border-color 240ms ease,box-shadow 240ms ease;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,77,204,0.12);outline:none}
.field textarea{min-height:120px;resize:vertical}
.field select{appearance:auto;-webkit-appearance:auto}
.field 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)}
.field--checkbox{flex-direction:row;align-items:flex-start;gap:10px}
.field--checkbox label{font-weight:400;font-size:0.85rem;color:var(--ink-soft);line-height:1.4;cursor:pointer}
.form-submit{margin-top:0.5rem}
.form-submit .btn-primary{width:100%}
@media(min-width:640px){.form-submit .btn-primary{width:auto}}
.honeypot{position:absolute;left:-9999px;opacity:0}

/* --- CONTACT CARDS ------------------------------------------------ */
.contact-cards{display:grid;gap:clamp(1rem,2vw,1.5rem);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.2rem,3vw,1.6rem);transition:transform 400ms cubic-bezier(.16,.84,.44,1),box-shadow 400ms ease,border-color 400ms ease}
.contact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:rgba(139,77,204,0.2)}
.contact-card__icon{width:48px;height:48px;border-radius:50%;background:rgba(139,77,204,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;transition:transform 400ms cubic-bezier(.16,.84,.44,1),background 400ms ease}
.contact-card:hover .contact-card__icon{transform:scale(1.1);background:rgba(139,77,204,0.18)}
.contact-card__icon svg{width:22px;height:22px;color:var(--accent)}
.contact-card__label{font-size:0.78rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:0.4rem}
.contact-card__value{font-size:1rem;color:var(--ink);font-weight:700}
.contact-card__value a{color:var(--ink);transition:color 240ms ease;word-break:break-all;overflow-wrap:anywhere}
.contact-card__value a:hover{color:var(--accent)}
.contact-card__sub{font-size:0.82rem;color:var(--ink-soft);margin-top:0.3rem}

/* --- HOURS TABLE -------------------------------------------------- */
.hours-grid{display:grid;gap:2px}
.hours-row{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;padding:8px 12px;border-radius:var(--radius-sm);font-size:0.9rem;font-variant-numeric:tabular-nums}
.hours-row:nth-child(odd){background:rgba(139,77,204,0.04)}
.hours-row .day{font-weight:700;color:var(--ink);min-width:44px}
.hours-row .time{color:var(--ink-soft)}
.hours-row.is-today{background:rgba(139,77,204,0.1);border:1px solid rgba(139,77,204,0.2)}
.hours-row.is-today .day{color:var(--accent)}

/* --- PAGE HERO (inner pages) -------------------------------------- */
.page-hero{background:var(--ink);color:#fff;padding:clamp(4rem,10vw,7rem) 0 clamp(3rem,6vw,4rem);text-align:center;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:120px;height:3px;background:var(--accent);border-radius:2px}
.page-hero .eyebrow{color:rgba(255,255,255,0.6)}
.page-hero h1{color:#fff;margin-bottom:0.8rem;font-size:clamp(2.2rem, 6vw, 3.5rem)}
.page-hero p{color:rgba(255,255,255,0.7);max-width:48ch;margin:0 auto}

/* --- LEGAL / TEXT PAGES ------------------------------------------- */
.legal-content{background:var(--surface);padding:clamp(2.5rem,5vw,4rem) 0}
.legal-content h2{margin:2.8rem 0 1.2rem;font-size:clamp(1.4rem,3vw,1.8rem)}
.legal-content h3{margin:2.2rem 0 0.9rem;font-size:1.2rem}
.legal-content p{color:var(--ink-soft);font-size:0.95rem;margin-bottom:1.2rem;max-width:72ch;line-height:1.75}
.legal-content ul,.legal-content ol{margin:1rem 0 1.4rem 1.5rem;color:var(--ink-soft);font-size:0.95rem;line-height:1.7}
.legal-content li{margin-bottom:0.5rem;padding-left:0.4rem}
.legal-content ol{list-style:decimal}
.legal-content ul{list-style:disc}
.legal-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;transition:color 240ms ease}
.legal-content a:hover{color:var(--accent-2)}

/* --- TABLE SCROLL ------------------------------------------------- */
.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}
table{border-collapse:collapse;width:100%;font-size:0.92rem}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line)}
th{font-weight:700;color:var(--ink);background:var(--surface-2);font-size:0.85rem;letter-spacing:0.04em;text-transform:uppercase}
td{color:var(--ink-soft)}

/* --- COOKIE BANNER ------------------------------------------------ */
.cookie-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:520px;margin:0 auto;transform:translateY(140%);opacity:0;transition:transform 480ms cubic-bezier(.2,.7,.2,1),opacity 350ms;z-index:9999;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.2rem,3vw,1.6rem);box-shadow:0 16px 48px -12px rgba(0,0,0,0.2)}
@media(min-width:640px){.cookie-banner{left:24px;right:auto;max-width:420px}}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner h3{font-size:1rem;margin-bottom:0.5rem}
.cookie-banner p{font-size:0.85rem;color:var(--ink-soft);margin-bottom:1rem;line-height:1.55}
.cookie-banner p a{color:var(--accent);text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-actions button{flex:1;min-width:90px;min-height:48px;padding:12px 16px;border-radius:var(--radius-sm);font-weight:700;font-size:0.88rem;cursor:pointer;transition:background 240ms ease,color 240ms ease,border-color 240ms ease,transform 180ms var(--ease-out),box-shadow 240ms ease}
.cookie-actions button:hover{transform:translateY(-1px)}
.cookie-actions button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.cookie-actions .cookie-accept{background:var(--accent);color:#fff;border:2px solid var(--accent)}
.cookie-actions .cookie-accept:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.cookie-actions .cookie-reject{background:transparent;color:var(--ink);border:2px solid var(--line-strong);font-weight:700}
.cookie-actions .cookie-reject:hover{background:var(--ink);border-color:var(--ink);color:#fff}
.cookie-actions .cookie-settings{background:transparent;color:var(--ink-soft);border:2px solid var(--line)}
.cookie-actions .cookie-settings:hover{border-color:var(--ink);color:var(--ink);background:transparent}
@media(max-width:640px){
  .cookie-banner{bottom:8px;left:8px;right:8px;padding:clamp(1rem,3vw,1.4rem)}
  .cookie-actions{gap:8px}
  .cookie-actions button{min-width:80px;min-height:48px;padding:12px 10px;font-size:0.85rem}
}

/* --- REVEAL ANIMATIONS -------------------------------------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 700ms cubic-bezier(.16,.84,.44,1),transform 700ms cubic-bezier(.16,.84,.44,1)}
.reveal.is-in{opacity:1;transform:none}
.reveal[style*="--i"]{transition-delay:calc(var(--i,0) * 110ms)}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}
html.no-js .reveal{opacity:1;transform:none}

/* Mask-clip text reveal */
.mask-reveal{clip-path:inset(0 100% 0 0);transition:clip-path 900ms cubic-bezier(.16,.84,.44,1)}
.mask-reveal.is-in{clip-path:inset(0 0 0 0)}
@media(prefers-reduced-motion:reduce){.mask-reveal{clip-path:none!important;transition:none!important}}
html.no-js .mask-reveal{clip-path:none}

/* Lateral reveal for alternating items */
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity 700ms cubic-bezier(.16,.84,.44,1),transform 700ms cubic-bezier(.16,.84,.44,1)}
.reveal-left.is-in{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity 700ms cubic-bezier(.16,.84,.44,1),transform 700ms cubic-bezier(.16,.84,.44,1)}
.reveal-right.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal-left,.reveal-right{opacity:1!important;transform:none!important;transition:none!important}}

/* --- NICHE ANIMATIONS (futsal) ------------------------------------ */
@keyframes ballBounce{
  0%,100%{transform:translateY(0) rotate(0deg)}
  30%{transform:translateY(-10px) rotate(-8deg)}
  50%{transform:translateY(-4px) rotate(4deg)}
  70%{transform:translateY(-6px) rotate(-2deg)}
}
@keyframes whistleSwing{
  0%,100%{transform:rotate(-3deg)}
  50%{transform:rotate(3deg)}
}
@keyframes netRipple{
  0%,100%{transform:scaleY(1) scaleX(1)}
  50%{transform:scaleY(1.015) scaleX(0.995)}
}
@keyframes courtDash{
  from{stroke-dashoffset:var(--dash-len,100)}
  to{stroke-dashoffset:0}
}
@keyframes goalShine{
  0%{background-position:-200% center}
  100%{background-position:200% center}
}
@keyframes kickPulse{
  0%{box-shadow:0 8px 24px -8px rgba(139,77,204,0.35)}
  50%{box-shadow:0 12px 32px -4px rgba(139,77,204,0.5)}
  100%{box-shadow:0 8px 24px -8px rgba(139,77,204,0.35)}
}
@keyframes courtGlow{
  0%,100%{box-shadow:0 4px 24px -8px rgba(28,28,42,0.10)}
  50%{box-shadow:0 8px 28px -4px rgba(139,77,204,0.18)}
}

.timeline-marker svg{animation:whistleSwing 3.5s cubic-bezier(.4,0,.2,1) infinite;transform-origin:top center}
.btn-primary:hover{animation:kickPulse 1.2s ease-in-out infinite}
.btn-primary:not(:hover){animation:none}
.pricing-card:hover,.voice-card:hover,.team-card:hover,.contact-card:hover,.process-card:hover{animation:courtGlow 2s ease-in-out infinite}
.pricing-card:not(:hover),.voice-card:not(:hover),.team-card:not(:hover),.contact-card:not(:hover),.process-card:not(:hover){animation:none}
@media(prefers-reduced-motion:reduce){
  .timeline-marker svg{animation:none}
  .btn-primary:hover .btn-icon{animation:none}
  .btn-primary:hover{animation:none}
  .pricing-card:hover,.voice-card:hover,.team-card:hover,.contact-card:hover,.process-card:hover{animation:none}
  .trust-strip span:hover{transform:none}
  .hero__content .eyebrow{animation:none}
}

/* Court dash on section dividers */
.section-line{display:block;width:80px;height:2px;background:var(--accent);margin:0 auto 2rem;border-radius:2px;position:relative}
.section-line::before,.section-line::after{content:'';position:absolute;top:50%;width:6px;height:6px;border-radius:50%;background:var(--accent);transform:translateY(-50%)}
.section-line::before{left:-12px}
.section-line::after{right:-12px}

/* --- THANK YOU PAGE ----------------------------------------------- */
.thankyou{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem var(--container-pad)}
.thankyou h1{margin-bottom:1rem}
.thankyou p{color:var(--ink-soft);margin-bottom:2rem;font-size:1.1rem}

/* --- 404 PAGE ----------------------------------------------------- */
.page-404{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem var(--container-pad)}
.page-404 h1{font-size:clamp(4rem, 12vw, 4.5rem);color:var(--accent);margin-bottom:0.5rem}
.page-404 p{color:var(--ink-soft);margin-bottom:2rem;font-size:1.1rem}

/* --- SITEMAP PAGE ------------------------------------------------- */
.sitemap-content{padding:clamp(2.5rem,5vw,4rem) 0}
.sitemap-content h2{margin:2rem 0 1rem}
.sitemap-list{display:grid;gap:8px;margin-bottom:2rem}
@media(min-width:640px){.sitemap-list{grid-template-columns:repeat(2,1fr)}}
.sitemap-list a{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:0.92rem;transition:border-color 240ms ease,transform 180ms var(--ease-out)}
.sitemap-list a:hover{border-color:var(--accent);transform:translateY(-2px)}
.sitemap-list a::before{content:'→';color:var(--accent);font-weight:700}

/* --- TEAM CARDS --------------------------------------------------- */
.team-grid{display:grid;gap:clamp(1.5rem,3vw,2rem)}
@media(min-width:640px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.team-grid{grid-template-columns:repeat(3,1fr)}}
.team-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);transition:transform 400ms cubic-bezier(.16,.84,.44,1),box-shadow 400ms ease,border-color 400ms ease}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:rgba(139,77,204,0.15)}
.team-card__photo img{transition:transform 500ms cubic-bezier(.16,.84,.44,1)}
.team-card:hover .team-card__photo img{transform:scale(1.04)}
.team-card__photo{aspect-ratio:1/1;background:linear-gradient(135deg,rgba(139,77,204,0.15),rgba(232,93,117,0.1));display:flex;align-items:center;justify-content:center}
.team-card__photo img{width:100%;height:100%;object-fit:cover}
.team-card__photo .placeholder-icon{width:64px;height:64px;color:var(--accent);opacity:0.3}
.team-card__info{padding:clamp(1.2rem,2.5vw,1.6rem)}
.team-card__info h3{font-size:1.15rem;margin-bottom:0.3rem}
.team-card__info .role{font-size:0.85rem;color:var(--accent);font-weight:700;margin-bottom:0.8rem;font-style:normal;font-family:'Lato',sans-serif}
.team-card__info p{font-size:0.88rem;color:var(--ink-soft);line-height:1.6;margin-bottom:0}

/* --- CAPACITY / AVAILABILITY BADGE -------------------------------- */
.capacity-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(139,77,204,0.08);border:1px solid rgba(139,77,204,0.15);border-radius:999px;font-size:0.82rem;font-weight:700;color:var(--accent)}
.capacity-badge::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--accent);animation:capacityPulse 2s ease-in-out infinite}
@keyframes capacityPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.8)}}
@media(prefers-reduced-motion:reduce){.capacity-badge::before{animation:none}}

/* --- NEWS / UPDATES BLOCK ----------------------------------------- */
.news-block{background:var(--surface-2);border-radius:var(--radius);padding:clamp(1.2rem,3vw,1.8rem);margin-top:2rem}
.news-block h4{margin-bottom:1rem;font-size:1rem}
.news-item{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--line)}
.news-item:last-child{border-bottom:none}
.news-item .news-date{font-size:0.78rem;font-weight:700;color:var(--accent);white-space:nowrap;min-width:80px}
.news-item .news-text{font-size:0.88rem;color:var(--ink-soft)}

/* --- STAGGER HELPERS ---------------------------------------------- */
.stagger-1{--i:1}.stagger-2{--i:2}.stagger-3{--i:3}
.stagger-4{--i:4}.stagger-5{--i:5}.stagger-6{--i:6}
.stagger-7{--i:7}.stagger-8{--i:8}

/* --- FOCUS STYLES ------------------------------------------------- */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* --- RESPONSIVE --------------------------------------------------- */
@media(max-width:1024px){
  :root{--header-h:64px}
}
@media(max-width:768px){
  .story__inner{grid-template-columns:1fr}
  .story__photo{max-height:420px}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-card.is-featured{order:-1}
  section{padding:clamp(2.5rem,6vw,4rem) 0}
}
@media(max-width:640px){
  :root{--header-h:58px}
  .trust-strip{flex-direction:column;align-items:center}
  .contact-cards{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-submit .btn-primary{width:100%}
  .team-grid{grid-template-columns:1fr}
}
@media(max-width:430px){
  .hero__content h1{font-size:2.4rem}
  .btn-primary{padding:14px 28px;font-size:0.95rem}
  .pricing-card{padding:1.2rem}
  .voice-card{padding:1.2rem}
}
@media(max-width:360px){
  .hero__content h1{font-size:2.1rem}
  .stat-number{font-size:2.2rem}
}

/* --- FUTSAL MICRO-EFFECTS ----------------------------------------- */
.timeline-card::before{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 500ms cubic-bezier(.16,.84,.44,1);z-index:1}
.timeline-card:hover::before{width:100%}

.pricing-card{position:relative}
.pricing-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 500ms cubic-bezier(.16,.84,.44,1);z-index:1}
.pricing-card:hover::after{width:100%}

.voice-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 500ms cubic-bezier(.16,.84,.44,1);z-index:1}
.voice-card:hover::after{width:100%}

.contact-card{position:relative}
.contact-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 500ms cubic-bezier(.16,.84,.44,1);z-index:1}
.contact-card:hover::after{width:100%}

.process-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 500ms cubic-bezier(.16,.84,.44,1);z-index:1}
.process-card:hover::after{width:100%}

.team-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 500ms cubic-bezier(.16,.84,.44,1);z-index:1}
.team-card:hover::after{width:100%}

.faq-item summary:hover .faq-chevron{color:var(--accent-2)}
.faq-item[open] summary .faq-chevron{color:var(--accent-2)}

.footer-col a:not(.logo){position:relative}
.footer-col a:not(.logo)::after{content:'';position:absolute;bottom:2px;left:0;width:0;height:1px;background:var(--accent);transition:width 300ms cubic-bezier(.16,.84,.44,1)}
.footer-col a:not(.logo):hover::after{width:100%}
.footer-contact-item a::after{content:'';position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width 300ms cubic-bezier(.16,.84,.44,1)}
.footer-contact-item a{position:relative}
.footer-contact-item a:hover::after{width:100%}

.trust-strip span::before{transition:transform 400ms cubic-bezier(.16,.84,.44,1)}
.trust-strip span:hover::before{transform:scale(1.5)}

@keyframes courtLineGlow{
  0%,100%{opacity:0.35}
  50%{opacity:0.6}
}
.court-divider.is-in{animation:courtLineGlow 4s ease-in-out infinite}

/* --- FUTSAL COURT GLOW ON STAT ITEMS ------------------------------ */
.stat-item{position:relative;transition:transform 400ms cubic-bezier(.16,.84,.44,1)}
.stat-item:hover{transform:translateY(-4px)}
.stat-item::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:2px;background:var(--accent);transition:width 500ms cubic-bezier(.16,.84,.44,1),left 500ms cubic-bezier(.16,.84,.44,1);border-radius:1px}
.stat-item:hover::after{width:60%;left:20%}

/* --- SCORE-FLASH ON STAT COUNTER ---------------------------------- */
@keyframes scoreFlash{0%{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 24px rgba(139,77,204,0.45)}100%{text-shadow:0 0 0 transparent}}
.stat-number.is-counting{animation:scoreFlash 1.8s ease-out}

/* --- IMPROVED CARD ENTRANCE STAGGER ------------------------------- */
.pricing-card{transition:transform 500ms cubic-bezier(.16,.84,.44,1),box-shadow 500ms ease,border-color 500ms ease}
.voice-card{transition:transform 500ms cubic-bezier(.16,.84,.44,1),box-shadow 500ms ease,border-color 500ms ease}
.timeline-card{transition:transform 500ms cubic-bezier(.16,.84,.44,1),box-shadow 500ms ease,border-color 500ms ease}
.team-card{transition:transform 500ms cubic-bezier(.16,.84,.44,1),box-shadow 500ms ease,border-color 500ms ease}
.contact-card{transition:transform 500ms cubic-bezier(.16,.84,.44,1),box-shadow 500ms ease,border-color 500ms ease}

/* --- WHISTLE LINE ON FAQ OPEN ------------------------------------- */
.faq-item[open]{border-bottom-color:var(--accent)}
.faq-item[open]>summary{color:var(--accent);border-left:3px solid var(--accent);padding-left:12px}

/* --- REDUCED MOTION EXTRAS ---------------------------------------- */
@media(prefers-reduced-motion:reduce){
  .btn-primary::after{display:none}
  .team-card__photo img{transition:none}
  .process-card__icon{transition:none}
  .faq-item[open] summary{padding-left:0;border-left:none}
  .contact-card__icon{transition:none}
  .story__photo img{transition:none}
  .timeline-card::before,.pricing-card::after,.voice-card::after,.contact-card::after,.process-card::after,.team-card::after{transition:none}
  .footer-col a::after,.footer-contact-item a::after{transition:none}
  .trust-strip span::before{transition:none}
  .court-divider.is-in{animation:none}
  .stat-item{transition:none}
  .stat-item::after{transition:none}
  .stat-number.is-counting{animation:none}
  .hero .reveal[style*="--i"]{animation:none}
  .hero .mask-reveal{animation:none;clip-path:none}
  .reveal-left,.reveal-right{transition:none}
}

/* --- PRINT -------------------------------------------------------- */
@media print{
  .site-header,.drawer,.drawer-backdrop,.cookie-banner,.nav-toggle,.skip-link,.court-divider{display:none!important}
  body{background:#fff;color:#000;font-size:11pt}
  main{padding-top:0}
  section{padding:1.5rem 0;page-break-inside:avoid}
  .hero{min-height:auto;background:none;color:#000}
  .hero__bg,.hero__overlay{display:none}
  .hero__content h1,.hero__content .eyebrow,.hero__content p{color:#000}
  .reveal{opacity:1!important;transform:none!important}
  .mask-reveal{clip-path:none!important}
  a{text-decoration:underline}
  .btn-primary,.btn-ghost{border:1px solid #000;background:none;color:#000}
}

.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}

/* iletisim-form-responsive-guard v2 */
main form, .form-section form, .contact-form, .iletisim-form, form#contact-form, form[id*="iletisim"], form[class*="iletisim"], form[class*="contact"] {
  display: block;
  max-width: 720px;
  margin: 24px auto;
  padding: clamp(20px, 4vw, 36px);
  background: var(--surface, rgba(255,255,255,0.04));
  border: 1px solid var(--line, rgba(127,127,127,0.18));
  border-radius: 16px;
  box-shadow: 0 8px 32px -12px rgba(0,0,0,0.25);
  box-sizing: border-box;
}
main form .form-grid,
main form > .grid,
.contact-form .form-grid,
form[class*="contact"] .form-grid,
form[class*="iletisim"] .form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 18px;
  width: 100%;
}
@media (max-width: 640px) {
  main form .form-grid,
  main form > .grid,
  .contact-form .form-grid,
  form[class*="contact"] .form-grid,
  form[class*="iletisim"] .form-grid {
    grid-template-columns: 1fr;
  }
}
main form .form-grid > .field-full,
main form .form-grid > .col-full,
main form .form-grid > [class*="full"] {
  grid-column: 1 / -1;
}
main form .field, main form label,
.contact-form .field, .contact-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
}
main form input[type="text"],
main form input[type="email"],
main form input[type="tel"],
main form input[type="number"],
main form input[type="date"],
main form input[type="url"],
main form input[type="search"],
main form input:not([type]),
main form select,
main form textarea,
.contact-form input:not([type=checkbox]):not([type=radio]):not([type=submit]):not([type=hidden]),
.contact-form select,
.contact-form textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 12px 14px;
  min-height: 44px;
  font-size: 16px;
  line-height: 1.4;
  font-family: inherit;
  border: 1px solid var(--line, rgba(127,127,127,0.22));
  border-radius: 10px;
  background: var(--input-bg, rgba(0,0,0,0.04));
  color: inherit;
  appearance: none;
  -webkit-appearance: none;
}
main form textarea, .contact-form textarea {
  min-height: 120px;
  resize: vertical;
}
main form input:focus, main form select:focus, main form textarea:focus,
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus {
  outline: 2px solid var(--accent, #5a8dee);
  outline-offset: 1px;
  border-color: transparent;
}
main form .checkbox, main form label.checkbox,
.contact-form .checkbox {
  flex-direction: row;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.5;
}
main form input[type="checkbox"], main form input[type="radio"],
.contact-form input[type="checkbox"], .contact-form input[type="radio"] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  margin-top: 2px;
  flex-shrink: 0;
  accent-color: var(--accent, #5a8dee);
}
main form button[type="submit"],
main form input[type="submit"],
main form .btn-submit,
.contact-form button[type="submit"],
.contact-form .btn-submit {
  width: 100%;
  min-height: 48px;
  padding: 14px 28px;
  background: var(--accent, #5a8dee);
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  margin-top: 8px;
  transition: filter 200ms ease, transform 120ms ease;
}
@media (min-width: 640px) {
  main form button[type="submit"],
  main form input[type="submit"],
  .contact-form button[type="submit"] {
    width: auto;
    min-width: 220px;
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
}
main form button[type="submit"]:hover,
.contact-form button[type="submit"]:hover {
  filter: brightness(1.05);
}
main form button[type="submit"]:active,
.contact-form button[type="submit"]:active {
  transform: translateY(1px);
}


/* honeypot-hide */
.form-honeypot, input[name="web_site"], input[name="honeypot"], input[name="hp_url"], input[name="trap"], input[aria-hidden="true"][tabindex="-1"] {
  position: absolute !important;
  left: -10000px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* form-reveal-opacity-fix */
main form.reveal, .form-section form.reveal, .contact-form.reveal, form[id*='iletisim'].reveal, form[class*='contact'].reveal { opacity: 1 !important; transform: none !important; translate: none !important; }
main form, .form-section form, .contact-form, form[id*='iletisim'], form[class*='contact'] { opacity: 1 !important; }

/* consent-checkbox-inline-fix */
main form label.checkbox, main form .form-checkbox, main form .consent, main form .kvkk, .contact-form label.checkbox, .contact-form .checkbox-group { display: flex !important; flex-direction: row !important; align-items: flex-start !important; gap: 10px !important; font-size: 14px !important; line-height: 1.5 !important; flex-wrap: nowrap !important; }
main form label.checkbox span, main form label.checkbox a, main form .form-checkbox span, main form .form-checkbox a, .contact-form label.checkbox span, .contact-form label.checkbox a { display: inline !important; flex: 1 1 auto; }
main form label.checkbox input[type='checkbox'], main form .form-checkbox input[type='checkbox'] { flex-shrink: 0 !important; width: 18px !important; height: 18px !important; margin-top: 3px !important; }


/* contacts-grid-v2 */
/* Contact cards in responsive grid */
.contact-grid, .contacts-grid, .iletisim-grid, .contact-cards, .contact-cards-grid,
.contact-list, main .contact-wrap, section[id*="iletisim"] > .container > div:has(> .contact-card) {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 20px !important;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 8px 16px;
  box-sizing: border-box;
}
@media (min-width: 1024px) {
  .contact-grid, .contacts-grid, .iletisim-grid, .contact-cards, .contact-cards-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 720px) {
  .contact-grid, .contacts-grid, .iletisim-grid, .contact-cards, .contact-cards-grid {
    grid-template-columns: 1fr !important;
  }
}
.contact-card { min-height: 0; box-sizing: border-box; }

/* Checkbox row alignment — override .field-checkbox column layout */
form .field.field-checkbox,
form .field-checkbox,
form .checkbox-field,
form .form-field--checkbox,
form .form-row--checkbox,
form .kvkk-field,
form .consent-field,
.contact-form .field.field-checkbox {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: flex-start !important;
  gap: 10px !important;
  width: 100%;
}
form .field.field-checkbox > input[type="checkbox"],
form .field-checkbox > input[type="checkbox"],
form .checkbox-field > input[type="checkbox"],
form .kvkk-field > input[type="checkbox"],
form .consent-field > input[type="checkbox"] {
  flex-shrink: 0 !important;
  width: 18px !important;
  height: 18px !important;
  margin: 3px 0 0 0 !important;
  accent-color: var(--accent, currentColor);
}
form .field.field-checkbox > label,
form .field-checkbox > label,
form .checkbox-field > label,
form .kvkk-field > label,
form .consent-field > label {
  flex: 1 1 auto !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
  margin: 0 !important;
  display: inline !important;
  cursor: pointer;
}
form .field.field-checkbox > label a,
form .field-checkbox > label a {
  text-decoration: underline;
}

/* field-full inside form grid spans both columns */
form .form-grid > .field-full,
form .form-grid > .field.field-full,
form .form-grid > .col-full,
form .form-grid > .full,
form .form-grid > [class*="--full"] {
  grid-column: 1 / -1;
}

