/* ===== Base / layout / components — built on tokens.css =====
   Mobile-first, semantic, accessible. Animate only transform/opacity. */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:var(--step-0);line-height:1.6;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
h1,h2,h3{font-family:var(--font-head);color:var(--brand-ink);line-height:1.1;margin:0 0 .4em}
p{margin:0 0 1em;max-width:var(--measure)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:4px}
.wrap{width:min(1140px,92vw);margin-inline:auto}
.skip{position:absolute;left:-999px;top:0;background:var(--brand);color:#fff;padding:.6rem 1rem;z-index:100}
.skip:focus{left:0}

/* ===== Buttons — ONE dominant primary, isolated, thumb-sized (L31) ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font:600 var(--step-0)/1 var(--font-body);padding:.85em 1.5em;border-radius:var(--radius);
  border:1px solid transparent;cursor:pointer;transition:transform .15s var(--ease),box-shadow .15s var(--ease);min-height:48px;text-decoration:none}
.btn:hover{transform:translateY(-1px);text-decoration:none}
.btn--primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-cta)}
.btn--primary:hover{filter:brightness(1.05)}
.btn--lg{padding:1.05em 2em;font-size:var(--step-1)}

/* ===== Nav ===== */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;gap:var(--s3);min-height:64px}
.nav__brand{display:flex;align-items:center}
.nav__links{display:none;gap:var(--s3);margin-left:auto}
.nav__links a{color:var(--ink);font-weight:500}
.nav__cta{margin-left:auto;padding:.6em 1.1em;min-height:42px}
@media(min-width:780px){ .nav__links{display:flex} .nav__cta{margin-left:0} }

/* ===== Hero ===== */
.hero{padding:var(--s6) 0 var(--s5);background:linear-gradient(180deg,var(--brand-tint),var(--paper))}
.hero__inner{display:grid;gap:var(--s4);align-items:center}
.hero__h1{font-size:var(--step-4)}
.hero__sub{font-size:var(--step-1);color:var(--ink-2);max-width:32ch}
.hero__cta{display:flex;flex-direction:column;gap:.6rem;align-items:flex-start;margin-top:var(--s3)}
.hero__trust{font-size:var(--step--1);color:var(--ink-2);margin:0}
.hero__img{border-radius:var(--radius);box-shadow:var(--shadow);object-fit:cover;width:100%}
@media(min-width:880px){ .hero__inner{grid-template-columns:1.05fr .95fr} .hero__img{max-width:560px;margin-left:auto} }

/* ===== Trust strip ===== */
.trust{background:var(--brand-ink);color:#fff;padding:var(--s3) 0}
.trust__row{display:flex;flex-wrap:wrap;gap:var(--s2) var(--s5);justify-content:center;align-items:center;font-size:var(--step--1);font-weight:500;text-align:center}

/* ===== Sections ===== */
section{padding:var(--s6) 0}
.section__h2{font-size:var(--step-3);margin-bottom:var(--s4)}
.cards{display:grid;gap:var(--s3);grid-template-columns:1fr}
.card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s4)}
.card h3{font-size:var(--step-1);color:var(--brand-ink)}
.card p{color:var(--ink-2);margin:0}
@media(min-width:760px){ .cards{grid-template-columns:repeat(3,1fr)} }

.about{background:var(--paper-2)}
.about__inner{display:grid;gap:var(--s4);align-items:center}
.about__img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}
/* the AEO answer object — visually a lead paragraph, semantically the extractable answer */
.answer{font-size:var(--step-1);color:var(--ink);font-weight:500;border-left:3px solid var(--brand);padding-left:var(--s2)}
@media(min-width:860px){ .about__inner{grid-template-columns:.85fr 1.15fr} }

/* ===== FAQ ===== */
.faq details{border-bottom:1px solid var(--line);padding:var(--s2) 0}
.faq summary{font-weight:600;font-size:var(--step-1);cursor:pointer;list-style:none;color:var(--brand-ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--brand)}
.faq details[open] summary::after{content:"–"}
.faq p{margin:.8rem 0 0;color:var(--ink-2)}

/* ===== Final CTA + footer ===== */
.cta-final{background:linear-gradient(180deg,var(--paper),var(--brand-tint));text-align:center}
.cta-final h2{font-size:var(--step-3);margin-bottom:var(--s3)}
.footer{background:var(--brand-ink);color:#fff;padding:var(--s4) 0;font-size:var(--step--1)}
.footer__inner{display:flex;flex-wrap:wrap;gap:var(--s2);justify-content:space-between}
.footer a{color:#fff;text-decoration:underline}

/* ===== Hero: secondary call link + service tags (All Fur Love) ===== */
.hero__cta .btn--ghost{background:transparent;color:var(--brand-ink);border:1px solid var(--brand-ink);box-shadow:none}
.hero__cta .btn--ghost:hover{background:var(--brand-ink);color:#fff}
.hero__row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:var(--s2) 0 0;padding:0;list-style:none}
.tags li{font-size:var(--step--1);font-weight:600;color:var(--brand-ink);background:#fff;border:1px solid var(--line);border-radius:999px;padding:.35em .9em}

/* ===== Services: card icon + small print ===== */
.card .ico{font-size:1.8rem;line-height:1;display:block;margin-bottom:.5rem}
.card .meta{display:block;margin-top:.8rem;font-weight:600;color:var(--brand)}

/* ===== Gallery (their strongest real asset) ===== */
.gallery{background:var(--paper)}
.gallery .grid{display:grid;gap:var(--s2);grid-template-columns:repeat(2,1fr)}
.gallery figure{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:1/1;background:var(--paper-2)}
.gallery img{width:100%;height:100%;object-fit:cover}
.gallery .note{color:var(--ink-2);margin-top:var(--s3)}
@media(min-width:760px){ .gallery .grid{grid-template-columns:repeat(4,1fr)} }

/* ===== Mobile sticky call bar (playbook L34 — phone is the booking path) ===== */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;gap:.6rem;padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));
  background:color-mix(in srgb,var(--paper) 94%,transparent);backdrop-filter:blur(8px);border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(0,0,0,.08)}
.callbar .btn{flex:1;min-height:54px;font-size:var(--step-0)}
.callbar .btn--call{background:var(--brand-ink);color:#fff;box-shadow:none}
body{padding-bottom:76px}
@media(min-width:780px){ .callbar{display:none} body{padding-bottom:0} }
