:root {
  --bg: #111214;
  --surface: #191b1e;
  --surface-2: #222428;
  --line: #36393e;
  --text: #f4f3ef;
  --muted: #a8aaad;
  --accent: #f27a1a;
  --accent-dark: #c75608;
  --max-width: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 76px; }
body { margin: 0; overflow-x: hidden; background: var(--bg); color: var(--text); font-family: Arial, Helvetica, sans-serif; line-height: 1.6; }
main, section, .container, .hero-grid, .hero-content, .price-box, .contact-grid, .route-grid { min-width: 0; max-width: 100%; }
img, svg, iframe { max-width: 100%; }
a { color: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
.container { width: min(calc(100% - 40px), var(--max-width)); margin-inline: auto; }
.skip-link { position: fixed; left: 16px; top: -100px; z-index: 100; padding: 10px 16px; background: var(--accent); color: #111; }
.skip-link:focus { top: 10px; }

.site-header { position: sticky; top: 0; z-index: 50; background: rgb(17 18 20 / 94%); border-bottom: 1px solid var(--line); backdrop-filter: blur(10px); }
.header-inner { height: 76px; display: flex; align-items: center; gap: 34px; }
.brand { display: inline-flex; align-items: center; gap: 8px; color: var(--text); font-size: 19px; font-weight: 800; letter-spacing: .08em; text-decoration: none; white-space: nowrap; }
.brand b { color: var(--accent); }
.brand-mark { display: grid; place-items: center; width: 34px; height: 34px; color: #111; background: var(--accent); font-size: 23px; transform: skew(-7deg); }
.main-nav { display: flex; align-items: center; gap: 26px; margin-left: auto; }
.main-nav a, .header-phone { color: var(--muted); font-size: 14px; font-weight: 700; text-decoration: none; }
.main-nav a:hover, .header-phone:hover { color: var(--accent); }
.header-phone { color: var(--text); }
.menu-toggle { display: none; width: 42px; height: 42px; margin-left: auto; padding: 10px; background: none; border: 1px solid var(--line); }
.menu-toggle span { display: block; height: 2px; margin: 5px 0; background: var(--text); }

.section { padding: 94px 0; }
.section-dark { background: radial-gradient(circle at 75% 35%, #292a2d 0, #17181a 35%, #111214 70%); }
.eyebrow { margin: 0 0 12px; color: var(--accent); font-size: 12px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1, h2 { line-height: 1.05; letter-spacing: -.035em; text-transform: uppercase; }
h1 { margin-bottom: 24px; font-size: clamp(46px, 4.7vw, 72px); }
h1 span { color: var(--accent); }
h2 { margin-bottom: 0; font-size: clamp(34px, 4vw, 56px); }
h3 { line-height: 1.2; }
.hero { min-height: calc(100vh - 76px); display: grid; align-items: center; padding: 76px 0; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(380px, .85fr); gap: clamp(34px, 4vw, 64px); align-items: center; }
.hero-content { min-width: 0; }
.hero-lead { max-width: 680px; color: #c4c5c7; font-size: 19px; }
.hero-address { margin: 28px 0; padding-left: 16px; border-left: 3px solid var(--accent); color: var(--text); font-style: normal; font-weight: 700; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.button { display: inline-flex; min-height: 50px; align-items: center; justify-content: center; padding: 12px 22px; border: 1px solid transparent; font-size: 14px; font-weight: 800; text-decoration: none; text-transform: uppercase; transition: .2s ease; }
.button:hover { transform: translateY(-2px); }
.button-primary { background: var(--accent); color: #151515; }
.button-primary:hover { background: #ff8b32; }
.button-outline { border-color: #686b70; color: var(--text); }
.button-outline:hover { border-color: var(--accent); color: var(--accent); }
.button-text { color: var(--muted); }
.button-text:hover { color: var(--text); }
.placeholder { position: relative; overflow: hidden; min-height: 420px; display: grid; place-items: center; border: 1px solid var(--line); background: repeating-linear-gradient(135deg, #1c1e21 0, #1c1e21 12px, #202225 12px, #202225 24px); color: #777a7f; text-align: center; text-transform: uppercase; }
.placeholder::after { content: ""; position: absolute; inset: 18px; border: 1px solid #34363a; }
.placeholder p { z-index: 1; font-size: 13px; font-weight: 800; letter-spacing: .12em; }
.placeholder-number { position: absolute; inset: auto -10px -64px auto; color: rgb(255 255 255 / 3%); font-size: 260px; font-weight: 900; line-height: 1; }

.section-heading { display: flex; justify-content: space-between; gap: 50px; align-items: end; margin-bottom: 44px; }
.section-heading > p { max-width: 480px; margin-bottom: 4px; color: var(--muted); }
.service-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.service-card { min-height: 250px; padding: 28px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--surface); transition: background .2s ease; }
.service-card:hover { background: var(--surface-2); }
.service-card > span { color: var(--accent); font-size: 12px; font-weight: 800; }
.service-card h3 { margin: 45px 0 14px; font-size: 19px; text-transform: uppercase; }
.service-card p { margin-bottom: 0; color: var(--muted); font-size: 14px; }

.price-section { background: var(--accent); color: #141414; }
.price-section .eyebrow { color: #612600; }
.price-box { display: grid; grid-template-columns: 1.3fr .7fr; gap: 80px; align-items: center; }
.price-copy p { font-size: 19px; font-weight: 600; }
.price-section .button-primary { background: #151515; color: #fff; }

.gallery-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.gallery-card { margin: 0; }
.gallery-card > div { min-height: 310px; display: grid; place-items: center; border: 1px solid var(--line); background: linear-gradient(145deg, #24262a, #17181a); color: #6f7276; font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.gallery-card figcaption { padding: 14px 0; font-weight: 800; text-transform: uppercase; }
.reviews-section { background: #17181a; }
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
blockquote { margin: 0; padding: 30px; border-top: 3px solid var(--accent); background: var(--surface-2); }
blockquote p { min-height: 100px; font-size: 17px; }
blockquote footer { color: var(--muted); font-size: 12px; text-transform: uppercase; }

.contact-grid { display: grid; grid-template-columns: .8fr 1.2fr; border: 1px solid var(--line); }
.contact-panel { padding: 40px; background: var(--surface); }
dl { margin: 0 0 35px; }
dl div + div { margin-top: 26px; }
dt { color: var(--muted); font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
dd { margin: 5px 0 0; font-size: 18px; font-weight: 700; }
dd a { text-decoration: none; }
.map-wrap { min-height: 460px; position: relative; background: #292b2f; }
.map-wrap iframe { width: 100%; height: 100%; min-height: 460px; border: 0; filter: grayscale(1) contrast(1.05); }
.map-wrap > a { position: absolute; right: 18px; bottom: 18px; padding: 10px 14px; background: var(--bg); color: var(--text); font-size: 13px; font-weight: 700; text-decoration: none; }
.route-section { background: #18191b; }
.route-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; }
.route-grid > div:first-child > p:not(.eyebrow) { max-width: 560px; margin: 25px 0; color: var(--muted); font-size: 18px; }
.route-placeholder { min-height: 300px; }
.text-link { color: var(--accent); font-weight: 800; text-decoration: none; }

.site-footer { padding: 38px 0; border-top: 1px solid var(--line); color: var(--muted); }
.footer-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr auto; gap: 28px; align-items: center; font-size: 13px; }
.footer-grid p { margin: 0; }
.footer-grid a { color: var(--text); font-weight: 700; text-decoration: none; }

@media (max-width: 900px) {
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-grid, .price-box, .contact-grid, .route-grid { grid-template-columns: minmax(0, 1fr); }
  .hero { min-height: auto; }
  .hero-visual { min-height: 280px; }
  .price-box { gap: 36px; }
  .reviews-grid { grid-template-columns: 1fr; }
  blockquote p { min-height: auto; }
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 700px) {
  .container { width: min(calc(100% - 28px), var(--max-width)); }
  .section { padding: 68px 0; }
  .header-inner { height: 66px; }
  .menu-toggle { display: block; }
  .main-nav { position: absolute; inset: 66px 0 auto; display: none; padding: 12px 20px 22px; flex-direction: column; align-items: stretch; gap: 0; background: #151619; border-bottom: 1px solid var(--line); }
  .main-nav.is-open { display: flex; }
  .main-nav a { padding: 12px 0; border-bottom: 1px solid var(--line); }
  .header-phone { display: none; }
  .hero { padding: 54px 0; }
  .hero-grid { gap: 42px; }
  h1 { max-width: 100%; font-size: clamp(34px, 11.5vw, 54px); overflow-wrap: anywhere; }
  h2 { font-size: clamp(30px, 10vw, 44px); }
  .hero-lead { font-size: 17px; }
  .hero-address { font-size: 15px; }
  .hero-visual { min-height: 230px; }
  .section-heading { display: block; margin-bottom: 32px; }
  .section-heading > p { margin-top: 18px; }
  .service-grid, .gallery-grid { grid-template-columns: 1fr; }
  .service-card { min-height: 215px; }
  .service-card h3 { margin-top: 30px; }
  .gallery-card > div { min-height: 230px; }
  .contact-panel { padding: 26px; }
  dd { overflow-wrap: anywhere; font-size: 17px; }
  .map-wrap, .map-wrap iframe { min-height: 350px; }
  .actions .button { width: 100%; max-width: 100%; }
  .button { padding-inline: 16px; overflow-wrap: anywhere; text-align: center; }
  .route-grid { gap: 38px; }
  .route-placeholder { min-height: 230px; }
  .text-link, .map-wrap > a { overflow-wrap: anywhere; }
  .footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 420px) {
  html { scroll-padding-top: 62px; }
  .container { width: calc(100% - 24px); }
  .section { padding: 56px 0; }
  .header-inner { height: 62px; }
  .brand { font-size: 16px; }
  .brand-mark { width: 31px; height: 31px; font-size: 21px; }
  .main-nav { top: 62px; }
  .hero { padding: 44px 0 52px; }
  h1 { margin-bottom: 18px; font-size: clamp(32px, 10.7vw, 42px); letter-spacing: -.045em; }
  h2 { font-size: 30px; }
  .hero-lead { font-size: 16px; line-height: 1.5; }
  .hero-address { margin: 22px 0; }
  .hero-visual { min-height: 190px; }
  .placeholder-number { font-size: 180px; }
  .button { min-height: 48px; font-size: 13px; }
  .service-card { min-height: 0; padding: 24px 22px; }
  .service-card h3 { margin: 25px 0 12px; font-size: 17px; }
  .price-copy p { font-size: 17px; }
  .gallery-card > div { min-height: 190px; }
  blockquote { padding: 24px 22px; }
  blockquote p { font-size: 16px; }
  .contact-panel { padding: 22px 18px; }
  .contact-panel .actions { gap: 10px; }
  .map-wrap, .map-wrap iframe { min-height: 300px; }
  .map-wrap > a { right: 10px; bottom: 10px; left: 10px; text-align: center; }
  .route-grid > div:first-child > p:not(.eyebrow) { font-size: 16px; }
  .site-footer { padding: 30px 0; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; }
}
