/* =========================================================
   Minahil Aesthetics — Elegant Feminine Theme
   Palette: soft pink + lavender luxury + champagne gold
   Fonts: Playfair Display (display) + Inter (body)
   ========================================================= */

:root{
  /* Brand colors */
  --primary:        #EC2D86;   /* rose pink   */
  --primary-deep:   #C81E6B;
  --secondary:      #F985C0;   /* soft pink   */
  --accent:         #8B5CF6;   /* lavender    */
  --accent-deep:    #6D28D9;
  --gold:           #C9A063;   /* champagne   */
  --gold-soft:      #E7D2A8;
  --gold-deep:      #9A6B12;   /* gold for text on light */

  --bg:             #FDEAF4;   /* blush       */
  --bg-2:           #FBF1FA;
  --surface:        #FFFFFF;
  --muted:          #F6EEF6;
  --border:         #F9B8DC;
  --border-soft:    #F2D6E8;

  --ink:            #34121F;   /* body text   */
  --ink-soft:       #5A2E42;   /* secondary   */
  --plum:           #9D0E50;   /* deep accent */

  /* Gradients */
  --grad-brand: linear-gradient(120deg, #EC4899 0%, #A855F7 55%, #8B5CF6 100%);
  --grad-soft:  linear-gradient(135deg, #FDF2F8 0%, #F5ECFB 100%);
  --grad-rose:  linear-gradient(135deg, #FFF1F7 0%, #FCE7F3 100%);
  --grad-gold:  linear-gradient(120deg, #E7D2A8, #C9A063);

  /* Effects */
  --radius:     22px;
  --radius-lg:  34px;
  --radius-sm:  14px;
  --shadow-sm:  0 4px 14px rgba(131,24,67,.06);
  --shadow:     0 14px 40px rgba(131,24,67,.10);
  --shadow-lg:  0 30px 70px rgba(131,24,67,.16);
  --shadow-glow:0 18px 50px rgba(236,72,153,.28);

  --maxw: 1180px;
  --nav-h: 76px;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
::selection{ background:var(--secondary); color:var(--plum); }

h1,h2,h3,h4{ font-family:'Playfair Display',Georgia,serif; color:var(--plum); line-height:1.15; font-weight:600; }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }
.section{ padding:clamp(70px,9vw,120px) 0; position:relative; }
.center{ text-align:center; }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Inter',sans-serif; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; font-size:.72rem; color:var(--primary-deep);
  background:var(--grad-rose); border:1px solid var(--border);
  padding:8px 16px; border-radius:100px;
}
.eyebrow::before{ content:""; width:18px; height:1.5px; background:var(--gold); }
.section-title{ font-size:clamp(2rem,4.4vw,3.2rem); margin:18px 0 14px; letter-spacing:-.5px; }
.section-sub{ color:var(--ink-soft); max-width:620px; font-size:1.05rem; }
.center .section-sub{ margin-inline:auto; }
.text-grad{
  background:var(--grad-brand); -webkit-background-clip:text;
  background-clip:text; color:transparent;
}
.script{ font-family:'Playfair Display',serif; font-style:italic; font-weight:500; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-weight:600; font-size:.97rem; padding:15px 30px; border-radius:100px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s;
  will-change:transform; line-height:1; white-space:nowrap;
}
.btn svg{ width:19px; height:19px; }
.btn-primary{ background:var(--grad-brand); color:#fff; box-shadow:var(--shadow-glow); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 24px 60px rgba(236,72,153,.42); }
.btn-ghost{ background:var(--surface); color:var(--plum); border:1.5px solid var(--border); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ transform:translateY(-3px); border-color:var(--primary); box-shadow:var(--shadow); }
.btn-wa{ background:#25D366; color:#fff; box-shadow:0 14px 34px rgba(37,211,102,.32); }
.btn-wa:hover{ transform:translateY(-3px); box-shadow:0 22px 48px rgba(37,211,102,.44); }
.btn-lg{ padding:18px 38px; font-size:1.02rem; }

/* ---------- Navbar ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; height:var(--nav-h); z-index:100;
  display:flex; align-items:center;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), height .4s var(--ease);
}
.nav.scrolled{
  background:rgba(255,255,255,.82); backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px); box-shadow:0 6px 24px rgba(131,24,67,.08);
  height:64px;
}
.nav .container{ display:flex; align-items:center; justify-content:space-between; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{
  width:42px; height:42px; border-radius:50%; display:grid; place-items:center;
  background:var(--grad-brand); color:#fff; box-shadow:var(--shadow-glow); flex:none;
}
.brand-mark svg{ width:22px; height:22px; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{ font-family:'Playfair Display',serif; font-weight:600; font-size:1.18rem; color:var(--plum); }
.brand-tag{ font-size:.62rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-deep); font-weight:700; margin-top:3px; }

.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  position:relative; font-weight:500; font-size:.94rem; color:var(--ink-soft);
  padding:9px 14px; border-radius:100px; transition:color .25s, background .25s;
}
.nav-links a:hover{ color:var(--plum); }
.nav-links a.active{ color:var(--primary-deep); background:var(--grad-rose); }
.nav-cta{ margin-left:8px; }
.nav-toggle{ display:none; width:44px; height:44px; border-radius:12px; place-items:center; color:var(--plum); }
.nav-toggle svg{ width:26px; height:26px; }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:99; background:rgba(253,242,248,.97);
  backdrop-filter:blur(14px); display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px;
  opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s;
}
.mobile-menu.open{ opacity:1; visibility:visible; }
.mobile-menu a{
  font-family:'Playfair Display',serif; font-size:1.7rem; color:var(--plum);
  padding:12px 24px; opacity:0; transform:translateY(14px);
}
.mobile-menu.open a{ animation:menuIn .5s var(--ease) forwards; }
.mobile-menu.open a:nth-child(1){ animation-delay:.06s; }
.mobile-menu.open a:nth-child(2){ animation-delay:.12s; }
.mobile-menu.open a:nth-child(3){ animation-delay:.18s; }
.mobile-menu.open a:nth-child(4){ animation-delay:.24s; }
.mobile-menu.open a:nth-child(5){ animation-delay:.30s; }
@keyframes menuIn{ to{ opacity:1; transform:none; } }
.mobile-menu .btn-wa{ margin-top:14px; }

/* ---------- Decorative blobs ---------- */
.blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; z-index:0; pointer-events:none; }
.blob-pink{ background:radial-gradient(circle,#FBCFE8,transparent 70%); }
.blob-violet{ background:radial-gradient(circle,#DDD6FE,transparent 70%); }
.float{ animation:float 9s ease-in-out infinite; }
@keyframes float{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-26px) } }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; padding-top:calc(var(--nav-h) + 40px); overflow:hidden; }
.hero .container{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,64px); align-items:center; }
.hero-copy{ max-width:560px; }
.hero h1{ font-size:clamp(2.6rem,6vw,4.5rem); letter-spacing:-1px; margin:20px 0; }
.hero h1 .ln{ display:block; overflow:hidden; }
.hero h1 .ln span{ display:inline-block; transform:translateY(110%); animation:rise .9s var(--ease) forwards; }
.hero h1 .ln:nth-child(2) span{ animation-delay:.12s; }
.hero h1 .ln:nth-child(3) span{ animation-delay:.24s; }
@keyframes rise{ to{ transform:none; } }
.hero-lead{ font-size:1.12rem; color:var(--ink-soft); margin-bottom:30px; opacity:0; animation:fadeUp .8s var(--ease) .5s forwards; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; opacity:0; animation:fadeUp .8s var(--ease) .65s forwards; }
.hero-trust{ display:flex; gap:26px; margin-top:34px; opacity:0; animation:fadeUp .8s var(--ease) .8s forwards; flex-wrap:wrap; }
.hero-trust .num{ font-family:'Playfair Display',serif; font-size:1.7rem; color:var(--primary-deep); font-weight:600; }
.hero-trust .lbl{ font-size:.82rem; color:var(--ink-soft); }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(22px); } to{ opacity:1; transform:none; } }

/* Hero visual */
.hero-visual{ position:relative; }
.hero-photo{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio:4/5; box-shadow:var(--shadow-lg);
  background:var(--grad-brand);
  border:6px solid #fff;
  opacity:0; transform:translateY(30px) scale(.97);
  animation:fadeUp .9s var(--ease) .35s forwards;
}
.hero-photo img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
/* fallback decorative when no photo */
.photo-fallback{ position:absolute; inset:0; display:grid; place-items:center; color:#fff; text-align:center; padding:30px; }
.photo-fallback svg{ width:70px; height:70px; opacity:.9; margin-bottom:14px; }
.photo-fallback p{ font-family:'Playfair Display',serif; font-size:1.2rem; opacity:.95; }
.photo-fallback small{ display:block; font-family:'Inter'; font-size:.75rem; opacity:.8; margin-top:6px; letter-spacing:.05em; }

.hero-badge{
  position:absolute; background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  border-radius:18px; padding:14px 18px; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:12px; z-index:3;
}
.hero-badge svg{ width:34px; height:34px; color:var(--primary); flex:none; }
.hero-badge .t{ font-weight:700; color:var(--plum); font-size:.92rem; }
.hero-badge .s{ font-size:.74rem; color:var(--ink-soft); }
.hero-badge.b1{ top:24px; left:-26px; animation:float 7s ease-in-out infinite; }
.hero-badge.b2{ bottom:30px; right:-22px; animation:float 8s ease-in-out infinite .5s; }

/* wavy divider */
.wave{ display:block; width:100%; height:auto; color:var(--surface); }

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{ background:var(--grad-brand); padding:18px 0; overflow:hidden; white-space:nowrap; }
.marquee-track{ display:inline-flex; gap:42px; animation:scrollX 30s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee span{ color:#fff; font-family:'Playfair Display',serif; font-style:italic; font-size:1.2rem; opacity:.95; display:inline-flex; align-items:center; gap:42px; }
.marquee span::after{ content:"✦"; color:var(--gold-soft); font-style:normal; }
@keyframes scrollX{ to{ transform:translateX(-50%); } }

/* =========================================================
   FEATURE / WHY CARDS
   ========================================================= */
.grid{ display:grid; gap:26px; }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.cols-2{ grid-template-columns:repeat(2,1fr); }

.feature{
  background:var(--surface); border:1px solid var(--border-soft);
  border-radius:var(--radius); padding:34px 28px; box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s;
}
.feature:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-color:var(--border); }
.feature .ic{
  width:60px; height:60px; border-radius:18px; display:grid; place-items:center;
  background:var(--grad-rose); color:var(--primary-deep); margin-bottom:18px;
}
.feature .ic svg{ width:30px; height:30px; }
.feature h3{ font-size:1.25rem; margin-bottom:8px; }
.feature p{ color:var(--ink-soft); font-size:.96rem; }

/* =========================================================
   SERVICE CARDS
   ========================================================= */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.svc-card{
  position:relative; background:var(--surface); border:1px solid var(--border-soft);
  border-radius:var(--radius); padding:30px 26px 26px; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; overflow:hidden;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .3s;
}
.svc-card::before{
  content:""; position:absolute; inset:0 0 auto 0; height:4px; background:var(--grad-brand);
  transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease);
}
.svc-card:hover{ transform:translateY(-10px); box-shadow:var(--shadow-lg); border-color:var(--border); }
.svc-card:hover::before{ transform:scaleX(1); }
.svc-icon{
  width:64px; height:64px; border-radius:50%; display:grid; place-items:center;
  background:var(--grad-rose); color:var(--primary-deep); margin-bottom:18px;
  transition:transform .5s var(--ease-spring), background .4s, color .4s;
}
.svc-card:hover .svc-icon{ transform:scale(1.08) rotate(-6deg); background:var(--grad-brand); color:#fff; }
.svc-icon svg{ width:32px; height:32px; }
.svc-cat{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:700; }
.svc-card h3{ font-size:1.32rem; margin:6px 0 10px; }
.svc-card p{ color:var(--ink-soft); font-size:.95rem; flex:1; }
.svc-tags{ display:flex; flex-wrap:wrap; gap:7px; margin:16px 0 18px; }
.svc-tags span{ font-size:.72rem; color:var(--accent-deep); background:#EDE4FE; border:1px solid #D6C4FA; padding:5px 11px; border-radius:100px; font-weight:600; }
.svc-foot{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:auto; }
.svc-book{
  display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:.9rem;
  color:#fff; background:#25D366; padding:11px 18px; border-radius:100px;
  transition:transform .3s var(--ease), box-shadow .3s; box-shadow:0 8px 20px rgba(37,211,102,.28);
}
.svc-book:hover{ transform:translateY(-2px); box-shadow:0 14px 30px rgba(37,211,102,.42); }
.svc-book svg{ width:17px; height:17px; }
.svc-more{ font-size:.84rem; color:var(--primary-deep); font-weight:600; display:inline-flex; align-items:center; gap:5px; }

/* category pill bar */
.cat-bar{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:44px; }
.cat-pill{
  font-weight:600; font-size:.9rem; padding:11px 22px; border-radius:100px;
  background:var(--surface); border:1.5px solid var(--border); color:var(--ink-soft);
  transition:all .3s var(--ease);
}
.cat-pill:hover{ color:var(--primary-deep); border-color:var(--primary); transform:translateY(-2px); }
.cat-pill.active{ background:var(--grad-brand); color:#fff; border-color:transparent; box-shadow:var(--shadow-glow); }

/* category section heading */
.cat-head{ display:flex; align-items:center; gap:16px; margin:60px 0 30px; }
.cat-head:first-of-type{ margin-top:0; }
.cat-head .line{ flex:1; height:1px; background:linear-gradient(90deg,var(--border),transparent); }
.cat-head h2{ font-size:clamp(1.5rem,3vw,2.1rem); white-space:nowrap; }
.cat-head .ic{ width:46px; height:46px; border-radius:14px; background:var(--grad-rose); color:var(--primary-deep); display:grid; place-items:center; flex:none; }
.cat-head .ic svg{ width:24px; height:24px; }

/* =========================================================
   ABOUT / SPLIT
   ========================================================= */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,6vw,72px); align-items:center; }
.about-visual{ position:relative; }
.about-photo{
  border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:5/6;
  box-shadow:var(--shadow-lg); border:6px solid #fff; background:var(--grad-brand);
  position:relative;
}
.about-photo img{ width:100%; height:100%; object-fit:cover; }
.about-frame{ position:absolute; inset:-18px -18px auto auto; width:140px; height:140px; border:2px solid var(--gold-soft); border-radius:24px; z-index:-1; }
.about-stat{
  position:absolute; bottom:-26px; left:-26px; background:#fff; border-radius:20px;
  padding:18px 22px; box-shadow:var(--shadow); text-align:center;
}
.about-stat .num{ font-family:'Playfair Display',serif; font-size:2rem; color:var(--primary-deep); }
.about-stat .lbl{ font-size:.78rem; color:var(--ink-soft); }
.check-list{ display:grid; gap:14px; margin:24px 0 30px; }
.check-list li{ display:flex; gap:13px; align-items:flex-start; color:var(--ink-soft); }
.check-list .ck{ width:26px; height:26px; border-radius:50%; background:var(--grad-rose); color:var(--primary-deep); display:grid; place-items:center; flex:none; margin-top:2px; }
.check-list .ck svg{ width:15px; height:15px; }
.check-list strong{ color:var(--plum); }

/* credentials badges */
.creds{ display:flex; flex-wrap:wrap; gap:12px; margin-top:10px; }
.cred{
  display:flex; align-items:center; gap:10px; background:var(--surface);
  border:1px solid var(--border-soft); border-radius:14px; padding:12px 16px; box-shadow:var(--shadow-sm);
}
.cred svg{ width:24px; height:24px; color:var(--gold); flex:none; }
.cred .t{ font-weight:600; color:var(--plum); font-size:.9rem; }
.cred .s{ font-size:.74rem; color:var(--ink-soft); }

/* =========================================================
   STEPS
   ========================================================= */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; counter-reset:step; }
.step{ position:relative; background:var(--surface); border:1px solid var(--border-soft); border-radius:var(--radius); padding:32px 24px; box-shadow:var(--shadow-sm); text-align:center; }
.step .n{ counter-increment:step; font-family:'Playfair Display',serif; font-size:2.4rem; background:var(--grad-brand); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:700; }
.step h3{ font-size:1.12rem; margin:6px 0 8px; }
.step p{ color:var(--ink-soft); font-size:.9rem; }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testi{ background:var(--surface); border:1px solid var(--border-soft); border-radius:var(--radius); padding:30px 28px; box-shadow:var(--shadow-sm); position:relative; transition:transform .4s var(--ease); }
.testi:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.testi .stars{ display:flex; gap:3px; color:var(--gold); margin-bottom:14px; }
.testi .stars svg{ width:18px; height:18px; }
.testi p{ color:var(--ink); font-size:1rem; font-style:italic; }
.testi .who{ display:flex; align-items:center; gap:12px; margin-top:18px; }
.testi .av{ width:46px; height:46px; border-radius:50%; background:var(--grad-brand); color:#fff; display:grid; place-items:center; font-weight:700; font-family:'Playfair Display',serif; }
.testi .nm{ font-weight:600; color:var(--plum); font-size:.95rem; }
.testi .rl{ font-size:.78rem; color:var(--ink-soft); }

/* =========================================================
   CTA BANNER
   ========================================================= */
.cta{ position:relative; overflow:hidden; }
.cta-inner{
  background:var(--grad-brand); border-radius:var(--radius-lg); padding:clamp(40px,6vw,72px);
  text-align:center; color:#fff; position:relative; overflow:hidden; box-shadow:var(--shadow-lg);
}
.cta-inner::before,.cta-inner::after{ content:""; position:absolute; border-radius:50%; background:rgba(255,255,255,.14); }
.cta-inner::before{ width:280px; height:280px; top:-120px; right:-60px; }
.cta-inner::after{ width:200px; height:200px; bottom:-100px; left:-40px; }
.cta-inner h2{ color:#fff; font-size:clamp(2rem,4.4vw,3rem); position:relative; }
.cta-inner p{ color:rgba(255,255,255,.92); max-width:560px; margin:16px auto 30px; position:relative; }
.cta-inner .btn-wa{ background:#fff; color:#128C7E; position:relative; }
.cta-inner .btn-wa:hover{ background:#fff; }

/* =========================================================
   PAGE HEADER (inner pages)
   ========================================================= */
.page-head{ position:relative; padding:calc(var(--nav-h) + 64px) 0 70px; text-align:center; overflow:hidden; background:var(--grad-soft); }
.page-head h1{ font-size:clamp(2.4rem,5.5vw,4rem); margin:16px 0 12px; }
.page-head p{ color:var(--ink-soft); max-width:600px; margin-inline:auto; font-size:1.08rem; }
.crumb{ display:inline-flex; align-items:center; gap:8px; font-size:.85rem; color:var(--ink-soft); }
.crumb a:hover{ color:var(--primary-deep); }
.crumb svg{ width:14px; height:14px; opacity:.6; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,56px); align-items:start; }
.contact-card{ background:var(--surface); border:1px solid var(--border-soft); border-radius:var(--radius); padding:34px; box-shadow:var(--shadow-sm); }
.info-row{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--border-soft); }
.info-row:last-child{ border-bottom:none; }
.info-row .ic{ width:50px; height:50px; border-radius:14px; background:var(--grad-rose); color:var(--primary-deep); display:grid; place-items:center; flex:none; }
.info-row .ic svg{ width:24px; height:24px; }
.info-row .t{ font-weight:600; color:var(--plum); }
.info-row .v{ color:var(--ink-soft); font-size:.95rem; }
.info-row a.v:hover{ color:var(--primary-deep); }

.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:600; color:var(--plum); font-size:.9rem; margin-bottom:7px; }
.field input,.field select,.field textarea{
  width:100%; padding:14px 16px; border-radius:14px; border:1.5px solid var(--border);
  background:var(--bg-2); color:var(--ink); font:inherit; font-size:.96rem; transition:border-color .25s, box-shadow .25s;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--primary); box-shadow:0 0 0 4px rgba(236,72,153,.12); background:#fff; }

/* hours table */
.hours li{ display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px dashed var(--border-soft); font-size:.95rem; }
.hours li:last-child{ border-bottom:none; }
.hours .d{ color:var(--ink-soft); }
.hours .h{ font-weight:600; color:var(--plum); }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ max-width:760px; margin-inline:auto; }
.faq-item{ background:var(--surface); border:1px solid var(--border-soft); border-radius:var(--radius-sm); margin-bottom:14px; overflow:hidden; transition:box-shadow .3s, border-color .3s; }
.faq-item.open{ box-shadow:var(--shadow); border-color:var(--border); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 24px; text-align:left; font-weight:600; color:var(--plum); font-size:1.02rem; }
.faq-q .pl{ width:28px; height:28px; flex:none; border-radius:50%; background:var(--grad-rose); color:var(--primary-deep); display:grid; place-items:center; transition:transform .35s var(--ease); }
.faq-item.open .faq-q .pl{ transform:rotate(135deg); }
.faq-q .pl svg{ width:16px; height:16px; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ padding:0 24px 22px; color:var(--ink-soft); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:#2C0F1E; color:#E9D5DF; padding:70px 0 28px; position:relative; overflow:hidden; }
.footer::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad-brand); }
.footer-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer .brand-name{ color:#fff; }
.footer p{ color:#C9A9B9; font-size:.94rem; margin-top:16px; max-width:300px; }
.footer h4{ color:#fff; font-family:'Inter'; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:18px; }
.footer-links li{ margin-bottom:11px; }
.footer-links a{ color:#C9A9B9; font-size:.94rem; transition:color .25s, padding .25s; }
.footer-links a:hover{ color:var(--secondary); padding-left:5px; }
.footer-social{ display:flex; gap:12px; margin-top:18px; }
.footer-social a{ width:42px; height:42px; border-radius:12px; background:rgba(255,255,255,.08); display:grid; place-items:center; color:#E9D5DF; transition:all .3s var(--ease); }
.footer-social a:hover{ background:var(--grad-brand); color:#fff; transform:translateY(-3px); }
.footer-social svg{ width:20px; height:20px; }
.footer-bottom{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; padding-top:24px; font-size:.86rem; color:#A98499; }
.lab{ display:inline-flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:6px 9px; max-width:100%; }
.lab a{ color:var(--secondary); font-weight:600; word-break:break-word; }
.lab a:hover{ color:#fff; }
.lab-mark{ width:26px; height:26px; border-radius:7px; background:var(--grad-brand); display:grid; place-items:center; color:#fff; }
.lab-mark svg{ width:15px; height:15px; }

/* floating WhatsApp */
.wa-float{
  position:fixed; bottom:24px; right:24px; z-index:90; width:60px; height:60px; border-radius:50%;
  background:#25D366; color:#fff; display:grid; place-items:center; box-shadow:0 14px 34px rgba(37,211,102,.46);
  transition:transform .35s var(--ease-spring); animation:pulse 2.6s infinite;
}
.wa-float:hover{ transform:scale(1.1); }
.wa-float svg{ width:32px; height:32px; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(37,211,102,.45);} 70%{ box-shadow:0 0 0 18px rgba(37,211,102,0);} 100%{ box-shadow:0 0 0 0 rgba(37,211,102,0);} }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
.reveal.d5{ transition-delay:.40s; } .reveal.d6{ transition-delay:.48s; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .cols-4{ grid-template-columns:repeat(2,1fr); }
  .svc-grid,.testi-grid{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .nav-links{ display:none; }
  .nav-toggle{ display:grid; }
  .nav .nav-cta{ display:none; }
  .hero .container{ grid-template-columns:1fr; }
  .hero-visual{ max-width:440px; margin-inline:auto; order:-1; }
  .hero-trust{ justify-content:center; }
  .hero-copy{ text-align:center; margin-inline:auto; }
  .hero-actions{ justify-content:center; }
  .split,.contact-grid{ grid-template-columns:1fr; }
  .about-visual{ max-width:440px; margin:0 auto 30px; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width:600px){
  .cols-3,.cols-4,.cols-2,.svc-grid,.testi-grid,.steps{ grid-template-columns:1fr; }
  /* keep floating badges visible on mobile, tucked inside the photo */
  .hero-badge{ padding:9px 12px; gap:9px; }
  .hero-badge svg{ width:26px; height:26px; }
  .hero-badge .t{ font-size:.78rem; }
  .hero-badge .s{ font-size:.66rem; }
  .hero-badge.b1{ top:8px; left:6px; }
  .hero-badge.b2{ bottom:12px; right:6px; }
  .about-stat{ left:0; }
  .footer{ padding-bottom:96px; }
  .footer-top{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; text-align:center; }
  .btn{ width:100%; }
  .hero-actions{ flex-direction:column; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .reveal{ opacity:1; transform:none; }
  .hero h1 .ln span,.hero-lead,.hero-actions,.hero-trust,.hero-photo{ opacity:1; transform:none; animation:none; }
}
