/* =========================================================
   PRODUCT PAGE — /product/i-love-life
   (desktop + mobile)
   ========================================================= */

body[data-page="product"] main {
    display: block;
}

/* общий контейнер */
body[data-page="product"] .p-shell {
    display: grid;
    grid-template-columns: 1.35fr .95fr;
    gap: 18px;
    align-items: start;
}

/* карточки */
body[data-page="product"] .p-card {
    border: 1px solid var(--border-soft);
    background: linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .02));
    border-radius: 18px;
    box-shadow:
        0 18px 40px rgba(0, 0, 0, .35),
        inset 0 1px 0 rgba(255, 255, 255, .06);
    overflow: hidden;
}

/* HERO */
body[data-page="product"] .p-hero {
    margin-top: 18px;
}

/* PREVIEW */
body[data-page="product"] .p-preview {
    position: relative;
}

body[data-page="product"] .p-preview-top {
    padding: 18px 18px 0;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

body[data-page="product"] .p-badge {
    font-size: 12px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .72);
}

body[data-page="product"] .p-kicker {
    font-size: 12px;
    color: rgba(255, 255, 255, .55);
}

body[data-page="product"] .p-video {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: 18px;
    background: #000;

    aspect-ratio: 506 / 402;
    display: block;
    isolation: isolate;
}

/* === VIDEO INTERACTION HINT === */
body[data-page="product"] .p-video {
    position: relative;
}

body[data-page="product"] .p-video-hint {
    position: absolute;
    right: 14px;
    bottom: 12px;
    z-index: 3;

    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;

    color: rgba(255, 255, 255, .55);
    opacity: 0;

    pointer-events: none;
    transition: opacity .25s ease;
}

/* показываем подсказку только когда видео на паузе */
body[data-page="product"] .p-video.is-paused .p-video-hint {
    opacity: 1;
}

body[data-page="product"] .p-video-el {
    position: absolute;
    inset: 0;

    width: 100%;
    height: 100%;
    display: block;

    object-fit: contain;
    object-position: 50% 50%;

    margin: 0;
    padding: 0;
    transform: translateZ(0);
    background: #000;
}

body[data-page="product"] .p-preview-bottom {
    padding: 18px;
    display: grid;
    gap: 14px;
}

body[data-page="product"] .p-title {
    margin: 0;
    font-size: clamp(30px, 3.2vw, 44px);
    line-height: 1.05;
    letter-spacing: .01em;
}

body[data-page="product"] .p-sub {
    margin: 10px 0 0;
    font-size: 15px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .75);
}

body[data-page="product"] .p-points {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

body[data-page="product"] .p-point {
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 14px;
    padding: 12px 12px;
    background: rgba(0, 0, 0, .18);
}

body[data-page="product"] .p-point-h {
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 6px;
}

body[data-page="product"] .p-point-t {
    font-size: 12px;
    line-height: 1.35;
    color: rgba(255, 255, 255, .65);
}

/* BUY */
body[data-page="product"] .p-buy {
    position: sticky;
    top: 18px;
    padding: 18px;
}

body[data-page="product"] .p-buy-top {
    display: grid;
    gap: 10px;
    margin-bottom: 14px;
}

/* BUY TITLE (moved from preview) */
body[data-page="product"] .p-buy-title {
    display: grid;
    gap: 8px;
    margin-bottom: 6px;
}

body[data-page="product"] .p-buy-title .p-title {
    font-size: 22px;
    line-height: 1.08;
    letter-spacing: .01em;
}

body[data-page="product"] .p-buy-title .p-sub {
    margin: 0;
    font-size: 13px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .70);
}

body[data-page="product"] .p-buy-label {
    font-size: 12px;
    color: rgba(255, 255, 255, .65);
}

body[data-page="product"] .p-price-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

body[data-page="product"] .p-price {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: .01em;
}

body[data-page="product"] .p-price-sub {
    font-size: 12px;
    color: rgba(255, 255, 255, .55);
}

body[data-page="product"] .p-buy-btn {
    width: 100%;
    margin-top: 2px;
}

body[data-page="product"] .p-buy-note {
    margin-top: 12px;
    font-size: 13px;
    color: rgba(255, 255, 255, .65);
}

body[data-page="product"] .p-mini {
    margin-top: 14px;
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 14px;
    overflow: hidden;
    background: rgba(0, 0, 0, .16);
}

body[data-page="product"] .p-mini-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px;
    border-top: 1px solid rgba(255, 255, 255, .06);
}

body[data-page="product"] .p-mini-row:first-child {
    border-top: 0;
}

body[data-page="product"] .p-mini-k {
    font-size: 12px;
    color: rgba(255, 255, 255, .55);
}

body[data-page="product"] .p-mini-v {
    font-size: 12px;
    color: rgba(255, 255, 255, .85);
}

body[data-page="product"] .p-buy-divider {
    height: 1px;
    margin: 16px 0 10px;
    background: rgba(255, 255, 255, .06);
}

/* SECTIONS GRID */
body[data-page="product"] .p-grid {
    margin-top: 18px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    padding-bottom: 74px;
    /* под sticky на мобильных */
}

body[data-page="product"] .p-section {
    padding: 18px;
}

body[data-page="product"] .p-wide {
    grid-column: 1 / -1;
}

body[data-page="product"] .p-h {
    font-size: 14px;
    font-weight: 800;
    letter-spacing: .02em;
    margin-bottom: 12px;
}

body[data-page="product"] .p-subh {
    margin-top: 14px;
    font-size: 12px;
    font-weight: 700;
    color: rgba(255, 255, 255, .72);
}

body[data-page="product"] .p-text {
    font-size: 14px;
    line-height: 1.55;
    color: rgba(255, 255, 255, .75);
}

body[data-page="product"] .p-list {
    margin: 0;
    padding-left: 18px;
    display: grid;
    gap: 8px;
}

body[data-page="product"] .p-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: .95em;
    color: rgba(255, 255, 255, .9);
}

body[data-page="product"] .p-hint {
    margin-top: 12px;
    font-size: 12px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .58);
}

/* steps */
body[data-page="product"] .p-steps {
    display: grid;
    gap: 10px;
}

body[data-page="product"] .p-step {
    display: grid;
    grid-template-columns: 30px 1fr;
    gap: 10px;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 14px;
    background: rgba(0, 0, 0, .16);
}

body[data-page="product"] .p-step-n {
    width: 30px;
    height: 30px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    font-weight: 800;
    background: rgba(245, 193, 91, .12);
    border: 1px solid rgba(245, 193, 91, .22);
    color: rgba(245, 193, 91, .95);
}

body[data-page="product"] .p-step-t {
    font-weight: 800;
    font-size: 13px;
    margin-bottom: 4px;
}

body[data-page="product"] .p-step-d {
    font-size: 12px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .68);
}

/* requirements */
body[data-page="product"] .p-req {
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 14px;
    background: rgba(0, 0, 0, .16);
}

body[data-page="product"] .p-req-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

body[data-page="product"] .p-req-k {
    font-size: 12px;
    color: rgba(255, 255, 255, .60);
}

body[data-page="product"] .p-req-v {
    font-size: 12px;
    color: rgba(255, 255, 255, .85);
    text-align: right;
}

/* chips */
body[data-page="product"] .p-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

body[data-page="product"] .p-chip {
    font-size: 12px;
    padding: 8px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .07);
    background:
        linear-gradient(145deg, rgba(245, 193, 91, .10), rgba(245, 193, 91, 0) 60%),
        rgba(0, 0, 0, .14);
    color: rgba(255, 255, 255, .86);
    white-space: nowrap;
}

/* FAQ details */
body[data-page="product"] .p-faq {
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 14px;
    background: rgba(0, 0, 0, .14);
    overflow: hidden;
    margin-top: 10px;
}

body[data-page="product"] .p-faq summary {
    cursor: pointer;
    padding: 12px 12px;
    list-style: none;
    font-weight: 800;
    font-size: 13px;
    color: rgba(255, 255, 255, .88);
    outline: none;
}

body[data-page="product"] .p-faq summary::-webkit-details-marker {
    display: none;
}

body[data-page="product"] .p-faq-body {
    padding: 0 12px 12px;
}

/* Sticky buy bar (mobile only) */
body[data-page="product"] .p-sticky {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 20;
    padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
    background: linear-gradient(180deg, rgba(5, 6, 10, 0), rgba(5, 6, 10, .88) 35%, rgba(5, 6, 10, .96));
    pointer-events: none;
    /* включим на внутреннем контейнере */
}

body[data-page="product"] .p-sticky-in {
    pointer-events: auto;
    max-width: 960px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 16px;
    padding: 10px 12px;
    background:
        linear-gradient(145deg, rgba(245, 193, 91, .10), rgba(245, 193, 91, 0) 55%),
        rgba(0, 0, 0, .42);
    box-shadow: 0 18px 50px rgba(0, 0, 0, .45);
}

body[data-page="product"] .p-sticky-t {
    font-weight: 800;
    font-size: 13px;
    line-height: 1.15;
}

body[data-page="product"] .p-sticky-p {
    font-size: 12px;
    color: rgba(255, 255, 255, .65);
    margin-top: 2px;
}

body[data-page="product"] .p-sticky-btn {
    width: auto;
    min-width: 120px;
}

/* =========================================================
   MOBILE
   ========================================================= */
@media (max-width: 768px) {

    /* чтобы iOS/Instagram не давали “лишние пиксели” по ширине */
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    /* ВАЖНО: фоновые линии в style.css используют 100vw + translate.
       На iOS это иногда даёт сдвиг — фиксируем только для product. */
    body[data-page="product"] .page::before {
        left: 0;
        right: 0;
        width: 100%;
        transform: none;
    }

    body[data-page="product"] .p-hero {
        margin-top: 10px;
    }

    body[data-page="product"] .p-shell {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    body[data-page="product"] .p-buy {
        position: relative;
        top: auto;
        padding: 16px;
    }

    body[data-page="product"] .p-preview-top {
        padding: 16px 16px 0;
    }

    body[data-page="product"] .p-video {
        margin: 12px 16px 0;
        width: calc(100% - 32px);
        box-sizing: border-box;
    }

    body[data-page="product"] .p-preview-bottom {
        padding: 16px;
    }

    body[data-page="product"] .p-points {
        grid-template-columns: 1fr;
    }

    body[data-page="product"] .p-grid {
        grid-template-columns: 1fr;
        gap: 14px;
        padding-bottom: 110px;
        /* чтобы контент не прятался под sticky */
    }

    /* sticky bar показываем только на мобилке */
    body[data-page="product"] .p-sticky {
        display: block;
    }
}

/* desktop: sticky bar скрываем */
@media (min-width: 769px) {
    body[data-page="product"] .p-sticky {
        display: none;
    }
}

/* Narrow desktop */
@media (max-width: 980px) and (min-width: 769px) {
    body[data-page="product"] .p-shell {
        grid-template-columns: 1.2fr 1fr;
    }

    body[data-page="product"] .p-points {
        grid-template-columns: 1fr;
    }
}

/* === ARCHIVE STRUCTURE === */
body[data-page="product"] .p-archive {
    margin-top: 16px;
}

body[data-page="product"] .p-archive-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 10px;
}

body[data-page="product"] .p-archive-title {
    font-weight: 700;
    font-size: 14px;
}

body[data-page="product"] .p-archive-sub {
    font-size: 11px;
    color: rgba(255, 255, 255, .55);
}

body[data-page="product"] .p-archive-tree {
    margin: 0;
    padding: 14px;
    border-radius: 12px;

    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 11px;
    line-height: 1.55;

    color: rgba(255, 255, 255, .85);
    background: linear-gradient(180deg,
            rgba(255, 255, 255, .05),
            rgba(0, 0, 0, .25));

    white-space: pre;
    overflow-x: auto;
}

body[data-page="product"] .p-archive-note {
    margin-top: 10px;
    font-size: 12px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .65);
}

/* =========================================================
   PRODUCT — JUICY + NOVICE FRIENDLY (append only)
   ========================================================= */

/* “анти-страх” блок */
body[data-page="product"] .p-softnote {
    margin-top: 12px;
    padding: 12px 12px;
    border-radius: 14px;
    border: 1px solid rgba(245, 193, 91, .14);
    background:
        radial-gradient(520px 160px at 10% 0%, rgba(245, 193, 91, .16), transparent 55%),
        rgba(0, 0, 0, .16);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

body[data-page="product"] .p-softnote-h {
    font-weight: 800;
    font-size: 12px;
    letter-spacing: .02em;
    margin-bottom: 6px;
    color: rgba(255, 255, 255, .92);
}

body[data-page="product"] .p-softnote-t {
    font-size: 12px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .72);
}

/* короткая поддерживающая строка перед плагинами */
body[data-page="product"] .p-softline {
    margin-top: 10px;
    font-size: 12px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .62);
}

/* CTA чуть “дороже” */
body[data-page="product"] .p-buy-btn.btn {
    position: relative;
    overflow: hidden;
    transform: translateZ(0);
}

body[data-page="product"] .p-buy-btn.btn::before {
    content: "";
    position: absolute;
    inset: -2px;
    background:
        radial-gradient(520px 140px at 18% 0%, rgba(245, 193, 91, .22), transparent 60%),
        radial-gradient(520px 140px at 82% 0%, rgba(245, 193, 91, .14), transparent 65%);
    opacity: .9;
    pointer-events: none;
}

body[data-page="product"] .p-buy-btn.btn::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, 0) 38%);
    opacity: .55;
    pointer-events: none;
}

/* “структура архива” — подаём как плюс */
body[data-page="product"] .p-archive-desc {
    margin: 8px 0 12px;
    font-size: 12px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .62);
}

body[data-page="product"] .p-archive-tree {
    position: relative;
    background:
        radial-gradient(700px 220px at 12% 0%, rgba(245, 193, 91, .10), transparent 60%),
        linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(0, 0, 0, .30));
}

body[data-page="product"] .p-archive-tree::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 34px;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, .55));
    pointer-events: none;
    opacity: .9;
}

/* =========================================================
   PRODUCT — DIFFICULTY LEVEL (badge)
   ========================================================= */

body[data-page="product"] .p-archive-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}

body[data-page="product"] .p-archive-head-left {
    min-width: 0;
}

body[data-page="product"] .p-level {
    display: inline-flex;
    align-items: center;
    gap: 8px;

    padding: 8px 10px;
    border-radius: 999px;

    border: 1px solid rgba(255, 255, 255, .10);
    background:
        linear-gradient(145deg, rgba(245, 193, 91, .12), rgba(245, 193, 91, 0) 55%),
        rgba(0, 0, 0, .22);

    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
    white-space: nowrap;
    flex: 0 0 auto;
}

body[data-page="product"] .p-level-label {
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .62);
}

body[data-page="product"] .p-level-value {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .02em;
    color: rgba(255, 255, 255, .86);
}

body[data-page="product"] .p-level-bars {
    display: inline-flex;
    gap: 4px;
    margin-left: 2px;
}

body[data-page="product"] .p-level-bars i {
    width: 7px;
    height: 7px;
    border-radius: 2px;
    background: rgba(255, 255, 255, .18);
}

body[data-page="product"] .p-level-bars i.is-on {
    background: rgba(245, 193, 91, .95);
}

/* мобилка: если узко — переносим бейдж на новую строку */
@media (max-width: 420px) {
    body[data-page="product"] .p-archive-head {
        flex-wrap: wrap;
    }
}

/* =========================================================
   PRODUCT — LEVEL (HERO)
   ========================================================= */

body[data-page="product"] .p-level--hero {
    margin-top: 10px;
    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 10px 12px;
    border-radius: 14px;

    border: 1px solid rgba(255, 255, 255, .10);
    background:
        radial-gradient(560px 160px at 20% 0%, rgba(245, 193, 91, .16), transparent 62%),
        rgba(0, 0, 0, .18);

    box-shadow:
        0 14px 34px rgba(0, 0, 0, .28),
        inset 0 1px 0 rgba(255, 255, 255, .06);
}

/* чтобы лейбл выглядел как “паспорт” */
body[data-page="product"] .p-level--hero .p-level-label {
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .62);
}

body[data-page="product"] .p-level--hero .p-level-value {
    font-size: 12px;
    font-weight: 900;
    color: rgba(255, 255, 255, .90);
}

/* =========================================================
   PRODUCT — WINDOWS TREE (collapsible + subtle)
   ========================================================= */

/* контейнер: по умолчанию закрыт, не кричит */
body[data-page="product"] .p-treebox {
    margin-top: 10px;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 16px;
    background: rgba(0, 0, 0, .10);
    overflow: hidden;
}

body[data-page="product"] .p-treebox-sum {
    list-style: none;
    cursor: pointer;
    padding: 12px 12px;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;

    background:
        linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .00));
}

body[data-page="product"] .p-treebox-sum::-webkit-details-marker {
    display: none;
}

body[data-page="product"] .p-treebox-ttl {
    font-weight: 800;
    font-size: 12px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .78);
}

body[data-page="product"] .p-treebox-sub {
    font-size: 12px;
    color: rgba(255, 255, 255, .50);
    white-space: nowrap;
}

body[data-page="product"] .p-treebox[open] .p-treebox-sum {
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}

body[data-page="product"] .p-treebox-body {
    padding: 10px 10px 12px;
}

/* Windows tree base */
body[data-page="product"] .win-tree,
body[data-page="product"] .win-tree ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

body[data-page="product"] .win-tree ul {
    margin-left: 18px;
    padding-left: 10px;
    border-left: 1px solid rgba(255, 255, 255, .08);
}

body[data-page="product"] .win-item {
    margin: 4px 0;
}

/* folder nodes */
body[data-page="product"] .win-folder>summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;

    padding: 7px 8px;
    border-radius: 10px;

    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 12px;
    color: rgba(255, 255, 255, .86);
}

body[data-page="product"] .win-folder>summary::-webkit-details-marker {
    display: none;
}

body[data-page="product"] .win-folder>summary:hover {
    background: rgba(255, 255, 255, .04);
}

/* leaf rows (без раскрытия) */
body[data-page="product"] .win-item:not(:has(details)),
body[data-page="product"] .win-item>.win-icn {
    /* no-op: просто чтобы селектор не ломал */
}

body[data-page="product"] .win-item>.win-icn+.win-name {
    vertical-align: middle;
}

body[data-page="product"] .win-item {
    display: block;
}

body[data-page="product"] .win-item>.win-icn {
    display: inline-block;
    vertical-align: middle;
    margin-left: 24px;
    /* место под стрелку как у summary */
    margin-right: 10px;
}

body[data-page="product"] .win-item>.win-name {
    display: inline-block;
    vertical-align: middle;

    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 12px;
    color: rgba(255, 255, 255, .82);

    padding: 7px 8px;
    border-radius: 10px;
}

body[data-page="product"] .win-item>.win-name:hover {
    background: rgba(255, 255, 255, .04);
}

/* стрелка раскрытия (как Windows) */
body[data-page="product"] .win-folder>summary::before {
    content: "";
    width: 10px;
    height: 10px;
    display: inline-block;
    margin-right: 2px;

    border-right: 2px solid rgba(255, 255, 255, .38);
    border-bottom: 2px solid rgba(255, 255, 255, .38);
    transform: rotate(-45deg);
    border-radius: 1px;

    flex: 0 0 auto;
    opacity: .9;
}

body[data-page="product"] .win-folder[open]>summary::before {
    transform: rotate(45deg);
}

/* icons: folder / file (Windows-like) */
body[data-page="product"] .win-icn {
    width: 16px;
    height: 14px;
    display: inline-block;
    flex: 0 0 auto;
    border-radius: 3px;
    position: relative;
}

body[data-page="product"] .win-icn.folder {
    background: linear-gradient(180deg, rgba(245, 193, 91, .95), rgba(194, 146, 58, .92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .25);
}

body[data-page="product"] .win-icn.folder::before {
    content: "";
    position: absolute;
    left: 2px;
    top: -2px;
    width: 9px;
    height: 5px;
    border-radius: 3px 3px 2px 2px;
    background: linear-gradient(180deg, rgba(245, 193, 91, .95), rgba(214, 168, 72, .92));
}

body[data-page="product"] .win-icn.file {
    background: linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .06));
    border: 1px solid rgba(255, 255, 255, .10);
}

body[data-page="product"] .win-icn.file::before {
    content: "";
    position: absolute;
    right: 1px;
    top: 1px;
    width: 5px;
    height: 5px;
    background: rgba(255, 255, 255, .12);
    transform: skew(-12deg);
    border-radius: 2px;
}

/* AE project icon for .aep */
body[data-page="product"] .win-icn.file.ae {
    background: url("/assets/icons/AE%20Project.svg") center / contain no-repeat !important;
    border: 0 !important;
}

/* убираем “загнутый уголок” у file-иконки только для AE */
body[data-page="product"] .win-icn.file.ae::before {
    display: none !important;
}

body[data-page="product"] .win-icn.file.pr {
    border-color: rgba(120, 180, 255, .22);
}

body[data-page="product"] .win-icn.file.txt {
    border-color: rgba(255, 255, 255, .16);
}

/* root line слегка выделим */
body[data-page="product"] .win-item.is-root>details>summary {
    background: rgba(0, 0, 0, .18);
    border: 1px solid rgba(255, 255, 255, .06);
}

/* =========================================================
   WINDOWS FOLDER ICON — FIX SIZE
   ========================================================= */

body[data-page="product"] .win-icn-img {
    width: 18px;
    height: 14px;

    max-width: 18px;
    max-height: 14px;

    object-fit: contain;
    display: inline-block;
    flex: 0 0 18px;

    vertical-align: middle;
    line-height: 1;

    filter: none;
    /* убираем лишние тени */
}

/* =========================================================
   PRODUCT — ARCHIVE SUMMARY (one block with tree)
   ========================================================= */

body[data-page="product"] .p-archive-summary {
    margin: 10px 0 12px;
    padding: 10px 12px;
    border-radius: 14px;

    border: 1px solid rgba(255, 255, 255, .07);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(0, 0, 0, .10));

    font-size: 13px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .78);

    list-style: none;
    display: grid;
    gap: 0;
}

body[data-page="product"] .p-archive-summary>li {
    display: grid;
    grid-template-columns: 112px 1fr;
    gap: 10px;

    padding: 10px 0;
    border-top: 1px solid rgba(255, 255, 255, .06);
}

body[data-page="product"] .p-archive-summary>li:first-child {
    border-top: none;
}

body[data-page="product"] .p-archive-summary>li>b {
    display: block;
    font-weight: 800;
    color: rgba(255, 255, 255, .92);
    letter-spacing: .01em;
    white-space: nowrap;
    opacity: .95;
}

body[data-page="product"] .p-archive-summary>li {
    /* правая колонка */
    color: rgba(255, 255, 255, .72);
}

body[data-page="product"] .p-archive-summary>li>b+* {
    /* страховка на случай переносов/разметки */
    min-width: 0;
}

@media (max-width: 420px) {
    body[data-page="product"] .p-archive-summary>li {
        grid-template-columns: 96px 1fr;
        gap: 8px;
    }
}

/* =========================================================
   PRODUCT — PASSPORT (BUY COLUMN)
   ========================================================= */

body[data-page="product"] .p-passport {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, .08);
}

body[data-page="product"] .p-passport-h {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .46);
    margin-bottom: 8px;
}

/* чтобы паспортная мини-таблица не выглядела “вторым блоком” */
body[data-page="product"] .p-mini--passport {
    margin-top: 0;
}

/* plugins details */
body[data-page="product"] .p-passport-plugs {
    margin-top: 10px;
    border: 1px solid rgba(255, 255, 255, .07);
    border-radius: 14px;
    overflow: hidden;
    background: rgba(0, 0, 0, .10);
}

body[data-page="product"] .p-passport-sum {
    list-style: none;
    cursor: pointer;
    padding: 10px 12px;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;

    font-size: 12px;
    font-weight: 700;
    color: rgba(255, 255, 255, .78);

    background: linear-gradient(180deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .00));
}

body[data-page="product"] .p-passport-sum::-webkit-details-marker {
    display: none;
}

body[data-page="product"] .p-passport-sum-sub {
    font-size: 12px;
    font-weight: 500;
    color: rgba(255, 255, 255, .45);
    white-space: nowrap;
}

body[data-page="product"] .p-passport-plugs-body {
    padding: 10px 12px 12px;
    border-top: 1px solid rgba(255, 255, 255, .06);
}

body[data-page="product"] .p-passport-list {
    margin: 0;
    padding: 0;
    list-style: none;

    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px 12px;

    font-size: 12px;
    color: rgba(255, 255, 255, .72);
}

body[data-page="product"] .p-passport-list>li {
    padding-left: 10px;
    position: relative;
}

body[data-page="product"] .p-passport-list>li::before {
    content: "•";
    position: absolute;
    left: 0;
    top: 0;
    color: rgba(255, 255, 255, .35);
}

body[data-page="product"] .p-passport-hint {
    margin-top: 10px;
    font-size: 11px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .45);
}

/* =========================================================
   PRODUCT — BUY CARD SPLIT (2 PARTS) — NO INNER BOXES
   ========================================================= */

body[data-page="product"] .p-buy {
    display: grid;
    gap: 14px;
    /* расстояние между 2 частями внутри одной карточки */
}

/* УБИРАЕМ внутренние боксы: без рамок/фонов/паддингов */
body[data-page="product"] .p-buy-part {
    border: 0;
    border-radius: 0;
    padding: 0;
    background: none;
    box-shadow: none;
}

/* В main делаем легкий верхний “блик” без бокса (чуть сочности) */
body[data-page="product"] .p-buy-part--main {
    position: relative;
    padding-top: 2px;
}

body[data-page="product"] .p-buy-part--main::before {
    content: "";
    position: absolute;
    left: -2px;
    right: -2px;
    top: -10px;
    height: 22px;
    pointer-events: none;
    background: radial-gradient(420px 70px at 16% 0%, rgba(245, 193, 91, .16), transparent 70%);
    opacity: .9;
}

/* meta-часть отделяем тонкой линией + воздух */
body[data-page="product"] .p-buy-part--meta {
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, .08);
}

/* divider внутри meta больше не нужен как отдельная “полоса” */
body[data-page="product"] .p-buy-part--meta .p-buy-divider {
    display: none;
}

/* паспорт внутри meta: убираем лишние “верхние” отступы, если они есть в базе */
body[data-page="product"] .p-buy-part--meta .p-passport {
    border-top: 0;
    padding-top: 0;
    margin-top: 0;
}

/* кнопка/нота — чуть ровнее по ритму */
body[data-page="product"] .p-buy-top {
    margin-bottom: 12px;
}

body[data-page="product"] .p-buy-note {
    margin-top: 10px;
}

/* =========================================================
   BUY — CLEAR SPLIT: PRICE vs PASSPORT
   ========================================================= */

/* верхний блок (цена) — чище и плотнее */
body[data-page="product"] .p-buy-part--main {
    padding-bottom: 14px;
}

/* акцент на цене, без “технических” шумов */
body[data-page="product"] .p-price {
    font-size: 26px;
}

/* паспорт — явно второй слой */
body[data-page="product"] .p-buy-part--meta {
    margin-top: 4px;
    padding-top: 14px;
    border-top: 1px dashed rgba(255, 255, 255, .12);
}

/* сложность в паспорте — компактная, не геройская */
body[data-page="product"] .p-level--passport {
    margin-bottom: 10px;
    padding: 8px 10px;
    border-radius: 12px;
    background:
        linear-gradient(145deg, rgba(245, 193, 91, .10), rgba(245, 193, 91, 0) 60%),
        rgba(0, 0, 0, .18);
}

body[data-page="product"] .p-level--passport .p-level-label {
    font-size: 9px;
}

body[data-page="product"] .p-level--passport .p-level-value {
    font-size: 11px;
}

/* =========================================================
   BUY COLUMN — split into 2 separate cards
   (append override)
   ========================================================= */

body[data-page="product"] .p-buycol {
    position: sticky;
    top: 18px;
    align-self: start;

    display: grid;
    gap: 14px;
}

/* первая карточка (цена) */
body[data-page="product"] .p-buy--main {
    position: relative;
    padding: 18px;
}

/* вторая карточка (паспорт) */
body[data-page="product"] .p-passcard {
    padding: 18px;
}

/* больше не нужно “разделять внутри одной карточки” */
body[data-page="product"] .p-buy-part--meta,
body[data-page="product"] .p-buy-part--main {
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* паспорт внутри отдельной карточки — без внутренней “верхней линии” */
body[data-page="product"] .p-passcard .p-passport {
    border-top: 0;
    padding-top: 0;
    margin-top: 0;
}

@media (max-width: 768px) {
    body[data-page="product"] .p-buycol {
        position: relative;
        top: auto;
    }

    body[data-page="product"] .p-buy--main,
    body[data-page="product"] .p-passcard {
        padding: 16px;
    }
}

/* =========================================================
   FIX: overlap between BUY and PASSPORT cards (desktop)
   Reason: double-sticky (.p-buycol + .p-buy)
   ========================================================= */

@media (min-width: 769px) {
    body[data-page="product"] .p-buy {
        position: relative;
        /* was sticky */
        top: auto;
        z-index: auto;
    }
}

/* =========================================================
   PRICE CARD — FULL REWORK (compact, shop-like)
   ========================================================= */

body[data-page="product"] .p-buy--main {
    padding: 14px;
    border-radius: 16px;

    background:
        radial-gradient(680px 220px at 18% -30%,
            rgba(245, 193, 91, .10),
            rgba(245, 193, 91, 0) 58%),
        linear-gradient(180deg,
            rgba(255, 255, 255, .035),
            rgba(0, 0, 0, .14));

    border: 1px solid rgba(255, 255, 255, .085);
    box-shadow:
        0 14px 38px rgba(0, 0, 0, .42),
        inset 0 1px 0 rgba(255, 255, 255, .05);
}

/* шапка: заголовок + бейджи */
body[data-page="product"] .p-buy--main .p-offer-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

body[data-page="product"] .p-buy--main .p-title {
    font-size: 23px;
    line-height: 1.06;
    margin: 0;
}

body[data-page="product"] .p-buy--main .p-offer-sub {
    margin-top: 6px;
    font-size: 12.5px;
    line-height: 1.25;
    color: rgba(255, 255, 255, .72);
    max-width: 44ch;
}

/* бейджи */
body[data-page="product"] .p-buy--main .p-offer-badges {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-end;
    flex: 0 0 auto;
}

body[data-page="product"] .p-buy--main .p-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 10px;
    border-radius: 999px;

    font-size: 11.5px;
    line-height: 1;
    color: rgba(255, 255, 255, .72);

    background: rgba(0, 0, 0, .18);
    border: 1px solid rgba(255, 255, 255, .10);
}

/* список “что внутри” — плотный, без воздуха */
body[data-page="product"] .p-buy--main .p-offer-list {
    display: grid;
    gap: 8px;

    padding: 10px 10px;
    border-radius: 12px;

    background: rgba(0, 0, 0, .16);
    border: 1px solid rgba(255, 255, 255, .07);

    margin-bottom: 10px;
}

body[data-page="product"] .p-buy--main .p-offer-item {
    position: relative;
    padding-left: 14px;

    font-size: 12.5px;
    line-height: 1.25;
    color: rgba(255, 255, 255, .74);
}

body[data-page="product"] .p-buy--main .p-offer-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: .55em;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: rgba(245, 193, 91, .95);
    box-shadow: 0 0 0 3px rgba(245, 193, 91, .10);
}

/* низ: цена + CTA + гарантия */
body[data-page="product"] .p-buy--main .p-offer-bottom {
    display: grid;
    gap: 10px;
}

body[data-page="product"] .p-buy--main .p-price-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;

    padding-top: 0;
    border-top: 0;
}

body[data-page="product"] .p-buy--main .p-price {
    font-size: 27px;
    font-weight: 900;
    letter-spacing: .01em;
    transform: translateY(-7px);
}

body[data-page="product"] .p-buy--main .p-price-sub {
    font-size: 11.5px;
    color: rgba(255, 255, 255, .55);
}

/* кнопка — компактнее по высоте */
body[data-page="product"] .p-buy--main .p-buy-btn {
    margin-top: 0;
    min-height: 46px;
}

/* нижняя строка — короткая и спокойная */
body[data-page="product"] .p-buy--main .p-buy-note {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;

    font-size: 11.5px;
    line-height: 1.35;
    color: rgba(255, 255, 255, .56);
}

/* =========================================================
   VIDEO — no black screen on first load (poster fallback)
   ========================================================= */

body[data-page="product"] .p-video {
    background: url("/assets/product/i-love-life/poster.jpg") center / cover no-repeat;
}

/* когда видео готово рисовать кадр — фон убираем */
body[data-page="product"] .p-video.is-ready {
    background: none;
}

/* =========================================================
   PRICE CARD — divider before includes (between note and list)
   ========================================================= */
body[data-page="product"] .p-buy--main .p-offer-bottom+.p-offer-list {
    margin-top: 12px;
    position: relative;
}

body[data-page="product"] .p-buy--main .p-offer-bottom+.p-offer-list::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -12px;
    /* это как раз место линии */
    border-top: 1px solid rgba(255, 255, 255, .07);
}

/* =========================================================
   PRODUCT — MOBILE: move points under price + hide 1 offer item
   (append only)
   ========================================================= */

/* по умолчанию (desktop): мобильный дубль скрыт */
body[data-page="product"] .p-points--mobile {
    display: none;
}

@media (max-width: 768px) {

    /* 1) под превью (hero) — скрываем, чтобы сразу шла карточка цены */
    body[data-page="product"] .p-points--hero {
        display: none;
    }

    /* 2) под ценой — показываем дубль */
    body[data-page="product"] .p-points--mobile {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
        margin-top: 12px;
    }

    /* 3) скрыть “After Effects / Premiere: готовая сборка” только на мобилке */
    body[data-page="product"] .p-offer-item--hide-m {
        display: none;
    }
}

/* =========================================================
   MOBILE ONLY — hide offer list under price
   ========================================================= */
@media (max-width: 768px) {
    body[data-page="product"] .p-buy--main .p-offer-list {
        display: none;
    }
}

/* =========================================================
   MOBILE ONLY — divider under buy note
   ========================================================= */
@media (max-width: 768px) {
    body[data-page="product"] .p-buy--main .p-buy-note {
        position: relative;
        padding-bottom: 14px;
        margin-bottom: 14px;
    }

    body[data-page="product"] .p-buy--main .p-buy-note::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        height: 1px;
        background: rgba(255, 255, 255, .07);
    }
}

/* =========================================================
   MOBILE FIX — disable legacy divider tied to offer-list
   ========================================================= */
@media (max-width: 768px) {

    body[data-page="product"] .p-buy--main .p-offer-bottom+.p-offer-list,
    body[data-page="product"] .p-buy--main .p-offer-bottom+.p-offer-list::before {
        display: none !important;
        content: none !important;
    }

    /* FIX: если “старая линия” приходит не от offer-list, а от внутренних делителей */
    body[data-page="product"] .p-buy-divider {
        display: none !important;
    }

    body[data-page="product"] .p-buy-part--meta {
        border-top: 0 !important;
        padding-top: 0 !important;
        margin-top: 0 !important;
    }
}

/* =========================================================
   MOBILE — replace points with archive summary
   ========================================================= */

/* по умолчанию мобильный дубль скрыт */
body[data-page="product"] .p-archive-summary--mobile {
    display: none;
}

@media (max-width: 768px) {

    /* показываем новый блок под ценой */
    body[data-page="product"] .p-archive-summary--mobile {
        display: grid;
        margin-top: 12px;
    }

    /* оригинальный archive-summary ниже по странице — скрываем */
    body[data-page="product"] .p-archive-summary:not(.p-archive-summary--mobile) {
        display: none;
    }
}

/* =========================================================
   MOBILE ONLY — soft chips under price (AE / PR)
   ========================================================= */

/* по умолчанию (desktop) — скрыто */
body[data-page="product"] .p-softchips--m {
    display: none;
}

@media (max-width: 768px) {

    body[data-page="product"] .p-softchips--m {
        display: flex;
        gap: 10px;
        flex-wrap: wrap;

        margin-top: -10px;
        padding-top: 0px;
    }

    body[data-page="product"] .p-softchip {
        display: inline-flex;
        align-items: center;
        justify-content: center;

        padding: 7px 10px;
        border-radius: 999px;

        font-size: 12px;
        line-height: 1;
        letter-spacing: .2px;

        color: rgba(255, 255, 255, .78);
        background: rgba(0, 0, 0, .18);
        border: 1px solid rgba(255, 255, 255, .10);
        box-shadow: 0 8px 20px rgba(0, 0, 0, .22);
        user-select: none;
        pointer-events: none;
    }
}

/* =========================================================
   PASSPORT — spacing between logical blocks
   ========================================================= */

body[data-page="product"] .p-mini--passport+.p-mini--passport {
    margin-top: 8px;
}

/* =========================================================
   MOBILE — hide "Как начать"
   ========================================================= */
@media (max-width: 768px) {
    body[data-page="product"] .p-grid>.p-card:first-child {
        display: none;
    }
}

/* =========================================================
   PASSPORT — subtle help "(?)"
   ========================================================= */

body[data-page="product"] .p-help {
    display: inline-flex;
    align-items: center;

    margin-left: 2px;
    padding: 0;

    border: 0;
    background: none;

    font: inherit;
    font-size: 12px;
    font-weight: 400;
    line-height: 1;

    color: rgba(245, 193, 91, .75);
    cursor: pointer;

    vertical-align: baseline;
}

body[data-page="product"] .p-help:hover {
    color: rgba(245, 193, 91, .95);
    text-decoration: none;
}

/* =========================================================
   MOBILE — treebox in passport only
   ========================================================= */

/* desktop: вставка в паспорте скрыта */
body[data-page="product"] .p-treebox--inpass {
    display: none;
}

@media (max-width: 768px) {

    /* mobile: показываем вставку в паспорте */
    body[data-page="product"] .p-treebox--inpass {
        display: block;
        margin-top: 12px;
    }

    /* mobile: скрываем оригинальный treebox в блоке "Что внутри архива" */
    body[data-page="product"] section.p-archive.p-card .p-treebox {
        display: none;
    }
}

@media (max-width: 768px) {

    /* HIDE: "Что внутри архива" — mobile only */
    body[data-page="product"] .p-archive {
        display: none !important;
    }

}

/* прячем "4/5" визуально, но оставляем для парсинга и доступности */
body[data-page="product"] .p-mini-row[data-pass="difficulty"] .p-diff-txt {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* =========================================================
   PRODUCT — DIFFICULTY DOTS (animated)
   ========================================================= */

body[data-page="product"] .p-diff {
    --dots: 5;
    --size: 7px;
    --gap: 4px;

    display: inline-flex;
    gap: var(--gap);
    margin-right: 0px;
}

body[data-page="product"] .p-diff i {
    width: var(--size);
    height: var(--size);
    border-radius: 50%;

    background: rgba(255, 255, 255, .22);
    opacity: .45;

    transform: scale(1);

    transition:
        background .35s ease,
        opacity .35s ease;
}


body[data-page="product"] .p-diff i.is-on {
    background: rgba(245, 193, 91, .95);
    transform: scale(1);
    opacity: 1;
}

body[data-page="product"] .p-diff i.is-on {
    animation: diff-pop .28s ease-out;
}

@keyframes diff-pop {
    0% {
        transform: scale(.6);
    }

    100% {
        transform: scale(1);
    }
}

/* =========================================================
   MOBILE ONLY: split "Passport" and "Tech" into two cards
   ========================================================= */

/* по умолчанию (десктоп): мобильная карточка скрыта */
body[data-page="product"] .p-techcard--m {
    display: none;
}

/* MOBILE */
@media (max-width: 768px) {

    /* 1) скрываем блок плагинов, который сидит в паспорте (десктопная версия) */
    body[data-page="product"] .p-passport-plugs--desk {
        display: none !important;
    }

    /* 2) показываем новую карточку "Технические рекомендации" */
    body[data-page="product"] .p-techcard--m {
        display: block;
        padding: 16px;
        /* как у остальных карточек на мобилке */
    }

    body[data-page="product"] .p-techcard-h {
        font-size: 12px;
        font-weight: 800;
        letter-spacing: .12em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, .46);
        margin-bottom: 10px;
    }

    body[data-page="product"] .p-techbox {
        border: 1px solid rgba(255, 255, 255, .07);
        border-radius: 14px;
        overflow: hidden;
        background: rgba(0, 0, 0, .10);
        padding: 10px 12px 12px;
        margin-bottom: 10px;
    }

    body[data-page="product"] .p-techlist {
        margin: 0;
        padding: 0;
        list-style: none;

        display: grid;
        gap: 8px;

        font-size: 12px;
        line-height: 1.45;
        color: rgba(255, 255, 255, .72);
    }

    body[data-page="product"] .p-techlist b {
        color: rgba(255, 255, 255, .92);
        font-weight: 800;
    }

    /* 3) чтобы внутри новой карточки "плагины" выглядели как раньше */
    body[data-page="product"] .p-techcard--m .p-passport-plugs {
        margin-top: 0;
        /* внутри карточки уже есть отступы */
    }
}





/* =========================================================
   TECH RECOMMENDATIONS — PREMIUM MINIMAL (2x2)
   append-only
   ========================================================= */

body[data-page="product"] .p-techcard {
    padding: 16px;
}

body[data-page="product"] .p-techcard-h {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .42);
    margin-bottom: 12px;
}

/* 2x2 always (на мобилке) */
body[data-page="product"] .p-techgrid {
    margin: 0;
    padding: 0;
    list-style: none;

    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5px;
}

/* плитка — плоская, тонкая, без бликов */
body[data-page="product"] .p-tech-tile {
    display: grid;
    grid-template-columns: 18px 1fr;
    gap: 10px;
    align-items: start;

    padding: 12px 12px;
    border-radius: 14px;

    border: 1px solid rgba(255, 255, 255, .07);
    background: rgba(0, 0, 0, .14);

    box-shadow: none;
}

/* иконка — без круга */
body[data-page="product"] .p-tech-icn {
    width: 18px;
    height: 18px;
    opacity: .5;
    object-fit: contain;
    margin-top: 2px;
}

body[data-page="product"] .p-tech-txt {
    min-width: 0;
    display: grid;
    gap: 2.5px;
}

body[data-page="product"] .p-tech-k {
    font-size: 10px;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .48);
}

body[data-page="product"] .p-tech-v {
    font-size: 13px;
    line-height: 1.22;
    font-weight: 800;
    color: rgba(255, 255, 255, .90);
}

body[data-page="product"] .p-tech-m {
    font-size: 12px;
    font-weight: 600;
    color: rgba(255, 255, 255, .52);
    margin-left: 6px;
    white-space: nowrap;
}

/* hint — тоже минимал, без "пузыря" */
body[data-page="product"] .p-tech-hint {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(255, 255, 255, .08);

    font-size: 12px;
    line-height: 1.45;
    color: rgba(255, 255, 255, .58);
}

body[data-page="product"] .p-tech-hint b {
    font-weight: 800;
    color: rgba(255, 255, 255, .82);
}

/* hover очень деликатный (на десктопе тоже выглядит "дорого") */
@media (hover: hover) {
    body[data-page="product"] .p-tech-tile:hover {
        border-color: rgba(255, 255, 255, .11);
        background: rgba(0, 0, 0, .18);
    }
}

/* =========================================================
   VIDEO SWIPE — allow horizontal gesture without ломать скролл
   ========================================================= */
body[data-page="product"] .p-video {
    touch-action: pan-y;
}

/* =========================================================
   VIDEO NEXT ICON (preview switch)
   append-only
   ========================================================= */

body[data-page="product"] .p-video {
    position: relative;
}

body[data-page="product"] .p-video-next {
    position: absolute;
    top: 50%;
    right: 14px;
    transform: translateY(-50%);
    z-index: 4;

    width: 28px;
    height: 28px;
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    border: none;
    background: rgba(0, 0, 0, .35);
    backdrop-filter: blur(6px);

    color: rgba(255, 255, 255, .75);
    cursor: pointer;

    transition:
        opacity .2s ease,
        transform .2s ease;
}

body[data-page="product"] .p-video-next:hover {
    opacity: .95;
}

body[data-page="product"] .p-video-next:active {
    transform: translateY(-50%) scale(.92);
}

body[data-page="product"] .p-video-next-icn {
    width: 14px;
    height: 14px;
    display: block;
    opacity: .85;
}