:root {
  --bg: #FAF6F1;
  --surface: #FFFFFF;
  --surface-2: #F3EDE4;
  --ink: #2C2418;
  --ink-soft: #6B5D4C;
  --accent: #7A8B6F;
  --accent-2: #C4622D;
  --line: rgba(44,36,24,0.12);
  --line-strong: rgba(44,36,24,0.25);
  --header-h: 72px;
  --container: 1180px;
  --pad: clamp(1.5rem,5vw,4rem);
  --radius: 10px;
  interpolate-size: allow-keywords;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  overflow-x:hidden;
  max-width:100vw;
}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:'Karla',system-ui,sans-serif;
  font-weight:400;
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.72;
  letter-spacing:-0.01em;
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
  max-width:100vw;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;transition:color 240ms}
a:hover{color:var(--accent-2)}
button{font:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

h1,h2,h3,h4,h5,h6{
  font-family:'Lora',Georgia,serif;
  font-weight:600;
  line-height:1.18;
  letter-spacing:-0.012em;
  color:var(--ink);
}

h1{font-size:clamp(2.4rem, 6vw, 4.5rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h3{font-size:clamp(1.2rem,2vw,1.6rem)}
h4{font-size:clamp(1rem,1.4vw,1.2rem)}

.eyebrow{
  font-family:'Karla',sans-serif;
  font-size:clamp(11px,0.85vw,13px);
  font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--accent);
  display:block;
  margin-bottom:14px;
}

/* ---- Scroll margin for anchor sections ---- */
section[id]{scroll-margin-top:calc(var(--header-h) + 16px)}

/* ---- Long URL / email break ---- */
a[href^="mailto:"],a[href^="tel:"]{word-break:break-word;overflow-wrap:anywhere}

/* ---- CTA block (replaces inline forms) ---- */
.cta-block{
  text-align:center;
  padding:clamp(48px,8vw,80px) 0;
}
.cta-block h2{margin-bottom:14px}
.cta-block p{color:var(--ink-soft);max-width:520px;margin:0 auto 28px;font-size:clamp(15px,1.2vw,18px);line-height:1.65}
.btn--primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;
  background:var(--ink);color:var(--surface);
  font-family:'Karla',sans-serif;font-weight:700;font-size:15px;
  letter-spacing:0.04em;text-transform:uppercase;
  border-radius:6px;border:2px solid var(--ink);
  transition:background 240ms,color 240ms,transform 200ms,box-shadow 200ms;
  text-decoration:none;
}
.btn--primary:hover,.btn--primary:focus-visible{
  background:var(--accent-2);color:var(--surface);
  border-color:var(--accent-2);
  transform:translateY(-2px);
  box-shadow:0 6px 20px -6px rgba(196,98,45,0.35);
}

/* ---- Skip link ---- */
.skip-link{
  position:fixed;top:-100%;left:16px;
  background:var(--ink);color:var(--surface);
  padding:10px 20px;border-radius:0 0 6px 6px;
  font-size:14px;font-weight:700;z-index:10000;
  transition:top 200ms;
}
.skip-link:focus{top:0}

/* ---- Container ---- */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding-inline:clamp(16px,4vw,32px);
}

/* ---- Buttons ---- */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;
  background:var(--ink);color:var(--surface);
  font-family:'Karla',sans-serif;font-weight:700;font-size:15px;
  letter-spacing:0.04em;text-transform:uppercase;
  border-radius:6px;border:2px solid var(--ink);
  transition:background 240ms,color 240ms,transform 200ms,box-shadow 200ms;
}
.btn-primary:hover,.btn-primary:focus-visible{
  background:var(--accent-2);color:var(--surface);
  border-color:var(--accent-2);
  transform:translateY(-2px);
  box-shadow:0 6px 20px -6px rgba(196,98,45,0.35);
}
.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn-primary svg{width:18px;height:18px;transition:transform 200ms}
.btn-primary:hover svg{transform:translateX(3px)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 28px;
  background:transparent;color:var(--ink);
  font-family:'Karla',sans-serif;font-weight:700;font-size:15px;
  letter-spacing:0.02em;
  border:2px solid var(--line-strong);border-radius:6px;
  transition:background 240ms,color 240ms,border-color 240ms,transform 200ms;
}
.btn-ghost:hover,.btn-ghost:focus-visible{
  background:var(--surface);color:var(--ink);
  border-color:var(--ink);transform:translateY(-2px);
}
.btn-ghost: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(250, 246, 241, 0.92);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease;
  padding:0;
}
.site-header.scrolled{
  background:rgba(250,246,241,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);
}
.header__logo{
  display:flex;align-items:center;gap:10px;
  font-family:'Lora',Georgia,serif;font-weight:600;font-size:20px;
  color:var(--ink);letter-spacing:-0.02em;
  text-decoration:none;
}
.header__logo:hover{color:var(--ink)}
.header__logo svg{width:32px;height:32px;flex-shrink:0}

/* Nav desktop */
.nav-desktop{display:none}
@media(min-width:1024px){
  .nav-desktop{
    display:flex;align-items:center;gap:28px;
    font-size:14px;font-weight:500;
  }
  .nav-desktop a{
    position:relative;color:var(--ink);transition:color 240ms;
    padding:4px 0;
  }
  .nav-desktop a::after{
    content:'';position:absolute;bottom:0;left:0;right:0;
    height:2px;background:var(--accent-2);
    transform:scaleX(0);transform-origin:right;
    transition:transform 280ms cubic-bezier(.2,.7,.2,1);
  }
  .nav-desktop a:hover::after,
  .nav-desktop a.is-active::after{transform:scaleX(1);transform-origin:left}
  .nav-desktop a:hover{color:var(--accent-2)}
  .nav-desktop a.is-active{color:var(--accent-2)}
  .nav-desktop .nav-cta{
    padding:10px 22px;
    background:var(--ink);color:var(--surface);
    border-radius:6px;font-weight:700;
    letter-spacing:0.03em;text-transform:uppercase;font-size:13px;
  }
  .nav-desktop .nav-cta::after{display:none}
  .nav-desktop .nav-cta:hover{
    background:var(--accent-2);color:var(--surface);
  }
  .nav-desktop .nav-cta.is-active{color:var(--surface)}
}

/* Nav toggle */
.nav-toggle{
  display:flex;flex-direction:column;justify-content:center;
  gap:5px;width:44px;height:44px;padding:10px;
  z-index:1100;position:relative;
  border-radius:6px;
  transition:background 200ms;
}
.nav-toggle:hover{background:rgba(44,36,24,0.06)}
.nav-toggle span{
  display:block;width:24px;height:2.5px;
  background:var(--ink);border-radius:2px;
  transition:transform 300ms cubic-bezier(.2,.7,.2,1),opacity 200ms;
  transform-origin:center;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
@media(min-width:1024px){.nav-toggle{display:none}}

/* ---- Drawer ---- */
.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(--surface);
  transform:translateX(100%);
  transition:transform 320ms cubic-bezier(.2,.7,.2,1);
  padding:calc(var(--header-h) + 24px) var(--pad) var(--pad);
  overflow-y:auto;
}
.drawer.is-open{transform:translateX(0)}
.drawer a{
  display:block;padding:14px 0;
  font-family:'Lora',Georgia,serif;font-weight:600;font-size:18px;
  color:var(--ink);border-bottom:1px solid var(--line);
  transition:color 240ms,padding-left 240ms;
}
.drawer a:hover,.drawer a.is-active{color:var(--accent-2);padding-left:8px}
.drawer .drawer-cta{
  display:block;margin-top:24px;text-align:center;
  padding:14px 24px;background:var(--ink);color:var(--surface);
  border-radius:6px;font-weight:700;
  letter-spacing:0.03em;text-transform:uppercase;font-size:14px;
  border-bottom:none;font-family:'Karla',sans-serif;
}
.drawer .drawer-cta:hover{background:var(--accent-2);color:var(--surface);padding-left:0}

/* ---- Main ---- */
main{padding-top:var(--header-h)}

/* ---- Section base ---- */
.section{
  padding:clamp(60px,10vw,120px) 0;
  position:relative;
}
.section--lined{
  border-top:1px solid var(--line);
}
.section__head{
  max-width:680px;margin-bottom:clamp(36px,6vw,64px);
}
.section__head h2{margin-bottom:14px}
.section__head p{color:var(--ink-soft);font-size:clamp(15px,1.1vw,17px)}

/* ---- Hero ---- */
.hero{
  position:relative;
  min-height:clamp(480px,85vh,900px);
  display:flex;align-items:flex-end;
  overflow:hidden;
}
.hero__bg{
  position:absolute;inset:0;z-index:0;
}
.hero__bg img{
  width:100%;height:100%;object-fit:cover;
  animation:heroZoom 12s ease-out forwards;
}
@keyframes heroZoom{
  from{transform:scale(1.06)}
  to{transform:scale(1)}
}
@media(prefers-reduced-motion:reduce){
  .hero__bg img{animation:none}
}
.hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to top,
    rgba(44,36,24,0.82) 0%,
    rgba(44,36,24,0.45) 40%,
    rgba(44,36,24,0.15) 70%,
    transparent 100%
  );
}
.hero__content{
  position:relative;z-index:2;
  max-width:var(--container);
  margin:0 auto;
  padding:clamp(40px,8vw,80px) var(--pad) clamp(48px,8vw,80px);
  width:100%;
}
.hero__content .eyebrow{color:var(--accent);opacity:0;animation:heroFadeUp 700ms 200ms forwards}
.hero__content h1{
  color:#FFFFFF;margin-bottom:18px;
  font-size:clamp(2.8rem, 7vw, 4.5rem);
  letter-spacing:-0.02em;
  max-width:12ch;
  opacity:0;animation:heroFadeUp 700ms 400ms forwards;
}
.hero__content .hero__sub{
  color:rgba(255,255,255,0.85);
  font-size:clamp(16px,1.3vw,20px);
  max-width:540px;line-height:1.65;
  margin-bottom:28px;
  opacity:0;animation:heroFadeUp 700ms 600ms forwards;
}
.hero__content .btn-primary{
  opacity:0;animation:heroFadeUp 700ms 800ms forwards;
  background:#FFFFFF;color:var(--ink);border-color:#FFFFFF;
}
.hero__content .btn-primary:hover{
  background:var(--accent-2);color:#FFFFFF;border-color:var(--accent-2);
}
@keyframes heroFadeUp{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:none}
}
@media(prefers-reduced-motion:reduce){
  .hero__content .eyebrow,
  .hero__content h1,
  .hero__content .hero__sub,
  .hero__content .btn-primary,
  .trust-strip{
    animation:none;opacity:1;
  }
}

/* Trust strip */
.trust-strip{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:28px;
  opacity:0;animation:heroFadeUp 700ms 1000ms forwards;
}
.trust-strip span{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:40px;
  color:rgba(255,255,255,0.9);
  font-size:12px;font-weight:700;
  letter-spacing:0.04em;text-transform:uppercase;
}
.trust-strip span svg{width:14px;height:14px;opacity:0.8}

/* ---- Stats ---- */
.stats{
  padding:clamp(40px,6vw,72px) 0;
  background:var(--ink);
  position:relative;
}
.stats__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  text-align:center;
}
.stat__number{
  font-family:'Lora',Georgia,serif;font-weight:600;
  font-size:clamp(2rem,4vw,3.2rem);
  color:#FFFFFF;
  font-variant-numeric:tabular-nums;
  line-height:1.1;
}
.stat__label{
  color:rgba(255,255,255,0.6);
  font-size:13px;font-weight:500;
  margin-top:6px;letter-spacing:0.04em;
  text-transform:uppercase;
}
@media(max-width:640px){
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:32px 16px}
}

/* ---- Ball trace ---- */
.ball-trace{
  position:absolute;
  left:clamp(16px,4vw,60px);
  top:0;
  width:60px;
  height:100%;
  pointer-events:none;
  z-index:0;
  opacity:0.18;
}
.ball-trace path{
  fill:none;
  stroke:var(--accent);
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  stroke-dasharray:var(--trace-len,3000);
  stroke-dashoffset:var(--trace-offset,3000);
  transition:stroke-dashoffset 60ms linear;
}
.ball-trace circle{
  fill:var(--accent);
  opacity:0;
  transition:opacity 300ms;
}
.ball-trace circle.is-in{opacity:1}
@media(max-width:768px){.ball-trace{display:none}}

/* ---- Hikaye (story) ---- */
.story{position:relative}
.story__body{
  max-width:720px;
  margin:0 auto;
}
.story__body p{
  font-size:clamp(16px,1.2vw,18px);
  line-height:1.8;
  color:var(--ink);
  margin-bottom:28px;
}
.story__body p:first-of-type::first-letter{
  font-family:'Lora',Georgia,serif;
  font-weight:600;
  font-size:3.6em;
  float:left;
  line-height:0.85;
  margin:4px 12px 0 0;
  color:var(--accent-2);
}

/* Pull quote */
.pull-quote{
  position:relative;
  margin:clamp(40px,6vw,72px) 0;
  padding:clamp(28px,4vw,48px) 0 clamp(28px,4vw,48px) clamp(28px,4vw,48px);
  border-left:3px solid var(--accent-2);
}
.pull-quote p{
  font-family:'Lora',Georgia,serif;
  font-weight:600;
  font-style:italic;
  font-size:clamp(1.3rem,2.6vw,2rem);
  line-height:1.45;
  color:var(--ink);
  margin-bottom:0;
}
.pull-quote p::first-letter{
  font-size:inherit;float:none;margin:0;
}
.pull-quote cite{
  display:block;margin-top:16px;
  font-family:'Karla',sans-serif;font-style:normal;
  font-size:14px;font-weight:500;color:var(--ink-soft);
}

/* ---- Metod (timeline) ---- */
.metod-timeline{
  max-width:800px;
  margin:0 auto;
  position:relative;
}
.metod-timeline::before{
  content:'';
  position:absolute;
  left:28px;top:0;bottom:0;
  width:2px;
  background:var(--line);
}
.metod-step{
  position:relative;
  padding-left:76px;
  padding-bottom:clamp(48px,8vw,80px);
}
.metod-step:last-child{padding-bottom:0}
.metod-step__num{
  position:absolute;left:0;top:0;
  width:56px;height:56px;
  border-radius:50%;
  background:var(--surface);
  border:2px solid var(--accent);
  display:flex;align-items:center;justify-content:center;
  z-index:1;
}
.metod-step__num svg{width:24px;height:24px;color:var(--accent)}
.metod-step h3{margin-bottom:10px;color:var(--accent-2)}
.metod-step p{color:var(--ink-soft);max-width:560px;line-height:1.72}
.metod-step__img{
  margin-top:20px;
  border-radius:var(--radius);overflow:hidden;
  max-width:clamp(280px,60%,480px);
}

/* ---- Dersler (pricing) ---- */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;
}
.pricing-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(28px,4vw,40px);
  position:relative;
  transition:transform 300ms cubic-bezier(.2,.7,.2,1),box-shadow 300ms;
}
.pricing-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 40px -12px rgba(122,139,111,0.18);
}
.pricing-card--featured{border-color:var(--accent-2);border-width:2px}
.pricing-card--featured::before{
  content:'Popüler';
  position:absolute;top:-12px;right:24px;
  background:var(--accent-2);color:#FFFFFF;
  padding:4px 14px;border-radius:20px;
  font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
}
.pricing-card__icon{
  width:48px;height:48px;
  border-radius:50%;
  background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
}
.pricing-card__icon svg{width:22px;height:22px;color:var(--accent)}
.pricing-card h3{margin-bottom:6px}
.pricing-card__desc{color:var(--ink-soft);font-size:14px;margin-bottom:20px}
.pricing-card__price{
  font-family:'Lora',Georgia,serif;font-weight:600;
  font-size:clamp(1.8rem,3vw,2.4rem);
  color:var(--ink);
  margin-bottom:4px;
}
.pricing-card__price small{
  font-size:14px;font-weight:400;
  font-family:'Karla',sans-serif;
  color:var(--ink-soft);
}
.pricing-card__includes{margin-top:20px;padding-top:20px;border-top:1px solid var(--line)}
.pricing-card__includes h4{
  font-family:'Karla',sans-serif;font-weight:700;font-size:12px;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);
  margin-bottom:10px;
}
.pricing-card__includes li{
  display:flex;align-items:flex-start;gap:8px;
  font-size:14px;line-height:1.55;
  padding:5px 0;color:var(--ink);
}
.pricing-card__includes li svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--accent)}
.pricing-card__excludes{margin-top:14px}
.pricing-card__excludes h4{
  font-family:'Karla',sans-serif;font-weight:700;font-size:12px;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-soft);
  margin-bottom:10px;
}
.pricing-card__excludes li{
  display:flex;align-items:flex-start;gap:8px;
  font-size:14px;line-height:1.55;
  padding:5px 0;color:var(--ink-soft);
}
.pricing-card__excludes li svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--ink-soft);opacity:0.5}
.pricing-card .btn-primary,.pricing-card .btn-ghost{
  width:100%;justify-content:center;margin-top:24px;
}
.pricing-disclaimer{
  text-align:center;margin-top:28px;
  font-size:13px;color:var(--ink-soft);
  font-style:italic;
}

/* ---- Dönüşüm (testimonials) ---- */
.testimonials-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(20px,3vw,32px);
}
.testimonial{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(24px,3vw,36px);
  position:relative;
  transition:transform 300ms cubic-bezier(.2,.7,.2,1),box-shadow 300ms;
}
.testimonial:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px -8px rgba(122,139,111,0.15);
}
.testimonial:first-child{grid-column:1/-1}
.testimonial__quote{
  font-family:'Lora',Georgia,serif;
  font-style:italic;font-weight:600;
  font-size:clamp(15px,1.1vw,17px);
  line-height:1.65;color:var(--ink);
  margin-bottom:20px;
  position:relative;
  padding-left:24px;
}
.testimonial__quote::before{
  content:'\201C';
  position:absolute;left:0;top:-6px;
  font-size:3rem;line-height:1;
  color:var(--accent);
  font-family:'Lora',Georgia,serif;
}
.testimonial__author{
  font-size:13px;font-weight:700;
  color:var(--ink);
}
.testimonial__meta{
  font-size:12px;color:var(--ink-soft);
  margin-top:2px;
}
@media(max-width:768px){
  .testimonials-grid{grid-template-columns:1fr}
  .testimonial:first-child{grid-column:auto}
}

/* ---- Süreç (process) ---- */
.process-steps{
  max-width:800px;margin:0 auto;
  position:relative;
}
.process-steps::before{
  content:'';position:absolute;
  left:23px;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom,var(--accent),var(--accent-2));
  opacity:0.3;
}
.process-step{
  display:grid;
  grid-template-columns:46px 1fr;
  gap:20px;
  padding-bottom:clamp(32px,5vw,56px);
  align-items:start;
}
.process-step:last-child{padding-bottom:0}
.process-step__dot{
  width:46px;height:46px;
  border-radius:50%;
  background:var(--surface);
  border:2px solid var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:'Lora',Georgia,serif;font-weight:600;
  font-size:16px;color:var(--accent);
  position:relative;z-index:1;
  transition:background 300ms,color 300ms;
}
.process-step:hover .process-step__dot{background:var(--accent);color:var(--surface)}
.process-step h4{margin-bottom:4px}
.process-step p{color:var(--ink-soft);font-size:14px;line-height:1.65}
.process-step__time{
  display:inline-block;margin-top:6px;
  font-size:12px;font-weight:700;
  color:var(--accent-2);
  letter-spacing:0.06em;text-transform:uppercase;
  background:rgba(196,98,45,0.08);
  padding:3px 10px;border-radius:20px;
}

/* ---- FAQ ---- */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;
  font-family:'Lora',Georgia,serif;font-weight:600;
  font-size:clamp(15px,1.1vw,17px);
  cursor:pointer;
  list-style:none;
  transition:color 240ms;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none}
.faq-item summary:hover{color:var(--accent-2)}
.faq-item summary .faq-icon{
  width:28px;height:28px;flex-shrink:0;
  border-radius:50%;
  background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;
  transition:transform 320ms cubic-bezier(.2,.7,.2,1),background 240ms;
}
.faq-item summary .faq-icon svg{
  width:14px;height:14px;color:var(--ink-soft);
  transition:transform 320ms cubic-bezier(.2,.7,.2,1);
}
.faq-item[open] summary .faq-icon{background:var(--accent);transform:rotate(0)}
.faq-item[open] summary .faq-icon svg{color:#FFFFFF;transform:rotate(180deg)}
.faq-item > .faq-body{
  height:0;
  padding:0 0;
  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:24px;
}
.faq-item .faq-body p{
  color:var(--ink-soft);font-size:15px;line-height:1.72;
  max-width:640px;
}
@media(prefers-reduced-motion:reduce){
  .faq-item > .faq-body{transition:none}
}

/* ---- Randevu (form) ---- */
.randevu-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,64px);
  align-items:start;
}
.randevu-info{padding-top:8px}
.randevu-info h3{margin-bottom:16px}
.randevu-info p{color:var(--ink-soft);line-height:1.72;margin-bottom:20px}
.randevu-info__detail{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 0;
  font-size:14px;
}
.randevu-info__detail svg{width:18px;height:18px;color:var(--accent);flex-shrink:0;margin-top:2px}
.randevu-info__detail strong{display:block;margin-bottom:2px}
.randevu-info__detail span{color:var(--ink-soft)}

.form{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(24px,4vw,40px);
}
.form__row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:16px;
}
.form__row--full{grid-template-columns:1fr}
.field{margin-bottom:0}
.field label{
  display:block;
  font-size:13px;font-weight:700;
  letter-spacing:0.04em;text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:6px;
}
.field input,.field select,.field textarea{
  width:100%;
  padding:12px 16px;
  background:var(--bg);
  border:2px solid var(--line);
  border-radius:6px;
  font:inherit;font-size:15px;
  color:var(--ink);
  transition:border-color 240ms,box-shadow 240ms;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(122,139,111,0.12);
}
.field textarea{min-height:120px;resize:vertical}
.field select{cursor:pointer}

.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);
}

.kvkk{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13px;line-height:1.55;
  color:var(--ink-soft);
  margin:20px 0;
  cursor:pointer;
}
.kvkk a{color:var(--accent-2);text-decoration:underline}

.form .btn-primary{width:100%;justify-content:center;margin-top:8px}
.honeypot{position:absolute;left:-9999px;opacity:0}

@media(max-width:768px){
  .randevu-grid{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
}

/* ---- Kort Notları (news) ---- */
.news-list{max-width:680px;margin:0 auto}
.news-item{
  padding:20px 0;
  border-bottom:1px solid var(--line);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:16px;
  align-items:start;
}
.news-item__date{
  font-family:'Lora',Georgia,serif;font-weight:600;
  font-size:13px;color:var(--accent-2);
  white-space:nowrap;
  padding-top:2px;
}
.news-item h4{font-size:15px;margin-bottom:4px}
.news-item p{font-size:14px;color:var(--ink-soft);line-height:1.6}

/* ---- Capacity / availability ---- */
.capacity-bar{
  max-width:680px;margin:32px auto 0;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px 24px;
  display:flex;align-items:center;gap:16px;
}
.capacity-bar__fill{
  flex:1;height:8px;
  background:var(--surface-2);
  border-radius:4px;overflow:hidden;
}
.capacity-bar__fill span{
  display:block;height:100%;width:87%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  border-radius:4px;
  animation:capacityGrow 1200ms cubic-bezier(.2,.7,.2,1) forwards;
  transform-origin:left;
}
@keyframes capacityGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@media(prefers-reduced-motion:reduce){
  .capacity-bar__fill span{animation:none}
}
.capacity-bar__label{
  font-size:13px;font-weight:700;color:var(--ink);
  white-space:nowrap;
}

/* ---- Cancellation mini ---- */
.cancel-tiers{
  margin-top:28px;
  padding:20px 24px;
  background:var(--surface-2);
  border-radius:var(--radius);
}
.cancel-tiers h4{
  font-family:'Karla',sans-serif;font-weight:700;font-size:13px;
  letter-spacing:0.06em;text-transform:uppercase;color:var(--accent);
  margin-bottom:12px;
}
.cancel-tiers li{
  display:flex;align-items:center;gap:8px;
  font-size:14px;padding:5px 0;color:var(--ink-soft);
}
.cancel-tiers li strong{color:var(--ink);min-width:110px}

/* ---- Section divider (line + ball motif) ---- */
.divider{
  display:flex;align-items:center;justify-content:center;
  padding:0;margin:0 auto;
  max-width:var(--container);
}
.divider::before,.divider::after{
  content:'';flex:1;height:1px;background:var(--line);
}
.divider svg{
  width:18px;height:18px;margin:0 16px;
  color:var(--accent);opacity:0.5;
  flex-shrink:0;
}

/* ---- Footer ---- */
.site-footer{
  background:var(--ink);
  color:rgba(255,255,255,0.7);
  padding:clamp(48px,8vw,80px) 0 0;
}
.footer__grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(24px,4vw,48px);
  padding-bottom:clamp(40px,6vw,60px);
}
.footer__brand{
  font-family:'Lora',Georgia,serif;font-weight:600;font-size:22px;
  color:#FFFFFF;margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.footer__brand svg{width:28px;height:28px}
.footer__desc{font-size:14px;line-height:1.65;max-width:320px;margin-bottom:20px}
.footer__social{display:flex;gap:12px}
.footer__social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.2);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.7);
  transition:background 240ms,color 240ms,border-color 240ms;
}
.footer__social a:hover{
  background:var(--accent-2);border-color:var(--accent-2);color:#FFFFFF;
}
.footer__social a svg{width:16px;height:16px}

.footer__col h4{
  font-family:'Karla',sans-serif;font-weight:700;font-size:12px;
  letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);
  margin-bottom:16px;
}
.footer__col a{
  display:block;padding:5px 0;
  font-size:14px;color:rgba(255,255,255,0.7);
  transition:color 240ms,padding-left 240ms;
}
.footer__col a:hover{color:#FFFFFF;padding-left:4px}
.footer__col p{font-size:14px;line-height:1.6;padding:3px 0}
.footer__col .contact-line{
  display:flex;align-items:flex-start;gap:10px;
  padding:5px 0;font-size:14px;
}
.footer__col .contact-line svg{width:16px;height:16px;flex-shrink:0;margin-top:3px;opacity:0.5}
.footer__col .contact-line a{display:inline;padding:0}

.footer__bottom{
  border-top:1px solid rgba(255,255,255,0.1);
  padding:20px 0;
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:space-between;gap:12px;
  font-size:12px;
}
.footer__bottom a{color:rgba(255,255,255,0.5)}
.footer__bottom a:hover{color:#FFFFFF}
.footer__legal{display:flex;flex-wrap:wrap;gap:8px 20px}
.footer__vkn{color:rgba(255,255,255,0.35);font-size:11px}

@media(max-width:768px){
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer__grid > :first-child{grid-column:1/-1}
  .footer__bottom{flex-direction:column;text-align:center}
}
@media(max-width:480px){
  .footer__grid{grid-template-columns:1fr}
}

/* ---- Cookie banner ---- */
.cookie-banner{
  position:fixed;
  bottom:16px;left:16px;right:16px;
  max-width:520px;margin:0 auto;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  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;
}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner h4{
  font-family:'Karla',sans-serif;font-weight:700;font-size:14px;
  margin-bottom:8px;color:var(--ink);
}
.cookie-banner p{font-size:13px;color:var(--ink-soft);line-height:1.55;margin-bottom:16px}
.cookie-banner p a{color:var(--accent-2);text-decoration:underline}
.cookie-btns{display:flex;gap:8px;flex-wrap:wrap}
.cookie-btns button{
  padding:10px 18px;border-radius:6px;
  font-size:13px;font-weight:700;
  min-height:44px;
  transition:background 240ms,color 240ms;
}
.cookie-btns .cookie-accept{background:var(--ink);color:var(--surface)}
.cookie-btns .cookie-accept:hover{background:var(--accent-2);color:var(--surface)}
.cookie-btns .cookie-reject{
  background:var(--surface-2);color:var(--ink);
  border:1px solid var(--line-strong);
}
.cookie-btns .cookie-reject:hover{background:var(--line);color:var(--ink)}
.cookie-btns .cookie-settings{
  background:transparent;color:var(--ink-soft);
  border:1px solid var(--line);
}
.cookie-btns .cookie-settings:hover{background:var(--surface-2);color:var(--ink)}
@media(max-width:639px){
  .cookie-banner{
    bottom:8px;left:8px;right:8px;
    padding:16px 18px;
    max-width:none;
  }
  .cookie-btns{gap:6px}
  .cookie-btns button{
    padding:10px 14px;
    min-height:44px;
    min-width:44px;
    font-size:13px;
  }
}
@media(min-width:640px){
  .cookie-banner{left:24px;right:auto;max-width:420px}
}

/* ---- Reveal ---- */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 600ms cubic-bezier(.2,.7,.2,1),
             transform 600ms cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--i,0) * 80ms);
}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
}
html.no-js .reveal{opacity:1;transform:none}

/* ---- Counter animation ---- */
.stat[data-target] .stat__number{
  font-variant-numeric:tabular-nums;
}

/* ---- Tennis ball spin ---- */
@keyframes ballSpin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
.ball-spin{
  display:inline-block;
  animation:ballSpin 8s linear infinite;
}
@media(prefers-reduced-motion:reduce){
  .ball-spin{animation:none}
}

/* ---- Tennis racket swing on CTA hover ---- */
@keyframes racketSwing{
  0%{transform:rotate(0deg)}
  30%{transform:rotate(-15deg)}
  60%{transform:rotate(8deg)}
  100%{transform:rotate(0deg)}
}
.btn-primary:hover .racket-icon{
  animation:racketSwing 500ms cubic-bezier(.2,.7,.2,1);
}

/* ---- Court line decoration ---- */
.court-line{
  position:relative;
}
.court-line::after{
  content:'';
  position:absolute;
  bottom:-4px;left:0;
  width:100%;height:3px;
  background:var(--accent-2);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 600ms cubic-bezier(.2,.7,.2,1);
}
.court-line.is-in::after{transform:scaleX(1)}

/* ---- Net pattern divider ---- */
.net-divider{
  height:24px;
  background:repeating-linear-gradient(
    90deg,
    transparent,transparent 11px,
    var(--line) 11px,var(--line) 12px
  ),
  repeating-linear-gradient(
    0deg,
    transparent,transparent 11px,
    var(--line) 11px,var(--line) 12px
  );
  opacity:0.5;
  margin:0 auto;
  max-width:var(--container);
}

/* ---- Parallax helper ---- */
.parallax-bg{will-change:transform}

/* ---- Table scroll ---- */
.table-scroll{
  display:block;width:100%;max-width:100%;min-width:0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  margin:18px 0;
  border:1px solid var(--line);
  border-radius:6px;
}
.table-scroll > table{margin:0 !important;min-width:480px;width:100%}
:where(*:has(> .table-scroll),*:has(> * > .table-scroll),*:has(> * > * > .table-scroll)){min-width:0}

table{
  width:100%;border-collapse:collapse;
  font-size:14px;
}
th,td{
  padding:12px 16px;text-align:left;
  border-bottom:1px solid var(--line);
}
th{
  font-weight:700;font-size:12px;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--ink-soft);
  background:var(--surface-2);
}
td{color:var(--ink)}

/* ---- Contact page ---- */
.contact-hero{
  min-height:240px;
  display:flex;align-items:center;
  background:var(--ink);
  padding:clamp(60px,10vw,100px) 0;
}
.contact-hero h1{color:#FFFFFF;margin-bottom:10px}
.contact-hero .eyebrow{color:var(--accent)}
.contact-hero p{color:rgba(255,255,255,0.7);max-width:520px;font-size:clamp(15px,1.2vw,18px)}

.contact-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
  margin-bottom:clamp(40px,6vw,64px);
}
.contact-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  padding:24px;
  transition:transform 300ms cubic-bezier(.2,.7,.2,1),box-shadow 300ms;
}
.contact-card:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 28px -6px rgba(122,139,111,0.18);
}
.contact-card__icon{
  width:48px;height:48px;border-radius:50%;
  background:rgba(122,139,111,0.1);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.contact-card__icon svg{width:20px;height:20px;color:var(--accent)}
.contact-card h4{font-size:14px;margin-bottom:6px}
.contact-card a,.contact-card p{
  font-size:14px;color:var(--ink-soft);line-height:1.55;
  word-break:break-all;overflow-wrap:anywhere;
}
.contact-card a:hover{color:var(--accent-2)}
.contact-card .contact-card__sub{
  font-size:12px;color:var(--ink-soft);opacity:0.7;margin-top:4px;
}

.hours-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
  gap:8px;margin-top:clamp(32px,5vw,48px);
}
.hour-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:8px;padding:14px 16px;text-align:center;
  font-variant-numeric:tabular-nums;
  transition:border-color 240ms;
}
.hour-card--today{border-color:var(--accent-2);background:rgba(196,98,45,0.04)}
.hour-card__day{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-soft);margin-bottom:4px}
.hour-card__time{font-size:14px;font-weight:500;color:var(--ink)}

/* ---- Thank you page ---- */
.thankyou{
  min-height:60vh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:clamp(60px,10vw,120px) var(--pad);
}
.thankyou h1{margin-bottom:16px}
.thankyou p{color:var(--ink-soft);max-width:460px;margin:0 auto 28px}

/* ---- Policy pages ---- */
.policy{padding:clamp(40px,6vw,80px) 0}
.policy h1{margin-bottom:8px}
.policy .policy-date{font-size:13px;color:var(--ink-soft);margin-bottom:clamp(32px,5vw,48px)}
.policy h2{margin-top:clamp(32px,4vw,48px);margin-bottom:14px;font-size:clamp(1.2rem,2vw,1.6rem)}
.policy h3{margin-top:24px;margin-bottom:10px;font-size:clamp(1rem,1.4vw,1.2rem)}
.policy p{margin-bottom:16px;color:var(--ink);line-height:1.75;max-width:760px}
.policy ul{margin-bottom:16px;padding-left:24px;list-style:disc}
.policy ul li{padding:4px 0;font-size:15px;line-height:1.65;color:var(--ink)}

/* ---- 404 page ---- */
.page-404{
  min-height:60vh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:clamp(60px,10vw,120px) var(--pad);
}
.page-404 h1{font-size:clamp(4rem, 12vw, 4.5rem);color:var(--accent);margin-bottom:8px}
.page-404 p{color:var(--ink-soft);margin-bottom:28px}

/* ---- Sitemap page ---- */
.sitemap-page{padding:clamp(40px,6vw,80px) 0}
.sitemap-page h1{margin-bottom:clamp(24px,4vw,40px)}
.sitemap-links{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
}
.sitemap-links section h3{margin-bottom:12px;font-size:1rem;color:var(--accent)}
.sitemap-links section a{
  display:block;padding:5px 0;font-size:14px;
  color:var(--ink-soft);transition:color 240ms;
}
.sitemap-links section a:hover{color:var(--accent-2)}

/* ---- Hakkimizda (about) ---- */
.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
  margin-top:clamp(32px,5vw,48px);
}
.team-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform 300ms cubic-bezier(.2,.7,.2,1),box-shadow 300ms;
}
.team-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px -8px rgba(122,139,111,0.15);
}
.team-card__img{
  aspect-ratio:4/3;
  background:var(--surface-2);
  overflow:hidden;
}
.team-card__img img{width:100%;height:100%;object-fit:cover;transition:transform 500ms}
.team-card:hover .team-card__img img{transform:scale(1.04)}
.team-card__body{padding:20px 24px 24px}
.team-card__body h3{margin-bottom:4px;font-size:1.1rem}
.team-card__body .team-role{
  font-size:13px;font-weight:700;color:var(--accent-2);
  letter-spacing:0.04em;text-transform:uppercase;
  margin-bottom:12px;
}
.team-card__body p{font-size:14px;color:var(--ink-soft);line-height:1.65}

/* ---- Dark band section ---- */
.section--dark{
  background:var(--ink);
  color:rgba(255,255,255,0.8);
}
.section--dark h2,.section--dark h3,.section--dark h4{color:#FFFFFF}
.section--dark .eyebrow{color:var(--accent)}
.section--dark .process-step__dot{
  background:var(--ink);border-color:var(--accent);color:var(--accent);
}
.section--dark .process-step__dot:hover{background:var(--accent);color:var(--ink)}
.section--dark .process-steps::before{opacity:0.15}

/* ---- Focus states ---- */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ---- Responsive ---- */
@media(max-width:1024px){
  :root{--header-h:64px}
  .site-header{
    background:rgba(250,246,241,0.96);
  }
  .site-header.scrolled{
    background:rgba(250,246,241,0.99);
  }
}

@media(max-width:768px){
  .pricing-grid{grid-template-columns:1fr}
  .randevu-grid{grid-template-columns:1fr}
  .process-step{grid-template-columns:40px 1fr;gap:14px}
  .process-step__dot{width:40px;height:40px;font-size:14px}
  .metod-step{padding-left:64px}
  .metod-step__num{width:48px;height:48px}
  .metod-timeline::before{left:24px}
}

@media(max-width:640px){
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:28px 16px}
  .testimonials-grid{grid-template-columns:1fr}
  .testimonial:first-child{grid-column:auto}
  .hours-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:1fr}
  .contact-cards{grid-template-columns:1fr}
}

@media(max-width:480px){
  .footer__grid{grid-template-columns:1fr}
  .pricing-card{padding:24px}
  .trust-strip{gap:8px}
  .trust-strip span{font-size:11px;padding:5px 10px}
}

@media(max-width:390px){
  .btn-primary{padding:12px 24px;font-size:14px}
  .btn-ghost{padding:10px 20px;font-size:14px}
  h1{font-size:clamp(2rem, 8vw, 2.8rem)}
}

/* ---- Enhanced hover & tennis micro-effects ---- */
.pricing-card{will-change:transform}
.pricing-card:hover .pricing-card__icon{
  background:rgba(122,139,111,0.18);
  transition:background 300ms;
}
.pricing-card:hover .pricing-card__icon svg{
  transform:scale(1.12);
  transition:transform 300ms cubic-bezier(.2,.7,.2,1);
}
.pricing-card--featured:hover{
  box-shadow:0 20px 48px -12px rgba(196,98,45,0.22);
}

.contact-card{will-change:transform}
.contact-card:hover .contact-card__icon{
  background:rgba(196,98,45,0.12);
  transition:background 280ms;
}
.contact-card:hover .contact-card__icon svg{
  color:var(--accent-2);
  transform:scale(1.1);
  transition:color 280ms,transform 280ms cubic-bezier(.2,.7,.2,1);
}

.team-card{will-change:transform}

.hour-card{
  transition:border-color 240ms,transform 240ms,box-shadow 240ms;
}
.hour-card:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 16px -4px rgba(122,139,111,0.15);
  border-color:var(--accent);
}

.testimonial{will-change:transform}
.testimonial__quote::before{
  transition:color 300ms;
}
.testimonial:hover .testimonial__quote::before{
  color:var(--accent-2);
}

.faq-item summary{
  transition:color 240ms,padding-left 240ms;
}
.faq-item summary:hover{
  padding-left:4px;
}

.news-item{
  transition:background 240ms;
  border-radius:6px;
  padding-left:8px;padding-right:8px;
  margin-left:-8px;margin-right:-8px;
}
.news-item:hover{
  background:rgba(122,139,111,0.04);
}

.footer__social a{will-change:transform}
.footer__social a:hover{
  transform:translateY(-2px);
}

.btn-primary,.btn-ghost,.btn--primary{
  will-change:transform;
}

.process-step{transition:opacity 200ms}

@keyframes ballBounce{
  0%,100%{transform:translateY(0)}
  40%{transform:translateY(-6px)}
  60%{transform:translateY(-2px)}
}
.stat:hover .stat__number{
  animation:ballBounce 500ms cubic-bezier(.2,.7,.2,1);
}

@keyframes courtGlow{
  from{box-shadow:0 0 0 0 rgba(196,98,45,0.25)}
  to{box-shadow:0 0 0 8px rgba(196,98,45,0)}
}
.btn-primary:focus-visible,.btn--primary:focus-visible{
  animation:courtGlow 600ms ease-out;
}

.metod-step__num svg{
  transition:transform 400ms cubic-bezier(.2,.7,.2,1);
}
.metod-step:hover .metod-step__num svg{
  transform:rotate(8deg) scale(1.1);
}
.metod-step:hover .metod-step__num{
  border-color:var(--accent-2);
  background:rgba(196,98,45,0.06);
  transition:border-color 300ms,background 300ms;
}

.drawer a{
  position:relative;
  overflow:hidden;
}
.drawer a::before{
  content:'';
  position:absolute;left:0;top:50%;
  width:3px;height:0;
  background:var(--accent-2);
  border-radius:2px;
  transform:translateY(-50%);
  transition:height 240ms cubic-bezier(.2,.7,.2,1);
}
.drawer a:hover::before,.drawer a.is-active::before{
  height:60%;
}

.section--dark .process-step:hover .process-step__dot{
  background:var(--accent);color:#FFFFFF;border-color:var(--accent);
  box-shadow:0 0 16px rgba(122,139,111,0.3);
  transition:background 300ms,color 300ms,border-color 300ms,box-shadow 300ms;
}

@media(prefers-reduced-motion:reduce){
  .stat:hover .stat__number{animation:none}
  .btn-primary:focus-visible,.btn--primary:focus-visible{animation:none}
  .pricing-card:hover,.contact-card:hover,.team-card:hover,
  .testimonial:hover,.hour-card:hover{transform:none}
  .footer__social a:hover{transform:none}
  .metod-step:hover .metod-step__num svg{transform:none}
  .faq-item summary:hover{padding-left:0}
  .drawer a::before{display:none}
  .contact-card:hover .contact-card__icon svg{transform:none}
  .pricing-card:hover .pricing-card__icon svg{transform:none}
}

/* ---- Tennis theme: enhanced micro-interactions ---- */
@keyframes serveSweep{
  0%{transform:translateX(-4px) rotate(-2deg);opacity:0}
  50%{transform:translateX(2px) rotate(0.5deg);opacity:1}
  100%{transform:none;opacity:1}
}
.pricing-card--featured:hover .pricing-card__icon svg{
  animation:serveSweep 500ms cubic-bezier(.22,.68,0,1.2);
}

.hero__content .btn-primary{
  position:relative;
  overflow:hidden;
}
.hero__content .btn-primary::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.15) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:none;
}
.hero__content .btn-primary:hover::after{
  transform:translateX(120%);
  transition:transform 600ms cubic-bezier(.22,.68,0,1.2);
}

.process-step__dot{
  transition:background 300ms cubic-bezier(.22,.68,0,1.2),
             color 300ms,
             transform 300ms cubic-bezier(.22,.68,0,1.2),
             box-shadow 300ms;
}
.process-step:hover .process-step__dot{
  transform:scale(1.08);
}

.faq-item[open] summary .faq-icon{
  box-shadow:0 0 0 4px rgba(122,139,111,0.15);
}

.testimonial::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 400ms cubic-bezier(.22,.68,0,1.2);
  border-radius:0 0 var(--radius) var(--radius);
}
.testimonial:hover::after{
  transform:scaleX(1);
}

.contact-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform 350ms cubic-bezier(.22,.68,0,1.2);
  border-radius:var(--radius) var(--radius) 0 0;
}
.contact-card{position:relative;overflow:hidden}
.contact-card:hover::before{
  transform:scaleX(1);
}

.team-card__img::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(44,36,24,0.08) 100%);
  pointer-events:none;
  transition:opacity 400ms;
  opacity:0;
}
.team-card__img{position:relative}
.team-card:hover .team-card__img::after{opacity:1}

.stat{
  transition:transform 300ms cubic-bezier(.22,.68,0,1.2);
}
.stat:hover{
  transform:translateY(-4px);
}

.btn--primary{
  position:relative;
  overflow:hidden;
}
.btn--primary::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.12) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:none;
}
.btn--primary:hover::after{
  transform:translateX(120%);
  transition:transform 600ms cubic-bezier(.22,.68,0,1.2);
}

.capacity-bar__fill span{
  position:relative;
}
.capacity-bar__fill span::after{
  content:'';
  position:absolute;right:0;top:-2px;bottom:-2px;width:4px;
  background:var(--accent-2);
  border-radius:2px;
  box-shadow:0 0 8px rgba(196,98,45,0.4);
  opacity:0;
  animation:capacityPulse 2s ease-in-out 1.2s infinite;
}
@keyframes capacityPulse{
  0%,100%{opacity:0.4;box-shadow:0 0 4px rgba(196,98,45,0.2)}
  50%{opacity:1;box-shadow:0 0 12px rgba(196,98,45,0.5)}
}

@media(prefers-reduced-motion:reduce){
  .pricing-card--featured:hover .pricing-card__icon svg{animation:none}
  .hero__content .btn-primary::after,
  .btn--primary::after{display:none}
  .process-step:hover .process-step__dot{transform:none}
  .testimonial::after{display:none}
  .contact-card::before{display:none}
  .team-card__img::after{display:none}
  .stat:hover{transform:none}
  .capacity-bar__fill span::after{animation:none;display:none}
}

/* ---- Print ---- */
@media print{
  .site-header,.drawer,.drawer-backdrop,.cookie-banner,.nav-toggle,.skip-link{display:none !important}
  body{background:#fff;color:#000;font-size:12pt}
  .hero{min-height:auto;padding:24pt 0}
  .hero__bg,.hero__overlay{display:none}
  .hero__content h1{color:#000}
  .hero__content .hero__sub{color:#333}
  .section{padding:24pt 0}
  .reveal{opacity:1 !important;transform:none !important}
  a{color:#000;text-decoration:underline}
  .ball-trace{display:none}
}

.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;
}

