:root{
  --bg:#1f1f1f;
  --bg-soft:#252525;
  --surface:#ffffff;
  --surface-soft:#f6f7fb;
  --text:#222222;
  --text-soft:#6e6e73;
  --text-inverse:#ffffff;
  --line:#e6e8ef;
  --line-dark:#2b2b31;
  --accent:#698cf0;
  --accent-strong:#86a3ff;
  --shadow:0 20px 54px rgba(0,0,0,.18);
  --shadow-soft:0 12px 28px rgba(30,34,44,.08);
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Montserrat","Open Sans",Arial,sans-serif;
  --radius:24px;
  --radius-button:6px;
  --radius-input:6px;
  --header-h:160px;
  --app-height:100vh;
  --browser-ui-offset:0px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-width:320px;
  min-height:100vh;
  overflow-x:hidden;
  background:var(--bg);
  color:var(--text);
  font:400 16px/1.7 var(--sans);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,textarea,select{font:inherit}
strong,b{font-weight:700}

.site-shell{
  min-height:100vh;
  background:linear-gradient(180deg,#222 0,var(--bg) 100%);
}

.wrap{
  width:min(1180px,calc(100% - 40px));
  margin:0 auto;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 28px;
  border:0;
  border-radius:var(--radius-button);
  font-size:15px;
  font-weight:700;
  letter-spacing:.045em;
  text-transform:uppercase;
  text-align:center;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease, background-color .18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  color:#fff;
  background:var(--accent);
  box-shadow:0 14px 28px rgba(105,140,240,.24);
}
.btn-secondary{
  color:var(--text);
  background:#fff;
  border:1px solid var(--line);
}
.btn-full{width:100%}
.btn-nav{min-height:56px;padding:0 30px}

.site-header{
  position:relative;
  z-index:40;
  background:#222;
  padding:28px 0 64px;
}
.header-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  min-width:0;
}
.brand-mark{
  width:210px;
  height:58px;
  flex:0 0 auto;
  background:url("./logo-old.png") center/contain no-repeat;
  font-size:0;
  color:transparent;
}
.brand-copy{display:none}

.top-contacts{
  display:flex;
  gap:44px;
  align-items:flex-start;
  justify-content:flex-end;
  padding-top:4px;
  min-width:0;
}
.top-contact{
  position:relative;
  min-width:220px;
  padding-right:74px;
  color:#d2d2d8;
  text-align:right;
  font-size:15px;
  line-height:1.45;
}
.top-contact strong{
  display:block;
  margin-bottom:2px;
  color:#d5d5da;
}
.top-contact a{display:inline-block}
.top-contact b{color:#fff}
.top-contact::after{
  content:"";
  position:absolute;
  top:-8px;
  right:0;
  width:60px;
  height:60px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}
.top-contact::before{
  content:"";
  position:absolute;
  top:10px;
  right:14px;
  z-index:1;
  width:30px;
  height:30px;
  background-position:center;
  background-repeat:no-repeat;
  background-size:30px 30px;
}
.top-contact--email::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Crect x='5.5' y='8.5' width='21' height='15' rx='3' fill='none' stroke='%23698cf0' stroke-width='2.6'/%3E%3Cpath d='M7.5 11.3 16 17l8.5-5.7' fill='none' stroke='%23698cf0' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.top-contact--phone::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath d='M10.8 6.8c.6-.6 1.5-.7 2.2-.2l2.6 1.8c.8.6 1 1.7.5 2.5l-1.3 2c-.3.5-.2 1.1.2 1.5l3.4 3.4c.4.4 1 .5 1.5.2l2-1.3c.8-.5 1.9-.3 2.5.5l1.8 2.6c.5.7.4 1.7-.2 2.2l-1.6 1.6c-1.4 1.4-4.6.5-8.4-3.3-3.8-3.8-4.7-7-3.3-8.4l1.6-1.6Z' fill='none' stroke='%23698cf0' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}

.main-nav-wrap{
  position:absolute;
  left:0;
  right:0;
  bottom:-38px;
}
.main-nav{
  display:flex;
  align-items:center;
  gap:clamp(14px,1.8vw,28px);
  min-height:106px;
  padding:18px clamp(16px,2vw,34px);
  background:#fff;
  border-radius:28px;
  box-shadow:var(--shadow);
}
.main-nav a{
  color:#24252b;
  font-size:clamp(12px,1.1vw,15px);
  font-weight:700;
  white-space:nowrap;
}
.main-nav a.is-active,
.main-nav a:hover{color:var(--accent)}
.nav-spacer{flex:1}

.menu-toggle,
.mobile-nav{display:none}

.hero{
  position:relative;
  overflow:hidden;
  min-height:calc(100svh - 24px);
  background:#151515;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("./dep.jpg") center center/cover no-repeat;
  transform:scale(1.02);
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.74) 0%,rgba(0,0,0,.56) 40%,rgba(0,0,0,.28) 72%,rgba(0,0,0,.18) 100%),
    linear-gradient(180deg,rgba(0,0,0,.24),rgba(0,0,0,.42));
}
.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,430px);
  gap:38px;
  align-items:center;
  min-height:calc(100svh - var(--header-h));
  padding:84px 0 58px;
}
.hero-copy{
  max-width:720px;
  color:#fff;
  padding:0 0 28px;
}
.kicker{
  display:block;
  margin:0 0 18px;
  color:#fff;
  font-size:24px;
  line-height:1.15;
}
.hero-title{
  margin:0;
  max-width:8.2ch;
  color:#fff;
  font:700 clamp(3rem,5.6vw,5.4rem)/.92 var(--sans);
  letter-spacing:-.02em;
  text-transform:uppercase;
}
.hero-title .accent{
  color:var(--accent);
  white-space:normal;
}
.hero-phone{
  display:inline-block;
  margin-top:28px;
  color:#fff;
  font-size:clamp(2rem,3.2vw,3.4rem);
  line-height:1;
  font-weight:700;
}
.hero-divider{
  width:58px;
  height:10px;
  margin-top:26px;
  background:url("./wave.png") left center/contain no-repeat;
  opacity:.95;
}

.hero-actions-card{
  width:100%;
  padding:32px 30px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(232,236,245,.92);
  border-radius:30px;
  box-shadow:0 24px 54px rgba(11,18,33,.18);
  backdrop-filter:blur(10px);
  transition:opacity .22s ease, visibility .22s ease, transform .22s ease;
}
.hero-actions-kicker{
  display:block;
  margin:0 0 12px;
  color:var(--accent);
  font-size:13px;
  line-height:1.2;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.hero-actions-title{
  margin:0;
  color:#22252d;
  font:700 clamp(1.6rem,2.1vw,2.15rem)/1.08 var(--sans);
  text-wrap:balance;
}
.hero-actions-text{
  margin:16px 0 0;
  color:#667087;
  font-size:16px;
  line-height:1.7;
}
.hero-actions-row{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:22px;
}
.hero-actions-btn{
  width:100%;
  min-height:60px;
  border-radius:18px;
}

.quote-form,
.consultation-form-card{
  width:100%;
  padding:36px 36px 30px;
  background:#fff url("./form-lines.png") center top/cover no-repeat;
  border:1px solid rgba(234,236,244,.92);
  border-radius:var(--radius);
  box-shadow:0 26px 54px rgba(0,0,0,.18);
}
.quote-form-heading{
  margin:0;
  color:#2b2c31;
  text-align:center;
  font:700 clamp(1.8rem,2.2vw,2.75rem)/.98 var(--sans);
  text-transform:uppercase;
  text-wrap:balance;
  overflow-wrap:anywhere;
}
.quote-form-subtitle{
  display:block;
  margin:8px 0 28px;
  color:#9a9ca5;
  text-align:center;
  font-size:16px;
}

#consultationForm,
.consultation-form{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.honeypot{display:none!important}
.field label{
  display:block;
  margin:0 0 8px;
  color:#5f6470;
  font-size:14px;
  font-weight:600;
}
.field input,
#consultationForm input[type="text"],
#consultationForm input[type="email"],
#consultationForm textarea{
  width:100%;
  min-height:68px;
  padding:0 22px;
  border:1px solid #edf0f6;
  border-radius:var(--radius-input);
  background:#fafbff;
  color:#2d2f35;
  font-size:18px;
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}
#consultationForm textarea{
  min-height:120px;
  padding:18px 22px;
  resize:vertical;
}
.field input:focus,
#consultationForm input:focus,
#consultationForm textarea:focus{
  border-color:rgba(105,140,240,.7);
  background:#fff;
  box-shadow:0 0 0 4px rgba(105,140,240,.08);
}
.consent-line{
  display:flex;
  align-items:flex-start;
  gap:14px;
  color:#7a7f8b;
  font-size:14px;
  line-height:1.65;
}
.consent-line input{
  width:28px;
  height:28px;
  min-width:28px;
  margin:2px 0 0;
}
.consent-line a{
  color:var(--accent);
  text-decoration:underline;
}
.turnstile-wrap{
  display:flex;
  justify-content:center;
}
.form-result{
  display:none;
  margin-top:18px;
  padding:18px 20px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.94);
  color:#343842;
  font-size:15px;
  line-height:1.65;
}
.form-result.show{display:block}
.form-result strong{
  display:block;
  margin-bottom:10px;
  font-size:17px;
}

.section{
  position:relative;
  padding:112px 0;
  background:var(--surface);
}
.section.alt,
.prices{background:#fbfbfd}
.section-dark{
  background:linear-gradient(180deg,#0d1533 0%,#171717 100%);
  color:#fff;
}
.section-head{
  max-width:860px;
  margin:0 auto 56px;
  text-align:center;
}
.section-heading{
  margin:0;
  color:#24252b;
  font:700 clamp(2.1rem,4vw,3.6rem)/1.08 var(--sans);
  text-transform:uppercase;
}
.section-heading .accent{color:var(--accent)}
.divider-line{
  width:98px;
  height:4px;
  margin:24px auto 0;
  border-radius:999px;
  background:var(--accent);
}
.section-lead{
  margin:28px auto 0;
  max-width:760px;
  color:var(--text-soft);
  font-size:18px;
  line-height:1.7;
}

.about-grid,
.price-grid,
.reviews-grid{
  display:grid;
  gap:28px;
}
.about-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.price-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.reviews-grid{grid-template-columns:1fr 1fr}

.about-box,
.price-card,
.review-panel,
.content-card{
  position:relative;
  height:100%;
  padding:30px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.about-box::before,
.price-card::before,
.review-panel::before,
.content-card::before{
  content:"";
  position:absolute;
  top:0;
  left:30px;
  width:72px;
  height:4px;
  border-radius:999px;
  background:var(--accent);
}
.about-title,
.price-card h3,
.review-panel h3,
.content-card h2,
.content-card h3{
  display:block;
  margin:14px 0 14px;
  color:#292b31;
  font-size:18px;
  line-height:1.35;
  font-weight:700;
  text-transform:uppercase;
}
.about-box p,
.price-card p,
.review-panel p,
.content-card p,
.content-card li{
  color:var(--text-soft);
  font-size:17px;
  line-height:1.8;
}
.content-stack{
  display:grid;
  gap:24px;
}
.content-card ul{
  margin:14px 0 0;
  padding-left:20px;
}
.content-card li+li{margin-top:10px}

.counter-band{
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%);
  color:#fff;
  padding:36px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.counter-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.counter-grid div{
  padding:16px 0;
  border-top:1px solid rgba(255,255,255,.12);
}
.counter-grid strong{
  display:block;
  margin-bottom:10px;
  color:var(--accent-strong);
  font-size:36px;
  line-height:1;
}
.counter-grid span{
  color:rgba(255,255,255,.82);
  font-size:14px;
  line-height:1.5;
}

.services-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,420px);
  gap:36px;
  align-items:start;
}
.services-list{
  margin:32px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:14px;
}
.services-list li,
.services-board li{
  position:relative;
  padding-left:22px;
  color:var(--text-soft);
  font-size:17px;
  line-height:1.75;
}
.services-list li::before,
.services-board li::before{
  content:"";
  position:absolute;
  top:.72em;
  left:0;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
}
.services-board{
  position:relative;
  padding:32px 30px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.services-board::before{
  content:"";
  position:absolute;
  inset:0 auto auto 30px;
  width:72px;
  height:4px;
  border-radius:999px;
  background:var(--accent);
}
.services-board ul{
  margin:18px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:14px;
}

.price-value{
  display:block;
  margin:10px 0 16px;
  color:var(--accent);
  font-size:clamp(2rem,3vw,3.1rem);
  line-height:1;
  font-weight:700;
}
.price-card .btn{margin-top:18px}

.review-panel iframe{
  display:block;
  width:100%;
  min-height:260px;
  border:0;
  border-radius:18px;
  background:#fff;
}

.inner-hero{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(11,18,47,.92),rgba(24,24,24,.94)),
    url("./dep.jpg") center/cover no-repeat;
  color:#fff;
  padding:84px 0 88px;
}
.inner-hero .kicker{
  margin:0 0 12px;
  color:var(--accent-strong);
  font-size:17px;
  text-transform:uppercase;
  letter-spacing:.1em;
}
.inner-hero h1{
  max-width:12ch;
  margin:0;
  color:#fff;
  font:600 clamp(2.5rem,5vw,4.5rem)/1.02 var(--serif);
}

.results-list{
  display:grid;
  gap:16px;
}
.result-row{
  display:grid;
  grid-template-columns:170px 1fr auto;
  gap:22px;
  align-items:center;
  padding:24px 26px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow-soft);
}
.result-ref{
  color:var(--accent);
  font-size:17px;
  font-weight:700;
}
.result-row > div:nth-child(2){
  color:var(--text-soft);
  font-size:17px;
  line-height:1.7;
}
.result-value{
  min-width:160px;
  padding:12px 16px;
  border-radius:14px;
  background:#f4f6ff;
  color:#2d2f35;
  text-align:center;
  font-size:15px;
  font-weight:700;
}

.consultation-block{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(11,18,47,.94),rgba(24,24,24,.94)),
    url("./dep.jpg") center/cover no-repeat;
  color:#fff;
  padding:96px 0;
}
.consultation-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,440px);
  gap:34px;
  align-items:center;
}
.consultation-copy h2{
  margin:0 0 18px;
  color:#fff;
  font:600 clamp(2.4rem,4.8vw,4rem)/1.06 var(--serif);
}
.consultation-copy p{
  margin:0;
  max-width:34rem;
  color:rgba(255,255,255,.78);
  font-size:18px;
  line-height:1.75;
}
.consultation-form-card{
  max-width:100%;
}

.consultation-lobby-page{
  position:relative;
  min-height:calc(100svh - 60px);
  padding:92px 0;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(11,18,47,.88),rgba(26,23,19,.88)),
    url("./dep.jpg") center/cover no-repeat;
}
.consultation-lobby-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:calc(100svh - 244px);
}

:root{
  --oa-unified-radius:22px;
}
.hero-actions-card,
.consultation-form-card,
.cw-window,
.cw-panel-intro,
.cw-panel-intro p,
.consultation-lobby-page .lobby-body,
.consultation-lobby-page .lobby-status-card,
.consultation-lobby-page .lobby-state{
  border-radius:var(--oa-unified-radius);
}
.hero-actions-btn,
.cw-start-btn,
.cw-send,
.cw-topic-btn,
.cw-status-btn,
.cw-continue-btn,
.cw-menu-item,
.consultation-lobby-page .btn,
.consultation-lobby-page .lobby-close{
  border-radius:var(--oa-unified-radius);
}
.hero-actions-kicker,
.cw-panel-kicker{
  display:none;
}
.hero-actions-text{
  max-width:32rem;
}
.consultation-lobby-page{
  background:
    linear-gradient(180deg,rgba(9,14,34,.94),rgba(17,16,18,.90)),
    url("./dep.jpg") center/cover no-repeat;
}
.consultation-lobby-page .lobby-topbar{
  color:rgba(255,255,255,.74);
  font-size:13px;
  letter-spacing:.12em;
}
.consultation-lobby-page .lobby-body{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(223,229,242,.92);
  box-shadow:0 26px 80px rgba(12,18,33,.26);
}
.consultation-lobby-page .lobby-body::before{
  background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(247,249,255,.95));
}
.consultation-lobby-page .lobby-body::after{
  right:-30px;
  bottom:-40px;
  width:240px;
  height:240px;
  background:radial-gradient(circle,rgba(105,140,240,.10),rgba(105,140,240,0));
}
.consultation-lobby-page .lobby-close{
  background:rgba(248,249,254,.96);
  border-color:rgba(222,228,242,.95);
  color:#6d7483;
}
.consultation-lobby-page .lobby-close:hover{
  background:#fff;
  color:#2b3038;
}
.consultation-lobby-page .lobby-eyebrow{
  color:rgba(106,128,209,.42);
  font-size:12px;
  letter-spacing:.16em;
}
.consultation-lobby-page .lobby-heading{
  color:#222631;
  font-family:inherit;
  font-size:clamp(2rem,4.3vw,3.7rem);
  font-weight:800;
  line-height:.96;
  letter-spacing:-.04em;
  max-width:9.2ch;
}
.consultation-lobby-page .lobby-subtitle{
  color:#6d7585;
  font-size:18px;
  line-height:1.6;
  max-width:44rem;
}
.consultation-lobby-page .lobby-status-card{
  background:rgba(255,255,255,.88);
  border-color:rgba(227,232,243,.92);
  backdrop-filter:blur(10px);
}
.consultation-lobby-page .lobby-status-title{
  color:#232833;
  font-size:19px;
  font-weight:800;
}
.consultation-lobby-page .lobby-status-copy{
  color:#757d8b;
  font-size:15px;
  line-height:1.6;
}
.consultation-lobby-page .lobby-state{
  min-height:64px;
  background:#f6f8fd;
  border-color:#e6ebf6;
  color:#2a2f39;
  font-size:17px;
}

.site-footer{
  background:#1f1f1f;
  color:#d4d4d9;
  padding:44px 0 52px;
  border-top:1px solid rgba(255,255,255,.05);
}
.footer-grid{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) repeat(2,minmax(0,.8fr));
  gap:26px;
  align-items:start;
}
.footer-title{
  display:block;
  margin-bottom:8px;
  color:#fff;
  font-size:13px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.footer-text{
  margin:18px 0 0;
  color:#b8bcc6;
  font-size:15px;
  line-height:1.7;
}

.cookie-bar{
  position:fixed;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 18px;
  background:rgba(31,31,31,.96);
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  box-shadow:0 18px 36px rgba(0,0,0,.28);
}
.cookie-bar[hidden]{display:none!important}
.cookie-bar p{margin:0;color:rgba(255,255,255,.8);font-size:14px}
.cookie-bar a{color:#fff;text-decoration:underline}

.cw-modal-overlay{
  position:fixed;
  inset:0;
  z-index:10020;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:
    linear-gradient(180deg,rgba(11,18,47,.72),rgba(26,23,19,.74)),
    url("./dep.jpg") center/cover no-repeat;
}
.cw-modal-overlay::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.14);
}
.cw-modal-overlay .quote-form,
.cw-modal-overlay .consultation-form-card{
  position:relative;
  z-index:1;
  width:min(100%,560px);
  max-height:min(88vh,820px);
  overflow:auto;
  padding-top:42px;
}
.cw-modal-close{
  position:absolute;
  top:18px;
  right:18px;
  z-index:2;
  width:50px;
  height:50px;
  border-radius:50%;
  border:1px solid rgba(227,230,240,.94);
  background:rgba(250,251,255,.96);
  color:#737886;
  font-size:30px;
  line-height:1;
  cursor:pointer;
}
.cw-modal-overlay .quote-form-heading{
  padding-right:68px;
  font:700 clamp(2rem,2.35vw,2.9rem)/.98 var(--sans);
  text-wrap:balance;
  overflow-wrap:anywhere;
}
.cw-modal-overlay .quote-form-subtitle{
  margin-top:12px;
}

@media (max-width:1180px){
  :root{--header-h:154px}
  .main-nav{gap:clamp(12px,1.4vw,22px);padding-inline:clamp(14px,1.8vw,28px)}
  .hero-grid,
  .consultation-grid{grid-template-columns:minmax(0,1fr) minmax(330px,410px)}
  .top-contacts{gap:28px}
  .top-contact{min-width:194px}
  .about-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:960px){
  :root{--header-h:120px}
  .site-header{
    padding:22px 0 0;
  }
  .top-contacts,
  .main-nav-wrap{display:none}
  .header-row{
    align-items:center;
    gap:16px;
  }
  .brand-mark{
    width:172px;
    height:48px;
  }
  .menu-toggle{
    display:inline-flex;
    width:72px;
    height:72px;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:9px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:16px;
    background:transparent;
    cursor:pointer;
  }
  .menu-toggle span{
    width:34px;
    height:3px;
    border-radius:999px;
    background:#fff;
  }
  .mobile-nav{
    display:none;
    margin-top:18px;
    padding:18px;
    border-radius:18px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.08);
  }
  .mobile-nav.open{
    display:grid;
    gap:10px;
  }
  .mobile-nav a{
    padding:12px 14px;
    border-radius:12px;
    background:rgba(255,255,255,.03);
    color:#fff;
    font-size:15px;
    font-weight:600;
  }
  .hero{
    min-height:auto;
  }
  .hero-grid{
    grid-template-columns:1fr;
    min-height:calc(100svh - var(--header-h));
    padding:34px 0 44px;
    align-items:end;
  }
  .hero-copy{
    max-width:min(560px,100%);
    padding:0 0 34px;
  }
  .hero-title{
    max-width:7.3ch;
    font-size:clamp(2.7rem,8vw,4.5rem);
  }
  .hero-phone{font-size:clamp(1.75rem,6vw,2.8rem)}
  .hero-actions-card{display:none}
  .services-grid,
  .consultation-grid,
  .reviews-grid,
  .footer-grid{
    grid-template-columns:1fr;
  }
  .counter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .result-row{
    grid-template-columns:1fr;
    gap:12px;
  }
  .result-value{justify-self:start}
  .inner-hero{
    padding:62px 0 70px;
  }
  .inner-hero h1{max-width:11ch}
  .consultation-lobby-page{
    padding:56px 0;
  }
  .consultation-lobby-wrap{
    min-height:auto;
  }
}

@media (max-width:640px){
  :root{--header-h:110px}
  body{font-size:15px}
  .wrap{width:min(100%,calc(100% - 22px))}
  .home .site-header{
    position:absolute;
    inset:0 0 auto;
    z-index:30;
    background:linear-gradient(180deg,rgba(31,31,31,.96) 0%, rgba(31,31,31,.92) 82%, rgba(31,31,31,0) 100%);
    overflow:clip;
  }
  .site-header{
    padding: max(18px,env(safe-area-inset-top)) 0 12px;
    overflow:clip;
  }
  .header-row{
    align-items:center;
    gap:10px;
  }
  .brand{
    flex:1 1 auto;
  }
  .brand-mark{
    width:150px;
    height:42px;
  }
  .menu-toggle{
    flex:0 0 58px;
    margin-left:auto;
    width:58px;
    height:58px;
    gap:7px;
    border-radius:14px;
  }
  .menu-toggle span{
    width:28px;
  }
  .hero{
    height:calc(var(--app-height) + var(--browser-ui-offset));
    min-height:calc(var(--app-height) + var(--browser-ui-offset));
  }
  .hero::before{
    inset:0;
    background-position:62% center;
    transform:none;
  }
  .hero-grid{
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    height:calc(var(--app-height) + var(--browser-ui-offset));
    min-height:calc(var(--app-height) + var(--browser-ui-offset));
    padding:calc(var(--header-h) + 28px) 0 calc(86px + env(safe-area-inset-bottom));
  }
  .hero-copy{
    max-width:min(340px,84vw);
    margin-top:0;
    padding:clamp(110px,18svh,168px) 0 clamp(44px,6svh,72px);
    align-self:flex-start;
  }
  .kicker{
    margin-bottom:8px;
    font-size:16px;
  }
  .hero-title{
    max-width:6.4ch;
    font-size:clamp(1.8rem,7.9vw,2.7rem);
    line-height:.95;
  }
  .hero-phone{
    margin-top:16px;
    font-size:clamp(1.18rem,5.4vw,1.72rem);
  }
  .hero-divider{display:none}
  .section{
    padding:76px 0;
  }
  .section-head{
    margin-bottom:34px;
  }
  .section-heading{
    font-size:clamp(1.65rem,8vw,2.6rem);
    line-height:1.08;
  }
  .section-lead{
    margin-top:18px;
    font-size:16px;
  }
  .about-grid,
  .price-grid{
    grid-template-columns:1fr;
  }
  .about-box,
  .price-card,
  .review-panel,
  .content-card{
    padding:24px 20px;
  }
  .about-box::before,
  .price-card::before,
  .review-panel::before,
  .content-card::before{
    left:20px;
  }
  .counter-band{padding:24px 0}
  .counter-grid{grid-template-columns:1fr}
  .services-board{padding:26px 20px}
  .services-board::before{left:20px}
  .price-value{font-size:2.35rem}
  .inner-hero h1{
    font-size:clamp(2rem,12vw,3rem);
  }
  .consultation-block{
    padding:76px 0;
  }
  .consultation-copy h2{
    font-size:clamp(1.9rem,11vw,3rem);
  }
  .consultation-copy p{
    font-size:16px;
  }
  .consultation-form-card,
  .cw-modal-overlay .consultation-form-card,
  .cw-modal-overlay .quote-form{
    width:100%;
    max-width:none;
    max-height:calc(100dvh - 8px);
    margin:0;
    padding:26px 18px calc(18px + env(safe-area-inset-bottom));
    border-radius:28px 28px 0 0;
    box-shadow:0 26px 60px rgba(9,13,24,.28);
  }
  .quote-form-heading{
    padding-right:58px;
    text-align:left;
    font-size:clamp(1.5rem,8.2vw,2.15rem);
    line-height:.94;
    letter-spacing:-.03em;
  }
  .quote-form-subtitle{
    margin:10px 0 20px;
    text-align:left;
    font-size:14px;
    line-height:1.45;
  }
  .field input,
  #consultationForm input[type="text"],
  #consultationForm input[type="email"],
  #consultationForm textarea{
    min-height:58px;
    padding-inline:18px;
    font-size:16px;
  }
  .consent-line{
    gap:10px;
    font-size:12.5px;
    line-height:1.55;
  }
  .consent-line input{
    width:22px;
    height:22px;
    min-width:22px;
    margin-top:1px;
  }
  .cookie-bar{
    left:12px;
    right:12px;
    bottom:12px;
    flex-direction:column;
    align-items:flex-start;
  }
  .cw-modal-overlay{
    align-items:flex-end;
    padding:0;
    background:
      linear-gradient(180deg,rgba(9,13,24,.52),rgba(17,18,22,.7)),
      url("./dep.jpg") center/cover no-repeat;
  }
  .cw-modal-close{
    top:12px;
    right:12px;
    width:44px;
    height:44px;
    border-color:rgba(224,228,238,.92);
    background:rgba(247,249,255,.94);
    color:#818796;
    font-size:24px;
    box-shadow:0 8px 18px rgba(21,26,39,.12);
  }
}

@media (max-width:420px){
  .hero-grid{
    padding-top:calc(var(--header-h) + 18px);
    padding-bottom:calc(78px + env(safe-area-inset-bottom));
  }
  .hero-copy{
    padding-top:clamp(94px,15svh,138px);
  }
  .hero-title{
    max-width:6.05ch;
    font-size:clamp(1.7rem,7.4vw,2.45rem);
  }
  .hero-phone{
    font-size:clamp(1.08rem,5.1vw,1.52rem);
  }
  .section-heading{
    font-size:clamp(1.5rem,7.6vw,2.2rem);
  }
}
