/* Paw Power — shared stylesheet */
:root{
  --cream:#e9eef4; --card:#ffffff;
  --ink:#13344f; --ink-deep:#0d2639; --muted:#5b6b78;
  --blue:#2f7dc9; --blue-dk:#235f9e; --blue-tint:#e9f1fb;
  --green:#3aa75c; --green-tint:#e8f4ec;
  --line:#d8e1ea;
  --gold:#caa23f;
  --berry:#b5403f; --berry-tint:#f6e7e6;
  --maxw:1140px; --r:20px; --r-sm:13px;
  --shadow-sm:0 1px 2px rgba(13,38,57,.05), 0 2px 8px rgba(13,38,57,.04);
  --shadow:0 2px 4px rgba(13,38,57,.05), 0 22px 44px -22px rgba(13,38,57,.30);
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Mulish", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--cream); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3{font-family:var(--serif); font-weight:600; line-height:1.08; letter-spacing:-.015em; margin:0; color:var(--ink)}
p{margin:0}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}
/* prevent grid/flex children from blowing out their track (min-width:auto) */
.hero-grid>*,.split>*,.book-grid>*,.contact-grid>*,.price-grid>*,.cards>*,.creds-row>*,.foot-grid>*,.req-list li{min-width:0}
.eyebrow{font-family:var(--sans); font-weight:700; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); margin:0 0 16px}
.lead{font-size:1.18rem; color:var(--muted); line-height:1.6}
.section{padding:clamp(64px,9vw,116px) 0}
.section.tight{padding:clamp(48px,6vw,80px) 0}
.muted{color:var(--muted)}
.center{text-align:center}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:.55em; font-family:var(--sans); font-weight:700; font-size:1rem;
  padding:15px 28px; border-radius:999px; border:1.6px solid transparent; cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease; white-space:nowrap}
.btn svg{width:19px; height:19px}
.btn-primary{background:var(--blue); color:#fff; box-shadow:0 10px 22px -10px rgba(47,125,201,.75)}
.btn-primary:hover{background:var(--blue-dk); transform:translateY(-2px); box-shadow:0 16px 28px -12px rgba(47,125,201,.8)}
.btn-ghost{background:transparent; color:var(--ink); border-color:#d4cbba}
.btn-ghost:hover{border-color:var(--ink); transform:translateY(-2px)}
.btn-light{background:#fff; color:var(--ink)}
.btn-light:hover{transform:translateY(-2px); box-shadow:0 14px 28px -14px rgba(0,0,0,.5)}
.btn-outline-light{background:transparent; color:#fff; border-color:rgba(255,255,255,.45)}
.btn-outline-light:hover{border-color:#fff; background:rgba(255,255,255,.08)}

/* header */
.site-header{position:sticky; top:0; z-index:50; background:rgba(233,238,244,.86); backdrop-filter:saturate(180%) blur(12px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; justify-content:space-between; gap:24px; height:74px}
.brand{display:flex; align-items:center; gap:12px}
.brand img{height:42px; width:auto}
.brand .bname{font-family:var(--serif); font-weight:600; font-size:1.2rem; color:var(--ink); line-height:1}
.brand .bsub{display:block; font-family:var(--sans); font-weight:600; font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:3px; white-space:nowrap}
.nav-links{display:flex; align-items:center; gap:26px; list-style:none; margin:0; padding:0}
.nav-links a{font-weight:600; font-size:.95rem; color:var(--ink); opacity:.82; transition:opacity .15s; white-space:nowrap}
.nav-links a:hover{opacity:1; color:var(--blue)}
.nav-links a[aria-current="page"]{opacity:1; color:var(--blue)}
.nav-cta{display:flex; align-items:center; gap:18px}
.nav-phone{display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--ink); white-space:nowrap}
.nav-phone svg{width:18px;height:18px;color:var(--blue)}
.nav-toggle, .nav-toggle-label{display:none}

/* brand banner (home, under header) */
.brandbanner{padding:clamp(30px,4.5vw,52px) 0 clamp(18px,2.5vw,28px); text-align:center}
.brandbanner .bb-mark{width:100%; max-width:1000px; height:auto; margin:0 auto; display:block}
.brandbanner .bb-tagline{margin:18px auto 0; font-weight:700; font-size:clamp(.78rem,1.3vw,.95rem); letter-spacing:.22em; text-transform:uppercase; color:var(--blue)}

/* hero (home) */
.hero{padding:clamp(10px,2vw,22px) 0 clamp(48px,7vw,82px)}
.hero-grid{display:grid; grid-template-columns:1.04fr .96fr; gap:clamp(36px,5vw,64px); align-items:center}
.hero h1{font-size:clamp(2.5rem,5.4vw,4rem); font-weight:600}
.hero h1 em{font-style:normal; color:var(--blue)}
.hero p.lead{margin-top:22px; max-width:30em}
.hero-loc{display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; color:var(--blue); margin-bottom:18px}
.hero-loc svg{width:16px;height:16px}
.hero-cta{display:flex; flex-wrap:wrap; gap:14px; margin-top:32px}
.hero-figure{position:relative}
.hero-figure .photo{border-radius:24px; overflow:hidden; box-shadow:var(--shadow); border:1px solid rgba(255,255,255,.6); aspect-ratio:1/.92}
.hero-figure .photo img{width:100%; height:100%; object-fit:cover}
.hero-badge{position:absolute; left:-18px; bottom:-22px; background:#fff; border:1px solid var(--line); border-radius:16px; padding:14px 18px; box-shadow:var(--shadow); display:flex; align-items:center; gap:13px}
.hero-badge .stars img{height:18px; width:auto}
.hero-badge .t{font-weight:800; font-size:.95rem; color:var(--ink); line-height:1.2}
.hero-badge .s{font-size:.78rem; color:var(--muted); font-weight:600}

/* page hero (inner pages) */
.page-hero{padding:clamp(48px,7vw,86px) 0 clamp(36px,4vw,52px); text-align:center}
.page-hero .crumb{font-weight:600; font-size:.85rem; color:var(--muted); margin-bottom:18px}
.page-hero .crumb a{color:var(--blue)}
.page-hero h1{font-size:clamp(2.3rem,4.6vw,3.4rem)}
.page-hero p.lead{margin:20px auto 0; max-width:42ch}

/* trust strip */
.trust{border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:#f3f6fa}
.trust-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:8px; padding:26px 0}
.trust-item{display:flex; align-items:center; gap:13px; justify-content:center; padding:6px 14px}
.trust-item svg{width:26px; height:26px; color:var(--blue); flex:none}
.trust-item .ti-t{font-weight:800; font-size:.96rem; color:var(--ink); line-height:1.15}
.trust-item .ti-s{font-size:.8rem; color:var(--muted); font-weight:600}

/* section header */
.shead{max-width:640px; margin-bottom:clamp(36px,5vw,56px)}
.shead.center{margin-left:auto; margin-right:auto; text-align:center}
.shead h2{font-size:clamp(1.95rem,3.6vw,2.7rem)}
.shead p{margin-top:16px}

/* value cards */
.cards{display:grid; grid-template-columns:repeat(4,1fr); gap:22px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:30px 26px; box-shadow:var(--shadow-sm)}
.card .ic{width:50px; height:50px; border-radius:13px; background:var(--blue-tint); color:var(--blue); display:flex; align-items:center; justify-content:center; margin-bottom:20px}
.card .ic svg{width:26px; height:26px}
.card h3{font-size:1.22rem; margin-bottom:10px}
.card p{font-size:.97rem; color:var(--muted); line-height:1.55}

/* gallery */
.gallery .wrap{max-width:1240px}
.gal-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.gal-grid figure{margin:0; border-radius:var(--r-sm); overflow:hidden; aspect-ratio:1/1; box-shadow:var(--shadow-sm); border:1px solid var(--line)}
.gal-grid img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease}
.gal-grid figure:hover img{transform:scale(1.05)}
.gal-note{text-align:center; margin-top:26px; color:var(--muted); font-weight:600}
.gal-note a{color:var(--blue); border-bottom:1.5px solid var(--blue-tint)}

/* pricing */
.pricing{background:#f3f6fa; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.price-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:stretch}
.price-card{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:34px 32px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column}
.price-card.feature{border-color:var(--blue); box-shadow:0 2px 4px rgba(13,38,57,.05), 0 24px 46px -24px rgba(47,125,201,.45)}
.price-tag{display:inline-flex; align-self:flex-start; align-items:center; gap:7px; font-weight:700; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); background:var(--blue-tint); padding:6px 13px; border-radius:999px; margin-bottom:18px}
.price-tag.berry{color:var(--berry); background:var(--berry-tint)}
.price-card h3{font-size:1.4rem; margin-bottom:4px}
.price-card .sub{color:var(--muted); font-size:.95rem; margin-bottom:22px}
.price-rows{border-top:1px solid var(--line); margin-top:auto}
.price-row{display:flex; align-items:baseline; justify-content:space-between; padding:16px 0; border-bottom:1px solid var(--line)}
.price-row .lbl{font-weight:600; color:var(--ink)}
.price-row .lbl small{display:block; font-weight:600; color:var(--muted); font-size:.8rem}
.price-row .amt{font-family:var(--serif); font-weight:600; font-size:1.5rem; color:var(--ink); white-space:nowrap}
.price-row .amt span{font-family:var(--sans); font-size:.8rem; font-weight:600; color:var(--muted)}
.price-aside{display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:24px}
.note{background:var(--card); border:1px solid var(--line); border-radius:var(--r-sm); padding:20px 22px}
.note h4{margin:0 0 6px; font-family:var(--sans); font-weight:800; font-size:.95rem; color:var(--ink)}
.note p{font-size:.9rem; color:var(--muted); line-height:1.55}
.price-foot{display:flex; flex-wrap:wrap; gap:10px 22px; align-items:center; justify-content:space-between; margin-top:28px}
.price-foot .dep{font-weight:600; color:var(--muted)}
.price-foot .dep b{color:var(--ink)}

/* prose + split content */
.split{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(36px,5vw,64px); align-items:center}
.split.flip{grid-template-columns:1.1fr .9fr}
.split-figure{border-radius:24px; overflow:hidden; box-shadow:var(--shadow); aspect-ratio:1/1; border:1px solid rgba(255,255,255,.6)}
.split-figure.tall{aspect-ratio:1/1.16}
.split-figure img{width:100%;height:100%;object-fit:cover}
.prose p{color:var(--muted); margin-top:18px; line-height:1.75}
.prose p.first{color:var(--ink); font-size:1.12rem}
.prose h2{font-size:clamp(1.85rem,3.3vw,2.5rem)}
.pullquote{margin:34px 0 0; padding:24px 28px; background:var(--blue-tint); border-left:4px solid var(--blue); border-radius:0 var(--r-sm) var(--r-sm) 0; font-family:var(--serif); font-style:italic; font-size:1.2rem; color:var(--ink); line-height:1.5}
.sig{margin-top:26px; font-family:var(--serif); font-style:italic; font-size:1.15rem; color:var(--ink)}
.sig span{display:block; font-family:var(--sans); font-style:normal; font-weight:700; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-top:6px}

/* before you book / requirements */
.book{background:#f3f6fa; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.book-grid{display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,60px); align-items:stretch}
.req-list{list-style:none; margin:22px 0 0; padding:0; display:grid; gap:14px}
.req-list li{display:flex; gap:13px; align-items:flex-start; font-size:1rem; color:var(--ink)}
.req-list .ck{flex:none; width:24px; height:24px; border-radius:50%; background:var(--green-tint); color:var(--green); display:flex; align-items:center; justify-content:center; margin-top:1px}
.req-list .ck svg{width:14px;height:14px}
.disclosure{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:38px 34px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; justify-content:center}
.disclosure .ic{width:54px;height:54px;border-radius:14px;background:var(--blue-tint);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.disclosure .ic svg{width:28px;height:28px}
.disclosure h3{font-size:1.4rem;margin-bottom:12px}
.disclosure p{color:var(--muted);font-size:.97rem;line-height:1.6;margin-bottom:22px}

/* credentials band (dark) */
.creds{background:var(--ink-deep); color:#fff}
.creds .wrap{padding-top:clamp(56px,7vw,84px); padding-bottom:clamp(56px,7vw,84px)}
.creds h2{color:#fff}
.creds .shead p{color:#b9c6d2}
.creds-row{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:8px}
.cred{background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--r); padding:26px 22px; text-align:center}
.cred .ch{height:54px; display:flex; align-items:center; justify-content:center; margin-bottom:16px}
.cred .ch img{max-height:54px; width:auto}
.cred .ct{font-weight:800; font-size:1rem; color:#fff}
.cred .cs{font-size:.84rem; color:#a9b8c6; margin-top:4px}
.badaw{display:flex; align-items:center; gap:14px; justify-content:center; margin-top:30px; padding:18px 24px; background:rgba(58,167,92,.14); border:1px solid rgba(58,167,92,.3); border-radius:999px; color:#dff0e5; font-weight:600; max-width:760px; margin-left:auto; margin-right:auto; text-align:center}
.badaw svg{width:22px;height:22px;color:#7fd49a;flex:none}
.badaw a{color:#fff; border-bottom:1px solid rgba(255,255,255,.4)}

/* legal / long-form pages */
.legal{max-width:780px; margin:0 auto}
.legal .updated{display:inline-block; font-weight:700; font-size:.82rem; letter-spacing:.04em; color:var(--blue); background:var(--blue-tint); padding:6px 14px; border-radius:999px; margin-bottom:26px}
.legal h2{font-size:clamp(1.4rem,2.4vw,1.85rem); margin:42px 0 12px}
.legal h3{font-family:var(--serif); font-weight:600; font-size:1.18rem; margin:26px 0 8px; color:var(--ink)}
.legal p{color:var(--muted); line-height:1.75; margin:0 0 14px}
.legal ul{color:var(--muted); line-height:1.7; margin:0 0 16px; padding-left:22px}
.legal li{margin-bottom:7px}
.legal a{color:var(--blue); font-weight:600; word-break:break-word}
.legal strong{color:var(--ink); font-weight:700}
.legal hr{border:none; border-top:1px solid var(--line); margin:36px 0}

/* FAQ */
.faq-list{max-width:760px; margin:0 auto; display:grid; gap:14px}
.faq-list details{background:var(--card); border:1px solid var(--line); border-radius:var(--r-sm); padding:0 24px; box-shadow:var(--shadow-sm)}
.faq-list summary{list-style:none; cursor:pointer; font-family:var(--serif); font-weight:600; font-size:1.12rem; color:var(--ink); padding:18px 0; display:flex; justify-content:space-between; align-items:center; gap:18px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+"; font-family:var(--sans); font-weight:600; font-size:1.5rem; line-height:1; color:var(--blue); transition:transform .2s ease; flex:none}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list .faq-a{padding:0 0 20px; margin-top:-2px}
.faq-list .faq-a p{font-size:1rem; color:var(--muted); line-height:1.65}
.faq-list .faq-a a{color:var(--blue); font-weight:600; border-bottom:1.5px solid var(--blue-tint)}

/* CTA band */
.cta{background:var(--blue); color:#fff; text-align:center}
.cta .wrap{padding:clamp(56px,7vw,90px) 28px}
.cta h2{color:#fff; font-size:clamp(2rem,3.8vw,2.8rem); max-width:16em; margin:0 auto}
.cta p{color:rgba(255,255,255,.9); margin:18px auto 0; max-width:34em; font-size:1.1rem}
.cta-btns{display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:34px}

/* contact */
.contact-grid{display:grid; grid-template-columns:1fr 1.15fr; gap:clamp(36px,5vw,56px); align-items:start}
.method-list{display:grid; gap:14px}
.method{display:flex; align-items:center; gap:16px; background:var(--card); border:1px solid var(--line); border-radius:var(--r-sm); padding:18px 20px; box-shadow:var(--shadow-sm); transition:transform .15s ease, box-shadow .2s ease}
.method:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.method .mi{flex:none; width:46px; height:46px; border-radius:12px; background:var(--blue-tint); color:var(--blue); display:flex; align-items:center; justify-content:center}
.method .mi svg{width:23px;height:23px}
.method .ml{font-weight:800; color:var(--ink); font-size:1.02rem}
.method .mv{color:var(--muted); font-size:.92rem; font-weight:600}
.form-card{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:32px 30px; box-shadow:var(--shadow-sm)}
.form-card h3{font-size:1.35rem; margin-bottom:6px}
.form-card .fsub{color:var(--muted); font-size:.95rem; margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block; font-weight:700; font-size:.85rem; color:var(--ink); margin-bottom:7px}
.field input, .field select, .field textarea{width:100%; font-family:var(--sans); font-size:1rem; color:var(--ink); background:#f5f8fc; border:1.5px solid var(--line); border-radius:10px; padding:12px 14px; transition:border-color .15s, box-shadow .15s}
.field textarea{resize:vertical; min-height:130px}
.field input:focus, .field select:focus, .field textarea:focus{outline:none; border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-tint)}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
.form-banner{padding:14px 18px; border-radius:10px; font-weight:600; margin-bottom:20px}
.form-banner.ok{background:var(--green-tint); color:#256b39; border:1px solid #b7e0c4}
.form-banner.err{background:var(--berry-tint); color:#8d2f2e; border:1px solid #e8c3c2}

/* christmas */
.xmas-hero{background:linear-gradient(180deg,#f3f6fa 0%, var(--cream) 100%); border-bottom:1px solid var(--line); overflow:hidden}
.xmas-hero .wrap{display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,4vw,56px); align-items:center; padding-top:clamp(40px,5vw,64px); padding-bottom:clamp(40px,5vw,64px)}
.xmas-hero h1{font-size:clamp(2.3rem,4.6vw,3.5rem)}
.xmas-hero .lead{margin-top:20px; max-width:32ch}
.xmas-pill{display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:var(--berry); background:var(--berry-tint); padding:7px 15px; border-radius:999px; margin-bottom:18px}
.xmas-figure{position:relative; text-align:center}
.xmas-figure img{max-width:330px; width:100%; margin:0 auto; filter:drop-shadow(0 18px 30px rgba(13,38,57,.18))}
.banner-note{background:var(--berry-tint); border:1px solid #e8c3c2; border-radius:var(--r); padding:22px 26px; color:#7a3635; display:flex; gap:14px; align-items:flex-start}
.banner-note svg{flex:none; width:24px; height:24px; color:var(--berry); margin-top:2px}
.banner-note b{color:#5e2827}

/* footer */
.footer{background:var(--ink-deep); color:#aebccb}
.footer .wrap{padding:64px 28px 30px}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px}
.foot-brand img{height:40px; width:auto; margin-bottom:16px}
.foot-brand p{font-size:.94rem; line-height:1.6; max-width:30ch; color:#9fb0bf}
.foot h5{font-family:var(--sans); font-weight:800; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:#fff; margin:0 0 16px}
.foot ul{list-style:none; margin:0; padding:0; display:grid; gap:11px}
.foot a{color:#aebccb; font-size:.95rem; transition:color .15s}
.foot a:hover{color:#fff}
.foot-contact li{display:flex; gap:10px; align-items:center; font-size:.95rem}
.foot-contact svg{width:17px;height:17px;color:var(--blue);flex:none}
.socials{display:flex; gap:12px; margin-top:4px}
.socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s}
.socials a:hover{background:var(--blue);transform:translateY(-2px)}
.socials svg{width:19px;height:19px;color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1); margin-top:48px; padding-top:24px; display:flex; flex-wrap:wrap; gap:8px 20px; justify-content:space-between; align-items:center; font-size:.85rem; color:#8597a6}

/* responsive */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr; gap:46px}
  .hero-figure{order:-1; max-width:560px}
  .trust-grid{grid-template-columns:1fr 1fr; gap:18px 8px}
  .cards, .cards.three{grid-template-columns:1fr 1fr}
  .gal-grid{grid-template-columns:1fr 1fr}
  .split, .split.flip{grid-template-columns:1fr; gap:38px}
  .split-figure, .split-figure.tall{max-width:480px; aspect-ratio:1/.82}
  .split.flip .split-figure{order:-1}
  .creds-row{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr; gap:40px}
  .xmas-hero .wrap{grid-template-columns:1fr; gap:30px}
  .xmas-figure{order:-1}
  .xmas-figure img{max-width:240px}
  .foot-grid{grid-template-columns:1fr 1fr; gap:34px}
}
@media(max-width:1000px){
  .nav-links{position:fixed; inset:74px 0 auto 0; flex-direction:column; background:var(--cream); border-bottom:1px solid var(--line); padding:18px 28px 26px; gap:6px; align-items:stretch; transform:translateY(-130%); transition:transform .3s ease; box-shadow:var(--shadow)}
  .nav-links a{padding:12px 4px; border-bottom:1px solid var(--line); font-size:1.05rem; opacity:1}
  .nav-toggle:checked ~ .nav-links{transform:translateY(0)}
  .nav-toggle-label{display:inline-flex; flex-direction:column; gap:5px; cursor:pointer; padding:8px 4px}
  .nav-toggle-label span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-phone span{display:none}
  .nav-cta .btn-primary{display:none}
  .nav{gap:16px}
  .brand{margin-right:auto}
  .nav-cta{order:3; gap:6px}
  .nav-toggle-label{order:4}
}
@media(max-width:620px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  .brand .bsub{display:none}
  .brand .bname{font-size:1.12rem}
  .trust-grid{grid-template-columns:1fr; gap:4px; padding:18px 0}
  .trust-item{justify-content:flex-start}
  .cards, .cards.three{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr 1fr; gap:12px}
  .price-grid{grid-template-columns:1fr}
  .price-aside{grid-template-columns:1fr}
  .price-foot{flex-direction:column; align-items:stretch}
  .price-foot .btn{justify-content:center}
  .book-grid{grid-template-columns:1fr; gap:34px}
  .creds-row{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero-badge{left:0}
}
