:root{
  --bg:#f0f4f8;
  --navy:#0f1b2d;
  --navy-2:#1a2942;
  --teal:#0d9da4;
  --teal-2:#0ab8c0;
  --muted:#5b6b82;
  --line:rgba(15,27,45,.08);
  --card:#ffffff;
  --shadow:0 20px 50px -20px rgba(15,27,45,.18);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--navy);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.5;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ---------- Floating vet icons background ---------- */
.bg-icons{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.bg-icons svg{
  position:absolute;
  color:var(--teal);
  opacity:.06;
  animation:drift 28s linear infinite;
  will-change:transform;
}
.bg-icons svg:nth-child(1){top:12%;left:6%;width:60px;animation-duration:32s}
.bg-icons svg:nth-child(2){top:28%;left:84%;width:80px;animation-duration:40s;animation-delay:-8s}
.bg-icons svg:nth-child(3){top:62%;left:10%;width:70px;animation-duration:36s;animation-delay:-14s}
.bg-icons svg:nth-child(4){top:78%;left:78%;width:54px;animation-duration:30s;animation-delay:-4s}
.bg-icons svg:nth-child(5){top:45%;left:48%;width:90px;animation-duration:44s;animation-delay:-20s;opacity:.04}
.bg-icons svg:nth-child(6){top:8%;left:60%;width:50px;animation-duration:34s;animation-delay:-12s}
@keyframes drift{
  0%{transform:translate(0,0) rotate(0deg)}
  50%{transform:translate(30px,-40px) rotate(180deg)}
  100%{transform:translate(0,0) rotate(360deg)}
}

/* ---------- Navbar (glassmorphism) ---------- */
.nav-wrap{position:sticky;top:0;z-index:50;padding:18px 0;transition:padding .3s ease}
.nav-wrap.scrolled{padding:10px 0}
.nav{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;
  border-radius:18px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.6);
  backdrop-filter:blur(0px) saturate(140%);
  -webkit-backdrop-filter:blur(0px) saturate(140%);
  transition:all .35s ease;
}
.nav-wrap.scrolled .nav{
  background:rgba(240,244,248,.72);
  backdrop-filter:blur(18px) saturate(180%);
  -webkit-backdrop-filter:blur(18px) saturate(180%);
  box-shadow:0 10px 30px -18px rgba(15,27,45,.25);
  border-color:rgba(15,27,45,.08);
}
.logo{display:inline-flex;align-items:center;gap:8px;font-size:22px;font-weight:800;color:var(--navy);letter-spacing:-.02em;line-height:1}
.logo img{height:36px;width:72px;max-width:72px;max-height:36px;object-fit:contain;display:block;flex:none}
.logo span{color:var(--teal)}
.about-grid .media.photo{background:none;box-shadow:none;padding:0;aspect-ratio:auto;border-radius:24px;overflow:hidden}
.about-grid .media.photo img{width:100%;height:auto;display:block;border-radius:24px}
.nav ul{display:flex;gap:6px;list-style:none;margin:0;padding:0}
.nav ul a{
  display:inline-block;padding:9px 14px;border-radius:10px;
  font-size:14.5px;font-weight:500;color:var(--navy);
  transition:background .2s,color .2s;
}
.nav ul a:hover,.nav ul a.active{background:rgba(13,157,164,.1);color:var(--teal)}
.nav-cta{display:flex;gap:10px;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 20px;border-radius:12px;
  font-weight:600;font-size:14.5px;
  transition:transform .2s,box-shadow .25s,background .2s;
  white-space:nowrap;
}
.btn-ghost{color:var(--navy)}
.btn-ghost:hover{background:rgba(15,27,45,.05)}
.btn-primary{
  background:var(--teal);color:#fff;
  box-shadow:0 8px 22px -10px rgba(13,157,164,.7);
}
.btn-primary:hover{transform:translateY(-2px);background:var(--teal-2);box-shadow:0 14px 34px -12px rgba(13,157,164,.85)}
.btn-primary.pulse{animation:pulse 2.6s ease-in-out infinite}
@keyframes pulse{
  0%,100%{box-shadow:0 8px 22px -10px rgba(13,157,164,.7)}
  50%{box-shadow:0 8px 30px -6px rgba(13,157,164,.95),0 0 0 6px rgba(13,157,164,.08)}
}
.btn-outline{color:var(--navy);border:1.5px solid rgba(15,27,45,.15)}
.btn-outline:hover{border-color:var(--navy);background:rgba(15,27,45,.03)}
.btn-lg{padding:15px 28px;font-size:15.5px;border-radius:14px}
.hamburger{display:none;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;color:var(--navy)}
.hamburger:hover{background:rgba(15,27,45,.05)}

/* ---------- Hero ---------- */
.hero{position:relative;z-index:1;padding:80px 0 120px}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:999px;
  background:rgba(13,157,164,.1);color:var(--teal);
  font-size:13px;font-weight:600;letter-spacing:.02em;
  margin-bottom:22px;
}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(13,157,164,.2)}
.hero h1{
  font-size:clamp(36px,5.2vw,64px);
  line-height:1.05;letter-spacing:-.025em;
  font-weight:800;margin:0 0 22px;color:var(--navy);
}
.hero h1 em{font-style:normal;background:linear-gradient(120deg,var(--teal),var(--teal-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:19px;color:var(--muted);margin:0 0 34px;max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{margin-top:34px;display:flex;gap:26px;color:var(--muted);font-size:13.5px;align-items:center;flex-wrap:wrap}
.hero-meta span{display:inline-flex;align-items:center;gap:6px}
.hero-meta svg{color:var(--teal)}

/* ---------- Dashboard mockup (floating) ---------- */
.mockup-wrap{position:relative;perspective:1400px;will-change:transform}
.mockup{
  position:relative;
  border-radius:22px;
  background:#fff;
  box-shadow:
    0 40px 80px -30px rgba(15,27,45,.4),
    0 20px 40px -20px rgba(13,157,164,.2);
  overflow:hidden;
  transform:rotateY(-10deg) rotateX(6deg) rotate(-2deg);
  animation:float 5s ease-in-out infinite;
  border:1px solid rgba(15,27,45,.06);
}
@keyframes float{
  0%,100%{transform:rotateY(-10deg) rotateX(6deg) rotate(-2deg) translateY(0)}
  50%{transform:rotateY(-10deg) rotateX(6deg) rotate(-2deg) translateY(-14px)}
}
.mockup-bar{
  display:flex;gap:6px;align-items:center;
  padding:12px 16px;background:#f5f7fa;border-bottom:1px solid var(--line);
}
.mockup-bar i{width:11px;height:11px;border-radius:50%;background:#e6ebf1}
.mockup-bar i:nth-child(1){background:#ff6159}
.mockup-bar i:nth-child(2){background:#ffbd2d}
.mockup-bar i:nth-child(3){background:#28c93f}
.mockup-body{display:grid;grid-template-columns:180px 1fr;min-height:360px}
.mock-side{background:var(--navy);color:#c9d4e2;padding:20px 14px;font-size:12.5px}
.mock-side .brand{color:#fff;font-weight:800;font-size:15px;margin-bottom:22px}
.mock-side .brand span{color:var(--teal)}
.mock-side ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.mock-side li{padding:9px 11px;border-radius:8px;display:flex;align-items:center;gap:9px}
.mock-side li.active{background:var(--teal);color:#fff;font-weight:600}
.mock-side li::before{content:"";width:13px;height:13px;border-radius:3px;background:currentColor;opacity:.8}
.mock-main{padding:22px;background:#fff}
.mock-main h4{margin:0 0 3px;font-size:15px}
.mock-main .sub{color:var(--muted);font-size:12px;margin-bottom:16px}
.mock-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
.mock-stat{background:#f5f8fc;border-radius:10px;padding:11px}
.mock-stat b{display:block;font-size:18px;color:var(--navy)}
.mock-stat em{font-style:normal;font-size:11px;color:var(--teal);font-weight:600}
.mock-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-top:1px solid var(--line);font-size:12.5px}
.mock-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--navy));flex:none}
.mock-row .name{font-weight:600}
.mock-row .pet{color:var(--muted);font-size:11.5px}
.mock-row .pill{margin-left:auto;padding:4px 10px;border-radius:999px;background:rgba(13,157,164,.12);color:var(--teal);font-size:11px;font-weight:600}

/* ---------- Section helpers ---------- */
section{position:relative;z-index:1}
.section{padding:110px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 60px}
.section-head .eyebrow{margin-bottom:16px}
.section-head h2{font-size:clamp(30px,3.6vw,46px);font-weight:800;letter-spacing:-.02em;margin:0 0 14px;line-height:1.1}
.section-head p{color:var(--muted);font-size:17.5px;margin:0}

/* ---------- Page header (non-home pages) ---------- */
.page-header{position:relative;z-index:1;padding:90px 0 40px;text-align:center}
.page-header .eyebrow{margin-bottom:18px}
.page-header h1{font-size:clamp(36px,4.6vw,58px);font-weight:800;letter-spacing:-.025em;margin:0 0 16px;line-height:1.1}
.page-header h1 em{font-style:normal;background:linear-gradient(120deg,var(--teal),var(--teal-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.page-header p{color:var(--muted);font-size:19px;margin:0 auto;max-width:680px}

/* ---------- Features ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature{
  background:var(--card);border-radius:20px;padding:30px;
  border:1px solid var(--line);
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.feature:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 50px -24px rgba(13,157,164,.35);
  border-color:rgba(13,157,164,.35);
}
.feature .ico{
  width:52px;height:52px;border-radius:14px;
  background:rgba(13,157,164,.12);color:var(--teal);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.feature h3{margin:0 0 8px;font-size:19px;font-weight:700;color:var(--navy)}
.feature p{margin:0;color:var(--muted);font-size:14.8px;line-height:1.6}

/* ---------- Feature showcase (alternating rows) ---------- */
.feat-showcase .section-head{margin-bottom:64px}
.feat-row{
  display:grid;grid-template-columns:1fr 1.1fr;gap:72px;
  align-items:center;
  padding:48px 0;
}
.feat-row + .feat-row{border-top:1px solid var(--line)}
.feat-row.reverse{grid-template-columns:1.1fr 1fr}
.feat-row.reverse .feat-copy{order:2}
.feat-row.reverse .feat-media{order:1}
.feat-copy{max-width:520px}
.feat-num{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;font-weight:700;letter-spacing:.18em;
  color:var(--teal);text-transform:uppercase;margin-bottom:16px;
}
.feat-num::after{content:"";width:32px;height:2px;background:var(--teal);border-radius:2px}
.feat-copy h3{
  margin:0 0 18px;font-size:32px;line-height:1.18;
  font-weight:800;color:var(--navy);letter-spacing:-.02em;
}
.feat-copy p{margin:0;color:var(--muted);font-size:17px;line-height:1.65}
.feat-copy strong{color:var(--navy);font-weight:700}

.feat-media{position:relative;perspective:1400px}
.feat-media-frame{
  position:relative;
  /* transparent — let the page background show through */
  background:transparent;
  filter:drop-shadow(0 24px 40px rgba(13,27,45,.18)) drop-shadow(0 6px 14px rgba(13,157,164,.12));
  will-change:transform;
  animation:featFloat 6s ease-in-out infinite;
}
.feat-row.reverse .feat-media-frame{animation-name:featFloatReverse}
.feat-media-frame img{
  display:block;width:100%;height:auto;
  /* keep whatever transparency the PNG already has */
  background:transparent;
}
@keyframes featFloat{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-14px) rotate(-1deg)}
}
@keyframes featFloatReverse{
  0%,100%{transform:translateY(0) rotate(1deg)}
  50%{transform:translateY(-14px) rotate(1deg)}
}
@media (prefers-reduced-motion:reduce){
  .feat-media-frame,.feat-row.reverse .feat-media-frame{animation:none}
}
@media (max-width:880px){
  .feat-row,.feat-row.reverse{
    grid-template-columns:1fr;gap:28px;padding:36px 0;
  }
  .feat-row.reverse .feat-copy{order:1}
  .feat-row.reverse .feat-media{order:2}
  .feat-copy h3{font-size:24px}
  .feat-copy p{font-size:15.5px}
}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative}
.step{background:var(--card);border-radius:20px;padding:32px;border:1px solid var(--line);text-align:center}
.step .num{
  width:52px;height:52px;border-radius:50%;margin:0 auto 18px;
  background:var(--navy);color:#fff;font-weight:800;font-size:20px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 8px rgba(15,27,45,.05);
}
.step h3{margin:0 0 8px;font-size:19px}
.step p{margin:0;color:var(--muted);font-size:14.8px}

/* ---------- Stats ---------- */
.stats-block{
  background:linear-gradient(135deg,#fff,#f5f8fc);
  border-radius:28px;padding:56px 48px;
  border:1px solid var(--line);
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  box-shadow:var(--shadow);
}
.stat{text-align:center}
.stat .val{
  font-size:clamp(34px,4vw,52px);font-weight:800;letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;
}
.stat .lbl{margin-top:10px;color:var(--muted);font-size:14.5px;font-weight:500}

/* ---------- Pets ---------- */
.pets{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.pet-card{
  background:var(--card);border-radius:24px;padding:40px;
  border:1px solid var(--line);text-align:center;
  transition:transform .4s;
}
.pet-card:hover{transform:translateY(-6px)}
.pet-card svg{margin:0 auto 18px;width:220px;height:220px}
.pet-card h3{margin:0 0 6px;font-size:22px}
.pet-card p{margin:0;color:var(--muted)}

/* ---------- Pricing ---------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price{
  background:var(--card);border-radius:22px;padding:36px 30px;
  border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .3s,box-shadow .3s;
}
.price:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price h3{margin:0 0 6px;font-size:18px;color:var(--muted);font-weight:600}
.price .amt{font-size:46px;font-weight:800;color:var(--navy);letter-spacing:-.02em;margin:6px 0 2px}
.price .amt small{font-size:16px;font-weight:500;color:var(--muted)}
.price .desc{color:var(--muted);font-size:14px;margin-bottom:22px}
.price ul{list-style:none;margin:0 0 28px;padding:0;flex:1}
.price li{padding:9px 0;font-size:14.5px;display:flex;gap:10px;align-items:center}
.price li::before{
  content:"";flex:none;width:18px;height:18px;border-radius:50%;
  background:rgba(13,157,164,.14) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230d9da4' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/11px no-repeat;
}
.price.featured{
  background:linear-gradient(165deg,var(--teal),#0b8890);
  color:#fff;border:0;position:relative;
  transform:scale(1.03);
  box-shadow:0 34px 60px -22px rgba(13,157,164,.55);
}
.price.featured:hover{transform:scale(1.03) translateY(-6px)}
.price.featured h3{color:rgba(255,255,255,.75)}
.price.featured .amt{color:#fff}
.price.featured .amt small{color:rgba(255,255,255,.75)}
.price.featured .desc{color:rgba(255,255,255,.82)}
.price.featured li::before{background-color:rgba(255,255,255,.22);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>")}
.price.featured .btn{background:#fff;color:var(--teal)}
.price.featured .btn:hover{background:var(--navy);color:#fff}
.badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--navy);color:#fff;font-size:11.5px;font-weight:700;
  letter-spacing:.08em;padding:7px 14px;border-radius:999px;text-transform:uppercase;
}

/* ---------- Testimonials ---------- */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{
  background:var(--card);border-radius:20px;padding:32px;
  border:1px solid var(--line);transition:transform .3s,box-shadow .3s;
}
.tcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tcard .stars{color:var(--teal);margin-bottom:14px;font-size:15px;letter-spacing:2px}
.tcard blockquote{margin:0 0 22px;font-size:15.5px;line-height:1.65;color:var(--navy)}
.tcard .who{display:flex;align-items:center;gap:12px}
.avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--navy));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;
}
.tcard .name{font-weight:700;font-size:14.5px}
.tcard .role{font-size:12.5px;color:var(--muted)}
.flag{margin-left:auto;font-size:22px}

/* ---------- Final CTA ---------- */
.final-cta{
  background:var(--navy);color:#fff;
  border-radius:28px;padding:72px 40px;text-align:center;
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 20%,rgba(13,157,164,.35),transparent 50%),
             radial-gradient(circle at 80% 80%,rgba(13,157,164,.2),transparent 50%);
}
.final-cta > *{position:relative}
.final-cta h2{font-size:clamp(30px,3.6vw,46px);margin:0 0 16px;font-weight:800;letter-spacing:-.02em}
.final-cta p{color:rgba(255,255,255,.72);font-size:17.5px;max-width:600px;margin:0 auto 32px}
.final-cta .btn-primary{background:var(--teal)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-grid .media{
  background:linear-gradient(135deg,var(--teal),#0b8890);
  border-radius:24px;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);
}
.about-grid .media svg{width:60%;height:60%;color:#fff;opacity:.85}
.about-grid h3{font-size:28px;letter-spacing:-.02em;margin:0 0 14px}
.about-grid p{color:var(--muted);font-size:16px;margin:0 0 14px;line-height:1.7}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.value{background:var(--card);border-radius:18px;padding:26px;border:1px solid var(--line);text-align:center}
.value .ico{width:48px;height:48px;border-radius:12px;background:rgba(13,157,164,.12);color:var(--teal);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.value h4{margin:0 0 6px;font-size:17px}
.value p{margin:0;color:var(--muted);font-size:14px;line-height:1.6}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:start}
.contact-info{background:var(--card);border-radius:22px;padding:34px;border:1px solid var(--line)}
.contact-info h3{margin:0 0 8px;font-size:22px;letter-spacing:-.02em}
.contact-info > p{color:var(--muted);margin:0 0 24px;font-size:14.5px;line-height:1.6}
.contact-row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-top:1px solid var(--line)}
.contact-row:first-of-type{border-top:0}
.contact-row .ico{flex:none;width:40px;height:40px;border-radius:10px;background:rgba(13,157,164,.12);color:var(--teal);display:flex;align-items:center;justify-content:center}
.contact-row .lbl{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:3px}
.contact-row .val{font-size:15px;font-weight:600;color:var(--navy)}
.contact-form{background:var(--card);border-radius:22px;padding:34px;border:1px solid var(--line);box-shadow:var(--shadow)}
.contact-form h3{margin:0 0 22px;font-size:22px;letter-spacing:-.02em}
.form-row{margin-bottom:16px}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:6px}
.form-row input,.form-row textarea,.form-row select{
  width:100%;padding:12px 14px;font-size:14.5px;font-family:inherit;
  border:1.5px solid var(--line);border-radius:10px;background:#f7fafb;
  color:var(--navy);transition:border-color .2s,background .2s;
}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{
  outline:none;border-color:var(--teal);background:#fff;
}
.form-row textarea{resize:vertical;min-height:110px}
.contact-ok{background:rgba(13,157,164,.1);color:var(--teal);border:1px solid rgba(13,157,164,.3);padding:12px 14px;border-radius:10px;font-size:14px;display:none}
.contact-ok.show{display:block}

/* ---------- Footer ---------- */
footer{padding:60px 0 40px;border-top:1px solid var(--line);margin-top:80px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.foot-grid h5{margin:0 0 14px;font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.foot-grid ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot-grid a{color:var(--navy);font-size:14.5px;opacity:.8}
.foot-grid a:hover{color:var(--teal);opacity:1}
.foot-brand p{color:var(--muted);font-size:14.5px;margin:10px 0 0;max-width:280px}
.foot-bottom{text-align:center;color:var(--muted);font-size:13px;padding-top:24px;border-top:1px solid var(--line)}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:none}

/* ---------- Mobile ---------- */
@media (max-width:960px){
  .hero-grid,.pets,.about-grid,.contact-grid{grid-template-columns:1fr;gap:50px}
  .features,.steps,.pricing,.testimonials,.values{grid-template-columns:1fr 1fr}
  .stats-block{grid-template-columns:1fr 1fr;padding:44px 30px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .mockup{transform:rotateY(-6deg) rotateX(4deg)}
  @keyframes float{0%,100%{transform:rotateY(-6deg) rotateX(4deg) translateY(0)}50%{transform:rotateY(-6deg) rotateX(4deg) translateY(-10px)}}
}
@media (max-width:680px){
  .nav ul,.nav-cta .btn-ghost{display:none}
  .hamburger{display:flex}
  .features,.steps,.pricing,.testimonials,.stats-block,.foot-grid,.values,.form-row.two{grid-template-columns:1fr}
  .section{padding:80px 0}
  .hero{padding:50px 0 80px}
  .page-header{padding:60px 0 20px}
  .final-cta{padding:56px 26px}
  .price.featured{transform:none}
  .price.featured:hover{transform:translateY(-6px)}
  .mobile-open ul{display:flex;flex-direction:column;position:absolute;top:70px;left:16px;right:16px;background:rgba(255,255,255,.95);backdrop-filter:blur(18px);padding:14px;border-radius:14px;box-shadow:var(--shadow);gap:2px}
}

/* ═══════════════════════ Language switcher ═══════════════════════ */
.bv-lang-switch{position:relative;margin-right:8px}
.bv-lang-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 11px 7px 8px;border-radius:999px;
  background:rgba(255,255,255,.7);
  border:1px solid rgba(15,27,45,.1);
  backdrop-filter:blur(10px);
  cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:700;
  color:var(--navy);letter-spacing:.02em;
  transition:background .2s,border-color .2s,transform .2s;
}
.bv-lang-btn:hover{background:rgba(255,255,255,.95);border-color:rgba(13,157,164,.4);transform:translateY(-1px)}
.bv-lang-flag{
  width:22px;height:15px;border-radius:3px;overflow:hidden;
  box-shadow:0 0 0 1px rgba(15,27,45,.08) inset,0 1px 2px rgba(15,27,45,.15);
  display:inline-flex;flex:none;
}
.bv-lang-flag svg{width:100%;height:100%;display:block}
.bv-lang-code{font-size:11.5px;letter-spacing:.06em}
.bv-lang-caret{opacity:.55;transition:transform .2s}
.bv-lang-switch.open .bv-lang-caret{transform:rotate(180deg)}

.bv-lang-dd{
  position:absolute;top:calc(100% + 8px);right:0;min-width:188px;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(15,27,45,.08);
  border-radius:14px;padding:6px;
  box-shadow:0 18px 42px -14px rgba(15,27,45,.25),0 6px 14px -6px rgba(13,157,164,.18);
  backdrop-filter:blur(16px);
  opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;
  transition:opacity .18s,transform .18s;
  z-index:1000;
}
.bv-lang-switch.open .bv-lang-dd{opacity:1;transform:none;pointer-events:auto}
.bv-lang-dd button{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:9px 11px;border:0;background:transparent;border-radius:10px;
  cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:600;
  color:var(--navy);text-align:left;
  transition:background .15s;
}
.bv-lang-dd button:hover{background:rgba(13,157,164,.08)}
.bv-lang-dd button.active{background:rgba(13,157,164,.12);color:var(--teal-2)}
.bv-lang-flag-sm{
  width:24px;height:16px;border-radius:3px;overflow:hidden;flex:none;
  box-shadow:0 0 0 1px rgba(15,27,45,.08) inset;
  display:inline-flex;
}
.bv-lang-flag-sm svg{width:100%;height:100%;display:block}

/* ── First-visit language modal ── */
.bv-lang-modal{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:rgba(15,27,45,.55);
  backdrop-filter:blur(10px);
  opacity:0;transition:opacity .28s ease;
}
.bv-lang-modal.open{opacity:1}
.bv-lang-modal.closing{opacity:0}
.bv-lang-modal-card{
  width:100%;max-width:720px;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(255,255,255,.6);
  border-radius:28px;padding:42px 42px 36px;
  box-shadow:0 50px 100px -30px rgba(15,27,45,.45);
  text-align:center;
  transform:translateY(20px) scale(.97);
  transition:transform .35s cubic-bezier(.22,.61,.36,1);
}
.bv-lang-modal.open .bv-lang-modal-card{transform:none}
.bv-lang-eyebrow{
  display:inline-block;padding:5px 14px;border-radius:999px;
  background:rgba(13,157,164,.12);color:var(--teal-2);
  font-weight:700;font-size:11.5px;letter-spacing:.14em;
  text-transform:uppercase;margin-bottom:14px;
}
.bv-lang-modal-card h2{
  margin:0 0 10px;font-size:clamp(26px,3.2vw,36px);font-weight:800;
  letter-spacing:-.02em;color:var(--navy);line-height:1.15;
}
.bv-lang-modal-card p{
  margin:0 auto 28px;max-width:480px;
  color:var(--muted);font-size:15.5px;line-height:1.55;
}
.bv-lang-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
.bv-lang-card{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:22px 14px 18px;border-radius:18px;
  background:#fff;border:1.5px solid rgba(15,27,45,.08);
  cursor:pointer;font-family:inherit;
  transition:transform .22s cubic-bezier(.22,.61,.36,1),border-color .22s,box-shadow .22s,background .22s;
}
.bv-lang-card:hover{
  transform:translateY(-4px);
  border-color:rgba(13,157,164,.5);
  background:linear-gradient(180deg,#fff,rgba(13,157,164,.06));
  box-shadow:0 22px 40px -18px rgba(13,157,164,.35);
}
.bv-lang-flag-big{
  width:64px;height:44px;border-radius:8px;overflow:hidden;
  box-shadow:0 0 0 1px rgba(15,27,45,.08) inset,0 4px 12px -4px rgba(15,27,45,.25);
  display:flex;
}
.bv-lang-flag-big svg{width:100%;height:100%;display:block}
.bv-lang-card .bv-lang-native{
  font-size:15px;font-weight:700;color:var(--navy);letter-spacing:-.01em;
}
.bv-lang-card .bv-lang-name{
  font-size:11.5px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;
}
@media (max-width:560px){
  .bv-lang-modal-card{padding:30px 22px 26px;border-radius:22px}
  .bv-lang-grid{grid-template-columns:repeat(2,1fr)}
}
