/* ============================================================
   THE GROOMING LOUNGE DOG SPA
   Design: Luxury / Minimal  |  Gold + Soft Rose + Cream
   Pamper · Relax · Shine
   HTML / Vanilla CSS / Vanilla JS
   ============================================================ */

/* ---------- Design Tokens ---------- */
:root{
  --gold-700:#8a6a34;
  --gold-600:#a07c3f;
  --gold-500:#b0894b;
  --gold-400:#c6a368;
  --gold-300:#e3cda0;
  --rose-600:#c2638f;
  --rose-500:#d580ac;
  --rose-400:#e3a4c5;
  --rose-200:#f4dbe8;
  --rose-100:#fbeef4;
  --cream:#FBF5EF;
  --cream-200:#f3e9df;
  --ink:#2E2730;
  --ink-soft:#544b56;
  --muted:#8a7f8a;
  --surface:#FFFFFF;
  --border:#ece2d8;
  --radius-sm:12px;
  --radius:20px;
  --radius-lg:32px;
  --shadow-sm:0 1px 2px rgba(46,39,48,.05),0 4px 10px rgba(46,39,48,.05);
  --shadow-md:0 8px 20px rgba(46,39,48,.08),0 16px 40px rgba(46,39,48,.08);
  --shadow-lg:0 16px 36px rgba(46,39,48,.12),0 32px 70px rgba(138,106,52,.14);
  --shadow-rose:0 12px 32px rgba(213,128,172,.32);
  --shadow-gold:0 12px 32px rgba(176,137,75,.34);
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-head:'Playfair Display',Georgia,serif;
  --font-body:'Lato',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--ink);background:var(--cream);line-height:1.7;font-size:16px;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);line-height:1.18;font-weight:700}
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold-500);color:#fff;padding:.7rem 1.2rem;z-index:200;border-radius:0 0 8px 0;font-weight:700}
.skip-link:focus{left:0}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.section{padding:clamp(3.5rem,7vw,6.5rem) 0}
.section--tight{padding:clamp(2.5rem,5vw,4rem) 0}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-600)}
.eyebrow::before,.eyebrow.center::after{content:"";width:30px;height:1.5px;background:linear-gradient(90deg,var(--gold-500),var(--rose-400));border-radius:2px}
.section-head{max-width:660px;margin:0 auto 3rem;text-align:center}
.section-head .eyebrow{margin-bottom:.9rem}
.section-head h2{font-size:clamp(2rem,4.4vw,3rem)}
.section-head p{color:var(--ink-soft);font-size:1.06rem;margin-top:.8rem}
.lead{font-size:1.16rem;color:var(--ink-soft)}
.script{font-family:var(--font-head);font-style:italic;font-weight:500}
.text-gold{color:var(--gold-600)}
.text-rose{color:var(--rose-600)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-body);font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;padding:1rem 1.9rem;border-radius:999px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s,color .3s;cursor:pointer;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn--primary{background:linear-gradient(135deg,var(--gold-500),var(--gold-400));color:#fff;box-shadow:var(--shadow-gold)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(176,137,75,.45)}
.btn--rose{background:linear-gradient(135deg,var(--rose-500),var(--rose-400));color:#fff;box-shadow:var(--shadow-rose)}
.btn--rose:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(213,128,172,.45)}
.btn--ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(255,255,255,.22);transform:translateY(-3px)}
.btn--outline{background:transparent;color:var(--gold-700);border:1.5px solid var(--gold-400)}
.btn--outline:hover{background:var(--gold-500);color:#fff;border-color:var(--gold-500);transform:translateY(-3px)}
.btn--lg{padding:1.15rem 2.2rem;font-size:.86rem}

/* ---------- Top Bar ---------- */
.topbar{background:var(--ink);color:#e9ddd1;font-size:.82rem}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.55rem;flex-wrap:wrap}
.topbar__contact{display:flex;gap:1.4rem;flex-wrap:wrap;align-items:center}
.topbar__contact a,.topbar__item{display:inline-flex;align-items:center;gap:.5rem;color:#e9ddd1;transition:color .2s}
.topbar__contact a:hover{color:var(--gold-300)}
.topbar__contact svg{width:15px;height:15px;color:var(--gold-400)}
.topbar__social{display:flex;gap:.55rem;align-items:center}
.topbar__social a{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:rgba(255,255,255,.08);transition:.25s var(--ease)}
.topbar__social a:hover{background:var(--rose-500);color:#fff;transform:translateY(-2px)}
.topbar__social svg{width:15px;height:15px}
@media(max-width:760px){.topbar__item--loc2{display:none}}
@media(max-width:520px){.topbar__inner{justify-content:center}.topbar__contact{gap:1rem;font-size:.78rem}}

/* ---------- Header / Nav ---------- */
.header{position:sticky;top:0;z-index:90}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:.7rem;
  background:rgba(251,245,239,.78);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid rgba(236,226,216,.8)}
.header.scrolled .header__inner{box-shadow:var(--shadow-md)}
.brand{display:flex;align-items:center;gap:.7rem}
.brand__logo{height:58px;width:auto;background:#fff;border-radius:14px;padding:3px;border:1px solid rgba(236,226,216,.9);box-shadow:0 4px 14px rgba(60,40,20,.1)}
.brand__txt{font-family:var(--font-head);font-weight:700;font-size:1.15rem;color:var(--ink);line-height:1}
.brand__txt small{display:block;font-family:var(--font-body);font-weight:700;font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-600);margin-top:3px}
.nav{display:flex;align-items:center;gap:.2rem}
.nav a{font-family:var(--font-body);font-weight:700;font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft);padding:.55rem .8rem;border-radius:10px;transition:.2s}
.nav a:hover,.nav a.active{color:var(--gold-700);background:rgba(176,137,75,.1)}
.header__actions{display:flex;align-items:center;gap:.8rem}
.nav-toggle{display:none;width:46px;height:46px;border-radius:12px;background:var(--gold-500);color:#fff;place-items:center}
.nav-toggle svg{width:22px;height:22px}
@media(max-width:1020px){
  .nav-toggle{display:grid}
  .header__actions .btn--rose{display:none}
  .nav{position:fixed;inset:0 0 0 auto;width:min(330px,84vw);flex-direction:column;align-items:stretch;gap:.3rem;
    background:var(--cream);padding:6rem 1.4rem 2rem;box-shadow:var(--shadow-lg);transform:translateX(105%);transition:transform .35s var(--ease);z-index:95}
  .nav.open{transform:translateX(0)}
  .nav a{font-size:1.05rem;padding:.9rem 1rem}
  .nav .btn{margin-top:1rem;justify-content:center}
  .nav-backdrop{position:fixed;inset:0;background:rgba(46,39,48,.45);opacity:0;visibility:hidden;transition:.3s;z-index:94}
  .nav-backdrop.show{opacity:1;visibility:visible}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(900px 500px at 80% 0%,var(--rose-100),transparent 60%),
  radial-gradient(800px 500px at 0% 100%,#fbf2e7,transparent 55%),var(--cream)}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;padding-block:clamp(3rem,7vw,5.5rem);position:relative;z-index:2}
.hero__badge{display:inline-flex;align-items:center;gap:.55rem;background:#fff;border:1px solid var(--border);padding:.5rem 1.1rem;border-radius:999px;font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700);box-shadow:var(--shadow-sm)}
.hero__badge .stars{display:inline-flex;color:var(--gold-500)}.hero__badge .stars svg{width:14px;height:14px}
.hero h1{font-size:clamp(2.5rem,6vw,4.4rem);margin:1.3rem 0 1.1rem;letter-spacing:-.01em}
.hero h1 em{font-style:italic;color:var(--gold-600)}
.hero h1 .rose{color:var(--rose-500)}
.hero__sub{font-size:1.14rem;color:var(--ink-soft);max-width:40ch;margin-bottom:2rem}
.hero__cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero__tag{display:flex;gap:1.6rem;margin-top:2.2rem;flex-wrap:wrap;align-items:center}
.hero__tag span{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--ink-soft);font-weight:700;letter-spacing:.04em}
.hero__tag svg{width:18px;height:18px;color:var(--rose-500)}
.hero__visual{position:relative}
.hero__frame{position:relative;border-radius:200px 200px 24px 24px;overflow:hidden;box-shadow:var(--shadow-lg);transform:perspective(1200px) rotateY(-6deg);transition:transform .5s var(--ease);border:8px solid #fff}
.hero__visual:hover .hero__frame{transform:perspective(1200px) rotateY(-2deg)}
.hero__frame img{width:100%;aspect-ratio:4/5;object-fit:cover}
.hero__float{position:absolute;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-radius:18px;padding:.85rem 1.1rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.7rem}
.hero__float .ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:#fff;flex:none}
.hero__float svg{width:21px;height:21px}
.hero__float .t{font-family:var(--font-head);font-weight:700;font-size:1rem;line-height:1.1}
.hero__float .s{font-size:.72rem;color:var(--muted)}
.hero__float--1{top:7%;left:-6%;animation:floaty 5s ease-in-out infinite}
.hero__float--1 .ic{background:linear-gradient(135deg,var(--rose-500),var(--rose-400))}
.hero__float--2{bottom:8%;right:-5%;animation:floaty 6s ease-in-out infinite .6s}
.hero__float--2 .ic{background:linear-gradient(135deg,var(--gold-500),var(--gold-400))}
@media(max-width:900px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__visual{max-width:400px;margin-inline:auto}
  .hero__float{display:none}
  .hero__frame{transform:none}
}

/* floating bubbles / paws */
.bubble{position:absolute;border-radius:50%;background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.9),var(--rose-200));opacity:.55;pointer-events:none;z-index:0}
.paw{position:absolute;color:var(--rose-300,#f0c4da);opacity:.5;pointer-events:none;z-index:0}
.paw svg{width:100%;height:100%}
.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;z-index:0;pointer-events:none}

/* ---------- Stats / paws strip ---------- */
.stripe{background:var(--ink);color:#f3e9df}
.stripe__inner{display:flex;align-items:center;justify-content:space-around;gap:1.6rem;flex-wrap:wrap;padding-block:2rem;text-align:center}
.stripe .n{font-family:var(--font-head);font-weight:700;font-size:clamp(1.7rem,3vw,2.3rem);color:var(--gold-400)}
.stripe .l{font-size:.82rem;letter-spacing:.05em;color:#d3c6b8}

/* ---------- Grids & Cards ---------- */
.grid{display:grid;gap:1.6rem}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2.1rem 1.8rem;box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s var(--ease);position:relative;overflow:hidden}
.card::after{content:"";position:absolute;inset:auto 0 0 0;height:3px;background:linear-gradient(90deg,var(--gold-500),var(--rose-400));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card:hover::after{transform:scaleX(1)}
.card__ic{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;margin-bottom:1.2rem;background:linear-gradient(135deg,var(--rose-100),#fbf2e7);color:var(--gold-600);box-shadow:inset 0 0 0 1px rgba(176,137,75,.14)}
.card__ic svg{width:30px;height:30px}
.card h3{font-size:1.32rem;margin-bottom:.5rem}
.card p{color:var(--ink-soft);font-size:.97rem}
.card .price{display:inline-block;margin-top:1rem;font-family:var(--font-head);font-weight:700;font-size:1.15rem;color:var(--gold-700)}
.card__link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--rose-600)}
.card__link svg{width:16px;height:16px;transition:transform .25s}
.card:hover .card__link svg{transform:translateX(4px)}

/* ---------- Split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:2.5rem}}
.split__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.split__media img{width:100%;aspect-ratio:5/4;object-fit:cover}
.split__media--round{border-radius:50% 50% 24px 24px;border:8px solid #fff}
.feature-list{display:grid;gap:1.3rem;margin-top:1.8rem}
.feature-list li{display:flex;gap:1rem;align-items:flex-start}
.feature-list .ic{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--rose-100);color:var(--rose-600)}
.feature-list .ic svg{width:23px;height:23px}
.feature-list h4{font-size:1.1rem;margin-bottom:.2rem}
.feature-list p{color:var(--ink-soft);font-size:.94rem}

/* ---------- Service packages (pricing) ---------- */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;align-items:stretch}
@media(max-width:900px){.pkg-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}
.pkg{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.3rem 2rem;box-shadow:var(--shadow-sm);transition:.4s var(--ease);position:relative;display:flex;flex-direction:column;text-align:center}
.pkg:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.pkg--pop{border:2px solid var(--gold-500);box-shadow:var(--shadow-lg)}
.pkg--pop::before{content:"Most Loved";position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--rose-500),var(--rose-400));color:#fff;font-family:var(--font-body);font-weight:700;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:.4rem 1.1rem;border-radius:999px;box-shadow:var(--shadow-rose)}
.pkg h3{font-size:1.5rem;margin-bottom:.3rem}
.pkg .ptag{color:var(--muted);font-size:.9rem;margin-bottom:1.2rem}
.pkg .amt{font-family:var(--font-head);font-weight:700;font-size:2.7rem;color:var(--gold-700);line-height:1}
.pkg .amt small{font-size:.9rem;font-weight:700;color:var(--muted);font-family:var(--font-body)}
.pkg ul{display:grid;gap:.7rem;margin:1.5rem 0;text-align:left}
.pkg li{display:flex;gap:.6rem;align-items:flex-start;font-size:.93rem;color:var(--ink-soft)}
.pkg li svg{width:18px;height:18px;color:var(--rose-500);flex:none;margin-top:2px}
.pkg .btn{margin-top:auto;width:100%;justify-content:center}

/* ---------- Gallery ---------- */
.gallery{columns:3;column-gap:1.1rem}
@media(max-width:900px){.gallery{columns:2}}
@media(max-width:560px){.gallery{columns:1}}
.gallery figure{break-inside:avoid;margin-bottom:1.1rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);position:relative;cursor:pointer}
.gallery img{width:100%;display:block;transition:transform .6s var(--ease)}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;inset:auto 0 0 0;padding:1.5rem 1rem .9rem;background:linear-gradient(transparent,rgba(46,39,48,.78));color:#fff;font-weight:700;font-size:.9rem;opacity:0;transform:translateY(8px);transition:.35s}
.gallery figure:hover figcaption{opacity:1;transform:none}
.gallery .play{position:absolute;inset:0;display:grid;place-items:center}
.gallery .play span{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;color:var(--rose-600);box-shadow:var(--shadow-md)}
.gallery .play svg{width:24px;height:24px}

/* ---------- Original cut-out pet portraits (transparent PNGs from the studio) ---------- */
.pet-bg{background:radial-gradient(125% 105% at 50% 100%,#f2bdd5 0%,#f9d9e8 46%,#fff6fb 100%)}
.hero__frame.pet-bg img,
.split__media.pet-bg img,
.gallery figure.pet-bg img{object-fit:contain;object-position:bottom center;background:transparent;filter:drop-shadow(0 14px 22px rgba(150,70,110,.22))}
.gallery figure.pet-bg{aspect-ratio:1/1}
.gallery figure.pet-bg img{width:100%;height:100%;padding:6% 6% 0}
.gallery figure.pet-bg:hover img{transform:scale(1.04)}
.gallery figure.pet-bg figcaption{opacity:1;transform:none;background:linear-gradient(transparent,rgba(46,39,48,.55))}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(46,39,48,.92);z-index:120;display:none;align-items:center;justify-content:center;padding:1.5rem}
.lightbox.open{display:flex}
.lightbox img,.lightbox iframe{max-width:92vw;max-height:86vh;border-radius:14px;box-shadow:var(--shadow-lg)}
.lightbox iframe{width:min(900px,92vw);aspect-ratio:16/9;height:auto;border:0}
.lightbox__close{position:absolute;top:1.2rem;right:1.4rem;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;display:grid;place-items:center}
.lightbox__close svg{width:26px;height:26px}

/* ---------- Reviews ---------- */
.reviews{background:linear-gradient(180deg,#fff,var(--cream))}
.cat-tabs{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.cat-tab{font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.04em;padding:.6rem 1.2rem;border-radius:999px;border:1.5px solid var(--border);background:#fff;color:var(--ink-soft);transition:.25s;cursor:pointer}
.cat-tab:hover{border-color:var(--gold-400);color:var(--gold-700)}
.cat-tab.active{background:linear-gradient(135deg,var(--gold-500),var(--gold-400));color:#fff;border-color:transparent;box-shadow:var(--shadow-gold)}
.review-meta{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2.2rem;flex-wrap:wrap}
.review-meta .gscore{font-family:var(--font-head);font-weight:700;font-size:2.4rem;color:var(--ink)}
.stars{display:inline-flex;gap:2px;color:var(--gold-500)}
.stars svg{width:18px;height:18px}
.gbadge{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--ink-soft)}
.gbadge svg{width:18px;height:18px}
.review-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.9rem;box-shadow:var(--shadow-sm);transition:.4s var(--ease);height:100%;display:flex;flex-direction:column}
.review-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.review-card .stars{margin-bottom:.9rem}
.review-card .svc{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--rose-600);margin-bottom:.6rem}
.review-card p{color:var(--ink-soft);font-size:.97rem;flex:1;font-style:italic}
.review-card__who{display:flex;align-items:center;gap:.8rem;margin-top:1.3rem}
.review-card__av{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;color:#fff;background:linear-gradient(135deg,var(--gold-500),var(--rose-500))}
.review-card__who .nm{font-family:var(--font-head);font-weight:700;font-size:.96rem;color:var(--ink)}
.review-card__who .rl{font-size:.78rem;color:var(--muted)}
.is-hidden{display:none!important}

/* ---------- CTA band ---------- */
.ctaband{position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:clamp(2.5rem,5vw,4.2rem);text-align:center;
  background:radial-gradient(700px 360px at 50% -20%,rgba(213,128,172,.28),transparent),linear-gradient(135deg,var(--gold-700),var(--gold-500))}
.ctaband *{color:#fff}
.ctaband h2{font-size:clamp(1.9rem,3.8vw,2.7rem);margin-bottom:.8rem}
.ctaband p{color:#fbeede;max-width:52ch;margin:0 auto 1.8rem}
.ctaband .btn-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------- Forms ---------- */
.formwrap{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
@media(max-width:900px){.formwrap{grid-template-columns:1fr;gap:2.2rem}}
.form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.5rem);box-shadow:var(--shadow-md)}
.form h3{font-size:1.6rem;margin-bottom:.4rem}
.form .fhint{color:var(--muted);font-size:.92rem;margin-bottom:1.5rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:700;font-size:.8rem;letter-spacing:.04em;color:var(--ink);margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;padding:.9rem 1rem;border:1.5px solid var(--border);border-radius:12px;font-family:inherit;font-size:.95rem;color:var(--ink);background:#fdfaf6;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--rose-500);box-shadow:0 0 0 4px rgba(213,128,172,.16);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:480px){.field--row{grid-template-columns:1fr}}
.form .btn{width:100%;justify-content:center;margin-top:.5rem}
.form-status{margin-top:1rem;padding:.9rem 1.1rem;border-radius:12px;font-size:.9rem;font-weight:700;display:none}
.form-status.ok{display:block;background:var(--rose-100);color:var(--rose-600)}
.form-status.err{display:block;background:#fdeaea;color:#c0392b}
.contact-aside{display:grid;gap:1.1rem}
.contact-aside .ci{display:flex;gap:1rem;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow-sm)}
.contact-aside .ic{flex:none;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--gold-500),var(--rose-500));color:#fff}
.contact-aside .ic svg{width:22px;height:22px}
.contact-aside h4{font-size:1.05rem;margin-bottom:.15rem}
.contact-aside p,.contact-aside a{color:var(--ink-soft);font-size:.92rem}
.contact-aside a:hover{color:var(--rose-600)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin-inline:auto;display:grid;gap:1rem}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:.3s;box-shadow:var(--shadow-sm)}
.faq-item.open{box-shadow:var(--shadow-md);border-color:var(--gold-300)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;text-align:left;padding:1.35rem 1.5rem;font-family:var(--font-head);font-weight:700;font-size:1.08rem;color:var(--ink)}
.faq-q .pm{flex:none;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;background:var(--rose-100);color:var(--rose-600);transition:.3s}
.faq-item.open .pm{background:var(--gold-500);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a p{padding:0 1.5rem 1.4rem;color:var(--ink-soft);font-size:.96rem}

/* ---------- Page hero (inner) ---------- */
.pagehero{position:relative;overflow:hidden;background:
  radial-gradient(700px 380px at 78% -10%,var(--rose-100),transparent 60%),
  radial-gradient(600px 360px at 0% 110%,#fbf2e7,transparent 55%),var(--cream);
  padding:clamp(3rem,6vw,5rem) 0 clamp(3.5rem,7vw,5rem)}
.pagehero__inner{position:relative;z-index:2;text-align:center;max-width:760px;margin-inline:auto}
.pagehero h1{font-size:clamp(2.2rem,5.4vw,3.6rem);margin-bottom:1rem}
.pagehero h1 em{font-style:italic;color:var(--gold-600)}
.pagehero p{color:var(--ink-soft);font-size:1.12rem}
.breadcrumb{display:flex;gap:.5rem;justify-content:center;align-items:center;font-size:.85rem;color:var(--muted);margin-bottom:1.2rem}
.breadcrumb a{color:var(--gold-700)}.breadcrumb a:hover{color:var(--rose-600)}
.breadcrumb svg{width:14px;height:14px;opacity:.6}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#c8bcc6;padding-top:clamp(3rem,6vw,4.5rem)}
.footer a{color:#c8bcc6;transition:.2s}
.footer a:hover{color:var(--gold-400)}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3rem}
@media(max-width:880px){.footer__grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}
.footer__logo{height:64px;margin-bottom:1.1rem;background:#fff;padding:8px 12px;border-radius:14px}
.footer__brand p{font-size:.92rem;max-width:32ch;margin-bottom:1.3rem}
.footer h4{color:#fff;font-family:var(--font-head);font-size:1.05rem;margin-bottom:1.1rem}
.footer__links{display:grid;gap:.65rem;font-size:.92rem}
.footer__social{display:flex;gap:.6rem;margin-top:1.2rem}
.footer__social a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);transition:.25s}
.footer__social a:hover{background:var(--rose-500);color:#fff;transform:translateY(-3px)}
.footer__social svg{width:18px;height:18px}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding-block:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem}
.footer__credit{color:#fff}
.footer__credit b{color:var(--gold-400)}

/* ---------- Mobile sticky call / whatsapp ---------- */
.mobilebar{position:fixed;bottom:0;left:0;right:0;z-index:80;display:none;grid-template-columns:1fr 1fr;gap:1px;background:rgba(46,39,48,.1);box-shadow:0 -6px 24px rgba(46,39,48,.18)}
.mobilebar a{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;font-weight:700;font-size:.9rem;letter-spacing:.04em;color:#fff}
.mobilebar .call{background:var(--gold-600)}
.mobilebar .wa{background:#25D366}
.mobilebar svg{width:20px;height:20px}
@media(max-width:768px){.mobilebar{display:grid}body{padding-bottom:54px}}

/* ---------- Reveal & motion ---------- */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.1s}
[data-reveal][data-delay="2"]{transition-delay:.2s}
[data-reveal][data-delay="3"]{transition-delay:.3s}
[data-reveal][data-delay="4"]{transition-delay:.4s}

@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes drift{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(24px,-26px) rotate(8deg)}}
@keyframes rise{0%{transform:translateY(0) scale(1);opacity:.5}100%{transform:translateY(-60px) scale(1.15);opacity:0}}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1;transform:none}
  .hero__frame{transform:none}
}
