/* ============================================================
   plincar.tech — landing enhancements (on top of kit.css)
   ============================================================ */

/* ---------- scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s var(--ease-out), transform .6s var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- top scroll progress ---------- */
.scrollbar { position: fixed; top: 0; left: 0; height: 2px; background: var(--brand-orange); z-index: 60; width: 0; box-shadow: 0 0 10px rgba(255,92,0,.6); }

/* ---------- header active link underline ---------- */
.hdr nav a { position: relative; padding: 6px 0; white-space: nowrap; }
.hdr nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -2px; height: 2px; background: var(--brand-orange); transition: right var(--dur) var(--ease-out); }
.hdr nav a:hover::after, .hdr nav a.active::after { right: 0; }
.hdr .tg-ico, .hdr .msg-ico { width: 36px; height: 36px; flex: none; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; transition: transform var(--dur) var(--ease-out), filter var(--dur); }
.hdr .msg-ico { color: #fff; box-shadow: 0 2px 8px rgba(0,0,0,.25); }
.hdr .tg-ico:hover, .hdr .msg-ico:hover { transform: translateY(-1px); filter: brightness(1.1); }
.hdr .tg-ico svg { display: block; }
.hdr .msg-ico img { display: block; width: 34px; height: 34px; object-fit: contain; }
.works-head-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 14px 28px; flex-wrap: wrap; }
.works-rating { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; font-family: var(--font-mono); font-size: 14px; color: var(--fg-2); white-space: nowrap; padding-bottom: 8px; transition: color var(--dur); }
.works-rating .st { color: var(--brand-amber); letter-spacing: 2px; }
.works-rating b { color: var(--brand-orange); font-weight: 700; font-size: 16px; }
.works-rating .arr { color: var(--brand-orange); transition: transform var(--dur) var(--ease-out); }
.works-rating:hover { color: var(--fg-1); }
.works-rating:hover .arr { transform: translateX(3px); }
.works-filters { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: -12px 0 18px; }
.works-filters button { border: 1px solid var(--line-1); background: var(--bg-1); color: var(--fg-2); border-radius: var(--r-pill); padding: 9px 14px; font-family: var(--font-mono); font-size: 12px; cursor: pointer; transition: all var(--dur) var(--ease-out); }
.works-filters button:hover, .works-filters button.on { border-color: rgba(255,92,0,.55); color: var(--fg-1); background: rgba(255,92,0,.08); }
:focus-visible { outline: 2px solid var(--brand-orange); outline-offset: 3px; }

/* ---------- hero refinements ---------- */
.hero h1 { letter-spacing: -.03em; }
.hero-stats .stat .num { font-variant-numeric: tabular-nums; }
.hero-trust { display: flex; align-items: center; gap: 14px; margin-top: 26px; font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); letter-spacing: .04em; flex-wrap: nowrap; min-width: 0; }
.hero-trust > span:first-child { flex: none; }
.hero-trust .brands { display: flex; gap: 0 10px; flex: 1; min-width: 0; overflow: hidden; white-space: nowrap; }
.hero-trust .brands span { color: var(--fg-2); flex: none; }
.hero-trust .brands span + span::before { content: "·"; color: var(--fg-3); margin-right: 10px; }

@media (max-width: 1240px) {
  .hero-trust { font-size: 11px; gap: 10px; }
  .hero-trust .brands { gap: 0 8px; }
  .hero-trust .brands span + span::before { margin-right: 8px; }
}
@media (max-width: 620px) {
  .hero-trust { font-size: 10.5px; }
}

/* hero gauge sweep ring */
.gring { position: relative; width: 188px; height: 188px; margin: 4px auto 6px; }
.gring svg { transform: rotate(-90deg); display: block; }
.gring .gtxt { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.gring .gtxt .v { font-family: var(--font-mono); font-weight: 700; font-size: 48px; line-height: 1; color: var(--brand-orange); font-variant-numeric: tabular-nums; }
.gring .gtxt .v .accent { color: var(--brand-orange); }
.gring .gtxt .u { font-family: var(--font-mono); font-size: 10.5px; color: var(--fg-3); letter-spacing: .1em; text-transform: uppercase; margin-top: 7px; }
.gring .gtxt .delta { font-family: var(--font-mono); font-size: 11px; color: var(--ok); margin-top: 8px; white-space: nowrap; letter-spacing: .01em; }

/* ---------- services: 6-card grid + price emphasis ---------- */
.svc { display: flex; flex-direction: column; position: relative; }
.svc.feat { border-color: rgba(255,92,0,.4); }
.svc.feat::before { content: ""; display: block; height: 3px; margin: -26px -26px 22px; background: linear-gradient(90deg, var(--brand-orange), var(--brand-amber)); border-radius: 16px 16px 0 0; }
.svc .tag { position: absolute; top: 22px; right: 22px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--brand-orange); background: rgba(255,92,0,.1); border: 1px solid rgba(255,92,0,.25); padding: 4px 9px; border-radius: var(--r-pill); }
.svc .spacer { flex: 1; }
.svc ul.feats { list-style: none; padding: 0; margin: 0 0 18px; display: flex; flex-direction: column; gap: 9px; }
.svc ul.feats li { display: flex; gap: 10px; align-items: flex-start; font-size: 13.5px; color: var(--fg-2); line-height: 1.45; }
.svc ul.feats li .s { width: 6px; height: 6px; background: var(--brand-orange); flex: none; margin-top: 6px; }
.svc .priceline { display: flex; align-items: baseline; justify-content: space-between; padding-top: 16px; border-top: 1px solid var(--line-1); }
.svc .priceline .lab { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); }
.svc .priceline .val { font-family: var(--font-mono); font-weight: 700; font-size: 19px; color: var(--brand-orange); }
.svc .svc-note { min-height: 14px; margin-top: 6px; font-family: var(--font-mono); font-size: 11px; line-height: 1.25; color: var(--brand-orange); }
.svc .svc-note.empty { visibility: hidden; }

/* services reassurance line under the card grid */
.svc-reassure {
  display: flex; align-items: center; gap: 14px;
  margin-top: 28px; padding: 18px 22px;
  background: var(--bg-1); border: 1px solid var(--line-1);
  border-radius: var(--r-lg);
  font-family: var(--font-mono); font-size: 14px; color: var(--fg-2);
  line-height: 1.5;
  cursor: pointer;
  transition: all var(--dur) var(--ease-out);
}
.svc-reassure b { color: var(--brand-orange); font-weight: 700; }
.svc-reassure > i[data-lucide] { width: 20px; height: 20px; color: var(--brand-orange); flex: none; }
.svc-reassure .arr { width: 18px; height: 18px; color: var(--fg-3); margin-left: auto; flex: none; transition: transform var(--dur), color var(--dur); }
.svc-reassure:hover { border-color: rgba(255,92,0,.35); background: rgba(255,92,0,.04); }
.svc-reassure:hover .arr { transform: translateX(4px); color: var(--brand-orange); }
@media (max-width: 620px) {
  .svc-reassure { font-size: 13px; padding: 16px 18px; }
}

/* russification CTA */
.russ-controls { display: flex; align-items: center; justify-content: space-between; gap: 24px; margin-bottom: 34px; }
.russ-cta { display: flex; align-items: center; justify-content: flex-end; gap: 16px; flex: 1 1 auto; min-width: 0; }
.russ-cta .btn { white-space: nowrap; }
.russ-cta p { flex: 1 1 260px; max-width: 540px; font-family: var(--font-mono); font-size: 12.5px; color: var(--fg-3); line-height: 1.55; margin: 0; }

/* ---------- russification tabs (магнитола / приборная панель) ---------- */
.russ-tabs { display: inline-flex; flex: none; background: var(--bg-1); border: 1px solid var(--line-2); border-radius: var(--r-pill); padding: 5px; gap: 4px; }
.russ-tabs button { font-family: var(--font-display); font-weight: 600; font-size: 14px; color: var(--fg-2); padding: 9px 18px; border: none; background: transparent; border-radius: var(--r-pill); cursor: pointer; transition: all var(--dur); display: inline-flex; align-items: center; gap: 8px; }
.russ-tabs button i { width: 15px; height: 15px; }
.russ-tabs button.on { background: var(--brand-orange); color: var(--fg-on-orange); }

/* instrument cluster */
.cluster { background: #05090B; border: 1px solid var(--line-2); border-radius: 18px; padding: 16px; box-shadow: var(--shadow-3); }
.cluster-screen { background: radial-gradient(circle at 50% 40%, #0c1b21, #05090b 75%); border-radius: 12px; aspect-ratio: 16/9; display: flex; align-items: center; justify-content: space-around; padding: 18px; position: relative; overflow: hidden; }
.cluster-id { position: absolute; top: 14px; right: 18px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--fg-3); }
.cluster-id::before { content: "● "; color: var(--ok); font-size: 12px; }
.dial { width: 150px; height: 150px; position: relative; flex: none; }
.dial svg { display: block; transform: rotate(135deg); }
.dial .dlabel { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.dial .dlabel .num { font-family: var(--font-mono); font-weight: 700; font-size: 28px; color: var(--fg-1); line-height: 1; font-variant-numeric: tabular-nums; }
.dial .dlabel .cap { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--fg-3); margin-top: 5px; }
.cluster-mid { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.cluster-mid .menu { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--fg-1); }
.cluster-mid .sub { font-family: var(--font-mono); font-size: 10.5px; color: var(--fg-3); letter-spacing: .08em; }
.cluster-warn { display: flex; gap: 14px; margin-top: 6px; }
.cluster-warn i { width: 18px; height: 18px; }

/* Virtual Cockpit badge in cluster corner */
.vc-badge { position: absolute; top: 12px; left: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-3); opacity: .7; }

/* cluster center: fuel display */
.c-fuel-lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 6px; }
.c-fuel-val { font-family: var(--font-mono); font-weight: 700; font-size: 22px; color: var(--fg-1); letter-spacing: -.01em; font-variant-numeric: tabular-nums; white-space: nowrap; }

/* dial: fix oversized numbers from dial value 3000 */
.dial .dlabel .num { font-family: var(--font-mono); font-weight: 700; font-size: 26px; color: var(--fg-1); line-height: 1; font-variant-numeric: tabular-nums; }
.dial .dlabel .cap { font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-3); margin-top: 4px; }

/* ---------- power calculator (rolling counters) ---------- */
.big-num { font-variant-numeric: tabular-nums; }
.calc-foot { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 28px; }
.chip-stat { background: var(--bg-1); border: 1px solid var(--line-1); border-radius: var(--r-md); padding: 12px 16px; }
.chip-stat .k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--fg-3); }
.chip-stat .v { font-family: var(--font-mono); font-weight: 700; font-size: 17px; color: var(--fg-1); margin-top: 4px; font-variant-numeric: tabular-nums; }
.chip-stat .v.accent { color: var(--brand-orange); }

/* dyno curve */
.dyno { margin-top: 26px; background: var(--bg-0); border: 1px solid var(--line-1); border-radius: var(--r-lg); padding: 22px 22px 16px; }
.dyno-halo { transform-box: fill-box; transform-origin: center; animation: dynoHalo 2.4s ease-in-out infinite; }
@keyframes dynoHalo { 0%, 100% { opacity: .4; transform: scale(1); } 50% { opacity: .12; transform: scale(1.55); } }
.dyno-legend { display: flex; flex-wrap: wrap; gap: 8px 18px; margin-bottom: 14px; font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); letter-spacing: .03em; }
.dyno-legend span { display: inline-flex; align-items: center; gap: 7px; }
.dyno-legend .dl { width: 16px; height: 0; flex: none; }
.dyno-legend .dl.pwr { width: 11px; height: 11px; border-radius: 50%; background: #FF5C00; }
.dyno-legend .dl.trq { width: 11px; height: 11px; border-radius: 50%; background: #36C6DC; }
.dyno-legend .dl.solid { border-top: 3px solid var(--fg-1); }
.dyno-legend .dl.dash { border-top: 2px dashed var(--fg-3); }
.dyno-foot { margin-top: 12px; font-family: var(--font-mono); font-size: 11px; line-height: 1.5; color: var(--fg-3); }

/* ---------- scanning section ---------- */
.scan-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: stretch; }
.scanner { position: relative; background: var(--bg-inset); border: 1px solid var(--line-2); border-radius: 16px; overflow: hidden; min-height: 420px; display: flex; flex-direction: column; }
.scan-stage { position: relative; flex: 1; min-height: 300px; overflow: hidden; }
.scan-stage .scan-photo { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.scan-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,16,20,.45), rgba(8,16,20,.82)); pointer-events: none; }
.scan-overlay-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,92,0,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(255,92,0,.07) 1px, transparent 1px); background-size: 30px 30px; opacity: 0; transition: opacity .4s; pointer-events: none; }
.scanner.run .scan-overlay-grid { opacity: 1; }
.scan-line { position: absolute; left: 0; right: 0; top: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--brand-orange) 30%, var(--brand-amber) 50%, var(--brand-orange) 70%, transparent); box-shadow: 0 0 22px 5px rgba(255,92,0,.5); opacity: 0; }
.scan-line::after { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 70px; background: linear-gradient(180deg, rgba(255,92,0,.18), transparent); }
.scanner.run .scan-line { opacity: 1; animation: scansweep 2.6s var(--ease-in-out) infinite; }
@keyframes scansweep { 0% { top: 3%; } 50% { top: 95%; } 100% { top: 3%; } }
.scan-bracket { position: absolute; width: 26px; height: 26px; border: 2px solid rgba(255,92,0,.7); opacity: 0; transition: opacity .4s; }
.scanner.run .scan-bracket { opacity: 1; }
.scan-bracket.tl { top: 16px; left: 16px; border-right: none; border-bottom: none; }
.scan-bracket.tr { top: 16px; right: 16px; border-left: none; border-bottom: none; }
.scan-bracket.bl { bottom: 16px; left: 16px; border-right: none; border-top: none; }
.scan-bracket.br { bottom: 16px; right: 16px; border-left: none; border-top: none; }
.scan-node { position: absolute; width: 12px; height: 12px; border-radius: 50%; background: var(--fg-3); border: 2px solid var(--bg-inset); transition: all .3s var(--ease-out); }
.scan-node.lit { background: var(--brand-orange); box-shadow: 0 0 0 4px rgba(255,92,0,.25), 0 0 14px rgba(255,92,0,.7); }
.scan-node.err { background: var(--danger); box-shadow: 0 0 0 4px rgba(255,82,71,.25), 0 0 14px rgba(255,82,71,.7); }
.scan-hud { position: absolute; left: 18px; bottom: 18px; right: 18px; display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; pointer-events: none; }
.scan-hud .hud-status { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); letter-spacing: .04em; }
.scan-hud .hud-status b { color: var(--brand-orange); }
.scan-pct { font-family: var(--font-mono); font-weight: 700; font-size: 40px; line-height: 1; color: var(--fg-1); font-variant-numeric: tabular-nums; }
.scan-progress { height: 4px; background: var(--gauge-track); }
.scan-progress > i { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--brand-orange), var(--brand-amber)); transition: width .25s linear; }

/* scan results panel */
.scan-results { background: var(--bg-inset); border: 1px solid var(--line-2); border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; }
.scan-results .sr-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; border-bottom: 1px solid var(--line-1); }
.scan-results .sr-head .ttl { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); letter-spacing: .06em; text-transform: uppercase; }
.scan-results .sr-body { padding: 6px 18px 16px; flex: 1; font-family: var(--font-mono); }
.scan-log { font-family: var(--font-mono); font-size: 13px; line-height: 1.85; min-height: 96px; }
.scan-log .ln { display: flex; gap: 12px; opacity: 0; animation: lnin .3s var(--ease-out) forwards; }
@keyframes lnin { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
.scan-log .t { color: var(--fg-3); width: 56px; flex: none; }
.scan-log .ok { color: var(--ok); }
.scan-log .val { color: var(--fg-1); }
.scan-log .warnc { color: var(--warn); }
.scan-log .err { color: var(--danger); }
.dtc-list { margin-top: 6px; }
.dtc-row .dtc-meta { display: flex; align-items: center; gap: 10px; }
.sev { font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; padding: 3px 8px; border-radius: var(--r-pill); }
.sev.high { color: var(--danger); background: var(--danger-bg); }
.sev.med { color: var(--warn); background: var(--warn-bg); }
.sr-foot { padding: 14px 18px; border-top: 1px solid var(--line-1); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.sr-foot .note { font-family: var(--font-mono); font-size: 12px; color: var(--ok); }

/* ---------- reviews with photos ---------- */
.rev { display: flex; flex-direction: column; }
.rev .quote-mark { font-family: var(--font-display); font-weight: 800; font-size: 40px; line-height: .6; color: var(--line-strong); margin-bottom: 6px; }
.rev p { flex: 1; }
.rev .who .av-slot { width: 44px; height: 44px; flex: none; }
.rev .badge { display: inline-flex; align-items: center; gap: 7px; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line-1); font-family: var(--font-mono); font-size: 11.5px; color: var(--fg-3); }
.rev .badge i { width: 14px; height: 14px; color: var(--ok); }
.rev .badge .pwr { color: var(--brand-orange); font-weight: 700; }

/* reviews aggregate strip */
.rev-agg { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; margin-bottom: 36px; padding: 20px 24px; background: var(--bg-1); border: 1px solid var(--line-1); border-radius: var(--r-lg); }
.rev-agg .score { display: flex; align-items: baseline; gap: 10px; }
.rev-agg .score .n { font-family: var(--font-mono); font-weight: 700; font-size: 34px; color: var(--brand-orange); }
.rev-agg .score .stars { color: var(--brand-amber); letter-spacing: 2px; }
.rev-agg .meta { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); line-height: 1.6; }

/* ---------- CTA contact methods ---------- */
.cta-methods { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 22px; position: relative; }
.cta-methods a { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-size: 13px; color: var(--fg-2); border: 1px solid var(--line-2); background: rgba(10,20,24,.5); border-radius: var(--r-pill); padding: 10px 18px; transition: all var(--dur) var(--ease-out); }
.cta-methods a:hover { border-color: rgba(255,92,0,.5); color: var(--fg-1); transform: translateY(-1px); }
.cta-methods a i { width: 16px; height: 16px; color: var(--brand-orange); }

@media (max-width: 920px) {
  .scan-grid { grid-template-columns: 1fr; }
  .cluster-screen { flex-direction: column; gap: 18px; }
}

/* header responsive: collapse nav/phone before content overflows */
@media (max-width: 1140px) {
  .hdr-in { gap: 18px; }
  .hdr nav { display: none; }
}
@media (max-width: 1024px) {
  .hdr .phone { display: none; }
}

/* ============================================================
   Full responsive layer
   ============================================================ */

/* --- tablet (≤920px): 2-col card grids, stacked calculator --- */
@media (max-width: 920px) {
  .svc-grid, .rev-grid { grid-template-columns: 1fr 1fr; }
  .stage .left { border-right: none; border-bottom: 1px solid var(--line-1); }
  .stage .right { padding: 28px; }
  .section { padding: 80px 0; }
  .hero { padding: 64px 0 72px; }
  .hero h1 { font-size: 48px; }
}

/* --- small tablet / large phone (≤720px) --- */
@media (max-width: 720px) {
  .steps { grid-template-columns: 1fr 1fr; }
  .ftr-grid { grid-template-columns: 1fr 1fr; }
  .section-head h2, .cta-band h2 { font-size: 32px; }
}

/* --- phones (≤620px) --- */
@media (max-width: 620px) {
  html, body { width: 100%; max-width: 100%; overflow-x: hidden; }
  .wrap { padding: 0 18px; }
  .hero-grid, .hero-grid > *, .hero-panel { min-width: 0; width: 100%; max-width: 100%; }
  .section { padding: 60px 0; }
  .section-head { margin-bottom: 32px; }
  .section-head h2, .cta-band h2 { font-size: 28px; }
  .section-head p { font-size: 16px; }

  .hero { padding: 44px 0 56px; }
  .hero h1 { font-size: 38px; overflow-wrap: anywhere; }
  .hero p.lead { font-size: 17px; }
  .hero-cta { gap: 10px; }
  .hero-cta .btn { flex: 1 1 100%; justify-content: center; }
  .hero-stats { gap: 22px 28px; flex-wrap: wrap; margin-top: 32px; }
  .hero-panel { padding: 20px; }

  .svc-grid, .rev-grid, .steps { grid-template-columns: 1fr; }
  .svc { padding: 22px; }

  .stage .left, .stage .right { padding: 24px; }
  .big-num { font-size: 46px; }

  .russ { gap: 28px; }
  .russ-controls { align-items: stretch; flex-direction: column; gap: 14px; margin-bottom: 28px; }
  .russ-tabs { width: 100%; }
  .russ-tabs button { flex: 1; justify-content: center; padding: 9px 10px; }
  .russ-cta { align-items: stretch; flex-direction: column; gap: 10px; }
  .russ-cta .btn { width: 100%; justify-content: center; }
  .russ-cta p { max-width: none; }

  .scan-pct { font-size: 32px; }
  .scanner { min-height: 360px; }

  .cta-band { padding: 38px 22px; border-radius: 18px; }
  .cta-band p { font-size: 16px; }
  .cta-methods a { font-size: 12px; padding: 9px 14px; }

  .ftr-grid { grid-template-columns: 1fr; gap: 28px; }
  .ftr .bottom { flex-direction: column; gap: 8px; text-align: center; }

  .modal { padding: 24px; border-radius: 16px; }
}

/* --- small phones (≤400px) --- */
@media (max-width: 400px) {
  .hdr-in { gap: 10px; }
  .hdr .right { gap: 8px; }
  .hdr .right .btn { display: none; }
  .hero h1 { font-size: 33px; }
  .section-head h2, .cta-band h2 { font-size: 25px; }
  .hero-tiles { grid-template-columns: 1fr; }
  .btn-lg { padding: 14px 22px; font-size: 16px; }
  .hdr .logo { height: 22px; }
}
