/* Self-hosted Geologica (latin + latin-ext, weights 300/400/500/700).
   Replaces the Google Fonts CDN — no third-party request (revDSG), no render-blocking. */
@font-face{font-family:'Geologica';font-style:normal;font-weight:300;font-display:swap;src:url('fonts/geologica-300-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Geologica';font-style:normal;font-weight:300;font-display:swap;src:url('fonts/geologica-300-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Geologica';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/geologica-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Geologica';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/geologica-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Geologica';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/geologica-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Geologica';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/geologica-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Geologica';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/geologica-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Geologica';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/geologica-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}

/* ============================================================= */
/* GOLDBLUM HOMEPAGE — собрана 1:1 по узлу Figma 7019:1463        */
/* Стек прода: Astro + vanilla CSS + Netlify (canon §1).          */
/* Этот файл — статичный HTML-превью; в Astro раскладывается на   */
/* компоненты (Header, Footer, Hero, PracticeCard, FAQ и т.д.).   */
/* ============================================================= */

:root{
  --font:'Geologica',system-ui,-apple-system,sans-serif;
  --fw-light:300;--fw-regular:400;--fw-medium:500;--fw-bold:700;
  --primary:#1d1d1d; --secondary:#b2b2b2; --tertiary:#e6e6e6;
  --inverse:#f9f9f9; --accent:#ff0000; --bg:#ffffff; --muted:#f5f5f5;
  --ink:#1a1a1a; --ink-hover:#222222;
  --gutter:100px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);color:var(--primary);background:var(--bg);
  font-variation-settings:'CRSV' 0,'SHRP' 0;-webkit-font-smoothing:antialiased;line-height:1.4;font-weight:var(--fw-regular)}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer}
.wrap{max-width:1440px;margin:0 auto;padding-inline:var(--gutter)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:14px;line-height:18px;text-transform:uppercase;letter-spacing:.04em;color:var(--secondary);font-weight:var(--fw-light)}
.eyebrow .diamond{width:6.43px;height:8.57px;flex-shrink:0}
.section{padding-block:100px}
.section h2,.h2{font-weight:var(--fw-medium);font-size:48px;line-height:1.06;letter-spacing:-.02em;margin-top:24px}
.section h2 .red,.h2 .red{color:var(--accent)}
.section h3,.h3{font-size:30px;line-height:1.1;font-weight:var(--fw-medium);letter-spacing:-.01em}
.h4{font-size:20px;line-height:24px;font-weight:var(--fw-medium)}
.lede{font-size:14px;line-height:18px;color:var(--primary);font-weight:var(--fw-light);max-width:48ch}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0} /* доступные скрытые лейблы для форм */

/* ---------- BUTTONS (canon §4) ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font:inherit;font-size:16px;line-height:20px;
  border:1px solid var(--secondary);background:transparent;color:var(--primary);border-radius:0;
  padding:12px 32px;transition:color .25s, border-color .25s; cursor:pointer}
.btn--lg{padding:16px 32px}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn--dark{background:var(--primary);color:var(--inverse);border-color:var(--primary);position:relative;overflow:hidden}
.btn--dark::before{content:"";position:absolute;inset:0;background:var(--accent);clip-path:circle(0% at 100% 50%);transition:clip-path .55s ease-in-out;z-index:0}
.btn--dark:hover::before{clip-path:circle(150% at 100% 50%)}
.btn--dark:hover{color:var(--inverse)}
.btn--dark .lbl{position:relative;z-index:1}
.btn svg{width:20px;height:20px}

/* ---------- UTILITY BAR ---------- */
.utility .wrap{display:flex;align-items:center;height:52px;gap:24px}
.u-phone{display:inline-flex;align-items:center;gap:10px;white-space:nowrap}
.u-phone img{width:20px;height:20px}
.u-phone a{font-size:14px;line-height:18px;text-decoration:underline;text-underline-offset:2px;font-weight:var(--fw-light)}
.u-cities{display:flex;gap:24px;white-space:nowrap}
.u-cities li{font-size:14px;line-height:18px;font-weight:var(--fw-light)}
.u-social{margin-left:auto;display:flex;gap:3px}
.u-social a{width:24px;height:24px;border:1px solid var(--secondary);padding:4px;display:block}
.u-social img{width:16px;height:16px}

/* ---------- NAV ---------- */
.nav{padding-block:25px}
.nav .wrap{display:flex;align-items:center}
.logo{flex-shrink:0}
.logo-box{position:relative;display:block;width:153px;height:34px}
.logo .emb{position:absolute;left:0;top:0;width:21.25px;height:34px}
.logo .wm{position:absolute;left:37.15px;top:9.33px;width:115.85px;height:15.05px}
.nav-links{display:flex;gap:40px;margin-left:62px}
.nav-links a{display:inline-flex;align-items:center;gap:8px;font-size:16px;line-height:20px;position:relative;padding:2px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:1px;width:0;height:2px;background:var(--accent);transition:.2s}
.nav-links a:hover::after,.nav-links a:focus-visible::after{width:100%}
.nav-links .chev{width:14px;height:14px;opacity:.7}
.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto}
.lang{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;font-size:16px;line-height:20px;background:none;border:0;font-family:inherit;color:inherit}
.lang .glb{width:20px;height:20px}.lang .chev{width:14px;height:14px;opacity:.7}

/* Primary-nav hover dropdowns (CSS-only) */
.nav-item{position:relative}
.has-sub > a .chev{transition:transform .2s}
.has-sub:hover > a .chev,.has-sub:focus-within > a .chev{transform:rotate(180deg)}
.subnav{position:absolute;top:100%;left:-24px;padding-top:24px;z-index:60;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s ease,transform .18s ease,visibility 0s linear .18s}
/* Right-hand dropdown opens leftward so its 700px panel never spills past the
   viewport edge — was a hidden 83px horizontal-overflow strip at 1024–1362px. */
.subnav--end{left:auto;right:-24px}
.has-sub:hover .subnav,.has-sub:focus-within .subnav{opacity:1;visibility:visible;transform:none;transition-delay:0s}
.subnav__panel{background:var(--bg);border:1px solid var(--tertiary);box-shadow:0 24px 48px rgba(0,0,0,.10);padding:16px;display:grid;grid-template-columns:1fr;gap:2px;min-width:340px}
.subnav__panel--wide{grid-template-columns:1fr 1fr;gap:2px 8px;min-width:700px}
/* `.nav-links a` (0,1,1) would otherwise beat `.subnav__link` (0,1,0) and force
   inline-flex/centre alignment — so these are scoped under .nav-links to win. */
.nav-links .subnav__link{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 16px;text-align:left;text-decoration:none;border-radius:2px;transition:background .15s}
.nav-links .subnav__link::after{display:none}
.nav-links .subnav__link:hover{background:var(--muted)}
.subnav__t{font-size:15px;line-height:1.15;font-weight:var(--fw-medium);color:var(--primary)}
.nav-links .subnav__link:hover .subnav__t{color:var(--accent)}
.subnav__d{font-size:13px;line-height:1.3;font-weight:var(--fw-light);color:var(--secondary)}
.burger{display:none;width:44px;height:44px;border:1px solid var(--secondary);background:none;align-items:center;justify-content:center}
.burger svg{width:22px;height:22px}

/* ---------- HERO (как в hero.html, узел 7029:1436) ---------- */
.hero{position:relative;overflow:hidden;background:var(--bg);min-height:748px;display:flex;flex-direction:column}
.hero__bg{position:absolute;left:0;bottom:0;width:100%;height:auto;z-index:0;pointer-events:none;transform-origin:center 70%;animation:hero-zoom 22s ease-in-out infinite alternate} /* ken-burns: тонкий зум горы вместо typewriter */
.hero__inner{position:relative;z-index:1;flex:1;padding-block:64px 0}
.hero__inner .wrap{position:relative}
.hero__cta{max-width:610px}
.headline{font-weight:var(--fw-medium);font-size:64px;line-height:1.05;letter-spacing:-1.28px;margin-top:32px}
.headline .red{color:var(--accent);position:relative;display:inline-block;white-space:nowrap}
/* typewriter-каретка (как на действующем goldblum.ch), без подчёркивания */
.headline .red::after{content:"";display:inline-block;width:3px;height:.92em;margin-left:.04em;vertical-align:-.08em;background:var(--accent);animation:tw-caret .9s steps(1) infinite}
@keyframes tw-caret{0%,49%{opacity:1}50%,100%{opacity:0}}
.hero .lede{font-size:14px;line-height:18px;max-width:462px;margin-top:24px}
.cta-row{display:flex;gap:20px;margin-top:32px;flex-wrap:wrap}

/* LATEST AWARDS badge — правый край бейджей садится на контент-гаттер (макет: x=1112..1340, y=308 от верха hero) */
.hero-awards{position:absolute;top:214px;right:var(--gutter);width:228px;z-index:2}
.hero-awards__label{display:block;font-size:14px;line-height:18px;text-transform:uppercase;letter-spacing:.04em;color:var(--secondary);font-weight:var(--fw-light);margin-bottom:20px}
.hero-awards__row{display:flex;gap:20px}
.hero-awards__badge{height:139px;width:auto;display:block} /* настоящие бейджи ITR / IFLR1000 из макета (узел 7087:52022) */

/* Каскадный fade-up для hero-контента (заменяет typewriter, остаётся свежим, не отвлекает) */
.hero__cta > *{opacity:0;transform:translateY(14px);animation:fadeUp .7s cubic-bezier(.2,.7,.2,1) forwards}
.hero__cta > .eyebrow{animation-delay:.05s}
.hero__cta > .headline{animation-delay:.2s}
.hero__cta > .lede{animation-delay:.45s}
.hero__cta > .cta-row{animation-delay:.65s}

@keyframes fadeUp{to{opacity:1;transform:none}}
@keyframes hero-zoom{from{transform:scale(1)}to{transform:scale(1.08) translateY(-6px)}}

/* "Book a Meeting" — FIXED плавающая карточка, остаётся в правом-нижнем углу при прокрутке. */
.meet-card{position:fixed;right:24px;bottom:24px;max-width:360px;z-index:100;transition:opacity .45s,transform .45s}
/* Ships hidden; revealed on the visitor's first scroll (scripts.njk removes --await). */
.meet-card--await{opacity:0;transform:translateY(120%);pointer-events:none}
.meet-card.is-hidden{opacity:0;transform:translateY(120%);pointer-events:none}
.meet-card.is-dismissed{display:none}
.meet-card__link{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:16px;padding:16px 44px 16px 16px;background:var(--primary);color:var(--inverse);text-decoration:none;box-shadow:0 6px 32px rgba(0,0,0,.18)}
.meet-card img{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--secondary)}
.meet-card__txt{display:flex;flex-direction:column;gap:4px}
.meet-card__title{font-size:15px;line-height:1.2;font-weight:var(--fw-medium)}
.meet-card__sub{font-size:12px;line-height:1.3;color:var(--secondary);font-weight:var(--fw-light)}
.meet-card__arrow{width:16px;height:16px;color:var(--accent);flex-shrink:0;margin-left:auto;transition:transform .25s}
.meet-card__action{margin-left:auto;flex-shrink:0;font-size:13px;line-height:1.3;font-weight:var(--fw-regular);color:var(--accent);white-space:nowrap;align-self:flex-end} /* красный «Schedule» как в макете */
.meet-card__link:hover .meet-card__action{color:#fff}
.meet-card__link::before{content:"";position:absolute;inset:0;background:var(--accent);clip-path:circle(0% at 100% 50%);transition:clip-path .55s ease-in-out;z-index:0}
.meet-card__link > *{position:relative;z-index:1}
.meet-card__link:hover{transform:translateY(-2px)}
.meet-card__link:hover::before{clip-path:circle(140% at 100% 50%)}
.meet-card__close{position:absolute;top:7px;right:7px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;padding:0;background:transparent;border:0;color:var(--inverse);opacity:.5;cursor:pointer;z-index:3;transition:opacity .2s}
.meet-card__close:hover{opacity:1}
.meet-card__close svg{width:14px;height:14px}
.meet-card:hover .meet-card__sub{color:rgba(255,255,255,.85)}
.meet-card:hover .meet-card__arrow{color:#fff;transform:translateX(4px)}
.meet-card.is-hidden{animation:none;transform:translateY(140%);opacity:0;pointer-events:none;transition:transform .5s cubic-bezier(.2,.7,.2,1), opacity .4s} /* прячется когда видна форма Contact, чтобы не дублировать CTA */

@keyframes meet-card-enter{to{transform:none;opacity:1}}

/* Scroll-reveal — каждая секция: fade-up при появлении в видимости */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in-view{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal-stagger.in-view > *{opacity:1;transform:none}
.reveal-stagger.in-view > *:nth-child(1){transition-delay:0s}
.reveal-stagger.in-view > *:nth-child(2){transition-delay:.08s}
.reveal-stagger.in-view > *:nth-child(3){transition-delay:.16s}
.reveal-stagger.in-view > *:nth-child(4){transition-delay:.24s}
.reveal-stagger.in-view > *:nth-child(5){transition-delay:.32s}
.reveal-stagger.in-view > *:nth-child(n+6){transition-delay:.4s}

/* Уважаем prefers-reduced-motion: все анимации мгновенно завершаются, ничего не движется. */
@media (prefers-reduced-motion:reduce){
  .hero__bg, .ihero__bg, .hero__cta > *, .meet-card, .headline .red::after, .reveal, .reveal-stagger > *, .vtimeline__step{animation:none !important;transition:none !important;transform:none !important;opacity:1 !important}
  .vtimeline__step::before{transform:scaleY(1) !important}
  .vtimeline__step.in-view::after, .vtimeline__step::after{border-color:var(--accent) !important;background:var(--accent) !important}
}

/* ---------- PRACTICES (sec01, узел 7019:1550) ---------- */
/* Макет: лево = eyebrow+заголовок (верх) + фото (низ); право = вводный абзац (верх) + аккордеон (низ). Фото и аккордеон стартуют с одного Y. */
.practices .wrap{display:grid;grid-template-columns:505px minmax(0,610px);justify-content:space-between;column-gap:80px;row-gap:50px;align-items:start;grid-template-areas:'head intro' 'photo acc'}
.practices__head{grid-area:head}
.practices__intro{grid-area:intro;align-self:end;font-size:14px;line-height:18px;color:var(--primary);font-weight:var(--fw-light);max-width:525px;padding-bottom:6px} /* абзац прижат к низу строки — как в макете (y=210 под заголовком) */
.practices__photo{grid-area:photo;aspect-ratio:505/606;background:var(--muted)}
.acc{grid-area:acc}
.practices__photo img{width:100%;height:100%;object-fit:cover}
.acc{display:flex;flex-direction:column;border-top:1px solid var(--tertiary)}
.acc__item{border-bottom:1px solid var(--tertiary)}
.acc__row{display:grid;grid-template-columns:48px 1fr 24px;gap:24px;padding:24px 0;align-items:center;width:100%;background:none;border:0;text-align:left;color:inherit;font-size:20px;line-height:24px;font-weight:var(--fw-medium)}
.acc__num{color:var(--secondary);font-size:14px;font-weight:var(--fw-light);letter-spacing:.04em}
.acc__chev{width:24px;height:24px;transition:transform .2s}
.acc__item[open] .acc__chev{transform:rotate(180deg)}
.acc__body{padding:0 0 24px 72px;color:var(--primary);font-size:14px;line-height:1.6;font-weight:var(--fw-light)}
.acc__body a{color:var(--accent);font-weight:var(--fw-medium);display:inline-block;margin-top:12px;text-decoration:none;border-bottom:1px solid currentColor}

/* ---------- SERVICES (sec02, узел 7019:1612) ---------- */
.services__head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:60px}
.services__head .lede{max-width:none}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{background:var(--muted);padding:32px;display:flex;flex-direction:column;gap:24px;min-height:280px;border:1px solid transparent;transition:border-color .2s}
.svc-card:hover{border-color:var(--accent)}
.svc-card__head{display:flex;justify-content:space-between;align-items:baseline}
.svc-card__eyebrow{color:var(--accent);text-transform:uppercase;font-size:12px;letter-spacing:.06em;font-weight:var(--fw-medium)}
.svc-card__num{color:var(--secondary);font-size:14px;font-weight:var(--fw-light)}
.svc-card__title{font-size:24px;line-height:1.1;font-weight:var(--fw-medium);margin-top:8px}
.svc-card__desc{font-size:14px;line-height:1.6;color:var(--primary);font-weight:var(--fw-light);flex-grow:1}
.svc-card__link{font-size:14px;font-weight:var(--fw-medium);color:var(--primary);display:inline-flex;align-items:center;gap:8px;margin-top:auto}
.svc-card__link svg{width:14px;height:14px}
.svc-card:hover .svc-card__link{color:var(--accent)}

/* ---------- DESKS (sec03, узел 7019:1680) ---------- */
.desks__head{display:grid;grid-template-columns:1fr auto;gap:60px;align-items:end;margin-bottom:60px}
.desks-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:32px 32px}
.desk{display:flex;flex-direction:column;gap:16px;min-width:0}                          /* min-width:0 lets the 5 grid tracks shrink evenly so a long desk title wraps instead of forcing ~8px horizontal overflow at ~1024px */
.desk__title{font-size:20px;line-height:24px;font-weight:var(--fw-medium)}
.desk__links{display:flex;flex-direction:column;border-top:1px solid var(--tertiary)}
.desk__link{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-size:14px;line-height:18px;color:var(--primary);border-bottom:1px solid var(--tertiary);font-weight:var(--fw-light)}
.desk__link svg{width:14px;height:14px;color:var(--accent);transition:transform .2s}
.desk__link:hover{color:var(--accent)}
.desk__link:hover svg{transform:translate(2px,-2px)}

/* ---------- BANNER (sec04, узел 7019:1812) ---------- */
.banner{position:relative;background:var(--ink);color:var(--inverse);padding-block:0;overflow:hidden;min-height:900px;display:flex;flex-direction:column;justify-content:center}
.banner__bg{position:absolute;inset:0;background:var(--ink) url('sections/banner-bg.webp') center bottom/cover no-repeat}
.banner__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(102,102,102,.2) 0%,rgba(0,0,0,.2) 100%)} /* лёгкий оверлей как в макете */
.banner .wrap{position:relative;z-index:1;padding-block:100px}
.banner__eyebrow{display:block;text-align:center;font-size:14px;line-height:18px;text-transform:uppercase;color:var(--secondary);font-weight:var(--fw-regular);margin-bottom:32px}
.banner h2{color:#fff;text-align:center;max-width:635px;margin:0 auto 64px;font-size:48px;line-height:1.05;letter-spacing:-.96px;font-weight:var(--fw-medium)}
.banner h2 .red{color:var(--accent)}
.banner-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bn-card{background:rgba(255,255,255,.1);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);padding:24px;color:var(--inverse);display:flex;flex-direction:column;justify-content:center;min-height:186px}
.bn-card__num{color:var(--inverse);font-size:14px;line-height:18px;font-weight:var(--fw-regular);text-align:right;margin-bottom:32px}
.bn-card__title{font-size:20px;line-height:24px;font-weight:var(--fw-regular);margin-bottom:10px}
.bn-card__desc{font-size:14px;line-height:18px;color:var(--inverse);font-weight:var(--fw-regular)}
.bn-card--solid{background:#fff;color:var(--primary);position:relative} /* выделенная карточка 02 — сплошная белая (макет) */
.bn-card--solid .bn-card__num{color:var(--accent)}
.bn-card--solid .bn-card__title,.bn-card--solid .bn-card__desc{color:var(--primary)}
.bn-card__cursor{position:absolute;right:24px;top:62px;width:22px;height:22px;color:var(--primary)}

/* ---------- RANKINGS (sec05, узел 7019:1861) ---------- */
.rank__head{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:48px}
.rank .rank__title{font-size:clamp(26px,2.4vw,33px);font-weight:var(--fw-medium);letter-spacing:-.015em;line-height:1.18;max-width:600px;color:var(--primary);margin:18px 0 32px}
/* Recognitions plaque wall — uniform grid of genuine IFLR1000 / ITR rankings.
   1px gap over a grey container paints clean table gridlines without double-border
   maths; every cell is identical in size so there are no broken/frameless slots. */
.rank-seals{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.rank-seals__track{display:flex;align-items:center;gap:56px;width:max-content;animation:rank-marquee 42s linear infinite}
.rank-seals:hover .rank-seals__track{animation-play-state:paused}
.rank-seal{flex:0 0 auto;margin:0;height:200px;display:flex;align-items:center;justify-content:center}
.rank-seal img{height:100%;width:auto;display:block}
@keyframes rank-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.rank-seals__track{animation:none;overflow-x:auto}.rank-seals{-webkit-mask-image:none;mask-image:none}}
@media (max-width:560px){.rank-seal{height:150px}.rank-seals__track{gap:32px}}

/* ---------- INSIGHTS (sec06, узел 7019:1914) ---------- */
.ins{overflow:hidden}                                                                   /* hard guard: nothing in the Read-more block can paint past the section edge */
.ins .wrap{overflow:hidden}                                                             /* tighter guard at the centred 1440 box: even a tampered/over-wide grid can't spill a 4th-card sliver into the right margin */
.ins__head{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end;margin-bottom:60px}
/* Column count is set by an explicit .ins-grid--N class (N = number of cards), NOT a
   CSS custom property. An inline custom prop can silently fail to apply (stale cached
   CSS, a stripped style attribute) and then `repeat(var(--ins-cols,4),1fr)` falls back
   to FOUR columns — which on three cards leaves a cut 4th-card sliver on the right.
   Safe default is 3 (the usual sibling count); modifiers cover 1 / 2 / 4. */
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ins-grid--1{grid-template-columns:minmax(0,380px)}
.ins-grid--2{grid-template-columns:repeat(2,1fr)}
.ins-grid--4{grid-template-columns:repeat(4,1fr)}
.ins-card{display:flex;flex-direction:column;gap:16px;min-width:0}                       /* min-width:0 → a long title wraps instead of widening its track */
.ins-card__img{aspect-ratio:305/200;background:var(--muted);overflow:hidden}
.ins-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.ins-card:hover .ins-card__img img{transform:scale(1.04)}
.ins-card__cat{color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:var(--fw-medium)}
.ins-card__title{font-size:20px;line-height:1.3;font-weight:var(--fw-medium)}
.ins-card__meta{font-size:12px;color:var(--secondary);display:flex;align-items:center;gap:8px;font-weight:var(--fw-light);margin-top:auto}

/* ---------- MATTERS (representative client work) ---------- */
.matters{background:var(--muted)}
.matters__head{display:grid;grid-template-columns:1fr auto;gap:60px;align-items:end;margin-bottom:60px}
.matters__head .lede{max-width:42ch}
.matters-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.matter{background:var(--bg);padding:32px;display:flex;flex-direction:column;gap:14px;border-top:2px solid var(--accent);height:100%;transition:transform .2s}
.matter:hover{transform:translateY(-3px)}
.matter__sector{color:var(--accent);text-transform:uppercase;font-size:12px;letter-spacing:.06em;font-weight:var(--fw-medium)}
.matter__title{font-size:20px;line-height:1.25;font-weight:var(--fw-medium);letter-spacing:-.01em}
.matter__situation{font-size:14px;line-height:1.6;color:var(--primary);font-weight:var(--fw-light);flex-grow:1}
.matter__outcome{font-size:14px;line-height:1.6;color:var(--primary);font-weight:var(--fw-light);margin-top:6px;padding-top:16px;border-top:1px solid var(--tertiary)}
.matter__outcome-label{display:block;text-transform:uppercase;font-size:11px;letter-spacing:.08em;color:var(--secondary);font-weight:var(--fw-medium);margin-bottom:6px}
.matters__cta{margin-top:48px}
.matters__note{margin-top:24px;font-size:12px;line-height:1.5;color:var(--secondary);font-weight:var(--fw-light);max-width:78ch}

/* ---------- HUBS (sec07, узел 7019:2090) ---------- */
.hubs__head{margin-bottom:60px;max-width:900px}
.hubs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:32px 24px;align-items:stretch}
.hub{display:flex;flex-direction:column;gap:16px;height:100%}                   /* колонка во всю высоту ячейки */
.hub__title{font-size:18px;line-height:22px;font-weight:var(--fw-medium);min-height:2.44em} /* 2 строки фикс — заголовки выровнены */
.hub__items{display:flex;flex-direction:column;border-top:1px solid var(--tertiary);flex-grow:1} /* забирает оставшуюся высоту */
.hub__item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;font-size:13px;line-height:1.35;color:var(--primary);border-bottom:1px solid var(--tertiary);font-weight:var(--fw-light);gap:8px;min-height:60px} /* 2 строки фикс */
.hub__item svg{width:14px;height:14px;color:var(--accent);flex-shrink:0;margin-top:2px}
.hub__item:hover{color:var(--accent)}
.hub__all{display:flex;justify-content:space-between;align-items:center;background:var(--primary);color:var(--inverse);padding:12px 16px;font-size:13px;font-weight:var(--fw-medium);margin-top:auto} /* margin:auto → прижато к низу */
.hub__all svg{width:14px;height:14px}
.hub__all:hover{background:var(--accent)}

/* ---------- LOCATIONS (sec08, узел 7055:46892) ---------- */
.locations{position:relative;background:var(--ink);color:var(--inverse);overflow:hidden;padding-block:0}
.locations::before{content:"";position:absolute;inset:0;background:url('sections/swiss-map-outline.svg') center center/auto 122% no-repeat;opacity:.45;pointer-events:none} /* контур кантонов Швейцарии на фоне (макет) */
.locations .wrap{position:relative;z-index:1;padding-block:100px}
.locations__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch} /* 3×2 как в макете: голова в (1,1), 5 городов в остальных */
.locations__head{padding-right:24px;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:8px}
.locations__head .eyebrow{color:var(--secondary)}
.locations__head h2{color:var(--inverse);font-size:40px;line-height:1.05;margin-top:16px;font-weight:var(--fw-medium);letter-spacing:-.02em;white-space:nowrap} /* nowrap: 'Swiss-wide reach.' одной строкой как в макете */
.locations__head h2 .red{color:var(--accent);display:block}
.locations__head .lede{color:var(--secondary);margin-top:20px;max-width:34ch;font-size:15px;line-height:1.55}
.city{background:var(--inverse);color:var(--primary);padding:28px 36px;display:flex;align-items:center;gap:28px;min-height:180px;transition:background .2s,transform .2s}
.city:hover{background:#fff;transform:translateY(-2px)}
.city__coa{width:96px;height:120px;flex-shrink:0;display:grid;place-items:center}
.city__coa img{max-width:100%;max-height:100%;height:auto;display:block;object-fit:contain}
.city__name{color:var(--accent);font-size:36px;font-weight:var(--fw-medium);line-height:1;letter-spacing:-.01em}

/* ---------- CONTACT (sec09, узел 7055:47074) ---------- */
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact__intro h2{font-size:42px}
.contact__intro .lede{margin-top:24px}
/* Карточка Of Counsel — портрет выходит за верх чёрной плашки (макет 7055:47074) */
.counsel{display:flex;align-items:center;gap:20px;margin-top:48px}
.counsel img{width:96px;height:96px;object-fit:cover;object-position:50% 18%;filter:grayscale(1);flex:0 0 auto}
.counsel__txt{display:flex;flex-direction:column;gap:4px;padding:0}
.counsel__label{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--secondary);font-weight:var(--fw-regular)}
.counsel__name{font-size:20px;font-weight:var(--fw-medium);color:var(--primary)}
.counsel__role{font-size:14px;color:var(--secondary);font-weight:var(--fw-light);line-height:1.4}
.contact__direct{display:flex;gap:16px;margin-top:24px;flex-wrap:wrap}
.contact__direct a{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border:1px solid var(--tertiary);font-size:14px;font-weight:var(--fw-light)}
.contact__direct svg{width:16px;height:16px;color:var(--accent)}
form.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-form .full{grid-column:1/-1}
.contact-form input,.contact-form select,.contact-form textarea{font-family:inherit;font-size:15px;padding:18px 20px;border:0;background:var(--muted);color:var(--primary);width:100%;border-radius:0}
.contact-form select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:48px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none' stroke='%231d1d1d' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 20px center}
.contact-form select:invalid{color:var(--secondary)}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}
.contact-form textarea{min-height:130px;resize:vertical}
.contact-form .check{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--primary);font-weight:var(--fw-light);line-height:1.5;cursor:pointer}
.contact-form .check input{width:18px;height:18px;padding:0;margin-top:2px;background:none;border:1px solid var(--secondary);accent-color:var(--accent);flex-shrink:0}
.contact-form .check span{flex:1;min-width:0}                                            /* всё, что НЕ checkbox, в одном flex-item — текст не разъезжается */
.contact-form .check a{color:var(--accent);font-weight:var(--fw-medium);text-decoration:underline}
.contact-form .submit{grid-column:1/-1}
.contact-form .submit button{width:100%;padding:20px;background:var(--primary);color:var(--inverse);border:0;font-size:16px;font-weight:var(--fw-medium);cursor:pointer;transition:background .2s}
.contact-form .submit button:hover{background:var(--accent)}

/* ---------- FOOTER (sec10, узел 7019:2398) ---------- */
.footer{background:var(--muted);color:var(--primary);padding-block:60px 0}
.footer__top{display:grid;grid-template-columns:160px 1fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px}
.footer__logo .logo-box{width:140px}
.footer__col h3{color:var(--accent);font-size:16px;font-weight:var(--fw-medium);margin-bottom:18px}
.footer__col ul{display:flex;flex-direction:column;gap:10px}
.footer__col li,.footer__col a{font-size:14px;font-weight:var(--fw-light);color:var(--primary);line-height:1.4}
.footer__col a:hover{color:var(--accent)}
.footer__col address{font-style:normal;font-size:14px;font-weight:var(--fw-light);color:var(--primary);line-height:1.5;margin-bottom:14px}
.footer__col address + address{margin-top:6px}
.footer__col a.tel,.footer__col a.mail{display:block;margin-top:4px}
.footer__social li{display:flex;align-items:center;gap:10px}
.footer__social svg,.footer__social img{width:18px;height:18px;color:var(--accent)}
.footer__bot{border-top:1px solid var(--tertiary);padding-block:30px;display:grid;grid-template-columns:1fr 2.5fr auto;gap:40px;font-size:13px;font-weight:var(--fw-light);color:var(--secondary);align-items:start}
.footer__disclaimer{line-height:1.5}
.footer__legal{display:flex;gap:24px;margin-top:14px;font-size:13px;color:var(--secondary);font-weight:var(--fw-light)}
.footer__bot .totop{display:inline-flex;gap:8px;align-items:center;font-size:14px;color:var(--primary);font-weight:var(--fw-medium)}
.footer__bot .totop svg{width:14px;height:14px}

/* ===== NAV fits down to 1024 — the full horizontal nav's intrinsic width is
   ~1142px at the 100px desktop gutter, so at 1024–1141px (and wider under
   browser zoom) the Callback button overflowed the right edge → a horizontal
   scrollbar that surfaces on macOS mouse-move (the "strip on hover"). Tighten
   the gutter + link spacing in this band so the nav stays visible/usable and
   nothing overflows, rather than collapsing to the burger (which is inert —
   no toggle JS yet). Burger still takes over at ≤1023 as before. */
@media (max-width:1199px){
  :root{--gutter:48px}
  .nav-links{gap:28px;margin-left:32px}
}

/* ===================== TABLET ≤1023 ===================== */
@media (max-width:1023px){
  .nav-links,.nav-right .lang,.nav-right .btn{display:none}
  .hero-awards{display:none}                                                            /* бейдж наград — только на десктопе, иначе перекрывает hero */
  .burger{display:inline-flex}
  .nav .wrap{justify-content:space-between}
  .headline{font-size:48px;letter-spacing:-1px}
  .hero{min-height:660px}
  .meet-card{right:16px;bottom:16px;max-width:300px;padding:12px 16px 12px 12px}        /* остаётся fixed, но компактнее на планшете */
  .meet-card img{width:40px;height:40px}
  .meet-card__title{font-size:14px}
  .meet-card__sub{font-size:11px}
  .section{padding-block:80px}
  .practices .wrap{grid-template-columns:1fr;gap:48px}
  .cards-3,.matters-grid{grid-template-columns:repeat(2,1fr)}
  .desks-grid,.hubs-grid{grid-template-columns:repeat(3,1fr)}
  .rank-row,.ins-grid{grid-template-columns:repeat(2,1fr)}
  .banner-grid{grid-template-columns:repeat(2,1fr)}
  .locations__grid{grid-template-columns:1fr}
  .cities{grid-template-columns:repeat(2,1fr)}
  .contact .wrap{grid-template-columns:1fr}
  .footer__top{grid-template-columns:repeat(2,1fr)}
  .footer__bot{grid-template-columns:1fr}
}
/* ===================== MOBILE ≤767 ===================== */
@media (max-width:767px){
  :root{--gutter:20px}
  .utility .wrap{height:auto;padding-block:8px;gap:12px;flex-wrap:wrap}
  .u-cities{order:3;flex-basis:100%;overflow-x:auto;gap:16px;-webkit-overflow-scrolling:touch}
  .nav{padding-block:14px}
  .hero{min-height:auto;flex-direction:column}
  .hero__inner{order:1;padding-block:40px 0}
  .headline{font-size:34px;letter-spacing:-.5px;margin-top:24px}
  .hero .lede{margin-top:20px}
  .cta-row{margin-top:28px;gap:12px}.cta-row .btn{flex:1 1 100%}
  .meet-card{right:12px;bottom:12px;left:12px;max-width:none;padding:10px 14px 10px 10px}  /* на мобильном — пинн снизу на всю ширину */
  .meet-card__sub{display:none}                                                            /* экономим место */
  .hero__bg{position:relative;order:2;margin-top:28px}
  .section{padding-block:60px}
  .section h2,.h2,.banner h2,.locations__head h2,.contact__intro h2,.rank h2{font-size:34px}
  .cards-3,.matters-grid,.desks-grid,.hubs-grid,.rank-row,.ins-grid,.banner-grid,.cities{grid-template-columns:1fr}
  .matters__head{grid-template-columns:1fr;gap:24px}
  form.contact-form{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
}

/* ============================================================= */
/* LOCATION PAGES (contacts/zurich.html, contacts/zug.html)       */
/* Схема: contact-page = full landing per memory/contact-page-... */
/* ============================================================= */

/* ---------- LOC-HERO: H1 слева, форма справа ---------- */
.loc-hero{padding-block:80px 60px;background:var(--bg)}
.loc-hero .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:start}
.loc-hero__head h1{font-weight:var(--fw-medium);font-size:56px;line-height:1.05;letter-spacing:-1px;margin-top:20px}
.loc-hero__head h1 .red{color:var(--accent);display:block}
.loc-hero__head .lede{font-size:16px;line-height:1.55;color:var(--primary);font-weight:var(--fw-light);margin-top:24px;max-width:54ch}
.loc-hero__head .lede strong{font-weight:var(--fw-medium)}
.loc-hero__quickfacts{display:flex;gap:32px;margin-top:32px;padding-top:24px;border-top:1px solid var(--tertiary);flex-wrap:wrap}
.loc-hero__quickfact{display:flex;flex-direction:column;gap:4px}
.loc-hero__quickfact .label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary);font-weight:var(--fw-light)}
.loc-hero__quickfact .value{font-size:16px;font-weight:var(--fw-medium);line-height:1.3}

/* ---------- LOC-FORM (правая колонка hero) ---------- */
.loc-form{background:var(--muted);padding:32px 28px;border-top:3px solid var(--accent);position:sticky;top:24px}
.loc-form h2{font-size:22px;font-weight:var(--fw-medium);line-height:1.2;margin-bottom:6px}
.loc-form p{font-size:13px;color:var(--secondary);font-weight:var(--fw-light);margin-bottom:20px}
.loc-form .field{display:block;margin-bottom:12px}
.loc-form input,.loc-form select,.loc-form textarea{font-family:inherit;font-size:14px;padding:14px 16px;border:0;background:var(--bg);color:var(--primary);width:100%;border-radius:0}
.loc-form textarea{min-height:90px;resize:vertical}
.loc-form input:focus,.loc-form select:focus,.loc-form textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}
.loc-form button{width:100%;padding:16px;background:var(--primary);color:var(--inverse);border:0;font-size:15px;font-weight:var(--fw-medium);cursor:pointer;transition:background .2s;margin-top:4px;font-family:inherit}
.loc-form button:hover{background:var(--accent)}
.loc-form .privacy{font-size:11px;color:var(--secondary);font-weight:var(--fw-light);margin-top:12px;line-height:1.4}
.loc-form .privacy a{color:var(--accent);text-decoration:underline}

/* ---------- LOC-INFO: 3 карточки (адрес, телефон, часы) ---------- */
/* Visit us — Figma "map left + office details right" pattern, both offices.
   OpenStreetMap embed (keyless, always renders — no Google consent blank void). */
.loc-visit{padding-block:72px;background:var(--bg);border-top:1px solid var(--tertiary)}
.loc-visit__head{margin-bottom:8px;max-width:760px}
.loc-visit__head .eyebrow{display:block;margin-bottom:14px}
.loc-visit__head h2{font-size:clamp(28px,3vw,40px);font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.1}
.loc-visit__lead{font-size:16px;line-height:1.6;color:var(--secondary);font-weight:var(--fw-light);margin-top:16px;max-width:62ch}
.loc-office{display:grid;grid-template-columns:1.35fr 1fr;border:1px solid var(--tertiary);margin-top:24px}
.loc-office__map{position:relative;min-height:360px;background:var(--muted);overflow:hidden;display:block}
.loc-office__map img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .4s}
.loc-office__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.loc-office__map:hover img{transform:scale(1.03)}
.loc-office__details{padding:40px 36px;display:flex;flex-direction:column;gap:16px;border-left:1px solid var(--tertiary)}
.loc-office__name{font-size:24px;font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.1}
.loc-office__addr{font-size:17px;font-weight:var(--fw-medium);line-height:1.5;color:var(--primary);margin:0}
.loc-office__rows{display:flex;flex-direction:column;margin:0}
.loc-office__rows > div{display:grid;grid-template-columns:78px 1fr;gap:18px;align-items:baseline;padding:12px 0;border-top:1px solid var(--tertiary)}
.loc-office__rows dt{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary);font-weight:var(--fw-light)}
.loc-office__rows dd{margin:0;font-size:14px;line-height:1.5;color:var(--primary);font-weight:var(--fw-light)}
.loc-office__rows dd a{color:inherit;font-weight:var(--fw-medium)}
.loc-office__rows dd a:hover{color:var(--accent)}
.loc-office__dir{display:inline-flex;align-items:center;gap:8px;margin-top:4px;font-size:14px;font-weight:var(--fw-medium);color:var(--accent);transition:gap .15s}
.loc-office__dir svg{width:14px;height:14px}
.loc-office__dir:hover{gap:11px}

/* ---------- LOC-MAP: Google Maps iframe ---------- */
/* (.loc-map full-bleed section removed — maps now live inside .loc-office) */

/* ---------- LOC-SERVICES: 5 услуг как чипсы ---------- */
.loc-services{padding-block:80px;background:var(--bg)}
.loc-services .eyebrow{display:block;margin-bottom:12px}
.loc-services h2{font-size:36px;font-weight:var(--fw-medium);letter-spacing:-.01em;margin-bottom:40px;line-height:1.1}
.loc-services__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--tertiary);border:1px solid var(--tertiary)}
.loc-services__item{background:var(--bg);padding:28px 24px;display:flex;flex-direction:column;gap:16px;text-decoration:none;color:var(--primary);min-height:200px;transition:background .2s}
.loc-services__item:hover{background:var(--muted)}
.loc-services__item .num{font-size:13px;color:var(--secondary);font-weight:var(--fw-light)}
.loc-services__item .title{font-size:16px;font-weight:var(--fw-medium);line-height:1.3;margin-top:auto}
.loc-services__item .desc{font-size:13px;color:var(--secondary);font-weight:var(--fw-light);line-height:1.45}
.loc-services__item .arrow{margin-top:14px;display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--accent);font-weight:var(--fw-medium)}
.loc-services__item .arrow svg{width:14px;height:14px}

/* ---------- LOC-HIGHLIGHTS: тёмный блок ключевых практик (FinTech / Crypto / SPV / Tax) ---------- */
.loc-highlights{padding-block:96px;background:var(--primary);color:var(--inverse)}
.loc-highlights .wrap{display:flex;flex-direction:column;gap:56px}
.loc-highlights__head{max-width:880px}
.loc-highlights__head .eyebrow{color:var(--secondary)}
.loc-highlights__head h2{font-size:42px;line-height:1.05;font-weight:var(--fw-medium);letter-spacing:-.01em;color:var(--inverse);margin-top:16px}
.loc-highlights__head h2 .red{color:var(--accent);display:block}
.loc-highlights__head p{color:var(--secondary);font-size:15px;line-height:1.6;font-weight:var(--fw-light);max-width:60ch;margin-top:20px}
.loc-highlights__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.12)}
.loc-highlights__item{display:flex;flex-direction:column;gap:14px;padding:32px 28px;background:var(--ink);text-decoration:none;color:var(--inverse);transition:background .25s}
.loc-highlights__item:hover{background:var(--ink-hover)}
.loc-highlights__icon{width:44px;height:44px;display:grid;place-items:center;background:var(--accent);border-radius:50%;color:#fff;flex-shrink:0}
.loc-highlights__icon svg{width:22px;height:22px}
.loc-highlights__title{font-size:20px;font-weight:var(--fw-medium);line-height:1.25;letter-spacing:-.01em;margin-top:8px}
.loc-highlights__desc{color:var(--secondary);font-size:13px;line-height:1.55;font-weight:var(--fw-light);flex:1}
.loc-highlights__link{margin-top:6px;color:var(--inverse);font-weight:var(--fw-medium);font-size:13px;display:inline-flex;align-items:center;gap:6px;width:fit-content;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:4px;transition:color .2s,border-color .2s}
.loc-highlights__link:hover{color:var(--accent);border-color:var(--accent)}
.loc-highlights__link svg{width:13px;height:13px;transition:transform .25s}
.loc-highlights__link:hover svg{transform:translateX(3px)}
@media (max-width:1023px){.loc-highlights__grid{grid-template-columns:repeat(2,1fr)}.loc-highlights{padding-block:72px}}
@media (max-width:600px){.loc-highlights__grid{grid-template-columns:1fr}.loc-highlights__head h2{font-size:32px}}

/* ---------- LOC-ABOUT: 2 колонки текст + изображение ---------- */
.loc-about{padding-block:80px;background:var(--muted)}
.loc-about .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.loc-about__txt h2{font-size:36px;font-weight:var(--fw-medium);letter-spacing:-.01em;margin-bottom:24px;line-height:1.1}
.loc-about__txt p{font-size:15px;line-height:1.6;color:var(--primary);font-weight:var(--fw-light);margin-bottom:14px}
.loc-about__photo{aspect-ratio:1.1/1;background:var(--tertiary);overflow:hidden}
.loc-about__photo img{width:100%;height:100%;object-fit:cover}

/* ---------- LOC-TEAM: 4 партнёра ---------- */
.loc-team{padding-block:80px}
.loc-team .head{margin-bottom:48px}
.loc-team h2{font-size:36px;font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.1;margin-top:12px}
.loc-team .lede{font-size:14px;color:var(--secondary);font-weight:var(--fw-light);margin-top:16px;max-width:50ch}
.loc-team__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.loc-team__card{display:flex;flex-direction:column;gap:14px}
.loc-team__photo{aspect-ratio:1/1;background:var(--tertiary);overflow:hidden}
.loc-team__photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15)}
.loc-team__name{font-size:18px;font-weight:var(--fw-medium)}
.loc-team__role{font-size:13px;color:var(--accent);font-weight:var(--fw-medium);margin-top:2px}
.loc-team__bio{font-size:13px;color:var(--secondary);font-weight:var(--fw-light);line-height:1.5;margin-top:6px}

/* ---------- LOC-REVIEWS: 3 отзыва ---------- */
.loc-reviews{padding-block:80px;background:var(--primary);color:var(--inverse)}
.loc-reviews__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px}
.loc-reviews__intro{max-width:60ch}
.loc-reviews h2{font-size:36px;font-weight:var(--fw-medium);letter-spacing:-.01em;color:var(--inverse);margin:6px 0 0;line-height:1.1}
.loc-reviews__agg{color:rgba(255,255,255,.66);font-weight:var(--fw-light);margin-top:14px;font-size:15px;line-height:1.5}
.loc-reviews__agg strong{color:#fff;font-weight:var(--fw-medium)}
.loc-reviews__agg a{color:var(--accent)}
.loc-reviews__stars-agg{display:inline-flex;gap:3px;color:var(--accent);vertical-align:-3px;margin-right:10px}
.loc-reviews__stars-agg svg{width:18px;height:18px}
.loc-reviews__marquee{overflow:hidden;margin-top:36px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.loc-reviews__track{display:flex;gap:24px;width:max-content;animation:reviews-marquee 56s linear infinite}
.loc-reviews__marquee:hover .loc-reviews__track{animation-play-state:paused}
@keyframes reviews-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.loc-reviews__track{animation:none}.loc-reviews__marquee{overflow-x:auto;-webkit-mask-image:none;mask-image:none}}
.loc-reviews__card{flex:0 0 360px;scroll-snap-align:start;background:rgba(255,255,255,.05);padding:28px;border:1px solid rgba(255,255,255,.1);margin:0;display:flex;flex-direction:column}
.loc-reviews__stars{display:flex;gap:2px;color:var(--accent);margin-bottom:16px}
.loc-reviews__stars svg{width:18px;height:18px}
.loc-reviews__quote{font-size:15px;line-height:1.6;font-weight:var(--fw-light);margin:0 0 20px;flex:1}
.loc-reviews__author{font-size:13px;color:var(--inverse);font-weight:var(--fw-medium);margin:0}
.loc-reviews__author span{color:var(--secondary);font-weight:var(--fw-light);display:block;font-size:12px;margin-top:2px}

/* ---------- LOC-GALLERY: 6 локальных фото ---------- */
.loc-gallery{padding-block:80px}
.loc-gallery h2{font-size:36px;font-weight:var(--fw-medium);letter-spacing:-.01em;margin-bottom:40px;line-height:1.1}
.loc-gallery__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.loc-gallery__item{aspect-ratio:1/1;background:var(--tertiary);overflow:hidden;position:relative;transition:transform .25s}
.loc-gallery__item:hover{transform:scale(1.02)}
.loc-gallery__item img{width:100%;height:100%;object-fit:cover}

/* ---------- LOC-AREA: 2-кол список районов обслуживания ---------- */
.loc-area{padding-block:80px;background:var(--muted)}
.loc-area h2{font-size:36px;font-weight:var(--fw-medium);letter-spacing:-.01em;margin-bottom:24px;line-height:1.1}
.loc-area .lede{font-size:14px;color:var(--secondary);font-weight:var(--fw-light);margin-bottom:36px;max-width:60ch}
.loc-area__cols{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 60px}
.loc-area__item{padding:10px 0;border-bottom:1px solid var(--tertiary);font-size:15px;font-weight:var(--fw-light);display:flex;align-items:center;gap:10px}
.loc-area__item::before{content:"→";color:var(--accent);font-weight:var(--fw-medium)}

/* ---------- LOC-FAQ: 3 вопроса (details/summary) ---------- */
.loc-faq{padding-block:80px}
.loc-faq h2{font-size:36px;font-weight:var(--fw-medium);letter-spacing:-.01em;margin-bottom:40px;line-height:1.1}
.loc-faq__item{border-top:1px solid var(--tertiary)}
.loc-faq__item:last-child{border-bottom:1px solid var(--tertiary)}
.loc-faq__item summary{padding:24px 0;font-size:18px;font-weight:var(--fw-medium);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;line-height:1.3}
.loc-faq__item summary::-webkit-details-marker{display:none}
.loc-faq__item summary::after{content:"+";font-size:24px;color:var(--accent);font-weight:var(--fw-light);transition:transform .2s}
.loc-faq__item[open] summary::after{content:"−"}
.loc-faq__item .ans{padding:0 0 24px;font-size:15px;line-height:1.6;color:var(--secondary);font-weight:var(--fw-light);max-width:80ch}
.loc-faq__item .ans a{color:var(--accent);text-decoration:underline}

/* ---------- LOC-CTA: финальный CTA-баннер ---------- */
.loc-cta{padding-block:80px;background:var(--primary);color:var(--inverse);text-align:center}
.loc-cta h2{font-size:42px;font-weight:var(--fw-medium);letter-spacing:-.01em;color:var(--inverse);margin-bottom:16px;line-height:1.1}
.loc-cta p{font-size:16px;color:var(--secondary);font-weight:var(--fw-light);margin-bottom:32px;max-width:60ch;margin-inline:auto}
.loc-cta__row{display:inline-flex;gap:16px;flex-wrap:wrap;justify-content:center}
.loc-cta .btn--dark{background:var(--accent);border-color:var(--accent)}
.loc-cta .btn{color:var(--inverse);border-color:rgba(255,255,255,.3)}
.loc-cta .btn:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- LOC-OTHER: ссылки на другие офисы ---------- */
.loc-other{padding-block:60px;background:var(--bg);border-top:1px solid var(--tertiary)}
.loc-other .eyebrow{display:block;margin-bottom:24px;color:var(--secondary)}
.loc-other__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.loc-other__card{display:flex;align-items:center;gap:24px;padding:24px;background:var(--muted);text-decoration:none;color:var(--primary);transition:background .2s}
.loc-other__card:hover{background:var(--tertiary)}
.loc-other__card img{width:64px;height:80px;object-fit:contain;flex-shrink:0}
.loc-other__card .info{flex:1}
.loc-other__card .info h3{font-size:18px;font-weight:var(--fw-medium);margin-bottom:4px}
.loc-other__card .info p{font-size:13px;color:var(--secondary);font-weight:var(--fw-light);line-height:1.4}
.loc-other__card .arrow{color:var(--accent);font-size:24px}

/* ---------- Contact: image hero, "Visit us" heading, shelf band, discuss form ---------- */
.loc-hero .wrap{align-items:stretch}
.loc-hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.loc-hero__media{margin:0;min-height:440px;overflow:hidden;background:var(--muted)}
.loc-hero__media img{display:block;width:100%;height:100%;min-height:440px;object-fit:cover;object-position:center}
.loc-info__head{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.loc-info__head h2{font-size:clamp(28px,3vw,40px);font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.1}
.eyebrow--inv{color:rgba(255,255,255,.6)}
.cic-shelf{padding-block:80px;background:var(--muted)}
.cic-shelf__text{max-width:760px}
.cic-shelf__text .eyebrow{display:block;margin-bottom:14px}
.cic-shelf__text h2{font-size:clamp(30px,3.2vw,44px);font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.08;margin-bottom:20px}
.cic-shelf__text p{font-size:16px;line-height:1.6;color:var(--primary);font-weight:var(--fw-light);margin-bottom:30px;max-width:64ch}
.cic-shelf__text p strong{font-weight:var(--fw-medium)}
.cic-discuss{padding-block:80px;background:var(--bg);border-top:1px solid var(--tertiary)}
.cic-discuss .wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.cic-discuss__intro .eyebrow{display:block;margin-bottom:14px}
.cic-discuss__intro h2{font-size:clamp(32px,3.6vw,48px);font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.05;margin-bottom:20px}
.cic-discuss__intro p{font-size:16px;line-height:1.6;color:var(--secondary);font-weight:var(--fw-light);max-width:54ch;margin-bottom:32px}
.cic-discuss__contacts{list-style:none;margin:0;padding:0}
.cic-discuss__contacts li{display:flex;gap:20px;align-items:baseline;padding:16px 0;border-top:1px solid var(--tertiary);font-size:17px;font-weight:var(--fw-medium)}
.cic-discuss__contacts li:last-child{border-bottom:1px solid var(--tertiary)}
.cic-discuss__contacts .k{flex:0 0 84px;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary);font-weight:var(--fw-light)}
.cic-discuss__contacts a{color:inherit}
.cic-discuss__contacts a:hover{color:var(--accent)}
.cic-discuss .loc-form{position:static;border-top:3px solid var(--accent)}

/* ---------- Адаптив для location-страниц ---------- */
@media (max-width:1023px){
  .loc-hero .wrap{grid-template-columns:1fr;gap:48px}
  .loc-form{position:static}
  .loc-office{grid-template-columns:1fr}
  .loc-office__map{min-height:260px}
  .loc-office__details{border-left:0;border-top:1px solid var(--tertiary)}
  .loc-services__grid{grid-template-columns:repeat(3,1fr)}
  .loc-about .wrap{grid-template-columns:1fr;gap:32px}
  .loc-team__grid{grid-template-columns:repeat(2,1fr)}
  .loc-area__cols,.loc-other__grid{grid-template-columns:1fr}
  .loc-reviews__head{flex-direction:column;align-items:flex-start;gap:16px}
  .loc-gallery__grid{grid-template-columns:repeat(3,1fr)}
  .cic-discuss .wrap{grid-template-columns:1fr;gap:48px}
  .loc-hero__media{min-height:300px}
  .loc-hero__media img{min-height:300px}
}
@media (max-width:767px){
  .loc-hero__head h1{font-size:36px}
  .loc-services__grid{grid-template-columns:1fr;border-left:0;border-right:0}
  .loc-team__grid,.loc-gallery__grid{grid-template-columns:repeat(2,1fr)}
  .loc-cta h2{font-size:30px}
}

/* ============================================================= */
/* ARTICLE / BLOG PAGE (узел 7091:53746) — переиспользуемый шаблон */
/* ============================================================= */
.article{padding-top:46px}
/* --- cover: хлебные крошки, категория, H1, мета, дивайдер --- */
.art-crumbs{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;line-height:1.3;color:var(--secondary)}
.art-crumbs a{color:var(--secondary)}
.art-crumbs a:hover{color:var(--primary)}
.art-crumbs .current{color:var(--primary)}
.art-cover__cat{display:block;font-size:16px;line-height:1.3;color:var(--secondary);font-weight:var(--fw-light);margin-top:34px}
.art-cover h1{font-size:64px;line-height:1.0;letter-spacing:-1.28px;font-weight:var(--fw-medium);margin-top:18px;max-width:1237px}
.art-meta{display:grid;grid-template-columns:repeat(3,minmax(0,190px));gap:20px;align-items:end;margin-top:60px;position:relative}
.art-meta__item{display:flex;flex-direction:column;gap:2px}
.art-meta__k{font-size:12px;line-height:1.3;color:var(--secondary)}
.art-meta__v{font-size:12px;line-height:1.3;color:var(--primary);margin-top:2px}
.art-meta__date{font-size:12px;line-height:1.3;color:var(--primary)}
.art-scroll{position:absolute;right:0;bottom:2px;display:flex;align-items:center;gap:12px;font-size:10px;color:var(--secondary)}
.art-scroll svg{width:14px;height:14px}
.art-cover__rule{border:0;border-top:1px solid var(--tertiary);margin-top:36px}

/* --- центральная колонка чтения 820px --- */
.art-col{width:min(820px,calc(100% - 40px));margin-inline:auto}
.art-lead{font-size:24px;line-height:1.4;color:var(--primary);font-weight:var(--fw-regular);margin-block:56px}

/* KB / article cover (Figma "Blog page": category + H1 + author/date/reading meta) */
.acover{position:relative;z-index:2;padding-bottom:0}
.acover__cat{display:inline-block;color:var(--accent);text-decoration:none}
.acover__cat:hover{text-decoration:underline}
.acover__title{font-size:clamp(32px,4.6vw,60px);line-height:1.05;letter-spacing:-.02em;font-weight:var(--fw-medium);margin:18px 0 0;max-width:22ch}
.acover__meta{display:flex;flex-wrap:wrap;gap:56px;margin:36px 0 0;padding:22px 0 0;border-top:1px solid var(--tertiary)}
.acover__metaitem{display:flex;flex-direction:column;gap:7px}
.acover__metaitem dt{font-size:11px;letter-spacing:.04em;color:var(--secondary);font-weight:var(--fw-light)}
.acover__metaitem dd{margin:0;font-size:14px;font-weight:var(--fw-medium)}
.acover__metaitem dd a{color:inherit;text-decoration:none}
.acover__metaitem dd a:hover{color:var(--accent)}
.acover__avatar{border-radius:50%;object-fit:cover}
/* hero cityscape, sky removed, bleeding up behind the H1 — homepage-mountain treatment */
.acover-fig{position:relative;z-index:1;margin:-68px 0 0;pointer-events:none}
.acover-fig__img{display:block;width:100%;height:auto;background:transparent}
.acover-fig__cap.wrap{margin:16px auto 0;font-size:13px;color:var(--secondary);font-weight:var(--fw-light);pointer-events:auto}
/* rotating Alps hero band on KB articles (same .ihero__bg system as the hubs); sits below the byline, full-bleed */
.acover-stage{position:relative;margin:44px 0 0}
.acover-byline{padding-top:8px;padding-bottom:0}
/* Lead paragraph, lifted above the TOC: a proper readable intro under the byline
   (was buried after the TOC as a cramped narrow block). */
.acover-lede{margin:24px 0 0;max-width:64ch;font-size:19px;line-height:1.55;font-weight:var(--fw-light);color:var(--primary)}
.acover-lede a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
/* mobile: the panorama is too short to bleed under the H1 — drop it below the title instead */
@media (max-width:767px){.acover-fig{margin-top:20px}.acover-fig__cap.wrap{margin-top:12px}.acover-lede{font-size:17px}.acover-stage{margin-top:24px}}
.toc-section{padding-top:8px;padding-bottom:0}
/* TOC precedes the body: the first heading rides on the section padding alone,
   so the TOC's last item is followed by the first H2, not a floating void. */
.toc-section + .section.prose .prose__col > :first-child{margin-top:0}
.rel-inline{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px;padding:22px 0 0;border-top:1px solid var(--tertiary);font-size:15px}
.rel-inline__k{color:var(--secondary);font-weight:var(--fw-light);margin-right:4px}
.rel-inline a{color:var(--primary);font-weight:var(--fw-medium);text-decoration:none}
.rel-inline a:hover{color:var(--accent)}
.rel-inline__sep{color:var(--tertiary)}

/* --- оглавление: лейбл в левом поле, нумерованный список --- */
.toc{position:relative;margin-block:48px 0}
.toc__label{font-size:16px;line-height:1.3;color:var(--secondary);font-weight:var(--fw-light);margin-bottom:20px}
.toc__list{list-style:none}
.toc__list a{display:flex;align-items:baseline;gap:80px;padding:13px 0;border-bottom:1px solid var(--tertiary);color:var(--primary);transition:color .2s}
.toc__list li:first-child a{border-top:1px solid var(--tertiary)}
.toc__num{flex:0 0 auto;min-width:30px;font-size:22px;line-height:1.1;font-weight:var(--fw-medium);color:var(--accent)}
.toc__num::after{content:"."}
.toc__ttl{font-size:20px;line-height:1.2;font-weight:var(--fw-regular)}
.toc__list a:hover .toc__ttl{color:var(--accent)}
@media(min-width:1240px){
  .toc__label{position:absolute;left:calc(-1 * (50vw - 410px - 100px));top:0;width:170px;margin-bottom:0}
}

/* --- фото с подписью --- */
.art-figure{margin-block:48px}
.art-figure img{width:100%;height:auto;display:block}
.art-figure figcaption{font-size:13px;line-height:1.4;color:var(--secondary);margin-top:10px}

/* --- текстовый блок: H2 + абзацы, красные ссылки --- */
.art-text{margin-block:48px}
.art-text[id],.art-text [id]{scroll-margin-top:110px} /* якорь не прячется под липкую шапку */
.art-text > * + *{margin-top:40px}
.art-text h2{font-size:48px;line-height:1.04;letter-spacing:-.96px;font-weight:var(--fw-medium);color:var(--primary)}
.art-text h3{font-size:28px;line-height:1.15;letter-spacing:-.4px;font-weight:var(--fw-medium);color:var(--primary)}
.art-text p{font-size:16px;line-height:1.5;color:var(--primary);font-weight:var(--fw-light)}
.art-text p.art-text__intro{font-size:20px;line-height:1.45;font-weight:var(--fw-regular)}
.art-text a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:from-font}
.art-text a:hover{text-decoration-thickness:2px}
.art-text ul,.art-text ol{margin-left:1.2em}
.art-text li{font-size:16px;line-height:1.5;color:var(--primary);font-weight:var(--fw-light);margin-top:8px}

/* --- двухколоночный блок: фото слева + текст справа --- */
.art-split{display:grid;grid-template-columns:294px 1fr;gap:20px;align-items:start;margin-block:48px}
.art-split figure img{width:100%;height:auto;display:block}
.art-split figcaption{font-size:13px;line-height:1.4;color:var(--secondary);margin-top:8px}
.art-split__text > * + *{margin-top:24px}
.art-split__text p{font-size:16px;line-height:1.5;color:var(--primary);font-weight:var(--fw-light)}

/* --- mid-CTA: тёмная полоса "Get in touch" --- */
/* "Discuss your matter" CTA band — LIGHT, per Figma KB design (was a heavy black
   block that diverged from the design and overwhelmed thin pages). Light grey panel,
   dark heading, outlined fields on white, dark submit. Consistent across every page. */
.midcta{background:var(--muted);color:var(--primary);margin-block:0;border-top:1px solid var(--tertiary)}
.midcta .wrap{display:grid;grid-template-columns:1fr 1fr;gap:96px;padding-block:80px;align-items:start}
.midcta__head h2{font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:-.01em;font-weight:var(--fw-medium);color:var(--primary)}
.midcta__head p{margin-top:20px;font-size:15px;line-height:1.6;color:var(--secondary);font-weight:var(--fw-light);max-width:44ch}
.midcta-form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.midcta-form .full{grid-column:1/-1}
.midcta-form input{font-family:inherit;font-size:15px;padding:16px 18px;border:1px solid var(--tertiary);background:var(--bg);color:var(--primary);width:100%}
.midcta-form input::placeholder,.midcta-form textarea::placeholder{color:var(--secondary)}
.midcta-form textarea{font-family:inherit;font-size:15px;padding:16px 18px;border:1px solid var(--tertiary);background:var(--bg);color:var(--primary);width:100%;min-height:108px;resize:vertical;display:block}
.midcta-form input:focus,.midcta-form textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}
.midcta-form .check{display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.5;color:var(--secondary);font-weight:var(--fw-light);cursor:pointer}
.midcta-form .check input{width:18px;height:18px;margin-top:2px;accent-color:var(--accent);background:none;border:1px solid var(--secondary);flex-shrink:0}
.midcta-form .check a{color:var(--accent);font-weight:var(--fw-medium);text-decoration:underline}
.midcta-form .check span{flex:1;min-width:0}
.midcta-form button{grid-column:1/-1;background:var(--primary);color:var(--inverse);border:0;font-family:inherit;font-size:16px;font-weight:var(--fw-medium);padding:18px;cursor:pointer;transition:background .2s}
.midcta-form button:hover{background:var(--accent)}

/* --- "Read more in our knowledge base": 4 карточки --- */
.knowledge{background:#f1f1f1}
.knowledge .wrap{padding-block:100px}
.knowledge__inner{display:flex;flex-direction:column;gap:64px;align-items:center}
.knowledge__head{width:100%}
.knowledge__head h2{font-size:48px;line-height:1.04;letter-spacing:-.96px;font-weight:var(--fw-medium);color:var(--primary)}
.kn-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;width:100%}
.kn-card{display:flex;flex-direction:column;background:var(--inverse)}
.kn-card__img{aspect-ratio:295/230;overflow:hidden}
.kn-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.kn-card:hover .kn-card__img img{transform:scale(1.04)}
.kn-card__body{display:flex;flex-direction:column;gap:32px;padding:24px;flex:1}
.kn-card__txt{display:flex;flex-direction:column;gap:14px}
.kn-card__cat{font-size:14px;line-height:18px;color:var(--primary);font-weight:var(--fw-regular)}
.kn-card__title{font-size:20px;line-height:1.1;color:var(--primary);font-weight:var(--fw-regular)}
.kn-card__time{display:flex;align-items:center;gap:8px;font-size:14px;line-height:18px;color:var(--secondary);margin-top:auto}
.kn-card__time svg{width:16px;height:16px}
.kn-more{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;padding:16px 32px;font-size:16px;font-weight:var(--fw-regular);transition:opacity .2s}
.kn-more:hover{opacity:.9}

/* --- адаптив статьи --- */
@media(max-width:1023px){
  .art-cover h1{font-size:44px;letter-spacing:-.8px}
  .art-lead{font-size:20px}
  .midcta .wrap{grid-template-columns:1fr;gap:40px;padding-block:64px}
  .kn-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .article{padding-top:28px}
  .art-cover h1{font-size:34px;letter-spacing:-.4px}
  .art-meta{grid-template-columns:1fr 1fr;gap:24px 20px}
  .art-scroll{display:none}
  .art-text h2{font-size:30px;letter-spacing:-.4px}
  .toc__list a{gap:32px}
  .toc__num{font-size:18px;min-width:22px}
  .toc__ttl{font-size:17px}
  .art-split{grid-template-columns:1fr;gap:24px}
  .midcta-form{grid-template-columns:1fr}
  .kn-cards{grid-template-columns:1fr}
  .midcta__head h2,.knowledge__head h2{font-size:30px;letter-spacing:-.4px}
}

/* ============================================================= */
/* AUTHOR / TEAM-MEMBER PAGE (узел 7107:55013) — без блока команды */
/* ============================================================= */
.author{padding-top:18px}
.author__grid{display:grid;grid-template-columns:1fr 400px;gap:125px;align-items:start}
.author__main{min-width:0}
.author__role{font-size:16px;line-height:1.3;color:var(--secondary);font-weight:var(--fw-regular);margin-top:34px}
.author__name{font-size:64px;line-height:1.0;letter-spacing:-1.28px;font-weight:var(--fw-medium);color:var(--primary);margin-top:14px}
.author__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.author__tag{display:inline-flex;align-items:center;height:30px;padding:0 7px;border:1px solid var(--secondary);font-size:14px;line-height:1.3;color:var(--primary);white-space:nowrap}
.author__bio{font-size:20px;line-height:1.32;color:var(--primary);font-weight:var(--fw-light);margin-top:70px;max-width:715px}
.author__cta{display:flex;flex-wrap:wrap;gap:20px;margin-top:70px}
.author__cta .cta-pill{display:inline-flex;align-items:center;justify-content:flex-start;gap:12px;width:190px;height:52px;padding:0 12px;background:var(--muted);color:var(--primary);font-size:16px;line-height:1.25;font-weight:var(--fw-regular);transition:background .2s}
.author__cta .cta-pill:hover{background:var(--tertiary)}
.author__cta .cta-pill svg{width:24px;height:24px;color:var(--accent);flex:0 0 auto}
.author__cta .cta-icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--muted);color:var(--accent);transition:background .2s}
.author__cta .cta-icon:hover{background:var(--tertiary)}
.author__cta .cta-icon svg{width:24px;height:24px}
.author__cta .cta-dark{display:inline-flex;align-items:center;height:52px;padding:0 40px;background:var(--primary);color:#fff;font-size:16px;line-height:1.25;font-weight:var(--fw-regular);transition:opacity .2s}
.author__cta .cta-dark:hover{opacity:.9}
.author__photo{margin:0}
.author__photo img{width:100%;height:auto;display:block;aspect-ratio:400/523;object-fit:cover}

/* --- цитата автора (узел 7107:55463 — знак сверху, текст прижат к верху) --- */
.author-quote{margin-top:100px}
.aq-inner{background:#f1f1f1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;padding:37px 40px;min-height:272px}
.aq-mark{font-size:100px;line-height:.66;height:66px;letter-spacing:-2px;color:var(--accent);font-weight:var(--fw-light)}
.aq-text{font-size:30px;line-height:1.1;font-weight:var(--fw-medium);color:var(--primary);max-width:1030px;margin:0}

/* --- публикации автора (та же карточка, что и Read more) --- */
.author-pubs .wrap{padding-block:100px}
.author-pubs__head{margin-bottom:80px}
.author-pubs__head h2{font-size:48px;line-height:1.04;letter-spacing:-.96px;font-weight:var(--fw-medium);color:var(--primary);margin-top:32px}

/* --- адаптив страницы автора --- */
@media(max-width:1023px){
  .author__grid{grid-template-columns:1fr;gap:40px}
  .author__photo{max-width:360px;order:-1}
  .author__name{font-size:48px;letter-spacing:-.8px}
  .aq-text{font-size:24px}
}
@media(max-width:680px){
  .author{padding-top:28px}
  .author__name{font-size:34px;letter-spacing:-.4px}
  .author__bio{font-size:17px}
  .author__cta{gap:12px}
  .author__cta .cta-pill,.author__cta .cta-dark{height:48px;font-size:14px}
  .aq-inner{padding:32px 20px}
  .aq-text{font-size:20px}
  .author-pubs__head h2{font-size:30px;letter-spacing:-.4px}
}

/* ============================================================= */
/* COOKIE CONSENT BANNER (узел 7087:51886) — слева внизу         */
/* ============================================================= */
.cookie-banner{position:fixed;left:16px;bottom:16px;z-index:1000;width:330px;max-width:calc(100vw - 32px);display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--primary);color:var(--inverse);box-shadow:0 12px 40px rgba(0,0,0,.22);opacity:0;transform:translateY(16px);transition:opacity .45s cubic-bezier(.2,.7,.2,1),transform .45s cubic-bezier(.2,.7,.2,1)}
.cookie-banner.in{opacity:1;transform:none}
.cookie-banner__text{width:auto;max-width:100%;margin:0;font-size:12px;line-height:1.45;font-weight:var(--fw-light)}
.cookie-banner__text a{color:var(--accent);text-decoration:none}
.cookie-banner__text a:hover{text-decoration:underline}
.cookie-banner__btn{flex:0 0 auto;padding:8px 16px;background:var(--inverse);color:var(--primary);border:0;font-family:inherit;font-size:12px;line-height:16px;font-weight:var(--fw-regular);cursor:pointer;transition:opacity .2s}
.cookie-banner__btn:hover{opacity:.85}
.cookie-banner__actions{flex:0 0 auto;display:flex;gap:10px}
.cookie-banner__btn--ghost{background:transparent;color:var(--inverse);border:1px solid rgba(255,255,255,.4)}
@media(max-width:560px){
  .cookie-banner{left:12px;right:12px;bottom:12px;width:auto;flex-direction:column;align-items:stretch;gap:16px;padding:20px}
  .cookie-banner__text{width:auto}
  .cookie-banner__btn{width:100%}
  .cookie-banner__actions{flex-direction:column}
}
@media(prefers-reduced-motion:reduce){
  .cookie-banner{transition:opacity .2s linear;transform:none}
}

/* infographic figure (static deck-style images, e.g. SRO "what you can run") */
.infographic{margin:40px auto 0;max-width:1000px}
.infographic img{display:block;width:100%;height:auto;border:1px solid var(--tertiary)}
.infographic figcaption{margin-top:14px;text-align:center;font-size:13px;line-height:1.4;font-weight:var(--fw-light);color:var(--secondary)}

/* ============================================================= */
/* INNER-PAGE HERO (узел 7086:49964) — обложка + врезка на гору  */
/* ============================================================= */
.ihero__head{padding-top:18px;position:relative;z-index:2}
.ihero__head:has(.byline){padding-bottom:84px}
.ihero__title{font-size:64px;line-height:1.04;letter-spacing:-1.28px;font-weight:var(--fw-medium);color:var(--primary);margin-top:18px}
.ihero__title .red{color:var(--accent)}
.ihero__intro{display:flex;flex-direction:column;gap:22px;max-width:760px;margin-top:32px}
.ihero__lead{font-size:20px;line-height:1.3;font-weight:var(--fw-regular);color:var(--primary)}
.ihero__intro p{font-size:16px;line-height:1.3;font-weight:var(--fw-regular);color:var(--primary)}

/* сцена с фуллблид-фото и налезающей карточкой */
.ihero__stage{position:relative;margin-top:-60px}
.ihero__bg{position:relative;display:block;width:100%;aspect-ratio:1440/440;min-height:380px;background-size:cover;background-position:center 100%;background-repeat:no-repeat;background-color:var(--bg);background-image:url(/assets/sections/mountains/mountain-1.webp)}
/* Dissolve the photo's hard top edge + any sky strip into the page, so the peaks
   bleed UP out of white like the homepage panorama — not a framed photo in a box.
   Independent of the swapped background-image, so the 11 data-mtn rules stay clean.
   Sits below the climbing card (.ihero__card z-index:2). */
.ihero__bg::before{content:"";position:absolute;left:0;top:0;right:0;height:16%;z-index:1;pointer-events:none;background:linear-gradient(180deg,var(--bg) 0%,rgba(255,255,255,0) 100%)}
/* mountain rotation — index set on <html data-mtn> by inline head script, cycles per page load */
html[data-mtn="1"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-1.webp)}
html[data-mtn="2"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-2.webp)}
html[data-mtn="3"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-3.webp)}
html[data-mtn="4"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-4.webp)}
html[data-mtn="5"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-5.webp)}
html[data-mtn="6"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-6.webp)}
html[data-mtn="7"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-7.webp)}
html[data-mtn="8"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-8.webp)}
html[data-mtn="9"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-9.webp)}
html[data-mtn="10"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-10.webp)}
html[data-mtn="11"] .ihero__bg{background-image:url(/assets/sections/mountains/mountain-11.webp)}
.ihero__stage > .wrap{position:relative}
.ihero__card{position:relative;z-index:2;margin-top:-300px;background:var(--bg);padding:105px;display:flex;flex-direction:column;gap:52px}
.ihero__cardhead{display:flex;flex-direction:column;gap:24px}
.ihero__cardtop{display:flex;flex-direction:column;gap:12px}
.ihero__eyebrow{font-size:12px;line-height:1.3;color:var(--secondary);font-weight:var(--fw-regular)}
.ihero__card h2{font-size:48px;line-height:1;letter-spacing:-.5px;font-weight:var(--fw-medium);color:var(--primary)}
.ihero__sub{font-size:16px;line-height:1.3;color:var(--primary);font-weight:var(--fw-regular)}
.ihero__acc{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:52px}
.ihero__acc-btn{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%;background:none;border:0;padding:0;cursor:pointer;text-align:left}
.ihero__acc-title{font-size:30px;line-height:1.1;font-weight:var(--fw-medium);color:var(--primary)}
.ihero__acc-icon{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:#f1f1f1;color:var(--primary);transition:background .2s}
.ihero__acc-btn:hover .ihero__acc-icon{background:var(--tertiary)}
.ihero__acc-icon svg{width:14px;height:14px}
.ihero__acc-divider{width:892px;max-width:100%;height:1px;border:0;background:var(--tertiary);margin:24px 0 0}

/* L2 inset-card variant: "at a glance" key facts + quote CTA (no accordion) */
.ihero__facts{margin:0;display:flex;flex-direction:column}
.ihero__facts > div{display:flex;align-items:baseline;justify-content:space-between;gap:24px;padding:18px 0;border-bottom:1px solid var(--tertiary)}
.ihero__facts > div:first-child{padding-top:0}
.ihero__facts dt{font-size:15px;line-height:1.3;color:var(--secondary);font-weight:var(--fw-light)}
.ihero__facts dd{margin:0;font-size:15px;line-height:1.3;color:var(--primary);font-weight:var(--fw-medium);text-align:right}
.ihero__cta{align-self:flex-start}

@media(max-width:1100px){
  .ihero__title{font-size:56px;letter-spacing:-1px}
  .ihero__card{margin-top:-300px;padding:60px}
  .ihero__card h2{font-size:36px}
  .ihero__acc-title{font-size:24px}
}
@media(max-width:680px){
  .ihero__head{padding-top:12px}
  .ihero__head:has(.byline){padding-bottom:24px}
  .ihero__title{font-size:38px;letter-spacing:-.6px;margin-top:14px}
  .ihero__intro{margin-top:40px;gap:16px}
  .ihero__lead{font-size:18px}
  .ihero__stage{margin-top:40px}
  .ihero__bg{aspect-ratio:1440/620;min-height:200px}
  .ihero__card{margin-top:-70px;padding:32px 24px;gap:36px}
  .ihero__card h2{font-size:26px}
  .ihero__acc{gap:32px}
  .ihero__acc-title{font-size:20px}
}

/* ============================================================= */
/* STANCE / POSITIONING — single-idea statement band            */
/* ============================================================= */
.stance{padding-block:100px;background:var(--muted)}
.stance .eyebrow{display:block;margin-bottom:24px}
.stance__lead{max-width:900px;font-size:40px;line-height:1.12;letter-spacing:-.02em;font-weight:var(--fw-medium);color:var(--primary)}
.stance__lead .red{color:var(--accent)}
.stance__body{max-width:760px;margin-top:28px;font-size:18px;line-height:1.5;font-weight:var(--fw-light);color:var(--primary)}
@media(max-width:1023px){.stance{padding-block:80px}.stance__lead{font-size:32px}}
@media(max-width:767px){.stance{padding-block:60px}.stance__lead{font-size:26px}.stance__body{font-size:16px}}

/* ============================================================= */
/* CONTENT PAGES — hub / money / article shared system          */
/* ============================================================= */

/* All content-page type reuses the homepage scale: eyebrow 14/300, H1 64/500,
   H2 48/500 (via .section h2), H3 30/500 (via .section h3), body 14/300.
   Spokes reuse .svc-card; FAQ reuses .acc. No parallel type system. */

/* Breadcrumb */
.crumbs{border-bottom:1px solid var(--tertiary);background:var(--bg)}
.crumbs ol{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding-block:16px;list-style:none;font-size:14px;line-height:18px;font-weight:var(--fw-light)}
.crumbs li{display:flex;align-items:center;gap:8px;color:var(--secondary)}
.crumbs li:not(:first-child)::before{content:"/";color:var(--tertiary)}
.crumbs a{color:var(--secondary)}
.crumbs a:hover{color:var(--accent)}
.crumbs [aria-current="page"]{color:var(--primary)}

/* Inner hero (non-home) — same scale as the homepage hero */
.inner-hero{padding-block:80px 64px;border-bottom:1px solid var(--tertiary)}
.inner-hero .eyebrow{margin-bottom:24px}
.inner-hero h1{font-weight:var(--fw-medium);font-size:64px;line-height:1.05;letter-spacing:-1.28px;max-width:16ch}
.inner-hero h1 .red{color:var(--accent)}
.inner-hero__answer{max-width:70ch;margin-top:24px;font-size:14px;line-height:1.7;font-weight:var(--fw-light)}
.inner-hero__answer strong{font-weight:var(--fw-medium)}
.inner-hero__cta{display:flex;flex-wrap:wrap;gap:20px;margin-top:32px}

/* Prose body — editorial long-form, ported 1:1 from the reference `.art-col`:
   a single 820px column CENTRED on the page (margin-inline:auto), not pinned to
   the gutter. Every child shares the same width, so all left/right edges line up
   and the block reads as one centred column with symmetric margins. Text inside
   stays left-aligned. */
.prose__col{max-width:820px;margin-inline:auto}
/* Topic-hub lead intro: left-aligned to the hero/cards grid (not centred — a centred
   74ch block under a left-aligned hero reads as a misaligned floating column). */
.prose__col--lead{max-width:74ch;margin:0 0 44px}
.prose__col--lead p{font-size:17px;line-height:1.65;color:var(--primary);font-weight:var(--fw-light);margin:0 0 14px}
.prose__col--lead p:last-child{margin-bottom:0}
.prose__col--lead strong{font-weight:var(--fw-medium)}
.prose__col--lead a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.spokes__head .btn{margin-top:26px}
/* Editorial sections flow tighter than full bands — avoid 200px voids between
   consecutive prose sub-sections (100px+100px). Major bands (hero/cta/spokes/faq)
   keep their full .section rhythm. */
.section.prose{padding-block:56px}
.prose .eyebrow{margin-bottom:18px}
.prose h2{margin-top:64px}
.prose h3{margin-top:48px}
.prose p{font-size:16px;line-height:1.6;font-weight:var(--fw-light);margin-top:20px}
.prose p strong{font-weight:var(--fw-medium)}
.prose ul,.prose ol{margin-top:20px;padding-left:20px;display:flex;flex-direction:column;gap:10px;list-style:disc}
.prose ol{list-style:decimal}
.prose li{font-size:16px;line-height:1.6;font-weight:var(--fw-light)}
.prose a:not(.btn){color:var(--accent);font-weight:var(--fw-medium);border-bottom:1px solid currentColor}

/* Callout (counterargument / "when this does not apply") */
.callout{margin-top:32px;padding:32px;background:var(--muted);border-left:2px solid var(--accent);max-width:880px}
.callout h3{margin-top:0;font-size:20px;line-height:24px;font-weight:var(--fw-medium)}
.callout p{margin-top:12px;font-size:14px;line-height:1.7;font-weight:var(--fw-light)}

/* SRO logo wall — uniform boxes so heterogeneous logos read as an intentional set.
   Scoped under .prose to beat `.prose ul{display:flex}` (specificity). */
.prose .sro-wall{list-style:none;margin:32px 0 0;padding:0;display:flex;flex-flow:row wrap;justify-content:center;gap:1px;background:transparent;border:1px solid var(--tertiary)}
.prose .sro-wall li{flex:1 1 190px;min-width:0;overflow:hidden;max-width:260px;background:var(--bg);box-shadow:0 0 0 1px var(--tertiary);display:flex;align-items:center;justify-content:center;padding:30px 24px;min-height:140px}
.prose .sro-wall img{max-height:60px;max-width:100%;width:auto;height:auto;object-fit:contain}
@media(max-width:640px){.prose .sro-wall li{flex:0 0 auto;box-sizing:border-box;width:calc(50% - 1px);max-width:none;padding:24px 16px;min-height:120px}}

/* ============================================================
   SRO money-page infographic components (brand palette only)
   ============================================================ */

/* Centred layout on money/service spokes: only the section header (eyebrow + H2) is
   centred; body — paragraphs, lists, h3, tables, callouts AND buttons — stays left in
   the centred .prose__col for readability. Centring just the two header elements avoids
   text-align:center leaking onto inline-flex buttons (which would otherwise centre). */
.prose--center .prose__col > .eyebrow{display:flex;width:max-content;max-width:100%;margin-inline:auto}
.prose--center .prose__col > h2{text-align:center}

/* Section head for full-width infographic sections — centred over centred grids */
.sec-head{max-width:880px;margin:0 auto 8px;text-align:center}
.sec-head .eyebrow{display:inline-flex;margin-bottom:16px}
.sec-head p{font-size:16px;line-height:1.6;font-weight:var(--fw-light);margin-top:18px;text-align:left}
.sec-note{font-size:13.5px;line-height:1.6;font-weight:var(--fw-light);color:var(--secondary);margin:24px auto 0;max-width:880px;text-align:left}

/* Regulatory landscape — 3 tiers (FINMA / SRO / Insurance) */
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.tier-card{background:var(--muted);padding:32px 28px;border-top:3px solid var(--tertiary)}
.tier-card--focus{border-top-color:var(--accent)}
.tier-card__tier{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--secondary);font-weight:var(--fw-medium)}
.tier-card h3{font-size:21px;line-height:1.15;font-weight:var(--fw-medium);margin-top:14px}
.tier-card__note{color:var(--secondary);font-size:13px;margin-top:6px;font-weight:var(--fw-light)}
.tier-card p{font-size:14px;line-height:1.6;font-weight:var(--fw-light);margin-top:16px}
.tier-card strong{font-weight:var(--fw-medium)}
@media(max-width:900px){.tier-grid{grid-template-columns:1fr}}

/* Use-case grid — what you can run under an SRO (icons) */
.uc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--tertiary);border:1px solid var(--tertiary);margin-top:40px}
.uc-card{background:var(--bg);padding:30px 26px;display:flex;flex-direction:column;gap:14px}
.uc-card__icon{width:30px;height:30px;color:var(--accent);flex:none}
.uc-card h3{font-size:17px;line-height:1.2;font-weight:var(--fw-medium)}
.uc-card p{font-size:13.5px;line-height:1.6;font-weight:var(--fw-light);color:var(--primary)}
.uc-card--cta{background:var(--ink)}
.uc-card--cta h3,.uc-card--cta p{color:var(--inverse)}
.uc-card--cta .uc-card__icon{color:var(--accent)}
.uc-card--cta a{color:#fff;font-weight:var(--fw-medium);display:inline-flex;align-items:center;gap:8px;margin-top:auto;font-size:14px}
.uc-card--cta a svg{width:14px;height:14px}
@media(max-width:900px){.uc-grid{grid-template-columns:1fr}}

/* Activity route map — the definitive "what takes the SRO route" reference */
.routemap{display:grid;gap:20px;margin-top:40px;text-align:left}
.routemap__hero{background:var(--muted);border-top:3px solid var(--accent);padding:36px 40px 32px}
.routemap__hero h3{font-size:24px;font-weight:var(--fw-medium);margin:12px 0 22px}
.rm-flag{display:inline-block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:var(--fw-medium);color:var(--accent)}
.rm-flag--alt{color:var(--secondary)}
.rm-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:16px 48px}
.rm-list li{position:relative;padding-left:30px;font-size:15px;line-height:1.55;font-weight:var(--fw-light)}
.rm-list li::before{content:"";position:absolute;left:0;top:4px;width:18px;height:18px;background:var(--accent);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/14px no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/14px no-repeat}
.rm-list strong{font-weight:var(--fw-medium)}
.routemap__others{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rm-card{background:var(--bg);border:1px solid var(--tertiary);padding:28px 26px}
.rm-card ul{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:11px}
.rm-card li{position:relative;padding-left:20px;font-size:14.5px;line-height:1.5;font-weight:var(--fw-light)}
.rm-card li::before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;border-radius:50%;background:var(--secondary)}
.rm-note{font-size:13px;color:var(--secondary);margin-top:16px;font-weight:var(--fw-light)}
@media(max-width:760px){.rm-list{grid-template-columns:1fr;gap:14px}.routemap__others{grid-template-columns:1fr}}

/* SRO contact directory */
.sro-contacts{list-style:none;margin:40px 0 0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--tertiary);border:1px solid var(--tertiary)}
.sro-con{background:var(--bg);padding:28px 26px;display:flex;flex-direction:column;gap:5px}
.sro-con h3{font-size:18px;font-weight:var(--fw-medium);line-height:1.2;margin-bottom:8px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.sro-con h3 span{font-size:12px;font-weight:var(--fw-light);color:var(--secondary);text-transform:uppercase;letter-spacing:.05em}
.sro-con address{font-style:normal;font-size:14px;line-height:1.5;font-weight:var(--fw-light);color:var(--secondary);margin-bottom:8px}
.sro-con a{font-size:14px;font-weight:var(--fw-light);color:var(--primary);text-decoration:none;width:max-content;max-width:100%}
.sro-con a:hover{color:var(--accent)}
.sro-con__site{color:var(--accent)!important;margin-top:4px}
@media(max-width:900px){.sro-contacts{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.sro-contacts{grid-template-columns:1fr}}
/* SRO directory — one table: logo + members + contact (replaces sro-wall + sro-contacts) */
.sro-table{margin-top:40px;overflow-x:auto}
.sro-table table{width:100%;border-collapse:collapse;font-size:13.5px;line-height:1.5;font-weight:var(--fw-light)}
.sro-table caption{text-align:left;font-size:13px;color:var(--secondary);font-weight:var(--fw-light);line-height:1.5;margin-bottom:18px;max-width:900px}
.sro-table thead th{text-align:left;font-weight:var(--fw-medium);text-transform:uppercase;font-size:11.5px;letter-spacing:.06em;color:var(--secondary);padding:0 20px 12px;border-bottom:1px solid var(--primary)}
.sro-table td,.sro-table tbody th{text-align:left;vertical-align:top;padding:14px 16px;border-bottom:1px solid var(--tertiary)}
.sro-table thead th:first-child,.sro-table td:first-child,.sro-table tbody th{padding-left:0}
.sro-table thead th:last-child,.sro-table td:last-child{padding-right:0}
.srt__id{min-width:150px;width:200px}
.srt__logo{height:58px;width:auto;max-width:185px;object-fit:contain;object-position:left center;display:block;margin-bottom:14px}
.srt__name{display:block;font-weight:var(--fw-medium);font-size:15px;color:var(--primary)}
.srt__city{display:block;font-size:11.5px;color:var(--secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:3px}
.sro-table td p{margin:0}

/* ---------- VS-GRAPHIC: comparison infographic (e.g. AG vs GmbH) ----------
   A designed comparison that keeps a real <table> as its accessible/crawlable
   core, topped with a party header and a proportional capital bar chart. */
.vs-graphic{margin:40px 0;border:1px solid var(--tertiary);background:var(--bg)}
.vs-graphic__cap{padding:26px 28px 0}
.vs-graphic__cap .eyebrow{display:block;margin-bottom:10px}
.vs-graphic__cap > span:last-child{font-size:19px;font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.3;color:var(--primary)}
.vs-graphic__head{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;padding:24px 28px}
.vs-party{display:flex;flex-direction:column;gap:6px;padding-left:14px}
.vs-party--ag{border-left:3px solid var(--accent)}
.vs-party--gmbh{border-left:3px solid var(--primary)}
.vs-party__abbr{font-size:30px;font-weight:var(--fw-medium);letter-spacing:-.015em;line-height:1;color:var(--primary)}
.vs-party__full{font-size:11px;text-transform:uppercase;letter-spacing:.045em;color:var(--secondary);font-weight:var(--fw-light)}
.vs-graphic__vs{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--secondary);font-weight:var(--fw-light)}
.vs-bars{padding:22px 28px 26px;display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--tertiary);background:var(--muted)}
.vs-bars__lbl{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--secondary);font-weight:var(--fw-light)}
.vs-bar{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:16px}
.vs-bar__name{font-size:13px;font-weight:var(--fw-medium);color:var(--primary)}
.vs-bar__track{height:30px;background:var(--bg);position:relative;overflow:hidden;border:1px solid var(--tertiary)}
.vs-bar__fill{display:block;height:100%}
.vs-bar__fill--ag{background:var(--accent)}
.vs-bar__fill--gmbh{background:var(--primary)}
.vs-bar__val{font-size:14px;font-weight:var(--fw-medium);color:var(--primary);min-width:108px;text-align:right;letter-spacing:-.01em}
.vs-table{width:100%;border-collapse:collapse;table-layout:fixed;border-top:1px solid var(--tertiary)}
.vs-table thead th{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary);font-weight:var(--fw-medium);text-align:left;padding:16px 22px 12px}
.vs-table tbody th[scope=row]{text-align:left;font-weight:var(--fw-medium);font-size:13px;color:var(--primary);padding:15px 22px;width:30%;border-top:1px solid var(--tertiary);vertical-align:top}
.vs-table td{padding:15px 22px;font-size:14px;line-height:1.5;color:var(--primary);font-weight:var(--fw-light);border-top:1px solid var(--tertiary);border-left:1px solid var(--tertiary);vertical-align:top}
.vs-table tbody tr:hover th[scope=row],.vs-table tbody tr:hover td{background:var(--muted)}
.vs-table__same{color:var(--secondary)}
.vs-table__best th[scope=row],.vs-table__best td{background:var(--muted)}
.vs-no{color:var(--accent);font-weight:var(--fw-medium)}
.vs-yes{color:var(--primary);font-weight:var(--fw-medium)}
@media (max-width:560px){
  .vs-graphic__cap,.vs-graphic__head,.vs-bars{padding-left:18px;padding-right:18px}
  .vs-party__abbr{font-size:22px}
  .vs-graphic__head{gap:14px}
  .vs-bar{grid-template-columns:42px 1fr auto;gap:10px}
  .vs-bar__val{min-width:92px;font-size:13px}
  .vs-table thead th{padding:14px 14px 10px}
  .vs-table tbody th[scope=row]{width:38%;font-size:12px;padding:12px 14px}
  .vs-table td{font-size:12.5px;padding:12px 14px}
}
.srt__con address{font-style:normal;max-width:24ch;margin-bottom:8px;color:var(--secondary)}
.srt__con a{display:block;color:var(--primary);text-decoration:none;width:max-content;max-width:100%;line-height:1.7}
.srt__con a:hover{color:var(--accent)}
.srt__site{color:var(--accent)!important;margin-top:4px}
@media(max-width:820px){
  .sro-table{overflow-x:visible}
  .sro-table thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}
  .sro-table table,.sro-table tbody,.sro-table tr,.sro-table td,.sro-table tbody th{display:block;width:auto}
  .sro-table caption{display:block;width:auto;max-width:none}
  .sro-table tr{border:1px solid var(--tertiary);padding:6px 20px 20px;margin-bottom:-1px}
  .sro-table td,.sro-table tbody th{border:0;padding:14px 0 0}
  .srt__id{padding-top:20px}
}
/* checker option label + plain-language note (step 1) */
.checker__opt-txt{display:flex;flex-direction:column;gap:4px;text-align:left;min-width:0}
.checker__opt-label{font-size:15.5px;font-weight:var(--fw-medium);line-height:1.3;color:var(--primary)}
.checker__opt-note{font-size:13px;font-weight:var(--fw-light);line-height:1.4;color:var(--secondary)}
.checker__opt:hover .checker__opt-label{color:var(--accent)}
/* keep CTA buttons inside prose from sticking to the paragraph above */
.prose .prose__col>.btn{margin-top:28px}

/* Five-phase timeline */
.timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:44px;counter-reset:phase;list-style:none;padding:0}
.tl-step{position:relative;padding-top:46px}
.tl-step::before{counter-increment:phase;content:counter(phase);position:absolute;top:0;left:0;width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:var(--fw-medium);z-index:1}
.tl-step::after{content:"";position:absolute;top:16px;left:34px;width:calc(100% + 24px - 34px);height:2px;background:var(--tertiary)}
.tl-step:last-child::after{display:none}
.tl-step h3{font-size:16px;line-height:1.2;font-weight:var(--fw-medium)}
.tl-step__time{display:block;font-size:11.5px;font-weight:var(--fw-medium);letter-spacing:.05em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.tl-step p{font-size:13px;line-height:1.55;color:var(--secondary);font-weight:var(--fw-light);margin-top:10px}
@media(max-width:760px){.timeline{grid-template-columns:1fr;gap:0}.tl-step{padding:0 0 28px 52px}.tl-step::before{top:0}.tl-step::after{top:34px;left:16px;width:2px;height:calc(100% - 34px)}.tl-step:last-child{padding-bottom:0}}

/* Set-up checklist */
.prose .checklist{list-style:none;display:block;margin:32px 0 0;padding:0;border:1px solid var(--tertiary)}
.prose .checklist li{position:relative;padding:20px 24px 20px 58px;border-bottom:1px solid var(--tertiary);font-size:15px;line-height:1.6;font-weight:var(--fw-light)}
.prose .checklist li:last-child{border-bottom:0}
.prose .checklist li::before{content:"";position:absolute;left:24px;top:21px;width:22px;height:22px;background:var(--accent);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/16px no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/16px no-repeat}
.checklist li strong{font-weight:var(--fw-medium)}

.subhead{font-size:24px;line-height:1.15;font-weight:var(--fw-medium);margin-top:60px;letter-spacing:-.01em;text-align:center}

/* Why-us / E-E-A-T cards */
.whyus{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.why-card{background:var(--muted);padding:32px 28px}
.why-card__stat{font-size:40px;line-height:1;font-weight:var(--fw-medium);color:var(--accent)}
.why-card h3{font-size:19px;font-weight:var(--fw-medium);margin-top:14px;line-height:1.15}
.why-card p{font-size:14px;line-height:1.6;font-weight:var(--fw-light);margin-top:12px}
@media(max-width:900px){.whyus{grid-template-columns:1fr}}

/* Vertical history timeline (firm page) — red line draws in as each step scrolls into view */
.vtimeline{position:relative;margin-top:44px;padding:0 0 0 38px;list-style:none}
.vtimeline__step{position:relative;padding:0 0 38px 0;opacity:0;transform:translateX(16px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}
.vtimeline__step:last-child{padding-bottom:0}
.vtimeline__step.in-view{opacity:1;transform:none}
/* grey base rail spanning all steps */
.vtimeline::before{content:"";position:absolute;left:6px;top:7px;bottom:7px;width:2px;background:var(--tertiary)}
/* red segment for each step that scales in on reveal — cumulatively the rail turns red as you scroll */
.vtimeline__step::before{content:"";position:absolute;left:-32px;top:7px;width:2px;height:100%;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .6s ease .05s}
.vtimeline__step:last-child::before{display:none}
.vtimeline__step.in-view::before{transform:scaleY(1)}
/* node dot */
.vtimeline__step::after{content:"";position:absolute;left:-38px;top:3px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:2px solid var(--tertiary);transition:border-color .4s ease,background .4s ease,transform .4s ease}
.vtimeline__step.in-view::after{border-color:var(--accent);background:var(--accent);transform:scale(1.08)}
.vtimeline__year{display:block;font-size:13px;font-weight:var(--fw-medium);letter-spacing:.05em;color:var(--accent);margin-bottom:6px}
.vtimeline__step h3{font-size:18px;line-height:1.25;font-weight:var(--fw-medium)}
.vtimeline__step p{font-size:14px;line-height:1.6;color:var(--secondary);font-weight:var(--fw-light);margin-top:8px;max-width:62ch}

/* Expertise & client-segment cards (firm page) — bare red icon, no box */
.segs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.seg-card{background:var(--bg);border:1px solid var(--tertiary);padding:30px 28px;display:flex;flex-direction:column;gap:14px;transition:border-color .2s,transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s}
.seg-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 16px 34px rgba(0,0,0,.07)}
.seg-card__icon{display:inline-flex;flex:0 0 auto}
.seg-card__icon svg{width:30px;height:30px;stroke:var(--accent);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.seg-card:hover .seg-card__icon svg{transform:scale(1.08) rotate(-2deg)}
.seg-card h3{font-size:18px;line-height:1.2;font-weight:var(--fw-medium)}
.seg-card p{font-size:14px;line-height:1.6;font-weight:var(--fw-light);color:var(--primary)}

/* Byline — author + published/updated dates (money & article pages) */
.byline{display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;margin-top:24px;font-size:13px;font-weight:var(--fw-light);color:var(--secondary)}
.byline__author{display:inline-flex;align-items:center;gap:9px}
.byline__avatar{width:38px;height:38px;border-radius:50%;background:var(--primary);color:var(--inverse);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--fw-medium);letter-spacing:.04em;object-fit:cover;flex:0 0 auto}
img.byline__avatar{border:1px solid var(--tertiary)}
.sec-head--spaced{margin-top:64px}
.lede--spaced{margin-top:24px}
.byline__name{color:var(--primary);font-weight:var(--fw-medium)}
.byline__role{color:var(--secondary)}
.byline__sep{color:var(--tertiary)}
.byline time{color:var(--secondary)}

/* Shelf catalogue — available companies as cards (age = the headline) */
.catalogue{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.cat-card{position:relative;border:1px solid var(--tertiary);padding:24px;display:flex;flex-direction:column;gap:16px;background:var(--bg);transition:border-color .2s,transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s}
.cat-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 16px 34px rgba(0,0,0,.07)}
.cat-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.cat-card__form{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);font-weight:var(--fw-medium)}
.cat-card__ref{font-size:12px;color:var(--secondary);font-weight:var(--fw-light)}
.cat-card__year{font-size:40px;line-height:.9;font-weight:var(--fw-medium);letter-spacing:-.02em}
.cat-card__year small{display:block;font-size:12px;letter-spacing:.04em;color:var(--secondary);font-weight:var(--fw-light);margin-top:6px;text-transform:none}
.cat-card__rows{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--tertiary);padding-top:14px;margin:0}
.cat-card__rows > div{display:flex;justify-content:space-between;gap:10px;font-size:13px}
.cat-card__rows dt{color:var(--secondary);font-weight:var(--fw-light)}
.cat-card__rows dd{color:var(--primary);margin:0;text-align:right}
.cat-card__foot{display:flex;align-items:baseline;justify-content:space-between;gap:10px;border-top:1px solid var(--tertiary);padding-top:14px;margin-top:auto}
.cat-card__price{font-size:21px;font-weight:var(--fw-medium)}
.cat-card__price small{font-size:12px;color:var(--secondary);font-weight:var(--fw-light)}
.cat-card__cta{font-size:13px;font-weight:var(--fw-medium);color:var(--accent);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.cat-card__cta svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.6;transition:transform .2s}
.cat-card:hover .cat-card__cta svg{transform:translateX(3px)}
.cat-note{margin-top:20px;font-size:13px;color:var(--secondary);font-weight:var(--fw-light)}
@media(max-width:900px){.catalogue{grid-template-columns:1fr}}
@media(max-width:900px){.segs{grid-template-columns:1fr}}


/* Firm hero — drifting alpine backdrop (ken-burns), reuses .ihero */
.ihero__bg{transform-origin:center 62%;animation:hero-zoom 26s ease-in-out infinite alternate;will-change:transform}

/* Selected engagements — client wall (logos + text tiles, uniform) */
.client-wall{list-style:none;margin:36px 0 0;padding:0;display:flex;flex-flow:row wrap;justify-content:center;gap:1px;background:transparent;border:1px solid var(--tertiary)}
.client-wall li{flex:1 1 200px;min-width:0;overflow:hidden;max-width:280px;background:var(--bg);box-shadow:0 0 0 1px var(--tertiary);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:28px 22px;min-height:128px}
.client-wall img{max-height:42px;max-width:min(165px,100%);width:auto;object-fit:contain}
.client-wall__icon{max-height:50px!important;max-width:56px!important}
.client-wall__name{font-size:16px;font-weight:var(--fw-medium);line-height:1.2}
.client-wall__tag{font-size:12px;color:var(--secondary);font-weight:var(--fw-light);line-height:1.3}
@media(max-width:640px){.client-wall li{flex:0 0 auto;box-sizing:border-box;width:calc(50% - 1px);max-width:none;min-height:118px}}

/* Eligibility checker (progressive-enhanced; works as static fallback) */
.checker{margin-top:40px;border:1px solid var(--tertiary);background:var(--muted);padding:36px 32px}
.checker__q{font-size:20px;font-weight:var(--fw-medium);line-height:1.25}
.checker__opts{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.checker__opt{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:inherit;font-size:15.5px;line-height:1.35;font-weight:var(--fw-light);padding:18px 22px;background:var(--bg);border:1px solid var(--tertiary);color:var(--primary);cursor:pointer;transition:border-color .15s,color .15s}
.checker__opt::after{content:"→";color:var(--secondary);font-size:16px;flex:0 0 auto;transition:color .15s,transform .15s}
.checker__opt:hover{border-color:var(--accent);color:var(--accent)}
.checker__opt:hover::after{color:var(--accent);transform:translateX(3px)}
.checker__progress{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--secondary);font-weight:var(--fw-medium);margin-bottom:18px}
.checker__result{}
.checker__verdict{font-size:24px;font-weight:var(--fw-medium);line-height:1.2;color:var(--accent)}
.checker__detail{font-size:15px;line-height:1.6;font-weight:var(--fw-light);margin-top:16px}
.checker__actions{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-top:26px}
.checker__restart{font-family:inherit;background:none;border:0;color:var(--secondary);font-size:14px;cursor:pointer;text-decoration:underline;padding:0}
.checker__fallback{font-size:14px;line-height:1.6;font-weight:var(--fw-light);color:var(--secondary);margin-top:20px}
.checker.is-enhanced .checker__fallback{display:none}
/* Step 3 readiness checklist */
.checker__checks{display:flex;flex-direction:column;margin-top:22px;border:1px solid var(--tertiary);background:var(--bg)}
.checker__check{display:flex;align-items:flex-start;gap:14px;padding:15px 20px;cursor:pointer;font-size:15px;font-weight:var(--fw-light);line-height:1.45;border-bottom:1px solid var(--tertiary);transition:color .15s}
.checker__check:last-child{border-bottom:0}
.checker__check:hover{color:var(--accent)}
.checker__check input{margin:3px 0 0;width:18px;height:18px;flex:0 0 auto;accent-color:var(--accent);cursor:pointer}
.checker__meter{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--secondary);font-weight:var(--fw-medium);margin-top:16px}
.checker__missing{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}
.checker__missing li{position:relative;padding-left:24px;font-size:14.5px;line-height:1.5;font-weight:var(--fw-light)}
.checker__missing li::before{content:"";position:absolute;left:0;top:5px;width:9px;height:9px;border:1.5px solid var(--accent);border-radius:50%}
.checker__opt--go{background:var(--ink);color:#fff;border-color:var(--ink);font-weight:var(--fw-medium)}
.checker__opt--go:hover{color:#fff;border-color:var(--ink);opacity:.9}

/* Factsheet / decision table */
.factsheet{margin-top:32px;overflow-x:auto}
.factsheet table{width:100%;border-collapse:collapse;font-size:14px;line-height:1.5;font-weight:var(--fw-light)}
.factsheet caption{text-align:left;font-size:14px;color:var(--secondary);font-weight:var(--fw-light);margin-bottom:16px}
.factsheet th,.factsheet td{text-align:left;padding:16px;border-bottom:1px solid var(--tertiary);vertical-align:top}
.factsheet thead th{font-weight:var(--fw-medium);text-transform:uppercase;font-size:12px;letter-spacing:.06em;border-bottom:1px solid var(--primary)}
.factsheet tbody th{font-weight:var(--fw-medium)}
.factsheet td strong{font-weight:var(--fw-medium)}

/* Decision map — custody-vs-deposit boundary (figure, brand-coloured rows) */
.boundary-map{margin:40px 0;border:1px solid var(--tertiary);background:var(--bg)}
.boundary-map__cap{padding:26px 28px 22px}
.boundary-map__cap .eyebrow{display:block;margin-bottom:10px}
.boundary-map__cap > span:last-child{display:block;font-size:19px;font-weight:var(--fw-medium);letter-spacing:-.01em;line-height:1.35;color:var(--primary)}
.boundary-map__scroll{overflow-x:auto}
.boundary-map__table{width:100%;border-collapse:collapse;font-size:14px;line-height:1.5;font-weight:var(--fw-light)}
.boundary-map__table thead th{text-align:left;padding:12px 18px;font-weight:var(--fw-medium);text-transform:uppercase;font-size:11px;letter-spacing:.06em;color:var(--secondary);border-top:1px solid var(--tertiary);border-bottom:1px solid var(--tertiary)}
.boundary-map__table tbody th,.boundary-map__table tbody td{text-align:left;padding:16px 18px;border-bottom:1px solid var(--tertiary);vertical-align:top}
.boundary-map__table tbody th{font-weight:var(--fw-medium);color:var(--primary);width:44%}
.boundary-map__table tbody tr:last-child th,.boundary-map__table tbody tr:last-child td{border-bottom:0}
.bmap--danger{background:var(--muted)}
.bmap__out{font-weight:var(--fw-medium);color:var(--primary)}
.bmap--danger .bmap__out{color:var(--accent)}
.boundary-map__note{padding:14px 28px 24px;font-size:13px;line-height:1.5;color:var(--secondary);font-weight:var(--fw-light)}
@media(max-width:560px){.boundary-map__cap{padding:22px 18px 18px}.boundary-map__note{padding:14px 18px 20px}.boundary-map__table{font-size:13px}.boundary-map__table tbody th,.boundary-map__table tbody td{padding:13px 14px}.boundary-map__table tbody th{width:auto}}
/* Content photo figure (thematic image with caption) */
.content-figure{margin:40px 0}
.content-figure img{display:block;width:100%;height:auto;border:1px solid var(--tertiary)}
.content-figure figcaption{margin-top:12px;font-size:13px;line-height:1.5;color:var(--secondary);font-weight:var(--fw-light);text-align:left}

/* Spokes — reuse the homepage services card (.svc-card) in 2 columns */
.spokes{background:var(--muted)}
.spokes__head{margin-bottom:60px;max-width:760px}
.cards-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.svc-card--pillar{background:var(--ink);border-color:var(--ink)}
.svc-card--pillar .svc-card__title,.svc-card--pillar .svc-card__desc,.svc-card--pillar .svc-card__link{color:var(--inverse)}
.svc-card--pillar .svc-card__num{color:var(--secondary)}
.svc-card--pillar:hover{border-color:var(--accent)}

/* Recognitions on inner pages reuses the homepage .rank + .rank-seals block. */

/* FAQ — reuses the .acc accordion. Only the head spacing is new. */
.faqs__head{margin-bottom:48px;max-width:760px}

@media(max-width:1023px){
  .cards-2{grid-template-columns:1fr}
  .inner-hero{padding-block:64px 48px}
  .inner-hero h1{font-size:44px;letter-spacing:-.02em}
}
@media(max-width:767px){
  .inner-hero h1{font-size:34px;letter-spacing:-.5px}
}

/* ============================================================= */
/* 404 — not found                                              */
/* ============================================================= */
.nf{padding-block:120px 100px}
.nf__code{display:block;font-size:clamp(88px,13vw,168px);font-weight:var(--fw-bold);line-height:.86;color:var(--accent);letter-spacing:-.04em}
.nf__title{font-size:clamp(32px,4vw,48px);font-weight:var(--fw-medium);letter-spacing:-.02em;margin-top:12px}
.nf__lead{max-width:58ch;margin-top:24px;font-size:18px;line-height:1.6;font-weight:var(--fw-light);color:var(--primary)}
.nf__cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:36px}
.nf__links{margin-top:64px;border-top:1px solid var(--tertiary);padding-top:32px}
.nf__links-label{display:block;text-transform:uppercase;font-size:12px;letter-spacing:.06em;color:var(--secondary);font-weight:var(--fw-medium);margin-bottom:22px}
.nf__links ul{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:16px 40px}
.nf__links a{display:inline-flex;align-items:baseline;gap:10px;font-size:15px;font-weight:var(--fw-regular);color:var(--primary);text-decoration:none;line-height:1.4}
.nf__links a::before{content:"";flex-shrink:0;width:6px;height:6px;background:var(--accent);transform:translateY(-1px)}
.nf__links a:hover{color:var(--accent)}
@media(max-width:1023px){.nf{padding-block:88px 72px}.nf__links ul{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.nf__links ul{grid-template-columns:1fr}.nf__cta .btn{flex:1 1 100%}}

/* ===== Restructuring distress triage (interactive, /restructuring/) ===== */
.triage__app{margin-top:40px;max-width:900px}
.triage__card{background:var(--muted);padding:44px;border:1px solid var(--tertiary)}
.triage__progress{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--secondary);font-weight:var(--fw-regular)}
.triage__q{margin-top:14px;font-size:26px;line-height:1.18;font-weight:var(--fw-medium);color:var(--primary);letter-spacing:-.01em;outline:none}
.triage__help{margin-top:12px;font-size:14px;line-height:1.55;color:var(--secondary);font-weight:var(--fw-light)}
.triage__opts{margin-top:28px;display:flex;flex-direction:column;gap:12px}
.triage__opt{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;text-align:left;background:var(--bg);border:1px solid var(--tertiary);padding:18px 22px;font:inherit;font-size:17px;font-weight:var(--fw-regular);color:var(--primary);cursor:pointer;transition:border-color .18s,color .18s,transform .18s}
.triage__opt:hover{border-color:var(--accent);color:var(--accent);transform:translateX(3px)}
.triage__opt:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.triage__opt>span{flex:1}
.triage__opt svg{flex:0 0 auto;color:inherit}
.triage__back{margin-top:24px;background:none;border:0;padding:0;font:inherit;font-size:14px;color:var(--secondary);cursor:pointer}
.triage__back:hover{color:var(--accent)}
/* result */
.triage__result{border-top:3px solid var(--primary)}
.triage__result--ok{border-top-color:#1a7f4b}
.triage__result--warn{border-top-color:#c9851a}
.triage__result--danger{border-top-color:var(--accent)}
.triage__result--info{border-top-color:var(--primary)}
.triage__rlabel{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--secondary)}
.triage__verdict{margin-top:10px;font-size:29px;line-height:1.12;font-weight:var(--fw-medium);letter-spacing:-.01em;color:var(--primary);outline:none}
.triage__sum{margin-top:14px;font-size:16px;line-height:1.62;font-weight:var(--fw-light);color:var(--primary);max-width:62ch}
.triage__basis{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.triage__chip{font-size:12px;font-weight:var(--fw-medium);letter-spacing:.02em;color:var(--primary);background:var(--bg);border:1px solid var(--tertiary);padding:6px 12px}
/* news/article tag pills — same token palette as .triage__chip */
.news-tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px;padding:0}
.chip{display:inline-block;font-size:12px;font-weight:var(--fw-medium);letter-spacing:.02em;color:var(--primary);background:var(--bg);border:1px solid var(--tertiary);padding:6px 12px}
/* flow stepper */
.triage__flow{margin-top:30px}
.triage__flowlabel{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--secondary);margin-bottom:18px}
.triage__steps{list-style:none;margin:0;padding:0}
.triage__step{position:relative;display:flex;gap:18px;padding-bottom:22px}
.triage__step:last-child{padding-bottom:0}
.triage__step:not(:last-child)::before{content:"";position:absolute;left:15px;top:34px;bottom:0;width:1px;background:var(--tertiary)}
.triage__step-num{flex:0 0 auto;width:31px;height:31px;border-radius:50%;background:var(--primary);color:var(--inverse);display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--fw-medium);z-index:1}
.triage__step-body{display:flex;flex-direction:column;gap:4px;padding-top:4px}
.triage__step-label{font-size:16px;line-height:1.4;color:var(--primary);font-weight:var(--fw-regular)}
.triage__step-time{font-size:13px;color:var(--accent);font-weight:var(--fw-medium)}
.triage__warn{margin-top:26px;padding:18px 22px;background:var(--bg);border-left:2px solid #c9851a;font-size:14px;line-height:1.62;font-weight:var(--fw-light);color:var(--primary)}
.triage__result--danger .triage__warn{border-left-color:var(--accent)}
.triage__actions{margin-top:30px;display:flex;flex-wrap:wrap;align-items:center;gap:20px}
.triage__restart{background:none;border:0;padding:0;font:inherit;font-size:14px;color:var(--secondary);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.triage__restart:hover{color:var(--accent)}
.triage__foot{margin-top:22px;font-size:13px;line-height:1.62;color:var(--secondary);font-weight:var(--fw-light);max-width:900px}
.triage__noscript{font-size:15px;line-height:1.6;color:var(--primary)}
@media(max-width:680px){
  .triage__card{padding:26px 20px}
  .triage__q{font-size:21px}
  .triage__verdict{font-size:23px}
  .triage__sum{font-size:15px}
  .triage__opt{font-size:16px;padding:16px 18px}
}
