/* =============================================
   LITTLE BLOSSOMS — v4 (parallax + vine + doodles)
   ============================================= */
:root {
  --pink:#ff9cca; --pink-mid:#d7699c; --pink-deep:#c04e88; --pink-light:#fff0f7;
  --brown:#795548; --brown-dark:#4e342e;
  --green:#aad9a4; --green-alt:#adc592; --green-dark:#6e9a68;
  --cream:#fdf5ee; --cream-dark:#f5e8d8; --white:#ffffff;
  --text:#3d2c1e; --muted:#9e7e72; --border:#f0ddd4;
  --shadow-sm:0 2px 8px rgba(121,85,72,.08);
  --shadow-md:0 4px 20px rgba(121,85,72,.12);
  --shadow-lg:0 8px 40px rgba(121,85,72,.16);
  --shadow-pink:0 8px 32px rgba(255,156,202,.32);
  --r-sm:8px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-full:9999px;
  --max-w:1180px; --nav-h:72px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Raleway',system-ui,sans-serif;background:var(--cream);color:var(--text);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul[role="list"]{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}

h1,h2,h3,h4{font-family:'Lora',Georgia,serif;color:var(--brown-dark);line-height:1.2}
h1{font-size:clamp(2.1rem,5vw,3.6rem);font-weight:700}
h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700}
h3{font-size:clamp(1.05rem,2.5vw,1.35rem);font-weight:600}
em{font-style:italic;color:var(--pink-mid)}
p{font-size:1.0625rem;line-height:1.75;color:var(--muted)}
p+p{margin-top:1rem}
.section-label{font-family:'Battambang',serif;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--pink-mid);margin-bottom:.75rem}
.section-heading{margin-bottom:1rem}
.section-sub{font-size:1.0625rem;max-width:520px;margin:0 auto;color:var(--muted)}
.section-header{text-align:center;margin-bottom:3.5rem}
.container{width:min(var(--max-w),100% - 2rem);margin-inline:auto}

.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--r-full);font-family:'Raleway',sans-serif;font-size:.9375rem;font-weight:700;transition:all .22s var(--ease);white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--pink) 0%,var(--pink-mid) 100%);color:var(--white);box-shadow:var(--shadow-pink)}
.btn-primary:hover,.btn-primary:focus-visible{transform:translateY(-2px);box-shadow:0 12px 40px rgba(255,156,202,.45)}
.btn-outline{background:transparent;color:var(--brown);border:2px solid var(--pink)}
.btn-outline:hover,.btn-outline:focus-visible{background:var(--pink-light);transform:translateY(-2px)}
.btn-lg{padding:1rem 2rem;font-size:1rem}
.btn-block{width:100%;justify-content:center}
.btn:focus-visible{outline:3px solid var(--pink-mid);outline-offset:3px}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal[style*="--delay"]{transition-delay:var(--delay,0ms)}

/* ── DOODLES (organic decorative SVGs) ── */
.doodle{position:absolute;pointer-events:none;z-index:0;overflow:hidden}
.doodle svg{display:block}
.doodle-hero-br{bottom:0;right:0;width:220px;height:200px}
.doodle-hero-tl{top:0;left:0;width:160px;height:160px}
.doodle-about-tl{top:0;right:0;width:180px;height:200px}
.doodle-svc-br{bottom:0;left:0;width:200px;height:180px}
/* new section doodles */
.doodle-testi-tl{top:0;right:0;width:200px;height:160px}
.doodle-testi-br{bottom:0;left:0;width:180px;height:160px}
.doodle-faq-tr{top:0;right:0;width:160px;height:180px}
.doodle-faq-bl{bottom:0;left:0;width:160px;height:140px}
.doodle-contact-tl{top:0;left:0;width:200px;height:200px}
.doodle-contact-br{bottom:0;right:0;width:180px;height:180px}

/* ══════════════════════════════════════
   NAVBAR — hidden during intro bloom
══════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);
  transition:background .3s var(--ease),box-shadow .3s,opacity .5s,transform .5s;
  opacity:1;transform:none;pointer-events:all;
}
.navbar.nav-visible{opacity:1;transform:none;pointer-events:all}
.navbar.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--border),var(--shadow-sm)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:100%;padding-inline:1.5rem;max-width:var(--max-w);margin-inline:auto}
.nav-logo img{height:48px;width:auto}
.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav-links a{font-size:.88rem;font-weight:600;color:var(--text);padding:.4rem .75rem;border-radius:var(--r-sm);transition:background .2s,color .2s}
.nav-links a:hover{background:var(--pink-light);color:var(--pink-mid)}
.nav-cta{font-size:.875rem;padding:.6rem 1.25rem}
.nav-hamburger{display:none;flex-direction:column;gap:5px;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--r-sm);transition:background .2s}
.nav-hamburger:hover{background:var(--pink-light)}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--brown);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ══════════════════════════════════════
   INTRO BLOOM — cinematic scroll
   Full-screen, no text, just the lotus
══════════════════════════════════════ */
.intro-bloom{height:300vh;position:relative}

.bloom-stage{
  position:sticky;top:0;height:100dvh;
  display:flex;align-items:center;justify-content:center;
  background:var(--cream);overflow:hidden;
}

/* Background scene (Kurzgesagt-inspired) */
.bloom-scene{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.bloom-bg-orbs{position:absolute;inset:0}
.orb{position:absolute;border-radius:50%;filter:blur(70px)}
.orb-1{width:380px;height:380px;background:rgba(255,156,202,.15);top:8%;right:12%;animation:orbDrift 8s ease-in-out infinite alternate}
.orb-2{width:300px;height:300px;background:rgba(170,217,164,.12);bottom:20%;left:8%;animation:orbDrift 11s ease-in-out infinite alternate-reverse}
.orb-3{width:220px;height:220px;background:rgba(255,176,213,.10);top:45%;left:48%;transform:translate(-50%,-50%);animation:orbDrift 6s ease-in-out infinite alternate}
@keyframes orbDrift{from{transform:translate(0,0)}to{transform:translate(18px,12px)}}

.scene-layer{position:absolute;inset:0;pointer-events:none}
.scene-layer svg{width:100%;height:100%;position:absolute;inset:0}

.bloom-lotus-wrap{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  width:min(340px,52vw);
}

#lotusBloom{
  width:100%;height:auto;
  filter:drop-shadow(0 20px 60px rgba(255,156,202,.3));
}

/* Scroll cue — fixed at bottom of bloom stage */
.scroll-cue{
  position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  z-index:5;
  animation:scrollCuePulse 2.8s ease-in-out infinite;
  transition:opacity .6s;
}
.scroll-cue.hidden{opacity:0!important;pointer-events:none;animation:none}

/* Mouse shape scroll indicator */
.scroll-cue-mouse{
  width:26px;height:42px;
  border:2px solid var(--pink-mid);
  border-radius:13px;
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:7px;
  background:rgba(255,240,247,.4);
}
.scroll-cue-wheel{
  display:block;width:4px;height:10px;
  background:var(--pink-mid);
  border-radius:2px;
  animation:scrollWheelDrop 1.6s ease-in-out infinite;
}
.scroll-cue p{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--pink-mid);font-family:'Battambang',serif}
@keyframes scrollWheelDrop{0%{transform:translateY(0);opacity:1}80%{transform:translateY(12px);opacity:.2}100%{transform:translateY(0);opacity:1}}
@keyframes scrollCuePulse{0%,100%{opacity:.85}50%{opacity:.4}}

/* Welcome reveal — appears after morph */
.bloom-welcome{
  position:absolute;
  bottom:auto;
  top:62%;
  left:50%;transform:translateX(-50%);
  text-align:center;
  opacity:0;
  pointer-events:none;
  z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
  transition:none; /* JS-driven */
}
.bloom-welcome img{max-width:min(340px,70vw);height:auto;filter:drop-shadow(0 4px 12px rgba(121,85,72,.15))}
.bloom-welcome-sub{font-family:'Battambang',serif;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--pink-mid)}
.bloom-welcome-hint{font-size:.8rem;color:var(--muted);animation:hintBounce 2s ease-in-out infinite}
@keyframes hintBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ══════════════════════════════════════
   HERO — after the bloom intro
══════════════════════════════════════ */
.hero{
  min-height:100dvh;padding:calc(var(--nav-h) + 3rem) 0 4rem;
  background:linear-gradient(180deg,#c8e4b0 0%,#d8ecc5 2%,#eef7e6 10%,var(--cream) 22%);
  position:relative;overflow:hidden;
  display:flex;align-items:center;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 55% 50% at 75% 55%,rgba(255,156,202,.1) 0%,transparent 70%),
             radial-gradient(ellipse 40% 35% at 15% 30%,rgba(170,217,164,.08) 0%,transparent 70%);
}

.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}

.hero-content .hero-label{font-family:'Battambang',serif;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--pink-mid);margin-bottom:1.25rem}
.hero-content .hero-heading{margin-bottom:1.25rem;animation:heroFadeUp .8s var(--ease) .1s both}
.c-green{color:#aad9a4}
.btn-ig{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.25rem;border-radius:var(--r-full);border:1.5px solid #E1306C;color:#E1306C;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .2s,color .2s}
.btn-ig:hover{background:#E1306C;color:#fff}
/* ── Language toggle ── */
.lang-toggle{display:flex;align-items:center;gap:.35rem}
.lang-btn{background:none;border:none;cursor:pointer;font-size:.8rem;font-weight:700;letter-spacing:.06em;color:var(--muted);padding:.2rem .35rem;border-radius:4px;transition:color .2s,background .2s}
.lang-btn.active{color:var(--pink-mid);background:color-mix(in srgb,var(--pink-mid) 10%,transparent)}
.lang-btn:hover:not(.active){color:var(--text)}
.lang-sep{color:var(--border);font-size:.75rem;user-select:none}
.hl{font-weight:600}
.hero-content .hero-sub{font-size:1.1rem;max-width:460px;margin-bottom:2rem;animation:heroFadeUp .8s var(--ease) .25s both}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;animation:heroFadeUp .8s var(--ease) .4s both}
.hero-location{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.4rem;animation:heroFadeUp .8s var(--ease) .55s both}
.loc-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--green)}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ── Decorative float animations ── */
@keyframes float-a{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-22px) rotate(5deg)}}
@keyframes float-b{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-18px) rotate(-6deg)}}
@keyframes float-c{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-16px) scale(1.06)}}
@keyframes sway-wind{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}

.doodle{animation:float-a 4s ease-in-out infinite}
.doodle-hero-br{transform-origin:bottom center;animation:sway-wind 3s ease-in-out infinite}
.doodle-hero-tl{animation:float-b 4.5s ease-in-out .8s infinite}
.doodle-about-tl{animation:float-a 5s ease-in-out .4s infinite}
.doodle-svc-br{animation:float-b 4.8s ease-in-out 1s infinite}
.doodle-testi-tl{animation:float-a 4.2s ease-in-out .6s infinite}
.doodle-testi-br{animation:float-b 5.5s ease-in-out 1.5s infinite}
.doodle-faq-tr{animation:float-a 4.5s ease-in-out .2s infinite}
.doodle-faq-bl{animation:float-b 5s ease-in-out .9s infinite}
.doodle-contact-tl{animation:float-a 4.8s ease-in-out .5s infinite}
.doodle-contact-br{animation:float-b 4.2s ease-in-out 1.3s infinite}
.about-photo-accent{animation:float-c 5s ease-in-out .7s infinite}
.hiw-deco span{animation:float-a var(--dur,4.5s) ease-in-out var(--del,0s) infinite}

.hero-photo-col{display:flex;justify-content:center;animation:heroFadeUp .9s var(--ease) .2s both}
.hero-photo-frame{position:relative;display:inline-block}
.hero-photo-frame img{width:440px;max-width:100%;height:540px;object-fit:cover;object-position:top center;border-radius:var(--r-xl);box-shadow:var(--shadow-pink),var(--shadow-lg)}
.hero-lottie{width:440px;max-width:100%;height:540px;display:flex;align-items:center;justify-content:center;position:relative}
.hero-lottie svg{width:100%;height:100%}
.hero-photo-deco{position:absolute;top:-20px;right:-20px;width:120px;height:120px;pointer-events:none}
.hero-tag{position:absolute;bottom:1.5rem;left:-1.5rem;background:var(--white);border-radius:var(--r-md);padding:.75rem 1.25rem;box-shadow:var(--shadow-md);text-align:center;display:flex;align-items:center;gap:.75rem;border:1.5px solid var(--border);z-index:2}
.tag-n{font-family:'Lora',serif;font-size:2rem;font-weight:700;color:var(--pink-mid);line-height:1}
.tag-l{font-size:.78rem;font-weight:600;color:var(--muted);line-height:1.3}

/* ══════════════════════════════════════
   ABOUT
══════════════════════════════════════ */
.about{padding:7rem 0;background:var(--white);position:relative;overflow:hidden}
.about-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:4.5rem;align-items:center}
.about-photo-frame{position:relative;display:inline-block;width:100%}
.about-photo-frame img{width:100%;max-width:420px;height:520px;object-fit:cover;object-position:top center;border-radius:var(--r-xl);box-shadow:var(--shadow-pink),var(--shadow-lg);position:relative;z-index:1}
.about-photo-accent{position:absolute;inset:-16px -16px 16px 16px;border-radius:var(--r-xl);border:2px solid var(--pink);opacity:.3;z-index:0}
.about-text h2{margin-bottom:1.5rem}
.about-text p{margin-bottom:1rem}
.about-cta{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;margin-top:1.5rem}
.about-note{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.35rem;font-weight:500}
.about-note svg{color:var(--green-alt)}

/* ══════════════════════════════════════
   SERVICES
══════════════════════════════════════ */
.services{padding:7rem 0;background:var(--cream);position:relative;overflow:hidden}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.svc-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;border:1.5px solid var(--border);transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;transition-delay:var(--delay,0ms)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-pink);border-color:var(--pink)}
.svc-card-top{background:var(--tc,var(--pink-light));min-height:148px;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;transition:background .25s}
.svc-card-top::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:24px;background:var(--white);border-radius:50% 50% 0 0 / 100% 100% 0 0}
.svc-card-top svg{position:relative;z-index:1;transition:transform .3s var(--ease)}
.svc-card:hover .svc-card-top svg{transform:scale(1.12)}
.svc-card-body{padding:1.5rem 2rem 2rem}
.svc-card-body h3{margin-bottom:.7rem;color:var(--brown-dark)}
.svc-card-body p{font-size:.9375rem;margin-bottom:1.25rem}
.svc-link{font-size:.9rem;font-weight:700;color:var(--pink-mid);display:inline-flex;align-items:center;gap:.3rem;transition:gap .2s}
.svc-link:hover{gap:.6rem}

/* ══════════════════════════════════════
   HOW IT WORKS — VINE SCROLL
══════════════════════════════════════ */
/* ══════════════════════════════════════════════════════
   HOW IT WORKS — scroll-driven fullscreen step reveal
══════════════════════════════════════════════════════ */
.hiw{
  height:500vh;
  position:relative;
  background:linear-gradient(180deg,var(--cream-dark) 0%,var(--pink-light) 100%);
}
.hiw-stage{
  position:sticky;top:0;
  height:100dvh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:1.75rem;
  overflow:hidden;
  padding:5rem 1.5rem 3rem;
}
.hiw-header{text-align:center;position:relative;z-index:2}
.hiw-header .section-label{margin-bottom:.4rem}

/* Big ambient watermark number */
.hiw-bg-num{
  position:absolute;
  font-family:'Lora',serif;
  font-size:min(40vw,300px);
  font-weight:700;
  color:var(--brown-dark);
  opacity:.035;
  line-height:1;letter-spacing:-.05em;
  user-select:none;pointer-events:none;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:0;
}

/* Card display area — one card visible at a time */
.hiw-cards{
  position:relative;
  width:min(560px,90vw);
  height:220px;
  z-index:2;
}
.hiw-card{
  position:absolute;inset:0;
  background:var(--white);
  border-radius:var(--r-xl);
  padding:2rem;
  border:1.5px solid var(--border);
  border-left:5px solid var(--ic,var(--pink));
  box-shadow:0 12px 48px rgba(121,85,72,.09),0 3px 12px rgba(121,85,72,.05);
  opacity:0;
  transform:translateY(60px);
  transition:none;
  display:flex;flex-direction:column;justify-content:center;
  gap:.9rem;
  overflow:hidden;
}
.hcard-top{display:flex;align-items:center;gap:1.25rem}
.hcard-icon{
  width:50px;height:50px;flex-shrink:0;
  background:color-mix(in srgb,var(--ic,var(--pink)) 15%,white);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  color:var(--ic,var(--pink));
}
.hcard-meta{display:flex;flex-direction:column;gap:.15rem}
.hcard-num{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:'Battambang',serif}
.hiw-card h3{font-size:1.25rem;color:var(--brown-dark);line-height:1.25;margin:0}
.hiw-card p{font-size:.9375rem;line-height:1.65;color:var(--muted);margin:0}

/* Step progress indicator */
.hiw-progress{display:flex;align-items:center;z-index:2}
.hiw-prog-dot{
  width:11px;height:11px;border-radius:50%;
  border:2px solid var(--pink-mid);
  background:transparent;flex-shrink:0;
  transition:background .35s,transform .35s;
}
.hiw-prog-dot.active{background:var(--pink-mid);transform:scale(1.3)}
.hiw-vine-seg{width:64px;height:24px;flex-shrink:0;overflow:visible}
.vine-track{fill:none;stroke:color-mix(in srgb,var(--pink-mid) 22%,white);stroke-width:2.5;stroke-linecap:round}
.vine-fill{fill:none;stroke:var(--pink-mid);stroke-width:2.5;stroke-linecap:round}

/* CTA — fades in at the end */
.hiw-cta{
  opacity:0;
  transform:translateY(20px);
  pointer-events:none;
  z-index:2;text-align:center;
  transition:none;
}

/* Ambient floating deco */
.hiw-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
.hiw-deco>span{position:absolute}
.hiw-deco .l1{width:64px;height:28px;background:#aad9a4;border-radius:50% 0;opacity:.22;top:12%;left:7%;animation:hiwDecoA 9s ease-in-out infinite alternate}
.hiw-deco .l2{width:52px;height:22px;background:#adc592;border-radius:0 50%;opacity:.2;top:70%;right:8%;animation:hiwDecoB 11s ease-in-out infinite alternate-reverse}
.hiw-deco .l3{width:44px;height:19px;background:#aad9a4;border-radius:50% 0;opacity:.18;top:28%;right:13%;animation:hiwDecoA 7s ease-in-out infinite alternate;animation-delay:2s}
.hiw-deco .p1{width:44px;height:44px;background:#ff9cca;border-radius:50%;opacity:.1;top:20%;right:24%;animation:hiwDecoB 8s ease-in-out infinite alternate;animation-delay:1s}
.hiw-deco .p2{width:32px;height:32px;background:#ffd6ec;border-radius:50%;opacity:.1;bottom:24%;left:19%;animation:hiwDecoA 10s ease-in-out infinite alternate-reverse;animation-delay:3s}
.hiw-deco .l4{width:70px;height:30px;background:#c8eab8;border-radius:0 50%;opacity:.22;top:50%;left:4%;transform:rotate(25deg);animation:hiwDecoB 8s ease-in-out infinite alternate;animation-delay:.5s}
.hiw-deco .l5{width:55px;height:24px;background:#aad9a4;border-radius:50% 0;opacity:.2;bottom:15%;right:5%;transform:rotate(-15deg);animation:hiwDecoA 10s ease-in-out infinite alternate-reverse;animation-delay:1.5s}
.hiw-deco .l6{width:40px;height:18px;background:#adc592;border-radius:0 50%;opacity:.18;top:40%;left:20%;transform:rotate(-30deg);animation:hiwDecoB 7s ease-in-out infinite alternate;animation-delay:2.5s}
.hiw-deco .l7{width:62px;height:26px;background:#c8eab8;border-radius:50% 0;opacity:.2;bottom:35%;right:18%;transform:rotate(20deg);animation:hiwDecoA 9s ease-in-out infinite alternate-reverse;animation-delay:4s}
.hiw-deco .p3{width:24px;height:24px;background:#ff9cca;border-radius:50%;opacity:.12;top:62%;left:28%;animation:hiwDecoB 8.5s ease-in-out infinite alternate;animation-delay:2s}
@keyframes hiwDecoA{0%{transform:rotate(-28deg) translate(0,0)}100%{transform:rotate(-28deg) translate(10px,-14px)}}
@keyframes hiwDecoB{0%{transform:rotate(22deg) translate(0,0)}100%{transform:rotate(22deg) translate(-10px,-12px)}}


/* ══════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════ */
.testimonials{padding:7rem 0;background:var(--white);position:relative;overflow:hidden}
.testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:860px;margin-inline:auto}
.testimonial-card{background:var(--cream);border-radius:var(--r-lg);padding:2rem;border:1.5px solid var(--border);position:relative;transition-delay:var(--delay,0ms)}
.testimonial-card::before{content:'\201C';position:absolute;top:.8rem;left:1.25rem;font-family:'Lora',serif;font-size:4.5rem;color:var(--pink);opacity:.2;line-height:1}
.stars{font-size:1.1rem;color:#f9c74f;margin-bottom:.85rem;letter-spacing:.05em}
.testimonial-text{font-size:.9375rem;line-height:1.7;color:var(--text);margin-bottom:1.25rem}
.testimonial-card footer{display:flex;flex-direction:column;gap:.15rem}
.t-name{font-size:.875rem;font-weight:700;color:var(--brown-dark);font-style:normal}
.t-loc{font-size:.78rem;color:var(--muted)}
.t-ig{font-size:.75rem;color:var(--pink);text-decoration:none;margin-top:.2rem;opacity:.8;transition:opacity .2s}
.t-ig:hover{opacity:1;text-decoration:underline}
.t-expand-wrap{position:relative;overflow:hidden;max-height:7.5em;transition:max-height .45s ease}
.t-expand-wrap.expanded{max-height:200em}
.t-expand-fade{position:absolute;bottom:0;left:0;right:0;height:3.5em;background:linear-gradient(to bottom,transparent,var(--cream));pointer-events:none;transition:opacity .3s}
.t-expand-wrap.expanded .t-expand-fade{opacity:0}
.t-expand-btn{background:none;border:none;padding:0;margin:.25rem 0 1rem;font-family:inherit;font-size:.8125rem;font-weight:700;color:var(--pink);cursor:pointer;letter-spacing:.02em;display:block}
.t-expand-btn:hover{color:var(--brown-dark)}

/* ══════════════════════════════════════
   FAQ
══════════════════════════════════════ */
.faq{padding:7rem 0;background:var(--cream);position:relative;overflow:hidden}
.faq-inner{max-width:760px;margin-inline:auto}
.faq-list{display:flex;flex-direction:column;gap:.75rem}
.faq-item{background:var(--white);border-radius:var(--r-md);border:1.5px solid var(--border);overflow:hidden;transition:border-color .2s}
.faq-item:has(.faq-question[aria-expanded="true"]){border-color:var(--pink)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;font-family:'Raleway',sans-serif;font-size:1rem;font-weight:600;color:var(--brown-dark);text-align:left;transition:background .2s}
.faq-question:hover{background:var(--pink-light)}
.faq-chevron{flex-shrink:0;color:var(--pink-mid);transition:transform .3s var(--ease)}
.faq-question[aria-expanded="true"] .faq-chevron{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-answer:not([hidden]){max-height:400px}
.faq-answer[hidden]{display:block!important}
.faq-answer p{padding:0 1.5rem 1.25rem;font-size:.9375rem}
.faq-answer a{color:var(--pink-mid);font-weight:600;text-decoration:underline}

/* ══════════════════════════════════════
   CONTACT
══════════════════════════════════════ */
.contact{padding:7rem 0;background:linear-gradient(135deg,var(--pink-light) 0%,var(--cream) 60%,var(--cream-dark) 100%);position:relative;overflow:hidden}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info h2{margin-bottom:1rem}
.contact-intro{margin-bottom:2rem}
.contact-methods{display:flex;flex-direction:column;gap:1rem}
.contact-method{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--white);border-radius:var(--r-md);border:1.5px solid var(--border);transition:transform .2s,box-shadow .2s;color:var(--text)}
.contact-method:not(.contact-method-static):hover{transform:translateX(4px);box-shadow:var(--shadow-sm)}
.contact-method-primary{border-color:var(--pink);box-shadow:0 2px 12px rgba(255,156,202,.2)}
.contact-method-primary:hover{box-shadow:var(--shadow-pink)!important}
.cm-icon{width:46px;height:46px;border-radius:var(--r-sm);background:color-mix(in srgb,var(--mc) 18%,transparent);display:flex;align-items:center;justify-content:center;color:var(--mc);flex-shrink:0}
.contact-method strong{display:block;font-size:.875rem;font-weight:700;color:var(--brown-dark);margin-bottom:.15rem}
.contact-method span{font-size:.9rem;color:var(--muted)}
.contact-form-wrap{background:var(--white);border-radius:var(--r-xl);padding:2.5rem;box-shadow:var(--shadow-md);border:1.5px solid var(--border)}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.875rem;font-weight:600;color:var(--brown-dark)}
.opt{font-weight:400;color:var(--muted)}
.form-group input,.form-group textarea{font-family:'Raleway',sans-serif;font-size:.9375rem;color:var(--text);background:var(--cream);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s;resize:vertical}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,156,202,.2)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted);opacity:.7}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.footer{background:var(--brown);color:rgba(255,255,255,.85);padding-top:5rem}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand p{font-size:.875rem;color:rgba(255,255,255,.65);margin-top:1rem}
.footer-tagline{font-family:'Lora',serif;font-style:italic;color:var(--pink)!important;margin-top:.5rem!important}
.footer-brand img{filter:brightness(0) invert(1);opacity:.9}
.footer-links h3,.footer-contact h3{font-family:'Battambang',serif;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--pink);margin-bottom:1.25rem;font-weight:700}
.footer-links ul,.footer-contact ul{display:flex;flex-direction:column;gap:.6rem}
.footer-links a,.footer-contact a{font-size:.9rem;color:rgba(255,255,255,.65);transition:color .2s}
.footer-links a:hover,.footer-contact a:hover{color:var(--pink)}
.footer-contact li:last-child{font-size:.9rem;color:rgba(255,255,255,.45)}
.footer-social{display:flex;gap:.75rem;margin-top:1.5rem}
.footer-social a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:rgba(255,255,255,.08);border-radius:50%;color:rgba(255,255,255,.65);transition:background .2s,color .2s}
.footer-social a:hover{background:var(--pink);color:var(--white)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:1.5rem 0;max-width:var(--max-w);margin-inline:auto;padding-inline:1rem}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.4)}
.footer-bottom a{color:var(--pink)}

/* ══════════════════════════════════════
   FAB CALL BUTTON
══════════════════════════════════════ */
.fab-call{position:fixed;bottom:1.75rem;right:1.75rem;z-index:200;width:60px;height:60px;background:linear-gradient(135deg,var(--pink) 0%,var(--pink-mid) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);box-shadow:0 4px 20px rgba(215,105,156,.5);transition:transform .25s var(--ease),box-shadow .25s}
.fab-call:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(215,105,156,.6)}
.fab-call:focus-visible{outline:3px solid var(--pink);outline-offset:3px}
.fab-pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:var(--pink);opacity:0;animation:fabPulse 3s ease-out infinite}
@keyframes fabPulse{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.9);opacity:0}}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1024px){
  .services-grid,.testimonials-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  :root{--nav-h:64px}

  /* Navbar sempre visível no mobile — não depende do bloom */
  .navbar{opacity:1!important;transform:none!important;pointer-events:all!important;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--border),var(--shadow-sm)}

  .nav-hamburger{display:flex}
  .nav-cta{display:none}
  .nav-links{position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);flex-direction:column;padding:1.5rem;gap:.25rem;box-shadow:var(--shadow-lg);transform:translateY(-100vh);transition:transform .35s var(--ease);z-index:99}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:.75rem 1rem;font-size:1rem;border-radius:var(--r-sm)}

  .intro-bloom{height:220vh}
  .bloom-lotus-wrap{width:min(300px,85vw)}

  .hero-inner{grid-template-columns:1fr;gap:2.5rem;text-align:center}
  .hero-content{order:2}
  .hero-photo-col{order:1}
  .hero-photo-frame img{height:360px;width:100%}
  .hero-lottie{height:360px;width:100%;max-width:360px;margin:0 auto}
  .hero-ctas{justify-content:center}
  .hero-location{justify-content:center}
  .hero-tag{left:50%;transform:translateX(-50%);bottom:-1rem}

  .about-inner{grid-template-columns:1fr;gap:2.5rem}
  .about-photo{order:1}.about-text{order:2}
  .about-photo-frame img{height:380px}

  /* HIW mobile: static stack, no sticky animation */
  .hiw{height:auto}
  .hiw-stage{position:relative;height:auto;padding:5rem 1.25rem 4rem;gap:1.5rem}
  .hiw-bg-num{display:none}
  .hiw-cards{height:auto;position:static;display:flex;flex-direction:column;gap:1rem}
  .hiw-card{position:static;opacity:1!important;transform:none!important;height:auto}
  .hiw-progress{display:none}
  .hiw-cta{opacity:1!important;transform:none!important;pointer-events:auto}

  /* Grids — todos verticais no mobile, sem scroll lateral */
  .services-grid{grid-template-columns:1fr}
  .testimonials-grid{display:flex;flex-direction:column;overflow-x:visible;scroll-snap-type:none;gap:1.25rem;padding-bottom:0}
  .testimonial-card{min-width:auto;scroll-snap-align:none}

  .contact-inner{grid-template-columns:1fr;gap:2.5rem}
  .footer-inner{grid-template-columns:1fr;gap:2.5rem}
  .footer-bottom{flex-direction:column;align-items:flex-start}

  .doodle{display:none}
}

@media(max-width:480px){
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{justify-content:center}
  .contact-form-wrap{padding:1.5rem}
  .btn-lg{padding:.875rem 1.5rem}
}

@media(min-width:1400px){
  :root{--max-w:1320px}
  .hero-photo-frame img{width:500px;height:600px}
  .hero-lottie{width:500px;height:600px}
}
