/* ============================================================
   VERO'S PET CARE — style.css
   Dark Rose + Gold palette · Pacifico / Nunito / Lato
   ============================================================ */

/* Fonts loaded via <link> in each HTML page for reliability */

/* ---- Variables ---- */
:root {
  --clr-primary:   #A0274A;
  --clr-secondary: #C9507A;
  --clr-accent:    #F0B800;
  --clr-neutral:   #FFF0F5;
  --clr-bg:        #FFFFFF;
  --clr-text:      #2C1020;
  --clr-muted:     #7A4055;
  --clr-dark:      #1A0510;
  --clr-border:    #F0C8D8;
  --font-brand:    'Pacifico', cursive;
  --font-head:     'Nunito', sans-serif;
  --font-body:     'Lato', sans-serif;
  --radius:        10px;
  --radius-lg:     18px;
  --max-w:         1180px;
  --trans:         0.22s ease;
  --shadow-sm:     0 2px 8px rgba(0,0,0,.07);
  --shadow-md:     0 6px 24px rgba(0,0,0,.11);
  --shadow-lg:     0 12px 40px rgba(0,0,0,.16);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--clr-text);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:var(--clr-primary);text-decoration:none}
a:hover{text-decoration:underline}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}

/* ---- Accessibility ---- */
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--clr-primary);color:#fff;padding:8px 16px;border-radius:0 0 var(--radius) var(--radius);font-size:.875rem;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}
:focus-visible{outline:2px solid var(--clr-accent);outline-offset:3px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---- Typography ---- */
h1,h2,h3,h4{font-family:var(--font-head);font-weight:800;line-height:1.2;color:var(--clr-text)}
h1{font-size:clamp(1.9rem,5vw,3rem)}
h2{font-size:clamp(1.45rem,3.5vw,2.2rem)}
h3{font-size:clamp(1.05rem,2.5vw,1.35rem)}
p{font-size:clamp(.94rem,2vw,1.04rem);color:var(--clr-muted)}
.brand-name{font-family:var(--font-brand);color:var(--clr-primary)}
.section-label{font-family:var(--font-head);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-primary);display:block;margin-bottom:.5rem}

/* ---- Layout ---- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 1.25rem}
section{padding:4rem 0}
@media(min-width:768px){section{padding:5rem 0}}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:50px;font-family:var(--font-head);font-weight:700;font-size:.93rem;text-decoration:none;border:2px solid transparent;transition:all var(--trans);white-space:nowrap;min-height:44px}
.btn-primary{background:var(--clr-accent);color:#2C1020;border-color:var(--clr-accent)}
.btn-primary:hover{background:#D4A000;border-color:#D4A000;transform:translateY(-1px);box-shadow:var(--shadow-md);text-decoration:none;color:#2C1020}
.btn-outline{background:transparent;color:var(--clr-primary);border-color:var(--clr-primary)}
.btn-outline:hover{background:var(--clr-primary);color:#fff;text-decoration:none}
.btn-white{background:#fff;color:var(--clr-primary);border-color:#fff}
.btn-white:hover{background:var(--clr-neutral);text-decoration:none}
.btn-whatsapp{background:#25D366;color:#fff;border-color:#25D366}
.btn-whatsapp:hover{background:#1daa55;border-color:#1daa55;text-decoration:none;color:#fff}
.btn-sm{padding:.5rem 1.25rem;font-size:.82rem}
.btn-ghost{background:transparent;color:var(--clr-muted);border-color:var(--clr-border)}
.btn-ghost:hover{background:var(--clr-neutral);color:var(--clr-text);text-decoration:none}

/* ---- NAV ---- */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--clr-border);box-shadow:var(--shadow-sm)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;gap:1rem}
.nav-logo{display:flex;align-items:center;gap:.55rem;text-decoration:none;flex-shrink:0}
.nav-logo:hover{text-decoration:none}
.logo-text{font-family:var(--font-brand);font-size:1.3rem;color:var(--clr-primary);line-height:1}
.logo-sub{font-family:var(--font-head);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--clr-secondary);display:block;margin-top:2px}
.nav-links{display:none;gap:.2rem;align-items:center}
.nav-links a{font-family:var(--font-head);font-weight:700;font-size:.88rem;color:var(--clr-text);padding:.45rem .75rem;border-radius:var(--radius);transition:all var(--trans);text-decoration:none}
.nav-links a:hover,.nav-links a.active{color:var(--clr-primary);background:var(--clr-neutral)}
.nav-actions{display:flex;align-items:center;gap:.65rem}
.lang-toggle{border:1.5px solid var(--clr-border);border-radius:50px;padding:.32rem .8rem;font-family:var(--font-head);font-weight:700;font-size:.76rem;color:var(--clr-muted);cursor:pointer;transition:all var(--trans)}
.lang-toggle:hover{border-color:var(--clr-primary);color:var(--clr-primary)}
.nav-cta{display:none}
.hamburger{padding:.5rem;color:var(--clr-text);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.mobile-menu{display:none;flex-direction:column;background:#fff;border-top:1px solid var(--clr-border);padding:1rem;gap:.2rem}
.mobile-menu.is-open{display:flex}
.mobile-menu a{font-family:var(--font-head);font-weight:700;color:var(--clr-text);padding:.7rem 1rem;border-radius:var(--radius);text-decoration:none;transition:all var(--trans)}
.mobile-menu a:hover{background:var(--clr-neutral);color:var(--clr-primary)}
.mobile-menu .btn{width:100%;justify-content:center;margin-top:.5rem}
@media(min-width:768px){.nav-links{display:flex}.nav-cta{display:inline-flex}.hamburger{display:none}}

/* ---- HERO ---- */
.hero{background:var(--clr-neutral);padding:4rem 0;position:relative;overflow:hidden}
.hero-inner{display:grid;gap:2.5rem;align-items:center}
.hero-eyebrow{font-family:var(--font-head);font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-secondary);display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}
.hero-eyebrow::before{content:'';display:inline-block;width:24px;height:2px;background:var(--clr-secondary)}
.hero-content h1{color:var(--clr-text);margin-bottom:1rem}
.hero-content h1 span{color:var(--clr-primary)}
.hero-content p{font-size:clamp(1rem,2.2vw,1.12rem);max-width:520px;margin-bottom:2rem}
.hero-btns{display:flex;flex-wrap:wrap;gap:.75rem}
.hero-visual{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;background:linear-gradient(135deg,var(--clr-secondary) 0%,#b8d4b5 100%);display:flex;align-items:center;justify-content:center;position:relative}
.hero-visual img{width:100%;height:100%;object-fit:cover}
.hero-img-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:rgba(255,255,255,.7);font-family:var(--font-head);font-weight:700;font-size:.82rem;text-align:center;padding:2rem}
.hero-badge{position:absolute;bottom:1.25rem;left:1.25rem;background:#fff;border-radius:var(--radius);padding:.65rem .9rem;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:700;font-size:.82rem}
@media(min-width:768px){.hero{padding:5.5rem 0}.hero-inner{grid-template-columns:1fr 1fr;gap:3.5rem}}

/* ---- TRUST BAR ---- */
.trust-bar{background:var(--clr-primary);padding:1.2rem 0}
.trust-bar-inner{display:flex;flex-wrap:wrap;gap:.75rem 2rem;align-items:center;justify-content:center}
.trust-item{display:flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:700;font-size:.83rem;color:#fff;white-space:nowrap}
.trust-item svg{width:17px;height:17px;fill:var(--clr-accent);flex-shrink:0}

/* ---- SECTION INTRO ---- */
.section-intro{text-align:center;max-width:600px;margin:0 auto 3rem}
.section-intro h2{margin-bottom:.75rem}

/* ---- SERVICES GRID (home teaser) ---- */
.services-section{background:#fff}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.25rem}
.service-card{background:var(--clr-neutral);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.6rem;transition:all var(--trans);text-decoration:none;display:block}
.service-card:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-md);transform:translateY(-3px);text-decoration:none}
.service-icon{font-size:1.9rem;margin-bottom:.9rem;display:block}
.service-card h3{color:var(--clr-text);margin-bottom:.4rem}
.service-card p{font-size:.9rem;margin-bottom:1rem}
.service-link{font-family:var(--font-head);font-weight:700;font-size:.82rem;color:var(--clr-primary)}

/* ---- HOW IT WORKS ---- */
.how-it-works{background:var(--clr-neutral)}
.steps-grid{display:grid;gap:2rem}
.step{display:flex;gap:1.25rem;align-items:flex-start}
.step-number{flex-shrink:0;width:50px;height:50px;border-radius:50%;background:var(--clr-primary);color:#fff;font-family:var(--font-head);font-weight:800;font-size:1.2rem;display:flex;align-items:center;justify-content:center}
.step-content h3{margin-bottom:.35rem}
@media(min-width:768px){.steps-grid{grid-template-columns:repeat(3,1fr)}.step{flex-direction:column;text-align:center;align-items:center}}

/* ---- GALLERY TEASER ---- */
.gallery-teaser{background:#fff}
.gallery-grid-teaser{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem;margin-bottom:2rem}
@media(min-width:768px){.gallery-grid-teaser{grid-template-columns:repeat(3,1fr)}}
.gallery-photo{border-radius:var(--radius);overflow:hidden;aspect-ratio:1;background:var(--clr-neutral)}
.gallery-photo img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.gallery-photo:hover img{transform:scale(1.05)}
.gallery-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--clr-neutral);aspect-ratio:1}
.gallery-cta{text-align:center}

/* ---- TESTIMONIALS ---- */
.testimonials-section{background:var(--clr-neutral)}
.testimonials-grid{display:grid;gap:1.25rem}
@media(min-width:768px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}
.testimonial-card{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-sm);border:1px solid var(--clr-border)}
.stars{display:flex;gap:3px;margin-bottom:.9rem;color:var(--clr-accent);font-size:1rem}
.testimonial-card blockquote{font-size:.94rem;color:var(--clr-text);font-style:italic;line-height:1.7;margin-bottom:1.1rem}
.testimonial-author{display:flex;align-items:center;gap:.7rem}
.author-avatar{width:42px;height:42px;border-radius:50%;background:var(--clr-secondary);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:.95rem;color:#fff;flex-shrink:0}
.author-info strong{display:block;font-family:var(--font-head);font-weight:700;font-size:.87rem;color:var(--clr-text)}
.author-info span{font-size:.78rem;color:var(--clr-muted)}

/* ---- ABOUT TEASER ---- */
.about-teaser{background:#fff}
.about-teaser-inner{display:grid;gap:2.5rem;align-items:center}
@media(min-width:768px){.about-teaser-inner{grid-template-columns:1fr 1fr}}
.about-photo{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;background:var(--clr-neutral)}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;min-height:280px;background:linear-gradient(135deg,#f0e8df 0%,#e8d5c8 100%)}
.about-content p{margin-bottom:1.25rem}

/* ---- MAP ---- */
.map-section{background:var(--clr-neutral)}
.map-area-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2rem}
.area-tag{background:#fff;border:1.5px solid var(--clr-border);border-radius:50px;padding:.38rem .95rem;font-family:var(--font-head);font-weight:700;font-size:.8rem;color:var(--clr-text)}
.map-embed{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.map-embed iframe{display:block;width:100%;height:360px;border:0}

/* ---- CTA BANNER ---- */
.cta-banner{background:var(--clr-primary);padding:4rem 0;text-align:center}
.cta-banner h2{color:#fff;margin-bottom:.75rem}
.cta-banner p{color:rgba(255,255,255,.85);max-width:500px;margin:0 auto 2rem;font-size:1.05rem}
.cta-btns{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}

/* ---- FOOTER ---- */
.site-footer{background:var(--clr-dark);color:rgba(255,255,255,.7);padding:3.5rem 0 1.5rem}
.footer-top{display:grid;gap:2.5rem;margin-bottom:2.5rem}
@media(min-width:768px){.footer-top{grid-template-columns:2fr 1fr 1fr}}
.footer-brand .logo-text{color:var(--clr-accent)}
.footer-brand .logo-sub{color:rgba(255,255,255,.45)}
.footer-brand p{color:rgba(255,255,255,.55);font-size:.88rem;margin-top:.75rem;max-width:260px}
.footer-col h4{font-family:var(--font-head);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.45rem}
.footer-col a{color:rgba(255,255,255,.65);font-size:.9rem;text-decoration:none;transition:color var(--trans)}
.footer-col a:hover{color:var(--clr-accent)}
.footer-col li{color:rgba(255,255,255,.65);font-size:.9rem}
.footer-social{display:flex;gap:.65rem;margin-top:1.1rem}
.social-link{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.65);transition:all var(--trans);text-decoration:none}
.social-link:hover{background:var(--clr-primary);color:#fff;text-decoration:none}
.social-link svg{width:17px;height:17px;fill:currentColor}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.4);text-decoration:none;transition:color var(--trans)}
.footer-bottom a:hover{color:var(--clr-accent)}

/* ---- COOKIE BANNER ---- */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--clr-dark);color:rgba(255,255,255,.85);padding:1.1rem 1.5rem;z-index:9999;display:flex;flex-wrap:wrap;align-items:center;gap:1rem;justify-content:space-between;box-shadow:0 -4px 20px rgba(0,0,0,.2)}
#cookie-banner p{color:rgba(255,255,255,.85);font-size:.88rem;margin:0;flex:1;min-width:200px}
#cookie-banner a{color:var(--clr-accent)}
.cookie-actions{display:flex;gap:.65rem;flex-shrink:0}

/* ---- WHATSAPP FLOAT ---- */
.whatsapp-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:998;width:54px;height:54px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.35);transition:all var(--trans);text-decoration:none}
.whatsapp-float:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,.45);text-decoration:none}
.whatsapp-float svg{width:27px;height:27px;fill:#fff}

/* ============================================================
   SERVICES PAGE
   ============================================================ */
.page-hero{background:var(--clr-neutral);padding:3.5rem 0;text-align:center}
.page-hero .section-label{margin-bottom:.5rem}
.page-hero h1{margin-bottom:.75rem}
.page-hero h1 span{color:var(--clr-primary)}
.page-hero p{max-width:560px;margin:0 auto}
.services-full-section{background:#fff}
.services-full-grid{display:grid;gap:1.5rem}
.service-full-card{background:var(--clr-neutral);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);padding:2rem;display:grid;gap:1.5rem;transition:box-shadow var(--trans)}
.service-full-card:hover{box-shadow:var(--shadow-md)}
@media(min-width:768px){.service-full-card{grid-template-columns:80px 1fr}}
.service-full-card .service-icon{font-size:2.5rem}
.service-full-card h2{font-size:1.3rem;margin-bottom:.4rem}
.service-tagline{font-style:italic;color:var(--clr-secondary);font-size:.92rem;margin-bottom:.6rem}
.service-full-card > div > p{font-size:.94rem;line-height:1.7}
.service-price{font-family:var(--font-head);font-weight:800;font-size:1.4rem;color:var(--clr-primary);margin-top:.75rem}
.service-price small{font-size:.8rem;font-weight:400;color:var(--clr-muted)}
.pricing-table-section{background:var(--clr-neutral)}
.pricing-table{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--clr-border);overflow-x:auto}
.pricing-table table{width:100%;border-collapse:collapse;min-width:480px}
.pricing-table th{background:var(--clr-primary);color:#fff;font-family:var(--font-head);font-weight:700;padding:.9rem 1.2rem;text-align:left;font-size:.84rem;letter-spacing:.05em;text-transform:uppercase}
.pricing-table td{padding:.85rem 1.2rem;border-bottom:1px solid var(--clr-border);font-size:.91rem}
.pricing-table tr:last-child td{border-bottom:none}
.pricing-table tr:nth-child(even) td{background:var(--clr-neutral)}
.price-cell{font-family:var(--font-head);font-weight:700;color:var(--clr-primary)}

/* ============================================================
   GALLERY PAGE
   ============================================================ */
.gallery-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;justify-content:center}
.filter-btn{background:#fff;border:1.5px solid var(--clr-border);border-radius:50px;padding:.42rem 1.05rem;font-family:var(--font-head);font-weight:700;font-size:.8rem;color:var(--clr-text);cursor:pointer;transition:all var(--trans)}
.filter-btn.active,.filter-btn:hover{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff}
.gallery-masonry{columns:2;column-gap:.65rem}
@media(min-width:768px){.gallery-masonry{columns:3}}
@media(min-width:1024px){.gallery-masonry{columns:4}}
.gallery-item{break-inside:avoid;margin-bottom:.65rem;border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative;background:var(--clr-neutral)}
.gallery-item img{width:100%;display:block;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item-placeholder{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:linear-gradient(135deg,#f5ede5 0%,#e8d9cc 100%)}
.gallery-item-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.5));padding:1.5rem .65rem .65rem;opacity:0;transition:opacity .3s}
.gallery-item:hover .gallery-item-overlay{opacity:1}
.gallery-item-overlay span{font-family:var(--font-head);font-weight:700;font-size:.75rem;color:#fff;background:rgba(0,0,0,.3);padding:.2rem .55rem;border-radius:50px}
.dog-profiles-section{background:var(--clr-neutral)}
.dog-profiles-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}
.dog-profile-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);text-align:center;transition:all var(--trans);text-decoration:none;display:block;border:1.5px solid var(--clr-border)}
.dog-profile-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);text-decoration:none}
.dog-profile-photo{aspect-ratio:1;overflow:hidden;background:var(--clr-neutral)}
.dog-profile-photo img{width:100%;height:100%;object-fit:cover}
.dog-profile-photo-placeholder{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:linear-gradient(135deg,#f0e8df 0%,#e2d4c8 100%)}
.dog-profile-info{padding:1.15rem}
.dog-profile-info h3{font-size:1.05rem;margin-bottom:.2rem}
.dog-breed{font-size:.8rem;color:var(--clr-muted);margin:0}
.dog-badge{display:inline-block;margin-top:.6rem;background:var(--clr-neutral);border-radius:50px;padding:.25rem .8rem;font-size:.75rem;font-family:var(--font-head);font-weight:700;color:var(--clr-secondary)}
.spotlight-cta-box{background:var(--clr-primary);border-radius:var(--radius-lg);padding:2.5rem;text-align:center;color:#fff}
.spotlight-cta-box h3{color:#fff;margin-bottom:.5rem}
.spotlight-cta-box p{color:rgba(255,255,255,.85);margin-bottom:1.5rem}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-hero-inner{display:grid;gap:3rem;align-items:center}
@media(min-width:768px){.about-hero-inner{grid-template-columns:5fr 7fr}}
.about-hero-photo{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/4;max-width:400px;margin:0 auto;background:linear-gradient(135deg,#e8d5c8 0%,#d4c0b0 100%);display:flex;align-items:center;justify-content:center;font-size:4rem}
@media(min-width:768px){.about-hero-photo{max-width:none;margin:0}}
.about-story-section{background:#fff}
.about-story-inner{max-width:720px;margin:0 auto}
.about-story-inner p{font-size:1.02rem;margin-bottom:1.25rem;line-height:1.8}
.values-section{background:var(--clr-neutral)}
.values-grid{display:grid;gap:1.5rem}
@media(min-width:768px){.values-grid{grid-template-columns:repeat(3,1fr)}}
.value-card{background:#fff;border-radius:var(--radius-lg);padding:2rem;text-align:center;box-shadow:var(--shadow-sm)}
.value-icon{font-size:2.4rem;margin-bottom:.85rem;display:block}
.value-card h3{margin-bottom:.5rem}
.credentials-section{background:#fff}
.credentials-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(195px,1fr))}
.credential-item{background:var(--clr-neutral);border:1.5px solid var(--clr-border);border-radius:var(--radius);padding:1.1rem;display:flex;align-items:center;gap:.7rem}
.cred-icon{font-size:1.45rem;flex-shrink:0}
.credential-item strong{display:block;font-family:var(--font-head);font-weight:700;font-size:.86rem;color:var(--clr-text)}
.credential-item span{font-size:.78rem;color:var(--clr-muted)}

/* ============================================================
   BOOKING PAGE
   ============================================================ */
.booking-layout{display:grid;gap:3rem}
@media(min-width:1024px){.booking-layout{grid-template-columns:3fr 2fr;align-items:start}}
.booking-form-card{background:#fff;border-radius:var(--radius-lg);padding:2.25rem;box-shadow:var(--shadow-sm);border:1px solid var(--clr-border)}
.booking-form-card h2{margin-bottom:1.75rem;font-size:1.45rem}
.form-row{display:grid;gap:1rem;margin-bottom:1rem}
.form-row.two-col{grid-template-columns:1fr}
@media(min-width:580px){.form-row.two-col{grid-template-columns:1fr 1fr}}
.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.9rem}
.form-group label{font-family:var(--font-head);font-weight:700;font-size:.86rem;color:var(--clr-text)}
.form-group label .req{color:var(--clr-primary)}
.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--clr-border);border-radius:var(--radius);padding:.68rem .9rem;font-family:var(--font-body);font-size:.93rem;color:var(--clr-text);background:var(--clr-neutral);transition:border-color var(--trans);width:100%;min-height:44px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--clr-primary);background:#fff}
.form-group textarea{resize:vertical;min-height:110px}
.form-error{font-size:.8rem;color:#c0392b;min-height:1.1em}
#form-feedback{font-family:var(--font-head);font-weight:700;font-size:.93rem}
.booking-sidebar-card{background:var(--clr-neutral);border-radius:var(--radius-lg);padding:1.75rem;margin-bottom:1.25rem}
.booking-sidebar-card h3{font-size:1.05rem;margin-bottom:1.15rem}
.contact-item{display:flex;align-items:flex-start;gap:.7rem;margin-bottom:.9rem;font-size:.9rem;color:var(--clr-text)}
.contact-item:last-child{margin-bottom:0}
.contact-item .ci-icon{font-size:1.05rem;margin-top:2px;flex-shrink:0}
.contact-item a{color:var(--clr-text);font-weight:700}
.contact-item a:hover{color:var(--clr-primary)}
.payment-methods{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.pay-badge{background:#fff;border:1.5px solid var(--clr-border);border-radius:50px;padding:.3rem .85rem;font-family:var(--font-head);font-weight:700;font-size:.78rem}

/* ============================================================
   FAQ PAGE
   ============================================================ */
.faq-groups{display:grid;gap:2.5rem}
.faq-group-title{font-size:1.1rem;color:var(--clr-primary);display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-family:var(--font-head);font-weight:800}
.faq-item{border-bottom:1px solid var(--clr-border)}
.faq-question{width:100%;background:none;border:none;text-align:left;padding:1rem 0;font-family:var(--font-head);font-weight:700;font-size:.95rem;color:var(--clr-text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:color var(--trans);min-height:44px}
.faq-question:hover{color:var(--clr-primary)}
.faq-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--clr-neutral);border:1.5px solid var(--clr-border);display:flex;align-items:center;justify-content:center;transition:all var(--trans);font-size:.9rem;color:var(--clr-muted)}
.faq-item.is-open .faq-icon{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff;transform:rotate(45deg)}
.faq-answer{display:none;padding:0 0 1.15rem;font-size:.93rem;color:var(--clr-muted);line-height:1.75}
.faq-item.is-open .faq-answer{display:block}

/* ============================================================
   TESTIMONIALS PAGE
   ============================================================ */
.rating-summary{background:var(--clr-primary);border-radius:var(--radius-lg);padding:2.5rem;display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem;align-items:center;justify-content:center;margin-bottom:3rem;text-align:center}
.rating-number{font-family:var(--font-head);font-weight:800;font-size:3.8rem;line-height:1;color:var(--clr-accent)}
.rating-stars{font-size:1.4rem;color:var(--clr-accent);margin:.2rem 0}
.rating-count{font-size:.87rem;color:rgba(255,255,255,.75)}
.rating-sep{width:1px;height:60px;background:rgba(255,255,255,.2)}
.rating-text strong{display:block;font-family:var(--font-head);font-size:1.05rem;color:#fff;margin-bottom:.25rem}
.rating-text p{font-size:.88rem;color:rgba(255,255,255,.75);margin:0}
.testimonials-full-grid{display:grid;gap:1.25rem}
@media(min-width:768px){.testimonials-full-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.testimonials-full-grid{grid-template-columns:repeat(3,1fr)}}
.review-source{font-size:.75rem;color:var(--clr-muted);margin-top:.5rem;font-family:var(--font-head);font-weight:700}
.google-cta-box{background:var(--clr-neutral);border-radius:var(--radius-lg);padding:2.5rem;text-align:center;margin-top:3rem;border:1.5px solid var(--clr-border)}
.google-cta-box h3{margin-bottom:.5rem}
.google-cta-box p{margin-bottom:1.5rem}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.container--narrow{max-width:780px;margin-left:auto;margin-right:auto}
.legal-hero{background:var(--clr-neutral);padding:3rem 0;text-align:center}
.legal-hero h1{margin-bottom:.4rem}
.legal-hero p{font-size:.9rem;color:var(--clr-muted)}
.legal-page{padding:3.5rem 0}
.legal-content{padding:3rem 0}
.legal-section{border-bottom:1px solid var(--clr-border);padding-bottom:2rem;margin-bottom:2rem}
.legal-section:last-of-type{border-bottom:none}
.legal-section h2{font-size:1.15rem;font-family:var(--font-head);font-weight:700;margin-bottom:.75rem;color:var(--clr-primary)}
.legal-section h3{font-size:.97rem;font-family:var(--font-head);font-weight:700;margin:1.25rem 0 .5rem;color:var(--clr-text)}
.legal-section p{font-size:.93rem;margin-bottom:.85rem;color:var(--clr-text)}
.legal-section ul,.legal-section ol{padding-left:1.5rem;margin-bottom:1rem}
.legal-section li{font-size:.92rem;color:var(--clr-muted);margin-bottom:.35rem}
.legal-section address{font-style:normal;font-size:.93rem;line-height:1.9;color:var(--clr-text)}
.legal-table{width:100%;border-collapse:collapse;font-size:.88rem;margin:1rem 0 1.25rem}
.legal-table th{background:var(--clr-primary);color:#fff;padding:.6rem .9rem;text-align:left;font-family:var(--font-head);font-weight:700}
.legal-table td{padding:.55rem .9rem;border-bottom:1px solid var(--clr-border);color:var(--clr-text)}
.legal-table tr:nth-child(even) td{background:var(--clr-neutral)}
.legal-back{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--clr-border)}
/* Legacy selector kept for backwards compat */
.legal-content-block{max-width:760px;margin:0 auto}
.legal-meta{font-size:.83rem;color:var(--clr-muted);margin-bottom:2.5rem;display:block}
.legal-notice{background:#fff3cd;border:1.5px solid #f0c040;border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1.5rem;font-size:.88rem;color:#856404}

/* ============================================================
   LANGUAGE TOGGLE
   ============================================================ */
[data-lang="es"] .lang-en{display:none!important}
[data-lang="en"] .lang-es{display:none!important}
