:root {
  --ink: #101820;
  --ink-2: #263646;
  --muted: #697481;
  --paper: #f4f0e8;
  --panel: #fff;
  --line: rgba(16, 24, 32, 0.12);
  --yellow: #f5b72e;
  --yellow-dark: #d99b13;
  --red: #d84a36;
  --blue: #143a5a;
  --green: #2d6f60;
  --shadow: 0 24px 62px rgba(16, 24, 32, 0.16);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; letter-spacing: 0; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
.topbar {
  position: fixed; inset: 0 0 auto; z-index: 50;
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 22px;
  min-height: 74px; padding: 12px clamp(18px, 4vw, 58px);
  color: #fff; transition: background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}
.topbar.solid { color: var(--ink); background: rgba(244,240,232,0.95); box-shadow: 0 12px 32px rgba(16,24,32,0.13); backdrop-filter: blur(16px); }
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: 0; }
.brand-mark { display: grid; width: 42px; height: 42px; place-items: center; border-radius: 8px; color: var(--ink); background: var(--yellow); font-weight: 950; }
.brand strong, .brand small { display: block; line-height: 1.05; }
.brand small { margin-top: 4px; opacity: 0.72; font-size: 0.78rem; }
nav { display: flex; justify-content: center; gap: clamp(14px,2.2vw,34px); font-size: 0.94rem; font-weight: 850; }
nav a { opacity: 0.84; }
.top-actions { display: flex; align-items: center; gap: 10px; }
.lang { min-width: 46px; height: 40px; border: 1px solid currentColor; border-radius: 8px; color: currentColor; background: transparent; cursor: pointer; font-weight: 900; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; border: 1px solid transparent; border-radius: 8px; padding: 0 20px; font-weight: 900; cursor: pointer; transition: transform 160ms ease, background 160ms ease; }
.btn:hover { transform: translateY(-1px); }
.btn-small { min-height: 40px; padding-inline: 16px; }
.btn-primary { color: var(--ink); background: var(--yellow); border-color: var(--yellow); }
.btn-primary:hover { background: var(--yellow-dark); }
.btn-ghost { color: #fff; border-color: rgba(255,255,255,0.58); background: rgba(255,255,255,0.08); }
.hero {
  min-height: 92vh; display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(330px, 0.72fr);
  gap: clamp(30px, 5vw, 76px); align-items: center;
  padding: 118px clamp(18px,5vw,78px) 54px;
  color: #fff;
  background: radial-gradient(circle at 70% 20%, rgba(245,183,46,0.2), transparent 24%), linear-gradient(120deg, #101820 0%, #122841 58%, #1e533f 100%);
}
.hero-copy { max-width: 820px; }
.eyebrow { color: var(--yellow); font-size: 0.8rem; font-weight: 950; letter-spacing: 0.07em; text-transform: uppercase; }
.hero h1 { margin: 14px 0 18px; max-width: 860px; font-size: clamp(2.7rem, 6vw, 6rem); line-height: 0.94; letter-spacing: 0; }
.hero p { max-width: 700px; color: rgba(255,255,255,0.83); font-size: clamp(1.02rem,1.6vw,1.25rem); line-height: 1.68; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.emergency-note { display: grid; gap: 6px; width: min(560px,100%); margin-top: 26px; padding: 16px; border-left: 5px solid var(--yellow); background: rgba(255,255,255,0.08); }
.emergency-note span { color: rgba(255,255,255,0.72); }
.hero-photo { position: relative; align-self: stretch; min-height: 560px; }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; box-shadow: var(--shadow); }
.score { position: absolute; right: -16px; bottom: 30px; width: min(230px, 72%); padding: 18px; color: var(--ink); background: #fff; border-left: 6px solid var(--yellow); box-shadow: var(--shadow); }
.score strong { display: block; color: var(--green); font-size: 4rem; line-height: 0.92; }
.score span { color: var(--muted); font-weight: 850; }
.quick-bar { position: relative; z-index: 3; display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); width: min(1120px, calc(100% - 36px)); margin: -34px auto 0; background: #fff; box-shadow: var(--shadow); }
.quick-bar a { display: grid; gap: 7px; min-width: 0; padding: 22px clamp(18px,2.4vw,30px); border-right: 1px solid var(--line); }
.quick-bar a:last-child { border-right: 0; }
.quick-bar span { color: var(--muted); font-size: 0.82rem; font-weight: 900; text-transform: uppercase; }
.quick-bar strong { overflow-wrap: anywhere; font-size: clamp(1rem,1.8vw,1.35rem); }
.section { width: min(1180px, calc(100% - 36px)); margin: 0 auto; padding: clamp(72px,9vw,118px) 0; }
.section h2 { margin: 10px 0 16px; font-size: clamp(2rem,4.2vw,4.15rem); line-height: 1; letter-spacing: 0; }
.section p { color: var(--ink-2); font-size: 1.05rem; line-height: 1.72; }
.urgent { display: grid; grid-template-columns: minmax(0,0.92fr) minmax(0,1.08fr); gap: 12px; }
.urgent-card { padding: clamp(26px,4vw,48px); color: #fff; background: var(--ink); }
.urgent-card p { color: rgba(255,255,255,0.76); }
.call-steps { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 12px; }
.call-steps article { display: grid; align-content: start; gap: 12px; padding: 24px; background: #fff; border: 1px solid var(--line); border-radius: 8px; }
.call-steps span { display: grid; width: 42px; height: 42px; place-items: center; border-radius: 8px; background: var(--yellow); font-weight: 950; }
.call-steps strong { font-size: 1.18rem; }
.services { display: grid; grid-template-columns: minmax(0,0.82fr) minmax(0,1.1fr); gap: clamp(30px,5vw,70px); padding-top: 0; }
.section-copy { position: sticky; top: 104px; align-self: start; }
.service-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.service-grid button { min-height: 126px; border: 1px solid var(--line); border-radius: 8px; padding: 18px; color: var(--ink); background: #fff; text-align: left; cursor: pointer; }
.service-grid button.active, .service-grid button:hover { border-color: rgba(245,183,46,0.64); background: #fff9e8; }
.service-grid span, .service-grid small { display: block; }
.service-grid span { font-size: 1.12rem; font-weight: 950; }
.service-grid small { margin-top: 8px; color: var(--muted); }
.service-detail { grid-column: span 2; padding: clamp(24px,3.5vw,38px); color: #fff; background: var(--blue); border-left: 6px solid var(--yellow); box-shadow: var(--shadow); }
.service-detail span { color: rgba(255,255,255,0.62); font-size: 0.78rem; font-weight: 900; text-transform: uppercase; }
.service-detail h3 { margin: 10px 0; font-size: clamp(1.5rem,3vw,2.45rem); }
.service-detail p { color: rgba(255,255,255,0.78); }
.service-detail a { display: inline-flex; margin-top: 12px; color: #fff; font-weight: 900; text-decoration: underline; text-underline-offset: 5px; text-decoration-thickness: 2px; }
.proof { display: grid; grid-template-columns: minmax(0,0.78fr) minmax(0,1.1fr); gap: clamp(30px,5vw,70px); padding-top: 0; }
.proof-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.proof-grid article { display: grid; align-content: space-between; min-height: 170px; padding: 24px; background: #fff; border: 1px solid var(--line); border-radius: 8px; }
.proof-grid strong { color: var(--green); font-size: clamp(2.4rem,5vw,4.3rem); line-height: 0.96; }
.proof-grid span { color: var(--ink-2); line-height: 1.45; }
.route { display: grid; grid-template-columns: minmax(0,0.9fr) minmax(0,1.1fr); gap: 12px; align-items: stretch; }
.route-card { padding: clamp(24px,4vw,46px); color: #fff; background: var(--ink); }
.route-card p { color: rgba(255,255,255,0.76); }
.photo-card img { width: 100%; height: 100%; min-height: 520px; object-fit: cover; }
.contact { display: grid; grid-template-columns: minmax(0,0.82fr) minmax(0,1fr); gap: clamp(28px,5vw,74px); padding-top: 0; }
.contact-form { display: grid; gap: 14px; padding: clamp(20px,3vw,34px); background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow); }
.contact-form label { display: grid; gap: 8px; }
.contact-form label span { color: var(--muted); font-size: 0.82rem; font-weight: 900; text-transform: uppercase; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 14px 15px; color: var(--ink); background: #fbfbfa; }
.contact-form textarea { resize: vertical; }
output { display: none; padding: 14px; color: var(--ink); background: #fff8e6; border: 1px solid rgba(245,183,46,0.44); border-radius: 8px; line-height: 1.55; white-space: pre-wrap; }
output.has-content { display: block; }
.footer { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 14px; padding: 28px clamp(18px,5vw,72px) 92px; color: rgba(255,255,255,0.74); background: var(--ink); }
.footer a { color: #fff; font-weight: 900; }
.mobile-bar { position: fixed; z-index: 60; inset: auto 10px 10px; display: none; grid-template-columns: repeat(3,1fr); overflow: hidden; border-radius: 8px; box-shadow: 0 18px 48px rgba(16,24,32,0.34); }
.mobile-bar a { display: grid; min-height: 52px; place-items: center; color: var(--ink); background: var(--yellow); border-right: 1px solid rgba(16,24,32,0.16); font-weight: 950; }
.mobile-bar a:last-child { border-right: 0; }
@media (max-width: 980px) {
  .topbar { grid-template-columns: 1fr auto; color: var(--ink); background: rgba(244,240,232,0.95); box-shadow: 0 12px 32px rgba(16,24,32,0.13); }
  nav, .brand small { display: none; }
  .hero, .urgent, .services, .proof, .route, .contact { grid-template-columns: 1fr; }
  .hero-photo { min-height: 420px; }
  .section-copy { position: static; }
}
@media (max-width: 680px) {
  .top-actions .btn { display: none; }
  .hero { min-height: auto; padding: 104px 18px 68px; }
  .hero h1 { font-size: clamp(2.35rem,12vw,4.1rem); }
  .hero-actions .btn { width: 100%; }
  .hero-photo { min-height: 390px; }
  .score { right: 14px; bottom: 14px; }
  .quick-bar, .call-steps, .service-grid, .proof-grid { grid-template-columns: 1fr; }
  .service-detail { grid-column: auto; }
  .quick-bar a { border-right: 0; border-bottom: 1px solid var(--line); }
  .quick-bar a:last-child { border-bottom: 0; }
  .section { width: min(100% - 28px, 1180px); }
  .section h2 { font-size: clamp(1.95rem,9vw,3rem); }
  .photo-card img { min-height: 360px; }
  .mobile-bar { display: grid; }
}

