/* ───────── DESIGN TOKENS ───────── */
:root{
  --bg:        #0a0a0a;
  --bg-soft:   #111111;
  --surface:   #161616;
  --surface-2: #1c1c1c;
  --line:      #262626;
  --line-soft: #1f1f1f;
  --ink:       #f5f5f5;
  --ink-mute:  #a8a8a8;
  --ink-dim:   #6b6b6b;
  --accent:    #ff3d00;
  --accent-2:  #ff6a3d;
  --steel-1:   #d9d9d9;
  --steel-2:   #8a8a8a;

  --display: 'Unbounded', system-ui, sans-serif;
  --body:    'Onest', system-ui, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

  --container: 1320px;
  --pad: clamp(20px, 4vw, 56px);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-weight:400;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='1'/></svg>");
}

img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

::selection{background:var(--accent);color:#fff}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad);position:relative;z-index:2}

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:'';width:24px;height:1px;background:var(--accent);
}
h1,h2,h3{
  font-family:var(--display);
  font-weight:800;
  line-height:.95;
  letter-spacing:-0.02em;
  margin:0;
  text-transform:uppercase;
}
h2{font-size:clamp(36px,6vw,84px)}
h3{font-size:clamp(20px,2vw,28px);letter-spacing:-0.01em}
p{margin:0}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--ink-mute);max-width:62ch;line-height:1.6}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:18px 28px;
  font-family:var(--display);
  font-weight:600;
  font-size:14px;
  letter-spacing:.06em;
  text-transform:uppercase;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--ink);
  transition:transform .25s cubic-bezier(.2,.8,.2,1),background .25s,border-color .25s,color .25s;
  position:relative;
  overflow:hidden;
}
.btn:hover{transform:translateY(-2px);border-color:var(--ink)}
.btn--primary{
  background:var(--accent);
  border-color:var(--accent);
  color:#0a0a0a;
}
.btn--primary:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn--ghost{background:transparent}
.btn .arrow{display:inline-block;transition:transform .3s}
.btn:hover .arrow{transform:translateX(4px)}

.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--pad);
  background:rgba(10,10,10,.7);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
}
.brand{
  display:flex;align-items:center;gap:12px;
  font-family:var(--display);
  font-weight:800;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:15px;
}
.brand .dot{width:9px;height:9px;background:var(--accent);display:inline-block}
.brand small{
  display:block;
  font-family:var(--mono);
  font-weight:400;
  font-size:10px;
  letter-spacing:.18em;
  color:var(--ink-mute);
  margin-top:3px;
  text-transform:uppercase;
}
.nav{display:flex;align-items:center;gap:32px}
.nav a{
  font-size:13px;
  letter-spacing:.04em;
  color:var(--ink-mute);
  transition:color .2s;
}
.nav a:hover{color:var(--ink)}
.header-cta{
  font-family:var(--display);
  font-weight:600;
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:11px 18px;
  border:1px solid var(--ink);
  background:transparent;
  transition:background .2s,color .2s;
}
.header-cta:hover{background:var(--ink);color:var(--bg)}
@media(max-width:880px){
  .nav{display:none}
}

.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:flex-end;
  padding:140px 0 80px;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero::after{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(900px 600px at 90% 20%, rgba(255,61,0,.08), transparent 60%),
    radial-gradient(700px 500px at 10% 90%, rgba(255,61,0,.05), transparent 60%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:60px;
  align-items:end;
  position:relative;
  z-index:2;
}
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
}
.hero h1{
  font-size:clamp(48px,9.5vw,168px);
  font-weight:900;
  line-height:.88;
  letter-spacing:-0.035em;
  margin-top:24px;
}
.hero h1 .accent{color:var(--accent);display:inline-block}
.hero .sub{
  margin-top:32px;
  max-width:54ch;
  font-size:clamp(15px,1.3vw,18px);
  color:var(--ink-mute);
  line-height:1.6;
}
.hero-ctas{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:40px;
}
.hero-aside{
  display:flex;flex-direction:column;gap:24px;
  padding-bottom:8px;
}
.kpi{
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--surface),var(--bg-soft));
  padding:28px;
}
.kpi .num{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(56px,7vw,96px);
  line-height:1;
  letter-spacing:-0.04em;
  background:linear-gradient(180deg,#fff 0%,#666 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
}
.kpi .label{
  margin-top:14px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.hero-meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-dim);
  border-top:1px solid var(--line);
  margin-top:60px;padding-top:20px;
  position:relative;z-index:2;
}
.hero-meta span:nth-child(2){color:var(--ink-mute)}

section{position:relative;padding:120px 0;border-bottom:1px solid var(--line)}
@media(max-width:760px){section{padding:80px 0}}

.section-head{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:48px;
  align-items:end;
  margin-bottom:64px;
}
.section-head .num{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.2em;
  color:var(--accent);
  text-transform:uppercase;
}
.section-head .title{max-width:18ch}
@media(max-width:760px){
  .section-head{grid-template-columns:1fr;gap:16px;margin-bottom:40px}
}

.adv-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
.adv-grid .cell{
  padding:36px 28px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;
  background:var(--bg-soft);
  transition:background .3s;
  min-height:200px;
}
.adv-grid .cell:hover{background:var(--surface)}
.adv-grid .cell .ix{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink-dim);
}
.adv-grid .cell h3{font-size:18px}
.adv-grid .cell p{font-size:13px;color:var(--ink-mute);line-height:1.55}
@media(max-width:1100px){.adv-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.adv-grid{grid-template-columns:1fr}}

.accept-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.accept-card{
  background:var(--bg-soft);
  padding:32px 24px;
  display:flex;flex-direction:column;justify-content:space-between;
  gap:48px;
  min-height:220px;
  transition:background .25s,transform .25s;
  cursor:default;
  position:relative;
}
.accept-card:hover{background:var(--surface);}
.accept-card .ic{width:32px;height:32px;color:var(--accent)}
.accept-card .name{
  font-family:var(--display);
  font-weight:700;
  font-size:17px;
  text-transform:uppercase;
  letter-spacing:-0.005em;
}
.accept-card .meta{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase;
  position:absolute;top:18px;right:20px;
}
@media(max-width:1100px){.accept-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.accept-grid{grid-template-columns:repeat(2,1fr)}}

.why{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:start;
}
.why .copy p{font-size:clamp(15px,1.2vw,17px);color:var(--ink-mute);line-height:1.7}
.why .copy p + p{margin-top:18px}
.why .copy strong{color:var(--ink);font-weight:600}
.why-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.why-stats .stat{
  background:var(--bg-soft);padding:32px;
}
.why-stats .stat .v{
  font-family:var(--display);font-weight:800;font-size:42px;line-height:1;
  letter-spacing:-0.02em;
  color:var(--ink);
}
.why-stats .stat .v .ac{color:var(--accent)}
.why-stats .stat .l{
  margin-top:12px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-mute);
}
@media(max-width:880px){.why{grid-template-columns:1fr;gap:48px}}

.pickup{
  background:linear-gradient(140deg,#171717,#0a0a0a 60%);
  position:relative;
  overflow:hidden;
}
.pickup::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(700px 400px at 80% 50%,rgba(255,61,0,.16),transparent 60%);
  pointer-events:none;
}
.pickup-inner{
  display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:end;
  position:relative;z-index:2;
}
.pickup h2{font-size:clamp(36px,6.5vw,96px)}
.pickup h2 .accent{color:var(--accent)}
.pickup .copy{margin-top:24px;color:var(--ink-mute);max-width:50ch;font-size:17px;line-height:1.65}
.pickup .actions{display:flex;flex-direction:column;gap:12px}
.pickup-meta{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);
  display:grid;gap:14px;
}
.pickup-meta div{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:10px}
.pickup-meta div span:last-child{color:var(--ink)}
@media(max-width:880px){.pickup-inner{grid-template-columns:1fr;gap:40px}}

.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:24px 0;overflow:hidden;background:var(--bg);
}
.marquee-track{
  display:flex;gap:64px;
  white-space:nowrap;
  animation:scroll 40s linear infinite;
  font-family:var(--display);font-weight:800;
  font-size:clamp(28px,4vw,48px);
  text-transform:uppercase;letter-spacing:-0.02em;
}
.marquee-track span{display:inline-flex;align-items:center;gap:64px}
.marquee-track .dot{width:10px;height:10px;background:var(--accent);display:inline-block}
@keyframes scroll{
  to{transform:translateX(-50%)}
}

.geo{background:var(--bg-soft)}
.geo .copy{
  font-size:clamp(15px,1.2vw,17px);color:var(--ink-mute);line-height:1.75;max-width:78ch;
}
.geo .copy strong{color:var(--ink);font-weight:600}
.geo-tags{
  margin-top:48px;display:flex;flex-wrap:wrap;gap:8px;
}
.geo-tags .tag{
  border:1px solid var(--line);
  padding:8px 14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-mute);
  transition:all .2s;
}
.geo-tags .tag:hover{border-color:var(--accent);color:var(--ink)}

.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:28px 0;text-align:left;
  font-family:var(--display);font-weight:600;
  font-size:clamp(17px,1.6vw,22px);
  letter-spacing:-0.005em;
  color:var(--ink);
  text-transform:none;
  transition:color .2s;
}
.faq-q:hover{color:var(--accent)}
.faq-q .plus{
  flex:0 0 28px;width:28px;height:28px;position:relative;
}
.faq-q .plus::before,.faq-q .plus::after{
  content:'';position:absolute;left:50%;top:50%;background:currentColor;
  transform:translate(-50%,-50%);
  transition:transform .3s;
}
.faq-q .plus::before{width:14px;height:1.5px}
.faq-q .plus::after{width:1.5px;height:14px}
.faq-item.open .faq-q .plus::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .35s ease;
}
.faq-a-inner{
  padding:0 0 28px;
  color:var(--ink-mute);
  font-size:15px;line-height:1.65;
  max-width:72ch;
}

.contacts{
  background:var(--bg);position:relative;
}
.contacts-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:start;
}
.contacts h2{font-size:clamp(40px,6vw,84px)}
.contact-actions{display:flex;flex-direction:column;gap:14px;margin-top:32px}
.contact-actions .btn{justify-content:space-between;padding:22px 26px}
.contact-info{
  border:1px solid var(--line);background:var(--bg-soft);padding:36px;
  display:flex;flex-direction:column;gap:24px;
}
.contact-info .row{
  display:flex;flex-direction:column;gap:6px;
  border-bottom:1px solid var(--line-soft);padding-bottom:20px;
}
.contact-info .row:last-child{border-bottom:none;padding-bottom:0}
.contact-info .row .l{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute)}
.contact-info .row .v{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink)}
.contact-info .row .v a:hover{color:var(--accent)}
@media(max-width:880px){.contacts-grid{grid-template-columns:1fr;gap:40px}}

.site-footer{
  padding:48px var(--pad) calc(48px + env(safe-area-inset-bottom));
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);
  border-top:1px solid var(--line);
}
.site-footer a:hover{color:var(--ink)}

.mobile-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:60;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
  gap:8px;
}
.mobile-cta a{
  flex:1;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 10px;
  font-family:var(--display);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.06em;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--ink);
}
.mobile-cta a.primary{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}
.mobile-cta a.wa{background:#1f7a3a;border-color:#1f7a3a;color:#fff}
@media(max-width:760px){
  .mobile-cta{display:flex}
  body{padding-bottom:80px}
}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

@media(max-width:760px){
  .hero{padding:120px 0 60px;min-height:auto}
  .hero-meta{margin-top:40px}
  .hero-aside{flex-direction:row;flex-wrap:wrap}
  .hero-aside .kpi{flex:1;min-width:140px}
}

/* ───────── BREADCRUMBS ───────── */
.breadcrumbs{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-dim);padding:120px var(--pad) 20px;position:relative;z-index:2;
  max-width:var(--container);margin:0 auto;
}
.breadcrumbs a{color:var(--ink-mute);transition:color .2s}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs .sep{margin:0 10px;color:var(--ink-dim)}

/* ───────── DROPDOWN NAV ───────── */
.nav-dropdown{position:relative}
.nav-dropdown > a{display:flex;align-items:center;gap:6px;cursor:pointer}
.nav-dropdown > a::after{content:'';width:6px;height:6px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .2s}
.nav-dropdown:hover > a::after{transform:rotate(225deg) translateY(2px)}
.nav-dropdown-menu{
  position:absolute;top:100%;left:-16px;
  min-width:240px;
  background:var(--surface);border:1px solid var(--line);
  padding:8px;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .2s,transform .2s,visibility .2s;
  z-index:60;
}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{
  display:block;padding:10px 14px;font-size:13px;letter-spacing:.04em;
  color:var(--ink-mute);transition:background .2s,color .2s;
}
.nav-dropdown-menu a:hover{background:var(--bg-soft);color:var(--accent)}

/* ───────── FORM ───────── */
.form-wrap{
  background:linear-gradient(180deg,var(--bg-soft),var(--bg));
  border:1px solid var(--line);
  padding:clamp(32px,4vw,56px);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:span 2}
@media(max-width:680px){.form-grid{grid-template-columns:1fr}.form-grid .full{grid-column:span 1}}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field label{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-mute);
}
.form-field input,
.form-field select,
.form-field textarea{
  background:var(--bg);
  border:1px solid var(--line);
  padding:14px 16px;
  font-family:var(--body);font-size:15px;
  color:var(--ink);
  transition:border-color .2s,background .2s;
  resize:vertical;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;border-color:var(--accent);background:var(--surface);
}
.form-field textarea{min-height:90px;font-family:var(--body)}
.form-field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='none' stroke='%23a8a8a8' stroke-width='1.5' d='M1 1l5 5 5-5'/></svg>");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
#form-status{
  margin-top:16px;font-size:14px;font-family:var(--mono);letter-spacing:.05em;
  min-height:20px;
}
.form-meta{
  margin-top:20px;font-family:var(--mono);font-size:11px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--ink-dim);text-align:center;
}

/* ───────── PRICE TABLE ───────── */
.price-table{
  border:1px solid var(--line);
  background:var(--bg-soft);
  overflow:hidden;
}
.price-row{
  display:grid;grid-template-columns:1.5fr 1fr 1fr;
  padding:18px 24px;
  border-bottom:1px solid var(--line);
  align-items:center;
  transition:background .2s;
}
.price-row:last-child{border-bottom:none}
.price-row:hover{background:var(--surface)}
.price-row.head{
  background:var(--surface-2);
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);
}
.price-row .name{
  font-family:var(--display);font-weight:700;font-size:15px;
  letter-spacing:-0.005em;
}
.price-row .cat{font-size:13px;color:var(--ink-mute)}
.price-row .price{
  font-family:var(--display);font-weight:700;font-size:15px;
  color:var(--accent);text-align:right;letter-spacing:-0.005em;
}
.price-note{
  margin-top:16px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  color:var(--ink-dim);
}
@media(max-width:680px){
  .price-row{grid-template-columns:1.4fr 1fr;padding:14px 18px;gap:8px}
  .price-row .cat{display:none}
  .price-row.head .cat{display:none}
}

/* ───────── REVIEWS ───────── */
.reviews-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.review-card{
  background:var(--bg-soft);padding:32px 28px;
  display:flex;flex-direction:column;gap:16px;
  transition:background .25s;
}
.review-card:hover{background:var(--surface)}
.review-stars{
  display:flex;gap:3px;color:var(--accent);
}
.review-stars svg{width:14px;height:14px;fill:currentColor}
.review-text{
  font-size:14.5px;color:var(--ink);line-height:1.6;
  flex:1;
}
.review-author{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding-top:16px;border-top:1px solid var(--line);
}
.review-author .name{
  font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink);
}
.review-author .date{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-dim);
}
@media(max-width:980px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.reviews-grid{grid-template-columns:1fr}}

/* ───────── ARTICLE / BLOG ───────── */
.article{padding:120px 0 80px}
.article-meta{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-mute);
  display:flex;gap:18px;margin-bottom:24px;flex-wrap:wrap;
}
.article-meta .accent{color:var(--accent)}
.article h1{
  font-size:clamp(32px,5.5vw,68px);font-weight:900;
  line-height:.95;letter-spacing:-0.025em;margin-bottom:32px;
  max-width:22ch;
}
.article-content{
  font-size:clamp(15px,1.2vw,17px);
  line-height:1.75;color:var(--ink-mute);max-width:72ch;
}
.article-content h2{
  font-size:clamp(22px,2.6vw,32px);
  margin:48px 0 16px;color:var(--ink);
}
.article-content h3{
  font-size:clamp(18px,1.8vw,22px);
  margin:32px 0 12px;color:var(--ink);
  text-transform:none;letter-spacing:-0.005em;
}
.article-content p{margin-bottom:18px}
.article-content strong{color:var(--ink);font-weight:600}
.article-content ul,.article-content ol{
  margin:18px 0;padding-left:24px;
}
.article-content li{margin-bottom:10px}
.article-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.article-content blockquote{
  border-left:2px solid var(--accent);
  padding:14px 22px;margin:24px 0;
  background:var(--bg-soft);
  color:var(--ink);font-style:italic;
}

/* ───────── BLOG INDEX ───────── */
.blog-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.blog-card{
  background:var(--bg-soft);padding:36px 32px;
  display:flex;flex-direction:column;gap:14px;
  transition:background .25s;
  min-height:240px;
}
.blog-card:hover{background:var(--surface)}
.blog-card .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  color:var(--accent);text-transform:uppercase;
}
.blog-card h3{
  font-size:clamp(18px,1.8vw,24px);
  text-transform:none;letter-spacing:-0.01em;
}
.blog-card .excerpt{
  font-size:14px;color:var(--ink-mute);line-height:1.6;flex:1;
}
.blog-card .more{
  font-family:var(--mono);font-size:11px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:8px;
}
@media(max-width:680px){.blog-grid{grid-template-columns:1fr}}

/* ───────── CROSS LINKS (внутренняя перелинковка) ───────── */
.cross-links{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  margin-top:48px;
}
.cross-link{
  background:var(--bg-soft);
  padding:24px 22px;
  font-family:var(--display);font-weight:600;font-size:14px;
  text-transform:uppercase;letter-spacing:-0.005em;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  color:var(--ink);
  transition:background .25s,color .2s;
}
.cross-link:hover{background:var(--surface);color:var(--accent)}
.cross-link .ar{color:var(--ink-dim);transition:color .2s,transform .2s}
.cross-link:hover .ar{color:var(--accent);transform:translateX(4px)}
@media(max-width:880px){.cross-links{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cross-links{grid-template-columns:1fr}}

/* ───────── MAPS embed ───────── */
.maps-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.map-card{background:var(--bg-soft);padding:0;position:relative;overflow:hidden}
.map-card iframe{display:block;border:0;width:100%;height:360px}
.map-label{
  position:absolute;top:14px;left:14px;
  background:rgba(10,10,10,.85);backdrop-filter:blur(8px);
  padding:8px 14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);
  z-index:2;border:1px solid var(--line);
}
@media(max-width:760px){.maps-wrap{grid-template-columns:1fr}}

/* Кнопка "Открыть в карте" поверх iframe (всегда видимая) */
.map-open{
  position:absolute;
  bottom:14px;left:14px;
  background:var(--accent);color:#000;
  padding:10px 18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  font-weight:700;
  z-index:3;
  border:1px solid var(--accent);
  transition:background .2s,color .2s,transform .2s;
}
.map-open:hover{
  background:#fff;color:#000;
  transform:translateX(2px);
}

/* ───────── СТИЛИЗОВАННАЯ КАРТА 2GIS (фирменный стиль) ───────── */
.map-stylized{
  position:relative;
  display:block;
  min-height:360px;
  overflow:hidden;
  cursor:pointer;
  text-decoration:none;
  background:#0f0f0f;
}
.map-svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}
.map-stylized-overlay{
  position:absolute;
  left:14px;
  top:48px;
  z-index:4;
  pointer-events:none;
}
.map-stylized-addr{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  background:rgba(10,10,10,.85);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  padding:6px 12px;
  border:1px solid var(--line);
  display:inline-block;
}

/* Hover-эффект на всю карту */
.map-stylized:hover .map-svg{
  filter:brightness(1.1);
  transition:filter .3s;
}
.map-stylized .map-svg{
  transition:filter .3s;
}
