/* ============================================================
   The Hertsmere — Family Fun Day landing page
   Brand system carried over from the poster (poster3.html)
   ============================================================ */

@font-face{font-family:'Museo Slab';src:url('fonts/MuseoSlab-700.otf') format('opentype');font-weight:700;font-display:swap}
@font-face{font-family:'Museo Slab';src:url('fonts/MuseoSlab-900.otf') format('opentype');font-weight:900;font-display:swap}

:root{
  --slate:#2d3d4d; --navy2:#22303d; --teal:#0e8b8d; --tealdk:#0a777a; --tealedge:#3fa9aa;
  --sand:#d8bd99; --sandl:#ead7b6; --cream:#f4eee1; --white:#fff;
  --ink:#2d3d4d; --muted:#54616d; --line:rgba(45,61,77,.12);
  --shadow:0 18px 50px -18px rgba(34,48,61,.38);
  --shadow-sm:0 8px 24px -10px rgba(34,48,61,.30);
  --serif:'Museo Slab',Georgia,serif;
  --sans:'Mulish',system-ui,-apple-system,sans-serif;
  --maxw:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:2}
.wrap.narrow{max-width:820px}
.center{text-align:center}
.spacer-sm{height:14px}

/* paper grain overlay (used on dark sections + hero) */
.grain{position:absolute;inset:0;z-index:1;background:url('images/paper-tex.png');background-size:520px;
  mix-blend-mode:soft-light;opacity:.14;pointer-events:none}

/* ---------- typography ---------- */
.h2{font-family:var(--serif);font-weight:900;font-size:clamp(28px,4.4vw,46px);line-height:1.04;
  letter-spacing:-.01em;color:var(--slate)}
.h2-light{color:#fff}
.lead{font-size:clamp(16px,1.9vw,19px);color:var(--muted);max-width:62ch;margin:0 0 14px}
.center .lead{margin-left:auto;margin-right:auto}
.lead-tight{margin-bottom:0}
.lead-light{color:rgba(255,255,255,.85)}
.rule{display:block;width:64px;height:5px;border-radius:3px;background:var(--teal);margin:18px 0 22px}
.center-rule{margin-left:auto;margin-right:auto}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--teal);color:#fff;font-family:var(--sans);
  font-weight:800;font-size:16px;letter-spacing:.01em;padding:15px 30px;border-radius:46px;border:none;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,background .18s ease,box-shadow .18s ease}
.btn:hover{background:var(--tealdk);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-lg{font-size:18px;padding:18px 38px}
.btn-sm{padding:11px 22px;font-size:14px;box-shadow:none}
.btn-block{width:100%;justify-content:center;margin-top:6px}
.btn-gold{background:var(--sand);color:var(--slate)}
.btn-gold:hover{background:var(--sandl)}
.btn-ghost-dark{background:transparent;color:var(--teal);box-shadow:none;border:2px solid var(--teal);padding:13px 28px}
.btn-ghost-dark:hover{background:var(--teal);color:#fff}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:16px;
  padding:14px 8px;opacity:.95}
.btn-ghost:hover{opacity:1}
.btn-ghost-dark2{display:inline-flex;align-items:center;color:var(--slate);font-weight:700;font-size:16px;
  text-decoration:underline;text-decoration-color:var(--sand);text-underline-offset:4px}
.ic-play{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:1.6}
.ic-play.big{width:64px;height:64px}

.squiggle{display:block;width:min(320px,70%);height:22px;margin:6px 0 18px}

/* ---------- top utility bar ---------- */
.topbar{background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;gap:12px;
  flex-wrap:wrap;font-weight:700;font-size:14px;padding:9px 16px;letter-spacing:.02em}
.topbar .ic{width:17px;height:17px;fill:none;stroke:var(--sandl);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-3px;margin-right:6px}
.topbar-item{display:inline-flex;align-items:center}
.topbar .dot{color:var(--sandl)}
.topbar-free{color:var(--sandl);font-weight:800}

/* ---------- nav ---------- */
.nav{position:absolute;top:38px;left:0;right:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:18px 24px;transition:none}
.nav.scrolled{position:fixed;top:0;background:rgba(45,61,77,.96);backdrop-filter:blur(8px);padding:12px 24px;
  box-shadow:0 6px 24px -10px rgba(0,0,0,.5);animation:dropin .3s ease}
@keyframes dropin{from{transform:translateY(-100%)}to{transform:translateY(0)}}
.nav-logo img{height:46px;width:auto}
.nav.scrolled .nav-logo img{height:38px}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{color:#fff;font-weight:700;font-size:15px}
.nav-links a:not(.btn){opacity:.9}
.nav-links a:not(.btn):hover{opacity:1}

/* ---------- hero ---------- */
.hero{position:relative;min-height:clamp(560px,86vh,820px);display:flex;align-items:center;overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:0;background:url('images/hero-slide-3.jpg') center 30%/cover no-repeat;z-index:0;
  transform:scale(1.03)}
.hero-scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,rgba(34,48,61,.92) 0%,rgba(34,48,61,.72) 42%,rgba(34,48,61,.28) 78%,rgba(34,48,61,.45) 100%)}
.hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:120px 24px 70px;width:100%}
.kicker{font-weight:800;letter-spacing:.13em;text-transform:uppercase;font-size:14px;color:var(--sandl);margin-bottom:16px}
.hero-h1{font-family:var(--serif);font-weight:900;font-size:clamp(46px,8.5vw,104px);line-height:.92;letter-spacing:-.015em;
  text-shadow:0 4px 24px rgba(0,0,0,.28)}
.hero-sub{font-size:clamp(16px,2.1vw,21px);max-width:56ch;margin:4px 0 26px;color:rgba(255,255,255,.92);font-weight:500}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}
.pill{display:inline-flex;align-items:center;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(4px);color:#fff;font-weight:700;font-size:15px;padding:8px 18px;border-radius:40px}
.pill-gold{background:var(--sand);border-color:var(--sand);color:var(--slate);font-weight:800}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.center-cta{justify-content:center}

/* ---------- bands ---------- */
.band-cream{background:var(--cream);padding:clamp(56px,8vw,96px) 0;position:relative}
.band-white{background:#fff;padding:clamp(56px,8vw,96px) 0;position:relative}
.band-slate{background:var(--slate);color:#fff;padding:clamp(56px,8vw,96px) 0;position:relative;overflow:hidden}
.band-slate .lead{color:rgba(255,255,255,.82)}

/* ---------- intro ---------- */
.intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.intro-photos{position:relative;height:420px}
.intro-photos img{position:absolute;border-radius:16px;box-shadow:var(--shadow);object-fit:cover}
.intro-photos .ip-1{width:74%;height:62%;top:0;right:0;z-index:1}
.intro-photos .ip-2{width:50%;height:46%;bottom:0;left:0;z-index:3;border:5px solid var(--cream)}
.intro-photos .ip-3{width:42%;height:40%;bottom:18%;right:8%;z-index:2;border:5px solid var(--cream)}

/* ---------- four / three grids ---------- */
.four-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin:42px 0 38px}
.three-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin:42px 0 38px}
.ecard,.fcard{background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);transition:transform .2s ease,box-shadow .2s ease}
.band-cream .ecard{background:#fff}
.ecard:hover,.fcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.ecard img{width:100%;height:170px;object-fit:cover}
.fcard img{width:100%;height:210px;object-fit:cover}
.ecard-body,.fcard-body{padding:20px 22px 24px}
.ecard-body h3,.fcard-body h3{font-family:var(--serif);font-weight:700;font-size:21px;color:var(--slate);margin-bottom:8px}
.ecard-body p,.fcard-body p{font-size:15.5px;color:var(--muted)}

/* ---------- what's happening ---------- */
.happen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:44px 0 40px}
.hitem{display:flex;gap:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:14px;padding:20px 20px}
.hitem .emoji{font-size:30px;line-height:1;flex:0 0 auto}
.hitem h4{font-family:var(--serif);font-weight:700;font-size:18px;color:#fff;margin-bottom:5px}
.hitem p{font-size:14.5px;color:rgba(255,255,255,.78);line-height:1.5}

/* ---------- tour ---------- */
.video-frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow);margin:30px 0;background:var(--slate)}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:2}
.video-ph{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;color:#fff;background:linear-gradient(160deg,#33485c,#22303d)}
.video-ph .ic-play{stroke:#fff}
.video-ph span{font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:14px;color:var(--sandl)}

/* ---------- reviews ---------- */
.rating{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin:14px 0 4px;font-weight:700}
.stars{color:#f0a830;font-size:24px;letter-spacing:2px}
.rating strong{font-size:20px;color:var(--slate)}
.rating-sub{color:var(--muted);font-weight:600}
.quote{background:var(--cream);border-radius:16px;padding:28px 26px;border:1px solid var(--line);position:relative}
.quote p{font-size:16.5px;color:var(--slate);line-height:1.6;margin-bottom:14px}
.quote cite{font-style:normal;font-weight:800;font-size:14px;color:var(--teal);letter-spacing:.02em}
.link-google{font-weight:800;color:var(--teal);text-underline-offset:4px}
.link-google:hover{text-decoration:underline}

/* ---------- faq ---------- */
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{list-style:none;cursor:pointer;font-family:var(--serif);font-weight:700;font-size:19px;color:var(--slate);
  padding:18px 44px 18px 0;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--sans);
  font-weight:800;font-size:26px;color:var(--teal);transition:transform .2s ease}
.faq details[open] summary::after{content:"−"}
.faq details p{padding:0 30px 20px 0;color:var(--muted);font-size:16px}
.faq .btn{margin-top:34px}

/* ---------- joining (soft) ---------- */
.joining{border-top:1px solid var(--line)}

/* ---------- register ---------- */
.register-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.incl-label{font-weight:800;letter-spacing:.1em;text-transform:uppercase;font-size:13px;color:var(--sandl);margin:24px 0 14px}
.incl{list-style:none;display:grid;gap:11px}
.incl li{position:relative;padding-left:32px;color:rgba(255,255,255,.92);font-weight:600;font-size:16px}
.incl li::before{content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;
  background:var(--teal) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12.5l4 4 10-10'/%3E%3C/svg%3E") center/13px no-repeat}
.register-form-card{background:#fff;border-radius:20px;padding:34px 32px;box-shadow:var(--shadow);color:var(--ink)}
#reg-form label{display:block;font-weight:700;font-size:14px;color:var(--slate);margin:14px 0 7px}
#reg-form label.consent{display:flex;gap:11px;align-items:flex-start;font-weight:500;font-size:13.5px;color:var(--muted);margin-top:20px}
#reg-form label.consent input{margin-top:3px;flex:0 0 auto;width:17px;height:17px;accent-color:var(--teal)}
#reg-form input[type=text],#reg-form input[type=email]{width:100%;padding:14px 16px;border:1.5px solid var(--line);
  border-radius:11px;font-family:var(--sans);font-size:16px;color:var(--ink);background:#fbfaf6;transition:border-color .15s}
#reg-form input:focus{outline:none;border-color:var(--teal);background:#fff}
#reg-form input.invalid{border-color:#d6534b;background:#fdf3f2}
.reassure{text-align:center;font-size:13px;color:var(--muted);margin-top:12px}
.reg-success{text-align:center;padding:20px 6px}
.reg-success .ic-check{width:64px;height:64px;margin:0 auto 14px;fill:var(--teal);stroke:none;display:block}
.reg-success .ic-check circle{fill:var(--teal)}
.reg-success h3{font-family:var(--serif);font-weight:900;font-size:26px;color:var(--slate);margin-bottom:10px}
.reg-success p{color:var(--muted);font-size:16px;max-width:34ch;margin:0 auto}

/* ---------- final cta + feature strip ---------- */
.feature-strip{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  padding-bottom:46px;margin-bottom:46px;border-bottom:1px solid var(--line);font-family:var(--serif);font-weight:700;
  font-size:clamp(15px,1.7vw,18px);color:var(--slate)}
.feature-strip .fs-dot{color:var(--sand)}
.finalcta-inner .hero-cta{margin-top:24px}

/* ---------- footer ---------- */
.footer{background:var(--navy2);color:#e9eef2;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:36px}
.footer-logo{height:48px;width:auto;margin-bottom:16px}
.footer-addr{color:#aab6c1;font-size:15px;line-height:1.6}
.footer-col h4{font-family:var(--serif);font-weight:700;font-size:16px;color:#fff;margin-bottom:16px}
.footer-col ul{list-style:none;display:grid;gap:10px}
.footer-col a{color:#aab6c1;font-size:15px;transition:color .15s,transform .15s}
.footer-col a:hover{color:#fff}
.footer-social{display:flex;gap:12px;margin-top:18px}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,255,255,.2)}
.footer-social a:hover{background:var(--teal);border-color:var(--teal)}
.footer-social .ic{width:20px;height:20px;fill:none;stroke:#fff;stroke-width:2}
.footer-social .ic-fill{width:20px;height:20px;fill:#fff}
.footer-openday .fo-date{font-family:var(--serif);font-weight:700;font-size:18px;color:#fff}
.footer-openday .fo-time{color:#aab6c1;margin-bottom:16px}
.footer-base{max-width:var(--maxw);margin:48px auto 0;padding:22px 24px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#7e8c98;font-size:13px}

/* ---------- sticky mobile cta ---------- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:40;display:none;flex-direction:column;align-items:center;
  background:var(--teal);color:#fff;text-align:center;padding:11px 16px;box-shadow:0 -8px 24px -10px rgba(0,0,0,.4)}
.sticky-cta span{font-size:12px;font-weight:700;color:var(--sandl)}
.sticky-cta strong{font-size:16px;font-weight:800}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  .nav-links a:not(.btn){display:none}
  .intro-grid{grid-template-columns:1fr;gap:36px}
  .intro-photos{height:340px;max-width:460px}
  .four-grid{grid-template-columns:repeat(2,1fr)}
  .three-grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}
  .happen-grid{grid-template-columns:repeat(2,1fr)}
  .register-grid{grid-template-columns:1fr;gap:34px}
}
@media(max-width:600px){
  .topbar{font-size:12.5px;gap:8px}
  .nav{top:34px;padding:14px 18px}
  .nav-logo img{height:40px}
  .hero-inner{padding:104px 22px 56px}
  .hero-scrim{background:linear-gradient(180deg,rgba(34,48,61,.72) 0%,rgba(34,48,61,.62) 50%,rgba(34,48,61,.82) 100%)}
  .four-grid{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
  .happen-grid{grid-template-columns:1fr}
  .hero-cta{gap:12px}
  .btn-lg{width:100%;justify-content:center}
  .feature-strip{gap:8px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-openday{grid-column:1/-1}
  .sticky-cta{display:flex}
  body{padding-bottom:64px}
  .finalcta-inner .btn-lg{width:auto}
}

/* ============================================================
   ADDED COMPONENTS — eyebrow, dog show, timetable, offer,
   register hook + fields, gallery carousel
   ============================================================ */

.eyebrow{display:inline-block;font-weight:800;letter-spacing:.13em;text-transform:uppercase;font-size:13px;
  color:var(--teal);margin-bottom:12px}
.eyebrow-light{color:var(--sandl)}
.narrow-block{max-width:760px;margin:0 auto}

/* ---------- dog show ---------- */
.dog-card{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:40px;background:#fff;border-radius:20px;
  overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.dog-col{padding:34px 36px}
.dog-col-2{background:var(--slate);color:#fff}
.dog-h3{font-family:var(--serif);font-weight:700;font-size:15px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--teal);margin:0 0 14px}
.dog-col-2 .dog-h3{color:var(--sandl)}
.dog-col-2 .dog-h3:nth-of-type(2){margin-top:26px}
.dog-rounds{list-style:none;display:grid;gap:12px;margin-bottom:20px}
.dog-rounds li{display:flex;align-items:baseline;gap:14px;font-weight:700;font-size:18px;color:var(--slate)}
.dr-time{display:inline-block;min-width:96px;font-family:var(--serif);font-weight:900;color:var(--teal)}
.dog-note{color:var(--muted);font-size:15px;line-height:1.55;border-top:1px solid var(--line);padding-top:18px}
.dog-cats{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:6px}
.dog-cat{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:30px;
  padding:7px 16px;font-weight:700;font-size:14px}
.dog-prize{color:rgba(255,255,255,.85);font-size:15px;line-height:1.55;margin-bottom:22px}

/* ---------- timetable ---------- */
.allday{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:26px 0 30px}
.chip{background:var(--cream);border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-weight:700;
  font-size:14px;color:var(--slate)}
.timetable{width:100%;border-collapse:collapse;margin-bottom:18px}
.timetable td{padding:15px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.tt-time{font-family:var(--serif);font-weight:900;color:var(--teal);white-space:nowrap;width:104px;font-size:17px}
.tt-what{font-weight:700;color:var(--slate);font-size:16px}
.tt-where{text-align:right;color:var(--muted);font-weight:600;font-size:14px;white-space:nowrap}
.tt-foot{text-align:center;color:var(--muted);font-size:15px;margin-bottom:26px}

/* ---------- membership offer ---------- */
.offer-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:840px;margin:42px auto 26px}
.offer{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 24px;text-align:center;
  box-shadow:var(--shadow-sm);position:relative}
.offer-mid{border:2px solid var(--teal);box-shadow:var(--shadow)}
.offer-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--teal);color:#fff;
  font-weight:800;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:5px 14px;border-radius:30px;white-space:nowrap}
.offer h3{font-family:var(--serif);font-weight:900;font-size:24px;color:var(--slate);margin-bottom:14px}
.offer-pts{font-weight:800;font-size:20px;color:var(--teal);margin-bottom:4px}
.offer-guest{color:var(--muted);font-weight:600;font-size:15px}
.offer-foot{max-width:60ch;margin:0 auto 26px;color:var(--muted);font-size:15px}

/* ---------- register hook + fields ---------- */
.reg-hook{display:flex;align-items:center;gap:14px;background:linear-gradient(100deg,#fff5e6,#ffe9c7);
  border:1px solid #f0d9a8;border-radius:14px;padding:14px 18px;margin-bottom:20px}
.reg-hook-emoji{font-size:34px;line-height:1;flex:0 0 auto}
.reg-hook-tx{display:flex;flex-direction:column;gap:2px}
.reg-hook-tx strong{font-family:var(--serif);font-weight:900;font-size:18px;color:var(--slate)}
.reg-hook-tx span{font-size:14px;color:#6b5836;line-height:1.4}
.reg-hook-tx em{font-style:normal;font-weight:800;color:var(--tealdk)}
#reg-form select{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:11px;
  font-family:var(--sans);font-size:16px;color:var(--ink);background:#fbfaf6;-webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2354616d' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:18px}
#reg-form select:focus{outline:none;border-color:var(--teal);background-color:#fff}
.reg-interests{border:none;margin:18px 0 0}
.reg-interests legend{font-weight:700;font-size:14px;color:var(--slate);margin-bottom:10px;padding:0}
.reg-interests legend span{font-weight:500;color:var(--muted)}
.chk{display:flex;align-items:center;gap:14px;padding:11px 16px;border:1.5px solid var(--line);border-radius:10px;
  margin-bottom:8px;cursor:pointer;font-size:15px;color:var(--slate);font-weight:600;transition:border-color .15s,background .15s}
.chk:hover{border-color:var(--tealedge)}
.chk input{width:18px;height:18px;min-width:18px;accent-color:var(--teal);flex:0 0 auto;margin:0 4px 0 0}
.chk span{flex:1}
.chk:has(input:checked){border-color:var(--teal);background:#f0f8f6}
.reg-mini{font-size:13px;color:var(--muted);margin-top:10px;line-height:1.45}
.reg-error{color:#c0392b;background:#fdecea;border:1px solid #f3c4be;border-radius:10px;padding:11px 14px;
  font-size:14px;font-weight:700;text-align:center;margin:4px 0 4px}

/* ---------- gallery carousel ---------- */
.gallery{padding-bottom:clamp(48px,7vw,80px)}
.carousel{position:relative;z-index:2;margin-top:36px;display:flex;align-items:center;gap:8px;
  padding:0 clamp(16px,5vw,64px)}
.car-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:6px 2px 14px;flex:1;scrollbar-width:none}
.car-track::-webkit-scrollbar{display:none}
.car-slide{flex:0 0 auto;width:min(560px,80vw);scroll-snap-align:center;margin:0;border-radius:16px;overflow:hidden;
  box-shadow:0 18px 44px -18px rgba(0,0,0,.6);background:#22303d}
.car-slide img{width:100%;height:clamp(280px,42vw,440px);object-fit:cover;display:block}
.car-btn{flex:0 0 auto;width:50px;height:50px;border-radius:50%;border:none;cursor:pointer;font-size:30px;line-height:1;
  background:#fff;color:var(--slate);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;
  transition:transform .15s,background .15s;z-index:3}
.car-btn:hover{background:var(--sandl);transform:scale(1.06)}
.car-dots{display:flex;gap:9px;justify-content:center;margin-top:18px;position:relative;z-index:2}
.car-dot{width:9px;height:9px;border-radius:50%;border:none;padding:0;cursor:pointer;background:rgba(255,255,255,.32);transition:background .15s,transform .15s}
.car-dot.active{background:var(--sandl);transform:scale(1.25)}

@media(max-width:760px){
  .dog-card{grid-template-columns:1fr}
  .offer-cards{grid-template-columns:1fr;max-width:380px}
  .car-btn{display:none}
  .carousel{padding:0 16px}
  .car-slide{width:86vw}
  .timetable td{padding:13px 8px}
  .tt-time{width:84px;font-size:15px}
  .tt-what{font-size:15px}
  .tt-where{display:none}
}
