/* ═══════════════════════════════════════════════════
   WHITE PILATES — styles.css
   ═══════════════════════════════════════════════════ */

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html,body{overflow-x:hidden;max-width:100vw;margin:0}
body{font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-weight:400;font-size:1rem;line-height:1.7;color:var(--ink);background:var(--bg)}
img,picture,video,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}
button{cursor:pointer;border:none;background:none}
html.no-js .reveal{opacity:1;transform:none}

/* --- Custom Properties --- */
:root{
  --bg:#F7F3F9;--surface:#FFFFFF;--surface-2:#F0EBF3;
  --ink:#3A2E44;--ink-soft:#6B5E78;
  --accent:#B07AA1;--accent-2:#D4A9C7;
  --line:rgba(58,46,68,0.12);--line-strong:rgba(58,46,68,0.25);
  --header-h:72px;
  --container-pad:clamp(16px,4vw,32px);
  interpolate-size:allow-keywords;
}
@media(max-width:768px){:root{--header-h:64px}}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:Georgia,'Noto Serif','Times New Roman',serif;font-weight:700;line-height:1.25;color:var(--ink)}
h1{font-size:clamp(2.25rem,5vw,4.5rem);letter-spacing:-0.012em}
h2{font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:-0.01em}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
h4{font-size:1.1rem}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}
strong{font-weight:700}

/* --- Skip Link --- */
.skip-link{position:absolute;top:-100%;left:16px;z-index:9999;padding:8px 20px;background:var(--ink);color:var(--surface);border-radius:0 0 8px 8px;font-size:.875rem;transition:top .2s}
.skip-link:focus{top:0}

/* --- Layout --- */
.container{width:100%;max-width:1180px;margin:0 auto;padding-inline:var(--container-pad)}
.section{padding:clamp(3.5rem,8vw,7rem) 0}
main section[id]{scroll-margin-top:calc(var(--header-h) + 16px)}

/* --- Eyebrow / Title --- */
.section__eyebrow,.hero__eyebrow{display:block;font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.section__title{margin-bottom:clamp(2rem,4vw,3.5rem)}

/* --- Buttons --- */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;background:var(--ink);color:var(--surface);font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-weight:600;font-size:.95rem;border-radius:6px;border:2px solid var(--ink);transition:background 240ms cubic-bezier(.2,.7,.2,1),color 240ms,transform 180ms,box-shadow 240ms}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--accent);color:var(--surface);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(176,122,161,.4),0 0 0 1px rgba(176,122,161,.1)}
.btn-primary:active{transform:translateY(0)}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;background:transparent;color:var(--ink);font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-weight:600;font-size:.95rem;border-radius:6px;border:2px solid var(--line-strong);transition:background 240ms cubic-bezier(.2,.7,.2,1),color 240ms,transform 180ms,border-color 240ms}
.btn-ghost:hover,.btn-ghost:focus-visible{background:var(--surface);color:var(--ink);border-color:var(--accent)}
.btn-ghost:active{transform:translateY(0)}

/* --- Focus Ring --- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:4px}

/* ═══════════════ HEADER ═══════════════ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1080;background:rgba(247,243,249,.88);transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease}
.site-header.scrolled{background:var(--bg);box-shadow:0 8px 24px -16px rgba(58,46,68,.18)}
.scroll-progress{position:absolute;bottom:0;left:0;height:2px;background:var(--accent);width:0;transition:none;pointer-events:none;z-index:1}
.site-header.scrolled .header__inner{height:56px}
@media(max-width:768px){.site-header.scrolled .header__inner{height:52px}}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:16px;transition:height 240ms ease}
.header__logo{font-family:Georgia,'Noto Serif','Times New Roman',serif;font-weight:700;font-size:1.25rem;color:var(--ink);white-space:nowrap;letter-spacing:-0.01em}

/* --- Nav Desktop --- */
.nav-desktop{display:none;align-items:center;gap:clamp(16px,2.5vw,32px)}
@media(min-width:1025px){.nav-desktop{display:flex}}
.nav-desktop a{position:relative;font-size:.9rem;font-weight:600;color:var(--ink);padding:4px 0;transition:color 240ms}
.nav-desktop a::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:center;transition:transform 280ms cubic-bezier(.2,.7,.2,1)}
.nav-desktop a:hover{color:var(--accent)}
.nav-desktop a:hover::after,.nav-desktop a.is-active::after{transform:scaleX(1)}
.nav-desktop .nav-cta{padding:10px 22px;background:var(--ink);color:var(--surface);border-radius:6px;font-size:.85rem;border:2px solid var(--ink);transition:background 240ms,color 240ms,border-color 240ms}
.nav-desktop .nav-cta::after{display:none}
.nav-desktop .nav-cta:hover,.nav-desktop .nav-cta:focus-visible{background:var(--accent);color:var(--surface);border-color:var(--accent)}

/* --- Nav Toggle (Hamburger) --- */
.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:48px;height:48px;padding:10px;z-index:1100;position:relative;-webkit-tap-highlight-color:transparent;border-radius:8px;transition:background 200ms;border:1.5px solid var(--line)}
.nav-toggle:hover{background:rgba(58,46,68,.08);border-color:var(--accent)}
@media(min-width:1025px){.nav-toggle{display:none}}
.nav-toggle span{display:block;width:100%;height:3px;background:var(--ink);border-radius:2px;transition:transform 320ms cubic-bezier(.2,.7,.2,1),opacity 240ms}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* --- Mobile Drawer --- */
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1040;opacity:0;pointer-events:none;transition:opacity 240ms}
.drawer-backdrop.is-open{opacity:1;pointer-events:auto}
.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(360px,92vw);background:var(--surface);z-index:1050;transform:translateX(100%);transition:transform 320ms cubic-bezier(.2,.7,.2,1);padding:calc(var(--header-h) + 24px) 28px 28px;overflow-y:auto}
.mobile-drawer.is-open{transform:translateX(0)}
.mobile-drawer nav{display:flex;flex-direction:column;gap:4px}
.mobile-drawer a{display:block;padding:14px 16px;font-size:1rem;font-weight:600;color:var(--ink);border-radius:8px;transition:background 200ms,color 200ms}
.mobile-drawer a:hover,.mobile-drawer a.is-active{background:rgba(176,122,161,.08);color:var(--accent)}
.mobile-drawer .btn-primary{margin-top:16px;text-align:center}
.drawer-close{position:absolute;top:16px;right:16px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--ink);border-radius:8px;transition:background 200ms cubic-bezier(.2,.7,.2,1),color 200ms;z-index:1}
.drawer-close:hover{background:rgba(58,46,68,.08);color:var(--accent)}
@media(min-width:1025px){.drawer-close{display:none}}

/* ═══════════════ MAIN ═══════════════ */
main{padding-top:var(--header-h)}

/* ═══════════════ HERO ═══════════════ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:-10%;background:url('../images/hero-studio.jpg') center/cover no-repeat;animation:heroZoom 12s ease-in-out infinite alternate;will-change:transform}
@keyframes heroZoom{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(170deg,rgba(58,46,68,.62) 0%,rgba(58,46,68,.78) 50%,rgba(58,46,68,.48) 100%)}
.hero__content{position:relative;z-index:2;padding:clamp(3rem,8vw,6rem) 0;max-width:680px}
.hero__eyebrow{color:rgba(255,255,255,.9);margin-bottom:16px;text-shadow:0 1px 8px rgba(58,46,68,.3)}
.hero__title{color:#fff;margin-bottom:20px;text-shadow:0 2px 32px rgba(58,46,68,.55),0 0 80px rgba(58,46,68,.35)}
.hero__sub{color:rgba(255,255,255,.92);font-size:clamp(1rem,2vw,1.25rem);line-height:1.7;margin-bottom:32px;text-shadow:0 1px 16px rgba(58,46,68,.35)}
.hero__cta{font-size:1rem;padding:16px 36px;transition:background 240ms cubic-bezier(.2,.7,.2,1),color 240ms,transform 180ms,box-shadow 240ms}
.hero__cta:hover{box-shadow:0 14px 32px -8px rgba(176,122,161,.5),0 0 0 1px rgba(176,122,161,.15)}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.trust-badge{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid rgba(255,255,255,.3);border-radius:100px;font-size:.78rem;font-weight:600;color:rgba(255,255,255,.88);transition:border-color 240ms}
.trust-badge:hover{border-color:rgba(255,255,255,.6)}
.trust-badge svg{width:16px;height:16px;flex-shrink:0}

/* --- Hero Breathing Pulse (Pilates-specific) --- */
.hero__breath{position:absolute;right:8%;bottom:20%;width:clamp(120px,18vw,220px);height:clamp(120px,18vw,220px);border-radius:50%;border:1.5px solid rgba(212,169,199,.35);animation:breathePulse 8s ease-in-out infinite;pointer-events:none;z-index:1}
@keyframes breathePulse{0%,100%{transform:scale(1);opacity:.4;border-color:rgba(212,169,199,.3)}50%{transform:scale(1.18);opacity:.7;border-color:rgba(176,122,161,.5)}}

/* ═══════════════ STATS STRIP ═══════════════ */
.stats-strip{background:var(--ink);color:var(--surface);padding:clamp(2rem,4vw,3rem) 0}
.stats-strip__inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:24px;text-align:center}
@media(max-width:640px){.stats-strip__inner{grid-template-columns:repeat(2,1fr);gap:20px}}
.stat-item{padding:8px 0}
.stat-number{display:block;font-family:'Cascadia Code',Consolas,'Courier New',monospace;font-size:clamp(2.2rem,5vw,3.2rem);font-weight:700;color:var(--accent-2);line-height:1.1;margin-bottom:4px}
.stat-label{font-size:.85rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.8}

/* ═══════════════ STORY (Hikaye) ═══════════════ */
.story-section{background:var(--surface)}
.story-grid{display:grid;grid-template-columns:1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
@media(min-width:768px){.story-grid{grid-template-columns:1.2fr .8fr}}
.story-text{font-size:clamp(.95rem,1.5vw,1.1rem);line-height:1.85;color:var(--ink-soft)}
.story-text p{margin-bottom:1.5em}
.story-image{position:relative;border-radius:12px;overflow:hidden}
.story-image img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform 600ms cubic-bezier(.2,.7,.2,1)}
.story-image:hover img{transform:scale(1.04)}
.story-image::after{content:'';position:absolute;inset:0;border:1px solid var(--line);border-radius:12px;pointer-events:none}
@media(min-width:768px){.story-image{margin-top:48px}}

/* --- Pull Quote --- */
.pull-quote{font-family:Georgia,'Noto Serif','Times New Roman',serif;font-weight:700;font-style:italic;font-size:clamp(1.35rem,3vw,2rem);color:var(--accent);border-left:3px solid var(--accent-2);padding:1rem 0 1rem 2rem;margin:2.5rem 0;line-height:1.5}

/* ═══════════════ FELSEFE (Philosophy) ═══════════════ */
.felsefe-section{background:var(--bg)}
.felsefe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2.5rem)}
@media(max-width:768px){.felsefe-grid{grid-template-columns:1fr;gap:24px}}
.felsefe-card{background:var(--surface);border-radius:14px;padding:clamp(24px,3vw,36px);border:1px solid var(--line);transition:transform 420ms cubic-bezier(.22,.61,.36,1),box-shadow 420ms cubic-bezier(.22,.61,.36,1),border-color 420ms}
.felsefe-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px -12px rgba(176,122,161,.32),0 0 0 1px rgba(176,122,161,.12);border-color:rgba(176,122,161,.18)}
.felsefe-icon{width:48px;height:48px;margin-bottom:20px;color:var(--accent);animation:gentleStretch 10s ease-in-out infinite}
.felsefe-icon svg{width:100%;height:100%}
@keyframes gentleStretch{0%,100%{transform:scaleY(1);opacity:.85}50%{transform:scaleY(1.06);opacity:1}}
@media(max-width:640px){.felsefe-icon{width:36px;height:36px}}
.felsefe-title{margin-bottom:12px}
.felsefe-text{color:var(--ink-soft);font-size:.92rem;line-height:1.7}

/* ═══════════════ PROCESS (Timeline) ═══════════════ */
.process-section{background:var(--surface)}
.timeline{position:relative;padding-left:52px;max-width:740px}
.timeline::before{content:'';position:absolute;left:18px;top:14px;bottom:14px;width:2px;background:linear-gradient(180deg,var(--accent-2),var(--accent),var(--accent-2))}
.timeline__step{position:relative;padding-bottom:clamp(32px,4vw,52px)}
.timeline__step:last-child{padding-bottom:0}
.timeline__marker{position:absolute;left:-52px;top:2px;width:36px;height:36px;border-radius:50%;background:var(--surface);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;z-index:1;transition:box-shadow 400ms}
.timeline__step.is-in .timeline__marker{animation:markerBreathe 3s ease-in-out .3s 1}
.timeline__num{font-family:'Cascadia Code',Consolas,'Courier New',monospace;font-size:.8rem;font-weight:700;color:var(--accent)}
.timeline__badge{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);background:rgba(176,122,161,.1);padding:3px 12px;border-radius:100px;margin-bottom:8px}
.timeline__content h3{margin-bottom:6px}
.timeline__content p{color:var(--ink-soft);font-size:.92rem;line-height:1.7}

/* ═══════════════ TESTIMONIALS ═══════════════ */
.testimonials-section{background:var(--bg)}
.testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.5rem,3vw,2rem)}
@media(max-width:768px){.testimonials-grid{grid-template-columns:1fr}}
.testimonial-card{background:var(--surface);border-radius:14px;padding:clamp(24px,3vw,36px);border:1px solid var(--line);transition:transform 420ms cubic-bezier(.22,.61,.36,1),box-shadow 420ms cubic-bezier(.22,.61,.36,1),border-color 420ms}
.testimonial-card:hover{transform:translateY(-6px) rotate(.3deg);box-shadow:0 20px 48px -12px rgba(176,122,161,.3),0 0 0 1px rgba(176,122,161,.1);border-color:rgba(176,122,161,.18)}
.testimonial-card:nth-child(even):hover{transform:translateY(-6px) rotate(-.3deg);box-shadow:0 20px 48px -12px rgba(176,122,161,.3),0 0 0 1px rgba(176,122,161,.1)}
.testimonial-card blockquote{font-size:.95rem;line-height:1.8;color:var(--ink-soft);margin-bottom:20px;font-style:italic;position:relative;padding-left:20px;border-left:2px solid var(--accent-2)}
.testimonial-author{display:flex;flex-direction:column;gap:2px}
.testimonial-author strong{font-size:.9rem;color:var(--ink)}
.testimonial-author span{font-size:.8rem;color:var(--ink-soft)}

/* ═══════════════ PRICING ═══════════════ */
.pricing-section{background:var(--surface)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.5vw,2rem);align-items:start}
@media(max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}}
.price-card{background:var(--bg);border-radius:14px;padding:clamp(24px,3vw,36px);border:1px solid var(--line);text-align:center;transition:transform 420ms cubic-bezier(.22,.61,.36,1),box-shadow 420ms cubic-bezier(.22,.61,.36,1),border-color 420ms}
.price-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px -12px rgba(176,122,161,.3),0 0 0 1px rgba(176,122,161,.1);border-color:rgba(176,122,161,.18)}
.price-card--featured{background:var(--ink);color:var(--surface);border-color:var(--ink);position:relative}
.price-card--featured .price-card__name{color:var(--accent-2)}
.price-card--featured .price-card__freq,.price-card--featured .price-card__includes li,.price-card--featured .price-card__excludes li,.price-card--featured .pricing-note{color:rgba(255,255,255,.75)}
.price-card--featured .price-card__price{color:var(--surface)}
.price-card--featured .price-card__amount{color:var(--surface)}
.price-card--featured .btn-primary{background:var(--accent);color:var(--surface);border-color:var(--accent)}
.price-card--featured .btn-primary:hover,.price-card--featured .btn-primary:focus-visible{background:var(--accent-2);color:var(--ink);border-color:var(--accent-2)}
.price-card--featured .price-card__includes li::before{color:var(--accent-2)}
.price-card--featured::before{content:'Popüler';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--surface);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 16px;border-radius:100px}
.price-card__name{font-family:Georgia,'Noto Serif','Times New Roman',serif;font-size:1.3rem;margin-bottom:6px}
.price-card__freq{font-size:.85rem;color:var(--ink-soft);margin-bottom:16px}
.price-card__price{margin-bottom:24px}
.price-card__amount{font-family:'Cascadia Code',Consolas,'Courier New',monospace;font-size:clamp(2rem,4vw,2.8rem);font-weight:700;color:var(--ink)}
.price-card__currency{font-size:1rem;color:var(--ink-soft);margin-left:4px}
.price-card__includes,.price-card__excludes{text-align:left;margin-bottom:16px}
.price-card__includes li,.price-card__excludes li{position:relative;padding-left:24px;font-size:.88rem;line-height:1.6;color:var(--ink-soft)}
.price-card__includes li::before{content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700}
.price-card__excludes li::before{content:'—';position:absolute;left:0;color:var(--ink-soft)}
.price-card .btn-primary{width:100%;margin-top:8px}
.pricing-disclaimer{text-align:center;font-size:.82rem;color:var(--ink-soft);margin-top:clamp(1.5rem,3vw,2.5rem);font-style:italic}
.pricing-note{font-size:.8rem;color:var(--ink-soft);margin-top:8px;text-align:left;font-style:italic}

/* ═══════════════ FAQ ACCORDION ═══════════════ */
.faq-section{background:var(--bg)}
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);margin-bottom:0}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:clamp(16px,2.5vw,22px) 0;cursor:pointer;font-family:Georgia,'Noto Serif','Times New Roman',serif;font-weight:700;font-size:clamp(.95rem,1.8vw,1.1rem);color:var(--ink);list-style:none;transition:color 240ms}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none;content:''}
.faq-item summary::after{content:'';width:20px;height:20px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B07AA1' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E") center/contain no-repeat;transition:transform 360ms cubic-bezier(.4,0,.2,1)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--accent)}
.faq-item .answer{height:0;padding:0 clamp(0px,3vw,4px);overflow:hidden;transition:height 360ms cubic-bezier(.4,0,.2,1),padding-block-end 360ms cubic-bezier(.4,0,.2,1)}
.faq-item[open] .answer{height:auto;padding-block-end:26px}
.faq-item .answer p{color:var(--ink-soft);font-size:.92rem;line-height:1.8}
@media(prefers-reduced-motion:reduce){.faq-item .answer{transition:none}}

/* ═══════════════ FORM ═══════════════ */
.form-section{background:var(--surface)}
.contact-form{max-width:680px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px}
.field--full{grid-column:1/-1}
.field--check{grid-column:1/-1;flex-direction:row;align-items:flex-start;gap:10px}
.field__label{font-size:.85rem;font-weight:600;color:var(--ink)}
.field input[type="text"],.field input[type="email"],.field input[type="tel"],.field select,.field textarea{width:100%;padding:12px 16px;border:1.5px solid var(--line-strong);border-radius:8px;background:var(--bg);font-size:.92rem;transition:border-color 240ms,box-shadow 240ms}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(176,122,161,.15);outline:none}
.field textarea{resize:vertical;min-height:100px}
.field select{appearance:auto;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)}
.field--check span{font-size:.85rem;color:var(--ink-soft);line-height:1.5}
.contact-form .btn-primary{margin-top:12px;width:100%}
@media(min-width:641px){.contact-form .btn-primary{width:auto}}

/* ═══════════════ FOOTER ═══════════════ */
.site-footer{background:var(--ink);color:rgba(255,255,255,.8);padding:clamp(3rem,6vw,5rem) 0 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(24px,4vw,40px);padding-bottom:clamp(2.5rem,4vw,4rem)}
@media(max-width:900px){.footer__grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:540px){.footer__grid{grid-template-columns:1fr;gap:28px}}
.footer__logo{display:block;font-family:Georgia,'Noto Serif','Times New Roman',serif;font-size:1.2rem;color:#fff;margin-bottom:12px}
.footer__brand p{font-size:.88rem;line-height:1.7;margin-bottom:16px}
.footer__social{display:flex;gap:12px}
.footer__social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.7);transition:color 240ms,border-color 240ms,background 240ms}
.footer__social a:hover{color:#fff;border-color:var(--accent);background:rgba(176,122,161,.15)}
.footer__social a svg{width:18px;height:18px}
.footer__grid h4{font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.footer__nav a,.footer__contact p,.footer__hours p{display:block;font-size:.88rem;line-height:1.8}
.footer__nav a{transition:color 240ms;padding:2px 0}
.footer__nav a:hover{color:var(--accent-2)}
.footer__contact p{word-break:break-word;overflow-wrap:anywhere}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px}
@media(max-width:640px){.footer__bottom{flex-direction:column;text-align:center}}
.footer__bottom p{font-size:.8rem;opacity:.6}
.footer__legal{display:flex;flex-wrap:wrap;gap:16px}
.footer__legal a{font-size:.8rem;opacity:.6;transition:opacity 240ms}
.footer__legal a:hover{opacity:1}

/* ═══════════════ COOKIE BANNER ═══════════════ */
.cookie-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:520px;margin:0 auto;background:var(--surface);border-radius:14px;padding:24px;box-shadow:0 16px 48px -8px rgba(58,46,68,.2);border:1px solid var(--line);transform:translateY(140%);opacity:0;transition:transform 280ms cubic-bezier(.2,.7,.2,1),opacity 240ms;z-index:10000}
@media(max-width:767px){.cookie-banner{bottom:0;left:0;right:0;max-width:100%;border-radius:14px 14px 0 0;padding:20px 16px}}
@media(min-width:768px){.cookie-banner{left:24px;right:auto;max-width:420px}}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner p{font-size:.85rem;line-height:1.6;color:var(--ink-soft);margin-bottom:8px}
.cookie-banner p:last-of-type{margin-bottom:16px}
.cookie-banner a{color:var(--accent);text-decoration:underline}
.cookie-banner__actions{display:flex;flex-wrap:wrap;gap:8px}
.cookie-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-weight:600;font-size:.85rem;border-radius:6px;min-height:48px;min-width:48px;cursor:pointer;transition:background 280ms cubic-bezier(.16,1,.3,1),color 280ms,transform 200ms,box-shadow 280ms,border-color 280ms}
.cookie-btn[data-consent="accept"]{background:var(--ink);color:var(--surface);border:2px solid var(--ink)}
.cookie-btn[data-consent="accept"]:hover,.cookie-btn[data-consent="accept"]:focus-visible{background:var(--accent);color:var(--surface);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(176,122,161,.4)}
.cookie-btn[data-consent="reject"]{background:transparent;border:1.5px solid var(--line-strong);color:var(--ink-soft);font-weight:600}
.cookie-btn[data-consent="reject"]:hover,.cookie-btn[data-consent="reject"]:focus-visible{background:var(--surface-2);color:var(--ink);border-color:var(--ink)}
.cookie-btn[data-consent="settings"]{background:transparent;border:1.5px solid var(--line-strong);color:var(--ink);font-weight:600}
.cookie-btn[data-consent="settings"]:hover,.cookie-btn[data-consent="settings"]:focus-visible{background:var(--surface);color:var(--ink);border-color:var(--accent)}

/* ═══════════════ BREATHING WAVE (Right Edge) ═══════════════ */
.breath-wave{position:fixed;right:0;top:0;width:28px;height:100vh;z-index:10;pointer-events:none;opacity:.3;overflow:hidden}
.breath-wave svg{width:100%;min-height:200vh;will-change:transform;transition:none}
@media(max-width:768px){.breath-wave{display:none}}

/* ═══════════════ HAIRLINE DIVIDERS ═══════════════ */
.hairline{border:0;border-top:1px solid var(--line);margin:0}

/* ═══════════════ PAGE BANNER (sub-pages) ═══════════════ */
.page-banner{padding:clamp(2.5rem,6vw,4rem) 0;background:var(--ink);color:var(--surface);text-align:center}
.page-banner .section__eyebrow{color:var(--accent-2)}
.page-banner h1{color:#fff;font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:8px}
.page-banner p{color:rgba(255,255,255,.7);font-size:.95rem}

/* ═══════════════ CONTACT PAGE LAYOUT ═══════════════ */
.iletisim-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
@media(max-width:768px){.iletisim-grid{grid-template-columns:1fr;gap:2rem}}

/* ═══════════════ CONTACT CHANNELS (iletisim) ═══════════════ */
.contact-channels{display:flex;flex-direction:column;gap:18px;max-width:540px}
.contact-row{display:grid;grid-template-columns:28px 1fr;gap:14px;align-items:start;padding:8px 0;border-radius:8px;transition:background 280ms cubic-bezier(.22,.61,.36,1)}
.contact-row:hover{background:var(--surface-2)}
.contact-row:hover .contact-icon{color:var(--accent);transform:scale(1.08)}
.contact-row:hover .contact-detail{transform:none}
.contact-icon{color:var(--ink-soft);transition:color 280ms cubic-bezier(.22,.61,.36,1),transform 280ms cubic-bezier(.22,.61,.36,1);padding-top:2px}
.contact-icon svg{width:20px;height:20px}
.contact-detail{transition:transform 280ms cubic-bezier(.22,.61,.36,1)}
.contact-detail strong{display:block;font-size:.85rem;color:var(--ink);margin-bottom:2px}
.contact-detail p,.contact-detail a{font-size:.92rem;color:var(--ink-soft);line-height:1.6;word-break:break-word;overflow-wrap:anywhere}
.contact-detail a{transition:color 240ms}
.contact-detail a:hover{color:var(--accent)}

/* ═══════════════ TEAM GRID ═══════════════ */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:clamp(1.5rem,3vw,2rem)}
.team-card{text-align:center;background:var(--surface);border-radius:14px;padding:clamp(16px,2vw,24px);border:1px solid var(--line);transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms cubic-bezier(.2,.7,.2,1),border-color 280ms}
.team-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px -12px rgba(176,122,161,.3),0 0 0 1px rgba(176,122,161,.1);border-color:rgba(176,122,161,.18)}
.team-card__photo{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:14px;margin-bottom:16px;background:var(--surface-2);transition:transform 600ms cubic-bezier(.16,1,.3,1)}
.team-card:hover .team-card__photo{transform:scale(1.03)}
.team-card__name{font-family:Georgia,'Noto Serif','Times New Roman',serif;font-size:1.1rem;margin-bottom:4px}
.team-card__role{font-size:.82rem;color:var(--accent);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}
.team-card__bio{font-size:.88rem;color:var(--ink-soft);line-height:1.7;text-align:left}

/* ═══════════════ POLICY PAGES ═══════════════ */
.policy-content{max-width:740px;margin:0 auto;padding:clamp(2rem,4vw,4rem) 0;line-height:1.7}
.policy-content h2{margin:clamp(2rem,4vw,3rem) 0 1rem}
.policy-content h3{margin:1.5rem 0 .75rem;font-size:1.1rem}
.policy-content p{color:var(--ink-soft);margin-bottom:1.2em;font-size:.94rem}
.policy-content ul{margin:1em 0;padding-left:24px}
.policy-content li{color:var(--ink-soft);font-size:.94rem;line-height:1.7;margin-bottom:.5em;position:relative;padding-left:16px}
.policy-content li::before{content:'•';position:absolute;left:0;color:var(--accent)}

/* ═══════════════ 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%;border-collapse:collapse}
.table-scroll th,.table-scroll td{padding:12px 16px;text-align:left;font-size:.88rem;border-bottom:1px solid var(--line)}
.table-scroll th{background:var(--surface-2);font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}
.table-scroll td{color:var(--ink-soft)}
:where(*:has(>.table-scroll),*:has(>*>.table-scroll),*:has(>*>*>.table-scroll)){min-width:0}

/* ═══════════════ 404 PAGE ═══════════════ */
.page-404{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem var(--container-pad)}
.page-404 h1{font-size:clamp(4rem,12vw,8rem);color:var(--accent-2);margin-bottom:8px}
.page-404 p{color:var(--ink-soft);margin-bottom:24px}

/* ═══════════════ THANK-YOU PAGE ═══════════════ */
.thank-you{min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem var(--container-pad)}
.thank-you h1{margin-bottom:12px}
.thank-you p{color:var(--ink-soft);margin-bottom:28px;max-width:480px}

/* ═══════════════ SITEMAP PAGE ═══════════════ */
.sitemap-list{max-width:600px;margin:0 auto}
.sitemap-list li{padding:8px 0;border-bottom:1px solid var(--line)}
.sitemap-list a{font-size:.95rem;color:var(--ink);transition:color 240ms}
.sitemap-list a:hover{color:var(--accent)}

/* ═══════════════ PILATES-SPECIFIC ANIMATIONS ═══════════════ */
@keyframes spineDraw{from{stroke-dashoffset:200}to{stroke-dashoffset:0}}
.spine-draw{stroke-dasharray:200;stroke-dashoffset:200}
.spine-draw.is-in{animation:spineDraw 1.2s cubic-bezier(.4,0,.2,1) forwards}

@keyframes balanceSway{0%,100%{transform:rotate(-.5deg)}50%{transform:rotate(.5deg)}}
@keyframes markerBreathe{0%,100%{box-shadow:0 0 0 0 rgba(176,122,161,.2)}50%{box-shadow:0 0 0 8px rgba(176,122,161,0)}}

/* ═══════════════ HERO ENTRANCE (load-based, not scroll) ═══════════════ */
.hero-enter{opacity:0;transform:translateY(28px)}
html.js .hero-enter{animation:heroEnter 900ms cubic-bezier(.22,.61,.36,1) forwards;animation-delay:calc(var(--i,0)*130ms + 350ms)}
@keyframes heroEnter{0%{opacity:0;transform:translateY(28px)}100%{opacity:1;transform:none}}
html.no-js .hero-enter{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.hero-enter,html.js .hero-enter{animation:none!important;opacity:1!important;transform:none!important}}

/* ═══════════════ REVEAL ═══════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 700ms cubic-bezier(.22,.61,.36,1),transform 700ms cubic-bezier(.22,.61,.36,1);transition-delay:calc(var(--i,0)*100ms)}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .team-card,.felsefe-card,.testimonial-card,.price-card,.team-card__photo,.story-image img,.story-image,.contact-row,.contact-icon,.trust-badge,.btn-primary,.btn-ghost,.stat-number,.footer__nav a,.faq-item summary{transition:none!important}
  .team-card:hover,.felsefe-card:hover,.testimonial-card:hover,.price-card:hover,.contact-row:hover,.trust-badge:hover,.btn-primary:hover,.btn-ghost:hover,.footer__nav a:hover,.faq-item summary:hover{transform:none!important;box-shadow:none!important;animation:none!important}
  .stat-item:hover .stat-number{transform:none!important}
  .timeline__step.is-in .timeline__marker{animation:none!important}
}
html.no-js .reveal{opacity:1;transform:none}

/* ═══════════════ RESPONSIVE ═══════════════ */
@media(max-width:1024px){
  .hero__content{max-width:100%}
}
@media(max-width:768px){
  .hero{min-height:85vh}
  .hero__breath{display:none}
}
@media(max-width:640px){
  .hero__trust{flex-direction:column;align-items:flex-start}
  .trust-badge{font-size:.72rem}
  .testimonials-grid{gap:16px}
  .felsefe-icon{width:36px;height:36px}
  .timeline{padding-left:44px}
  .timeline::before{left:14px}
  .timeline__marker{left:-44px;width:30px;height:30px}
  .footer__bottom{gap:16px}
}
@media(max-width:430px){
  .hero__title{font-size:2.2rem}
  .trust-badge{padding:5px 10px;font-size:.7rem}
  .price-card{padding:20px}
  .btn-primary,.btn-ghost{padding:12px 24px;font-size:.88rem}
}
@media(max-width:360px){
  .hero__title{font-size:2rem}
  .stat-number{font-size:2rem}
}

/* ═══════════════ PILATES MICRO-EFFECTS ═══════════════ */
@keyframes breathGlow{0%,100%{box-shadow:0 0 0 0 rgba(176,122,161,0)}50%{box-shadow:0 0 20px 2px rgba(176,122,161,.12)}}
.hero__cta.breathe:not(:hover):not(:focus-visible){animation:breathGlow 4s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.hero__cta.breathe{animation:none!important}}

.felsefe-card:hover .felsefe-icon{animation:none;transform:scale(1.1);transition:transform 400ms cubic-bezier(.22,.61,.36,1)}

.story-image img{transition:transform 700ms cubic-bezier(.22,.61,.36,1)}

.team-card__photo{transition:transform 700ms cubic-bezier(.22,.61,.36,1),box-shadow 420ms}
.team-card:hover .team-card__photo{transform:scale(1.03);box-shadow:0 12px 32px -8px rgba(176,122,161,.2)}

.footer__social a{transition:color 280ms cubic-bezier(.22,.61,.36,1),border-color 280ms,background 280ms,transform 280ms}
.footer__social a:hover{transform:scale(1.1)}

/* ═══════════════ CSS VISIBILITY FALLBACK ═══════════════ */
@keyframes revealFallback{to{opacity:1;transform:none}}
html.js .reveal:not(.is-in){animation:revealFallback 600ms cubic-bezier(.22,.61,.36,1) both;animation-delay:calc(var(--i,0)*80ms + 2.2s)}
html.js .hero-enter:not(.is-in){animation:heroEnter 900ms cubic-bezier(.22,.61,.36,1) forwards,revealFallback 600ms both;animation-delay:calc(var(--i,0)*130ms + 350ms),calc(var(--i,0)*80ms + 2.5s)}
@media(prefers-reduced-motion:reduce){
  html.js .reveal:not(.is-in),html.js .hero-enter:not(.is-in){animation:none!important;opacity:1!important;transform:none!important}
}

/* ═══════════════ ENHANCED STAGGER & MICRO-EFFECTS ═══════════════ */
.felsefe-card{transition:transform 480ms cubic-bezier(.16,1,.3,1),box-shadow 480ms cubic-bezier(.16,1,.3,1),border-color 480ms}
.felsefe-card:hover{transform:translateY(-8px);box-shadow:0 24px 56px -12px rgba(176,122,161,.35),0 0 0 1px rgba(176,122,161,.14);border-color:rgba(176,122,161,.2)}
.testimonial-card{transition:transform 480ms cubic-bezier(.16,1,.3,1),box-shadow 480ms cubic-bezier(.16,1,.3,1),border-color 480ms}
.testimonial-card:hover{transform:translateY(-8px) rotate(.4deg);box-shadow:0 24px 56px -12px rgba(176,122,161,.32),0 0 0 1px rgba(176,122,161,.12);border-color:rgba(176,122,161,.2)}
.testimonial-card:nth-child(even):hover{transform:translateY(-8px) rotate(-.4deg)}
.price-card{transition:transform 480ms cubic-bezier(.16,1,.3,1),box-shadow 480ms cubic-bezier(.16,1,.3,1),border-color 480ms}
.price-card:hover{transform:translateY(-8px);box-shadow:0 24px 56px -12px rgba(176,122,161,.32),0 0 0 1px rgba(176,122,161,.12);border-color:rgba(176,122,161,.2)}

.timeline__step{transition:opacity 500ms cubic-bezier(.22,.61,.36,1)}
.timeline__step.is-in .timeline__marker{animation:markerBreathe 3s ease-in-out .3s 1,markerGlow 600ms cubic-bezier(.16,1,.3,1) .2s both}
@keyframes markerGlow{from{box-shadow:0 0 0 0 rgba(176,122,161,.3)}to{box-shadow:0 0 0 4px rgba(176,122,161,0)}}

.contact-row{transition:background 320ms cubic-bezier(.16,1,.3,1),transform 320ms cubic-bezier(.16,1,.3,1)}
.contact-row:hover{transform:translateX(4px)}
.contact-icon{transition:color 320ms cubic-bezier(.16,1,.3,1),transform 320ms cubic-bezier(.16,1,.3,1)}

.trust-badge{transition:border-color 280ms,background 280ms,transform 280ms cubic-bezier(.16,1,.3,1)}
.trust-badge:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.08);transform:translateY(-1px)}

.faq-item summary{transition:color 280ms,padding-left 280ms}
.faq-item summary:hover{color:var(--accent);padding-left:4px}

.btn-primary{transition:background 280ms cubic-bezier(.16,1,.3,1),color 280ms,transform 200ms cubic-bezier(.16,1,.3,1),box-shadow 280ms,border-color 280ms}
.btn-primary:hover,.btn-primary:focus-visible{transform:translateY(-3px);box-shadow:0 14px 32px -8px rgba(176,122,161,.45),0 0 0 1px rgba(176,122,161,.12)}

.btn-ghost{transition:background 280ms cubic-bezier(.16,1,.3,1),color 280ms,transform 200ms cubic-bezier(.16,1,.3,1),border-color 280ms,box-shadow 280ms}
.btn-ghost:hover,.btn-ghost:focus-visible{transform:translateY(-2px);box-shadow:0 8px 20px -6px rgba(58,46,68,.1)}

@keyframes pilatesFlow{0%,100%{border-radius:14px}50%{border-radius:18px 10px 18px 10px}}
.felsefe-card:hover{animation:pilatesFlow 1.2s ease-in-out}
@media(prefers-reduced-motion:reduce){.felsefe-card:hover{animation:none}}

.story-image{transition:box-shadow 600ms cubic-bezier(.16,1,.3,1)}
.story-image:hover{box-shadow:0 20px 48px -12px rgba(176,122,161,.2)}

.stat-number{transition:transform 400ms cubic-bezier(.16,1,.3,1)}
.stat-item:hover .stat-number{transform:scale(1.08)}

.footer__nav a{transition:color 280ms,transform 280ms cubic-bezier(.16,1,.3,1)}
.footer__nav a:hover{color:var(--accent-2);transform:translateX(3px)}

/* ═══════════════ PRINT ═══════════════ */
@media print{
  .site-header,.nav-toggle,.mobile-drawer,.drawer-backdrop,.cookie-banner,.breath-wave,.hero__breath,.hero__bg,.hero__overlay{display:none!important}
  body{background:#fff;color:#000;font-size:11pt}
  .section{padding:1.5rem 0}
  main{padding-top:0}
  a{color:#000;text-decoration:underline}
  .btn-primary,.btn-ghost{border:1px solid #000;background:none;color:#000}
  .reveal,.hero-enter{opacity:1!important;transform:none!important;animation:none!important}
}
