/* ===========================================================
   AFL — main page styles
   =========================================================== */

:root{
    --c-primary:        #f7b80b;
    --c-primary-dark:   #d99f00;
    --c-primary-soft:   #fef4d6;
    --c-accent:         #eaa700;
    --c-on-primary:     #1f1500;
    --grad-brand-deep:  linear-gradient(160deg,#8a6300,#5e4300);
    --c-bg:             #ffffff;
    --c-bg-soft:        #fbf8f6;
    --c-bg-deep:        #0f1a24;
    --c-line:           #f2ece6;
    --c-text:           #0f1a24;
    --c-text-muted:     #5b6877;
    --c-text-light:     #8895a5;

    --shadow-sm:  0 1px 2px rgba(15,26,36,.04), 0 1px 3px rgba(15,26,36,.06);
    --shadow-md:  0 4px 12px rgba(15,26,36,.06), 0 2px 4px rgba(15,26,36,.04);
    --shadow-lg:  0 12px 32px rgba(15,26,36,.10), 0 4px 8px rgba(15,26,36,.04);
    --shadow-xl:  0 24px 64px rgba(15,26,36,.14);

    --radius-sm: 8px;
    --radius:    14px;
    --radius-lg: 20px;
    --radius-xl: 28px;

    --container: 1240px;
    --gutter:    24px;

    --t: cubic-bezier(.2,.8,.2,1);
    --t-fast: 160ms var(--t);
    --t-base: 280ms var(--t);
    --t-slow: 480ms var(--t);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:'Inter','Helvetica Neue',Arial,sans-serif;
    font-size:16px;
    line-height:1.6;
    color:var(--c-text);
    background:var(--c-bg);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color var(--t-fast)}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5,h6{margin:0;font-family:'Manrope','Inter',sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.15;color:var(--c-text)}
p{margin:0}

.container{
    width:100%;
    max-width:var(--container);
    margin:0 auto;
    padding:0 var(--gutter);
}

/* типография общих элементов */
.eyebrow{
    display:inline-block;
    font-size:13px;
    font-weight:600;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:var(--c-primary);
    margin-bottom:14px;
}
.section-title{
    font-size:clamp(28px,3.6vw,46px);
    font-weight:800;
    letter-spacing:-.025em;
}
.section-title .dot{color:var(--c-accent)}
.section-sub{
    margin-top:18px;
    color:var(--c-text-muted);
    max-width:640px;
    font-size:17px;
}
.section-head{margin-bottom:48px;max-width:780px}
.section-head--center{margin-left:auto;margin-right:auto;text-align:center}

/* кнопки */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:12px 22px;
    border-radius:999px;
    font-weight:600;
    font-size:15px;
    line-height:1;
    border:1px solid transparent;
    cursor:pointer;
    transition:transform var(--t-fast), background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
    white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{
    background:var(--c-primary);
    color:var(--c-on-primary);
    box-shadow:0 6px 16px rgba(247,184,11,.32);
}
.btn--primary:hover{background:var(--c-primary-dark);color:var(--c-on-primary);box-shadow:0 8px 22px rgba(247,184,11,.42)}
.btn--ghost{
    background:rgba(255,255,255,.08);
    border-color:rgba(255,255,255,.5);
    color:#fff;
    backdrop-filter:blur(8px);
}
.btn--ghost:hover{background:rgba(255,255,255,.18)}
.btn--outline{background:#fff;border-color:var(--c-primary);color:var(--c-primary)}
.btn--outline:hover{background:var(--c-primary);color:var(--c-on-primary);box-shadow:0 6px 16px rgba(247,184,11,.28)}
.btn--lg{padding:16px 28px;font-size:16px}
.btn--full{width:100%}

.link-arrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-weight:600;
    color:var(--c-primary);
    margin-top:8px;
}
.link-arrow svg{transition:transform var(--t-fast)}
.link-arrow:hover svg{transform:translateX(4px)}

/* ============ TOPBAR ============ */
.topbar{
    background:var(--c-primary);
    color:var(--c-on-primary);
    font-size:13px;
}
.topbar__inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding-top:10px;
    padding-bottom:10px;
    gap:24px;
}
.topbar__left,.topbar__right{display:flex;align-items:center;gap:24px}
.topbar__item{display:inline-flex;align-items:center;gap:8px;color:var(--c-on-primary);opacity:.85;transition:opacity var(--t-fast)}
.topbar__item:hover{opacity:1;color:var(--c-on-primary)}
.topbar__item svg{flex-shrink:0;color:var(--c-on-primary)}

.lang{position:relative}
.lang__btn{
    display:inline-flex;
    align-items:center;
    gap:6px;
    color:rgba(255,255,255,.78);
    padding:4px 10px;
    border-radius:6px;
    font-weight:500;
}
.lang__btn:hover{color:#fff;background:rgba(255,255,255,.06)}
.lang__menu{
    position:absolute;
    top:calc(100% + 8px);
    right:0;
    min-width:140px;
    background:#fff;
    border-radius:10px;
    box-shadow:var(--shadow-lg);
    padding:6px;
    opacity:0;
    visibility:hidden;
    transform:translateY(-6px);
    transition:all var(--t-base);
    z-index:50;
}
.lang.is-open .lang__menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang__menu a{
    display:block;
    padding:8px 12px;
    color:var(--c-text);
    border-radius:6px;
    font-weight:500;
}
.lang__menu a:hover,.lang__menu a.active{background:var(--c-primary-soft);color:var(--c-primary)}

/* ============ HEADER ============ */
.header{
    background:#fff;
    box-shadow:0 1px 0 var(--c-line);
    position:sticky;
    top:0;
    z-index:100;
    transition:box-shadow var(--t-base);
}
.header.is-scrolled{box-shadow:var(--shadow-md)}
.header__inner{
    display:flex;
    align-items:center;
    gap:32px;
    padding-top:18px;
    padding-bottom:18px;
    position:relative;
}
.header__logo{display:flex;align-items:center;flex-shrink:0}
.header__logo img{height:42px;width:auto}

.nav{display:flex;align-items:center;flex:1}
.nav__close{display:none}
.nav__list{display:flex;align-items:center;gap:2px;flex-wrap:nowrap}
.nav__link{
    display:inline-block;
    padding:8px 11px;
    border-radius:8px;
    font-weight:500;
    font-size:14.5px;
    color:var(--c-text);
    position:relative;
    white-space:nowrap;
}
.nav__link:hover{color:var(--c-primary);background:var(--c-primary-soft)}
.nav__link--active{color:var(--c-primary)}
/* Активный пункт: подчёркивание через ::before, чтобы не конфликтовать
   с каретом дропдауна (::after) — иначе у пунктов с подменю получался
   кривой «артефакт-точка». */
.nav__link--active::before{
    content:'';
    position:absolute;
    bottom:-2px;
    left:14px;right:14px;
    height:2px;
    background:var(--c-primary);
    border-radius:2px;
}

.header__actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.icon-btn{
    width:40px;height:40px;
    border-radius:50%;
    display:inline-flex;
    align-items:center;justify-content:center;
    color:var(--c-text);
    transition:background var(--t-fast),color var(--t-fast);
}
.icon-btn:hover{background:var(--c-primary-soft);color:var(--c-primary)}
.icon-btn--burger{display:none;flex-direction:column;gap:5px}
.icon-btn--burger span{display:block;width:18px;height:2px;background:currentColor;border-radius:2px}

.search-pop{
    position:absolute;
    top:calc(100% + 4px);
    right:24px;
    background:#fff;
    box-shadow:var(--shadow-lg);
    border-radius:14px;
    padding:8px;
    display:flex;
    gap:8px;
    width:min(440px, 90vw);
    z-index:90;
}
.search-pop[hidden]{display:none}
.search-pop input{
    flex:1;
    border:0;
    padding:0 14px;
    font-size:15px;
    outline:none;
    background:transparent;
    color:var(--c-text);
}

/* ============ HERO ============ */
.hero{
    position:relative;
    background:
        radial-gradient(ellipse 56% 72% at 84% 26%, rgba(247,184,11,.16), transparent 60%),
        radial-gradient(ellipse 72% 80% at -6% 102%, rgba(205, 189, 100,.16), transparent 55%),
        linear-gradient(165deg, #ffffff 0%, #f8f4ed 52%, #f3ece1 100%);
    color:var(--c-text);
    overflow:hidden;
    border-bottom:1px solid var(--c-line);
}
.hero::before{
    content:'';
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(247,184,11,.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(247,184,11,.07) 1px, transparent 1px);
    background-size: 78px 78px;
    -webkit-mask-image: radial-gradient(ellipse at 78% 42%, black 20%, transparent 68%);
    mask-image: radial-gradient(ellipse at 78% 42%, black 20%, transparent 68%);
    pointer-events:none;
}
.hero__slider{
    position:relative;
    height:min(86vh, 720px);
    min-height:560px;
}
.hero__slide{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    opacity:0;
    visibility:hidden;
    transition:opacity 450ms ease, visibility 450ms;
    pointer-events:none;
}
.hero__slide.is-active{opacity:1;visibility:visible;pointer-events:auto}
.hero__slide > .container{position:relative}
.hero__visual{
    position:absolute;
    right:var(--gutter);
    top:50%;
    transform:translateY(-50%);
    width:38%;
    max-width:420px;
    aspect-ratio:1/1;
    border-radius:24px;
    background:linear-gradient(160deg, #ffffff 0%, #f8f4ee 100%);
    padding:28px;
    box-shadow:0 30px 70px rgba(42,34,16,.16), 0 0 0 1px rgba(15,26,36,.05);
    pointer-events:none;
    z-index:1;
}
.hero__visual::before{
    content:'';
    position:absolute;
    inset:-18%;
    background:radial-gradient(circle at 50% 50%, rgba(247,184,11,.22), transparent 60%);
    z-index:-1;
    border-radius:50%;
    filter:blur(22px);
}
.hero__visual img{
    position:relative;
    width:100%;
    height:100%;
    object-fit:contain;
    z-index:1;
    animation:heroFloat 9s ease-in-out infinite;
}
@keyframes heroFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-12px)}
}
.hero__content{
    position:relative;
    z-index:2;
    max-width:600px;
    padding-top:48px;
    padding-bottom:48px;
}
.hero__lead{max-width:480px}
.hero__eyebrow{
    display:inline-block;
    font-size:13px;
    font-weight:600;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:var(--c-primary);
    padding:8px 14px;
    background:var(--c-primary-soft);
    border:1px solid rgba(247,184,11,.22);
    border-radius:999px;
    margin-bottom:24px;
}
.hero__title{
    font-size:clamp(30px, 4.2vw, 54px);
    font-weight:800;
    letter-spacing:-.025em;
    line-height:1.1;
    color:var(--c-text);
    margin-bottom:24px;
    max-width:520px;
}
.hero__title span{
    background:linear-gradient(120deg, var(--c-primary-dark), #b07f00);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.hero__lead{
    font-size:clamp(16px, 1.5vw, 19px);
    line-height:1.6;
    color:var(--c-text-muted);
    max-width:580px;
    margin-bottom:32px;
}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px}
.hero .btn--ghost{
    background:#fff;
    border-color:var(--c-line);
    color:var(--c-text);
    backdrop-filter:none;
    box-shadow:var(--shadow-sm);
}
.hero .btn--ghost:hover{background:var(--c-primary-soft);border-color:var(--c-primary);color:var(--c-primary)}

.hero__nav{
    position:absolute;
    bottom:32px;left:50%;transform:translateX(-50%);
    display:flex;align-items:center;gap:18px;
    padding:8px;
    background:rgba(255,255,255,.72);
    backdrop-filter:blur(12px);
    border:1px solid var(--c-line);
    box-shadow:var(--shadow-md);
    border-radius:999px;
    z-index:5;
}
.hero__arrow{
    width:42px;height:42px;border-radius:50%;
    color:var(--c-text);
    display:inline-flex;align-items:center;justify-content:center;
    transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast);
}
.hero__arrow:hover{background:var(--c-primary-soft);color:var(--c-primary)}
.hero__dots{display:flex;gap:8px}
.hero__dot{
    width:8px;height:8px;border-radius:50%;
    background:rgba(15,26,36,.18);
    transition:all var(--t-fast);
    cursor:pointer;
}
.hero__dot.is-active{background:var(--c-primary);width:24px;border-radius:4px}

.hero__scroll{
    position:absolute;
    bottom:32px;right:32px;
    width:36px;height:60px;
    border:2px solid rgba(15,26,36,.22);
    border-radius:18px;
    z-index:5;
    display:none;
}
.hero__scroll span{
    position:absolute;
    top:8px;left:50%;
    width:4px;height:8px;background:var(--c-primary);border-radius:2px;
    transform:translateX(-50%);
    animation:scrollDown 1.6s var(--t) infinite;
}
@keyframes scrollDown{
    0%{transform:translate(-50%,0);opacity:1}
    100%{transform:translate(-50%,24px);opacity:0}
}
@media(min-width:1024px){.hero__scroll{display:block}}

/* ============ ABOUT ============ */
.about{padding:96px 0}
.about__grid{
    display:grid;
    grid-template-columns:1.4fr 1fr;
    gap:64px;
    align-items:start;
}
.about__text .lead{
    font-size:17px;
    color:var(--c-text-muted);
    margin-bottom:18px;
    max-width:580px;
}
.about__text .lead--small{
    font-size:15px;
    margin-bottom:28px;
}
.about__facts{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:18px;
    margin-bottom:24px;
    max-width:520px;
}
.about__facts li{
    background:var(--c-bg-soft);
    padding:18px 20px;
    border-radius:var(--radius);
    border:1px solid var(--c-line);
}
.about__facts b{
    display:block;
    font-family:'Manrope',sans-serif;
    font-size:26px;
    font-weight:800;
    color:var(--c-text);
    margin-bottom:2px;
    letter-spacing:-.02em;
}
.about__facts span{font-size:13px;color:var(--c-text-muted)}

.about__features{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
    margin-top:40px;
    padding-top:32px;
    border-top:1px solid var(--c-line);
}
.feature{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
}
.feature img{width:36px;height:36px;object-fit:contain}
.feature p{font-weight:600;font-size:14px;line-height:1.4;color:var(--c-text)}

.about__aside{
    background:linear-gradient(180deg,#fff,#fafcfd);
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:28px;
    box-shadow:var(--shadow-sm);
    position:sticky;
    top:96px;
}
.about__aside h3{
    font-size:18px;
    font-weight:700;
    margin-bottom:16px;
    color:var(--c-text);
}
.about__aside .cat{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:14px 16px;
    border-radius:var(--radius);
    background:var(--c-bg-soft);
    margin-bottom:8px;
    font-weight:600;
    font-size:14.5px;
    color:var(--c-text);
    border:1px solid transparent;
    transition:all var(--t-fast);
}
.about__aside .cat:hover{
    background:#fff;
    border-color:var(--c-line);
    color:var(--c-primary);
    transform:translateX(2px);
    box-shadow:var(--shadow-sm);
}
.about__aside .cat svg{color:var(--c-text-light);flex-shrink:0;transition:color var(--t-fast)}
.about__aside .cat:hover svg{color:var(--c-primary)}
.about__aside .btn{margin-top:14px}

/* ============ PRODUCTS / TABS ============ */
.products{padding:96px 0;background:var(--c-bg-soft)}
.products .section-head{margin-left:auto;margin-right:auto;text-align:center}

.tabs__nav{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    justify-content:center;
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:999px;
    padding:6px;
    box-shadow:var(--shadow-sm);
    max-width:fit-content;
    margin:0 auto 40px;
}
.tabs__tab{
    padding:10px 22px;
    border-radius:999px;
    font-weight:600;
    font-size:14px;
    color:var(--c-text-muted);
    transition:all var(--t-fast);
}
.tabs__tab:hover{color:var(--c-primary)}
.tabs__tab.is-active{background:var(--c-primary);color:var(--c-on-primary);box-shadow:0 6px 16px rgba(247,184,11,.3)}

.tabs__panel{display:none}
.tabs__panel.is-active{display:block;animation:fadeUp .4s var(--t)}
@keyframes fadeUp{
    from{opacity:0;transform:translateY(12px)}
    to{opacity:1;transform:translateY(0)}
}

.cards{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}
.cards--two{grid-template-columns:repeat(2,1fr);max-width:760px;margin:0 auto}
.card{
    background:#fff;
    border-radius:var(--radius-lg);
    overflow:hidden;
    border:1px solid var(--c-line);
    transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-fast);
    display:flex;flex-direction:column;
}
.card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow-lg);
    border-color:transparent;
}
.card__img{
    aspect-ratio:1/1;
    background:linear-gradient(180deg,#fbf8f5,#f6f2ee);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
}
.card__img img{
    width:88%;height:88%;
    object-fit:contain;
    transition:transform var(--t-slow);
}
.card:hover .card__img img{transform:scale(1.06)}
.card__body{
    padding:20px 22px 24px;
    display:flex;flex-direction:column;flex:1;
}
.card__body h4{
    font-size:16px;
    font-weight:700;
    margin-bottom:8px;
    line-height:1.3;
    color:var(--c-text);
    min-height:42px;
}
.card__body p{
    font-size:13.5px;
    color:var(--c-text-muted);
    line-height:1.55;
    margin-bottom:16px;
    flex:1;
}
.card__more{
    font-size:13px;
    font-weight:600;
    color:var(--c-primary);
    transition:gap var(--t-fast);
}
.card:hover .card__more{letter-spacing:.02em}

/* ============ APPLICATIONS ============ */
/* 4 преимущества (All Found / Timely / Economical / Worry-free) */
.claims{padding:44px 0 8px}
.claims__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.claims__item{background:var(--c-bg);border:1px solid var(--c-line);border-radius:var(--radius-lg);padding:24px 22px;box-shadow:var(--shadow-sm);transition:box-shadow var(--t-base),transform var(--t-base)}
.claims__item:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.claims__key{font-family:'Manrope',sans-serif;font-size:13px;font-weight:800;color:var(--c-primary);letter-spacing:.02em}
.claims__item h3{font-size:18px;font-weight:700;margin:6px 0 8px;color:var(--c-text)}
.claims__item p{font-size:13.5px;color:var(--c-text-muted);line-height:1.55}
@media(max-width:880px){.claims__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.claims__grid{grid-template-columns:1fr}}

.apps{padding:96px 0}
.apps__grid{
    display:grid;
    grid-template-columns:repeat(12,1fr);
    gap:16px;
}
/* 7 карточек применений: 3 в верхнем ряду (шире) + 4 в нижнем */
.apps__card:nth-child(-n+3){grid-column:span 4}
.apps__card:nth-child(n+4){grid-column:span 3}
.apps__card{
    position:relative;
    height:360px;
    border-radius:var(--radius-lg);
    overflow:hidden;
    background-size:cover;
    background-position:center;
    color:#fff;
    display:flex;
    align-items:flex-end;
    transition:transform var(--t-base), box-shadow var(--t-base);
    cursor:pointer;
    isolation:isolate;
}
.apps__card::after{
    content:'';
    position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(8,18,28,0) 25%,rgba(8,18,28,.92) 100%);
    z-index:1;
    transition:background var(--t-base);
}
.apps__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.apps__card:hover::after{background:linear-gradient(180deg,rgba(8,18,28,.15) 0%,rgba(8,18,28,.95) 100%)}
.apps__overlay{
    position:relative;z-index:2;
    padding:20px 22px 22px;
    width:100%;
}
.apps__letter{
    position:absolute;
    top:16px;right:20px;
    font-family:'Manrope',sans-serif;
    font-size:56px;
    font-weight:800;
    line-height:1;
    color:rgba(255,255,255,.20);
    letter-spacing:-.04em;
}
.apps__overlay h3{
    font-size:18px;
    font-weight:700;
    color:#fff;
    margin-bottom:8px;
    letter-spacing:-.01em;
    line-height:1.25;
}
.apps__overlay p{
    font-size:13.5px;
    color:rgba(255,255,255,.85);
    line-height:1.55;
    max-height:0;
    opacity:0;
    overflow:hidden;
    transition:max-height var(--t-base), opacity var(--t-base), margin-top var(--t-base);
}
.apps__card:hover .apps__overlay p{
    max-height:200px;
    opacity:1;
    margin-top:6px;
}
@media(max-width:1100px){
    .apps__grid{grid-template-columns:repeat(3,1fr)}
    .apps__card:nth-child(n){grid-column:auto}
}
@media(max-width:680px){
    .apps__grid{grid-template-columns:repeat(2,1fr)}
    .apps__card{height:300px}
    .apps__card:nth-child(n){grid-column:auto}
}
@media(max-width:420px){
    .apps__grid{grid-template-columns:1fr}
    .apps__card:nth-child(n){grid-column:auto}
}

/* ============ FACTORY ============ */
.factory{padding:96px 0;background:var(--c-bg-deep);color:#fff;position:relative;overflow:hidden}
.factory::before{
    content:'';
    position:absolute;inset:0;
    background:radial-gradient(circle at 0% 0%,rgba(247,184,11,.18),transparent 50%);
    pointer-events:none;
}
.factory__grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:64px;
    align-items:center;
    position:relative;
    z-index:1;
}
.factory__media{
    position:relative;
    border-radius:var(--radius-xl);
    overflow:hidden;
    aspect-ratio:4/3;
    background:#000;
    box-shadow:var(--shadow-xl);
}
.factory__media img{
    width:100%;height:100%;
    object-fit:cover;
    opacity:.9;
    transition:transform var(--t-slow);
}
.factory__media:hover img{transform:scale(1.04)}
.factory__play{
    position:absolute;
    top:50%;left:50%;transform:translate(-50%,-50%);
    width:88px;height:88px;
    background:#fff;
    color:var(--c-primary);
    border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    box-shadow:0 8px 32px rgba(0,0,0,.4);
    transition:transform var(--t-base),box-shadow var(--t-base);
}
.factory__play::before{
    content:'';
    position:absolute;inset:-12px;
    border:2px solid rgba(255,255,255,.4);
    border-radius:50%;
    animation:pulse 2s var(--t) infinite;
}
@keyframes pulse{
    0%{transform:scale(1);opacity:.6}
    100%{transform:scale(1.4);opacity:0}
}
.factory__play:hover{transform:translate(-50%,-50%) scale(1.08)}
.factory__play svg{margin-left:4px}

.factory__text .eyebrow{color:var(--c-accent)}
.factory__text .section-title{color:#fff}
.factory__text p{
    color:rgba(255,255,255,.74);
    font-size:15.5px;
    line-height:1.7;
    margin-bottom:14px;
}
.factory__text .link-arrow{color:var(--c-accent);margin-top:18px}

/* ============ MARKETS ============ */
.markets{padding:96px 0;background:var(--c-bg-soft)}
.markets__grid{
    display:grid;
    grid-template-columns:1fr 1.2fr;
    gap:64px;
    align-items:center;
}
.markets__text p{
    color:var(--c-text-muted);
    font-size:16.5px;
    margin-bottom:24px;
    max-width:480px;
}
.markets__list{display:flex;flex-direction:column;gap:12px}
.markets__list li{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius);
    padding:14px 18px;
    font-size:14px;
    color:var(--c-text-muted);
    line-height:1.55;
    box-shadow:var(--shadow-sm);
    transition:transform var(--t-fast),border-color var(--t-fast);
}
.markets__list li:hover{transform:translateX(4px);border-color:var(--c-primary)}
.markets__list b{
    display:inline-block;
    color:var(--c-primary);
    font-weight:700;
    margin-right:10px;
    min-width:80px;
}
.markets__map img{width:100%;height:auto;filter:saturate(.9)}

/* ============ WHY ============ */
.why{padding:96px 0}
.why__grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
    margin-top:8px;
}
.why__card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:36px 32px 32px;
    position:relative;
    overflow:hidden;
    transition:transform var(--t-base),box-shadow var(--t-base);
}
.why__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.why__num{
    font-family:'Manrope',sans-serif;
    font-size:80px;
    font-weight:800;
    line-height:1;
    color:var(--c-primary-soft);
    letter-spacing:-.04em;
    display:block;
    margin-bottom:16px;
    transition:color var(--t-fast);
}
.why__card:hover .why__num{color:var(--c-accent)}
.why__card--accent{
    background:var(--grad-brand-deep);
    border-color:transparent;
    color:#fff;
}
.why__card--accent h4,.why__card--accent p{color:#fff}
.why__card--accent .why__num{color:rgba(255,255,255,.22)}
.why__card--accent:hover .why__num{color:rgba(255,255,255,.4)}
.why__card h4{
    font-size:22px;
    font-weight:700;
    margin-bottom:14px;
    line-height:1.25;
}
.why__card p{
    font-size:15px;
    color:var(--c-text-muted);
    line-height:1.65;
}
.why__card.why__card--accent h4,
.why__card.why__card--accent p{color:#fff}

/* ============ CASES ============ */
.cases{padding:96px 0 96px;background:var(--c-bg-soft);overflow:hidden}
.cases__track{
    display:flex;
    gap:20px;
    animation:scrollX 40s linear infinite;
    will-change:transform;
}
.cases:hover .cases__track{animation-play-state:paused}
@keyframes scrollX{
    from{transform:translateX(0)}
    to{transform:translateX(calc(-50% - 10px))}
}
.cases__item{
    flex:0 0 auto;
    width:340px;
    aspect-ratio:4/3;
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    background:#fff;
}
.cases__item img{
    width:100%;height:100%;
    object-fit:cover;
    transition:transform var(--t-slow);
}
.cases__item:hover img{transform:scale(1.06)}

/* ============ CTA ============ */
.cta{padding:96px 0}
.cta__box{
    background:var(--grad-brand-deep);
    border-radius:var(--radius-xl);
    padding:56px;
    color:#fff;
    display:grid;
    grid-template-columns:1fr 1.2fr;
    gap:48px;
    align-items:center;
    box-shadow:var(--shadow-xl);
    position:relative;
    overflow:hidden;
}
.cta__box::before{
    content:'';
    position:absolute;
    top:-50%;right:-15%;
    width:60%;height:200%;
    background:radial-gradient(circle,rgba(255,255,255,.18),transparent 60%);
    pointer-events:none;
}
.cta__text{position:relative;z-index:1}
.cta__text h2{
    font-size:clamp(26px,3vw,38px);
    color:#fff;
    margin-bottom:14px;
    letter-spacing:-.02em;
}
.cta__text p{color:rgba(255,255,255,.85);font-size:16px;line-height:1.6}

.cta__form{
    position:relative;
    z-index:1;
    background:#fff;
    border-radius:var(--radius-lg);
    padding:24px;
    display:flex;flex-direction:column;gap:12px;
    box-shadow:0 24px 48px rgba(0,0,0,.18);
}
.cta__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cta__form input,
.cta__form textarea,
.modal__form input,
.modal__form textarea{
    width:100%;
    padding:12px 16px;
    background:var(--c-bg-soft);
    border:1px solid var(--c-line);
    border-radius:10px;
    font:inherit;
    font-size:15px;
    color:var(--c-text);
    transition:border-color var(--t-fast),background var(--t-fast);
}
.cta__form input:focus,
.cta__form textarea:focus,
.modal__form input:focus,
.modal__form textarea:focus{
    outline:none;
    border-color:var(--c-primary);
    background:#fff;
}
.cta__form textarea,.modal__form textarea{resize:vertical;min-height:90px}
.cta__legal{
    font-size:12px;
    color:var(--c-text-light);
    text-align:center;
    margin-top:4px;
}

/* ============ FOOTER ============ */
.footer{
    background:var(--c-bg-deep);
    color:rgba(255,255,255,.7);
    padding:64px 0 24px;
}
.footer__top{
    display:grid;
    grid-template-columns:1.5fr repeat(4,1fr);
    gap:40px;
    padding-bottom:48px;
    border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__brand p{font-size:14px;line-height:1.65;margin:18px 0;max-width:340px}
.footer__logo img{height:40px;width:auto;filter:brightness(0) invert(1)}
.footer__social{display:flex;gap:8px;margin-top:18px}
.footer__social a{
    width:36px;height:36px;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    display:inline-flex;align-items:center;justify-content:center;
    transition:background var(--t-fast),transform var(--t-fast);
    overflow:hidden;
}
.footer__social a:hover{background:var(--c-primary);transform:translateY(-2px)}
.footer__social img{width:18px;height:18px;border-radius:50%;object-fit:cover}

.footer__col h5{
    font-size:14px;
    font-weight:600;
    color:#fff;
    text-transform:uppercase;
    letter-spacing:.1em;
    margin-bottom:18px;
}
.footer__col ul li{margin-bottom:10px;font-size:14.5px}
.footer__col ul a{color:rgba(255,255,255,.7);transition:color var(--t-fast)}
.footer__col ul a:hover{color:var(--c-accent)}
.footer__contacts li{color:rgba(255,255,255,.7);line-height:1.55}
.footer__contacts a{color:rgba(255,255,255,.7)}
.footer__contacts a:hover{color:var(--c-accent)}

.footer__bottom{
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
    gap:12px;
    padding-top:24px;
    font-size:13px;
    color:rgba(255,255,255,.5);
}

/* ============ FAB & MODAL ============ */
.fab{
    position:fixed;
    bottom:24px;right:24px;
    z-index:60;
    background:var(--c-primary);
    color:#fff;
    border-radius:999px;
    padding:14px 22px;
    display:inline-flex;align-items:center;gap:10px;
    font-weight:600;font-size:14px;
    box-shadow:0 12px 32px rgba(247,184,11,.45);
    transition:transform var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);
}
.fab:hover{transform:translateY(-2px);background:var(--c-primary-dark);box-shadow:0 16px 40px rgba(247,184,11,.55)}

.modal{
    position:fixed;inset:0;
    z-index:200;
    display:flex;align-items:center;justify-content:center;
    padding:20px;
    opacity:0;
    visibility:hidden;
    transition:opacity var(--t-base),visibility var(--t-base);
}
.modal.is-open{opacity:1;visibility:visible}
.modal__backdrop{
    position:absolute;inset:0;
    background:rgba(8,18,28,.6);
    backdrop-filter:blur(6px);
}
.modal__window{
    position:relative;
    background:#fff;
    border-radius:var(--radius-lg);
    padding:32px;
    width:100%;max-width:460px;
    box-shadow:var(--shadow-xl);
    transform:translateY(20px) scale(.96);
    transition:transform var(--t-base);
}
.modal.is-open .modal__window{transform:translateY(0) scale(1)}
.modal__close{
    position:absolute;
    top:14px;right:14px;
    width:32px;height:32px;
    border-radius:50%;
    color:var(--c-text-muted);
    font-size:24px;line-height:1;
    transition:background var(--t-fast),color var(--t-fast);
}
.modal__close:hover{background:var(--c-bg-soft);color:var(--c-text)}
.modal__window h3{font-size:24px;margin-bottom:6px}
.modal__window > p{color:var(--c-text-muted);font-size:14.5px;margin-bottom:20px}
.modal__form{display:flex;flex-direction:column;gap:10px}

.toast{
    position:fixed;
    top:24px;left:50%;transform:translateX(-50%) translateY(-80px);
    background:#fff;
    color:var(--c-text);
    padding:14px 22px;
    border-radius:12px;
    box-shadow:var(--shadow-xl);
    border-left:4px solid var(--c-primary);
    font-weight:500;font-size:14px;
    z-index:300;
    transition:transform var(--t-base);
    max-width:360px;
}
.toast.is-visible{transform:translateX(-50%) translateY(0)}
.toast.is-error{border-left-color:#e74c3c}

/* ============ RESPONSIVE ============ */
@media(max-width:1100px){
    .about__grid{grid-template-columns:1fr;gap:48px}
    .about__aside{position:static}
    .cards{grid-template-columns:repeat(3,1fr)}
    .footer__top{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:900px){
    .about,.products,.apps,.factory,.markets,.why,.cases,.cta{padding:64px 0}
    .factory__grid,.markets__grid,.cta__box{grid-template-columns:1fr;gap:32px}
    .cta__box{padding:32px}
    .markets__map{order:-1;max-width:600px;margin:0 auto}
    .why__grid{grid-template-columns:1fr;gap:16px}
    .apps__grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,260px)}
    .apps__card--big,.apps__card--wide{grid-column:span 2}
    .apps__card--big{grid-row:auto}
}
@media(max-width:768px){
    .topbar__left{display:none}
    .topbar__inner{justify-content:center;gap:12px}
    .container.topbar__inner{padding:6px 0px}
    .topbar__right{margin-left:0;width:100%;justify-content:center;flex-wrap:wrap;gap:6px 22px}
    .topbar__item{font-size:13px}
    .nav{
        position:fixed;
        top:0;right:0;
        width:340px;max-width:92vw;
        height:100vh;
        overflow-y:auto;
        background:#fff;
        flex-direction:column;
        align-items:flex-start;
        padding:80px 24px 24px;
        box-shadow:-12px 0 40px rgba(0,0,0,.12);
        transform:translateX(100%);
        transition:transform var(--t-base);
        z-index:120;
    }
    .nav.is-open{transform:translateX(0)}
    .nav__close{
        display:flex;align-items:center;justify-content:center;
        position:absolute;top:14px;right:14px;
        width:36px;height:36px;border-radius:50%;
        font-size:28px;color:var(--c-text);
        background:var(--c-bg-soft);
    }
    .nav__list{flex-direction:column;align-items:stretch;width:100%;gap:2px}
    .nav__link{padding:13px 14px;display:block;border-radius:8px;font-size:16px}
    .nav__link--active::before{display:none}
    .nav__link--active{background:var(--c-primary-soft)}
    .icon-btn--burger{display:inline-flex}
    .header__cta{display:none}

    .about__facts{grid-template-columns:1fr 1fr;gap:10px}
    .about__features{grid-template-columns:repeat(3,1fr);gap:8px}
    .feature{align-items:center;text-align:center;gap:8px}
    .feature img{width:34px;height:34px}
    .feature p{font-size:12.5px;line-height:1.3}
    .cards{grid-template-columns:1fr 1fr;gap:14px}
    .cards--two{grid-template-columns:1fr}

    .footer__top{grid-template-columns:1fr;gap:32px;padding-bottom:32px}
    .footer__bottom{flex-direction:column;text-align:center}
    .fab span{display:none}
    .fab{padding:14px;width:52px;height:52px;justify-content:center}

    .container.header__inner{padding:10px 15px}

    .hero{padding:0}
    /* слайды стопкой в одной grid-ячейке: высота = по самому высокому (без скачков),
       переключение — плавный кроссфейд через opacity (а не display) */
    .hero__slider{display:grid;min-height:auto;height:auto;padding:34px 0 82px}
    .hero__slide{position:static;grid-area:1/1;display:flex;align-items:center;opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s;pointer-events:none}
    .hero__slide.is-active{opacity:1;visibility:visible;pointer-events:auto}
    .hero__slide > .container{display:flex;flex-direction:column;gap:18px}
    .hero__content{padding:0;max-width:none}
    /* картинка теперь видна — карточкой сверху */
    .hero__visual{display:block;position:static;transform:none;order:-1;width:100%;max-width:230px;margin:0 auto;aspect-ratio:1/1;padding:16px;box-shadow:0 16px 38px rgba(42,34,16,.16),0 0 0 1px rgba(15,26,36,.05)}
    .hero__visual img{animation:none}
    .hero__title{font-size:clamp(28px,8vw,40px)}
    .hero__lead{max-width:none;font-size:15px}
    .hero__actions{flex-direction:column;align-items:stretch}
    .hero__actions .btn{width:100%;justify-content:center}
    .hero__nav{bottom:20px}

    .tabs__nav{flex-wrap:nowrap;overflow-x:auto;border-radius:var(--radius);max-width:100%;justify-content:flex-start}
    .tabs__tab{flex-shrink:0}

    .cta__row{grid-template-columns:1fr}
}
@media(max-width:480px){
    .cards{grid-template-columns:1fr}
    .apps__grid{grid-template-columns:1fr;grid-template-rows:none}
    .apps__card,.apps__card--big,.apps__card--wide{grid-column:auto;height:280px}
    .about__facts{grid-template-columns:1fr 1fr}
    .container{padding:0 16px}
    .hero__title{font-size:34px}
    .cta__box{padding:24px}
    .cta__form{padding:18px}
    .modal__window{padding:24px 20px}
}

/* ============ SCROLL REVEAL ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--t),transform .6s var(--t)}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* ============ PAGE HERO ============ */
.page-hero{
    background:
        radial-gradient(ellipse 58% 80% at 84% 38%, rgba(247,184,11,.14), transparent 60%),
        linear-gradient(165deg, #ffffff 0%, #f8f4ed 55%, #f3ede2 100%);
    color:var(--c-text);
    padding:88px 0 72px;
    position:relative;
    overflow:hidden;
    border-bottom:1px solid var(--c-line);
}
.page-hero::before{
    content:'';
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(247,184,11,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(247,184,11,.06) 1px, transparent 1px);
    background-size:80px 80px;
    -webkit-mask-image:radial-gradient(ellipse at 80% 45%, black 22%, transparent 72%);
    mask-image:radial-gradient(ellipse at 80% 45%, black 22%, transparent 72%);
    pointer-events:none;
}
.page-hero > .container{position:relative;z-index:1}
.breadcrumb{
    display:flex;align-items:center;gap:8px;
    color:var(--c-text-muted);font-size:13.5px;
    margin-bottom:20px;
    letter-spacing:.02em;
}
.breadcrumb a{
    color:var(--c-text-muted);
    transition:color var(--t-fast);
}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb span{color:var(--c-text-light)}
.page-hero__title{
    font-size:clamp(32px, 4vw, 52px);
    font-weight:800;
    color:var(--c-text);
    margin-bottom:14px;
    letter-spacing:-.025em;
    line-height:1.1;
}
.page-hero__lead{
    font-size:17px;
    color:var(--c-text-muted);
    max-width:560px;
    line-height:1.55;
}

/* ============ CONTACT PAGE ============ */
.contact-page{padding:80px 0 96px;background:var(--c-bg-soft)}
.contact-page__grid{
    display:grid;
    grid-template-columns:1fr 1.4fr;
    gap:32px;
    align-items:start;
}
.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:22px 24px;
    transition:transform var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
}
.contact-card:hover{
    transform:translateY(-2px);
    border-color:var(--c-primary);
    box-shadow:var(--shadow-md);
}
.contact-card__icon{
    width:42px;height:42px;
    border-radius:50%;
    background:var(--c-primary-soft);
    color:var(--c-primary);
    display:inline-flex;align-items:center;justify-content:center;
    margin-bottom:14px;
}
.contact-card h3{
    font-size:12.5px;
    font-weight:600;
    color:var(--c-text-muted);
    text-transform:uppercase;
    letter-spacing:.14em;
    margin-bottom:8px;
}
.contact-card p{
    font-size:15.5px;
    line-height:1.55;
    color:var(--c-text);
    font-weight:500;
}
.contact-card a{
    color:var(--c-text);
    transition:color var(--t-fast);
}
.contact-card a:hover{color:var(--c-primary)}

.contact-social{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:22px 24px;
}
.contact-social h3{
    font-size:12.5px;
    font-weight:600;
    color:var(--c-text-muted);
    text-transform:uppercase;
    letter-spacing:.14em;
    margin-bottom:14px;
}
.contact-social__list{display:flex;gap:8px}
.contact-social__list a{
    width:40px;height:40px;
    border-radius:50%;
    background:var(--c-bg-soft);
    border:1px solid var(--c-line);
    display:inline-flex;align-items:center;justify-content:center;
    overflow:hidden;
    transition:all var(--t-fast);
}
.contact-social__list a:hover{
    background:var(--c-primary);
    border-color:var(--c-primary);
    transform:translateY(-2px);
}
.contact-social__list img{width:18px;height:18px;border-radius:50%;object-fit:cover}

.contact-form-card{
    background:#fff;
    border-radius:var(--radius-xl);
    padding:36px 36px 32px;
    box-shadow:var(--shadow-md);
    border:1px solid var(--c-line);
}
.contact-form-card h2{
    font-size:28px;
    margin-bottom:8px;
    color:var(--c-text);
    letter-spacing:-.015em;
}
.contact-form-card > p{
    color:var(--c-text-muted);
    margin-bottom:24px;
    font-size:14.5px;
    line-height:1.55;
}
.contact-form{display:flex;flex-direction:column;gap:12px}
.contact-form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-form input,
.contact-form textarea{
    width:100%;
    padding:13px 16px;
    background:var(--c-bg-soft);
    border:1px solid var(--c-line);
    border-radius:10px;
    font:inherit;
    font-size:15px;
    color:var(--c-text);
    transition:border-color var(--t-fast), background var(--t-fast);
}
.contact-form input:focus,
.contact-form textarea:focus{
    outline:none;
    border-color:var(--c-primary);
    background:#fff;
}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form button{align-self:flex-start;margin-top:4px}
.contact-form__legal{
    font-size:12px;
    color:var(--c-text-light);
    margin-top:6px;
}

/* На странице контактов FAB не нужен */
body.page-contact .fab{display:none}

/* ============ ABOUT-INTRO ============ */
.about-intro{padding:80px 0}
.about-intro__grid{
    display:grid;
    grid-template-columns:1.3fr 1fr;
    gap:64px;
    align-items:start;
}
.about-intro__text .lead{font-size:17px;color:var(--c-text-muted);margin-bottom:18px;max-width:600px}
.about-intro__text .lead--small{font-size:15px}

/* ============ STATS GRID ============ */
.stats-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px;
}
.stats-grid--four{grid-template-columns:repeat(4,1fr)}
.stats-grid li{
    background:var(--c-bg-soft);
    padding:22px 24px;
    border-radius:var(--radius-lg);
    border:1px solid var(--c-line);
    transition:border-color var(--t-fast), transform var(--t-fast);
}
.stats-grid li:hover{border-color:var(--c-primary);transform:translateY(-2px)}
.stats-grid b{
    display:block;
    font-family:'Manrope',sans-serif;
    font-size:26px;
    font-weight:800;
    color:var(--c-text);
    letter-spacing:-.025em;
    margin-bottom:4px;
    line-height:1.1;
}
.stats-grid span{font-size:13px;color:var(--c-text-muted);line-height:1.4}

/* ============ FACILITIES ============ */
.facilities{padding:96px 0;background:var(--c-bg-soft)}
.facility-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
}
.facility-card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:32px 28px 28px;
    transition:transform var(--t-base), box-shadow var(--t-base);
}
.facility-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.facility-card__year{
    display:inline-block;
    font-family:'Manrope',sans-serif;
    font-size:13px;
    font-weight:700;
    color:var(--c-primary);
    background:var(--c-primary-soft);
    padding:5px 14px;
    border-radius:999px;
    margin-bottom:18px;
    letter-spacing:.04em;
}
.facility-card h3{
    font-size:22px;
    margin-bottom:10px;
    color:var(--c-text);
}
.facility-card__lead{
    font-size:14.5px;
    color:var(--c-text-muted);
    line-height:1.55;
    margin-bottom:18px;
}
.facility-card__list{
    display:flex;
    flex-direction:column;
    gap:8px;
    border-top:1px solid var(--c-line);
    padding-top:16px;
}
.facility-card__list li{
    font-size:14px;
    color:var(--c-text);
    padding-left:20px;
    position:relative;
    line-height:1.5;
}
.facility-card__list li::before{
    content:'';
    position:absolute;
    left:0;top:8px;
    width:8px;height:8px;
    border-radius:50%;
    background:var(--c-primary);
}
.facility-card--accent{
    background:var(--grad-brand-deep);
    border-color:transparent;
}
.facility-card--accent h3{color:#fff}
.facility-card--accent .facility-card__lead{color:rgba(255,255,255,.85)}
.facility-card--accent .facility-card__list li{color:#fff}
.facility-card--accent .facility-card__year{
    background:rgba(255,255,255,.2);
    color:#fff;
}
.facility-card--accent .facility-card__list{border-top-color:rgba(255,255,255,.18)}
.facility-card--accent .facility-card__list li::before{background:#fff}

/* ============ TIMELINE ============ */
.timeline-section{padding:96px 0}
.timeline{
    position:relative;
    margin-top:40px;
    padding-left:36px;
    list-style:none;
}
.timeline::before{
    content:'';
    position:absolute;
    left:8px;
    top:8px;bottom:8px;
    width:2px;
    background:linear-gradient(180deg, var(--c-primary), var(--c-line));
}
.timeline__item{
    position:relative;
    padding:0 0 30px 28px;
}
.timeline__item:last-child{padding-bottom:0}
.timeline__item::before{
    content:'';
    position:absolute;
    left:-36px;top:6px;
    width:18px;height:18px;
    border-radius:50%;
    background:#fff;
    border:3px solid var(--c-primary);
    box-shadow:0 0 0 4px var(--c-primary-soft);
}
.timeline__date{
    font-family:'Manrope',sans-serif;
    font-size:13px;
    font-weight:700;
    color:var(--c-primary);
    letter-spacing:.05em;
    text-transform:uppercase;
    margin-bottom:6px;
}
.timeline__body h4{
    font-size:19px;
    color:var(--c-text);
    margin-bottom:6px;
    line-height:1.3;
}
.timeline__body p{
    font-size:14.5px;
    color:var(--c-text-muted);
    line-height:1.55;
    max-width:540px;
}

/* ============ APPS CATS ============ */
.applications-grid-section{padding:96px 0;background:var(--c-bg-soft)}
.apps-cats{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:14px;
}
.apps-cat{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:28px 24px;
    transition:transform var(--t-base), border-color var(--t-fast), box-shadow var(--t-base);
}
.apps-cat:hover{
    transform:translateY(-3px);
    border-color:var(--c-primary);
    box-shadow:var(--shadow-md);
}
.apps-cat h4{
    font-size:17px;
    color:var(--c-text);
    line-height:1.3;
    font-weight:700;
}

/* ============ MISSION BLOCK ============ */
.mission-block{padding:80px 0;background:var(--c-bg-soft)}
.mission-block__quote{
    max-width:880px;
    margin:0 auto;
    text-align:center;
}
.mission-block__quote .eyebrow{display:inline-block}
.mission-block__quote blockquote{
    margin:14px 0 0;
    padding:0;
    border:0;
}
.mission-block__quote blockquote p{
    font-family:'Manrope',sans-serif;
    font-size:clamp(24px, 3vw, 38px);
    font-weight:700;
    color:var(--c-text);
    line-height:1.3;
    letter-spacing:-.02em;
}
.mission-block__sub{
    margin-top:18px;
    font-size:16px;
    color:var(--c-text-muted);
    line-height:1.55;
    max-width:580px;
    margin-left:auto;
    margin-right:auto;
}

/* ============ RD SECTION ============ */
.rd-section{padding:96px 0;background:var(--c-bg-deep);color:#fff;position:relative;overflow:hidden}
.rd-section::before{
    content:'';
    position:absolute;inset:0;
    background:radial-gradient(circle at 20% 100%, rgba(247,184,11,.18), transparent 55%);
    pointer-events:none;
}
.rd-section__grid{
    display:grid;
    grid-template-columns:1.3fr 1fr;
    gap:56px;
    align-items:center;
    position:relative;
    z-index:1;
}
.rd-section__text .eyebrow{color:var(--c-accent)}
.rd-section__text .section-title{color:#fff}
.rd-section__text p{
    color:rgba(255,255,255,.78);
    font-size:16px;
    line-height:1.65;
    margin-top:14px;
    max-width:560px;
}
.rd-section__stats{display:flex;flex-direction:column;gap:12px}
.rd-stat{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.1);
    border-radius:var(--radius-lg);
    padding:22px 26px;
    backdrop-filter:blur(8px);
}
.rd-stat b{
    display:block;
    font-family:'Manrope',sans-serif;
    font-size:26px;
    font-weight:800;
    color:#fff;
    letter-spacing:-.025em;
    margin-bottom:4px;
    line-height:1.1;
}
.rd-stat span{font-size:13px;color:rgba(255,255,255,.72);line-height:1.4}

/* ============ WORKFLOW ============ */
.workflow-section{padding:96px 0}
.workflow{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
    margin-top:32px;
    align-items:stretch;
}
.workflow__step{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:28px 26px;
    transition:transform var(--t-base), box-shadow var(--t-base);
}
.workflow__step:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.workflow__num{
    display:inline-block;
    font-family:'Manrope',sans-serif;
    font-size:34px;
    font-weight:800;
    color:var(--c-primary);
    line-height:1;
    margin-bottom:12px;
    letter-spacing:-.02em;
}
.workflow__step h4{
    font-size:17px;
    color:var(--c-text);
    margin-bottom:8px;
    line-height:1.3;
}
.workflow__step p{
    font-size:13.5px;
    color:var(--c-text-muted);
    line-height:1.5;
}
.workflow__step--mid{
    background:var(--c-bg-soft);
    border-style:dashed;
}
.workflow__step--mid .workflow__num{color:var(--c-text-muted)}
.workflow__note{
    margin-top:28px;
    text-align:center;
    color:var(--c-text-muted);
    font-size:14.5px;
}

/* ============ FLOOR ============ */
.floor-section{padding:96px 0;background:var(--c-bg-soft)}
.floor-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
}
.floor-card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    overflow:hidden;
    transition:transform var(--t-base), box-shadow var(--t-base);
}
.floor-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.floor-card__img{aspect-ratio:16/10;overflow:hidden}
.floor-card__img img{
    width:100%;height:100%;
    object-fit:cover;
    transition:transform var(--t-slow);
}
.floor-card:hover .floor-card__img img{transform:scale(1.05)}
.floor-card h3{
    font-size:19px;
    margin:22px 24px 8px;
    color:var(--c-text);
}
.floor-card p{
    font-size:14px;
    color:var(--c-text-muted);
    line-height:1.55;
    margin:0 24px 22px;
}

/* ============ ADVANTAGES ============ */
.advantages-section{padding:96px 0;background:var(--c-bg-soft)}
.adv-list{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:18px;
    margin-top:8px;
}
.adv-list .adv-card:nth-child(1){grid-column:span 2}
.adv-card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:32px 30px 28px;
    position:relative;
    transition:transform var(--t-base), box-shadow var(--t-base);
}
.adv-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.adv-card__num{
    display:inline-block;
    font-family:'Manrope',sans-serif;
    font-size:32px;
    font-weight:800;
    color:var(--c-primary-soft);
    line-height:1;
    letter-spacing:-.025em;
    margin-bottom:14px;
    transition:color var(--t-fast);
}
.adv-card:hover .adv-card__num{color:var(--c-accent)}
.adv-card h3{
    font-size:19px;
    color:var(--c-text);
    margin-bottom:10px;
    line-height:1.3;
}
.adv-card p{
    font-size:14.5px;
    color:var(--c-text-muted);
    line-height:1.6;
}
.adv-card--accent{
    background:var(--grad-brand-deep);
    border-color:transparent;
}
.adv-card--accent h3{color:#fff}
.adv-card--accent p{color:rgba(255,255,255,.86)}
.adv-card--accent .adv-card__num{color:rgba(255,255,255,.3)}
.adv-card--accent:hover .adv-card__num{color:rgba(255,255,255,.5)}

.adv-numbers{padding:64px 0}

/* ============ RESPONSIVE ============ */
@media(max-width:1100px){
    .adv-list{grid-template-columns:repeat(2,1fr)}
    .adv-list .adv-card:nth-child(1){grid-column:span 2}
}
@media(max-width:900px){
    .about-intro__grid{grid-template-columns:1fr;gap:32px}
    .facility-grid{grid-template-columns:1fr}
    .floor-grid{grid-template-columns:1fr}
    .rd-section__grid{grid-template-columns:1fr;gap:32px}
    .stats-grid--four{grid-template-columns:repeat(2,1fr)}
    .workflow{grid-template-columns:1fr}
    .apps-cats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
    .adv-list{grid-template-columns:1fr}
    .adv-list .adv-card:nth-child(1){grid-column:auto}
    .apps-cats{grid-template-columns:1fr}
    .stats-grid{grid-template-columns:1fr 1fr}
}

/* ============ APPLICATION PAGE ============ */
.page-hero--app{position:relative}
.page-hero--app .page-hero__title{font-size:clamp(34px,4.4vw,56px);line-height:1.1;max-width:760px}
.page-hero__letter{
    position:absolute;
    top:32px;right:var(--gutter);
    font-family:'Manrope',sans-serif;
    font-size:clamp(140px, 18vw, 240px);
    font-weight:800;
    line-height:1;
    color:rgba(247,184,11,.08);
    letter-spacing:-.05em;
    pointer-events:none;
    user-select:none;
    z-index:0;
}
.app-intro{padding:80px 0}
.app-intro__grid{
    display:grid;
    grid-template-columns:1.4fr 1fr;
    gap:48px;
    align-items:start;
}
.app-intro p{
    font-size:16px;
    color:var(--c-text-muted);
    line-height:1.65;
    margin-top:14px;
    max-width:580px;
}
.app-bullets{
    display:flex;
    flex-direction:column;
    gap:10px;
    background:var(--c-bg-soft);
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:24px 26px;
}
.app-bullets li{
    position:relative;
    padding-left:24px;
    font-size:15px;
    color:var(--c-text);
    line-height:1.5;
}
.app-bullets li::before{
    content:'';
    position:absolute;
    left:0;top:9px;
    width:8px;height:8px;
    border-radius:50%;
    background:var(--c-primary);
}

.app-advantages{padding:80px 0;background:var(--c-bg-soft)}
.adv-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:16px;
}
.adv-mini{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:24px 22px;
    transition:transform var(--t-base),box-shadow var(--t-base);
}
.adv-mini:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.adv-mini__num{
    display:inline-block;
    font-family:'Manrope',sans-serif;
    font-size:24px;
    font-weight:800;
    color:var(--c-primary);
    line-height:1;
    margin-bottom:10px;
    letter-spacing:-.02em;
}
.adv-mini h4{
    font-size:16px;
    color:var(--c-text);
    margin-bottom:8px;
    line-height:1.3;
}
.adv-mini p{
    font-size:13.5px;
    color:var(--c-text-muted);
    line-height:1.55;
}

.app-products{padding:80px 0}
.app-product-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
    gap:16px;
}
.app-product{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    overflow:hidden;
    transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-fast);
    display:flex;
    flex-direction:column;
}
.app-product:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.app-product__img{
    aspect-ratio:1/1;
    background:linear-gradient(180deg,#fbf8f5,#f6f2ee);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
}
.app-product__img img{
    width:88%;height:88%;
    object-fit:contain;
    transition:transform var(--t-slow);
}
.app-product:hover .app-product__img img{transform:scale(1.06)}
.app-product h4{
    font-size:15px;
    font-weight:700;
    color:var(--c-text);
    margin:18px 20px 4px;
    font-family:'Manrope',sans-serif;
    letter-spacing:-.01em;
}
.app-product p{
    font-size:13px;
    color:var(--c-text-muted);
    margin:0 20px 18px;
}
.app-products__note{
    margin-top:24px;
    text-align:center;
    color:var(--c-text-muted);
    font-size:14px;
}

.app-related{padding:80px 0;background:var(--c-bg-soft)}
.related-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:14px;
}
.related-card{
    position:relative;
    height:200px;
    border-radius:var(--radius-lg);
    overflow:hidden;
    background-size:cover;
    background-position:center;
    color:#fff;
    isolation:isolate;
    transition:transform var(--t-base);
}
.related-card::after{
    content:'';
    position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(8,18,28,.2) 0%,rgba(8,18,28,.85) 100%);
    z-index:1;
}
.related-card:hover{transform:translateY(-3px)}
.related-card__overlay{
    position:absolute;
    inset:0;
    z-index:2;
    padding:20px 22px;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
}
.related-card__overlay span{
    position:absolute;
    top:14px;right:18px;
    font-family:'Manrope',sans-serif;
    font-size:42px;
    font-weight:800;
    color:rgba(255,255,255,.25);
    line-height:1;
    letter-spacing:-.04em;
}
.related-card__overlay h4{
    font-size:17px;
    color:#fff;
    line-height:1.2;
}

@media(max-width:900px){
    .app-intro__grid{grid-template-columns:1fr;gap:32px}
}

/* ============ NEWS LIST ============ */
.news-section{padding:80px 0}
.news-tabs{
    display:flex;
    gap:6px;
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:999px;
    padding:6px;
    box-shadow:var(--shadow-sm);
    max-width:fit-content;
    margin:0 auto 32px;
}
.news-tab{
    padding:9px 22px;
    border-radius:999px;
    font-weight:600;
    font-size:14px;
    color:var(--c-text-muted);
    transition:all var(--t-fast);
}
.news-tab:hover{color:var(--c-primary)}
.news-tab.is-active{background:var(--c-primary);color:var(--c-on-primary);box-shadow:0 6px 16px rgba(247,184,11,.3)}
.news-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:22px;
}
.news-grid--three{grid-template-columns:repeat(3,1fr)}
.news-card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    overflow:hidden;
    transition:transform var(--t-base),box-shadow var(--t-base);
    display:flex;
    flex-direction:column;
}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.news-card__img{aspect-ratio:16/10;overflow:hidden;background:#fbf8f5}
.news-card__img img{width:100%;height:100%;object-fit:contain;padding:14%;transition:transform var(--t-slow)}
.news-card:hover .news-card__img img{transform:scale(1.04)}
.news-card__body{padding:20px 22px 22px;flex:1;display:flex;flex-direction:column}
.news-card__date{
    font-size:12.5px;
    font-weight:600;
    color:var(--c-primary);
    letter-spacing:.05em;
    text-transform:uppercase;
    margin-bottom:8px;
}
.news-card h3{
    font-size:17px;
    color:var(--c-text);
    margin-bottom:8px;
    line-height:1.3;
    font-weight:700;
}
.news-card p{
    font-size:13.5px;
    color:var(--c-text-muted);
    line-height:1.55;
    flex:1;
}
.news-section__more{margin-top:32px;text-align:center}
.news-section--related{background:var(--c-bg-soft)}
@media(max-width:900px){
    .news-grid--three{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
    .news-grid--three{grid-template-columns:1fr}
}

/* ============ POST DETAIL ============ */
.post-header{
    background:
        radial-gradient(ellipse 58% 80% at 84% 38%, rgba(247,184,11,.14), transparent 60%),
        linear-gradient(165deg, #ffffff 0%, #f8f4ed 55%, #f3ede2 100%);
    color:var(--c-text);
    padding:80px 0 88px;
    position:relative;
    overflow:hidden;
    border-bottom:1px solid var(--c-line);
}
.post-header::before{
    content:'';
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(247,184,11,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(247,184,11,.06) 1px, transparent 1px);
    background-size:80px 80px;
    -webkit-mask-image:radial-gradient(ellipse at 80% 45%, black 22%, transparent 72%);
    mask-image:radial-gradient(ellipse at 80% 45%, black 22%, transparent 72%);
    pointer-events:none;
}
.post-header > .container{position:relative;z-index:1}
.post-header .breadcrumb{margin-bottom:24px}
.post-header__cat{
    display:inline-block;
    font-size:12.5px;
    font-weight:600;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--c-primary);
    background:var(--c-primary-soft);
    border:1px solid rgba(247,184,11,.22);
    padding:6px 14px;
    border-radius:999px;
    margin-bottom:18px;
}
.post-header__title{
    font-size:clamp(28px,3.8vw,46px);
    font-weight:800;
    color:#fff;
    line-height:1.15;
    max-width:880px;
    margin-bottom:18px;
    letter-spacing:-.025em;
}
.post-header__meta{
    display:flex;
    gap:10px;
    font-size:14px;
    color:var(--c-text-muted);
}
.post-body{padding:48px 0 80px}
.post-cover{
    margin:-100px auto 40px;
    max-width:780px;
    border-radius:var(--radius-xl);
    overflow:hidden;
    aspect-ratio:16/9;
    box-shadow:var(--shadow-xl);
    position:relative;
    z-index:2;
    background:#fbf8f5;
}
.post-cover img{width:100%;height:100%;object-fit:contain;padding:6%}
.post-content{
    max-width:720px;
    margin:0 auto;
    font-size:17px;
    line-height:1.7;
    color:var(--c-text);
}
.post-content > *+*{margin-top:18px}
.post-content .post-lead{
    font-size:19px;
    color:var(--c-text);
    font-weight:500;
    line-height:1.6;
    padding-left:16px;
    border-left:3px solid var(--c-primary);
}
.post-content h2{font-size:28px;margin-top:40px;letter-spacing:-.02em}
.post-content h3{font-size:22px;margin-top:32px;letter-spacing:-.015em}
.post-content p{color:var(--c-text-muted)}
.post-content ul,.post-content ol{padding-left:24px}
.post-content ul{list-style:disc}
.post-content ol{list-style:decimal}
.post-content li{margin-top:6px;color:var(--c-text-muted)}
.post-content blockquote{
    border-left:3px solid var(--c-accent);
    background:var(--c-bg-soft);
    padding:18px 22px;
    border-radius:0 var(--radius) var(--radius) 0;
    margin:28px 0;
}
.post-content blockquote p{font-style:italic;color:var(--c-text);font-size:18px}
.post-content a{color:var(--c-primary);text-decoration:underline;text-underline-offset:3px}
.post-content a:hover{color:var(--c-primary-dark)}
.post-content strong{color:var(--c-text);font-weight:700}
.post-share{
    max-width:720px;
    margin:48px auto 0;
    padding-top:24px;
    border-top:1px solid var(--c-line);
    display:flex;
    align-items:center;
    gap:14px;
    font-size:14px;
    color:var(--c-text-muted);
}
.post-share a{
    color:var(--c-primary);
    font-weight:600;
    transition:color var(--t-fast);
}
.post-share a:hover{color:var(--c-primary-dark)}

/* ============ CERTIFICATES ============ */
.certs-section{padding:80px 0}
.certs-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:18px;
}
.cert-card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:28px 26px;
    transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-fast);
}
.cert-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.cert-card__badge{
    display:inline-flex;
    align-items:center;justify-content:center;
    width:64px;height:64px;
    border-radius:16px;
    background:var(--c-primary-soft);
    color:var(--c-primary);
    font-family:'Manrope',sans-serif;
    font-size:22px;
    font-weight:800;
    letter-spacing:-.01em;
    margin-bottom:18px;
}
.cert-card h3{
    font-size:18px;
    color:var(--c-text);
    margin-bottom:10px;
    line-height:1.3;
}
.cert-card p{
    font-size:14px;
    color:var(--c-text-muted);
    line-height:1.6;
}
.cert-card--accent{
    background:var(--grad-brand-deep);
    border-color:transparent;
}
.cert-card--accent h3{color:#fff}
.cert-card--accent p{color:rgba(255,255,255,.86)}
.cert-card--accent .cert-card__badge{
    background:rgba(255,255,255,.2);
    color:#fff;
}
.certs-note{
    margin-top:32px;
    text-align:center;
    color:var(--c-text-muted);
    font-size:14.5px;
    max-width:680px;
    margin-left:auto;
    margin-right:auto;
}

/* ============ CATALOG ============ */
.catalog-section{padding:64px 0 96px}
.catalog-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
    gap:20px;
    margin-top:8px;
}
.catalog-grid--two{grid-template-columns:repeat(2,1fr);max-width:760px;margin:0 auto}
.catalog-card{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    overflow:hidden;
    transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-fast);
    display:flex;flex-direction:column;
}
.catalog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.catalog-card__img{
    aspect-ratio:1/1;
    background:linear-gradient(180deg,#fbf8f5,#f6f2ee);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
}
.catalog-card__img img{
    width:88%;height:88%;
    object-fit:contain;
    transition:transform var(--t-slow);
}
.catalog-card:hover .catalog-card__img img{transform:scale(1.06)}
.catalog-card__body{
    padding:18px 20px 20px;
    display:flex;flex-direction:column;flex:1;
}
.catalog-card__cat{
    font-size:11.5px;
    font-weight:600;
    color:var(--c-primary);
    letter-spacing:.06em;
    text-transform:uppercase;
    margin-bottom:6px;
}
.catalog-card h4{
    font-size:15.5px;
    font-weight:700;
    margin-bottom:6px;
    line-height:1.3;
    color:var(--c-text);
    font-family:'Manrope',sans-serif;
    letter-spacing:-.01em;
    min-height:40px;
}
.catalog-card p{
    font-size:13px;
    color:var(--c-text-muted);
    line-height:1.5;
    margin-bottom:12px;
    flex:1;
}
.catalog-card__specs{
    display:flex;flex-wrap:wrap;gap:6px;
    margin-top:auto;
    padding-top:12px;
    border-top:1px solid var(--c-line);
}
.catalog-card__specs li{
    font-size:11px;
    font-weight:600;
    color:var(--c-text-muted);
    background:var(--c-bg-soft);
    padding:3px 8px;
    border-radius:6px;
    letter-spacing:.02em;
}

/* ============ PRODUCT DETAIL ============ */
.product-crumbs{
    background:#fff;
    border-bottom:1px solid var(--c-line);
    padding:14px 0;
}
.product-crumbs .breadcrumb{
    margin:0;
    color:var(--c-text-muted);
    font-size:13.5px;
}
.product-crumbs .breadcrumb a{color:var(--c-text-muted)}
.product-crumbs .breadcrumb a:hover{color:var(--c-primary)}
.product-crumbs .breadcrumb span{color:var(--c-text-light)}

.product-main{padding:48px 0 64px}
.product-main__grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:56px;
    align-items:start;
}
.product-gallery{position:sticky;top:96px}
.product-gallery__main{
    aspect-ratio:1/1;
    background:linear-gradient(180deg,#fbf8f5,#f6f2ee);
    border:1px solid var(--c-line);
    border-radius:var(--radius-xl);
    overflow:hidden;
    display:flex;align-items:center;justify-content:center;
    margin-bottom:14px;
}
.product-gallery__main img{
    width:80%;height:80%;
    object-fit:contain;
}
.product-gallery__thumbs{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:10px;
}
.product-gallery__thumb{
    aspect-ratio:1/1;
    background:linear-gradient(180deg,#fbf8f5,#f6f2ee);
    border:2px solid var(--c-line);
    border-radius:12px;
    overflow:hidden;
    padding:0;
    cursor:pointer;
    transition:border-color var(--t-fast),transform var(--t-fast);
}
.product-gallery__thumb:hover{border-color:var(--c-primary);transform:translateY(-2px)}
.product-gallery__thumb.is-active{border-color:var(--c-primary)}
.product-gallery__thumb img{width:100%;height:100%;object-fit:contain;padding:8%}

.product-info__cat{
    display:inline-block;
    font-size:12.5px;
    font-weight:600;
    color:var(--c-primary);
    letter-spacing:.08em;
    text-transform:uppercase;
    background:var(--c-primary-soft);
    padding:5px 12px;
    border-radius:999px;
    margin-bottom:18px;
}
.product-info__title{
    font-size:clamp(28px,3.4vw,40px);
    font-weight:800;
    color:var(--c-text);
    letter-spacing:-.02em;
    line-height:1.15;
    margin-bottom:16px;
}
.product-info__lead{
    font-size:16.5px;
    color:var(--c-text-muted);
    line-height:1.6;
    margin-bottom:24px;
}
.product-info__badges{
    display:flex;flex-wrap:wrap;gap:8px;
    margin-bottom:28px;
}
.badge{
    display:inline-block;
    font-size:12.5px;
    font-weight:700;
    color:var(--c-primary);
    background:var(--c-primary-soft);
    padding:6px 12px;
    border-radius:999px;
    letter-spacing:.04em;
    font-family:'Manrope',sans-serif;
}

.product-specs{
    width:100%;
    border-collapse:collapse;
    margin-bottom:28px;
}
.product-specs th,
.product-specs td{
    text-align:left;
    padding:13px 0;
    border-bottom:1px solid var(--c-line);
    font-size:14.5px;
    vertical-align:top;
}
.product-specs th{
    width:42%;
    font-weight:600;
    color:var(--c-text-muted);
}
.product-specs td{color:var(--c-text);font-weight:500}
.product-specs tr:last-child th,
.product-specs tr:last-child td{border-bottom:0}

.product-info__cta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.product-info__note{
    font-size:13px;
    color:var(--c-text-light);
    line-height:1.5;
}

/* Описание */
.product-desc{padding:64px 0;background:var(--c-bg-soft)}
.product-desc__grid{
    display:grid;
    grid-template-columns:1.6fr 1fr;
    gap:40px;
    align-items:start;
}
.product-desc__main{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:40px 44px;
}
.product-desc__main h2{
    font-size:26px;
    margin-bottom:16px;
    letter-spacing:-.015em;
}
.product-desc__main h3{
    font-size:18px;
    margin:28px 0 10px;
    letter-spacing:-.01em;
}
.product-desc__main p{
    font-size:15.5px;
    color:var(--c-text-muted);
    line-height:1.7;
    margin-bottom:14px;
}
.product-desc__main ul{
    margin:6px 0 0;
    padding-left:22px;
    list-style:disc;
}
.product-desc__main li{
    font-size:15px;
    color:var(--c-text-muted);
    line-height:1.7;
    margin-bottom:6px;
}
.product-desc__placeholder{
    margin-top:24px;
    padding:14px 18px;
    background:var(--c-bg-soft);
    border-left:3px solid var(--c-text-light);
    border-radius:0 8px 8px 0;
    font-size:13.5px;
    color:var(--c-text-light);
}
.product-desc__aside{
    background:#fff;
    border:1px solid var(--c-line);
    border-radius:var(--radius-lg);
    padding:28px 30px;
    position:sticky;
    top:96px;
}
.product-desc__aside h4{
    font-size:18px;
    margin-bottom:8px;
    letter-spacing:-.01em;
}
.product-desc__aside > p{
    font-size:14px;
    color:var(--c-text-muted);
    line-height:1.55;
    margin-bottom:18px;
}
.product-desc__aside-list{
    display:flex;flex-direction:column;gap:10px;
    margin-bottom:18px;
}
.product-desc__aside-list li{
    display:flex;align-items:center;gap:10px;
    font-size:14px;
    color:var(--c-text);
    font-weight:500;
}
.product-desc__aside-list svg{color:var(--c-primary);flex-shrink:0}

.product-related{padding:80px 0}

@media(max-width:900px){
    .product-main__grid{grid-template-columns:1fr;gap:32px}
    .product-gallery{position:static}
    .product-desc__grid{grid-template-columns:1fr;gap:24px}
    .product-desc__main{padding:28px 26px}
    .product-desc__aside{position:static}
}
@media(max-width:600px){
    .catalog-grid--two{grid-template-columns:1fr}
    .product-info__title{font-size:26px}
    .product-specs th{width:50%}
}

@media(max-width:900px){
    .contact-page__grid{grid-template-columns:1fr;gap:24px}
    .contact-form__row{grid-template-columns:1fr}
    .contact-form-card{padding:28px 24px}
    .page-hero{padding:64px 0 56px}
}

/* ============ NEWS LISTING + ARTICLE (redesign) ============ */
.news-listing{padding:60px 0 84px}
.news-listing__head{margin-bottom:30px}
.news-listing .news-grid{grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:980px){.news-listing .news-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.news-listing .news-grid{grid-template-columns:1fr}}
.news-card h3{min-height:0}
.news-card__body time{display:block;font-size:12.5px;font-weight:600;color:var(--c-primary);letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}
.news-card__body h3,.news-card__body h4{font-size:16.5px;color:var(--c-text);margin:0 0 9px;line-height:1.34;font-weight:700;font-family:'Manrope',sans-serif;letter-spacing:-.01em}
.news-card__body p{font-size:13.5px;color:var(--c-text-muted);line-height:1.55;margin:0;flex:1}
.news-empty{text-align:center;color:var(--c-text-muted);padding:64px 0}

/* pagination */
.afl-pagination{margin-top:50px}
.afl-pagination .nav-links{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center}
.afl-pagination .page-numbers{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:44px;height:44px;padding:0 15px;
    border:1px solid var(--c-line);border-radius:11px;background:#fff;
    color:var(--c-text);font-weight:600;font-size:14.5px;text-decoration:none;
    transition:border-color var(--t-fast),color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);
}
.afl-pagination a.page-numbers:hover{border-color:var(--c-primary);color:var(--c-primary)}
.afl-pagination .page-numbers.current{background:var(--c-primary);border-color:var(--c-primary);color:#fff;box-shadow:0 6px 16px rgba(247,184,11,.28)}
.afl-pagination .page-numbers.dots{border:0;background:none;min-width:20px;color:var(--c-text-light)}

/* single article */
.post-single{padding:52px 0 76px}
.post-single .container{max-width:824px}
.post-single__cover{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:40px;background:#fbf8f5;border:1px solid var(--c-line)}
.post-single__cover img{display:block;width:100%;height:auto}
.post-meta{margin-top:18px;color:var(--c-text-muted);font-size:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.post-meta time{color:var(--c-text);font-weight:600}
.post-meta .post-cat{color:var(--c-primary);font-weight:600}
.post-body{font-size:16.5px;color:#2b3a48;line-height:1.78}
.post-body>*:first-child{margin-top:0}
.post-body h2{font-size:25px;color:var(--c-text);margin:40px 0 14px;line-height:1.26;letter-spacing:-.015em;font-family:'Manrope',sans-serif;font-weight:800}
.post-body h3{font-size:19px;color:var(--c-text);margin:30px 0 10px;letter-spacing:-.01em;font-weight:700}
.post-body p{margin:0 0 18px}
.post-body ul,.post-body ol{margin:0 0 18px;padding-left:24px;list-style:disc}
.post-body ol{list-style:decimal}
.post-body li{margin-bottom:9px}
.post-body a{color:var(--c-primary);text-decoration:underline;text-underline-offset:2px}
.post-body img{max-width:100%;height:auto;border-radius:12px;margin:22px 0}
.post-body strong,.post-body b{color:var(--c-text)}
.post-single__taxonomy{margin-top:40px;padding-top:22px;border-top:1px solid var(--c-line);font-size:14px;color:var(--c-text-muted)}
.post-single__taxonomy a{color:var(--c-primary)}
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:46px}
.post-nav a{display:flex;flex-direction:column;gap:7px;padding:18px 22px;border:1px solid var(--c-line);border-radius:var(--radius);background:#fff;color:var(--c-text);font-weight:600;font-size:14.5px;line-height:1.4;transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast)}
.post-nav a:hover{border-color:var(--c-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.post-nav a span{font-size:12px;font-weight:700;color:var(--c-primary);text-transform:uppercase;letter-spacing:.06em}
.post-nav__next{text-align:right;align-items:flex-end}
.post-back{text-align:center;margin-top:42px}
@media(max-width:600px){
    .post-nav{grid-template-columns:1fr}
    .post-nav__next{text-align:left;align-items:flex-start}
    .post-body{font-size:16px}
    .post-body h2{font-size:22px}
}

/* ============ PAGE CONTENT: full-bleed section backgrounds ============ */
.page-content{padding-bottom:6px}
.page-article{width:100%}
.page-article > section{width:100%}                       /* секции на всю ширину экрана (фон до краёв) */
.page-article > :not(section):not(style):not(script):not(.alignfull):not(.container){
    max-width:1200px;margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px;
}
/* страницы с обычным текстом (без секций) — отступы + типографика */
.page-article--text{padding:54px 0 66px}
.page-article--text > .container > p{font-size:16.5px;color:var(--c-text-muted);line-height:1.75;margin:0 0 16px;max-width:840px}
.page-article--text > .container > ul,.page-article--text > .container > ol{margin:4px 0 20px;padding-left:24px;max-width:840px;list-style:disc}
.page-article--text > .container > ol{list-style:decimal}
.page-article--text > .container > li{font-size:16px;color:var(--c-text-muted);line-height:1.7;margin-bottom:9px}
.page-article--text > .container > h2{font-size:25px;color:var(--c-text);margin:32px 0 12px;font-family:'Manrope',sans-serif;font-weight:800;letter-spacing:-.015em}
.page-article--text > .container > h3{font-size:19px;color:var(--c-text);margin:26px 0 10px}
.page-article--text > .container > *:first-child{margin-top:0}
.page-article--text a{color:var(--c-primary);text-decoration:underline;text-underline-offset:2px}

/* ============ CATALOG (страница продукции) ============ */
.catalog-tabs{padding:30px 0 80px}
.catalog-tabs .tabs__nav{margin-bottom:28px}
.catalog-pager{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin-top:38px}
.catalog-pager button{min-width:44px;height:44px;padding:0 15px;border:1px solid var(--c-line);border-radius:11px;background:#fff;color:var(--c-text);font-weight:600;font-size:14.5px;cursor:pointer;transition:border-color var(--t-fast),color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast)}
.catalog-pager button:hover:not(:disabled):not(.dots){border-color:var(--c-primary);color:var(--c-primary)}
.catalog-pager button.is-active{background:var(--c-primary);border-color:var(--c-primary);color:var(--c-on-primary);box-shadow:0 6px 16px rgba(247,184,11,.28)}
.catalog-pager button:disabled{opacity:.4;cursor:default}
.catalog-pager .dots{border:0;background:none;cursor:default;min-width:16px;padding:0;color:var(--c-text-light)}
.catalog-cta{margin-top:50px;text-align:center;background:linear-gradient(135deg,#2a2210,#6b4d10);color:#fff;border-radius:var(--radius-lg);padding:48px 32px;position:relative;overflow:hidden}
.catalog-cta h3{font-size:25px;font-weight:800;font-family:'Manrope',sans-serif;margin:0 0 8px;color:#fff;letter-spacing:-.01em}
.catalog-cta p{font-size:15.5px;color:rgba(255,255,255,.82);margin:0 auto 24px;max-width:580px;line-height:1.6}
.catalog-cta .btn--primary{background:#fff;color:#0f2a35}
.catalog-cta .btn--primary:hover{background:#fef4d6;color:#0f2a35}

/* ============ Каталог: карточки категорий (лендинг) ============ */
.catalog-cats{padding:16px 0 0}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(430px,1fr));gap:28px}
.cat-card{display:flex;flex-direction:column;background:var(--c-bg);border:1px solid var(--c-line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast)}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--c-primary)}
.cat-card__img{aspect-ratio:16/10;background:linear-gradient(135deg,#fbf8f6,#f6f2ee);display:flex;align-items:center;justify-content:center;padding:26px}
.cat-card__img img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 14px 26px rgba(15,26,36,.14))}
.cat-card__body{padding:24px 28px 28px;display:flex;flex-direction:column;gap:9px;flex:1}
.cat-card__count{align-self:flex-start;background:var(--c-primary-soft);color:#7a5a00;font-size:12px;font-weight:700;letter-spacing:.02em;padding:4px 11px;border-radius:999px}
.cat-card__body h3{font-size:23px;letter-spacing:-.02em}
.cat-card__body p{color:var(--c-text-muted);font-size:15px;line-height:1.62;flex:1}
.cat-card__more{margin-top:4px;font-weight:700;color:var(--c-text);display:inline-flex;align-items:center;gap:8px}
.cat-card__more svg{transition:transform var(--t-fast)}
.cat-card:hover .cat-card__more{color:var(--c-primary-dark)}
.cat-card:hover .cat-card__more svg{transform:translateX(4px)}
@media(max-width:760px){.cat-grid{grid-template-columns:1fr;gap:18px}.cat-card__body h3{font-size:21px}}

/* выдача категории */
.catalog-cat{padding:4px 0 0}
.catalog-back{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14.5px;color:var(--c-text-muted);margin-bottom:26px;transition:color var(--t-fast),gap var(--t-fast)}
.catalog-back:hover{color:var(--c-primary-dark);gap:11px}
.catalog-cta-wrap{padding:56px 0 90px}
.catalog-cta-wrap .catalog-cta{margin-top:0}
a.catalog-back{margin-top:20px}
.product-gallery__main{background:#fff!important}
.catalog-card__img{background:#fff!important}
.page-content{padding-bottom:0}

/* мягкая CTA-полоса внизу страниц */
.cta--soft{padding:60px 0;background:var(--c-bg-soft);border-top:1px solid var(--c-line)}
.cta--soft .cta__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.cta--soft .cta__inner > div{flex:1 1 320px;min-width:0}
.cta--soft h3{font-size:24px;font-weight:800;color:var(--c-text);font-family:'Manrope',sans-serif;letter-spacing:-.01em;line-height:1.25;margin:0}
.cta--soft p{margin:8px 0 0;color:var(--c-text-muted);font-size:15.5px;line-height:1.6}
.cta--soft .btn{flex-shrink:0}
@media(max-width:700px){.cta--soft .cta__inner{flex-direction:column;align-items:flex-start}}

/* ============ NAV DROPDOWNS ============ */
.nav__list .menu-item-has-children{position:relative}
.nav__list .menu-item-has-children > .nav__link::after{content:"";display:inline-block;width:6px;height:6px;margin-left:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-2px) rotate(45deg);opacity:.5}
.nav__list .menu-item-has-children::before{content:"";position:absolute;top:100%;left:0;right:0;height:12px}
.nav__list .sub-menu{
    position:absolute;top:calc(100% + 8px);left:0;z-index:120;
    min-width:228px;list-style:none;margin:0;padding:7px;
    background:#fff;border:1px solid var(--c-line);border-radius:14px;box-shadow:var(--shadow-lg);
    opacity:0;visibility:hidden;transform:translateY(8px);
    transition:opacity .18s var(--t),transform .18s var(--t),visibility .18s;
}
.nav__list .menu-item-has-children:hover > .sub-menu,
.nav__list .menu-item-has-children:focus-within > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav__list .sub-menu .menu-item{width:100%}
.nav__list .sub-menu .nav__link{display:block;width:100%;padding:9px 13px;border-radius:9px;font-weight:500;white-space:nowrap}
.nav__list .sub-menu .nav__link:hover{background:var(--c-primary-soft);color:var(--c-primary)}
@media(max-width:768px){
    .nav__list .sub-menu{
        position:static;opacity:1;visibility:visible;transform:none;
        box-shadow:none;border:0;border-left:2px solid var(--c-line);border-radius:0;
        margin:2px 0 6px 12px;padding:0 0 0 8px;min-width:0;
    }
    .nav__list .menu-item-has-children::before{display:none}
    .nav__list .menu-item-has-children > .nav__link::after{display:none}
    .nav__list .sub-menu .nav__link{padding:11px 10px;font-size:14.5px;white-space:normal;line-height:1.3}
}

/* ============ HOME: представительство (FMR) ============ */
.home-company{padding:78px 0;background:var(--c-bg-soft);border-bottom:1px solid var(--c-line)}
.home-company__grid{display:grid;grid-template-columns:0.92fr 1.08fr;gap:52px;align-items:stretch}
.home-company__media{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--c-line);height:100%;min-height:420px;box-shadow:0 18px 44px rgba(42,34,16,.14)}
.home-company__media img{width:100%;height:100%;object-fit:cover;display:block}
.home-company__body .section-title{margin:12px 0 20px}
.home-company__text p{font-size:16px;color:var(--c-text-muted);line-height:1.78;margin:0 0 16px}
.home-company__text p:first-child{font-size:18px;color:var(--c-text);font-weight:500;line-height:1.65}
.home-company__text p:last-child{margin-bottom:0}
@media(max-width:860px){
    .home-company{padding:54px 0}
    .home-company__grid{grid-template-columns:1fr;gap:26px}
    .home-company__media{max-width:480px;height:340px;min-height:0}
    .home-company__text p:first-child{font-size:17px}
}

/* ============ PRODUCT: тех. данные (cloudair) ============ */
.product-cloud{padding:58px 0;border-top:1px solid var(--c-line)}
.product-cloud--desc,.product-cloud--dim{background:var(--c-bg-soft)}
.section-head--left{text-align:left;align-items:flex-start;margin-bottom:26px}
/* 1. описание типа */
.product-cloud--desc .product-cloud__cols{display:grid;grid-template-columns:.82fr 1.18fr;gap:48px;align-items:center}
.product-cloud__media{border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(180deg,#fff,#f5f0ea);border:1px solid var(--c-line);display:flex;align-items:center;justify-content:center;padding:18px;height:320px}
.product-cloud__media img{width:100%;height:100%;object-fit:contain;display:block}
.product-cloud__body .section-title{margin:10px 0 16px}
.product-cloud__rich p{font-size:16px;color:var(--c-text-muted);line-height:1.75;margin:0 0 14px}
.product-cloud__rich p:last-child{margin-bottom:0}
/* 2. характеристики */
.product-spectable{width:100%;border-collapse:collapse;max-width:780px}
.product-spectable th,.product-spectable td{text-align:left;padding:11px 16px;border-bottom:1px solid var(--c-line);font-size:15px;vertical-align:top}
.product-spectable th{color:var(--c-text-muted);font-weight:500;width:56%}
.product-spectable td{color:var(--c-text);font-weight:600}
/* 3. габариты */
.product-cloud__dimgrid{display:grid;grid-template-columns:1.25fr .75fr;gap:42px;align-items:center}
.product-cloud__drawing,.product-cloud__schema{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);padding:22px;display:flex;align-items:center;justify-content:center;height:400px;width:100%;max-width:580px;box-sizing:border-box}
.product-cloud__drawing img,.product-cloud__schema img{width:100%;height:100%;object-fit:contain;display:block}
.product-cloud__dimtable-wrap{overflow-x:auto}
.product-dimtable{border-collapse:collapse;width:100%}
.product-dimtable th,.product-dimtable td{border:1px solid var(--c-line);padding:9px 14px;text-align:center;font-size:15px}
.product-dimtable thead th{background:var(--c-primary);color:#fff;font-weight:700}
.product-dimtable__unit td{background:var(--c-bg-soft);color:var(--c-text-light);font-size:12px;padding:4px 14px}
.product-dimtable tbody td{font-weight:600;font-size:16px}
.product-cloud__hint{font-size:13px;color:var(--c-text-light);margin:12px 0 0}
/* 4. схема — общий фрейм с чертежом (см. .product-cloud__drawing,.product-cloud__schema выше) */
@media(max-width:860px){
    .product-cloud{padding:42px 0}
    .product-cloud--desc .product-cloud__cols{grid-template-columns:1fr;gap:24px}
    .product-cloud__dimgrid{grid-template-columns:1fr;gap:24px}
    .product-spectable th{width:62%}
}
/* описание типа внутри подборщика (вкладка «номиналы») */
.sel-cloud-desc p{margin:0 0 10px}
.sel-cloud-desc p:last-child{margin:0}
/* подборщик: тех. данные стопкой под графиком (без табов) */
.sel-tech{margin-top:18px;display:flex;flex-direction:column;gap:16px}
.sel-tech-grid{display:grid;grid-template-columns:.72fr 1.28fr;gap:28px;align-items:center}
.sel-tech-dimgrid{display:grid;grid-template-columns:1.3fr .7fr;gap:30px;align-items:center}
.sel-tech-fam{background:linear-gradient(180deg,#fff,#f6f3ee);border:1px solid var(--c-line);border-radius:12px;padding:16px;display:flex;align-items:center;justify-content:center;height:300px}
.sel-tech-fam img{width:100%;height:100%;object-fit:contain;display:block}
/* унифицированный фрейм чертежа/схемы в подборщике */
.sel-tech .sel-dim-img{height:340px;max-width:560px;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}
.sel-tech .sel-dim-img img{width:100%;height:100%;object-fit:contain}
@media(max-width:760px){.sel-tech-grid,.sel-tech-dimgrid{grid-template-columns:1fr;gap:18px}}
/* подборщик: характеристики в 2 колонки + габариты/схема в ряд */
.sel-spec-cols{column-count:2;column-gap:50px}
.sel-spec-row{display:flex;justify-content:space-between;gap:14px;padding:9px 2px;border-bottom:1px solid var(--c-line);break-inside:avoid}
.sel-spec-row .sk{color:var(--c-text-muted);font-size:13.5px;line-height:1.35}
.sel-spec-row .sv{color:var(--c-text);font-weight:600;font-size:13.5px;text-align:right;padding-left:10px}
.sel-tech-row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.sel-tech-row2 .sel-dim-img{height:auto;max-width:none;margin-top:6px;padding:16px}
.sel-tech-row2 .sel-dim-img img{width:100%;height:auto}
.sel-tech-hint{font-size:12px;color:var(--c-text-light);margin:10px 0 0}
.sel-tech-sub{font-size:12.5px;color:var(--c-text-muted);margin:0 0 12px}
@media(max-width:760px){.sel-spec-cols{column-count:1}.sel-tech-row2{grid-template-columns:1fr}}

/* ============ Плавающий виджет связи ============ */
.cfab{position:fixed;right:22px;bottom:22px;z-index:960;display:flex;flex-direction:column;align-items:center;gap:10px}
.cfab__toggle{width:58px;height:58px;border-radius:50%;border:0;background:var(--c-primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(247,184,11,.42);transition:transform var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);position:relative}
.cfab__toggle:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(247,184,11,.5)}
.cfab__toggle svg{width:24px;height:24px;position:absolute;transition:opacity .18s,transform .25s}
.cfab__icon-close{opacity:0;transform:rotate(-45deg) scale(.6)}
.cfab.is-open .cfab__icon-open{opacity:0;transform:rotate(45deg) scale(.6)}
.cfab.is-open .cfab__icon-close{opacity:1;transform:rotate(0) scale(1)}
.cfab__toggle::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(247,184,11,.45);animation:cfabPulse 2.6s ease-out infinite;pointer-events:none}
.cfab.is-open .cfab__toggle::after{animation:none;opacity:0}
@keyframes cfabPulse{0%{transform:scale(.9);opacity:.9}70%{transform:scale(1.35);opacity:0}100%{transform:scale(1.35);opacity:0}}
.cfab__menu{display:flex;flex-direction:column;gap:4px;background:linear-gradient(180deg,#3a2e13,#2a2210);padding:10px 7px;border-radius:999px;box-shadow:0 16px 38px rgba(42,34,16,.35);opacity:0;transform:translateY(14px) scale(.92);transform-origin:bottom center;pointer-events:none;transition:opacity .22s,transform .25s cubic-bezier(.3,1.4,.5,1)}
.cfab.is-open .cfab__menu{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.cfab__item{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;position:relative;transition:background var(--t-fast),color var(--t-fast)}
.cfab__item:hover{background:rgba(255,255,255,.14);color:var(--c-primary)}
.cfab__item svg{width:21px;height:21px}
.cfab__item::before{content:attr(data-tip);position:absolute;right:calc(100% + 14px);top:50%;transform:translateY(-50%) translateX(6px);background:#0f2a35;color:#fff;font-size:12.5px;font-weight:500;line-height:1;padding:9px 13px;border-radius:9px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s,transform .2s;box-shadow:0 8px 20px rgba(42,34,16,.3)}
.cfab__item::after{content:"";position:absolute;right:calc(100% + 8px);top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:#0f2a35;opacity:0;transition:opacity .15s}
.cfab__item:hover::before{opacity:1;transform:translateY(-50%) translateX(0)}
.cfab__item:hover::after{opacity:1}
@media(max-width:768px){
    .cfab{right:14px;bottom:14px}
    .cfab__toggle{width:52px;height:52px}
    .cfab__item{width:44px;height:44px}
    .cfab__item::before,.cfab__item::after{display:none} /* тултипы не нужны на тач-экранах */
}
/* баннер подборщика на главной: на мобиле — в столбик (текст сверху, цифры снизу) */
.selector-cta__grid{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center}
@media(max-width:768px){
    .selector-cta__grid{grid-template-columns:1fr;gap:20px}
    .selector-cta .section-title{font-size:26px}
}

/* ============ Каталог: карточки-группы + исполнения ============ */
.catalog-card__img{position:relative}
.catalog-card__badge{position:absolute;top:10px;right:10px;background:rgba(42,34,16,.82);color:#fff;font-size:12px;font-weight:600;padding:4px 9px;border-radius:999px;backdrop-filter:blur(2px)}
.catalog-card__opts{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.catalog-card__opt{font-size:12px;color:var(--c-text-muted);background:var(--c-bg-soft);border:1px solid var(--c-line);border-radius:7px;padding:3px 9px;white-space:nowrap}
/* страница товара: блок исполнений */
.product-variants{padding:48px 0;background:var(--c-bg-soft);border-top:1px solid var(--c-line)}
.product-variants__lead{font-size:15px;color:var(--c-text-muted);max-width:640px;margin-top:8px;line-height:1.6}
.product-variants__wrap{overflow-x:auto;margin-top:24px;border:1px solid var(--c-line);border-radius:var(--radius-lg);background:#fff}
.product-variants__table{width:100%;border-collapse:collapse;min-width:480px}
.product-variants__table th,.product-variants__table td{text-align:left;padding:13px 18px;border-bottom:1px solid var(--c-line);font-size:15px}
.product-variants__table th{font-size:12.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-light);font-weight:600;background:var(--c-bg-soft)}
.product-variants__table tr:last-child td{border-bottom:0}
.product-variants__table tr.is-current{background:var(--c-primary-soft)}
.product-variants__code{font-weight:600;color:var(--c-text)}
.product-variants__you{display:inline-block;font-size:11px;font-weight:600;color:var(--c-primary);background:#fff;border:1px solid var(--c-primary);border-radius:6px;padding:1px 7px;margin-left:8px;vertical-align:middle}
.product-variants__go a{color:var(--c-primary);font-weight:600;font-size:14px;white-space:nowrap}
.product-variants__go a:hover{text-decoration:underline}
@media(max-width:768px){.product-variants{padding:36px 0}}
