:root {
  --bg: #F9F5F0;
  --surface: #FFFFFF;
  --ink: #3D3229;
  --accent: #7B9E6B;
  --accent-2: #D4A574;
  --line: rgba(61,50,41,0.13);
  --header-h: 72px;
  --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%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

html,body{overflow-x:hidden;max-width:100vw;margin:0}

body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-weight:400;line-height:1.75;color:var(--ink);
  background:var(--bg);-webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{font-family:'Libre Baskerville',Georgia,'Times New Roman',serif;font-weight:700;line-height:1.25}
h1{font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.15rem,2vw,1.45rem)}

img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;transition:color 240ms cubic-bezier(.4,0,.2,1)}
a:hover{color:var(--accent)}
ul,ol{list-style:none}

.skip-link{
  position:absolute;top:-100%;left:16px;
  background:var(--ink);color:var(--surface);
  padding:10px 18px;border-radius:0 0 6px 6px;
  font-size:.875rem;z-index:9999;
  transition:top .2s;
}
.skip-link:focus{top:0}

.container{
  width:100%;max-width:1180px;
  margin:0 auto;
  padding-left:clamp(16px,4vw,32px);
  padding-right:clamp(16px,4vw,32px);
}

main{padding-top:var(--header-h)}

/* ===== HEADER ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;
  z-index:1080;
  background:rgba(249,245,240,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(249,245,240,0.98);
  box-shadow:0 8px 24px -16px rgba(0,0,0,.18);
}
.site-header.scrolled .header-inner{height:56px}
.site-header.scrolled .logo{font-size:1.1rem}
.site-header.scrolled .logo svg{width:22px;height:22px}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
  max-width:1180px;margin:0 auto;
  padding:0 clamp(16px,4vw,32px);
  transition:height 240ms ease;
}
.logo{
  font-family:'Libre Baskerville',Georgia,serif;font-weight:700;
  font-size:1.25rem;color:var(--ink);
  display:flex;align-items:center;gap:8px;
  z-index:1100;
  transition:font-size 240ms ease;
}
.logo svg{width:28px;height:28px;flex-shrink:0;transition:width 240ms ease,height 240ms ease}

.nav-desktop{display:none}
@media(min-width:1024px){
  .nav-desktop{
    display:flex;align-items:center;gap:clamp(18px,2.5vw,32px);
  }
  .nav-desktop a{
    font-size:.9rem;font-weight:500;
    color:var(--ink);position:relative;
    padding:6px 0;
    transition:color 240ms cubic-bezier(.4,0,.2,1);
  }
  .nav-desktop a::after{
    content:'';position:absolute;bottom:0;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::after,
  .nav-desktop a.is-active::after{transform:scaleX(1)}
  .nav-desktop a.is-active{color:var(--accent)}
  .nav-desktop .nav-cta{
    background:var(--ink);color:var(--surface);
    padding:9px 22px;border-radius:6px;
    font-weight:600;
  }
  .nav-desktop .nav-cta::after{display:none}
  .nav-desktop .nav-cta:hover,
  .nav-desktop .nav-cta:focus-visible{
    background:var(--accent);color:var(--surface);
    box-shadow:0 4px 12px -4px rgba(123,158,107,0.3);
  }
  .nav-toggle{display:none!important}
}

/* Hamburger */
.nav-toggle{
  position:relative;z-index:1100;
  width:44px;height:44px;
  background:rgba(61,50,41,0.04);cursor:pointer;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:5px;
  padding:0;
  border:1.5px solid rgba(61,50,41,0.35);border-radius:8px;
}
.nav-toggle span{
  display:block;width:22px;height:2.5px;
  background:var(--ink);border-radius:2px;
  transition:transform 320ms cubic-bezier(.2,.7,.2,1),opacity 200ms;
}
.nav-toggle:hover,.nav-toggle:focus-visible{
  background:rgba(61,50,41,0.08);border-radius:8px;
  border-color:rgba(61,50,41,0.45);
}
.nav-toggle.is-active{border-color:transparent;background:transparent}
.nav-toggle.is-active span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.is-active span:nth-child(2){opacity:0}
.nav-toggle.is-active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* Mobile drawer */
.drawer-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,0.55);
  opacity:0;visibility:hidden;
  transition:opacity 240ms,visibility 240ms;
  z-index:1040;
}
.drawer-backdrop.is-open{opacity:1;visibility:visible}

.mobile-drawer{
  position:fixed;top:0;right:0;bottom:0;
  width:min(360px,92vw);
  background:var(--bg);
  transform:translateX(100%);
  visibility:hidden;
  transition:transform 320ms cubic-bezier(.2,.7,.2,1),visibility 0ms 320ms;
  z-index:1050;
  padding:calc(var(--header-h) + 24px) 32px 32px;
  display:flex;flex-direction:column;gap:4px;
  overflow-y:auto;
}
.mobile-drawer.is-open{transform:translateX(0);visibility:visible;transition:transform 320ms cubic-bezier(.2,.7,.2,1),visibility 0ms 0ms}
.mobile-drawer a{
  display:block;padding:14px 0;
  font-size:1.05rem;font-weight:500;
  color:var(--ink);border-bottom:1px solid var(--line);
  transition:color 240ms,padding-left 240ms;
}
.mobile-drawer a:hover{color:var(--accent);padding-left:8px}
.mobile-drawer a.is-active{color:var(--accent)}
.mobile-drawer .nav-cta-mobile{
  margin-top:16px;
  background:var(--ink);color:var(--surface);
  text-align:center;border-radius:8px;
  padding:14px 0;font-weight:600;border:none;
}
.mobile-drawer .nav-cta-mobile:hover{
  background:var(--accent);color:var(--surface);
  box-shadow:0 4px 12px -4px rgba(123,158,107,0.3);
}

/* ===== HERO ===== */
.hero{
  text-align:center;
  padding:clamp(48px,8vw,100px) 0 clamp(40px,6vw,80px);
}
.hero .eyebrow{
  font-size:.8rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent);
  margin-bottom:18px;
}
.hero h1{margin-bottom:20px}
.hero .hero-sub{
  max-width:600px;margin:0 auto 32px;
  font-size:clamp(1rem,1.8vw,1.15rem);
  color:rgba(61,50,41,0.72);line-height:1.7;
}
.hero-img-wrap{
  max-width:clamp(900px,90%,1280px);
  margin:0 auto;border-radius:var(--radius);
  overflow:hidden;position:relative;
}
.hero-img-wrap img{
  width:100%;display:block;
  animation:babyBreath 6s ease-in-out infinite;
}
@keyframes babyBreath{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.025)}
}
@media(prefers-reduced-motion:reduce){
  .hero-img-wrap img{animation:none!important}
}
.hero-img-wrap .placeholder-hero{
  width:100%;aspect-ratio:16/9;
  background:linear-gradient(135deg,#e8e0d6 0%,#d4ccc2 100%);
  display:flex;align-items:center;justify-content:center;
  color:rgba(61,50,41,0.35);font-size:.9rem;
}

/* ===== SECTION DIVIDER ===== */
.section{padding:clamp(48px,8vw,96px) 0;position:relative;scroll-margin-top:var(--header-h)}
.section-divider{
  width:80px;height:1px;
  background:var(--line);
  margin:0 auto clamp(32px,5vw,56px);
}
.section .section-eyebrow{
  font-size:.75rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-2);margin-bottom:12px;
}
.section-title{margin-bottom:clamp(20px,3vw,36px)}

/* Leaf decoration */
.leaf-decor{
  position:absolute;opacity:.07;pointer-events:none;
}
.leaf-decor svg{width:120px;height:120px}
.leaf-decor--tl{top:20px;left:-20px;transform:rotate(-15deg)}
.leaf-decor--br{bottom:20px;right:-20px;transform:rotate(165deg)}

/* ===== #hikaye ===== */
.story-grid{
  display:grid;gap:clamp(24px,4vw,48px);
  align-items:start;
}
@media(min-width:768px){
  .story-grid{grid-template-columns:1fr 1fr}
}
.story-text{font-size:clamp(.95rem,1.4vw,1.05rem);line-height:1.85}
.story-text p+p{margin-top:1.2em}
.story-img{
  border-radius:var(--radius);overflow:hidden;
  position:relative;
}
.story-img img{width:100%;aspect-ratio:3/4;object-fit:cover}

/* ===== #galeri — horizontal scroll ===== */
.gallery-strip{
  display:flex;gap:16px;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  padding:8px 0 24px;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;
  scrollbar-color:var(--accent-2) transparent;
}
.gallery-strip::-webkit-scrollbar{height:6px}
.gallery-strip::-webkit-scrollbar-track{background:transparent}
.gallery-strip::-webkit-scrollbar-thumb{background:var(--accent-2);border-radius:3px}
.gallery-item{
  flex:0 0 auto;
  width:clamp(260px,40vw,380px);
  border-radius:var(--radius);overflow:hidden;
  scroll-snap-align:start;
  position:relative;
  transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms,border-color 280ms;
}
.gallery-item:hover{
  transform:translateY(-6px);
  box-shadow:0 14px 36px -8px rgba(212,165,116,0.28),0 0 0 1px rgba(212,165,116,0.12);
  border-color:rgba(212,165,116,0.35);
}
.gallery-item::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center bottom,rgba(212,165,116,0.12) 0%,transparent 70%);
  opacity:0;transition:opacity 400ms cubic-bezier(.2,.7,.2,1);
  pointer-events:none;border-radius:inherit;
}
.gallery-item:hover::after{opacity:1}
.gallery-item img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  transition:transform 400ms cubic-bezier(.2,.7,.2,1);
}
.gallery-item:hover img{transform:scale(1.03)}
.gallery-item .placeholder-gallery{
  width:100%;aspect-ratio:4/5;
  background:linear-gradient(135deg,#e8e0d6 0%,#d4ccc2 100%);
  display:flex;align-items:center;justify-content:center;
  color:rgba(61,50,41,0.3);font-size:.8rem;
}

/* ===== #deneyim — process steps ===== */
.process-steps{
  display:grid;gap:clamp(32px,5vw,56px);
  max-width:900px;margin:0 auto;
}
.process-step{
  display:grid;gap:clamp(20px,3vw,36px);
  align-items:center;
}
@media(min-width:768px){
  .process-step{grid-template-columns:1fr 1fr}
  .process-step:nth-child(even){direction:rtl}
  .process-step:nth-child(even)>*{direction:ltr}
}
.step-content .step-number{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  background:var(--accent);color:var(--surface);
  font-family:'Libre Baskerville',serif;font-weight:700;
  font-size:.95rem;margin-bottom:12px;
  animation:cradleRock 4s ease-in-out infinite;
}
@keyframes cradleRock{
  0%,100%{transform:rotate(0deg)}
  25%{transform:rotate(3deg)}
  75%{transform:rotate(-3deg)}
}
@media(prefers-reduced-motion:reduce){
  .step-content .step-number{animation:none!important}
}
.step-content .step-time{
  font-size:.8rem;font-weight:600;
  color:var(--accent-2);margin-bottom:6px;
  letter-spacing:.06em;
}
.step-content h3{margin-bottom:8px}
.step-img{border-radius:var(--radius);overflow:hidden;position:relative}
.step-img img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform 400ms cubic-bezier(.2,.7,.2,1)}
.process-step:hover .step-img img{transform:scale(1.03)}
.step-img .placeholder-step{
  width:100%;aspect-ratio:4/3;
  background:linear-gradient(135deg,#e8e0d6 0%,#d4ccc2 100%);
  display:flex;align-items:center;justify-content:center;
  color:rgba(61,50,41,0.3);font-size:.8rem;
}

/* ===== #fiyat ===== */
.pricing-list{
  display:grid;gap:clamp(20px,3vw,32px);
  max-width:860px;margin:0 auto;
}
.price-card{
  background:var(--surface);
  border-radius:var(--radius);
  padding:clamp(24px,4vw,40px);
  border:1px solid var(--line);
  transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms,border-color 280ms;
  position:relative;overflow:hidden;
}
.price-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--accent);opacity:0;
  transition:opacity 280ms;
}
.price-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 44px -12px rgba(212,165,116,0.22),0 0 20px -4px rgba(212,165,116,0.08);
  border-color:rgba(212,165,116,0.35);
}
.price-card:hover::before{opacity:1}
.price-card .panel-head{
  display:flex;align-items:baseline;justify-content:space-between;
  flex-wrap:wrap;gap:8px;margin-bottom:16px;
}
.price-card h3{margin:0}
.price-card .price{
  font-family:'Libre Baskerville',serif;font-weight:700;
  font-size:1.4rem;color:var(--accent);
}
.price-card .duration{
  font-size:.85rem;color:rgba(61,50,41,0.6);
  margin-bottom:16px;
}
.price-card .included, .price-card .not-included{margin-bottom:12px}
.price-card .included h4, .price-card .not-included h4{
  font-family:'Inter',sans-serif;font-weight:600;
  font-size:.85rem;margin-bottom:6px;
  color:var(--accent);letter-spacing:.04em;
}
.price-card .not-included h4{color:var(--accent-2)}
.price-card .included li, .price-card .not-included li{
  padding:4px 0 4px 20px;position:relative;
  font-size:.92rem;
}
.price-card .included li::before{
  content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700;
}
.price-card .not-included li::before{
  content:'—';position:absolute;left:0;color:var(--accent-2);
}
.price-card .delivery{
  font-size:.82rem;color:rgba(61,50,41,0.6);
  margin-top:8px;padding-top:12px;
  border-top:1px solid var(--line);
}
.pricing-disclaimer{
  text-align:center;margin-top:24px;
  font-size:.82rem;color:rgba(61,50,41,0.55);
  font-style:italic;
}

/* Star twinkle on pricing */
.price-card .price{position:relative}
.price-card .price::after{
  content:'✦';position:absolute;top:-4px;right:-16px;
  font-size:.6rem;color:var(--accent-2);
  animation:twinkle 3s ease-in-out infinite;
}
@keyframes twinkle{
  0%,100%{opacity:.3;transform:scale(.8)}
  50%{opacity:1;transform:scale(1.2)}
}
@media(prefers-reduced-motion:reduce){
  .price-card .price::after{animation:none!important;opacity:.6}
}

/* ===== #yorumlar ===== */
.testimonials-grid{
  display:grid;gap:clamp(16px,3vw,24px);
}
@media(min-width:768px){
  .testimonials-grid{grid-template-columns:1fr 1fr}
}
.testimonial-card{
  background:var(--surface);
  border-radius:var(--radius);
  padding:clamp(20px,3vw,32px);
  border:1px solid var(--line);
  transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms,border-color 280ms;
}
.testimonial-card:hover{
  transform:translateY(-6px);
  box-shadow:0 12px 32px -8px rgba(212,165,116,0.22),0 0 16px -4px rgba(212,165,116,0.1);
  border-color:rgba(212,165,116,0.35);
}
.testimonial-card blockquote{
  font-size:clamp(.92rem,1.3vw,1rem);
  line-height:1.8;margin-bottom:16px;
  font-style:italic;color:rgba(61,50,41,0.85);
}
.testimonial-card blockquote::before{
  content:'"';font-family:'Libre Baskerville',serif;
  font-size:2.4rem;color:var(--accent);
  line-height:0;vertical-align:-12px;
  margin-right:4px;
}
.testimonial-card .client{font-weight:600;font-size:.88rem}
.testimonial-card .session{
  font-size:.8rem;color:rgba(61,50,41,0.55);
}

/* Heart pulse on testimonial hover */
.testimonial-card .client::before{
  content:'♥';margin-right:6px;display:inline-block;
  color:var(--accent-2);font-size:.7rem;
  animation:heartPulse 2s ease-in-out infinite;
}
@keyframes heartPulse{
  0%,100%{transform:scale(1)}
  15%{transform:scale(1.3)}
  30%{transform:scale(1)}
  45%{transform:scale(1.2)}
  60%,100%{transform:scale(1)}
}
@media(prefers-reduced-motion:reduce){
  .testimonial-card .client::before{animation:none!important}
}

/* ===== FAQ ===== */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 0;cursor:pointer;
  font-weight:600;font-size:clamp(.95rem,1.3vw,1.05rem);
  list-style:none;
  transition:color 240ms,padding-left 240ms cubic-bezier(.2,.7,.2,1);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none;content:''}
.faq-item summary::after{
  content:'+';font-size:1.3rem;font-weight:400;
  color:var(--accent);
  transition:transform 360ms cubic-bezier(.4,0,.2,1);
  flex-shrink:0;margin-left:12px;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--accent);padding-left:4px}
.faq-item .faq-body{
  height:0;
  padding:0 clamp(18px,3vw,28px);
  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:26px;
}
@media(prefers-reduced-motion:reduce){
  .faq-item .faq-body{transition:none}
}
.faq-body p{font-size:.93rem;line-height:1.75;color:rgba(61,50,41,0.8)}

/* ===== CONTACT CHANNELS ===== */
.contact-channels{
  display:grid;gap:0;
}
.contact-row{
  display:grid;grid-template-columns:auto 1fr;gap:14px;
  align-items:start;
  padding:16px 0;border-bottom:1px solid var(--line);
  transition:transform 240ms cubic-bezier(.4,0,.2,1),background 240ms;
  border-radius:4px;
}
.contact-row:hover{
  transform:translateX(4px);
}
.contact-row svg{
  width:20px;height:20px;color:var(--ink);
  transition:color 240ms,transform 240ms;
  margin-top:2px;flex-shrink:0;
}
.contact-row:hover svg{color:var(--accent);transform:scale(1.08)}
.contact-row .label{
  font-weight:600;font-size:.88rem;color:var(--accent-2);
  margin-bottom:2px;
}
.contact-row .value{font-size:.95rem}
.contact-row .value a{
  color:var(--ink);text-decoration:underline;
  text-decoration-color:rgba(61,50,41,0.2);
  text-underline-offset:3px;
  word-break:break-word;overflow-wrap:anywhere;
}
.contact-row .value a:hover{color:var(--accent);text-decoration-color:var(--accent)}

/* ===== FORM ===== */
.contact-form{max-width:640px}
.field{margin-bottom:20px}
.field label{
  display:block;font-weight:600;font-size:.88rem;
  margin-bottom:6px;color:var(--ink);
}
.field label .req{color:var(--accent-2);margin-left:2px}
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field select,
.field textarea{
  width:100%;padding:12px 16px;
  border:1px solid var(--line);
  border-radius:6px;background:var(--surface);
  font-family:'Inter',sans-serif;font-size:.95rem;
  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(123,158,107,0.15);
}
.field textarea{resize:vertical;min-height:120px}
.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);
}
.field-checkbox{
  display:flex;gap:10px;align-items:flex-start;
}
.field-checkbox label{margin-bottom:0;font-weight:400;font-size:.88rem;line-height:1.5}
.field-error{
  font-size:.8rem;color:#c0392b;margin-top:4px;display:none;
}
.field.has-error .field-error{display:block}
.field.has-error input,.field.has-error textarea,.field.has-error select{
  border-color:#c0392b;
}
.form-status{
  padding:16px;border-radius:6px;
  font-size:.92rem;margin-top:16px;display:none;
}
.form-status.is-success{
  display:block;background:rgba(123,158,107,0.12);color:var(--accent);
}
.form-status.is-error{
  display:block;background:rgba(192,57,43,0.08);color:#c0392b;
}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ===== BUTTONS ===== */
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--ink);color:var(--surface);
  padding:14px 32px;border-radius:8px;
  font-family:'Inter',sans-serif;font-weight:600;
  font-size:.95rem;border:none;cursor:pointer;
  transition:background 240ms cubic-bezier(.4,0,.2,1),transform 180ms,box-shadow 240ms,color 240ms;
  min-height:48px;
}
.btn-primary:hover,.btn-primary:focus-visible{
  background:var(--accent);color:var(--surface);
  transform:translateY(-2px);
  box-shadow:0 8px 24px -8px rgba(123,158,107,0.35);
}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}

.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;color:var(--ink);
  padding:13px 30px;border-radius:8px;
  font-family:'Inter',sans-serif;font-weight:600;
  font-size:.95rem;cursor:pointer;
  border:1.5px solid var(--line);
  transition:background 240ms,color 240ms,border-color 240ms,transform 180ms;
  min-height:48px;
}
.btn-ghost:hover,.btn-ghost:focus-visible{
  background:var(--surface);color:var(--ink);
  border-color:var(--accent);
  transform:translateY(-2px);
}

/* CTA heartbeat */
.btn-primary.cta-hero{
  animation:ctaPulse 5s cubic-bezier(.4,0,.6,1) infinite;
}
@keyframes ctaPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(212,165,116,0)}
  40%{box-shadow:0 0 0 10px rgba(212,165,116,0.18)}
  60%{box-shadow:0 0 0 14px rgba(212,165,116,0.06)}
}
@media(prefers-reduced-motion:reduce){
  .btn-primary.cta-hero{animation:none!important}
}

/* ===== FOOTER ===== */
.site-footer{
  background:var(--ink);color:rgba(255,255,255,0.75);
  padding:clamp(40px,6vw,72px) 0 24px;
  margin-top:clamp(40px,6vw,80px);
}
.footer-grid{
  display:grid;gap:clamp(24px,4vw,40px);
  margin-bottom:clamp(28px,4vw,48px);
}
@media(min-width:768px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer-col h4{
  font-family:'Libre Baskerville',serif;
  color:var(--surface);font-size:1rem;
  margin-bottom:14px;
}
.footer-col p{font-size:.88rem;line-height:1.7;margin-bottom:6px}
.footer-col a{
  color:rgba(255,255,255,0.75);
  transition:color 240ms;
  word-break:break-word;overflow-wrap:anywhere;
}
.footer-col a:hover{color:var(--accent)}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:.88rem;padding:2px 0}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.1);
  padding-top:20px;
  display:flex;flex-wrap:wrap;gap:8px;
  justify-content:space-between;
  font-size:.78rem;
}
.footer-bottom a{color:rgba(255,255,255,0.5)}
.footer-bottom a:hover{color:var(--accent)}

/* ===== COOKIE BANNER ===== */
.cookie-banner{
  position:fixed;bottom:16px;left:16px;right:16px;
  max-width:520px;margin:0 auto;
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:0 12px 40px -8px rgba(0,0,0,0.18);
  padding:20px 24px;
  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}
@media(min-width:768px){
  .cookie-banner{left:24px;right:auto;max-width:420px}
}
.cookie-banner h3{
  font-family:'Inter',sans-serif;font-weight:700;
  font-size:.95rem;margin-bottom:8px;
}
.cookie-banner p{font-size:.82rem;line-height:1.6;margin-bottom:14px;color:rgba(61,50,41,0.75)}
.cookie-banner p a{color:var(--accent);text-decoration:underline}
.cookie-btns{display:flex;gap:8px;flex-wrap:wrap}
.cookie-btns button{
  flex:1 1 0;min-width:90px;min-height:44px;
  padding:10px 16px;border-radius:6px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:.82rem;
  cursor:pointer;border:1.5px solid var(--line);
  background:transparent;color:var(--ink);
  transition:background 200ms,color 200ms;
}
.cookie-btns button[data-consent="accept"]{
  background:var(--ink);color:var(--surface);border-color:var(--ink);
}
.cookie-btns button[data-consent="accept"]:hover{
  background:var(--accent);color:var(--surface);border-color:var(--accent);
}
.cookie-btns button[data-consent="reject"]{
  font-weight:600;color:var(--ink);border-color:var(--line);
}
.cookie-btns button[data-consent="reject"]:hover{
  background:rgba(61,50,41,0.08);color:var(--ink);border-color:rgba(61,50,41,0.3);
}
.cookie-btns button[data-consent="settings"]{
  font-weight:500;color:rgba(61,50,41,0.7);border-color:rgba(61,50,41,0.15);
}
.cookie-btns button[data-consent="settings"]:hover{
  background:rgba(61,50,41,0.06);color:var(--ink);border-color:var(--line);
}

/* ===== REVEAL ===== */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 900ms cubic-bezier(.22,.68,.18,1),
             transform 900ms cubic-bezier(.22,.68,.18,1);
  transition-delay:calc(var(--reveal-i, 0) * 120ms);
}
.reveal.is-in{opacity:1;transform:none}
.process-step.reveal{transform:translateY(36px) scale(0.97)}
.process-step.reveal.is-in{transform:none}
.gallery-strip .gallery-item{opacity:0;transform:translateY(24px) scale(0.97)}
.gallery-strip.is-in .gallery-item{
  animation:galleryReveal 700ms cubic-bezier(.22,.68,.18,1) forwards;
}
.gallery-strip.is-in .gallery-item:nth-child(1){animation-delay:0ms}
.gallery-strip.is-in .gallery-item:nth-child(2){animation-delay:100ms}
.gallery-strip.is-in .gallery-item:nth-child(3){animation-delay:200ms}
.gallery-strip.is-in .gallery-item:nth-child(4){animation-delay:300ms}
.gallery-strip.is-in .gallery-item:nth-child(5){animation-delay:400ms}
.gallery-strip.is-in .gallery-item:nth-child(6){animation-delay:500ms}
.gallery-strip.is-in .gallery-item:nth-child(7){animation-delay:600ms}
.gallery-strip.is-in .gallery-item:nth-child(8){animation-delay:700ms}
@keyframes galleryReveal{
  from{opacity:0;transform:translateY(24px) scale(0.97)}
  to{opacity:1;transform:none}
}
.value-card.reveal{transform:translateY(28px) scale(0.96)}
.value-card.reveal.is-in{transform:none}
.testimonial-card.reveal{transform:translateY(24px) scale(0.97)}
.testimonial-card.reveal.is-in{transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal,.process-step.reveal,.value-card.reveal,.testimonial-card.reveal,.gallery-item{
    opacity:1!important;transform:none!important;transition:none!important;animation:none!important;
  }
}
html.no-js .reveal{opacity:1;transform:none}
html.no-js .gallery-item{opacity:1;transform:none}

/* ===== PARALLAX ===== */
.parallax-img{
  transition:transform 120ms linear;
  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{border-collapse:collapse;width:100%}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:.9rem}
th{font-weight:600;background:rgba(61,50,41,0.04)}

/* ===== TEAM ===== */
.team-grid{
  display:grid;gap:clamp(20px,3vw,32px);
}
@media(min-width:640px){.team-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}
.team-member{
  background:var(--surface);border-radius:var(--radius);
  overflow:hidden;border:1px solid var(--line);
  transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms,border-color 280ms;
}
.team-member:hover{
  transform:translateY(-6px);
  box-shadow:0 14px 36px -8px rgba(212,165,116,0.22),0 0 20px -4px rgba(212,165,116,0.1),0 0 0 1px rgba(212,165,116,0.15);
  border-color:rgba(212,165,116,0.35);
}
.team-member .member-photo{
  aspect-ratio:3/4;background:linear-gradient(135deg,#e8e0d6,#d4ccc2);
  display:flex;align-items:center;justify-content:center;
  color:rgba(61,50,41,0.3);font-size:.8rem;
  overflow:hidden;
}
.team-member .member-photo img{width:100%;height:100%;object-fit:cover;transition:transform 400ms cubic-bezier(.2,.7,.2,1)}
.team-member:hover .member-photo img{transform:scale(1.04)}
.team-member .member-info{padding:clamp(16px,3vw,24px)}
.team-member h3{margin-bottom:4px;font-size:1.1rem}
.team-member .role{
  font-size:.82rem;color:var(--accent);font-weight:600;
  margin-bottom:10px;
}
.team-member p{font-size:.88rem;line-height:1.7;color:rgba(61,50,41,0.8)}

/* ===== POLICY PAGE ===== */
.policy-content{max-width:760px;margin:0 auto;padding:clamp(32px,5vw,64px) 0}
.policy-content h1{margin-bottom:clamp(20px,3vw,32px)}
.policy-content h2{
  margin-top:clamp(28px,4vw,44px);margin-bottom:14px;
  padding-left:16px;border-left:3px solid var(--accent);
}
.policy-content h3{margin-top:20px;margin-bottom:10px;color:var(--accent-2)}
.policy-content p{margin-bottom:14px;font-size:.93rem;line-height:1.8}
.policy-content ul,.policy-content ol{margin:12px 0 16px 20px}
.policy-content li{padding:4px 0;font-size:.92rem;line-height:1.7}
.policy-content ol{list-style:decimal}
.policy-content ul{list-style:disc}
.policy-content li::marker{color:var(--accent)}

/* ===== 404 ===== */
.page-404{
  text-align:center;
  padding:clamp(60px,12vw,140px) 0;
}
.page-404 h1{margin-bottom:16px}
.page-404 p{margin-bottom:28px;color:rgba(61,50,41,0.65)}

/* ===== SITEMAP PAGE ===== */
.sitemap-list{max-width:600px;margin:0 auto}
.sitemap-list a{
  display:block;padding:10px 0;
  border-bottom:1px solid var(--line);
  font-size:.95rem;
  transition:padding-left 240ms,color 240ms;
}
.sitemap-list a:hover{padding-left:8px;color:var(--accent)}

/* ===== FOCUS ===== */
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;
  box-shadow:0 0 0 5px rgba(123,158,107,0.12);
}

/* ===== NICHE ANIMATIONS ===== */

/* 1. Baby footprint stagger */
.footprint-trail{
  position:relative;
}
.footprint-trail .step-number{
  position:relative;
}
.footprint-trail .step-number::after{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--accent-2);position:absolute;
  bottom:-8px;right:-8px;
  opacity:0;
  animation:footprintAppear 800ms cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay:calc(var(--i,0) * 200ms);
}
@media(prefers-reduced-motion:reduce){
  .footprint-trail .step-number::after{animation:none!important;opacity:1}
}
@keyframes footprintAppear{
  0%{opacity:0;transform:translateY(8px) scale(.6)}
  100%{opacity:.5;transform:translateY(0) scale(1)}
}

/* 2. Soft sparkle ambient */
.sparkle-ambient{
  position:absolute;top:0;left:0;right:0;bottom:0;
  pointer-events:none;overflow:hidden;
}
.sparkle-ambient i{
  position:absolute;width:4px;height:4px;
  background:var(--accent-2);border-radius:50%;
  opacity:0;
  animation:sparkleFloat 8s ease-in-out infinite;
}
.sparkle-ambient i:nth-child(1){top:15%;left:10%;animation-delay:0s}
.sparkle-ambient i:nth-child(2){top:40%;left:80%;animation-delay:2s}
.sparkle-ambient i:nth-child(3){top:70%;left:30%;animation-delay:4s}
.sparkle-ambient i:nth-child(4){top:25%;left:65%;animation-delay:6s}
@keyframes sparkleFloat{
  0%,100%{opacity:0;transform:translateY(0) scale(.5)}
  30%{opacity:.6;transform:translateY(-12px) scale(1)}
  70%{opacity:.3;transform:translateY(-24px) scale(.8)}
}
@media(prefers-reduced-motion:reduce){
  .sparkle-ambient i{animation:none!important;display:none}
}

/* 3. Blanket wave on section dividers */
.section-divider{
  position:relative;overflow:visible;
}
.section-divider::after{
  content:'';position:absolute;
  top:-1px;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,transparent,var(--accent-2),transparent);
  animation:blanketWave 6s ease-in-out infinite;
}
@keyframes blanketWave{
  0%,100%{transform:scaleX(.3);opacity:.2}
  50%{transform:scaleX(1);opacity:.5}
}
@media(prefers-reduced-motion:reduce){
  .section-divider::after{animation:none!important;opacity:.3;transform:scaleX(.5)}
}

/* 4. Cradle rock on hover for cards */
.price-card:hover .price{
  animation:gentleRock 600ms cubic-bezier(.2,.7,.2,1);
}
@keyframes gentleRock{
  0%{transform:rotate(0)}
  25%{transform:rotate(1deg)}
  75%{transform:rotate(-1deg)}
  100%{transform:rotate(0)}
}
@media(prefers-reduced-motion:reduce){
  .price-card:hover .price{animation:none!important}
}

/* ===== WARM HOVER MICRO-EFFECTS ===== */
@media(prefers-reduced-motion:reduce){
  .gallery-item:hover img,.team-member:hover .member-photo img,
  .process-step:hover .step-img img{transform:none!important;transition:none!important}
}
.story-img img{transition:transform 400ms cubic-bezier(.2,.7,.2,1)}
.story-img:hover img{transform:scale(1.02)}
@media(prefers-reduced-motion:reduce){
  .story-img:hover img{transform:none!important}
}
.step-img::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 100%,rgba(212,165,116,0.1) 0%,transparent 60%);
  opacity:0;transition:opacity 400ms;pointer-events:none;
}
.process-step:hover .step-img::after{opacity:1}
.contact-row{
  padding-left:8px;padding-right:8px;
}
.contact-row:hover{
  background:rgba(212,165,116,0.04);
  border-radius:8px;
}

/* Warm glow on hero image */
.hero-img-wrap::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 80%,rgba(212,165,116,0.08) 0%,transparent 65%);
  pointer-events:none;border-radius:inherit;
  animation:warmGlow 8s ease-in-out infinite;
}
@keyframes warmGlow{
  0%,100%{opacity:.4}
  50%{opacity:1}
}
@media(prefers-reduced-motion:reduce){
  .hero-img-wrap::after{animation:none!important;opacity:.6}
}

/* FAQ item smooth expand with warm accent */
.faq-item[open] summary{color:var(--accent-2)}
.faq-item[open] summary::after{color:var(--accent-2)}

/* Testimonial card warm border on hover */
.testimonial-card:hover blockquote::before{
  color:var(--accent-2);
  transition:color 280ms;
}

/* ===== RESPONSIVE ===== */
@media(prefers-reduced-motion:reduce){
  .gallery-item::after,.step-img::after,.hero-img-wrap::after{display:none}
  .faq-item summary{transition:none}
  .contact-row{transition:none}
  .btn-primary,.btn-ghost{transition:none}
}

@media(max-width:640px){
  .hero h1{font-size:1.8rem}
  .hero-img-wrap{border-radius:0;margin:0 calc(-1 * clamp(16px,4vw,32px))}
  .hero-img-wrap img,.hero-img-wrap .placeholder-hero{border-radius:0}
  .gallery-item{width:280px}
  .pricing-list{gap:16px}
  .testimonials-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .policy-content h2{font-size:1.25rem}
  .policy-content h3{font-size:1.05rem}
}
@media(max-width:430px){
  .cookie-banner{left:8px;right:8px;padding:16px 14px}
  .cookie-btns{flex-direction:column}
  .cookie-btns button{min-width:100%;min-height:46px;font-size:.85rem}
}
@media(min-width:1440px){
  .container{max-width:1240px}
}

/* ===== WARM GLOW ON CTA HOVER ===== */
.btn-primary:hover{
  box-shadow:0 8px 24px -8px rgba(123,158,107,0.35),0 0 16px -2px rgba(123,158,107,0.12),0 2px 8px -2px rgba(212,165,116,0.1);
}
.btn-primary:active{
  box-shadow:0 2px 8px -4px rgba(123,158,107,0.3);
}
.btn-ghost:hover{
  box-shadow:0 6px 20px -6px rgba(212,165,116,0.2),0 0 12px -4px rgba(212,165,116,0.08);
}


/* ===== PRINT ===== */
@media print{
  .site-header,.cookie-banner,.mobile-drawer,.drawer-backdrop,.nav-toggle{display:none!important}
  main{padding-top:0!important}
  body{background:#fff;color:#000}
  .reveal{opacity:1!important;transform:none!important}
  .section{page-break-inside:avoid}
}

/* ===== ABOUT PAGE SPECIFIC ===== */
.about-intro{
  max-width:800px;margin:0 auto clamp(32px,5vw,56px);
  text-align:center;
}
.about-intro p{font-size:clamp(.95rem,1.4vw,1.05rem);line-height:1.85}

.values-grid{
  display:grid;gap:clamp(16px,3vw,28px);
  margin:clamp(28px,4vw,48px) 0;
}
@media(min-width:640px){.values-grid{grid-template-columns:repeat(3,1fr)}}
.value-card{
  background:var(--surface);border-radius:var(--radius);
  padding:clamp(20px,3vw,28px);
  border:1px solid var(--line);text-align:center;
  transition:transform 280ms cubic-bezier(.2,.7,.2,1),box-shadow 280ms,border-color 280ms;
}
.value-card:hover{
  transform:translateY(-6px);
  box-shadow:0 14px 36px -8px rgba(212,165,116,0.22),0 0 18px -4px rgba(212,165,116,0.1),inset 0 -2px 8px -4px rgba(212,165,116,0.1);
  border-color:rgba(212,165,116,0.35);
}
.value-card svg{
  width:36px;height:36px;margin:0 auto 12px;
  color:var(--accent);
}
.value-card h3{font-size:1rem;margin-bottom:8px}
.value-card p{font-size:.88rem;line-height:1.65;color:rgba(61,50,41,0.75)}

/* Contact page 2-col */
.contact-grid{
  display:grid;gap:clamp(28px,5vw,56px);
}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1.1fr}}

/* Cancellation policy tiers */
.cancel-tiers{
  display:grid;gap:12px;margin:16px 0;
}
.cancel-tier{
  background:var(--surface);border-radius:6px;
  padding:14px 18px;border:1px solid var(--line);
  display:flex;align-items:baseline;gap:12px;
}
.cancel-tier .tier-badge{
  font-weight:700;font-size:.82rem;
  white-space:nowrap;color:var(--accent);
}
.cancel-tier p{font-size:.88rem;margin:0}

/* ===== DRAWER CLOSE ===== */
.drawer-close{
  position:absolute;top:16px;right:16px;
  width:44px;height:44px;
  background:transparent;border:1.5px solid var(--line);
  border-radius:8px;cursor:pointer;
  font-size:1.5rem;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  z-index:10;line-height:1;
  transition:background 200ms cubic-bezier(.4,0,.2,1),border-color 200ms;
}
.drawer-close:hover{
  background:rgba(61,50,41,0.08);border-color:rgba(61,50,41,0.4);
}
@media(min-width:1024px){.drawer-close{display:none}}

/* ===== SCROLL PROGRESS ===== */
.scroll-progress{
  position:absolute;bottom:0;left:0;
  height:2px;width:0;
  background:var(--accent);
  z-index:1;
}
