
:root{--bg:#070A0D;--surface:#10161C;--surface2:#151E26;--text:#F4F1EA;--muted:#AEB7BF;--muted2:#7C8792;--gold:#C8A45D;--gold2:#E4C884;--emerald:#0F3D35;--border:rgba(244,241,234,.12);--border2:rgba(200,164,93,.32);--container:1180px;--serif:Georgia,"Times New Roman",serif;--sans:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;--shadow:0 24px 80px rgba(0,0,0,.36)}
*{box-sizing:border-box}html{scroll-behavior:smooth;background:var(--bg)}body{margin:0;font-family:var(--sans);color:var(--text);background:radial-gradient(circle at 72% 0%,rgba(200,164,93,.18),transparent 34%),radial-gradient(circle at 8% 12%,rgba(15,61,53,.58),transparent 28%),linear-gradient(180deg,#070A0D,#0B1015 48%,#070A0D);line-height:1.6;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;z-index:-1;background-image:linear-gradient(rgba(244,241,234,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(244,241,234,.018) 1px,transparent 1px);background-size:72px 72px;pointer-events:none}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,input,textarea,select{font:inherit}.container{width:min(100% - 40px,var(--container));margin:0 auto}.skip-link{position:absolute;top:10px;left:10px;z-index:1000;transform:translateY(-150%);background:var(--text);color:var(--bg);padding:10px 14px;border-radius:999px;font-weight:800}.skip-link:focus{transform:translateY(0)}
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(20px);background:rgba(7,10,13,.72);border-bottom:1px solid var(--border)}.nav{height:76px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:grid}.brand strong{font-size:15px;text-transform:uppercase;letter-spacing:.16em}.brand span{font-size:12px;color:var(--muted)}.nav-links{display:flex;gap:22px;color:var(--muted);font-size:14px}.nav-links a:hover{color:var(--gold2)}.nav-cta{display:flex;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:13px 20px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.03);font-weight:800;transition:.18s}.btn:hover{transform:translateY(-2px);border-color:var(--border2);background:rgba(200,164,93,.08)}.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#171109;border-color:transparent;box-shadow:0 14px 40px rgba(200,164,93,.22)}.btn-ghost{background:transparent}
.section{padding:108px 0}.section-tight{padding:70px 0}.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--gold2);font-size:12px;text-transform:uppercase;letter-spacing:.18em;font-weight:900;margin-bottom:18px}.eyebrow:before{content:"";width:34px;height:1px;background:var(--gold)}h1,h2,h3{margin:0;font-family:var(--serif);line-height:.98;letter-spacing:0;font-weight:600}h1{font-size:clamp(48px,7vw,98px);max-width:850px}h2{font-size:clamp(38px,4.8vw,68px);max-width:920px}h3{font-size:clamp(26px,3vw,36px)}p{margin:0}.lead{color:var(--muted);font-size:clamp(18px,2vw,22px);line-height:1.55;max-width:780px}.muted{color:var(--muted)}
.hero{min-height:calc(100vh - 76px);display:grid;align-items:center;padding:92px 0 80px;overflow:hidden;position:relative}.hero:before{content:"";position:absolute;left:50%;top:40px;width:min(980px,92vw);height:min(980px,92vw);transform:translateX(-50%);border:1px solid rgba(200,164,93,.1);border-radius:999px;pointer-events:none}.hero-grid,.split,.status-grid,.contact-grid,.route-wide,.footer-premium-grid{display:grid;gap:22px}.hero-grid{grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}.split{grid-template-columns:.92fr 1.08fr}.status-grid{grid-template-columns:1.15fr .85fr}.contact-grid{grid-template-columns:.9fr 1.1fr}.route-wide{grid-template-columns:.9fr 1.1fr}.footer-premium-grid{grid-template-columns:1.1fr .75fr .75fr}.hero .lead{margin-top:26px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}.hero-note{margin-top:22px;color:var(--muted2);font-size:13px;max-width:680px}.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid rgba(200,164,93,.28);border-radius:999px;background:rgba(200,164,93,.065);font-size:12px;font-weight:900}.hero-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold2)}
.hero-card{position:relative;min-height:620px;border:1px solid var(--border);border-radius:38px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02)),radial-gradient(circle at 50% 0%,rgba(200,164,93,.18),transparent 34%),var(--surface);box-shadow:var(--shadow),0 30px 110px rgba(200,164,93,.16);overflow:hidden}.premium-mark{position:absolute;right:26px;top:26px;z-index:3;width:86px;height:86px;border-radius:999px;display:grid;place-items:center;text-align:center;border:1px solid rgba(200,164,93,.36);color:var(--gold2);background:rgba(7,10,13,.62);backdrop-filter:blur(14px);font-size:10px;font-weight:900;letter-spacing:.13em;text-transform:uppercase}.portrait-placeholder{position:absolute;inset:28px 28px 140px;border-radius:30px;overflow:hidden;border:1px solid var(--border)}.portrait-photo{width:100%;height:100%;object-fit:cover;object-position:center 18%;filter:saturate(.92) contrast(1.04)}.hero-stats{position:absolute;left:28px;right:28px;bottom:28px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat{padding:18px;border-radius:22px;border:1px solid var(--border);background:rgba(7,10,13,.56);backdrop-filter:blur(16px)}.stat strong{display:block;font-family:var(--serif);font-size:34px;color:var(--gold2);line-height:1}.stat span{display:block;margin-top:8px;font-size:12px;color:var(--muted)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.section-head{display:flex;align-items:end;justify-content:space-between;gap:32px;margin-bottom:42px}.section-head .lead{max-width:460px;font-size:17px}.card,.panel,.quote,.route-card,.footer-card{border:1px solid var(--border);border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.068),rgba(255,255,255,.018)),linear-gradient(135deg,rgba(200,164,93,.045),transparent 38%);box-shadow:var(--shadow),0 30px 110px rgba(200,164,93,.08)}.card{min-height:240px;padding:28px;transition:.18s}.card:hover{transform:translateY(-5px);border-color:var(--border2)}.card h3{font-size:30px}.card p{margin-top:16px;color:var(--muted);font-size:15px}.card-link{display:inline-flex;margin-top:22px;color:var(--gold2);font-weight:800}.panel,.quote{padding:34px}.quote p{font-family:var(--serif);font-size:34px;line-height:1.12}.quote small{display:block;margin-top:22px;color:var(--muted)}
.list{display:grid;gap:14px;margin:28px 0 0;padding:0;list-style:none}.list li{display:grid;grid-template-columns:24px 1fr;gap:12px;color:var(--muted)}.list li:before{content:"";width:8px;height:8px;margin-top:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px rgba(200,164,93,.08)}.timeline{display:grid;gap:16px;counter-reset:step}.step{counter-increment:step;display:grid;grid-template-columns:64px 1fr;gap:20px;padding:24px;border-radius:20px;border:1px solid var(--border);background:rgba(255,255,255,.028)}.step:before{content:counter(step,decimal-leading-zero);width:54px;height:54px;border-radius:18px;display:grid;place-items:center;border:1px solid var(--border2);color:var(--gold2);font-weight:900}.step h3{font-family:var(--sans);font-size:18px;letter-spacing:0;font-weight:900}.step p{color:var(--muted);margin-top:8px;font-size:15px}
.credential-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border:1px solid var(--border);border-radius:28px;overflow:hidden;background:var(--border)}.credential-item{padding:22px;background:rgba(16,22,28,.82)}.credential-item span{display:block;color:var(--muted2);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.16em}.credential-item strong{display:block;margin-top:10px;font-family:var(--serif);font-size:25px;line-height:1.05}.luxury-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(200,164,93,.42),transparent);margin:34px 0}.fact-list{display:grid;gap:12px;margin-top:28px}.fact{display:flex;justify-content:space-between;gap:18px;padding:16px 0;border-bottom:1px solid var(--border)}.fact span{color:var(--muted)}.fact strong{text-align:right}.practice-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}.tag{border:1px solid var(--border);border-radius:999px;padding:9px 13px;color:var(--muted);font-size:13px}
.articles{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}.article-main{min-height:420px;display:flex;flex-direction:column;justify-content:end;background:linear-gradient(180deg,transparent,rgba(7,10,13,.9)),radial-gradient(circle at 10% 10%,rgba(200,164,93,.22),transparent 32%),var(--surface2)}.article-list{display:grid;gap:18px}.faq{display:grid;gap:12px}.faq-item{border:1px solid var(--border);border-radius:20px;background:rgba(255,255,255,.026);overflow:hidden}.faq-button{width:100%;padding:22px 24px;border:0;background:transparent;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;gap:20px;text-align:left;font-weight:900}.faq-button span:last-child{color:var(--gold2);font-size:22px;transition:.18s}.faq-panel{max-height:0;overflow:hidden;transition:max-height .22s}.faq-panel p{padding:0 24px 24px;color:var(--muted)}.faq-item.is-open .faq-panel{max-height:260px}.faq-item.is-open .faq-button span:last-child{transform:rotate(45deg)}
.contact-methods{display:grid;gap:12px;margin-top:28px}.contact-method{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border:1px solid var(--border);border-radius:20px;color:var(--muted);background:rgba(255,255,255,.025)}.contact-method strong{color:var(--text)}.request-panel{position:relative;overflow:hidden;border-color:rgba(200,164,93,.24)}.form{display:grid;gap:14px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field-full{grid-column:1/-1}.field{display:grid;gap:8px}.field label{color:var(--muted);font-size:13px;font-weight:800}.field input,.field textarea,.field select{width:100%;color:var(--text);background:rgba(7,10,13,.62);border:1px solid var(--border);border-radius:16px;padding:15px 16px;outline:0}.field textarea{min-height:126px;resize:vertical}.checkbox{display:grid;grid-template-columns:20px 1fr;gap:10px;color:var(--muted);font-size:13px}.checkbox input{margin-top:3px;accent-color:var(--gold)}.form-note{color:var(--muted2);font-size:12px}.form-status{min-height:22px;color:var(--gold2);font-size:13px;font-weight:800}.form-guidance{margin:18px 0 0;padding:18px;border-radius:22px;border:1px solid rgba(200,164,93,.18);background:rgba(200,164,93,.045)}.form-guidance strong{display:block;font-family:var(--serif);font-size:28px;line-height:1}.form-guidance p{margin-top:10px;color:var(--muted);font-size:14px}
.route-section{padding-top:0}.route-wide{padding:28px;border-radius:34px}.route-copy{display:flex;flex-direction:column;justify-content:center}.route-address-line{margin-top:22px;display:inline-flex;width:fit-content;max-width:100%;padding:12px 14px;border-radius:999px;border:1px solid rgba(200,164,93,.22);background:rgba(200,164,93,.055);color:var(--gold2);font-size:13px;font-weight:900}.map-preview{position:relative;min-height:310px;border-radius:22px;overflow:hidden;border:1px solid var(--border);background:linear-gradient(135deg,rgba(200,164,93,.10),transparent 34%),linear-gradient(90deg,rgba(244,241,234,.035) 1px,transparent 1px),linear-gradient(rgba(244,241,234,.035) 1px,transparent 1px),radial-gradient(circle at 50% 50%,rgba(15,61,53,.45),rgba(7,10,13,.92));background-size:auto,34px 34px,34px 34px,auto}.map-pin{position:absolute;left:58%;top:48%;transform:translate(-50%,-50%);width:74px;height:74px;border-radius:999px;display:grid;place-items:center;color:#171109;background:linear-gradient(135deg,var(--gold),var(--gold2));font-weight:900;font-size:12px}.map-caption{position:absolute;left:16px;right:16px;bottom:16px;padding:14px 16px;border-radius:18px;background:rgba(7,10,13,.70);color:var(--muted);font-size:13px}.route-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.route-actions .btn{min-height:42px;padding:10px 14px;font-size:13px}
.site-footer{border-top:1px solid rgba(200,164,93,.2);padding:76px 0 42px;background:radial-gradient(circle at 75% 0%,rgba(200,164,93,.13),transparent 32%),linear-gradient(180deg,rgba(7,10,13,.15),rgba(0,0,0,.52))}.footer-card{padding:26px}.footer-brand-title{font-family:var(--serif);font-size:clamp(34px,4vw,56px);line-height:.96}.footer-meta,.footer-list{margin-top:18px;display:grid;gap:10px;color:var(--muted);font-size:14px}.footer-list a,.footer-list span{color:var(--muted)}.footer-list a:hover{color:var(--gold2)}.footer-bottom{margin-top:22px;padding-top:22px;border-top:1px solid var(--border);display:flex;justify-content:space-between;gap:18px;color:var(--muted2);font-size:12px}.footer-disclaimer{max-width:820px}.footer-year{white-space:nowrap;color:var(--gold2);font-weight:900}.footer-mini-mark{margin-top:24px;display:inline-flex;padding:10px 13px;border-radius:999px;border:1px solid rgba(200,164,93,.22);color:var(--gold2);background:rgba(200,164,93,.055);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:100;display:none}.cookie-inner{width:min(100%,980px);margin:0 auto;border:1px solid var(--border2);border-radius:24px;background:rgba(16,22,28,.94);backdrop-filter:blur(18px);box-shadow:var(--shadow);padding:20px;display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center}.cookie-inner p{color:var(--muted);font-size:13px}.cookie-actions{display:flex;gap:10px}.reveal{opacity:1}.js .reveal{opacity:0;transform:translateY(20px);transition:.52s}.js .reveal.is-visible{opacity:1;transform:translateY(0)}.mobile-sticky{position:fixed;left:12px;right:12px;bottom:12px;z-index:80;display:none;grid-template-columns:1fr 1fr;gap:8px}
@media (min-width:1440px){:root{--container:1320px}.hero-card{min-height:680px}.portrait-placeholder{inset:32px 32px 156px}}@media (min-width:1920px){:root{--container:1480px}h1{font-size:clamp(72px,6vw,122px)}h2{font-size:clamp(52px,4.6vw,88px)}.lead{font-size:clamp(19px,1.25vw,24px)}.section{padding:128px 0}}@media (max-width:1024px){.nav-links{display:none}.hero-grid,.split,.status-grid,.articles,.contact-grid,.route-wide,.footer-premium-grid{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr}.credential-strip{grid-template-columns:repeat(2,1fr)}}@media (max-width:680px){.container{width:min(100% - 28px,var(--container))}.nav{height:68px}.brand strong{font-size:12px}.brand span{display:none}.nav-cta .btn-ghost{display:none}.hero{padding:54px 0 44px;min-height:auto}.hero-actions .btn{width:100%}.hero-card{min-height:500px;border-radius:28px}.portrait-placeholder{inset:18px 18px 150px}.hero-stats{left:18px;right:18px;bottom:18px;grid-template-columns:1fr}.stat{padding:12px 14px;display:flex;align-items:center;gap:12px}.section{padding:72px 0}.grid-4,.credential-strip{grid-template-columns:1fr}.card,.panel,.quote{padding:22px}.form-grid{grid-template-columns:1fr}.footer-bottom{display:grid}.route-actions .btn{width:100%}.contact-method,.fact{display:grid;gap:6px}.fact strong{text-align:left;overflow-wrap:anywhere}.credential-item strong,.footer-list a,.footer-list span{overflow-wrap:anywhere}.cookie-inner{grid-template-columns:1fr}.mobile-sticky{display:grid}body{padding-bottom:74px}}@media (max-width:360px){.container{width:min(100% - 18px,var(--container))}h1{font-size:40px}h2{font-size:34px}.lead{font-size:16px}.btn{min-height:44px;padding:11px 13px;font-size:13px}.card,.panel,.quote{padding:18px}.premium-mark{display:none}}


.footer-credit {
  color: var(--muted2);
  font-size: 12px;
}
.footer-credit a {
  color: var(--gold2);
  font-weight: 900;
}
.footer-credit a:hover,
.footer-credit a:focus {
  text-decoration: underline;
}


html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  overflow-x: hidden;
}

a, button, .btn, .contact-method, .faq-button {
  -webkit-tap-highlight-color: rgba(200, 164, 93, 0.18);
  touch-action: manipulation;
}

:focus-visible {
  outline: 2px solid var(--gold2);
  outline-offset: 4px;
  border-radius: 12px;
}

.org-link {
  color: var(--gold2);
  font-weight: 900;
  text-decoration: none;
  text-underline-offset: 4px;
}

.org-link:hover,
.org-link:focus {
  text-decoration: underline;
}

.brand,
.nav,
.nav-cta,
.footer-card,
.card,
.panel,
.quote,
.contact-method,
.credential-item,
.stat {
  min-width: 0;
}

.card p,
.panel p,
.footer-meta,
.footer-list,
.contact-method strong,
.credential-item strong,
.fact strong {
  overflow-wrap: anywhere;
}

.field input,
.field textarea,
.field select {
  font-size: 16px;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }

  .js .reveal {
    opacity: 1 !important;
    transform: none !important;
  }
}

@supports (padding: max(0px)) {
  .mobile-sticky {
    bottom: max(12px, env(safe-area-inset-bottom));
    left: max(12px, env(safe-area-inset-left));
    right: max(12px, env(safe-area-inset-right));
  }
}

@media (max-width: 430px) {
  .site-header {
    position: sticky;
  }

  .nav {
    gap: 10px;
  }

  .brand strong {
    max-width: 132px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .nav-cta .btn-primary {
    padding-inline: 12px;
  }

  .hero-badges {
    gap: 8px;
  }

  .hero-badge {
    width: fit-content;
    max-width: 100%;
  }

  .faq-button {
    padding: 18px;
  }

  .faq-panel p {
    padding: 0 18px 20px;
  }

  .footer-card {
    padding: 20px;
  }
}

@media (max-width: 320px) {
  .container {
    width: min(100% - 14px, var(--container));
  }

  h1 {
    font-size: 36px;
  }

  h2 {
    font-size: 30px;
  }

  .nav-cta .btn-primary {
    font-size: 12px;
    min-height: 40px;
  }

  .mobile-sticky {
    grid-template-columns: 1fr;
  }

  body {
    padding-bottom: 120px;
  }
}

@media print {
  body {
    background: #fff !important;
    color: #111 !important;
    padding-bottom: 0 !important;
  }

  .site-header,
  .mobile-sticky,
  .cookie-banner,
  .hero-actions,
  .route-actions,
  .request-panel {
    display: none !important;
  }

  .section {
    padding: 24px 0 !important;
  }

  .card,
  .panel,
  .quote,
  .footer-card {
    border: 1px solid #ccc !important;
    box-shadow: none !important;
    background: #fff !important;
    color: #111 !important;
  }

  .muted,
  .lead,
  .card p,
  .panel p {
    color: #222 !important;
  }
}


section[id],
main[id] {
  scroll-margin-top: 92px;
}

.section:not(.hero) {
  content-visibility: auto;
  contain-intrinsic-size: 1px 780px;
}

.route-actions a[href*="2gis.ru"],
.route-actions a[href*="2gis.com"] {
  border-color: rgba(89, 196, 119, 0.32);
  background: linear-gradient(180deg, rgba(89,196,119,0.10), rgba(255,255,255,0.025));
}

.route-actions a[href*="2gis.ru"],
.route-actions a[href*="2gis.com"]:hover,
.route-actions a[href*="2gis.ru"],
.route-actions a[href*="2gis.com"]:focus {
  border-color: rgba(89, 196, 119, 0.58);
  background: rgba(89,196,119,0.14);
}

.noscript-note {
  margin-top: 18px;
  padding: 14px 16px;
  border: 1px solid rgba(200,164,93,0.22);
  border-radius: 16px;
  background: rgba(200,164,93,0.055);
  color: var(--muted);
  font-size: 14px;
}

.noscript-note a {
  color: var(--gold2);
  font-weight: 900;
}

@media (hover: none) and (pointer: coarse) {
  .card:hover,
  .contact-method:hover,
  .btn:hover {
    transform: none;
  }

  .btn,
  .faq-button,
  .contact-method {
    min-height: 48px;
  }
}

@media (max-width: 820px) and (orientation: landscape) {
  .hero {
    min-height: auto;
    padding: 42px 0;
  }

  .hero-card {
    min-height: 420px;
  }

  .portrait-placeholder {
    inset: 16px 16px 126px 16px;
  }
}

@media (max-width: 390px) {
  .hero-badge {
    font-size: 11px;
    min-height: 32px;
    padding: 7px 10px;
  }

  .stat span {
    font-size: 11px;
  }

  .map-pin {
    width: 62px;
    height: 62px;
    font-size: 10px;
  }

  .map-caption {
    font-size: 12px;
    padding: 12px;
  }
}


:root {
  color-scheme: dark;
}

img, svg, video, canvas {
  max-width: 100%;
  height: auto;
}

.hero-stats .stat strong {
  white-space: nowrap;
}

.section-head .lead {
  overflow-wrap: anywhere;
}

.hero-note,
.form-note,
.footer-disclaimer {
  text-wrap: pretty;
}

h1, h2, h3 {
  text-wrap: balance;
}

@media (max-width: 680px) {
  .section-head {
    gap: 14px;
  }

  .section-head .lead {
    font-size: 16px;
  }

  .hero-stats .stat strong {
    min-width: 72px;
  }
}

@media (max-width: 340px) {
  .hero-stats .stat strong {
    font-size: 22px;
    min-width: 64px;
  }

  .hero-stats .stat span {
    line-height: 1.35;
  }

  .credential-item {
    padding: 18px;
  }

  .footer-brand-title {
    font-size: 32px;
  }
}

@supports not (content-visibility: auto) {
  .section:not(.hero) {
    contain-intrinsic-size: auto;
  }
}


.hero-badges {
  max-width: 640px;
}

.hero-badges .hero-badge {
  white-space: nowrap;
}

@media (max-width: 430px) {
  .hero-badges {
    margin-top: 22px;
  }

  .hero-badges .hero-badge {
    white-space: normal;
  }
}

@media (max-width: 680px) {
  .hero-actions {
    margin-top: 28px;
  }
}

@media (min-width: 1440px) {
  .hero-grid {
    gap: 64px;
  }
}


#principles .grid-3 {
  align-self: stretch;
}

#principles .card {
  min-height: 210px;
}

.form textarea + .form-note {
  margin-top: -6px;
  text-align: right;
}

[data-section^="legal-"] .panel h3 {
  font-size: clamp(24px, 2.8vw, 34px);
}

[data-section^="legal-"] .list {
  margin-top: 18px;
}

@media (max-width: 1024px) {
  #principles .grid-3 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  #principles .card {
    min-height: auto;
  }

  .form textarea + .form-note {
    text-align: left;
  }
}


.breadcrumbs {
  border-bottom: 1px solid rgba(244,241,234,.08);
  background: rgba(7,10,13,.38);
}

.breadcrumbs .container {
  min-height: 44px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted2);
  font-size: 13px;
}

.breadcrumbs a {
  color: var(--muted);
}

.breadcrumbs a:hover,
.breadcrumbs a:focus {
  color: var(--gold2);
}

.breadcrumbs span:last-child {
  color: var(--gold2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

table, pre, code {
  max-width: 100%;
}

pre {
  overflow-x: auto;
}

main {
  min-width: 0;
}

@media (max-width: 430px) {
  .breadcrumbs .container {
    min-height: 40px;
    font-size: 12px;
  }

  .footer-credit {
    overflow-wrap: anywhere;
  }
}

@media (max-width: 300px) {
  .brand {
    display: none;
  }

  .nav {
    justify-content: center;
  }
}


.nav-links {
  flex-wrap: wrap;
}

@media (min-width: 1025px) {
  .nav-links {
    max-width: 620px;
    justify-content: center;
  }
}


.site-header a[href*="dqirs.ru"],
.site-header .nav-links a[href*="dqirs.ru"],
header a[href*="dqirs.ru"] {
  display: none !important;
}


.footer-list a[href*="dqirs.ru"] {
  display: none !important;
}
.footer-credit a[href*="dqirs.ru"] {
  display: inline !important;
}


:root{
  --motion-gold-soft: rgba(228,200,132,.18);
  --motion-gold-line: rgba(228,200,132,.34);
  --motion-emerald-soft: rgba(15,61,53,.36);
  --motion-surface-glow: rgba(244,241,234,.055);
}

.hero > .container,
.section > .container,
.section-tight > .container,
.site-footer > .container{
  position: relative;
  z-index: 1;
}

.hero::after{
  content:"";
  position:absolute;
  inset:-24% -14% auto auto;
  width:min(720px,72vw);
  height:min(720px,72vw);
  border-radius:999px;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(circle at 45% 50%, rgba(228,200,132,.17), transparent 0 34%),
    radial-gradient(circle at 38% 44%, rgba(15,61,53,.36), transparent 0 58%);
  filter:blur(14px);
  opacity:.55;
  transform:translate3d(0,0,0);
}

.section,
.section-tight,
.site-footer{
  position:relative;
  overflow:hidden;
}

.section::before,
.section-tight::before,
.site-footer::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(circle at 14% 18%, rgba(15,61,53,.20), transparent 0 28%),
    radial-gradient(circle at 88% 8%, rgba(200,164,93,.10), transparent 0 26%);
  opacity:.58;
}

.hero-card,
.card,
.panel,
.quote,
.step,
.footer-card,
.request-panel,
.route-card,
.contact-method,
.faq-item,
.article-list article,
.map-preview{
  position:relative;
  isolation:isolate;
  transform:translateZ(0);
  backface-visibility:hidden;
  transition:
    transform .28s ease,
    border-color .28s ease,
    box-shadow .28s ease,
    background-color .28s ease;
}

.hero-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at var(--mx, 62%) var(--my, 24%), rgba(228,200,132,.18), transparent 0 32%),
    linear-gradient(135deg, transparent 10%, rgba(244,241,234,.07) 34%, transparent 58%);
  opacity:.72;
  mix-blend-mode:screen;
}

.hero-card::after,
.card::before,
.panel::before,
.quote::before,
.step::before,
.footer-card::before,
.request-panel::before,
.route-card::before,
.contact-method::before,
.faq-item::before,
.article-list article::before,
.map-preview::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:-1;
  border-radius:inherit;
  background:
    radial-gradient(circle at var(--mx, 50%) var(--my, 0%), rgba(228,200,132,.14), transparent 0 38%),
    linear-gradient(135deg, rgba(244,241,234,.045), transparent 38%);
  opacity:0;
  transition:opacity .32s ease;
}

.hero-card:hover,
.card:hover,
.panel:hover,
.quote:hover,
.step:hover,
.footer-card:hover,
.request-panel:hover,
.route-card:hover,
.contact-method:hover,
.faq-item:hover,
.article-list article:hover,
.map-preview:hover{
  border-color:rgba(228,200,132,.34);
  box-shadow:var(--shadow),0 24px 90px rgba(200,164,93,.10);
}

.hero-card:hover::after,
.card:hover::before,
.panel:hover::before,
.quote:hover::before,
.step:hover::before,
.footer-card:hover::before,
.request-panel:hover::before,
.route-card:hover::before,
.contact-method:hover::before,
.faq-item:hover::before,
.article-list article:hover::before,
.map-preview:hover::before{
  opacity:1;
}

.btn{
  position:relative;
  overflow:hidden;
}

.btn::after{
  content:"";
  position:absolute;
  inset:-120% auto -120% -70%;
  width:52%;
  pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);
  transform:translateX(-120%) rotate(18deg);
  opacity:0;
}

.btn:hover::after,
.btn:focus-visible::after{
  opacity:1;
  transform:translateX(420%) rotate(18deg);
  transition:transform .78s ease, opacity .18s ease;
}

.btn-primary{
  background-size:210% 210%;
}

.nav-links a,
.footer-list a,
.card-link,
.org-link{
  position:relative;
}

.nav-links a::after,
.footer-list a::after,
.card-link::after,
.org-link::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-5px;
  height:1px;
  transform:scaleX(0);
  transform-origin:right;
  background:linear-gradient(90deg,transparent,var(--gold2),transparent);
  transition:transform .28s ease;
}

.nav-links a:hover::after,
.nav-links a:focus-visible::after,
.footer-list a:hover::after,
.footer-list a:focus-visible::after,
.card-link:hover::after,
.card-link:focus-visible::after,
.org-link:hover::after,
.org-link:focus-visible::after{
  transform:scaleX(1);
  transform-origin:left;
}

.premium-mark{
  box-shadow:0 0 0 1px rgba(228,200,132,.08),0 20px 70px rgba(200,164,93,.10);
}

.luxury-divider{
  position:relative;
  overflow:hidden;
}

.luxury-divider::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  left:-30%;
  width:22%;
  background:linear-gradient(90deg,transparent,rgba(228,200,132,.36),transparent);
  opacity:.0;
}

.form input:focus,
.form textarea:focus,
.form select:focus,
.field input:focus,
.field textarea:focus,
.field select:focus{
  box-shadow:0 0 0 4px rgba(200,164,93,.10),0 16px 46px rgba(0,0,0,.18);
}

@media (prefers-reduced-motion:no-preference){
  .hero::after{
    animation:aamak-aurora-drift 18s ease-in-out infinite alternate;
  }

  .hero-card{
    animation:aamak-hero-breathe 9s ease-in-out infinite;
  }

  .premium-mark{
    animation:aamak-mark-breathe 7.5s ease-in-out infinite;
  }

  .btn-primary{
    animation:aamak-gold-flow 9s ease-in-out infinite;
  }

  .luxury-divider::after{
    animation:aamak-divider-pass 7s ease-in-out infinite;
  }

  .eyebrow::before{
    animation:aamak-line-pulse 5.5s ease-in-out infinite;
  }
}

@keyframes aamak-aurora-drift{
  0%{transform:translate3d(0,0,0) scale(1);opacity:.42}
  50%{transform:translate3d(-4%,6%,0) scale(1.06);opacity:.62}
  100%{transform:translate3d(6%,-3%,0) scale(1.02);opacity:.48}
}

@keyframes aamak-hero-breathe{
  0%,100%{box-shadow:var(--shadow),0 30px 110px rgba(200,164,93,.13)}
  50%{box-shadow:var(--shadow),0 34px 128px rgba(200,164,93,.20)}
}

@keyframes aamak-mark-breathe{
  0%,100%{transform:translateZ(0) scale(1)}
  50%{transform:translateZ(0) scale(1.025)}
}

@keyframes aamak-gold-flow{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

@keyframes aamak-divider-pass{
  0%,62%{left:-35%;opacity:0}
  70%{opacity:.8}
  100%{left:112%;opacity:0}
}

@keyframes aamak-line-pulse{
  0%,100%{opacity:.62;transform:scaleX(1)}
  50%{opacity:1;transform:scaleX(1.28)}
}

@media (max-width:680px){
  .hero::after,
  .section::before,
  .section-tight::before,
  .site-footer::before{
    opacity:.18;
    animation:none !important;
  }

  .hero-card,
  .premium-mark,
  .btn-primary{
    animation:none !important;
  }

  .btn::after,
  .luxury-divider::after{
    display:none;
  }
}

@media (prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.001ms !important;
  }

  .btn::after,
  .luxury-divider::after{
    display:none !important;
  }
}

html,
body{
  overflow-x:hidden;
}

:focus-visible{
  outline:2px solid rgba(228,200,132,.92);
  outline-offset:4px;
}

.portrait-photo{
  transform:translateZ(0);
  will-change:transform;
}

.hero-card:hover .portrait-photo{
  transform:scale(1.012);
  transition:transform .55s ease;
}

.mobile-menu-toggle{
  display:none;
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.035);
  color:var(--text);
  place-items:center;
  padding:0;
  cursor:pointer;
}

.mobile-menu-toggle span{
  display:block;
  width:18px;
  height:2px;
  margin:3px auto;
  border-radius:99px;
  background:var(--text);
  transition:transform .24s ease, opacity .24s ease;
}

.is-mobile-menu-open .mobile-menu-toggle span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.is-mobile-menu-open .mobile-menu-toggle span:nth-child(2){opacity:0}
.is-mobile-menu-open .mobile-menu-toggle span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

.mobile-menu-backdrop{
  position:fixed;
  inset:0;
  z-index:98;
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(8px);
}

.mobile-menu-drawer{
  position:fixed;
  top:12px;
  right:12px;
  bottom:12px;
  z-index:99;
  width:min(360px,calc(100vw - 24px));
  padding:20px;
  border:1px solid rgba(228,200,132,.22);
  border-radius:28px;
  background:linear-gradient(180deg,rgba(20,27,34,.98),rgba(8,11,14,.98));
  box-shadow:0 30px 110px rgba(0,0,0,.62),0 0 0 1px rgba(255,255,255,.035) inset;
  transform:translateX(calc(100% + 24px));
  transition:transform .32s ease;
  display:flex;
  flex-direction:column;
  gap:20px;
}

.is-mobile-menu-open .mobile-menu-drawer{
  transform:translateX(0);
}

.is-mobile-menu-open{
  overflow:hidden;
}

.mobile-menu-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
}

.mobile-menu-head strong{
  letter-spacing:.13em;
  text-transform:uppercase;
  font-size:13px;
}

.mobile-menu-close{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid var(--border);
  color:var(--gold2);
  background:rgba(255,255,255,.035);
  font-size:26px;
  line-height:1;
  cursor:pointer;
}

.mobile-menu-links,
.mobile-menu-actions{
  display:grid;
  gap:10px;
}

.mobile-menu-links a,
.mobile-menu-actions a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:48px;
  padding:12px 14px;
  border-radius:16px;
  color:var(--muted);
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
}

.mobile-menu-links a:hover,
.mobile-menu-links a:focus-visible,
.mobile-menu-actions a:hover,
.mobile-menu-actions a:focus-visible{
  color:var(--text);
  border-color:var(--border2);
  background:rgba(200,164,93,.065);
}

.mobile-menu-actions{
  margin-top:auto;
}

.cookie-banner{
  pointer-events:none;
}

.cookie-inner{
  pointer-events:auto;
}

.form-status:not(:empty){
  padding:12px 14px;
  border:1px solid rgba(228,200,132,.22);
  border-radius:14px;
  background:rgba(200,164,93,.055);
}

@media (max-width:1024px){
  .mobile-menu-toggle{
    display:grid;
  }

  .site-header .nav-links{
    display:none!important;
  }
}

@media (max-width:680px){
  .site-header .nav-cta{
    display:none;
  }

  .mobile-menu-toggle{
    margin-left:auto;
  }

  .cookie-banner{
    bottom:86px;
  }

  .cookie-actions .btn,
  .mobile-menu-actions .btn{
    width:100%;
  }

  .portrait-photo{
    object-position:center 20%;
  }
}

@media (max-width:360px){
  .mobile-menu-drawer{
    top:8px;
    right:8px;
    bottom:8px;
    width:calc(100vw - 16px);
    border-radius:22px;
    padding:16px;
  }

  .mobile-menu-links a,
  .mobile-menu-actions a{
    min-height:46px;
  }
}


#publications .lead {
  max-width: 720px;
}
#publications .card {
  min-height: 265px;
}


#publications .card-link {
  margin-top: 22px;
}
#publications .card p {
  min-height: 96px;
}
@media (max-width: 680px) {
  #publications .card p {
    min-height: auto;
  }
}



.nav a,
.nav .btn,
.mobile-menu-drawer a {
  -webkit-tap-highlight-color: transparent;
}


.timeline {
  counter-reset: step;
}

.timeline .step {
  grid-template-columns: 64px minmax(0, 1fr) !important;
  align-items: start;
  overflow: hidden;
}

.timeline .step::before {
  content: counter(step, decimal-leading-zero) !important;
  position: static !important;
  inset: auto !important;
  z-index: 1 !important;
  width: 54px !important;
  height: 54px !important;
  min-width: 54px !important;
  border-radius: 18px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid var(--border2) !important;
  color: var(--gold2) !important;
  font-weight: 900 !important;
  background: rgba(7,10,13,.58) !important;
  box-shadow: inset 0 1px 0 rgba(244,241,234,.08), 0 14px 38px rgba(0,0,0,.22) !important;
  opacity: 1 !important;
  pointer-events: none !important;
  mix-blend-mode: normal !important;
  transition: border-color .28s ease, box-shadow .28s ease !important;
}

.timeline .step:hover::before {
  opacity: 1 !important;
  border-color: rgba(228,200,132,.46) !important;
  box-shadow: inset 0 1px 0 rgba(244,241,234,.10), 0 18px 46px rgba(200,164,93,.12) !important;
}

.timeline .step > * {
  grid-column: 2 !important;
  min-width: 0;
  max-width: 100%;
}

.timeline .step h3,
.timeline .step p {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

@media (max-width: 680px) {
  .timeline .step {
    grid-template-columns: 50px minmax(0, 1fr) !important;
    gap: 14px !important;
  }

  .timeline .step::before {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    border-radius: 15px !important;
    font-size: 13px !important;
  }
}


:root {
  --aamak-header-height: 76px;
  --aamak-adminbar-height: 0px;
}

body.admin-bar {
  --aamak-adminbar-height: 32px;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--aamak-header-height) + var(--aamak-adminbar-height) + 18px) !important;
}

.site-header {
  position: fixed !important;
  top: var(--aamak-adminbar-height) !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 99999 !important;
  transform: translateZ(0);
  will-change: transform;
}

body {
  padding-top: calc(var(--aamak-header-height) + var(--aamak-adminbar-height)) !important;
}

#main,
#practice,
#approach,
#principles,
#status,
#fee,
#publications,
#faq,
#contacts,
#request,
#route {
  scroll-margin-top: calc(var(--aamak-header-height) + var(--aamak-adminbar-height) + 18px) !important;
}

#publications,
#faq {
  scroll-margin-top: calc(var(--aamak-header-height) + var(--aamak-adminbar-height) + 12px) !important;
}

@media (max-width: 782px) {
  body.admin-bar {
    --aamak-adminbar-height: 46px;
  }
}

@media (max-width: 680px) {
  :root {
    --aamak-header-height: 68px;
  }

  html {
    scroll-padding-top: calc(var(--aamak-header-height) + var(--aamak-adminbar-height) + 14px) !important;
  }

  #main,
  #practice,
  #approach,
  #principles,
  #status,
  #fee,
  #publications,
  #faq,
  #contacts,
  #request,
  #route {
    scroll-margin-top: calc(var(--aamak-header-height) + var(--aamak-adminbar-height) + 14px) !important;
  }
}


@media screen and (max-width: 600px) {
  body.admin-bar {
    --aamak-adminbar-height: 0px;
  }

  body.admin-bar .site-header {
    top: 0 !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){.admin-bar .site-header{top:46px}}
.credential-strip{grid-template-columns:1fr 1.35fr minmax(300px,1.28fr) 1fr}
.credential-contact{min-width:0}
.credential-email{font-family:var(--sans);font-size:clamp(17px,1.55vw,22px);letter-spacing:0;line-height:1.12;white-space:nowrap;overflow-wrap:normal;word-break:keep-all;text-wrap:nowrap}
#principles.section-tight{padding-top:44px}
@media (max-width:1180px){.credential-strip{grid-template-columns:1fr 1.2fr 1.28fr 1fr}.credential-email{font-size:18px}}
@media (max-width:1024px){.credential-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.credential-email{white-space:normal;overflow-wrap:anywhere;word-break:normal;text-wrap:auto}}
@media (max-width:680px){.credential-strip{grid-template-columns:1fr}.credential-email{font-size:18px}.section-tight{padding:52px 0}#principles.section-tight{padding-top:52px}}

.btn,
.btn:visited{color:var(--text)}
.btn-primary,
.btn-primary:visited,
button.btn-primary{color:#161006;background:linear-gradient(135deg,#e4c572 0%,#d5aa4b 56%,#b9852f 100%);border-color:rgba(228,197,114,.88);text-shadow:none}
.btn-primary:hover,
.btn-primary:focus-visible,
button.btn-primary:hover,
button.btn-primary:focus-visible{color:#100b04;background:linear-gradient(135deg,#f0d684 0%,#dfbc5d 56%,#c4933e 100%);box-shadow:0 18px 44px rgba(213,170,75,.28),0 0 0 4px rgba(228,197,114,.14)}
.btn-ghost,
.btn-ghost:visited,
.route-actions .btn-ghost,
.cookie-actions .btn-ghost{color:var(--text);background:rgba(244,241,234,.045);border-color:rgba(244,241,234,.24)}
.btn-ghost:hover,
.btn-ghost:focus-visible,
.route-actions .btn-ghost:hover,
.route-actions .btn-ghost:focus-visible,
.cookie-actions .btn-ghost:hover,
.cookie-actions .btn-ghost:focus-visible{color:var(--text);background:rgba(244,241,234,.09);border-color:rgba(228,197,114,.48)}
button.btn-primary[type="submit"]{min-height:52px}
.map-pin{text-transform:uppercase;letter-spacing:.06em}
.footer-mini-mark{text-transform:none;letter-spacing:.05em}
.route-card .route-copy {
  --route-control-width: 292px;
}

.route-address-line,
.route-actions {
  width: min(100%, var(--route-control-width));
}

.route-address-line {
  box-sizing: border-box;
  justify-content: center;
  text-align: center;
  white-space: nowrap;
}

.route-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.route-actions .btn {
  width: 100%;
  min-width: 0;
  justify-content: center;
}

@media (max-width: 680px) {
  .route-card .route-copy {
    --route-control-width: 100%;
  }
}

/* Targeted visual fix: status containment and noble branded map buttons. */
#status .status-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.82fr);
  align-items: stretch;
  gap: clamp(24px, 3vw, 44px);
}

#status .panel,
#status .quote {
  min-width: 0;
  max-width: 100%;
}

#status .panel {
  overflow: visible;
}

#status h2 {
  inline-size: 100%;
  max-width: 100%;
  font-size: clamp(42px, 3.25vw, 56px);
  line-height: 1.04;
  letter-spacing: 0;
  text-wrap: balance;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

#status .lead,
#status .fact,
#status .fact strong {
  min-width: 0;
  max-width: 100%;
}

#status .lead,
#status .fact strong {
  overflow-wrap: anywhere;
}

.route-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  width: min(100%, 390px);
}

.route-actions .btn {
  min-height: 48px;
  width: 100%;
  min-width: 0;
  border-radius: 999px;
  justify-content: center;
  font-weight: 900;
  letter-spacing: 0;
}

.route-actions a[href*="2gis"] {
  color: #06160e;
  background:
    linear-gradient(135deg, rgba(151, 235, 179, 0.96), rgba(77, 190, 116, 0.96) 52%, rgba(32, 132, 74, 0.98));
  border-color: rgba(126, 224, 158, 0.78);
  box-shadow:
    0 16px 34px rgba(43, 170, 89, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.route-actions a[href*="2gis"]:hover,
.route-actions a[href*="2gis"]:focus-visible {
  color: #031007;
  background:
    linear-gradient(135deg, rgba(181, 247, 200, 1), rgba(91, 210, 131, 1) 52%, rgba(42, 153, 86, 1));
  border-color: rgba(168, 246, 194, 0.95);
}

.route-actions a[href*="yandex"] {
  color: #fff7f4;
  background:
    linear-gradient(135deg, rgba(255, 105, 83, 0.98), rgba(226, 50, 36, 0.98) 56%, rgba(156, 34, 28, 1));
  border-color: rgba(255, 117, 96, 0.72);
  box-shadow:
    0 16px 34px rgba(226, 50, 36, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

.route-actions a[href*="yandex"]:hover,
.route-actions a[href*="yandex"]:focus-visible {
  color: #ffffff;
  background:
    linear-gradient(135deg, rgba(255, 128, 110, 1), rgba(241, 65, 48, 1) 56%, rgba(180, 39, 31, 1));
  border-color: rgba(255, 142, 124, 0.92);
}

@media (max-width: 1180px) {
  #status .status-grid {
    grid-template-columns: 1fr;
  }

  #status h2 {
    font-size: clamp(38px, 7vw, 56px);
  }
}

@media (max-width: 680px) {
  #status h2 {
    font-size: clamp(24px, 7.6vw, 44px);
    line-height: 1.05;
  }
}

@media (max-width: 520px) {
  .route-actions {
    grid-template-columns: 1fr;
    width: 100%;
  }
}

/* AAMAK_TARGET_FIX_ROUTE_ADDRESS_WIDTH_20260621_V2
   Phase 1 surgical fix: align route address pill with the full 2GIS + Yandex buttons row.
   Do not use this marker for awards or any other layout changes. */
#route .route-card .route-copy {
  --route-control-width: 390px;
}

#route .route-address-line,
#route .route-actions {
  width: min(100%, var(--route-control-width));
}

@media (max-width: 680px) {
  #route .route-card .route-copy {
    --route-control-width: 100%;
  }
}

/* AAMAK_AWARDS_SURGICAL_REPAIR_20260621
   Scoped repair for section#awards only. No global card/panel/heading overrides. */
.awards-section {
  padding-top: clamp(26px, 3.2vw, 46px);
  padding-bottom: clamp(76px, 7vw, 118px);
}

#awards .awards-layout {
  display: grid;
  grid-template-columns: minmax(300px, 370px) minmax(0, 1fr);
  gap: clamp(22px, 3vw, 40px);
  align-items: stretch;
}

#awards .awards-copy {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  overflow: hidden;
  padding: clamp(26px, 3vw, 38px);
  border-radius: 30px;
}

#awards .awards-copy h2 {
  max-width: 9.8ch;
  font-size: clamp(38px, 3.15vw, 54px);
  line-height: 1.02;
  letter-spacing: -0.024em;
  text-wrap: balance;
  overflow-wrap: normal;
  word-break: normal;
}

#awards .awards-copy .lead {
  margin-top: 22px;
  max-width: 33ch;
  font-size: clamp(17px, 1.38vw, 20px);
  line-height: 1.56;
}

#awards .awards-note {
  margin-top: 22px;
  max-width: 42ch;
  color: var(--muted2);
  font-size: 13px;
  line-height: 1.55;
}

#awards .awards-copy::after {
  content: "";
  position: absolute;
  right: -92px;
  bottom: -96px;
  width: 230px;
  height: 230px;
  border: 1px solid rgba(200, 164, 93, 0.18);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(200, 164, 93, 0.12), transparent 64%);
  pointer-events: none;
}

#awards .awards-gallery {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(14px, 1.35vw, 20px);
  min-width: 0;
  align-items: stretch;
}

#awards .award-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  padding: clamp(13px, 1.05vw, 16px);
  border: 1px solid rgba(244, 241, 234, 0.12);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.062), rgba(255, 255, 255, 0.018)),
    radial-gradient(circle at 50% 0%, rgba(200, 164, 93, 0.12), transparent 42%),
    rgba(16, 22, 28, 0.84);
  box-shadow: var(--shadow), 0 18px 52px rgba(200, 164, 93, 0.055);
  overflow: hidden;
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

#awards .award-card:hover,
#awards .award-card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(228, 200, 132, 0.44);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.078), rgba(255, 255, 255, 0.022)),
    radial-gradient(circle at 50% 0%, rgba(200, 164, 93, 0.15), transparent 42%),
    rgba(16, 22, 28, 0.92);
}

#awards .award-card-featured {
  border-color: rgba(200, 164, 93, 0.30);
  box-shadow: var(--shadow), 0 18px 52px rgba(200, 164, 93, 0.085);
}

#awards .award-year {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 11px;
  border: 1px solid rgba(200, 164, 93, 0.26);
  border-radius: 999px;
  color: var(--gold2);
  background: rgba(7, 10, 13, 0.58);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.10em;
}

#awards .award-media {
  display: grid;
  place-items: center;
  aspect-ratio: 3 / 4;
  width: 100%;
  margin-top: 14px;
  border: 1px solid rgba(244, 241, 234, 0.10);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(244, 241, 234, 0.045), transparent 38%),
    rgba(7, 10, 13, 0.50);
  overflow: hidden;
}

#awards .award-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  padding: clamp(10px, 1vw, 15px);
  filter: saturate(0.96) contrast(1.02);
}

#awards .award-meta {
  display: grid;
  gap: 6px;
  margin-top: 14px;
  min-width: 0;
}

#awards .award-meta strong {
  font-family: var(--serif);
  color: var(--text);
  font-size: clamp(20px, 1.35vw, 25px);
  line-height: 1.08;
  letter-spacing: -0.012em;
  text-wrap: balance;
}

#awards .award-meta small {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.38;
}

@media (min-width: 1440px) {
  #awards .awards-layout {
    grid-template-columns: minmax(320px, 390px) minmax(0, 1fr);
  }

  #awards .awards-copy h2 {
    font-size: clamp(44px, 3.05vw, 58px);
  }
}

@media (max-width: 1180px) {
  #awards .awards-layout {
    grid-template-columns: 1fr;
  }

  #awards .awards-copy {
    justify-content: flex-start;
  }

  #awards .awards-copy h2 {
    max-width: 15ch;
  }

  #awards .awards-gallery {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  #awards .awards-gallery {
    grid-template-columns: 1fr;
  }

  #awards .award-card {
    width: 100%;
    max-width: 520px;
    margin-inline: auto;
  }
}

@media (max-width: 520px) {
  .awards-section {
    padding-top: 12px;
    padding-bottom: 72px;
  }

  #awards .awards-layout {
    gap: 16px;
  }

  #awards .awards-copy {
    padding: 28px;
    border-radius: 28px;
  }

  #awards .awards-copy h2 {
    max-width: 10ch;
    font-size: clamp(32px, 8.4vw, 39px);
    line-height: 1.08;
  }

  #awards .awards-copy .lead {
    font-size: 17px;
  }

  #awards .award-card {
    padding: 12px;
    border-radius: 24px;
  }

  #awards .award-media {
    border-radius: 18px;
  }

  #awards .award-meta strong {
    font-size: 24px;
  }
}



/* Awards premium viewer, scoped to awards modal only. */
#awards .award-card {
  cursor: zoom-in;
}

#awards .award-card:focus-visible {
  outline: 2px solid rgba(221, 185, 103, .9);
  outline-offset: 4px;
}

body.is-awards-viewer-open {
  overflow: hidden;
}

.awards-viewer[hidden] {
  display: none !important;
}

.awards-viewer {
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  display: grid;
  place-items: center;
  padding: clamp(12px, 2.8vw, 44px);
  color: var(--ivory, #f6f1e8);
  isolation: isolate;
}

.awards-viewer-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 18% 10%, rgba(221, 185, 103, .20), transparent 34%),
    radial-gradient(circle at 84% 90%, rgba(111, 78, 28, .22), transparent 38%),
    linear-gradient(180deg, rgba(1, 5, 8, .78), rgba(0, 2, 4, .90));
  backdrop-filter: blur(18px) saturate(126%);
  -webkit-backdrop-filter: blur(18px) saturate(126%);
}

.awards-viewer-shell {
  position: relative;
  z-index: 1;
  width: min(1180px, 100%);
  max-height: min(900px, calc(100vh - 24px));
  border: 1px solid rgba(221, 185, 103, .42);
  border-radius: 34px;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 0%, rgba(221, 185, 103, .10), transparent 30%),
    radial-gradient(circle at 96% 110%, rgba(221, 185, 103, .08), transparent 32%),
    linear-gradient(145deg, rgba(26, 29, 31, .97), rgba(6, 11, 14, .985));
  box-shadow:
    0 34px 110px rgba(0, 0, 0, .72),
    0 0 0 1px rgba(255, 255, 255, .045) inset,
    0 0 92px rgba(184, 154, 94, .12);
}

.awards-viewer-shell::before {
  content: '';
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(221, 185, 103, .14);
  border-radius: 24px;
  pointer-events: none;
}

.awards-viewer-shell::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(115deg, rgba(255, 255, 255, .08), transparent 22%, transparent 68%, rgba(221, 185, 103, .055));
  mix-blend-mode: screen;
  opacity: .55;
}

.awards-viewer-close {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 5;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(221, 185, 103, .36);
  background: rgba(9, 12, 13, .78);
  color: #f6f1e8;
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

.awards-viewer-frame {
  position: relative;
  z-index: 2;
  min-height: min(680px, calc(100vh - 150px));
  padding: clamp(24px, 4vw, 54px);
}

.awards-viewer-figure {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
  gap: clamp(22px, 4vw, 46px);
  align-items: center;
  margin: 0;
}

.awards-viewer-image-wrap {
  display: grid;
  place-items: center;
  min-height: min(72vh, 680px);
  border-radius: 26px;
  border: 1px solid rgba(255, 255, 255, .09);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .012)),
    rgba(1, 6, 8, .58);
  box-shadow: inset 0 0 82px rgba(0, 0, 0, .44);
  overflow: hidden;
  cursor: grab;
  user-select: none;
  touch-action: pan-y;
}

.awards-viewer-image-wrap.is-dragging {
  cursor: grabbing;
}

.awards-viewer-image {
  display: block;
  width: auto;
  max-width: min(100%, 720px);
  max-height: min(72vh, 680px);
  height: auto;
  object-fit: contain;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 28px 80px rgba(0, 0, 0, .50);
}

.awards-viewer-caption {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
  min-width: 0;
}

.awards-viewer-eyebrow,
.awards-viewer-year,
.awards-viewer-counter {
  color: #ddba67;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 12px;
}

.awards-viewer-caption h3 {
  margin: 0;
  font-family: var(--serif, Georgia, serif);
  font-size: clamp(34px, 4.8vw, 64px);
  line-height: .94;
  letter-spacing: -.04em;
  color: #f6f1e8;
  overflow-wrap: anywhere;
}

.awards-viewer-issuer,
.awards-viewer-hint {
  margin: 0;
  color: rgba(233, 236, 238, .76);
  font-size: 16px;
  line-height: 1.55;
}

.awards-viewer-hint {
  color: rgba(233, 236, 238, .48);
  font-size: 13px;
}

.awards-viewer-nav {
  position: absolute;
  top: 50%;
  z-index: 4;
  transform: translateY(-50%);
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 1px solid rgba(221, 185, 103, .32);
  background: rgba(8, 12, 14, .74);
  color: #f6f1e8;
  font-size: 44px;
  line-height: .8;
  cursor: pointer;
  box-shadow: 0 18px 44px rgba(0, 0, 0, .36);
}

.awards-viewer-prev { left: 18px; }
.awards-viewer-next { right: 18px; }

.awards-viewer-close:hover,
.awards-viewer-nav:hover,
.awards-viewer-close:focus-visible,
.awards-viewer-nav:focus-visible {
  border-color: rgba(221, 185, 103, .78);
  box-shadow: 0 0 0 4px rgba(221, 185, 103, .10), 0 20px 54px rgba(0, 0, 0, .40);
  outline: none;
}

.awards-viewer-footer {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 0 clamp(24px, 4vw, 54px) clamp(22px, 3vw, 34px);
}

@media (max-width: 900px) {
  .awards-viewer-shell {
    border-radius: 26px;
  }

  .awards-viewer-frame {
    min-height: auto;
    padding: 74px 18px 24px;
  }

  .awards-viewer-figure {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .awards-viewer-image-wrap {
    min-height: 52vh;
  }

  .awards-viewer-image {
    max-height: 52vh;
    max-width: 100%;
  }

  .awards-viewer-caption {
    text-align: left;
    gap: 8px;
  }

  .awards-viewer-nav {
    top: auto;
    bottom: 18px;
    transform: none;
    width: 48px;
    height: 48px;
    font-size: 38px;
  }

  .awards-viewer-prev { left: 18px; }
  .awards-viewer-next { right: 18px; }

  .awards-viewer-footer {
    padding: 0 76px 22px;
    justify-content: center;
    text-align: center;
  }

  .awards-viewer-year {
    display: none;
  }
}

@media (max-width: 390px) {
  .awards-viewer {
    padding: 10px;
  }

  .awards-viewer-shell {
    border-radius: 22px;
    max-height: calc(100vh - 20px);
  }

  .awards-viewer-caption h3 {
    font-size: 29px;
  }

  .awards-viewer-issuer {
    font-size: 14px;
  }
}

@media (max-width: 340px) {
  .awards-viewer-frame {
    padding-left: 12px;
    padding-right: 12px;
  }

  .awards-viewer-close {
    top: 14px;
    right: 14px;
  }

  .awards-viewer-caption h3 {
    font-size: 27px;
  }

  .awards-viewer-footer {
    padding-left: 66px;
    padding-right: 66px;
  }
}

/* ========================================================================== 
   AAMAKARENKOV mobile UI surgical fix - 2026-06-21
   Scope: mobile publications header, footer duplicate badge, mobile menu CTA,
   hero badges/org-link wrapping, sticky CTA safe-area. No logo implementation.
   ========================================================================== */

@media (max-width: 680px) {
  #publications .section-head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: start !important;
    justify-content: start !important;
    gap: 18px !important;
    margin-bottom: 28px;
  }

  #publications .section-head > div,
  #publications .section-head .lead {
    min-width: 0;
    width: 100%;
    max-width: none !important;
  }

  #publications .section-head .lead {
    display: block;
    font-size: 16px;
    line-height: 1.58;
    overflow-wrap: normal !important;
    word-break: normal !important;
    text-wrap: pretty;
  }
}

.footer-mini-mark {
  display: none !important;
}

.mobile-menu-actions a.btn-ghost {
  justify-content: center !important;
  color: var(--text) !important;
  background: rgba(255,255,255,.04) !important;
  border-color: rgba(244,241,234,.18) !important;
  font-weight: 900 !important;
  text-align: center;
}

.mobile-menu-actions a.btn-primary {
  justify-content: center !important;
  color: #080b0d !important;
  background: linear-gradient(135deg, var(--gold2), var(--gold)) !important;
  border-color: rgba(228,200,132,.62) !important;
  font-weight: 950 !important;
  text-align: center;
  box-shadow: 0 16px 38px rgba(200,164,93,.22) !important;
}

.mobile-menu-actions a.btn-ghost:hover,
.mobile-menu-actions a.btn-ghost:focus-visible {
  color: var(--text) !important;
  border-color: rgba(228,200,132,.38) !important;
  background: rgba(228,200,132,.08) !important;
}

.mobile-menu-actions a.btn-primary:hover,
.mobile-menu-actions a.btn-primary:focus-visible {
  color: #080b0d !important;
  filter: brightness(1.03);
}

@media (max-width: 680px) {
  .hero-badges {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 100%;
    max-width: none;
  }

  .hero-badges .hero-badge {
    width: 100% !important;
    max-width: none !important;
    min-height: 46px !important;
    justify-content: center;
    padding: 12px 14px !important;
    font-size: 14px !important;
    line-height: 1.15 !important;
    text-align: center;
    white-space: nowrap !important;
  }

  .hero .lead,
  .hero-copy .lead {
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none;
  }

  .hero .lead .org-link,
  .hero-copy .lead .org-link,
  .hero-badges .org-link {
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }

  .hero-note {
    margin-bottom: calc(78px + env(safe-area-inset-bottom));
  }
}

@media (max-width: 360px) {
  .hero-badges {
    grid-template-columns: 1fr !important;
  }

  .hero-badges .hero-badge {
    min-height: 44px !important;
    font-size: 14px !important;
  }
}

@media (max-width: 680px) {
  .mobile-sticky {
    left: max(12px, env(safe-area-inset-left)) !important;
    right: max(12px, env(safe-area-inset-right)) !important;
    bottom: max(12px, env(safe-area-inset-bottom)) !important;
    max-width: calc(100vw - 24px);
  }

  body {
    padding-bottom: calc(108px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width: 320px) {
  .mobile-sticky {
    grid-template-columns: 1fr;
  }

  body {
    padding-bottom: calc(144px + env(safe-area-inset-bottom)) !important;
  }
}
