/* =============================================
   GlamPetz — Complete Redesign
   Font: Roboto + Playfair Display
   Theme: Pink & Yellow Premium
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&family=Playfair+Display:ital,wght@0,700;0,800;1,700&display=swap');

:root {
  --pink:#FF4E8B; --pink-d:#D6306D; --pink-l:#FF80AA; --pink-pale:#FFF0F6; --pink-bg:#FFF5F9;
  --yellow:#FFD60A; --yellow-d:#E6B800; --yellow-pale:#FFFBEC;
  --dark:#150D1E; --dark2:#221535; --dark3:#2D1F3A;
  --text:#2C1D3A; --muted:#7B6A8A; --light:#C4B5D4;
  --white:#fff; --border:rgba(255,78,139,.13); --border2:rgba(255,78,139,.22);
  --sh-sm:0 2px 12px rgba(255,78,139,.1); --sh-md:0 8px 32px rgba(255,78,139,.18); --sh-lg:0 24px 64px rgba(255,78,139,.22);
  --r:16px; --r-sm:10px; --r-lg:24px; --r-xl:40px; --r-full:9999px;
  --t:.3s cubic-bezier(.4,0,.2,1);
  --f:Roboto,sans-serif; --fd:'Playfair Display',serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--f);color:var(--text);background:var(--white);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:#f1e8f5}
::-webkit-scrollbar-thumb{background:var(--pink);border-radius:3px}

/* ── CONTAINER ── */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
section{position:relative;z-index:1}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--r-full);font-weight:700;font-size:.92rem;letter-spacing:.3px;transition:var(--t);white-space:nowrap;cursor:pointer;position:relative;overflow:hidden}
.btn-primary{background:linear-gradient(135deg,var(--pink),var(--pink-d));color:#fff;box-shadow:0 6px 24px rgba(255,78,139,.38)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(255,78,139,.48)}
.btn-yellow{background:var(--yellow);color:var(--dark);box-shadow:0 6px 24px rgba(255,214,10,.4)}
.btn-yellow:hover{background:var(--yellow-d);transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,214,10,.5)}
.btn-outline{border:2px solid var(--pink);color:var(--pink)}
.btn-outline:hover{background:var(--pink);color:#fff;transform:translateY(-1px)}
.btn-white{background:#fff;color:var(--pink);box-shadow:0 4px 18px rgba(0,0,0,.12)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.18)}
.btn-ghost{background:rgba(255,78,139,.08);color:var(--pink)}
.btn-ghost:hover{background:rgba(255,78,139,.15)}
.btn-sm{padding:6px 18px;font-size:.82rem}
.btn-lg{padding:17px 36px;font-size:1rem}

/* ── HEADER ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:var(--t);padding:0}
.header-inner{max-width:1300px;margin:0 auto;padding:0 5px;height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px;background:#d1c2c2}
.site-header.scrolled{background:rgba(255,255,255,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 2px 24px rgba(255,78,139,.1)}
.site-header.hero-transparent{background:transparent}

.logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--pink),var(--pink-d));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:0 4px 14px rgba(255,78,139,.4)}
.logo-main{display:block;font-weight:900;font-size:1.2rem;color:var(--dark);letter-spacing:-.3px}
.logo-sub{display:block;font-size:.6rem;color:var(--muted);font-weight:500;letter-spacing:.8px;text-transform:uppercase}
.logo-white .logo-main,.logo-white .logo-sub{color:#fff}

.main-nav{display:flex;align-items:center;gap:2px}
.nav-link{padding:8px 14px;border-radius:8px;font-weight:500;font-size:.88rem;color:var(--muted);transition:var(--t);white-space:nowrap}
.nav-link:hover,.nav-link.active{color:var(--pink);}
.nav-white .nav-link{color:rgba(255,255,255,.8)}
.nav-white .nav-link:hover,.nav-white .nav-link.active{color:#fff;background:rgba(255,255,255,.15)}

.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn-header-ghost{padding:9px 18px;border:1.5px solid var(--pink);color:var(--pink);border-radius:var(--r-full);font-weight:600;font-size:.85rem;transition:var(--t)}
.btn-header-ghost:hover{background:var(--pink);color:#fff}
.btn-header-ghost.white{border-color:rgba(255,255,255,.6);color:#fff}
.btn-header-ghost.white:hover{background:rgba(255,255,255,.2)}

.hamburger{display:none;flex-direction:column;gap:5px;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:var(--t)}
.hamburger.white span{background:#fff}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{display:none;flex-direction:column;background:#fff;padding:12px 24px 24px;border-top:1px solid var(--border);gap:4px}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:12px 16px;border-radius:10px;font-weight:500;color:var(--text);transition:var(--t)}
.mobile-nav a:hover{background:var(--pink-pale);color:var(--pink)}
.mobile-nav .m-cta{background:var(--pink);color:#fff;text-align:center;font-weight:700;border-radius:var(--r-full);margin-top:6px}

/* ── HERO ── */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;overflow:hidden;padding-top:72px}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#1A0A2E 0%,#2D1040 40%,#1A0A2E 100%);z-index:0}
.hero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(255,78,139,.25) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(255,214,10,.12) 0%,transparent 50%)}
.hero-paws{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
.hero-paw{position:absolute;font-size:1.5rem;opacity:.06;animation:floatUp linear infinite}
@keyframes floatUp{0%{transform:translateY(110vh) rotate(0deg);opacity:0}10%{opacity:.08}90%{opacity:.05}100%{transform:translateY(-20vh) rotate(360deg);opacity:0}}

.hero-inner{max-width:1200px;margin:0 auto;padding:80px 32px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:rgba(255,214,10,.15);color:var(--yellow);border:1px solid rgba(255,214,10,.3);border-radius:var(--r-full);font-size:.78rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-bottom:22px}
.hero h1{font-family:var(--fd);font-size:clamp(2.6rem,5vw,4.2rem);font-weight:800;line-height:1.12;color:#fff;margin-bottom:20px;letter-spacing:-.5px}
.hero h1 em{font-style:normal;color:var(--yellow)}
.hero h1 .pink-word{color:var(--pink-l)}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.7);line-height:1.75;margin-bottom:36px;max-width:480px;font-weight:300}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.hero-trust{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.trust-faces{display:flex}
.trust-face{width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:linear-gradient(135deg,var(--pink),var(--yellow));display:flex;align-items:center;justify-content:center;font-size:1rem;margin-left:-8px}
.trust-face:first-child{margin-left:0}
.trust-text{color:rgba(255,255,255,.75);font-size:.82rem}
.trust-text strong{color:#fff;display:block;font-size:.9rem}

.hero-visual{position:relative}
.hero-img-main{width:100%;border-radius:24px;aspect-ratio:4/5;object-fit:cover;box-shadow:0 32px 80px rgba(0,0,0,.5)}
.hero-card{position:absolute;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-radius:var(--r);padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-lg);font-size:.82rem;animation:cardFloat 4s ease-in-out infinite}
.hero-card-1{bottom:24px;left:-24px}
.hero-card-2{top:32px;right:-20px;animation-delay:2s}
.hero-card .card-icon{font-size:1.6rem}
.hero-card .card-lbl{font-weight:700;color:var(--dark);font-size:.85rem}
.hero-card .card-sub{color:var(--muted);font-size:.72rem;margin-top:1px}
.hero-ring{position:absolute;top:-20px;right:-20px;width:160px;height:160px;border:2px dashed rgba(255,214,10,.3);border-radius:50%;animation:spin 20s linear infinite}
@keyframes cardFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── STATS BAR ── */
.stats-bar{background:linear-gradient(135deg,var(--pink),var(--pink-d));padding:28px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;gap:10px}
.stats-grid .divider{width:1px;background:rgba(255,255,255,.2);margin:auto 0}
.stat-val{font-size:2rem;font-weight:900;color:#fff;line-height:1}
.stat-lbl{font-size:.78rem;color:rgba(255,255,255,.75);margin-top:4px;font-weight:500;letter-spacing:.3px}

/* ── SECTION HEADERS ── */
.sec-head{text-align:center;margin-bottom:56px}
.sec-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;background:var(--pink-pale);color:var(--pink);border-radius:var(--r-full);font-size:.72rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:14px}
.sec-title{font-family:var(--fd);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:var(--dark);margin-bottom:14px;line-height:1.2;letter-spacing:-.3px}
.sec-title em{font-style:normal;color:var(--pink)}
.sec-sub{font-size:1rem;color:var(--muted);max-width:500px;margin:0 auto;line-height:1.7}

/* ── SERVICES ── */
.services-sec{padding:100px 0;background:#fff}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.svc-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1.5px solid var(--border);transition:var(--t);position:relative;cursor:pointer}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--sh-lg);border-color:var(--pink-l)}
.svc-img{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--pink-pale),var(--yellow-pale));display:flex;align-items:center;justify-content:center;font-size:4.5rem;transition:var(--t)}
.svc-card:hover .svc-img{transform:scale(1.03)}
.svc-body{padding:22px}
.svc-tag{display:inline-block;padding:4px 12px;background:var(--pink-pale);color:var(--pink);border-radius:var(--r-full);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.svc-name{font-size:1.05rem;font-weight:700;color:var(--dark);margin-bottom:8px}
.svc-desc{font-size:.85rem;color:var(--muted);line-height:1.6;margin-bottom:16px}
.svc-foot{display:flex;align-items:center;justify-content:space-between}
.svc-book-btn{padding:9px 18px;background:linear-gradient(135deg,var(--pink),var(--pink-d));color:#fff;border-radius:var(--r-full);font-size:.8rem;font-weight:700;transition:var(--t)}
.svc-book-btn:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(255,78,139,.4)}
.svc-hot{position:absolute;top:14px;right:14px;background:var(--yellow);color:var(--dark);padding:4px 10px;border-radius:var(--r-full);font-size:.7rem;font-weight:900;letter-spacing:.3px}

/* ── WHY US ── */
.why-sec{padding:100px 0;background:linear-gradient(160deg,var(--pink-bg),var(--yellow-pale))}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.why-img-wrap{position:relative}
.why-img{width:100%;border-radius:24px;box-shadow:var(--sh-lg);aspect-ratio:4/5;object-fit:cover}
.why-badge-float{position:absolute;bottom:-20px;right:-20px;background:#fff;border-radius:var(--r);padding:18px 22px;box-shadow:var(--sh-md);text-align:center}
.why-badge-float .big-num{font-size:2rem;font-weight:900;color:var(--pink);line-height:1}
.why-badge-float .big-lbl{font-size:.72rem;color:var(--muted);font-weight:500;margin-top:2px}
.why-list{display:flex;flex-direction:column;gap:22px;margin-top:32px}
.why-item{display:flex;gap:16px;align-items:flex-start}
.why-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--pink-pale),var(--yellow-pale));display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;box-shadow:var(--sh-sm)}
.why-item h4{font-weight:700;color:var(--dark);margin-bottom:4px}
.why-item p{font-size:.88rem;color:var(--muted);line-height:1.6}

/* ── HOW IT WORKS ── */
.how-sec{padding:100px 0;background:#fff}
.steps-wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative}
.steps-wrap::before{content:'';position:absolute;top:40px;left:12%;right:12%;height:2px;background:linear-gradient(90deg,var(--pink),var(--yellow),var(--pink));z-index:0;border-radius:2px}
.step-card{text-align:center;position:relative;z-index:1}
.step-num{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--pink-d));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:900;margin:0 auto 20px;box-shadow:0 8px 28px rgba(255,78,139,.4);border:4px solid #fff}
.step-title{font-weight:700;font-size:1rem;color:var(--dark);margin-bottom:8px}
.step-text{font-size:.85rem;color:var(--muted);line-height:1.65}

/* ── FEATURES TICKER ── */
.ticker-sec{background:var(--dark);padding:18px 0;overflow:hidden}
.ticker-track{display:flex;gap:0;animation:ticker 25s linear infinite;width:max-content}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{display:flex;align-items:center;gap:10px;padding:0 32px;color:rgba(255,255,255,.7);font-size:.85rem;font-weight:500;white-space:nowrap}
.ticker-item span{color:var(--pink-l)}
.ticker-dot{width:6px;height:6px;border-radius:50%;background:var(--yellow);flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── GALLERY ── */
.gallery-sec{padding:100px 0;background:var(--pink-bg)}
.gallery-masonry{columns:4;column-gap:16px}
.gallery-item{break-inside:avoid;margin-bottom:16px;border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer}
.gallery-item img{width:100%;display:block;transition:var(--t)}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item-placeholder{width:100%;background:linear-gradient(135deg,var(--pink-pale),var(--yellow-pale));display:flex;align-items:center;justify-content:center;font-size:3rem;transition:var(--t)}
.gallery-item:hover .gallery-item-placeholder{transform:scale(1.05)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);opacity:0;transition:var(--t);display:flex;align-items:flex-end;padding:14px}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{color:#fff;font-size:.8rem;font-weight:600}
.gallery-scroll-row{display:flex;gap:16px;overflow:hidden;margin-top:20px}
.gallery-scroll-inner{display:flex;gap:16px;animation:scrollGal 30s linear infinite}
.gallery-scroll-inner:hover{animation-play-state:paused}
.gal-slide{width:220px;height:180px;flex-shrink:0;border-radius:var(--r);overflow:hidden;background:linear-gradient(135deg,var(--pink-pale),var(--yellow-pale));display:flex;align-items:center;justify-content:center;font-size:3.5rem}
.gal-slide img{width:100%;height:100%;object-fit:cover}
@keyframes scrollGal{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── TESTIMONIALS ── */
.testi-sec{padding:100px 0;background:#fff}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);padding:28px;transition:var(--t);position:relative}
.testi-card:hover{box-shadow:var(--sh-md);transform:translateY(-4px);border-color:var(--pink-l)}
.testi-card::before{content:'"';position:absolute;top:12px;left:18px;font-size:6rem;color:var(--pink);opacity:.08;font-family:var(--fd);line-height:1}
.testi-stars{color:var(--yellow-d);font-size:.95rem;margin-bottom:12px}
.testi-text{font-size:.9rem;color:var(--text);line-height:1.75;margin-bottom:20px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--yellow));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1.1rem;flex-shrink:0}
.testi-name{font-weight:700;font-size:.9rem;color:var(--dark)}
.testi-pet{font-size:.75rem;color:var(--muted)}

/* ── PROMO BANNER ── */
.promo-sec{padding:80px 0;background:linear-gradient(135deg,var(--dark),#3D1060)}
.promo-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.promo-text h2{font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);color:#fff;font-weight:800;margin-bottom:16px;line-height:1.2}
.promo-text h2 em{font-style:normal;color:var(--yellow)}
.promo-text p{color:rgba(255,255,255,.7);font-size:1rem;line-height:1.7;margin-bottom:32px}
.promo-features{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.promo-feat{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.8);font-size:.88rem}
.promo-feat .check{width:22px;height:22px;border-radius:50%;background:var(--pink);display:flex;align-items:center;justify-content:center;font-size:.7rem;flex-shrink:0}
.promo-img{border-radius:24px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.5)}
.promo-img img{width:100%;aspect-ratio:1;object-fit:cover}
.promo-img-placeholder{width:100%;aspect-ratio:1;background:linear-gradient(135deg,rgba(255,78,139,.3),rgba(255,214,10,.2));display:flex;align-items:center;justify-content:center;font-size:8rem}

/* ── CTA ── */
.cta-sec{padding:100px 0;background:linear-gradient(135deg,var(--pink-bg),var(--yellow-pale));text-align:center}
.cta-inner h2{font-family:var(--fd);font-size:clamp(2rem,4vw,3.2rem);font-weight:800;color:var(--dark);margin-bottom:16px}
.cta-inner h2 em{font-style:normal;color:var(--pink)}
.cta-inner p{color:var(--muted);font-size:1.05rem;margin-bottom:36px;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.7}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── BOOKING STRIP ── */
.strip{background:linear-gradient(135deg,var(--pink),var(--pink-d));padding:28px 0}
.strip-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.strip-text h3{font-size:1.25rem;font-weight:700;color:#fff}
.strip-text p{font-size:.88rem;color:rgba(255,255,255,.8);margin-top:2px}
.strip-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.strip-ctrl{padding:11px 18px;border-radius:var(--r-full);border:none;font-family:var(--f);font-size:.88rem;font-weight:500;background:rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(10px);outline:none;min-width:150px}
.strip-ctrl::placeholder{color:rgba(255,255,255,.65)}
.strip-ctrl option{color:var(--dark);background:#fff}
.strip-go{padding:11px 24px;background:var(--yellow);color:var(--dark);border:none;border-radius:var(--r-full);font-weight:700;font-size:.88rem;cursor:pointer;transition:var(--t)}
.strip-go:hover{background:var(--yellow-d);transform:scale(1.03)}

/* ── PAGE HERO ── */
.page-hero{padding:130px 0 70px;background:linear-gradient(135deg,var(--dark),var(--dark2));text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'🐾';position:absolute;font-size:20rem;opacity:.04;bottom:-60px;right:-60px;pointer-events:none}
.page-hero h1{font-family:var(--fd);font-size:clamp(2.2rem,4.5vw,3.5rem);font-weight:800;color:#fff;margin-bottom:14px}
.page-hero h1 em{font-style:normal;color:var(--yellow)}
.page-hero p{color:rgba(255,255,255,.7);font-size:1.05rem;max-width:520px;margin:0 auto}
.breadcrumb{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:16px;font-size:.8rem;color:rgba(255,255,255,.5)}
.breadcrumb a{color:var(--pink-l)}
.breadcrumb span{color:rgba(255,255,255,.3)}

/* ── GALLERY PAGE ── */
.gallery-page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.gallery-page-item{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;position:relative;cursor:pointer;group}
.gallery-page-item img,.gallery-page-item .gp-placeholder{width:100%;height:100%;object-fit:cover;transition:var(--t)}
.gp-placeholder{display:flex;align-items:center;justify-content:center;font-size:4rem;background:linear-gradient(135deg,var(--pink-pale),var(--yellow-pale))}
.gallery-page-item:hover img,.gallery-page-item:hover .gp-placeholder{transform:scale(1.08)}
.gp-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 55%);opacity:0;transition:var(--t);display:flex;align-items:flex-end;padding:20px}
.gallery-page-item:hover .gp-overlay{opacity:1}
.gp-overlay-text{color:#fff;font-weight:600;font-size:.88rem}

/* ── ABOUT PAGE ── */
.about-story{padding:100px 0;background:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-img-stack{position:relative}
.about-img-main{width:100%;border-radius:24px;box-shadow:var(--sh-lg);aspect-ratio:3/4;object-fit:cover}
.about-img-sec{position:absolute;bottom:-24px;right:-24px;width:55%;border-radius:var(--r-lg);box-shadow:var(--sh-lg);border:4px solid #fff;aspect-ratio:4/3;object-fit:cover}
.about-img-badge{position:absolute;top:24px;left:-24px;background:#fff;border-radius:var(--r);padding:16px 20px;box-shadow:var(--sh-md);text-align:center}
.about-img-badge .bn{font-size:1.8rem;font-weight:900;color:var(--pink);line-height:1}
.about-img-badge .bl{font-size:.7rem;color:var(--muted);font-weight:500;margin-top:2px}
.about-content h2{font-family:var(--fd);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:var(--dark);margin-bottom:18px;line-height:1.2}
.about-content p{color:var(--muted);line-height:1.8;margin-bottom:18px;font-size:.95rem}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:28px}
.about-val{background:var(--pink-pale);border-radius:var(--r);padding:18px;display:flex;gap:12px;align-items:flex-start}
.about-val .vi{font-size:1.4rem}
.about-val h5{font-weight:700;font-size:.88rem;color:var(--dark);margin-bottom:3px}
.about-val p{font-size:.78rem;color:var(--muted);margin:0;line-height:1.5}

.about-team{padding:100px 0;background:var(--pink-bg)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px}
.team-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1.5px solid var(--border);transition:var(--t);text-align:center}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md)}
.team-photo{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--pink-pale),var(--yellow-pale));display:flex;align-items:center;justify-content:center;font-size:5rem}
.team-body{padding:20px}
.team-name{font-weight:700;font-size:1rem;color:var(--dark);margin-bottom:4px}
.team-role{font-size:.78rem;color:var(--pink);font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.team-bio{font-size:.82rem;color:var(--muted);line-height:1.6}

/* ── FORMS ── */
.form-page{min-height:100vh;background:linear-gradient(160deg,var(--pink-bg),var(--yellow-pale));display:flex;align-items:center;justify-content:center;padding:100px 24px 60px}
.form-card{width:100%;max-width:520px;background:#fff;border-radius:var(--r-xl);padding:48px;box-shadow:var(--sh-lg);position:relative;overflow:hidden}
.form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--pink),var(--yellow),var(--pink))}
.form-logo{text-align:center;margin-bottom:32px}
.form-logo .fli{width:60px;height:60px;background:linear-gradient(135deg,var(--pink),var(--pink-d));border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 12px;box-shadow:0 6px 20px rgba(255,78,139,.35)}
.form-title{font-family:var(--fd);font-size:1.8rem;font-weight:800;color:var(--dark);margin-bottom:6px}
.form-subtitle{color:var(--muted);font-size:.88rem}

.fg{margin-bottom:18px}
.flbl{display:block;font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:6px}
.fc{width:100%;padding:13px 17px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:var(--f);font-size:.93rem;color:var(--text);background:#fff;transition:var(--t);outline:none}
.fc:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,78,139,.1)}
.fc::placeholder{color:var(--light)}
select.fc{cursor:pointer}
textarea.fc{resize:vertical;min-height:100px}
.fc.invalid{border-color:#e53e3e}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.f-hint{font-size:.75rem;color:var(--muted);margin-top:4px}
.f-err{font-size:.78rem;color:#e53e3e;margin-top:4px}
.f-submit{width:100%;padding:16px;font-size:1rem;margin-top:8px;justify-content:center}
.f-foot{text-align:center;margin-top:22px;font-size:.88rem;color:var(--muted)}
.f-foot a{color:var(--pink);font-weight:600}
.f-divider{display:flex;align-items:center;gap:12px;margin:18px 0}
.f-divider::before,.f-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.f-divider span{font-size:.78rem;color:var(--muted);font-weight:500}
.input-wrap{position:relative}
.input-wrap .fc{padding-right:44px}
.eye-btn{position:absolute;right:13px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);font-size:1rem;line-height:1}

/* ── ALERTS ── */
.alert{padding:13px 17px;border-radius:var(--r-sm);font-size:.86rem;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.alert-err{background:#FFF5F5;color:#c53030;border:1px solid #fed7d7}
.alert-ok{background:#f0fff4;color:#276749;border:1px solid #c6f6d5}
.alert-info{background:var(--pink-pale);color:var(--pink-d);border:1px solid rgba(255,78,139,.2)}

/* ── DASHBOARD ── */
.dash-layout{display:flex;min-height:100vh;padding-top:72px}
.sidebar{width:260px;flex-shrink:0;background:var(--dark);color:#fff;padding:28px 0;position:sticky;top:72px;height:calc(100vh - 72px);overflow-y:auto}
.sb-user{padding:0 24px 24px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:16px}
.sb-av{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--yellow));display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;margin-bottom:10px}
.sb-name{font-weight:700;font-size:.92rem}
.sb-email{font-size:.72rem;color:rgba(255,255,255,.45)}
.sb-nav{padding:0 12px}
.sb-nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:9px;font-size:.86rem;font-weight:500;color:rgba(255,255,255,.6);transition:var(--t);margin-bottom:2px}
.sb-nav a:hover,.sb-nav a.active{background:rgba(255,78,139,.2);color:var(--pink-l)}
.sb-nav a .ni{font-size:1.05rem;width:22px;text-align:center}
.sb-sec{padding:16px 13px 6px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.3)}

.dash-main{flex:1;background:#F5F0FF;overflow-y:auto}
.dash-content{padding:32px;max-width:1100px}
.dash-title{font-family:var(--fd);font-size:1.6rem;font-weight:800;color:var(--dark);margin-bottom:4px}
.dash-sub{color:var(--muted);font-size:.88rem;margin-bottom:26px}
.dash-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:#fff;border-radius:var(--r);padding:20px;border:1.5px solid var(--border);display:flex;align-items:center;gap:14px}
.stat-ico{width:50px;height:50px;border-radius:13px;background:linear-gradient(135deg,var(--pink-pale),var(--yellow-pale));display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.stat-val{font-size:1.5rem;font-weight:800;color:var(--dark)}
.stat-lbl{font-size:.75rem;color:var(--muted);font-weight:500}

.dash-card{background:#fff;border-radius:var(--r-lg);border:1.5px solid var(--border);overflow:hidden;margin-bottom:22px}
.dash-card-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.dash-card-title{font-weight:700;font-size:.95rem;color:var(--dark)}
.dash-card-body{padding:22px}

/* ── TABLES ── */
.tbl{width:100%;border-collapse:collapse;font-size:.85rem}
.tbl th{padding:11px 13px;background:var(--pink-pale);color:var(--pink-d);font-weight:700;text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px}
.tbl td{padding:13px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--pink-bg)}

/* ── BADGES ── */
.badge{display:inline-block;padding:4px 11px;border-radius:var(--r-full);font-size:.72rem;font-weight:700}
.b-pending{background:#FFF3CD;color:#856404}
.b-confirmed{background:#D1ECF1;color:#0C5460}
.b-in_progress{background:#CCE5FF;color:#004085}
.b-completed{background:#D4EDDA;color:#155724}
.b-cancelled{background:#F8D7DA;color:#721C24}

/* ── PETS GRID ── */
.pets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.pet-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);padding:20px;text-align:center;transition:var(--t)}
.pet-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.pet-photo{width:76px;height:76px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--yellow));display:flex;align-items:center;justify-content:center;font-size:2.2rem;margin:0 auto 12px}
.pet-name{font-weight:700;font-size:1rem;color:var(--dark)}
.pet-breed{font-size:.8rem;color:var(--muted);margin-bottom:10px}
.pet-tags{display:flex;gap:5px;justify-content:center;flex-wrap:wrap;margin-bottom:12px}
.pet-tag{padding:3px 9px;background:var(--pink-pale);color:var(--pink);border-radius:var(--r-full);font-size:.7rem;font-weight:600}
.pet-actions{display:flex;gap:7px;justify-content:center}

/* ── ACTION BTNS ── */
.act{padding:6px 13px;border-radius:7px;font-size:.74rem;font-weight:600;border:none;cursor:pointer;transition:var(--t)}
.act-ok{background:#D4EDDA;color:#155724}.act-ok:hover{background:#c3e6cb}
.act-del{background:#F8D7DA;color:#721C24}.act-del:hover{background:#f5c6cb}
.act-view{background:var(--pink-pale);color:var(--pink-d)}.act-view:hover{background:var(--pink);color:#fff}

/* ── BOOKING FORM ── */
.book-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:start}
.book-summary{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);padding:24px;position:sticky;top:100px}
.bs-title{font-weight:800;font-size:.95rem;color:var(--dark);margin-bottom:16px}
.bs-line{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}
.bs-line:last-child{border-bottom:none}
.bs-total{font-weight:800;color:var(--pink);font-size:1.1rem}

/* ── ADMIN ── */
.admin-wrap{display:flex;min-height:100vh}
.admin-sb{width:240px;flex-shrink:0;background:#120820;color:#fff;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:100}
.admin-logo{padding:22px 20px;border-bottom:1px solid rgba(255,255,255,.07);font-weight:800;font-size:1.05rem;display:flex;align-items:center;gap:10px;color:#fff}
.admin-nav{padding:14px 10px}
.admin-nav a{display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:8px;font-size:.86rem;color:rgba(255,255,255,.55);transition:var(--t);margin-bottom:2px}
.admin-nav a:hover,.admin-nav a.active{background:rgba(255,78,139,.18);color:var(--pink-l)}
.admin-nav .nav-sec{padding:14px 13px 5px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.25)}
.admin-main{margin-left:240px;flex:1;background:#F0EBF8;min-height:100vh}
.admin-top{background:#fff;height:64px;padding:0 28px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;box-shadow:var(--sh-sm)}
.admin-top-title{font-weight:700;font-size:1.05rem;color:var(--dark)}
.admin-content{padding:28px}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.a-stat{background:#fff;border-radius:var(--r);padding:20px;border:1.5px solid var(--border)}
.a-stat-ico{font-size:1.8rem;margin-bottom:8px}
.a-stat-val{font-size:1.9rem;font-weight:900;color:var(--pink)}
.a-stat-lbl{font-size:.8rem;color:var(--muted);font-weight:500;margin-top:3px}

.admin-tbl-card{background:#fff;border-radius:var(--r-lg);border:1.5px solid var(--border);overflow:hidden;margin-bottom:24px}
.atc-head{padding:17px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.atc-title{font-weight:700;color:var(--dark);font-size:.95rem}
.admin-tbl{width:100%;border-collapse:collapse;font-size:.84rem}
.admin-tbl th{background:var(--pink-pale);padding:11px 15px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--pink-d)}
.admin-tbl td{padding:13px 15px;border-bottom:1px solid var(--border);vertical-align:middle}
.admin-tbl tr:last-child td{border-bottom:none}
.admin-tbl tr:hover td{background:var(--pink-bg)}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.fi{padding:10px 15px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:var(--f);font-size:.86rem;outline:none;transition:var(--t);background:#fff}
.fi:focus{border-color:var(--pink)}

/* ── FOOTER ── */
.site-footer{background:var(--dark);color:#fff}
.ft-top{padding:70px 0 50px}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:40px}
.ft-logo{display:flex;align-items:center;gap:10px;font-size:1.3rem;font-weight:900;margin-bottom:14px}
.ft-brand p{color:rgba(255,255,255,.5);font-size:.86rem;line-height:1.75;margin-bottom:20px}
.ft-socials{display:flex;gap:8px;flex-wrap:wrap}
.ft-soc{padding:8px 14px;background:rgba(255,255,255,.07);border-radius:8px;font-size:.76rem;font-weight:600;color:rgba(255,255,255,.65);transition:var(--t)}
.ft-soc:hover{background:var(--pink);color:#fff}
.ft-links h4{font-weight:700;margin-bottom:16px;font-size:.88rem;color:rgba(255,255,255,.9)}
.ft-links ul{display:flex;flex-direction:column;gap:8px}
.ft-links a{color:rgba(255,255,255,.48);font-size:.84rem;transition:var(--t)}
.ft-links a:hover{color:var(--pink-l)}
.ft-contact h4{font-weight:700;margin-bottom:16px;font-size:.88rem}
.ft-ci{display:flex;gap:10px;align-items:flex-start;font-size:.84rem;color:rgba(255,255,255,.5);margin-bottom:10px}
.ft-bottom{border-top:1px solid rgba(255,255,255,.07);padding:20px 0}
.ft-bottom .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.ft-bottom p{color:rgba(255,255,255,.35);font-size:.8rem}
.ft-bottom a{color:rgba(255,255,255,.45)}
.ft-bottom a:hover{color:var(--pink-l)}

/* ── TOAST ── */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:13px 18px;border-radius:var(--r-sm);font-size:.86rem;font-weight:600;max-width:300px;display:flex;align-items:center;gap:9px;animation:toastIn .3s ease;box-shadow:var(--sh-md)}
.toast-ok{background:#d4edda;color:#155724}
.toast-err{background:#f8d7da;color:#721c24}
.toast-info{background:var(--pink-pale);color:var(--pink-d)}
@keyframes toastIn{from{transform:translateX(80px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── MODAL ── */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:var(--t)}
.modal-ov.open{opacity:1}
.modal-box{background:#fff;border-radius:var(--r-xl);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;padding:36px;transform:scale(.95);transition:var(--t)}
.modal-ov.open .modal-box{transform:scale(1)}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px}
.modal-title{font-family:var(--fd);font-size:1.4rem;font-weight:800;color:var(--dark)}
.modal-cls{background:var(--pink-pale);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--pink);font-size:1rem}
.modal-cls:hover{background:var(--pink);color:#fff}

/* ── UTILS ── */
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--pink);border-radius:50%;animation:spin .8s linear infinite;margin:32px auto}
.text-pink{color:var(--pink)}.text-yellow{color:var(--yellow-d)}.text-muted{color:var(--muted)}
.fw-bold{font-weight:700}.mt-3{margin-top:12px}.mb-4{margin-bottom:16px}
.flex{display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.items-center{align-items:center}.justify-between{justify-content:space-between}
.text-center{text-align:center}.text-sm{font-size:.875rem}.w-full{width:100%}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:40px}
  .hero h1{font-size:2.8rem}
  .hero-btns{justify-content:center}
  .hero-trust{justify-content:center}
  .hero-visual{max-width:480px;margin:0 auto}
  .hero-ring{display:none}
  .why-grid{grid-template-columns:1fr;gap:40px}
  .why-img-wrap{max-width:480px;margin:0 auto}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-img-stack{max-width:440px;margin:0 auto}
  .promo-inner{grid-template-columns:1fr;gap:40px}
  .steps-wrap{grid-template-columns:1fr 1fr}.steps-wrap::before{display:none}
  .testi-grid{grid-template-columns:1fr 1fr}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr 1fr}
  .gallery-masonry{columns:3}
  .book-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .main-nav,.header-cta .btn-header-ghost:not(.always){display:none}
  .hamburger{display:flex}
  .mobile-nav.open{display:flex}
  .hero-inner{padding:60px 24px}
  .hero h1{font-size:2.2rem}
  .testi-grid{grid-template-columns:1fr}
  .admin-sb{transform:translateX(-100%);transition:var(--t)}
  .admin-sb.open{transform:translateX(0)}
  .admin-main{margin-left:0}
  .admin-stats{grid-template-columns:1fr 1fr}
  .dash-layout{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;padding:16px 0}
  .dash-content{padding:18px}
  .gallery-masonry{columns:2}
  .f-row{grid-template-columns:1fr}
  .about-img-sec{display:none}
  .ft-grid{grid-template-columns:1fr}
  .strip-inner{flex-direction:column;align-items:flex-start}
  .strip-form{width:100%}
  .stats-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .hero h1{font-size:1.9rem}
  .form-card{padding:28px 20px}
  .admin-stats{grid-template-columns:1fr}
  .admin-content{padding:14px}
  .gallery-masonry{columns:1}
  .stats-grid{grid-template-columns:1fr 1fr}
  .container{padding:0 16px}
}

/* ── SEO/A11Y ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--pink);outline-offset:2px}
