.realtor-niche,
.tourism-niche,
.dealer-niche,
.sto-niche,
.beauty-niche {
    overflow: hidden;
    color: var(--text-color);
}

/* Studio solution suite: isolated shared blocks for niche pages */
.studio-suite {
    --studio-accent: #5aa7ff;
    --studio-accent-rgb: 90, 167, 255;
    overflow: hidden;
    color: #eef3fb;
    background: #0b0f16;
}

.studio-suite *,
.studio-suite *::before,
.studio-suite *::after {
    box-sizing: border-box;
}

.studio-suite section {
    position: relative;
    padding: 112px 0;
}

.studio-suite h1,
.studio-suite h2,
.studio-suite h3,
.studio-suite p {
    font-family: inherit;
}

.studio-suite h2 {
    margin: 0;
    color: #f7f9fd;
    font-size: clamp(36px, 4.8vw, 66px);
    font-weight: 800;
    line-height: 1.04;
    letter-spacing: -0.04em;
}

.studio-suite__eyebrow {
    display: inline-flex;
    width: fit-content;
    margin-bottom: 22px;
    padding: 9px 15px;
    border: 1px solid rgba(var(--studio-accent-rgb), 0.32);
    border-radius: 999px;
    color: var(--studio-accent);
    background: rgba(var(--studio-accent-rgb), 0.08);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.studio-suite__hero {
    min-height: 850px;
    display: flex;
    align-items: center;
    padding-top: 145px !important;
    background:
        linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px),
        radial-gradient(circle at 74% 42%, rgba(var(--studio-accent-rgb), .16), transparent 28%),
        #0d1118;
    background-size: 38px 38px, 38px 38px, auto, auto;
    isolation: isolate;
}

.studio-suite__glow {
    position: absolute;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(var(--studio-accent-rgb), .13);
    filter: blur(120px);
    pointer-events: none;
}

.studio-suite__glow--one { top: -180px; left: -140px; }
.studio-suite__glow--two { right: -170px; bottom: -220px; opacity: .65; }

.studio-suite__hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, .93fr) minmax(440px, 1.07fr);
    gap: 76px;
    align-items: center;
}

.studio-suite__hero-copy h1 {
    max-width: 760px;
    margin: 0 0 28px;
    color: #f7f9fd;
    font-size: clamp(46px, 6vw, 88px);
    font-weight: 800;
    line-height: .98;
    letter-spacing: -0.055em;
}

.studio-suite__hero-copy > p {
    max-width: 670px;
    margin: 0;
    color: #aeb9ca;
    font-size: 18px;
    line-height: 1.75;
}

.studio-suite__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    align-items: center;
    margin-top: 34px;
}

.studio-suite__button {
    display: inline-flex;
    min-height: 56px;
    align-items: center;
    justify-content: center;
    padding: 0 25px;
    border-radius: 14px;
    color: #071019;
    background: var(--studio-accent);
    box-shadow: 0 18px 48px rgba(var(--studio-accent-rgb), .2);
    font-size: 15px;
    font-weight: 900;
    text-decoration: none;
    transition: transform .2s ease, box-shadow .2s ease;
}

.studio-suite__button:hover {
    color: #071019;
    transform: translateY(-2px);
    box-shadow: 0 24px 56px rgba(var(--studio-accent-rgb), .3);
}

.studio-suite__link {
    display: inline-flex;
    gap: 10px;
    align-items: center;
    color: #eef3fb;
    font-weight: 800;
    text-decoration: none;
}

.studio-suite__link span { color: var(--studio-accent); font-size: 20px; }

.studio-suite__hero-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 40px;
}

.studio-suite__hero-tags span {
    padding: 8px 11px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 7px;
    color: #8591a2;
    background: rgba(255,255,255,.025);
    font-family: monospace;
    font-size: 11px;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.studio-suite__interface {
    position: relative;
    min-height: 590px;
    perspective: 1200px;
}

.studio-suite__window {
    position: absolute;
    inset: 25px 10px 35px 0;
    overflow: hidden;
    border: 1px solid rgba(var(--studio-accent-rgb), .25);
    border-radius: 22px;
    background: rgba(12, 17, 25, .9);
    box-shadow: 0 42px 100px rgba(0,0,0,.5);
    transform: rotateY(-5deg) rotateX(2deg);
    transition: transform .45s ease;
}

.studio-suite__interface:hover .studio-suite__window {
    transform: rotateY(0) rotateX(0) translateY(-5px);
}

.studio-suite__window-bar {
    display: flex;
    gap: 7px;
    align-items: center;
    height: 52px;
    padding: 0 18px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    color: #687587;
    font-family: monospace;
    font-size: 11px;
}

.studio-suite__window-bar i {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #3a4554;
}

.studio-suite__window-bar i:first-child { background: var(--studio-accent); }
.studio-suite__window-bar span { margin-left: auto; }
.studio-suite__window-body { padding: 30px; }

.studio-suite__signal {
    display: flex;
    justify-content: space-between;
    padding-bottom: 22px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    color: #f5f8fd;
    font-size: 14px;
    font-weight: 800;
}

.studio-suite__signal b {
    color: var(--studio-accent);
    font-family: monospace;
    font-size: 11px;
    text-transform: uppercase;
}

.studio-suite__route {
    position: relative;
    display: grid;
    gap: 14px;
    margin-top: 25px;
}

.studio-suite__route::before {
    content: "";
    position: absolute;
    top: 25px;
    bottom: 25px;
    left: 23px;
    width: 1px;
    background: linear-gradient(var(--studio-accent), rgba(var(--studio-accent-rgb), .15));
}

.studio-suite__route div {
    position: relative;
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 4px 14px;
    padding: 18px;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 13px;
    background: linear-gradient(110deg, rgba(var(--studio-accent-rgb), .08), rgba(255,255,255,.018));
}

.studio-suite__route span {
    grid-row: span 2;
    z-index: 1;
    color: var(--studio-accent);
    font-family: monospace;
    font-weight: 900;
}

.studio-suite__route strong { color: #f4f7fc; }
.studio-suite__route small { color: #778395; }

.studio-suite__metric {
    margin-top: 22px;
    padding: 20px;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 13px;
    color: #758194;
}

.studio-suite__metric strong {
    float: right;
    color: #fff;
}

.studio-suite__metric i {
    display: block;
    width: 82%;
    height: 5px;
    margin-top: 15px;
    border-radius: 99px;
    background: linear-gradient(90deg, var(--studio-accent), rgba(var(--studio-accent-rgb), .15));
}

.studio-suite__floating-card {
    position: absolute;
    right: -20px;
    bottom: 0;
    width: min(300px, 70%);
    padding: 22px;
    border: 1px solid rgba(var(--studio-accent-rgb), .32);
    border-radius: 16px;
    background: rgba(15, 21, 31, .88);
    box-shadow: 0 24px 70px rgba(0,0,0,.42);
    backdrop-filter: blur(18px);
}

.studio-suite__floating-card span {
    display: block;
    margin-bottom: 9px;
    color: var(--studio-accent);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.studio-suite__floating-card strong { color: #fff; font-size: 19px; }

.studio-suite__pains {
    background:
        radial-gradient(circle at 15% 35%, rgba(var(--studio-accent-rgb), .08), transparent 25%),
        #10151e;
}

.studio-suite__heading {
    display: grid;
    grid-template-columns: .75fr 1.45fr .8fr;
    gap: 42px;
    align-items: end;
    margin-bottom: 55px;
}

.studio-suite__heading .studio-suite__eyebrow { align-self: start; }

.studio-suite__heading > p {
    margin: 0;
    color: #9da9ba;
    line-height: 1.7;
}

.studio-suite__heading--wide {
    grid-template-columns: .6fr 1.4fr;
}

.studio-suite__pain-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.studio-suite__pain-grid article {
    position: relative;
    min-height: 370px;
    padding: 28px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 22px;
    background: linear-gradient(145deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
    transition: transform .25s ease, border-color .25s ease;
}

.studio-suite__pain-grid article::after {
    content: "";
    position: absolute;
    right: -90px;
    bottom: -90px;
    width: 190px;
    height: 190px;
    border: 1px solid rgba(var(--studio-accent-rgb), .18);
    border-radius: 50%;
}

.studio-suite__pain-grid article:hover {
    transform: translateY(-7px);
    border-color: rgba(var(--studio-accent-rgb), .3);
}

.studio-suite__pain-grid article.is-featured {
    border-color: rgba(var(--studio-accent-rgb), .38);
    background:
        radial-gradient(circle at 85% 10%, rgba(var(--studio-accent-rgb), .17), transparent 35%),
        linear-gradient(145deg, rgba(var(--studio-accent-rgb), .08), rgba(255,255,255,.018));
    box-shadow: 0 30px 70px rgba(0,0,0,.28);
}

.studio-suite__card-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.studio-suite__card-top span {
    color: var(--studio-accent);
    font-family: monospace;
    font-size: 13px;
}

.studio-suite__card-top i {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--studio-accent);
    box-shadow: 0 0 0 7px rgba(var(--studio-accent-rgb), .1);
}

.studio-suite__pain-grid h3 {
    max-width: 280px;
    margin: 70px 0 24px;
    color: #f5f8fd;
    font-size: 26px;
    line-height: 1.16;
}

.studio-suite__pain-grid ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.studio-suite__pain-grid li {
    position: relative;
    padding: 9px 0 9px 17px;
    border-top: 1px solid rgba(255,255,255,.07);
    color: #9da9b9;
    font-size: 14px;
}

.studio-suite__pain-grid li::before {
    content: "";
    position: absolute;
    top: 17px;
    left: 0;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--studio-accent);
}

.studio-suite__offer { background: #0b0f16; }

.studio-suite__offer-grid {
    display: grid;
    grid-template-columns: .82fr 1.18fr;
    gap: 95px;
    align-items: start;
}

.studio-suite__offer-intro {
    position: sticky;
    top: 110px;
}

.studio-suite__offer-intro > p {
    max-width: 520px;
    margin: 25px 0 0;
    color: #9da9ba;
    font-size: 17px;
    line-height: 1.75;
}

.studio-suite__orbit {
    position: relative;
    display: grid;
    width: 210px;
    height: 210px;
    place-items: center;
    margin-top: 55px;
    border: 1px solid rgba(var(--studio-accent-rgb), .18);
    border-radius: 50%;
}

.studio-suite__orbit::before,
.studio-suite__orbit::after {
    content: "";
    position: absolute;
    border: 1px solid rgba(var(--studio-accent-rgb), .12);
    border-radius: 50%;
}

.studio-suite__orbit::before { inset: 24px; }
.studio-suite__orbit::after { inset: 52px; background: rgba(var(--studio-accent-rgb), .08); }

.studio-suite__orbit span {
    z-index: 1;
    color: #fff;
    font-weight: 900;
}

.studio-suite__orbit i {
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--studio-accent);
    box-shadow: 0 0 18px rgba(var(--studio-accent-rgb), .8);
}

.studio-suite__orbit i:nth-of-type(1) { top: 23px; right: 44px; }
.studio-suite__orbit i:nth-of-type(2) { right: 7px; bottom: 67px; }
.studio-suite__orbit i:nth-of-type(3) { bottom: 17px; left: 53px; }

.studio-suite__offer-list {
    border-top: 1px solid rgba(255,255,255,.12);
}

.studio-suite__offer-list article {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 24px;
    padding: 29px 0;
    border-bottom: 1px solid rgba(255,255,255,.12);
}

.studio-suite__offer-list article > span {
    color: var(--studio-accent);
    font-family: monospace;
    font-size: 13px;
}

.studio-suite__offer-list h3 {
    margin: 0 0 9px;
    color: #f5f8fd;
    font-size: 24px;
}

.studio-suite__offer-list p {
    margin: 0;
    color: #909cad;
    line-height: 1.65;
}

.studio-suite__results {
    background:
        linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px),
        #10151e;
    background-size: 42px 42px;
}

.studio-suite__result-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.studio-suite__result-grid article {
    position: relative;
    min-height: 280px;
    padding: 30px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 20px;
    background: rgba(12,17,25,.78);
}

.studio-suite__result-grid article.is-combined {
    border-color: rgba(var(--studio-accent-rgb), .35);
    background:
        linear-gradient(125deg, rgba(var(--studio-accent-rgb), .16), transparent 65%),
        rgba(12,17,25,.9);
}

.studio-suite__result-grid article > span {
    color: var(--studio-accent);
    font-family: monospace;
    font-size: 12px;
    letter-spacing: .1em;
}

.studio-suite__result-grid h3 {
    margin: 78px 0 12px;
    color: #f7f9fd;
    font-size: 29px;
}

.studio-suite__result-grid p {
    max-width: 430px;
    margin: 0;
    color: #98a4b5;
    line-height: 1.65;
}

.studio-suite__result-grid b {
    position: absolute;
    right: 22px;
    bottom: -18px;
    color: rgba(var(--studio-accent-rgb), .09);
    font-size: 108px;
    line-height: 1;
}

.studio-suite__result-line {
    display: flex;
    gap: 18px;
    align-items: center;
    margin-top: 28px;
    color: #8793a4;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.studio-suite__result-line i {
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, var(--studio-accent), rgba(var(--studio-accent-rgb), .08));
}

.studio-suite__process {
    background:
        radial-gradient(circle at 15% 20%, rgba(var(--studio-accent-rgb), .1), transparent 27%),
        #0b0f16;
}

.studio-suite__process-grid {
    display: grid;
    grid-template-columns: .8fr 1.2fr;
    gap: 100px;
}

.studio-suite__process-heading {
    position: sticky;
    top: 110px;
    align-self: start;
}

.studio-suite__process-heading > p {
    max-width: 500px;
    margin: 25px 0 0;
    color: #99a5b6;
    font-size: 17px;
    line-height: 1.72;
}

.studio-suite__steps {
    position: relative;
    margin: 0;
    padding: 0;
    list-style: none;
}

.studio-suite__steps::before {
    content: "";
    position: absolute;
    top: 32px;
    bottom: 32px;
    left: 31px;
    width: 1px;
    background: linear-gradient(var(--studio-accent), rgba(var(--studio-accent-rgb), .08));
}

.studio-suite__steps li {
    position: relative;
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: 24px;
    padding: 0 0 38px;
}

.studio-suite__steps li > span {
    z-index: 1;
    display: grid;
    width: 64px;
    height: 64px;
    place-items: center;
    border: 1px solid rgba(var(--studio-accent-rgb), .32);
    border-radius: 50%;
    color: var(--studio-accent);
    background: #10151e;
    font-family: monospace;
    font-weight: 900;
}

.studio-suite__steps li > div {
    min-height: 135px;
    padding: 23px 25px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 17px;
    background: linear-gradient(120deg, rgba(var(--studio-accent-rgb), .06), rgba(255,255,255,.018));
}

.studio-suite__steps h3 {
    margin: 0 0 10px;
    color: #f5f8fd;
    font-size: 23px;
}

.studio-suite__steps p {
    margin: 0;
    color: #929eaf;
    line-height: 1.65;
}

@media (max-width: 1050px) {
    .studio-suite__hero-grid,
    .studio-suite__offer-grid,
    .studio-suite__process-grid {
        grid-template-columns: 1fr;
        gap: 55px;
    }

    .studio-suite__hero-copy { max-width: 820px; }
    .studio-suite__interface { width: min(720px, 100%); }
    .studio-suite__offer-intro,
    .studio-suite__process-heading { position: static; }
    .studio-suite__orbit { display: none; }
}

@media (max-width: 820px) {
    .studio-suite section { padding: 78px 0; }
    .studio-suite__hero { min-height: auto; padding-top: 115px !important; }

    .studio-suite__heading,
    .studio-suite__heading--wide {
        grid-template-columns: 1fr;
        gap: 20px;
        align-items: start;
    }

    .studio-suite__pain-grid { grid-template-columns: 1fr; }
    .studio-suite__pain-grid article { min-height: auto; }
    .studio-suite__pain-grid h3 { margin-top: 42px; }
    .studio-suite__result-line { align-items: flex-start; flex-direction: column; }
    .studio-suite__result-line i { width: 100%; flex: none; }
}

@media (max-width: 560px) {
    .studio-suite h2 { font-size: 36px; }
    .studio-suite__hero-copy h1 { font-size: 43px; }
    .studio-suite__hero-copy > p { font-size: 16px; }
    .studio-suite__actions { align-items: stretch; flex-direction: column; }
    .studio-suite__button,
    .studio-suite__link { justify-content: center; width: 100%; }
    .studio-suite__interface { min-height: 510px; }
    .studio-suite__window { inset: 0 0 45px; transform: none; }
    .studio-suite__window-body { padding: 18px; }
    .studio-suite__floating-card { right: 12px; }
    .studio-suite__route div { padding: 14px; }
    .studio-suite__result-grid { grid-template-columns: 1fr; }
    .studio-suite__result-grid article { min-height: 250px; padding: 24px; }
    .studio-suite__result-grid h3 { margin-top: 58px; font-size: 25px; }
    .studio-suite__offer-list article { grid-template-columns: 48px 1fr; gap: 14px; }
    .studio-suite__steps li { grid-template-columns: 52px 1fr; gap: 14px; }
    .studio-suite__steps::before { left: 25px; }
    .studio-suite__steps li > span { width: 52px; height: 52px; }
    .studio-suite__steps li > div { padding: 20px; }
}

.realtor-hero,
.realtor-board,
.realtor-flow,
.tourism-hero,
.tourism-route,
.tourism-destinations,
.dealer-hero,
.dealer-lanes,
.dealer-matrix,
.sto-hero,
.sto-checklist,
.sto-modules,
.beauty-hero,
.beauty-services,
.beauty-studio,
.realtor-stack,
.realtor-audience,
.realtor-data,
.tourism-offers,
.tourism-logic,
.tourism-formats,
.dealer-process,
.dealer-data,
.dealer-stock,
.sto-flow,
.sto-service-map,
.sto-admin,
.beauty-flow,
.beauty-menu,
.beauty-client {
    position: relative;
    padding: 100px 0;
}

.realtor-chip,
.tourism-label,
.dealer-label,
.sto-label,
.beauty-label {
    display: inline-flex;
    width: fit-content;
    margin-bottom: 22px;
    padding: 9px 16px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #f8fbff;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.realtor-niche {
    background:
        linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px),
        radial-gradient(circle at 8% 10%, rgba(58, 176, 255, 0.16), transparent 32%),
        linear-gradient(180deg, #0d111a 0%, #09111c 100%);
    background-size: 34px 34px, 34px 34px, auto, auto;
}

.realtor-hero__grid,
.dealer-hero__grid,
.sto-hero__grid,
.beauty-hero__grid {
    display: grid;
    gap: 56px;
    align-items: center;
}

.realtor-hero__grid {     grid-template-columns: minmax(0, 1.5fr) minmax(323px, 1fr); }
.dealer-hero__grid { grid-template-columns: minmax(0, 1fr) minmax(380px, 0.8fr); }
.sto-hero__grid { grid-template-columns: minmax(360px, 0.8fr) minmax(0, 1fr); }
.beauty-hero__grid { grid-template-columns: minmax(0, 0.9fr) minmax(340px, 0.55fr); }

.realtor-hero h1,
.tourism-hero h1,
.dealer-hero h1,
.sto-hero h1,
.beauty-hero h1 {
    margin: 0 0 26px;
    color: #f6f9ff;
    font-size: clamp(38px, 5.4vw, 74px);
    line-height: 1.08;
    font-weight: 800;
}

.realtor-hero p,
.tourism-hero p,
.sto-hero p,
.beauty-hero p,
.dealer-matrix p {
    max-width: 720px;
    color: #b8c3d8;
    font-size: 18px;
    line-height: 1.78;
}

.realtor-chip { background: rgba(58, 176, 255, 0.12); }

.realtor-map {
    position: relative;
    min-height: 460px;
    border-radius: 18px;
    border: 1px solid rgba(58, 176, 255, 0.22);
    background:
        linear-gradient(90deg, transparent 49%, rgba(255, 255, 255, 0.08) 50%, transparent 51%),
        linear-gradient(0deg, transparent 49%, rgba(255, 255, 255, 0.08) 50%, transparent 51%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.018));
    background-size: 54px 54px, 54px 54px, auto;
    box-shadow: 0 32px 80px rgba(0, 0, 0, 0.48);
}

.realtor-map__card {
    position: absolute;
    left: 38px;
    bottom: 38px;
    width: min(340px, calc(100% - 76px));
    padding: 24px;
    border-radius: 18px;
    background: rgba(10, 15, 26, 0.86);
    border: 1px solid rgba(255, 255, 255, 0.10);
}

.realtor-map__card span,
.realtor-board article span {
    color: #3ab0ff;
    font-weight: 900;
}

.realtor-map__card strong {
    display: block;
    margin: 10px 0;
    color: #fff;
    font-size: 38px;
}

.realtor-map__pin {
    position: absolute;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #3ab0ff;
    box-shadow: 0 0 0 10px rgba(58, 176, 255, 0.12), 0 0 28px rgba(58, 176, 255, 0.6);
}

.realtor-map__pin--one { top: 22%; left: 28%; }
.realtor-map__pin--two { top: 38%; right: 20%; }
.realtor-map__pin--three {     bottom: 28%;
    right: 13%; }

.realtor-board__head,
.sto-modules h2 {
    max-width: 820px;
    margin-bottom: 44px;
}

.realtor-board h2,
.realtor-flow h2,
.realtor-stack h2,
.tourism-destinations h2,
.tourism-offers h2,
.dealer-matrix h2,
.sto-modules h2,
.sto-flow h2,
.beauty-studio h2 {
    margin: 0;
    color: #f6f9ff;
    font-size: clamp(30px, 4vw, 54px);
    line-height: 1.12;
    font-weight: 800;
}

.realtor-board__grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 22px;
}

.realtor-board article,
.realtor-flow__steps div,
.tourism-route article,
.tourism-destinations__cards div,
.dealer-lanes article,
.dealer-matrix__items span,
.sto-checklist article,
.sto-modules span,
.beauty-services article,
.beauty-studio span {
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.058), rgba(255, 255, 255, 0.018));
    box-shadow: 0 24px 58px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.realtor-board article {
    min-height: 230px;
    padding: 30px;
    border-radius: 22px;
}

.realtor-board article:nth-child(1) { grid-row: span 2; }

.realtor-board h3,
.tourism-route h3,
.dealer-lanes h3,
.sto-checklist h3,
.beauty-services h3 {
    margin: 16px 0 12px;
    color: #f4f7fb;
    font-size: 24px;
    line-height: 1.2;
}

.realtor-board p,
.realtor-flow p,
.tourism-route p,
.dealer-lanes p,
.sto-checklist p,
.beauty-services p {
    color: #aeb8cb;
    line-height: 1.7;
}

.realtor-flow__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 44px;
}

.realtor-flow__steps {
    display: grid;
    gap: 16px;
}

.realtor-flow__steps div {
    padding: 24px;
    border-radius: 16px;
}

.realtor-flow__steps strong {
    color: #fff;
    font-size: 20px;
}

.tourism-niche {
    background:
        radial-gradient(circle at 16% 18%, rgba(34, 211, 238, 0.14), transparent 30%),
        radial-gradient(circle at 86% 28%, rgba(74, 222, 128, 0.12), transparent 30%),
        linear-gradient(160deg, #0e111a 0%, #071622 56%, #101418 100%);
}

.tourism-hero { padding-top: 130px; }
.tourism-label { background: rgba(34, 211, 238, 0.13); }
.tourism-hero h1 { max-width: 1080px; }

.tourism-hero__bottom {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.45fr);
    gap: 36px;
    align-items: end;
}

.tourism-ticket {
    width: min(100%, 520px);
    justify-self: end;
    padding: 28px;
    border-radius: 46px;
    background: linear-gradient(135deg, rgba(34, 211, 238, 0.16), rgba(74, 222, 128, 0.12));
    border: 1px solid rgba(255, 255, 255, 0.10);
}

.tourism-ticket span,
.tourism-route article span {
    color: #4ade80;
    font-weight: 900;
    letter-spacing: 0.12em;
}

.tourism-ticket strong {
    display: block;
    margin: 10px 0;
    color: #fff;
    font-size: 28px;
}

.tourism-route__line {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
}

.tourism-route__line::before {
    content: "";
    position: absolute;
    top: -22px;
    left: 9%;
    right: 9%;
    height: 2px;
    background: linear-gradient(90deg, #22d3ee, #4ade80);
    opacity: 0.55;
    z-index: 0;
}

.tourism-route article {
    position: relative;
    z-index: 1;
    padding: 30px;
    border-radius: 16px;
    background: linear-gradient(145deg, rgba(19, 32, 41, 0.96), rgba(14, 23, 31, 0.94));
}

.tourism-destinations__grid,
.dealer-matrix__grid,
.beauty-studio__grid,
.realtor-stack__grid,
.sto-flow__grid,
.niche-split {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: 46px;
    align-items: start;
}

.tourism-destinations__cards,
.dealer-matrix__items,
.beauty-studio__grid > div:last-child,
.realtor-stack__items {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.tourism-destinations__cards div,
.dealer-matrix__items span,
.realtor-stack__items span {
    min-height: 92px;
    padding: 22px;
    border-radius: 18px;
    color: #eefcff;
    font-weight: 800;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.058), rgba(255, 255, 255, 0.018));
    box-shadow: 0 24px 58px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.05);
    display: flex;
    align-items: center;
    justify-content: center;
}

.tourism-offers__head {
    max-width: 860px;
    margin-bottom: 42px;
}

.tourism-offers__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}

.tourism-offers article {
    min-height: 260px;
    padding: 30px;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top right, rgba(74, 222, 128, 0.10), transparent 36%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.058), rgba(255, 255, 255, 0.018));
    box-shadow: 0 24px 58px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.tourism-offers article strong {
    display: block;
    margin-bottom: 16px;
    color: #fff;
    font-size: 28px;
}

.tourism-offers article span {
    display: inline-flex;
    margin-bottom: 18px;
    color: #4ade80;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tourism-offers article p {
    margin: 0;
    color: #aeb8cb;
    line-height: 1.7;
}

.realtor-stack__grid p {
    color: #aeb8cb;
    font-size: 17px;
    line-height: 1.75;
    margin-top: 18px;
}


.dealer-niche {
    background:
        linear-gradient(120deg, rgba(96, 165, 250, 0.10), transparent 34%),
        linear-gradient(180deg, #0f121b 0%, #090d15 100%);
}

.dealer-label { background: rgba(96, 165, 250, 0.13); }

.dealer-panel {
    padding: 28px;
    border-radius: 8px;
    border: 1px solid rgba(96, 165, 250, 0.24);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.02));
    box-shadow: 0 30px 76px rgba(0, 0, 0, 0.50);
    transform: perspective(900px) rotateY(-4deg);
}

.dealer-panel__top,
.dealer-panel__row {
    padding: 18px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.dealer-panel__top {
    color: #60a5fa;
    font-weight: 900;
}

.dealer-panel__row {
    display: flex;
    justify-content: space-between;
    color: #fff;
}

.dealer-panel__row strong { color: #818cf8; }

.dealer-lanes .container {
    display: grid;
    gap: 18px;
}

.dealer-lanes article {
    display: grid;
    grid-template-columns: 90px 0.7fr 1fr;
    gap: 24px;
    align-items: center;
    padding: 26px;
    border-radius: 14px;
}

.dealer-lanes article span {
    color: #60a5fa;
    font-size: 28px;
    font-weight: 900;
}

.dealer-process__grid,
.beauty-flow__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.dealer-process article,
.beauty-flow article,
.sto-flow article {
    min-height: 220px;
    padding: 28px;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.058), rgba(255, 255, 255, 0.018));
    box-shadow: 0 24px 58px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.dealer-process span,
.beauty-flow span,
.sto-flow strong {
    display: inline-flex;
    margin-bottom: 18px;
    color: #60a5fa;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.dealer-process h3,
.beauty-flow h3 {
    margin: 0 0 12px;
    color: #f4f7fb;
    font-size: 23px;
    line-height: 1.22;
}

.dealer-process p,
.beauty-flow p,
.sto-flow p {
    margin: 0;
    color: #aeb8cb;
    line-height: 1.7;
}

.sto-niche {
    background:
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 18px),
        radial-gradient(circle at 80% 18%, rgba(250, 204, 21, 0.10), transparent 28%),
        linear-gradient(180deg, #10131a 0%, #0b0f16 100%);
}

.sto-label { background: rgba(250, 204, 21, 0.10); }

.sto-diagnostic {
    padding: 32px;
    border-radius: 22px;
    border: 1px dashed rgba(250, 204, 21, 0.36);
    background: rgba(255, 255, 255, 0.035);
    box-shadow: 0 28px 72px rgba(0, 0, 0, 0.46);
}

.sto-diagnostic span,
.sto-checklist article span {
    color: #facc15;
    font-weight: 900;
}

.sto-diagnostic div {
    height: 16px;
    margin: 22px 0;
    border-radius: 999px;
    background: linear-gradient(90deg, #38bdf8, rgba(250, 204, 21, 0.45));
}

.sto-diagnostic strong { color: #fff; }

.sto-checklist__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.sto-checklist article {
    min-height: 260px;
    padding: 28px;
    border-radius: 10px;
}

.sto-modules .container > div {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 36px;
}

.sto-modules span {
    min-height: 100px;
    padding: 22px;
    border-radius: 10px;
    color: #fff;
    font-weight: 800;
}

.sto-flow__grid > div:last-child {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.sto-flow strong {
    color: #facc15;
}

.beauty-niche {
    background:
        radial-gradient(circle at 18% 16%, rgba(244, 114, 182, 0.13), transparent 30%),
        radial-gradient(circle at 84% 26%, rgba(167, 139, 250, 0.12), transparent 28%),
        linear-gradient(180deg, #11101a 0%, #0e111a 100%);
}

.beauty-label { background: rgba(244, 114, 182, 0.13); }

.beauty-card {
    min-height: 360px;
    padding: 34px;
    border-radius: 38px;
    background: linear-gradient(145deg, rgba(244, 114, 182, 0.15), rgba(167, 139, 250, 0.08));
    border: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 0 32px 80px rgba(0, 0, 0, 0.42);
}

.beauty-card span {
    color: #f472b6;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.beauty-card strong {
    display: block;
    margin: 130px 0 14px;
    color: #fff;
    font-size: 30px;
    line-height: 1.2;
}

.beauty-services__grid {
    display: grid;
    grid-template-columns: 0.8fr 1.2fr 0.8fr;
    gap: 22px;
    align-items: stretch;
}

.beauty-services article {
    padding: 30px;
    border-radius: 34px;
}

.beauty-services article:nth-child(2) { transform: translateY(-28px); }

.beauty-studio span {
    min-height: 72px;
    padding: 20px;
    border-radius: 999px;
    color: #fff;
    font-weight: 800;
}

.beauty-flow span {
    color: #f472b6;
}

.niche-copy-head {
    max-width: 900px;
    margin-bottom: 42px;
}

.niche-copy-head h2,
.niche-split h2 {
    margin: 0;
    color: #f6f9ff;
    font-size: clamp(30px, 4vw, 54px);
    line-height: 1.12;
    font-weight: 800;
}

.niche-copy-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}

.niche-copy-grid article,
.niche-list-panel {
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top right, rgba(58, 176, 255, 0.08), transparent 38%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.058), rgba(255, 255, 255, 0.018));
    box-shadow: 0 24px 58px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.niche-copy-grid article {
    min-height: 245px;
    padding: 30px;
    border-radius: 24px;
}

.niche-copy-grid h3 {
    margin: 0 0 14px;
    color: #f4f7fb;
    font-size: 23px;
    line-height: 1.24;
}

.niche-copy-grid p,
.niche-list-panel p {
    margin: 0;
    color: #aeb8cb;
    line-height: 1.72;
}

.niche-list-panel {
    padding: 30px;
    border-radius: 24px;
}

.niche-list-panel p + p {
    margin-top: 18px;
}

@media (max-width: 1100px) {
    .realtor-hero__grid,
    .realtor-flow__grid,
    .tourism-hero__bottom,
    .tourism-destinations__grid,
    .dealer-hero__grid,
    .dealer-matrix__grid,
    .sto-hero__grid,
    .beauty-hero__grid,
    .beauty-studio__grid,
    .realtor-stack__grid,
    .sto-flow__grid,
    .niche-split {
        grid-template-columns: 1fr;
    }

    .dealer-panel { transform: none; }
}

@media (max-width: 820px) {
    .realtor-hero,
    .realtor-board,
    .realtor-flow,
    .tourism-hero,
    .tourism-route,
    .tourism-destinations,
    .dealer-hero,
    .dealer-lanes,
    .dealer-matrix,
    .sto-hero,
    .sto-checklist,
    .sto-modules,
    .beauty-hero,
    .beauty-services,
    .beauty-studio,
    .realtor-stack,
    .realtor-audience,
    .realtor-data,
    .tourism-offers,
    .tourism-logic,
    .tourism-formats,
    .dealer-process,
    .dealer-data,
    .dealer-stock,
    .sto-flow,
    .sto-service-map,
    .sto-admin,
    .beauty-flow,
    .beauty-menu,
    .beauty-client {
        padding: 64px 0 !important;
    }

    .realtor-board__grid,
    .tourism-route__line,
    .tourism-destinations__cards,
    .tourism-offers__grid,
    .niche-copy-grid,
    .dealer-lanes article,
    .dealer-matrix__items,
    .dealer-process__grid,
    .sto-checklist__grid,
    .sto-modules .container > div,
    .sto-flow__grid > div:last-child,
    .beauty-services__grid,
    .beauty-flow__grid,
    .realtor-stack__items,
    .beauty-studio__grid > div:last-child {
        grid-template-columns: 1fr;
    }

    .tourism-route__line::before { display: none; }
    .beauty-services article:nth-child(2) { transform: none; }
}

@media (max-width: 560px) {
    .realtor-hero h1,
    .tourism-hero h1,
    .dealer-hero h1,
    .sto-hero h1,
    .beauty-hero h1 {
        font-size: 34px;
    }

    .realtor-map,
    .beauty-card {
        min-height: 320px;
    }

}

/* Rich niche heroes */
.niche-hero-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 18px;
    margin-top: 32px;
}

.niche-primary-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 0 24px;
    border-radius: 14px;
    color: #07111c;
    background: #fff;
    font-size: 15px;
    font-weight: 900;
    text-decoration: none;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.niche-primary-btn:hover {
    color: #07111c;
    transform: translateY(-2px);
    box-shadow: 0 22px 50px rgba(0, 0, 0, 0.36);
}

.niche-text-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #eaf1ff;
    font-size: 15px;
    font-weight: 800;
    text-decoration: none;
}

.niche-text-link span {
    font-size: 19px;
    transition: transform 0.2s ease;
}

.niche-text-link:hover span {
    transform: translate(3px, 2px);
}

.realtor-map,
.tourism-visual,
.dealer-visual,
.sto-visual,
.beauty-visual {
    position: relative;
    margin: 0;
    isolation: isolate;
}

.realtor-map img,
.tourism-visual img,
.dealer-visual img,
.sto-visual img,
.beauty-visual img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Realtors: architectural editorial */
.realtor-hero {
    padding-top: 132px;
}

.realtor-hero__grid {
    grid-template-columns: minmax(0, 0.92fr) minmax(480px, 1.08fr);
}

.realtor-hero__content {
    position: relative;
    z-index: 2;
}

.realtor-map {
    min-height: 590px;
    overflow: hidden;
    border-radius: 6px 86px 6px 6px;
    background: #101927;
}

.realtor-map::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, transparent 38%, rgba(5, 12, 23, 0.74) 100%);
    pointer-events: none;
}

.realtor-map img {
    position: absolute;
    inset: 0;
}

.realtor-map__card {
    z-index: 3;
    backdrop-filter: blur(18px);
}

.realtor-map__card small {
    display: block;
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    color: #dfe9f8;
}

.realtor-map__pin {
    z-index: 3;
}

.realtor-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 38px;
}

.realtor-proof span {
    padding: 9px 13px;
    border: 1px solid rgba(58, 176, 255, 0.18);
    border-radius: 4px;
    color: #9dd9ff;
    background: rgba(58, 176, 255, 0.07);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.realtor-niche .niche-primary-btn {
    background: #3ab0ff;
}

/* Tourism: cinematic route */
.tourism-hero {
    padding-bottom: 60px;
}

.tourism-hero__bottom {
    align-items: start;
}

.tourism-mini-facts {
    display: grid;
    gap: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.tourism-mini-facts span {
    padding: 14px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #d9f9ef;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tourism-visual {
    min-height: 610px;
    margin-top: 58px;
    overflow: hidden;
    border-radius: 90px 18px 90px 18px;
    box-shadow: 0 36px 100px rgba(0, 0, 0, 0.44);
}

.tourism-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, rgba(3, 19, 27, 0.05), rgba(3, 16, 24, 0.62));
    pointer-events: none;
}

.tourism-visual img {
    position: absolute;
    inset: 0;
}

.tourism-ticket {
    position: absolute;
    left: 38px;
    bottom: 38px;
    z-index: 3;
    width: min(420px, calc(100% - 76px));
    border-radius: 26px;
    background: rgba(7, 27, 34, 0.72);
    backdrop-filter: blur(18px);
}

.tourism-route-badge {
    position: absolute;
    top: 30px;
    right: 30px;
    z-index: 3;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 4px 10px;
    min-width: 190px;
    padding: 18px;
    border-radius: 18px;
    color: #eafff6;
    background: rgba(7, 27, 34, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.16);
    backdrop-filter: blur(18px);
}

.tourism-route-badge i {
    grid-row: span 2;
    align-self: center;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #4ade80;
    box-shadow: 0 0 0 7px rgba(74, 222, 128, 0.15);
}

.tourism-route-badge span {
    color: #9fc8be;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.tourism-niche .niche-primary-btn {
    background: linear-gradient(135deg, #22d3ee, #4ade80);
}

/* Dealers: premium digital showroom */
.dealer-hero {
    padding-top: 132px;
}

.dealer-hero__grid {
    grid-template-columns: minmax(0, 0.78fr) minmax(540px, 1.22fr);
}

.dealer-hero__content p {
    max-width: 650px;
    color: #b8c3d8;
    font-size: 18px;
    line-height: 1.78;
}

.dealer-visual {
    min-height: 590px;
    overflow: visible;
    border-radius: 2px;
    box-shadow: 0 38px 90px rgba(0, 0, 0, 0.54);
}

.dealer-visual::before {
    content: "";
    position: absolute;
    inset: -14px 14px 14px -14px;
    z-index: -1;
    border: 1px solid rgba(129, 140, 248, 0.34);
}

.dealer-visual img {
    position: absolute;
    inset: 0;
}

.dealer-panel {
    position: absolute;
    right: -26px;
    bottom: -38px;
    z-index: 2;
    width: min(440px, calc(100% - 36px));
    padding: 12px 24px;
    border-radius: 4px;
    background: rgba(8, 12, 22, 0.84);
    backdrop-filter: blur(20px);
    transform: none;
}

.dealer-panel__top {
    display: flex;
    justify-content: space-between;
}

.dealer-panel__top strong {
    color: #fff;
}

.dealer-niche .niche-primary-btn {
    color: #fff;
    background: linear-gradient(135deg, #60a5fa, #818cf8);
}

/* Service station: industrial diagnostic */
.sto-hero {
    padding-top: 132px;
}

.sto-hero__grid {
    grid-template-columns: minmax(500px, 1.12fr) minmax(0, 0.88fr);
}

.sto-visual {
    min-height: 570px;
    border: 1px solid rgba(250, 204, 21, 0.24);
    clip-path: polygon(0 0, 92% 0, 100% 9%, 100% 100%, 0 100%);
    background: #111720;
}

.sto-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, transparent 35%, rgba(6, 10, 15, 0.78));
}

.sto-visual img {
    position: absolute;
    inset: 0;
}

.sto-diagnostic {
    position: absolute;
    left: 28px;
    right: 28px;
    bottom: 28px;
    z-index: 3;
    padding: 24px;
    border-radius: 3px;
    background: rgba(10, 15, 21, 0.8);
    backdrop-filter: blur(16px);
}

.sto-diagnostic div {
    height: 8px;
    margin: 13px 0;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.09);
}

.sto-diagnostic div i {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, #38bdf8, #facc15);
}

.sto-status {
    display: grid;
    gap: 10px;
    margin-top: 38px;
    padding: 18px 0;
    border-top: 1px solid rgba(250, 204, 21, 0.2);
    border-bottom: 1px solid rgba(250, 204, 21, 0.2);
}

.sto-status span,
.sto-status strong {
    color: #dce4ee;
    font-size: 13px;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.sto-status i {
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-right: 8px;
    border-radius: 50%;
    background: #4ade80;
    box-shadow: 0 0 14px rgba(74, 222, 128, 0.7);
}

.sto-niche .niche-primary-btn {
    background: #facc15;
}

/* Beauty: soft editorial booking */
.beauty-hero {
    padding-top: 132px;
}

.beauty-hero__grid {
    grid-template-columns: minmax(0, 0.88fr) minmax(500px, 1.12fr);
}

.beauty-visual {
    min-height: 610px;
    overflow: hidden;
    border-radius: 180px 24px 180px 24px;
    box-shadow: 0 36px 90px rgba(4, 3, 12, 0.5);
}

.beauty-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, transparent 42%, rgba(29, 11, 28, 0.76));
}

.beauty-visual img {
    position: absolute;
    inset: 0;
}

.beauty-booking {
    position: absolute;
    left: 34px;
    right: 34px;
    bottom: 34px;
    z-index: 3;
    padding: 24px 28px;
    border-radius: 28px;
    color: #fff;
    background: rgba(36, 15, 35, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(18px);
}

.beauty-booking span {
    color: #f9a8d4;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.beauty-booking strong {
    display: block;
    margin: 8px 0;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 28px;
    font-weight: 500;
}

.beauty-booking p {
    margin: 0;
    color: #f2dfe9;
    font-size: 14px;
}

.beauty-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 38px;
}

.beauty-metrics div {
    padding: 18px 0;
    border-top: 1px solid rgba(244, 114, 182, 0.28);
}

.beauty-metrics strong,
.beauty-metrics span {
    display: block;
}

.beauty-metrics strong {
    color: #fff;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 27px;
    font-weight: 500;
}

.beauty-metrics span {
    margin-top: 6px;
    color: #cbbac8;
    font-size: 13px;
}

.beauty-niche .niche-primary-btn {
    background: linear-gradient(135deg, #f9a8d4, #c4b5fd);
}

@media (max-width: 1180px) {
    .realtor-hero__grid,
    .dealer-hero__grid,
    .sto-hero__grid,
    .beauty-hero__grid {
        grid-template-columns: 1fr;
    }

    .realtor-map,
    .dealer-visual,
    .sto-visual,
    .beauty-visual {
        min-height: 560px;
    }

    .dealer-panel {
        right: 24px;
    }
}

/* =========================================================
   Final niche architecture
   ========================================================= */

.niche-page {
    overflow: hidden;
    color: #edf2fb;
    background: #0b0f16;
}

.niche-page section {
    position: relative;
    box-sizing: border-box;
}

.niche-page h1 {
    margin: 0;
    color: #f7f9fd;
    font-size: clamp(38px, 4.4vw, 66px);
    font-weight: 800;
    line-height: 1.02;
    letter-spacing: -0.045em;
}

.niche-page h2 {
    margin: 0;
    color: #f5f8fd;
    font-size: clamp(32px, 4vw, 45px);
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: -0.035em;
}

.niche-page h3 {
    color: #f4f7fc;
}

.niche-page p {
    color: #aeb9ca;
    line-height: 1.75;
}

.niche-page .niche-hero-actions {
    margin-top: 28px;
}

/* Beauty */
.beauty-page {
    --page-accent: #ed83ba;
    background:
        radial-gradient(circle at 12% 10%, rgba(237, 131, 186, 0.12), transparent 28%),
        #0c0f16;
}

.beauty-page .niche-primary-btn { background: var(--page-accent); }

.beauty-cover {
    display: grid;
    grid-template-columns: 47% 53%;
    height: 100svh;
    min-height: 650px;
    max-height: 940px;
    padding-top: 88px;
    background: #0e1017;
}

.beauty-cover__image {
    grid-column: 2;
    grid-row: 1;
    overflow: hidden;
}

.beauty-cover__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, #0e1017, transparent 28%), linear-gradient(0deg, rgba(9, 11, 17, .48), transparent 50%);
}

.beauty-cover__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.beauty-cover__content {
    grid-column: 1 / -1;
    grid-row: 1;
    z-index: 2;
    align-self: center;
}

.beauty-cover__content > * {
    max-width: 650px;
}

.beauty-cover__content > p {
    margin-top: 24px;
    font-size: 17px;
}

.beauty-story {
    padding: 120px 0;
}

.beauty-story__grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 100px;
}

.beauty-story__title span,
.beauty-steps-v2__head span,
.tourism-choice__title span,
.tourism-answers__aside span,
.dealer-intents__head > span,
.dealer-routing__title > span {
    color: var(--page-accent, #5aa7ff);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.beauty-story__title h2 {
    margin-top: 18px;
}

.beauty-story__text {
    padding-top: 28px;
}

.beauty-story__text p {
    margin: 0;
    font-size: 17px;
}

.beauty-story__text p + p {
    margin-top: 18px;
}

.beauty-services-v2 {
    padding: 115px 0;
    background:
        linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px),
        #10141c;
    background-size: 40px 40px;
}

.beauty-services-v2__layout {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 24px;
}

.beauty-services-v2 article {
    padding: 36px;
    border: 1px solid rgba(255,255,255,.09);
    background: linear-gradient(145deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
}

.beauty-services-v2 article > span {
    color: var(--page-accent);
    font-size: 12px;
    font-weight: 900;
}

.beauty-services-v2__main {
    min-height: 540px;
    display: flex;
    flex-direction: column;
}

.beauty-services-v2__main h2 {
    margin: auto 0 24px;
}

.beauty-services-v2__main p {
    max-width: 720px;
}

.beauty-services-v2__side {
    display: grid;
    gap: 24px;
}

.beauty-services-v2__side h3 {
    margin: 14px 0 14px;
    font-size: 26px;
}

.beauty-steps-v2 {
    padding: 115px 0;
}

.beauty-steps-v2__head {
    max-width: 760px;
    margin-bottom: 55px;
}

.beauty-steps-v2__head h2 {
    margin-top: 18px;
}

.beauty-steps-v2__row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 1px solid rgba(255,255,255,.14);
    border-left: 1px solid rgba(255,255,255,.14);
}

.beauty-steps-v2__row article {
    min-height: 270px;
    padding: 28px;
    border-right: 1px solid rgba(255,255,255,.14);
    border-bottom: 1px solid rgba(255,255,255,.14);
}

.beauty-steps-v2__row b {
    color: var(--page-accent);
}

.beauty-steps-v2__row h3 {
    margin: 70px 0 12px;
    font-size: 22px;
}

.beauty-return {
    padding: 120px 0;
    background: radial-gradient(circle at 80% 35%, rgba(237,131,186,.13), transparent 30%), #11151e;
}

.beauty-return__grid {
    display: grid;
    grid-template-columns: .85fr 1.15fr;
    gap: 100px;
}

.beauty-return h2 {
    margin-top: 18px;
}

.beauty-return p {
    margin-top: 0;
    font-size: 17px;
}

.beauty-return ul {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 24px;
    margin: 30px 0 0;
    padding: 0;
    list-style: none;
}

.beauty-return li {
    padding: 14px 0;
    border-top: 1px solid rgba(255,255,255,.12);
    color: #d9dfeb;
}

/* STO */
.sto-page {
    --page-accent: #f3c74b;
    background:
        repeating-linear-gradient(135deg, rgba(255,255,255,.014) 0 1px, transparent 1px 18px),
        #0b0f15;
}

.sto-page .niche-primary-btn { background: var(--page-accent); }

.sto-cover-v2 {
    height: 100svh;
    min-height: 650px;
    max-height: 940px;
    padding: 110px 0 45px;
}

.sto-cover-v2__grid {
    display: grid;
    grid-template-columns: 1.12fr .88fr;
    gap: 70px;
    align-items: center;
    height: 100%;
}

.sto-cover-v2__image {
    height: min(70vh, 650px);
    overflow: hidden;
    border: 1px solid rgba(243,199,75,.25);
    box-shadow: 0 32px 80px rgba(0,0,0,.42);
}

.sto-cover-v2__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sto-cover-v2__content > p {
    margin: 24px 0 0;
    font-size: 17px;
}

.sto-diagnostic-v2 {
    padding: 120px 0;
    background: #11161d;
}

.sto-diagnostic-v2__head {
    display: grid;
    grid-template-columns:  1fr .65fr;
    gap: 40px;
    align-items: start;
    margin-bottom: 60px;
}

.sto-diagnostic-v2__head > span,
.sto-process-v2__head > span {
    color: var(--page-accent);
    font-family: monospace;
    font-size: 12px;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.sto-diagnostic-v2__head > p {
    margin: 8px 0 0;
}

.sto-diagnostic-v2__list {
    border-top: 2px solid var(--page-accent);
}

.sto-diagnostic-v2__list article {
    display: grid;
    grid-template-columns: .45fr 1.55fr;
    gap: 45px;
    padding: 28px 0;
    border-bottom: 1px solid rgba(255,255,255,.12);
}

.sto-diagnostic-v2__list b {
    color: #f4f6fa;
    font-size: 21px;
}

.sto-diagnostic-v2__list p {
    margin: 0;
}

.sto-directions-v2 {
    padding: 120px 0;
}

.sto-directions-v2__grid {
    display: grid;
    grid-template-columns: 1fr 0.75fr;
    gap: 80px;
}

.sto-directions-v2__title {
    position: sticky;
    top: 120px;
    align-self: start;
}

.sto-directions-v2__title h2 {
    margin: 20px 0 24px;
}

.sto-directions-v2__items {
    border-top: 1px solid rgba(255,255,255,.13);
}

.sto-directions-v2__items article {
    padding: 34px 0;
    border-bottom: 1px solid rgba(255,255,255,.13);
}

.sto-directions-v2__items span {
    color: var(--page-accent);
    font-family: monospace;
}

.sto-directions-v2__items h3 {
    margin: 16px 0 12px;
    font-size: 26px;
    text-transform: uppercase;
}

.sto-directions-v2__items p {
    max-width: 720px;
    margin: 0;
}

.sto-process-v2 {
    padding: 115px 0;
    background: #f3c74b;
}

.sto-process-v2 h2,
.sto-process-v2 h3,
.sto-process-v2 p,
.sto-process-v2__head > span {
    color: #10151b;
}

.sto-process-v2__head {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
    margin-bottom: 50px;
}

.sto-process-v2__timeline {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 2px solid #10151b;
    border-left: 1px solid rgba(16,21,27,.35);
}

.sto-process-v2__timeline article {
    min-height: 220px;
    padding: 26px;
    border-right: 1px solid rgba(16,21,27,.35);
    border-bottom: 1px solid rgba(16,21,27,.35);
}
.sto-process-v2__timeline article b{
    color: black;
}
.sto-process-v2__timeline h3 {
    margin: 12px 0 12px;
    font-size: 22px;
}

.sto-team-v2 {
    padding: 120px 0;
}

.sto-team-v2__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
}
.sto-team-v2__layout.low{
    grid-template-columns: 1fr 1fr;
    margin-top: 24px;
}
.sto-team-v2 h2 {
    margin-top: 18px;
}

.sto-team-v2 p {
    margin-top: 0;
}

.sto-team-v2 aside {
    padding: 26px;
    border-top: 2px solid var(--page-accent);
    background: rgba(255,255,255,.045);
}

.sto-team-v2 aside strong {
    color: var(--page-accent);
    text-transform: uppercase;
}

/* Realtors */
.realtor-page {
    --page-accent: #57b6ff;
    background: radial-gradient(circle at 12% 8%, rgba(87,182,255,.12), transparent 28%), #0b0f16;
}

.realtor-page .niche-primary-btn { background: var(--page-accent); }

.realtor-cover-v2 {
    height: 100svh;
    min-height: 650px;
    max-height: 940px;
    padding-top: 88px;
    overflow: hidden;
}

.realtor-cover-v2__image {
    position: absolute;
    inset: 0;
}

.realtor-cover-v2__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(8,12,18,.94), rgba(8,12,18,.58) 52%, rgba(8,12,18,.18)), linear-gradient(0deg, rgba(8,12,18,.65), transparent 48%);
}

.realtor-cover-v2__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.realtor-cover-v2__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}

.realtor-cover-v2__content > * {
    max-width: 720px;
}

.realtor-cover-v2__content > p {
    margin-top: 24px;
    font-size: 18px;
}

.realtor-roles {
    padding: 120px 0;
}

.realtor-roles__head {
    /*max-width: 950px;*/
    margin-bottom: 55px;
}

.realtor-roles__head > span,
.realtor-usecases__intro > span {
    color: var(--page-accent);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.realtor-roles__head h2,
.realtor-usecases__intro h2 {
    margin-top: 18px;
}

.realtor-roles__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-top: 1px solid rgba(255,255,255,.12);
    border-left: 1px solid rgba(255,255,255,.12);
}

.realtor-roles__grid article {
    min-height: 230px;
    padding: 34px;
    border-right: 1px solid rgba(255, 255, 255, .12);
    border-bottom: 1px solid rgba(255, 255, 255, .12);
}

.realtor-roles__grid b {
    color: var(--page-accent);
}

.realtor-roles__grid h3 {
    margin: 14px 0 14px;
    font-size: 27px;
}

.realtor-qualification {
    padding: 120px 0;
    background: #111720;
}

.realtor-qualification__layout {
    display: grid;
    grid-template-columns: .8fr 1.2fr;
    gap: 100px;
}

.realtor-qualification__title {
    position: sticky;
    top: 120px;
    align-self: start;
}

.realtor-qualification__title h2 {
    margin: 20px 0 24px;
}

.realtor-qualification__text {
    padding-top: 6px;
}

.realtor-qualification__text h3 {
    margin: 0 0 14px;
    font-size: 25px;
}

.realtor-qualification__text p {
    margin: 0 0 38px;
    font-size: 17px;
}

.realtor-usecases {
    padding: 115px 0;
}

.realtor-usecases__grid {
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 22px;
}

.realtor-usecases__intro {
    grid-row: span 3;
    padding: 18px 70px 18px 0;
}

.realtor-usecases article {
    padding: 30px;
    border-left: 2px solid var(--page-accent);
    background: rgba(255,255,255,.04);
}

.realtor-usecases article h3 {
    margin: 0 0 12px;
    font-size: 24px;
}

.realtor-usecases article p {
    margin: 0;
}

.realtor-forwhom {
    padding: 120px 0;
    background: radial-gradient(circle at 80% 30%, rgba(87,182,255,.12), transparent 30%), #10151e;
}

.realtor-forwhom__grid {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 100px;
}

.realtor-forwhom h2 {
    margin-top: 18px;
}

.realtor-forwhom p {
    margin-top: 0;
    font-size: 17px;
}

/* Tourism */
.tourism-page {
    --page-accent: #48d5c0;
    background: radial-gradient(circle at 80% 8%, rgba(72,213,192,.1), transparent 28%), #0b0f16;
}

.tourism-page .niche-primary-btn { background: var(--page-accent); }

.tourism-cover-v2 {
    height: 100svh;
    min-height: 650px;
    max-height: 940px;
    padding-top: 88px;
    overflow: hidden;
}

.tourism-cover-v2::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(7,17,18,.9), rgba(7,17,18,.28) 65%), linear-gradient(0deg, rgba(7,17,18,.62), transparent 48%);
}

.tourism-cover-v2 > img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tourism-cover-v2__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}

.tourism-cover-v2__content > * {
    max-width: 790px;
}

.tourism-cover-v2__content > p {
    margin-top: 24px;
    font-size: 18px;
}

.tourism-choice {
    padding: 120px 0;
}

.tourism-choice__grid {
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 100px;
}

.tourism-choice__title h2 {
    margin-top: 18px;
}

.tourism-choice__copy {
    padding-top: 30px;
}

.tourism-choice__copy p {
    margin: 0;
    font-size: 17px;
}

.tourism-choice__copy p + p {
    margin-top: 18px;
}

.tourism-formats-v2 {
    padding: 115px 0;
    background: #10161d;
}

.tourism-formats-v2__head {
    max-width: 900px;
    margin-bottom: 55px;
}

.tourism-formats-v2__head h2 {
    margin-top: 18px;
}

.tourism-formats-v2__list {
    border-top: 1px solid rgba(255,255,255,.13);
}

.tourism-formats-v2__list article {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 30px;
    padding: 32px 0;
    border-bottom: 1px solid rgba(255,255,255,.13);
}

.tourism-formats-v2__list b {
    color: var(--page-accent);
    font-size: 25px;
}

.tourism-formats-v2__list h3 {
    margin: 0 0 12px;
    font-size: 25px;
}

.tourism-formats-v2__list p {
    max-width: 860px;
    margin: 0;
}

.tourism-answers {
    padding: 120px 0;
}

.tourism-answers__layout {
    display: grid;
    grid-template-columns: .55fr 1.45fr;
    gap: 80px;
}

.tourism-answers__aside {
    align-self: start;
    padding: 28px;
    border-top: 2px solid var(--page-accent);
    background: rgba(255,255,255,.045);
}

.tourism-answers__aside strong {
    display: block;
    margin-top: 16px;
    color: #fff;
    font-size: 24px;
    line-height: 1.35;
}

.tourism-answers__content h2 {
    margin-bottom: 26px;
}

.tourism-answers__content > p {
    font-size: 17px;
}

.tourism-answers__content > div {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin-top: 28px;
}

.tourism-answers__content > div span {
    padding: 10px 14px;
    border: 1px solid rgba(255,255,255,.13);
    color: #dbe4ef;
    font-size: 12px;
}

.tourism-request {
    padding: 115px 0;
    background: radial-gradient(circle at 15% 25%, rgba(72,213,192,.12), transparent 30%), #111720;
}

.tourism-request__grid {
    display: grid;
    grid-template-columns: .8fr 1.2fr;
    gap: 90px;
}

.tourism-request h2 {
    margin-top: 18px;
}

.tourism-request__steps {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-top: 1px solid rgba(255,255,255,.13);
    border-left: 1px solid rgba(255,255,255,.13);
}

.tourism-request__steps article {
    min-height: 130px;
    padding: 25px;
    border-right: 1px solid rgba(255,255,255,.13);
    border-bottom: 1px solid rgba(255,255,255,.13);
}

.tourism-request__steps span {
    color: var(--page-accent);
    font-weight: 800;
}

.tourism-business {
    padding: 120px 0;
}

.tourism-business__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 90px;
}

.tourism-business p {
    margin-top: 0;
    font-size: 17px;
}

/* Dealers */
.dealer-page {
    --page-accent: #8793ff;
    background: radial-gradient(circle at 12% 8%, rgba(135,147,255,.12), transparent 28%), #090d14;
}

.dealer-page .niche-primary-btn { background: var(--page-accent); color: #fff; }

.dealer-cover-v2 {
    height: 100svh;
    min-height: 650px;
    max-height: 940px;
    padding-top: 88px;
    overflow: hidden;
}

.dealer-cover-v2__image {
    position: absolute;
    inset: 0 0 0 38%;
}

.dealer-cover-v2__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, #090d14, rgba(9,13,20,.35) 42%, transparent), linear-gradient(0deg, rgba(9,13,20,.55), transparent 48%);
}

.dealer-cover-v2__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dealer-cover-v2__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}

.dealer-cover-v2__content > * {
    max-width: 670px;
}

.dealer-cover-v2__content > p {
    margin-top: 24px;
    font-size: 17px;
}

.dealer-intents {
    padding: 120px 0;
}

.dealer-intents__head {
    display: grid;
    grid-template-columns: .25fr 1fr .65fr;
    gap: 40px;
    align-items: start;
    margin-bottom: 55px;
}

.dealer-intents__head > p {
    margin: 8px 0 0;
}

.dealer-intents__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 1px solid rgba(255,255,255,.12);
    border-left: 1px solid rgba(255,255,255,.12);
}

.dealer-intents__grid article {
    min-height: 220px;
    padding: 28px;
    border-right: 1px solid rgba(255,255,255,.12);
    border-bottom: 1px solid rgba(255,255,255,.12);
}

.dealer-intents__grid b {
    color: var(--page-accent);
}

.dealer-intents__grid h3 {
    margin: 14px 0 14px;
    font-size: 23px;
    text-transform: uppercase;
}

.dealer-credit {
    padding: 120px 0;
    background: #111620;
}

.dealer-credit__layout {
    display: grid;
    grid-template-columns: 1fr .85fr;
    gap: 90px;
}

.dealer-credit__copy h2 {
    margin: 18px 0 26px;
}

.dealer-credit__copy p {
    font-size: 17px;
}

.dealer-credit__points {
    border-top: 1px solid rgba(255,255,255,.13);
}

.dealer-credit__points div {
    padding: 26px 0;
    border-bottom: 1px solid rgba(255,255,255,.13);
}

.dealer-credit__points strong {
    color: var(--page-accent);
    text-transform: uppercase;
}

.dealer-credit__points p {
    margin: 8px 0 0;
}

.dealer-routing {
    padding: 115px 0;
}

.dealer-routing__grid {
    display: grid;
    grid-template-columns: .75fr 1.25fr;
    gap: 80px;
    align-items: center;
}

.dealer-routing__title h2 {
    margin-top: 18px;
}

.dealer-routing__flow {
    display: grid;
    grid-template-columns: 1fr 50px 1fr 50px 1fr;
    align-items: center;
}

.dealer-routing__flow article {
    min-height: 220px;
    padding: 26px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.035);
}

.dealer-routing__flow article span {
    color: var(--page-accent);
    font-weight: 900;
    text-transform: uppercase;
}

.dealer-routing__flow article p {
    margin-top: 20px;
}

.dealer-routing__flow i {
    height: 1px;
    background: var(--page-accent);
}

.dealer-benefits {
    padding: 120px 0;
    background: radial-gradient(circle at 82% 28%, rgba(135,147,255,.13), transparent 28%), #111620;
}

.dealer-benefits__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
}
.dealer-benefits__layout .low-row{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
}

.dealer-benefits h2 {
    margin-top: 18px;
}

.dealer-benefits__text p {
    margin-top: 0;
}

.dealer-benefits aside {
    padding: 26px;
    border: 1px solid rgba(255,255,255,.1);
    border-top: 2px solid var(--page-accent);
    background: rgba(255,255,255,.035);
}

.dealer-benefits aside strong {
    color: var(--page-accent);
    text-transform: uppercase;
}

.dealer-benefits aside ul {
    margin: 22px 0 0;
    padding: 0;
    list-style: none;
}

.dealer-benefits aside li {
    padding: 10px 0;
    border-top: 1px solid rgba(255,255,255,.1);
    color: #d5ddea;
}

/* Hero composition fix: one canvas instead of two disconnected columns */
.beauty-cover,
.dealer-cover-v2 {
    display: block;
    height: calc(100svh - 68px);
    min-height: 620px;
    max-height: 880px;
    padding-top: 0;
    isolation: isolate;
}

.beauty-cover__image,
.dealer-cover-v2__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.beauty-cover__image::after,
.dealer-cover-v2__image::after {
    content: "";
    position: absolute;
    inset: 0;
}

.beauty-cover__image::after {
    background:
        linear-gradient(90deg, rgba(10, 13, 20, 0.98) 0%, rgba(10, 13, 20, 0.9) 30%, rgba(10, 13, 20, 0.48) 55%, rgba(10, 13, 20, 0.08) 82%),
        linear-gradient(0deg, rgba(10, 13, 20, 0.46), transparent 48%);
}

.dealer-cover-v2__image::after {
    background:
        linear-gradient(90deg, rgba(8, 12, 19, 0.98) 0%, rgba(8, 12, 19, 0.91) 31%, rgba(8, 12, 19, 0.5) 57%, rgba(8, 12, 19, 0.08) 84%),
        linear-gradient(0deg, rgba(8, 12, 19, 0.52), transparent 50%);
}

.beauty-cover__image img,
.dealer-cover-v2__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.beauty-cover__image img {
    object-position: 66% center;
}

.dealer-cover-v2__image img {
    object-position: 65% center;
}

.beauty-cover__content,
.dealer-cover-v2__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding-top: 0;
    padding-bottom: 0;
}

.beauty-cover__content > *,
.dealer-cover-v2__content > * {
    max-width: 610px;
}

.beauty-cover__content h1,
.dealer-cover-v2__content h1 {
    max-width: 640px;
    font-size: clamp(38px, 3.65vw, 58px);
    line-height: 1.02;
}

.beauty-cover__content > p,
.dealer-cover-v2__content > p {
    max-width: 600px;
    margin-top: 22px;
    font-size: 16px;
    line-height: 1.7;
}

.sto-cover-v2,
.realtor-cover-v2,
.tourism-cover-v2 {
    height: calc(100svh - 68px);
    min-height: 620px;
    max-height: 880px;
}

.realtor-cover-v2__content,
.tourism-cover-v2__content {
    height: 100%;
}

@media (max-width: 1050px) {
    .beauty-story__grid,
    .beauty-return__grid,
    .sto-directions-v2__grid,
    .sto-team-v2__layout,
    .realtor-qualification__layout,
    .realtor-forwhom__grid,
    .tourism-choice__grid,
    .tourism-answers__layout,
    .tourism-request__grid,
    .dealer-credit__layout,
    .dealer-routing__grid,
    .dealer-benefits__layout {
        grid-template-columns: 1fr;
        gap: 45px;
    }

    .sto-directions-v2__title,
    .realtor-qualification__title {
        position: static;
    }

    .dealer-intents__grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 820px) {
    .beauty-cover,
    .sto-cover-v2,
    .realtor-cover-v2,
    .tourism-cover-v2,
    .dealer-cover-v2 {
        height: calc(100svh - 72px);
        min-height: 600px;
        max-height: none;
    }

    .beauty-cover__image,
    .dealer-cover-v2__image {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        min-height: 0;
    }

    .beauty-cover__content,
    .dealer-cover-v2__content {
        display: flex;
        height: 100%;
        padding-top: 28px;
        padding-bottom: 28px;
    }

    .beauty-cover__image::after,
    .dealer-cover-v2__image::after {
        background:
            linear-gradient(0deg, rgba(9, 12, 18, 0.98) 0%, rgba(9, 12, 18, 0.86) 54%, rgba(9, 12, 18, 0.28) 100%),
            linear-gradient(90deg, rgba(9, 12, 18, 0.62), transparent);
    }

    .beauty-cover__image img {
        object-position: 63% center;
    }

    .dealer-cover-v2__image img {
        object-position: 68% center;
    }

    .sto-cover-v2 {
        padding-top: 105px;
    }

    .sto-cover-v2__grid {
        grid-template-columns: 1fr;
        height: auto;
    }

    .sto-cover-v2__image {
        order: 2;
        height: 390px;
    }

    .realtor-cover-v2__content,
    .tourism-cover-v2__content {
        min-height: calc(100svh - 88px);
    }

    .beauty-story,
    .beauty-services-v2,
    .beauty-steps-v2,
    .beauty-return,
    .sto-diagnostic-v2,
    .sto-directions-v2,
    .sto-process-v2,
    .sto-team-v2,
    .realtor-roles,
    .realtor-qualification,
    .realtor-usecases,
    .realtor-forwhom,
    .tourism-choice,
    .tourism-formats-v2,
    .tourism-answers,
    .tourism-request,
    .tourism-business,
    .dealer-intents,
    .dealer-credit,
    .dealer-routing,
    .dealer-benefits {
        padding: 78px 0;
    }

    .beauty-services-v2__layout,
    .realtor-usecases__grid,
    .tourism-business__grid {
        grid-template-columns: 1fr;
    }

    .beauty-services-v2__main {
        min-height: 420px;
    }

    .beauty-steps-v2__row,
    .sto-process-v2__timeline {
        grid-template-columns: 1fr 1fr;
    }

    .sto-diagnostic-v2__head,
    .sto-process-v2__head,
    .dealer-intents__head {
        grid-template-columns: 1fr;
    }

    .realtor-usecases__intro {
        grid-row: auto;
        padding-right: 0;
    }

    .tourism-request__steps {
        grid-template-columns: 1fr;
    }

    .dealer-routing__flow {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .dealer-routing__flow i {
        width: 1px;
        height: 28px;
        margin-left: 30px;
    }
}

@media (max-width: 560px) {
    .niche-page h1 {
        font-size: 36px;
    }

    .niche-page h2 {
        font-size: 31px;
    }

    .beauty-services-v2 article,
    .tourism-answers__aside,
    .dealer-benefits aside {
        padding: 23px;
    }

    .beauty-steps-v2__row,
    .sto-process-v2__timeline,
    .realtor-roles__grid,
    .dealer-intents__grid {
        grid-template-columns: 1fr;
    }

    .beauty-return ul {
        grid-template-columns: 1fr;
    }

    .sto-diagnostic-v2__list article,
    .tourism-formats-v2__list article {
        grid-template-columns: 58px 1fr;
        gap: 16px;
    }

    .sto-diagnostic-v2__list article p {
        grid-column: 2;
    }

    .sto-process-v2__timeline article {
        min-height: 220px;
    }

    .sto-process-v2__timeline h3 {
        margin-top: 45px;
    }
}

@media (max-width: 820px) {
    .realtor-hero,
    .tourism-hero,
    .dealer-hero,
    .sto-hero,
    .beauty-hero {
        padding-top: 96px !important;
    }

    .realtor-map,
    .tourism-visual,
    .dealer-visual,
    .sto-visual,
    .beauty-visual {
        min-height: 460px;
    }

    .tourism-visual {
        margin-top: 38px;
        border-radius: 48px 12px;
    }

    .beauty-visual {
        border-radius: 100px 18px;
    }

    .dealer-panel {
        right: 18px;
        bottom: 18px;
    }
}

@media (max-width: 560px) {
    .niche-hero-actions {
        align-items: stretch;
    }

    .niche-primary-btn {
        width: 100%;
    }

    .realtor-map,
    .tourism-visual,
    .dealer-visual,
    .sto-visual,
    .beauty-visual {
        min-height: 390px;
    }

    .realtor-map {
        border-radius: 4px 48px 4px 4px;
    }

    .realtor-map__card,
    .tourism-ticket,
    .beauty-booking {
        left: 16px;
        right: 16px;
        bottom: 16px;
        width: auto;
        padding: 18px;
    }

    .tourism-route-badge {
        top: 14px;
        right: 14px;
        min-width: 165px;
        padding: 13px;
    }

    .dealer-panel {
        left: 14px;
        right: 14px;
        bottom: 14px;
        width: auto;
        padding: 8px 14px;
    }

    .dealer-panel__top,
    .dealer-panel__row {
        padding: 11px 4px;
        font-size: 12px;
    }

    .sto-diagnostic {
        left: 14px;
        right: 14px;
        bottom: 14px;
        padding: 16px;
    }

    .beauty-metrics {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   Niche layouts v2: five independent page architectures
   ========================================================= */

.beauty-niche section,
.sto-niche section,
.realtor-niche section,
.tourism-niche section,
.dealer-niche section {
    box-sizing: border-box;
}

.beauty-niche h2,
.sto-niche h2,
.realtor-niche h2,
.tourism-niche h2,
.dealer-niche h2 {
    margin: 0;
    color: #f7f9fd;
    font-size: clamp(32px, 4.2vw, 62px);
    line-height: 1.04;
}

/* BEAUTY: editorial magazine */
.beauty-niche {
    background: #f2e9ed;
    color: #351f2c;
}

.beauty-hero {
    min-height: 900px;
    padding: 0;
    background: #291522;
}

.beauty-hero__photo {
    position: absolute;
    inset: 0 0 0 44%;
    overflow: hidden;
}

.beauty-hero__photo::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, #291522 0%, transparent 32%), linear-gradient(0deg, rgba(41, 21, 34, 0.5), transparent 45%);
}

.beauty-hero__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.beauty-hero__layout {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 0.86fr) minmax(420px, 1.14fr);
    grid-template-rows: auto 1fr auto;
    min-height: 900px;
    padding-top: 130px;
    padding-bottom: 54px;
}

.beauty-hero__issue {
    grid-column: 1 / -1;
    display: flex;
    justify-content: space-between;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.25);
    color: #e9cfda;
    font-family: Georgia, serif;
    font-size: 13px;
    font-style: italic;
    letter-spacing: 0.08em;
}

.beauty-hero__content {
    align-self: center;
    max-width: 650px;
    padding: 70px 54px 70px 0;
}

.beauty-hero h1 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(48px, 6.1vw, 94px);
    font-weight: 400;
    line-height: 0.98;
    letter-spacing: -0.045em;
}

.beauty-hero__content > p {
    max-width: 570px;
    color: #d6c3cc;
    font-size: 17px;
    line-height: 1.75;
}

.beauty-hero__note {
    grid-column: 2;
    align-self: end;
    justify-self: end;
    width: min(390px, 82%);
    padding: 26px 30px;
    color: #351f2c;
    background: rgba(249, 238, 243, 0.92);
    backdrop-filter: blur(16px);
}

.beauty-hero__note span,
.beauty-kicker {
    display: block;
    color: #a74272;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.beauty-hero__note strong {
    display: block;
    margin: 8px 0;
    font-family: Georgia, serif;
    font-size: 27px;
    font-weight: 400;
}

.beauty-hero__note p {
    margin: 0;
    color: #725264;
    line-height: 1.55;
}

.beauty-ribbon {
    overflow: hidden;
    padding: 24px 0;
    color: #341e2a;
    background: #e7b8ca;
}

.beauty-ribbon__track {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    min-width: max-content;
    padding: 0 28px;
    font-family: Georgia, serif;
    font-size: 20px;
    font-style: italic;
}

.beauty-ribbon__track i {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #a74272;
}

.beauty-editorial {
    padding: 130px 0;
    color: #351f2c;
}

.beauty-editorial__grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr 0.8fr;
    grid-template-rows: auto auto;
    gap: 22px;
}

.beauty-editorial__intro {
    grid-row: span 2;
    padding: 12px 70px 30px 0;
}

.beauty-editorial h2,
.beauty-booking-story h2,
.beauty-result h2 {
    margin: 20px 0 28px;
    color: #351f2c;
    font-family: Georgia, serif;
    font-size: clamp(40px, 5.2vw, 76px);
    font-weight: 400;
    line-height: 1.02;
    letter-spacing: -0.035em;
}

.beauty-editorial__intro p,
.beauty-booking-story__sticky p,
.beauty-result__copy > p {
    color: #765b69;
    font-size: 17px;
    line-height: 1.8;
}

.beauty-feature {
    min-height: 250px;
    padding: 32px;
    color: #f8edf2;
    background: #55283e;
}

.beauty-feature--large {
    grid-column: span 2;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0 30px;
    background: #7e3659;
}

.beauty-feature > span {
    color: #e7b8ca;
    font-family: Georgia, serif;
    font-size: 38px;
}

.beauty-feature h3 {
    margin: 4px 0 16px;
    font-family: Georgia, serif;
    font-size: 32px;
    font-weight: 400;
}

.beauty-feature p {
    margin: 0;
    color: #e5ccd7;
    line-height: 1.7;
}

.beauty-swatches {
    grid-column: 2;
    display: flex;
    gap: 8px;
    align-self: end;
    margin-top: 32px;
}

.beauty-swatches i {
    width: 54px;
    height: 8px;
    background: #f3cbd9;
}

.beauty-swatches i:nth-child(2) { background: #d48aaa; }
.beauty-swatches i:nth-child(3) { background: #9d5275; }
.beauty-swatches i:nth-child(4) { background: #351f2c; }

.beauty-feature--quote {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    color: #351f2c;
    background: #dfc4cf;
}

.beauty-feature--quote blockquote {
    margin: 0;
    font-family: Georgia, serif;
    font-size: 27px;
    font-style: italic;
    line-height: 1.35;
}

.beauty-feature--quote p { color: #765b69; }

.beauty-feature--number {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    background: #351f2c;
}

.beauty-feature--number strong {
    font-family: Georgia, serif;
    font-size: 76px;
    font-weight: 400;
}

.beauty-booking-story {
    padding: 130px 0;
    color: #351f2c;
    background: #ead7df;
}

.beauty-booking-story__layout {
    display: grid;
    grid-template-columns: 0.82fr 1.18fr;
    gap: 100px;
}

.beauty-booking-story__sticky {
    position: sticky;
    top: 120px;
    align-self: start;
}

.beauty-booking-story__steps {
    border-top: 1px solid rgba(53, 31, 44, 0.25);
}

.beauty-booking-story__steps article {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 24px;
    padding: 38px 0;
    border-bottom: 1px solid rgba(53, 31, 44, 0.25);
}

.beauty-booking-story__steps article > span {
    color: #a74272;
    font-family: Georgia, serif;
    font-size: 34px;
}

.beauty-booking-story__steps small {
    color: #a74272;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.beauty-booking-story__steps h3 {
    margin: 8px 0 12px;
    color: #351f2c;
    font-family: Georgia, serif;
    font-size: 31px;
    font-weight: 400;
}

.beauty-booking-story__steps p {
    margin: 0;
    color: #765b69;
    line-height: 1.7;
}

.beauty-result {
    padding: 130px 0;
    color: #351f2c;
}

.beauty-result__grid {
    display: grid;
    grid-template-columns: 0.8fr 1.2fr;
    gap: 110px;
    align-items: center;
}

.beauty-result__card {
    padding: 34px;
    color: #f8edf2;
    background: #351f2c;
    box-shadow: 30px 30px 0 #dfb6c7;
}

.beauty-result__card > span {
    color: #e7b8ca;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.beauty-result__avatar {
    display: grid;
    place-items: center;
    width: 76px;
    height: 76px;
    margin: 44px 0 18px;
    border-radius: 50%;
    color: #351f2c;
    background: #e7b8ca;
    font-family: Georgia, serif;
    font-size: 24px;
}

.beauty-result__card h3 {
    margin: 0 0 28px;
    font-family: Georgia, serif;
    font-size: 34px;
    font-weight: 400;
}

.beauty-result__card dl { margin: 0; }

.beauty-result__card dl div {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 16px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.beauty-result__card dt { color: #bfa9b4; }
.beauty-result__card dd { margin: 0; text-align: right; }

.beauty-result__copy ul {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 30px;
    margin: 30px 0 0;
    padding: 0;
    list-style: none;
    color: #633e52;
}

.beauty-result__copy li::before {
    content: "—";
    margin-right: 10px;
    color: #a74272;
}

/* STO: workshop terminal */
.sto-niche {
    background: #0d1116;
    color: #d9e0e7;
}

.sto-hero {
    padding: 118px 0 72px;
    background: repeating-linear-gradient(90deg, transparent 0 79px, rgba(255,255,255,.025) 80px), #0d1116;
}

.sto-hero__shell {
    border: 1px solid #303840;
    background: #10161c;
}

.sto-hero__topline {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 30px;
    padding: 14px 20px;
    border-bottom: 1px solid #303840;
    color: #7d8a95;
    font-family: monospace;
    font-size: 11px;
    letter-spacing: 0.12em;
}

.sto-hero__topline span:last-child { color: #8ddf72; }

.sto-hero__grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 0;
}

.sto-hero__content {
    padding: 80px 56px;
    border-right: 1px solid #303840;
}

.sto-hero h1 {
    max-width: 680px;
    font-family: Arial, sans-serif;
    font-size: clamp(46px, 5.4vw, 82px);
    font-weight: 900;
    line-height: 0.98;
    letter-spacing: -0.05em;
    text-transform: uppercase;
}

.sto-hero__content > p {
    max-width: 620px;
    color: #9ba8b4;
    font-size: 17px;
    line-height: 1.75;
}

.sto-visual {
    position: relative;
    min-height: 660px;
    clip-path: none;
    border: 0;
}

.sto-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(0.65) contrast(1.08);
}

.sto-visual::after {
    background: linear-gradient(180deg, transparent 38%, rgba(4, 8, 11, 0.9));
}

.sto-scan {
    position: absolute;
    right: 24px;
    bottom: 24px;
    left: 24px;
    z-index: 3;
    padding: 22px;
    border: 1px solid rgba(250, 204, 21, 0.42);
    background: rgba(8, 13, 17, 0.86);
    backdrop-filter: blur(12px);
}

.sto-scan > span {
    color: #facc15;
    font-family: monospace;
    font-size: 11px;
    letter-spacing: 0.14em;
}

.sto-scan > strong {
    display: block;
    margin: 9px 0 18px;
    color: #fff;
    font-size: 24px;
}

.sto-scan > div {
    display: grid;
    grid-template-columns: 10px 1fr auto;
    gap: 10px;
    padding: 9px 0;
    border-top: 1px solid rgba(255,255,255,.1);
    font-family: monospace;
    font-size: 12px;
}

.sto-scan i {
    align-self: center;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #8ddf72;
}

.sto-scan em { color: #b5bec6; font-style: normal; }
.sto-scan b { color: #facc15; }

.sto-hero__metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid #303840;
}

.sto-hero__metrics div {
    display: flex;
    align-items: baseline;
    gap: 14px;
    padding: 22px;
    border-right: 1px solid #303840;
}

.sto-hero__metrics div:last-child { border-right: 0; }
.sto-hero__metrics strong { color: #facc15; font-family: monospace; font-size: 28px; }
.sto-hero__metrics span { color: #7d8a95; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }

.sto-workorder,
.sto-bays,
.sto-pipeline,
.sto-control {
    padding: 120px 0;
}

.sto-section-heading {
    display: grid;
    grid-template-columns: 0.45fr 1.55fr;
    gap: 40px;
    align-items: start;
    margin-bottom: 54px;
}

.sto-section-heading > span,
.sto-bays__title > span,
.sto-control__copy > span {
    color: #facc15;
    font-family: monospace;
    font-size: 12px;
    letter-spacing: .12em;
}

.sto-niche h2 {
    font-family: Arial, sans-serif;
    font-size: clamp(36px, 4.8vw, 68px);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.045em;
    text-transform: uppercase;
}

.sto-workorder { background: #151b21; }

.sto-workorder__table {
    border-top: 2px solid #facc15;
    font-family: monospace;
}

.sto-workorder__table > div {
    display: grid;
    grid-template-columns: 0.55fr 1.45fr 150px;
    gap: 20px;
    padding: 20px;
    border-right: 1px solid #343d45;
    border-bottom: 1px solid #343d45;
    border-left: 1px solid #343d45;
}

.sto-workorder__head {
    color: #77838e;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .1em;
}

.sto-workorder__table > div:not(.sto-workorder__head) > span { color: #7f8b95; }
.sto-workorder__table strong { color: #e4e9ed; font-weight: 400; }
.sto-workorder__table b { color: #8ddf72; text-align: right; }

.sto-bays__layout {
    display: grid;
    grid-template-columns: 0.7fr 1.3fr;
    gap: 80px;
}

.sto-bays__title {
    position: sticky;
    top: 120px;
    align-self: start;
}

.sto-bays__title h2 { margin-top: 22px; }

.sto-bays__list {
    border-top: 1px solid #3a4249;
}

.sto-bays__list article {
    display: grid;
    grid-template-columns: 70px 1fr 190px;
    gap: 24px;
    align-items: center;
    padding: 30px 0;
    border-bottom: 1px solid #3a4249;
}

.sto-bays__list article > span {
    color: #facc15;
    font-family: monospace;
    font-size: 34px;
}

.sto-bays__list h3 { margin: 0 0 8px; color: #fff; font-size: 23px; text-transform: uppercase; }
.sto-bays__list p { margin: 0; color: #8996a1; line-height: 1.6; }
.sto-bays__list article > strong { color: #71808c; font-family: monospace; font-size: 11px; text-align: right; letter-spacing: .08em; }

.sto-pipeline { background: #facc15; }
.sto-pipeline .sto-section-heading > span,
.sto-pipeline h2 { color: #11161b; }

.sto-pipeline__rail {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 2px solid #11161b;
    border-left: 1px solid rgba(17,22,27,.35);
}

.sto-pipeline__rail article {
    min-height: 260px;
    padding: 26px;
    border-right: 1px solid rgba(17,22,27,.35);
    border-bottom: 1px solid rgba(17,22,27,.35);
    color: #11161b;
}

.sto-pipeline__rail b { display: block; font-family: monospace; font-size: 13px; }
.sto-pipeline__rail span { display: block; margin: 80px 0 12px; font-size: 23px; font-weight: 900; text-transform: uppercase; }
.sto-pipeline__rail p { margin: 0; line-height: 1.55; }

.sto-control__grid {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 80px;
    align-items: center;
}

.sto-control__screen {
    border: 1px solid #37414a;
    background: #151b21;
    box-shadow: 18px 18px 0 #222a31;
}

.sto-control__screen > div {
    display: flex;
    justify-content: space-between;
    padding: 22px;
    border-bottom: 1px solid #37414a;
    font-family: monospace;
}

.sto-control__screen > div span { color: #7f8b95; }
.sto-control__screen > div strong { color: #facc15; }
.sto-control__screen ul { margin: 0; padding: 0; list-style: none; }

.sto-control__screen li {
    display: grid;
    grid-template-columns: 10px 1fr auto;
    gap: 14px;
    padding: 20px 22px;
    border-bottom: 1px solid #303840;
}

.sto-control__screen li i {
    align-self: center;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #8ddf72;
}

.sto-control__screen li span { color: #e3e8ec; }
.sto-control__screen li b { color: #7f8b95; font-family: monospace; font-size: 11px; text-transform: uppercase; }
.sto-control__copy h2 { margin: 20px 0 26px; }
.sto-control__copy p { color: #929faa; line-height: 1.75; }
.sto-control__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 28px; }
.sto-control__tags span { padding: 10px 14px; border: 1px solid #3b454e; color: #c3cbd2; font-family: monospace; font-size: 11px; }

/* REALTORS: property portal */
.realtor-niche {
    background: #f0eee8;
    color: #1e2b38;
}

.realtor-hero {
    min-height: 880px;
    padding: 0;
    background: #122232;
}

.realtor-hero__image {
    position: absolute;
    inset: 0 0 0 42%;
}

.realtor-hero__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, #122232 0%, rgba(18,34,50,.74) 24%, transparent 58%), linear-gradient(0deg, rgba(9,18,28,.52), transparent 48%);
}

.realtor-hero__image img { width: 100%; height: 100%; object-fit: cover; }

.realtor-hero__layout {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, .82fr) minmax(420px, 1.18fr);
    min-height: 880px;
    padding-top: 130px;
    padding-bottom: 62px;
}

.realtor-hero__content {
    align-self: center;
    padding-right: 58px;
}

.realtor-hero h1 {
    font-size: clamp(48px, 5.6vw, 86px);
    line-height: .98;
    letter-spacing: -.05em;
}

.realtor-hero__content > p { color: #b9c8d6; font-size: 17px; line-height: 1.75; }

.realtor-search-card {
    align-self: end;
    justify-self: end;
    width: min(440px, 88%);
    padding: 28px;
    color: #1e2b38;
    background: #f5f3ee;
    box-shadow: 0 28px 70px rgba(0,0,0,.32);
}

.realtor-search-card > span {
    display: block;
    margin-bottom: 24px;
    color: #3a80b7;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.realtor-search-card > div {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 16px 0;
    border-top: 1px solid #d9d5cc;
}

.realtor-search-card small { color: #7b858e; }
.realtor-search-card strong { text-align: right; }
.realtor-search-card button,
.realtor-lead__card button {
    width: 100%;
    margin-top: 12px;
    padding: 16px;
    border: 0;
    color: #fff;
    background: #277dbb;
    font-weight: 800;
}

.realtor-market,
.realtor-paths,
.realtor-showing,
.realtor-lead {
    padding: 125px 0;
}

.realtor-market__heading {
    display: grid;
    grid-template-columns: 1.25fr .75fr;
    gap: 70px;
    align-items: end;
    margin-bottom: 52px;
}

.realtor-market__heading span,
.realtor-showing__copy > span,
.realtor-lead__copy > span {
    color: #277dbb;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.realtor-niche h2 {
    margin-top: 18px;
    color: #182632;
    letter-spacing: -.045em;
}

.realtor-market__heading p,
.realtor-showing__copy > p,
.realtor-lead__copy > p {
    margin: 0;
    color: #66727c;
    font-size: 17px;
    line-height: 1.75;
}

.realtor-market__grid {
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 22px;
}

.realtor-property {
    display: grid;
    grid-template-columns: .85fr 1.15fr;
    min-height: 260px;
    border: 1px solid #d7d4cc;
    background: #f8f7f3;
}

.realtor-property--featured {
    grid-row: span 2;
    grid-template-columns: 1fr;
}

.realtor-property__visual {
    position: relative;
    min-height: 230px;
    padding: 22px;
    overflow: hidden;
    color: #d8edfc;
    background: linear-gradient(145deg, #1b425f, #7aa4be);
}

.realtor-property__visual::before {
    content: "";
    position: absolute;
    inset: 22% 12% 0;
    border: 1px solid rgba(255,255,255,.35);
    border-bottom: 0;
    background: linear-gradient(90deg, transparent 32%, rgba(255,255,255,.18) 33% 34%, transparent 35% 65%, rgba(255,255,255,.18) 66% 67%, transparent 68%);
}

.realtor-property__visual span { position: relative; z-index: 1; font-size: 11px; text-transform: uppercase; letter-spacing: .1em; }
.realtor-property__visual > strong { position: absolute; right: 20px; bottom: 10px; color: rgba(255,255,255,.25); font-size: 84px; }
.realtor-property > div:last-child { padding: 28px; }
.realtor-property small { color: #74818b; text-transform: uppercase; letter-spacing: .08em; }
.realtor-property h3 { margin: 12px 0; color: #1c2d3a; font-size: 25px; }
.realtor-property p { color: #77818a; line-height: 1.55; }
.realtor-property > div:last-child > strong { color: #277dbb; font-size: 22px; }

.realtor-paths { color: #fff; background: #142535; }

.realtor-paths__layout {
    display: grid;
    grid-template-columns: .7fr 1.3fr;
    gap: 80px;
}

.realtor-paths__heading h2 { margin: 20px 0 28px; color: #fff; }
.realtor-paths__heading p { color: #9eafbe; line-height: 1.75; }

.realtor-paths__cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-top: 1px solid rgba(255,255,255,.15);
    border-left: 1px solid rgba(255,255,255,.15);
}

.realtor-paths__cards article {
    min-height: 280px;
    padding: 30px;
    border-right: 1px solid rgba(255,255,255,.15);
    border-bottom: 1px solid rgba(255,255,255,.15);
}

.realtor-paths__cards article > span { color: #62b7ef; font-size: 13px; }
.realtor-paths__cards h3 { margin: 50px 0 12px; font-size: 29px; }
.realtor-paths__cards p { color: #9eafbe; line-height: 1.65; }
.realtor-paths__cards b { display: block; margin-top: 28px; color: #62b7ef; font-size: 13px; }

.realtor-showing__grid {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 90px;
    align-items: center;
}

.realtor-showing__calendar {
    display: grid;
    grid-template-columns: 170px 1fr;
    border: 1px solid #cfcbc1;
    background: #f8f7f3;
    box-shadow: 24px 24px 0 #dce8ef;
}

.realtor-showing__calendar > div {
    display: flex;
    flex-direction: column;
    padding: 28px;
    color: #fff;
    background: #277dbb;
}

.realtor-showing__calendar > div span { text-transform: uppercase; letter-spacing: .1em; }
.realtor-showing__calendar > div strong { margin: auto 0 0; font-size: 74px; line-height: 1; }
.realtor-showing__calendar > div small { margin-top: 8px; }
.realtor-showing__calendar ul { margin: 0; padding: 18px 26px; list-style: none; }

.realtor-showing__calendar li {
    display: grid;
    grid-template-columns: 65px 1fr auto;
    gap: 14px;
    padding: 19px 0;
    border-bottom: 1px solid #dedbd3;
}

.realtor-showing__calendar time { color: #277dbb; font-weight: 800; }
.realtor-showing__calendar b { color: #7d8992; font-size: 10px; text-transform: uppercase; }
.realtor-showing__copy h2 { margin: 18px 0 28px; }
.realtor-showing__copy > div { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 28px; }
.realtor-showing__copy > div span { padding: 10px 14px; border: 1px solid #c9c5bc; font-size: 12px; }

.realtor-lead { background: #e1ded6; }

.realtor-lead__layout {
    display: grid;
    grid-template-columns: .85fr 1.15fr;
    gap: 100px;
    align-items: center;
}

.realtor-lead__copy h2 { margin: 18px 0 28px; }

.realtor-lead__card {
    padding: 32px;
    background: #f9f8f4;
    box-shadow: 0 28px 70px rgba(25,41,54,.13);
}

.realtor-lead__person {
    display: flex;
    align-items: center;
    gap: 16px;
    padding-bottom: 24px;
    border-bottom: 1px solid #ddd9d1;
}

.realtor-lead__person > span {
    display: grid;
    place-items: center;
    width: 54px;
    height: 54px;
    border-radius: 50%;
    color: #fff;
    background: #277dbb;
}

.realtor-lead__person strong,
.realtor-lead__person small { display: block; }
.realtor-lead__person small { margin-top: 5px; color: #7a858e; }
.realtor-lead__card dl { display: grid; grid-template-columns: 1fr 1fr; margin: 20px 0; }
.realtor-lead__card dl div { padding: 15px 0; border-bottom: 1px solid #e2dfd8; }
.realtor-lead__card dt { color: #869099; font-size: 12px; }
.realtor-lead__card dd { margin: 6px 0 0; font-weight: 800; }

/* TOURISM: immersive itinerary */
.tourism-niche {
    color: #173329;
    background: #f1efe6;
}

.tourism-hero {
    min-height: 920px;
    padding: 0;
    overflow: hidden;
    background: #17342d;
}

.tourism-hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tourism-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(7,31,27,.9), rgba(7,31,27,.25) 60%, rgba(7,31,27,.08)), linear-gradient(0deg, rgba(7,31,27,.65), transparent 48%);
}

.tourism-hero__layout {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1fr .55fr;
    grid-template-rows: 1fr auto;
    gap: 50px;
    min-height: 920px;
    padding-top: 150px;
    padding-bottom: 52px;
}

.tourism-hero__copy {
    align-self: center;
    max-width: 890px;
}

.tourism-hero h1 {
    max-width: 980px;
    font-size: clamp(52px, 7vw, 108px);
    line-height: .92;
    letter-spacing: -.055em;
}

.tourism-hero__copy > p {
    max-width: 670px;
    color: #d1e2dc;
    font-size: 18px;
    line-height: 1.75;
}

.tourism-hero__passport {
    align-self: end;
    justify-self: end;
    width: min(360px, 100%);
    padding: 26px;
    color: #173329;
    background: #f3e8bd;
    transform: rotate(2deg);
    box-shadow: 0 24px 60px rgba(0,0,0,.28);
}

.tourism-hero__passport > span { color: #b05d36; font-size: 11px; font-weight: 900; letter-spacing: .13em; text-transform: uppercase; }
.tourism-hero__passport > strong { display: block; margin: 12px 0 24px; font-family: Georgia, serif; font-size: 30px; }
.tourism-hero__passport > div { display: flex; justify-content: space-between; padding: 12px 0; border-top: 1px dashed rgba(23,51,41,.35); }
.tourism-hero__passport small { color: #66776f; text-transform: uppercase; }
.tourism-hero__coordinates { grid-column: 1 / -1; color: rgba(255,255,255,.7); font-family: monospace; font-size: 11px; line-height: 1.7; letter-spacing: .13em; }

.tourism-intro,
.tourism-itinerary,
.tourism-tickets,
.tourism-booking { padding: 125px 0; }

.tourism-intro__grid {
    display: grid;
    grid-template-columns: 1fr .75fr;
    gap: 80px;
}

.tourism-intro__grid > div:first-child > span,
.tourism-itinerary__heading > span,
.tourism-tickets__heading > span,
.tourism-booking__copy > span {
    color: #b05d36;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.tourism-niche h2 {
    margin-top: 18px;
    color: #173329;
    font-family: Georgia, serif;
    font-weight: 400;
    line-height: 1.05;
}

.tourism-intro__grid > p {
    margin: 40px 0 0;
    color: #65736c;
    font-size: 18px;
    line-height: 1.8;
}

.tourism-intro__stats {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 40px;
    border-top: 1px solid #cfcbbd;
}

.tourism-intro__stats div { padding: 28px 0; border-right: 1px solid #cfcbbd; }
.tourism-intro__stats div:last-child { border-right: 0; }
.tourism-intro__stats strong { display: block; color: #b05d36; font-family: Georgia, serif; font-size: 46px; font-weight: 400; }
.tourism-intro__stats span { color: #6e7b74; }

.tourism-itinerary {
    color: #fff;
    background: #173329;
}

.tourism-itinerary__heading {
    display: grid;
    grid-template-columns: .45fr 1.55fr;
    gap: 40px;
    margin-bottom: 70px;
}

.tourism-itinerary h2 { margin: 0; color: #f3eee0; }
.tourism-itinerary__mapline { position: relative; }

.tourism-itinerary__mapline::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 70px;
    width: 1px;
    background: repeating-linear-gradient(#d5b86b 0 8px, transparent 8px 16px);
}

.tourism-itinerary__mapline article {
    position: relative;
    display: grid;
    grid-template-columns: 140px 1fr 100px;
    gap: 30px;
    align-items: center;
    min-height: 190px;
    padding: 28px 0;
    border-top: 1px solid rgba(255,255,255,.15);
}

.tourism-itinerary__day {
    position: relative;
    z-index: 2;
    display: grid;
    place-items: center;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    color: #173329;
    background: #d5b86b;
}

.tourism-itinerary__day span { font-size: 10px; letter-spacing: .12em; }
.tourism-itinerary__day strong { font-family: Georgia, serif; font-size: 35px; font-weight: 400; line-height: 1; }
.tourism-itinerary article small { color: #d5b86b; text-transform: uppercase; letter-spacing: .1em; }
.tourism-itinerary article h3 { margin: 8px 0 12px; font-family: Georgia, serif; font-size: 31px; font-weight: 400; }
.tourism-itinerary article p { margin: 0; color: #a9bbb3; line-height: 1.65; }
.tourism-itinerary article > b { color: #d5b86b; font-family: monospace; text-align: right; }

.tourism-tickets__heading { max-width: 820px; margin-bottom: 52px; }
.tourism-tickets__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

.tourism-tickets__grid article {
    display: grid;
    grid-template-columns: 90px 1fr auto;
    gap: 24px;
    align-items: center;
    min-height: 210px;
    padding: 28px;
    border: 1px solid #c9c5b8;
    background: #f8f5eb;
}

.tourism-ticket__code {
    display: grid;
    place-items: center;
    width: 74px;
    height: 74px;
    border-radius: 50%;
    color: #f3eee0;
    background: #b05d36;
    font-family: monospace;
    font-size: 12px;
}

.tourism-tickets article span { color: #a0684e; font-size: 11px; text-transform: uppercase; letter-spacing: .1em; }
.tourism-tickets article h3 { margin: 8px 0 10px; font-family: Georgia, serif; font-size: 26px; font-weight: 400; }
.tourism-tickets article p { margin: 0; color: #6e7973; line-height: 1.55; }
.tourism-tickets article > strong { color: #173329; font-family: monospace; text-transform: uppercase; }

.tourism-booking { background: #dfd8c7; }

.tourism-booking__layout {
    display: grid;
    grid-template-columns: .85fr 1.15fr;
    gap: 100px;
    align-items: center;
}

.tourism-booking__copy h2 { margin: 18px 0 28px; }
.tourism-booking__copy p { color: #637069; line-height: 1.75; }
.tourism-booking__copy ul { margin: 28px 0 0; padding: 0; list-style: none; }
.tourism-booking__copy li { padding: 10px 0; border-bottom: 1px solid rgba(23,51,41,.18); }
.tourism-booking__copy li::before { content: "✓"; margin-right: 12px; color: #b05d36; font-weight: 900; }

.tourism-booking__card {
    padding: 36px;
    color: #f2eee2;
    background: #173329;
    box-shadow: 24px 24px 0 #b05d36;
}

.tourism-booking__route { display: flex; align-items: center; gap: 16px; color: #d5b86b; font-family: monospace; font-size: 20px; }
.tourism-booking__route i { flex: 1; height: 1px; background: repeating-linear-gradient(90deg, #d5b86b 0 6px, transparent 6px 12px); }
.tourism-booking__card h3 { margin: 30px 0; font-family: Georgia, serif; font-size: 34px; font-weight: 400; }
.tourism-booking__details { display: grid; grid-template-columns: 1fr 1fr; }
.tourism-booking__details div { padding: 16px 0; border-top: 1px solid rgba(255,255,255,.14); }
.tourism-booking__details small { display: block; color: #93a79e; margin-bottom: 6px; }
.tourism-booking__card button { width: 100%; margin-top: 24px; padding: 16px; border: 0; color: #173329; background: #d5b86b; font-weight: 900; }

/* DEALERS: digital showroom */
.dealer-niche {
    background: #080a0e;
    color: #c9cfda;
}

.dealer-hero {
    min-height: 920px;
    padding: 0;
    background: #090b10;
}

.dealer-hero__media {
    position: absolute;
    inset: 0;
}

.dealer-hero__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(4,5,9,.96), rgba(4,5,9,.5) 52%, rgba(4,5,9,.12)), linear-gradient(0deg, rgba(4,5,9,.72), transparent 48%);
}

.dealer-hero__media img { width: 100%; height: 100%; object-fit: cover; }

.dealer-hero__layout {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    min-height: 920px;
    padding-top: 140px;
    padding-bottom: 60px;
}

.dealer-hero__content { align-self: center; max-width: 700px; padding-right: 60px; }

.dealer-hero h1 {
    font-size: clamp(50px, 6.5vw, 100px);
    line-height: .92;
    letter-spacing: -.06em;
    text-transform: uppercase;
}

.dealer-hero__content > p { color: #abb3c0; font-size: 17px; line-height: 1.75; }

.dealer-hero__spec {
    align-self: end;
    justify-self: end;
    width: min(440px, 88%);
    padding: 28px;
    color: #e8ecf4;
    background: rgba(8,10,16,.84);
    border: 1px solid rgba(129,140,248,.5);
    backdrop-filter: blur(15px);
}

.dealer-hero__spec > span { color: #818cf8; font-family: monospace; font-size: 11px; letter-spacing: .12em; }
.dealer-hero__spec > strong { display: block; margin: 14px 0 24px; font-size: 34px; text-transform: uppercase; }
.dealer-hero__spec > div { display: flex; justify-content: space-between; padding: 13px 0; border-top: 1px solid rgba(255,255,255,.13); }
.dealer-hero__spec small { color: #7f8998; text-transform: uppercase; }
.dealer-hero__spec button { width: 100%; margin-top: 16px; padding: 16px; border: 0; color: #fff; background: linear-gradient(90deg, #4768d8, #7c4fc4); font-weight: 900; text-transform: uppercase; }

.dealer-command { padding: 0; border-top: 1px solid #222833; border-bottom: 1px solid #222833; background: #0e1117; }

.dealer-command__bar {
    display: grid;
    grid-template-columns: 1.25fr repeat(4, 1fr);
    align-items: stretch;
}

.dealer-command__bar > span,
.dealer-command__bar > div { padding: 24px; border-right: 1px solid #252b35; }
.dealer-command__bar > span { color: #818cf8; font-family: monospace; font-size: 11px; letter-spacing: .12em; }
.dealer-command__bar strong { display: block; color: #fff; font-size: 28px; }
.dealer-command__bar small { color: #77818e; text-transform: uppercase; }

.dealer-inventory,
.dealer-actions,
.dealer-funnel,
.dealer-lead { padding: 125px 0; }

.dealer-inventory__heading {
    display: grid;
    grid-template-columns: .35fr 1fr .65fr;
    gap: 35px;
    align-items: end;
    margin-bottom: 55px;
}

.dealer-inventory__heading > span,
.dealer-actions__heading > span,
.dealer-funnel__copy > span,
.dealer-lead__grid > div:first-child > span {
    color: #818cf8;
    font-family: monospace;
    font-size: 11px;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.dealer-niche h2 {
    color: #f4f6fa;
    font-size: clamp(38px, 5.1vw, 74px);
    font-weight: 900;
    line-height: .98;
    letter-spacing: -.05em;
    text-transform: uppercase;
}

.dealer-inventory__heading p { margin: 0; color: #7e8795; line-height: 1.7; }

.dealer-inventory__rail {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.dealer-inventory__rail article {
    padding: 16px 16px 24px;
    border: 1px solid #252b35;
    background: #0e1117;
}

.dealer-car {
    position: relative;
    height: 280px;
    overflow: hidden;
    background: linear-gradient(145deg, #182031, #080b10);
}

.dealer-car::before {
    content: "";
    position: absolute;
    top: 38%;
    left: 12%;
    width: 76%;
    height: 35%;
    border-radius: 52% 58% 22% 24% / 65% 65% 30% 30%;
    background: linear-gradient(160deg, #7887a2, #1b2433 58%, #06080c);
    box-shadow: 0 36px 35px rgba(0,0,0,.55);
}

.dealer-car::after {
    content: "";
    position: absolute;
    top: 42%;
    left: 29%;
    width: 39%;
    height: 20%;
    border-radius: 70% 65% 8% 8%;
    background: #111a28;
    transform: skewX(-15deg);
}

.dealer-car--two::before { background: linear-gradient(160deg, #8b8f97, #282d35 58%, #08090c); }
.dealer-car--three::before { background: linear-gradient(160deg, #463d67, #171525 58%, #06060a); }
.dealer-car span { position: absolute; top: 16px; left: 16px; z-index: 2; color: rgba(255,255,255,.35); font-size: 42px; font-weight: 900; }
.dealer-inventory article small { display: block; margin-top: 20px; color: #687381; text-transform: uppercase; letter-spacing: .1em; }
.dealer-inventory article h3 { margin: 10px 0 22px; color: #fff; font-size: 29px; text-transform: uppercase; }
.dealer-inventory article > div:last-child { display: flex; justify-content: space-between; gap: 12px; padding-top: 18px; border-top: 1px solid #272e38; }
.dealer-inventory article > div:last-child span { color: #818cf8; font-size: 12px; }

.dealer-actions { background: #10131a; }

.dealer-actions__grid {
    display: grid;
    grid-template-columns: .7fr 1.3fr;
    gap: 80px;
    align-items: center;
}

.dealer-actions__heading h2 { margin-top: 18px; }

.dealer-actions__wheel {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.dealer-actions__center {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 3;
    display: grid;
    place-items: center;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    color: #fff;
    background: linear-gradient(145deg, #4865d1, #713f9f);
    transform: translate(-50%, -50%);
    box-shadow: 0 0 0 14px #10131a;
}

.dealer-actions__center span,
.dealer-actions__center strong { display: block; text-align: center; text-transform: uppercase; }
.dealer-actions__center span { font-weight: 900; }
.dealer-actions__center strong { color: #c8cdef; font-size: 10px; letter-spacing: .12em; }

.dealer-actions__wheel article {
    min-height: 250px;
    padding: 28px;
    border: 1px solid #2b323e;
    background: #0b0e13;
}

.dealer-actions__wheel article:nth-child(2),
.dealer-actions__wheel article:nth-child(4) { text-align: right; }
.dealer-actions__wheel article > span { color: #818cf8; font-family: monospace; }
.dealer-actions__wheel h3 { margin: 70px 0 10px; color: #fff; font-size: 23px; text-transform: uppercase; }
.dealer-actions__wheel p { margin: 0; color: #788391; }

.dealer-funnel__layout {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 80px;
    align-items: center;
}

.dealer-funnel__board { border: 1px solid #2a313b; background: #0e1117; }
.dealer-funnel__head { display: flex; justify-content: space-between; padding: 20px; border-bottom: 1px solid #2a313b; font-family: monospace; }
.dealer-funnel__head span { color: #818cf8; }
.dealer-funnel__columns { display: grid; grid-template-columns: repeat(3, 1fr); }
.dealer-funnel__columns > div { min-height: 340px; padding: 16px; border-right: 1px solid #2a313b; }
.dealer-funnel__columns > div:last-child { border-right: 0; }
.dealer-funnel__columns > div > span { color: #717c89; font-size: 11px; text-transform: uppercase; letter-spacing: .1em; }
.dealer-funnel__columns article { margin-top: 16px; padding: 16px; border-left: 3px solid #818cf8; background: #171c24; }
.dealer-funnel__columns article b,
.dealer-funnel__columns article small { display: block; }
.dealer-funnel__columns article b { color: #fff; }
.dealer-funnel__columns article small { margin-top: 7px; color: #7b8693; line-height: 1.45; }
.dealer-funnel__copy h2 { margin: 18px 0 28px; }
.dealer-funnel__copy p { color: #818b98; line-height: 1.75; }
.dealer-funnel__copy ul { margin: 24px 0 0; padding: 0; list-style: none; }
.dealer-funnel__copy li { padding: 11px 0; border-bottom: 1px solid #262d36; text-transform: uppercase; }
.dealer-funnel__copy li::before { content: "→"; margin-right: 12px; color: #818cf8; }

.dealer-lead { background: linear-gradient(110deg, #1b2545, #3a2051); }

.dealer-lead__grid {
    display: grid;
    grid-template-columns: .8fr 1.2fr .45fr;
    gap: 60px;
    align-items: center;
}

.dealer-lead__grid h2 { margin-top: 18px; }
.dealer-lead__data { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid rgba(255,255,255,.2); }
.dealer-lead__data div { padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.2); }
.dealer-lead__data small { display: block; color: #a8acce; margin-bottom: 7px; }
.dealer-lead__data strong { color: #fff; }
.dealer-lead__result { padding-left: 28px; border-left: 1px solid rgba(255,255,255,.25); }
.dealer-lead__result strong { color: #fff; font-size: 90px; line-height: 1; }
.dealer-lead__result p { color: #c0c3dc; line-height: 1.55; }

/* Responsive architecture */
@media (max-width: 1100px) {
    .beauty-hero__layout,
    .realtor-hero__layout,
    .dealer-hero__layout {
        grid-template-columns: 1fr 1fr;
    }

    .beauty-editorial__grid { grid-template-columns: 1fr 1fr; }
    .beauty-editorial__intro { grid-column: 1 / -1; grid-row: auto; padding-right: 0; }
    .beauty-feature--large { grid-column: span 2; }

    .sto-hero__grid,
    .sto-control__grid,
    .realtor-showing__grid,
    .tourism-booking__layout,
    .dealer-funnel__layout {
        grid-template-columns: 1fr;
    }

    .sto-hero__content { border-right: 0; border-bottom: 1px solid #303840; }
    .sto-visual { min-height: 560px; }
    .sto-bays__layout,
    .realtor-paths__layout,
    .dealer-actions__grid { grid-template-columns: .8fr 1.2fr; gap: 50px; }
    .dealer-command__bar { grid-template-columns: 1fr repeat(2, 1fr); }
    .dealer-command__bar > div:nth-last-child(-n+2) { border-top: 1px solid #252b35; }
    .dealer-lead__grid { grid-template-columns: 1fr 1.2fr; }
    .dealer-lead__result { grid-column: 1 / -1; padding: 24px 0 0; border-top: 1px solid rgba(255,255,255,.25); border-left: 0; }
}

@media (max-width: 820px) {
    .beauty-hero,
    .realtor-hero,
    .tourism-hero,
    .dealer-hero { min-height: auto; }

    .beauty-hero__photo,
    .realtor-hero__image,
    .dealer-hero__media {
        position: relative;
        inset: auto;
        height: 440px;
    }

    .beauty-hero__photo::after,
    .realtor-hero__image::after,
    .dealer-hero__media::after {
        background: linear-gradient(0deg, currentColor, transparent 45%);
    }

    .beauty-hero__layout,
    .realtor-hero__layout,
    .dealer-hero__layout {
        display: block;
        min-height: auto;
        padding-top: 60px;
        padding-bottom: 60px;
    }

    .beauty-hero__issue { margin-bottom: 30px; }
    .beauty-hero__content,
    .realtor-hero__content,
    .dealer-hero__content { padding: 0; }
    .beauty-hero__note,
    .realtor-search-card,
    .dealer-hero__spec { width: 100%; margin-top: 38px; }

    .beauty-editorial,
    .beauty-booking-story,
    .beauty-result,
    .sto-workorder,
    .sto-bays,
    .sto-pipeline,
    .sto-control,
    .realtor-market,
    .realtor-paths,
    .realtor-showing,
    .realtor-lead,
    .tourism-intro,
    .tourism-itinerary,
    .tourism-tickets,
    .tourism-booking,
    .dealer-inventory,
    .dealer-actions,
    .dealer-funnel,
    .dealer-lead {
        padding: 80px 0;
    }

    .beauty-booking-story__layout,
    .beauty-result__grid,
    .sto-section-heading,
    .sto-bays__layout,
    .realtor-market__heading,
    .realtor-paths__layout,
    .realtor-lead__layout,
    .tourism-intro__grid,
    .tourism-itinerary__heading,
    .tourism-booking__layout,
    .dealer-inventory__heading,
    .dealer-actions__grid,
    .dealer-funnel__layout,
    .dealer-lead__grid {
        grid-template-columns: 1fr;
        gap: 38px;
    }

    .beauty-booking-story__sticky,
    .sto-bays__title { position: static; }
    .beauty-result__card { box-shadow: 16px 16px 0 #dfb6c7; }

    .sto-hero { padding-top: 95px; }
    .sto-hero__topline { grid-template-columns: 1fr auto; }
    .sto-hero__topline span:nth-child(2) { display: none; }
    .sto-hero__metrics { grid-template-columns: 1fr; }
    .sto-hero__metrics div { border-right: 0; border-bottom: 1px solid #303840; }
    .sto-pipeline__rail { grid-template-columns: 1fr 1fr; }

    .realtor-market__grid { grid-template-columns: 1fr; }
    .realtor-property--featured { grid-row: auto; }

    .tourism-hero__layout {
        grid-template-columns: 1fr;
        min-height: 850px;
        padding-top: 130px;
    }

    .tourism-hero__passport { justify-self: start; width: min(360px, 90%); }
    .tourism-tickets__grid { grid-template-columns: 1fr; }

    .dealer-command__bar { grid-template-columns: 1fr 1fr; }
    .dealer-command__bar > span { grid-column: 1 / -1; }
    .dealer-inventory__rail { grid-template-columns: 1fr; }
    .dealer-car { height: 330px; }
}

@media (max-width: 560px) {
    .beauty-hero__photo,
    .realtor-hero__image,
    .dealer-hero__media { height: 330px; }

    .beauty-hero h1,
    .sto-hero h1,
    .realtor-hero h1,
    .tourism-hero h1,
    .dealer-hero h1 { font-size: 42px; }

    .beauty-editorial__grid,
    .beauty-result__copy ul,
    .realtor-paths__cards,
    .realtor-lead__card dl,
    .tourism-intro__stats,
    .tourism-booking__details,
    .dealer-actions__wheel,
    .dealer-lead__data {
        grid-template-columns: 1fr;
    }

    .beauty-feature--large { grid-column: auto; grid-template-columns: 1fr; }
    .beauty-swatches { grid-column: auto; }
    .beauty-booking-story__steps article { grid-template-columns: 62px 1fr; }
    .beauty-result__card dl div { display: block; }
    .beauty-result__card dd { margin-top: 6px; text-align: left; }

    .sto-hero__content { padding: 44px 22px; }
    .sto-visual { min-height: 420px; }
    .sto-workorder__table > div { grid-template-columns: 1fr; gap: 8px; }
    .sto-workorder__table b { text-align: left; }
    .sto-bays__list article { grid-template-columns: 45px 1fr; }
    .sto-bays__list article > strong { grid-column: 2; text-align: left; }
    .sto-pipeline__rail { grid-template-columns: 1fr; }
    .sto-control__screen li { grid-template-columns: 10px 1fr; }
    .sto-control__screen li b { grid-column: 2; }

    .realtor-property { grid-template-columns: 1fr; }
    .realtor-showing__calendar { grid-template-columns: 1fr; }
    .realtor-showing__calendar > div { min-height: 180px; }
    .realtor-showing__calendar li { grid-template-columns: 55px 1fr; }
    .realtor-showing__calendar li b { grid-column: 2; }

    .tourism-hero__layout { min-height: 760px; }
    .tourism-itinerary__mapline::before { left: 36px; }
    .tourism-itinerary__mapline article { grid-template-columns: 75px 1fr; gap: 20px; }
    .tourism-itinerary__day { width: 72px; height: 72px; }
    .tourism-itinerary article > b { grid-column: 2; text-align: left; }
    .tourism-tickets__grid article { grid-template-columns: 70px 1fr; }
    .tourism-tickets article > strong { grid-column: 2; }
    .tourism-booking__card { padding: 24px; box-shadow: 14px 14px 0 #b05d36; }

    .dealer-command__bar { grid-template-columns: 1fr; }
    .dealer-command__bar > span,
    .dealer-command__bar > div { grid-column: auto; border-top: 1px solid #252b35; }
    .dealer-car { height: 250px; }
    .dealer-actions__center { position: static; grid-column: 1; width: 130px; height: 130px; margin: 0 auto 10px; transform: none; }
    .dealer-actions__wheel article:nth-child(2),
    .dealer-actions__wheel article:nth-child(4) { text-align: left; }
    .dealer-actions__wheel h3 { margin-top: 35px; }
    .dealer-funnel__columns { grid-template-columns: 1fr; }
    .dealer-funnel__columns > div { min-height: auto; border-right: 0; border-bottom: 1px solid #2a313b; }
}

/* =========================================================
   Niche pages v3: UnionDev visual system, contextual content
   ========================================================= */

.niche-v3 {
    --niche-accent: #5aa7ff;
    --niche-accent-rgb: 90, 167, 255;
    overflow: hidden;
    color: #eef3fb;
    background:
        radial-gradient(circle at 12% 8%, rgba(var(--niche-accent-rgb), 0.12), transparent 28%),
        linear-gradient(180deg, #0e1118 0%, #090c12 100%);
}

.beauty-niche.niche-v3 { --niche-accent: #f08abd; --niche-accent-rgb: 240, 138, 189; }
.sto-niche.niche-v3 { --niche-accent: #f5c84c; --niche-accent-rgb: 245, 200, 76; }
.realtor-niche.niche-v3 { --niche-accent: #55b6ff; --niche-accent-rgb: 85, 182, 255; }
.tourism-niche.niche-v3 { --niche-accent: #43d7c1; --niche-accent-rgb: 67, 215, 193; }
.dealer-niche.niche-v3 { --niche-accent: #8792ff; --niche-accent-rgb: 135, 146, 255; }

.niche-v3 section {
    position: relative;
    box-sizing: border-box;
}

.niche-v3 h1,
.niche-v3 h2,
.niche-v3 h3,
.niche-v3 p {
    font-family: inherit;
}

.niche-v3 h2 {
    margin: 0;
    color: #f5f8fd;
    font-size: clamp(34px, 4.5vw, 64px);
    font-weight: 800;
    line-height: 1.06;
    letter-spacing: -0.035em;
}

.niche-v3 h3 {
    color: #f5f8fd;
}

.niche-v3-hero {
    min-height: 850px;
    padding: 0;
    background: #0d1118;
}

.niche-v3-hero__photo {
    position: absolute;
    inset: 0 0 0 43%;
    overflow: hidden;
}

.niche-v3-hero__photo::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, #0d1118 0%, rgba(13, 17, 24, 0.82) 23%, rgba(13, 17, 24, 0.12) 65%),
        linear-gradient(0deg, rgba(9, 12, 18, 0.74), transparent 50%);
}

.niche-v3-hero__photo img,
.niche-v3-hero__image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.niche-v3-hero__grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 0.88fr) minmax(420px, 1.12fr);
    min-height: 850px;
    padding-top: 130px;
    padding-bottom: 58px;
}

.niche-v3-hero__grid--reverse {
    grid-template-columns: minmax(480px, 1.08fr) minmax(0, 0.92fr);
    gap: 70px;
    align-items: center;
}

.niche-v3-hero__image {
    position: relative;
    min-height: 590px;
    overflow: hidden;
    border: 1px solid rgba(var(--niche-accent-rgb), 0.25);
    box-shadow: 0 35px 90px rgba(0, 0, 0, 0.45);
}

.niche-v3-hero__image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(8, 11, 17, 0.52));
}

.niche-v3-hero__content {
    align-self: center;
    max-width: 720px;
    padding-right: 58px;
}

.niche-v3-hero__grid--reverse .niche-v3-hero__content {
    padding-right: 0;
}

.niche-v3-hero h1 {
    margin: 0 0 28px;
    color: #f7f9fd;
    font-size: clamp(45px, 5.7vw, 86px);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.05em;
}

.niche-v3-hero__content > p {
    max-width: 660px;
    color: #b5c0d1;
    font-size: 18px;
    line-height: 1.75;
}

.niche-v3-hero__aside {
    align-self: end;
    justify-self: end;
    width: min(390px, 85%);
    padding: 28px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-top: 2px solid var(--niche-accent);
    background: rgba(14, 19, 29, 0.78);
    box-shadow: 0 24px 65px rgba(0, 0, 0, 0.32);
    backdrop-filter: blur(18px);
}

.niche-v3-hero__aside strong {
    display: block;
    margin-bottom: 12px;
    color: #fff;
    font-size: 21px;
}

.niche-v3-hero__aside p {
    margin: 0;
    color: #aeb9c9;
    line-height: 1.65;
}

.niche-v3 .niche-primary-btn {
    color: #071019;
    background: var(--niche-accent);
}

.niche-v3-intro {
    padding: 125px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.niche-v3-intro__grid {
    display: grid;
    grid-template-columns: 0.35fr 1.05fr 0.8fr;
    gap: 45px;
    align-items: start;
}

.niche-v3-intro__copy {
    padding-top: 8px;
}

.niche-v3-intro__copy p,
.niche-v3-summary__copy p {
    margin: 0;
    color: #aeb9c9;
    font-size: 17px;
    line-height: 1.78;
}

.niche-v3-intro__copy p + p,
.niche-v3-summary__copy p + p {
    margin-top: 18px;
}

.niche-v3-feature {
    padding: 115px 0;
    background:
        linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px),
        #0b0f16;
    background-size: 42px 42px;
}

.niche-v3-feature__stagger {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 22px;
    align-items: start;
}

.niche-v3-feature__stagger article,
.niche-v3-feature__columns article,
.niche-v3-feature__split article {
    padding: 34px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top right, rgba(var(--niche-accent-rgb), 0.1), transparent 38%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.018));
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.28);
}

.niche-v3-feature__stagger article:nth-child(2),
.niche-v3-feature__stagger article:nth-child(4) {
    transform: translateY(44px);
}

.niche-v3-feature article > span,
.niche-v3-lines article > span {
    color: var(--niche-accent);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.niche-v3-feature h3,
.niche-v3-lines h3 {
    margin: 45px 0 14px;
    font-size: 27px;
    line-height: 1.2;
}

.niche-v3-feature p,
.niche-v3-lines p {
    margin: 0;
    color: #aab5c5;
    line-height: 1.72;
}

.niche-v3-feature__columns {
    display: grid;
    grid-template-columns: 0.8fr 1.2fr 0.8fr;
    gap: 20px;
}

.niche-v3-feature__columns article:nth-child(2) {
    min-height: 360px;
}

.niche-v3-feature__split {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 24px;
}

.niche-v3-feature__split > div {
    display: grid;
    gap: 24px;
}

.niche-v3-feature__split > div:last-child {
    padding-top: 70px;
}

.niche-v3-lines {
    padding: 40px 0 110px;
    background: #0b0f16;
}

.niche-v3-lines .container {
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.niche-v3-lines article {
    display: grid;
    grid-template-columns: 90px 0.7fr 1.3fr;
    gap: 30px;
    align-items: start;
    padding: 34px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.niche-v3-lines h3 {
    margin: 0;
}

.niche-v3-flow {
    padding: 125px 0;
    background:
        radial-gradient(circle at 85% 30%, rgba(var(--niche-accent-rgb), 0.1), transparent 30%),
        #10151e;
}

.niche-v3-flow__grid {
    display: grid;
    grid-template-columns: 0.78fr 1.22fr;
    gap: 90px;
}

.niche-v3-flow__heading {
    position: sticky;
    top: 120px;
    align-self: start;
}

.niche-v3-flow__heading h2 {
    margin-top: 22px;
}

.niche-v3-flow__steps {
    margin: 0;
    padding: 0;
    list-style: none;
    border-top: 1px solid rgba(255, 255, 255, 0.13);
}

.niche-v3-flow__steps li {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 26px;
    padding: 32px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.13);
}

.niche-v3-flow__steps li > span {
    color: var(--niche-accent);
    font-size: 25px;
    font-weight: 800;
}

.niche-v3-flow__steps h3 {
    margin: 0 0 10px;
    font-size: 24px;
}

.niche-v3-flow__steps p {
    margin: 0;
    color: #aab5c5;
    line-height: 1.65;
}

.niche-v3-flow--realtor .niche-v3-flow__grid {
    grid-template-columns: 1.05fr 0.95fr;
}

.niche-v3-flow--tourism .niche-v3-flow__steps li {
    grid-template-columns: 120px 1fr;
}

.niche-v3-flow--dealer .niche-v3-flow__grid {
    gap: 55px;
}

.niche-v3-summary {
    padding: 125px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.niche-v3-summary__grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 90px;
    align-items: start;
}

.niche-v3-summary h2 {
    margin-top: 22px;
}

@media (max-width: 1050px) {
    .niche-v3-hero__grid,
    .niche-v3-hero__grid--reverse {
        grid-template-columns: 1fr;
        gap: 45px;
    }

    .niche-v3-hero__grid--reverse .niche-v3-hero__image {
        order: 2;
    }

    .niche-v3-hero__aside {
        width: min(460px, 100%);
    }

    .niche-v3-intro__grid {
        grid-template-columns: 0.35fr 1.65fr;
    }

    .niche-v3-intro__copy {
        grid-column: 2;
    }
}

@media (max-width: 820px) {
    .niche-v3-hero {
        min-height: auto;
    }

    .niche-v3-hero__photo {
        position: relative;
        inset: auto;
        height: 440px;
    }

    .niche-v3-hero__photo::after {
        background: linear-gradient(0deg, #0d1118, transparent 52%);
    }

    .niche-v3-hero__grid {
        min-height: auto;
        padding-top: 55px;
        padding-bottom: 70px;
    }

    .niche-v3-hero__content {
        padding-right: 0;
    }

    .niche-v3-hero__image {
        min-height: 470px;
    }

    .niche-v3-intro,
    .niche-v3-feature,
    .niche-v3-flow,
    .niche-v3-summary {
        padding: 78px 0;
    }

    .niche-v3-intro__grid,
    .niche-v3-summary__grid,
    .niche-v3-flow__grid,
    .niche-v3-flow--realtor .niche-v3-flow__grid {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .niche-v3-intro__copy {
        grid-column: auto;
    }

    .niche-v3-feature__stagger,
    .niche-v3-feature__columns,
    .niche-v3-feature__split {
        grid-template-columns: 1fr;
    }

    .niche-v3-feature__stagger article:nth-child(2),
    .niche-v3-feature__stagger article:nth-child(4),
    .niche-v3-feature__split > div:last-child {
        padding-top: 0;
        transform: none;
    }

    .niche-v3-flow__heading {
        position: static;
    }
}

@media (max-width: 560px) {
    .niche-v3-hero__photo {
        height: 330px;
    }

    .niche-v3-hero h1 {
        font-size: 39px;
    }

    .niche-v3-hero__aside,
    .niche-v3-feature__stagger article,
    .niche-v3-feature__columns article,
    .niche-v3-feature__split article {
        padding: 24px;
    }

    .niche-v3-lines article {
        grid-template-columns: 55px 1fr;
        gap: 16px;
    }

    .niche-v3-lines article p {
        grid-column: 2;
    }

    .niche-v3-flow__steps li,
    .niche-v3-flow--tourism .niche-v3-flow__steps li {
        grid-template-columns: 58px 1fr;
        gap: 16px;
    }
}

/* Compact studio information block */
.studio-suite {
    position: relative;
    padding: 96px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    background:
        radial-gradient(circle at 82% 18%, rgba(var(--studio-accent-rgb), 0.11), transparent 28%),
        #0d1118;
}

.studio-suite__head {
    display: grid;
    grid-template-columns: 1.05fr 0.75fr;
    gap: 70px;
    align-items: end;
    margin-bottom: 38px;
}

.studio-suite__head h2,
.studio-suite__process-title h2 {
    margin: 0;
    color: #f7f9fd;
    font-size: clamp(34px, 4vw, 58px);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.04em;
}

.studio-suite__head > p {
    margin: 0 0 4px;
    color: #a4afbf;
    font-size: 16px;
    line-height: 1.72;
}

.studio-suite__board {
    display: grid;
    grid-template-columns: 1.08fr 1fr 1fr;
    gap: 16px;
}

.studio-suite__board article {
    min-height: 330px;
    padding: 26px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    background: linear-gradient(145deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
}

.studio-suite__board article > span {
    color: var(--studio-accent);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.studio-suite__board h3 {
    margin: 22px 0 22px;
    color: #f5f8fd;
    font-size: 25px;
    line-height: 1.16;
}

.studio-suite__board ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.studio-suite__board li {
    padding: 9px 0;
    border-top: 1px solid rgba(255,255,255,.07);
    color: #9ba7b8;
    font-size: 14px;
}

.studio-suite__solution {
    border-color: rgba(var(--studio-accent-rgb), .3) !important;
    background:
        radial-gradient(circle at 90% 5%, rgba(var(--studio-accent-rgb), .15), transparent 35%),
        linear-gradient(145deg, rgba(var(--studio-accent-rgb), .06), rgba(255,255,255,.015)) !important;
}

.studio-suite__solution > div {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.studio-suite__solution b {
    padding: 8px 10px;
    border: 1px solid rgba(var(--studio-accent-rgb), .2);
    border-radius: 7px;
    color: #dce5f2;
    background: rgba(var(--studio-accent-rgb), .06);
    font-size: 12px;
}

.studio-suite__solution p {
    margin: 20px 0 0;
    color: #929eaf;
    font-size: 14px;
    line-height: 1.6;
}

.studio-suite__process {
    margin-top: 50px;
    padding: 34px 0 0;
    border-top: 1px solid rgba(255,255,255,.11);
    background: none;
}

.studio-suite__process-title {
    display: flex;
    justify-content: space-between;
    gap: 30px;
    align-items: end;
    margin-bottom: 28px;
}

.studio-suite__process-title .studio-suite__eyebrow {
    margin-bottom: 0;
}

.studio-suite__process ol {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.studio-suite__process li {
    min-height: 135px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 14px;
    background: rgba(255, 255, 255, .025);
}

.studio-suite__process li > span {
    color: var(--studio-accent);
    font-family: monospace;
    font-size: 12px;
    font-weight: 900;
}

.studio-suite__process h3 {
    margin: 7px 0 7px;
    color: #f3f6fb;
    font-size: 17px;
    line-height: 1.2;
}

.studio-suite__process p {
    margin: 0;
    color: #8995a6;
    font-size: 13px;
    line-height: 1.5;
}

@media (max-width: 900px) {
    .studio-suite__head,
    .studio-suite__board {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .studio-suite__board article {
        min-height: auto;
    }

    .studio-suite__board h3 {
        margin-top: 35px;
    }

    .studio-suite__process ol {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .studio-suite {
        padding: 68px 0;
    }

    .studio-suite__head {
        margin-bottom: 28px;
    }

    .studio-suite__process-title {
        display: block;
    }

    .studio-suite__process-title h2 {
        margin-top: 18px;
    }

    .studio-suite__process ol {
        grid-template-columns: 1fr;
    }

    .studio-suite__process li {
        min-height: auto;
    }
}

/* Beauty v2: photographic depth for content-heavy cards */
.beauty-services-v2 article {
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.beauty-services-v2 article::before {
    content: "";
    position: absolute;
    z-index: -2;
    background-repeat: no-repeat;
    background-size: cover;
    filter: saturate(.8) contrast(1.06);
}

.beauty-services-v2 article::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
}

.beauty-services-v2__main::before {
    inset: 0 0 42%;
    background-image: url("/images/niches/beauty-services-overview.jpg");
    background-position: 50% 52%;
}

.beauty-services-v2__main::after {
    background: linear-gradient(180deg, rgba(13, 17, 24, .12) 0%, rgba(13, 17, 24, 0.9) 39%, #111720 61%, #111720 100%);
}

.beauty-services-v2__side article::before {
    inset: 0 0 0 42%;
}

.beauty-services-v2__side article:first-child::before {
    background-image: url("/images/niches/beauty-master-consultation.jpg");
    background-position: 63% 45%;
}

.beauty-services-v2__side article:last-child::before {
    background-image: url("/images/niches/beauty-client-wishes.jpg");
    background-position: 56% 45%;
}

.beauty-services-v2__side article::after {
    background: linear-gradient(90deg, #111720 0%, rgba(17, 23, 32, 1) 45%, rgba(17, 23, 32, .36) 100%), linear-gradient(0deg, rgba(17, 23, 32, .72), transparent 55%);
}

.beauty-services-v2__side article > * {
    position: relative;
    max-width: 68%;
}

.beauty-steps-v2 {
    padding: 88px 0;
}

.beauty-steps-v2__head {
    margin-bottom: 34px;
}

.beauty-steps-v2__row article {
    min-height: 205px;
    padding: 24px;
}

.beauty-steps-v2__row h3 {
    margin: 10px 0 10px;
}

@media (max-width: 820px) {
    .beauty-services-v2__side article {
        min-height: 260px;
    }
}

@media (max-width: 560px) {
    .beauty-services-v2__main::before {
        inset: 0 0 52%;
    }

    .beauty-services-v2__side article::before {
        inset: 0 0 48%;
    }

    .beauty-services-v2__side article::after {
        background: linear-gradient(180deg, rgba(13,17,24,.08), #111720 54%, #111720);
    }

    .beauty-services-v2__side article > * {
        max-width: none;
    }

    .beauty-services-v2__side h3 {
        margin-top: 125px;
    }

    .beauty-steps-v2 {
        padding: 62px 0;
    }

    .beauty-steps-v2__head {
        margin-bottom: 26px;
    }

    .beauty-steps-v2__row article {
        min-height: auto;
        padding: 22px;
    }

    .beauty-steps-v2__row h3 {
        margin-top: 28px;
    }
}

/* Belarus regional pages in niche architecture */
.belarus-region-page {
    overflow: hidden;
    color: #eef3fb;
    background:
        linear-gradient(135deg, rgba(var(--belarus-accent-rgb), 0.08), transparent 30%),
        linear-gradient(225deg, rgba(78, 110, 242, 0.08), transparent 34%),
        #0b0f16;
}

.belarus-region-page *,
.belarus-region-page *::before,
.belarus-region-page *::after {
    box-sizing: border-box;
}

.belarus-region-page .niche-primary-btn {
    color: #071019;
    background: var(--belarus-accent);
    box-shadow: 0 18px 48px rgba(var(--belarus-accent-rgb), 0.2);
}

.belarus-chip {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    min-height: 34px;
    padding: 0 13px;
    border: 1px solid rgba(var(--belarus-accent-rgb), 0.28);
    border-radius: 999px;
    color: var(--belarus-accent);
    background: rgba(var(--belarus-accent-rgb), 0.08);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.belarus-hero {
    position: relative;
    min-height: 820px;
    display: flex;
    align-items: center;
    padding: 136px 0 86px;
    background:
        linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px),
        radial-gradient(circle at 78% 35%, rgba(var(--belarus-accent-rgb), 0.16), transparent 30%),
        #0d1118;
    background-size: 38px 38px, 38px 38px, auto, auto;
}

.belarus-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(430px, 1.08fr);
    gap: 72px;
    align-items: center;
}

.belarus-hero__copy h1 {
    max-width: 820px;
    margin: 24px 0 26px;
    color: #f7f9fd;
    font-size: 72px;
    line-height: 1;
    font-weight: 850;
    letter-spacing: 0;
    text-wrap: balance;
}

.belarus-hero__copy p {
    max-width: 700px;
    margin: 0;
    color: #aeb9ca;
    font-size: 18px;
    line-height: 1.75;
}

.belarus-dashboard,
.belarus-route-visual,
.belarus-editorial-visual,
.belarus-matrix-visual,
.belarus-premium-card,
.belarus-ops-visual {
    position: relative;
    min-height: 520px;
    border: 1px solid rgba(var(--belarus-accent-rgb), 0.24);
    border-radius: 24px;
    background:
        radial-gradient(circle at 90% 10%, rgba(var(--belarus-accent-rgb), 0.18), transparent 34%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.014));
    box-shadow: 0 42px 100px rgba(0, 0, 0, 0.48), inset 0 1px 0 rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(18px) saturate(150%);
    overflow: hidden;
}

.belarus-window-bar {
    display: flex;
    height: 52px;
    align-items: center;
    gap: 7px;
    padding: 0 18px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    color: #748194;
    font-size: 12px;
}

.belarus-window-bar i {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #3a4554;
}

.belarus-window-bar i:first-child {
    background: var(--belarus-accent);
}

.belarus-window-bar span {
    margin-left: auto;
}

.belarus-dashboard {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    align-content: start;
    padding: 0 26px 26px;
}

.belarus-dashboard .belarus-window-bar {
    grid-column: 1 / -1;
    margin: 0 -26px 8px;
}

.belarus-dashboard__metric {
    min-height: 132px;
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.035);
}

.belarus-dashboard__metric b,
.belarus-flow__list article > span,
.belarus-card-grid article b {
    color: var(--belarus-accent);
    font-size: 13px;
    font-weight: 900;
}

.belarus-dashboard__metric span {
    display: block;
    margin-top: 16px;
    color: #edf4ff;
    font-size: 20px;
    font-weight: 800;
    line-height: 1.24;
}

.belarus-dashboard__graph {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 0.7fr 1fr 0.82fr 1.18fr;
    gap: 10px;
    align-items: end;
    min-height: 160px;
    padding: 20px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.025);
}

.belarus-dashboard__graph span {
    display: block;
    min-height: 48px;
    border-radius: 10px;
    background: linear-gradient(180deg, rgba(var(--belarus-accent-rgb), 0.75), rgba(var(--belarus-accent-rgb), 0.14));
}

.belarus-dashboard__graph span:nth-child(2) { min-height: 96px; }
.belarus-dashboard__graph span:nth-child(3) { min-height: 72px; }
.belarus-dashboard__graph span:nth-child(4) { min-height: 132px; }

.belarus-route-visual {
    display: grid;
    gap: 14px;
    align-content: center;
    padding: 30px;
}

.belarus-route-visual div {
    display: grid;
    grid-template-columns: 0.78fr 1fr;
    gap: 18px;
    align-items: center;
    min-height: 84px;
    padding: 20px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.035);
}

.belarus-route-visual b,
.belarus-editorial-visual__poster,
.belarus-premium-card div:first-child,
.belarus-ops-visual__hub {
    color: #f7f9fd;
    font-size: 24px;
    font-weight: 850;
    line-height: 1.12;
}

.belarus-route-visual span {
    color: #9daabd;
    line-height: 1.45;
}

.belarus-editorial-visual {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 14px;
    align-content: center;
    padding: 28px;
}

.belarus-editorial-visual__poster {
    display: flex;
    min-height: 330px;
    grid-row: span 3;
    align-items: flex-end;
    padding: 26px;
    border-radius: 18px;
    background: linear-gradient(145deg, rgba(var(--belarus-accent-rgb), 0.26), rgba(255, 255, 255, 0.04));
    font-size: 44px;
}

.belarus-editorial-visual__card,
.belarus-matrix-visual span,
.belarus-premium-card div,
.belarus-ops-visual span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 96px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    color: #dfe8f5;
    background: rgba(255, 255, 255, 0.035);
    font-weight: 800;
    text-align: center;
}

.belarus-matrix-visual {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    align-content: center;
    padding: 28px;
}

.belarus-matrix-visual span {
    min-height: 145px;
}

.belarus-matrix-visual span:nth-child(5) {
    border-color: rgba(var(--belarus-accent-rgb), 0.32);
    background: rgba(var(--belarus-accent-rgb), 0.12);
}

.belarus-premium-card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    align-content: center;
    padding: 28px;
}

.belarus-premium-card div:first-child {
    grid-column: 1 / -1;
    min-height: 190px;
    border-color: rgba(var(--belarus-accent-rgb), 0.3);
    background: rgba(var(--belarus-accent-rgb), 0.1);
    font-size: 38px;
}

.belarus-ops-visual {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    align-content: center;
    padding: 28px;
}

.belarus-ops-visual__hub {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    border: 1px solid rgba(var(--belarus-accent-rgb), 0.3);
    border-radius: 18px;
    background: rgba(var(--belarus-accent-rgb), 0.11);
    font-size: 44px;
}

.belarus-split,
.belarus-card-section,
.belarus-flow,
.belarus-map-section,
.belarus-seo-text,
.belarus-cta {
    position: relative;
    padding: 96px 0;
}

.belarus-split__grid {
    display: grid;
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
    gap: 70px;
    align-items: start;
}

.belarus-split h2,
.belarus-section-head h2,
.belarus-seo-text h2,
.belarus-cta h2 {
    margin: 18px 0 0;
    color: #f7f9fd;
    font-size: 52px;
    line-height: 1.08;
    font-weight: 850;
    letter-spacing: 0;
    text-wrap: balance;
}

.belarus-split p,
.belarus-seo-text p,
.belarus-cta p {
    margin: 0 0 18px;
    color: #a7b2c2;
    font-size: 17px;
    line-height: 1.78;
}

.belarus-section-head {
    max-width: 900px;
    margin-bottom: 38px;
}

.belarus-card-grid,
.belarus-map-grid,
.belarus-flow__list {
    display: grid;
    gap: 16px;
}

.belarus-card-grid--four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.belarus-card-grid--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.belarus-map-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.belarus-card-grid article,
.belarus-map-grid article,
.belarus-flow__list article,
.belarus-seo-text__box,
.belarus-cta__box {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(14px) saturate(150%);
}

.belarus-card-grid article,
.belarus-map-grid article {
    min-height: 230px;
    padding: 26px;
}

.belarus-card-grid h3,
.belarus-map-grid h3,
.belarus-flow__list h3 {
    margin: 18px 0 12px;
    color: #f5f8fd;
    font-size: 23px;
    line-height: 1.2;
}

.belarus-card-grid p,
.belarus-map-grid p,
.belarus-flow__list p {
    margin: 0;
    color: #9ba7b8;
    font-size: 15px;
    line-height: 1.68;
}

.belarus-flow__list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.belarus-flow__list article {
    min-height: 260px;
    padding: 24px;
}

.belarus-tag-cloud {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-content: flex-start;
}

.belarus-tag-cloud span,
.belarus-internal-links a {
    display: inline-flex;
    min-height: 40px;
    align-items: center;
    padding: 0 14px;
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 999px;
    color: #dce6f3;
    background: rgba(255, 255, 255, 0.035);
    font-size: 14px;
    font-weight: 750;
}

.belarus-seo-text__box {
    padding: 34px;
    border-color: rgba(var(--belarus-accent-rgb), 0.18);
    background:
        radial-gradient(circle at 92% 12%, rgba(var(--belarus-accent-rgb), 0.12), transparent 34%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
}

.belarus-seo-text h2 {
    max-width: 940px;
    margin-top: 0;
    font-size: 42px;
}

.belarus-seo-text p {
    max-width: 1040px;
    margin-top: 22px;
}

.belarus-internal-links {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 24px;
}

.belarus-internal-links a {
    color: var(--belarus-accent);
    text-decoration: none;
}

.belarus-cta {
    padding-top: 70px;
}

.belarus-cta__box {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 34px;
    align-items: center;
    padding: 38px;
    border-color: rgba(var(--belarus-accent-rgb), 0.2);
    background:
        radial-gradient(circle at 86% 20%, rgba(var(--belarus-accent-rgb), 0.14), transparent 34%),
        linear-gradient(145deg, rgba(18, 23, 34, 0.92), rgba(13, 17, 24, 0.98));
}

.belarus-cta h2 {
    margin-top: 18px;
    font-size: 44px;
}

.belarus-cta p {
    max-width: 760px;
    margin-top: 18px;
    margin-bottom: 0;
}

@media (max-width: 1200px) {
    .belarus-hero__grid,
    .belarus-split__grid,
    .belarus-cta__box {
        grid-template-columns: 1fr;
    }

    .belarus-hero__copy h1 {
        font-size: 58px;
    }

    .belarus-card-grid--four,
    .belarus-flow__list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .belarus-cta__box {
        align-items: start;
    }
}

@media (max-width: 820px) {
    .belarus-hero {
        min-height: auto;
        padding: 92px 0 56px;
    }

    .belarus-hero__grid {
        gap: 34px;
    }

    .belarus-hero__copy h1 {
        font-size: 40px;
        line-height: 1.08;
        text-align: center;
    }

    .belarus-hero__copy p,
    .belarus-split p,
    .belarus-seo-text p,
    .belarus-cta p {
        font-size: 15px;
        text-align: center;
    }

    .belarus-chip {
        display: flex;
        margin-right: auto;
        margin-left: auto;
        text-align: center;
    }

    .niche-hero-actions {
        justify-content: center;
    }

    .belarus-dashboard,
    .belarus-route-visual,
    .belarus-editorial-visual,
    .belarus-matrix-visual,
    .belarus-premium-card,
    .belarus-ops-visual {
        min-height: auto;
    }

    .belarus-split,
    .belarus-card-section,
    .belarus-flow,
    .belarus-map-section,
    .belarus-seo-text,
    .belarus-cta {
        padding: 62px 0;
    }

    .belarus-split h2,
    .belarus-section-head h2,
    .belarus-seo-text h2,
    .belarus-cta h2 {
        font-size: 31px;
        line-height: 1.16;
        text-align: center;
    }

    .belarus-section-head {
        margin-right: auto;
        margin-left: auto;
    }

    .belarus-card-grid--four,
    .belarus-card-grid--three,
    .belarus-map-grid,
    .belarus-flow__list,
    .belarus-dashboard,
    .belarus-editorial-visual,
    .belarus-matrix-visual,
    .belarus-premium-card,
    .belarus-ops-visual {
        grid-template-columns: 1fr;
    }

    .belarus-card-grid article,
    .belarus-map-grid article,
    .belarus-flow__list article,
    .belarus-seo-text__box,
    .belarus-cta__box {
        min-height: auto;
        padding: 22px 18px;
        border-radius: 16px;
    }

    .belarus-card-grid h3,
    .belarus-map-grid h3,
    .belarus-flow__list h3 {
        font-size: 20px;
        text-align: center;
    }

    .belarus-card-grid p,
    .belarus-map-grid p,
    .belarus-flow__list p {
        text-align: center;
    }

    .belarus-editorial-visual__poster,
    .belarus-premium-card div:first-child,
    .belarus-ops-visual__hub {
        min-height: 150px;
        font-size: 31px;
        text-align: center;
    }

    .belarus-route-visual div {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .belarus-internal-links,
    .belarus-tag-cloud {
        justify-content: center;
    }

    .belarus-cta__box .niche-primary-btn {
        width: 100%;
    }
}

/* Belarus photo niche pages */
.by-photo-page {
    min-height: 100vh;
    overflow: hidden;
    color: #edf5ff;
    background:
        radial-gradient(circle at 15% 5%, rgba(var(--by-accent-rgb), 0.16), transparent 34%),
        radial-gradient(circle at 85% 18%, color-mix(in srgb, var(--by-accent-2) 23%, transparent), transparent 30%),
        linear-gradient(180deg, #050811 0%, #0a101c 48%, #05070d 100%);
}

.by-photo-page section {
    position: relative;
    padding: 92px 0;
}

.by-photo-page .container {
    position: relative;
    z-index: 2;
}

.by-chip {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 14px;
    border: 1px solid rgba(var(--by-accent-rgb), 0.34);
    border-radius: 999px;
    color: var(--by-accent);
    background: rgba(var(--by-accent-rgb), 0.12);
    font-size: 12px;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.by-photo-hero {
    min-height: 790px;
    display: flex;
    align-items: center;
    padding-top: 132px !important;
}

.by-photo-hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.by-photo-hero__shade {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(3, 6, 13, 0.9) 0%, rgba(5, 9, 18, 0.72) 42%, rgba(5, 9, 18, 0.35) 100%),
        radial-gradient(circle at 24% 22%, rgba(var(--by-accent-rgb), 0.3), transparent 36%),
        linear-gradient(180deg, rgba(5, 8, 16, 0.08), rgba(5, 8, 16, 0.92));
}

.by-photo-hero__content,
.by-map-hero__layout,
.by-ops-hero__grid {
    width: 100%;
}

.by-photo-hero__content h1,
.by-industrial-hero__copy h1,
.by-editorial-hero__copy h1,
.by-map-hero__layout h1,
.by-premium-hero__center h1,
.by-ops-hero__grid h1 {
    max-width: 1010px;
    margin: 18px 0 20px;
    color: #fff;
    font-size: clamp(46px, 6.1vw, 92px);
    line-height: 0.96;
    font-weight: 900;
    letter-spacing: 0;
}

.by-photo-hero__content p,
.by-industrial-hero__copy p,
.by-editorial-hero__copy p,
.by-map-hero__layout p,
.by-premium-hero__center > p,
.by-ops-hero__grid p {
    max-width: 720px;
    margin: 0;
    color: rgba(226, 235, 247, 0.82);
    font-size: 18px;
    line-height: 1.75;
}

.by-photo-page .niche-hero-actions {
    margin-top: 30px;
}

.by-hero-strip {
    position: absolute !important;
    left: 50%;
    bottom: 28px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    transform: translateX(-50%);
}

.by-hero-strip article,
.by-map-hero__layout aside,
.by-ops-panel,
.by-editorial-hero__collage article {
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 22px;
    background: rgba(8, 12, 22, 0.58);
    backdrop-filter: blur(18px);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 20px 70px rgba(0,0,0,0.25);
}

.by-hero-strip article {
    padding: 18px;
}

.by-hero-strip b,
.by-route-line span,
.by-photo-page article b,
.by-ops-panel b {
    display: block;
    color: var(--by-accent);
    font-weight: 900;
}

.by-hero-strip span,
.by-ops-panel span {
    display: block;
    margin-top: 6px;
    color: #fff;
    font-size: 16px;
    font-weight: 760;
}

.by-industrial-hero__grid,
.by-editorial-hero__grid,
.by-photo-split__grid,
.by-story__grid,
.by-switchback__grid,
.by-system-split__grid,
.by-industrial-band__grid,
.by-calm-process__grid {
    display: grid;
    grid-template-columns: minmax(0, 0.82fr) minmax(420px, 0.72fr);
    gap: 58px;
    align-items: center;
}

.by-industrial-hero__photo,
.by-editorial-hero__collage figure,
.by-photo-split figure,
.by-story figure,
.by-switchback figure,
.by-system-split figure,
.by-premium-hero__center figure {
    position: relative;
    overflow: hidden;
    margin: 0;
    border: 1px solid rgba(255, 255, 255, 0.13);
    border-radius: 30px;
    background: linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.024));
    box-shadow: 0 34px 100px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.06);
}

.by-industrial-hero__photo img,
.by-editorial-hero__collage img,
.by-photo-split img,
.by-story img,
.by-switchback img,
.by-system-split img,
.by-premium-hero__center img {
    display: block;
    width: 100%;
    min-height: 420px;
    height: 100%;
    object-fit: cover;
}

.by-industrial-hero__photo figcaption {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    padding: 14px 16px;
    border-radius: 18px;
    color: #fff;
    background: rgba(5, 8, 14, 0.62);
    backdrop-filter: blur(16px);
}

.by-editorial-hero__collage {
    display: grid;
    grid-template-columns: 1fr 0.62fr;
    gap: 16px;
    align-items: stretch;
}

.by-editorial-hero__collage .main {
    grid-row: span 2;
}

.by-editorial-hero__collage article {
    display: flex;
    min-height: 190px;
    align-items: flex-end;
    padding: 22px;
    color: #fff;
    font-size: 24px;
    font-weight: 860;
}

.by-map-hero__layout,
.by-ops-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 0.82fr) minmax(300px, 0.36fr);
    gap: 36px;
    align-items: center;
}

.by-map-hero__layout aside,
.by-ops-panel {
    display: grid;
    gap: 12px;
    padding: 24px;
}

.by-map-hero__layout aside strong {
    color: #fff;
    font-size: 22px;
}

.by-map-hero__layout aside span {
    padding: 14px 16px;
    border-radius: 16px;
    color: #fff;
    background: rgba(255,255,255,0.08);
}

.by-premium-hero__center {
    text-align: center;
}

.by-premium-hero__center .niche-hero-actions {
    justify-content: center;
}

.by-premium-hero__center > p {
    margin: 0 auto;
}

.by-premium-hero__center figure {
    max-width: 980px;
    margin: 42px auto 0;
    aspect-ratio: 16 / 8.4;
}

.by-ops-panel article {
    padding: 16px;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 18px;
    background: rgba(255,255,255,0.06);
}

.by-section__head {
    max-width: 900px;
    margin-bottom: 34px;
}

.by-section__head--split {
    display: grid;
    max-width: none;
    grid-template-columns: minmax(0, 0.8fr) minmax(320px, 0.6fr);
    gap: 30px;
    align-items: end;
}

.by-section__head--center {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.by-section__head h2,
.by-photo-split h2,
.by-story h2,
.by-switchback h2,
.by-industrial-band h2,
.by-calm-process h2,
.by-system-split h2,
.by-seo h2,
.by-cta h2 {
    margin: 14px 0 0;
    color: #fff;
    font-size: clamp(34px, 4.3vw, 62px);
    line-height: 1.02;
    font-weight: 900;
    letter-spacing: 0;
}

.by-section__head p,
.by-photo-split p,
.by-story p,
.by-switchback p,
.by-industrial-band p,
.by-calm-process p,
.by-system-split p,
.by-seo p,
.by-cta p {
    color: rgba(226,235,247,0.76);
    font-size: 16px;
    line-height: 1.75;
}

.by-signal-grid,
.by-route-line,
.by-conditions__grid,
.by-trust__row,
.by-scale__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.by-signal-grid article,
.by-route-line article,
.by-conditions article,
.by-trust__row article,
.by-scale__grid article,
.by-mosaic article,
.by-industrial-band__cards article {
    position: relative;
    overflow: hidden;
    padding: 24px;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 24px;
    background: linear-gradient(145deg, rgba(255,255,255,0.078), rgba(255,255,255,0.025));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.by-photo-page article h3,
.by-route-line h3,
.by-industrial-band__cards h3 {
    margin: 18px 0 10px;
    color: #fff;
    font-size: 23px;
    line-height: 1.16;
    font-weight: 850;
}

.by-photo-page article p {
    margin: 0;
    color: rgba(226,235,247,0.72);
    line-height: 1.68;
}

.by-photo-split,
.by-story,
.by-switchback,
.by-system-split,
.by-industrial-band,
.by-calm-process {
    background: rgba(255,255,255,0.018);
}

.by-check-list {
    display: grid;
    gap: 12px;
    padding: 0;
    margin: 24px 0 0;
    list-style: none;
}

.by-check-list li {
    position: relative;
    padding-left: 28px;
    color: rgba(238,246,255,0.82);
    line-height: 1.6;
}

.by-check-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.68em;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--by-accent);
    box-shadow: 0 0 18px rgba(var(--by-accent-rgb),0.62);
}

.by-industrial-band__cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.by-mosaic__grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr 0.8fr;
    grid-auto-rows: minmax(210px, auto);
    gap: 16px;
}

.by-mosaic article.wide { grid-column: span 2; }
.by-mosaic article.tall { grid-row: span 2; }

.by-calm-process ol {
    display: grid;
    gap: 14px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.by-calm-process li {
    display: grid;
    grid-template-columns: 52px 1fr;
    gap: 16px;
    align-items: center;
    padding: 18px;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 22px;
    background: rgba(255,255,255,0.05);
}

.by-calm-process li span {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 16px;
    color: #06111c;
    background: linear-gradient(135deg, var(--by-accent), var(--by-accent-2));
    font-weight: 900;
}

.by-seo__box,
.by-cta__box {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    padding: 34px;
    border: 1px solid rgba(255,255,255,0.11);
    border-radius: 30px;
    background: radial-gradient(circle at 12% 0%, rgba(var(--by-accent-rgb),0.16), transparent 32%), linear-gradient(145deg, rgba(255,255,255,0.075), rgba(255,255,255,0.026));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.by-seo__box { grid-template-columns: 1fr; }

.by-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
}

.by-links a {
    display: inline-flex;
    min-height: 42px;
    align-items: center;
    padding: 0 15px;
    border: 1px solid rgba(var(--by-accent-rgb),0.22);
    border-radius: 999px;
    color: #eef7ff;
    background: rgba(var(--by-accent-rgb),0.08);
    text-decoration: none;
}

.by-links a:hover {
    color: #fff;
    border-color: rgba(var(--by-accent-rgb),0.42);
}

.by-cta__box .niche-primary-btn { white-space: nowrap; }

@media (max-width: 1180px) {
    .by-industrial-hero__grid,
    .by-editorial-hero__grid,
    .by-photo-split__grid,
    .by-story__grid,
    .by-switchback__grid,
    .by-system-split__grid,
    .by-industrial-band__grid,
    .by-calm-process__grid,
    .by-map-hero__layout,
    .by-ops-hero__grid,
    .by-section__head--split {
        grid-template-columns: 1fr;
    }

    .by-signal-grid,
    .by-route-line,
    .by-conditions__grid,
    .by-trust__row,
    .by-scale__grid,
    .by-industrial-band__cards {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .by-hero-strip {
        position: relative !important;
        left: auto;
        bottom: auto;
        margin-top: 34px;
        transform: none;
    }
}

@media (max-width: 760px) {
    .by-photo-page section { padding: 68px 0; }
    .by-photo-hero { min-height: auto; padding-top: 112px !important; }
    .by-photo-hero--full,
    .by-photo-hero--map,
    .by-photo-hero--ops { padding-bottom: 42px; }
    .by-photo-hero__content h1,
    .by-industrial-hero__copy h1,
    .by-editorial-hero__copy h1,
    .by-map-hero__layout h1,
    .by-premium-hero__center h1,
    .by-ops-hero__grid h1 { font-size: 42px; }
    .by-photo-hero__content p,
    .by-industrial-hero__copy p,
    .by-editorial-hero__copy p,
    .by-map-hero__layout p,
    .by-premium-hero__center > p,
    .by-ops-hero__grid p { font-size: 16px; }
    .by-hero-strip,
    .by-signal-grid,
    .by-route-line,
    .by-conditions__grid,
    .by-trust__row,
    .by-scale__grid,
    .by-industrial-band__cards,
    .by-mosaic__grid,
    .by-editorial-hero__collage {
        grid-template-columns: 1fr;
    }
    .by-mosaic article.wide,
    .by-mosaic article.tall,
    .by-editorial-hero__collage .main {
        grid-column: auto;
        grid-row: auto;
    }
    .by-industrial-hero__photo img,
    .by-editorial-hero__collage img,
    .by-photo-split img,
    .by-story img,
    .by-switchback img,
    .by-system-split img,
    .by-premium-hero__center img { min-height: 300px; }
    .by-seo__box,
    .by-cta__box {
        grid-template-columns: 1fr;
        padding: 22px;
    }
    .by-cta__box .niche-primary-btn {
        width: 100%;
        justify-content: center;
        white-space: normal;
    }
}

/* STO photo hero refresh */
.sto-photo-hero {
    position: relative;
    min-height: 790px;
    display: flex;
    align-items: center;
    padding: 132px 0 70px !important;
    overflow: hidden;
    background: #050811;
}

.sto-photo-hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sto-photo-hero__shade {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(3, 6, 13, 0.92) 0%, rgba(6, 10, 18, 0.76) 46%, rgba(6, 10, 18, 0.28) 100%),
        radial-gradient(circle at 28% 22%, rgba(245, 200, 76, 0.26), transparent 36%),
        linear-gradient(180deg, rgba(5, 8, 16, 0.05), rgba(5, 8, 16, 0.92));
}

.sto-photo-hero__content {
    position: relative;
    z-index: 2;
}

.sto-photo-hero h1 {
    max-width: 980px;
    margin: 18px 0 20px;
    color: #fff;
    font-size: clamp(46px, 6vw, 88px);
    line-height: 0.96;
    font-weight: 900;
    letter-spacing: 0;
}

.sto-photo-hero p {
    max-width: 690px;
    margin: 0;
    color: rgba(236, 241, 248, 0.82);
    font-size: 18px;
    line-height: 1.72;
}

.sto-photo-hero .niche-hero-actions {
    margin-top: 30px;
}

.sto-photo-hero__cards {
    display: grid;
    max-width: 860px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 44px;
}

.sto-photo-hero__cards article {
    padding: 18px;
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 22px;
    background: rgba(8, 12, 22, 0.58);
    backdrop-filter: blur(18px);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 20px 70px rgba(0,0,0,0.25);
}

.sto-photo-hero__cards b {
    display: block;
    color: #f5c84c;
    font-weight: 900;
}

.sto-photo-hero__cards span {
    display: block;
    margin-top: 6px;
    color: #fff;
    font-size: 16px;
    font-weight: 760;
}

@media (max-width: 760px) {
    .sto-photo-hero {
        min-height: auto;
        padding: 112px 0 46px !important;
    }

    .sto-photo-hero h1 {
        font-size: 42px;
    }

    .sto-photo-hero p {
        font-size: 16px;
    }

    .sto-photo-hero__cards {
        grid-template-columns: 1fr;
        margin-top: 30px;
    }
}
/* Service niche layout variety */
.realtor-page .studio-suite__board {
    grid-template-columns: 1.18fr 0.9fr 0.9fr;
}

.dealer-page .studio-suite__board {
    grid-template-columns: 0.86fr 1.22fr 0.86fr;
    align-items: stretch;
}

.dealer-page .studio-suite__solution {
    transform: translateY(-22px);
}

.dealer-page .studio-suite__process ol {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.dealer-page .studio-suite__process ol li {
    grid-template-columns: 1fr;
    align-content: start;
}

.sto-page .studio-suite__board {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
}

.sto-page .studio-suite__result {
    grid-column: 1 / -1;
    min-height: 220px;
}

.sto-page .studio-suite__process {
    display: grid;
    grid-template-columns: minmax(0, 0.48fr) minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.sto-page .studio-suite__process ol {
    margin: 0;
}

@media (max-width: 1180px) {
    .realtor-page .studio-suite__board,
    .dealer-page .studio-suite__board,
    .sto-page .studio-suite__board,
    .sto-page .studio-suite__process {
        grid-template-columns: 1fr;
    }

    .dealer-page .studio-suite__solution {
        transform: none;
    }

    .dealer-page .studio-suite__process ol {
        grid-template-columns: 1fr;
    }

    .sto-page .studio-suite__result {
        grid-column: auto;
    }
}

/* Belarus photo page polish */
.by-photo-page {
    background:
        radial-gradient(circle at 14% 6%, rgba(var(--by-accent-rgb), 0.20), transparent 36%),
        radial-gradient(circle at 84% 16%, rgba(var(--by-accent-rgb), 0.12), transparent 32%),
        linear-gradient(180deg, #050811 0%, #0a101c 48%, #05070d 100%);
}

.by-photo-page figure,
.by-photo-page img {
    max-width: 100%;
}

.by-photo-page figure {
    margin: 0;
}

.by-photo-page img {
    display: block;
}

.by-photo-page .niche-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
}

.by-photo-page .niche-primary-btn,
.by-photo-page a.niche-primary-btn {
    position: relative;
    isolation: isolate;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    padding: 0 28px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 999px;
    color: #06111c !important;
    background: linear-gradient(135deg, var(--by-accent) 0%, var(--by-accent-2) 100%);
    box-shadow: 0 20px 48px rgba(var(--by-accent-rgb), 0.30), inset 0 1px 0 rgba(255, 255, 255, 0.38);
    font-size: 16px;
    font-weight: 950;
    line-height: 1.1;
    text-decoration: none !important;
    letter-spacing: 0;
    overflow: hidden;
    transform: translateZ(0);
}

.by-photo-page .niche-primary-btn::before {
    content: '';
    position: absolute;
    inset: 1px;
    z-index: -1;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.36), rgba(255, 255, 255, 0));
    opacity: 0.62;
}

.by-photo-page .niche-primary-btn:hover,
.by-photo-page .niche-primary-btn:focus-visible {
    color: #06111c !important;
    transform: translateY(-2px);
    box-shadow: 0 26px 60px rgba(var(--by-accent-rgb), 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.by-photo-page .niche-primary-btn:focus-visible,
.by-photo-page .niche-text-link:focus-visible {
    outline: 3px solid rgba(var(--by-accent-rgb), 0.42);
    outline-offset: 4px;
}

.by-photo-page .niche-text-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 18px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    color: #f3f8ff;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    text-decoration: none !important;
    backdrop-filter: blur(16px);
}

.by-photo-page .niche-text-link:hover {
    color: #fff;
    border-color: rgba(var(--by-accent-rgb), 0.42);
    background: rgba(var(--by-accent-rgb), 0.14);
}

.by-photo-page .by-cta__box .niche-primary-btn {
    min-width: 230px;
    white-space: normal;
}

.by-rich-band {
    position: relative;
    padding: 98px 0;
}

.by-rich-band::before {
    content: '';
    position: absolute;
    inset: 8% -12% auto auto;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--by-accent-rgb), 0.16), transparent 70%);
    pointer-events: none;
}

.by-rich-layout,
.by-rich-route,
.by-rich-gallery,
.by-rich-market,
.by-rich-trust,
.by-growth-board {
    display: grid;
    gap: 24px;
}

.by-rich-layout,
.by-rich-route,
.by-rich-market,
.by-rich-trust {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    align-items: stretch;
}

.by-rich-copy,
.by-rich-route__intro,
.by-market-map,
.by-trust-panel,
.by-growth-head,
.by-rich-cards article,
.by-rich-timeline article,
.by-rich-notes article,
.by-trust-list article,
.by-growth-lanes article,
.by-gallery-strip article {
    border: 1px solid rgba(255, 255, 255, 0.13);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.045));
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(18px);
}

.by-rich-copy,
.by-rich-route__intro,
.by-market-map,
.by-trust-panel,
.by-growth-head {
    padding: 30px;
    border-radius: 30px;
}

.by-rich-copy h2,
.by-rich-route__intro h2,
.by-gallery-strip h2,
.by-market-map h2,
.by-trust-panel h2,
.by-growth-head h2 {
    margin: 18px 0 14px;
    color: #fff;
    font-size: clamp(30px, 4vw, 54px);
    line-height: 1.02;
    letter-spacing: 0;
}

.by-rich-copy p,
.by-rich-route__intro p,
.by-gallery-strip p,
.by-market-map p,
.by-trust-panel p,
.by-growth-head p,
.by-rich-cards p,
.by-rich-timeline p,
.by-rich-notes p,
.by-trust-list p,
.by-growth-lanes p {
    color: rgba(237, 245, 255, 0.76);
}

.by-rich-media,
.by-rich-image,
.by-growth-photo,
.by-gallery-strip figure {
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 26px;
    background: rgba(255, 255, 255, 0.06);
    box-shadow: 0 28px 80px rgba(0, 0, 0, 0.32);
}

.by-rich-media,
.by-rich-image {
    margin-top: 24px;
    aspect-ratio: 16 / 9;
}

.by-rich-media img,
.by-rich-image img,
.by-growth-photo img,
.by-gallery-strip figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(1.08) contrast(1.04);
}

.by-rich-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.by-rich-cards article,
.by-trust-list article,
.by-growth-lanes article,
.by-rich-notes article,
.by-gallery-strip article {
    padding: 24px;
    border-radius: 24px;
}

.by-rich-cards article b,
.by-rich-timeline article b,
.by-rich-notes article b,
.by-growth-lanes article b {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 34px;
    margin-bottom: 18px;
    padding: 0 12px;
    border-radius: 999px;
    color: var(--by-accent);
    background: rgba(var(--by-accent-rgb), 0.14);
    font-size: 12px;
    font-weight: 950;
}

.by-rich-cards h3,
.by-rich-timeline h3,
.by-gallery-strip h3,
.by-trust-list h3,
.by-growth-lanes h3 {
    margin: 0 0 10px;
    color: #fff;
    font-size: 21px;
    line-height: 1.18;
}

.by-rich-route {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
}

.by-rich-timeline {
    display: grid;
    gap: 16px;
}

.by-rich-timeline article {
    position: relative;
    padding: 26px 26px 26px 84px;
    border-radius: 26px;
}

.by-rich-timeline article b {
    position: absolute;
    left: 24px;
    top: 26px;
}

.by-rich-gallery {
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr);
}

.by-gallery-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.by-gallery-strip figure {
    grid-column: 1 / -1;
    min-height: 330px;
}

.by-gallery-strip article:first-of-type {
    grid-column: 1 / -1;
}

.by-rich-notes,
.by-trust-list,
.by-growth-lanes {
    display: grid;
    gap: 16px;
}

.by-rich-notes {
    align-content: stretch;
}

.by-rich-notes article {
    display: grid;
    grid-template-columns: 54px 1fr;
    align-items: start;
    gap: 16px;
}

.by-rich-notes article b {
    margin: 0;
}

.by-market-map {
    min-height: 470px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background:
        linear-gradient(145deg, rgba(var(--by-accent-rgb), 0.16), rgba(255, 255, 255, 0.045)),
        radial-gradient(circle at 78% 18%, rgba(255, 255, 255, 0.16), transparent 32%);
}

.by-market-points {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 28px;
}

.by-market-points span {
    min-height: 72px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 20px;
    color: #fff;
    background: rgba(255, 255, 255, 0.075);
    font-weight: 900;
}

.by-rich-cards--wide {
    align-self: stretch;
}

.by-rich-trust {
    grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
}

.by-trust-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.by-growth-board {
    grid-template-columns: 1fr;
}

.by-growth-head {
    max-width: 940px;
}

.by-growth-lanes {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.by-growth-photo {
    aspect-ratio: 21 / 8;
}

@media (max-width: 980px) {
    .by-rich-layout,
    .by-rich-route,
    .by-rich-gallery,
    .by-rich-market,
    .by-rich-trust,
    .by-growth-lanes {
        grid-template-columns: 1fr;
    }

    .by-rich-copy h2,
    .by-rich-route__intro h2,
    .by-gallery-strip h2,
    .by-market-map h2,
    .by-trust-panel h2,
    .by-growth-head h2 {
        font-size: clamp(28px, 8vw, 42px);
    }

    .by-gallery-strip figure,
    .by-growth-photo {
        aspect-ratio: 16 / 10;
        min-height: 0;
    }
}

@media (max-width: 760px) {
    .by-photo-page .niche-hero-actions,
    .by-photo-page .niche-primary-btn,
    .by-photo-page .niche-text-link,
    .by-photo-page .by-cta__box .niche-primary-btn {
        width: 100%;
    }

    .by-photo-page .niche-primary-btn,
    .by-photo-page .niche-text-link {
        min-height: 56px;
        padding-inline: 18px;
        text-align: center;
    }

    .by-rich-band {
        padding: 68px 0;
    }

    .by-rich-copy,
    .by-rich-route__intro,
    .by-market-map,
    .by-trust-panel,
    .by-growth-head,
    .by-rich-cards article,
    .by-rich-timeline article,
    .by-rich-notes article,
    .by-trust-list article,
    .by-growth-lanes article,
    .by-gallery-strip article {
        padding: 20px;
        border-radius: 22px;
    }

    .by-rich-cards,
    .by-gallery-strip,
    .by-trust-list,
    .by-market-points {
        grid-template-columns: 1fr;
    }

    .by-rich-timeline article {
        padding-left: 20px;
    }

    .by-rich-timeline article b {
        position: static;
    }

    .by-rich-notes article {
        grid-template-columns: 1fr;
    }
}




/* Belarus city architecture upgrade */
.by-hero-label {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 34px;
    margin-bottom: 16px;
    padding: 0 14px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    color: #fff;
    background: rgba(255, 255, 255, 0.10);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(16px);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.by-city-lab {
    position: relative;
    overflow: hidden;
    padding: 92px 0;
    background:
        linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px),
        radial-gradient(circle at 18% 12%, rgba(var(--by-accent-rgb), 0.16), transparent 32%),
        rgba(8, 13, 24, 0.86);
    background-size: 38px 38px, 38px 38px, auto, auto;
}

.by-city-lab::before {
    content: '';
    position: absolute;
    inset: auto -160px -220px auto;
    width: 520px;
    height: 520px;
    border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--by-accent-2) 20%, transparent), transparent 70%);
    pointer-events: none;
}

.by-minsk-lab,
.by-industrial-console,
.by-border-map,
.by-growth-console {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    gap: 24px;
    align-items: stretch;
}

.by-lab-copy,
.by-console-panel,
.by-border-copy,
.by-growth-copy,
.by-comparison-board article,
.by-console-screen,
.by-border-routes article,
.by-proof-gallery article,
.by-proof-title,
.by-growth-matrix article,
.by-spread-note,
.by-editorial-spread article {
    border: 1px solid rgba(255, 255, 255, 0.13);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.105), rgba(255, 255, 255, 0.04));
    box-shadow: 0 26px 76px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(18px) saturate(130%);
}

.by-lab-copy,
.by-console-panel,
.by-border-copy,
.by-growth-copy,
.by-console-screen,
.by-proof-title,
.by-spread-note {
    padding: 30px;
    border-radius: 28px;
}

.by-lab-copy h2,
.by-console-panel h2,
.by-border-copy h2,
.by-growth-copy h2,
.by-proof-title h2,
.by-spread-note h2 {
    margin: 18px 0 14px;
    color: #fff;
    font-size: clamp(30px, 4.2vw, 56px);
    line-height: 1.02;
    letter-spacing: 0;
}

.by-lab-copy p,
.by-console-panel p,
.by-border-copy p,
.by-growth-copy p,
.by-spread-note p,
.by-comparison-board p,
.by-proof-gallery p {
    margin: 0;
    color: rgba(237, 245, 255, 0.74);
    line-height: 1.72;
}

.by-comparison-board {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.by-comparison-board article {
    position: relative;
    min-height: 164px;
    padding: 24px;
    border-radius: 24px;
    overflow: hidden;
}

.by-comparison-board article::after {
    content: '';
    position: absolute;
    right: -34px;
    bottom: -52px;
    width: 140px;
    height: 140px;
    border: 1px solid rgba(var(--by-accent-rgb), 0.20);
    border-radius: 50%;
}

.by-comparison-board article.is-active {
    border-color: rgba(var(--by-accent-rgb), 0.38);
    background: linear-gradient(135deg, rgba(var(--by-accent-rgb), 0.18), rgba(255, 255, 255, 0.05));
}

.by-comparison-board span,
.by-spread-note > span {
    display: block;
    margin-bottom: 14px;
    color: var(--by-accent);
    font-size: 12px;
    font-weight: 950;
    text-transform: uppercase;
}

.by-comparison-board h3,
.by-proof-gallery h3 {
    margin: 0 0 10px;
    color: #fff;
    font-size: 24px;
    line-height: 1.16;
}

.by-console-screen {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.by-console-screen div,
.by-growth-matrix article,
.by-border-routes article,
.by-editorial-spread article {
    display: flex;
    min-height: 128px;
    flex-direction: column;
    justify-content: space-between;
    padding: 22px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.065);
}

.by-console-screen b,
.by-growth-matrix b,
.by-border-routes b,
.by-editorial-spread b,
.by-proof-gallery b {
    color: var(--by-accent);
    font-size: 13px;
    font-weight: 950;
    text-transform: uppercase;
}

.by-console-screen span,
.by-growth-matrix span,
.by-border-routes span,
.by-editorial-spread span {
    color: #fff;
    font-size: 18px;
    font-weight: 850;
    line-height: 1.22;
}

.by-editorial-spread {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: 18px;
    align-items: stretch;
}

.by-editorial-spread figure {
    grid-row: span 2;
    min-height: 520px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.13);
    border-radius: 30px;
    box-shadow: 0 28px 90px rgba(0, 0, 0, 0.34);
}

.by-editorial-spread figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.by-border-map {
    grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
}

.by-border-routes,
.by-growth-matrix {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.by-border-routes article:nth-child(2),
.by-growth-matrix article:nth-child(3) {
    transform: translateY(26px);
}

.by-proof-gallery {
    display: grid;
    grid-template-columns: 1.18fr repeat(3, minmax(0, 0.7fr));
    gap: 16px;
    align-items: stretch;
}

.by-proof-gallery article {
    min-height: 310px;
    padding: 24px;
    border-radius: 26px;
}

.by-proof-gallery article:nth-of-type(2) {
    transform: translateY(28px);
}

.by-proof-gallery article:nth-of-type(3) {
    transform: translateY(56px);
}

.by-growth-console {
    grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
}

@media (max-width: 980px) {
    .by-minsk-lab,
    .by-industrial-console,
    .by-editorial-spread,
    .by-border-map,
    .by-proof-gallery,
    .by-growth-console {
        grid-template-columns: 1fr;
    }

    .by-editorial-spread figure {
        grid-row: auto;
        min-height: 320px;
    }

    .by-border-routes article:nth-child(2),
    .by-growth-matrix article:nth-child(3),
    .by-proof-gallery article:nth-of-type(2),
    .by-proof-gallery article:nth-of-type(3) {
        transform: none;
    }
}

@media (max-width: 760px) {
    .by-city-lab {
        padding: 66px 0;
    }

    .by-lab-copy,
    .by-console-panel,
    .by-border-copy,
    .by-growth-copy,
    .by-console-screen,
    .by-proof-title,
    .by-spread-note,
    .by-comparison-board article,
    .by-proof-gallery article {
        padding: 20px;
        border-radius: 22px;
    }

    .by-console-screen,
    .by-border-routes,
    .by-growth-matrix {
        grid-template-columns: 1fr;
    }

    .by-lab-copy h2,
    .by-console-panel h2,
    .by-border-copy h2,
    .by-growth-copy h2,
    .by-proof-title h2,
    .by-spread-note h2 {
        font-size: clamp(28px, 9vw, 40px);
    }
}

/* Grodno first screen fix */
.by-grodno .by-photo-hero--premium {
    min-height: 760px;
    padding: 128px 0 82px !important;
    align-items: center;
    background:
        radial-gradient(circle at 12% 18%, rgba(var(--by-accent-rgb), 0.18), transparent 34%),
        radial-gradient(circle at 88% 6%, rgba(20, 184, 166, 0.12), transparent 28%),
        linear-gradient(135deg, #071119 0%, #091725 48%, #050910 100%);
}
.by-grodno .by-photo-hero--premium::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.016) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: linear-gradient(180deg, rgba(0,0,0,0.75), transparent 92%);
    pointer-events: none;
}
.by-grodno .by-premium-hero__center {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(420px, 0.82fr);
    gap: 58px;
    align-items: center;
    text-align: left;
}
.by-grodno .by-grodno-hero__copy { max-width: 720px; }
.by-grodno .by-premium-hero__center h1 {
    max-width: 720px;
    margin: 16px 0 22px;
    font-size: clamp(48px, 5.2vw, 78px);
    line-height: 0.98;
}
.by-grodno .by-premium-hero__center > p,
.by-grodno .by-grodno-hero__copy > p {
    max-width: 620px;
    margin: 0;
    color: rgba(237, 245, 255, 0.80);
    font-size: 18px;
    line-height: 1.72;
}
.by-grodno .by-premium-hero__center .niche-hero-actions {
    justify-content: flex-start;
    margin-top: 30px;
}
.by-grodno .by-premium-hero__center figure {
    position: relative;
    max-width: none;
    width: 100%;
    margin: 0;
    aspect-ratio: 4 / 5;
    border-radius: 34px;
    border-color: rgba(var(--by-accent-rgb), 0.22);
    box-shadow: 0 34px 110px rgba(0,0,0,0.42), 0 0 0 1px rgba(255,255,255,0.05) inset;
}
.by-grodno .by-premium-hero__center figure::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, transparent 48%, rgba(3, 8, 14, 0.70));
    pointer-events: none;
}
.by-grodno .by-premium-hero__center img {
    min-height: 0;
    height: 100%;
    object-fit: cover;
}
.by-grodno .by-premium-hero__center figcaption {
    position: absolute;
    left: 22px;
    right: 22px;
    bottom: 22px;
    z-index: 2;
    padding: 17px 18px;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 20px;
    color: rgba(245, 250, 255, 0.90);
    background: rgba(4, 10, 18, 0.62);
    backdrop-filter: blur(18px);
    font-size: 14px;
    line-height: 1.45;
}
.by-grodno-hero__points {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    max-width: 610px;
    margin-top: 34px;
}
.by-grodno-hero__points article {
    min-height: 112px;
    padding: 18px;
    border: 1px solid rgba(255,255,255,0.13);
    border-radius: 22px;
    background: linear-gradient(145deg, rgba(255,255,255,0.105), rgba(255,255,255,0.04));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
    backdrop-filter: blur(16px);
}
.by-grodno-hero__points b {
    display: block;
    margin-bottom: 18px;
    color: var(--by-accent);
    font-size: 12px;
    font-weight: 950;
}
.by-grodno-hero__points span {
    display: block;
    color: #fff;
    font-size: 17px;
    font-weight: 850;
    line-height: 1.18;
}
@media (max-width: 1050px) {
    .by-grodno .by-premium-hero__center { grid-template-columns: 1fr; gap: 38px; }
    .by-grodno .by-premium-hero__center figure { aspect-ratio: 16 / 10; }
}
@media (max-width: 760px) {
    .by-grodno .by-photo-hero--premium { padding: 112px 0 54px !important; }
    .by-grodno .by-premium-hero__center h1 { font-size: clamp(38px, 12vw, 48px); }
    .by-grodno-hero__points { grid-template-columns: 1fr; }
    .by-grodno .by-premium-hero__center figure { aspect-ratio: 4 / 3.5; border-radius: 24px; }
    .by-grodno .by-premium-hero__center figcaption { position: static; margin: 12px; }
}

/* Minsk realtor-inspired rebuild */
.minsk-realtor-style-page {
    --page-accent: #58c7ff;
    --page-accent-2: #8b5cf6;
    --page-accent-rgb: 88, 199, 255;
    color: #f6fbff;
    background:
        radial-gradient(circle at 12% 6%, rgba(88, 199, 255, .18), transparent 32%),
        radial-gradient(circle at 88% 18%, rgba(139, 92, 246, .16), transparent 34%),
        linear-gradient(180deg, #070b13 0%, #0b111c 45%, #06080e 100%);
    overflow: hidden;
}

.minsk-realtor-style-page .niche-primary-btn {
    color: #061016;
    background: linear-gradient(135deg, #6ee7ff, #8b5cf6);
    box-shadow: 0 18px 50px rgba(88, 199, 255, .24);
}

.minsk-realtor-style-page h1,
.minsk-realtor-style-page h2,
.minsk-realtor-style-page h3 {
    letter-spacing: 0;
}

.minsk-kicker {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 10px;
    color: #7be8ff;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.minsk-kicker::before {
    content: "";
    width: 24px;
    height: 1px;
    background: currentColor;
    opacity: .75;
}

.minsk-hero-v2 {
    position: relative;
    min-height: 100svh;
    max-height: 980px;
    padding-top: 88px;
    overflow: hidden;
}

.minsk-hero-v2__media {
    position: absolute;
    inset: 0;
}

.minsk-hero-v2__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(5, 9, 15, .96) 0%, rgba(5, 9, 15, .78) 42%, rgba(5, 9, 15, .2) 78%),
        linear-gradient(0deg, rgba(5, 9, 15, .88), transparent 52%);
}

.minsk-hero-v2__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 62% center;
    filter: saturate(1.05) contrast(1.04);
}

.minsk-hero-v2__content {
    position: relative;
    z-index: 2;
    display: flex;
    min-height: calc(100svh - 88px);
    max-width: 1840px;
    flex-direction: column;
    justify-content: center;
    padding-bottom: 96px;
}

.minsk-hero-v2__content > * {
    max-width: 760px;
}

.minsk-hero-v2 h1 {
    margin: 18px 0 0;
    font-size: clamp(48px, 6.4vw, 80px);
    line-height: .92;
    max-width: 860px;
}

.minsk-hero-v2 p {
    margin: 28px 0 0;
    max-width: 690px;
    color: #cad9e5;
    font-size: 19px;
    line-height: 1.75;
}

.minsk-hero-v2 .niche-hero-actions {
    margin-top: 34px;
}

.minsk-hero-v2__panel {
    position: absolute;
    z-index: 3;
    right: max(28px, calc((100vw - 1180px) / 2));
    bottom: 54px;
    display: grid;
    width: min(420px, 42vw);
    grid-template-columns: repeat(3, minmax(0, 1fr));
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 24px;
    background: rgba(9, 15, 25, .52);
    backdrop-filter: blur(18px);
    box-shadow: 0 30px 80px rgba(0, 0, 0, .32);
}

.minsk-hero-v2__panel div {
    min-height: 132px;
    padding: 22px;
    border-right: 1px solid rgba(255, 255, 255, .12);
}

.minsk-hero-v2__panel div:last-child { border-right: 0; }
.minsk-hero-v2__panel span { color: #7be8ff; font-weight: 900; }
.minsk-hero-v2__panel b { display: block; margin-top: 16px; font-size: 18px; }
.minsk-hero-v2__panel small { display: block; margin-top: 7px; color: #a9b7c3; line-height: 1.45; }

.minsk-system,
.minsk-market,
.minsk-route,
.minsk-board,
.minsk-seo,
.minsk-cta {
    position: relative;
    padding: 118px 0;
}

.minsk-system {
    background:
        linear-gradient(180deg, rgba(88, 199, 255, .05), transparent),
        #0b111c;
}

.minsk-system__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.85fr);
    gap: 54px;
    align-items: center;
}

.minsk-system__intro h2,
.minsk-market__head h2,
.minsk-route__copy h2,
.minsk-board__copy h2,
.minsk-seo__box h2,
.minsk-cta__box h2 {
    margin: 18px 0 0;
    font-size: clamp(34px, 4vw, 62px);
    line-height: 1.02;
}

.minsk-system__intro p,
.minsk-route__copy p,
.minsk-board__copy p,
.minsk-seo__box p,
.minsk-cta__box p {
    color: #b8c7d4;
    font-size: 17px;
    line-height: 1.75;
    margin-top: 16px;
}

.minsk-system__diagram {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.minsk-system__diagram article,
.minsk-market__grid article,
.minsk-board__visual,
.minsk-seo__box,
.minsk-cta__box {
    border: 1px solid rgba(255, 255, 255, .12);
    background: linear-gradient(145deg, rgba(255,255,255,.09), rgba(255,255,255,.035));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 24px 80px rgba(0,0,0,.22);
    backdrop-filter: blur(18px);
}

.minsk-system__diagram article {
    min-height: 220px;
    padding: 28px;
    border-radius: 22px;
}

.minsk-system__diagram .is-main {
    grid-row: span 2;
    min-height: 456px;
    background:
        radial-gradient(circle at 72% 18%, rgba(88,199,255,.28), transparent 34%),
        linear-gradient(145deg, rgba(88,199,255,.16), rgba(255,255,255,.04));
}

.minsk-system__diagram span,
.minsk-market__grid b,
.minsk-route__steps span {
    color: #7be8ff;
    font-weight: 900;
}

.minsk-system__diagram h3,
.minsk-market__grid h3 {
    margin: 18px 0 12px;
    font-size: 25px;
}

.minsk-system__diagram p,
.minsk-market__grid p,
.minsk-route__steps p,
.minsk-board__copy li {
    color: #adbdc9;
    line-height: 1.65;
}

.minsk-market {
    background: #070b13;
}

.minsk-market__head {
    display: grid;
    grid-template-columns: .58fr 1fr;
    gap: 42px;
    align-items: end;
    margin-bottom: 48px;
}

.minsk-market__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.minsk-market__grid article {
    min-height: 292px;
    padding: 28px;
    border-radius: 18px;
}

.minsk-market__grid article:nth-child(even) {
    transform: translateY(32px);
}

.minsk-route {
    background:
        radial-gradient(circle at 18% 36%, rgba(139,92,246,.16), transparent 28%),
        #0e1420;
}

.minsk-route__layout {
    display: grid;
    grid-template-columns: minmax(0, .78fr) minmax(0, 1.22fr);
    gap: 70px;
    align-items: start;
}

.minsk-route__copy {
    position: sticky;
    top: 120px;
}

.minsk-route__steps {
    display: grid;
    gap: 14px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.minsk-route__steps li {
    display: grid;
    grid-template-columns: 40px 1fr;
    gap: 22px;
    padding: 26px;
    border: 1px solid rgba(255, 255, 255, .11);
    border-radius: 22px;
    background: rgba(255, 255, 255, .045);
}

.minsk-route__steps h3 {
    margin: 0 0 8px;
    font-size: 24px;
}

.minsk-route__steps p { margin: 0; }

.minsk-board {
    background: #070b13;
}

.minsk-board__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, .92fr);
    gap: 50px;
    align-items: center;
}

.minsk-board__visual {
    position: relative;
    display: grid;
    gap: 14px;
    min-height: 470px;
    padding: 26px;
    border-radius: 26px;
    overflow: hidden;
}

.minsk-board__visual::before {
    content: "";
    position: absolute;
    inset: auto -12% -22% 34%;
    height: 260px;
    background: radial-gradient(circle, rgba(88,199,255,.28), transparent 62%);
}

.minsk-board__top {
    display: flex;
    gap: 8px;
    position: relative;
    z-index: 1;
}

.minsk-board__top span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255,255,255,.35);
}

.minsk-board__row {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 24px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 18px;
    background: rgba(8, 14, 24, .72);
}

.minsk-board__row.is-wide {
    min-height: 82px;
    align-items: end;
    background: linear-gradient(135deg, rgba(88, 199, 255, .18), rgba(139, 92, 246, .12));
}

.minsk-board__row.is-accent {
    background: linear-gradient(135deg, rgba(88,199,255,.28), rgba(88,199,255,.06));
}

.minsk-board__row b { font-size: 19px; }
.minsk-board__row small { color: #9eafbd; text-align: right; }
.minsk-board__copy ul { display: grid; gap: 12px; margin: 24px 0 0; padding: 0; list-style: none; }
.minsk-board__copy li { position: relative; padding-left: 28px; }
.minsk-board__copy li::before { content: ""; position: absolute; left: 0; top: .72em; width: 12px; height: 2px; background: #7be8ff; }

.minsk-seo {
    padding-top: 104px;
    background: linear-gradient(180deg, #070b13, #0d1320);
}

.minsk-seo__box {
    border-radius: 26px;
    padding: 46px;
}

.minsk-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 26px;
}

.minsk-links a {
    display: inline-flex;
    padding: 11px 16px;
    border: 1px solid rgba(123,232,255,.24);
    border-radius: 999px;
    color: #dff9ff;
    background: rgba(123,232,255,.08);
    text-decoration: none;
}

.minsk-cta {
    padding-top: 54px;
    padding-bottom: 130px;
    background: #0d1320;
}

.minsk-cta__box {
    display: flex;
    gap: 36px;
    align-items: center;
    justify-content: space-between;
    border-radius: 26px;
    padding: 42px;
    background:
        radial-gradient(circle at 82% 22%, rgba(88,199,255,.24), transparent 32%),
        linear-gradient(145deg, rgba(255,255,255,.09), rgba(255,255,255,.035));
}

.minsk-cta__box > div { max-width: 790px; }

@media (max-width: 1180px) {
    .minsk-hero-v2__panel {
        position: relative;
        right: auto;
        bottom: auto;
        width: auto;
        margin: -94px 24px 50px;
    }

    .minsk-system__grid,
    .minsk-route__layout,
    .minsk-board__grid,
    .minsk-market__head {
        grid-template-columns: 1fr;
    }

    .minsk-route__copy { position: static; }
    .minsk-market__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .minsk-market__grid article:nth-child(even) { transform: none; }
}

@media (max-width: 760px) {
    .minsk-hero-v2 {
        min-height: auto;
        max-height: none;
        padding-top: 82px;
    }

    .minsk-hero-v2__media {
        position: relative;
        height: 380px;
        margin-bottom: -86px;
    }

    .minsk-hero-v2__media::after {
        background:
            linear-gradient(0deg, #070b13 0%, rgba(7,11,19,.84) 36%, rgba(7,11,19,.18) 100%),
            linear-gradient(90deg, rgba(7,11,19,.58), transparent);
    }

    .minsk-hero-v2__content {
        min-height: auto;
        padding-bottom: 42px;
    }

    .minsk-hero-v2 h1 {
        font-size: clamp(40px, 13vw, 58px);
        line-height: .96;
    }

    .minsk-hero-v2 p,
    .minsk-system__intro p,
    .minsk-route__copy p,
    .minsk-board__copy p,
    .minsk-seo__box p,
    .minsk-cta__box p {
        font-size: 16px;
    }

    .minsk-hero-v2__panel {
        grid-template-columns: 1fr;
        margin: 0 18px 42px;
        border-radius: 20px;
    }

    .minsk-hero-v2__panel div {
        min-height: auto;
        border-right: 0;
        border-bottom: 1px solid rgba(255,255,255,.12);
    }

    .minsk-system,
    .minsk-market,
    .minsk-route,
    .minsk-board,
    .minsk-seo,
    .minsk-cta {
        padding: 72px 0;
    }

    .minsk-system__diagram,
    .minsk-market__grid {
        grid-template-columns: 1fr;
    }

    .minsk-system__diagram .is-main {
        grid-row: auto;
        min-height: 260px;
    }

    .minsk-system__diagram article,
    .minsk-market__grid article {
        min-height: auto;
        padding: 24px;
    }

    .minsk-route__steps li {
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 24px;
    }

    .minsk-board__visual {
        min-height: auto;
        padding: 18px;
        border-radius: 20px;
    }

    .minsk-board__row {
        flex-direction: column;
        padding: 20px;
    }

    .minsk-board__row small { text-align: left; }

    .minsk-seo__box,
    .minsk-cta__box {
        padding: 26px;
        border-radius: 20px;
    }

    .minsk-cta__box {
        flex-direction: column;
        align-items: flex-start;
    }
}
/* End Minsk realtor-inspired rebuild */

/* Mogilev production rebuild */
.mogilev-production-page {
    --page-accent: #7ee787;
    --page-accent-2: #34d399;
    --page-accent-rgb: 126, 231, 135;
    color: #f3fff7;
    background:
        radial-gradient(circle at 10% 8%, rgba(126, 231, 135, .14), transparent 30%),
        radial-gradient(circle at 88% 16%, rgba(52, 211, 153, .12), transparent 34%),
        linear-gradient(180deg, #07110e 0%, #0b1514 45%, #060908 100%);
    overflow: hidden;
}

.mogilev-production-page .niche-primary-btn {
    color: #04100b;
    background: linear-gradient(135deg, #9af7a1, #34d399);
    box-shadow: 0 18px 50px rgba(126, 231, 135, .2);
}

.mogilev-production-page h1,
.mogilev-production-page h2,
.mogilev-production-page h3 {
    letter-spacing: 0;
}

.mogilev-kicker {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 10px;
    color: #9af7a1;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.mogilev-kicker::before {
    content: "";
    width: 24px;
    height: 1px;
    background: currentColor;
    opacity: .75;
}

.mogilev-hero-v2 {
    position: relative;
    min-height: 100svh;
    padding: 124px 0 92px;
    overflow: hidden;
}

.mogilev-hero-v2::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.014) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.9), transparent 88%);
    pointer-events: none;
}

.mogilev-hero-v2__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(430px, 1.08fr);
    gap: 64px;
    align-items: center;
}

.mogilev-hero-v2 h1 {
    max-width: 820px;
    margin: 18px 0 0;
    font-size: clamp(46px, 5.9vw, 70px);
    line-height: .95;
}

.mogilev-hero-v2 p {
    max-width: 680px;
    margin: 26px 0 0;
    color: #c5d6cc;
    font-size: 18px;
    line-height: 1.75;
}

.mogilev-hero-v2 .niche-hero-actions {
    margin-top: 34px;
}

.mogilev-hero-v2__visual {
    position: relative;
    min-height: 620px;
}

.mogilev-hero-v2__visual figure {
    position: absolute;
    inset: 0 0 86px 38px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 32px;
    box-shadow: 0 34px 110px rgba(0,0,0,.4);
}

.mogilev-hero-v2__visual figure::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 42%, rgba(4, 14, 10, .82));
}

.mogilev-hero-v2__visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.mogilev-hero-v2__cards {
    position: absolute;
    left: 0;
    right: 42px;
    bottom: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.mogilev-hero-v2__cards article {
    min-height: 138px;
    padding: 22px;
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 22px;
    background: rgba(8, 18, 15, .68);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 22px 60px rgba(0,0,0,.24);
    backdrop-filter: blur(18px);
}

.mogilev-hero-v2__cards span,
.mogilev-line__track b,
.mogilev-control__rows span {
    color: #9af7a1;
    font-weight: 900;
}

.mogilev-hero-v2__cards b {
    display: block;
    margin-top: 18px;
    font-size: 18px;
}

.mogilev-hero-v2__cards small {
    display: block;
    margin-top: 8px;
    color: #aabbb1;
    line-height: 1.45;
}

.mogilev-line,
.mogilev-passport,
.mogilev-industries,
.mogilev-control,
.mogilev-seo,
.mogilev-cta {
    position: relative;
    padding: 118px 0;
}

.mogilev-line {
    background: #07110e;
}

.mogilev-line__head {
    display: grid;
    grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr);
    gap: 44px;
    align-items: end;
    margin-bottom: 52px;
}

.mogilev-line__head h2,
.mogilev-passport__copy h2,
.mogilev-industries__intro h2,
.mogilev-control__copy h2,
.mogilev-seo__box h2,
.mogilev-cta__box h2 {
    margin: 18px 0 18px;
    font-size: clamp(34px, 4vw, 48px);
    line-height: 1.03;
}

.mogilev-line__head p,
.mogilev-passport__copy p,
.mogilev-control__copy p,
.mogilev-seo__box p,
.mogilev-cta__box p {
    color: #b5c8bd;
    font-size: 17px;
    line-height: 1.75;
}

.mogilev-line__track {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    border-top: 1px solid rgba(154, 247, 161, .24);
    border-left: 1px solid rgba(255,255,255,.1);
}

.mogilev-line__track article {
    min-height: 300px;
    padding: 30px;
    border-right: 1px solid rgba(255,255,255,.1);
    border-bottom: 1px solid rgba(255,255,255,.1);
    background: linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
}

.mogilev-line__track article:nth-child(even) {
    transform: translateY(34px);
}

.mogilev-line__track h3 {
    margin: 20px 0 12px;
    font-size: 26px;
}

.mogilev-line__track p,
.mogilev-industries article p,
.mogilev-control__copy li,
.mogilev-passport__sheet span,
.mogilev-control__rows small {
    color: #acbeb4;
    line-height: 1.65;
}

.mogilev-passport {
    background:
        radial-gradient(circle at 78% 26%, rgba(126,231,135,.13), transparent 30%),
        #0c1714;
}

.mogilev-passport__grid {
    display: grid;
    grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr);
    gap: 58px;
    align-items: center;
}

.mogilev-passport__sheet,
.mogilev-control__panel,
.mogilev-seo__box,
.mogilev-cta__box {
    border: 1px solid rgba(255,255,255,.12);
    background: linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.035));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 24px 80px rgba(0,0,0,.22);
    backdrop-filter: blur(18px);
}

.mogilev-passport__sheet {
    display: grid;
    gap: 12px;
    padding: 22px;
    border-radius: 26px;
}

.mogilev-passport__sheet div {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 22px;
    padding: 22px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 18px;
    background: rgba(6, 15, 12, .54);
}

.mogilev-passport__sheet b {
    color: #f3fff7;
    line-height: 1.45;
}

.mogilev-industries {
    background: #07110e;
}

.mogilev-industries__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) repeat(2, minmax(0, .94fr));
    gap: 16px;
}

.mogilev-industries__intro,
.mogilev-industries article {
    min-height: 250px;
    padding: 30px;
    border: 1px solid rgba(255,255,255,.11);
    border-radius: 22px;
    background: linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
}

.mogilev-industries__intro {
    grid-row: span 2;
    min-height: 516px;
    background:
        radial-gradient(circle at 80% 18%, rgba(126,231,135,.24), transparent 30%),
        linear-gradient(145deg, rgba(126,231,135,.12), rgba(255,255,255,.035));
}

.mogilev-industries article:nth-of-type(2),
.mogilev-industries article:nth-of-type(4) {
    transform: translateY(28px);
}

.mogilev-industries article h3 {
    margin: 0 0 14px;
    font-size: 25px;
}

.mogilev-control {
    background:
        radial-gradient(circle at 18% 38%, rgba(52,211,153,.13), transparent 29%),
        #0d1715;
}

.mogilev-control__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, .92fr);
    gap: 54px;
    align-items: center;
}

.mogilev-control__panel {
    overflow: hidden;
    border-radius: 28px;
}

.mogilev-control__bar {
    display: flex;
    gap: 8px;
    align-items: center;
    min-height: 58px;
    padding: 0 22px;
    border-bottom: 1px solid rgba(255,255,255,.09);
    color: #93a79b;
}

.mogilev-control__bar span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255,255,255,.32);
}

.mogilev-control__bar span:first-child { background: #9af7a1; }
.mogilev-control__bar b { margin-left: auto; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; }

.mogilev-control__rows {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    padding: 24px;
}

.mogilev-control__rows div {
    min-height: 170px;
    padding: 24px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 18px;
    background: rgba(6, 15, 12, .62);
}

.mogilev-control__rows b {
    display: block;
    margin-top: 18px;
    color: #fff;
    font-size: 22px;
}

.mogilev-control__rows small {
    display: block;
    margin-top: 8px;
}

.mogilev-control__copy ul {
    display: grid;
    gap: 12px;
    margin: 24px 0 0;
    padding: 0;
    list-style: none;
}

.mogilev-control__copy li {
    position: relative;
    padding-left: 28px;
}

.mogilev-control__copy li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .72em;
    width: 12px;
    height: 2px;
    background: #9af7a1;
}

.mogilev-seo {
    padding-top: 104px;
    background: linear-gradient(180deg, #07110e, #0c1714);
}

.mogilev-seo__box {
    border-radius: 26px;
    padding: 46px;
}

.mogilev-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 26px;
}

.mogilev-links a {
    display: inline-flex;
    padding: 11px 16px;
    border: 1px solid rgba(154,247,161,.24);
    border-radius: 999px;
    color: #e7ffee;
    background: rgba(154,247,161,.08);
    text-decoration: none;
}

.mogilev-cta {
    padding-top: 54px;
    padding-bottom: 130px;
    background: #0c1714;
}

.mogilev-cta__box {
    display: flex;
    gap: 36px;
    align-items: center;
    justify-content: space-between;
    border-radius: 26px;
    padding: 42px;
    background:
        radial-gradient(circle at 82% 22%, rgba(126,231,135,.22), transparent 32%),
        linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.035));
}

.mogilev-cta__box > div { max-width: 790px; }

@media (max-width: 1180px) {
    .mogilev-hero-v2__grid,
    .mogilev-line__head,
    .mogilev-passport__grid,
    .mogilev-control__layout {
        grid-template-columns: 1fr;
    }

    .mogilev-hero-v2__visual { min-height: 560px; }
    .mogilev-line__track { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .mogilev-line__track article:nth-child(even),
    .mogilev-industries article:nth-of-type(2),
    .mogilev-industries article:nth-of-type(4) { transform: none; }
    .mogilev-industries__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .mogilev-industries__intro { grid-row: auto; min-height: 260px; }
}

@media (max-width: 760px) {
    .mogilev-hero-v2 {
        min-height: auto;
        padding: 104px 0 64px;
    }

    .mogilev-hero-v2 h1 {
        font-size: clamp(40px, 13vw, 58px);
        line-height: .96;
    }

    .mogilev-hero-v2 p,
    .mogilev-line__head p,
    .mogilev-passport__copy p,
    .mogilev-control__copy p,
    .mogilev-seo__box p,
    .mogilev-cta__box p {
        font-size: 16px;
    }

    .mogilev-hero-v2__visual {
        min-height: auto;
        display: grid;
        gap: 14px;
    }

    .mogilev-hero-v2__visual figure {
        position: relative;
        inset: auto;
        aspect-ratio: 4 / 3.2;
        border-radius: 22px;
    }

    .mogilev-hero-v2__cards {
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
        grid-template-columns: 1fr;
    }

    .mogilev-hero-v2__cards article {
        min-height: auto;
    }

    .mogilev-line,
    .mogilev-passport,
    .mogilev-industries,
    .mogilev-control,
    .mogilev-seo,
    .mogilev-cta {
        padding: 72px 0;
    }

    .mogilev-line__track,
    .mogilev-industries__grid,
    .mogilev-control__rows {
        grid-template-columns: 1fr;
    }

    .mogilev-line__track article,
    .mogilev-industries__intro,
    .mogilev-industries article {
        min-height: auto;
        padding: 24px;
    }

    .mogilev-passport__sheet,
    .mogilev-control__panel,
    .mogilev-seo__box,
    .mogilev-cta__box {
        border-radius: 20px;
    }

    .mogilev-passport__sheet {
        padding: 16px;
    }

    .mogilev-passport__sheet div {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 20px;
    }

    .mogilev-control__rows {
        padding: 16px;
    }

    .mogilev-control__rows div,
    .mogilev-seo__box,
    .mogilev-cta__box {
        padding: 24px;
    }

    .mogilev-cta__box {
        flex-direction: column;
        align-items: flex-start;
    }
}
/* End Mogilev production rebuild */

/* Belarus remaining city rebuilds */
.vitebsk-editorial-page,
.brest-route-page,
.grodno-trust-page,
.gomel-growth-page {
    color: #f7fbff;
    overflow: hidden;
}

.vitebsk-editorial-page { --page-accent: #c49aff; --page-accent-rgb: 196,154,255; --page-accent-2: #f472b6; background: radial-gradient(circle at 14% 8%, rgba(196,154,255,.16), transparent 32%), #080913; }
.brest-route-page { --page-accent: #ffbd68; --page-accent-rgb: 255,189,104; --page-accent-2: #f97316; background: radial-gradient(circle at 85% 12%, rgba(255,189,104,.14), transparent 32%), #0b0c10; }
.grodno-trust-page { --page-accent: #6ee7d8; --page-accent-rgb: 110,231,216; --page-accent-2: #14b8a6; background: radial-gradient(circle at 15% 8%, rgba(110,231,216,.14), transparent 34%), #071012; }
.gomel-growth-page { --page-accent: #63adff; --page-accent-rgb: 99,173,255; --page-accent-2: #22c55e; background: radial-gradient(circle at 82% 12%, rgba(34,197,94,.13), transparent 34%), #070b12; }

.vitebsk-editorial-page .niche-primary-btn,
.brest-route-page .niche-primary-btn,
.grodno-trust-page .niche-primary-btn,
.gomel-growth-page .niche-primary-btn {
    color: #061016;
    background: linear-gradient(135deg, var(--page-accent), var(--page-accent-2));
    box-shadow: 0 18px 50px rgba(var(--page-accent-rgb), .22);
}

.belarus-kicker {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 10px;
    color: var(--page-accent);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.belarus-kicker::before { content: ""; width: 24px; height: 1px; background: currentColor; opacity: .78; }

.vitebsk-editorial-page h1,
.vitebsk-editorial-page h2,
.vitebsk-editorial-page h3,
.brest-route-page h1,
.brest-route-page h2,
.brest-route-page h3,
.grodno-trust-page h1,
.grodno-trust-page h2,
.grodno-trust-page h3,
.gomel-growth-page h1,
.gomel-growth-page h2,
.gomel-growth-page h3 { letter-spacing: 0; }

.vitebsk-scenes,
.vitebsk-storyline,
.vitebsk-cards,
.vitebsk-seo,
.vitebsk-cta,
.brest-routes,
.brest-conditions,
.brest-proof,
.brest-seo,
.brest-cta,
.grodno-proof,
.grodno-care,
.grodno-ledger,
.grodno-seo,
.grodno-cta,
.gomel-architecture,
.gomel-modules,
.gomel-roadmap,
.gomel-seo,
.gomel-cta { position: relative; padding: 118px 0; }

.vitebsk-scenes__intro h2,
.vitebsk-storyline h2,
.vitebsk-cards .main h2,
.vitebsk-seo__box h2,
.vitebsk-cta__box h2,
.brest-routes__copy h2,
.brest-conditions__head h2,
.brest-proof__panel h2,
.brest-seo__box h2,
.brest-cta__box h2,
.grodno-proof__title h2,
.grodno-care h2,
.grodno-ledger .main h2,
.grodno-seo__box h2,
.grodno-cta__box h2,
.gomel-architecture h2,
.gomel-modules__head h2,
.gomel-roadmap .main h2,
.gomel-seo__box h2,
.gomel-cta__box h2 {
    margin: 18px 0 0;
    font-size: clamp(34px, 4vw, 62px);
    line-height: 1.03;
}

.vitebsk-editorial-page p,
.brest-route-page p,
.grodno-trust-page p,
.gomel-growth-page p {
    color: #b8c8d2;
    line-height: 1.72;
    margin-top: 12px;
}

.vitebsk-seo__box,
.vitebsk-cta__box,
.brest-seo__box,
.brest-cta__box,
.grodno-seo__box,
.grodno-cta__box,
.gomel-seo__box,
.gomel-cta__box {
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 26px;
    background: linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.035));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 24px 80px rgba(0,0,0,.22);
    backdrop-filter: blur(18px);
}

.vitebsk-seo__box,
.brest-seo__box,
.grodno-seo__box,
.gomel-seo__box { padding: 46px; }

.vitebsk-cta__box,
.brest-cta__box,
.grodno-cta__box,
.gomel-cta__box {
    display: flex;
    gap: 36px;
    align-items: center;
    justify-content: space-between;
    padding: 42px;
}

.vitebsk-cta__box > div,
.brest-cta__box > div,
.grodno-cta__box > div,
.gomel-cta__box > div { max-width: 790px; }

.belarus-links { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.belarus-links a { display: inline-flex; padding: 11px 16px; border: 1px solid rgba(var(--page-accent-rgb), .25); border-radius: 999px; color: #f3fbff; background: rgba(var(--page-accent-rgb), .08); text-decoration: none; }

/* Vitebsk */
.vitebsk-hero-v2 { min-height: 100svh; padding: 122px 0 90px; background: linear-gradient(180deg, #0b0a18, #100d1d); }
.vitebsk-hero-v2__grid { display: grid; grid-template-columns: minmax(0,.9fr) minmax(420px,1.1fr); gap: 64px; align-items: center; }
.vitebsk-hero-v2 h1 { margin: 18px 0 0; font-size: clamp(46px, 6vw, 92px); line-height: .94; }
.vitebsk-hero-v2 p { max-width: 690px; margin: 26px 0 0; font-size: 18px; }
.vitebsk-hero-v2 .niche-hero-actions { margin-top: 34px; }
.vitebsk-hero-v2__art { position: relative; min-height: 610px; }
.vitebsk-hero-v2__art figure { position: absolute; inset: 0 0 74px 34px; overflow: hidden; border: 1px solid rgba(255,255,255,.14); border-radius: 36px; box-shadow: 0 36px 110px rgba(0,0,0,.42); }
.vitebsk-hero-v2__art figure::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 42%, rgba(12,8,25,.78)); }
.vitebsk-hero-v2__art img { width: 100%; height: 100%; object-fit: cover; }
.vitebsk-hero-v2__notes { position: absolute; left: 0; right: 40px; bottom: 0; display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.vitebsk-hero-v2__notes span { padding: 22px; border: 1px solid rgba(255,255,255,.15); border-radius: 22px; background: rgba(18,13,31,.68); backdrop-filter: blur(18px); color: #f5edff; font-weight: 900; text-transform: uppercase; }
.vitebsk-scenes { background: #0a0915; }
.vitebsk-scenes__grid { display: grid; grid-template-columns: 1.14fr .86fr .86fr; gap: 16px; }
.vitebsk-scenes__intro,
.vitebsk-scenes article,
.vitebsk-cards article,
.grodno-ledger article,
.gomel-roadmap article { border: 1px solid rgba(255,255,255,.11); border-radius: 22px; background: linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.03)); }
.vitebsk-scenes__intro { grid-row: span 2; min-height: 520px; padding: 32px; background: radial-gradient(circle at 84% 16%, rgba(196,154,255,.22), transparent 34%), rgba(255,255,255,.05); }
.vitebsk-scenes article { min-height: 250px; padding: 30px; }
.vitebsk-scenes .wide { grid-column: span 2; }
.vitebsk-storyline { background: #100d1d; }
.vitebsk-storyline__layout { display: grid; grid-template-columns: .88fr 1.12fr; gap: 64px; align-items: start; }
.vitebsk-storyline ol { display: grid; gap: 14px; margin: 0; padding: 0; list-style: none; }
.vitebsk-storyline li { display: grid; grid-template-columns: 64px 1fr; gap: 20px; padding: 26px; border: 1px solid rgba(255,255,255,.11); border-radius: 22px; background: rgba(255,255,255,.045); }
.vitebsk-storyline li span,
.vitebsk-cards b { color: var(--page-accent); font-weight: 900; }
.vitebsk-cards { background: #0a0915; }
.vitebsk-cards__grid { display: grid; grid-template-columns: 1.3fr repeat(3,.75fr); gap: 16px; }
.vitebsk-cards article { min-height: 300px; padding: 30px; }
.vitebsk-cards .main { min-height: 420px; background: radial-gradient(circle at 80% 20%, rgba(244,114,182,.22), transparent 34%), rgba(255,255,255,.055); }

/* Brest */
.brest-hero-v2 { position: relative; min-height: 100svh; padding-top: 88px; overflow: hidden; }
.brest-hero-v2__media { position: absolute; inset: 0; }
.brest-hero-v2__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(7,8,10,.96), rgba(7,8,10,.72) 48%, rgba(7,8,10,.25)), linear-gradient(0deg, rgba(7,8,10,.82), transparent 52%); }
.brest-hero-v2__media img { width: 100%; height: 100%; object-fit: cover; }
.brest-hero-v2__layout { position: relative; z-index: 1; display: grid; min-height: calc(100svh - 88px); grid-template-columns: 1fr 330px; gap: 60px; align-items: center; padding-bottom: 80px; }
.brest-hero-v2 h1 { max-width: 850px; margin: 18px 0 0; font-size: clamp(46px, 6vw, 92px); line-height: .94; }
.brest-hero-v2 p { max-width: 710px; margin: 26px 0 0; font-size: 18px; }
.brest-hero-v2 .niche-hero-actions { margin-top: 34px; }
.brest-hero-v2 aside { display: grid; gap: 12px; padding: 24px; border: 1px solid rgba(255,255,255,.14); border-radius: 26px; background: rgba(16,12,8,.6); backdrop-filter: blur(18px); }
.brest-hero-v2 aside span { padding: 18px; border-radius: 16px; background: rgba(255,255,255,.08); color: #ffe6c5; font-weight: 900; text-transform: uppercase; }
.brest-routes { background: #0b0c10; }
.brest-routes__grid { display: grid; grid-template-columns: .82fr 1.18fr; gap: 58px; align-items: center; }
.brest-routes__map { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.brest-routes__map article,
.brest-conditions article,
.brest-proof__panel,
.brest-proof__cards article { border: 1px solid rgba(255,255,255,.11); border-radius: 22px; background: linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.03)); }
.brest-routes__map article { min-height: 100px; padding: 28px; }
.brest-routes__map article:nth-child(2), .brest-routes__map article:nth-child(3) { transform: translateY(30px); }
.brest-routes__map b, .brest-proof__cards b { color: var(--page-accent); }
.brest-routes__map span { display: block; margin-top: 0px; color: #fff1dd; font-size: 20px; font-weight: 850; }
.brest-conditions { background: #11100f; }
.brest-conditions__head { max-width: 900px; margin-bottom: 48px; }
.brest-conditions__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.brest-conditions article { min-height: 0px; padding: 28px; }
.brest-proof { background: #0b0c10; }
.brest-proof__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.brest-proof__panel { padding: 34px; min-height: 420px; }
.brest-proof__cards { display: grid; gap: 14px; }
.brest-proof__cards article { padding: 26px; }

/* Grodno */
.grodno-hero-v2 { min-height: 100svh; padding: 124px 0 92px; background: linear-gradient(180deg,#071012,#0b1718); }
.grodno-hero-v2__grid { display: grid; grid-template-columns: .95fr minmax(390px,.86fr); gap: 62px; align-items: center; }
.grodno-hero-v2 h1 { margin: 18px 0 0; font-size: clamp(46px, 5.8vw, 88px); line-height: .95; }
.grodno-hero-v2 p { max-width: 680px; margin: 26px 0 0; font-size: 18px; }
.grodno-hero-v2 .niche-hero-actions { margin-top: 34px; }
.grodno-hero-v2 figure { overflow: hidden; border: 1px solid rgba(255,255,255,.14); border-radius: 34px; background: rgba(255,255,255,.045); box-shadow: 0 36px 110px rgba(0,0,0,.4); }
.grodno-hero-v2 figure img { width: 100%; aspect-ratio: 4 / 4.7; object-fit: cover; }
.grodno-hero-v2 figcaption { margin: 14px; padding: 18px; border: 1px solid rgba(255,255,255,.12); border-radius: 18px; color: #c8dedc; background: rgba(5,13,14,.66); }
.grodno-proof { background: #071012; }
.grodno-proof__grid { display: grid; grid-template-columns: 1.25fr repeat(3,.72fr); gap: 16px; align-items: stretch; }
.grodno-proof__title,
.grodno-proof article { border: 1px solid rgba(255,255,255,.11); border-radius: 24px; background: linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.03)); }
.grodno-proof__title { min-height: 360px; padding: 32px; background: radial-gradient(circle at 84% 16%, rgba(110,231,216,.22), transparent 34%), rgba(255,255,255,.05); }
.grodno-proof article { min-height: 300px; padding: 28px; }
.grodno-proof article:nth-of-type(2) { transform: translateY(28px); }
.grodno-proof article:nth-of-type(3) { transform: translateY(56px); }
.grodno-proof b { color: var(--page-accent); }
.grodno-care { background: #0b1718; }
.grodno-care__layout { display: grid; grid-template-columns: .86fr 1.14fr; gap: 64px; }
.grodno-care ol { display: grid; gap: 14px; margin: 0; padding: 0; list-style: none; }
.grodno-care li { display: grid; grid-template-columns: 64px 1fr; gap: 20px; padding: 26px; border: 1px solid rgba(255,255,255,.11); border-radius: 22px; background: rgba(255,255,255,.045); }
.grodno-care li span { color: var(--page-accent); font-weight: 900; }
.grodno-ledger { background: #071012; }
.grodno-ledger__grid { display: grid; grid-template-columns: 1.05fr 1fr 1fr; gap: 16px; }
.grodno-ledger article {     min-height: 147px;
    padding: 30px; }
.grodno-ledger .main { grid-row: span 2; background: radial-gradient(circle at 80% 20%, rgba(110,231,216,.19), transparent 34%), rgba(255,255,255,.055); }

/* Gomel */
.gomel-hero-v2 { position: relative; min-height: 100svh; padding-top: 88px; overflow: hidden; }
.gomel-hero-v2__media { position: absolute; inset: 0; }
.gomel-hero-v2__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,9,15,.96), rgba(5,9,15,.72) 48%, rgba(5,9,15,.24)), linear-gradient(0deg, rgba(5,9,15,.84), transparent 52%); }
.gomel-hero-v2__media img { width: 100%; height: 100%; object-fit: cover; }
.gomel-hero-v2__content { position: relative; z-index: 1; display: flex; min-height: calc(100svh - 88px); max-width: 1840px; flex-direction: column; justify-content: center; padding-bottom: 96px; }
.gomel-hero-v2 h1 { max-width: 880px; margin: 18px 0 0; font-size: clamp(46px, 6vw, 92px); line-height: .94; }
.gomel-hero-v2 p { max-width: 720px; margin: 26px 0 0; font-size: 18px; }
.gomel-hero-v2 .niche-hero-actions { margin-top: 34px; }
.gomel-hero-v2__panel { display: grid; width: min(700px,100%); grid-template-columns: repeat(3,1fr); gap: 12px; margin-top: 44px; }
.gomel-hero-v2__panel article { padding: 22px; border: 1px solid rgba(255,255,255,.14); border-radius: 22px; background: rgba(7,13,20,.62); backdrop-filter: blur(18px); }
.gomel-hero-v2__panel b { display: block; color: var(--page-accent); }
.gomel-hero-v2__panel span { display: block; margin-top: 14px; color: #d5e5f2; font-weight: 850; }
.gomel-architecture { background: #070b12; }
.gomel-architecture__grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 58px; align-items: center; }
.gomel-architecture__matrix { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.gomel-architecture__matrix article,
.gomel-modules article { border: 1px solid rgba(255,255,255,.11); border-radius: 22px; background: linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.03)); }
.gomel-architecture__matrix article { min-height: 120px; padding: 28px; }
.gomel-architecture__matrix article:nth-child(3) { transform: translateY(30px); }
.gomel-architecture__matrix b, .gomel-modules b, .gomel-roadmap b { color: var(--page-accent); }
.gomel-architecture__matrix span { display: block;   color: #dcecff; font-size: 20px; font-weight: 850; }
.gomel-modules { background: #0b121a; }
.gomel-modules__head { max-width: 900px; margin-bottom: 48px; }
.gomel-modules__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.gomel-modules article { min-height: 172px; padding: 28px; }
.gomel-roadmap { background: #070b12; }
.gomel-roadmap__grid { display: grid; grid-template-columns: 1.22fr repeat(3,.78fr); gap: 16px; }
.gomel-roadmap article { min-height: 320px; padding: 30px; }
.gomel-roadmap .main { min-height: 430px; background: radial-gradient(circle at 84% 18%, rgba(34,197,94,.2), transparent 34%), rgba(255,255,255,.055); }

@media (max-width: 1180px) {
    .vitebsk-hero-v2__grid,
    .vitebsk-storyline__layout,
    .brest-hero-v2__layout,
    .brest-routes__grid,
    .brest-proof__layout,
    .grodno-hero-v2__grid,
    .grodno-care__layout,
    .gomel-architecture__grid { grid-template-columns: 1fr; }
    .vitebsk-scenes__grid,
    .vitebsk-cards__grid,
    .brest-conditions__grid,
    .grodno-proof__grid,
    .grodno-ledger__grid,
    .gomel-modules__grid,
    .gomel-roadmap__grid { grid-template-columns: repeat(2,1fr); }
    .vitebsk-scenes__intro,
    .vitebsk-cards .main,
    .grodno-ledger .main { grid-row: auto; }
    .vitebsk-scenes .wide { grid-column: auto; }
    .brest-routes__map article:nth-child(2), .brest-routes__map article:nth-child(3), .grodno-proof article:nth-of-type(2), .grodno-proof article:nth-of-type(3), .gomel-architecture__matrix article:nth-child(3) { transform: none; }
}

@media (max-width: 760px) {
    .vitebsk-hero-v2,
    .brest-hero-v2,
    .grodno-hero-v2,
    .gomel-hero-v2 { min-height: auto; }
    .vitebsk-hero-v2,
    .grodno-hero-v2 { padding: 104px 0 64px; }
    .brest-hero-v2__layout,
    .gomel-hero-v2__content { min-height: auto; padding-top: 104px; padding-bottom: 64px; }
    .vitebsk-hero-v2 h1,
    .brest-hero-v2 h1,
    .grodno-hero-v2 h1,
    .gomel-hero-v2 h1 { font-size: clamp(40px, 13vw, 58px); line-height: .96; }
    .vitebsk-hero-v2__art { min-height: auto; display: grid; gap: 14px; }
    .vitebsk-hero-v2__art figure { position: relative; inset: auto; aspect-ratio: 4 / 3.2; border-radius: 22px; }
    .vitebsk-hero-v2__notes,
    .gomel-hero-v2__panel { position: relative; left: auto; right: auto; bottom: auto; grid-template-columns: 1fr; }
    .vitebsk-scenes,
    .vitebsk-storyline,
    .vitebsk-cards,
    .vitebsk-seo,
    .vitebsk-cta,
    .brest-routes,
    .brest-conditions,
    .brest-proof,
    .brest-seo,
    .brest-cta,
    .grodno-proof,
    .grodno-care,
    .grodno-ledger,
    .grodno-seo,
    .grodno-cta,
    .gomel-architecture,
    .gomel-modules,
    .gomel-roadmap,
    .gomel-seo,
    .gomel-cta { padding: 72px 0; }
    .vitebsk-scenes__grid,
    .vitebsk-cards__grid,
    .brest-routes__map,
    .brest-conditions__grid,
    .grodno-proof__grid,
    .grodno-ledger__grid,
    .gomel-architecture__matrix,
    .gomel-modules__grid,
    .gomel-roadmap__grid { grid-template-columns: 1fr; }
    .vitebsk-scenes__intro,
    .vitebsk-scenes article,
    .vitebsk-cards article,
    .brest-conditions article,
    .grodno-proof__title,
    .grodno-proof article,
    .grodno-ledger article,
    .gomel-modules article,
    .gomel-roadmap article { min-height: auto; padding: 24px; }
    .vitebsk-storyline li,
    .grodno-care li { grid-template-columns: 1fr; }
    .brest-hero-v2 aside { display: none; }
    .grodno-hero-v2 figure img { aspect-ratio: 4 / 3.2; }
    .vitebsk-seo__box,
    .vitebsk-cta__box,
    .brest-seo__box,
    .brest-cta__box,
    .grodno-seo__box,
    .grodno-cta__box,
    .gomel-seo__box,
    .gomel-cta__box { padding: 24px; border-radius: 20px; }
    .vitebsk-cta__box,
    .brest-cta__box,
    .grodno-cta__box,
    .gomel-cta__box { flex-direction: column; align-items: flex-start; }
}
/* End Belarus remaining city rebuilds */

/* Belarus hero sizing and no-overlap polish */
.minsk-hero-v2 h1,
.mogilev-hero-v2 h1,
.vitebsk-hero-v2 h1,
.brest-hero-v2 h1,
.grodno-hero-v2 h1,
.gomel-hero-v2 h1 {
    font-size: clamp(38px, 4.6vw, 64px);
    line-height: 1.02;
    max-width: 780px;
}

.minsk-hero-v2 p,
.mogilev-hero-v2 p,
.vitebsk-hero-v2 p,
.brest-hero-v2 p,
.grodno-hero-v2 p,
.gomel-hero-v2 p {
    max-width: 660px;
    font-size: 17px;
    line-height: 1.66;
}

.minsk-system__intro h2,
.minsk-market__head h2,
.minsk-route__copy h2,
.minsk-board__copy h2,
.minsk-seo__box h2,
.minsk-cta__box h2,
.mogilev-line__head h2,
.mogilev-passport__copy h2,
.mogilev-industries__intro h2,
.mogilev-control__copy h2,
.mogilev-seo__box h2,
.mogilev-cta__box h2,
.vitebsk-scenes__intro h2,
.vitebsk-storyline h2,
.vitebsk-cards .main h2,
.vitebsk-seo__box h2,
.vitebsk-cta__box h2,
.brest-routes__copy h2,
.brest-conditions__head h2,
.brest-proof__panel h2,
.brest-seo__box h2,
.brest-cta__box h2,
.grodno-proof__title h2,
.grodno-care h2,
.grodno-ledger .main h2,
.grodno-seo__box h2,
.grodno-cta__box h2,
.gomel-architecture h2,
.gomel-modules__head h2,
.gomel-roadmap .main h2,
.gomel-seo__box h2,
.gomel-cta__box h2 {
    font-size: clamp(30px, 3.2vw, 48px);
    line-height: 1.08;
    text-align: left;
}

.minsk-market__grid article:nth-child(even),
.mogilev-line__track article:nth-child(even),
.mogilev-industries article:nth-of-type(2),
.mogilev-industries article:nth-of-type(4),
.brest-routes__map article:nth-child(2),
.brest-routes__map article:nth-child(3),
.grodno-proof article:nth-of-type(2),
.grodno-proof article:nth-of-type(3),
.gomel-architecture__matrix article:nth-child(3) {
    transform: none;
}

.minsk-market__grid,
.mogilev-line__track,
.mogilev-industries__grid,
.brest-routes__map,
.grodno-proof__grid,
.gomel-architecture__matrix {
    align-items: stretch;
}

.minsk-hero-v2__panel,
.mogilev-hero-v2__cards,
.vitebsk-hero-v2__notes,
.gomel-hero-v2__panel {
    margin-top: 22px;
}

@media (max-width: 1180px) {
    .minsk-hero-v2__panel {
        margin: 24px 24px 50px;
    }

    .mogilev-hero-v2__cards,
    .vitebsk-hero-v2__notes {
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
    }

    .mogilev-hero-v2__visual,
    .vitebsk-hero-v2__art {
        display: grid;
        gap: 14px;
        min-height: auto;
    }

    .mogilev-hero-v2__visual figure,
    .vitebsk-hero-v2__art figure {
        position: relative;
        inset: auto;
        aspect-ratio: 16 / 10;
    }
}

@media (max-width: 760px) {
    .minsk-hero-v2 h1,
    .mogilev-hero-v2 h1,
    .vitebsk-hero-v2 h1,
    .brest-hero-v2 h1,
    .grodno-hero-v2 h1,
    .gomel-hero-v2 h1 {
        font-size: clamp(34px, 10vw, 44px);
        line-height: 1.04;
    }

    .minsk-hero-v2 p,
    .mogilev-hero-v2 p,
    .vitebsk-hero-v2 p,
    .brest-hero-v2 p,
    .grodno-hero-v2 p,
    .gomel-hero-v2 p {
        font-size: 15.5px;
        line-height: 1.62;
    }

    .minsk-system__intro h2,
    .minsk-market__head h2,
    .minsk-route__copy h2,
    .minsk-board__copy h2,
    .minsk-seo__box h2,
    .minsk-cta__box h2,
    .mogilev-line__head h2,
    .mogilev-passport__copy h2,
    .mogilev-industries__intro h2,
    .mogilev-control__copy h2,
    .mogilev-seo__box h2,
    .mogilev-cta__box h2,
    .vitebsk-scenes__intro h2,
    .vitebsk-storyline h2,
    .vitebsk-cards .main h2,
    .vitebsk-seo__box h2,
    .vitebsk-cta__box h2,
    .brest-routes__copy h2,
    .brest-conditions__head h2,
    .brest-proof__panel h2,
    .brest-seo__box h2,
    .brest-cta__box h2,
    .grodno-proof__title h2,
    .grodno-care h2,
    .grodno-ledger .main h2,
    .grodno-seo__box h2,
    .grodno-cta__box h2,
    .gomel-architecture h2,
    .gomel-modules__head h2,
    .gomel-roadmap .main h2,
    .gomel-seo__box h2,
    .gomel-cta__box h2 {
        font-size: clamp(26px, 8vw, 34px);
        line-height: 1.1;
    }
}
/* End Belarus hero sizing and no-overlap polish */

/* Beauty cover repair */
.beauty-cover {
    position: relative;
    overflow: hidden;
}

.beauty-cover__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
}

.beauty-cover__image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.beauty-cover__content {
    position: relative;
    z-index: 2;
}
/* End Beauty cover repair */
