/* ============================================================
   AD GARAGE — components
   ============================================================ */

/* ---------------- HEADER ---------------- */
.topbar{
  background: #0b0b0f;
  color: var(--bone-dim);
  font-size: 13px;
  border-bottom: 1px solid var(--line-dark);
}
.topbar .container{ display:flex; align-items:center; justify-content:space-between; height:38px; gap:18px; }
.topbar .tb-left{ display:flex; gap:22px; align-items:center; }
.topbar .tb-item{ display:inline-flex; gap:.5em; align-items:center; white-space:nowrap; }
.topbar .tb-item .ico{ width:14px;height:14px;color:var(--red); }
@media (max-width:760px){
  .topbar .tb-item.hide-sm, .topbar .tb-tail.hide-sm{ display:none; }
  .topbar .container{ gap:10px; font-size:12px; }
  .topbar .tb-left{ gap:10px; min-width:0; flex:1 1 auto; }
  .topbar .container > a.tb-item{ flex:0 0 auto; }
}

/* ── back to top button ── */
.to-top{
  position:fixed; right:16px; bottom:84px; z-index:60;
  width:46px; height:46px; border-radius:50%;
  background:var(--red); color:#fff; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 26px -8px rgba(194,13,24,.8);
  opacity:0; visibility:hidden; transform:translateY(12px);
  transition:opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
}
.to-top.show{ opacity:1; visibility:visible; transform:translateY(0); }
.to-top:hover{ background:#a50b14; }
.to-top svg{ width:22px; height:22px; }
@media (min-width:821px){ .to-top{ bottom:28px; } }

.header{
  position: sticky; top:0; z-index: 60;
  background: rgba(15,15,20,.78);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line-dark);
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.header.scrolled{ background: rgba(11,11,15,.95); }
.header .container{ display:flex; align-items:center; gap:24px; height:74px; }

.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand img{ height:46px; width:auto; }
.brand .bk{ display:flex; flex-direction:column; line-height:1; }
.brand .bk b{ font-family:var(--font-display); font-size:20px; letter-spacing:.04em; color:var(--bone); }
.brand .bk span{ font-size:10.5px; letter-spacing:.32em; text-transform:uppercase; color:var(--bone-dim); margin-top:3px; }
.brand .brand-loc{
  align-self:center; margin-left:4px; padding-left:11px; border-left:1px solid var(--line-dark-2);
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.16em; font-size:13px;
  color:var(--red-bright); font-weight:600;
}
@media (max-width:520px){ .brand .brand-loc{ display:none; } }
/* pin label on zone map */
.zone-map .pin-label{
  position:absolute; top:calc(50% + 16px); left:50%; transform:translateX(-50%);
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em; font-size:15px;
  color:var(--bone); background:rgba(11,11,15,.78); padding:5px 12px; border-radius:var(--radius);
  border:1px solid var(--line-dark-2); white-space:nowrap;
}

.nav{ display:flex; align-items:center; gap:6px; margin-left:auto; }
.nav a{
  padding:10px 14px; font-weight:600; font-size:14.5px; color:var(--bone-dim);
  border-radius: var(--radius); transition:color .15s, background .15s; position:relative;
}
.nav a:hover{ color:var(--bone); }
.nav a::after{
  content:""; position:absolute; left:14px; right:14px; bottom:6px; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .22s var(--ease);
}
.nav a:hover::after{ transform:scaleX(1); }

.header-actions{ display:flex; align-items:center; gap:14px; flex-shrink:0; }

.lang{ display:flex; border:1px solid var(--line-dark-2); border-radius:999px; overflow:hidden; }
.lang button{ padding:6px 11px; font-size:12.5px; font-weight:700; color:var(--bone-dim); letter-spacing:.04em; transition:.15s; }
.lang button.active{ background:var(--red); color:#fff; }
.lang button:not(.active):hover{ color:var(--bone); background:rgba(236,230,217,.06); }

.header .call-btn{ display:inline-flex; flex-shrink:0; }
.burger{ display:none; width:44px;height:44px; align-items:center; justify-content:center; }
.burger span{ display:block; width:22px; height:2px; background:var(--bone); position:relative; transition:.25s; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:22px; height:2px; background:var(--bone); transition:.25s; }
.burger span::before{ top:-7px; } .burger span::after{ top:7px; }
.burger.open span{ background:transparent; }
.burger.open span::before{ top:0; transform:rotate(45deg); }
.burger.open span::after{ top:0; transform:rotate(-45deg); }

@media (max-width: 1140px){
  .nav, .header .call-btn .txt{ display:none; }
  .burger{ display:flex; }
}

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:80; background:rgba(8,8,11,.6);
  backdrop-filter: blur(6px); opacity:0; pointer-events:none; transition:opacity .25s;
}
.drawer.open{ opacity:1; pointer-events:auto; }
.drawer .panel{
  position:absolute; top:0; right:0; height:100%; width:min(86vw,340px);
  background:var(--ink-soft); border-left:3px solid var(--red);
  padding:26px 24px; display:flex; flex-direction:column; gap:6px;
  transform:translateX(100%); transition:transform .3s var(--ease);
  overflow-y:auto;
}
.drawer.open .panel{ transform:none; }
.drawer .panel a{ padding:14px 6px; font-family:var(--font-display); text-transform:uppercase; font-size:19px; letter-spacing:.03em; border-bottom:1px solid var(--line-dark); }
.drawer .panel a:hover{ color:var(--red-bright); }
.drawer .d-close{ align-self:flex-end; font-size:30px; line-height:1; color:var(--bone-dim); }

/* ---------------- HERO ---------------- */
.hero{ background:var(--ink); position:relative; overflow:hidden; }
.hero .grid-bg{
  position:absolute; inset:0; opacity:.5;
  background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);
  background-size:64px 64px; mask-image:radial-gradient(120% 90% at 20% 0%,#000 30%,transparent 75%);
  pointer-events:none;
}
.hero .container{ position:relative; display:grid; grid-template-columns: 1.04fr .96fr; gap: clamp(28px,4vw,60px); align-items:center; padding-block: clamp(48px,7vw,96px); }
.hero-copy{ max-width: 600px; }
.hero h1{
  font-size: clamp(40px, 6.6vw, 88px);
  margin:.28em 0 0;
  color:var(--bone);
}
.hero h1 .accent{ color:var(--red-bright); display:block; }
.hero .lead{ font-size: clamp(16px,1.5vw,20px); color:var(--bone-dim); margin-top:22px; max-width:48ch; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.hero-trust{ display:flex; gap:10px; flex-wrap:wrap; margin-top:30px; }

.hero-media{ position:relative; }
.hero-media .frame{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--line-dark-2);
  box-shadow: var(--shadow-card);
  aspect-ratio: 1099/1320; background:#0a0a0d;
}
.hero-media .frame img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; }
.hero-media .frame::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(10,10,13,.55)); }
.hero-media .corner{ position:absolute; width:46px;height:46px; border:3px solid var(--red); }
.hero-media .corner.tl{ top:-3px; left:-3px; border-right:0;border-bottom:0; }
.hero-media .corner.br{ bottom:-3px; right:-3px; border-left:0;border-top:0; }
.hero-badge{
  position:absolute; left:-18px; bottom:34px; z-index:3;
  background:var(--paper-card); color:var(--ink-text);
  border-radius:var(--radius); padding:14px 18px; box-shadow:var(--shadow-card);
  display:flex; align-items:center; gap:13px; max-width:260px;
}
.hero-badge .big{ font-family:var(--font-display); font-size:34px; line-height:.9; color:var(--red); }
.hero-badge small{ display:block; font-size:12.5px; color:var(--ink-dim); line-height:1.3; }
.hero-badge .t{ font-weight:700; font-size:14px; }

@media (max-width: 920px){
  .hero .container{ grid-template-columns:1fr; }
  .hero-media{ order:-1; max-width:520px; }
  .hero-media .frame{ aspect-ratio:16/10; }
  .hero-media .frame img{ object-position:center 32%; }
  .hero-badge{ left:auto; right:14px; bottom:14px; }
}

/* ---------------- STRIP (trust) ---------------- */
.strip{ background:var(--ink-soft); border-block:1px solid var(--line-dark); }
.strip .container{ display:grid; grid-template-columns:repeat(3,1fr); }
.strip .cell{ display:flex; gap:16px; align-items:flex-start; padding: clamp(26px,3.4vw,40px) clamp(18px,2.4vw,40px); border-right:1px solid var(--line-dark); }
.strip .cell:last-child{ border-right:0; }
.strip .cell .ico{ width:30px;height:30px;color:var(--red);flex-shrink:0; }
.strip .cell h3{ font-size:18px; letter-spacing:.02em; color:var(--bone); }
.strip .cell p{ font-size:14.5px; color:var(--bone-dim); margin-top:5px; line-height:1.45; }
@media (max-width:780px){ .strip .container{ grid-template-columns:1fr; } .strip .cell{ border-right:0; border-bottom:1px solid var(--line-dark); } .strip .cell:last-child{ border-bottom:0; } }

/* marquee of brands */
.marquee{ background:var(--ink); border-bottom:1px solid var(--line-dark); overflow:hidden; padding:18px 0; }
.marquee .track{ display:flex; gap:54px; width:max-content; animation:scroll 32s linear infinite; }
.marquee:hover .track{ animation-play-state:paused; }
.marquee span{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em; font-size:20px; color:rgba(236,230,217,.3); white-space:nowrap; }
@keyframes scroll{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee .track{ animation:none; } }

/* ---------------- SERVICES ---------------- */
.services-grid{ grid-template-columns:repeat(3,1fr); margin-top:48px; }
@media (max-width:900px){ .services-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .services-grid{ grid-template-columns:1fr;} }
.svc{
  background:var(--paper-card); border:1px solid var(--line-light);
  border-radius:var(--radius-lg); padding:28px 26px 26px; position:relative; overflow:hidden;
  transition:transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s;
}
.svc:hover{ transform:translateY(-4px); box-shadow:var(--shadow-soft); border-color:var(--line-light-2); }
.svc::before{ content:""; position:absolute; top:0;left:0; width:0; height:3px; background:var(--red); transition:width .3s var(--ease); }
.svc:hover::before{ width:100%; }
.svc .ico-wrap{ width:52px;height:52px; border-radius:var(--radius); background:rgba(194,13,24,.09); display:flex;align-items:center;justify-content:center; color:var(--red); margin-bottom:18px; }
.svc .ico-wrap .ico{ width:27px;height:27px; }
.svc h3{ font-size:21px; color:var(--ink-text); letter-spacing:.01em; }
.svc p{ font-size:14.5px; color:var(--ink-dim); margin-top:9px; line-height:1.5; }
.svc .from{ margin-top:16px; font-family:var(--font-display); font-size:15px; color:var(--ink-text); display:flex; align-items:baseline; gap:7px; }
.svc .from b{ color:var(--red); font-size:20px; }
.svc .from small{ font-family:var(--font-body); font-weight:500; color:var(--ink-dim); text-transform:none; letter-spacing:0; }

/* ---------------- PROCESS ---------------- */
.steps{ counter-reset:step; margin-top:54px; display:grid; grid-template-columns:repeat(5,1fr); gap:0; }
.step{ position:relative; padding:0 22px; }
.step:not(:last-child)::after{ content:""; position:absolute; top:26px; left:calc(50% + 30px); right:calc(-50% + 30px); height:2px; background:var(--line-dark); }
.step .num{
  counter-increment:step; width:54px;height:54px; border-radius:50%;
  border:2px solid var(--red); color:var(--red);
  display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:24px;
  background:var(--ink); position:relative; z-index:1;
}
.step .num::before{ content:counter(step,decimal-leading-zero); }
.step h4{ font-size:17px; margin-top:20px; color:var(--bone); letter-spacing:.02em; }
.step p{ font-size:14px; color:var(--bone-dim); margin-top:7px; line-height:1.45; }
@media (max-width:860px){
  .steps{ grid-template-columns:1fr; gap:8px; }
  .step{ padding:0 0 0 76px; min-height:64px; }
  .step .num{ position:absolute; left:0; top:0; }
  .step:not(:last-child)::after{ top:54px; bottom:-8px; left:26px; right:auto; width:2px; height:auto; }
  .step h4{ margin-top:2px; }
}

/* ---------------- PRICE LIST ---------------- */
.price-grid{ grid-template-columns:repeat(2,1fr); margin-top:46px; gap:clamp(18px,2.4vw,30px); }
@media (max-width:760px){ .price-grid{ grid-template-columns:1fr; } }
.price-card{ background:var(--paper-card); border:1px solid var(--line-light); border-radius:var(--radius-lg); padding:28px 28px 14px; }
.price-card > h3{ font-size:19px; color:var(--ink-text); display:flex; align-items:center; gap:11px; padding-bottom:16px; border-bottom:2px solid var(--red); margin-bottom:6px; }
.price-card > h3 .ico{ width:22px;height:22px;color:var(--red); }
.price-row{ display:flex; justify-content:space-between; align-items:baseline; gap:16px; padding:13px 0; border-bottom:1px solid var(--line-light); }
.price-row:last-child{ border-bottom:0; }
.price-row .nm{ font-size:15px; color:var(--ink-text); font-weight:500; }
.price-row .nm small{ display:block; font-size:12.5px; color:var(--ink-dim); font-weight:500; margin-top:2px; }
.price-row .val{ font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--ink-text); white-space:nowrap; }
.price-note{ margin-top:30px; font-size:13.5px; color:var(--ink-dim); display:flex; gap:8px; align-items:flex-start; }
.price-note .ico{ width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--red); }

/* ---------------- CALCULATOR ---------------- */
.calc{ display:grid; grid-template-columns: 1.15fr .85fr; gap:clamp(24px,3vw,44px); margin-top:48px; align-items:start; }
@media (max-width:880px){ .calc{ grid-template-columns:1fr; } }
.calc-panel{ background:var(--card-dark); border:1px solid var(--line-dark); border-radius:var(--radius-lg); padding:clamp(22px,2.6vw,34px); }
.calc-group{ margin-bottom:24px; }
.calc-group > label{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em; font-size:13px; color:var(--bone-dim); display:block; margin-bottom:12px; }
.opt-row{ display:flex; flex-wrap:wrap; gap:10px; }
.opt{
  border:1px solid var(--line-dark-2); border-radius:var(--radius); padding:11px 15px;
  font-size:14px; font-weight:600; color:var(--bone-dim); display:inline-flex; gap:8px; align-items:center;
  transition:.15s; user-select:none;
}
.opt:hover{ border-color:var(--bone); color:var(--bone); }
.opt.sel{ border-color:var(--red); background:rgba(194,13,24,.12); color:var(--bone); }
.opt .tick{ width:16px;height:16px; border:1.5px solid currentColor; border-radius:3px; display:inline-flex;align-items:center;justify-content:center; }
.opt.sel .tick{ background:var(--red); border-color:var(--red); }
.opt.sel .tick::after{ content:"✓"; font-size:11px; color:#fff; }
.switch-row{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px 0; border-top:1px solid var(--line-dark); }
.switch-row span{ font-size:14.5px; }
.switch{ width:50px; height:28px; border-radius:999px; background:var(--card-dark-2); border:1px solid var(--line-dark-2); position:relative; transition:.2s; flex-shrink:0; }
.switch::after{ content:""; position:absolute; top:2px;left:2px; width:22px;height:22px;border-radius:50%; background:var(--bone-dim); transition:.2s; }
.switch.on{ background:var(--red); border-color:var(--red); }
.switch.on::after{ left:24px; background:#fff; }
.range-wrap{ display:flex; flex-direction:column; gap:8px; }
.range-wrap input[type=range]{ width:100%; accent-color:var(--red); }
.range-val{ font-family:var(--font-display); font-size:16px; color:var(--bone); }

.calc-result{ position:sticky; top:96px; background:linear-gradient(160deg,var(--card-dark),var(--ink-soft)); border:1px solid var(--line-dark-2); border-radius:var(--radius-lg); padding:clamp(24px,2.6vw,32px); }
.calc-result .lbl{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em; font-size:13px; color:var(--bone-dim); }
.calc-result .amount{ font-family:var(--font-display); font-size:clamp(38px,5vw,58px); line-height:1; color:var(--bone); margin:10px 0 4px; }
.calc-result .amount .cur{ color:var(--red); font-size:.5em; }
.calc-result .hint{ font-size:13px; color:var(--bone-dim); }
.calc-result ul.bd{ margin:20px 0; border-top:1px solid var(--line-dark); }
.calc-result ul.bd li{ display:flex; justify-content:space-between; gap:12px; font-size:13.5px; padding:9px 0; border-bottom:1px solid var(--line-dark); color:var(--bone-dim); }
.calc-result ul.bd li b{ color:var(--bone); font-weight:600; }
.calc-result .btn{ width:100%; }
.calc-result .disc{ font-size:12px; color:var(--bone-dim); margin-top:14px; text-align:center; line-height:1.4; }

/* ---------------- VIDEO / GALLERY ---------------- */
.video-grid{ grid-template-columns:1.4fr 1fr 1fr; grid-auto-rows:1fr; margin-top:46px; }
@media (max-width:820px){ .video-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .video-grid{ grid-template-columns:1fr; } }
.vthumb{
  position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:200px;
  border:1px solid var(--line-light); background-size:cover; background-position:center; background:
    repeating-linear-gradient(135deg,#e4ddcd,#e4ddcd 14px,#ddd5c2 14px,#ddd5c2 28px);
  display:flex; align-items:flex-end; padding:18px; cursor:pointer; text-decoration:none;
  transition:transform .2s var(--ease);
}
.vthumb:first-child{ grid-row:span 2; }
@media (max-width:820px){ .vthumb:first-child{ grid-row:auto; grid-column:span 2; } }
@media (max-width:520px){ .vthumb:first-child{ grid-column:auto; } }
.vthumb:hover{ transform:translateY(-3px); }
.vthumb .play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:62px;height:62px; border-radius:50%; background:var(--red); display:flex;align-items:center;justify-content:center; box-shadow:0 10px 30px -10px rgba(194,13,24,.9); }
.vthumb .play::after{ content:""; border-left:18px solid #fff; border-top:11px solid transparent; border-bottom:11px solid transparent; margin-left:4px; }
.vthumb .vcap{ position:relative; z-index:2; background:rgba(11,11,15,.82); color:var(--bone); padding:8px 13px; border-radius:var(--radius); font-size:13px; font-weight:600; backdrop-filter:blur(3px); }
.vthumb .ph-tag{ position:absolute; top:12px; left:12px; font-family:monospace; font-size:11px; color:var(--ink-dim); background:rgba(251,249,243,.8); padding:3px 7px; border-radius:3px; }

/* ---------------- TESTIMONIALS ---------------- */
.tst-grid{ grid-template-columns:repeat(3,1fr); margin-top:46px; }
@media (max-width:840px){ .tst-grid{ grid-template-columns:1fr; max-width:560px; } }
.tst{ background:var(--paper-card); border:1px solid var(--line-light); border-radius:var(--radius-lg); padding:28px 26px; display:flex; flex-direction:column; }
.tst .stars{ color:var(--red); letter-spacing:3px; font-size:16px; }
.tst blockquote{ font-size:16px; color:var(--ink-text); line-height:1.55; margin:14px 0 18px; flex:1; }
.tst .who{ display:flex; align-items:center; gap:12px; border-top:1px solid var(--line-light); padding-top:16px; }
.tst .av{ width:42px;height:42px;border-radius:50%; background:var(--paper-2); display:flex;align-items:center;justify-content:center; font-family:var(--font-display); font-size:18px; color:var(--ink-text); }
.tst .who b{ font-size:14.5px; color:var(--ink-text); }
.tst .who small{ display:block; font-size:12.5px; color:var(--ink-dim); }

/* ---------------- FAQ ---------------- */
.faq{ margin-top:42px; max-width:840px; }
.faq-item{ border-bottom:1px solid var(--line-light); }
.faq-q{ width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:18px; padding:22px 4px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.01em; font-size:18px; color:var(--ink-text); }
.faq-q .pm{ width:26px;height:26px;flex-shrink:0; position:relative; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; background:var(--red); transition:.25s; }
.faq-q .pm::before{ top:12px;left:3px; width:20px;height:2px; }
.faq-q .pm::after{ left:12px;top:3px; width:2px;height:20px; }
.faq-item.open .pm::after{ transform:rotate(90deg); opacity:0; }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .3s var(--ease); }
.faq-a .inner{ padding:0 4px 22px; font-size:15.5px; color:var(--ink-dim); line-height:1.6; max-width:70ch; }

/* ---------------- ZONE ---------------- */
.zone{ position:relative; background:var(--ink); overflow:hidden; }
.zone .bg{ position:absolute; inset:0; background:url('../assets/zone-tex-opt.jpg') center/cover; background-image:image-set(url('../assets/zone-tex.webp') type('image/webp'), url('../assets/zone-tex-opt.jpg') type('image/jpeg')); background-size:cover; background-position:center; opacity:.22; }
.zone .bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,var(--ink) 8%,rgba(15,15,20,.55)); }
.zone .container{ position:relative; display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,60px); align-items:center; }
@media (max-width:820px){ .zone .container{ grid-template-columns:1fr; } }
.zone-cities{ display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.zone-city{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.04em; font-size:17px; color:var(--bone); border:1px solid var(--line-dark-2); border-radius:var(--radius); padding:11px 16px; display:flex; gap:9px; align-items:center; }
.zone-city .ico{ width:15px;height:15px;color:var(--red); }
.zone-map{ aspect-ratio:4/3; border-radius:var(--radius-lg); border:1px solid var(--line-dark-2); position:relative; overflow:hidden; background:
  repeating-linear-gradient(135deg,#15151c,#15151c 16px,#191921 16px,#191921 32px); }
.zone-map .ring{ position:absolute; top:50%;left:50%; transform:translate(-50%,-50%); border:2px dashed var(--red); border-radius:50%; opacity:.6; }
.zone-map .ring.r1{ width:48%; aspect-ratio:1; } .zone-map .ring.r2{ width:74%; aspect-ratio:1; opacity:.35; } .zone-map .ring.r3{ width:100%; aspect-ratio:1; opacity:.18; }
.zone-map .pin{ position:absolute; top:50%;left:50%; transform:translate(-50%,-100%); width:22px;height:22px; }
.zone-map .pin::before{ content:""; position:absolute; inset:0; background:var(--red); border-radius:50% 50% 50% 0; transform:rotate(-45deg); box-shadow:0 6px 18px -4px rgba(194,13,24,.9); }
.zone-map .pin::after{ content:""; position:absolute; top:6px;left:6px; width:10px;height:10px;border-radius:50%; background:var(--ink); }
.zone-map .ph-tag{ position:absolute; bottom:12px; left:12px; font-family:monospace; font-size:11px; color:var(--bone-dim); background:rgba(11,11,15,.7); padding:3px 8px; border-radius:3px; }

/* ---------------- LEAD FORM ---------------- */
.lead{ background:var(--ink-soft); }
.lead .container{ display:grid; grid-template-columns: .92fr 1.08fr; gap:clamp(30px,4vw,64px); align-items:start; }
@media (max-width:900px){ .lead .container{ grid-template-columns:1fr; } }
.lead-info h2{ font-size:clamp(30px,4vw,52px); color:var(--bone); }
.lead-info .contacts{ margin-top:30px; display:flex; flex-direction:column; gap:18px; }
.lead-info .ct{ display:flex; gap:14px; align-items:flex-start; }
.lead-info .ct .ico{ width:22px;height:22px;color:var(--red); flex-shrink:0; margin-top:3px; }
.lead-info .ct .k{ font-size:12.5px; text-transform:uppercase; letter-spacing:.12em; color:var(--bone-dim); }
.lead-info .ct .v{ font-size:19px; font-family:var(--font-display); color:var(--bone); }
.lead-info .ct a.v:hover{ color:var(--red-bright); }

.form-card{ background:var(--card-dark); border:1px solid var(--line-dark-2); border-radius:var(--radius-lg); padding:clamp(24px,2.8vw,38px); box-shadow:var(--shadow-card); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:13px; font-weight:600; color:var(--bone-dim); margin-bottom:7px; }
.field label .req{ color:var(--red); }
.field input, .field select, .field textarea{
  width:100%; background:var(--ink); border:1px solid var(--line-dark-2); border-radius:var(--radius);
  padding:13px 14px; font-size:15px; color:var(--bone); transition:border-color .15s, box-shadow .15s;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input::placeholder, .field textarea::placeholder{ color:#5c5a52; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(194,13,24,.18); }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a7a195' stroke-width='1.6' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }
.field.invalid input, .field.invalid select, .field.invalid textarea{ border-color:var(--red-bright); }
.field .err{ display:none; color:var(--red-bright); font-size:12.5px; margin-top:6px; }
.field.invalid .err{ display:block; }
.row2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:520px){ .row2{ grid-template-columns:1fr; } }
.hp{ position:absolute; left:-9999px; width:1px;height:1px; overflow:hidden; }
.consent{ display:flex; gap:11px; align-items:flex-start; font-size:13px; color:var(--bone-dim); margin:6px 0 20px; line-height:1.45; }
.consent input{ width:18px;height:18px; margin-top:2px; accent-color:var(--red); flex-shrink:0; }
.consent a{ color:var(--red-bright); text-decoration:underline; }
.form-card .btn{ width:100%; }
.flash{ display:none; }

/* success state */
.form-success{ display:none; text-align:center; padding:20px 6px; }
.form-success.show{ display:block; }
.form-success .ok{ width:74px;height:74px; border-radius:50%; background:rgba(35,160,90,.14); border:2px solid #2fae6a; display:flex;align-items:center;justify-content:center; margin:0 auto 18px; }
.form-success .ok::after{ content:""; width:24px;height:13px; border-left:3px solid #2fae6a; border-bottom:3px solid #2fae6a; transform:rotate(-45deg) translate(2px,-3px); }
.form-success h3{ color:var(--bone); font-size:24px; }
.form-success p{ color:var(--bone-dim); margin-top:10px; font-size:15px; }
.mailpreview{ text-align:left; margin-top:22px; background:var(--ink); border:1px solid var(--line-dark); border-radius:var(--radius); padding:16px; font-size:13px; }
.mailpreview .mp-h{ font-family:monospace; color:var(--bone-dim); border-bottom:1px solid var(--line-dark); padding-bottom:10px; margin-bottom:10px; }
.mailpreview .mp-h b{ color:var(--bone); }
.mailpreview .mp-b{ color:var(--bone-dim); line-height:1.5; }

/* ---------------- FOOTER ---------------- */
.footer{ background:#0b0b0f; color:var(--bone-dim); padding-top:64px; border-top:1px solid var(--line-dark); }
.footer .top{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:36px; padding-bottom:48px; border-bottom:1px solid var(--line-dark); }
@media (max-width:760px){ .footer .top{ grid-template-columns:1fr; gap:30px; } }
.footer .fbrand img{ height:64px; }
.footer .fbrand p{ margin-top:16px; font-size:14px; max-width:36ch; line-height:1.55; }
.footer .socials{ display:flex; gap:10px; margin-top:20px; }
.footer .socials a{ width:40px;height:40px;border-radius:var(--radius); border:1px solid var(--line-dark-2); display:flex;align-items:center;justify-content:center; transition:.18s; }
.footer .socials a:hover{ background:var(--red); border-color:var(--red); color:#fff; }
.footer .socials .ico{ width:18px;height:18px; }
.footer h5{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em; font-size:14px; color:var(--bone); margin-bottom:16px; }
.footer .fcol a, .footer .fcol p{ display:block; font-size:14px; padding:5px 0; }
.footer .fcol a:hover{ color:var(--bone); }
.footer .bottom{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding:24px 0 30px; font-size:13px; }
.footer .bottom a{ color:var(--bone-dim); } .footer .bottom a:hover{ color:var(--bone); }

/* floating mobile call */
.fab{ position:fixed; right:18px; bottom:18px; z-index:55; display:none; width:58px;height:58px; border-radius:50%; background:var(--red); box-shadow:0 12px 30px -8px rgba(194,13,24,.9); align-items:center;justify-content:center; animation:pulse 2.6s infinite; }
.fab .ico{ width:26px;height:26px;color:#fff; }
@keyframes pulse{ 0%,100%{ box-shadow:0 12px 30px -8px rgba(194,13,24,.7);} 50%{ box-shadow:0 12px 38px -6px rgba(194,13,24,1);} }
@media (prefers-reduced-motion: reduce){ .fab{ animation:none; } }

/* mobile sticky action bar */
.mobile-bar{ display:none; }
@media (max-width:1040px){
  .mobile-bar{
    display:grid; grid-template-columns:1fr 1fr; gap:10px;
    position:fixed; left:0; right:0; bottom:0; z-index:56;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));
    background:rgba(11,11,15,.93); backdrop-filter:blur(12px);
    border-top:1px solid var(--line-dark);
  }
  body{ padding-bottom:80px; }
  .fab{ display:none !important; }
}
.mb-btn{
  display:flex; align-items:center; justify-content:center; gap:9px; height:54px;
  border-radius:var(--radius); font-family:var(--font-display); text-transform:uppercase;
  letter-spacing:.03em; font-weight:600; font-size:15px;
}
.mb-btn.solid{ background:var(--red); color:#fff; box-shadow:0 10px 24px -12px rgba(194,13,24,.9); }
.mb-btn.ghost{ background:var(--card-dark); color:var(--bone); border:1px solid var(--line-dark-2); }
.mb-btn .ico{ width:19px;height:19px; flex-shrink:0; }
.mb-btn:active{ transform:translateY(1px); }

/* mobile: full-width hero CTAs + tighter rhythm */
@media (max-width:560px){
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ width:100%; }
  .hero h1{ font-size:clamp(38px,11vw,56px); }
}

/* ===== TWEAK: hero layout variants ===== */
/* overlay — full-bleed image behind copy */
:root[data-hero="overlay"] .hero .container{ grid-template-columns:1fr; min-height:74vh; align-content:center; }
:root[data-hero="overlay"] .hero-media{ position:absolute; inset:0; order:0; max-width:none; }
:root[data-hero="overlay"] .hero-media .frame{ position:absolute; inset:0; border:0; border-radius:0; aspect-ratio:auto; box-shadow:none; }
:root[data-hero="overlay"] .hero-media .frame img{ object-position:center 35%; }
:root[data-hero="overlay"] .hero-media .frame::after{ background:linear-gradient(90deg,rgba(9,9,13,.94) 30%,rgba(9,9,13,.55) 70%,rgba(9,9,13,.35)); inset:0; }
:root[data-hero="overlay"] .hero-media .corner{ display:none; }
:root[data-hero="overlay"] .hero-badge{ left:auto; right:24px; bottom:24px; }
:root[data-hero="overlay"] .hero-copy{ position:relative; z-index:3; max-width:640px; }
@media (max-width:920px){ :root[data-hero="overlay"] .hero-media .frame img{ object-position:center 30%; } }

/* minimal — no photo, centered statement */
:root[data-hero="minimal"] .hero .container{ grid-template-columns:1fr; text-align:center; min-height:64vh; align-content:center; }
:root[data-hero="minimal"] .hero-media{ display:none; }
:root[data-hero="minimal"] .hero-copy{ max-width:900px; margin-inline:auto; }
:root[data-hero="minimal"] .hero .eyebrow,
:root[data-hero="minimal"] .hero-cta,
:root[data-hero="minimal"] .hero-trust{ justify-content:center; }
:root[data-hero="minimal"] .hero-cta,
:root[data-hero="minimal"] .hero-trust{ display:flex; }
:root[data-hero="minimal"] .hero .lead{ margin-inline:auto; }

/* ===== TWEAK: bold direction — louder hero & headings ===== */
:root[data-dir="bold"] .hero h1{ font-size: clamp(46px,8vw,108px); }
:root[data-dir="bold"] .section-title{ font-size: clamp(34px,5.2vw,68px); }
:root[data-dir="bold"] .eyebrow{ letter-spacing:.3em; }

/* logo treatment variants (tweak) */
.brand img.logo-mono{ filter:grayscale(1) brightness(1.25) contrast(1.05); }
.brand .badge-logo{ display:none; }
:root[data-logo="badge"] .brand img{ display:none; }
:root[data-logo="badge"] .brand .badge-logo{ display:flex; align-items:center; justify-content:center; width:48px;height:48px; background:var(--red); border-radius:var(--radius); font-family:var(--font-display); font-size:22px; color:#fff; letter-spacing:.02em; }
:root[data-logo="mono"] .brand img{ filter:grayscale(1) brightness(1.3) contrast(1.02); }
