@font-face{font-family:'Caveat';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/caveat-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/inter-400.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/inter-500.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/inter-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/space-grotesk-500.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/space-grotesk-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/space-grotesk-700.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
/* =============================================================================
   TINKY & FRIENDS — design system (mobile-first, premium "Fresh Forest")
   ============================================================================= */
:root{
  --primary:#1f6f5c; --primary-dk:#164e3e; --primary-lt:#2f8f76;
  --accent:#ff7a4d; --accent-dk:#e85f33;
  --ink:#11231d; --ink-2:#3a4a43;
  --paper:#fbf7f0; --paper-2:#f5eee1; --sand:#f1e7d6;
  --mint:#e7f3ee; --mint-2:#d6ebe1;
  --line:#e7dfce; --line-2:#d9cfba;
  --muted:#52615a;
  --white:#fff;
  --r-xs:10px; --r-sm:14px; --r-md:20px; --r-lg:28px; --r-xl:36px; --r-pill:999px;
  --sh-1:0 2px 8px rgba(17,35,29,.06);
  --sh-2:0 10px 30px rgba(17,35,29,.10);
  --sh-3:0 24px 60px rgba(17,35,29,.16);
  --sh-accent:0 14px 34px rgba(255,122,77,.34);
  --maxw:1180px;
  --ff:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,system-ui,sans-serif;
  --ff-d:"Space Grotesk",var(--ff);
  --ff-hand:"Caveat",cursive;
  --space:clamp(1rem,4.5vw,2rem);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--ff);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:var(--primary);text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-d);line-height:1.08;letter-spacing:-.025em;margin:0 0 .5em;font-weight:700}
h1{font-size:clamp(2.3rem,8.5vw,4.1rem)}
h2{font-size:clamp(1.75rem,5.2vw,2.7rem)}
h3{font-size:clamp(1.15rem,3vw,1.4rem);font-weight:600}
p{margin:0 0 1rem}
.muted{color:var(--muted)}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--space)}
section{padding-block:clamp(2.8rem,9vw,5.5rem)}
.center{text-align:center}
.hand{font-family:var(--ff-hand);color:var(--accent-dk);font-size:1.5em;line-height:1;font-weight:600}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.18em;
  font-size:.74rem;font-weight:700;color:var(--primary);background:var(--mint);
  padding:.4rem .9rem;border-radius:var(--r-pill);margin-bottom:1rem}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--ff);
  font-weight:600;font-size:1rem;padding:.95rem 1.5rem;border-radius:var(--r-pill);border:2px solid transparent;
  cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease;min-height:50px;
  text-align:center;line-height:1.1}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--sh-accent)}
.btn-primary:hover{background:var(--accent-dk);transform:translateY(-2px)}
.btn-dark{background:var(--primary);color:#fff;box-shadow:0 12px 30px rgba(31,111,92,.3)}
.btn-dark:hover{background:var(--primary-dk);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.btn-lg{padding:1.1rem 1.9rem;font-size:1.08rem}
.btn-block{width:100%}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* ---- header ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,247,240,.82);
  border-bottom:1px solid transparent;transition:.2s}
.site-header.scrolled{background:rgba(251,247,240,.95);border-bottom-color:var(--line);box-shadow:var(--sh-1);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:70px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--ff-d);font-weight:700;font-size:1.3rem;color:var(--ink)}
.brand .mark{width:40px;height:40px;border-radius:13px;background:var(--primary);display:grid;place-items:center;
  color:#fff;box-shadow:var(--sh-1);transform:rotate(-6deg)}
.brand .mark svg{width:23px;height:23px}
.brand .bn{display:flex;flex-direction:column;line-height:1}
.brand .bn small{font-family:var(--ff);font-weight:500;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.nav-links{display:none;gap:1.9rem;align-items:center}
.nav-links a{color:var(--ink-2);font-weight:500;font-size:.97rem;position:relative}
.nav-links a:hover{color:var(--primary)}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--accent);
  transform:scaleX(0);transform-origin:left;transition:transform .2s}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{display:none}
.hamburger{background:none;border:0;padding:.5rem;cursor:pointer;display:flex;color:var(--ink)}
.hamburger svg{width:30px;height:30px}
.drawer{position:fixed;inset:0 0 0 auto;width:min(84vw,340px);background:var(--paper);box-shadow:var(--sh-3);
  transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:70;padding:1.4rem;
  display:flex;flex-direction:column;gap:.2rem}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.drawer a{color:var(--ink);font-size:1.15rem;font-weight:600;padding:.9rem .4rem;border-bottom:1px solid var(--line)}
.drawer .btn{margin-top:1.1rem}
.iconbtn{background:none;border:0;cursor:pointer;color:var(--ink);font-size:1.6rem;line-height:1}
.scrim{position:fixed;inset:0;background:rgba(17,35,29,.45);z-index:65;opacity:0;pointer-events:none;transition:opacity .28s}
.scrim.open{opacity:1;pointer-events:auto}
@media(min-width:920px){.nav-links{display:flex}.nav-cta{display:inline-flex}.hamburger{display:none}}

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(60% 50% at 88% 0%,rgba(255,122,77,.16),transparent 60%),
    radial-gradient(50% 60% at 0% 30%,rgba(31,111,92,.12),transparent 60%),
    linear-gradient(180deg,var(--mint),var(--paper) 70%)}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cg fill='%231f6f5c' fill-opacity='.05'%3E%3Cellipse cx='60' cy='66' rx='13' ry='16'/%3E%3Cellipse cx='42' cy='44' rx='6' ry='8'/%3E%3Cellipse cx='60' cy='38' rx='6' ry='8'/%3E%3Cellipse cx='78' cy='44' rx='6' ry='8'/%3E%3Cellipse cx='90' cy='62' rx='5' ry='7'/%3E%3C/g%3E%3C/svg%3E")}
.hero-grid{position:relative;display:grid;gap:2.2rem;align-items:center;padding-block:clamp(2.4rem,7vw,4.5rem)}
.hero h1 span{color:var(--primary)}
.hero .lead{font-size:1.18rem;max-width:46ch;color:var(--ink-2)}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.hero-rating{display:flex;align-items:center;gap:.7rem;margin-top:1.5rem;font-size:.92rem;color:var(--muted)}
.stars{color:#f5a623;letter-spacing:1px}
.hero-art{position:relative}
.hero-photo{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-3);aspect-ratio:4/4.4;
  background:linear-gradient(150deg,var(--primary-lt),var(--primary-dk));display:grid;place-items:center;position:relative}
.hero-photo .dog{font-size:clamp(7rem,30vw,13rem);filter:drop-shadow(0 12px 20px rgba(0,0,0,.25))}
.hero-photo::after{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 30% at 30% 18%,rgba(255,255,255,.18),transparent)}
.chip{position:absolute;background:rgba(255,255,255,.96);border-radius:var(--r-md);box-shadow:var(--sh-2);
  padding:.7rem .95rem;display:flex;align-items:center;gap:.6rem;font-size:.85rem;font-weight:600}
.chip .ic{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:1.05rem}
.chip small{display:block;font-weight:500;color:var(--muted);font-size:.74rem}
.chip-tl{top:8%;left:-6%}.chip-br{bottom:9%;right:-5%}
@media(min-width:920px){
  .hero-grid{grid-template-columns:1.04fr .96fr;gap:3.4rem}
  .hero .lead{font-size:1.25rem}
}

/* ---- trust marquee ---- */
.trust{background:var(--ink);color:#dfe8e3;padding-block:1rem;overflow:hidden}
.trust .row{display:flex;gap:3rem;white-space:nowrap;animation:marq 26s linear infinite;width:max-content}
.trust .row span{display:inline-flex;align-items:center;gap:.55rem;font-size:.92rem;color:#cdd9d2}
.trust .row span b{color:#fff}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---- section header ---- */
.sec-head{max-width:38rem;margin:0 auto 2rem}
.sec-head.center{text-align:center}
.sec-head .lead{font-size:1.08rem;color:var(--muted)}

/* ---- service cards ---- */
.cards{display:grid;gap:1.2rem;grid-template-columns:1fr}
@media(min-width:600px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.cards{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;
  box-shadow:var(--sh-1);transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;height:100%}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}
.card .ic{width:60px;height:60px;border-radius:18px;display:grid;place-items:center;font-size:1.9rem;
  background:var(--mint);margin-bottom:1rem}
.card.alt .ic{background:#ffe9df}
.card .tag{align-self:flex-start;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;
  color:var(--accent-dk);background:#ffe4d8;padding:.28rem .65rem;border-radius:var(--r-pill);margin-bottom:.7rem}
.card h3{margin-bottom:.4rem}
.card p{color:var(--muted);font-size:.96rem;margin-bottom:1rem}
.card .feat{list-style:none;padding:0;margin:0 0 1.1rem;display:grid;gap:.4rem}
.card .feat li{display:flex;gap:.5rem;font-size:.92rem;color:var(--ink-2)}
.card .feat li::before{content:"✓";color:var(--primary);font-weight:700}
.card .spacer{flex:1}
.card .foot{display:flex;align-items:center;justify-content:space-between;gap:.8rem;
  border-top:1px solid var(--line);padding-top:1rem;margin-top:.4rem}
.price{font-family:var(--ff-d);font-weight:700;font-size:1.6rem;color:var(--ink);line-height:1}
.price small{font-size:.82rem;color:var(--muted);font-weight:500;font-family:var(--ff)}
.price .from{font-size:.72rem;display:block;color:var(--muted);font-weight:500;letter-spacing:.04em;text-transform:uppercase}

/* ---- bands ---- */
.band-mint{background:var(--mint)}
.band-sand{background:var(--paper-2)}
.band-dark{background:var(--ink);color:#e7efeb}
.band-dark h2,.band-dark h3{color:#fff}.band-dark .muted{color:#9fb3aa}
.band-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dk));color:#eafff7}
.band-primary h2{color:#fff}

/* ---- calculator ---- */
.calc{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.3rem,4vw,2rem);box-shadow:var(--sh-2);max-width:520px;margin-inline:auto}
.calc h3{margin-bottom:.3rem}
.stepper{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin:1.4rem 0}
.stepper button{width:54px;height:54px;border-radius:50%;border:2px solid var(--line-2);background:#fff;
  font-size:1.6rem;color:var(--primary);cursor:pointer;line-height:1;transition:.15s}
.stepper button:hover:not([disabled]){border-color:var(--primary);background:var(--mint)}
.stepper button[disabled]{opacity:.35;cursor:not-allowed}
.stepper .val{font-family:var(--ff-d);font-weight:700;font-size:2.6rem;min-width:2ch;text-align:center}
.stepper .val small{display:block;font-family:var(--ff);font-size:.8rem;font-weight:500;color:var(--muted)}
.calc .total{text-align:center;background:var(--mint);border-radius:var(--r-md);padding:1.1rem;margin-top:.5rem}
.calc .total .n{font-family:var(--ff-d);font-weight:700;font-size:2.4rem;color:var(--primary)}
.calc .total small{display:block;color:var(--muted);font-size:.85rem}

/* ---- steps ---- */
.steps{display:grid;gap:1.1rem;grid-template-columns:1fr;counter-reset:s}
@media(min-width:620px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:1.5rem;position:relative}
.step .n{width:44px;height:44px;border-radius:14px;background:var(--ink);color:#fff;display:grid;place-items:center;
  font-family:var(--ff-d);font-weight:700;font-size:1.25rem;margin-bottom:.9rem}
.step h3{font-size:1.12rem}
.step p{color:var(--muted);font-size:.93rem;margin:0}

/* ---- features ---- */
.features{display:grid;gap:1.4rem;grid-template-columns:1fr}
@media(min-width:700px){.features{grid-template-columns:repeat(2,1fr)}}
.feature{display:flex;gap:1rem}
.feature .fi{flex:0 0 auto;width:52px;height:52px;border-radius:16px;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;font-size:1.5rem;box-shadow:var(--sh-1)}
.feature h3{font-size:1.12rem;margin-bottom:.25rem}
.feature p{color:var(--muted);font-size:.95rem;margin:0}

/* ---- testimonials ---- */
.quotes{display:grid;gap:1.2rem;grid-template-columns:1fr}
@media(min-width:760px){.quotes{grid-template-columns:repeat(3,1fr)}}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:1.5rem;box-shadow:var(--sh-1)}
.quote .stars{font-size:.95rem;margin-bottom:.6rem}
.quote p{font-size:1rem;color:var(--ink-2)}
.quote .who{display:flex;align-items:center;gap:.7rem;margin-top:1rem}
.quote .av{width:40px;height:40px;border-radius:50%;background:var(--mint-2);display:grid;place-items:center;font-weight:700;color:var(--primary)}
.quote .who b{display:block;font-size:.92rem}.quote .who small{color:var(--muted);font-size:.8rem}

/* ---- area / faq ---- */
.area-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.area-list span{background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:.45rem 1rem;font-size:.9rem;font-weight:500}
details.faq{border:1px solid var(--line);border-radius:var(--r-md);background:#fff;padding:0 1.2rem;margin-bottom:.7rem}
details.faq summary{cursor:pointer;list-style:none;padding:1.1rem 0;font-weight:600;display:flex;justify-content:space-between;gap:1rem;align-items:center}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";font-size:1.5rem;color:var(--accent);transition:.2s;line-height:1}
details.faq[open] summary::after{transform:rotate(45deg)}
details.faq p{padding-bottom:1.1rem;margin:0;color:var(--muted)}

/* ---- CTA band ---- */
.cta-band{text-align:center}
.cta-band .lead{max-width:40ch;margin-inline:auto;font-size:1.12rem}
.cta-band .hero-cta{justify-content:center}

/* ---- footer ---- */
.site-footer{background:var(--ink);color:#c7d4cd;padding-block:3.4rem 7rem}
@media(min-width:920px){.site-footer{padding-block:3.4rem 2.4rem}}
.site-footer a{color:#c7d4cd}.site-footer a:hover{color:#fff}
.foot-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:760px){.foot-grid{grid-template-columns:2fr 1fr 1fr}}
.foot-brand{font-family:var(--ff-d);font-weight:700;font-size:1.4rem;color:#fff;display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem}
.foot-grid h4{color:#fff;font-size:.92rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:.6rem;font-size:.95rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.4rem;padding-top:1.5rem;font-size:.85rem;
  color:#93a69d;display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;justify-content:space-between}

/* ---- sticky mobile CTA ---- */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:45;padding:.7rem var(--space);
  background:rgba(251,247,240,.97);border-top:1px solid var(--line);display:flex;gap:.6rem;
  box-shadow:0 -6px 20px rgba(17,35,29,.08)}
.mobile-cta .btn{flex:1}
@media(min-width:920px){.mobile-cta{display:none}}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .trust .row{animation:none!important}
}

/* --- a11y & contrast overrides --- */
.btn-primary{color:var(--ink)}
.site-footer .muted{color:#aebcb4}
.foot-grid h3{color:#fff;font-weight:600;font-size:.92rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}

/* ---- booking flow ---- */
.booking{max-width:660px;margin-inline:auto}
.bk-steps{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.4rem;font-size:.8rem;color:var(--muted)}
.bk-steps b{color:var(--primary)} .bk-steps span{opacity:.55}
.bk-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.1rem,4vw,1.8rem);box-shadow:var(--sh-1)}
.bk-h{font-family:var(--ff-d);font-weight:600;font-size:1.25rem;margin-bottom:.3rem}
.bk-sub{color:var(--muted);font-size:.95rem;margin-bottom:1.1rem}
.field{margin-bottom:1rem}
.field label{display:block;font-weight:600;margin-bottom:.35rem;font-size:.95rem}
.field input,.field textarea,.field select{width:100%;font:inherit;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:var(--r-sm);background:#fff;min-height:48px;color:var(--ink)}
.field textarea{min-height:90px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(31,111,92,.15)}
.field .hint{font-size:.82rem;color:var(--muted);margin-top:.3rem}
.svc-list{display:grid;gap:.7rem}
.svc-opt{display:flex;gap:.9rem;align-items:center;border:1.5px solid var(--line);border-radius:var(--r-md);padding:.9rem 1rem;cursor:pointer;background:#fff;text-align:left;width:100%;font:inherit;color:inherit}
.svc-opt:hover{border-color:var(--primary)}
.svc-opt.sel{border-color:var(--primary);box-shadow:0 0 0 3px rgba(31,111,92,.14)}
.svc-opt .ic{font-size:1.6rem} .svc-opt .t{flex:1} .svc-opt .t b{display:block} .svc-opt .t small{color:var(--muted)}
.svc-opt .p{font-family:var(--ff-d);font-weight:700;white-space:nowrap}
.date-strip{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}
.date-chip{flex:0 0 auto;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.55rem .7rem;text-align:center;cursor:pointer;background:#fff;min-width:62px}
.date-chip.sel{background:var(--primary);color:#fff;border-color:var(--primary)}
.date-chip .dow{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em} .date-chip .dom{font-family:var(--ff-d);font-weight:700;font-size:1.15rem}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:.6rem;margin-top:1rem}
.slot{border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.7rem .3rem;text-align:center;cursor:pointer;background:#fff;font-weight:600;min-height:48px}
.slot:hover{border-color:var(--primary)} .slot.sel{background:var(--primary);color:#fff;border-color:var(--primary)}
.slot.none{grid-column:1/-1;color:var(--muted);border-style:dashed;cursor:default}
.summary-box{background:var(--mint);border-radius:var(--r-md);padding:1rem 1.1rem;margin-bottom:1.1rem}
.summary-box .line{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.95rem}
.summary-box .tot{border-top:1px solid var(--line-2);margin-top:.4rem;padding-top:.6rem;font-weight:700;font-family:var(--ff-d);font-size:1.2rem}
.notice{padding:.9rem 1.1rem;border-radius:var(--r-sm);margin:1rem 0;font-size:.93rem}
.notice-err{background:#fdeaea;border:1px solid #f2b8b8;color:#9a2b2b}
.notice-info{background:var(--mint);border:1px solid var(--mint-2)}
.bk-actions{display:flex;gap:.7rem;margin-top:1.2rem} .bk-actions .btn{flex:1}
.bk-back{background:none;border:0;color:var(--muted);cursor:pointer;font:inherit;text-decoration:underline;padding:.3rem 0;margin-top:.4rem}

/* ---- blog ---- */
.lang-toggle{display:inline-flex;border:1.5px solid var(--line);border-radius:var(--r-pill);overflow:hidden}
.lang-toggle button{border:0;background:#fff;padding:.4rem .95rem;font:inherit;font-weight:600;cursor:pointer;color:var(--muted)}
.lang-toggle button.on{background:var(--primary);color:#fff}
.post-body{font-size:1.07rem;line-height:1.75}
.post-body p{margin:0 0 1.1rem}
.admin-post{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.8rem 0;border-bottom:1px solid var(--line)}
.admin-post .st{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .55rem;border-radius:var(--r-pill)}
.admin-post .live{background:rgba(31,111,92,.12);color:var(--primary)} .admin-post .draft{background:var(--sand);color:var(--muted)}
.grid2{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:680px){.grid2{grid-template-columns:1fr 1fr}}
