/* ============================================================
   Bark of the Town — Dog grooming, Knoxville TN
   Palette: oat paper / espresso ink / spruce green / biscuit
   Type: Bricolage Grotesque (display) + Hanken Grotesk (body)
   ============================================================ */

:root{
  --paper:    #F6EFE2;
  --paper-2:  #EFE6D4;
  --surface:  #FFFDF8;
  --ink:      #241E17;
  --ink-soft: #5A5044;
  --spruce:   #345C50;
  --spruce-d: #284A40;
  --spruce-l: #6E9B86;
  --biscuit:  #E0995A;
  --biscuit-d:#C97E3F;
  --rust:     #9E4E1C;
  --eyebrow-d:#ECE4D3;
  --line:     #E0D5C0;
  --line-2:   #D2C4A9;

  --maxw: 1180px;
  --r: 4px;
  --r-lg: 8px;
  --shadow: 0 18px 44px -28px rgba(40,33,22,.45);
  --ease: cubic-bezier(.22,.61,.36,1);

  --f-disp: "Bricolage Grotesque", Georgia, serif;
  --f-body: "Hanken Grotesk", system-ui, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }

h1,h2,h3,h4{ font-family:var(--f-disp); font-weight:700; line-height:1.04; margin:0; letter-spacing:-.015em; }
h2{ font-size:clamp(2rem,4.4vw,3.1rem); }
h3{ font-size:1.28rem; letter-spacing:-.01em; }
p{ margin:0; }
a{ color:inherit; }
img,svg{ max-width:100%; }

.skip{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--spruce); color:#fff; padding:10px 16px; border-radius:var(--r);
}
.skip:focus{ left:12px; top:12px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--f-body); font-weight:600; font-size:1rem;
  padding:13px 24px; border-radius:var(--r); border:1.5px solid transparent;
  text-decoration:none; cursor:pointer;
  transition:background-color .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.btn .ico{ width:18px; height:18px; }
.btn-primary{ background:var(--spruce); color:#FFFDF8; }
.btn-primary:hover{ background:var(--spruce-d); }
.btn-primary:focus-visible{ outline:3px solid var(--biscuit); outline-offset:2px; }
.btn-ghost{ background:transparent; color:var(--spruce); border-color:var(--line-2); }
.btn-ghost:hover{ background:var(--spruce); color:#FFFDF8; border-color:var(--spruce); }
.btn-block{ width:100%; }

/* call button used in nav + mobile */
.btn-call{ background:var(--biscuit); color:var(--ink); font-weight:700; }
.btn-call:hover{ background:var(--biscuit-d); color:var(--ink); }

/* focus baseline */
a:focus-visible, button:focus-visible, summary:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:3px solid var(--biscuit); outline-offset:2px; border-radius:3px;
}

/* ---------- eyebrow / tick ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.8rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--spruce); margin:0 0 18px;
}
.tick{ width:18px; height:2px; background:currentColor; display:inline-block; }
/* eyebrows on dark (spruce) grounds: light text, biscuit tick — keeps AA */
.hero .eyebrow, .care .eyebrow, .book-copy .eyebrow, .map-body .eyebrow{ color:var(--eyebrow-d); }
.hero .eyebrow .tick, .care .eyebrow .tick, .book-copy .eyebrow .tick, .map-body .eyebrow .tick{ background:var(--biscuit); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background-color .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to bottom, rgba(36,30,23,.32), transparent);
  opacity:1; transition:opacity .3s var(--ease);
}
.site-header.solid{ background:var(--paper); border-bottom-color:var(--line); box-shadow:0 6px 24px -22px rgba(40,33,22,.6); }
.site-header.solid::before{ opacity:0; }

.header-inner{ display:flex; align-items:center; justify-content:space-between; height:74px; }

.brand{ display:inline-flex; align-items:center; gap:11px; text-decoration:none; color:#FFFDF8; }
.site-header.solid .brand{ color:var(--ink); }
.brand-mark{ width:34px; height:34px; color:var(--biscuit); flex:none; }
.site-header.solid .brand-mark{ color:var(--spruce); }
.brand-word{ font-family:var(--f-disp); font-weight:700; font-size:1.24rem; letter-spacing:-.02em; }

.nav{ display:flex; align-items:center; gap:30px; }
.navlinks{ display:flex; gap:26px; list-style:none; margin:0; padding:0; }
.navlinks a{
  text-decoration:none; color:#F6EFE2; font-weight:500; font-size:.98rem;
  padding:6px 0; position:relative; transition:color .2s var(--ease);
}
.site-header.solid .navlinks a{ color:var(--ink-soft); }
.navlinks a::after{
  content:""; position:absolute; left:0; right:100%; bottom:0; height:2px;
  background:var(--biscuit); transition:right .28s var(--ease);
}
.navlinks a:hover{ color:#fff; }
.site-header.solid .navlinks a:hover{ color:var(--spruce); }
.navlinks a:hover::after{ right:0; }
/* nav CTA needs more specificity than .navlinks a — set explicitly */
.nav a.btn.navcta{ padding:10px 18px; color:var(--ink); font-size:.95rem; }
.nav a.btn.navcta::after{ display:none; }

.hamburger{
  display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer;
  padding:8px; margin-right:-8px;
}
.hamburger span{ width:24px; height:2px; background:#FFFDF8; transition:.25s var(--ease); }
.site-header.solid .hamburger span{ background:var(--ink); }
.hamburger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.hamburger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobilenav{
  display:flex; flex-direction:column; gap:2px;
  background:var(--paper); border-top:1px solid var(--line); padding:14px 28px 22px;
}
.mobilenav a{ text-decoration:none; color:var(--ink); font-weight:600; padding:12px 0; border-bottom:1px solid var(--line); }
.mobilenav a:last-child{ border-bottom:0; }
.mobilenav .btn-call{ margin-top:14px; justify-content:center; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; background:var(--spruce); color:#F6EFE2; overflow:hidden; }
.hero::after{ /* faint paw texture */
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.06;
  background-image:radial-gradient(circle at 20% 30%, #fff 2px, transparent 3px),
                   radial-gradient(circle at 80% 70%, #fff 2px, transparent 3px);
  background-size:120px 120px;
}
.hero-grid{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.15fr .85fr; gap:40px; align-items:center;
  padding:130px 28px 96px;
}
.hero-copy{ max-width:600px; }
.hero h1{
  font-size:clamp(2.7rem,6.2vw,4.7rem); font-weight:800; line-height:1.0;
  margin:0 0 22px; letter-spacing:-.03em;
}
.hero h1 .accent{ color:var(--biscuit); }
.hero .lede{ font-size:clamp(1.06rem,1.6vw,1.2rem); color:#E7DFCF; max-width:48ch; margin:0 0 30px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:34px; }
.hero .btn-ghost{ color:#F6EFE2; border-color:rgba(246,239,226,.4); }
.hero .btn-ghost:hover{ background:#F6EFE2; color:var(--spruce); border-color:#F6EFE2; }
.hero-trust{
  display:flex; gap:30px; flex-wrap:wrap; list-style:none; margin:0; padding:24px 0 0;
  border-top:1px solid rgba(246,239,226,.2);
}
.hero-trust li{ font-size:.92rem; color:#CFC6B4; }
.hero-trust strong{ display:block; font-family:var(--f-disp); font-size:1.5rem; font-weight:700; color:#fff; line-height:1; margin-bottom:4px; }

.hero-art{ position:relative; display:flex; flex-direction:column; align-items:center; }
.dog{ width:min(100%,340px); color:#F6EFE2; }
.dog .dl{ opacity:.96; }
.art-note{
  margin-top:18px; font-size:.72rem; letter-spacing:.04em; color:rgba(246,239,226,.5);
}
.hero-base{ position:absolute; left:0; right:0; bottom:-1px; height:48px; background:var(--paper); clip-path:polygon(0 100%, 100% 100%, 100% 38%, 0 100%); z-index:1; }

/* draw-on animation for the dog */
.dog .dl{ stroke-dasharray:var(--len,400); stroke-dashoffset:var(--len,400); }
.js-ready .dog.draw .dl{ animation:draw 1.5s var(--ease) forwards; }
@keyframes draw{ to{ stroke-dashoffset:0; } }

/* ============================================================
   TRUST STRIP
   ============================================================ */
.strip{ background:var(--paper-2); border-bottom:1px solid var(--line); }
.strip-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.strip-item{
  padding:26px 24px; border-left:1px solid var(--line);
  transition:background-color .25s var(--ease);
}
.strip-item:first-child{ border-left:0; }
.strip-item:hover{ background:var(--paper); }
.si-k{ display:block; font-family:var(--f-disp); font-weight:700; font-size:1.25rem; color:var(--spruce); }
.si-l{ display:block; font-size:.88rem; color:var(--ink-soft); margin-top:3px; }

/* ============================================================
   SECTION SHELL
   ============================================================ */
.section{ padding:96px 0; }
.sec-head{ max-width:680px; margin:0 0 52px; }
.sec-head h2{ margin-bottom:18px; }
.sec-lede{ font-size:1.1rem; color:var(--ink-soft); }

/* ============================================================
   SERVICES
   ============================================================ */
.svc-list{ list-style:none; margin:0; padding:0; border-top:1px solid var(--line); }
.svc{
  display:grid; grid-template-columns:230px 1fr; gap:32px; align-items:baseline;
  padding:30px 18px; border-bottom:1px solid var(--line); position:relative;
  transition:background-color .28s var(--ease);
}
.svc::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--biscuit);
  transform:scaleY(0); transform-origin:top; transition:transform .3s var(--ease);
}
.svc:hover{ background:var(--surface); }
.svc:hover::before{ transform:scaleY(1); }
.svc-num{ font-family:var(--f-disp); font-weight:700; font-size:1.15rem; color:var(--spruce); transition:color .25s var(--ease); }
.svc:hover .svc-num{ color:var(--rust); }
.svc-body h3{ margin-bottom:8px; }
.svc-body p{ color:var(--ink-soft); max-width:54ch; }
.svc-foot{ margin-top:34px; color:var(--ink-soft); }
.svc-foot a{ color:var(--spruce); font-weight:600; text-decoration:underline; text-underline-offset:3px; text-decoration-color:var(--line-2); transition:text-decoration-color .2s; }
.svc-foot a:hover{ text-decoration-color:var(--spruce); }

/* ============================================================
   CARE / PROCESS
   ============================================================ */
.care{ background:var(--spruce); color:#F6EFE2; }
.care-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:start; }
.care-copy{ position:sticky; top:100px; }
.care-copy h2{ margin-bottom:18px; }
.care-copy p{ color:#D8D0BF; }
.steps{ list-style:none; margin:0; padding:0; counter-reset:step; }
.step{
  display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:start;
  padding:26px 22px; border-radius:var(--r); border:1px solid rgba(246,239,226,.16);
  transition:background-color .28s var(--ease), border-color .28s var(--ease);
}
.step + .step{ margin-top:14px; }
.step:hover{ background:var(--spruce-d); border-color:var(--biscuit); }
.step-n{ font-family:var(--f-disp); font-weight:700; font-size:1.5rem; color:var(--biscuit); line-height:1; }
.step h3{ margin-bottom:7px; }
.step p{ color:#CFC6B4; margin:0; }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{ background:var(--paper); }
.reviews-inner{ display:grid; grid-template-columns:.8fr 1.2fr; gap:48px; align-items:center; }
.rating-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:42px 36px; text-align:center; box-shadow:var(--shadow);
}
.stars{ display:flex; justify-content:center; gap:5px; color:var(--biscuit); margin-bottom:16px; }
.star{ width:26px; height:26px; }
.star path{ fill:var(--biscuit); }
.star.half path:first-child{ fill:url(#hg); }
.rating-num{ font-family:var(--f-disp); font-weight:800; font-size:4.2rem; line-height:1; color:var(--ink); }
.rating-sub{ color:var(--ink-soft); margin:10px 0 24px; }
.reviews-copy h2{ margin-bottom:18px; }
.reviews-copy p{ color:var(--ink-soft); margin-bottom:14px; }
.reviews-note{ font-size:.95rem; color:var(--spruce); font-weight:600; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ background:var(--paper-2); }
.faq-grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:48px; align-items:start; }
.faq-head{ margin:0; position:sticky; top:100px; }
.faq-list{ border-top:1px solid var(--line-2); }
.qa{ border-bottom:1px solid var(--line-2); }
.qa summary{
  list-style:none; cursor:pointer; padding:22px 40px 22px 0; position:relative;
  font-family:var(--f-disp); font-weight:600; font-size:1.12rem; color:var(--ink);
  transition:color .2s var(--ease);
}
.qa summary::-webkit-details-marker{ display:none; }
.qa summary::after{
  content:""; position:absolute; right:6px; top:28px; width:11px; height:11px;
  border-right:2px solid var(--spruce); border-bottom:2px solid var(--spruce);
  transform:rotate(45deg); transition:transform .25s var(--ease);
}
.qa[open] summary::after{ transform:rotate(-135deg); }
.qa summary:hover{ color:var(--spruce); }
.qa p{ color:var(--ink-soft); padding:0 40px 24px 0; max-width:62ch; }

/* ============================================================
   BOOK / CONTACT
   ============================================================ */
.book{ background:var(--spruce-d); color:#F6EFE2; }
.book-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.book-copy h2{ margin-bottom:18px; }
.book-copy p{ color:#D8D0BF; max-width:42ch; }
.book-phone{
  display:inline-flex; align-items:center; gap:12px; margin:28px 0 10px;
  font-family:var(--f-disp); font-weight:700; font-size:1.7rem; color:var(--biscuit);
  text-decoration:none; transition:color .2s var(--ease);
}
.book-phone .ico{ width:24px; height:24px; }
.book-phone:hover{ color:#fff; }
.book-loc{ font-size:.95rem; color:#BDB4A2; }

.book-form{ background:var(--surface); border-radius:var(--r-lg); padding:32px; box-shadow:var(--shadow); }
.field{ margin-bottom:18px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field label{ display:block; font-size:.86rem; font-weight:600; color:var(--ink); margin-bottom:7px; }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--f-body); font-size:1rem; color:var(--ink);
  padding:12px 14px; border:1.5px solid var(--line-2); border-radius:var(--r);
  background:var(--paper); transition:border-color .2s var(--ease), background-color .2s var(--ease);
}
.field input:focus, .field select:focus, .field textarea:focus{ background:#fff; border-color:var(--spruce); outline:none; }
.field textarea{ resize:vertical; }
.field.invalid input, .field.invalid select{ border-color:#B0432F; background:#FCEEEA; }
.err{ display:none; color:#9C3A28; font-size:.82rem; margin-top:6px; font-weight:600; }
.field.invalid .err{ display:block; }
.gotcha{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.book-form .btn-primary{ background:var(--spruce); }
.book-form .btn-primary:hover{ background:var(--spruce-d); }
.form-fine{ font-size:.82rem; color:var(--ink-soft); text-align:center; margin-top:14px; }
.form-success{ text-align:center; padding:20px 8px; }
.form-success .ok{ width:46px; height:46px; color:var(--spruce); margin-bottom:12px; }
.form-success p{ color:var(--ink); }

/* ============================================================
   VISIT / HOURS + MAP
   ============================================================ */
.visit{ background:var(--paper); }
.visit-grid{ display:grid; grid-template-columns:1fr 1.15fr; gap:36px; align-items:stretch; }
.hours-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:38px 34px; }
.hours-card h2{ font-size:1.9rem; margin-bottom:22px; }
.hours{ list-style:none; margin:0; padding:0; }
.hours li{
  display:flex; justify-content:space-between; gap:16px; padding:13px 12px;
  border-bottom:1px solid var(--line); border-radius:var(--r);
  transition:background-color .2s var(--ease);
}
.hours li:last-child{ border-bottom:0; }
.hours li:hover{ background:var(--paper-2); }
.hours li span:first-child{ font-weight:600; }
.hours li span:last-child{ color:var(--ink-soft); }
.hours .closed{ color:var(--rust); font-weight:600; }
.hours-note{ margin-top:18px; font-size:.88rem; color:var(--ink-soft); }

.map-card{ background:var(--spruce); color:#F6EFE2; border-radius:var(--r-lg); overflow:hidden; display:flex; flex-direction:column; }
.map-art{ position:relative; height:230px; background:var(--spruce-d); overflow:hidden; }
.map-grid{ position:absolute; inset:0; opacity:.5;
  background-image:linear-gradient(rgba(246,239,226,.10) 1px, transparent 1px),
                   linear-gradient(90deg, rgba(246,239,226,.10) 1px, transparent 1px);
  background-size:34px 34px; }
.map-road{ position:absolute; background:rgba(246,239,226,.20); }
.map-road-h{ left:0; right:0; top:58%; height:14px; }
.map-road-v{ top:0; bottom:0; left:34%; width:9px; }
.map-pin{ position:absolute; left:34%; top:58%; transform:translate(-50%,-100%); color:var(--biscuit); width:34px; }
.map-pin svg{ width:34px; height:auto; filter:drop-shadow(0 6px 8px rgba(0,0,0,.35)); }
.map-body{ padding:30px 32px 34px; }
.map-body h3{ font-size:1.5rem; margin-bottom:10px; }
.map-addr{ color:#CFC6B4; margin-bottom:22px; }
.map-body .btn-primary{ background:var(--biscuit); color:var(--ink); }
.map-body .btn-primary:hover{ background:var(--biscuit-d); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--ink); color:#CFC6B4; padding:64px 0 30px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; }
.brand-foot{ color:#F6EFE2; margin-bottom:16px; }
.brand-foot .brand-mark{ color:var(--biscuit); width:38px; height:38px; }
.brand-foot .brand-word{ font-size:1.35rem; }
.foot-brand p{ max-width:38ch; font-size:.95rem; margin-bottom:18px; }
.foot-fb{ display:inline-flex; align-items:center; gap:9px; color:#F6EFE2; text-decoration:none; font-weight:600; font-size:.92rem; transition:color .2s var(--ease); }
.foot-fb .ico{ width:20px; height:20px; }
.foot-fb:hover{ color:var(--biscuit); }
.foot-col h4{ font-family:var(--f-disp); font-size:1rem; color:#F6EFE2; margin-bottom:12px; letter-spacing:.02em; }
.foot-col p{ font-size:.94rem; margin-bottom:10px; line-height:1.7; }
.foot-col a{ color:var(--biscuit); text-decoration:none; font-weight:600; font-size:.92rem; transition:color .2s var(--ease); }
.foot-col a:hover{ color:#fff; }
.foot-base{ display:flex; justify-content:space-between; gap:16px; margin-top:44px; padding-top:22px; border-top:1px solid rgba(246,239,226,.14); font-size:.84rem; color:#ADA491; }

/* ============================================================
   REVEAL ANIMATIONS (gated by js-ready)
   ============================================================ */
.reveal{ opacity:1; transform:none; }
.js-ready .reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.js-ready .reveal.in{ opacity:1; transform:none; }
.js-ready .hero .reveal{ transition-delay:calc(var(--d,0) * .09s); }

@media (prefers-reduced-motion: reduce){
  .js-ready .reveal{ opacity:1 !important; transform:none !important; }
  .js-ready .dog.draw .dl{ animation:none !important; stroke-dashoffset:0 !important; }
  *{ transition:none !important; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .hero-grid{ grid-template-columns:1fr; gap:18px; padding:120px 28px 84px; }
  .hero-art{ order:-1; max-width:260px; }
  .dog{ width:200px; }
  .art-note{ display:none; }
  .care-grid{ grid-template-columns:1fr; gap:34px; }
  .care-copy{ position:static; }
  .reviews-inner{ grid-template-columns:1fr; gap:30px; }
  .faq-grid{ grid-template-columns:1fr; gap:26px; }
  .faq-head{ position:static; }
  .book-grid{ grid-template-columns:1fr; gap:36px; }
  .visit-grid{ grid-template-columns:1fr; }
}

@media (max-width:760px){
  .navlinks{ display:none; }
  .nav .navcta{ display:none; }
  .hamburger{ display:flex; }
  .strip-grid{ grid-template-columns:1fr 1fr; }
  .strip-item:nth-child(odd){ border-left:0; }
  .strip-item:nth-child(3), .strip-item:nth-child(4){ border-top:1px solid var(--line); }
}

@media (max-width:560px){
  body{ font-size:16px; }
  .wrap{ padding:0 20px; }
  .section{ padding:66px 0; }
  .sec-head{ margin-bottom:36px; }
  .hero-grid{ padding:108px 20px 70px; }
  .hero h1{ font-size:clamp(2.4rem,10vw,3rem); }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ width:100%; }
  .hero-trust{ gap:22px; }
  .svc{ grid-template-columns:1fr; gap:8px; padding:22px 14px; }
  .svc-num{ font-size:1rem; }
  .field-row{ grid-template-columns:1fr; gap:0; }
  .book-form{ padding:24px 20px; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .foot-brand{ grid-column:1 / -1; }
  .foot-base{ flex-direction:column; gap:6px; }
  .book-phone{ font-size:1.4rem; }
  .rating-num{ font-size:3.4rem; }
}

@media (max-width:380px){
  .strip-grid{ grid-template-columns:1fr; }
  .strip-item{ border-left:0 !important; border-top:1px solid var(--line); }
  .strip-item:first-child{ border-top:0; }
  .footer-grid{ grid-template-columns:1fr; }
}
