:root {
    --gold: #D6B16F;
    --gold-dark: #BF9852;
    --gold-deep: #A57F3D;
    --gold-soft: #F5EBD7;
    --ink: #0C0C0C;
    --ink-soft: #1A1A1A;
    --ink-mid: #3A3A3A;
    --muted: #707070;
    --mute-2: #9A9690;
    --line: #E5E7EB;
    --line-soft: #EFF1F4;
    --canvas: #FFFFFF;
    --canvas-tint: #F4F5F7;
    --cream: #EEF0F3;
    --navy: #0B1B3A;
    --navy-deep: #070F22;
    --blue: #1F6AE3;
    --green: #1E9E5C;
    --red: #D6322B;
    --ease: cubic-bezier(.16, 1, .3, 1);
    --ease-out: cubic-bezier(.23, 1, .32, 1);
    --ease-in-out: cubic-bezier(.77, 0, .175, 1);
    --shadow-sm: 0 1px 2px rgba(12, 12, 12, .05);
    --shadow-md: 0 6px 24px rgba(12, 12, 12, .08);
    --shadow-lg: 0 24px 60px rgba(12, 12, 12, .14);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

button, input, select, textarea {
    font-family: inherit
}

html, body {
    background: var(--canvas);
    color: var(--ink);
    font-family: -apple-system, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Arial, sans-serif;
    font-size: 16px;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    letter-spacing: -0.005em;
}

img {
    max-width: 100%;
    height: auto;
    display: block
}

a {
    color: inherit;
    text-decoration: none
}

button {
    font: inherit;
    cursor: pointer;
    border: 0;
    background: none
}

.wrap {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 24px
}

/* Buttons */
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt,
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 22px;
    border-radius: 4px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
    border: 2px solid transparent;
    transition: color .2s var(--ease), background-color .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease), opacity .2s var(--ease);
    white-space: nowrap;
    cursor: pointer
}

.btn-gold {
    background: var(--gold)!important;
    color: var(--ink)!important;
    border-color: var(--gold)!important
}

.btn-gold:hover {
    background: var(--gold-dark);
    border-color: var(--gold-dark)
}

.btn-gold-lg {
    padding: 14px 28px;
    font-size: 17px
}

.btn-outline {
    background: transparent;
    color: var(--ink);
    border-color: var(--ink)!important;
}

.btn-outline:hover {
    background: var(--ink);
    color: #fff
}

.btn-outline-light {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, .35)
}

.btn-outline-light:hover {
    background: #fff;
    color: var(--ink);
    border-color: #fff
}

.btn-dark {
    background: var(--ink);
    color: #fff;
    border-color: var(--ink)
}

.btn-dark:hover {
    background: #000
}

.btn .arrow {
    font-size: .85em;
    line-height: 1;
    transition: transform .2s var(--ease)
}

.btn:hover .arrow {
    transform: translateX(3px)
}

/* Promo */
.promo-strip {
    background: linear-gradient(90deg, var(--gold-soft) 0%, #FFE2A6 50%, var(--gold-soft) 100%);
    border-top: 1px solid var(--gold);
    border-bottom: 1px solid var(--gold);
    padding: 12px 0
}

.promo-strip .wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
    font-size: 13px;
    color: var(--ink);
    font-weight: 600;
    text-align: center
}

.promo-strip .badge {
    font-size: 10.5px;
    font-weight: 800;
    background: var(--ink);
    color: var(--gold);
    padding: 4px 10px;
    border-radius: 3px;
    letter-spacing: .08em;
    text-transform: uppercase
}

.promo-strip b {
    color: var(--gold-deep);
    font-weight: 800
}

.promo-strip a {
    color: var(--ink);
    font-weight: 700;
    border-bottom: 1.5px solid var(--ink);
    cursor: pointer
}

.promo-strip a:hover {
    color: var(--gold-deep);
    border-bottom-color: var(--gold-deep)
}

/* Breadcrumbs */
.crumbs {
    padding: 14px 0;
    background: var(--canvas-tint);
    border-bottom: 1px solid var(--line)
}

.crumbs .wrap {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 12.5px;
    color: var(--muted);
    font-weight: 500;
    flex-wrap: wrap
}

.crumbs a {
    color: var(--muted);
    transition: color .2s var(--ease)
}

.crumbs a:hover {
    color: var(--gold-deep)
}

.crumbs .sep {
    color: var(--line);
    margin: 0 2px
}

.crumbs .current {
    color: var(--ink);
    font-weight: 600
}

/* Final CTA — navy gradient from v2005 */
.final-cta {
    background: linear-gradient(135deg, #070F22 0%, #0B1B3A 50%, #1A1F2E 100%);
    color: #fff;
    padding: 60px 0;
    position: relative;
    overflow: hidden
}

.final-cta::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, rgba(214, 177, 111, .12) 0, transparent 60%);
    pointer-events: none
}

.final-cta .wrap {
    position: relative
}

.final-cta .head {
    text-align: center;
    margin-bottom: 30px
}

.final-cta h2 {
    font-size: clamp(28px, 3.6vw, 40px);
    font-weight: 800;
    letter-spacing: -.01em;
    line-height: 1.1;
    margin-bottom: 12px
}

.final-cta h2 em {
    color: var(--gold);
    font-style: normal
}

.final-cta .head p {
    font-size: 15px;
    color: rgba(255, 255, 255, .78);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.55
}

.final-single-cta {
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 14px
}

/* ===== Product hero — even 50/50 split ===== */
.prod-hero {
    padding: 18px 0 28px
}

.prod-grid {
    display: grid;
    grid-template-columns:1fr 1fr;
    gap: 32px;
    align-items: start
}

.gallery .main-img {
    position: relative;
    background: var(--cream);
    border: 1px solid var(--line);
    border-radius: 12px;
    overflow: hidden;
    height: clamp(280px, 26vw, 340px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px;
    box-shadow: var(--shadow-sm)
}

.gallery .main-img img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain
}

.gallery .badge-stock {
    position: absolute;
    top: 16px;
    left: 16px;
    background: var(--green);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 5px 11px;
    border-radius: 4px;
    letter-spacing: .04em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 6px
}

.gallery .badge-stock::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #fff
}

.gallery .badge-zoom {
    position: absolute;
    top: 16px;
    right: 16px;
    background: rgba(12, 12, 12, .8);
    color: #fff;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600
}

.gallery .badge-made {
    position: absolute;
    bottom: 16px;
    left: 16px;
    background: rgba(255, 255, 255, .92);
    color: var(--ink);
    padding: 6px 11px;
    border-radius: 4px;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    backdrop-filter: blur(4px)
}

.gallery .badge-made b {
    color: var(--gold-deep)
}

.gallery .thumbs {
    display: flex;
    gap: 8px;
    margin-top: 9px
}

.thumb {
    width: 66px;
    height: 66px;
    border: 1.5px solid var(--line);
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
    overflow: hidden;
    padding: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color .15s var(--ease)
}

.thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain
}

.thumb:hover {
    border-color: var(--gold)
}

.thumb.active {
    border-color: var(--ink)
}

.gal-included {
    margin-top: 13px;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 13px 15px;
    background: #fff
}

.gal-included .gi-title {
    font-size: 11px;
    font-weight: 800;
    color: var(--gold-deep);
    letter-spacing: .1em;
    text-transform: uppercase;
    margin-bottom: 9px
}

.gal-included ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 7px
}

.gal-included li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 12.5px;
    color: var(--ink-mid);
    line-height: 1.4
}

.gal-included li svg {
    width: 14px;
    height: 14px;
    fill: var(--green);
    flex-shrink: 0;
    margin-top: 1px
}

.gal-included li b {
    color: var(--ink);
    font-weight: 700
}

/* Info column — compact, navy/blue accents */
.info {
    position: sticky;
    top: 94px
}

.info .pcat {
    font-size: 10.5px;
    font-weight: 700;
    color: var(--navy);
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 6px
}

.info h1 {
    font-size: clamp(20px, 2.1vw, 24px);
    font-weight: 800;
    letter-spacing: -.01em;
    line-height: 1.18;
    color: var(--ink);
    margin-bottom: 6px
}

.info .pitch {
    font-size: 13px;
    color: var(--ink-mid);
    line-height: 1.5;
    margin-bottom: 11px
}

.info .pitch b {
    color: var(--ink);
    font-weight: 600
}

.vp-row {
    display: grid;
    grid-template-columns:1fr 1fr;
    gap: 4px;
    margin-bottom: 12px
}

.vp-row .vp {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11.5px;
    color: var(--ink-mid);
    font-weight: 500;
    padding: 5px 9px;
    background: var(--canvas-tint);
    border-radius: 5px
}

.vp-row .vp svg {
    width: 12px;
    height: 12px;
    fill: var(--navy);
    flex-shrink: 0
}

.vp-row .vp b {
    color: var(--ink);
    font-weight: 700
}

.price-block {
    padding: 13px 15px;
    background: #fff;
    border: 1px solid rgba(11, 27, 58, .18);
    border-radius: 9px;
    margin-bottom: 11px;
    position: relative;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(11, 27, 58, .04)
}

.price-block::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--navy) 0%, var(--blue) 50%, var(--navy) 100%)
}

.price-row {
    display: flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 3px
}

.price-amount {
    font-size: 25px;
    font-weight: 800;
    letter-spacing: -.02em;
    color: var(--ink);
    font-variant-numeric: tabular-nums;
    line-height: 1
}

.price-amount small {
    font-size: 13px;
    color: var(--muted);
    font-weight: 500;
    margin-left: 2px
}

.price-unit {
    font-size: 12.5px;
    color: var(--ink-mid);
    font-weight: 500
}

.price-unit b {
    color: var(--ink);
    font-weight: 700
}

.price-anchor {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--navy);
    background: rgba(31, 106, 227, .08);
    padding: 3px 9px;
    border-radius: 4px;
    font-weight: 600;
    margin-top: 7px
}

.price-anchor::before {
    content: "";
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--navy)
}

.price-anchor b {
    font-weight: 800
}

/* Lot-hold guarantee strip */
.lot-hold {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-top: 10px;
    padding: 7px 10px;
    background: rgba(11, 27, 58, .04);
    border-radius: 5px;
    font-size: 11px;
    color: var(--ink-mid);
    line-height: 1.4
}

.lot-hold svg {
    width: 13px;
    height: 13px;
    fill: var(--navy);
    flex-shrink: 0
}

.lot-hold b {
    color: var(--ink);
    font-weight: 700
}

/* Reassurance microline directly under ATC */
.atc-reassure {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    margin-top: 8px;
    font-size: 10.5px;
    color: var(--ink-mid);
    font-weight: 500;
    text-align: center
}

.atc-reassure span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    flex: 1;
    justify-content: center
}

.atc-reassure svg {
    width: 11px;
    height: 11px;
    fill: var(--green);
    flex-shrink: 0
}

.atc-reassure b {
    color: var(--ink);
    font-weight: 700
}

/* Volume / quantity tiers */
.tier-label {
    font-size: 10px;
    font-weight: 700;
    color: var(--muted);
    letter-spacing: .08em;
    text-transform: uppercase;
    margin: 10px 0 6px
}

.tier-select {
    display: flex;
    flex-direction: column;
    gap: 7px
}

.tier {
    display: flex;
    align-items: center;
    gap: 9px;
    margin-bottom: 7px;
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 6px 10px;
    cursor: pointer;
    transition: color .15s var(--ease), background-color .15s var(--ease), border-color .15s var(--ease), box-shadow .15s var(--ease), transform .15s var(--ease), opacity .15s var(--ease);
    position: relative
}

.tier:hover {
    border-color: var(--navy)
}

.tier.selected {
    border-color: var(--navy);
    background: rgba(31, 106, 227, .06)
}

.tier input {
    position: absolute;
    opacity: 0;
    pointer-events: none
}

.tier .t-radio {
    width: 15px;
    height: 15px;
    border-radius: 50%;
    border: 2px solid var(--line);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color .15s var(--ease)
}

.tier.selected .t-radio {
    border-color: var(--navy)
}

.tier.selected .t-radio::after {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--navy)
}

.tier .t-qty {
    font-size: 13px;
    font-weight: 700;
    color: var(--ink)
}

.tier .t-per {
    font-size: 11px;
    color: var(--ink-mid)
}

.tier .t-save {
    font-size: 9.5px;
    font-weight: 800;
    color: #fff;
    background: var(--green);
    padding: 2px 6px;
    border-radius: 3px;
    letter-spacing: .02em
}

.tier .t-total {
    margin-left: auto;
    font-size: 13.5px;
    font-weight: 800;
    color: var(--ink);
    font-variant-numeric: tabular-nums
}

.tier .t-best {
    position: absolute;
    top: -9px;
    right: 12px;
    font-size: 9px;
    font-weight: 800;
    color: #fff;
    background: var(--blue);
    padding: 3px 8px;
    border-radius: 3px;
    letter-spacing: .05em;
    text-transform: uppercase;
    box-shadow: 0 0 0 3px #fff, 0 1px 2px rgba(31, 106, 227, .25);
    line-height: 1
}

.atc-row {
    display: grid;
    grid-template-columns:108px 1fr;
    gap: 7px;
    margin-top: 11px
}

.qty-input {
    display: flex;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fff;
    overflow: hidden;
    height: 40px
}

.qty-input button {
    width: 32px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: var(--ink);
    font-size: 15px;
    font-weight: 600
}

.qty-input button:hover {
    background: var(--canvas-tint)
}

.qty-input input {
    flex: 1;
    text-align: center;
    border: 0;
    outline: none;
    font-size: 14px;
    font-weight: 700;
    color: var(--ink);
    background: #fff;
    width: 40px;
    font-family: inherit
}

.atc-row .btn-gold {
    height: 40px;
    font-size: 13.5px;
    font-weight: 600;
    justify-content: center
}

.sec-actions {
    display: grid;
    grid-template-columns:1fr 1fr;
    gap: 7px;
    margin-top: 7px
}

.sec-actions .btn {
    padding: 7px 10px;
    font-size: 11.5px;
    justify-content: center;
    border-width: 1px
}

.trust-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 11px;
    padding-top: 10px;
    border-top: 1px solid var(--line);
    font-size: 11px;
    color: var(--ink-mid)
}

.trust-row span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-weight: 500
}

.trust-row svg {
    width: 12px;
    height: 12px;
    fill: var(--navy);
    flex-shrink: 0
}

.trust-row b {
    color: var(--ink);
    font-weight: 700
}

/* Proof bar — scroll hook under hero */
.proof-bar {
    background: linear-gradient(90deg, var(--gold-soft) 0%, #FFF6E6 50%, var(--gold-soft) 100%);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line)
}

.proof-bar .wrap {
    display: grid;
    grid-template-columns:repeat(4, 1fr);
    gap: 0
}

.proof-item {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 16px 18px;
    position: relative
}

.proof-item:not(:last-child)::after {
    content: "";
    position: absolute;
    right: 0;
    top: 22%;
    height: 56%;
    width: 1px;
    background: rgba(165, 127, 61, .28)
}

.proof-item .pf-ico {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: var(--shadow-sm)
}

.proof-item .pf-ico svg {
    width: 16px;
    height: 16px;
    fill: var(--gold-deep)
}

.proof-item .pf-txt {
    line-height: 1.25
}

.proof-item .pf-txt b {
    display: block;
    font-size: 16px;
    font-weight: 800;
    color: var(--ink);
    letter-spacing: -.01em
}

.proof-item .pf-txt span {
    font-size: 11.5px;
    color: var(--ink-mid);
    font-weight: 600
}

/* Why section */
.why-section {
    padding: 54px 0;
    background: var(--canvas-tint);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line)
}

.why-section .head {
    text-align: center;
    margin-bottom: 34px
}

.why-section .tag {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--gold-deep);
    margin-bottom: 10px
}

.why-section h2 {
    font-size: clamp(24px, 2.8vw, 30px);
    font-weight: 800;
    letter-spacing: -.01em;
    line-height: 1.2;
    color: var(--ink)
}

.why-section h2 em {
    color: var(--gold-deep);
    font-style: normal
}

.why-grid {
    display: grid;
    grid-template-columns:repeat(3, 1fr);
    gap: 16px
}

.why-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 24px
}

.why-card .ico {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    background: var(--gold-soft);
    color: var(--gold-deep);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px
}

.why-card .ico svg {
    width: 20px;
    height: 20px;
    fill: currentColor
}

.why-card h4 {
    font-size: 15.5px;
    font-weight: 800;
    color: var(--ink);
    margin-bottom: 7px;
    letter-spacing: -.005em
}

.why-card p {
    font-size: 13.5px;
    color: var(--ink-mid);
    line-height: 1.55
}

.why-card p b {
    color: var(--ink);
    font-weight: 600
}

/* Key specs strip */
.spec-strip {
    padding: 22px 0;
    background: #fff;
    border-bottom: 1px solid var(--line)
}

.spec-strip .wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap
}

.spec-cell {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    text-align: center;
    padding: 8px 0
}

.spec-cell .num {
    font-size: 17px;
    font-weight: 700;
    color: var(--ink);
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
    font-family: "SF Mono", ui-monospace, monospace
}

.spec-cell .lbl {
    font-size: 10.5px;
    font-weight: 600;
    color: var(--muted);
    letter-spacing: .05em;
    text-transform: uppercase;
    margin-top: 3px
}

.spec-cell:not(:last-child) {
    border-right: 1px solid var(--line)
}

/* Tabs */
.tabs-section {
    padding: 44px 0 54px
}

.tabs-nav {
    display: flex;
    border-bottom: 1px solid var(--line);
    gap: 0;
    margin-bottom: 26px;
    overflow-x: auto
}

.tabs-nav button {
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 600;
    color: var(--muted);
    background: transparent;
    border: 0;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    white-space: nowrap
}

.tabs-nav button:hover {
    color: var(--ink)
}

.tabs-nav button.active {
    color: var(--ink);
    border-bottom-color: var(--gold)
}

.tab-pane {
    display: none
}

.tab-pane.active {
    display: block;
    animation: fadeIn .25s var(--ease)
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(4px)
    }
    to {
        opacity: 1;
        transform: none
    }
}

.tab-pane h3 {
    font-size: 18px;
    font-weight: 800;
    letter-spacing: -.005em;
    margin-bottom: 12px;
    color: var(--ink)
}

.tab-pane h4 {
    font-size: 14.5px;
    font-weight: 700;
    color: var(--ink);
    margin: 20px 0 9px
}

.tab-pane p {
    font-size: 14px;
    color: var(--ink-mid);
    line-height: 1.65;
    margin-bottom: 11px;
    max-width: 780px
}

.tab-pane p b {
    color: var(--ink);
    font-weight: 600
}

.tab-pane ul {
    list-style: none;
    margin-bottom: 11px
}

.tab-pane li {
    padding: 4px 0 4px 17px;
    position: relative;
    font-size: 14px;
    color: var(--ink-mid)
}

.tab-pane li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 12px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--gold)
}

.tab-grid-2 {
    display: grid;
    grid-template-columns:1fr 1fr;
    gap: 26px;
    margin-top: 14px
}

.tab-pane .lead {
    font-size: 15px;
    color: var(--ink);
    font-weight: 500;
    line-height: 1.6;
    margin-bottom: 4px;
    max-width: 820px
}

.tab-pane ul.feat-list li {
    padding: 6px 0 6px 22px
}

.tab-pane ul.feat-list li::before {
    top: 13px
}

.tab-pane ul.feat-list li b {
    color: var(--ink);
    font-weight: 700
}

.tab-pane ul.cols-2 {
    columns: 2;
    column-gap: 34px
}

.tab-pane ul.cols-2 li {
    break-inside: avoid
}

.alt-rows {
    margin: 2px 0 12px;
    max-width: 560px;
    border-top: 1px solid var(--line-soft)
}

.alt-rows .alt {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    padding: 9px 2px;
    border-bottom: 1px solid var(--line-soft);
    font-size: 13.5px;
    color: var(--ink-mid)
}

.alt-rows .alt b {
    color: var(--gold-deep);
    font-weight: 700;
    white-space: nowrap
}

@media (max-width: 640px) {
    .tab-pane ul.cols-2 {
        columns: 1
    }
}

.spec-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    margin-bottom: 14px
}

.spec-table tr {
    border-bottom: 1px solid var(--line-soft)
}

.spec-table td {
    padding: 9px 12px;
    color: var(--ink-mid)
}

.spec-table td:first-child {
    font-weight: 600;
    color: var(--ink);
    width: 46%;
    background: var(--canvas-tint)
}

.spec-table td:last-child {
    font-family: "SF Mono", ui-monospace, monospace
}

.dl-list {
    display: grid;
    grid-template-columns:1fr 1fr 1fr;
    gap: 10px;
    margin-top: 10px
}

.dl-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 13px;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: #fff;
    cursor: pointer;
    transition: color .15s var(--ease), background-color .15s var(--ease), border-color .15s var(--ease), box-shadow .15s var(--ease), transform .15s var(--ease), opacity .15s var(--ease)
}

.dl-card:hover {
    border-color: var(--gold);
    background: var(--canvas-tint)
}

.dl-ico {
    width: 32px;
    height: 32px;
    border-radius: 6px;
    background: var(--gold-soft);
    color: var(--gold-deep);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.dl-ico svg {
    width: 16px;
    height: 16px;
    fill: currentColor
}

.dl-card h6 {
    font-size: 12.5px;
    font-weight: 700;
    color: var(--ink);
    margin-bottom: 1px;
    line-height: 1.2
}

.dl-card .meta {
    font-size: 10.5px;
    color: var(--muted);
    text-transform: uppercase;
    font-family: "SF Mono", ui-monospace, monospace
}

.dl-card .arrow-out {
    margin-left: auto;
    color: var(--muted);
    font-size: 13px
}

/* Custom alloy promo */
.custom-promo {
    background: linear-gradient(135deg, #070F22 0%, #0B1B3A 50%, #2D2A22 100%);
    color: #fff;
    border-radius: 14px;
    padding: 30px;
    display: grid;
    grid-template-columns:1fr 260px;
    gap: 30px;
    align-items: center;
    position: relative;
    overflow: hidden;
    margin-top: 38px
}

.custom-promo::before {
    content: "";
    position: absolute;
    top: -30%;
    right: -10%;
    width: 50%;
    height: 160%;
    background: radial-gradient(ellipse at center, rgba(214, 177, 111, .16) 0, transparent 60%);
    pointer-events: none
}

.custom-promo .eyebrow-dark {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 11px;
    border-radius: 999px;
    background: rgba(214, 177, 111, .15);
    border: 1px solid rgba(214, 177, 111, .35);
    font-size: 10.5px;
    font-weight: 700;
    color: var(--gold);
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 10px;
    position: relative
}

.custom-promo h4 {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -.01em;
    line-height: 1.18;
    margin-bottom: 8px;
    position: relative
}

.custom-promo h4 em {
    color: var(--gold);
    font-style: normal
}

.custom-promo p {
    color: rgba(255, 255, 255, .78);
    font-size: 13.5px;
    line-height: 1.55;
    position: relative
}

.custom-promo .cta {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 8px
}

.custom-promo .cta .btn {
    justify-content: center
}

/* Related */
.related-section {
    padding: 44px 0 54px;
    background: var(--canvas-tint);
    border-top: 1px solid var(--line)
}

.section-head {
    margin-bottom: 24px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 18px;
    flex-wrap: wrap
}

.section-head h2 {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -.01em;
    color: var(--ink)
}

.section-head h2 em {
    color: var(--gold-deep);
    font-style: normal
}

.pm-grid {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    padding-bottom: 10px;
    -webkit-overflow-scrolling: touch
}

.pm-grid::-webkit-scrollbar {
    height: 7px
}

.pm-grid::-webkit-scrollbar-track {
    background: var(--canvas-tint);
    border-radius: 4px
}

.pm-grid::-webkit-scrollbar-thumb {
    background: var(--line);
    border-radius: 4px
}

.pm-grid::-webkit-scrollbar-thumb:hover {
    background: var(--muted)
}

/* Catalog-style tile — identical to catalog cards */
.pm-grid .card {
    flex: 0 0 250px;
    scroll-snap-align: start
}

.card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 10px;
    overflow: hidden;
    transition: color .25s var(--ease), background-color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease), opacity .25s var(--ease);
    display: flex;
    flex-direction: column;
    position: relative
}

.card:hover {
    border-color: var(--gold);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md)
}

.card .ci {
    height: 180px;
    background: var(--cream);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    position: relative
}

.card .ci img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform .35s var(--ease)
}

.card:hover .ci img {
    transform: scale(1.04)
}

.card .ribbon {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--ink);
    color: var(--gold);
    padding: 4px 9px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    z-index: 2
}

.card .ribbon.new {
    background: var(--green);
    color: #fff
}

.card .ribbon.sale {
    background: var(--red);
    color: #fff
}

.card .ribbon.hot {
    background: var(--gold);
    color: var(--ink)
}

.card .ribbon.usa {
    background: #fff;
    color: var(--ink);
    border: 1px solid var(--ink)
}

.card .wish {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--muted);
    z-index: 2;
    box-shadow: var(--shadow-sm);
    transition: color .15s var(--ease)
}

.card .wish:hover {
    color: var(--red)
}

.card .wish svg {
    width: 14px;
    height: 14px;
    fill: currentColor
}

.card .cb {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    flex: 1
}

.card .brand {
    font-size: 10.5px;
    font-weight: 700;
    color: var(--gold-deep);
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 5px
}

.card .ttl {
    font-size: 14px;
    font-weight: 800;
    color: var(--ink);
    margin-bottom: 7px;
    letter-spacing: -.005em;
    line-height: 1.25;
    height: 35px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.card .pitch {
    font-size: 12px;
    color: var(--ink-mid);
    line-height: 1.45;
    margin-bottom: 11px;
    font-style: italic;
    height: 52px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.card .specs-mini {
    font-size: 11.5px;
    color: var(--muted);
    margin-bottom: 9px;
    line-height: 1.4;
    display: flex;
    justify-content: space-between;
    gap: 6px
}

.card .specs-mini b {
    color: var(--ink);
    font-weight: 600;
    font-family: "SF Mono", ui-monospace, monospace
}

.card .compat {
    font-size: 11px;
    color: var(--ink-mid);
    margin-bottom: 11px;
    padding-bottom: 11px;
    border-bottom: 1px solid var(--line-soft);
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.card .compat .lbl {
    font-size: 9px;
    font-weight: 800;
    color: var(--gold-deep);
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-right: 6px
}

.card .compat span {
    color: var(--ink);
    font-weight: 600
}

.card .row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    gap: 10px;
    flex-wrap: wrap;
    row-gap: 8px
}

.card .price {
    font-size: 10.5px;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 600;
    flex-shrink: 0
}

.card .price b {
    display: block;
    font-size: 16px;
    font-weight: 800;
    color: var(--ink);
    letter-spacing: 0;
    line-height: 1.1;
    text-transform: none
}

.card .row .btn-gold {
    padding: 7px 12px;
    font-size: 12px;
    flex-shrink: 0;
    white-space: nowrap
}

.card .ship-note {
    margin-top: 9px;
    font-size: 11px;
    color: var(--green);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 6px;
    min-height: 30px
}

.fbt-section {
    padding: 46px 0 18px;
    background: #fff
}

.fbt-section .section-head .sub-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 10.5px;
    font-weight: 700;
    color: var(--gold-deep);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 7px
}

.fbt-section .section-head .sub-eyebrow .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--gold)
}

.fbt-section .section-head p {
    font-size: 13px;
    color: var(--muted);
    margin-top: 5px;
    line-height: 1.5;
    max-width: 520px
}

@media (max-width: 1024px) {
    .prod-grid {
        grid-template-columns:1fr;
        gap: 30px
    }

    .info {
        position: static
    }

    .why-grid {
        grid-template-columns:1fr;
        gap: 12px
    }

    .tab-grid-2, .dl-list {
        grid-template-columns:1fr
    }

    .pm-grid {
        grid-template-columns:repeat(2, 1fr)
    }

    .custom-promo {
        grid-template-columns:1fr;
        padding: 24px
    }

    .spec-cell {
        flex: 0 0 calc(50% - 8px)
    }

    .spec-cell:not(:last-child) {
        border-right: 0
    }

    .modal-2col {
        grid-template-columns:1fr
    }

    .proof-bar .wrap {
        grid-template-columns:repeat(2, 1fr)
    }

    .proof-item:nth-child(2)::after {
        display: none
    }
}

@media (max-width: 640px) {
    .vp-row {
        grid-template-columns:1fr
    }

    .atc-row {
        grid-template-columns:1fr
    }

    .sec-actions {
        grid-template-columns:1fr
    }

    .pm-grid {
        grid-template-columns:1fr
    }

    .form-row-2 {
        grid-template-columns:1fr
    }
}

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(7, 15, 34, .78);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    opacity: 0;
    transition: opacity .25s var(--ease);
    padding: 24px;
    overflow-y: auto
}

.modal-overlay.open {
    display: flex;
    opacity: 1
}

.modal-card {
    background: #fff;
    border-radius: 18px;
    max-width: 560px;
    width: 100%;
    position: relative;
    box-shadow: 0 40px 80px rgba(7, 15, 34, .4), 0 0 0 1px rgba(255, 255, 255, .06);
    transform: translateY(20px) scale(.97);
    transition: transform .35s var(--ease), opacity .25s var(--ease);
    opacity: 0;
    overflow: hidden;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    margin: auto
}

.modal-overlay.open .modal-card {
    transform: translateY(0) scale(1);
    opacity: 1
}

.modal-card::-webkit-scrollbar {
    width: 6px
}

.modal-card::-webkit-scrollbar-track {
    background: transparent
}

.modal-card::-webkit-scrollbar-thumb {
    background: var(--line);
    border-radius: 3px
}

.modal-card.lg {
    max-width: 760px
}

.modal-card.xl {
    max-width: 920px
}

.modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .92);
    border: 1px solid var(--line);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ink);
    cursor: pointer;
    z-index: 5;
    transition: color .2s var(--ease), background-color .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease), opacity .2s var(--ease);
    font-size: 18px;
    line-height: 1
}

.modal-close:hover {
    background: var(--ink);
    color: #fff;
    border-color: var(--ink);
    transform: rotate(90deg)
}

.modal-close svg {
    width: 14px;
    height: 14px
}

.modal-head {
    padding: 20px 28px 12px;
    border-bottom: 1px solid var(--line-soft)
}

.modal-head .modal-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 10.5px;
    font-weight: 700;
    color: var(--gold-deep);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 6px
}

.modal-head .modal-eyebrow .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--gold)
}

.modal-head h3 {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -.01em;
    line-height: 1.18;
    color: var(--ink)
}

.modal-head h3 em {
    font-style: normal;
    color: var(--gold-deep)
}

.modal-head .modal-sub {
    font-size: 13px;
    color: var(--muted);
    margin-top: 6px;
    line-height: 1.45
}

.modal-body {
    padding: 16px 28px 20px
}

.modal-foot {
    padding: 0 28px 20px
}

.form-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 10px
}

.form-row-2 {
    display: grid;
    grid-template-columns:1fr 1fr;
    gap: 10px;
    margin-bottom: 10px
}

.form-row-2 .form-row {
    margin-bottom: 0
}

.form-row label {
    font-size: 11.5px;
    font-weight: 600;
    color: var(--ink-soft);
    letter-spacing: .01em
}

.form-row label .opt {
    color: var(--muted);
    font-weight: 500;
    font-size: 10.5px;
    margin-left: 4px
}

.form-row label .req {
    color: var(--red);
    margin-left: 2px
}

.form-row input, .form-row select, .form-row textarea {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--line);
    border-radius: 7px;
    font-family: inherit;
    font-size: 13.5px;
    color: var(--ink);
    background: #fff;
    transition: color .15s var(--ease), background-color .15s var(--ease), border-color .15s var(--ease), box-shadow .15s var(--ease), transform .15s var(--ease), opacity .15s var(--ease);
    font-weight: 500
}

.form-row input::placeholder, .form-row textarea::placeholder {
    color: #B8B8B5;
    font-weight: 400
}

.form-row input:focus, .form-row select:focus, .form-row textarea:focus {
    outline: none;
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(214, 177, 111, .18)
}

.form-row textarea {
    resize: vertical;
    min-height: 54px;
    line-height: 1.45;
    font-family: inherit
}

.form-row select {
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1.2l4 3.6 4-3.6' stroke='%237A7872' stroke-width='1.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 10px 6px;
    padding-right: 34px
}

.modal-submit {
    width: 100%;
    justify-content: center;
    padding: 11px 22px;
    font-size: 14px;
    border-radius: 7px
}

.modal-trust {
    margin-top: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
    font-size: 11px;
    color: var(--muted);
    text-align: center;
    line-height: 1.45
}

.modal-trust b {
    color: var(--ink);
    font-weight: 700
}

.modal-trust svg {
    width: 13px;
    height: 13px;
    fill: var(--green);
    flex-shrink: 0
}

.modal-trust .mt-item {
    display: inline-flex;
    align-items: center;
    gap: 5px
}

/* Two-column modal (Claim Offer) */
.modal-2col {
    display: grid;
    grid-template-columns:1fr 1.05fr;
    gap: 0;
    min-height: 0
}

.modal-2col .modal-aside {
    background: linear-gradient(135deg, #070F22 0%, #0B1B3A 50%, #2D2A22 100%);
    color: #fff;
    padding: 22px 24px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 14px
}

.modal-2col .modal-aside::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 100% 0%, rgba(214, 177, 111, .22) 0, transparent 55%);
    pointer-events: none
}

.modal-2col .modal-aside > * {
    position: relative;
    z-index: 1
}

.offer-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 10px;
    font-weight: 800;
    background: var(--gold);
    color: var(--ink);
    padding: 4px 10px;
    border-radius: 4px;
    letter-spacing: .08em;
    text-transform: uppercase;
    align-self: flex-start;
    margin-bottom: 10px
}

.offer-headline {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -.01em;
    line-height: 1.18;
    color: #fff;
    margin-bottom: 6px
}

.offer-headline em {
    font-style: normal;
    color: var(--gold)
}

.offer-desc {
    font-size: 12.5px;
    color: rgba(255, 255, 255, .78);
    line-height: 1.5;
    margin-bottom: 12px
}

.offer-perks {
    list-style: none;
    padding: 0;
    margin: 0 0 12px 0
}

.offer-perks li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 12px;
    color: #E6E5E2;
    padding: 3px 0;
    line-height: 1.4
}

.offer-perks li::before {
    content: "";
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--gold);
    color: var(--ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 9px;
    font-weight: 800;
    margin-top: 3px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M3 6.5L5 8.5L9 4' stroke='%230C0C0C' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat: no-repeat;
    background-position: center
}

.offer-stamp {
    margin-top: auto;
    border-top: 1px solid rgba(255, 255, 255, .1);
    padding-top: 10px;
    font-size: 10.5px;
    color: rgba(255, 255, 255, .6);
    display: flex;
    align-items: center;
    gap: 8px
}

.offer-stamp b {
    color: var(--gold);
    font-weight: 700;
    letter-spacing: .04em
}

.modal-2col .modal-side {
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    justify-content: center
}

.modal-2col .modal-side h4 {
    font-size: 16px;
    font-weight: 800;
    letter-spacing: -.005em;
    color: var(--ink);
    margin-bottom: 4px
}

.modal-2col .modal-side .ms-sub {
    font-size: 12.5px;
    color: var(--muted);
    margin-bottom: 12px;
    line-height: 1.45
}

/* Equipment dropdown with checkboxes */
.eq-multi-hint {
    font-size: 11.5px;
    color: var(--muted);
    margin-top: 4px;
    line-height: 1.4
}

/* Modal step indicator (for multi-step forms) */
.modal-steps {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 18px
}

.modal-step {
    flex: 1;
    height: 3px;
    background: var(--line);
    border-radius: 2px;
    position: relative;
    overflow: hidden
}

.modal-step.done {
    background: var(--gold)
}

.modal-step.active {
    background: linear-gradient(90deg, var(--gold) 0%, var(--line) 100%)
}

/* Modal success state */
.modal-success {
    padding: 48px 36px;
    text-align: center
}

.modal-success .ms-ico {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold-soft), #FFE2A6);
    color: var(--gold-deep);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 18px
}

.modal-success .ms-ico svg {
    width: 32px;
    height: 32px;
    fill: currentColor
}

.modal-success h4 {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -.01em;
    color: var(--ink);
    margin-bottom: 8px
}

.modal-success p {
    font-size: 14px;
    color: var(--muted);
    line-height: 1.55;
    max-width: 380px;
    margin: 0 auto 20px
}

/* No body scroll when modal open */
body.modal-open {
    overflow: hidden
}

/* EMIL POLISH (Emil Kowalski design-eng) */
.btn:active {
    transform: scale(.97)
}

@media (prefers-reduced-motion: no-preference) {
    .prod-hero {
        animation: emRise .6s var(--ease-out) both
    }

    .em-reveal {
        opacity: 0;
        transform: translateY(12px);
        transition: opacity .5s var(--ease-out), transform .5s var(--ease-out)
    }

    .em-reveal.em-in {
        opacity: 1;
        transform: none
    }
}

@keyframes emRise {
    from {
        opacity: 0;
        transform: translateY(10px)
    }
    to {
        opacity: 1;
        transform: none
    }
}

/* ===== Description tab — middle-weight (typography first, navy accents) ===== */
.desc-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 10.5px;
    font-weight: 700;
    color: var(--gold-deep);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 11px
}

.desc-eyebrow .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--gold);
    box-shadow: 0 0 0 3px rgba(214, 177, 111, .18)
}

.desc-block {
    margin-top: 30px
}

.desc-block-head {
    margin-bottom: 14px;
    max-width: 780px
}

.desc-block-head h4 {
    font-size: 16.5px;
    font-weight: 800;
    letter-spacing: -.01em;
    color: var(--ink);
    margin: 0 0 4px;
    position: relative;
    padding-left: 14px
}

.desc-block-head h4::before {
    content: "";
    position: absolute;
    left: 0;
    top: 6px;
    bottom: 6px;
    width: 3px;
    border-radius: 2px;
    background: var(--gold)
}

.desc-block-head .sub {
    font-size: 13px;
    color: var(--muted);
    line-height: 1.55;
    margin: 0;
    padding-left: 14px
}

/* Why engineers choose — flat 2-col list, no boxes */
.feat-grid {
    display: grid;
    grid-template-columns:repeat(2, 1fr);
    gap: 14px 28px;
    margin-top: 8px;
    padding-left: 14px
}

.feat-tile {
    display: flex;
    gap: 11px;
    align-items: flex-start;
    background: transparent;
    border: 0;
    padding: 0;
    transition: none
}

.feat-tile:hover {
    transform: none;
    box-shadow: none;
    border: 0
}

.feat-tile .ft-ico {
    width: 26px;
    height: 26px;
    border-radius: 6px;
    background: var(--canvas-tint);
    color: var(--ink-mid);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 1px;
    border: 1px solid var(--line-soft)
}

.feat-tile .ft-ico svg {
    width: 14px;
    height: 14px;
    fill: currentColor
}

.feat-tile h5 {
    font-size: 13.5px;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 2px;
    letter-spacing: -.005em;
    line-height: 1.3
}

.feat-tile p {
    font-size: 12.5px;
    color: var(--ink-mid);
    line-height: 1.5;
    margin: 0;
    max-width: none
}

/* How we make it — full navy-gradient block (matches .custom-promo / AO banner) */
.how-grid {
    display: grid;
    grid-template-columns:repeat(3, 1fr);
    gap: 24px;
    margin-top: 8px;
    padding: 22px 24px;
    background: linear-gradient(135deg, #070F22 0%, #0B1B3A 50%, #2D2A22 100%);
    border: 0;
    border-radius: 12px;
    position: relative;
    overflow: hidden;
    color: #fff
}

.how-grid::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--gold) 0%, #FFE2A6 50%, var(--gold) 100%)
}

.how-grid::after {
    content: "";
    position: absolute;
    top: -20%;
    right: -10%;
    width: 50%;
    height: 140%;
    background: radial-gradient(ellipse at center, rgba(214, 177, 111, .14) 0, transparent 60%);
    pointer-events: none
}

.how-step {
    background: transparent;
    border: 0;
    padding: 0;
    position: relative;
    z-index: 1
}

.how-step .hs-n {
    font-family: "SF Mono", ui-monospace, monospace;
    font-size: 10px;
    font-weight: 700;
    color: var(--gold);
    letter-spacing: .1em;
    margin-bottom: 6px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-transform: uppercase
}

.how-step .hs-n::before {
    content: "";
    width: 14px;
    height: 1px;
    background: var(--gold)
}

.how-step h6 {
    font-size: 13.5px;
    font-weight: 800;
    color: #fff;
    margin: 0 0 4px;
    letter-spacing: -.005em;
    line-height: 1.25
}

.how-step p {
    font-size: 12.5px;
    color: rgba(255, 255, 255, .78);
    line-height: 1.5;
    margin: 0;
    max-width: none
}

/* Applications — flat 2-col list with small gold badges */
.app-chips {
    display: grid;
    grid-template-columns:repeat(2, 1fr);
    gap: 9px 28px;
    margin-top: 8px;
    padding-left: 14px
}

.app-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    background: transparent;
    border: 0;
    padding: 0;
    transition: none
}

.app-chip:hover {
    border: 0;
    transform: none
}

.app-chip .ac-ico {
    width: 22px;
    height: 22px;
    border-radius: 5px;
    background: var(--canvas-tint);
    color: var(--ink-mid);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 1px solid var(--line-soft)
}

.app-chip .ac-ico svg {
    width: 12px;
    height: 12px;
    fill: currentColor
}

.app-chip .ac-body {
    line-height: 1.3
}

.app-chip .ac-t {
    font-size: 13px;
    color: var(--ink);
    font-weight: 700;
    letter-spacing: -.005em
}

.app-chip .ac-s {
    font-size: 11.5px;
    color: var(--muted);
    font-weight: 500;
    margin-top: 1px
}

/* Alt-alloy cards — retoned to gold, matches catalog tile hover */
.alt-grid {
    display: grid;
    grid-template-columns:repeat(3, 1fr);
    gap: 12px;
    margin-top: 8px
}

.alt-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 14px 16px 13px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    transition: border-color .2s var(--ease), transform .2s var(--ease-out), box-shadow .2s var(--ease);
    cursor: pointer;
    position: relative;
    overflow: hidden
}

.alt-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--gold);
    transform: scaleX(.15);
    transform-origin: left;
    transition: transform .3s var(--ease)
}

.alt-card:hover {
    border-color: var(--gold);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm)
}

.alt-card:hover::before {
    transform: scaleX(1)
}

.alt-card .ac-lbl {
    font-size: 10.5px;
    font-weight: 700;
    color: var(--muted);
    letter-spacing: .06em;
    text-transform: uppercase
}

.alt-card .ac-name {
    font-size: 15px;
    font-weight: 800;
    color: var(--ink);
    letter-spacing: -.005em;
    line-height: 1.2
}

.alt-card .ac-meta {
    font-size: 11.5px;
    color: var(--ink-mid);
    line-height: 1.4;
    margin-top: 1px
}

.alt-card .ac-cta {
    margin-top: 8px;
    font-size: 12px;
    color: var(--ink-mid);
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-weight: 600;
    padding-top: 8px;
    border-top: 1px solid var(--line-soft)
}

.alt-card:hover .ac-cta {
    color: var(--ink)
}

.alt-card .ac-cta .arrow {
    transition: transform .2s var(--ease)
}

.alt-card:hover .ac-cta .arrow {
    transform: translateX(3px)
}

/* Closing engineer-CTA strip — neutral with single gold wink on the bar */
.desc-close {
    margin-top: 16px;
    padding: 13px 18px;
    background: var(--canvas-tint);
    border-left: 3px solid var(--gold);
    border-radius: 0 8px 8px 0;
    font-size: 13.5px;
    color: var(--ink-mid);
    line-height: 1.55;
    max-width: 820px
}

.desc-close b {
    color: var(--ink);
    font-weight: 700
}

.desc-close a {
    color: var(--ink);
    font-weight: 600;
    border-bottom: 1px solid var(--ink-mid);
    transition: color .2s var(--ease), border-color .2s var(--ease);
    cursor: pointer
}

.desc-close a:hover {
    color: var(--gold-deep);
    border-bottom-color: var(--gold-deep)
}

@media (max-width: 880px) {
    .alt-grid {
        grid-template-columns:1fr
    }

    .how-grid {
        grid-template-columns:repeat(2, 1fr);
        gap: 18px
    }

    .feat-grid, .app-chips {
        grid-template-columns:1fr
    }
}

@media (max-width: 560px) {
    .how-grid {
        grid-template-columns:1fr;
        gap: 16px
    }
}

/* ===== Reviews section ===== */
.rev-section {
    padding: 48px 0 24px;
    background: #fff;
    border-top: 1px solid var(--line)
}

.rev-section .head {
    margin-bottom: 24px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap
}

.rev-section .head h2 {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -.01em;
    color: var(--ink);
    margin-bottom: 5px
}

.rev-section .head h2 em {
    color: var(--gold-deep);
    font-style: normal
}

.rev-section .head .head-sub {
    font-size: 13px;
    color: var(--muted);
    max-width: 520px;
    line-height: 1.5;
    margin: 0
}

.rev-section .rev-meta {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-size: 13px;
    color: var(--ink-mid)
}

.rev-section .rev-stars {
    color: #F5A623;
    font-size: 14px;
    letter-spacing: 1.5px
}

.rev-section .rev-meta b {
    color: var(--ink);
    font-weight: 700
}

.rev-grid {
    display: grid;
    grid-template-columns:repeat(3, 1fr);
    gap: 14px
}

.rev-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 18px 19px;
    display: flex;
    flex-direction: column;
    gap: 11px;
    transition: border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease-out)
}

.rev-card:hover {
    border-color: var(--gold);
    box-shadow: var(--shadow-sm);
    transform: translateY(-2px)
}

.rev-card .stars {
    color: #F5A623;
    font-size: 13px;
    letter-spacing: 1.5px
}

.rev-card p {
    font-size: 13px;
    color: var(--ink-mid);
    line-height: 1.6;
    margin: 0;
    flex: 1
}

.rev-card .who {
    display: flex;
    align-items: center;
    gap: 10px;
    border-top: 1px solid var(--line-soft);
    padding-top: 11px;
    margin-top: auto
}

.rev-card .who .av {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), var(--gold-deep));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 11.5px;
    flex-shrink: 0
}

.rev-card .who b {
    font-size: 12.5px;
    color: var(--ink);
    font-weight: 700;
    display: block;
    line-height: 1.2
}

.rev-card .who small {
    font-size: 11px;
    color: var(--muted);
    display: block;
    margin-top: 1px
}

.rev-card .verified {
    font-size: 10px;
    font-weight: 700;
    color: var(--green);
    letter-spacing: .04em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: 3px
}

.rev-card .verified::before {
    content: "●";
    font-size: 6px
}

/* ===== FAQ section ===== */
.faq-section {
    padding: 54px 0;
    background: var(--canvas-tint);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line)
}

.faq-wrap {
    display: grid;
    grid-template-columns:.85fr 2.15fr;
    gap: 50px;
    align-items: start
}

.faq-l .tag {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--gold-deep);
    margin-bottom: 10px;
    display: inline-block
}

.faq-l h3 {
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -.01em;
    line-height: 1.15;
    color: var(--ink)
}

.faq-l h3 em {
    color: var(--gold-deep);
    font-style: normal
}

.faq-l p {
    font-size: 13.5px;
    color: var(--muted);
    margin-top: 12px;
    line-height: 1.55
}

.faq-l p a {
    color: var(--ink);
    font-weight: 600;
    border-bottom: 1px solid var(--gold);
    transition: color .2s var(--ease)
}

.faq-l p a:hover {
    color: var(--gold-deep)
}

.faq-l .btn {
    margin-top: 18px
}

.faq-item {
    border-top: 1px solid var(--line)
}

.faq-item:last-child {
    border-bottom: 1px solid var(--line)
}

.faq-item summary {
    padding: 16px 0;
    font-size: 14.5px;
    font-weight: 600;
    color: var(--ink);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    list-style: none;
    transition: color .2s var(--ease)
}

.faq-item summary::-webkit-details-marker {
    display: none
}

.faq-item summary:hover {
    color: var(--gold-deep)
}

.faq-item summary::after {
    content: "+";
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    border: 1.5px solid var(--ink);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 600;
    transition: transform .3s var(--ease);
    line-height: 0
}

.faq-item[open] summary::after {
    transform: rotate(45deg)
}

.faq-item .ans {
    padding: 0 0 16px;
    font-size: 13.5px;
    color: var(--ink-mid);
    line-height: 1.6;
    max-width: 92%
}

.faq-item .ans b {
    color: var(--ink);
    font-weight: 600
}

@media (max-width: 880px) {
    .rev-grid {
        grid-template-columns:1fr
    }

    .faq-wrap {
        grid-template-columns:1fr;
        gap: 24px
    }
}

/* ============================================================ */
/* === PHASE 1 — MOBILE / RESPONSIVE / OVERFLOW FIXES ========= */
/* ============================================================ */

/* --- 7.1 Global horizontal scroll lock --- */
html, body {
    overflow-x: hidden;
    max-width: 100%;
    width: 100%
}

.wrap {
    box-sizing: border-box
}

img, svg, video {
    max-width: 100%;
    height: auto
}

/* --- 7.2 Flex/grid children — prevent overflow from long content --- */
.prod-grid, .gallery, .info, .vp-row, .atc-row, .sec-actions, .tier, .tier-select, .price-row,
.proof-bar .wrap, .proof-item, .spec-strip .wrap, .spec-cell,
.tabs-nav, .tab-pane, .tab-grid-2, .dl-list, .dl-card, .alt-rows .alt,
.feat-grid, .feat-tile, .feat-tile > div, .app-chips, .app-chip, .app-chip .ac-body,
.how-grid, .how-step, .alt-grid, .alt-card,
.fbt-section, .related-section, .rev-grid, .rev-card, .rev-card .who,
.faq-wrap, .faq-l, .faq-item,
.form-row, .form-row-2,
.modal-2col, .modal-card, .modal-side, .modal-aside,
.section-head, .section-head > * {
    min-width: 0
}

/* --- 7.3 Break long words on headings & product specs --- */
.info h1, .info .pitch, .tab-pane h3, .tab-pane h4, .tab-pane p, .tab-pane li,
.card .ttl, .card .pitch, .card .compat,
.modal-head h3, .offer-headline, .spec-table td,
.feat-tile h5, .feat-tile p, .app-chip .ac-t, .app-chip .ac-s,
.faq-item summary, .faq-item .ans {
    overflow-wrap: break-word;
    word-wrap: break-word;
    hyphens: auto
}

/* --- 7.4 Modal viewport guardrails --- */
.modal-overlay {
    width: 100vw;
    max-width: 100%;
    padding: 14px
}

.modal-card {
    max-width: calc(100vw - 28px)
}

@media (min-width: 769px) {
    .modal-card {
        max-width: 560px
    }

    .modal-card.lg {
        max-width: 760px
    }

    .modal-card.xl {
        max-width: 920px
    }
}

/* --- 8. FORMS — iOS-safe font-size, full width inputs --- */
.form-row input, .form-row select, .form-row textarea {
    max-width: 100%;
    box-sizing: border-box
}

.form-row textarea {
    resize: vertical
}

@media (max-width: 768px) {
    .modal-head {
        padding: 18px 18px 12px
    }

    .modal-body {
        padding: 14px 18px 18px
    }

    .form-row-2 {
        grid-template-columns:1fr;
        gap: 0
    }

    .form-row-2 .form-row {
        margin-bottom: 10px
    }

    .form-row input, .form-row select, .form-row textarea {
        font-size: 16px;
        padding: 10px 12px
    }

    .form-row label {
        font-size: 12px
    }

    .modal-submit {
        padding: 12px 18px;
        font-size: 14.5px
    }

    .modal-trust {
        gap: 8px;
        font-size: 10.5px;
        margin-top: 8px
    }

    .modal-head h3 {
        font-size: 18px
    }

    .modal-head .modal-sub {
        font-size: 12.5px
    }

    input[type="date"] {
        min-width: 0;
        width: 100%
    }
}

/* --- 9. PRODUCT HERO — image rules + buy box stacking --- */
.gallery .main-img {
    aspect-ratio: 1/1;
    height: auto;
    min-height: 0
}

.gallery .main-img img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    margin: 0 auto
}

@media (max-width: 1024px) {
    .prod-hero {
        padding: 14px 0 22px
    }

    .prod-grid {
        gap: 22px
    }

    .gallery .main-img {
        padding: 24px;
        max-width: 480px;
        margin: 0 auto
    }

    .gallery .thumbs {
        justify-content: center;
        flex-wrap: wrap
    }
}

@media (max-width: 768px) {
    .gallery .main-img {
        padding: 20px;
        max-width: 100%
    }

    .thumb {
        width: 56px;
        height: 56px
    }

    .gallery .badge-stock, .gallery .badge-zoom, .gallery .badge-made {
        font-size: 10px;
        padding: 4px 8px
    }

    .info h1 {
        font-size: 20px;
        line-height: 1.22
    }

    .info .pitch {
        font-size: 13px
    }

    .price-amount {
        font-size: 22px
    }

    .price-amount small {
        font-size: 12px
    }

    .tier {
        padding: 7px 11px;
        gap: 8px
    }

    .tier .t-qty {
        font-size: 12.5px
    }

    .tier .t-per {
        font-size: 10.5px
    }

    .tier .t-save {
        font-size: 9px;
        padding: 2px 5px
    }

    .tier .t-total {
        font-size: 12.5px
    }

    .tier .t-best {
        font-size: 8.5px;
        padding: 2px 7px;
        top: -8px
    }

    .atc-row {
        grid-template-columns:1fr;
        gap: 8px
    }

    .atc-row .qty-input {
        height: 44px;
        width: 100%;
        justify-content: space-between
    }

    .atc-row .qty-input input {
        width: 100%
    }

    .atc-row .btn-gold {
        height: 44px;
        font-size: 14px;
        padding: 0 16px
    }

    .sec-actions {
        grid-template-columns:1fr 1fr;
        gap: 8px
    }

    .sec-actions .btn {
        padding: 8px 10px;
        font-size: 12px
    }

    .trust-row {
        gap: 8px;
        font-size: 10.5px
    }

    .proof-bar .wrap {
        grid-template-columns:1fr 1fr;
        gap: 0
    }

    .proof-item {
        padding: 11px 12px;
        gap: 8px
    }

    .proof-item .pf-txt b {
        font-size: 13.5px
    }

    .proof-item .pf-txt span {
        font-size: 10.5px
    }

    .proof-item:not(:last-child)::after {
        display: none
    }

    .proof-item:nth-child(odd)::after {
        content: "";
        display: block;
        position: absolute;
        right: 0;
        top: 22%;
        height: 56%;
        width: 1px;
        background: rgba(165, 127, 61, .28)
    }

    .proof-item:nth-child(n+3) {
        border-top: 1px solid rgba(165, 127, 61, .28)
    }

    .spec-strip {
        padding: 14px 0
    }

    .spec-cell {
        flex: 0 0 calc(50% - 8px);
        padding: 6px 0
    }

    .spec-cell .num {
        font-size: 15px
    }

    .spec-cell .lbl {
        font-size: 10px
    }

    .spec-cell:not(:last-child) {
        border-right: 0
    }
}

@media (max-width: 480px) {
    .vp-row {
        grid-template-columns:1fr
    }

    .sec-actions {
        grid-template-columns:1fr
    }

    .spec-strip .wrap {
        flex-direction: column;
        align-items: stretch
    }

    .spec-cell {
        flex: 1;
        text-align: left;
        display: grid;
        grid-template-columns:auto 1fr;
        gap: 10px;
        align-items: center;
        padding: 8px 0;
        border-bottom: 1px solid var(--line-soft)
    }

    .spec-cell:last-child {
        border-bottom: 0
    }
}

/* --- 10. WHY/HOW sections compactness --- */
@media (max-width: 768px) {
    .why-section {
        padding: 36px 0
    }

    .why-section .head {
        margin-bottom: 24px
    }

    .why-card {
        padding: 18px
    }

    .how-grid {
        padding: 18px 18px;
        gap: 14px
    }
}

/* --- 11. TABS — scrollable nav + conditional show/hide --- */
.tabs-nav {
    display: flex;
    border-bottom: 1px solid var(--line);
    gap: 0;
    margin-bottom: 26px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none
}

.tabs-nav::-webkit-scrollbar {
    display: none
}

.tabs-nav button {
    flex: 0 0 auto
}

.tabs-nav button[hidden], .tab-pane[hidden] {
    display: none !important
}

@media (max-width: 768px) {
    .tabs-section {
        padding: 28px 0 36px
    }

    .tabs-nav {
        margin: 0 -16px 18px;
        padding: 0 16px;
        border-bottom-width: 1px
    }

    .tabs-nav button {
        padding: 10px 14px;
        font-size: 13px
    }

    .tab-pane h3 {
        font-size: 16px
    }

    .tab-pane p, .tab-pane li {
        font-size: 13.5px
    }
}

/* --- 12. PRODUCT SLIDER (.p-slider) — replaces old .pm-grid for FBT/related --- */
.p-slider {
    position: relative;
    margin: 0 -8px
}

.p-slider-viewport {
    overflow: hidden;
    padding: 8px 8px 14px;
    touch-action: pan-y;
    cursor: grab;
    user-select: none
}

.p-slider-viewport.dragging {
    cursor: grabbing;
    scroll-behavior: auto
}

.p-slider-viewport.dragging * {
    pointer-events: none
}

.p-slider-track {
    display: flex;
    gap: 14px;
    will-change: transform;
    transition: transform .42s var(--ease)
}

.p-slider-viewport.no-transition .p-slider-track {
    transition: none
}

.p-slider-track > .card {
    flex: 0 0 var(--slide-w);
    min-width: 0;
    scroll-snap-align: start;
    margin: 0
}

.p-slider {
    --slide-w: calc((100% - 14px * 3) / 4)
}

@media (max-width: 1199px) {
    .p-slider {
        --slide-w: calc((100% - 14px * 2) / 3)
    }
}

@media (max-width: 899px) {
    .p-slider {
        --slide-w: calc((100% - 14px) / 2)
    }
}

@media (max-width: 599px) {
    .p-slider {
        --slide-w: calc(86% - 6px)
    }
}

.p-slider-controls {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 14px;
    flex-wrap: wrap
}

.p-slider-arrows {
    display: flex;
    gap: 8px
}

.p-slider-arrow {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1.5px solid var(--ink);
    background: #fff;
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    transition: all .2s var(--ease);
    flex-shrink: 0
}

.p-slider-arrow:hover:not([disabled]) {
    background: var(--ink);
    color: #fff
}

.p-slider-arrow[disabled] {
    opacity: .3;
    cursor: not-allowed
}

.p-slider-dots {
    display: flex;
    gap: 6px;
    align-items: center;
    flex-wrap: wrap
}

.p-slider-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--line);
    transition: all .2s var(--ease);
    cursor: pointer;
    border: 0;
    padding: 0
}

.p-slider-dot.active {
    background: var(--gold);
    width: 24px;
    border-radius: 4px
}

.p-slider-counter {
    font-size: 12px;
    color: var(--muted);
    font-weight: 600;
    letter-spacing: .04em;
    font-family: "SF Mono", ui-monospace, monospace;
    margin-left: auto
}

.p-slider-counter b {
    color: var(--ink)
}

@media (max-width: 768px) {
    .p-slider-arrows {
        display: none
    }

    .p-slider-controls {
        margin-top: 10px;
        justify-content: center
    }

    .p-slider-counter {
        margin: 0
    }
}

/* --- 13. RELATED + REVIEWS responsive --- */
@media (max-width: 768px) {
    .related-section {
        padding: 32px 0 40px
    }

    .section-head {
        margin-bottom: 18px;
        gap: 12px
    }

    .section-head h2 {
        font-size: 18px
    }

    .rev-section {
        padding: 32px 0 18px
    }

    .rev-section .head h2 {
        font-size: 18px
    }

    .rev-card {
        padding: 14px 15px
    }

    .rev-card p {
        font-size: 12.5px
    }
}

/* --- 14. FAQ responsive --- */
@media (max-width: 768px) {
    .faq-section {
        padding: 36px 0
    }

    .faq-l h3 {
        font-size: 22px
    }

    .faq-item summary {
        font-size: 14px;
        padding: 14px 0
    }

    .faq-item .ans {
        font-size: 13px;
        max-width: 100%
    }
}

/* --- 15. FINAL CTA --- */
@media (max-width: 768px) {
    .final-cta {
        padding: 36px 0
    }

    .final-cta h2 {
        font-size: 22px
    }

    .final-cta .head p {
        font-size: 13.5px
    }

    .final-single-cta {
        flex-direction: column;
        width: 100%;
        gap: 10px
    }

    .final-single-cta .btn {
        width: 100%;
        justify-content: center;
        font-size: 14px;
        padding: 13px 18px
    }
}

/* --- 16. Custom promo (Custom alloy block) — responsive --- */
@media (max-width: 768px) {
    .custom-promo {
        padding: 22px 18px;
        grid-template-columns:1fr;
        gap: 18px
    }

    .custom-promo h4 {
        font-size: 18px
    }

    .custom-promo p {
        font-size: 13px
    }

    .custom-promo .cta .btn {
        font-size: 14px;
        padding: 12px 16px
    }
}

/* --- 17. PROMO STRIP responsive --- */
@media (max-width: 768px) {
    .promo-strip .wrap {
        gap: 10px;
        font-size: 12px;
        flex-direction: column;
        text-align: center
    }
}

/* --- 18. CRUMBS responsive --- */
@media (max-width: 768px) {
    .crumbs {
        padding: 10px 0
    }

    .crumbs .wrap {
        font-size: 11.5px;
        gap: 4px
    }
}

/* ADD-ONS */
.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product .stock {
    color: #fff;
}

.woocommerce div.product form.cart {
    margin-bottom: 0!important;
}

.qty {
    -moz-appearance: textfield;
}

.qty::-webkit-outer-spin-button,
.qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.related-section .card .ship-note:before,
.tier-select select,
.added_to_cart.wc-forward {
    display: none!important;
}

.starter-price .price bdi,
.price-amount .price bdi {
    font-size: 25px;
    font-weight: 800;
    letter-spacing: -.02em;
    color: var(--ink);
    font-variant-numeric: tabular-nums;
    line-height: 1;
}

.related-section .pitch,
.fbt-section .pitch {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
    max-height: 35px;
}

.related-section .card a,
.fbt-section .card a {
    position: relative;
    z-index: 100;
    pointer-events: auto !important;
}

.related-section .card .ship-note p {
    color: var(--green)!important;
}