/* ===== Kapow Pest Control — purple + lime ===== */
:root {
  --blue: #5A189A;        /* primary purple (splat) */
  --blue-d: #46127a;
  --blue-dk: #2B004F;     /* deep purple */
  --blue-bright: #6a1fb0;
  --blue-pill: #6d28b8;   /* lighter purple pill */
  --yellow: #B9F500;      /* splat lime accent */
  --yellow-d: #9fd400;
  --yellow-soft: #edffb4;
  --grass: #38B000;       /* fresh green */
  --grass-d: #2d8f00;
  --red: #E63946;
  --ink: #2B004F;         /* deep purple headings */
  --body: #4a4458;
  --muted: #7d7390;
  --line: #ece4f5;
  --cream: #f7f2fc;       /* light lavender */
  --cream2: #efe4fb;
  --white: #ffffff;

  /* aliases keep the booking widget coherent */
  --navy: #5A189A;
  --navy-d: #46127a;
  --navy-dk: #2B004F;
  --green: #5A189A;
  --green-d: #46127a;
  --green-dk: #2B004F;
  --leaf: #6d28b8;

  --radius: 14px;
  --radius-lg: 22px;
  --radius-xl: 34px;
  --shadow: 0 14px 34px rgba(43, 0, 79, 0.16);
  --shadow-lg: 0 28px 64px rgba(43, 0, 79, 0.26);
  --ring: 0 0 0 4px rgba(185, 245, 0, 0.45);
  --maxw: 1240px;
  --font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --head: "Plus Jakarta Sans", "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --brand: "Baloo 2", "Plus Jakarta Sans", system-ui, sans-serif;
  --splat-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%20200%20200'%3E%3Cg%20fill='%23fff'%3E%3Ccircle%20cx='100'%20cy='100'%20r='80'/%3E%3Ccircle%20cx='45'%20cy='62'%20r='40'/%3E%3Ccircle%20cx='158'%20cy='55'%20r='44'/%3E%3Ccircle%20cx='165'%20cy='142'%20r='40'/%3E%3Ccircle%20cx='55'%20cy='150'%20r='42'/%3E%3Ccircle%20cx='100'%20cy='38'%20r='34'/%3E%3Ccircle%20cx='100'%20cy='168'%20r='32'/%3E%3Ccircle%20cx='34'%20cy='112'%20r='32'/%3E%3Ccircle%20cx='172'%20cy='100'%20r='30'/%3E%3Ccircle%20cx='188'%20cy='28'%20r='8'/%3E%3Ccircle%20cx='18'%20cy='176'%20r='9'/%3E%3C/g%3E%3C/svg%3E");
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font); color: var(--body); background: var(--white); line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
h1, h2, h3, h4, h5 { font-family: var(--head); color: var(--ink); line-height: 1.1; margin: 0 0 .5em; letter-spacing: -.025em; font-weight: 800; }
h1 { font-size: clamp(2.6rem, 6.2vw, 4.6rem); }
h2 { font-size: clamp(1.9rem, 4vw, 2.9rem); }
h3 { font-size: 1.2rem; font-weight: 700; letter-spacing: -.015em; }
p { margin: 0 0 1rem; }
a { color: var(--blue); text-decoration: none; }
img { max-width: 100%; display: block; }
.hl { color: var(--yellow); }
.hl-b { color: var(--blue); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.wrap--narrow { max-width: 860px; }

/* ===== Icons ===== */
.ico { width: 1.15em; height: 1.15em; display: inline-block; vertical-align: -0.18em; fill: none; stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; }
.ibadge { display: inline-grid; place-items: center; width: 64px; height: 64px; border-radius: 50%; color: var(--blue); background: var(--yellow); box-shadow: 0 12px 24px rgba(185,245,0,.35); flex: none; transition: transform .25s ease; }
.ibadge .ico { width: 30px; height: 30px; }
.ibadge--blue, .ibadge--amber { background: var(--yellow); color: var(--blue); }
.ibadge--violet, .ibadge--teal { background: var(--blue); color: var(--yellow); }
.ibadge--ghost { background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); box-shadow: none; color: var(--yellow); }

/* ===== Buttons ===== */
.btn { position: relative; display: inline-flex; align-items: center; justify-content: center; gap: .5em; font-family: var(--head); font-weight: 700; font-size: 1rem; padding: .95rem 1.7rem; border-radius: 10px; border: 2px solid transparent; cursor: pointer; transition: transform .14s ease, box-shadow .2s ease, background .2s ease; text-align: center; line-height: 1; letter-spacing: -.01em; }
.btn .ico { width: 1.05em; height: 1.05em; transition: transform .2s ease; }
.btn:hover .ico { transform: translateX(3px); }
.btn:active { transform: translateY(1px) scale(.99); }
.btn--accent { background: var(--yellow); color: var(--blue); box-shadow: 0 10px 22px rgba(185,245,0,.4); }
.btn--accent:hover { background: var(--yellow-d); transform: translateY(-3px); box-shadow: 0 16px 30px rgba(185,245,0,.5); }
.btn--green { background: var(--blue); color: #fff; }
.btn--green:hover { background: var(--blue-d); transform: translateY(-3px); }
.btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.7); }
.btn--ghost:hover { background: rgba(255,255,255,.14); transform: translateY(-3px); }
.btn--outline { background: #fff; color: var(--blue); border-color: var(--line); }
.btn--outline:hover { border-color: var(--yellow); box-shadow: var(--shadow); transform: translateY(-3px); }
.btn--lg { padding: 1.1rem 2rem; font-size: 1.05rem; }
.btn--sm { padding: .6rem 1.15rem; font-size: .9rem; }
.btn--block { width: 100%; }

/* ===== Eyebrow ===== */
.eyebrow { display: inline-flex; align-items: center; gap: .7em; font-family: var(--head); font-weight: 700; font-size: .78rem; letter-spacing: .18em; text-transform: uppercase; color: var(--blue); background: none; padding: 0; border-radius: 0; margin-bottom: 1.1rem; }
.eyebrow::before { content: ""; width: 28px; height: 2px; background: var(--yellow-d); border-radius: 2px; flex: none; }
.eyebrow .ico { display: none; }
.eyebrow--light { background: none; color: #d8c8ff; }
.eyebrow--light::before { background: var(--yellow); }
.section__head { text-align: center; max-width: 800px; margin: 0 auto 3rem; }
.section__head .eyebrow { display: inline-flex; }
.section__lead { color: var(--muted); font-size: 1.12rem; }
.on-dark { color: #fff; }

/* ===== Reveal ===== */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ===== Header (all blue) ===== */
.topbadge { background: var(--blue); color: #fff; }
.topbadge__inner { display: flex; align-items: center; gap: 2.4rem; padding: .7rem 24px; }
.topbadge__item { display: inline-flex; align-items: center; gap: .8em; font-size: .82rem; color: #dfe0ff; }
.topbadge__item .ico { color: var(--yellow); width: 42px; height: 42px; stroke-width: 1.7; flex: none; }
.topbadge__item b { font-family: var(--head); color: #fff; display: block; font-size: .95rem; text-transform: uppercase; letter-spacing: .04em; font-weight: 800; }
.topbadge__item span { display: block; line-height: 1.15; }
.topbadge__spacer { margin-left: auto; }

.header { position: sticky; top: 0; z-index: 50; background: var(--blue); }
.header__inner { display: flex; align-items: center; gap: 1.5rem; padding: .65rem 24px; }
.header__badges { display: flex; gap: 2.2rem; flex: 1; justify-content: center; }
.hbadge { display: inline-flex; align-items: center; gap: .7em; color: #d7d8ff; }
.hbadge > .ico { color: var(--yellow); width: 42px; height: 42px; flex: none; stroke-width: 1.7; }
.hbadge__txt b { display: block; font-family: var(--head); font-weight: 800; color: #fff; text-transform: uppercase; letter-spacing: .03em; font-size: .92rem; }
.hbadge__txt span { display: block; font-size: .76rem; line-height: 1.15; color: #c9caff; }
.brand { display: inline-flex; align-items: center; background: none; padding: 0; box-shadow: none; transition: transform .15s ease; }
.brand:hover { transform: translateY(-1px) rotate(-1.5deg); }
.logo { display: inline-flex; flex-direction: column; align-items: flex-start; line-height: 1; }
.logo__word { font-family: "Baloo 2", "Montserrat", sans-serif; font-weight: 800; font-size: 2.5rem; color: #fff; letter-spacing: .005em; display: inline-flex; align-items: center; line-height: .9; }
.logo__o { display: inline-block; width: .92em; height: .92em; margin: 0 .005em; position: relative; top: .05em; }
.logo__splat { width: 100%; height: 100%; display: block; filter: drop-shadow(0 2px 4px rgba(0,0,0,.25)); }
.logo__sub { font-family: "Baloo 2", "Montserrat", sans-serif; font-weight: 700; font-size: .74rem; letter-spacing: .36em; color: var(--yellow); text-transform: uppercase; margin-top: .05em; padding-left: .18em; }
.header__cta { display: flex; align-items: center; gap: .7rem; flex: none; }
.header__phone { font-family: var(--head); font-weight: 800; color: var(--blue); background: var(--yellow); padding: .55rem 1rem; border-radius: 8px; display: inline-flex; align-items: center; gap: .4em; }
.header__phone .ico { color: var(--blue); }

/* Nav bar */
.navbar { background: var(--blue-d); position: sticky; top: 0; z-index: 49; }
.navbar__inner { display: flex; align-items: stretch; gap: .1rem; padding: 0 24px; }
.navitem { position: relative; }
.navitem > a { display: flex; align-items: center; gap: .4em; padding: .9rem 1.05rem; color: #ececff; font-family: var(--head); font-weight: 600; font-size: .93rem; }
.navitem > a .ico { width: .85em; height: .85em; opacity: .8; }
.navitem:hover > a, .navitem > a:hover { color: var(--yellow); }
.navitem__panel { position: absolute; top: 100%; left: 0; background: #fff; border-radius: 0 0 14px 14px; box-shadow: var(--shadow-lg); padding: 1.2rem; min-width: 640px; display: grid; grid-template-columns: repeat(4, 1fr); gap: .15rem 1.2rem; opacity: 0; visibility: hidden; transform: translateY(8px); transition: all .18s ease; z-index: 60; }
.navitem:hover .navitem__panel { opacity: 1; visibility: visible; transform: translateY(0); }
.navitem__panel a { display: block; padding: .42rem .5rem; color: var(--body); font-size: .88rem; border-radius: 8px; }
.navitem__panel a:hover { background: var(--cream2); color: var(--blue); }
.navitem__col-h { grid-column: 1/-1; font-family: var(--head); font-weight: 700; color: var(--blue); text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; padding: .2rem .5rem .4rem; }
.navbar__book { margin-left: auto; align-self: center; }
.navbar__social { margin-left: auto; display: flex; align-items: center; gap: 1.1rem; padding-left: 1rem; }
.navbar__social a { color: #fff; display: inline-flex; transition: color .15s, transform .15s; }
.navbar__social a:hover { color: var(--yellow); transform: translateY(-2px); }
.navbar__social .ico { width: 20px; height: 20px; }

/* ===== Hero (solid blue + stats panel) ===== */
.hero { position: relative; color: #fff; overflow: hidden;
  background:
    linear-gradient(100deg, rgba(43,0,79,.96) 0%, rgba(43,0,79,.88) 26%, rgba(43,0,79,.60) 48%, rgba(43,0,79,.30) 72%, rgba(43,0,79,.16) 100%),
    url("img/hero-team.jpg") center right / cover no-repeat;
  background-color: var(--blue); }
.hero h1, .hero__lead { text-shadow: 0 2px 14px rgba(20,0,40,.45); }
.hero::before { content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0; background:
    radial-gradient(700px 460px at 86% 8%, rgba(185,245,0,.16), transparent 62%),
    radial-gradient(620px 420px at 70% 100%, rgba(124,58,237,.30), transparent 60%); }
/* Comic halftone dot texture (top-left) */
.hero::after { content: ""; position: absolute; top: 0; left: 0; width: 48%; height: 78%; pointer-events: none; z-index: 0;
    background-image: radial-gradient(rgba(185,245,0,.55) 2px, transparent 2.6px); background-size: 17px 17px;
    -webkit-mask-image: linear-gradient(135deg, #000 0%, transparent 62%); mask-image: linear-gradient(135deg, #000 0%, transparent 62%); opacity: .22; }

/* Right column: comic burst stacked over the stats */
.hero__right { display: flex; flex-direction: column; align-items: center; gap: 1.3rem; position: relative; z-index: 1; }

/* Splat promo badge (replaces comic burst) */
@keyframes splatIn {
  0%   { transform: scale(0) rotate(var(--r,0deg)); opacity: 0; }
  55%  { transform: scale(1.18) rotate(calc(var(--r,0deg) + 6deg)); opacity: var(--o,1); }
  78%  { transform: scale(.93) rotate(var(--r,0deg)); }
  100% { transform: scale(1) rotate(var(--r,0deg)); opacity: var(--o,1); }
}
.splatbadge { position: relative; width: 212px; height: 198px; display: grid; place-items: center; --o: 1; animation: splatIn .7s .05s cubic-bezier(.2,1.5,.5,1) both; }
.splatbadge__shape { position: absolute; inset: 0; width: 100%; height: 100%; filter: drop-shadow(0 8px 18px rgba(43,0,79,.4)); }
.splatbadge__txt { position: relative; z-index: 2; text-align: center; color: #2B004F; font-family: "Baloo 2","Montserrat",sans-serif; line-height: .92; transform: rotate(-6deg); }
.splatbadge__txt b { display: block; font-size: 2.9rem; font-weight: 800; }
.splatbadge__txt span { display: block; font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .14em; }
@media (prefers-reduced-motion: reduce) { .splatbadge { animation: none; } }

/* Splat-the-bug mini game */
.bughunt { position: relative; width: 100%; max-width: 320px; height: 200px; border: 3px dashed rgba(185,245,0,.55); border-radius: 18px; background: rgba(255,255,255,.06); overflow: hidden; }
.bughunt__hint { position: absolute; top: 12px; left: 0; right: 0; text-align: center; font-family: "Baloo 2","Montserrat",sans-serif; font-weight: 700; font-size: .92rem; color: #fff; z-index: 1; pointer-events: none; }
.bughunt__hint b { color: var(--yellow); }
.bughunt__bug { position: absolute; top: 0; left: 0; width: 46px; height: 46px; padding: 6px; border: none; background: none; cursor: pointer; transform: translate(135px, 90px); transition: transform .8s cubic-bezier(.5,.05,.5,1); z-index: 2; }
.bughunt__bug svg { width: 100%; height: 100%; fill: none; stroke: var(--yellow); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; filter: drop-shadow(0 2px 3px rgba(0,0,0,.35)); }
.bughunt__bug:hover svg { stroke: #fff; }
.bughunt__win[hidden] { display: none; }
.bughunt__win { position: absolute; inset: 0; z-index: 4; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .3rem; text-align: center; background: #2B004F; border-radius: 15px; padding: .9rem; animation: splatIn .55s cubic-bezier(.2,1.5,.5,1) both; }
.bughunt__splat { display: block; width: 56px; height: 48px; margin: 0 auto .15rem; }
.bughunt__splat svg { width: 100%; height: 100%; display: block; }
.bughunt__win strong { font-family: "Baloo 2","Montserrat",sans-serif; color: #fff; font-size: 1.1rem; }
.bughunt__codeline { color: #e9dcff; font-size: .9rem; }
.bughunt__codeline code { background: var(--yellow); color: #2B004F; font-family: "Baloo 2","Montserrat",sans-serif; font-weight: 800; padding: .2rem .6rem; border-radius: 8px; letter-spacing: .08em; }
.bughunt__btns { display: flex; gap: .5rem; margin-top: .4rem; }
.bughunt__copy, .bughunt__book { background: var(--yellow); color: #2B004F; border: none; border-radius: 8px; padding: .45rem .9rem; font-family: "Baloo 2","Montserrat",sans-serif; font-weight: 800; cursor: pointer; font-size: .9rem; }
.bughunt__book { background: #fff; }
.bughunt__copy:hover, .bughunt__book:hover { transform: translateY(-1px); }
/* Decorative bug-splats */
.splatdeco { position: absolute; pointer-events: none; z-index: 0; line-height: 0; opacity: var(--o, .8); }
.splatdeco .ico { fill: var(--yellow); stroke: none; display: block; width: 100%; height: 100%; }
.splatdeco--1 { top: -40px; right: 4%; width: 175px; height: 175px; --o: .9; --r: 18deg; --d: .12s; animation: splatIn .7s var(--d) cubic-bezier(.2,1.5,.5,1) both, floaty 7s calc(var(--d) + .8s) ease-in-out infinite; }
.splatdeco--2 { bottom: -55px; left: 1%; width: 150px; height: 150px; --o: .85; --r: -12deg; --d: .26s; animation: splatIn .7s var(--d) cubic-bezier(.2,1.5,.5,1) both, floaty 9s calc(var(--d) + .8s) ease-in-out infinite; }
.splatdeco--3 { top: 40%; left: 47%; width: 95px; height: 95px; --o: .5; --r: 6deg; --d: .4s; animation: splatIn .7s var(--d) cubic-bezier(.2,1.5,.5,1) both, floaty 8s calc(var(--d) + .8s) ease-in-out infinite; }

/* ===== Motion (restrained) ===== */
@keyframes floaty { 0%,100% { transform: translateY(0) rotate(var(--r,0deg)); } 50% { transform: translateY(-14px) rotate(calc(var(--r,0deg) + 4deg)); } }

/* Navbar */
.navbar { background: var(--blue-dk); border-bottom: 1px solid rgba(255,255,255,.08); }
.navitem > a { position: relative; transition: color .15s ease; }
.navitem > a::before { content: ""; position: absolute; left: 16px; right: 16px; bottom: 8px; height: 2px; background: var(--yellow); border-radius: 2px; transform: scaleX(0); transform-origin: left; transition: transform .22s ease; }
.navitem:hover > a { color: var(--yellow); }
.navitem:hover > a::before { transform: scaleX(1); }
.navbar__social a { transition: color .15s ease, transform .15s ease; }

/* Subtle, consistent lift on interactive surfaces */
.tcard, .misspill, .eco-pill, .bookchip { transition: transform .18s ease, box-shadow .18s ease; }
.tcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.misspill:hover { transform: translateX(4px); }

@media (prefers-reduced-motion: reduce) {
  .splatdeco--1, .splatdeco--2, .splatdeco--3 { animation: none !important; }
}
.hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.25fr .75fr; gap: 3rem; align-items: center; padding: 6rem 24px 7rem; min-height: 76vh; }
.hero__curve { position: absolute; left: 0; right: 0; bottom: -1px; width: 100%; height: clamp(44px, 5.5vw, 84px); display: block; z-index: 3; pointer-events: none; }
.hero__curve path { fill: var(--cream); }
.hero h1 { color: #fff; text-transform: none; line-height: 1.05; font-size: clamp(2rem, 4.6vw, 3.1rem); letter-spacing: -.015em; }
.hero h1 .hl { color: var(--yellow); display: inline; }
.hero__lead { font-size: 1.15rem; color: #d9d9ff; max-width: 33rem; margin-top: 1rem; }
.hero__eyebrow { display: inline-flex; align-items: center; gap: .55em; font-family: var(--head); font-weight: 700; font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; color: var(--yellow); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.18); padding: .5rem 1.05rem; border-radius: 999px; margin-bottom: 1.2rem; }
.hero__eyebrow .ico { width: 1em; height: 1em; color: var(--yellow); }
.hero__cta { display: flex; gap: .9rem; flex-wrap: wrap; margin: 1.8rem 0 0; }
.hero__stats { background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius-lg); padding: 2rem 1.6rem; display: grid; gap: 1.4rem; backdrop-filter: blur(4px); align-self: stretch; }
.hero__stat { display: flex; align-items: center; gap: 1.15rem; }
.hero__stat-ico { width: 64px; height: 64px; color: var(--yellow); display: grid; place-items: center; flex: none; }
.hero__stat-ico .ico { width: 56px; height: 56px; fill: var(--yellow); stroke: none; }
.hero__stat-num { font-family: var(--head); font-weight: 800; font-size: 3.6rem; color: var(--yellow); line-height: .85; flex: none; width: 64px; text-align: center; }
.hero__stat-txt b { font-family: var(--head); color: var(--yellow); font-size: 1.55rem; display: block; line-height: 1; text-transform: uppercase; letter-spacing: .01em; font-weight: 800; }
.hero__stat-txt span { color: #fff; font-size: 1.02rem; text-transform: uppercase; font-weight: 700; letter-spacing: .03em; }

/* ===== Sections ===== */
.section { padding: 5rem 0; }
.section--cream { background: var(--cream); }
.section--lav { background: var(--cream2); }

/* Plain-gradient hero (interior pages, no background photo) */
.hero--plain { background: linear-gradient(155deg, #2B004F 0%, #3d0a6b 55%, #2B004F 100%); }
.hero--plain h1 { font-size: clamp(2.3rem, 4.8vw, 3.7rem); line-height: 1; }
.hero--plain .hero__inner { min-height: 0; padding: 4.5rem 24px 6.5rem; align-items: center; }
.hero__media { max-width: 380px; width: 100%; }
.hero__emblem { position: relative; width: clamp(210px, 30vw, 300px); aspect-ratio: 1/1; margin: 0 auto; display: grid; place-items: center; filter: drop-shadow(0 16px 26px rgba(0,0,0,.32)); }
.hero__emblem-splat { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero__emblem-ico { position: relative; width: 40%; height: 40%; color: #2B004F; stroke-width: 1.7; }
.herochips { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: 1.4rem; }
.herochip { display: inline-flex; align-items: center; gap: .45em; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); color: #fff; font-family: var(--head); font-weight: 600; padding: .5rem 1rem; border-radius: 999px; font-size: .9rem; }
.herochip .ico { color: var(--yellow); width: 1.05em; height: 1.05em; }

/* Interior page breadcrumb */
.crumbs { font-size: .85rem; color: var(--muted); padding: 1.1rem 0 0; }
.crumbs a { color: var(--blue); font-weight: 600; }
.crumbs span { color: var(--muted); margin: 0 .4em; }
.section--blue, .section--navy, .section--green { background: var(--blue); color: #fff; position: relative; overflow: hidden; }
.section--blue::before, .section--navy::before { content: ""; position: absolute; inset: 0; background: radial-gradient(800px 460px at 85% 0%, rgba(255,255,255,.08), transparent 60%); }
.section--book { background: var(--cream); }
.section--blue .eyebrow, .section--navy .eyebrow { background: rgba(255,255,255,.14); color: var(--yellow); }
.section--blue h2, .section--navy h2, .section--blue h3, .section--blue p, .section--navy p { color: #fff; }

.grid { display: grid; gap: 1.6rem; }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }

/* Eco band (white, green pills) */
.eco-bar { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); display: flex; align-items: center; flex-wrap: wrap; gap: 1.2rem 2rem; padding: 1.4rem 2rem; }
.eco-bar__lead { display: flex; align-items: center; gap: .8rem; font-family: var(--head); font-weight: 700; color: var(--ink); font-size: 1.15rem; }
.eco-bar__leaf { width: 44px; height: 44px; border-radius: 50%; background: #e7f7ec; color: var(--grass); display: grid; place-items: center; flex: none; }
.eco-bar__leaf .ico { width: 24px; height: 24px; }
.eco-bar__pills { display: flex; gap: .8rem; margin-left: auto; flex-wrap: wrap; }
.eco-pill { display: inline-flex; align-items: center; gap: .5em; background: var(--grass); color: #fff; font-family: var(--head); font-weight: 700; padding: .7rem 1.3rem; border-radius: 10px; font-size: 1rem; }
.eco-pill .ico { width: 1.1em; height: 1.1em; }

/* Pest price cards */
.pestcard { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; transition: transform .22s ease, box-shadow .22s ease; display: flex; flex-direction: column; }
.pestcard:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); }
.pestcard__media { position: relative; aspect-ratio: 16/10; background: var(--blue); overflow: hidden; }
.pestcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease; }
.pestcard:hover .pestcard__media img { transform: scale(1.06); }
.pestcard__icon { position: absolute; bottom: -26px; left: 20px; width: 56px; height: 56px; border-radius: 14px; background: var(--yellow); color: var(--blue); display: grid; place-items: center; box-shadow: var(--shadow); }
.pestcard__icon .ico { width: 28px; height: 28px; }
.pestcard__body { padding: 2rem 1.4rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.pestcard__name { font-family: var(--head); font-weight: 800; text-transform: uppercase; letter-spacing: .04em; color: var(--ink); font-size: 1.05rem; }
.pestcard__price { font-family: var(--head); font-weight: 800; color: var(--blue); font-size: 1.5rem; margin: .2rem 0 1rem; }
.pestcard__price span { font-size: .8rem; color: var(--muted); font-weight: 600; }
.pestcard__save { position: absolute; top: 12px; right: 12px; background: var(--yellow); color: var(--blue); font-family: var(--head); font-weight: 800; font-size: .72rem; padding: .3rem .6rem; border-radius: 6px; letter-spacing: .03em; z-index: 2; }
.pestcard .btn { margin-top: auto; }
.fineprint { text-align: center; color: var(--muted); font-size: .92rem; margin-top: 2rem; }

/* Two-col content */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; }
.split + .split { margin-top: 4.5rem; }
.split--flip .split__media { order: 2; }
.split__img { width: 100%; height: auto; aspect-ratio: 1/1; object-fit: cover; -webkit-mask: var(--splat-mask) center / 100% 100% no-repeat; mask: var(--splat-mask) center / 100% 100% no-repeat; }
.split h2 { margin-bottom: .6rem; }
.split ul { list-style: none; padding: 0; margin: 1.2rem 0 1.6rem; display: grid; gap: .7rem; }
.split ul li { display: flex; align-items: flex-start; gap: .6em; font-weight: 500; }
.split ul li .ico { color: var(--yellow-d); margin-top: .15em; flex: none; }
.section--blue .split ul li .ico { color: var(--yellow); }

/* Affordable excellence block */
.afford { display: grid; grid-template-columns: 1fr 1.05fr; gap: 3rem; align-items: center; position: relative; z-index: 1; }
.afford h2 { font-size: clamp(2.4rem, 5vw, 3.6rem); color: var(--yellow); line-height: .98; text-transform: uppercase; }
.afford__sub { font-family: var(--head); font-weight: 700; color: #fff; letter-spacing: .12em; text-transform: uppercase; font-size: .9rem; margin: .4rem 0 1.2rem; }
.afford p { color: #d9d9ff; }
.misspills { display: grid; gap: .8rem; }
.misspill { display: flex; align-items: center; gap: 1rem; background: var(--blue-pill); border: 1px solid rgba(255,255,255,.14); border-radius: 999px; padding: .9rem 1.3rem; color: #fff; font-weight: 500; }
.misspill__tick { width: 30px; height: 30px; border-radius: 50%; background: var(--yellow); color: var(--blue); display: grid; place-items: center; flex: none; }
.misspill__tick .ico { width: 17px; height: 17px; stroke-width: 3; }

/* Pest chips */
.chips { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; }
.chip { display: inline-flex; align-items: center; gap: .4em; background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: .55rem 1.1rem; font-weight: 600; color: var(--blue); font-size: .92rem; transition: all .15s; }
.chip:hover { background: var(--yellow); border-color: var(--yellow); color: var(--blue); transform: translateY(-2px); }
.chip .ico { width: 1.1em; height: 1.1em; color: var(--yellow-d); }
.chip:hover .ico { color: var(--blue); }

/* Pest picker tiles */
.pestpick { display: grid; grid-template-columns: repeat(8, 1fr); gap: .9rem; }
.pesttile { display: flex; flex-direction: column; align-items: center; gap: .7rem; background: #fff; border: 2px solid var(--line); border-radius: 16px; padding: 1.4rem .6rem; text-align: center; transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease; }
.pesttile:hover { border-color: var(--yellow); background: var(--yellow-soft); transform: translateY(-4px); box-shadow: var(--shadow); }
.pesttile__ico { width: 58px; height: 58px; display: grid; place-items: center; color: var(--blue); }
.pesttile__ico .ico { width: 44px; height: 44px; stroke-width: 1.7; }
.pesttile__name { font-family: var(--head); font-weight: 700; color: var(--ink); font-size: .86rem; }

/* Booking page chips */
.bookchips { display: flex; flex-wrap: wrap; justify-content: center; gap: .7rem; margin-top: 1.7rem; }
.bookchip { display: inline-flex; align-items: center; gap: .5em; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); color: #fff; font-family: var(--head); font-weight: 600; padding: .65rem 1.15rem; border-radius: 999px; font-size: .95rem; }
.bookchip .ico { color: var(--yellow); width: 1.15em; height: 1.15em; }

/* Steps */
.steps .step { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 2rem 1.6rem; transition: transform .2s ease, box-shadow .2s ease; }
.steps .step:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.step__num { display: grid; place-items: center; width: 52px; height: 52px; border-radius: 14px; background: var(--yellow); color: var(--blue); font-family: var(--head); font-weight: 800; font-size: 1.5rem; margin-bottom: 1rem; }
.step h3 { margin-bottom: .3rem; }
.step p { color: var(--muted); margin: 0; }
.how__cta { text-align: center; margin-top: 2.8rem; }

/* Logo strips */
.logos { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; align-items: center; }
.logos__item { width: 140px; height: 76px; background: #fff; border: 1px solid var(--line); border-radius: 12px; display: grid; place-items: center; color: var(--muted); font-family: var(--head); font-weight: 700; font-size: .8rem; text-align: center; padding: .5rem; }
.section--blue .logos__item, .section--navy .logos__item { background: #fff; border: none; }

/* Testimonials */
.tcard { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 2rem; box-shadow: var(--shadow); }
.tcard__stars { display: inline-flex; gap: 2px; color: var(--yellow); margin-bottom: .8rem; }
.tcard__stars .ico { fill: var(--yellow); stroke: var(--yellow); width: 1.2em; height: 1.2em; }
.tcard p { color: var(--ink); font-size: 1.02rem; }
.tcard__by { display: flex; align-items: center; gap: .7rem; margin-top: 1.2rem; }
.tcard__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--blue); color: var(--yellow); display: grid; place-items: center; font-family: var(--head); font-weight: 800; }
.tcard__name { font-family: var(--head); font-weight: 700; color: var(--ink); }
.tcard__loc { color: var(--muted); font-size: .85rem; }

/* FAQ block (two-column, shared accordion style) */
.faqblock { display: grid; grid-template-columns: .8fr 1.2fr; gap: 2.8rem; align-items: start; }
.faqblock__intro { position: sticky; top: 92px; }
.faqblock__intro h2 { margin-bottom: .6rem; }
.faqblock__intro p { color: var(--muted); font-size: 1.06rem; margin-bottom: 1.6rem; }
.faqblock__cta { display: flex; flex-wrap: wrap; gap: .7rem; }
.faqlist { display: flex; flex-direction: column; gap: .85rem; }

/* FAQ */
.faq { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 1.1rem 1.4rem; margin-bottom: .8rem; }
.faq[open] { box-shadow: var(--shadow); }
.faq summary { font-family: var(--head); font-weight: 700; color: var(--ink); cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 1rem; font-size: 1.05rem; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 1.6rem; color: var(--yellow-d); }
.faq[open] summary::after { content: "−"; }
.faq p { margin: .8rem 0 .2rem; color: var(--muted); }

/* CTA band (deep purple, premium) */
.ctaband { position: relative; overflow: hidden; border-radius: 16px; padding: 2.4rem 2.2rem; text-align: center; box-shadow: var(--shadow-lg);
  background: radial-gradient(520px 260px at 86% 0%, rgba(185,245,0,.16), transparent 60%), linear-gradient(160deg, #3a0866 0%, #2B004F 72%); }
.ctaband::before { content: ""; position: absolute; top: 0; right: 0; width: 48%; height: 82%; pointer-events: none; z-index: 0;
  background-image: radial-gradient(rgba(185,245,0,.5) 1.7px, transparent 2.3px); background-size: 15px 15px;
  -webkit-mask-image: linear-gradient(225deg, #000 0%, transparent 62%); mask-image: linear-gradient(225deg, #000 0%, transparent 62%); opacity: .15; }
.ctaband > * { position: relative; z-index: 1; }
.ctaband .splatdeco { position: absolute; opacity: .85; }
.ctaband .splatdeco--1 { top: -28px; right: -18px; width: 96px; height: 96px; }
.ctaband .splatdeco--2 { bottom: -30px; left: -16px; width: 84px; height: 84px; }
.ctaband h2 { color: #fff; font-size: clamp(1.55rem, 2.8vw, 2.1rem); margin-bottom: .5rem; }
.ctaband h2 .hl { color: var(--yellow); }
.ctaband p { color: #d9cff0; max-width: 520px; margin: 0 auto 1.4rem; font-size: 1.02rem; }

/* ===== Assurance / trust cards ===== */
.assure { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.acard { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 1.9rem 1.6rem; transition: transform .18s ease, box-shadow .18s ease; }
.acard:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.acard__ico { width: 52px; height: 52px; border-radius: 14px; background: var(--cream2); color: var(--blue); display: grid; place-items: center; margin-bottom: 1.1rem; }
.acard__ico .ico { width: 26px; height: 26px; }
.acard h3 { margin-bottom: .35rem; }
.acard p { color: var(--muted); margin: 0; font-size: .95rem; }

/* ===== Stat / credentials band ===== */
.statband { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); border-radius: var(--radius-lg); padding: 2.4rem 1.6rem; }
.statband__item { text-align: center; padding: .4rem 1rem; position: relative; }
.statband__item + .statband__item::before { content: ""; position: absolute; left: 0; top: 12%; height: 76%; width: 1px; background: rgba(255,255,255,.16); }
.statband__num { font-family: var(--head); font-weight: 800; font-size: clamp(2.1rem, 4vw, 3rem); color: var(--yellow); line-height: 1; letter-spacing: -.02em; }
.statband__txt { display: block; margin-top: .5rem; color: #e7ddf7; font-size: .92rem; font-weight: 500; }

/* ===== Mobile sticky book bar ===== */
.bookbar { display: none; }

/* ===== Splat decorations (reusable, section-level) ===== */
.splatdeco--sm { width: 70px; height: 70px; }
.splatdeco--md { width: 110px; height: 110px; }
.splatdeco--lg { width: 170px; height: 170px; }
.splatdeco--tl { top: -28px; left: -28px; }
.splatdeco--tr { top: -30px; right: 3%; }
.splatdeco--br { bottom: -34px; right: 4%; }
.splatdeco--bl { bottom: -36px; left: 2%; }
.splatdeco--soft { opacity: .14; }
.splatdeco--g .ico { fill: var(--grass); }
.section { position: relative; }
.section--cream, .section--blue { overflow: hidden; }

/* ===== Split media (splat-masked photo) ===== */
.split__media { position: relative; z-index: 1; filter: drop-shadow(0 16px 26px rgba(43,0,79,.26)); }

/* ===== Price block (interactive price list) ===== */
.priceblock__grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 2.6rem; align-items: start; }
.priceblock__intro { position: sticky; top: 92px; background: linear-gradient(165deg, #3a0866 0%, #2B004F 72%); color: #fff; border-radius: var(--radius-lg); padding: 2.5rem 2.2rem; overflow: hidden; box-shadow: var(--shadow); }
.priceblock__intro h2 { color: #fff; margin-bottom: .6rem; }
.priceblock__intro h2 .hl { color: var(--yellow); }
.priceblock__intro p { color: #d9cff0; margin: 0; }
.priceblock__points { list-style: none; padding: 0; margin: 1.3rem 0 1.7rem; display: grid; gap: .65rem; }
.priceblock__points li { display: flex; align-items: center; gap: .6em; font-weight: 500; font-size: .96rem; }
.priceblock__points .ico { color: var(--yellow); width: 1.1em; height: 1.1em; flex: none; }
.priceblock__intro .splatdeco { position: absolute; z-index: 0; }
.priceblock__intro > * { position: relative; z-index: 1; }

.pricelist { display: flex; flex-direction: column; gap: .85rem; }
.pricerow { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; transition: box-shadow .2s ease, border-color .2s ease, transform .18s ease; }
.pricerow:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.pricerow[open] { box-shadow: var(--shadow); border-color: var(--cream2); }
.pricerow > summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: 1rem; padding: 1.15rem 1.3rem; }
.pricerow > summary::-webkit-details-marker { display: none; }
.pricerow__ico { width: 46px; height: 46px; border-radius: 12px; background: var(--cream2); color: var(--blue); display: grid; place-items: center; flex: none; transition: background .2s ease, color .2s ease; }
.pricerow__ico .ico { width: 24px; height: 24px; }
.pricerow[open] .pricerow__ico { background: var(--blue); color: var(--yellow); }
.pricerow__head { flex: 1; min-width: 0; }
.pricerow__name { font-family: var(--head); font-weight: 700; color: var(--ink); font-size: 1.08rem; display: block; line-height: 1.2; }
.pricerow__tag { color: var(--muted); font-size: .85rem; display: block; }
.pricerow__price { font-family: var(--head); font-weight: 800; color: var(--blue); font-size: 1.2rem; white-space: nowrap; line-height: 1; }
.pricerow__price span { display: block; font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); text-align: right; margin-bottom: .2rem; }
.pricerow__toggle { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--line); color: var(--blue); flex: none; position: relative; transition: all .2s ease; }
.pricerow__toggle::before, .pricerow__toggle::after { content: ""; position: absolute; top: 50%; left: 50%; background: currentColor; border-radius: 2px; transform: translate(-50%, -50%); }
.pricerow__toggle::before { width: 12px; height: 2px; }
.pricerow__toggle::after { width: 2px; height: 12px; transition: transform .2s ease; }
.pricerow[open] .pricerow__toggle { background: var(--yellow); border-color: var(--yellow); color: var(--blue); }
.pricerow[open] .pricerow__toggle::after { transform: translate(-50%, -50%) scaleY(0); }
.pricerow__body { padding: 0 1.3rem 1.4rem; }
.pricerow__body p { color: var(--body); margin: 0 0 1rem; }
.pricerow__incl { list-style: none; padding: 0; margin: 0 0 1.3rem; display: grid; gap: .5rem; }
.pricerow__incl li { display: flex; align-items: center; gap: .55em; color: var(--ink); font-size: .93rem; font-weight: 500; }
.pricerow__incl .ico { color: var(--grass); width: 1.1em; height: 1.1em; flex: none; stroke-width: 2.4; }

/* ===== How it works + Why (side by side) ===== */
.howwhy { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.howwhy__col:first-child { padding-right: 3.2rem; }
.howwhy__col:last-child { padding-left: 3.2rem; border-left: 1px solid rgba(255,255,255,.15); }
.howwhy__col h2 { color: #fff; margin-bottom: .6rem; }
.howwhy__col > p { color: #d9cff0; margin: 0; }
.howwhy__photo { max-width: 230px; margin-bottom: 1.5rem; filter: drop-shadow(0 14px 22px rgba(0,0,0,.28)); }
.howwhy__photo img { width: 100%; height: auto; aspect-ratio: 1/1; object-fit: cover; -webkit-mask: var(--splat-mask) center / 100% 100% no-repeat; mask: var(--splat-mask) center / 100% 100% no-repeat; }
.flowv { list-style: none; padding: 0; margin: 1.5rem 0 0; display: grid; gap: 1.2rem; }
.flowv__step { display: flex; gap: 1rem; align-items: flex-start; }
.flowv__num { width: 42px; height: 42px; border-radius: 50%; background: var(--yellow); color: var(--blue); font-family: var(--head); font-weight: 800; font-size: 1.15rem; display: grid; place-items: center; flex: none; box-shadow: 0 8px 16px rgba(185,245,0,.32); }
.flowv__step h3 { color: #fff; margin: 0 0 .15rem; font-size: 1.06rem; }
.flowv__step p { color: #cfc3e8; margin: 0; font-size: .92rem; }
.checklist { list-style: none; padding: 0; margin: 1.5rem 0 0; display: grid; gap: .75rem; }
.checklist li { display: flex; align-items: flex-start; gap: .6em; color: #fff; font-weight: 500; }
.checklist li .ico { color: var(--yellow); margin-top: .2em; flex: none; }

/* ===== Reviews rating summary ===== */
.revsum { display: flex; align-items: center; justify-content: center; gap: 1.4rem; flex-wrap: wrap; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 1.3rem 1.8rem; max-width: 620px; margin: 0 auto 2.6rem; }
.revsum__score { font-family: var(--head); font-weight: 800; font-size: 3rem; color: var(--ink); line-height: 1; }
.revsum__stars { display: inline-flex; gap: 2px; }
.revsum__stars .ico { width: 1.25em; height: 1.25em; fill: var(--yellow); stroke: var(--yellow); }
.revsum__meta { color: var(--muted); font-size: .92rem; }
.revsum__meta b { color: var(--ink); font-family: var(--head); }
.revsum__div { width: 1px; align-self: stretch; background: var(--line); }
.revsum__google { display: inline-flex; align-items: center; gap: .45em; font-family: var(--head); font-weight: 700; color: var(--ink); }
.revsum__google .ico { width: 1.3em; height: 1.3em; }

/* ===== Footer ===== */
.footer { background: var(--blue-dk); color: #b9baf0; }
.footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2rem; padding: 3.5rem 24px; }
.footer__brand p { max-width: 24rem; margin-top: 1rem; }
.footer__col h4 { color: #fff; font-size: .95rem; margin-bottom: 1rem; text-transform: uppercase; letter-spacing: .06em; }
.footer__col a, .footer__col span { display: block; color: #b9baf0; margin-bottom: .5rem; font-size: .9rem; }
.footer__col a:hover { color: var(--yellow); }
.footer__contact { display: flex; align-items: center; gap: .5em; }
.footer__contact .ico { color: var(--yellow); width: 1em; height: 1em; }
.footer__base { border-top: 1px solid rgba(255,255,255,.12); font-size: .85rem; padding: 1.2rem 0; color: #8485d6; text-align: center; }

/* ===== Booking widget (themed) ===== */
.booking { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; max-width: 960px; margin: 0 auto; }
.booking__noscript { padding: 2rem; text-align: center; }
.bk-steps { display: flex; background: var(--cream); border-bottom: 1px solid var(--line); }
.bk-step { flex: 1; display: flex; align-items: center; justify-content: center; gap: .45em; padding: 1rem .5rem; font-family: var(--head); font-weight: 700; font-size: .82rem; color: var(--muted); }
.bk-step__dot { display: inline-grid; place-items: center; width: 28px; height: 28px; border-radius: 50%; background: #c7c8ea; color: #fff; font-size: .85rem; transition: background .2s ease, transform .2s ease; }
.bk-step__dot .ico { width: 14px; height: 14px; stroke-width: 3; }
.bk-step.is-active { color: var(--blue); }
.bk-step.is-active .bk-step__dot { background: var(--yellow); color: var(--blue); transform: scale(1.1); }
.bk-step.is-done { color: var(--blue); }
.bk-step.is-done .bk-step__dot { background: var(--blue); }
.bk-body { padding: 2.2rem; }
.bk-pane h3 { font-size: 1.5rem; margin-bottom: .3rem; }
.bk-pane__sub { color: var(--muted); margin-bottom: 1.5rem; }
.bk-services { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.bk-choice { text-align: left; background: #fff; border: 2px solid var(--line); border-radius: var(--radius); padding: 1.15rem 1.25rem; cursor: pointer; transition: border-color .15s, box-shadow .15s, transform .15s; display: flex; gap: .95rem; align-items: flex-start; }
.bk-choice:hover { border-color: var(--yellow); box-shadow: var(--shadow); transform: translateY(-2px); }
.bk-choice.is-selected { border-color: var(--yellow); box-shadow: var(--ring); }
.bk-choice .ibadge { width: 48px; height: 48px; border-radius: 12px; }
.bk-choice .ibadge .ico { width: 24px; height: 24px; }
.bk-choice__name { font-family: var(--head); font-weight: 800; color: var(--ink); display: block; }
.bk-choice__tag { color: var(--muted); font-size: .88rem; }
.bk-choice__price { margin-top: .3rem; font-family: var(--head); font-weight: 800; color: var(--blue); }
.bk-choice__pop { display: inline-flex; align-items: center; gap: .25em; background: var(--yellow); color: var(--blue); font-size: .64rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; padding: .14rem .5rem; border-radius: 999px; margin-left: .4rem; vertical-align: middle; }
.bk-choice__pop .ico { fill: var(--blue); stroke: var(--blue); }
.bk-field { margin-bottom: 1.35rem; }
.bk-field > label { display: block; font-family: var(--head); font-weight: 700; color: var(--ink); margin-bottom: .55rem; }
.bk-hint { color: var(--muted); font-weight: 400; font-size: .88rem; }
.bk-options { display: flex; flex-wrap: wrap; gap: .55rem; }
.bk-pill { border: 2px solid var(--line); background: #fff; border-radius: 999px; padding: .58rem 1.05rem; font-weight: 700; font-family: var(--head); color: var(--body); cursor: pointer; transition: all .15s; }
.bk-pill:hover { border-color: var(--yellow); transform: translateY(-1px); }
.bk-pill.is-selected { background: var(--blue); border-color: var(--blue); color: #fff; }
.bk-checks { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: .6rem; }
.bk-check { display: flex; gap: .6rem; align-items: flex-start; border: 2px solid var(--line); border-radius: 12px; padding: .8rem 1rem; cursor: pointer; transition: border-color .15s, background .15s; }
.bk-check.is-selected { border-color: var(--yellow); background: var(--yellow-soft); }
.bk-check input { margin-top: .25rem; accent-color: var(--blue); }
.bk-input, .bk-textarea { width: 100%; border: 2px solid var(--line); border-radius: 12px; padding: .85rem 1rem; font: inherit; color: var(--ink); transition: border-color .15s, box-shadow .15s; background: #fff; }
.bk-input:focus, .bk-textarea:focus { outline: none; border-color: var(--yellow); box-shadow: var(--ring); }
.bk-input.is-error, .bk-textarea.is-error { border-color: var(--red); }
.bk-err { color: var(--red); font-size: .85rem; margin-top: .3rem; }
.bk-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.bk-quote { position: sticky; bottom: 0; display: flex; align-items: center; justify-content: space-between; gap: 1rem; background: var(--blue); color: #fff; padding: 1.05rem 1.4rem; border-radius: 14px; margin-top: 1.7rem; box-shadow: 0 14px 30px rgba(43,0,79,.3); }
.bk-quote__label { font-size: .82rem; color: #c5c5f5; display: flex; align-items: center; gap: .4em; }
.bk-quote__label .ico { width: 1em; height: 1em; color: var(--yellow); }
.bk-quote__amount { font-family: var(--head); font-weight: 800; font-size: 2rem; line-height: 1; color: var(--yellow); }
.bk-quote__lines { font-size: .78rem; color: #b6b6ef; margin-top: .25rem; }
.bk-cal { display: grid; grid-template-columns: 240px 1fr; gap: 1.5rem; }
.bk-dates { max-height: 380px; overflow-y: auto; border: 1px solid var(--line); border-radius: 16px; padding: .5rem; }
.bk-date { display: flex; justify-content: space-between; align-items: center; width: 100%; text-align: left; background: #fff; border: none; border-radius: 11px; padding: .72rem .85rem; cursor: pointer; font: inherit; color: var(--ink); transition: background .15s; }
.bk-date:hover { background: var(--cream); }
.bk-date.is-selected { background: var(--blue); color: #fff; }
.bk-date.is-selected .bk-date__open { color: #cfcfff; }
.bk-date__day { font-family: var(--head); font-weight: 700; }
.bk-date__open { font-size: .76rem; color: var(--blue); font-weight: 700; }
.bk-date.is-full { opacity: .42; cursor: not-allowed; }
.bk-date.is-full .bk-date__open { color: var(--muted); }
.bk-slots { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; align-content: start; }
.bk-slot { border: 2px solid var(--line); background: #fff; border-radius: 12px; padding: .95rem; font-family: var(--head); font-weight: 700; color: var(--ink); cursor: pointer; transition: all .15s; }
.bk-slot:hover:not(:disabled) { border-color: var(--yellow); transform: translateY(-2px); }
.bk-slot.is-selected { background: var(--yellow); border-color: var(--yellow); color: var(--blue); }
.bk-slot:disabled { opacity: .35; cursor: not-allowed; text-decoration: line-through; }
.bk-slots__empty { color: var(--muted); grid-column: 1/-1; padding: 1.5rem; text-align: center; }
.bk-foot { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-top: 1.9rem; }
.bk-back { background: none; border: none; color: var(--muted); font-family: var(--head); font-weight: 700; cursor: pointer; padding: .8rem; }
.bk-back:hover { color: var(--ink); }
.bk-foot .btn--accent { background: var(--yellow); color: var(--blue); }
.bk-foot .btn--accent:hover { background: var(--yellow-d); }
.bk-review { display: grid; gap: .6rem; background: var(--cream); border-radius: 16px; padding: 1.3rem 1.5rem; margin-bottom: 1.2rem; }
.bk-review__row { display: flex; justify-content: space-between; gap: 1rem; }
.bk-review__row span:first-child { color: var(--muted); }
.bk-review__row span:last-child { font-weight: 700; color: var(--ink); text-align: right; }
.bk-review__total { border-top: 1px dashed #c7c8ea; padding-top: .75rem; margin-top: .4rem; }
.bk-review__total span:last-child { color: var(--blue); font-family: var(--head); font-weight: 800; font-size: 1.4rem; }
.bk-success { text-align: center; padding: 1.2rem; }
.bk-success__tick { width: 88px; height: 88px; border-radius: 50%; background: var(--yellow); color: var(--blue); display: grid; place-items: center; margin: 0 auto 1.1rem; box-shadow: 0 16px 34px rgba(185,245,0,.45); animation: pop .5s cubic-bezier(.16,1.3,.5,1); }
.bk-success__tick .ico { width: 44px; height: 44px; stroke-width: 3; }
@keyframes pop { 0% { transform: scale(0); } 100% { transform: scale(1); } }
.bk-success__ref { display: inline-block; background: var(--cream2); color: var(--blue); font-family: var(--head); font-weight: 800; letter-spacing: .05em; padding: .55rem 1.1rem; border-radius: 11px; margin: .6rem 0 1.3rem; }
.bk-loading, .bk-error-msg { padding: 3rem; text-align: center; color: var(--muted); }
.bk-spinner { width: 40px; height: 40px; border: 4px solid var(--line); border-top-color: var(--yellow); border-radius: 50%; margin: 0 auto 1rem; animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.is-hidden { display: none !important; }

/* ===== Responsive ===== */
@media (max-width: 1024px) {
  .navbar { display: none; }
  .topbadge { display: none; }
}
@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; padding-top: 3rem; }
  .grid--4 { grid-template-columns: 1fr 1fr; }
  .grid--3 { grid-template-columns: 1fr; }
  .split, .split--flip .split__media, .afford { grid-template-columns: 1fr; }
  .split--flip .split__media { order: -1; }
  .bk-cal { grid-template-columns: 1fr; }
  .bk-dates { max-height: 210px; }
  .footer__top { grid-template-columns: 1fr 1fr; }
  .pestpick { grid-template-columns: repeat(4, 1fr); }
  .eco-bar { flex-direction: column; align-items: flex-start; }
  .eco-bar__pills { margin-left: 0; }
  .assure { grid-template-columns: 1fr 1fr; }
  .statband { grid-template-columns: 1fr 1fr; gap: 1.6rem 1rem; }
  .statband__item:nth-child(odd)::before { display: none; }
  .priceblock__grid { grid-template-columns: 1fr; gap: 1.6rem; }
  .priceblock__intro { position: static; }
  .howwhy { grid-template-columns: 1fr; gap: 2.6rem; }
  .howwhy__col:first-child { padding-right: 0; }
  .howwhy__col:last-child { padding-left: 0; border-left: none; }
  .faqblock { grid-template-columns: 1fr; gap: 1.6rem; }
  .faqblock__intro { position: static; }
}
@media (max-width: 560px) {
  .grid--4, .grid--2, .bk-services, .bk-checks, .bk-slots, .bk-row { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr; }
  .pestpick { grid-template-columns: repeat(2, 1fr); }
  .assure { grid-template-columns: 1fr; }
  .revsum { gap: 1rem; padding: 1.1rem 1.2rem; }
  .revsum__div { display: none; }
  .bk-step__label { display: none; }
  .bk-body { padding: 1.4rem; }
  .hero__cta { flex-direction: column; }
  .hero__cta .btn { width: 100%; }
  .ctaband { padding: 2rem 1.4rem; }
  .header__phone span { display: none; }
  /* Sticky instant-book bar on phones */
  .bookbar { display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; gap: .6rem; padding: .6rem .8rem calc(.6rem + env(safe-area-inset-bottom)); background: rgba(43,0,79,.97); backdrop-filter: blur(6px); border-top: 1px solid rgba(255,255,255,.12); }
  .bookbar .btn { flex: 1; padding: .85rem 1rem; }
  .bookbar__call { flex: none; width: 52px; padding: 0; }
  body { padding-bottom: 72px; }
}

/* ===== SEO blocks: internal-link clouds, quick-answer callout, local context ===== */
.linkcloud{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1rem}
.linkcloud a{display:inline-block;padding:.5rem .95rem;border-radius:999px;border:1.5px solid rgba(43,0,79,.16);
  background:#fff;color:#2B004F;text-decoration:none;font-weight:600;font-size:.92rem;transition:border-color .15s,color .15s}
.linkcloud a:hover{border-color:#7C3AED;color:#7C3AED}
.linkcloud a.is-strong{background:#2B004F;color:#fff;border-color:#2B004F}
.linkcloud a.is-strong:hover{background:#7C3AED;border-color:#7C3AED;color:#fff}
.linksub-h{margin:1.8rem 0 .2rem;font-size:1.05rem;color:#2B004F}
.qa{background:#F4ECFF;border-left:4px solid #7C3AED;border-radius:0 14px 14px 0;padding:1rem 1.25rem;
  margin:0 auto 1.4rem;max-width:760px;text-align:left;font-size:1.02rem;line-height:1.55}
.qa b{color:#2B004F}
.localfacts{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:1.2rem 0 .2rem;padding:0;list-style:none}
.localfacts li{display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid rgba(43,0,79,.12);
  border-radius:999px;padding:.4rem .85rem;font-size:.9rem;font-weight:600;color:#2B004F}
.localfacts .ico{width:1.05em;height:1.05em}

/* Breadcrumbs + clickable pest cards (suburb pages) */
.crumbs{font-size:.85rem;color:rgba(255,255,255,.75);margin-bottom:.9rem}
.crumbs a{color:rgba(255,255,255,.9);text-decoration:none}
.crumbs a:hover{color:#B9F500}
.crumbs span{color:#B9F500}
.acard--link{text-decoration:none;color:inherit;display:block;transition:transform .15s,box-shadow .15s}
.acard--link:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(43,0,79,.12)}
.acard--link h3{color:#2B004F}

/* Long-form guide articles */
.prose{max-width:760px;margin:0 auto;text-align:left}
.prose h2{margin-top:2.2rem}
.prose h3{margin-top:1.5rem}
.prose p,.prose li{font-size:1.04rem;line-height:1.72;color:#33263f}
.prose ul,.prose ol{padding-left:1.2rem}
.prose li{margin:.35rem 0}
.prose a{color:#7C3AED;font-weight:600}
.ptable{width:100%;border-collapse:collapse;margin:1.3rem 0;font-size:.98rem}
.ptable th,.ptable td{text-align:left;padding:.65rem .8rem;border-bottom:1px solid rgba(43,0,79,.12);vertical-align:top}
.ptable th{background:#F4ECFF;color:#2B004F}
.guidegrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin-top:1.4rem}
.guidecard{display:block;text-decoration:none;color:inherit;background:#fff;border:1px solid rgba(43,0,79,.1);
  border-radius:16px;padding:1.4rem;transition:transform .15s,box-shadow .15s}
.guidecard:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(43,0,79,.12)}
.guidecard h3{color:#2B004F;margin:.2rem 0 .4rem}
.guidecard span{color:#7C3AED;font-weight:700;font-size:.9rem}

/* Areas directory (region-grouped suburb lists — replaces pill clouds) */
.arealist{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.8rem 2rem;margin-top:1.4rem;text-align:left}
.arealist__group h3{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:#7C3AED;margin:0 0 .7rem;padding-bottom:.45rem;border-bottom:1px solid rgba(43,0,79,.14)}
.arealist__group ul{list-style:none;margin:0;padding:0}
.arealist__group li{margin:.32rem 0}
.arealist__group a{color:#2B004F;text-decoration:none;font-weight:500;font-size:.98rem}
.arealist__group a:hover{color:#7C3AED;text-decoration:underline}
.arealist--light .arealist__group h3{color:#B9F500;border-bottom-color:rgba(255,255,255,.18)}
.arealist--light .arealist__group a{color:#efeaf7}
.arealist--light .arealist__group a:hover{color:#fff}
.areas-more{margin-top:2.2rem;text-align:center}

/* ===== Splat-backed feature items (replaces the generic icon-on-card grid) ===== */
.featgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2.6rem 1.9rem; }
.feat { position: relative; }
.feat__art { position: relative; width: 92px; height: 92px; margin-bottom: 1.15rem; display: grid; place-items: center; }
.feat__art::before { content: ""; position: absolute; inset: 0; background: var(--yellow);
  -webkit-mask: var(--splat-mask) center / contain no-repeat; mask: var(--splat-mask) center / contain no-repeat;
  filter: drop-shadow(0 10px 16px rgba(43,0,79,.18)); }
.feat__ico { position: relative; z-index: 1; width: 42px; height: 42px; fill: none; stroke: var(--blue-dk); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.feat h3 { margin-bottom: .35rem; font-size: 1.14rem; }
.feat p { color: var(--muted); margin: 0; font-size: .96rem; line-height: 1.55; }
/* alternate colours (clean) + organic angles (varied) so it reads hand-made, not templated */
.feat:nth-child(odd) .feat__art::before { background: var(--yellow); }
.feat:nth-child(even) .feat__art::before { background: var(--blue); }
.feat:nth-child(even) .feat__ico { stroke: var(--yellow); }
.feat:nth-child(4n+1) .feat__art::before { transform: rotate(-8deg); }
.feat:nth-child(4n+2) .feat__art::before { transform: rotate(7deg); }
.feat:nth-child(4n+3) .feat__art::before { transform: rotate(-4deg); }
.feat:nth-child(4n+4) .feat__art::before { transform: rotate(11deg); }
/* playful vertical stagger on wide screens */
@media (min-width: 920px) { .feat:nth-child(2n) { margin-top: 2.2rem; } }
/* clickable variant (suburb "common pests") */
a.feat--link { display: block; text-decoration: none; color: inherit; }
a.feat--link h3 { color: var(--blue-dk); transition: color .15s ease; }
a.feat--link:hover h3 { color: var(--blue); }
a.feat--link .feat__art { transition: transform .25s ease; }
a.feat--link:hover .feat__art { transform: scale(1.07) rotate(-3deg); }
.feat__more { display: inline-flex; align-items: center; gap: .35em; margin-top: .55rem; color: var(--blue); font-family: var(--head); font-weight: 700; font-size: .9rem; }
.feat__more .ico { width: 1em; height: 1em; transition: transform .2s ease; }
a.feat--link:hover .feat__more .ico { transform: translateX(4px); }
@media (max-width: 880px) { .featgrid { grid-template-columns: 1fr 1fr; gap: 2.2rem 1.6rem; } }
@media (max-width: 540px) {
  .featgrid { grid-template-columns: 1fr; gap: 1.6rem; }
  .feat { display: grid; grid-template-columns: 64px 1fr; column-gap: 1.1rem; align-items: start; }
  .feat:nth-child(2n) { margin-top: 0; }
  .feat__art { width: 64px; height: 64px; margin-bottom: 0; }
  .feat__ico { width: 30px; height: 30px; }
}

/* ===== Steps ("how we treat") — splat-backed numbers, no card boxes ===== */
.steps .step { background: none; border: none; padding: 0; }
.steps .step:hover { transform: none; box-shadow: none; }
.step__num { position: relative; z-index: 0; width: 74px; height: 74px; border-radius: 0; background: none;
  display: grid; place-items: center; font-family: var(--head); font-weight: 800; font-size: 1.9rem;
  color: var(--blue-dk); margin-bottom: 1rem; }
.step__num::before { content: ""; position: absolute; inset: 0; z-index: -1; background: var(--yellow);
  -webkit-mask: var(--splat-mask) center / contain no-repeat; mask: var(--splat-mask) center / contain no-repeat;
  filter: drop-shadow(0 8px 14px rgba(43,0,79,.16)); }
.steps .step:nth-child(even) .step__num::before { background: var(--blue); }
.steps .step:nth-child(even) .step__num { color: var(--yellow); }
.steps .step:nth-child(4n+1) .step__num::before { transform: rotate(-7deg); }
.steps .step:nth-child(4n+2) .step__num::before { transform: rotate(8deg); }
.steps .step:nth-child(4n+3) .step__num::before { transform: rotate(-5deg); }
.steps .step:nth-child(4n+4) .step__num::before { transform: rotate(10deg); }
@media (min-width: 920px) { .steps .step:nth-child(even) { margin-top: 1.8rem; } }

/* ===== Homepage price-list icons — splat motif instead of faded-purple square ===== */
.pricerow__ico { position: relative; z-index: 0; width: 54px; height: 54px; border-radius: 0; background: none; color: var(--blue-dk); }
.pricerow__ico::before { content: ""; position: absolute; inset: 0; z-index: -1; background: var(--yellow);
  -webkit-mask: var(--splat-mask) center / contain no-repeat; mask: var(--splat-mask) center / contain no-repeat;
  transform: rotate(-6deg); transition: transform .25s ease, background .2s ease; filter: drop-shadow(0 6px 12px rgba(43,0,79,.16)); }
.pricerow__ico .ico { position: relative; width: 27px; height: 27px; stroke-width: 2.5; }
.pricerow[open] .pricerow__ico { background: none; color: var(--yellow); }
.pricerow[open] .pricerow__ico::before { background: var(--blue); transform: rotate(7deg); }
.pricerow:hover .pricerow__ico::before { transform: rotate(2deg) scale(1.05); }

/* ===== White header + inverted (dark) logo ===== */
.header { background: rgba(255,255,255,.96); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.header__inner { padding: 1rem 24px; }              /* roomier so the logo isn't touching the edges */
.logo__word { color: var(--blue-dk); }
.logo__sub { color: var(--blue); }
.hbadge__txt b { color: var(--blue-dk); }
.hbadge__txt span { color: #6b5b7e; }
.hbadge > .ico { color: var(--blue); }
.header__cta .btn--ghost { color: var(--blue); border-color: rgba(43,0,79,.22); }
.header__cta .btn--ghost:hover { border-color: var(--blue); background: var(--cream2); }

/* ===== Mobile nav: hamburger -> right slide-in drawer ===== */
.navtoggle { display: none; flex-direction: column; justify-content: center; gap: 5px;
  width: 46px; height: 46px; padding: 9px; border: none; background: none; cursor: pointer; flex: none; }
.navtoggle span { display: block; width: 26px; height: 3px; background: var(--blue-dk); border-radius: 3px; transition: transform .25s ease, opacity .2s ease; }
.navtoggle.on span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.navtoggle.on span:nth-child(2) { opacity: 0; }
.navtoggle.on span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

.m-overlay { display: none; position: fixed; inset: 0; z-index: 90; background: rgba(20,0,40,.5);
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); opacity: 0; pointer-events: none; transition: opacity .3s ease; }
.m-overlay.show { opacity: 1; pointer-events: auto; }

.m-drawer { display: none; position: fixed; top: 0; right: -110%; z-index: 95; width: 320px; max-width: 86vw; height: 100vh; height: 100dvh;
  flex-direction: column; background: linear-gradient(175deg, #3a0a63 0%, var(--blue-dk) 62%);
  box-shadow: -12px 0 50px rgba(0,0,0,.32); transition: right .32s cubic-bezier(.4,0,.2,1); }
.m-drawer.open { right: 0; }
.m-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 1.05rem 1.4rem; border-bottom: 1px solid rgba(255,255,255,.14); }
.m-drawer__brand { font-family: "Baloo 2","Montserrat",sans-serif; font-weight: 800; font-size: 1.5rem; color: #fff; line-height: 1; }
.m-drawer__brand .o { color: var(--yellow); }
.m-drawer__brand small { display: block; font-size: .5rem; letter-spacing: .34em; color: var(--yellow); text-transform: uppercase; font-weight: 700; margin-top: .25em; }
.m-drawer__close { width: 42px; height: 42px; flex: none; border: none; background: rgba(255,255,255,.12); color: #fff; font-size: 1.7rem; line-height: 1; border-radius: 11px; cursor: pointer; }
.m-drawer__close:hover { background: rgba(255,255,255,.22); }
.m-drawer__links { display: flex; flex-direction: column; overflow-y: auto; flex: 1; padding: .4rem 0; }
.m-drawer__links a { display: flex; align-items: center; gap: .7em; padding: 1rem 1.5rem; font-family: var(--head); font-weight: 600; font-size: 1.1rem; color: rgba(255,255,255,.92); border-bottom: 1px solid rgba(255,255,255,.07); }
.m-drawer__links a:active, .m-drawer__links a:hover { background: rgba(255,255,255,.07); color: var(--yellow); }
.m-drawer__cta { padding: 1.1rem 1.4rem calc(1.4rem + env(safe-area-inset-bottom)); border-top: 1px solid rgba(255,255,255,.12); display: flex; flex-direction: column; gap: .7rem; }
.m-drawer__cta .mn-primary { background: var(--yellow); color: #2B004F; text-align: center; padding: 1rem; border-radius: 12px; font-family: var(--head); font-weight: 800; font-size: 1.05rem; }
.m-drawer__cta .mn-phone { display: flex; align-items: center; justify-content: center; gap: .45em; color: var(--yellow); font-family: var(--head); font-weight: 700; font-size: 1.05rem; }
.m-drawer__cta .mn-phone .ico { width: 1.05em; height: 1.05em; }

@media (max-width: 1024px) {
  .navtoggle { display: flex; margin-left: auto; }
  .m-drawer { display: flex; }
  .m-overlay { display: block; }
  .navbar { display: none; }
  .header__badges { display: none; }
  .header__cta { display: none; }
}
@media (max-width: 600px) {
  .header__inner { gap: .7rem; padding: .85rem 18px; }
  .logo__word { font-size: 1.95rem; }
  .section { padding: 3rem 0; }
  .wrap { padding: 0 18px; }
  .ptable { font-size: .82rem; }
  .ptable th, .ptable td { padding: .5rem .45rem; }
  .drawer { width: 100%; }
}

/* ===== Booking form — new elements for the full pricing engine ===== */
.bk-cat { font-family: var(--head); font-weight: 800; text-transform: uppercase; letter-spacing: .08em; font-size: .74rem; color: #7C3AED; margin: 1.4rem 0 .6rem; }
.bk-cat:first-child { margin-top: 0; }
.bk-options--col { flex-direction: column; align-items: stretch; }
.bk-options--col .bk-pill { text-align: left; justify-content: space-between; display: flex; }
.bk-pill strong { color: #2B004F; font-weight: 800; margin-left: .6rem; }
.bk-pill.is-selected strong { color: #2B004F; }
.bk-num { display: flex; align-items: center; gap: .8rem; }
.bk-num__btn { width: 44px; height: 44px; border-radius: 12px; border: 1.5px solid #e2d6f0; background: #fff; font-size: 1.4rem; font-weight: 700; color: #2B004F; cursor: pointer; line-height: 1; }
.bk-num__btn:hover { border-color: #7C3AED; }
.bk-num__v { font-family: var(--head); font-weight: 800; font-size: 1.5rem; min-width: 2ch; text-align: center; color: #2B004F; }
.bk-num__hint { color: #6b5b7e; font-size: .9rem; }
.bk-note { display: flex; align-items: flex-start; gap: .6em; background: #f4ecff; border: 1px solid #e2d2f7; border-radius: 12px; padding: .85rem 1rem; margin: 1rem 0; font-size: .94rem; color: #3a2b4d; }
.bk-note .ico { color: #7C3AED; flex: none; margin-top: .1em; }
.bk-note a { color: #7C3AED; font-weight: 700; }
.bk-note--ok { background: #eafbe9; border-color: #c7e8c2; }
.bk-note--ok .ico { color: #1f8a4c; }
.bk-note--warn { background: #fff4e2; border-color: #f3dcb4; }
.bk-note--warn .ico { color: #c98a00; }
.bk-slot__sur { display: inline-block; margin-left: .4em; font-size: .72rem; font-weight: 700; color: #c98a00; }
.bk-quote--q { background: #f4ecff; }
.bk-quote--q .bk-quote__label { color: #7C3AED; }
