/* Lift Kings site components — built on tokens.css */
@import url("./tokens.css");

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg-page);
  color: var(--fg-1);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--lk-royal-navy); text-decoration: none; transition: color 140ms var(--ease-out); }
a:hover { color: var(--accent); }

/* Layout */
.container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-pad-desktop); }
.section { padding: var(--section-pad-desktop) 0; }
.section--alt { background: var(--bg-alt); }
.section--dark { background: var(--bg-dark); color: var(--fg-on-dark); }
.section--premium { background: var(--bg-premium); }
.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4 { color: #fff; }
@media (max-width: 768px) {
  .container { padding: 0 var(--container-pad-mobile); }
  .section { padding: var(--section-pad-mobile) 0; }
}

/* Typography */
h1, h2, h3, h4 { font-family: var(--font-heading); color: var(--lk-royal-navy); margin: 0; }
h1 { font-size: var(--fs-h1); line-height: var(--lh-h1); font-weight: 800; letter-spacing: -0.01em; }
h2 { font-size: var(--fs-h2); line-height: var(--lh-h2); font-weight: 700; }
h3 { font-size: var(--fs-h3); line-height: var(--lh-h3); font-weight: 700; }
h4 { font-size: var(--fs-h4); line-height: var(--lh-h4); font-weight: 600; }
p { margin: 0 0 var(--space-4); }
.lead { font-size: var(--fs-body-lg); line-height: 1.6; color: var(--fg-1); }
.eyebrow { font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-eyebrow); letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-2); margin: 0 0 var(--space-3); }
.eyebrow--gold { color: var(--gold); }
.muted { color: var(--fg-2); }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: 10px; padding: 16px 28px; border-radius: var(--radius-md); border: 0; cursor: pointer;
  font-family: var(--font-heading); font-weight: 700; font-size: var(--fs-button); text-transform: uppercase; letter-spacing: 0.04em; text-decoration: none;
  transition: all var(--t-fast) var(--ease-out); justify-content: center; line-height: 1; }
.btn--lg { padding: 20px 32px; font-size: 18px; }
.btn--sm { padding: 12px 18px; font-size: 14px; }
.btn--primary { background: var(--accent); color: #fff; box-shadow: var(--shadow-cta); }
.btn--primary:hover { background: var(--accent-hover); transform: translateY(-2px); box-shadow: var(--shadow-cta-hover); color: #fff; }
.btn--primary:active { background: var(--accent-active); transform: translateY(0); box-shadow: var(--shadow-cta-active); }
.btn--secondary { background: transparent; color: var(--lk-royal-navy); border: 2px solid var(--lk-royal-navy); padding: 14px 26px; }
.btn--secondary:hover { background: var(--lk-royal-navy); color: #fff; }
.btn--ghost-light { background: transparent; color: #fff; border: 2px solid #fff; padding: 14px 26px; }
.btn--ghost-light:hover { background: #fff; color: var(--lk-royal-navy); }
.btn--emergency { background: var(--danger); color: #fff; }
.btn--emergency:hover { background: #b41f33; color: #fff; }
.btn--block { width: 100%; }

/* Top bar */
.topbar { background: var(--lk-royal-navy); color: #fff; font-size: 13px; }
.topbar__inner { display: flex; align-items: center; gap: 18px; padding: 8px 0; flex-wrap: wrap; }
.topbar a { color: #fff; }
.topbar a:hover { color: var(--gold); }
.topbar__avail { display: inline-flex; align-items: center; gap: 6px; }
.topbar__dot { width: 8px; height: 8px; border-radius: 999px; background: var(--success); box-shadow: 0 0 0 3px rgba(46,139,87,0.25); }
.topbar__sep { opacity: 0.4; }
.topbar__phone { font-weight: 700; }
.topbar__lang { margin-left: auto; display: inline-flex; gap: 6px; align-items: center; }
.topbar__lang button { background: transparent; border: 0; color: #fff; font-family: var(--font-heading); font-weight: 700; font-size: 12px; cursor: pointer; padding: 2px 6px; border-radius: 4px; letter-spacing: 0.04em; }
.topbar__lang button.is-active { background: rgba(255,255,255,0.18); }
.topbar__lang button:hover { color: var(--gold); }
.topbar__trust { width: 100%; padding: 6px 0; border-top: 1px solid rgba(255,255,255,0.1); font-size: 12px; color: rgba(255,255,255,0.85); display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.topbar__trust .sep { opacity: 0.4; }
@media (max-width: 768px) {
  .topbar__inner { padding: 6px 0; gap: 10px; }
  .topbar__emergency, .topbar__trust { display: none; }
}

/* Header */
.header { position: sticky; top: 0; z-index: 50; background: #fff; border-bottom: 1px solid var(--border); transition: all var(--t-med) var(--ease-out); }
.header.is-scrolled { background: rgba(255,255,255,0.96); backdrop-filter: saturate(180%) blur(8px); -webkit-backdrop-filter: saturate(180%) blur(8px); }
.header__inner { display: flex; align-items: center; gap: 28px; height: 80px; transition: height var(--t-med) var(--ease-out); }
.header.is-scrolled .header__inner { height: 64px; }
.header__logo img { height: 40px; transition: height var(--t-med) var(--ease-out); }
.header.is-scrolled .header__logo img { height: 32px; }
.header__nav { display: flex; gap: 22px; align-items: center; }
.header__nav a { font-family: var(--font-heading); font-weight: 600; font-size: 15px; color: var(--fg-1); position: relative; padding: 8px 0; display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.header__nav ul { flex-wrap: nowrap; }
.header__nav ul li { white-space: nowrap; }
.header__nav a::after { content: ""; position: absolute; left: 0; right: 0; bottom: 4px; height: 2px; background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform var(--t-med) var(--ease-out); }
.header__nav a:hover { color: var(--accent); }
.header__nav a:hover::after, .header__nav a.is-active::after { transform: scaleX(1); }
.header__nav .has-mega { cursor: pointer; }
.header__nav .caret { font-size: 10px; opacity: 0.5; transition: transform var(--t-fast); }
.header__nav .has-mega:hover .caret { transform: rotate(180deg); }
.header__right { margin-left: auto; display: flex; align-items: center; gap: 16px; }
.header__phone { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-heading); font-weight: 700; font-size: 16px; color: var(--lk-royal-navy); }
.header__phone:hover { color: var(--accent); }
.header__mobile-toggle { display: none; background: transparent; border: 0; padding: 8px; cursor: pointer; color: var(--lk-royal-navy); }

/* Mega menu */
.mega { position: absolute; left: 0; right: 0; top: 100%; background: #fff; border-bottom: 1px solid var(--border); box-shadow: var(--shadow-card-hover); padding: 32px 0 24px; opacity: 0; visibility: hidden; transform: translateY(-8px); transition: all var(--t-med) var(--ease-out); z-index: 40; }
.has-mega { position: static; }
.has-mega:hover > .mega, .mega:hover, .has-mega.is-open > .mega { opacity: 1; visibility: visible; transform: translateY(0); }
.mega__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.mega__col h5 { font-family: var(--font-heading); font-weight: 700; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-2); margin: 0 0 12px; }
.mega__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.mega__col a { font-size: 15px; color: var(--fg-1); display: inline-flex; align-items: center; gap: 8px; padding: 4px 0; white-space: nowrap; }
.mega__col a i { font-size: 18px; color: var(--lk-royal-navy); width: 20px; }
.mega__col a:hover { color: var(--accent); }
.mega__col a:hover i { color: var(--accent); }
.mega__footer { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border); }
.mega__footer a { font-family: var(--font-heading); font-weight: 700; font-size: 14px; color: var(--accent); text-transform: uppercase; letter-spacing: 0.04em; }

/* Mobile nav drawer */
.mobile-nav { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 90; display: none; }
.mobile-nav.is-open { display: block; }
.mobile-nav__panel { position: absolute; top: 0; right: 0; bottom: 0; width: 320px; max-width: 90vw; background: #fff; padding: 24px; overflow-y: auto; }
.mobile-nav__close { background: transparent; border: 0; font-size: 24px; float: right; cursor: pointer; }
.mobile-nav a { display: block; padding: 12px 0; border-bottom: 1px solid var(--border); font-family: var(--font-heading); font-weight: 600; font-size: 17px; color: var(--lk-royal-navy); }

@media (max-width: 1024px) {
  .header__nav { display: none; }
  .header__phone span:not(.short) { display: none; }
  .header__mobile-toggle { display: inline-flex; }
}
@media (max-width: 640px) {
  .header__inner { gap: 12px; }
  .header__right .btn:not(.btn--icon) { display: none; }
}

/* Hero */
.hero { position: relative; min-height: 640px; background: var(--lk-royal-navy); color: #fff; isolation: isolate; overflow: hidden; }
.hero__media { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center 45%; }
.hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(105deg, rgba(32,67,89,0.88) 0%, rgba(32,67,89,0.72) 40%, rgba(32,67,89,0.20) 80%, rgba(32,67,89,0.05) 100%); }
.hero__inner { position: relative; z-index: 2; padding: 96px 0; }
.hero__eyebrow { font-family: var(--font-heading); font-weight: 700; font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin-bottom: 18px; }
.hero h1 { color: #fff; font-family: var(--font-display); font-weight: 900; font-size: var(--fs-hero); line-height: var(--lh-hero); letter-spacing: -0.02em; max-width: 900px; margin: 0; }
.hero__sub { font-size: 20px; line-height: 1.6; color: rgba(255,255,255,0.92); margin-top: 20px; max-width: 640px; }
.hero__cta { display: flex; gap: 14px; margin-top: 28px; flex-wrap: wrap; }
.hero__trust { margin-top: 28px; display: flex; gap: 18px; flex-wrap: wrap; align-items: center; font-size: 14px; color: rgba(255,255,255,0.9); }
.hero__trust .stars { color: var(--gold); letter-spacing: 2px; }
.hero__trust .dot { opacity: 0.4; }
.hero--compact { min-height: 480px; }
.hero--compact .hero__inner { padding: 72px 0; }
@media (max-width: 768px) {
  .hero { min-height: 560px; }
  .hero__inner { padding: 56px 0; }
  .hero__sub { font-size: 17px; }
}

/* Breadcrumb */
.crumbs { display: flex; gap: 8px; flex-wrap: wrap; font-size: 13px; color: rgba(255,255,255,0.8); margin-bottom: 14px; }
.crumbs a { color: rgba(255,255,255,0.8); }
.crumbs a:hover { color: var(--gold); }
.crumbs__sep { opacity: 0.5; }
.crumbs--light a { color: var(--fg-2); }
.crumbs--light { color: var(--fg-2); margin-bottom: 24px; }

/* Cards */
.card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 28px; box-shadow: var(--shadow-card); transition: all var(--t-med) var(--ease-out); display: flex; flex-direction: column; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.card--clickable { cursor: pointer; }
.card__icon { font-size: 32px; color: var(--lk-royal-navy); margin-bottom: 12px; }
.card__icon--orange { color: var(--accent); }
.card__icon--gold { color: var(--gold); }
.card h3 { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.card p { font-size: 16px; line-height: 1.55; margin-bottom: 16px; }
.card__link { font-family: var(--font-heading); font-weight: 700; font-size: 14px; color: var(--accent); text-transform: uppercase; letter-spacing: 0.04em; margin-top: auto; display: inline-flex; align-items: center; gap: 6px; }
.card__link:hover { gap: 10px; }
.card__media { aspect-ratio: 4/3; margin: -28px -28px 20px; border-radius: var(--radius-xl) var(--radius-xl) 0 0; overflow: hidden; background: var(--bg-alt); }
.card__media img { width: 100%; height: 100%; object-fit: cover; object-position: center 28%; }

/* Site-wide image crop rule — our photos are mostly garage door installers
   working overhead, so the focal point is the upper-third of the frame.
   Default object-position (center center) crops out heads and the work itself. */
img[style*="object-fit"] { object-position: center 28%; }
img[style*="object-fit"][style*="aspect-ratio:1/1"] { object-position: center 22%; }
img[style*="object-fit"][style*="aspect-ratio:4/5"] { object-position: center 18%; }

/* Grid helpers */
.grid { display: grid; gap: var(--space-8); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--6 { grid-template-columns: repeat(6, 1fr); }
@media (max-width: 1024px) {
  .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .grid--6 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .grid--2, .grid--3, .grid--4, .grid--6 { grid-template-columns: 1fr; }
  .grid--6 { grid-template-columns: repeat(2, 1fr); }
  .grid { gap: var(--space-5); }
}

/* Service tile (smaller card for grid quick-picks) */
.svc-tile { position: relative; display: flex; flex-direction: column; align-items: flex-start; height: 100%; min-width: 0; padding: 22px 22px 24px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); transition: transform var(--t-med) var(--ease-out), box-shadow var(--t-med) var(--ease-out), border-color var(--t-med) var(--ease-out); text-decoration: none; color: var(--fg-1); overflow: hidden; }
.svc-tile::after { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 3px; background: var(--lk-royal-navy); transform: scaleX(0); transform-origin: left; transition: transform var(--t-med) var(--ease-out); }
.svc-tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); border-color: var(--lk-royal-navy); color: var(--fg-1); }
.svc-tile:hover::after { transform: scaleX(1); }
.svc-tile i { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 12px; background: var(--lk-cream); font-size: 22px; color: var(--lk-royal-navy); margin-bottom: 16px; transition: background var(--t-med) var(--ease-out), color var(--t-med) var(--ease-out); }
.svc-tile:hover i { background: var(--lk-royal-navy); color: #fff; }
.svc-tile h3, .svc-tile h4 { font-family: var(--font-heading); font-size: 17px; font-weight: 700; line-height: 1.25; margin: 0 0 6px; color: var(--lk-royal-navy); text-wrap: balance; }
.svc-tile p { font-size: 13.5px; color: var(--fg-2); margin: 0 0 auto; line-height: 1.45; }
.svc-tile__arrow { display: inline-flex; align-items: center; gap: 4px; margin-top: 14px; font-size: 12px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--lk-royal-navy); opacity: 0; transform: translateY(4px); transition: opacity var(--t-med) var(--ease-out), transform var(--t-med) var(--ease-out); }
.svc-tile:hover .svc-tile__arrow { opacity: 1; transform: translateY(0); }

/* ============ SERVICE FINDER (homepage hero section) ============ */
.finder { display: flex; flex-direction: column; gap: 28px; }
.finder__group { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 24px; }
.finder__group-head { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; }
.finder__group-head h3 { font-family: var(--font-heading); font-size: 22px; font-weight: 700; margin: 0; color: var(--lk-royal-navy); line-height: 1.2; }
.finder__group-head > div > p { font-size: 14px; color: var(--fg-2); margin: 2px 0 0; line-height: 1.4; }
.finder__badge { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: 14px; font-size: 24px; flex: none; }
.finder__badge--repair { background: rgba(217,141,29,0.12); color: var(--gold); }
.finder__badge--install { background: rgba(32,67,89,0.10); color: var(--lk-royal-navy); }
.finder__badge--urgent { background: rgba(196,30,58,0.10); color: #C41E3A; }
.finder__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.finder__card { display: flex; align-items: stretch; gap: 14px; padding: 18px; background: var(--lk-cream); border: 1px solid transparent; border-radius: var(--radius-lg); text-decoration: none; color: var(--fg-1); transition: transform var(--t-med) var(--ease-out), box-shadow var(--t-med) var(--ease-out), border-color var(--t-med) var(--ease-out), background var(--t-med) var(--ease-out); min-width: 0; }
.finder__card:hover { transform: translateY(-2px); background: #fff; border-color: var(--lk-royal-navy); box-shadow: var(--shadow-card-hover); color: var(--fg-1); }
.finder__card-icon { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 10px; background: #fff; color: var(--lk-royal-navy); font-size: 20px; flex: none; transition: background var(--t-med), color var(--t-med); }
.finder__card:hover .finder__card-icon { background: var(--lk-royal-navy); color: #fff; }
.finder__card-body { flex: 1; min-width: 0; }
.finder__card-body h4 { font-family: var(--font-heading); font-size: 15px; font-weight: 700; margin: 0 0 4px; color: var(--lk-royal-navy); line-height: 1.25; }
.finder__card-body p { font-size: 13px; color: var(--fg-2); margin: 0; line-height: 1.4; }
.finder__card-meta { display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; gap: 8px; flex: none; }
.finder__price { font-family: var(--font-heading); font-size: 13px; font-weight: 700; color: var(--gold); white-space: nowrap; letter-spacing: 0.01em; }
.finder__card-meta i { font-size: 16px; color: var(--lk-royal-navy); opacity: 0.4; transition: opacity var(--t-med), transform var(--t-med); }
.finder__card:hover .finder__card-meta i { opacity: 1; transform: translateX(2px); }

.finder__help { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 22px 26px; background: var(--lk-royal-navy); border-radius: var(--radius-xl); color: #fff; flex-wrap: wrap; }
.finder__help-left { display: flex; align-items: center; gap: 16px; flex: 1; min-width: 280px; }
.finder__help-left strong { font-family: var(--font-heading); font-size: 17px; display: block; color: #fff; line-height: 1.25; }
.finder__help-left p { font-size: 14px; color: rgba(255,255,255,0.78); margin: 4px 0 0; line-height: 1.4; }
.finder__help .finder__badge--urgent { background: rgba(255,255,255,0.12); color: var(--gold); }
.finder__help-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.finder__help-actions .btn--ghost { color: #fff; }

@media (max-width: 1024px) { .finder__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) {
  .finder__group { padding: 18px; }
  .finder__grid { grid-template-columns: 1fr; }
  .finder__card-meta { flex-direction: row; align-items: center; }
  .finder__help { padding: 18px; flex-direction: column; align-items: flex-start; }
  .finder__help-actions { width: 100%; }
  .finder__help-actions .btn { flex: 1; justify-content: center; }
}

/* Trust strip */
.trust-strip { display: flex; gap: 24px; flex-wrap: wrap; align-items: center; font-size: 14px; }
.trust-strip__item { display: inline-flex; align-items: center; gap: 8px; }
.trust-strip__item i { font-size: 18px; color: var(--lk-royal-navy); }
.trust-strip__item.on-dark { color: rgba(255,255,255,0.9); }
.trust-strip__item.on-dark i { color: var(--gold); }
.trust-strip .sep { opacity: 0.4; }

/* Stat band */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
@media (max-width: 768px) { .stats { grid-template-columns: repeat(2, 1fr); gap: 24px; } }
.stat__num { font-family: var(--font-heading); font-weight: 800; font-size: 56px; line-height: 1; color: var(--gold); margin-bottom: 6px; letter-spacing: -0.02em; }
.stat__label { font-family: var(--font-heading); font-weight: 700; font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.7); }
.stat__desc { font-size: 14px; color: rgba(255,255,255,0.85); margin-top: 4px; }

/* Review card */
.review { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 28px; }
.review__stars { color: var(--gold); letter-spacing: 2px; margin-bottom: 12px; font-size: 18px; }
.review__quote { font-size: 17px; line-height: 1.55; color: var(--fg-1); margin: 0 0 16px; }
.review__author { display: flex; align-items: center; gap: 12px; }
.review__avatar { width: 40px; height: 40px; border-radius: 999px; background: var(--lk-royal-navy); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-heading); font-weight: 700; font-size: 14px; }
.review__meta { font-size: 14px; }
.review__name { font-weight: 700; color: var(--lk-royal-navy); }
.review__sub { color: var(--fg-2); font-size: 13px; }

/* Pill / badge */
.pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 999px; font-family: var(--font-heading); font-weight: 700; font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase; }
.pill--navy { background: var(--lk-royal-navy); color: #fff; }
.pill--gold { background: var(--gold); color: var(--lk-royal-navy); }
.pill--orange { background: var(--accent); color: #fff; }
.pill--green { background: var(--success); color: #fff; }
.pill--red { background: var(--danger); color: #fff; }
.pill--outline { background: transparent; border: 1.5px solid currentColor; }
.pill--soft-green { background: rgba(46,139,87,0.12); color: var(--success); }
.pill--soft-navy { background: rgba(32,67,89,0.08); color: var(--lk-royal-navy); }

/* Footer */
.footer { background: var(--lk-royal-navy); color: rgba(255,255,255,0.75); padding: 72px 0 28px; }
.footer a { color: rgba(255,255,255,0.75); }
.footer a:hover { color: var(--gold); }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr 1fr; gap: 32px; margin-bottom: 48px; }
@media (max-width: 1024px) { .footer__grid { grid-template-columns: 1fr 1fr 1fr; } .footer__brand { grid-column: 1 / -1; } }
@media (max-width: 640px) { .footer__grid { grid-template-columns: 1fr 1fr; gap: 28px; } }
.footer__brand img { height: 44px; margin-bottom: 16px; }
.footer__brand p { font-size: 14px; line-height: 1.6; margin-bottom: 16px; max-width: 280px; }
.footer__nap { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,0.85); }
.footer__nap strong { color: #fff; }
.footer__grid { align-items: start; }
.footer__col { display: flex; flex-direction: column; }
.footer__col h3, .footer__col h5 { font-family: var(--font-heading); font-weight: 700; font-size: 13px; line-height: 1.4; letter-spacing: 0.08em; text-transform: uppercase; color: #fff; margin: 0 0 14px; }
.footer__col ul + h3, .footer__col ul + h5 { margin-top: 24px; }
.footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.footer__col a { font-size: 14px; }
.footer__social { display: flex; gap: 8px; margin-top: 16px; }
.footer__social a { width: 36px; height: 36px; border-radius: 999px; background: rgba(255,255,255,0.1); display: inline-flex; align-items: center; justify-content: center; color: #fff; }
.footer__social a:hover { background: var(--gold); color: var(--lk-royal-navy); }
.footer__trust { padding: 24px 0; border-top: 1px solid rgba(255,255,255,0.12); border-bottom: 1px solid rgba(255,255,255,0.12); display: flex; gap: 32px; flex-wrap: wrap; align-items: center; }
.footer__trust .badge { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: rgba(255,255,255,0.8); }
.footer__trust .badge i { font-size: 22px; color: var(--gold); }
.footer__payments { display: flex; gap: 6px; margin-left: auto; }
.footer__payments span { background: rgba(255,255,255,0.1); padding: 4px 10px; border-radius: 4px; font-size: 12px; font-weight: 700; }
.footer__legal { padding-top: 20px; display: flex; flex-wrap: wrap; gap: 16px; justify-content: space-between; font-size: 13px; color: rgba(255,255,255,0.5); }
.footer__legal a { color: rgba(255,255,255,0.7); }

/* Sticky mobile call/text/book bar */
.mobile-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 80; display: none; grid-template-columns: 1fr 1fr 1fr; background: #fff; border-top: 1px solid var(--border); padding: 8px 8px calc(8px + env(safe-area-inset-bottom)); gap: 8px; box-shadow: 0 -8px 24px rgba(0,0,0,0.08); }
.mobile-bar a { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 14px 4px; border-radius: var(--radius-md); font-family: var(--font-heading); font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: 0.04em; text-decoration: none; text-align: center; white-space: nowrap; }
.mobile-bar a.call { background: var(--accent); color: #fff; }
.mobile-bar a.text { background: var(--lk-royal-navy); color: #fff; }
.mobile-bar a.book { background: #fff; color: var(--lk-royal-navy); border: 2px solid var(--lk-royal-navy); }
@media (max-width: 768px) { .mobile-bar { display: grid; } body { padding-bottom: 76px; } }

/* Chat widget */
.chat-fab { position: fixed; bottom: 24px; right: 24px; z-index: 70; background: var(--lk-royal-navy); color: #fff; width: 60px; height: 60px; border-radius: 999px; border: 0; cursor: pointer; box-shadow: 0 8px 24px rgba(0,0,0,0.25); display: inline-flex; align-items: center; justify-content: center; transition: all var(--t-med) var(--ease-out); }
.chat-fab:hover { transform: translateY(-2px); background: var(--accent); }
.chat-fab i { font-size: 26px; }
.chat-fab__badge { position: absolute; top: 4px; right: 4px; width: 12px; height: 12px; background: var(--success); border-radius: 999px; border: 2px solid var(--lk-royal-navy); }
.chat-panel { position: fixed; bottom: 96px; right: 24px; z-index: 70; width: 340px; max-width: calc(100vw - 48px); background: #fff; border-radius: var(--radius-xl); box-shadow: 0 16px 48px rgba(0,0,0,0.20); overflow: hidden; display: none; }
.chat-panel.is-open { display: block; }
.chat-panel__head { background: var(--lk-royal-navy); color: #fff; padding: 16px 18px; display: flex; align-items: center; gap: 12px; }
.chat-panel__head img { width: 36px; height: 36px; border-radius: 999px; background: rgba(255,255,255,0.15); padding: 4px; }
.chat-panel__head h4 { color: #fff; font-size: 15px; font-weight: 700; margin: 0; }
.chat-panel__head .sub { font-size: 12px; color: rgba(255,255,255,0.7); }
.chat-panel__body { padding: 18px; }
.chat-panel__msg { background: var(--bg-alt); padding: 12px 14px; border-radius: 12px 12px 12px 4px; font-size: 14px; line-height: 1.5; margin-bottom: 14px; }
.chat-panel__opts { display: flex; flex-direction: column; gap: 8px; }
.chat-panel__opts button { text-align: left; padding: 10px 12px; border-radius: 8px; border: 1px solid var(--border); background: #fff; cursor: pointer; font-size: 14px; font-family: var(--font-body); }
.chat-panel__opts button:hover { border-color: var(--accent); color: var(--accent); }
@media (max-width: 768px) { .chat-fab, .chat-panel { display: none !important; } }

/* Form */
.form-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-field label { font-family: var(--font-heading); font-weight: 600; font-size: 14px; color: var(--lk-royal-navy); }
.form-field .hint { font-size: 13px; color: var(--fg-2); }
.form-field input, .form-field select, .form-field textarea {
  font-family: var(--font-body); font-size: 16px; padding: 14px 16px; border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--bg-alt); color: var(--fg-1); width: 100%; transition: border var(--t-fast), background var(--t-fast); }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { outline: none; border-color: var(--lk-royal-navy); background: #fff; }
.form-field textarea { min-height: 120px; resize: vertical; }
.form-field--invalid input, .form-field--invalid select { border-color: var(--danger); }

/* Section header common */
.section-head, .section__head { margin-bottom: 48px; max-width: 760px; }
.section-head--center, .section__head--center { margin: 0 auto 48px; text-align: center; }
.section-head h2, .section__head h2 { margin-bottom: 12px; }
.section-head p, .section__head p { font-size: 18px; line-height: 1.6; color: var(--fg-1); margin: 0; }

/* AI answer block */
.answer-box { background: var(--bg-premium); border-left: 4px solid var(--gold); padding: 24px 28px; border-radius: 0 var(--radius-md) var(--radius-md) 0; margin: 24px 0; }
.answer-box .eyebrow { color: var(--lk-royal-navy); margin-bottom: 8px; }
.answer-box p { margin: 0; font-size: 17px; line-height: 1.6; }

/* FAQ */
.faq details { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 0; margin-bottom: 12px; overflow: hidden; }
.faq summary { padding: 20px 24px; cursor: pointer; font-family: var(--font-heading); font-weight: 600; font-size: 17px; color: var(--lk-royal-navy); display: flex; justify-content: space-between; align-items: center; gap: 16px; list-style: none; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 22px; font-weight: 400; color: var(--fg-2); transition: transform var(--t-fast); }
.faq details[open] summary::after { content: "−"; }
.faq details[open] summary { border-bottom: 1px solid var(--border); }
.faq__body { padding: 18px 24px 22px; font-size: 16px; line-height: 1.6; }
.faq__body p { margin: 0 0 10px; }

/* Process steps */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; counter-reset: step; }
@media (max-width: 1024px) { .steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .steps { grid-template-columns: 1fr; } }
.step { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 24px; position: relative; }
.step__num { font-family: var(--font-heading); font-weight: 800; font-size: 14px; color: var(--accent); letter-spacing: 0.12em; }
.step__num::before { counter-increment: step; content: counter(step, decimal-leading-zero); }
.step h4 { margin: 8px 0 8px; font-size: 18px; }
.step p { font-size: 14px; line-height: 1.55; margin: 0; color: var(--fg-1); }
.step i { font-size: 24px; color: var(--lk-royal-navy); margin-bottom: 8px; display: block; }

/* Final CTA band */
.cta-band { background: var(--lk-royal-navy); color: #fff; text-align: center; padding: 80px 0; }
.cta-band h2 { color: #fff; max-width: 780px; margin: 0 auto 16px; }
.cta-band p { color: rgba(255,255,255,0.85); font-size: 19px; max-width: 640px; margin: 0 auto 28px; }
.cta-band .phone { display: block; font-family: var(--font-heading); font-weight: 800; font-size: 48px; color: var(--accent); margin: 16px 0; letter-spacing: -0.01em; }
.cta-band .phone:hover { color: var(--gold); }

/* Map placeholder */
.map { background: var(--bg-alt) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 480'><defs><pattern id='p' width='40' height='40' patternUnits='userSpaceOnUse'><path d='M 40 0 L 0 0 0 40' fill='none' stroke='%23E5E9EE' stroke-width='1'/></pattern></defs><rect width='800' height='480' fill='%23F4F6F8'/><rect width='800' height='480' fill='url(%23p)'/><path d='M 100 100 Q 200 50 300 120 T 500 160 T 700 200' fill='none' stroke='%23204359' stroke-width='2' stroke-opacity='0.3'/><path d='M 50 300 L 200 280 L 380 320 L 560 280 L 750 340' fill='none' stroke='%23204359' stroke-width='2' stroke-opacity='0.3'/><circle cx='200' cy='150' r='6' fill='%23FF6B1A'/><circle cx='340' cy='220' r='6' fill='%23FF6B1A'/><circle cx='480' cy='180' r='6' fill='%23FF6B1A'/><circle cx='600' cy='280' r='6' fill='%23FF6B1A'/><circle cx='400' cy='340' r='10' fill='%23204359' stroke='%23fff' stroke-width='3'/></svg>"); background-size: cover; background-position: center; border: 1px solid var(--border); border-radius: var(--radius-xl); aspect-ratio: 16/9; position: relative; overflow: hidden; }
.map__overlay {
  position: absolute;
  left: 12px;
  bottom: 12px;
  top: auto;
  right: auto;
  width: auto;
  max-width: min(220px, 55%);
  background: rgba(13,59,102,0.92);
  color: #fff;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 12px;
  line-height: 1.35;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
  pointer-events: none;
}
.map__overlay strong { display: block; color: #fff; font-size: 13px; margin-bottom: 2px; }

/* Live availability */
.live { display: inline-flex; align-items: center; gap: 8px; padding: 10px 14px; background: rgba(46,139,87,0.10); color: var(--success); border-radius: 999px; font-family: var(--font-heading); font-weight: 700; font-size: 13px; }
.live__dot { width: 8px; height: 8px; border-radius: 999px; background: var(--success); animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

/* Misc */
.divider { border: 0; border-top: 1px solid var(--border); margin: 32px 0; }
.skip-link { position: absolute; top: -40px; left: 8px; background: var(--lk-royal-navy); color: #fff; padding: 8px 14px; border-radius: 4px; z-index: 100; }
.skip-link:focus { top: 8px; color: #fff; }

.before-after { position: relative; border-radius: var(--radius-xl); overflow: hidden; border: 1px solid var(--border); }
.before-after img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.before-after__split { position: absolute; left: 50%; top: 0; bottom: 0; width: 2px; background: #fff; }
.before-after__tag { position: absolute; top: 12px; padding: 4px 10px; background: rgba(0,0,0,0.7); color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; border-radius: 4px; }
.before-after__tag--before { left: 12px; }
.before-after__tag--after { right: 12px; background: var(--accent); }

/* Brand logos row */
.brand-row { display: grid; grid-template-columns: repeat(8, 1fr); gap: 24px; align-items: center; }
@media (max-width: 1024px) { .brand-row { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 480px) { .brand-row { grid-template-columns: repeat(2, 1fr); } }
.brand-row .logo { display: flex; align-items: center; justify-content: center; height: 56px; font-family: var(--font-heading); font-weight: 800; font-size: 18px; color: var(--fg-2); letter-spacing: 0.04em; transition: color var(--t-fast); opacity: 0.7; }
.brand-row .logo:hover { color: var(--lk-royal-navy); opacity: 1; }

/* Symptoms / checklist */
.symptoms { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 1024px) { .symptoms { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .symptoms { grid-template-columns: 1fr; } }
.symptom { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 18px 20px; display: flex; gap: 14px; align-items: flex-start; transition: all var(--t-fast); }
.symptom:hover { border-color: var(--danger); transform: translateY(-2px); }
.symptom i { font-size: 22px; color: var(--danger); flex: none; margin-top: 2px; }
.symptom strong { display: block; font-family: var(--font-heading); font-weight: 700; font-size: 15px; color: var(--lk-royal-navy); margin-bottom: 4px; }
.symptom p { margin: 0; font-size: 14px; color: var(--fg-2); line-height: 1.4; }

/* City link grid */
.city-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
@media (max-width: 1024px) { .city-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px) { .city-grid { grid-template-columns: repeat(2, 1fr); } }
.city-grid a { padding: 10px 14px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); font-size: 14px; color: var(--fg-1); display: inline-flex; align-items: center; justify-content: space-between; }
.city-grid a:hover { border-color: var(--accent); color: var(--accent); }
.city-grid a::after { content: "→"; opacity: 0; transition: opacity var(--t-fast); }
.city-grid a:hover::after { opacity: 1; }

/* Price table */
.price-table { width: 100%; border-collapse: separate; border-spacing: 0; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); overflow: hidden; }
.price-table th { background: var(--lk-royal-navy); color: #fff; text-align: left; padding: 14px 18px; font-family: var(--font-heading); font-weight: 700; font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; }
.price-table td { padding: 14px 18px; border-top: 1px solid var(--border); font-size: 15px; }
.price-table td strong { color: var(--lk-royal-navy); }
.price-table .price { font-family: var(--font-heading); font-weight: 800; color: var(--lk-royal-navy); font-size: 17px; }

/* Stat cards (city hub, service leaf) */
.stat-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 28px; text-align: center; box-shadow: var(--shadow-card); }
.stat-card__num { font-family: var(--font-heading); font-weight: 800; font-size: 40px; color: var(--lk-royal-navy); letter-spacing: -0.01em; line-height: 1; }
.stat-card__label { font-size: 14px; color: var(--fg-2); margin-top: 8px; font-family: var(--font-heading); font-weight: 600; }

/* ZIP grid */
.zip-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 768px) { .zip-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .zip-grid { grid-template-columns: 1fr; } }
.zip-grid > div { background: #fff; padding: 16px 18px; border: 1px solid var(--border); border-radius: var(--radius-md); font-size: 15px; }
.zip-grid strong { color: var(--lk-royal-navy); font-family: var(--font-heading); }

/* Contact page */
.hero--contact { background: linear-gradient(180deg, var(--lk-royal-navy) 0%, var(--lk-deep-navy) 100%); color: #fff; }
.hero--contact h1, .hero--contact .hero__sub, .hero--contact .crumbs, .hero--contact .crumbs a { color: #fff; }
.hero--contact .crumbs a { opacity: 0.8; }
.hero--contact .hero__eyebrow { color: var(--gold); }

.contact-card { display: block; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 32px; text-decoration: none; color: inherit; box-shadow: var(--shadow-card); transition: transform var(--t-fast), box-shadow var(--t-fast); text-align: center; }
.contact-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); border-color: var(--accent); color: inherit; }
.contact-card__icon { font-size: 48px; color: var(--lk-royal-navy); }
.contact-card h3 { font-size: 18px; margin: 12px 0 6px; }
.contact-card__big { font-family: var(--font-heading); font-weight: 800; font-size: 28px; color: var(--accent); margin: 8px 0 12px; letter-spacing: -0.01em; }
.contact-card p { font-size: 14px; color: var(--fg-2); margin: 0; }

/* Forms */
.contact-form { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 32px; box-shadow: var(--shadow-card); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px) { .form-row { grid-template-columns: 1fr; } }
.field { margin-bottom: 16px; display: flex; flex-direction: column; }
.field label { font-family: var(--font-heading); font-weight: 600; font-size: 13px; color: var(--lk-royal-navy); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 6px; }
.field input, .field select, .field textarea { width: 100%; padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--radius-md); font-family: var(--font-body); font-size: 15px; background: #fff; color: var(--fg-1); transition: border-color var(--t-fast); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 20%, transparent); }
.field textarea { resize: vertical; min-height: 80px; }
.checkbox-row { display: flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 400; font-size: 14px; color: var(--fg-1); text-transform: none; letter-spacing: 0; cursor: pointer; }
.checkbox-row input { width: auto; }

/* Hours card */
.hours-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-card); margin-top: 20px; }
.hours-table { width: 100%; border-collapse: collapse; margin-top: 12px; }
.hours-table td { padding: 8px 0; font-size: 14px; border-bottom: 1px solid var(--border); }
.hours-table td:last-child { text-align: right; font-family: var(--font-heading); font-weight: 600; color: var(--lk-royal-navy); }
.hours-table tr:last-child td { border-bottom: none; }
.hours-table tr.emergency td { text-align: center; padding-top: 14px; color: var(--accent); font-family: var(--font-heading); font-weight: 700; font-size: 13px; }

/* Rating summary (reviews) */
.rating-summary { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 36px; box-shadow: var(--shadow-card); display: grid; grid-template-columns: 220px 1fr 260px; gap: 40px; align-items: center; }
@media (max-width: 900px) { .rating-summary { grid-template-columns: 1fr; gap: 24px; text-align: center; } }
.rating-summary__big { text-align: center; }
.rating-summary__num { font-family: var(--font-heading); font-weight: 800; font-size: 72px; color: var(--lk-royal-navy); line-height: 1; letter-spacing: -0.02em; }
.rating-summary__bars { display: flex; flex-direction: column; gap: 8px; }
.bar-row { display: grid; grid-template-columns: 36px 1fr 36px; align-items: center; gap: 12px; font-size: 13px; color: var(--fg-2); }
.bar { height: 8px; background: var(--bg-alt); border-radius: 999px; overflow: hidden; }
.bar span { display: block; height: 100%; background: var(--gold); border-radius: 999px; }
.rating-summary__sources { display: flex; flex-direction: column; gap: 8px; }
.source-row { display: grid; grid-template-columns: 90px auto 1fr; align-items: center; gap: 10px; font-size: 13px; padding: 8px 12px; background: var(--bg-alt); border-radius: var(--radius-md); }
.source-row strong { color: var(--lk-royal-navy); font-family: var(--font-heading); }

/* Filter bar + chips */
.filter-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; padding: 16px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); }
.filter-bar__label { font-family: var(--font-heading); font-weight: 700; font-size: 13px; color: var(--lk-royal-navy); text-transform: uppercase; letter-spacing: 0.04em; }
.chip { padding: 10px 16px; background: #fff; border: 1px solid var(--border); border-radius: 999px; font-family: var(--font-heading); font-weight: 600; font-size: 14px; color: var(--fg-1); cursor: pointer; transition: all var(--t-fast); }
.chip:hover { border-color: var(--lk-royal-navy); color: var(--lk-royal-navy); }
.chip--active, .chip.chip--active { background: var(--lk-royal-navy); border-color: var(--lk-royal-navy); color: #fff; }
.filter-select { padding: 8px 14px; border: 1px solid var(--border); border-radius: 999px; background: #fff; font-family: var(--font-heading); font-weight: 600; font-size: 13px; color: var(--fg-1); cursor: pointer; }

/* Review card variant */
.review--card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-card); display: flex; flex-direction: column; gap: 12px; }

/* Video frame */
.video-frame { aspect-ratio: 16/10; background: linear-gradient(135deg, var(--lk-royal-navy), var(--lk-deep-navy)); border-radius: var(--radius-xl); overflow: hidden; position: relative; box-shadow: var(--shadow-card-hover); cursor: pointer; }
.video-frame__inner { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.video-frame__label { position: absolute; bottom: 18px; left: 18px; background: rgba(0,0,0,0.6); color: #fff; padding: 6px 12px; border-radius: 999px; font-family: var(--font-heading); font-weight: 700; font-size: 13px; }

/* Coupons (specials page) */
.coupon { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 28px; display: grid; grid-template-columns: 110px minmax(0, 1fr) auto; gap: 24px; align-items: center; box-shadow: var(--shadow-card); position: relative; overflow: hidden; }
@media (max-width: 720px) { .coupon { grid-template-columns: 1fr; gap: 16px; text-align: center; } }
.coupon--featured { border: 2px solid var(--gold); background: linear-gradient(135deg, color-mix(in oklab, var(--gold) 6%, white), #fff); }
.coupon__badge { background: var(--lk-royal-navy); color: #fff; font-family: var(--font-heading); font-weight: 800; font-size: 13px; letter-spacing: 0.06em; padding: 14px 12px; border-radius: var(--radius-md); text-align: center; display: flex; align-items: center; justify-content: center; align-self: center; min-height: 88px; word-break: break-word; line-height: 1.2; }
.coupon__badge--gold { background: var(--gold); color: var(--lk-deep-navy); }
.coupon__body h3 { font-size: 22px; margin: 4px 0 8px; }
.coupon__body p { font-size: 15px; color: var(--fg-2); margin: 0 0 12px; }
.coupon__meta { display: flex; flex-wrap: wrap; gap: 14px; font-size: 13px; color: var(--fg-2); }
.coupon__meta strong { color: var(--lk-royal-navy); font-family: var(--font-heading); }
.coupon__cta { display: flex; align-items: center; }
.coupon__cta .btn { white-space: nowrap; }

/* Bundles */
.bundle { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 28px; box-shadow: var(--shadow-card); display: flex; flex-direction: column; gap: 14px; }
.bundle--featured { border: 2px solid var(--accent); position: relative; }
.bundle--featured::before { content: "Most popular"; position: absolute; top: -12px; left: 24px; background: var(--accent); color: #fff; padding: 4px 12px; border-radius: 999px; font-family: var(--font-heading); font-weight: 700; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; }
.bundle__price { font-family: var(--font-heading); font-weight: 800; font-size: 40px; color: var(--lk-royal-navy); line-height: 1; letter-spacing: -0.01em; }
.bundle__price span { display: inline-block; margin-left: 10px; font-size: 13px; color: var(--accent); background: color-mix(in oklab, var(--accent) 10%, white); padding: 4px 10px; border-radius: 999px; vertical-align: middle; }
.bundle p { font-size: 15px; color: var(--fg-2); margin: 0; }
.check-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; font-size: 14px; }
.check-list li { padding-left: 26px; position: relative; }
.check-list li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--gold); font-weight: 800; }

/* Ordered list (service leaf) */
.ordered-list { list-style: none; counter-reset: ord; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.ordered-list li { counter-increment: ord; padding: 16px 16px 16px 56px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); font-size: 15px; line-height: 1.6; position: relative; }
.ordered-list li::before { content: counter(ord); position: absolute; left: 14px; top: 14px; width: 30px; height: 30px; background: var(--lk-royal-navy); color: #fff; border-radius: 50%; font-family: var(--font-heading); font-weight: 800; font-size: 14px; display: flex; align-items: center; justify-content: center; }
.ordered-list strong { color: var(--lk-royal-navy); }

/* Warning callout */
.callout { display: flex; gap: 24px; align-items: flex-start; padding: 32px; border-radius: var(--radius-xl); }
.callout--warning { background: linear-gradient(135deg, var(--lk-deep-navy), #1a1f2e); color: #fff; border: 1px solid var(--gold); }

/* Icon color variants */
.card__icon--red { color: #C8362A !important; }
.card__icon--orange { color: var(--accent) !important; }

/* ───────────────────────────────────────────────────────
   MOBILE & DESKTOP HEADER POLISH
   ─────────────────────────────────────────────────────── */

/* Desktop header: phone & Book Now never break across lines */
.header__phone, .header__phone-num, .header__book { white-space: nowrap; }
.header__inner { flex-wrap: nowrap; }

/* Universal: any tel: link or `.phone` element never wraps */
a[href^="tel:"], .phone, .topbar__phone { white-space: nowrap; }
/* But card-style anchors that wrap big layouts need normal wrapping */
.contact-card, .contact-card *, .coupon, .coupon *, .review, .review *,
a.btn, a.btn * { white-space: normal; }
.contact-card__big, .coupon__code, .btn { white-space: nowrap; }

/* Mobile-nav links: row layout w/ submenu chevron */
.mobile-nav__panel a.mn-link { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 4px; border-bottom: 1px solid var(--border); font-family: var(--font-heading); font-weight: 600; font-size: 17px; color: var(--lk-royal-navy); }
.mobile-nav__panel a.mn-link i { font-size: 18px; color: var(--fg-2); opacity: 0.7; flex: 0 0 auto; }
.mobile-nav__panel a.mn-link--has-sub::after { content: ""; }
.mobile-nav__panel a.mn-link:active, .mobile-nav__panel a.mn-link:hover { color: var(--accent); }

/* ───────────────────────────────────────────────────────
   MOBILE TYPOGRAPHY: cap inline hero font sizes
   The hero pages use inline `style="font-size:56px"` on h1 —
   override here so it scales down on phones.
   ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .hero h1, .hero h1[style] { font-size: 34px !important; line-height: 1.08 !important; letter-spacing: -0.02em !important; }
  .hero__eyebrow { font-size: 11px; letter-spacing: 0.08em; }
  .hero__sub { font-size: 16px !important; max-width: 100%; }
  .hero__cta { gap: 10px; }
  .hero__cta .btn { padding: 12px 18px; font-size: 14px; }
  .hero__trust { gap: 10px; font-size: 12px; }
  .hero__trust .dot { display: none; }
  .crumbs { font-size: 12px; margin-bottom: 10px; }
}
@media (max-width: 480px) {
  .hero h1, .hero h1[style] { font-size: 28px !important; }
  .hero__inner { padding: 44px 0 !important; }
  .hero { min-height: 480px !important; }
}

/* Section heads tighten on mobile */
@media (max-width: 768px) {
  .section-head h2, .section__head h2, h2 { font-size: 28px !important; line-height: 1.15 !important; }
  .section-head h3, .section__head h3, h3 { font-size: 20px; }
  .section-head .eyebrow, .section__head .eyebrow { font-size: 11px; }
}

/* CTA band & big phone numbers on mobile */
@media (max-width: 640px) {
  .cta-band h2 { font-size: 26px !important; }
  .cta-band .phone, .phone { font-size: 28px !important; }
}

/* ───────────────────────────────────────────────────────
   GRID SAFETY: any inline grid template doesn't survive
   on small screens. Force single column for known offenders.
   ─────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  /* Inline `grid-template-columns: 1fr 1fr` etc → 1fr */
  [style*="grid-template-columns"]:not(.keep-grid) { grid-template-columns: 1fr !important; }
  /* Wide multi-column custom layouts collapse */
  .grid--asym, .two-col, .three-col, .split-2, .split-3 { grid-template-columns: 1fr !important; }
  /* Coupon, rating summary, callout: stack & center on mobile */
  .coupon { text-align: center; }
  .callout { flex-direction: column; gap: 14px; align-items: flex-start; padding: 24px; }
  /* Service-leaf "process + photo" 2-col already collapses via .grid--2 */
  .ordered-list li { padding: 14px 14px 14px 48px; font-size: 14px; }
}

/* ───────────────────────────────────────────────────────
   FOOTER: centered, balanced padding on mobile
   ─────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .footer { text-align: center; }
  .footer__grid { grid-template-columns: 1fr !important; gap: 32px !important; margin-bottom: 32px; padding: 0 4px; }
  .footer__brand img { margin-left: auto; margin-right: auto; display: block; }
  .footer__brand p { max-width: 100%; margin-left: auto; margin-right: auto; }
  .footer__nap { text-align: center; }
  .footer__social { justify-content: center; }
  .footer__col { display: flex; flex-direction: column; align-items: center; }
  .footer__col h5 { text-align: center; }
  .footer__col ul { align-items: center; }
  .footer__trust { flex-direction: column; gap: 14px; padding: 20px 0; text-align: center; }
  .footer__payments { margin-left: 0; justify-content: center; }
  .footer__legal { justify-content: center; text-align: center; gap: 8px; flex-direction: column; }
  .footer__legal a { display: inline-block; }
}

/* ───────────────────────────────────────────────────────
   HEADER LOGO + chrome shrink on very narrow phones
   so the toggle button still fits.
   ─────────────────────────────────────────────────────── */
@media (max-width: 420px) {
  .header__logo img { height: 30px !important; }
  .header__phone span:not(.short) { display: none; }
}

/* ───────────────────────────────────────────────────────
   SECTION + CONTAINER padding tighter on small phones
   ─────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .container { padding-left: 22px !important; padding-right: 22px !important; }
  .section { padding: 40px 0; }
  .card { padding: 20px; }
  .hero .container, .hero__inner > .container { padding-left: 22px !important; padding-right: 22px !important; }
  .crumbs { font-size: 12px; flex-wrap: wrap; }
  .hero__cta { justify-content: center; align-items: stretch; }
  .hero__cta .btn { width: 100%; justify-content: center; }
}
@media (max-width: 640px) {
  .hero__cta { justify-content: center; }
}

/* ═══════════════════════════════════════════════════════
   MOBILE-FIRST PASS — universal optimizations for every page
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Prevent any horizontal overflow */
  html, body { overflow-x: hidden; max-width: 100vw; }
  * { max-width: 100%; }
  img, svg, video, iframe { max-width: 100%; height: auto; }
  /* Type rhythm: condensed but still tappable */
  h1 { font-size: 32px; line-height: 1.15; letter-spacing: -0.01em; }
  h2 { font-size: 26px; line-height: 1.2; }
  h3 { font-size: 19px; line-height: 1.3; }
  body, p { font-size: 16px; line-height: 1.55; }
  .eyebrow { font-size: 12px; letter-spacing: 0.1em; }
  .section-head h2 { max-width: 100%; }
  .section-head p { font-size: 16px; }

  /* Hero: shorter, content priority */
  .hero { min-height: auto !important; }
  .hero__inner { padding: 44px 0 36px !important; }
  .hero__eyebrow { font-size: 11px; letter-spacing: 0.14em; margin-bottom: 12px; }
  .hero__sub { font-size: 16px; margin-top: 14px; }
  .hero__cta { margin-top: 20px; gap: 10px; flex-direction: column; }
  .hero__trust { margin-top: 18px; font-size: 13px; gap: 8px 10px; flex-wrap: wrap; }
  .hero__trust .dot { display: none; }
  .hero__overlay { background: linear-gradient(180deg, rgba(32,67,89,0.92) 0%, rgba(32,67,89,0.78) 60%, rgba(32,67,89,0.55) 100%) !important; }

  /* Section heads: centered on mobile so headings feel composed */
  .section-head, .section__head { text-align: center; }
  .section-head p, .section__head p { margin-left: auto; margin-right: auto; }

  /* All grids collapse cleanly */
  .grid, .grid--2, .grid--3, .grid--4, .grid--6 { grid-template-columns: 1fr !important; gap: 14px !important; }

  /* Stats: 2x2 not 1x4 */
  .stats { grid-template-columns: 1fr 1fr !important; gap: 24px 14px !important; text-align: center; }
  .stats .stat__num { font-size: 36px !important; }
  .stats .stat__label { font-size: 14px; }
  .stats .stat__desc { font-size: 12px; }

  /* Service tiles: keep readable, full-width touch targets */
  .svc-tile { padding: 18px 18px 16px; min-height: auto; }
  .svc-tile i { font-size: 28px; }
  .svc-tile h4 { font-size: 16px; margin-top: 8px; }
  .svc-tile p { font-size: 13px; }

  /* CTA band: tighter padding, full-width button */
  .cta-band { padding: 56px 0; }
  .cta-band .phone { font-size: 36px; margin: 12px 0; }
  .cta-band .btn { width: 100%; max-width: 360px; }

  /* Trust strip: centered, smaller */
  .trust-strip { justify-content: center; gap: 6px 12px; font-size: 13px; }

  /* Forms: 16px font (prevents iOS zoom), bigger inputs, full-width submit */
  input, select, textarea { font-size: 16px !important; padding: 14px 16px !important; }
  button[type="submit"], .form__submit, form .btn { width: 100%; justify-content: center; }

  /* Cards / coupons stack centered */
  .coupon { text-align: left; }

  /* FAQ items full-tap */
  .faq__q { min-height: 56px; padding: 16px 18px; font-size: 15px; }
  .faq__a { padding: 0 18px 16px; font-size: 15px; }

  /* Map block: shorter on mobile */
  .map { min-height: 220px !important; aspect-ratio: 16/10; }

  /* City grid: 2-col tappable */
  .city-grid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
  .city-grid a { padding: 12px 14px; font-size: 14px; }

  /* Section padding tighter */
  .section { padding: 48px 0; }

  /* Final CTA buttons centered */
  .cta-band div[style*="flex"] { justify-content: center !important; }

  /* Eyebrow above section heads slightly tighter */
  .section-head, .section__head { margin-bottom: 24px; }

  /* Buttons: ensure tap target ≥48px */
  .btn { min-height: 48px; }
  .btn--lg { min-height: 56px; font-size: 17px; padding: 16px 22px; }

  /* Reviews summary stacks cleanly */
  .rating-summary { grid-template-columns: 1fr !important; gap: 20px !important; text-align: center; }
  .rating-summary__big { font-size: 56px !important; }
  .source-row { justify-content: center; }

  /* Booking wizard: stack summary + form */
  .booking-layout { grid-template-columns: 1fr !important; }
  .booking-summary { position: static !important; order: -1; margin-bottom: 16px; }

  /* Contact cards: phone first, big tap targets */
  .contact-card { padding: 20px; text-align: center; }
  .contact-card i { font-size: 32px; }

  /* Coupon cards: tighter padding, full-width CTA */
  .coupon h3 { font-size: 22px; }
  .coupon .btn { width: 100%; justify-content: center; }

  /* Process steps numbered */
  .steps__item { padding: 18px; }
  .steps__num { font-size: 26px; }

  /* Reviews grid → 1-col cards already, just tighten */
  .review { padding: 20px; }
  .review__quote { font-size: 15px; }

  /* Chat hidden on mobile */
  .chat-fab, .chat-panel { display: none !important; }

  /* Standalone section buttons centered on mobile */
  .section > .container > .btn,
  .section > .container > p > .btn,
  .section > .container > div:not(.grid):not(.hero__cta):not(.coupon) > .btn { display: inline-flex; margin-left: auto; margin-right: auto; }

  /* Center any inline button row on mobile */
  div:has(> .btn + .btn) { justify-content: center !important; text-align: center; }
  div:has(> .btn:only-child) { text-align: center; }

/* Very small phones: aggressive type compression */
@media (max-width: 380px) {
  h1 { font-size: 28px; }
  h2 { font-size: 22px; }
  .hero__sub { font-size: 15px; }
  .stats { grid-template-columns: 1fr 1fr; gap: 16px 10px; }
  .stats .stat__num { font-size: 30px !important; }
  .btn--lg { font-size: 15px; padding: 14px 18px; min-height: 52px; }
  .city-grid { grid-template-columns: 1fr !important; }
}

/* Mobile sticky bottom bar — stronger visual treatment */
@media (max-width: 768px) {
  .mobile-bar { padding: 10px 16px calc(10px + env(safe-area-inset-bottom)); gap: 8px; box-shadow: 0 -8px 24px rgba(0,0,0,0.08); }
  .mobile-bar a { font-size: 12px; padding: 12px 4px; min-height: 48px; border-radius: 10px; letter-spacing: 0.02em; }
  .mobile-bar a i, .mobile-bar a svg { font-size: 16px; width: 16px; height: 16px; flex-shrink: 0; }
}

/* ───────────────────────────────────────────────────────
   MOBILE STICKY HEADER — logo + menu button only.
   Topbar (phone, availability, emergency, language, trust)
   is hidden entirely on mobile; language moves into drawer.
   ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .topbar { display: none !important; }
  .header__inner { gap: 12px; height: 64px; padding-left: 4px; padding-right: 4px; }
  .header.is-scrolled .header__inner { height: 56px; }
  .header__right .header__phone,
  .header__right .btn,
  .header__right a:not(.header__mobile-toggle) { display: none !important; }
  .header__right { gap: 8px; }
  .header__logo img { height: 36px; }
}
@media (max-width: 420px) {
  .header__inner { gap: 8px; padding-left: 2px; padding-right: 2px; }
  .header__logo img { height: 30px !important; }
}

/* ───────────────────────────────────────────────────────
   MOBILE NAV DRAWER — call/book CTAs + language switcher
   ─────────────────────────────────────────────────────── */
.mobile-nav__cta {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}
.mn-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 18px;
  border-radius: var(--radius-md);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  white-space: nowrap;
  transition: transform var(--t-fast), filter var(--t-fast);
}
.mn-cta--call { background: var(--accent); color: #fff; }
.mn-cta--book { background: var(--lk-royal-navy); color: #fff; }
.mn-cta:hover { filter: brightness(1.05); }
.mn-cta:active { transform: scale(0.99); }
.mn-cta svg { width: 18px; height: 18px; }

.mobile-nav__lang {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.mobile-nav__lang-label {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-2);
}
.mobile-nav__lang-btns { display: inline-flex; gap: 6px; }
.mobile-nav__lang-btns button {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg-1);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.04em;
  padding: 8px 14px;
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--t-fast);
}
.mobile-nav__lang-btns button.is-active {
  background: var(--lk-royal-navy);
  color: #fff;
  border-color: var(--lk-royal-navy);
}
}

/* ───────────────────────────────────────────────────────
   TABLES on mobile — stack rows as cards so columns don't
   crush. Applies to .price-table; .hours-table is 2-col and
   readable as-is, just tightened.
   ─────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .price-table { display: block; border: 0; background: transparent; border-radius: 0; overflow: visible; }
  .price-table thead { display: none; }
  .price-table tbody { display: block; }
  .price-table tr {
    display: block;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 14px 16px;
    margin-bottom: 12px;
    box-shadow: var(--shadow-card);
  }
  .price-table td {
    display: block;
    border-top: 0;
    padding: 4px 0;
    font-size: 14px;
    line-height: 1.5;
  }
  .price-table td:first-child {
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 16px;
    color: var(--lk-royal-navy);
    padding-bottom: 8px;
    margin-bottom: 6px;
    border-bottom: 1px solid var(--border);
  }
  .price-table td:not(:first-child)::before {
    content: attr(data-label);
    display: inline-block;
    min-width: 90px;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fg-2);
    margin-right: 8px;
  }
  .price-table .price { font-size: 15px; }
  .hours-table td { font-size: 13px; padding: 6px 0; }
}

/* ═══════════════════════════════════════════════════════
   BATCH 2 COMPONENTS
   ═══════════════════════════════════════════════════════ */

/* Timeline (history / process) */
.timeline { position: relative; padding-left: 0; list-style: none; margin: 0; }
.timeline::before { content: ""; position: absolute; left: 18px; top: 8px; bottom: 8px; width: 2px; background: var(--border); }
.timeline__item { position: relative; padding: 4px 0 40px 60px; }
.timeline__item:last-child { padding-bottom: 0; }
.timeline__dot { position: absolute; left: 8px; top: 4px; width: 22px; height: 22px; border-radius: 999px; background: var(--lk-royal-navy); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 800; font-family: var(--font-heading); box-shadow: 0 0 0 4px var(--bg-page); z-index: 1; }
.timeline__item--accent .timeline__dot { background: var(--accent); }
.timeline__year { font-family: var(--font-heading); font-weight: 800; font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--accent); margin-bottom: 4px; }
.timeline__title { font-family: var(--font-heading); font-weight: 700; font-size: 20px; color: var(--lk-royal-navy); margin: 0 0 6px; }
.timeline__body { color: var(--fg-1); font-size: 15px; line-height: 1.55; margin: 0; }

/* Team grid */
.team { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 24px; }
.team__card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-card); transition: transform var(--t-med) var(--ease-out), box-shadow var(--t-med) var(--ease-out); }
.team__card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.team__photo { aspect-ratio: 4 / 5; background: var(--lk-royal-navy) center/cover no-repeat; display: flex; align-items: flex-end; justify-content: flex-start; padding: 16px; }
.team__photo .pill { background: rgba(255,255,255,0.95); color: var(--lk-royal-navy); }
.team__body { padding: 20px 22px 22px; }
.team__name { font-family: var(--font-heading); font-weight: 800; font-size: 19px; color: var(--lk-royal-navy); margin: 0 0 2px; }
.team__role { font-size: 13px; color: var(--accent); font-family: var(--font-heading); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 8px; }
.team__bio { font-size: 14px; line-height: 1.55; color: var(--fg-1); margin: 0; }
.team__meta { display: flex; gap: 14px; margin-top: 12px; font-size: 12px; color: var(--fg-2); }
.team__meta span { display: inline-flex; align-items: center; gap: 4px; }

/* Calculator widget */
.calc { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 32px; box-shadow: var(--shadow-card); display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; }
@media (max-width: 768px) { .calc { grid-template-columns: 1fr; padding: 22px; gap: 22px; } }
.calc__form > div { margin-bottom: 20px; }
.calc__form label { display: block; font-family: var(--font-heading); font-weight: 600; font-size: 14px; color: var(--lk-royal-navy); margin-bottom: 6px; }
.calc__form input[type="range"] { width: 100%; accent-color: var(--accent); }
.calc__row { display: flex; justify-content: space-between; align-items: baseline; }
.calc__row .calc__val { font-family: var(--font-heading); font-weight: 800; color: var(--lk-royal-navy); font-size: 18px; }
.calc__terms { display: flex; gap: 8px; flex-wrap: wrap; }
.calc__terms button { flex: 1; min-width: 60px; padding: 10px 14px; border: 2px solid var(--border); background: #fff; border-radius: var(--radius-md); font-family: var(--font-heading); font-weight: 700; font-size: 14px; color: var(--lk-royal-navy); cursor: pointer; transition: all var(--t-fast); }
.calc__terms button.is-active { background: var(--lk-royal-navy); border-color: var(--lk-royal-navy); color: #fff; }
.calc__result { background: var(--bg-premium); border-radius: var(--radius-lg); padding: 28px; display: flex; flex-direction: column; justify-content: center; text-align: center; }
.calc__result .eyebrow { color: var(--lk-royal-navy); margin-bottom: 6px; }
.calc__big { font-family: var(--font-heading); font-weight: 900; font-size: 56px; color: var(--lk-royal-navy); line-height: 1; letter-spacing: -0.02em; }
.calc__big sup { font-size: 22px; font-weight: 700; }
.calc__big small { font-size: 16px; color: var(--fg-2); font-weight: 600; }
.calc__sub { font-size: 14px; color: var(--fg-2); margin-top: 10px; }
.calc__total { margin-top: 16px; padding-top: 16px; border-top: 1px dashed var(--border); display: flex; justify-content: space-between; font-size: 14px; }
.calc__total strong { color: var(--lk-royal-navy); font-family: var(--font-heading); }

/* Article layout (TOC + body + byline) */
.article-layout { display: grid; grid-template-columns: 240px 1fr; gap: 56px; align-items: start; }
@media (max-width: 1024px) { .article-layout { grid-template-columns: 1fr; gap: 32px; } }
.toc { position: sticky; top: 96px; }
@media (max-width: 1024px) { .toc { position: static; padding: 20px; background: var(--bg-alt); border-radius: var(--radius-lg); } }
.toc__title { font-family: var(--font-heading); font-weight: 700; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-2); margin: 0 0 12px; }
.toc ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; border-left: 2px solid var(--border); }
.toc a { display: block; padding: 7px 14px; font-size: 14px; line-height: 1.4; color: var(--fg-1); border-left: 2px solid transparent; margin-left: -2px; }
.toc a:hover, .toc a.is-active { color: var(--accent); border-left-color: var(--accent); font-weight: 600; }
.article { max-width: 720px; font-size: 17px; line-height: 1.7; color: var(--fg-1); }
.article > h2 { font-size: 30px; margin: 40px 0 16px; scroll-margin-top: 96px; }
.article > h3 { font-size: 22px; margin: 32px 0 12px; scroll-margin-top: 96px; }
.article > p { margin: 0 0 18px; }
.article > p strong { color: var(--lk-royal-navy); }
.article > ul, .article > ol { padding-left: 22px; margin: 0 0 18px; }
.article > ul li, .article > ol li { margin-bottom: 8px; }
.article blockquote { border-left: 4px solid var(--gold); background: var(--bg-premium); margin: 24px 0; padding: 20px 28px; font-style: italic; color: var(--fg-1); border-radius: 0 var(--radius-md) var(--radius-md) 0; }

/* ─── TOC upgrade ─── */
.toc { position: sticky; top: 96px; }
.toc__card { background: var(--bg-alt); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 20px 18px; }
.toc__title { font-family: var(--font-heading); font-weight: 700; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-2); margin: 0 0 14px; padding: 0 6px; }
.toc ul, .toc__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; border-left: none; counter-reset: tocnum; }
.toc li, .toc__list li { counter-increment: tocnum; }
.toc a { display: flex; align-items: baseline; gap: 10px; padding: 9px 10px; font-size: 14px; line-height: 1.35; color: var(--fg-1); border-radius: var(--radius-sm); border-left: none; margin-left: 0; text-decoration: none; transition: background 120ms ease, color 120ms ease; }
.toc a::before { content: counter(tocnum, decimal-leading-zero); font-family: var(--font-heading); font-weight: 700; font-size: 11px; color: var(--fg-3, var(--fg-2)); opacity: 0.55; min-width: 22px; flex: none; }
.toc a:hover { background: rgba(0,0,0,0.03); color: var(--lk-royal-navy); }
.toc a:hover::before { opacity: 1; color: var(--accent); }
.toc a.is-active { background: #fff; color: var(--lk-royal-navy); font-weight: 600; box-shadow: inset 3px 0 0 var(--accent); }
.toc a.is-active::before { color: var(--accent); opacity: 1; }
@media (max-width: 1024px) {
  .toc { position: static; }
  .toc__card { padding: 18px 16px; }
}

/* ─── Byline upgrade (specific overrides) ─── */
.article .byline { display: flex !important; align-items: center; gap: 16px; padding: 18px 0 22px; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 0 0 32px; }
.article .byline__avatar { width: 52px !important; height: 52px !important; min-width: 52px; flex: none !important; border-radius: 999px !important; background: var(--lk-royal-navy) !important; color: #fff !important; display: inline-flex !important; align-items: center; justify-content: center; font-family: var(--font-heading); font-weight: 700; font-size: 16px; letter-spacing: 0.04em; box-shadow: 0 0 0 4px rgba(20,43,58,0.06); }
.article .byline__name { font-family: var(--font-heading); font-weight: 700; color: var(--lk-royal-navy); font-size: 15px; line-height: 1.3; margin-bottom: 4px; }
.article .byline__meta { font-size: 13px; color: var(--fg-2); display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.article .byline__meta i { font-size: 14px; vertical-align: -1px; margin-right: 3px; opacity: 0.7; }
.article .byline__meta .dot { opacity: 0.35; }
.article .byline__meta a { color: var(--lk-royal-navy); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; text-decoration-color: rgba(20,43,58,0.25); }
.article .byline__meta a:hover { text-decoration-color: var(--accent); color: var(--accent); }
@media (max-width: 480px) {
  .article .byline { align-items: flex-start; }
  .article .byline__avatar { width: 44px !important; height: 44px !important; min-width: 44px; font-size: 14px; }
}

/* Byline */
.byline { display: flex; align-items: center; gap: 14px; padding: 18px 0 24px; border-bottom: 1px solid var(--border); margin-bottom: 32px; }
.byline__avatar { width: 48px; height: 48px; border-radius: 999px; background: var(--lk-royal-navy); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-heading); font-weight: 800; font-size: 17px; flex: none; }
.byline__name { font-family: var(--font-heading); font-weight: 700; color: var(--lk-royal-navy); font-size: 15px; }
.byline__meta { font-size: 13px; color: var(--fg-2); display: flex; gap: 10px; flex-wrap: wrap; }
.byline__meta .dot { opacity: 0.4; }

/* Spec comparison table */
.spec-table { width: 100%; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); overflow: visible; border-collapse: separate; border-spacing: 0; }
.spec-table thead tr:first-child th:first-child { border-top-left-radius: var(--radius-xl); }
.spec-table thead tr:first-child th:last-child { border-top-right-radius: var(--radius-xl); }
.spec-table th, .spec-table td { padding: 16px 18px; text-align: left; vertical-align: top; border-top: 1px solid var(--border); font-size: 14px; }
.spec-table thead th { background: var(--lk-royal-navy); color: #fff; border-top: 0; font-family: var(--font-heading); font-weight: 700; font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; }
.spec-table thead th.is-featured { background: var(--accent); position: relative; }
.spec-table thead th.is-featured .featured-label { display: inline-flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: center; }
.spec-table thead th.is-featured .featured-pill { display: inline-block; background: var(--gold); color: var(--lk-royal-navy); padding: 3px 9px; border-radius: 999px; font-size: 9px; letter-spacing: 0.08em; font-weight: 800; white-space: nowrap; text-transform: uppercase; box-shadow: 0 1px 0 rgba(0,0,0,0.08); }
.spec-table thead th.is-featured::after { display: none; }
.spec-table thead th.is-featured::before { display: none; }px; font-size: 10px; letter-spacing: 0.05em; }
.spec-table tbody td:first-child { font-family: var(--font-heading); font-weight: 600; color: var(--lk-royal-navy); background: var(--bg-alt); width: 24%; }
.spec-table tbody td.is-yes { color: var(--success); font-weight: 700; }
.spec-table tbody td.is-no { color: var(--fg-2); }
.spec-table tbody td.is-featured-col { background: rgba(255,107,26,0.05); }
.spec-table tbody tr:last-child td { padding-bottom: 22px; }
.spec-table tfoot td { background: var(--bg-alt); font-family: var(--font-heading); font-weight: 700; border-top: 2px solid var(--lk-royal-navy); }

/* Mobile spec cards (visible only < 768px; table hidden there) */
.spec-cards { display: none; }
.spec-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); overflow: hidden; }
.spec-card__head { background: var(--lk-royal-navy); color: #fff; padding: 18px 20px; position: relative; }
.spec-card__name { font-family: var(--font-heading); font-weight: 800; font-size: 18px; color: #fff; letter-spacing: 0.01em; }
.spec-card__price { font-family: var(--font-heading); font-weight: 700; font-size: 18px; color: var(--gold); margin-top: 6px; }
.spec-card__price span { display: block; font-size: 11px; font-weight: 500; color: rgba(255,255,255,0.7); margin-top: 2px; letter-spacing: 0.04em; }
.spec-card__badge { display: inline-block; background: var(--gold); color: var(--lk-royal-navy); padding: 3px 9px; border-radius: 999px; font-family: var(--font-heading); font-weight: 700; font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 10px; }
.spec-card--featured .spec-card__head { background: var(--accent); }
.spec-card--featured .spec-card__price { color: #fff; }
.spec-card--featured .spec-card__price span { color: rgba(255,255,255,0.85); }
.spec-card__list { display: grid; grid-template-columns: 44% 1fr; gap: 0; margin: 0; padding: 0; font-size: 14px; }
.spec-card__list dt { padding: 12px 16px; background: var(--bg-alt); color: var(--lk-royal-navy); font-family: var(--font-heading); font-weight: 600; font-size: 13px; border-top: 1px solid var(--border); }
.spec-card__list dd { padding: 12px 16px; margin: 0; color: var(--fg-1); border-top: 1px solid var(--border); }
.spec-card__list dd.is-yes { color: var(--success); font-weight: 700; }
.spec-card__list dt:first-of-type, .spec-card__list dd:first-of-type { border-top: 0; }
@media (max-width: 768px) {
  .spec-table-wrap { display: none; }
  .spec-cards { display: grid; gap: 16px; }
  .spec-cards { font-size: 14px; }
  .spec-card__list { font-size: 14px; }
  .spec-card__list dt, .spec-card__list dd { font-size: 14px; padding: 14px 16px; }
  .spec-card--featured { order: -1; box-shadow: 0 8px 24px rgba(255,107,26,0.18); border-color: var(--accent); }
  .chip { padding: 12px 18px; font-size: 14px; min-height: 44px; display: inline-flex; align-items: center; }
}
@media (max-width: 768px) {
  .spec-table { font-size: 12px; }
  .spec-table th, .spec-table td { padding: 12px 10px; }
  .spec-table tbody td:first-child { font-size: 12px; }
}

/* City directory grid */
.city-dir { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.city-dir a { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); padding: 14px 18px; display: flex; justify-content: space-between; align-items: center; color: var(--lk-royal-navy); font-family: var(--font-heading); font-weight: 600; font-size: 15px; transition: all var(--t-fast); }
.city-dir a:hover { border-color: var(--accent); color: var(--accent); transform: translateX(2px); }
.city-dir a span { font-size: 12px; color: var(--fg-2); font-weight: 500; }
.city-dir a:hover span { color: var(--accent); }

