/* PET PAVILION - SHARED FOUNDATION (base.css)
   Extracted shared chrome/typography/reset common to all pages.
   Loaded before each page CSS; page CSS overrides as needed. */

hgroup{display:block}
hgroup>*{margin-top:0;margin-bottom:0}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container-pp{width:100%;max-width:1140px;margin:0 auto;padding:0 1.25rem}
.section-pad{padding:clamp(4rem,10vh,7.5rem) 0}
.font-serif{font-family:'DM Serif Display',Georgia,serif;font-weight:400}
.btn-primary:hover{background:#3e3e3e}
.btn-ghost:hover{border-color:var(--sage);color:var(--sage)}
.logo-link{flex-shrink:0}
.centre-nav{display:flex;align-items:center;gap:1.75rem}
.header-icons{display:flex;align-items:center;gap:.25rem}
.icon-btn:hover{color:var(--charcoal)}
.mobile-nav-link:hover{color:var(--charcoal)}
.footer-logo{display:block;margin-bottom:1.25rem;opacity:.92}
.footer-kicker{font-size:.86rem;line-height:1.6;color:rgba(247,245,240,.78);margin:0 0 1rem;max-width:24ch}
.footer-socials a{color:rgba(247,245,240,.9);transition:color .2s}
.footer-socials a:hover{color:var(--ivory)}
.footer-menu{margin:0}
.footer-menu summary{list-style:none}
.footer-menu summary::-webkit-details-marker{display:none}
.footer-menu summary h3{margin:0 0 1.125rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.625rem}
.footer-col li a{font-size:.9rem;color:rgba(247,245,240,.8);transition:color .2s}
.footer-col li a:hover{color:var(--ivory)}
.footer-copy{font-size:.82rem;color:rgba(247,245,240,.9)}
.footer-legal{display:flex;gap:1.125rem}
.footer-legal a{font-size:.82rem;color:rgba(247,245,240,.9);transition:color .2s}
.footer-legal a:hover{color:rgba(247,245,240,.55)}
@media(min-width:768px){
  .footer-menu:not([open])>ul{display:flex}
  .footer-menu summary{cursor:default;pointer-events:none}
}
@media(max-width:767px){
  .footer-menu{border-top:1px solid rgba(247,245,240,.12);padding-top:.875rem}
  .footer-menu summary{cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:44px}
  .footer-menu summary h3{margin:0}
  .footer-menu summary::after{content:'+';font-size:1.25rem;line-height:1;color:rgba(247,245,240,.72)}
  .footer-menu[open] summary::after{content:'-'}
  .footer-menu:not([open])>ul{display:none}
  .footer-menu[open]>ul{margin-top:.875rem}
}
/* ═══ FONT SIZING — VISIBILITY PASS ═══════════════════════ */
strong{font-weight:600}
#cookie-bar.visible{transform:translateY(0)}
#cookie-bar a{color:var(--sage-light);text-decoration:underline;text-underline-offset:3px}
#cookie-bar p{flex:1;min-width:200px}
.cookie-btns{display:flex;gap:.625rem;flex-shrink:0}
.cookie-accept:hover{background:#4a6145}
.cookie-decline:hover{border-color:rgba(247,245,240,.5)}
#back-top.visible{opacity:1;pointer-events:all}
#back-top:hover{background:var(--sage)}
.page-fade{animation:pagein .35s ease both}
@keyframes pagein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.mobile-nav-link:hover::before,.mobile-nav-link.active-mob::before{height:60%}
#menu-backdrop{display:none;pointer-events:none;z-index:98;opacity:0;transition:opacity .25s ease}
#menu-backdrop.open{display:block;opacity:1;pointer-events:auto}
@keyframes slidedown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
/* ═══════════════════════════════════════════════════════════════
   MOBILE-FIRST RESPONSIVE SYSTEM — Pet Pavilion
   Applied across index / grooming / locations / luxury-collection
   ═══════════════════════════════════════════════════════════════ */

/* ── 0. Global image safety ─────────────────────────────────── */
img, video, iframe, embed, object {
  max-width: 100%;
  height: auto;
}
/* ── 1. Touch-target minimum for all interactive elements ────── */
.btn-primary, .btn-secondary, .btn-ghost,
a.btn-primary, a.btn-secondary, a.btn-ghost,
button, [role="button"],
.icon-btn, .hamburger,
.cookie-accept, .cookie-decline,
.mobile-nav-link, .nav-link,
.sh-btn, .ir-btn-outline,
.hero-ghost, .beds-all,
.cat-shop-btn, .tab-link,
.pkg-book, .sticky-book,
.store-actions a,
#back-top {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
button.btn-primary[style*="width:100%"],
a.btn-primary[style*="width:100%"] {
  display: flex;
}
/* Utility tweaks after inline extraction */
.skip-link:focus{top:0;left:0}
.btn-primary,
a.btn-primary,
button.btn-primary{
  border:1px solid transparent !important;
  --bs-btn-border-color: transparent;
  --bs-btn-hover-border-color: transparent;
  --bs-btn-active-border-color: transparent;
  --bs-btn-disabled-border-color: transparent;
  --bs-btn-focus-shadow-rgb: 44,44,44;
  box-shadow:none !important;
}
.btn-secondary,
a.btn-secondary,
button.btn-secondary{
  --bs-btn-border-color: var(--charcoal);
  --bs-btn-hover-border-color: var(--charcoal);
  --bs-btn-active-border-color: var(--charcoal);
  --bs-btn-focus-shadow-rgb: 44,44,44;
}
.btn-ghost,
a.btn-ghost,
button.btn-ghost{
  --bs-btn-border-color: var(--warmgrey);
  --bs-btn-hover-border-color: var(--warmgrey);
  --bs-btn-active-border-color: var(--warmgrey);
  --bs-btn-focus-shadow-rgb: 44,44,44;
}
