:root{
  --primary:#4f46e5;
  --secondary:#0ea5e9;
  --accent:#f59e0b;
  --ink:#1f2433;
  --body:#454b5e;
  --muted:#6b melody;
  --muted:#6b7280;
  --bg:#ffffff;
  --bg-soft:#f4f6fb;
  --line:#e3e7f0;
  --radius:16px;
  --shadow:0 10px 30px rgba(31,36,51,.08);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Nunito",system-ui,sans-serif;
  color:var(--body);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand strong{font-family:"Fredoka",system-ui,sans-serif;color:var(--ink);line-height:1.2}
img{max-width:100%;display:block}
a{color:var(--primary);text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}

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

:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}

.btn{
  display:inline-block;font-weight:700;font-family:"Fredoka",sans-serif;
  padding:13px 22px;border-radius:50px;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  font-size:1rem;text-align:center;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{box-shadow:0 8px 20px rgba(79,70,229,.35)}
.btn-accent{background:var(--accent);color:#3a2700}
.btn-accent:hover{box-shadow:0 8px 20px rgba(245,158,11,.4)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--primary)}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:44px;height:44px;border-radius:12px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-size:1.3rem;color:var(--primary)}
.brand-text small{color:var(--muted);font-size:.78rem}
.nav{display:flex;align-items:center;gap:8px}
.nav a{padding:8px 12px;border-radius:8px;color:var(--ink);font-weight:600}
.nav a:hover{color:var(--primary)}
.nav a.btn{color:#3a2700}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.2s}

/* Hero */
.hero{background:
  radial-gradient(circle at 80% 10%,rgba(14,165,233,.10),transparent 40%),
  linear-gradient(135deg,#eef2ff,#f4f6fb)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:64px 20px}
.eyebrow{color:var(--secondary);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;margin-bottom:10px}
.hero h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:16px}
.hl{color:var(--primary)}
.lead{font-size:1.15rem;color:var(--ink);margin-bottom:24px;max-width:46ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.hero-points{list-style:none;display:flex;flex-wrap:wrap;gap:10px 22px}
.hero-points li{position:relative;padding-left:24px;font-weight:600;color:var(--ink)}
.hero-points li::before{content:"🐾";position:absolute;left:0}
.hero-media img{border-radius:24px;box-shadow:var(--shadow);aspect-ratio:4/3;width:100%;height:100%;object-fit:cover}

/* Intro */
.intro{padding:56px 0;background:#fff}
.section-intro{font-size:1.1rem;max-width:80ch;margin:0 auto;text-align:center}

/* Sections */
section{scroll-margin-top:80px}
.block-head{text-align:center;max-width:60ch;margin:0 auto 36px}
.block-head h2,.about h2,.zone h2,.faq h2,.contact h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:12px}
.block-head p{color:var(--muted)}

.services{padding:64px 0;background:var(--bg-soft)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .15s ease}
.card:hover{transform:translateY(-4px)}
.card img{aspect-ratio:3/2;width:100%;height:100%;object-fit:cover}
.card-body{padding:18px}
.card-body h3{font-size:1.15rem;margin-bottom:6px}
.price{color:var(--accent);font-weight:700;font-family:"Fredoka",sans-serif;margin-bottom:8px}
.services-detail{margin-top:48px;max-width:80ch;margin-left:auto;margin-right:auto}
.services-detail h3{font-size:1.4rem;margin-bottom:14px}
.services-detail p{margin-bottom:16px}

.about{padding:64px 0;background:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
.about-media img{border-radius:24px;box-shadow:var(--shadow);aspect-ratio:4/3;width:100%;height:100%;object-fit:cover}
.about-text p{margin-bottom:16px}
.about-text .btn{margin-top:8px}

.zone{padding:64px 0;background:linear-gradient(135deg,#eef2ff,#e0f2fe)}
.zone p{max-width:80ch;margin-bottom:18px}
.zone-list{list-style:none;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.zone-list li{background:#fff;border:1px solid var(--line);padding:8px 16px;border-radius:50px;font-weight:600;color:var(--ink)}

.faq{padding:64px 0;background:#fff}
.faq-list{max-width:80ch;margin:0 auto;display:flex;flex-direction:column;gap:12px}
details{border:1px solid var(--line);border-radius:12px;padding:4px 18px;background:var(--bg-soft)}
summary{cursor:pointer;font-weight:700;font-family:"Fredoka",sans-serif;color:var(--ink);padding:14px 0;list-style:none}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";float:right;color:var(--primary);font-size:1.4rem;line-height:1}
details[open] summary::after{content:"–"}
details p{padding:0 0 16px}

.contact{padding:64px 0;background:var(--bg-soft)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start}
.contact-list{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:14px}
.contact-list li{display:flex;flex-direction:column}
.contact-list span:first-child{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}
.contact-list a{font-weight:700}

.contact-form{background:#fff;padding:28px;border-radius:var(--radius);box-shadow:var(--shadow)}
.field{margin-bottom:16px;display:flex;flex-direction:column}
.field label{font-weight:600;margin-bottom:6px;color:var(--ink)}
.field input,.field textarea{
  border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;font:inherit;color:var(--ink);background:#fff;
}
.field input:focus,.field textarea:focus{border-color:var(--primary);outline:none}
.field-check{flex-direction:row;align-items:flex-start;gap:10px}
.field-check input{width:18px;height:18px;margin-top:4px}
.field-check label{font-weight:400;font-size:.92rem;margin:0}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{margin-top:14px;font-weight:600}
.form-status.ok{color:#15803d}
.form-status.err{color:#b91c1c}
#submitBtn[disabled]{opacity:.6;cursor:not-allowed;transform:none}

/* Footer */
.site-footer{background:var(--ink);color:#cfd5e6;padding:48px 0 24px}
.footer-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-bottom:24px}
.site-footer strong{color:#fff;font-family:"Fredoka",sans-serif;font-size:1.2rem}
.site-footer a{color:#cfd5e6}
.site-footer a:hover{color:#fff}
.site-footer .muted{color:#8a90a6}
.footer-bottom{border-top:1px solid #343a4f;padding-top:18px;font-size:.85rem;color:#8a90a6}

@media(max-width:900px){
  .nav-toggle{display:flex}
  .nav{position:fixed;inset:64px 0 auto 0;flex-direction:column;background:#fff;padding:20px;gap:6px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .25s ease;align-items:stretch}
  .nav.open{transform:translateY(0)}
  .nav a{padding:12px 8px}
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
  .hero-media{order:-1}
  .cards{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr}
}
@media(max-width:520px){
  .cards{grid-template-columns:1fr}
  .hero-grid{padding:40px 20px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}