/* ============================================================
   TopKontrol Futsal Akademi — Styles
   ============================================================ */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;interpolate-size:allow-keywords}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html,body{overflow-x:hidden;max-width:100vw;margin:0}
body{font-family:'Nunito Sans',system-ui,sans-serif;font-weight:400;color:var(--ink);background:var(--bg);line-height:1.65;letter-spacing:-0.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button,input,select,textarea{font:inherit;color:inherit;border:none;background:none}
button{cursor:pointer}

/* --- CSS Variables --- */
:root{
  --bg:#FFFFFF;
  --surface:#F2F6FF;
  --surface-2:#E4EAF5;
  --ink:#1A1A2E;
  --ink-soft:#5A5A72;
  --accent:#E63946;
  --accent-2:#457B9D;
  --accent-glow:rgba(230,57,70,0.18);
  --accent2-glow:rgba(69,123,157,0.18);
  --line:#D1D9E6;
  --line-strong:#A8B5C8;
  --header-h:72px;
  --radius:12px;
  --radius-sm:8px;
  --radius-lg:18px;
  --shadow-sm:0 2px 8px rgba(26,26,46,0.06);
  --shadow-md:0 8px 24px -8px rgba(26,26,46,0.1);
  --shadow-lg:0 16px 48px -12px rgba(26,26,46,0.14);
  --shadow-accent:0 8px 24px -8px rgba(230,57,70,0.22);
  --container-max:1240px;
  --container-pad:clamp(16px,4vw,32px);
  --transition:240ms cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.2,.7,.2,1);
  --ease-std:cubic-bezier(.4,0,.2,1);
}

/* --- Skip Link --- */
.skip-link{position:absolute;top:-100px;left:16px;background:var(--accent);color:#fff;padding:8px 18px;border-radius:var(--radius-sm);z-index:10000;font-weight:600;transition:top .2s}
.skip-link:focus{top:8px}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:'Outfit',system-ui,sans-serif;font-weight:600;line-height:1.15;letter-spacing:-0.012em;color:var(--ink)}
h1{font-size:clamp(2.4rem, 6vw, 4.2rem);font-weight:700}
h2{font-size:clamp(1.8rem,4vw,2.8rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.7rem)}
h4{font-size:clamp(1.1rem,2vw,1.3rem)}
.eyebrow{font-family:'Outfit',system-ui,sans-serif;font-size:.82rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.text-accent{color:var(--accent)}
.text-accent2{color:var(--accent-2)}
p{max-width:68ch}

/* --- Container --- */
.container{width:100%;max-width:var(--container-max);margin:0 auto;padding-inline:var(--container-pad)}
.container-narrow,.prose{max-width:760px}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:var(--radius-sm);font-family:'Outfit',system-ui,sans-serif;font-weight:600;font-size:.95rem;letter-spacing:.02em;transition:all var(--transition);min-height:48px;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}
.btn-primary:hover,.btn-primary:focus-visible{background:#c62b38;color:#fff;transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(230,57,70,0.32)}
.btn-primary:active{transform:translateY(0)}
.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-2)}
.btn-secondary{background:var(--accent-2);color:#fff}
.btn-secondary:hover,.btn-secondary:focus-visible{background:#366a87;color:#fff;transform:translateY(-2px)}
.btn svg{width:18px;height:18px;flex-shrink:0}

/* --- Focus Ring --- */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

/* ============================================================
   HEADER (sticky-with-morph)
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1080;background:rgba(255, 255, 255, 0.92);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:background var(--transition),box-shadow var(--transition),padding var(--transition)}
.site-header.scrolled{background:rgba(255,255,255,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);max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad)}
.logo{display:flex;align-items:center;gap:10px;font-family:'Outfit',system-ui,sans-serif;font-weight:700;font-size:1.2rem;color:var(--ink);z-index:1100;letter-spacing:-0.02em}
.logo svg{width:36px;height:36px;flex-shrink:0}
.logo span:last-child{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:.9rem;font-weight:600;color:var(--ink-soft);transition:color var(--transition);padding:4px 0}
.nav-desktop a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent);border-radius:1px;transition:width 360ms cubic-bezier(.22,.61,.36,1)}
.nav-desktop a:hover,.nav-desktop a.is-active{color:var(--ink)}
.nav-desktop a.is-active::after,.nav-desktop a:hover::after{width:100%}
.nav-desktop .nav-cta{background:var(--accent);color:#fff;padding:10px 22px;border-radius:var(--radius-sm);font-weight:600;font-size:.88rem}
.nav-desktop .nav-cta::after{display:none}
.nav-desktop .nav-cta:hover{background:#c62b38;color:#fff;box-shadow:0 4px 16px -4px rgba(230,57,70,0.4)}
.nav-desktop .nav-cta.is-active{color:#fff}

/* Hamburger Toggle */
.nav-toggle{display:flex;flex-direction:column;justify-content:center;align-items:center;width:46px;height:46px;background:#fff;border:2px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;z-index:1100;gap:5px;padding:0;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);box-shadow:0 2px 8px rgba(230,57,70,0.10)}
.nav-toggle:hover{background:var(--accent);border-color:var(--accent);box-shadow:0 4px 16px rgba(230,57,70,0.25)}
.nav-toggle:hover span{background:#fff}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-toggle span{display:block;width:22px;height:2.5px;background:var(--accent);border-radius:2px;transition:transform 320ms var(--ease-out),opacity 240ms,background 240ms}
.nav-toggle[aria-expanded="true"]{background:var(--accent);border-color:var(--accent)}
.nav-toggle[aria-expanded="true"] span{background:#fff}
.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)}

/* ============================================================
   MOBILE DRAWER (outside header)
   ============================================================ */
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.55);opacity:0;pointer-events:none;z-index:1040;transition:opacity 240ms}
.drawer-backdrop.is-open{opacity:1;pointer-events:auto}

.drawer{position:fixed;top:0;right:0;bottom:0;width:min(360px,92vw);background:var(--bg);z-index:1050;transform:translateX(100%);transition:transform 320ms var(--ease-out);padding:calc(var(--header-h) + 24px) 28px 40px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}
.drawer.is-open{transform:translateX(0)}
.drawer a{display:block;padding:14px 16px;font-family:'Outfit',system-ui,sans-serif;font-size:1.05rem;font-weight:600;color:var(--ink);border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition)}
.drawer a:hover,.drawer a.is-active{background:var(--surface);color:var(--accent)}
.drawer .drawer-cta{display:inline-flex;align-items:center;justify-content:center;margin-top:16px;background:var(--accent);color:#fff;padding:14px 24px;border-radius:var(--radius-sm);font-weight:600;text-align:center}
.drawer .drawer-cta:hover{background:#c62b38;color:#fff;box-shadow:0 4px 16px -4px rgba(230,57,70,0.4)}

/* ============================================================
   MAIN — compensate fixed header
   ============================================================ */
main{padding-top:var(--header-h)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:clamp(60px,10vw,100px) 0 clamp(48px,8vw,80px);overflow:hidden;background:var(--bg)}
.hero .container{display:grid;gap:48px;align-items:center}
@media(min-width:1024px){.hero .container{grid-template-columns:1fr 1fr;gap:64px}}
.hero-content{position:relative;z-index:2}
.hero h1{margin:16px 0 20px}
.hero h1 .char{display:inline-block;opacity:0;transform:translateY(18px);animation:charIn 400ms var(--ease-out) forwards}
@keyframes charIn{to{opacity:1;transform:none}}
.hero-sub{font-size:clamp(1rem,2vw,1.15rem);color:var(--ink-soft);max-width:48ch;margin-bottom:32px;line-height:1.7}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface);border:1px solid var(--line);border-radius:999px;font-size:.82rem;font-weight:600;color:var(--ink);transition:transform 300ms var(--ease-out),box-shadow 300ms,background 300ms}
.hero-badge:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);background:var(--surface-2)}
.hero-badge svg{width:16px;height:16px;color:var(--accent)}
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}

/* Futsal Court SVG */
.court-svg{width:100%;max-width:480px;filter:drop-shadow(0 12px 32px rgba(69,123,157,0.12))}
.court-line{stroke:var(--accent-2);stroke-width:2;fill:none;opacity:.75}
.court-fill{fill:rgba(69,123,157,0.06);stroke:var(--accent-2);stroke-width:1.5;opacity:.9}
.court-center{fill:none;stroke:var(--accent-2);stroke-width:1.5;opacity:.6}
.position-dot{r:8;fill:var(--line);stroke:#fff;stroke-width:2;transition:fill 400ms var(--ease-out),r 400ms var(--ease-out),filter 400ms;cursor:default}
.position-dot.active{fill:var(--accent);r:10;filter:drop-shadow(0 0 8px rgba(230,57,70,0.5))}
.position-dot.active-secondary{fill:var(--accent-2);r:9;filter:drop-shadow(0 0 6px rgba(69,123,157,0.4))}
.position-label{font-family:'Outfit',system-ui,sans-serif;font-size:9px;fill:var(--ink-soft);text-anchor:middle;opacity:0;transition:opacity 500ms var(--ease-out)}
.position-dot.active~.position-label,.position-dot.active-secondary~.position-label{opacity:1}
.court-connection{stroke:var(--accent);stroke-width:1;stroke-dasharray:4 4;opacity:0;transition:opacity 600ms}
.court-connection.visible{opacity:.4}

@keyframes courtPulse{0%,100%{filter:drop-shadow(0 0 6px rgba(230,57,70,0.3))}50%{filter:drop-shadow(0 0 14px rgba(230,57,70,0.55))}}
.position-dot.active.pulse{animation:courtPulse 2s ease-in-out infinite}

/* Hero parallax layer */
.hero-decor{position:absolute;right:-5%;top:10%;width:40%;opacity:.06;z-index:0;pointer-events:none}

/* Stats Counter Row */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:clamp(32px,5vw,56px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg)}
@media(max-width:640px){.stats-row{grid-template-columns:repeat(2,1fr);gap:24px}}
.stat-item{text-align:center;padding:12px 8px}
.stat-num{font-family:'Outfit',system-ui,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--accent);line-height:1;margin-bottom:6px}
.stat-label{font-size:.85rem;color:var(--ink-soft);font-weight:600}

/* ============================================================
   INTERACTIVE TOOL (#arac)
   ============================================================ */
.arac{padding:clamp(64px,10vw,100px) 0;background:var(--surface)}
.arac-header{text-align:center;margin-bottom:48px}
.arac-header p{margin:12px auto 0;color:var(--ink-soft);max-width:52ch}

.tool-wrapper{max-width:880px;margin:0 auto;background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--line);box-shadow:var(--shadow-lg);overflow:hidden}

/* Step indicator */
.step-indicator{display:flex;align-items:center;padding:20px 28px;border-bottom:1px solid var(--line);gap:8px}
.step-dot{width:32px;height:32px;border-radius:50%;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:'Outfit',system-ui,sans-serif;font-size:.8rem;font-weight:700;color:var(--ink-soft);transition:all 360ms var(--ease-out)}
.step-dot.active{background:var(--accent);border-color:var(--accent);color:#fff}
.step-dot.done{background:var(--accent-2);border-color:var(--accent-2);color:#fff}
.step-line{flex:1;height:2px;background:var(--line);border-radius:1px;position:relative}
.step-line::after{content:'';position:absolute;left:0;top:0;height:100%;background:var(--accent-2);border-radius:1px;width:0;transition:width 400ms var(--ease-out)}
.step-line.filled::after{width:100%}

/* Step panels */
.tool-body{position:relative;min-height:320px;overflow:hidden}
.step-panel{padding:32px 28px;opacity:0;transform:translateX(40px);transition:opacity 360ms var(--ease-out),transform 360ms var(--ease-out);position:absolute;top:0;left:0;right:0;pointer-events:none}
.step-panel.active{opacity:1;transform:none;position:relative;pointer-events:auto}
.step-panel.exit-left{transform:translateX(-40px);opacity:0}

.step-panel h3{margin-bottom:8px}
.step-panel .step-desc{color:var(--ink-soft);margin-bottom:24px;font-size:.95rem}

/* Option cards */
.option-grid{display:grid;gap:14px}
@media(min-width:640px){.option-grid{grid-template-columns:repeat(3,1fr)}}
.option-card{position:relative;padding:20px;border:2px solid var(--line);border-radius:var(--radius);cursor:pointer;transition:all 280ms var(--ease-out);text-align:center;background:var(--bg)}
.option-card:hover{border-color:var(--accent-2);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.option-card.selected{border-color:var(--accent);background:rgba(230,57,70,0.04);box-shadow:var(--shadow-accent)}
.option-card input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.option-icon{width:48px;height:48px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:50%;color:var(--accent-2);transition:background 280ms,color 280ms}
.option-card.selected .option-icon{background:var(--accent);color:#fff}
.option-icon svg{width:24px;height:24px}
.option-card h4{font-size:1rem;margin-bottom:4px}
.option-card p{font-size:.82rem;color:var(--ink-soft);line-height:1.55}

/* Availability step */
.avail-options{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:480px){.avail-options{grid-template-columns:repeat(2,1fr)}}
.avail-btn{padding:16px 12px;border:2px solid var(--line);border-radius:var(--radius-sm);text-align:center;cursor:pointer;transition:all 280ms var(--ease-out);font-family:'Outfit',system-ui,sans-serif;font-weight:600;font-size:1.1rem;color:var(--ink)}
.avail-btn:hover{border-color:var(--accent-2)}
.avail-btn.selected{border-color:var(--accent);background:var(--accent);color:#fff}
.avail-btn small{display:block;font-weight:400;font-size:.78rem;color:var(--ink-soft);margin-top:2px}
.avail-btn.selected small{color:rgba(255,255,255,0.8)}

/* Step navigation */
.step-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 28px;border-top:1px solid var(--line)}
.step-nav .btn{min-width:120px}

/* Result card */
.result-card{padding:36px 28px;text-align:center;opacity:0;transform:scale(0.92) translateY(20px);transition:opacity 500ms var(--ease-out),transform 500ms var(--ease-out)}
.result-card.show{opacity:1;transform:none}
@keyframes resultBounce{0%{transform:scale(0.85) translateY(30px);opacity:0}60%{transform:scale(1.03) translateY(-4px);opacity:1}100%{transform:none;opacity:1}}
.result-card.bounce{animation:resultBounce 600ms var(--ease-out) forwards}
.result-icon{width:64px;height:64px;margin:0 auto 16px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}
.result-icon svg{width:32px;height:32px}
.result-card h3{font-size:1.5rem;margin-bottom:8px}
.result-card .result-tier{display:inline-block;padding:6px 18px;background:var(--accent);color:#fff;border-radius:999px;font-family:'Outfit',system-ui,sans-serif;font-weight:700;font-size:.9rem;margin-bottom:16px}
.result-details{display:grid;gap:8px;max-width:400px;margin:0 auto 24px;text-align:left}
.result-detail{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border-radius:var(--radius-sm);font-size:.9rem}
.result-detail svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}
.result-card .result-price{font-family:'Outfit',system-ui,sans-serif;font-size:1.8rem;font-weight:700;color:var(--ink);margin:16px 0 8px}
.result-card .result-price small{font-size:.7em;font-weight:400;color:var(--ink-soft)}
.result-card .result-note{font-size:.78rem;color:var(--ink-soft);margin-bottom:24px}

/* ============================================================
   PROGRAMS / PRICING (#programlar)
   ============================================================ */
.programlar{padding:clamp(64px,10vw,100px) 0;background:var(--bg)}
.programlar-header{text-align:center;margin-bottom:48px}
.programlar-header p{margin:12px auto 0;color:var(--ink-soft);max-width:52ch}

.program-grid{display:grid;gap:24px}
@media(min-width:768px){.program-grid{grid-template-columns:repeat(2,1fr)}}

.program-card{background:var(--bg);border:1.5px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;transition:transform 400ms cubic-bezier(.2,.7,.2,1),box-shadow 400ms cubic-bezier(.2,.7,.2,1),border-color 400ms;position:relative;overflow:hidden}
.program-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--accent-2)}
.program-card.featured{border-color:var(--accent);box-shadow:var(--shadow-accent)}
.program-card.featured:hover{border-color:var(--accent)}
.program-card.featured::before{content:'Popüler';position:absolute;top:16px;right:-28px;background:var(--accent);color:#fff;font-family:'Outfit',system-ui,sans-serif;font-size:.72rem;font-weight:700;padding:4px 36px;transform:rotate(45deg);letter-spacing:.04em}
.program-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.program-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:var(--radius-sm);color:var(--accent-2)}
.program-card.featured .program-card-icon{background:rgba(230,57,70,0.08);color:var(--accent)}
.program-card-icon svg{width:24px;height:24px}
.program-card h3{font-size:1.2rem;margin-bottom:4px}
.program-sessions{font-size:.85rem;color:var(--ink-soft);margin-bottom:16px}
.program-price{font-family:'Outfit',system-ui,sans-serif;font-size:2rem;font-weight:700;color:var(--ink);margin-bottom:4px}
.program-price small{font-size:.45em;font-weight:400;color:var(--ink-soft)}
.program-note{font-size:.75rem;color:var(--ink-soft);margin-bottom:20px}
.program-includes h4{font-size:.82rem;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.program-list{display:grid;gap:6px}
.program-list li{display:flex;align-items:flex-start;gap:8px;font-size:.88rem;line-height:1.5}
.program-list li svg{width:16px;height:16px;flex-shrink:0;margin-top:3px}
.program-list .incl svg{color:var(--accent)}
.program-list .excl{color:var(--ink-soft)}
.program-list .excl svg{color:var(--line-strong)}
.program-disclaimer{text-align:center;margin-top:24px;font-size:.78rem;color:var(--ink-soft);font-style:italic}

/* ============================================================
   HOW IT WORKS (#nasil)
   ============================================================ */
.nasil{padding:clamp(64px,10vw,100px) 0;background:var(--surface)}
.nasil-header{text-align:center;margin-bottom:56px}
.nasil-header p{margin:12px auto 0;color:var(--ink-soft);max-width:52ch}

.steps-timeline{position:relative;display:grid;gap:0;max-width:720px;margin:0 auto}
.steps-timeline::before{content:'';position:absolute;left:24px;top:28px;bottom:28px;width:2px;background:var(--line);border-radius:1px}
@media(min-width:768px){.steps-timeline::before{left:50%;transform:translateX(-1px)}}

.timeline-step{position:relative;display:grid;grid-template-columns:48px 1fr;gap:20px;padding:24px 0;align-items:start}
@media(min-width:768px){
  .timeline-step{grid-template-columns:1fr 48px 1fr}
  .timeline-step .step-marker{grid-column:2;grid-row:1}
  .timeline-step .step-content{grid-column:1;grid-row:1;text-align:right}
  .timeline-step:nth-child(even) .step-content{grid-column:3;text-align:left}
}
.step-marker{width:48px;height:48px;background:var(--bg);border:2px solid var(--accent-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Outfit',system-ui,sans-serif;font-weight:700;font-size:1rem;color:var(--accent-2);z-index:2;transition:all 400ms var(--ease-out)}
.timeline-step:hover .step-marker{background:var(--accent-2);color:#fff;transform:scale(1.1)}
.step-content h4{font-size:1.05rem;margin-bottom:4px}
.step-content .step-time{font-size:.78rem;color:var(--accent);font-weight:600;margin-bottom:6px;display:inline-block}
.step-content p{font-size:.9rem;color:var(--ink-soft);line-height:1.6}

/* ============================================================
   TESTIMONIALS (#referanslar)
   ============================================================ */
.referanslar{padding:clamp(64px,10vw,100px) 0;background:var(--bg)}
.referanslar-header{text-align:center;margin-bottom:48px}
.referanslar-header p{margin:12px auto 0;color:var(--ink-soft)}

.testimonial-grid{display:grid;gap:24px}
@media(min-width:768px){.testimonial-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.testimonial-grid{grid-template-columns:repeat(3,1fr)}}

.testimonial-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;transition:transform 360ms var(--ease-out),box-shadow 360ms var(--ease-out);position:relative}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testimonial-card::before{content:'\201C';position:absolute;top:12px;right:20px;font-family:Georgia,serif;font-size:3.5rem;color:var(--accent);opacity:.15;line-height:1}
.testimonial-text{font-size:.92rem;line-height:1.7;color:var(--ink);margin-bottom:16px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:14px}
.testimonial-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-2);display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Outfit',system-ui,sans-serif;font-weight:700;font-size:.9rem;flex-shrink:0}
.testimonial-meta strong{display:block;font-size:.88rem}
.testimonial-meta span{font-size:.78rem;color:var(--ink-soft)}

/* ============================================================
   FAQ (#sss)
   ============================================================ */
.sss{padding:clamp(64px,10vw,100px) 0;background:var(--surface)}
.sss-header{text-align:center;margin-bottom:48px}
.sss-header p{margin:12px auto 0;color:var(--ink-soft)}

.faq-list{max-width:760px;margin:0 auto;display:grid;gap:12px}
.faq-item{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color 280ms,box-shadow 280ms}
.faq-item[open]{border-color:var(--accent-2);box-shadow:0 4px 16px -4px var(--accent2-glow)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;cursor:pointer;font-family:'Outfit',system-ui,sans-serif;font-weight:600;font-size:.98rem;color:var(--ink);list-style:none;gap:12px;transition:color 280ms}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none}
.faq-item summary:hover{color:var(--accent)}
.faq-item summary .faq-chevron{width:20px;height:20px;flex-shrink:0;transition:transform 360ms var(--ease-std);color:var(--ink-soft)}
.faq-item[open] summary .faq-chevron{transform:rotate(180deg);color:var(--accent)}
.faq-item .faq-body{height:0;padding:0 22px;overflow:hidden;transition:height 360ms var(--ease-std),padding-block-end 360ms var(--ease-std)}
.faq-item[open] .faq-body{height:auto;padding-block-end:22px}
@media(prefers-reduced-motion:reduce){.faq-item .faq-body{transition:none}}
.faq-body p{font-size:.9rem;color:var(--ink-soft);line-height:1.7}

/* ============================================================
   CTA + CONTACT FORM (#basla)
   ============================================================ */
.basla{padding:clamp(64px,10vw,100px) 0;background:var(--bg);position:relative}
.basla::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%);pointer-events:none}
.basla .container{position:relative;z-index:1}
.basla-inner{display:grid;gap:48px;align-items:start}
@media(min-width:768px){.basla-inner{grid-template-columns:1fr 1fr}}

.basla-content h2{margin-bottom:12px}
.basla-content p{color:var(--ink-soft);margin-bottom:24px;max-width:44ch}
.basla-content .contact-quick{display:grid;gap:14px}
.contact-quick-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border-radius:var(--radius-sm);transition:transform 280ms var(--ease-out),box-shadow 280ms}
.contact-quick-item:hover{transform:translateX(6px);box-shadow:var(--shadow-sm)}
.contact-quick-item svg{width:20px;height:20px;color:var(--accent);flex-shrink:0}
.contact-quick-item a{font-size:.9rem;color:var(--ink);font-weight:600}
.contact-quick-item span{font-size:.9rem;color:var(--ink)}
.contact-quick-item small{display:block;font-size:.78rem;color:var(--ink-soft);font-weight:400}

/* CTA block */
.basla-cta{background:var(--surface);border-radius:var(--radius-lg);padding:36px 32px;border:1px solid var(--line);box-shadow:var(--shadow-md)}
.basla-cta h3{margin-bottom:10px}
.basla-cta p{color:var(--ink-soft);margin-bottom:24px}

/* Form Styles */
.form-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;box-shadow:var(--shadow-md)}
.form-card h3{margin-bottom:20px;font-size:1.2rem}
.form-row{display:grid;gap:16px;margin-bottom:16px}
@media(min-width:480px){.form-row.two-col{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.82rem;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;padding:12px 16px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);font-size:.92rem;transition:border-color 240ms,box-shadow 240ms}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent-2);box-shadow:0 0 0 3px rgba(69,123,157,0.12);outline:none}
.field textarea{min-height:100px;resize:vertical}
.field select{appearance:auto;cursor:pointer}
.field-checkbox{display:flex;align-items:flex-start;gap:10px;padding:4px 0}
.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 label{font-size:.82rem;color:var(--ink-soft);line-height:1.5;cursor:pointer}
.honeypot{position:absolute;left:-9999px;opacity:0}
.form-card .btn{width:100%;margin-top:8px}
@media(min-width:768px){.form-card .btn{width:auto}}

/* ============================================================
   NEWS / UPDATES (#bulten)
   ============================================================ */
.bulten{padding:clamp(48px,8vw,72px) 0;background:var(--surface);border-top:1px solid var(--line)}
.bulten-header{margin-bottom:28px}
.bulten-header h3{font-size:1.15rem}
.news-list{display:grid;gap:12px;max-width:640px}
.news-item{display:grid;grid-template-columns:auto 1fr;gap:14px;padding:14px 18px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--line);align-items:center;transition:transform 280ms var(--ease-out),box-shadow 280ms,border-color 280ms}
.news-item:hover{transform:translateX(6px);box-shadow:var(--shadow-sm);border-color:var(--accent)}
.news-date{font-family:'Outfit',system-ui,sans-serif;font-size:.78rem;font-weight:700;color:var(--accent);white-space:nowrap;min-width:100px}
.news-text{font-size:.88rem;color:var(--ink)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:rgba(255,255,255,0.7);padding:clamp(48px,8vw,72px) 0 0}
.footer-grid{display:grid;gap:36px;margin-bottom:40px}
@media(min-width:768px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr}}
.footer-brand{max-width:320px}
.footer-brand .logo{color:#fff;margin-bottom:12px}
.footer-brand .logo span:last-child{color:var(--accent)}
.footer-brand p{font-size:.85rem;line-height:1.7;color:rgba(255,255,255,0.55)}
.footer-col h4{color:#fff;font-size:.88rem;margin-bottom:14px;text-transform:uppercase;letter-spacing:.1em}
.footer-col a{display:block;font-size:.85rem;padding:4px 0;transition:color 240ms;color:rgba(255,255,255,0.6)}
.footer-col a:hover{color:var(--accent)}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:.85rem}
.footer-contact-item svg{width:16px;height:16px;flex-shrink:0;margin-top:3px;color:var(--accent)}
.footer-contact-item a{display:inline;padding:0}
.footer-contact-item a:hover{color:var(--accent)}
.footer-hours{font-size:.82rem;color:rgba(255,255,255,0.5)}
.footer-hours dt{color:rgba(255,255,255,0.7);font-weight:600;float:left;clear:left;min-width:36px}
.footer-hours dd{margin-left:44px;margin-bottom:2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding:20px 0;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center;font-size:.78rem}
.footer-bottom a{transition:color 240ms}
.footer-bottom a:hover{color:var(--accent)}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 20px}
.footer-vkn{color:rgba(255,255,255,0.35);font-size:.72rem}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:520px;margin:0 auto;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-lg);z-index:9999;transform:translateY(140%);opacity:0;transition:transform 280ms var(--ease-out),opacity 240ms}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
@media(min-width:768px){.cookie-banner{left:24px;right:auto;max-width:420px}}
.cookie-banner h4{font-size:.92rem;margin-bottom:6px}
.cookie-banner p{font-size:.8rem;color:var(--ink-soft);line-height:1.6;margin-bottom:14px}
.cookie-buttons{display:flex;gap:8px;flex-wrap:wrap}
.cookie-buttons button{flex:1;min-width:100px;min-height:44px;padding:10px 16px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition)}
.cookie-btn-accept{background:var(--accent);color:#fff;border:1.5px solid var(--accent)}
.cookie-btn-accept:hover{background:#c62b38;color:#fff}
.cookie-btn-reject{background:var(--surface-2);color:var(--ink);border:1.5px solid var(--ink-soft);font-weight:700}
.cookie-btn-reject:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.cookie-btn-settings{background:transparent;color:var(--ink-soft);border:1.5px solid var(--line)}
.cookie-btn-settings:hover{background:var(--surface);color:var(--ink)}

/* ============================================================
   COOKIE BANNER — FOOTER SAFE AREA
   ============================================================ */
@media(max-width:640px){}

/* ============================================================
   REVEAL ON SCROLL
   ============================================================ */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 650ms cubic-bezier(.16,1,.3,1),transform 650ms cubic-bezier(.16,1,.3,1)}
.reveal.is-in{opacity:1;transform:none}
.reveal[style*="--i"]{transition-delay:calc(var(--i) * 120ms)}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}
html.no-js .reveal{opacity:1;transform:none}

/* ============================================================
   PAGE-SPECIFIC: About, Contact, Policy, Thank-you, 404
   ============================================================ */
.page-hero{padding:clamp(48px,8vw,80px) 0 clamp(36px,6vw,56px);background:var(--surface)}
.page-hero .eyebrow{margin-bottom:8px}
.page-hero h1{font-size:clamp(2rem, 5vw, 3.2rem);margin-bottom:12px}
.page-hero p{color:var(--ink-soft);max-width:56ch}
.page-hero-subtitle{color:var(--ink-soft);max-width:56ch}

/* Generic section */
.section{padding:clamp(48px,8vw,80px) 0}
.section-alt{background:var(--surface)}

.page-content{padding:clamp(48px,8vw,80px) 0}
.page-content h2{margin:40px 0 14px}
.prose h2{padding-top:24px;border-top:1px solid var(--line)}
.prose h2:first-of-type{border-top:none;padding-top:0}
.page-content h3{margin:28px 0 10px}
.prose h3{padding-left:14px;border-left:3px solid var(--accent-2)}
.page-content p{margin-bottom:16px;color:var(--ink-soft);line-height:1.75}
.page-content ul,.page-content ol{margin:12px 0 18px 24px}
.page-content li{margin-bottom:8px;color:var(--ink-soft);line-height:1.65;list-style:disc}
.page-content ol li{list-style:decimal}
.page-content a{color:var(--accent-2);text-decoration:underline;text-underline-offset:2px}
.page-content a:hover{color:var(--accent)}

/* About page team */
.team-grid{display:grid;gap:24px;margin-top:32px}
@media(min-width:768px){.team-grid{grid-template-columns:repeat(2,1fr)}}
.team-card{padding:28px 24px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--line);transition:transform 360ms var(--ease-out),box-shadow 360ms var(--ease-out)}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.team-card-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.team-avatar{width:56px;height:56px;border-radius:50%;background:var(--accent-2);display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Outfit',system-ui,sans-serif;font-weight:700;font-size:1.1rem;flex-shrink:0}
.team-card-header h3{font-size:1.05rem;line-height:1.2}
.team-card-header .team-role{font-size:.82rem;color:var(--accent);font-weight:600}
.team-card p{font-size:.88rem;color:var(--ink-soft);line-height:1.7}

/* Contact page cards */
.contact-grid{display:grid;gap:16px;margin:32px 0}
@media(min-width:640px){.contact-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}}
.contact-card{padding:24px 20px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);transition:transform 360ms var(--ease-out),box-shadow 360ms var(--ease-out)}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.contact-card-icon{width:48px;height:48px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:12px;transition:background 280ms,color 280ms}
.contact-card:hover .contact-card-icon{background:var(--accent);color:#fff}
.contact-card-icon svg{width:22px;height:22px}
.contact-card h3,.contact-card h4{font-size:.92rem;margin-bottom:4px}
.contact-card a,.contact-card p,.contact-card span{font-size:.88rem;color:var(--ink-soft);line-height:1.5;overflow-wrap:anywhere}
.contact-card a{color:var(--accent-2);text-decoration:underline;text-underline-offset:2px;word-break:break-word}
.contact-card a:hover{color:var(--accent)}
.contact-card small{font-size:.78rem;color:var(--ink-soft);display:block;margin-top:4px}
.contact-card-subtitle{font-size:.78rem;color:var(--ink-soft);margin-top:4px}

/* Hours grid */
.hours-grid{display:grid;gap:4px;margin-top:8px}
.hours-row{display:grid;grid-template-columns:48px 1fr;gap:8px;padding:6px 10px;border-radius:4px;font-size:.85rem;font-variant-numeric:tabular-nums}
.hours-row.today{background:rgba(230,57,70,0.06);font-weight:600}
.hours-row dt,.hours-row span:first-child{color:var(--ink);font-weight:600}
.hours-row dd,.hours-row span:last-child{color:var(--ink-soft)}

/* Thank-you page */
.thankyou{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 24px}
.thankyou-inner{max-width:480px}
.thankyou-icon{width:80px;height:80px;margin:0 auto 24px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}
.thankyou-icon svg{width:40px;height:40px}
.thankyou h1{font-size:clamp(1.6rem, 4vw, 2.4rem);margin-bottom:12px}
.thankyou p{color:var(--ink-soft);margin-bottom:28px}

/* 404 page */
.page-404{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 24px}
.page-404 h1{font-size:clamp(4rem, 12vw, 4.5rem);color:var(--accent);line-height:1;margin-bottom:12px}
.page-404 p{color:var(--ink-soft);margin-bottom:28px;max-width:44ch}

/* Sitemap page */
.sitemap-list{columns:2;column-gap:32px}
@media(max-width:640px){.sitemap-list{columns:1}}
.sitemap-list li{break-inside:avoid;margin-bottom:12px}
.sitemap-list a{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface);border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;transition:all 240ms}
.sitemap-list a:hover{background:var(--accent);color:#fff}
.sitemap-list a svg{width:16px;height:16px;flex-shrink:0}

/* 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}
table{border-collapse:collapse}
th,td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:.88rem}
th{background:var(--surface);font-weight:700;font-family:'Outfit',system-ui,sans-serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink)}

/* ============================================================
   SECTION IMAGES
   ============================================================ */
.hero>.container>img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);object-fit:cover;width:100%}
.programlar>.container>img,
.nasil>.container>img,
.referanslar>.container>img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);object-fit:cover;width:100%;max-height:420px;margin-bottom:40px}

/* ============================================================
   NICHE-SPECIFIC ANIMATIONS
   ============================================================ */

/* 1. Ball Bounce on CTA hover */
@keyframes ballBounce{0%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}60%{transform:translateY(-2px)}}
.btn-primary:hover svg,.basla .btn-primary:hover svg{animation:ballBounce 500ms var(--ease-out)}

/* 2. Position Glow — radial pulse on active court dots */
@keyframes posGlow{0%,100%{box-shadow:0 0 6px var(--accent-glow)}50%{box-shadow:0 0 18px var(--accent-glow)}}

/* 3. Goal Net Ripple — wavy divider between sections */
@keyframes netRipple{0%{d:path('M0 20 Q 60 0, 120 20 T 240 20 T 360 20 T 480 20')}50%{d:path('M0 20 Q 60 40, 120 20 T 240 20 T 360 20 T 480 20')}100%{d:path('M0 20 Q 60 0, 120 20 T 240 20 T 360 20 T 480 20')}}

/* 4. Whistle blast on step marker hover */
@keyframes whistleBlast{0%{transform:scale(1) rotate(0)}50%{transform:scale(1.15) rotate(-8deg)}100%{transform:scale(1) rotate(0)}}
.timeline-step:hover .step-marker{animation:whistleBlast 400ms var(--ease-out)}

/* 5. Court Line Draw — stroke animation */
@keyframes courtDraw{from{stroke-dashoffset:800}to{stroke-dashoffset:0}}
.court-animated{stroke-dasharray:800;stroke-dashoffset:800;animation:courtDraw 2s var(--ease-out) forwards}

/* Card hover — accent shadow */
.program-card:hover,.testimonial-card:hover,.team-card:hover,.contact-card:hover{box-shadow:0 12px 32px -8px var(--accent2-glow)}
.program-card.featured:hover{box-shadow:0 12px 32px -8px var(--accent-glow)}

/* 6. Step dot completion pulse */
@keyframes dotComplete{0%{transform:scale(1)}50%{transform:scale(1.25)}100%{transform:scale(1)}}
.step-dot.done{animation:dotComplete 400ms var(--ease-out)}

/* 7. Stat number color sweep */
@keyframes statHighlight{0%{color:var(--ink)}100%{color:var(--accent)}}

/* 8. Button press tactile */
.btn:active{transform:translateY(1px) scale(.98);transition-duration:80ms}

/* 9. Primary button hover glow */
.btn-primary{transition:all 320ms cubic-bezier(.22,.61,.36,1)}
.btn-primary:hover,.btn-primary:focus-visible{box-shadow:0 8px 28px -6px rgba(230,57,70,0.35),0 0 0 3px var(--accent-glow)}

/* 10. Card accent-border sweep on hover */
.program-card,.testimonial-card,.team-card,.contact-card{position:relative;overflow:hidden;transition:transform 400ms cubic-bezier(.22,.61,.36,1),box-shadow 400ms cubic-bezier(.22,.61,.36,1),border-color 360ms}
.program-card::after,.testimonial-card::after,.team-card::after,.contact-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:0 0 var(--radius) var(--radius);transition:width 400ms cubic-bezier(.22,.61,.36,1);z-index:1}
.program-card:hover::after,.testimonial-card:hover::after,.team-card:hover::after,.contact-card:hover::after{width:100%}

/* 11. FAQ item smooth open */
.faq-item summary{transition:color 280ms,background 280ms}
.faq-item summary:hover{background:rgba(69,123,157,0.04)}

/* 12. Court dots entrance stagger */
@keyframes dotFadeIn{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
#pos-gk,#pos-fixo,#pos-ala-l,#pos-ala-r,#pos-pivo{opacity:0;transform-origin:center;transform-box:fill-box;animation:dotFadeIn 400ms var(--ease-out) forwards}
#pos-gk{animation-delay:1.2s}
#pos-fixo{animation-delay:1.4s}
#pos-ala-l{animation-delay:1.6s}
#pos-ala-r{animation-delay:1.8s}
#pos-pivo{animation-delay:2s}

/* 13. News item hover accent flash */
.news-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);border-radius:3px 0 0 3px;transform:scaleY(0);transition:transform 300ms cubic-bezier(.22,.61,.36,1)}
.news-item{position:relative;overflow:hidden}
.news-item:hover::before{transform:scaleY(1)}

/* 14. Stats counter glow on active */
.stat-num{transition:color 1.6s var(--ease-out),text-shadow 1.6s var(--ease-out)}

@media(prefers-reduced-motion:reduce){
  .hero h1 .char{opacity:1;transform:none;animation:none}
  .court-animated{stroke-dashoffset:0;animation:none}
  .position-dot.active.pulse{animation:none}
  #pos-gk,#pos-fixo,#pos-ala-l,#pos-ala-r,#pos-pivo{opacity:1;animation:none;transform:none}
  .btn-primary:hover svg{animation:none}
  .timeline-step:hover .step-marker{animation:none}
  .step-dot.done{animation:none}
  .hero-badge:hover{transform:none}
  .contact-quick-item:hover{transform:none}
  .news-item:hover{transform:none}
  .btn:active{transform:none}
  .program-card::after,.testimonial-card::after,.team-card::after,.contact-card::after{transition:none}
  .news-item::before{transition:none}
  .btn-primary{transition:background 0s,color 0s}
  .program-card,.testimonial-card,.team-card,.contact-card{transition:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  :root{--header-h:64px}
  .hero .container{grid-template-columns:1fr}
  .hero-visual{order:-1;max-width:380px;margin:0 auto}
}
@media(max-width:768px){
  .basla-inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  :root{--header-h:60px}
  .footer-grid{grid-template-columns:1fr}
  .option-grid{grid-template-columns:1fr}
  .avail-options{grid-template-columns:repeat(2,1fr)}
  .program-grid{grid-template-columns:1fr}
  .testimonial-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  h1{font-size:clamp(1.8rem, 7vw, 2.6rem)}
  .program-card{padding:24px 20px}
  .form-card{padding:24px 20px}
  .step-panel{padding:24px 20px}
  .step-nav{padding:16px 20px}
  .tool-wrapper{border-radius:var(--radius)}
}
@media(max-width:430px){
  .hero-badges{gap:8px}
  .hero-badge{padding:6px 12px;font-size:.78rem}
  .cookie-banner{left:8px;right:8px;bottom:8px;padding:16px 18px}
  .cookie-buttons{flex-direction:column}
  .cookie-buttons button{min-width:0;min-height:48px;font-size:.88rem}
}
@media(max-width:360px){
  .step-indicator{padding:14px 16px;gap:4px}
  .step-dot{width:28px;height:28px;font-size:.72rem}
}

/* ============================================================
   FUTSAL-THEMED MICRO-EFFECTS
   ============================================================ */

/* Scoreboard glow on stat numbers after count-up */
.stat-num.counted{text-shadow:0 0 24px rgba(230,57,70,0.2)}

/* Ball trail on CTA — subtle pulse ring via pseudo */
@keyframes ballTrail{0%{transform:scale(1);opacity:.4}100%{transform:scale(1.5);opacity:0}}
.btn-primary{position:relative;overflow:visible}
.btn-primary::before{content:'';position:absolute;inset:-4px;border-radius:inherit;border:2px solid var(--accent);opacity:0;pointer-events:none;transition:opacity 200ms}
.btn-primary:hover::before{animation:ballTrail 500ms ease-out forwards}

/* Timeline step connector glow */
.steps-timeline::before{background:linear-gradient(180deg,var(--accent) 0%,var(--line) 20%,var(--line) 80%,var(--accent-2) 100%)}

/* FAQ chevron smooth rotation with spring feel */
.faq-item summary .faq-chevron{transition:transform 400ms cubic-bezier(.34,1.56,.64,1)}

/* Program card featured — pulsing border glow */
@keyframes featuredGlow{0%,100%{box-shadow:0 0 0 0 rgba(230,57,70,0.1),var(--shadow-accent)}50%{box-shadow:0 0 0 4px rgba(230,57,70,0.08),var(--shadow-accent)}}
.program-card.featured{animation:featuredGlow 3s ease-in-out infinite}

/* Testimonial card quote mark entrance */
.testimonial-card.is-in::before{animation:charIn 600ms var(--ease-out) 300ms both}

/* Contact quick item hover slide */
.contact-quick-item{transition:transform 320ms cubic-bezier(.34,1.56,.64,1),box-shadow 280ms}

/* News item hover with accent flash */
.news-item{transition:transform 320ms cubic-bezier(.34,1.56,.64,1),box-shadow 280ms,border-color 280ms}

/* Cookie banner entrance */
@keyframes cookieSlideUp{from{transform:translateY(120%);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner.is-visible{animation:cookieSlideUp 400ms cubic-bezier(.16,1,.3,1) forwards}

/* Court dot hover interactivity */
.position-dot{cursor:pointer}
.position-dot:hover{r:11;fill:var(--accent);filter:drop-shadow(0 0 10px rgba(230,57,70,0.6));transition:all 200ms var(--ease-out)}

@media(prefers-reduced-motion:reduce){
  .btn-primary:hover::before{animation:none}
  .program-card.featured{animation:none}
  .cookie-banner.is-visible{animation:none;transform:translateY(0);opacity:1}
  .testimonial-card.is-in::before{animation:none}
  .position-dot:hover{transition:none}
}

/* Print */
@media print{
  .site-header,.drawer,.drawer-backdrop,.cookie-banner,.nav-toggle{display:none!important}
  main{padding-top:0!important}
  .reveal{opacity:1!important;transform:none!important}
  body{color:#000;background:#fff}
  a{text-decoration:underline}
}

.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;
}

