/* ============================================================
   Gol Akademi — styles.css
   ============================================================ */

/* --- Fonts (Google) --- */
/* --- Tokens --- */
:root {
  interpolate-size: allow-keywords;

  --bg: #FFFFFF;
  --surface: #F0F4FF;
  --surface-2: #E0E9FF;
  --ink: #1A1A2E;
  --ink-soft: #4A4A6A;
  --accent: #0055FF;
  --accent-2: #00C2FF;
  --line: rgba(26,26,46,0.10);
  --line-strong: rgba(26,26,46,0.22);
  --radius: 12px;
  --radius-sm: 6px;
  --header-h: 72px;
  --max-w: 1320px;
  --pad: clamp(16px,4vw,32px);

  --font-heading: 'Space Grotesk', system-ui, sans-serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
}

/* --- Reset --- */
*,*::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:var(--font-body);font-weight:400;color:var(--ink);background:var(--bg);line-height:1.65;letter-spacing:-0.005em;-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}
table{border-collapse:collapse;border-spacing:0}

/* --- Utility --- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
a[href^="mailto:"],a[href^="http"]{word-break:break-word;overflow-wrap:anywhere}

/* Skip link */
.skip-link{position:absolute;top:-100%;left:16px;z-index:10000;padding:8px 18px;background:var(--accent);color:#fff;border-radius:0 0 var(--radius-sm) var(--radius-sm);font-weight:600;transition:top 180ms}
.skip-link:focus{top:0}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.15;letter-spacing:-0.012em;color:var(--ink)}
h1{font-size:clamp(2.4rem, 6vw, 4.2rem)}
h2{font-size:clamp(1.7rem,4vw,2.6rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
h4{font-size:clamp(1rem,2vw,1.25rem)}
p{max-width:68ch}
.eyebrow{font-family:var(--font-heading);font-size:0.82rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent)}
.sub{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--ink-soft);max-width:52ch}

/* Accent number font */
.num-accent{font-family:'Space Grotesk',monospace;font-variant-numeric:tabular-nums}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:var(--radius-sm);font-family:var(--font-heading);font-weight:600;font-size:0.95rem;letter-spacing:0.02em;transition:background 240ms cubic-bezier(.4,0,.2,1),color 240ms,transform 180ms,box-shadow 240ms;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--ink);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px -8px rgba(0,85,255,0.35)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong)}
.btn-ghost:hover,.btn-ghost:focus-visible{background:var(--surface);color:var(--ink);border-color:var(--accent);transform:translateY(-2px)}
.btn-accent2{background:var(--accent-2);color:var(--ink)}
.btn-accent2:hover,.btn-accent2:focus-visible{background:var(--accent);color:#fff;transform:translateY(-2px)}

/* Focus ring */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1080;background:rgba(255, 255, 255, 0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease;padding:0 var(--pad)}
.site-header.scrolled{background:rgba(255,255,255,0.98);box-shadow:0 8px 24px -16px rgba(0,0,0,0.18)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);max-width:var(--max-w);margin:0 auto}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-heading);font-weight:700;font-size:1.3rem;color:var(--ink);letter-spacing:-0.02em;z-index:1100}
.logo svg{width:36px;height:36px;flex-shrink:0}
.logo span{color:var(--accent)}

/* Desktop nav */
.nav-desktop{display:none;align-items:center;gap:6px}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{position:relative;padding:8px 14px;font-size:0.9rem;font-weight:500;color:var(--ink-soft);transition:color 200ms}
.nav-desktop a:hover{color:var(--ink)}
.nav-desktop a.is-active{color:var(--accent)}
.nav-desktop a::after{content:'';position:absolute;bottom:2px;left:14px;right:14px;height:2px;background:var(--accent);transform:scaleX(0);transition:transform 240ms cubic-bezier(.2,.7,.2,1)}
.nav-desktop a.is-active::after,.nav-desktop a:hover::after{transform:scaleX(1)}
.nav-desktop .nav-cta{background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:10px 22px;margin-left:8px}
.nav-desktop .nav-cta::after{display:none}
.nav-desktop .nav-cta:hover{background:var(--ink);color:#fff}

/* Hamburger */
.nav-toggle{display:flex;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;gap:5px;background:none;border:none;cursor:pointer;z-index:1100;position:relative}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-toggle span{display:block;width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform 320ms cubic-bezier(.2,.7,.2,1),opacity 200ms}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer — OUTSIDE header */
.drawer-backdrop{position:fixed;inset:0;z-index:1040;background:rgba(0,0,0,0.55);opacity:0;pointer-events:none;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);z-index:1050;background:var(--bg);transform:translateX(100%);transition:transform 320ms cubic-bezier(.2,.7,.2,1);padding:calc(var(--header-h) + 24px) 32px 32px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}
.drawer.is-open{transform:translateX(0)}
.drawer a{display:block;padding:14px 0;font-size:1.1rem;font-weight:500;color:var(--ink);border-bottom:1px solid var(--line);transition:color 200ms,padding-left 200ms}
.drawer a:hover,.drawer a.is-active{color:var(--accent);padding-left:8px}
.drawer .drawer-cta{display:inline-flex;align-items:center;justify-content:center;margin-top:16px;padding:14px 28px;background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-weight:600;border-bottom:none;text-align:center}
.drawer .drawer-cta:hover{background:var(--ink);color:#fff;padding-left:0}

/* Main offset */
main{padding-top:var(--header-h)}
main section[id]{scroll-margin-top:calc(var(--header-h) + 16px)}

/* ============================================================
   DOT-GRID BACKGROUND DECO
   ============================================================ */
.dot-grid-bg{position:relative}
.dot-grid-bg::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,var(--line) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;opacity:0.45;z-index:0}
.dot-grid-bg>*{position:relative;z-index:1}

/* ============================================================
   HERO — split-asymmetric 60/40
   ============================================================ */
.hero{padding:clamp(48px,8vh,96px) 0 clamp(40px,6vh,72px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:768px){.hero-grid{grid-template-columns:60% 40%;gap:32px}}

.hero-text{display:flex;flex-direction:column;gap:20px}
.hero-text .eyebrow{margin-bottom:-8px}
.hero-text h1{line-height:1.08}
.hero-text h1 .accent{color:var(--accent)}
.hero-sub{font-size:clamp(1.05rem,2vw,1.25rem);color:var(--ink-soft);max-width:46ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}

/* Trust strip */
.trust-strip{display:flex;flex-wrap:wrap;gap:16px;margin-top:24px}
.trust-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--surface);border-radius:var(--radius-sm);font-size:0.82rem;font-weight:500;color:var(--ink-soft)}
.trust-badge svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}

/* Hero image area */
.hero-visual{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius) 60px var(--radius) var(--radius);max-width:480px;margin:0 auto}
@media(min-width:768px){.hero-visual{max-width:none;margin:0;clip-path:polygon(12% 0,100% 0,100% 100%,0 100%)}}
.hero-visual img{width:100%;height:100%;object-fit:cover}

/* Parallax subtle */
.hero-visual img{will-change:transform}

/* ============================================================
   STATS STRIP
   ============================================================ */
.stats-strip{padding:clamp(32px,5vw,56px) 0;background:var(--ink);color:#fff}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(min-width:640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-item{text-align:center}
.stat-num{font-family:var(--font-heading);font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--accent-2);line-height:1.1}
.stat-label{font-size:0.85rem;color:rgba(255,255,255,0.7);margin-top:4px}

/* ============================================================
   SECTION COMMON
   ============================================================ */
section{padding:clamp(48px,8vw,88px) 0}
.section-header{text-align:center;margin-bottom:clamp(32px,5vw,56px)}
.section-header .eyebrow{margin-bottom:10px}
.section-header h2{margin-bottom:12px}
.section-header .sub{margin:0 auto}

/* Dark section band */
.section-dark{background:var(--ink);color:#fff}
.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-dark .eyebrow{color:var(--accent-2)}
.section-dark .sub{color:rgba(255,255,255,0.7)}

/* Surface section */
.section-surface{background:var(--surface)}

/* ============================================================
   CAMP CARDS — #vitrin
   ============================================================ */
.camp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
@media(min-width:1024px){.camp-grid{grid-template-columns:repeat(3,1fr)}}

.camp-card{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:0;overflow:hidden;transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms;display:flex;flex-direction:column}
.camp-card:hover{transform:scale(1.03);box-shadow:0 16px 48px -12px rgba(0,85,255,0.18)}

/* Football field line animation — theme signature */
.camp-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:36px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 36' fill='none'%3E%3Crect x='1' y='1' width='198' height='34' stroke='%230055FF' stroke-width='0.8' opacity='0.35'/%3E%3Cline x1='100' y1='1' x2='100' y2='35' stroke='%230055FF' stroke-width='0.8' opacity='0.35'/%3E%3Ccircle cx='100' cy='18' r='10' stroke='%230055FF' stroke-width='0.8' opacity='0.35'/%3E%3Crect x='1' y='9' width='24' height='18' stroke='%230055FF' stroke-width='0.8' opacity='0.35'/%3E%3Crect x='175' y='9' width='24' height='18' stroke='%230055FF' stroke-width='0.8' opacity='0.35'/%3E%3C/svg%3E") center/contain no-repeat;opacity:0;transform:translateY(100%);transition:opacity 320ms cubic-bezier(.2,.7,.2,1),transform 360ms cubic-bezier(.2,.7,.2,1);pointer-events:none;z-index:2}
.camp-card:hover::after{opacity:1;transform:translateY(0)}

.camp-card-img{width:100%;aspect-ratio:16/10;object-fit:cover}
.camp-card-body{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column;gap:12px}
.camp-card-badges{display:flex;flex-wrap:wrap;gap:6px}
.badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:0.72rem;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;border-radius:3px}
.badge-age{background:var(--accent);color:#fff}
.badge-level{background:var(--accent-2);color:var(--ink)}
.badge-duration{background:var(--surface-2);color:var(--ink-soft)}
.camp-card-title{font-family:var(--font-heading);font-size:1.15rem;font-weight:700}
.camp-card-desc{font-size:0.88rem;color:var(--ink-soft);line-height:1.55;flex:1}
.camp-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.camp-card-price{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--accent)}
.camp-card-price small{font-size:0.72rem;font-weight:400;color:var(--ink-soft);display:block}
.camp-card-link{font-size:0.85rem;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:4px;transition:gap 200ms}
.camp-card-link:hover{gap:8px}

/* ============================================================
   FILTER BAR — #filtre
   ============================================================ */
.filter-bar{display:flex;flex-wrap:wrap;gap:12px;padding:20px 24px;background:var(--surface);border-radius:var(--radius);margin-bottom:32px;align-items:center}
.filter-group{display:flex;flex-direction:column;gap:4px;min-width:140px;flex:1}
.filter-group label{font-size:0.75rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-soft)}
.filter-group select{padding:8px 12px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--bg);font-size:0.88rem;cursor:pointer;transition:border-color 200ms}
.filter-group select:focus{border-color:var(--accent)}
.filter-reset{align-self:flex-end;padding:8px 18px;font-size:0.82rem;font-weight:600;color:var(--accent);border:1.5px solid var(--accent);border-radius:var(--radius-sm);background:transparent;transition:background 200ms,color 200ms}
.filter-reset:hover{background:var(--accent);color:#fff}

/* ============================================================
   COMPARISON TABLE — #karsilastir
   ============================================================ */
.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:var(--radius-sm);scrollbar-width:thin;scrollbar-color:var(--accent) var(--surface)}
.table-scroll>table{margin:0 !important;min-width:580px;width:100%}
:where(*:has(>.table-scroll),*:has(>*>.table-scroll),*:has(>*>*>.table-scroll)){min-width:0}

.compare-table{width:100%;text-align:left}
.compare-table thead{background:var(--ink)}
.compare-table thead th{color:#fff;padding:16px 18px;font-family:var(--font-heading);font-weight:600;font-size:0.9rem}
.compare-table tbody tr{border-bottom:1px solid var(--line)}
.compare-table tbody tr:nth-child(even){background:var(--surface)}
.compare-table td{padding:14px 18px;font-size:0.88rem;vertical-align:top}
.compare-table td:first-child{font-weight:600;color:var(--ink);white-space:nowrap}
.compare-check{color:var(--accent);font-weight:700}
.compare-x{color:var(--ink-soft);opacity:0.4}

/* ============================================================
   CALENDAR — #takvim
   ============================================================ */
.calendar-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:768px){.calendar-grid{grid-template-columns:repeat(3,1fr)}}

.cal-month{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cal-month-header{background:var(--accent);color:#fff;padding:14px 18px;font-family:var(--font-heading);font-weight:700;font-size:1.05rem;text-align:center}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:12px}
.cal-day-name{font-size:0.68rem;font-weight:600;text-transform:uppercase;color:var(--ink-soft);text-align:center;padding:4px}
.cal-day{text-align:center;padding:6px 2px;font-size:0.82rem;border-radius:4px;position:relative}
.cal-day.empty{visibility:hidden}
.cal-day.has-camp{background:rgba(0,85,255,0.12);color:var(--accent);font-weight:600;cursor:default}
.cal-day.has-camp-elite{background:rgba(0,194,255,0.15);color:#0088BB;font-weight:600}
.cal-legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:20px;justify-content:center}
.cal-legend-item{display:flex;align-items:center;gap:6px;font-size:0.8rem;color:var(--ink-soft)}
.cal-legend-swatch{width:14px;height:14px;border-radius:3px}

/* ============================================================
   PROCESS / TIMELINE
   ============================================================ */
.process-timeline{position:relative;max-width:720px;margin:0 auto}
.process-timeline::before{content:'';position:absolute;left:23px;top:0;bottom:0;width:2px;background:var(--line-strong)}
@media(min-width:640px){.process-timeline::before{left:31px}}

.process-step{position:relative;padding-left:60px;padding-bottom:40px;display:grid;grid-template-columns:1fr;gap:6px}
@media(min-width:640px){.process-step{padding-left:76px}}
.process-step:last-child{padding-bottom:0}
.process-step-num{position:absolute;left:0;top:0;width:48px;height:48px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:1.1rem;z-index:1}
@media(min-width:640px){.process-step-num{width:64px;height:64px;font-size:1.3rem}}
.process-step-time{font-size:0.78rem;font-weight:600;color:var(--accent);letter-spacing:0.06em;text-transform:uppercase}
.process-step h4{font-size:1.05rem}
.process-step p{font-size:0.88rem;color:var(--ink-soft);max-width:54ch}

/* ============================================================
   TEAM
   ============================================================ */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:28px}
.team-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms}
.team-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px -12px rgba(0,85,255,0.15)}
.team-card-img{width:100%;aspect-ratio:3/4;object-fit:cover;background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 90' fill='none'%3E%3Ccircle cx='40' cy='30' r='14' fill='%230055FF' opacity='0.09'/%3E%3Cpath d='M14 82c0-14.4 11.6-26 26-26s26 11.6 26 26' fill='%230055FF' opacity='0.06'/%3E%3C/svg%3E") center 45%/80px no-repeat}
.team-card-body{padding:20px}
.team-card-body h4{margin-bottom:2px}
.team-card-role{font-size:0.82rem;font-weight:600;color:var(--accent);margin-bottom:10px}
.team-card-body p{font-size:0.85rem;color:var(--ink-soft);line-height:1.55}

/* ============================================================
   TESTIMONIALS — asymmetric 2-col
   ============================================================ */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.testimonials-grid{grid-template-columns:1fr 1fr;gap:28px}}
.testimonial-card{background:var(--surface);border-radius:var(--radius);padding:clamp(24px,3vw,36px);position:relative;display:flex;flex-direction:column;gap:14px}
@media(min-width:768px){.testimonial-card:first-child{grid-row:span 2}}
.testimonial-card::before{content:'\201C';position:absolute;top:12px;left:20px;font-family:Georgia,serif;font-size:4rem;line-height:1;color:var(--accent);opacity:0.15}
.testimonial-text{font-size:0.92rem;color:var(--ink);line-height:1.65;font-style:italic;position:relative;z-index:1}
.testimonial-author{display:flex;align-items:center;gap:12px;margin-top:auto}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:1rem;flex-shrink:0}
.testimonial-meta{font-size:0.82rem;color:var(--ink-soft)}
.testimonial-meta strong{display:block;color:var(--ink);font-weight:600}

/* ============================================================
   FAQ / PARENT GUIDE — #rehber
   ============================================================ */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:4px}
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;font-family:var(--font-heading);font-weight:600;font-size:0.95rem;cursor:pointer;list-style:none;transition:background 200ms}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none}
.faq-item summary:hover{background:var(--surface)}
.faq-item summary .faq-icon{width:24px;height:24px;transition:transform 360ms cubic-bezier(.4,0,.2,1);flex-shrink:0;color:var(--accent)}
.faq-item[open] summary .faq-icon{transform:rotate(45deg)}

/* Pure CSS smooth animation for details */
.faq-item .faq-body{height:0;padding:0 22px;overflow:hidden;transition:height 360ms cubic-bezier(.4,0,.2,1),padding-block-end 360ms cubic-bezier(.4,0,.2,1)}
.faq-item[open] .faq-body{height:auto;padding-block-end:22px}
.faq-body p{font-size:0.9rem;color:var(--ink-soft);line-height:1.65;max-width:62ch}
@media(prefers-reduced-motion:reduce){.faq-item .faq-body{transition:none}}

/* ============================================================
   FORM — #basvuru
   ============================================================ */
.form-section{background:var(--surface)}
.form-card{background:var(--bg);border-radius:var(--radius);padding:clamp(28px,4vw,48px);max-width:720px;margin:0 auto;box-shadow:0 8px 32px -12px rgba(0,0,0,0.08)}
.form-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:640px){.form-grid{grid-template-columns:1fr 1fr}.form-full{grid-column:1/-1}}

.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:0.82rem;font-weight:600;letter-spacing:0.02em;color:var(--ink)}
.field input[type="text"],.field input[type="email"],.field input[type="tel"],.field select,.field textarea{padding:12px 16px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--bg);font-size:0.92rem;transition:border-color 200ms,box-shadow 200ms}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,85,255,0.1)}
.field textarea{min-height:120px;resize:vertical}

.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-check{flex-direction:row;align-items:flex-start;gap:10px}
.field-check label{font-size:0.84rem;font-weight:400;color:var(--ink-soft);line-height:1.45}

.form-submit{margin-top:8px}
.form-submit .btn{width:100%}
@media(min-width:640px){.form-submit .btn{width:auto;min-width:200px}}

/* Honeypot */
.hp-field{position:absolute;left:-9999px;opacity:0}

/* ============================================================
   NEWS / UPDATES BLOCK
   ============================================================ */
.news-list{display:flex;flex-direction:column;gap:14px;max-width:640px;margin:0 auto}
.news-item{display:flex;gap:14px;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--line)}
.news-date{font-family:var(--font-heading);font-size:0.78rem;font-weight:600;color:var(--accent);white-space:nowrap;min-width:110px}
.news-text{font-size:0.88rem;color:var(--ink-soft)}

/* ============================================================
   PRICING PACKAGES
   ============================================================ */
.pricing-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.pricing-grid{grid-template-columns:repeat(3,1fr)}}
.pricing-card{background:var(--bg);border:1.5px solid var(--line);border-radius:var(--radius);padding:clamp(24px,3vw,36px);display:flex;flex-direction:column;gap:16px;transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms,border-color 280ms;position:relative;overflow:hidden}
.pricing-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px -12px rgba(0,85,255,0.15)}
.pricing-card.featured{border-color:var(--accent);box-shadow:0 8px 32px -8px rgba(0,85,255,0.18)}
.pricing-card.featured::before{content:'Popüler';position:absolute;top:16px;right:-28px;background:var(--accent);color:#fff;font-size:0.7rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:4px 36px;transform:rotate(45deg)}
.pricing-card-name{font-family:var(--font-heading);font-size:1.15rem;font-weight:700}
.pricing-card-price{font-family:var(--font-heading);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:var(--accent)}
.pricing-card-price small{font-size:0.78rem;font-weight:400;color:var(--ink-soft);display:block;margin-top:2px}
.pricing-list{display:flex;flex-direction:column;gap:8px;flex:1}
.pricing-list li{font-size:0.86rem;color:var(--ink-soft);padding-left:24px;position:relative;line-height:1.5}
.pricing-list li::before{content:'';position:absolute;left:0;top:6px;width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230055FF'%3E%3Cpath d='M6.5 12.5l-4-4 1.4-1.4L6.5 9.7l5.6-5.6 1.4 1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.pricing-excluded{border-top:1px solid var(--line);padding-top:12px;margin-top:8px}
.pricing-excluded li::before{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23999'%3E%3Cpath d='M12 4.7L11.3 4 8 7.3 4.7 4 4 4.7 7.3 8 4 11.3l.7.7L8 8.7l3.3 3.3.7-.7L8.7 8z'/%3E%3C/svg%3E") center/contain no-repeat}
.pricing-disclaimer{text-align:center;font-size:0.78rem;color:var(--ink-soft);margin-top:24px;font-style:italic}

/* ============================================================
   CANCELLATION TIERS
   ============================================================ */
.cancel-tiers{display:grid;grid-template-columns:1fr;gap:14px;max-width:640px;margin:0 auto}
@media(min-width:640px){.cancel-tiers{grid-template-columns:repeat(2,1fr)}}
.cancel-tier{padding:18px 22px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--bg)}
.cancel-tier-label{font-family:var(--font-heading);font-weight:700;font-size:0.95rem;margin-bottom:4px}
.cancel-tier-detail{font-size:0.85rem;color:var(--ink-soft)}

/* ============================================================
   CONTACT PAGE — cards grid
   ============================================================ */
.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.contact-card{border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;display:flex;flex-direction:column;gap:10px;transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms}
.contact-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px -8px rgba(0,85,255,0.12)}
.contact-card-icon{width:48px;height:48px;background:rgba(0,85,255,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent)}
.contact-card-icon svg{width:22px;height:22px}
.contact-card h4{font-size:0.92rem}
.contact-card a{color:var(--accent);font-weight:500;word-break:break-all;transition:opacity 200ms}
.contact-card a:hover{opacity:0.75}
.contact-card .contact-sub{font-size:0.78rem;color:var(--ink-soft)}

/* Hours mini-grid */
.hours-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-variant-numeric:tabular-nums;font-size:0.88rem}
.hours-grid .day{font-weight:600}
.hours-grid .today{color:var(--accent)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:rgba(255,255,255,0.8);padding:clamp(48px,6vw,72px) 0 0}
.footer-grid{display:grid;grid-template-columns:1fr;gap:36px;padding-bottom:40px}
@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand{display:flex;flex-direction:column;gap:14px}
.footer-brand .logo{color:#fff}
.footer-brand p{font-size:0.85rem;color:rgba(255,255,255,0.6);max-width:32ch}
.footer-col h4{color:#fff;font-size:0.88rem;margin-bottom:14px;letter-spacing:0.04em;text-transform:uppercase}
.footer-col a{display:block;font-size:0.85rem;color:rgba(255,255,255,0.6);padding:4px 0;transition:color 200ms}
.footer-col a:hover{color:var(--accent-2)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding:20px 0;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:0.78rem;color:rgba(255,255,255,0.45)}
.footer-bottom a{color:rgba(255,255,255,0.45);transition:color 200ms}
.footer-bottom a:hover{color:var(--accent-2)}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 18px}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 600ms cubic-bezier(.2,.7,.2,1),transform 600ms cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:none}

/* Stagger via --i */
.reveal[style*="--i"]{transition-delay:calc(var(--i,0) * 80ms)}

@media(prefers-reduced-motion:reduce){.reveal{opacity:1 !important;transform:none !important;transition:none !important}}
html.no-js .reveal{opacity:1;transform:none}

/* ============================================================
   FOOTBALL NICHE ANIMATIONS
   ============================================================ */

/* 1. Ball bounce on CTA hover */
@keyframes ball-bounce{0%,100%{transform:translateY(0)}40%{transform:translateY(-6px)}60%{transform:translateY(-2px)}}
.btn-primary:hover svg,.hero-actions .btn:hover svg{animation:ball-bounce 600ms cubic-bezier(.2,.7,.2,1)}

/* 2. Goal net shimmer on stats */
@keyframes net-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.stat-item::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(0,194,255,0.06) 50%,transparent 70%);background-size:200% 100%;opacity:0;transition:opacity 400ms}
.stat-item{position:relative;overflow:hidden}
.stat-item:hover::before{opacity:1;animation:net-shimmer 2.4s ease infinite}

/* 3. Grass stripe ambient */
@keyframes grass-sway{0%,100%{background-position:0 0}50%{background-position:3px 0}}
.section-surface::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:repeating-linear-gradient(90deg,rgba(0,85,255,0.06) 0 2px,transparent 2px 8px);pointer-events:none}
.section-surface{position:relative}
@media(prefers-reduced-motion:no-preference){.section-surface::after{animation:grass-sway 8s ease-in-out infinite}}

/* 4. Whistle pulse on pricing featured */
@keyframes whistle-pulse{0%,100%{box-shadow:0 0 0 0 rgba(0,85,255,0.18)}50%{box-shadow:0 0 0 8px rgba(0,85,255,0)}}
.pricing-card.featured{animation:whistle-pulse 3s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.pricing-card.featured{animation:none}}

/* 5. Field corner flag wave on section headers */
@keyframes flag-wave{0%,100%{transform:rotate(0deg)}25%{transform:rotate(3deg)}75%{transform:rotate(-2deg)}}
.section-header .eyebrow::before{content:'';display:inline-block;width:3px;height:14px;background:var(--accent);margin-right:10px;vertical-align:middle;border-radius:1px}
@media(prefers-reduced-motion:no-preference){.section-header .eyebrow::before{animation:flag-wave 4s ease-in-out infinite;transform-origin:bottom center}}

/* ============================================================
   COUNTER-UP (JS driven)
   ============================================================ */
.counter-up{font-variant-numeric:tabular-nums}

/* ============================================================
   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:0 12px 40px -8px rgba(0,0,0,0.18);transform:translateY(140%);opacity:0;transition:transform 280ms cubic-bezier(.2,.7,.2,1),opacity 240ms;z-index:9999;display:flex;flex-direction:column;gap:14px}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
@media(min-width:640px){.cookie-banner{left:24px;right:auto;max-width:420px}}

.cookie-banner h4{font-size:0.92rem;display:flex;align-items:center;gap:8px}
.cookie-banner p{font-size:0.82rem;color:var(--ink-soft);line-height:1.55}
.cookie-btns{display:flex;gap:8px;flex-wrap:wrap}
.cookie-btns button{flex:1;min-width:100px;padding:10px 16px;border-radius:var(--radius-sm);font-size:0.82rem;font-weight:600;transition:background 200ms,color 200ms;min-height:44px}
.cookie-accept{background:var(--accent);color:#fff}
.cookie-accept:hover{background:var(--ink);color:#fff}
.cookie-reject{background:var(--surface);color:var(--ink);border:1px solid var(--line-strong)}
.cookie-reject:hover{background:var(--surface-2);color:var(--ink)}
.cookie-settings{background:transparent;color:var(--ink-soft);border:1px solid var(--line)}
.cookie-settings:hover{background:var(--surface);color:var(--ink)}

/* ============================================================
   PAGE HERO (secondary pages)
   ============================================================ */
.page-hero{padding:clamp(48px,8vh,80px) 0 clamp(32px,5vh,56px);background:var(--surface);text-align:center}
.page-hero .eyebrow{margin-bottom:12px}
.page-hero h1{margin-bottom:14px}
.page-hero .sub{margin:0 auto}

/* ============================================================
   POLICY / PROSE
   ============================================================ */
.prose{max-width:780px;margin:0 auto;padding:clamp(32px,5vw,64px) 0}
.prose h2{margin:clamp(28px,4vw,48px) 0 14px;font-size:clamp(1.3rem,2.5vw,1.7rem)}
.prose h3{margin:24px 0 10px;font-size:clamp(1.05rem,2vw,1.3rem)}
.prose p{margin-bottom:16px;color:var(--ink-soft);line-height:1.7}
.prose ul,.prose ol{margin-bottom:16px;padding-left:24px}
.prose li{margin-bottom:8px;color:var(--ink-soft);line-height:1.6}
.prose ul li{list-style:disc}
.prose ol li{list-style:decimal}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* ============================================================
   THANK-YOU PAGE
   ============================================================ */
.thankyou-section{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:clamp(48px,8vh,96px) 0}
.thankyou-content{max-width:520px;display:flex;flex-direction:column;align-items:center;gap:20px}
.thankyou-icon{width:80px;height:80px;background:var(--surface);border-radius:50%;display:flex;align-items:center;justify-content:center}
.thankyou-icon svg{width:40px;height:40px;color:var(--accent)}

/* ============================================================
   SITEMAP PAGE
   ============================================================ */
.sitemap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:32px;max-width:900px;margin:0 auto}
.sitemap-group h3{margin-bottom:12px;font-size:1rem}
.sitemap-group a{display:block;padding:4px 0;font-size:0.9rem;color:var(--ink-soft);transition:color 200ms}
.sitemap-group a:hover{color:var(--accent)}

/* ============================================================
   404 PAGE
   ============================================================ */
.page-404{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:clamp(48px,8vh,96px) 0}
.page-404-content{max-width:480px;display:flex;flex-direction:column;align-items:center;gap:20px}
.page-404-num{font-family:var(--font-heading);font-size:clamp(6rem,12vw,10rem);font-weight:700;color:var(--accent);line-height:1;opacity:0.15}

/* ============================================================
   PRINT
   ============================================================ */
@media print{
  .site-header,.drawer,.drawer-backdrop,.cookie-banner,.nav-toggle,.skip-link{display:none !important}
  main{padding-top:0 !important}
  body{color:#000;background:#fff}
  a{color:#000;text-decoration:underline}
  .reveal{opacity:1 !important;transform:none !important}
}

/* ============================================================
   RESPONSIVE FINE-TUNING
   ============================================================ */
@media(max-width:1024px){
  :root{--header-h:64px}
}
@media(max-width:640px){
  :root{--header-h:60px}
  .camp-grid{grid-template-columns:1fr}
  .hero-visual{max-width:320px}
  .pricing-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .trust-strip{gap:10px}
  .trust-badge{padding:6px 12px;font-size:0.78rem}
  .stats-grid{gap:16px}
  .contact-cards{grid-template-columns:1fr}
}
@media(max-width:430px){
  .camp-card-body{padding:16px 18px 20px}
  .hero-text h1{font-size:clamp(2rem, 7vw, 2.8rem)}
  .filter-bar{flex-direction:column;gap:14px}
  .filter-group{min-width:100%}
  .pricing-card{padding:20px}
  .team-card-body{padding:16px}
}
@media(max-width:360px){
  .trust-badge{padding:5px 10px;font-size:0.74rem}
  .camp-card-price{font-size:1.1rem}
}

/* ============================================================
   FIX: Dark section contrast for process steps
   ============================================================ */
.section-dark .process-step p{color:rgba(255,255,255,0.6)}
.section-dark .process-step-time{color:var(--accent-2)}
.section-dark .process-timeline::before{background:rgba(255,255,255,0.15)}

/* ============================================================
   FIX: Cookie banner mobile button layout
   ============================================================ */
@media(max-width:400px){
  .cookie-btns{flex-direction:column}
  .cookie-btns button{flex:none;width:100%}
  .cookie-banner{padding:16px 18px}
}

/* ============================================================
   ENHANCED: Football-themed hover & micro-interactions
   ============================================================ */

/* Nav link football dot indicator */
.nav-desktop a{position:relative}
.nav-desktop a::before{content:'';position:absolute;bottom:0;left:50%;width:5px;height:5px;border-radius:50%;background:var(--accent);transform:translateX(-50%) scale(0);transition:transform 280ms cubic-bezier(.2,.7,.2,1)}
.nav-desktop a:hover::before,.nav-desktop a.is-active::before{transform:translateX(-50%) scale(1)}
.nav-desktop .nav-cta::before{display:none}

/* FAQ hover glow */
.faq-item{transition:box-shadow 240ms cubic-bezier(.2,.7,.2,1)}
.faq-item:hover{box-shadow:0 4px 20px -6px rgba(0,85,255,0.12)}

/* Cancel tier hover */
.cancel-tier{transition:transform 220ms cubic-bezier(.2,.7,.2,1),box-shadow 220ms}
.cancel-tier:hover{transform:translateY(-3px);box-shadow:0 8px 24px -8px rgba(0,85,255,0.12)}

/* News item hover */
.news-item{transition:padding-left 220ms cubic-bezier(.2,.7,.2,1)}
.news-item:hover{padding-left:8px}

/* Contact card icon pulse on hover */
.contact-card:hover .contact-card-icon{animation:icon-pulse 400ms cubic-bezier(.2,.7,.2,1)}
@keyframes icon-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}

/* Camp card — field stripe reveal on hover */
.camp-card{transition:transform 320ms cubic-bezier(.22,1,.36,1),box-shadow 320ms cubic-bezier(.22,1,.36,1)}
.camp-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 20px 56px -16px rgba(0,85,255,0.22)}

/* Camp card link arrow slide */
.camp-card-link{transition:gap 240ms cubic-bezier(.2,.7,.2,1),color 200ms}
.camp-card-link:hover{gap:10px;color:var(--ink)}

/* Team card shimmer on hover */
@keyframes team-shimmer{0%{left:-100%}100%{left:100%}}
.team-card{position:relative;overflow:hidden}
.team-card::before{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,85,255,0.04),transparent);z-index:1;pointer-events:none;transition:none}
.team-card:hover::before{animation:team-shimmer 700ms cubic-bezier(.22,1,.36,1)}

/* Pricing card hover lift — smoother */
.pricing-card{transition:transform 320ms cubic-bezier(.22,1,.36,1),box-shadow 320ms,border-color 320ms}
.pricing-card:hover{transform:translateY(-8px);box-shadow:0 20px 48px -12px rgba(0,85,255,0.2)}

/* Stat item — number glow on hover */
.stat-item{transition:transform 240ms cubic-bezier(.2,.7,.2,1)}
.stat-item:hover{transform:translateY(-2px)}
.stat-item:hover .stat-num{text-shadow:0 0 24px rgba(0,194,255,0.3)}
.stat-num{transition:text-shadow 300ms}

/* Trust badge hover */
.trust-badge{transition:background 200ms,transform 200ms}
.trust-badge:hover{background:var(--surface-2);transform:translateY(-1px)}

/* Testimonial card hover */
.testimonial-card{transition:transform 280ms cubic-bezier(.22,1,.36,1),box-shadow 280ms}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px -8px rgba(0,85,255,0.1)}

/* Smoother reveal with enhanced stagger */
.reveal{transition:opacity 700ms cubic-bezier(.22,1,.36,1),transform 700ms cubic-bezier(.22,1,.36,1)}
.reveal[style*="--i"]{transition-delay:calc(var(--i,0) * 100ms)}

/* Football goal net background on hero — subtle diagonal crosshatch */
@keyframes goalnet-drift{0%{background-position:0 0}100%{background-position:28px 28px}}
.hero::after{content:'';position:absolute;top:0;right:0;bottom:0;width:40%;background-image:repeating-linear-gradient(45deg,transparent,transparent 14px,rgba(0,85,255,0.02) 14px,rgba(0,85,255,0.02) 15px),repeating-linear-gradient(-45deg,transparent,transparent 14px,rgba(0,85,255,0.02) 14px,rgba(0,85,255,0.02) 15px);pointer-events:none;z-index:0}
@media(prefers-reduced-motion:no-preference){.hero::after{animation:goalnet-drift 20s linear infinite}}

/* Table scroll fade hint on mobile */
@media(max-width:640px){
  .table-scroll{position:relative}
  .table-scroll::after{content:'';position:sticky;right:0;top:0;bottom:0;width:24px;min-height:100%;background:linear-gradient(to right,transparent,rgba(240,244,255,0.9));pointer-events:none;float:right;margin-top:-100%;display:block}
}

/* ============================================================
   REDUCED MOTION: all enhanced effects
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  .cancel-tier,.faq-item,.contact-card,.camp-card,.team-card,.pricing-card,.testimonial-card,.stat-item,.trust-badge,.news-item{transition:none !important;transform:none !important;animation:none !important}
  .team-card::before,.hero::after{animation:none !important}
  .nav-desktop a::before{transition:none !important}
}

.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}

/* 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; }

/* 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);
}


/* 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;
}

/* footer-contrast-guard */
.site-footer, footer, .footer {
  border-top: 1px solid rgba(255,255,255,0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
  position: relative;
}
.site-footer::before, footer::before, .footer::before {
  content:'';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 64px; height: 2px;
  background: currentColor;
  opacity: 0.35;
  border-radius: 2px;
}
@media (prefers-color-scheme: light) {
  .site-footer, footer, .footer { border-top: 1px solid rgba(0,0,0,0.10); }
}

