/* ===========================
   BED PRODUCT PAGE — DESIGN 2026
=========================== */

:root {
    --bed-bg: #f6f3ee;
    --bed-surface: rgba(255, 255, 255, 0.68);
    --bed-surface-strong: #ffffff;
    --bed-border: rgba(60, 46, 32, 0.08);
    --bed-text: #2e2924;
    --bed-muted: #7b736b;
    --bed-accent: #bba58c;
    --bed-accent-dark: #3a322c;
    --bed-radius-xl: 28px;
    --bed-radius-lg: 22px;
    --bed-radius-md: 16px;
    --bed-shadow-soft: 0 20px 60px rgba(32, 24, 18, 0.06);
}

.bed-product-page,
.bed-story-section,
.bed-features-section,
.bed-specs-section,
.bed-final-cta {
    background: var(--bed-bg);
}

.bed-product-page {
    padding: 50px 0 40px;
}

.bed-story-section,
.bed-features-section,
.bed-specs-section,
.bed-final-cta {
    padding: 90px 0;
}

.bed-shell {
    padding-left: 40px;
    padding-right: 40px;
}

.bed-breadcrumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    font-size: 14px;
    color: var(--bed-muted);
    margin-bottom: 30px;
}

.bed-breadcrumbs a {
    color: var(--bed-muted);
    text-decoration: none;
}

.bed-breadcrumbs a:hover {
    color: var(--bed-text);
}

.bed-breadcrumbs .current {
    color: var(--bed-text);
    font-weight: 600;
}

.bed-hero-row,
.bed-section-row {
    row-gap: 30px;
}

.bed-gallery-card,
.bed-summary-card,
.bed-story-image,
.bed-feature-card,
.bed-spec-card,
.bed-final-cta-card {
    background: var(--bed-surface);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid var(--bed-border);
    box-shadow: var(--bed-shadow-soft);
}

.bed-gallery-card {
    border-radius: var(--bed-radius-xl);
    padding: 18px;
}

.bed-main-image {
    border-radius: 22px;
    overflow: hidden;
    background: #efe9e1;
}

.bed-main-image img {
    width: 100%;
    display: block;
    object-fit: cover;
}

.bed-thumbs-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-top: 16px;
}

.bed-thumb {
    padding: 0;
    border: 1px solid transparent;
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
    cursor: pointer;
    transition: all 0.25s ease;
}

.bed-thumb img {
    width: 100%;
    display: block;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.bed-thumb:hover,
.bed-thumb.is-active {
    border-color: rgba(187, 165, 140, 0.5);
    transform: translateY(-2px);
    box-shadow: 0 12px 26px rgba(36, 28, 22, 0.08);
}

.bed-summary-card {
    border-radius: var(--bed-radius-xl);
    padding: 38px;
    position: sticky;
    top: 30px;
}

.bed-label,
.bed-eyebrow {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--bed-accent-dark);
    margin-bottom: 14px;
}

.bed-title {
    font-size: clamp(38px, 5vw, 62px);
    line-height: 1;
    margin: 0 0 16px;
    color: var(--bed-text);
    font-weight: 700;
    letter-spacing: -0.03em;
}

.bed-subtitle {
    font-size: 18px;
    line-height: 1.75;
    color: var(--bed-muted);
    margin-bottom: 28px;
}

.bed-quick-specs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-bottom: 24px;
}

.bed-spec-box {
    background: rgba(255,255,255,0.72);
    border: 1px solid var(--bed-border);
    border-radius: 18px;
    padding: 16px 18px;
}

.bed-spec-box span {
    display: block;
    font-size: 12px;
    color: var(--bed-muted);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.bed-spec-box strong {
    font-size: 15px;
    color: var(--bed-text);
    font-weight: 600;
}

.bed-feature-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 28px;
}

.bed-feature-tags span,
.bed-size-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 16px;
    border-radius: 999px;
    border: 1px solid var(--bed-border);
    background: rgba(255,255,255,0.75);
    color: var(--bed-text);
    font-size: 14px;
    font-weight: 500;
}

.bed-cta-row,
.bed-final-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.bed-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 0 24px;
    border-radius: 999px;
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
    transition: all 0.25s ease;
}

.bed-btn-dark {
    background: var(--bed-accent-dark);
    color: #fff;
}

.bed-btn-dark:hover {
    background: #211c18;
    color: #fff;
    transform: translateY(-2px);
}

.bed-btn-light {
    background: rgba(255,255,255,0.7);
    color: var(--bed-text);
    border: 1px solid var(--bed-border);
}

.bed-btn-light:hover {
    background: #fff;
    color: var(--bed-text);
    transform: translateY(-2px);
}

.bed-note {
    margin-top: 18px;
    margin-bottom: 0;
    color: var(--bed-muted);
    font-size: 14px;
    line-height: 1.7;
}

.bed-section-copy h2,
.bed-section-head h2,
.bed-spec-card h2,
.bed-final-cta-card h2 {
    font-size: clamp(28px, 4vw, 46px);
    line-height: 1.12;
    letter-spacing: -0.03em;
    color: var(--bed-text);
    margin-bottom: 18px;
}

.bed-section-copy p,
.bed-final-cta-card p,
.bed-feature-card p,
.bed-spec-card p {
    color: var(--bed-muted);
    font-size: 17px;
    line-height: 1.8;
}

.bed-story-image {
    border-radius: var(--bed-radius-xl);
    overflow: hidden;
    padding: 14px;
}

.bed-story-image img {
    width: 100%;
    display: block;
    border-radius: 20px;
    object-fit: cover;
}

.bed-section-head {
    margin-bottom: 34px;
}

.bed-section-head.center {
    text-align: center;
}

.bed-feature-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}

.bed-feature-card {
    border-radius: var(--bed-radius-lg);
    padding: 28px;
}

.bed-feature-card h3 {
    font-size: 22px;
    line-height: 1.2;
    margin-bottom: 14px;
    color: var(--bed-text);
    letter-spacing: -0.02em;
}

.bed-spec-card {
    border-radius: var(--bed-radius-xl);
    padding: 34px;
    height: 100%;
}

.bed-spec-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.bed-spec-row {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 16px 0;
    border-bottom: 1px solid rgba(60, 46, 32, 0.08);
}

.bed-spec-row:last-child {
    border-bottom: 0;
}

.bed-spec-row span {
    color: var(--bed-muted);
    font-size: 15px;
}

.bed-spec-row strong {
    color: var(--bed-text);
    font-size: 15px;
    font-weight: 600;
    text-align: right;
}

.bed-size-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 22px;
    margin-bottom: 18px;
}

.bed-final-cta-card {
    border-radius: 32px;
    padding: 40px;
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: center;
}

@media (max-width: 1199px) {
    .bed-feature-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .bed-summary-card {
        position: static;
    }
}

@media (max-width: 991px) {
    .bed-shell {
        padding-left: 20px;
        padding-right: 20px;
    }

    .bed-product-page {
        padding-top: 30px;
    }

    .bed-story-section,
    .bed-features-section,
    .bed-specs-section,
    .bed-final-cta {
        padding: 65px 0;
    }

    .bed-quick-specs {
        grid-template-columns: 1fr;
    }

    .bed-final-cta-card {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767px) {
    .bed-thumbs-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .bed-feature-grid {
        grid-template-columns: 1fr;
    }

    .bed-summary-card,
    .bed-gallery-card,
    .bed-spec-card,
    .bed-feature-card,
    .bed-final-cta-card {
        padding: 22px;
    }

    .bed-title {
        font-size: 36px;
    }

    .bed-subtitle,
    .bed-section-copy p,
    .bed-feature-card p,
    .bed-spec-card p {
        font-size: 16px;
    }

    .bed-spec-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .bed-spec-row strong {
        text-align: left;
    }

    .bed-btn {
        width: 100%;
    }
}

.bed-main-image img {
    transition: opacity 0.25s ease;
}


.bed-main-image img {
    transition: opacity 0.25s ease;
}

.bed-product-page {
    padding: 34px 0 56px;
}

.bed-hero-row {
    row-gap: 36px;
}

.bed-gallery-card {
    border-radius: var(--bed-radius-xxl);
    padding: 18px;
}

.bed-main-image {
    border-radius: 26px;
    overflow: hidden;
    background: #eee7df;
}

.bed-main-image img {
    width: 100%;
    display: block;
    object-fit: cover;
    transition: opacity 0.25s ease, transform 0.45s ease;
}

.bed-main-image:hover img {
    transform: scale(1.01);
}

.bed-summary-card {
    border-radius: var(--bed-radius-xxl);
    padding: 42px 42px 38px;
    position: sticky;
    top: 26px;
    background: var(--bed-surface);
    border: 1px solid rgba(60, 46, 32, 0.05);
    box-shadow: 0 18px 44px rgba(30, 22, 16, 0.035);
}

.bed-label {
    margin-bottom: 16px;
    font-size: 11px;
    letter-spacing: 0.16em;
    color: #5c5146;
}

.bed-title {
    font-size: clamp(44px, 5vw, 74px);
    line-height: 0.96;
    margin: 0 0 20px;
    letter-spacing: -0.045em;
    font-weight: 700;
    color: var(--bed-text);
}

.bed-subtitle {
    font-size: 19px;
    line-height: 1.85;
    color: var(--bed-muted);
    margin-bottom: 30px;
    max-width: 92%;
}

.bed-quick-specs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 26px;
}

.bed-spec-box {
    background: rgba(255,255,255,0.46);
    border: 1px solid rgba(60, 46, 32, 0.05);
    border-radius: 20px;
    padding: 18px 18px 17px;
    transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}

.bed-spec-box:hover {
    transform: translateY(-2px);
    background: rgba(255,255,255,0.62);
    box-shadow: 0 14px 28px rgba(31, 24, 18, 0.04);
}

.bed-spec-box span {
    display: block;
    font-size: 11px;
    color: #8a8178;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.bed-spec-box strong {
    font-size: 16px;
    color: var(--bed-text);
    font-weight: 600;
}

.bed-feature-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 30px;
}

.bed-feature-tags span,
.bed-size-pill {
    min-height: 42px;
    padding: 10px 16px;
    border-radius: 999px;
    border: 1px solid rgba(60, 46, 32, 0.05);
    background: rgba(255,255,255,0.42);
    color: #4f473f;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.22s ease;
}

.bed-feature-tags span:hover,
.bed-size-pill:hover {
    background: rgba(255,255,255,0.7);
    transform: translateY(-1px);
}


.bed-cta-row,
.bed-final-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.bed-btn {
    min-height: 56px;
    padding: 0 26px;
    border-radius: 999px;
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: -0.01em;
    transition: all 0.25s ease;
}

.bed-btn-dark {
    background: #4c3d32;
    color: #fff;
    box-shadow: 0 12px 24px rgba(76, 61, 50, 0.16);
}

.bed-btn-dark:hover {
    background: #3e3128;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 18px 30px rgba(76, 61, 50, 0.22);
}

.bed-btn-light {
    background: rgba(255,255,255,0.54);
    color: var(--bed-text);
    border: 1px solid rgba(60, 46, 32, 0.05);
}

.bed-btn-light:hover {
    background: rgba(255,255,255,0.82);
    color: var(--bed-text);
    transform: translateY(-2px);
}

.bed-story-section {
    padding: 104px 0;
}

.bed-section-copy {
    max-width: 560px;
}

.bed-eyebrow {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #54493f;
    margin-bottom: 18px;
}

.bed-section-copy h2,
.bed-section-head h2,
.bed-spec-card h2,
.bed-final-cta-card h2 {
    font-size: clamp(34px, 4vw, 58px);
    line-height: 1.04;
    letter-spacing: -0.045em;
    color: var(--bed-text);
    margin-bottom: 20px;
}

.bed-section-copy p {
    color: var(--bed-muted);
    font-size: 18px;
    line-height: 1.9;
    margin-bottom: 20px;
}

.bed-story-image {
    border-radius: 30px;
    overflow: hidden;
    padding: 12px;
    background: rgba(255,255,255,0.46);
}

.bed-story-image img {
    width: 100%;
    display: block;
    border-radius: 22px;
    object-fit: cover;
}


.bed-specs-section {
    padding: 60px 0 110px;
}

.bed-spec-card {
    border-radius: 30px;
    padding: 38px 32px;
    height: 100%;
    background: rgba(255,255,255,0.56);
    border: 1px solid rgba(60, 46, 32, 0.045);
}

.bed-spec-list {
    margin-top: 24px;
}

.bed-spec-row {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 18px 0;
    border-bottom: 1px solid rgba(60, 46, 32, 0.06);
}

.bed-spec-row span {
    color: var(--bed-muted);
    font-size: 15px;
}

.bed-spec-row strong {
    color: var(--bed-text);
    font-size: 15px;
    font-weight: 600;
    text-align: right;
}


/* =========================
   FLEXY FOOTER 2026
========================= */

.flexy-footer-2026 {
    position: relative;
    overflow: hidden;
    padding: 90px 0 28px;
    background:
        radial-gradient(circle at top left, rgba(210, 190, 170, 0.08), transparent 30%),
        radial-gradient(circle at right center, rgba(190, 170, 150, 0.08), transparent 26%),
        linear-gradient(135deg, #151618 0%, #1c1d20 50%, #17181b 100%);
    color: rgba(255,255,255,0.78);
}

.flexy-footer-2026::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url(../images/demo-branding-agency-pattern.svg);
    background-size: cover;
    background-position: center;
    opacity: 0.06;
    pointer-events: none;
}

.flexy-footer-2026 .container {
    position: relative;
    z-index: 2;
}

.flexy-footer-top {
    padding-bottom: 46px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.footer-brand-block {
    max-width: 520px;
}

.footer-logo-wrap {
    display: inline-block;
    margin-bottom: 16px;
}

.footer-logo {
    max-width: 220px;
    width: 100%;
    height: auto;
}

.footer-brand-text {
    margin: 0 0 28px;
    max-width: 430px;
    color: rgba(255,255,255,0.68);
    font-size: 17px;
    line-height: 1.85;
    letter-spacing: -0.01em;
}

.footer-title {
    display: inline-block;
    margin-bottom: 16px;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.footer-certifications {
    margin-bottom: 28px;
}

.footer-certifications-box {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
    padding: 16px 18px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.footer-certifications-box img {
    width: 100%;
    max-width: 470px;
    display: block;
    height: auto;
}

.footer-cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.footer-btn {
    min-height: 56px;
    padding: 0 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: -0.01em;
    transition: all 0.25s ease;
}

.footer-btn-light {
    background: #ffffff;
    color: #18191c;
    box-shadow: 0 12px 30px rgba(0,0,0,0.14);
}

.footer-btn-light:hover {
    background: #f3f0ea;
    color: #18191c;
    transform: translateY(-2px);
}

.footer-btn-outline {
    background: transparent;
    color: #ffffff;
    border: 1px solid rgba(255,255,255,0.18);
}

.footer-btn-outline:hover {
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    transform: translateY(-2px);
}

.footer-links-column {
    height: 100%;
}

.footer-links {
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer-links li {
    margin-bottom: 10px;
}

.footer-links li:last-child {
    margin-bottom: 0;
}

.footer-links a {
    color: rgba(255,255,255,0.68);
    text-decoration: none;
    font-size: 16px;
    line-height: 1.7;
    transition: all 0.22s ease;
}

.footer-links a:hover {
    color: #ffffff;
    padding-left: 4px;
}

.footer-contact-card {
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px solid rgba(255,255,255,0.08);
}

.footer-mini-title {
    display: block;
    margin-bottom: 8px;
    color: rgba(255,255,255,0.86);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.footer-contact-link {
    color: #ffffff;
    font-size: 22px;
    line-height: 1.2;
    font-weight: 500;
    text-decoration: none;
    letter-spacing: -0.03em;
}

.footer-contact-link:hover {
    color: #ffffff;
    opacity: 0.86;
}

.flexy-footer-bottom {
    padding-top: 26px;
}

.footer-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.footer-socials a {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    color: #ffffff;
    font-size: 18px;
    text-decoration: none;
    transition: all 0.25s ease;
}

.footer-socials a:hover {
    transform: translateY(-3px);
    background: rgba(255,255,255,0.11);
    border-color: rgba(255,255,255,0.18);
    color: #ffffff;
}

.footer-copyright {
    margin: 0;
    color: rgba(255,255,255,0.46);
    font-size: 15px;
    line-height: 1.8;
}

.footer-copyright a {
    color: #ffffff;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.26);
    transition: all 0.22s ease;
}

.footer-copyright a:hover {
    border-color: rgba(255,255,255,0.8);
}

.footer-separator {
    display: inline-block;
    margin: 0 10px;
    color: rgba(255,255,255,0.24);
}

/* Responsive */

@media (max-width: 1199px) {
    .footer-logo {
        max-width: 300px;
    }

    .footer-contact-link {
        font-size: 22px;
    }
}

@media (max-width: 991px) {
    .flexy-footer-2026 {
        padding: 72px 0 28px;
    }

    .flexy-footer-top {
        padding-bottom: 34px;
    }

    .footer-brand-block {
        max-width: 100%;
    }

    .footer-logo {
        max-width: 280px;
    }

    .footer-brand-text {
        max-width: 100%;
    }

    .footer-contact-link {
        font-size: 20px;
    }

    .footer-copyright {
        text-align: left;
    }
}

@media (max-width: 767px) {
    .flexy-footer-2026 {
        padding: 56px 0 24px;
    }

    .footer-cta-row {
        flex-direction: column;
    }

    .footer-btn {
        width: 100%;
    }

    .footer-contact-link {
        font-size: 18px;
    }

    .footer-copyright {
        font-size: 14px;
        line-height: 1.7;
    }

    .footer-separator {
        display: none;
    }
}



.mattress-product-section {
    padding: 80px 32px;
    background: #f5f3ef;
    color: #1d1d1d;
}

.mattress-product-section .container-fluid {
    max-width: 1580px;
}

.mattress-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    font-size: 13px;
    line-height: 1.5;
    color: rgba(29, 29, 29, 0.55);
    margin-bottom: 34px;
    letter-spacing: 0.01em;
}

.mattress-breadcrumb a {
    color: rgba(29, 29, 29, 0.55);
    text-decoration: none;
    transition: color 0.25s ease;
}

.mattress-breadcrumb a:hover {
    color: #1d1d1d;
}

.mattress-breadcrumb .current {
    color: #1d1d1d;
    font-weight: 600;
}

/* LEFT */
.mattress-media-card {
    position: sticky;
    top: 120px;
}

.mattress-media-main {
    background: #ffffff;
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(16, 24, 40, 0.08);
    border: 1px solid rgba(20, 20, 20, 0.06);
}

.mattress-media-main img {
    width: 100%;
    display: block;
}

.mattress-feature-icons {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 18px;
}

.feature-icon-chip {
    width: 72px;
    height: 72px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(20, 20, 20, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
    box-shadow: 0 10px 30px rgba(16, 24, 40, 0.05);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.feature-icon-chip:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(16, 24, 40, 0.08);
    border-color: rgba(20, 20, 20, 0.12);
}

.feature-icon-chip img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* RIGHT PANEL */
.mattress-product-panel {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.mattress-product-intro {
    margin-bottom: 4px;
}

.product-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #7b7468;
    margin-bottom: 16px;
}

.mattress-product-intro h1 {
    font-size: clamp(34px, 4vw, 62px);
    line-height: 1.02;
    letter-spacing: -0.04em;
    font-weight: 700;
    color: #111111;
    margin-bottom: 18px;
}

.product-lead {
    max-width: 720px;
    font-size: 17px;
    line-height: 1.7;
    color: rgba(17, 17, 17, 0.68);
    margin-bottom: 0;
}

/* META */
.mattress-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.meta-card {
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(20, 20, 20, 0.06);
    border-radius: 22px;
    padding: 22px 24px;
    box-shadow: 0 10px 30px rgba(16, 24, 40, 0.04);
}

.meta-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #8c8578;
    margin-bottom: 10px;
}

.meta-card strong {
    font-size: 24px;
    font-weight: 700;
    color: #121212;
}

/* FIRMNESS */
.firmness-card {
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(20, 20, 20, 0.06);
    border-radius: 24px;
    padding: 24px;
    box-shadow: 0 10px 30px rgba(16, 24, 40, 0.04);
}

.section-label {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #8c8578;
    margin-bottom: 20px;
}

.firmness-item + .firmness-item {
    margin-top: 18px;
}

.firmness-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    font-size: 14px;
    color: #222;
    font-weight: 600;
}

.firmness-track {
    position: relative;
    height: 12px;
    width: 100%;
    border-radius: 999px;
    background: rgba(17, 17, 17, 0.08);
    overflow: hidden;
}

.firmness-fill {
    height: 100%;
    border-radius: 999px;
}

.firmness-warm {
    background: linear-gradient(90deg, #d96a4f 0%, #efc4b6 100%);
}

.firmness-cool {
    background: linear-gradient(90deg, #3959b8 0%, #b9c8ef 100%);
}

/* ACCORDION */
.mattress-accordion {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.mattress-accordion .accordion-item {
    border: 1px solid rgba(20, 20, 20, 0.06);
    border-radius: 22px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.76);
    box-shadow: 0 10px 30px rgba(16, 24, 40, 0.04);
}

.mattress-accordion .accordion-button {
    background: transparent;
    color: #131313;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.45;
    padding: 24px 26px;
    box-shadow: none;
    border: 0;
}

.mattress-accordion .accordion-button:not(.collapsed) {
    background: transparent;
    color: #111111;
    box-shadow: none;
}

.mattress-accordion .accordion-button:focus {
    box-shadow: none;
    border: none;
}

.mattress-accordion .accordion-button::after {
    background-size: 16px;
    width: 16px;
    height: 16px;
    opacity: 0.75;
}

.mattress-accordion .accordion-body {
    padding: 0 26px 26px;
}

.mattress-accordion .accordion-body p {
    margin: 0;
    font-size: 15px;
    line-height: 1.85;
    color: rgba(17, 17, 17, 0.68);
}

/* SPECS */
.spec-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.spec-row {
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: 14px;
    align-items: center;
    padding: 14px 0;
    border-bottom: 1px solid rgba(17, 17, 17, 0.08);
}

.spec-row:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.spec-icon {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background: #f6f2eb;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px;
}

.spec-icon img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.spec-text {
    font-size: 15px;
    line-height: 1.7;
    color: rgba(17, 17, 17, 0.72);
}

/* CTA */
.mattress-cta-wrap {
    margin-top: 8px;
}

.mattress-main-cta {
    width: 100%;
    min-height: 62px;
    border-radius: 18px;
    background: #151515;
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 24px;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-decoration: none;
    transition: transform 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
    box-shadow: 0 18px 40px rgba(17, 17, 17, 0.18);
}

.mattress-main-cta:hover {
    color: #ffffff;
    background: #000000;
    transform: translateY(-2px);
}

/* TOOLTIP */
.tooltip-inner {
    max-width: 320px;
    padding: 12px 14px;
    border-radius: 14px;
    font-size: 13px;
    line-height: 1.6;
    background: #111111;
    color: #ffffff;
    text-align: left;
}

/* RESPONSIVE */
@media (max-width: 1199px) {
    .mattress-media-card {
        position: relative;
        top: auto;
    }

    .mattress-product-intro h1 {
        font-size: 42px;
    }
}

@media (max-width: 767px) {
    .mattress-product-section {
        padding: 56px 18px;
    }

    .mattress-breadcrumb {
        margin-bottom: 24px;
        font-size: 12px;
    }

    .mattress-product-intro h1 {
        font-size: 34px;
    }

    .product-lead {
        font-size: 15px;
        line-height: 1.75;
    }

    .mattress-meta-grid {
        grid-template-columns: 1fr;
    }

    .feature-icon-chip {
        width: 64px;
        height: 64px;
        border-radius: 18px;
    }

    .mattress-accordion .accordion-button {
        font-size: 16px;
        padding: 20px;
    }

    .mattress-accordion .accordion-body {
        padding: 0 20px 20px;
    }

    .spec-row {
        grid-template-columns: 48px 1fr;
        gap: 12px;
    }

    .spec-icon {
        width: 48px;
        height: 48px;
        border-radius: 14px;
    }
}



.mattress-product-2026 {
  --bg: #f6f3ee;
  --surface: rgba(255, 255, 255, 0.72);
  --surface-strong: #ffffff;
  --text: #1f1d1a;
  --muted: #6e685f;
  --line: rgba(31, 29, 26, 0.10);
  --accent: #b89d7a;
  --accent-soft: #e5d8c8;
  --shadow: 0 20px 60px rgba(27, 23, 18, 0.08);
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 16px;

  background:
    radial-gradient(circle at top left, rgba(184, 157, 122, 0.10), transparent 35%),
    linear-gradient(180deg, #f8f6f2 0%, #f3efe9 100%);
  padding: 80px 0;
  color: var(--text);
}

.mattress-shell {
  width: min(1380px, calc(100% - 48px));
  margin: 0 auto;
}

.mattress-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--muted);
  margin-bottom: 34px;
}

.mattress-breadcrumb a {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.25s ease;
}

.mattress-breadcrumb a:hover {
  opacity: 0.65;
}

.mattress-breadcrumb .current {
  color: var(--text);
  font-weight: 600;
}

.mattress-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 34px;
  align-items: start;
  margin-bottom: 34px;
}

.mattress-visual-card,
.construction-card,
.feature-card,
.bottom-card {
  background: var(--surface);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.55);
  box-shadow: var(--shadow);
}

.mattress-visual-card {
  position: relative;
  border-radius: var(--radius-xl);
  padding: 34px;
  min-height: 640px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.mattress-label-chip {
  position: absolute;
  top: 22px;
  left: 22px;
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.75);
  border: 1px solid rgba(31, 29, 26, 0.08);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
}

.mattress-main-image {
  max-width: 100%;
  max-height: 560px;
  width: auto;
  height: auto;
  display: block;
  object-fit: contain;
}

.mattress-icon-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.m-icon-pill {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.62);
  border: 1px solid rgba(31,29,26,0.08);
  font-size: 13px;
  color: var(--muted);
}

.mattress-content-col {
  padding: 10px 4px 0 4px;
}

.mattress-kicker,
.section-mini-title {
  display: inline-block;
  margin-bottom: 12px;
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.mattress-title {
  font-size: clamp(42px, 6vw, 72px);
  line-height: 0.96;
  letter-spacing: -0.04em;
  margin: 0 0 20px;
  font-weight: 700;
}

.mattress-intro {
  font-size: 18px;
  line-height: 1.75;
  color: var(--muted);
  max-width: 640px;
  margin-bottom: 28px;
}

.mattress-top-specs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 26px;
}

.spec-card {
  background: rgba(255,255,255,0.62);
  border: 1px solid rgba(31, 29, 26, 0.08);
  border-radius: var(--radius-md);
  padding: 18px 18px 20px;
}

.spec-card .spec-label {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  margin-bottom: 10px;
}

.spec-card strong {
  display: block;
  font-size: 17px;
  line-height: 1.45;
  font-weight: 600;
  color: var(--text);
}

.mattress-dual-scale {
  background: rgba(255,255,255,0.62);
  border: 1px solid rgba(31, 29, 26, 0.08);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-bottom: 26px;
}

.mattress-dual-scale h3 {
  font-size: 20px;
  line-height: 1.2;
  margin: 0 0 18px;
  font-weight: 600;
}

.firmness-item + .firmness-item {
  margin-top: 16px;
}

.firmness-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 9px;
  font-size: 14px;
  color: var(--muted);
}

.firmness-meta strong {
  color: var(--text);
  font-weight: 600;
}

.firmness-bar {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: rgba(31,29,26,0.08);
  overflow: hidden;
  margin-bottom: 8px;
}

.firmness-fill {
  height: 100%;
  border-radius: inherit;
}

.firmness-fill.side-a {
  background: linear-gradient(90deg, #d8c7b2 0%, #b89d7a 100%);
}

.firmness-fill.side-b {
  background: linear-gradient(90deg, #7a7267 0%, #1f1d1a 100%);
}

.firmness-score {
  display: inline-block;
  font-size: 13px;
  color: var(--muted);
}

.mattress-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.m-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 22px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.01em;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease;
}

.m-btn:hover {
  transform: translateY(-2px);
}

.m-btn-dark {
  background: var(--text);
  color: #fff;
  box-shadow: 0 14px 28px rgba(31, 29, 26, 0.14);
}

.m-btn-dark:hover {
  color: #fff;
}

.m-btn-light {
  background: rgba(255,255,255,0.72);
  color: var(--text);
  border: 1px solid rgba(31,29,26,0.10);
}

.mattress-feature-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-bottom: 34px;
}

.feature-card {
  border-radius: var(--radius-lg);
  padding: 26px;
}

.feature-number {
  display: inline-block;
  margin-bottom: 20px;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.feature-card h3 {
  font-size: 22px;
  line-height: 1.15;
  margin: 0 0 14px;
  font-weight: 600;
}

.feature-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
  font-size: 15px;
}

.mattress-story-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 34px;
  align-items: start;
  margin-bottom: 34px;
}

.story-copy {
  padding: 8px 4px;
}

.story-copy h2 {
  font-size: clamp(30px, 4vw, 50px);
  line-height: 1.02;
  letter-spacing: -0.03em;
  margin: 0 0 20px;
  font-weight: 700;
}

.story-copy p {
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.85;
}

.mattress-bullets {
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}

.mattress-bullets li {
  position: relative;
  padding-left: 22px;
  margin-bottom: 12px;
  color: var(--text);
  line-height: 1.7;
}

.mattress-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 11px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
}

.construction-card {
  border-radius: var(--radius-xl);
  padding: 30px;
}

.construction-image {
  display: block;
  width: 100%;
  max-width: 700px;
  margin: 10px auto 28px;
  object-fit: contain;
}

.construction-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.layer-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 16px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.52);
  border: 1px solid rgba(31,29,26,0.06);
}

.layer-index {
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}

.layer-item p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
  font-size: 14px;
}

.mattress-bottom-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.bottom-card {
  border-radius: var(--radius-xl);
  padding: 30px;
}

.bottom-card h3 {
  font-size: 28px;
  line-height: 1.1;
  margin: 0 0 14px;
  font-weight: 600;
}

.bottom-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: 15px;
}

.assurance-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.assurance-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.62);
  border: 1px solid rgba(31,29,26,0.08);
  font-size: 13px;
  color: var(--text);
}

.warranty-card {
  display: flex;
  align-items: center;
  gap: 24px;
}

.warranty-circle {
  width: 132px;
  height: 132px;
  flex: 0 0 132px;
  border-radius: 50%;
  background: linear-gradient(180deg, #c9b39a 0%, #b89d7a 100%);
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 14px 34px rgba(184, 157, 122, 0.24);
}

.warranty-circle strong {
  font-size: 42px;
  line-height: 1;
  font-weight: 700;
}

.warranty-circle span {
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: 8px;
}

.warranty-copy {
  flex: 1;
}

@media (max-width: 1199px) {
  .mattress-hero-grid,
  .mattress-story-grid,
  .mattress-bottom-grid {
    grid-template-columns: 1fr;
  }

  .mattress-feature-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .mattress-visual-card {
    min-height: 560px;
  }
}

@media (max-width: 767px) {
  .mattress-product-2026 {
    padding: 48px 0;
  }

  .mattress-shell {
    width: min(100% - 24px, 1380px);
  }

  .mattress-top-specs,
  .mattress-feature-grid,
  .construction-list {
    grid-template-columns: 1fr;
  }

  .mattress-visual-card,
  .construction-card,
  .bottom-card,
  .feature-card {
    padding: 22px;
  }

  .mattress-visual-card {
    min-height: 420px;
  }

  .mattress-title {
    font-size: 40px;
  }

  .mattress-intro {
    font-size: 16px;
    line-height: 1.7;
  }

  .warranty-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .warranty-circle {
    width: 110px;
    height: 110px;
    flex-basis: 110px;
  }

  .mattress-cta-row {
    flex-direction: column;
  }

  .m-btn {
    width: 100%;
  }
}




:root {
  --n-bg: #f3f1ee;
  --n-surface: #fbfaf8;
  --n-surface-2: #f8f6f3;
  --n-text: #1e1a17;
  --n-muted: #746d66;
  --n-line: #e5e0d9;
  --n-line-2: #ddd6ce;
  --n-accent: #d9c9b4;
  --n-shadow: 0 12px 32px rgba(30, 26, 23, 0.04);
  --n-radius-xl: 30px;
  --n-radius-lg: 24px;
  --n-radius-md: 18px;
  --n-radius-sm: 999px;
  --n-container: 1320px;
}

.natura-page {
  background: var(--n-bg);
  color: var(--n-text);
  padding: 52px 0 84px;
}

.natura-page * {
  box-sizing: border-box;
}

.natura-container {
  width: min(var(--n-container), calc(100% - 48px));
  margin: 0 auto;
}

/* TYPOGRAPHY */
.natura-eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--n-muted);
}

.natura-title-xl,
.natura-title-lg,
.natura-title-md {
  margin: 0;
  color: var(--n-text);
  font-weight: 700;
  letter-spacing: -0.045em;
}

.natura-title-xl {
  font-size: clamp(42px, 4.6vw, 72px);
  line-height: 0.98;
  margin-bottom: 20px;
}

.natura-title-lg {
  font-size: clamp(34px, 3.5vw, 54px);
  line-height: 1.02;
  margin-bottom: 18px;
}

.natura-title-md {
  font-size: clamp(26px, 2.4vw, 36px);
  line-height: 1.08;
  margin-bottom: 16px;
}

.natura-lead {
  margin: 0 0 28px;
  max-width: 620px;
  font-size: 18px;
  line-height: 1.75;
  color: var(--n-muted);
}

.natura-body {
  margin: 0;
  max-width: 620px;
  font-size: 17px;
  line-height: 1.9;
  color: var(--n-muted);
}

/* CARDS */
.natura-card {
  background: var(--n-surface);
  border: 1px solid var(--n-line);
  border-radius: var(--n-radius-xl);
  box-shadow: var(--n-shadow);
}

.natura-card--image {
  overflow: hidden;
}

.natura-card--image img {
  width: 100%;
  height: 100%;
  display: block;
}

.natura-card--panel {
  padding: 34px;
}

/* HERO */
.natura-hero {
  margin-bottom: 34px;
}

.natura-hero__grid {
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  gap: 36px;
  align-items: center;
}

.natura-hero__image {
  padding: 10px;
  aspect-ratio: 1.18 / 1;
}

.natura-hero__image img {
  object-fit: cover;
  border-radius: 22px;
}

.natura-specs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 22px;
}

.natura-spec {
  min-height: 112px;
  padding: 18px 16px;
  background: var(--n-surface);
  border: 1px solid var(--n-line);
  border-radius: var(--n-radius-md);
}

.natura-spec__label {
  display: block;
  margin-bottom: 12px;
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--n-muted);
}

.natura-spec__value {
  display: block;
  font-size: 16px;
  line-height: 1.45;
  font-weight: 600;
  color: var(--n-text);
}

.natura-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.natura-btn {
  min-height: 50px;
  padding: 0 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--n-radius-sm);
  text-decoration: none;
  font-size: 15px;
  font-weight: 600;
  transition: all 0.25s ease;
}

.natura-btn--dark {
  background: #1f1916;
  color: #fff;
}

.natura-btn--dark:hover {
  background: #2a221f;
  color: #fff;
}

.natura-btn--light {
  background: transparent;
  color: var(--n-text);
  border: 1px solid var(--n-line-2);
}

.natura-btn--light:hover {
  background: #f7f4ef;
  color: var(--n-text);
}

/* GALLERY */
.natura-gallery {
  margin-bottom: 56px;
}

.natura-gallery__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 0.78fr;
  gap: 18px;
}

.natura-gallery__item {
  padding: 0;
  aspect-ratio: 1 / 1;
}

.natura-gallery__item img {
  object-fit: cover;
}

.natura-gallery__item--contain {
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.natura-gallery__item--contain img {
  object-fit: contain;
}

/* SECTIONS */
.natura-section {
  margin-bottom: 68px;
}

.natura-section--last {
  margin-bottom: 0;
}

.natura-section__head {
  margin-bottom: 24px;
}

/* SPLIT */
.natura-split {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 36px;
  align-items: center;
}

.natura-split--reverse {
  grid-template-columns: 1.08fr 0.92fr;
}

.natura-copy {
  max-width: 520px;
}

.natura-feature-image {
  padding: 12px;
  aspect-ratio: 1.15 / 0.82;
}

.natura-feature-image img {
  object-fit: cover;
  border-radius: 22px;
}

/* CONSTRUCTION */
.natura-construction {
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  gap: 26px;
  align-items: stretch;
}

.natura-construction__image {
  padding: 18px;
  min-height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.natura-construction__image img {
  object-fit: contain;
  max-width: 100%;
  max-height: 100%;
}

.natura-construction__list {
  display: grid;
  gap: 14px;
}

.natura-layer {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 16px;
  align-items: start;
  padding: 22px 22px 20px;
  background: var(--n-surface);
  border: 1px solid var(--n-line);
  border-radius: 22px;
  box-shadow: var(--n-shadow);
}

.natura-layer__index {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--n-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--n-text);
  margin-top: 4px;
}

.natura-layer__content h3 {
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 1.3;
  font-weight: 600;
  color: var(--n-text);
}

.natura-layer__content p {
  margin: 0;
  font-size: 15px;
  line-height: 1.75;
  color: var(--n-muted);
}

/* DUAL */
.natura-dual {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.natura-feature-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.natura-feature-list li {
  position: relative;
  padding-left: 22px;
  font-size: 16px;
  line-height: 1.8;
  color: var(--n-text);
}

.natura-feature-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #cdb79a;
}

.natura-natural .natura-body {
  max-width: 100%;
}

/* TRUST */
.natura-trust {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: 20px;
  align-items: stretch;
}

.natura-trust__main .natura-body {
  max-width: 100%;
}

.natura-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.natura-chip {
  min-height: 38px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--n-line-2);
  background: #fff;
  font-size: 14px;
  line-height: 1;
  color: var(--n-text);
}

.natura-warranty {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 22px;
  align-items: center;
}

.natura-warranty__badge {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: #d3bea2;
  color: var(--n-text);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.natura-warranty__badge strong {
  font-size: 42px;
  line-height: 1;
  font-weight: 700;
}

.natura-warranty__badge span {
  margin-top: 8px;
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.natura-warranty__content .natura-body {
  max-width: 100%;
}

/* RESPONSIVE */
@media (max-width: 1200px) {
  .natura-hero__grid,
  .natura-split,
  .natura-split--reverse,
  .natura-construction,
  .natura-dual,
  .natura-trust {
    grid-template-columns: 1fr;
  }

  .natura-copy {
    max-width: 100%;
  }
}

@media (max-width: 900px) {
  .natura-container {
    width: min(100% - 24px, var(--n-container));
  }

  .natura-page {
    padding: 28px 0 54px;
  }

  .natura-gallery__grid,
  .natura-specs {
    grid-template-columns: 1fr;
  }

  .natura-warranty {
    grid-template-columns: 1fr;
  }

  .natura-warranty__badge {
    width: 96px;
    height: 96px;
  }

  .natura-title-xl {
    font-size: 42px;
  }

  .natura-title-lg {
    font-size: 32px;
  }

  .natura-title-md {
    font-size: 24px;
  }

  .natura-lead,
  .natura-body,
  .natura-feature-list li,
  .natura-layer__content p {
    font-size: 15px;
  }

  .natura-card--panel {
    padding: 24px;
  }

  .natura-hero__image,
  .natura-feature-image,
  .natura-gallery__item {
    aspect-ratio: auto;
  }

  .natura-construction__image {
    min-height: 300px;
  }
}








:root {
  --fs-bg: #f4f1eb;
  --fs-bg-soft: #efeae2;
  --fs-surface: #fbfaf7;
  --fs-surface-2: #ffffff;
  --fs-border: rgba(72, 57, 45, 0.09);
  --fs-border-strong: rgba(72, 57, 45, 0.14);
  --fs-text: #2f2925;
  --fs-text-soft: #6e655e;
  --fs-text-muted: #978c83;
  --fs-accent: #6b5241;
  --fs-accent-hover: #594436;
  --fs-radius-xl: 36px;
  --fs-radius-lg: 28px;
  --fs-radius-md: 20px;
  --fs-radius-sm: 14px;
  --fs-shadow-soft: 0 20px 60px rgba(50, 40, 34, 0.06);
  --fs-shadow-card: 0 12px 30px rgba(50, 40, 34, 0.04);
  --fs-container: 1380px;
}

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

html {
  scroll-behavior: smooth;
}

body.genesi-page {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--fs-text);
  background: var(--fs-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img {
  max-width: 100%;
  display: block;
}

a {
  text-decoration: none;
}

.fs-container {
  width: min(var(--fs-container), calc(100% - 48px));
  margin-inline: auto;
}

.eyebrow {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fs-text-muted);
  font-weight: 600;
}

.section-head {
  margin-bottom: 40px;
}

.section-head--center {
  text-align: center;
}

.section-head h2 {
  margin: 14px 0 0;
  font-size: clamp(24px, 3vw, 48px);
  line-height: 0.95;
  letter-spacing: -0.045em;
  font-weight: 500;
}

.fs-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 26px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 600;
  transition: all .25s ease;
  white-space: nowrap;
}

.fs-btn--primary {
  background: var(--fs-accent);
  color: #fff;
  border: 1px solid var(--fs-accent);
}

.fs-btn--primary:hover {
  background: var(--fs-accent-hover);
  border-color: var(--fs-accent-hover);
}

.fs-btn--secondary {
  background: transparent;
  color: var(--fs-text);
  border: 1px solid var(--fs-border-strong);
}

.fs-btn--secondary:hover {
  background: #fff;
  border-color: rgba(72, 57, 45, 0.2);
}

/* HERO */
.mattress-hero {
  padding: 42px 0 90px;
}

.mattress-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(420px, 0.95fr);
  gap: 28px;
  align-items: stretch;
}

.mattress-hero__media,
.mattress-hero__content {
  min-width: 0;
}

.mattress-hero__image-wrap {
  height: 100%;
  min-height: 740px;
  background: var(--fs-surface-2);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-xl);
  overflow: hidden;
  box-shadow: var(--fs-shadow-soft);
}

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

.mattress-hero__content {
  background: rgba(255,255,255,0.72);
  backdrop-filter: blur(10px);
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius-xl);
  padding: 42px;
  box-shadow: var(--fs-shadow-soft);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.mattress-hero__content h1 {
  margin: 14px 0 18px;
  font-size: clamp(32px, 4vw, 66px);
  line-height: 0.94;
  letter-spacing: -0.055em;
  font-weight: 500;
}

.mattress-hero__content .lead {
  margin: 0 0 28px;
  font-size: 19px;
  line-height: 1.65;
  color: var(--fs-text-soft);
  max-width: 58ch;
}

.hero-spec-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}

.hero-spec-card {
  background: var(--fs-surface);
  border: 1px solid var(--fs-border);
  border-radius: 22px;
  padding: 20px 20px 18px;
}

.hero-spec-card span {
  display: block;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fs-text-muted);
  margin-bottom: 8px;
  font-weight: 600;
}

.hero-spec-card strong {
  display: block;
  font-size: 20px;
  line-height: 1.25;
  font-weight: 600;
  color: var(--fs-text);
}

.hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 28px;
}

.hero-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 16px;
  border: 1px solid var(--fs-border);
  border-radius: 999px;
  background: rgba(255,255,255,0.85);
  font-size: 13px;
  color: var(--fs-text-soft);
  font-weight: 500;
}

.hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 22px;
}

.hero-note {
  padding-top: 22px;
  border-top: 1px solid var(--fs-border);
  color: var(--fs-text-muted);
  font-size: 14px;
  line-height: 1.7;
}

/* FEATURES */
.mattress-features {
  padding: 28px 0 100px;
}

.feature-grid {
  display: grid;
  gap: 22px;
}

.feature-grid--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.feature-card {
  background: rgba(255,255,255,0.76);
  border: 1px solid var(--fs-border);
  border-radius: 28px;
  padding: 32px 28px;
  box-shadow: var(--fs-shadow-card);
}

.feature-card h3 {
  margin: 0 0 14px;
  font-size: 32px;
  line-height: 1.02;
  letter-spacing: -0.05em;
  font-weight: 500;
}

.feature-card p {
  margin: 0;
  color: var(--fs-text-soft);
  line-height: 1.75;
  font-size: 16px;
}

/* STORY */
.mattress-story {
  padding: 10px 0 110px;
}

.story-split {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 34px;
  align-items: center;
}

.story-copy {
  padding-right: 24px;
}

.story-copy h2 {
  margin: 14px 0 22px;
  font-size: clamp(28px, 3.4vw, 54px);
  line-height: 0.96;
  letter-spacing: -0.055em;
  font-weight: 500;
}

.story-copy p {
  margin: 0 0 18px;
  color: var(--fs-text-soft);
  font-size: 18px;
  line-height: 1.85;
}

.story-image-wrap {
  background: var(--fs-surface-2);
  border: 1px solid var(--fs-border);
  border-radius: 34px;
  overflow: hidden;
  box-shadow: var(--fs-shadow-soft);
  min-height: 680px;
}

.story-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* TECHNICAL */
.mattress-technical {
  padding: 10px 0 110px;
}

.technical-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(320px, 0.78fr);
  gap: 32px;
  align-items: start;
}

.technical-main {
  display: grid;
  gap: 22px;
}

.technical-block {
  background: rgba(255,255,255,0.76);
  border: 1px solid var(--fs-border);
  border-radius: 28px;
  padding: 30px 30px 26px;
  box-shadow: var(--fs-shadow-card);
}

.technical-block h3 {
  margin: 0 0 14px;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: -0.04em;
  font-weight: 500;
}

.technical-block p {
  margin: 0 0 12px;
  color: var(--fs-text-soft);
  font-size: 16px;
  line-height: 1.8;
}

.technical-block p:last-child {
  margin-bottom: 0;
}

.data-panel {
  position: sticky;
  top: 24px;
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(8px);
  border: 1px solid var(--fs-border);
  border-radius: 30px;
  padding: 16px;
  box-shadow: var(--fs-shadow-soft);
}

.data-item {
  padding: 18px 16px;
  border-bottom: 1px solid var(--fs-border);
}

.data-item:last-child {
  border-bottom: 0;
}

.data-item span {
  display: block;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fs-text-muted);
  margin-bottom: 8px;
  font-weight: 600;
}

.data-item strong {
  display: block;
  font-size: 18px;
  color: var(--fs-text);
  line-height: 1.45;
  font-weight: 600;
}

/* CONSTRUCTION */
.mattress-construction {
  padding: 0 0 110px;
}

.construction-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  gap: 32px;
  align-items: stretch;
}

.construction-image-wrap {
  height: 100%;
  min-height: 720px;
  background: var(--fs-surface-2);
  border: 1px solid var(--fs-border);
  border-radius: 34px;
  overflow: hidden;
  box-shadow: var(--fs-shadow-soft);
}

.construction-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.construction-copy {
  background: rgba(255,255,255,0.78);
  border: 1px solid var(--fs-border);
  border-radius: 34px;
  padding: 38px;
  box-shadow: var(--fs-shadow-soft);
}

.construction-copy h2 {
  margin: 14px 0 24px;
  font-size: clamp(24px, 3vw, 42px);
  line-height: 0.97;
  letter-spacing: -0.05em;
  font-weight: 500;
}

.construction-list {
  display: grid;
  gap: 18px;
}

.construction-item {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid var(--fs-border);
}

.construction-item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.construction-index {
  display: inline-flex;
  width: 48px;
  height: 48px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--fs-bg-soft);
  border: 1px solid var(--fs-border);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--fs-text-soft);
}

.construction-item h3 {
  margin: 0 0 8px;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -0.03em;
  font-weight: 500;
}

.construction-item p {
  margin: 0;
  color: var(--fs-text-soft);
  line-height: 1.8;
  font-size: 16px;
}

/* IDEAL */
.mattress-ideal {
  padding: 0 0 110px;
}

.ideal-box {
  background: rgba(255,255,255,0.76);
  border: 1px solid var(--fs-border);
  border-radius: 38px;
  padding: 38px;
  box-shadow: var(--fs-shadow-soft);
}

.ideal-head {
  margin-bottom: 28px;
}

.ideal-head h2 {
  margin: 14px 0 0;
  font-size: clamp(24px, 3vw, 42px);
  line-height: 0.98;
  letter-spacing: -0.05em;
  font-weight: 500;
}

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

.ideal-card {
  background: var(--fs-surface);
  border: 1px solid var(--fs-border);
  border-radius: 24px;
  padding: 26px 24px;
}

.ideal-card h3 {
  margin: 0 0 12px;
  font-size: 24px;
  line-height: 1.08;
  letter-spacing: -0.04em;
  font-weight: 500;
}

.ideal-card p {
  margin: 0;
  color: var(--fs-text-soft);
  line-height: 1.75;
  font-size: 15px;
}

/* GALLERY */
.mattress-gallery {
  padding: 0 0 110px;
}

.gallery-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
  gap: 28px;
}

.gallery-card {
  border-radius: 32px;
  overflow: hidden;
  border: 1px solid var(--fs-border);
  box-shadow: var(--fs-shadow-soft);
  min-width: 0;
}

.gallery-card--large {
  background: var(--fs-surface-2);
  min-height: 620px;
}

.gallery-card--large img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gallery-card--text {
  background: rgba(255,255,255,0.78);
  display: flex;
  align-items: center;
}

.gallery-copy {
  padding: 40px;
}

.gallery-copy h3 {
  margin: 14px 0 18px;
  font-size: clamp(22px, 3vw, 38px);
  line-height: 0.98;
  letter-spacing: -0.05em;
  font-weight: 500;
}

.gallery-copy p {
  margin: 0;
  color: var(--fs-text-soft);
  line-height: 1.85;
  font-size: 17px;
}

/* CTA */
.mattress-cta {
  padding: 0 0 120px;
}

.cta-box {
  background: rgba(255,255,255,0.82);
  border: 1px solid var(--fs-border);
  border-radius: 42px;
  padding: 42px 36px;
  box-shadow: var(--fs-shadow-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.cta-copy {
  max-width: 760px;
}

.cta-copy h2 {
  margin: 14px 0 18px;
  font-size: clamp(26px, 3vw, 48px);
  line-height: 0.95;
  letter-spacing: -0.055em;
  font-weight: 500;
}

.cta-copy p {
  margin: 0;
  color: var(--fs-text-soft);
  font-size: 18px;
  line-height: 1.8;
}

.cta-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* RESPONSIVE */
@media (max-width: 1399px) {
  .feature-grid--4,
  .ideal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1199px) {
  .mattress-hero__grid,
  .story-split,
  .technical-grid,
  .construction-grid,
  .gallery-grid,
  .cta-box {
    grid-template-columns: 1fr;
    display: grid;
  }

  .cta-box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .mattress-hero__image-wrap,
  .story-image-wrap,
  .construction-image-wrap,
  .gallery-card--large {
    min-height: 560px;
  }

  .technical-side {
    order: -1;
  }

  .data-panel {
    position: static;
  }
}

@media (max-width: 991px) {
  .fs-container {
    width: min(var(--fs-container), calc(100% - 32px));
  }

  .mattress-hero {
    padding: 24px 0 72px;
  }

  .mattress-hero__content,
  .construction-copy,
  .ideal-box,
  .cta-box {
    padding: 28px;
  }

  .hero-spec-grid,
  .feature-grid--4,
  .ideal-grid {
    grid-template-columns: 1fr 1fr;
  }

  .mattress-hero__image-wrap,
  .story-image-wrap,
  .construction-image-wrap,
  .gallery-card--large {
    min-height: 460px;
  }
}

@media (max-width: 767px) {
  .mattress-hero__content h1,
  .section-head h2,
  .story-copy h2,
  .construction-copy h2,
  .ideal-head h2,
  .gallery-copy h3,
  .cta-copy h2 {
    line-height: 1.02;
  }

  .hero-spec-grid,
  .feature-grid--4,
  .ideal-grid,
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .mattress-hero__content {
    padding: 24px;
  }

  .feature-card,
  .technical-block,
  .ideal-card,
  .gallery-copy {
    padding: 22px;
  }

  .cta-box {
    padding: 28px 24px;
  }

  .mattress-hero__image-wrap,
  .story-image-wrap,
  .construction-image-wrap,
  .gallery-card--large {
    min-height: 360px;
  }

  .hero-cta,
  .cta-actions {
    width: 100%;
  }

  .hero-cta .fs-btn,
  .cta-actions .fs-btn {
    flex: 1 1 100%;
  }

  .construction-item {
    grid-template-columns: 1fr;
  }
}


/* HERO OFFSET — desktop only */
@media (min-width: 1024px) {
  .mattress-hero {
    padding-top: 150px;
  }
}

/* HERO STACK LAYOUT */

@media (min-width: 1024px) {

  .mattress-hero__grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .mattress-hero__media {
    order: 1;
  }

  .mattress-hero__content {
    order: 2;
    max-width: 1400px;
  }

  .mattress-hero__image-wrap {
    min-height: 640px;
    border-radius: 32px;
  }

}


/* PRICING SECTION */
.mattress-pricing {
  padding: 80px 0 120px;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  max-width: 800px;
  margin: 0 auto 40px;
}

.price-card {
  background: rgba(255,255,255,0.78);
  border: 1px solid var(--fs-border);
  border-radius: 28px;
  padding: 32px 28px;
  text-align: center;
  box-shadow: var(--fs-shadow-card);
}

.price-size {
  display: block;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fs-text-muted);
  margin-bottom: 18px;
  font-weight: 600;
}

.price-values {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}

.price-old {
  font-size: 16px;
  color: var(--fs-text-muted);
  text-decoration: line-through;
}

.price-new {
  font-size: 34px;
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--fs-text);
}

.price-note {
  font-size: 13px;
  color: var(--fs-text-soft);
}

.pricing-cta {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* MOBILE */
@media (max-width: 767px) {
  .pricing-grid {
    grid-template-columns: 1fr;
  }

  .price-new {
    font-size: 28px;
  }

  .pricing-cta .fs-btn {
    width: 100%;
  }
}
.price-card:first-child {
  transform: scale(1.03);
  border-color: rgba(72,57,45,0.2);
}


.mattress-certifications {
  padding: 60px 0 90px;
  text-align: center;
}

.certifications-head h3 {
  margin: 12px 0 28px;
  font-size: 22px;
  letter-spacing: -0.02em;
  font-weight: 500;
}

.certifications-logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 26px;
  opacity: 0.75;
}

.certifications-logos img {
  height: 46px;
  width: auto;
  filter: grayscale(100%);
  opacity: 0.7;
  transition: all 0.3s ease;
}

.certifications-logos img:hover {
  filter: grayscale(0%);
  opacity: 1;
  transform: scale(1.05);
}


.certifications-logos img {
  height: 64px; /* από 46 → 64 */
  width: auto;
  filter: grayscale(100%);
  opacity: 0.75;
  transition: all 0.3s ease;
}

.certifications-logos img {
  height: 72px;
  width: auto;
  filter: grayscale(100%);
  opacity: 0.75;
  transition: all 0.35s ease;
}

.certifications-logos img:hover {
  filter: grayscale(0%);
  opacity: 1;
  transform: translateY(-4px) scale(1.08);
}
/* CONSTRUCTION — WIDE LANDSCAPE VERSION */
.mattress-construction {
  padding: 0 0 110px;
}

.construction--wide .construction-head {
  max-width: 920px;
  margin: 0 0 34px;
}

.construction--wide .construction-head h2 {
  margin: 14px 0 18px;
  font-size: clamp(24px, 3vw, 42px);
  line-height: 0.97;
  letter-spacing: -0.05em;
  font-weight: 500;
}

.construction--wide .construction-head p {
  margin: 0;
  color: var(--fs-text-soft);
  font-size: 16px;
  line-height: 1.85;
  max-width: 70ch;
}

.construction-media--wide {
  margin-bottom: 34px;
}

.construction-image-wrap--landscape {
  background: var(--fs-surface-2);
  border: 1px solid var(--fs-border);
  border-radius: 34px;
  overflow: hidden;
  box-shadow: var(--fs-shadow-soft);
}

.construction-image-wrap--landscape img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.construction-copy--wide {
  width: 100%;
}

.construction-list--grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.construction-item--card {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  align-items: start;
  background: rgba(255,255,255,0.78);
  border: 1px solid var(--fs-border);
  border-radius: 28px;
  padding: 26px 24px;
  box-shadow: var(--fs-shadow-card);
}

.construction-index {
  display: inline-flex;
  width: 46px;
  height: 46px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--fs-bg-soft);
  border: 1px solid var(--fs-border);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--fs-text-soft);
  flex-shrink: 0;
}

.construction-item__content h3 {
  margin: 0 0 8px;
  font-size: 20px;
  line-height: 1.12;
  letter-spacing: -0.03em;
  font-weight: 500;
  color: var(--fs-text);
}

.construction-item__content p {
  margin: 0;
  color: var(--fs-text-soft);
  line-height: 1.8;
  font-size: 15px;
}

/* RESPONSIVE */
@media (max-width: 991px) {
  .construction--wide .construction-head p {
    font-size: 15px;
  }

  .construction-list--grid {
    grid-template-columns: 1fr;
  }

  .construction-item--card {
    padding: 22px 20px;
  }
}

@media (max-width: 767px) {
  .construction-image-wrap--landscape {
    border-radius: 24px;
  }

  .construction-item--card {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .construction-index {
    width: 42px;
    height: 42px;
  }

  .construction-item__content h3 {
    font-size: 18px;
  }

  .construction-item__content p {
    font-size: 14px;
  }
}

.story-image-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--fs-surface-2);
  border-radius: 34px;
  overflow: hidden;
  padding: 20px;
}

.story-image-wrap img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.story-image-wrap {
  padding: 40px;
  background: linear-gradient(180deg, #ffffff, #f5f1eb);
}


.mattress-hero__content h1 {
  font-size: clamp(28px, 3.2vw, 44px);
}
h1 {
  font-size: clamp(24px, 2.8vw, 38px);
}

h2 {
  font-size: clamp(18px, 2.2vw, 26px);
}

.construction-grid {
  grid-template-columns: 1fr;
}

.construction-image-wrap {
  min-height: 480px;
}

.construction-copy {
  max-width: 900px;
  margin: 0 auto;
  margin-top: -80px;
  position: relative;
  z-index: 2;
}

.mattress-hero__image-wrap img {
  transform: scale(1.02);
}


.telaro-product-page--clean {
    background: #f4f1eb;
    padding-bottom: 80px;
}

.telaro-shell {
    max-width: 1520px;
    margin: 0 auto;
    padding-left: 24px;
    padding-right: 24px;
}

.telaro-breadcrumbs {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 26px;
    font-size: 14px;
    color: #8a8178;
}

.telaro-breadcrumbs a {
    color: #8a8178;
    text-decoration: none;
    transition: color .25s ease;
}

.telaro-breadcrumbs a:hover {
    color: #2a241f;
}

.telaro-breadcrumbs .current {
    color: #2a241f;
    font-weight: 500;
}

.telaro-hero-row {
    --bs-gutter-x: 30px;
}

.telaro-gallery-card,
.telaro-summary-card {
    background: #fbfaf7;
    border: 1px solid #ece6de;
}

.telaro-gallery-card {
    padding: 14px;
}

.telaro-gallery-card--single {
    height: 100%;
}

.telaro-main-image {
    background: #f8f5ef;
    border-radius: 24px;
    overflow: hidden;
}

.telaro-main-image img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.telaro-summary-card {
    padding: 34px 34px 30px;
    min-height: 100%;
}

.telaro-label {
    display: inline-block;
    margin-bottom: 16px;
    font-size: 11px;
    line-height: 1;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: #8c8378;
    font-weight: 600;
}

.telaro-title {
    margin: 0 0 18px;
    font-size: 62px;
    line-height: 0.95;
    font-weight: 600;
    letter-spacing: -2px;
    color: #211d1a;
}

.telaro-subtitle {
    margin: 0 0 28px;
    font-size: 17px;
    line-height: 1.9;
    color: #7a7268;
    max-width: 95%;
}

.telaro-quick-specs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 22px;
}

.telaro-spec-box {
    background: #fcfbf8;
    border: 1px solid #ece6de;
    border-radius: 18px;
    padding: 18px 16px;
    min-height: 96px;
}

.telaro-spec-box span {
    display: block;
    margin-bottom: 12px;
    font-size: 11px;
    line-height: 1;
    letter-spacing: 1.6px;
    text-transform: uppercase;
    color: #b0a79d;
    font-weight: 600;
}

.telaro-spec-box strong {
    display: block;
    font-size: 16px;
    line-height: 1.5;
    font-weight: 500;
    color: #2a241f;
}

.telaro-feature-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 28px;
}

.telaro-feature-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 16px;
    border: 1px solid #ece6de;
    border-radius: 999px;
    background: #fcfbf8;
    font-size: 14px;
    color: #6d655c;
}

.telaro-cta-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 18px;
}

.telaro-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 26px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 500;
    text-decoration: none;
    transition: all .28s ease;
}

.telaro-btn-dark {
    background: #5a4337;
    color: #fff;
    border: 1px solid #5a4337;
}

.telaro-btn-dark:hover {
    background: #463329;
    border-color: #463329;
    color: #fff;
}

.telaro-btn-light {
    background: transparent;
    color: #433b34;
    border: 1px solid #ddd4ca;
}

.telaro-btn-light:hover {
    background: #f5efe8;
    color: #433b34;
}

.telaro-note {
    margin: 0;
    font-size: 14px;
    line-height: 1.7;
    color: #8a8178;
}

@media (max-width: 1399px) {
    .telaro-title {
        font-size: 54px;
    }
}

@media (max-width: 1199px) {
    .telaro-title {
        font-size: 48px;
    }

    .telaro-summary-card {
        padding: 28px 28px 24px;
    }
}

@media (max-width: 991px) {
    .telaro-hero-row > div + div {
        margin-top: 24px;
    }

    .telaro-title {
        font-size: 44px;
    }

    .telaro-subtitle {
        max-width: 100%;
    }
}

@media (max-width: 767px) {
    .telaro-shell {
        padding-left: 16px;
        padding-right: 16px;
    }

    .telaro-breadcrumbs {
        margin-bottom: 20px;
        font-size: 13px;
        gap: 8px;
    }

    .telaro-gallery-card {
        padding: 10px;
    }

    .telaro-main-image {
        border-radius: 18px;
    }

    .telaro-summary-card {
        padding: 22px 18px 20px;
    }

    .telaro-title {
        font-size: 38px;
        line-height: 1;
        margin-bottom: 16px;
    }

    .telaro-subtitle {
        font-size: 15px;
        line-height: 1.8;
        margin-bottom: 22px;
    }

    .telaro-quick-specs {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .telaro-spec-box {
        min-height: auto;
    }

    .telaro-feature-tags {
        gap: 8px;
        margin-bottom: 22px;
    }

    .telaro-feature-tags span {
        font-size: 13px;
        min-height: 36px;
        padding: 0 14px;
    }

    .telaro-cta-row {
        flex-direction: column;
        align-items: stretch;
    }

    .telaro-btn {
        width: 100%;
    }
}



.butterfly-features-section {
    padding: 70px 60px;
}

.butterfly-features-intro {
    max-width: 420px;
}

.butterfly-feature-card {
    height: 100%;
    display: flex;
    align-items: flex-start;
    gap: 22px;
    padding: 28px;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 20px;
    transition: all 0.3s ease;
}

.butterfly-feature-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(0,0,0,0.08);
}

.butterfly-feature-card__icon {
    flex: 0 0 72px;
    width: 72px;
}

.butterfly-feature-card__icon img {
    width: 100%;
    height: auto;
    display: block;
}

.butterfly-feature-card__content span {
    display: inline-block;
    margin-bottom: 8px;
    font-size: 13px;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #8a8a8a;
    font-weight: 600;
}

.butterfly-feature-card__content h4 {
    margin: 0 0 10px;
    font-size: 22px;
    line-height: 1.2;
    color: #1d1d1d;
    font-weight: 600;
}

.butterfly-feature-card__content p {
    margin: 0;
    font-size: 15px;
    line-height: 1.75;
    color: #5f5f5f;
}

@media (max-width: 991px) {
    .butterfly-features-section {
        padding: 45px 25px;
    }

    .butterfly-features-intro {
        max-width: 100%;
    }
}

@media (max-width: 575px) {
    .butterfly-feature-card {
        padding: 22px;
        gap: 16px;
    }

    .butterfly-feature-card__icon {
        flex: 0 0 58px;
        width: 58px;
    }

    .butterfly-feature-card__content h4 {
        font-size: 19px;
    }
}



.butterfly-offer-box {
    padding: 70px 60px;
}

.butterfly-offer-content {
    max-width: 760px;
}

.butterfly-offer-title {
    margin: 0 0 18px;
    font-size: clamp(30px, 3vw, 48px);
    line-height: 1.12;
    font-weight: 600;
    color: #1d1d1d;
    letter-spacing: -0.03em;
}

.butterfly-offer-text {
    margin: 0;
    max-width: 620px;
    font-size: 17px;
    line-height: 1.85;
    color: #5f5f5f;
}

.butterfly-offer-points {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.butterfly-offer-points span {
    display: inline-flex;
    align-items: center;
    padding: 12px 18px;
    border-radius: 999px;
    background: #f5f5f5;
    color: #1d1d1d;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
}

.butterfly-price-card {
    max-width: 420px;
    margin-left: auto;
    padding: 34px;
    background: #ffffff;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 26px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.06);
}

.butterfly-price-card__label {
    display: inline-block;
    margin-bottom: 18px;
    font-size: 13px;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #8a8a8a;
    font-weight: 600;
}

.butterfly-price-card__prices {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 14px;
}

.butterfly-price-card__old {
    font-size: 26px;
    line-height: 1;
    color: #9a9a9a;
    text-decoration: line-through;
}

.butterfly-price-card__new {
    font-size: 52px;
    line-height: 1;
    font-weight: 700;
    color: #1d1d1d;
    letter-spacing: -0.04em;
}

.butterfly-price-card__note {
    margin: 0;
    font-size: 14px;
    line-height: 1.7;
    color: #777;
}

.butterfly-price-card__actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 26px;
}

@media (max-width: 991px) {
    .butterfly-offer-box {
        padding: 45px 25px;
    }

    .butterfly-price-card {
        max-width: 100%;
        margin-left: 0;
    }

    .butterfly-offer-title {
        font-size: 32px;
    }

    .butterfly-offer-text {
        font-size: 16px;
    }
}

@media (max-width: 575px) {
    .butterfly-price-card {
        padding: 24px;
        border-radius: 20px;
    }

    .butterfly-price-card__new {
        font-size: 42px;
    }

    .butterfly-offer-points span {
        width: 100%;
        justify-content: center;
    }
}
.butterfly-feature-card__icon-text {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f3f3f3;
    color: #1d1d1d;
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
}



.mattress-hero.v3 .mattress-hero__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.mattress-hero.v3 .mattress-hero__media.v3 {
    order: 1;
}

.mattress-hero.v3 .mattress-hero__card.v3 {
    order: 2;
}

.hero-image-square {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: 24px;
}

.hero-image-square img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mattress-hero__card.v3 {
    background: #f6f4f1;
    padding: 40px;
    border-radius: 24px;
}

.hero-spec-grid.v3 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin: 28px 0 22px;
}

.hero-spec-card {
    background: #ebe7e2;
    padding: 18px;
    border-radius: 14px;
}

.hero-spec-card span {
    display: block;
    font-size: 12px;
    opacity: 0.6;
    margin-bottom: 8px;
}

.hero-spec-card strong {
    font-size: 16px;
}

.hero-tags.v3 {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 24px;
}

.hero-tags.v3 span {
    background: #ebe7e2;
    padding: 7px 14px;
    border-radius: 999px;
    font-size: 13px;
}

.hero-cta.v3 {
    display: flex;
    gap: 14px;
    margin-bottom: 18px;
}

.hero-note.v3 {
    font-size: 13px;
    opacity: 0.6;
    padding-top: 18px;
    border-top: 1px solid rgba(0,0,0,0.08);
}

@media (max-width: 992px) {
    .mattress-hero.v3 .mattress-hero__grid {
        grid-template-columns: 1fr;
    }

    .mattress-hero.v3 .mattress-hero__media.v3,
    .mattress-hero.v3 .mattress-hero__card.v3 {
        order: initial;
    }
}

.hero-image-square {
    aspect-ratio: 1 / 1;
    height: auto;
    max-height: none;
}

.mattress-hero__card.v3 {
    padding: 48px;
    border-radius: 28px;
}

.mattress-hero__card.v3 h1 {
    font-size: 3.2rem;
    line-height: 1.05;
    margin: 14px 0 22px;
}

.mattress-hero__card.v3 .lead {
    font-size: 1.15rem;
    line-height: 1.7;
    margin-bottom: 28px;
}

.hero-spec-card {
    background: #efebe6;
    border: 1px solid rgba(0,0,0,0.05);
}
.hero-note.v3 {
    opacity: 0.78;
    font-size: 13px;
}

.fs-btn--secondary {
    border: 1px solid rgba(0,0,0,0.14);
}


.mattress-feel.v2 {
    padding: 110px 0;
    background: linear-gradient(180deg, #f7f4ef 0%, #fff 100%);
}

.mattress-feel.v2 .mattress-feel__grid {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    gap: 64px;
    align-items: start;
}

.mattress-feel.v2 .mattress-feel__intro {
    max-width: 440px;
    position: sticky;
    top: 120px;
}

.mattress-feel.v2 .eyebrow {
    display: inline-block;
    margin-bottom: 16px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #8f7f6f;
}

.mattress-feel.v2 h2 {
    margin: 0 0 18px;
    font-size: clamp(2rem, 3vw, 3.4rem);
    line-height: 1.02;
    letter-spacing: -0.03em;
    color: #1f1a17;
}

.mattress-feel.v2 .mattress-feel__lead {
    margin: 0;
    font-size: 17px;
    line-height: 1.8;
    color: rgba(31, 26, 23, 0.72);
}

.mattress-feel.v2 .mattress-feel__panel {
    background: rgba(255, 255, 255, 0.66);
    border: 1px solid rgba(31, 26, 23, 0.06);
    border-radius: 28px;
    padding: 18px 30px;
    box-shadow: 0 20px 60px rgba(44, 34, 24, 0.06);
    backdrop-filter: blur(8px);
}

.mattress-feel.v2 .feel-row {
    display: grid;
    grid-template-columns: 145px 1fr;
    gap: 28px;
    padding: 26px 0;
    border-bottom: 1px solid rgba(31, 26, 23, 0.08);
}

.mattress-feel.v2 .feel-row:last-child {
    border-bottom: none;
}

.mattress-feel.v2 .feel-row__label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #9a8877;
    padding-top: 6px;
}

.mattress-feel.v2 .feel-row__content strong {
    display: block;
    margin-bottom: 10px;
    font-size: 24px;
    line-height: 1.15;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: #201a16;
}

.mattress-feel.v2 .feel-row__content p {
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
    color: rgba(32, 26, 22, 0.72);
    max-width: 560px;
}

@media (max-width: 1199px) {
    .mattress-feel.v2 .mattress-feel__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .mattress-feel.v2 .mattress-feel__intro {
        max-width: none;
        position: static;
    }
}

@media (max-width: 767px) {
    .mattress-feel.v2 {
        padding: 80px 0;
    }

    .mattress-feel.v2 .mattress-feel__panel {
        padding: 10px 22px;
        border-radius: 22px;
    }

    .mattress-feel.v2 .feel-row {
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 22px 0;
    }

    .mattress-feel.v2 .feel-row__label {
        padding-top: 0;
    }

    .mattress-feel.v2 .feel-row__content strong {
        font-size: 21px;
    }

    .mattress-feel.v2 .feel-row__content p {
        font-size: 15px;
        line-height: 1.7;
    }
}
.certifications-logos {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 18px;
    max-width: 700px;
    margin: 0 auto;
}

/* 🔥 ΤΕΤΡΑΓΩΝΟ */
.cert-item {
    position: relative;
    aspect-ratio: 1 / 1; /* ΚΛΕΙΔΙ */

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

    background: #fff;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 14px;

    cursor: pointer;
    transition: 0.25s ease;
}

/* image scaling */
.cert-item img {
    max-width: 60%;
    max-height: 60%;
    object-fit: contain;
}

/* hover */
.cert-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(0,0,0,0.08);
}

/* tooltip */
.cert-tooltip {
    position: absolute;
    bottom: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%) translateY(10px);

    background: #1f1a17;
    color: #fff;
    font-size: 13px;
    line-height: 1.4;

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

    white-space: nowrap;

    opacity: 0;
    pointer-events: none;
    transition: 0.25s ease;
}

.cert-item:hover .cert-tooltip {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.certifications-logos {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 🔥 4 σε κάθε σειρά */
    gap: 18px;
    max-width: 520px; /* κρατάει tight το section */
    margin: 0 auto;
}

/* τετράγωνα */
.cert-item {
    position: relative;
    aspect-ratio: 1 / 1;

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

    background: #fff;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 14px;

    cursor: pointer;
    transition: 0.25s ease;
}

/* icon */
.cert-item img {
    max-width: 58%;
    max-height: 58%;
    object-fit: contain;
}

/* hover */
.cert-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(0,0,0,0.08);
}

/* tooltip */
.cert-tooltip {
    position: absolute;
    bottom: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%) translateY(10px);

    background: #1f1a17;
    color: #fff;
    font-size: 13px;
    line-height: 1.4;

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

    white-space: nowrap;

    opacity: 0;
    pointer-events: none;
    transition: 0.25s ease;
}

.cert-item:hover .cert-tooltip {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}



.mattress-hero.v4 {
    padding: 48px 0 90px;
}

.mattress-hero.v4 .mattress-hero__grid.v4 {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 56px;
    align-items: stretch;
}

/* κλειδώνει τη σειρά */
.mattress-hero.v4 .mattress-hero__media.v4 {
    order: 1;
    display: flex;
    align-items: stretch;
}

.mattress-hero.v4 .mattress-hero__card.v4 {
    order: 2;
    background: #f5f2ee;
    border-radius: 28px;
    padding: 44px 48px;
    display: flex;
    flex-direction: column;
    justify-content: center; /* 🔥 για να μη δείχνει κολλημένο πάνω */
    min-height: 100%;
}

/* image */
.mattress-hero.v4 .mattress-hero__image-wrap.v4 {
    width: 100%;
    height: 100%;
    border-radius: 28px;
    overflow: hidden;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

/* typography */
.mattress-hero.v4 h1 {
    margin: 12px 0 20px;
    font-size: clamp(2rem, 3vw, 3.4rem);
    line-height: 1.02;
    letter-spacing: -0.04em;
}

.mattress-hero.v4 .lead {
    margin-bottom: 26px;
    font-size: 1.1rem;
    line-height: 1.7;
    color: rgba(31, 26, 23, 0.72);
}

.mattress-hero.v4 .hero-spec-grid.v4 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 0 0 22px;
}

.mattress-hero.v4 .hero-spec-card {
    background: #ede8e2;
    border: 1px solid rgba(0,0,0,0.05);
    border-radius: 16px;
    padding: 18px 18px 16px;
}

.mattress-hero.v4 .hero-spec-card span {
    display: block;
    margin-bottom: 8px;
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    opacity: 0.55;
}

.mattress-hero.v4 .hero-spec-card strong {
    font-size: 17px;
    font-weight: 600;
}

.mattress-hero.v4 .hero-tags.v4 {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 22px;
}

.mattress-hero.v4 .hero-tags.v4 span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    background: #ede8e2;
    border: 1px solid rgba(0,0,0,0.05);
    font-size: 14px;
}

.mattress-hero.v4 .hero-cta.v4 {
    display: flex;
    gap: 14px;
    margin-bottom: 18px;
}

.mattress-hero.v4 .hero-note.v4 {
    margin-top: 8px;
    padding-top: 18px;
    border-top: 1px solid rgba(0,0,0,0.08);
    font-size: 13px;
    opacity: 0.7;
}

@media (max-width: 991px) {
    .mattress-hero.v4 .mattress-hero__grid.v4 {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .mattress-hero.v4 .mattress-hero__media.v4 {
        order: 1;
    }

    .mattress-hero.v4 .mattress-hero__card.v4 {
        order: 2;
        padding: 32px;
        justify-content: flex-start;
    }

    .mattress-hero.v4 .mattress-hero__image-wrap.v4 {
        aspect-ratio: 1 / 1;
    }

    .mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
        height: 100%;
    }
}

.mattress-hero.v4 .mattress-hero__grid.v4 {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 56px;
    align-items: center; /* από stretch -> center */
}

.mattress-hero.v4 .mattress-hero__media.v4 {
    order: 1;
    display: flex;
    align-items: center; /* από stretch -> center */
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 {
    width: 100%;
    aspect-ratio: 1 / 1; /* κρατάει το block controlled */
    border-radius: 28px;
    overflow: hidden;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

.mattress-hero.v4 .mattress-hero__card.v4 {
    order: 2;
    background: #f5f2ee;
    border-radius: 28px;
    padding: 44px 48px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}
.mattress-hero.v4 {
    padding-top: 140px; /* 🔥 αυτό ζητάς */
}
.mattress-hero.v4 .mattress-hero__card.v4 {
    padding: 36px 40px;
}

.mattress-hero.v4 h1 {
    margin: 10px 0 16px;
}

.mattress-hero.v4 .lead {
    margin-bottom: 20px;
    line-height: 1.55;
}

.mattress-hero.v4 .hero-spec-grid.v4 {
    gap: 12px;
    margin: 0 0 16px;
}

.mattress-hero.v4 .hero-spec-card {
    padding: 14px 16px 13px;
    border-radius: 14px;
}

.mattress-hero.v4 .hero-spec-card span {
    margin-bottom: 6px;
    font-size: 11px;
}

.mattress-hero.v4 .hero-spec-card strong {
    font-size: 15px;
}

.mattress-hero.v4 .hero-tags.v4 {
    gap: 8px;
    margin-bottom: 16px;
}

.mattress-hero.v4 .hero-tags.v4 span {
    min-height: 36px;
    padding: 0 13px;
    font-size: 13px;
}

.mattress-hero.v4 .hero-cta.v4 {
    gap: 10px;
    margin-bottom: 14px;
}

.mattress-hero.v4 .hero-note.v4 {
    margin-top: 4px;
    padding-top: 14px;
    font-size: 12px;
}


@media (max-width: 767px) {

    .mattress-hero.v4 {
        padding: 28px 0 48px !important;
    }

    .mattress-hero.v4 .mattress-hero__grid.v4 {
        display: grid;
        grid-template-columns: 1fr !important;
        gap: 22px !important;
        align-items: start !important;
    }

    .mattress-hero.v4 .mattress-hero__media.v4 {
        order: 1;
        display: block;
    }

    .mattress-hero.v4 .mattress-hero__card.v4 {
        order: 2;
        width: 100%;
        min-width: 0;
        padding: 24px 20px !important;
        border-radius: 22px;
    }

    .mattress-hero.v4 .mattress-hero__image-wrap.v4 {
        width: 100%;
        aspect-ratio: 1 / 1;
        border-radius: 22px;
        overflow: hidden;
    }

    .mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center center;
        display: block;
    }

    .mattress-hero.v4 .eyebrow {
        display: block;
        margin-bottom: 10px;
        font-size: 11px;
        letter-spacing: 0.14em;
        line-height: 1.4;
    }

    .mattress-hero.v4 h1 {
        margin: 0 0 14px !important;
        font-size: 42px !important;
        line-height: 0.98 !important;
        letter-spacing: -0.04em;
        word-break: break-word;
    }

    .mattress-hero.v4 .lead {
        margin-bottom: 18px !important;
        font-size: 16px !important;
        line-height: 1.55 !important;
    }

    .mattress-hero.v4 .hero-spec-grid.v4 {
        grid-template-columns: 1fr 1fr;
        gap: 10px !important;
        margin: 0 0 14px !important;
    }

    .mattress-hero.v4 .hero-spec-card {
        padding: 12px 12px 11px !important;
        border-radius: 14px;
        min-width: 0;
    }

    .mattress-hero.v4 .hero-spec-card span {
        margin-bottom: 5px;
        font-size: 10px !important;
        letter-spacing: 0.12em;
        line-height: 1.3;
    }

    .mattress-hero.v4 .hero-spec-card strong {
        font-size: 14px !important;
        line-height: 1.3;
        word-break: break-word;
    }

    .mattress-hero.v4 .hero-tags.v4 {
        gap: 8px !important;
        margin-bottom: 16px !important;
    }

    .mattress-hero.v4 .hero-tags.v4 span {
        min-height: 34px;
        padding: 0 12px;
        font-size: 12px !important;
        line-height: 1;
    }

    .mattress-hero.v4 .hero-cta.v4 {
        display: flex;
        flex-direction: column;
        gap: 10px !important;
        margin-bottom: 16px !important;
    }

    .mattress-hero.v4 .hero-cta.v4 .fs-btn {
        width: 100%;
        justify-content: center;
        text-align: center;
    }

    .mattress-hero.v4 .hero-note.v4 {
        margin-top: 0 !important;
        padding-top: 14px !important;
        font-size: 12px !important;
        line-height: 1.5;
    }
}


/* FORCE override */
.mattress-feel .mattress-feel__panel .feel-row__label {
    font-size: 18px !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(45, 40, 36, 0.65);
}

/* ensure layout σωστό */
.mattress-feel .mattress-feel__panel .feel-row {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 24px;
}

/* mobile */
@media (max-width: 767px) {
    .mattress-feel .mattress-feel__panel .feel-row__label {
        font-size: 14px !important;
    }

    .mattress-feel .mattress-feel__panel .feel-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }
}


.firmness {
    margin-top: 6px;
}

.firmness-bar {
    width: 100%;
    height: 6px;
    background: #e6e0d9;
    border-radius: 10px;
    overflow: hidden;
}

.firmness-fill {
    height: 100%;
    background: #6f5a4b;
    border-radius: 10px;
    transition: width 0.4s ease;
}

.firmness small {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    color: #8a8178;
}

/* =========================
   FEEL SECTION v3
========================= */

.mattress-feel.v3 {
    padding: 120px 0;
}

.mattress-feel__grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 80px;
    align-items: start;
}

/* LEFT */

.mattress-feel__intro .eyebrow {
    display: block;
    margin-bottom: 16px;
    font-size: 12px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #9c8f84;
}

.mattress-feel__intro h2 {
    margin-bottom: 20px;
    font-size: clamp(32px, 3vw, 48px);
    line-height: 1.2;
    color: #2b2623;
}

.mattress-feel__lead {
    max-width: 420px;
    font-size: 16px;
    line-height: 1.7;
    color: #6f6761;
}

/* RIGHT ACCORDION */

.mattress-feel__accordion {
    display: flex;
    flex-direction: column;
    gap: 18px;
    max-width: 560px;
}

/* ITEM */

.feel-acc-item {
    overflow: hidden;
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.65);
    backdrop-filter: blur(6px);
    transition: all 0.3s ease;
}

.feel-acc-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.06);
}

.feel-acc-item.active {
    background: #ffffff;
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.06);
}

/* TRIGGER */

.feel-acc-trigger {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    padding: 26px 64px 26px 30px;
    background: none;
    border: none;
    text-align: left;
    cursor: pointer;
}

/* LABEL */

.feel-label {
    font-size: 11px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #9c8f84;
}

/* TITLE */

.feel-title {
    font-size: 18px;
    font-weight: 500;
    line-height: 1.35;
    color: #2b2623;
}

/* CONTENT */

.feel-acc-content {
    max-height: 0;
    overflow: hidden;
    padding: 0 30px;
    transition: max-height 0.35s ease, padding 0.35s ease;
}

.feel-acc-content p {
    margin: 0;
    padding-bottom: 22px;
    font-size: 15px;
    line-height: 1.7;
    color: #6f6761;
}

/* ACTIVE */

.feel-acc-item.active .feel-acc-content {
    max-height: 220px;
}

/* ARROW */

.feel-arrow {
    position: absolute;
    right: 28px;
    top: 26px;
    width: 10px;
    height: 10px;
    border-right: 2px solid #9c8f84;
    border-bottom: 2px solid #9c8f84;
    transform: rotate(45deg);
    transition: all 0.3s ease;
}

.feel-acc-trigger:hover .feel-arrow {
    border-color: #2b2623;
}

.feel-acc-item.active .feel-arrow {
    transform: rotate(-135deg);
}

/* =========================
   TABLET
========================= */

@media (max-width: 992px) {
    .mattress-feel.v3 {
        padding: 80px 0;
    }

    .mattress-feel__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .mattress-feel__accordion {
        max-width: 100%;
    }
}

/* =========================
   MOBILE
========================= */

@media (max-width: 767px) {
    .mattress-feel__intro h2 {
        font-size: 34px;
    }

    .mattress-feel__lead {
        max-width: 100%;
        font-size: 15px;
    }

    .feel-acc-trigger {
        padding: 20px 52px 20px 18px;
    }

    .feel-acc-content {
        padding: 0 18px;
    }

    .feel-acc-content p {
        padding-bottom: 18px;
        font-size: 14px;
    }

    .feel-title {
        font-size: 17px;
    }

    .feel-arrow {
        right: 18px;
        top: 22px;
    }
}


/* =========================
   COMBINE SECTION v2
========================= */

.mattress-combine.v2 {
    padding: 120px 0;
}

.mattress-combine.v2 .section-sub {
    max-width: 760px;
    margin: 18px auto 0;
}

/* LAYOUT */
.combine-layout {
    display: grid;
    grid-template-columns: 1.35fr 1fr;
    gap: 28px;
    align-items: stretch;
    margin-top: 56px;
}

/* MAIN CARD */
.combine-main {
    position: relative;
    display: block;
    min-height: 540px;
    border-radius: 22px;
    overflow: hidden;
    text-decoration: none;
    background: #e8e2db;
    box-shadow: 0 18px 50px rgba(22, 16, 12, 0.08);
}

.combine-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}

.combine-main__overlay {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 34px 34px 30px;
    background: linear-gradient(to top, rgba(24, 18, 14, 0.72), rgba(24, 18, 14, 0.06));
    color: #fff;
}

.combine-main:hover img {
    transform: scale(1.035);
}

/* RIGHT SIDE */
.combine-side {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.combine-card {
    display: grid;
    grid-template-columns: 220px 1fr;
    align-items: stretch;
    min-height: 259px;
    border-radius: 20px;
    overflow: hidden;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(43, 38, 35, 0.06);
    box-shadow: 0 14px 40px rgba(22, 16, 12, 0.06);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.combine-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 50px rgba(22, 16, 12, 0.1);
}

.combine-card__image {
    background: #efe8e1;
}

.combine-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* CONTENT */
.combine-card__content {
    padding: 30px 28px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.combine-kicker {
    display: inline-block;
    margin-bottom: 10px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #a08e7e;
}

.combine-main__overlay .combine-kicker {
    color: rgba(255, 255, 255, 0.75);
}

.combine-main h3,
.combine-card h3 {
    margin: 0 0 12px;
    font-size: clamp(24px, 2vw, 38px);
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: inherit;
}

.combine-card h3 {
    font-size: 28px;
    color: #2b2623;
}

.combine-main p,
.combine-card p {
    margin: 0 0 18px;
    font-size: 16px;
    line-height: 1.7;
    color: inherit;
    opacity: 0.95;
}

.combine-card p {
    color: #6f6761;
}

.combine-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: inherit;
    letter-spacing: -0.01em;
}

.combine-link::after {
    content: "→";
    font-size: 15px;
    line-height: 1;
    transition: transform 0.25s ease;
}

.combine-main:hover .combine-link::after,
.combine-card:hover .combine-link::after {
    transform: translateX(4px);
}

/* TABLET */
@media (max-width: 1199px) {
    .combine-layout {
        grid-template-columns: 1fr;
    }

    .combine-main {
        min-height: 460px;
    }
}

/* MOBILE */
@media (max-width: 767px) {
    .mattress-combine.v2 {
        padding: 80px 0;
    }

    .combine-layout {
        gap: 20px;
        margin-top: 40px;
    }

    .combine-main {
        min-height: 380px;
        border-radius: 18px;
    }

    .combine-main__overlay {
        padding: 24px 22px 22px;
    }

    .combine-card {
        grid-template-columns: 1fr;
        min-height: auto;
        border-radius: 18px;
    }

    .combine-card__image {
        aspect-ratio: 4 / 3;
    }

    .combine-card__content {
        padding: 22px 20px;
    }

    .combine-main h3 {
        font-size: 30px;
    }

    .combine-card h3 {
        font-size: 24px;
    }

    .combine-main p,
    .combine-card p {
        font-size: 15px;
        line-height: 1.65;
    }
}

.mattress-category-section {
    padding: 20px 0 90px;
}

.mattress-category-card {
    height: 100%;
    background: #ffffff;
    border-radius: 30px;
    overflow: hidden;
    box-shadow: 0 14px 45px rgba(16, 24, 40, 0.08);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}

.mattress-category-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 60px rgba(16, 24, 40, 0.14);
}

.mattress-category-card__image-link {
    display: block;
    text-decoration: none;
}

.mattress-category-card__image-wrap {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1.18 / 1;
    background: #ececec;
}

.mattress-category-card__image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.7s ease, filter 0.7s ease;
}

.mattress-category-card:hover .mattress-category-card__image-wrap img {
    transform: scale(1.045);
    filter: saturate(1.03) contrast(1.02);
}

.mattress-category-card__content {
    padding: 28px 32px 34px;
    text-align: center;
}

.mattress-category-card__eyebrow {
    display: inline-block;
    margin-bottom: 10px;
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #9b8b7a;
}

.mattress-category-card__title {
    margin: 0 0 12px;
    font-size: 34px;
    line-height: 1.05;
    font-weight: 600;
    letter-spacing: -1px;
}

.mattress-category-card__title a {
    color: #1f1f1f;
    text-decoration: none;
    transition: color 0.3s ease;
}

.mattress-category-card__title a:hover {
    color: #7f6a57;
}

.mattress-category-card__text {
    max-width: 430px;
    margin: 0 auto;
    font-size: 16px;
    line-height: 1.75;
    color: #6e6e6e;
}

@media (max-width: 1199px) {
    .mattress-category-card__title {
        font-size: 30px;
    }
}

@media (max-width: 991px) {
    .mattress-category-section {
        padding: 10px 0 70px;
    }

    .mattress-category-card__content {
        padding: 24px 24px 28px;
    }

    .mattress-category-card__title {
        font-size: 28px;
    }

    .mattress-category-card__text {
        font-size: 15px;
        line-height: 1.65;
    }
}

@media (max-width: 575px) {
    .mattress-category-card {
        border-radius: 24px;
    }

    .mattress-category-card__image-wrap {
        border-radius: 24px 24px 0 0;
    }

    .mattress-category-card__content {
        padding: 22px 18px 24px;
    }

    .mattress-category-card__eyebrow {
        font-size: 10px;
        letter-spacing: 1.8px;
    }

    .mattress-category-card__title {
        font-size: 24px;
    }

    .mattress-category-card__text {
        font-size: 14px;
        line-height: 1.6;
    }
}


/* =========================================
   HOTEL PAGE V2 / FLEXYSTROM / 2026 REFINED
========================================= */

.hotel-page-v2 {
    --v2-bg: #f5f3ef;
    --v2-surface: #fcfbf8;
    --v2-surface-2: #f0ece6;
    --v2-card: rgba(255, 255, 255, 0.78);
    --v2-text: #2b2926;
    --v2-text-soft: #6b6660;
    --v2-line: rgba(43, 41, 38, 0.09);
    --v2-line-strong: rgba(43, 41, 38, 0.16);
    --v2-accent: #b29673;
    --v2-accent-soft: rgba(178, 150, 115, 0.14);
    --v2-dark: #171512;
    --v2-radius-xl: 34px;
    --v2-radius-lg: 26px;
    --v2-radius-md: 20px;
    --v2-radius-sm: 14px;
    --v2-shadow-soft: 0 14px 40px rgba(18, 16, 13, 0.05);
    --v2-shadow-card: 0 24px 70px rgba(18, 16, 13, 0.06);
    --v2-shadow-deep: 0 30px 80px rgba(8, 8, 8, 0.16);
    --v2-transition: all 0.35s ease;
}

.hotel-page-v2 section {
    position: relative;
}

.hotel-v2-intro,
.hotel-v2-solutions,
.hotel-v2-quality,
.hotel-v2-use-cases,
.hotel-v2-cta {
    padding: 110px 0;
}

.hotel-v2-intro-box {
    background: linear-gradient(180deg, #faf8f4 0%, #f3efe8 100%);
    border: 1px solid var(--v2-line);
    border-radius: var(--v2-radius-xl);
    padding: 60px 64px;
    box-shadow: var(--v2-shadow-soft);
    overflow: hidden;
    position: relative;
}

.hotel-v2-intro-box::after {
    content: "";
    position: absolute;
    top: -120px;
    right: -120px;
    width: 280px;
    height: 280px;
    background: radial-gradient(circle, rgba(178, 150, 115, 0.18) 0%, rgba(178, 150, 115, 0) 70%);
    pointer-events: none;
}

.hotel-v2-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--v2-accent);
    margin-bottom: 20px;
}

.hotel-v2-kicker::before {
    content: "";
    width: 28px;
    height: 1px;
    background: currentColor;
    opacity: 0.9;
}

.hotel-v2-kicker.center {
    justify-content: center;
}

.hotel-v2-kicker-light {
    color: rgba(255, 255, 255, 0.76);
}

.hotel-v2-title {
    margin: 0;
    color: var(--v2-text);
    font-weight: 600;
    letter-spacing: -0.045em;
    line-height: 1.02;
    font-size: clamp(2rem, 3vw, 3.5rem);
}

.hotel-v2-title-intro {
    max-width: 720px;
}

.hotel-v2-title-wide {
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.hotel-v2-side-text,
.hotel-v2-description,
.hotel-v2-card p,
.hotel-v2-quality-content p,
.hotel-v2-quality-item p,
.hotel-v2-use-box p,
.hotel-v2-cta-text {
    font-size: 1rem;
    line-height: 1.9;
    color: var(--v2-text-soft);
}

.hotel-v2-heading {
    max-width: 980px;
    margin: 0 auto 56px;
}

.hotel-v2-description {
    max-width: 760px;
    margin: 20px auto 0;
}

.hotel-v2-solutions {
    padding-top: 95px;
    background:
        radial-gradient(circle at top left, rgba(178, 150, 115, 0.08), transparent 30%),
        linear-gradient(180deg, #f7f4ef 0%, #f5f2ed 100%);
}

.hotel-v2-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    background: var(--v2-card);
    backdrop-filter: blur(8px);
    border: 1px solid var(--v2-line);
    border-radius: var(--v2-radius-lg);
    padding: 30px 28px 28px;
    box-shadow: var(--v2-shadow-card);
    transition: var(--v2-transition);
    position: relative;
    overflow: hidden;
}

.hotel-v2-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0) 40%);
    pointer-events: none;
}

.hotel-v2-card:hover {
    transform: translateY(-8px);
    border-color: rgba(178, 150, 115, 0.28);
    box-shadow: 0 28px 80px rgba(18, 16, 13, 0.10);
}

.hotel-v2-card-featured {
    background: linear-gradient(180deg, #ffffff 0%, #f5efe8 100%);
    border-color: rgba(178, 150, 115, 0.22);
}

.hotel-v2-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 24px;
}

.hotel-v2-card-index {
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(43, 41, 38, 0.55);
}

.hotel-v2-badge {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 8px 12px;
    border-radius: 999px;
    background: var(--v2-accent-soft);
    color: var(--v2-text);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.hotel-v2-card h3 {
    font-size: 1.55rem;
    line-height: 1.14;
    letter-spacing: -0.03em;
    font-weight: 600;
    color: var(--v2-text);
    margin-bottom: 18px;
    min-height: 72px;
}

.hotel-v2-card p {
    margin-bottom: 24px;
}

.hotel-v2-card-list {
    display: grid;
    gap: 0;
    margin-bottom: 28px;
    border-top: 1px solid var(--v2-line);
}

.hotel-v2-card-list span {
    position: relative;
    display: block;
    padding: 15px 0 15px 18px;
    font-size: 0.97rem;
    color: var(--v2-text);
    border-bottom: 1px solid var(--v2-line);
    line-height: 1.65;
}

.hotel-v2-card-list span::before {
    content: "";
    position: absolute;
    left: 0;
    top: 24px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--v2-accent);
}

.hotel-v2-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: auto;
    font-size: 0.96rem;
    font-weight: 700;
    color: var(--v2-text);
    text-decoration: none;
    transition: var(--v2-transition);
}

.hotel-v2-link::after {
    content: "→";
    transition: transform 0.3s ease;
}

.hotel-v2-link:hover {
    color: var(--v2-accent);
}

.hotel-v2-link:hover::after {
    transform: translateX(4px);
}

.hotel-v2-quality {
    background: #f7f5f1;
}

.hotel-v2-quality-content {
    max-width: 620px;
}

.hotel-v2-quality-content p + p {
    margin-top: 14px;
}

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

.hotel-v2-quality-item {
    background: #ffffff;
    border: 1px solid var(--v2-line);
    border-radius: var(--v2-radius-md);
    padding: 24px 22px;
    box-shadow: var(--v2-shadow-soft);
    min-height: 190px;
}

.hotel-v2-quality-item strong {
    display: block;
    font-size: 1rem;
    font-weight: 700;
    color: var(--v2-text);
    margin-bottom: 12px;
}

.hotel-v2-quality-item p {
    margin: 0;
    font-size: 0.96rem;
    line-height: 1.8;
}

.hotel-v2-quality-image-item {
    padding: 0;
    overflow: hidden;
}

.hotel-v2-quality-image-item img {
    width: 100%;
    height: 100%;
    min-height: 190px;
    object-fit: cover;
    display: block;
    transition: transform 0.8s ease;
}

.hotel-v2-quality-image-item:hover img {
    transform: scale(1.03);
}

.hotel-v2-use-cases {
    padding-top: 70px;
}

.hotel-v2-use-box {
    height: 100%;
    background: linear-gradient(180deg, #f8f5f0 0%, #f1ece5 100%);
    border: 1px solid var(--v2-line);
    border-radius: var(--v2-radius-md);
    padding: 28px 24px;
    box-shadow: var(--v2-shadow-soft);
}

.hotel-v2-use-box h4 {
    font-size: 1.22rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--v2-text);
    margin-bottom: 12px;
}

.hotel-v2-use-box p {
    margin: 0;
}

.hotel-v2-cta {
    padding-top: 90px;
}

.hotel-v2-cta-box {
    background:
        radial-gradient(circle at top right, rgba(178, 150, 115, 0.24), transparent 26%),
        linear-gradient(180deg, #1d1a16 0%, #11100e 100%);
    border-radius: 36px;
    padding: 52px 54px;
    box-shadow: var(--v2-shadow-deep);
    overflow: hidden;
    position: relative;
}

.hotel-v2-cta-title {
    margin: 0 0 16px;
    color: #ffffff;
    font-weight: 600;
    letter-spacing: -0.045em;
    line-height: 1.04;
    font-size: clamp(1.95rem, 2.8vw, 3.1rem);
    max-width: 760px;
}

.hotel-v2-cta-text {
    color: rgba(255, 255, 255, 0.76);
    max-width: 760px;
    margin: 0;
}

.hotel-v2-cta-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 60px;
    padding: 16px 28px;
    border-radius: 999px;
    background: #ffffff;
    color: var(--v2-dark);
    text-decoration: none;
    font-weight: 700;
    font-size: 0.96rem;
    box-shadow: 0 10px 28px rgba(255,255,255,0.10);
    transition: var(--v2-transition);
}

.hotel-v2-cta-button:hover {
    color: var(--v2-dark);
    transform: translateY(-2px);
    box-shadow: 0 14px 36px rgba(255,255,255,0.16);
}

/* responsive */

@media (max-width: 1199px) {
    .hotel-v2-intro,
    .hotel-v2-solutions,
    .hotel-v2-quality,
    .hotel-v2-use-cases,
    .hotel-v2-cta {
        padding: 90px 0;
    }

    .hotel-v2-intro-box,
    .hotel-v2-cta-box {
        padding: 46px 44px;
    }
}

@media (max-width: 991px) {
    .hotel-v2-intro,
    .hotel-v2-solutions,
    .hotel-v2-quality,
    .hotel-v2-use-cases,
    .hotel-v2-cta {
        padding: 72px 0;
    }

    .hotel-v2-intro-box,
    .hotel-v2-cta-box {
        padding: 34px 28px;
        border-radius: 24px;
    }

    .hotel-v2-quality-grid {
        grid-template-columns: 1fr;
    }

    .hotel-v2-card h3 {
        min-height: auto;
    }
}

@media (max-width: 767px) {
    .hotel-v2-intro,
    .hotel-v2-solutions,
    .hotel-v2-quality,
    .hotel-v2-use-cases,
    .hotel-v2-cta {
        padding: 58px 0;
    }

    .hotel-v2-intro-box,
    .hotel-v2-card,
    .hotel-v2-quality-item,
    .hotel-v2-use-box,
    .hotel-v2-cta-box {
        border-radius: 20px;
    }

    .hotel-v2-intro-box,
    .hotel-v2-card,
    .hotel-v2-quality-item,
    .hotel-v2-use-box,
    .hotel-v2-cta-box {
        padding-left: 22px;
        padding-right: 22px;
    }

    .hotel-v2-title,
    .hotel-v2-cta-title {
        line-height: 1.08;
    }

    .hotel-v2-side-text,
    .hotel-v2-description,
    .hotel-v2-card p,
    .hotel-v2-quality-content p,
    .hotel-v2-quality-item p,
    .hotel-v2-use-box p,
    .hotel-v2-cta-text {
        font-size: 0.97rem;
        line-height: 1.8;
    }

    .hotel-v2-card-top {
        flex-wrap: wrap;
    }
}

.hotel-v2-quality-clean {
    background: #f7f5f1;
}

.hotel-v2-quality-points {
    list-style: none;
    padding: 0;
    margin: 30px 0 0;
    border-top: 1px solid var(--v2-line);
    max-width: 620px;
}

.hotel-v2-quality-points li {
    position: relative;
    padding: 18px 0 18px 20px;
    border-bottom: 1px solid var(--v2-line);
    color: var(--v2-text);
    font-size: 0.98rem;
    line-height: 1.7;
}

.hotel-v2-quality-points li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 28px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--v2-accent);
}

.hotel-v2-quality-visual {
    position: relative;
    overflow: hidden;
    border-radius: var(--v2-radius-lg);
    box-shadow: var(--v2-shadow-card);
    min-height: 100%;
}

.hotel-v2-quality-visual img {
    width: 100%;
    height: 100%;
    min-height: 520px;
    object-fit: cover;
    display: block;
    transition: transform 0.8s ease;
}

.hotel-v2-quality-visual:hover img {
    transform: scale(1.03);
}

/* tighter rhythm for cards */
.hotel-v2-card-list span {
    padding: 18px 0 18px 18px;
}

.hotel-v2-link {
    margin-top: 10px;
    font-weight: 800;
}

@media (max-width: 991px) {
    .hotel-v2-quality-visual img {
        min-height: 420px;
    }
}

@media (max-width: 767px) {
    .hotel-v2-quality-visual img {
        min-height: 320px;
    }

    .hotel-v2-quality-points li {
        padding: 16px 0 16px 18px;
    }
}


/* ===========================
   FLEXYSTROM FABRICS 2026
   IMAGE TOP / TEXT BOTTOM
=========================== */

.flexy-materials-section {
    position: relative;
    padding: 120px 0;
    background:
        radial-gradient(circle at top, rgba(255,255,255,0.96) 0%, rgba(246,243,238,1) 50%, rgba(241,237,231,1) 100%);
}

.flexy-materials-heading {
    max-width: 920px;
    margin: 0 auto 60px;
}

.flexy-materials-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 46px;
    height: 46px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(120, 101, 79, 0.08);
    border: 1px solid rgba(120, 101, 79, 0.10);
    color: #7a634c;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.6px;
    margin-bottom: 18px;
}

.flexy-materials-heading h2 {
    margin: 0 0 16px;
    font-size: 62px;
    line-height: 1;
    font-weight: 600;
    letter-spacing: -2.5px;
    color: #1c1815;
}

.flexy-materials-heading p {
    margin: 0 auto;
    max-width: 760px;
    font-size: 17px;
    line-height: 1.85;
    color: #6f665d;
}

.flexy-fabric-card {
    height: 100%;
    border-radius: 30px;
    overflow: hidden;
    background: rgba(255,255,255,0.78);
    border: 1px solid rgba(84, 66, 48, 0.08);
    box-shadow:
        0 12px 35px rgba(28, 22, 18, 0.05),
        inset 0 1px 0 rgba(255,255,255,0.78);
    backdrop-filter: blur(12px);
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.flexy-fabric-card:hover {
    transform: translateY(-6px);
    box-shadow:
        0 22px 50px rgba(28, 22, 18, 0.08),
        inset 0 1px 0 rgba(255,255,255,0.85);
    border-color: rgba(120, 101, 79, 0.16);
}

.flexy-fabric-card__image {
    position: relative;
    aspect-ratio: 1 / 0.72;
    overflow: hidden;
    background: #ebe5dd;
}

.flexy-fabric-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .6s ease;
}

.flexy-fabric-card:hover .flexy-fabric-card__image img {
    transform: scale(1.03);
}

.flexy-fabric-card__body {
    padding: 24px 24px 26px;
}

.flexy-toggle-card {
    margin: 0;
    border: 0;
}

.flexy-toggle-card .togglet {
    position: relative;
    margin: 0;
    padding: 0 44px 0 0;
    cursor: pointer;
}

.flexy-toggle-card .togglet:before,
.flexy-toggle-card .togglet:after {
    content: "";
    position: absolute;
    right: 0;
    top: 24px;
    width: 16px;
    height: 2px;
    border-radius: 999px;
    background: #8b735b;
    transition: transform .28s ease, opacity .28s ease, background .28s ease;
}

.flexy-toggle-card .togglet:after {
    transform: rotate(90deg);
}

.flexy-toggle-card.toggle-active .togglet:after {
    opacity: 0;
    transform: rotate(0deg);
}

.flexy-toggle-card.toggle-active .togglet:before {
    background: #6e5743;
}

.flexy-toggle-head {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 50px;
}

.flexy-toggle-icon {
    width: 50px;
    height: 50px;
    flex: 0 0 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: linear-gradient(180deg, #f8f4ef 0%, #ede4d7 100%);
    border: 1px solid rgba(120, 101, 79, 0.10);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.92),
        0 6px 18px rgba(34, 25, 18, 0.05);
}

.flexy-toggle-icon img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
}

.flexy-toggle-title {
    display: block;
    font-size: 29px;
    line-height: 1.1;
    font-weight: 600;
    letter-spacing: -0.9px;
    color: #1d1916;
    transition: color .25s ease;
}

.flexy-toggle-card .togglet:hover .flexy-toggle-title {
    color: #7a634c;
}

.flexy-toggle-card .togglec {
    margin-top: 18px;
    padding: 20px 22px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(248,244,239,0.95) 0%, rgba(241,235,227,0.92) 100%);
    border: 1px solid rgba(120, 101, 79, 0.08);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.72);
    font-size: 15px;
    line-height: 1.9;
    color: #5f564d;
}

/* responsive */
@media (max-width: 1399px) {
    .flexy-materials-heading h2 {
        font-size: 56px;
    }

    .flexy-toggle-title {
        font-size: 26px;
    }
}

@media (max-width: 991px) {
    .flexy-materials-section {
        padding: 90px 0;
    }

    .flexy-materials-heading {
        margin-bottom: 44px;
    }

    .flexy-materials-heading h2 {
        font-size: 44px;
        letter-spacing: -1.4px;
    }

    .flexy-toggle-title {
        font-size: 24px;
    }
}

@media (max-width: 767px) {
    .flexy-materials-section {
        padding: 72px 0;
    }

    .flexy-materials-heading h2 {
        font-size: 36px;
    }

    .flexy-materials-heading p {
        font-size: 15px;
        line-height: 1.75;
    }

    .flexy-fabric-card {
        border-radius: 24px;
    }

    .flexy-fabric-card__body {
        padding: 18px 18px 20px;
    }

    .flexy-toggle-head {
        gap: 12px;
    }

    .flexy-toggle-icon {
        width: 46px;
        height: 46px;
        flex-basis: 46px;
        border-radius: 14px;
    }

    .flexy-toggle-icon img {
        width: 24px;
        height: 24px;
    }

    .flexy-toggle-title {
        font-size: 22px;
    }

    .flexy-toggle-card .togglet {
        padding-right: 34px;
    }

    .flexy-toggle-card .togglet:before,
    .flexy-toggle-card .togglet:after {
        top: 22px;
    }

    .flexy-toggle-card .togglec {
        margin-top: 14px;
        padding: 16px;
        border-radius: 16px;
        font-size: 14px;
        line-height: 1.8;
    }
}


/* ===========================
   FLEXYSTROM FABRICS 2026
   IMAGE TOP / TEXT BOTTOM
=========================== */

.flexy-materials-section {
    position: relative;
    padding: 120px 0;
    background:
        radial-gradient(circle at top, rgba(255,255,255,0.96) 0%, rgba(246,243,238,1) 50%, rgba(241,237,231,1) 100%);
}

.flexy-materials-heading {
    max-width: 920px;
    margin: 0 auto 60px;
}

.flexy-materials-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 46px;
    height: 46px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(120, 101, 79, 0.08);
    border: 1px solid rgba(120, 101, 79, 0.10);
    color: #7a634c;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.6px;
    margin-bottom: 18px;
}

.flexy-materials-heading h2 {
    margin: 0 0 16px;
    font-size: 62px;
    line-height: 1;
    font-weight: 600;
    letter-spacing: -2.5px;
    color: #1c1815;
}

.flexy-materials-heading p {
    margin: 0 auto;
    max-width: 760px;
    font-size: 17px;
    line-height: 1.85;
    color: #6f665d;
}

.flexy-fabric-card {
    height: 100%;
    border-radius: 30px;
    overflow: hidden;
    background: rgba(255,255,255,0.78);
    border: 1px solid rgba(84, 66, 48, 0.08);
    box-shadow:
        0 12px 35px rgba(28, 22, 18, 0.05),
        inset 0 1px 0 rgba(255,255,255,0.78);
    backdrop-filter: blur(12px);
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.flexy-fabric-card:hover {
    transform: translateY(-6px);
    box-shadow:
        0 22px 50px rgba(28, 22, 18, 0.08),
        inset 0 1px 0 rgba(255,255,255,0.85);
    border-color: rgba(120, 101, 79, 0.16);
}

.flexy-fabric-card__image {
    position: relative;
    aspect-ratio: 1 / 0.95;
    overflow: hidden;
    background: #ebe5dd;
}

.flexy-fabric-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform .6s ease;
}

.flexy-fabric-card:hover .flexy-fabric-card__image img {
    transform: scale(1.03);
}

.flexy-fabric-card__body {
    padding: 20px 24px 24px;
}

.flexy-toggle-card {
    margin: 0;
    border: 0;
}

.flexy-toggle-card .togglet {
    position: relative;
    margin: 0;
    padding: 0 44px 0 0;
    cursor: pointer;
}

.flexy-toggle-card .togglet:before,
.flexy-toggle-card .togglet:after {
    content: "";
    position: absolute;
    right: 0;
    top: 24px;
    width: 16px;
    height: 2px;
    border-radius: 999px;
    background: #8b735b;
    transition: transform .28s ease, opacity .28s ease, background .28s ease;
}

.flexy-toggle-card .togglet:after {
    transform: rotate(90deg);
}

.flexy-toggle-card.toggle-active .togglet:after {
    opacity: 0;
    transform: rotate(0deg);
}

.flexy-toggle-card.toggle-active .togglet:before {
    background: #6e5743;
}

.flexy-toggle-head {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 50px;
}

.flexy-toggle-icon {
    width: 50px;
    height: 50px;
    flex: 0 0 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: linear-gradient(180deg, #f8f4ef 0%, #ede4d7 100%);
    border: 1px solid rgba(120, 101, 79, 0.10);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.92),
        0 6px 18px rgba(34, 25, 18, 0.05);
}

.flexy-toggle-icon img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
}

.flexy-toggle-title {
    display: block;
    font-size: 29px;
    line-height: 1.1;
    font-weight: 600;
    letter-spacing: -0.9px;
    color: #1d1916;
    transition: color .25s ease;
}

.flexy-toggle-card .togglet:hover .flexy-toggle-title {
    color: #7a634c;
}

.flexy-toggle-card .togglec {
    margin-top: 18px;
    padding: 20px 22px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(248,244,239,0.95) 0%, rgba(241,235,227,0.92) 100%);
    border: 1px solid rgba(120, 101, 79, 0.08);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.72);
    font-size: 15px;
    line-height: 1.9;
    color: #5f564d;
}

/* responsive */
@media (max-width: 1399px) {
    .flexy-materials-heading h2 {
        font-size: 56px;
    }

    .flexy-toggle-title {
        font-size: 26px;
    }
}

@media (max-width: 991px) {
    .flexy-materials-section {
        padding: 90px 0;
    }

    .flexy-materials-heading {
        margin-bottom: 44px;
    }

    .flexy-materials-heading h2 {
        font-size: 44px;
        letter-spacing: -1.4px;
    }

    .flexy-toggle-title {
        font-size: 24px;
    }
}

@media (max-width: 767px) {
    .flexy-materials-section {
        padding: 72px 0;
    }

    .flexy-materials-heading h2 {
        font-size: 36px;
    }

    .flexy-materials-heading p {
        font-size: 15px;
        line-height: 1.75;
    }

    .flexy-fabric-card {
        border-radius: 24px;
    }

    .flexy-fabric-card__body {
        padding: 18px 18px 20px;
    }

    .flexy-toggle-head {
        gap: 12px;
    }

    .flexy-toggle-icon {
        width: 46px;
        height: 46px;
        flex-basis: 46px;
        border-radius: 14px;
    }

    .flexy-toggle-icon img {
        width: 24px;
        height: 24px;
    }

    .flexy-toggle-title {
        font-size: 22px;
    }

    .flexy-toggle-card .togglet {
        padding-right: 34px;
    }

    .flexy-toggle-card .togglet:before,
    .flexy-toggle-card .togglet:after {
        top: 22px;
    }

    .flexy-toggle-card .togglec {
        margin-top: 14px;
        padding: 16px;
        border-radius: 16px;
        font-size: 14px;
        line-height: 1.8;
    }
}



/* ==========================================
   FLEXYSTROM — FABRIC FEATURE CARD / PREMIUM
========================================== */

.flexy-materials-section {
    position: relative;
    padding: 128px 0;
    background:
        radial-gradient(circle at top, rgba(255,255,255,0.98) 0%, rgba(247,244,239,1) 48%, rgba(241,237,231,1) 100%);
}

.flexy-materials-heading {
    max-width: 940px;
    margin: 0 auto 68px;
}

.flexy-materials-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 50px;
    height: 50px;
    padding: 0 16px;
    border-radius: 999px;
    background: rgba(122, 99, 76, 0.07);
    border: 1px solid rgba(122, 99, 76, 0.10);
    color: #7a634c;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1.9px;
    margin-bottom: 20px;
}

.flexy-materials-heading h2 {
    margin: 0 0 18px;
    font-size: 64px;
    line-height: 0.98;
    font-weight: 600;
    letter-spacing: -0.6px;
    color: #1d1916;
}

.flexy-materials-heading p {
    max-width: 780px;
    margin: 0 auto;
    font-size: 17px;
    line-height: 1.9;
    color: #70675e;
}

/* CARD */

.fabric-test-card {
    position: relative;
    border-radius: 36px;
    overflow: hidden;
    background: rgba(255,255,255,0.84);
    border: 1px solid rgba(92, 73, 52, 0.07);
    box-shadow:
        0 20px 50px rgba(27, 21, 17, 0.05),
        inset 0 1px 0 rgba(255,255,255,0.86);
    backdrop-filter: blur(10px);
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.fabric-test-card:hover {
    transform: translateY(-6px);
    border-color: rgba(122, 99, 76, 0.13);
    box-shadow:
        0 28px 68px rgba(27, 21, 17, 0.08),
        inset 0 1px 0 rgba(255,255,255,0.92);
}

.fabric-test-card__media {
    padding: 18px 18px 0;
}

.fabric-test-card__image-frame {
    position: relative;
    border-radius: 28px;
    overflow: hidden;
    background: linear-gradient(180deg, #f3ede7 0%, #e8dfd3 100%);
    border: 1px solid rgba(98, 77, 55, 0.05);
    box-shadow:
        0 12px 30px rgba(27, 21, 17, 0.05),
        inset 0 1px 0 rgba(255,255,255,0.65);
}

/* SPLIT IMAGE SYSTEM */

.fabric-test-card__image-frame--split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    padding: 12px;
    align-items: center;
}

.fabric-test-card__image-frame--split img {
    width: 100%;
    display: block;
    border-radius: 20px;
}

/* αριστερή εικόνα — texture / sample */
.fabric-test-card__image-frame--split img:first-child {
    height: 152px;
    object-fit: cover;
    object-position: center;
    background: #e9e1d7;
    box-shadow: 0 10px 24px rgba(27, 21, 17, 0.05);
    filter: saturate(0.94) contrast(1.02);
    transition: transform .7s ease;
}

/* δεξιά εικόνα — icon / brand panel */
.fabric-test-card__image-frame--split img:last-child {
    height: 184px;
    object-fit: contain;
    padding: 24px;
    background: linear-gradient(180deg, #f7f1ea 0%, #ebe1d4 100%);
    border: 1px solid rgba(98, 77, 55, 0.05);
    box-shadow:
        0 10px 24px rgba(27, 21, 17, 0.04),
        inset 0 1px 0 rgba(255,255,255,0.75);
    transition: transform .7s ease;
}

.fabric-test-card:hover .fabric-test-card__image-frame--split img:first-child,
.fabric-test-card:hover .fabric-test-card__image-frame--split img:last-child {
    transform: scale(1.02);
}

.fabric-test-card__body {
    padding: 22px 26px 28px;
}

.fabric-test-card__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.fabric-test-card__icon {
    width: 56px;
    height: 56px;
    flex: 0 0 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    background: linear-gradient(180deg, #f8f3ed 0%, #ece2d5 100%);
    border: 1px solid rgba(122, 99, 76, 0.10);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.92),
        0 8px 20px rgba(29, 23, 18, 0.05);
}

.fabric-test-card__icon img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
}

.fabric-test-card__eyebrow {
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #8e7d6b;
}

.fabric-test-card h3 {
    margin: 0 0 14px;
    font-size: 36px;
    line-height: 1.04;
    font-weight: 600;
    letter-spacing: -1.3px;
    color: #1c1815;
}

.fabric-test-card p {
    margin: 0 0 24px;
    font-size: 16px;
    line-height: 1.92;
    color: #5f564d;
}

.fabric-test-card__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 0 20px;
    border: 0;
    border-radius: 999px;
    background: #1f1b17;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.2px;
    box-shadow: 0 10px 20px rgba(31, 27, 23, 0.14);
    transition: transform .25s ease, opacity .25s ease, box-shadow .25s ease;
}

.fabric-test-card__cta:hover {
    transform: translateY(-2px);
    opacity: 0.96;
    box-shadow: 0 14px 24px rgba(31, 27, 23, 0.18);
}

/* RESPONSIVE */

@media (max-width: 1199px) {
    .flexy-materials-heading h2 {
        font-size: 56px;
    }

    .fabric-test-card h3 {
        font-size: 33px;
    }

    .fabric-test-card__image-frame--split img:first-child {
        height: 142px;
    }

    .fabric-test-card__image-frame--split img:last-child {
        height: 172px;
    }
}

@media (max-width: 991px) {
    .flexy-materials-section {
        padding: 96px 0;
    }

    .flexy-materials-heading {
        margin-bottom: 50px;
    }

    .flexy-materials-heading h2 {
        font-size: 46px;
        letter-spacing: -1.5px;
    }

    .fabric-test-card h3 {
        font-size: 31px;
    }

    .fabric-test-card__image-frame--split img:first-child {
        height: 148px;
    }

    .fabric-test-card__image-frame--split img:last-child {
        height: 176px;
    }
}

@media (max-width: 767px) {
    .flexy-materials-section {
        padding: 74px 0;
    }

    .flexy-materials-heading {
        margin-bottom: 40px;
    }

    .flexy-materials-heading h2 {
        font-size: 38px;
        letter-spacing: -1px;
    }

    .flexy-materials-heading p {
        font-size: 15px;
        line-height: 1.8;
    }

    .fabric-test-card {
        border-radius: 28px;
    }

    .fabric-test-card__media {
        padding: 14px 14px 0;
    }

    .fabric-test-card__image-frame {
        border-radius: 22px;
    }

    .fabric-test-card__image-frame--split {
        gap: 10px;
        padding: 10px;
    }

    .fabric-test-card__image-frame--split img {
        border-radius: 16px;
    }

    .fabric-test-card__image-frame--split img:first-child {
        height: 124px;
    }

    .fabric-test-card__image-frame--split img:last-child {
        height: 148px;
        padding: 18px;
    }

    .fabric-test-card__body {
        padding: 18px 18px 22px;
    }

    .fabric-test-card__meta {
        margin-bottom: 14px;
    }

    .fabric-test-card__icon {
        width: 48px;
        height: 48px;
        flex-basis: 48px;
        border-radius: 15px;
    }

    .fabric-test-card__icon img {
        width: 24px;
        height: 24px;
    }

    .fabric-test-card h3 {
        font-size: 30px;
        letter-spacing: -1px;
    }

    .fabric-test-card p {
        font-size: 15px;
        line-height: 1.85;
    }

    .fabric-test-card__cta {
        min-height: 48px;
        padding: 0 18px;
        font-size: 13px;
    }
}

.fabric-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 30px;
    align-items: stretch;
}

.fabric-card-col {
    display: flex;
}

.fabric-test-card {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.fabric-test-card__body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}

.fabric-test-card h3 {
    min-height: 72px;
    display: flex;
    align-items: flex-start;
}

.fabric-test-card__text {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}

.fabric-test-card__excerpt {
    display: -webkit-box;
    -webkit-line-clamp: 8;   /* ίδιο preview ύψος */
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(1.92em * 8);
    margin-bottom: 16px;
}

.fabric-test-card__fulltext {
    display: none;
    margin-bottom: 16px;
    font-size: 16px;
    line-height: 1.92;
    color: #5f564d;
}

.fabric-test-card.is-open .fabric-test-card__excerpt {
    display: none;
}

.fabric-test-card.is-open .fabric-test-card__fulltext {
    display: block;
}

.fabric-test-card__toggle {
    margin-top: auto;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 18px;
    border: 0;
    border-radius: 999px;
    background: #1f1b17;
    color: #ffffff;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.2px;
    cursor: pointer;
    transition: transform .2s ease, opacity .2s ease;
}

.fabric-test-card__toggle:hover {
    transform: translateY(-1px);
    opacity: 0.95;
}

@media (max-width: 1199px) {
    .fabric-cards-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .fabric-cards-grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .fabric-test-card h3 {
        min-height: auto;
    }

    .fabric-test-card__excerpt {
        -webkit-line-clamp: 7;
        min-height: calc(1.85em * 7);
    }
}


/* =========================================================
   FLEXYSTROM CERTIFICATIONS PAGE / 2026 LUXURY STYLE
========================================================= */

.flexy-certifications-page {
    --flexy-bg: #f7f4ef;
    --flexy-surface: #ffffff;
    --flexy-surface-2: #fbf9f5;
    --flexy-text: #2b2926;
    --flexy-muted: #6f695f;
    --flexy-line: rgba(43, 41, 38, 0.10);
    --flexy-line-strong: rgba(43, 41, 38, 0.16);
    --flexy-accent: #b89a6a;
    --flexy-shadow: 0 20px 60px rgba(31, 26, 18, 0.08);
    --flexy-shadow-hover: 0 24px 80px rgba(31, 26, 18, 0.12);
    --flexy-radius-xl: 34px;
    --flexy-radius-lg: 26px;
    --flexy-radius-md: 20px;
    --flexy-container: 1320px;

    background: linear-gradient(180deg, #f9f6f1 0%, #f6f2ec 100%);
    color: var(--flexy-text);
}

.flexy-certifications-page .container {
    width: 100%;
    max-width: var(--flexy-container);
    margin: 0 auto;
    padding-left: 28px;
    padding-right: 28px;
}

.flexy-certifications-page .content-wrap {
    background: transparent;
}

/* Intro */
.flexy-certifications-intro {
    padding: 110px 0 40px;
    position: relative;
    overflow: hidden;
}

.flexy-certifications-intro::before {
    content: "";
    position: absolute;
    top: -120px;
    right: -100px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(184,154,106,0.13) 0%, rgba(184,154,106,0.04) 38%, rgba(184,154,106,0) 72%);
    pointer-events: none;
}

.flexy-certifications-intro__inner {
    max-width: 940px;
    margin: 0 auto;
    text-align: center;
}

.flexy-certifications-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 9px 16px;
    margin-bottom: 22px;
    border: 1px solid rgba(184,154,106,0.30);
    border-radius: 999px;
    background: rgba(255,255,255,0.7);
    color: var(--flexy-accent);
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    backdrop-filter: blur(8px);
}

.flexy-certifications-intro h1 {
    margin: 0 0 24px;
    color: var(--flexy-text);
    font-size: clamp(2.35rem, 4.8vw, 4.6rem);
    line-height: 0.97;
    font-weight: 600;
    letter-spacing: -0.05em;
}

.flexy-certifications-intro__text {
    max-width: 880px;
    margin: 0 auto;
}

.flexy-certifications-intro__text p {
    margin: 0 0 18px;
    color: var(--flexy-muted);
    font-size: 17px;
    line-height: 1.9;
    font-weight: 400;
}

.flexy-certifications-intro__text p:last-child {
    margin-bottom: 0;
}

/* List */
.flexy-certifications-list {
    padding: 30px 0 120px;
}

.flexy-certifications-list .container {
    display: flex;
    flex-direction: column;
    gap: 34px;
}

/* Item */
.flexy-certification-item {
    display: grid;
    grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
    align-items: stretch;
    gap: 0;
    background: rgba(255,255,255,0.76);
    border: 1px solid rgba(255,255,255,0.65);
    border-radius: var(--flexy-radius-xl);
    overflow: hidden;
    box-shadow: var(--flexy-shadow);
    backdrop-filter: blur(12px);
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
    position: relative;
}

.flexy-certification-item:hover {
    transform: translateY(-4px);
    box-shadow: var(--flexy-shadow-hover);
    border-color: rgba(184,154,106,0.24);
}

.flexy-certification-item.is-reversed {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
}

.flexy-certification-item.is-reversed .flexy-certification-item__media {
    order: 2;
}

.flexy-certification-item.is-reversed .flexy-certification-item__content {
    order: 1;
}

.flexy-certification-item__media {
    position: relative;
    min-height: 100%;
    background: linear-gradient(180deg, #f3eee6 0%, #ebe4da 100%);
    padding: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 1px solid var(--flexy-line);
}

.flexy-certification-item.is-reversed .flexy-certification-item__media {
    border-right: 0;
    border-left: 1px solid var(--flexy-line);
}

.flexy-certification-item__media::after {
    content: "";
    position: absolute;
    inset: 22px;
    border: 1px solid rgba(184,154,106,0.12);
    border-radius: calc(var(--flexy-radius-lg) - 8px);
    pointer-events: none;
}

.flexy-certification-item__media img {
    position: relative;
    z-index: 1;
    max-width: 100%;
    max-height: 360px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 16px 30px rgba(43, 41, 38, 0.08));
    transition: transform 0.45s ease;
}

.flexy-certification-item:hover .flexy-certification-item__media img {
    transform: scale(1.025);
}

.flexy-certification-item__content {
    padding: 52px 54px;
    background: linear-gradient(180deg, rgba(255,255,255,0.90) 0%, rgba(251,249,245,0.96) 100%);
}

.flexy-certification-item__label {
    display: inline-block;
    margin-bottom: 16px;
    color: var(--flexy-accent);
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
}

.flexy-certification-item__content h3 {
    margin: 0 0 20px;
    color: var(--flexy-text);
    font-size: clamp(1.7rem, 2.1vw, 2.45rem);
    line-height: 1.1;
    font-weight: 600;
    letter-spacing: -0.04em;
}

.flexy-certification-item__text p,
.flexy-certification-item__text li {
    color: var(--flexy-muted);
    font-size: 16px;
    line-height: 1.9;
    font-weight: 400;
}

.flexy-certification-item__text p {
    margin: 0 0 16px;
}

.flexy-certification-item__text p:last-child {
    margin-bottom: 0;
}

.flexy-certification-item__text ul {
    margin: 14px 0 18px;
    padding: 0;
    list-style: none;
}

.flexy-certification-item__text li {
    position: relative;
    padding-left: 24px;
    margin-bottom: 10px;
}

.flexy-certification-item__text li:last-child {
    margin-bottom: 0;
}

.flexy-certification-item__text li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 12px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(180deg, #c5aa7b 0%, #a98854 100%);
    box-shadow: 0 0 0 4px rgba(184,154,106,0.10);
}

.flexy-certification-item__text strong,
.flexy-certification-item__text b {
    color: var(--flexy-text);
    font-weight: 600;
}

/* Optional sticky socials if you keep them */
.si-sticky {
    position: fixed;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 20;
}

.si-sticky a.social-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-bottom: 12px;
    border-radius: 50%;
    background: rgba(255,255,255,0.85);
    color: var(--flexy-text);
    border: 1px solid rgba(43,41,38,0.08);
    box-shadow: 0 10px 30px rgba(43,41,38,0.08);
    transition: all 0.25s ease;
}

.si-sticky a.social-icon:hover {
    transform: translateY(-2px);
    color: var(--flexy-accent);
    border-color: rgba(184,154,106,0.28);
    box-shadow: 0 16px 38px rgba(43,41,38,0.12);
}

/* Responsive */
@media (max-width: 1199px) {
    .flexy-certification-item,
    .flexy-certification-item.is-reversed {
        grid-template-columns: 360px minmax(0, 1fr);
    }

    .flexy-certification-item.is-reversed .flexy-certification-item__media {
        order: 1;
        border-left: 0;
        border-right: 1px solid var(--flexy-line);
    }

    .flexy-certification-item.is-reversed .flexy-certification-item__content {
        order: 2;
    }
}

@media (max-width: 991px) {
    .flexy-certifications-intro {
        padding: 84px 0 24px;
    }

    .flexy-certifications-list {
        padding: 20px 0 90px;
    }

    .flexy-certification-item,
    .flexy-certification-item.is-reversed {
        grid-template-columns: 1fr;
    }

    .flexy-certification-item__media,
    .flexy-certification-item.is-reversed .flexy-certification-item__media {
        border-right: 0;
        border-left: 0;
        border-bottom: 1px solid var(--flexy-line);
        padding: 30px;
    }

    .flexy-certification-item__media img {
        max-height: 280px;
    }

    .flexy-certification-item__content {
        padding: 38px 32px;
    }
}

@media (max-width: 767px) {
    .flexy-certifications-page .container {
        padding-left: 18px;
        padding-right: 18px;
    }

    .flexy-certifications-intro h1 {
        letter-spacing: -0.04em;
    }

    .flexy-certifications-intro__text p,
    .flexy-certification-item__text p,
    .flexy-certification-item__text li {
        font-size: 15px;
        line-height: 1.8;
    }

    .flexy-certification-item {
        border-radius: 24px;
    }

    .flexy-certification-item__media {
        padding: 24px;
    }

    .flexy-certification-item__media::after {
        inset: 16px;
        border-radius: 18px;
    }

    .flexy-certification-item__content {
        padding: 28px 22px;
    }

    .flexy-certification-item__content h3 {
        font-size: 1.55rem;
    }
}

.flexy-certification-item__media {
    padding: 20px;
}

.flexy-certification-item__media img {
    width: 100%;
    max-width: 100%;
    max-height: none;
    object-fit: cover;
}

.flexy-certification-item__media {
    display: flex;
    align-items: flex-start; /* αντί για center */
    justify-content: center;
}

/* =========================
   STORES / FLEXYSTROM 2026
   ========================= */

.stores-section {
    padding: 100px 0 130px;
    background:
        radial-gradient(circle at top left, rgba(130, 22, 22, 0.045), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #fbf9f7 52%, #f7f4f1 100%);
}

.stores-intro {
    max-width: 820px;
    margin: 0 auto 56px;
}

.stores-kicker {
    display: inline-block;
    margin-bottom: 16px;
    padding: 9px 15px;
    border: 1px solid rgba(25, 25, 25, 0.08);
    border-radius: 999px;
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #8a8580;
    background: rgba(255,255,255,0.78);
    backdrop-filter: blur(10px);
}

.stores-intro h2 {
    margin: 0 0 18px;
    font-size: clamp(2.1rem, 3.9vw, 3.7rem);
    line-height: 1.02;
    letter-spacing: -0.05em;
    font-weight: 700;
    color: #171717;
}

.stores-intro p {
    margin: 0 auto;
    max-width: 700px;
    font-size: 1.03rem;
    line-height: 1.82;
    color: #6d6863;
}

.stores-notice-card {
    margin: 0 auto 42px;
    max-width: 1160px;
    border-radius: 30px;
    overflow: hidden;
    background: rgba(255,255,255,0.92);
    box-shadow: 0 20px 70px rgba(20, 20, 20, 0.06);
    border: 1px solid rgba(20, 20, 20, 0.06);
    backdrop-filter: blur(10px);
}

.stores-notice-card img {
    display: block;
    width: 100%;
    height: auto;
    filter: saturate(0.84) contrast(0.98) brightness(1.01);
}

/* Featured store */
.store-featured-card {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 0;
    max-width: 1160px;
    margin: 0 auto 36px;
    background: rgba(255,255,255,0.9);
    border: 1px solid rgba(20, 20, 20, 0.06);
    border-radius: 34px;
    overflow: hidden;
    box-shadow: 0 28px 90px rgba(20, 20, 20, 0.07);
    backdrop-filter: blur(12px);
}

.store-featured-card__media {
    min-height: 470px;
    overflow: hidden;
    background: #efebe7;
}

.store-featured-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: saturate(0.82) contrast(0.98) brightness(0.99);
    transition: transform 1s ease, filter 0.35s ease;
}

.store-featured-card:hover .store-featured-card__media img {
    transform: scale(1.035);
    filter: saturate(0.88) contrast(1) brightness(1);
}

.store-featured-card__content {
    padding: 54px 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.store-badge {
    display: inline-flex;
    align-self: flex-start;
    padding: 10px 16px;
    margin-bottom: 20px;
    border-radius: 999px;
    background: rgba(179, 33, 33, 0.07);
    color: #8f2a2a;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.store-featured-card__content h3 {
    margin: 0 0 18px;
    font-size: clamp(2rem, 2.2vw, 3rem);
    line-height: 1.04;
    letter-spacing: -0.045em;
    color: #181818;
    font-weight: 700;
}

/* Grid */
.stores-grid {
    max-width: 1160px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
}

.store-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: rgba(255,255,255,0.9);
    border: 1px solid rgba(20, 20, 20, 0.06);
    border-radius: 30px;
    overflow: hidden;
    box-shadow: 0 18px 60px rgba(20, 20, 20, 0.06);
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
    backdrop-filter: blur(10px);
}

.store-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 28px 75px rgba(20, 20, 20, 0.09);
    border-color: rgba(179, 33, 33, 0.14);
}

.store-card__image {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: #efebe7;
}

.store-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: grayscale(10%) saturate(0.78) contrast(0.98) brightness(0.99);
    transition: transform 0.85s ease, filter 0.45s ease;
}

.store-card:hover .store-card__image img {
    transform: scale(1.04);
    filter: grayscale(4%) saturate(0.84) contrast(1) brightness(1);
}

.store-card__body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    padding: 30px 30px 32px;
}

.store-card__body h3 {
    margin: 0 0 14px;
    font-size: 1.52rem;
    line-height: 1.12;
    letter-spacing: -0.03em;
    color: #1d1d1d;
    font-weight: 700;
}

.store-address {
    margin: 0 0 12px;
    font-size: 1rem;
    line-height: 1.72;
    color: #5d5853;
}

.store-subnote {
    color: #8a847e;
    font-size: 0.95rem;
}

.store-phone {
    display: inline-block;
    margin-bottom: 14px;
    font-size: 1.18rem;
    font-weight: 700;
    color: #a32525;
    text-decoration: none !important;
    transition: color 0.25s ease, opacity 0.25s ease;
}

.store-phone:hover {
    color: #1d1d1d;
}

.store-fax {
    margin: -2px 0 16px;
    color: #87807a;
    font-size: 0.95rem;
}

.store-hours {
    margin-top: 8px;
    padding-top: 18px;
    border-top: 1px solid rgba(20, 20, 20, 0.08);
}

.store-hours h4 {
    margin: 0 0 10px;
    font-size: 0.84rem;
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #1e1e1e;
}

.store-hours p {
    margin: 0;
    color: #68625d;
    line-height: 1.84;
    font-size: 0.97rem;
}

.store-note {
    margin-top: 8px;
    padding: 15px 18px;
    border-radius: 18px;
    background: rgba(179, 33, 33, 0.045);
    color: #8b3333;
    line-height: 1.68;
    font-size: 0.95rem;
}

.store-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.store-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid rgba(20, 20, 20, 0.1);
    background: rgba(255,255,255,0.92);
    color: #1f1f1f;
    text-decoration: none !important;
    font-size: 0.94rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    transition: all 0.25s ease;
}

.store-btn:hover {
    border-color: #1f1f1f;
    color: #1f1f1f;
    background: #fff;
    transform: translateY(-1px);
}

.store-btn--primary {
    background: #b32121;
    color: #fff;
    border-color: #b32121;
    box-shadow: 0 10px 24px rgba(179, 33, 33, 0.18);
}

.store-btn--primary:hover {
    background: #942020;
    border-color: #942020;
    color: #fff;
    box-shadow: 0 14px 28px rgba(148, 32, 32, 0.2);
}

/* optional: hide old sticky socials only inside this page area if needed */
.stores-section + .si-sticky,
.stores-section .si-sticky {
    display: none !important;
}

/* Responsive */
@media (max-width: 991px) {
    .stores-section {
        padding: 76px 0 96px;
    }

    .stores-intro {
        margin-bottom: 42px;
    }

    .store-featured-card {
        grid-template-columns: 1fr;
        border-radius: 28px;
    }

    .store-featured-card__media {
        min-height: 340px;
    }

    .store-featured-card__content {
        padding: 38px 30px;
    }

    .stores-grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .store-card {
        border-radius: 26px;
    }

    .store-card__body {
        padding: 25px 24px 28px;
    }
}

@media (max-width: 767px) {
    .stores-intro {
        margin-bottom: 36px;
    }

    .stores-intro h2 {
        font-size: clamp(2rem, 10vw, 2.9rem);
    }

    .stores-intro p {
        font-size: 0.98rem;
        line-height: 1.74;
    }

    .stores-notice-card {
        border-radius: 22px;
        margin-bottom: 26px;
    }

    .store-featured-card,
    .store-card {
        border-radius: 22px;
    }

    .store-featured-card__media {
        min-height: 280px;
    }

    .store-card__image {
        aspect-ratio: 4 / 3;
    }

    .store-actions {
        flex-direction: column;
    }

    .store-btn {
        width: 100%;
    }
}


/* =========================
   SINGLE STORE / FLEXYSTROM
   ========================= */

.single-store-section {
    padding: 90px 0 120px;
    background:
        radial-gradient(circle at top left, rgba(130, 22, 22, 0.04), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #fbf9f7 55%, #f7f4f1 100%);
}

.single-store-intro {
    max-width: 860px;
    margin: 0 auto 52px;
}

.single-store-kicker {
    display: inline-block;
    margin-bottom: 16px;
    padding: 9px 15px;
    border: 1px solid rgba(25, 25, 25, 0.08);
    border-radius: 999px;
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #8a8580;
    background: rgba(255,255,255,0.78);
    backdrop-filter: blur(10px);
}

.single-store-intro h2 {
    margin: 0 0 18px;
    font-size: clamp(2.2rem, 4vw, 4rem);
    line-height: 1.03;
    letter-spacing: -0.05em;
    font-weight: 700;
    color: #171717;
}

.single-store-intro p {
    max-width: 720px;
    margin: 0 auto;
    font-size: 1.03rem;
    line-height: 1.82;
    color: #6d6863;
}

.single-store-card {
    display: grid;
    grid-template-columns: 1.12fr 0.88fr;
    max-width: 1160px;
    margin: 0 auto 32px;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(20,20,20,0.06);
    border-radius: 34px;
    overflow: hidden;
    box-shadow: 0 28px 90px rgba(20,20,20,0.07);
    backdrop-filter: blur(12px);
}

.single-store-card__media {
    min-height: 500px;
    background: #efebe7;
    overflow: hidden;
}

.single-store-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: saturate(0.82) contrast(0.98) brightness(0.99);
    transition: transform 1s ease, filter 0.35s ease;
}

.single-store-card:hover .single-store-card__media img {
    transform: scale(1.035);
    filter: saturate(0.88) contrast(1) brightness(1);
}

.single-store-card__content {
    padding: 56px 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.single-store-badge {
    display: inline-flex;
    align-self: flex-start;
    padding: 10px 16px;
    margin-bottom: 20px;
    border-radius: 999px;
    background: rgba(179, 33, 33, 0.07);
    color: #8f2a2a;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.single-store-card__content h3 {
    margin: 0 0 18px;
    font-size: clamp(2rem, 2.3vw, 3rem);
    line-height: 1.04;
    letter-spacing: -0.045em;
    color: #181818;
    font-weight: 700;
}

.single-store-address {
    margin: 0 0 12px;
    font-size: 1rem;
    line-height: 1.72;
    color: #5d5853;
}

.single-store-phone {
    display: inline-block;
    margin-bottom: 16px;
    font-size: 1.2rem;
    font-weight: 700;
    color: #a32525;
    text-decoration: none !important;
    transition: color 0.25s ease;
}

.single-store-phone:hover {
    color: #1d1d1d;
}

.single-store-note {
    margin-top: 8px;
    padding: 15px 18px;
    border-radius: 18px;
    background: rgba(179, 33, 33, 0.045);
    color: #8b3333;
    line-height: 1.68;
    font-size: 0.95rem;
}

.single-store-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.single-store-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid rgba(20,20,20,0.1);
    background: rgba(255,255,255,0.92);
    color: #1f1f1f;
    text-decoration: none !important;
    font-size: 0.94rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    transition: all 0.25s ease;
}

.single-store-btn:hover {
    border-color: #1f1f1f;
    color: #1f1f1f;
    background: #fff;
    transform: translateY(-1px);
}

.single-store-btn--primary {
    background: #b32121;
    color: #fff;
    border-color: #b32121;
    box-shadow: 0 10px 24px rgba(179, 33, 33, 0.18);
}

.single-store-btn--primary:hover {
    background: #942020;
    border-color: #942020;
    color: #fff;
    box-shadow: 0 14px 28px rgba(148, 32, 32, 0.2);
}

.single-store-info-grid {
    max-width: 1160px;
    margin: 0 auto 32px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.single-store-info-card {
    background: rgba(255,255,255,0.88);
    border: 1px solid rgba(20,20,20,0.06);
    border-radius: 28px;
    padding: 30px 28px;
    box-shadow: 0 18px 60px rgba(20,20,20,0.05);
}

.single-store-info-card h4 {
    margin: 0 0 12px;
    font-size: 1.2rem;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: #1c1c1c;
    font-weight: 700;
}

.single-store-info-card p {
    margin: 0;
    color: #68625d;
    line-height: 1.82;
    font-size: 0.98rem;
}

.single-store-map-wrap {
    max-width: 1160px;
    margin: 0 auto;
}

.single-store-map-header {
    text-align: center;
    margin-bottom: 24px;
}

.single-store-map-kicker {
    display: inline-block;
    margin-bottom: 10px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #8a847e;
}

.single-store-map-header h3 {
    margin: 0;
    font-size: clamp(1.8rem, 2.4vw, 2.7rem);
    line-height: 1.08;
    letter-spacing: -0.04em;
    color: #181818;
    font-weight: 700;
}

.single-store-map-card {
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(20,20,20,0.06);
    background: #fff;
    box-shadow: 0 24px 70px rgba(20,20,20,0.06);
}

.single-store-map-card iframe {
    display: block;
    width: 100%;
}

/* Responsive */
@media (max-width: 991px) {
    .single-store-section {
        padding: 72px 0 96px;
    }

    .single-store-card {
        grid-template-columns: 1fr;
        border-radius: 28px;
    }

    .single-store-card__media {
        min-height: 340px;
    }

    .single-store-card__content {
        padding: 38px 30px;
    }

    .single-store-info-grid {
        grid-template-columns: 1fr;
        gap: 18px;
    }
}

@media (max-width: 767px) {
    .single-store-intro {
        margin-bottom: 38px;
    }

    .single-store-intro h2 {
        font-size: clamp(2rem, 10vw, 3rem);
    }

    .single-store-intro p {
        font-size: 0.98rem;
        line-height: 1.74;
    }

    .single-store-card,
    .single-store-info-card,
    .single-store-map-card {
        border-radius: 22px;
    }

    .single-store-card__media {
        min-height: 280px;
    }

    .single-store-actions {
        flex-direction: column;
    }

    .single-store-btn {
        width: 100%;
    }
}

.single-store-fax {
    margin: -2px 0 16px;
    color: #87807a;
    font-size: 0.95rem;
}

.single-store-hours {
    margin-top: 8px;
    padding-top: 18px;
    border-top: 1px solid rgba(20,20,20,0.08);
}

.single-store-hours h4 {
    margin: 0 0 10px;
    font-size: 0.84rem;
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #1e1e1e;
}

.single-store-hours p {
    margin: 0;
    color: #68625d;
    line-height: 1.84;
    font-size: 0.97rem;
}


.single-store-subnote {
    color: #8a847e;
    font-size: 0.95rem;
}

.single-store-hours {
    margin-top: 8px;
    padding-top: 18px;
    border-top: 1px solid rgba(20,20,20,0.08);
}

.single-store-hours h4 {
    margin: 0 0 10px;
    font-size: 0.84rem;
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #1e1e1e;
}

.single-store-hours p {
    margin: 0;
    color: #68625d;
    line-height: 1.84;
    font-size: 0.97rem;
}

.single-store-tour-wrap {
    max-width: 1160px;
    margin: 0 auto 32px;
}

.single-store-tour-card {
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(20,20,20,0.06);
    background: #fff;
    box-shadow: 0 24px 70px rgba(20,20,20,0.06);
}

.single-store-tour-card iframe {
    display: block;
    width: 100%;
}

.single-store-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}

.single-store-badge--new {
    background: rgba(179, 33, 33, 0.1);
    color: #a32525;
}


.single-store-fax {
    margin: -2px 0 16px;
    color: #87807a;
    font-size: 0.95rem;
}

.single-store-hours {
    margin-top: 8px;
    padding-top: 18px;
    border-top: 1px solid rgba(20,20,20,0.08);
}

.single-store-hours h4 {
    margin: 0 0 10px;
    font-size: 0.84rem;
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #1e1e1e;
}

.single-store-hours p {
    margin: 0;
    color: #68625d;
    line-height: 1.84;
    font-size: 0.97rem;
}

/* Premium B2B Partner Section */
.fx-partner-intro {
    position: relative;
    padding: 130px 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 10% 15%, rgba(181, 142, 92, 0.10) 0%, rgba(181, 142, 92, 0) 32%),
        linear-gradient(135deg, #f8f5ef 0%, #ffffff 48%, #f3eee6 100%);
}

.fx-partner-intro::before {
    content: "";
    position: absolute;
    top: -120px;
    right: -120px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(181, 142, 92, 0.08);
    filter: blur(10px);
}

.fx-partner-intro::after {
    content: "";
    position: absolute;
    bottom: 60px;
    left: 0;
    width: 34%;
    height: 1px;
    background: linear-gradient(90deg, rgba(181, 142, 92, 0.55), rgba(181, 142, 92, 0));
}

.fx-partner-intro .container {
    position: relative;
    z-index: 2;
}

.fx-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: #9b7447;
}

.fx-eyebrow::before {
    content: "";
    width: 42px;
    height: 1px;
    background: #b58e5c;
}

.fx-section-title {
    max-width: 560px;
    margin-bottom: 26px;
    font-size: clamp(38px, 4.2vw, 62px);
    line-height: 1.02;
    letter-spacing: -0.6px;
    font-weight: 600;
    color: #191715;
}

.fx-section-text {
    max-width: 530px;
    margin-bottom: 38px;
    font-size: 18px;
    line-height: 1.75;
    color: #5f5a54;
}

.fx-premium-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 0 32px;
    border-radius: 100px;
    background: #191715;
    color: #ffffff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    box-shadow: 0 18px 38px rgba(25, 23, 21, 0.18);
    transition: all 0.35s ease;
}

.fx-premium-btn:hover {
    transform: translateY(-3px);
    background: #b58e5c;
    color: #ffffff;
    box-shadow: 0 22px 44px rgba(181, 142, 92, 0.28);
}

.fx-benefits-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.fx-benefit-card {
    position: relative;
    min-height: 285px;
    padding: 38px 34px;
    border: 1px solid rgba(181, 142, 92, 0.18);
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.78);
    box-shadow: 0 28px 70px rgba(50, 42, 32, 0.08);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    overflow: hidden;
    transition: all 0.4s ease;
}

.fx-benefit-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(145deg, rgba(181, 142, 92, 0.16), rgba(255, 255, 255, 0) 45%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.fx-benefit-card:hover {
    transform: translateY(-8px);
    border-color: rgba(181, 142, 92, 0.38);
    box-shadow: 0 34px 90px rgba(50, 42, 32, 0.13);
}

.fx-benefit-card:hover::before {
    opacity: 1;
}

.fx-card-offset {
    transform: translateY(38px);
}

.fx-card-offset:hover {
    transform: translateY(30px);
}

.fx-card-number {
    position: relative;
    display: block;
    margin-bottom: 44px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #b58e5c;
}

.fx-card-number::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -18px;
    width: 44px;
    height: 1px;
    background: rgba(181, 142, 92, 0.55);
}

.fx-benefit-card h3 {
    position: relative;
    margin-bottom: 13px;
    font-size: 23px;
    line-height: 1.25;
    font-weight: 600;
    letter-spacing: -0.5px;
    color: #191715;
}

.fx-benefit-card p {
    position: relative;
    margin: 0;
    font-size: 15.5px;
    line-height: 1.7;
    color: #655f58;
}

@media (max-width: 1199px) {
    .fx-partner-intro {
        padding: 110px 0;
    }

    .fx-section-title {
        font-size: clamp(36px, 5vw, 54px);
    }
}

@media (max-width: 991px) {
    .fx-partner-intro {
        padding: 90px 0;
    }

    .fx-card-offset {
        transform: none;
    }

    .fx-card-offset:hover {
        transform: translateY(-8px);
    }
}

@media (max-width: 767px) {
    .fx-partner-intro {
        padding: 75px 0;
    }

    .fx-benefits-grid {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .fx-benefit-card {
        min-height: auto;
        padding: 32px 28px;
        border-radius: 22px;
    }

    .fx-section-title {
        letter-spacing: 1.6px;
    }

    .fx-section-text {
        font-size: 16px;
    }
}



/* Premium Ideal Partners Section */
.fx-ideal-partners {
    position: relative;
    padding: 125px 0;
    overflow: hidden;
    background: #191715;
}

.fx-ideal-partners::before {
    content: "";
    position: absolute;
    top: -180px;
    left: 50%;
    width: 720px;
    height: 720px;
    transform: translateX(-50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(181, 142, 92, 0.18) 0%, rgba(181, 142, 92, 0) 62%);
}

.fx-ideal-partners::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
    background-size: 58px 58px;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,0.8), rgba(0,0,0,0.15));
    pointer-events: none;
}

.fx-ideal-partners .container {
    position: relative;
    z-index: 2;
}

.fx-eyebrow-center {
    justify-content: center;
    color: #c9a878;
}

.fx-eyebrow-center::before,
.fx-eyebrow-center::after {
    content: "";
    width: 38px;
    height: 1px;
    background: rgba(201, 168, 120, 0.8);
}

.fx-title-center {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
    color: #ffffff;
}

.fx-text-center {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    color: rgba(255,255,255,0.68);
}

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

.fx-partner-type-card {
    position: relative;
    min-height: 270px;
    padding: 38px 34px;
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: 28px;
    background: linear-gradient(145deg, rgba(255,255,255,0.075), rgba(255,255,255,0.025));
    box-shadow: 0 28px 80px rgba(0,0,0,0.18);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    overflow: hidden;
    transition: all 0.4s ease;
}

.fx-partner-type-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(181, 142, 92, 0.24), rgba(181, 142, 92, 0) 46%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.fx-partner-type-card:hover {
    transform: translateY(-8px);
    border-color: rgba(201, 168, 120, 0.38);
    background: linear-gradient(145deg, rgba(255,255,255,0.105), rgba(255,255,255,0.04));
}

.fx-partner-type-card:hover::before {
    opacity: 1;
}

.fx-partner-icon {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    margin-bottom: 42px;
    border-radius: 50%;
    border: 1px solid rgba(201, 168, 120, 0.45);
    color: #c9a878;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
}

.fx-partner-type-card h3 {
    position: relative;
    z-index: 1;
    margin-bottom: 14px;
    font-size: 23px;
    line-height: 1.25;
    font-weight: 600;
    letter-spacing: -0.5px;
    color: #ffffff;
}

.fx-partner-type-card p {
    position: relative;
    z-index: 1;
    margin: 0;
    font-size: 15.5px;
    line-height: 1.72;
    color: rgba(255,255,255,0.64);
}

@media (max-width: 1199px) {
    .fx-ideal-partners {
        padding: 105px 0;
    }

    .fx-partner-types-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .fx-ideal-partners {
        padding: 80px 0;
    }

    .fx-partner-types-grid {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .fx-partner-type-card {
        min-height: auto;
        padding: 32px 28px;
        border-radius: 22px;
    }
}


/* Premium Partner Support Section */
.fx-partner-support {
    position: relative;
    padding: 130px 0;
    overflow: hidden;
    background:
        linear-gradient(135deg, #ffffff 0%, #f8f5ef 48%, #efe8dc 100%);
}

.fx-partner-support::before {
    content: "";
    position: absolute;
    top: 80px;
    left: -160px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(181, 142, 92, 0.10);
    filter: blur(14px);
}

.fx-partner-support::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 80px;
    width: 38%;
    height: 1px;
    background: linear-gradient(90deg, rgba(181, 142, 92, 0), rgba(181, 142, 92, 0.55));
}

.fx-partner-support .container {
    position: relative;
    z-index: 2;
}

.fx-support-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.fx-support-item {
    position: relative;
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 24px;
    padding: 30px 34px;
    border: 1px solid rgba(181, 142, 92, 0.18);
    border-radius: 26px;
    background: rgba(255,255,255,0.76);
    box-shadow: 0 24px 70px rgba(50, 42, 32, 0.075);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    overflow: hidden;
    transition: all 0.35s ease;
}

.fx-support-item::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, rgba(181, 142, 92, 0.14), rgba(255,255,255,0) 42%);
    opacity: 0;
    transition: opacity 0.35s ease;
}

.fx-support-item:hover {
    transform: translateX(-8px);
    border-color: rgba(181, 142, 92, 0.38);
    box-shadow: 0 30px 86px rgba(50, 42, 32, 0.12);
}

.fx-support-item:hover::before {
    opacity: 1;
}

.fx-support-item > span {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    border-radius: 50%;
    background: #191715;
    color: #ffffff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
    box-shadow: 0 18px 36px rgba(25, 23, 21, 0.16);
}

.fx-support-item div {
    position: relative;
    z-index: 1;
}

.fx-support-item h3 {
    margin-bottom: 8px;
    font-size: 22px;
    line-height: 1.28;
    font-weight: 600;
    letter-spacing: -0.45px;
    color: #191715;
}

.fx-support-item p {
    margin: 0;
    font-size: 15.5px;
    line-height: 1.7;
    color: #655f58;
}

@media (max-width: 1199px) {
    .fx-partner-support {
        padding: 110px 0;
    }
}

@media (max-width: 991px) {
    .fx-partner-support {
        padding: 90px 0;
    }

    .fx-support-item:hover {
        transform: translateY(-6px);
    }
}

@media (max-width: 767px) {
    .fx-partner-support {
        padding: 75px 0;
    }

    .fx-support-item {
        grid-template-columns: 1fr;
        gap: 18px;
        padding: 30px 26px;
        border-radius: 22px;
    }
}


/* Premium Products Section */
.fx-partner-products {
    position: relative;
    padding: 130px 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 85% 10%, rgba(181, 142, 92, 0.12) 0%, rgba(181, 142, 92, 0) 34%),
        linear-gradient(180deg, #f9f6f1 0%, #ffffff 100%);
}

.fx-partner-products .container {
    position: relative;
    z-index: 2;
}

.fx-eyebrow-center-light {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: #9b7447;
}

.fx-eyebrow-center-light::before,
.fx-eyebrow-center-light::after {
    content: "";
    width: 38px;
    height: 1px;
    background: rgba(181, 142, 92, 0.8);
}

.fx-title-center-dark {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
    color: #191715;
}

.fx-text-center-dark {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    color: #655f58;
}

.fx-products-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 22px;
}

.fx-product-card {
    position: relative;
    min-height: 250px;
    padding: 34px 30px;
    border: 1px solid rgba(181, 142, 92, 0.18);
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: 0 26px 70px rgba(50, 42, 32, 0.075);
    overflow: hidden;
    transition: all 0.4s ease;
}

.fx-product-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(145deg, rgba(181, 142, 92, 0.16), rgba(255,255,255,0) 50%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.fx-product-card:hover {
    transform: translateY(-8px);
    border-color: rgba(181, 142, 92, 0.38);
    box-shadow: 0 34px 90px rgba(50, 42, 32, 0.12);
}

.fx-product-card:hover::before {
    opacity: 1;
}

.fx-product-card-large {
    grid-column: span 2;
    grid-row: span 2;
    min-height: 522px;
    display: flex;
    align-items: flex-end;
    background:
        linear-gradient(180deg, rgba(25,23,21,0.12) 0%, rgba(25,23,21,0.82) 100%),
        url("../imgs/synergates-products-mattress.jpg") center/cover no-repeat;
    border-color: rgba(255,255,255,0.18);
}

.fx-product-card-wide {
    grid-column: span 2;
}

.fx-product-card span {
    position: relative;
    z-index: 1;
    display: block;
    margin-bottom: 38px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #b58e5c;
}

.fx-product-card span::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -17px;
    width: 42px;
    height: 1px;
    background: rgba(181, 142, 92, 0.55);
}

.fx-product-card h3 {
    position: relative;
    z-index: 1;
    margin-bottom: 12px;
    font-size: 23px;
    line-height: 1.25;
    font-weight: 600;
    letter-spacing: -0.5px;
    color: #191715;
}

.fx-product-card p {
    position: relative;
    z-index: 1;
    margin: 0;
    font-size: 15.5px;
    line-height: 1.7;
    color: #655f58;
}

.fx-product-card-large span,
.fx-product-card-large h3,
.fx-product-card-large p {
    color: #ffffff;
}

.fx-product-card-large span::after {
    background: rgba(255,255,255,0.5);
}

.fx-product-card-large h3 {
    font-size: 34px;
    letter-spacing: -1px;
}

.fx-product-card-large p {
    max-width: 420px;
    color: rgba(255,255,255,0.78);
}

@media (max-width: 1199px) {
    .fx-partner-products {
        padding: 110px 0;
    }

    .fx-products-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fx-product-card-large {
        min-height: 460px;
    }
}

@media (max-width: 767px) {
    .fx-partner-products {
        padding: 80px 0;
    }

    .fx-products-grid {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .fx-product-card,
    .fx-product-card-large,
    .fx-product-card-wide {
        grid-column: span 1;
        grid-row: span 1;
        min-height: auto;
    }

    .fx-product-card {
        padding: 32px 28px;
        border-radius: 22px;
    }

    .fx-product-card-large {
        min-height: 420px;
    }
}


/* Premium Hospitality Section */
.fx-hospitality-section {
    position: relative;
    overflow: hidden;
    background: #111111;
}

.fx-hospitality-image {
    position: relative;
}

.fx-hospitality-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(17,17,17,0.08) 0%, rgba(17,17,17,0.25) 100%);
    pointer-events: none;
}

.fx-hospitality-image img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 1.8s ease;
}

.fx-hospitality-section:hover .fx-hospitality-image img {
    transform: scale(1.04);
}

.fx-hospitality-content {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding: 120px 9%;
    background:
        radial-gradient(circle at top right, rgba(181, 142, 92, 0.16) 0%, rgba(181, 142, 92, 0) 34%),
        linear-gradient(180deg, #191715 0%, #111111 100%);
}

.fx-hospitality-content::before {
    content: "";
    position: absolute;
    top: 90px;
    right: -120px;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: rgba(181, 142, 92, 0.08);
    filter: blur(10px);
}

.fx-eyebrow-light {
    color: #d2ae7d;
}

.fx-eyebrow-light::before {
    background: rgba(210, 174, 125, 0.85);
}

.fx-hospitality-title {
    position: relative;
    z-index: 1;
    max-width: 700px;
    margin-bottom: 30px;
    font-size: clamp(42px, 4.2vw, 68px);
    line-height: 1.02;
    letter-spacing: -2.8px;
    font-weight: 600;
    color: #ffffff;
}

.fx-hospitality-text {
    position: relative;
    z-index: 1;
    max-width: 620px;
    margin-bottom: 22px;
    font-size: 18px;
    line-height: 1.85;
    color: rgba(255,255,255,0.68);
}

.fx-hospitality-features {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-top: 18px;
    margin-bottom: 42px;
}

.fx-hospitality-feature {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.fx-hospitality-feature span {
    position: relative;
    top: 9px;
    flex-shrink: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #b58e5c;
    box-shadow: 0 0 0 8px rgba(181, 142, 92, 0.14);
}

.fx-hospitality-feature p {
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
    color: rgba(255,255,255,0.72);
}

.fx-hospitality-btn {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 56px;
    padding: 0 34px;
    border-radius: 100px;
    background: #b58e5c;
    color: #ffffff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.3px;
    text-transform: uppercase;
    box-shadow: 0 20px 46px rgba(181, 142, 92, 0.28);
    transition: all 0.35s ease;
}

.fx-hospitality-btn:hover {
    transform: translateY(-3px);
    background: #ffffff;
    color: #191715;
    box-shadow: 0 24px 52px rgba(255,255,255,0.16);
}

@media (max-width: 1199px) {
    .fx-hospitality-content {
        padding: 100px 8%;
    }

    .fx-hospitality-image {
        min-height: 680px;
    }
}

@media (max-width: 991px) {
    .fx-hospitality-image {
        min-height: 500px;
    }

    .fx-hospitality-content {
        padding: 80px 40px;
    }

    .fx-hospitality-title {
        letter-spacing: -2px;
    }
}

@media (max-width: 767px) {
    .fx-hospitality-image {
        min-height: 380px;
    }

    .fx-hospitality-content {
        padding: 70px 26px;
    }

    .fx-hospitality-title {
        font-size: 38px;
        letter-spacing: -1.5px;
    }

    .fx-hospitality-text {
        font-size: 16px;
        line-height: 1.75;
    }

    .fx-hospitality-feature p {
        font-size: 15px;
    }
}


/* Premium Process Section */
.fx-process-section {
    position: relative;
    padding: 140px 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 15% 20%, rgba(181, 142, 92, 0.12) 0%, rgba(181, 142, 92, 0) 34%),
        linear-gradient(180deg, #f9f6f1 0%, #ffffff 100%);
}

.fx-process-section::before {
    content: "";
    position: absolute;
    top: -140px;
    right: -120px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(181, 142, 92, 0.08);
    filter: blur(12px);
}

.fx-process-wrapper {
    position: relative;
}

.fx-process-line {
    position: absolute;
    top: 70px;
    left: 0;
    right: 0;
    height: 1px;
    background:
        linear-gradient(90deg,
        rgba(181, 142, 92, 0),
        rgba(181, 142, 92, 0.55),
        rgba(181, 142, 92, 0));
}

.fx-process-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 24px;
}

.fx-process-card {
    position: relative;
    padding-top: 36px;
}

.fx-process-card-offset {
    transform: translateY(55px);
}

.fx-process-number {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    margin-bottom: 38px;
    border-radius: 50%;
    background: #191715;
    color: #ffffff;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 1px;
    box-shadow: 0 22px 46px rgba(25,23,21,0.14);
}

.fx-process-number::before {
    content: "";
    position: absolute;
    inset: -10px;
    border-radius: 50%;
    border: 1px solid rgba(181, 142, 92, 0.28);
}

.fx-process-content {
    position: relative;
    padding: 38px 34px;
    min-height: 320px;
    border-radius: 30px;
    border: 1px solid rgba(181, 142, 92, 0.18);
    background: rgba(255,255,255,0.82);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow: 0 28px 70px rgba(50,42,32,0.08);
    overflow: hidden;
    transition: all 0.4s ease;
}

.fx-process-content::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(145deg,
        rgba(181, 142, 92, 0.15),
        rgba(255,255,255,0) 48%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.fx-process-card:hover .fx-process-content {
    transform: translateY(-8px);
    border-color: rgba(181, 142, 92, 0.38);
    box-shadow: 0 34px 90px rgba(50,42,32,0.12);
}

.fx-process-card:hover .fx-process-content::before {
    opacity: 1;
}

.fx-process-content span {
    position: relative;
    z-index: 1;
    display: inline-block;
    margin-bottom: 16px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #b58e5c;
}

.fx-process-content h3 {
    position: relative;
    z-index: 1;
    margin-bottom: 16px;
    font-size: 24px;
    line-height: 1.2;
    font-weight: 600;
    letter-spacing: -0.6px;
    color: #191715;
}

.fx-process-content p {
    position: relative;
    z-index: 1;
    margin: 0;
    font-size: 15.5px;
    line-height: 1.78;
    color: #655f58;
}

@media (max-width: 1199px) {
    .fx-process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fx-process-line {
        display: none;
    }
}

@media (max-width: 991px) {
    .fx-process-section {
        padding: 100px 0;
    }

    .fx-process-card-offset {
        transform: none;
    }
}

@media (max-width: 767px) {
    .fx-process-section {
        padding: 80px 0;
    }

    .fx-process-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .fx-process-content {
        min-height: auto;
        padding: 32px 28px;
        border-radius: 24px;
    }

    .fx-process-number {
        width: 64px;
        height: 64px;
        margin-bottom: 28px;
    }
}


/* Premium Philosophy Section */
.fx-philosophy-section {
    position: relative;
    padding: 150px 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 15% 15%, rgba(181, 142, 92, 0.10) 0%, rgba(181, 142, 92, 0) 30%),
        linear-gradient(180deg, #111111 0%, #1b1a18 100%);
}

.fx-philosophy-section::before {
    content: "";
    position: absolute;
    top: -240px;
    right: -140px;
    width: 520px;
    height: 520px;
    border-radius: 50%;
    background: rgba(181, 142, 92, 0.07);
    filter: blur(14px);
}

.fx-philosophy-wrapper {
    position: relative;
    padding: 90px 85px;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 42px;
    background:
        linear-gradient(145deg,
        rgba(255,255,255,0.06),
        rgba(255,255,255,0.02));
    box-shadow: 0 40px 120px rgba(0,0,0,0.28);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    overflow: hidden;
}

.fx-philosophy-wrapper::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(145deg,
        rgba(181, 142, 92, 0.10),
        rgba(255,255,255,0) 42%);
    pointer-events: none;
}

.fx-philosophy-bg-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: clamp(120px, 15vw, 260px);
    font-weight: 700;
    letter-spacing: -10px;
    line-height: 1;
    color: rgba(255,255,255,0.025);
    white-space: nowrap;
    user-select: none;
    pointer-events: none;
}

.fx-philosophy-side-text {
    position: relative;
    z-index: 1;
    max-width: 300px;
    padding-left: 26px;
    border-left: 1px solid rgba(181, 142, 92, 0.4);
    font-size: 22px;
    line-height: 1.6;
    letter-spacing: -0.5px;
    color: rgba(255,255,255,0.82);
}

.fx-philosophy-content {
    position: relative;
    z-index: 1;
}

.fx-philosophy-content h2 {
    margin-bottom: 32px;
    font-size: clamp(40px, 4.6vw, 74px);
    line-height: 1.02;
    letter-spacing: -3px;
    font-weight: 600;
    color: #ffffff;
}

.fx-philosophy-content p {
    max-width: 720px;
    margin-bottom: 24px;
    font-size: 18px;
    line-height: 1.9;
    color: rgba(255,255,255,0.68);
}

.fx-philosophy-quote {
    margin-top: 55px;
    padding-top: 28px;
    border-top: 1px solid rgba(181, 142, 92, 0.22);
    font-size: 30px;
    line-height: 1.45;
    letter-spacing: -1px;
    font-weight: 500;
    color: #d2ae7d;
}

@media (max-width: 1199px) {
    .fx-philosophy-wrapper {
        padding: 75px 60px;
    }
}

@media (max-width: 991px) {
    .fx-philosophy-section {
        padding: 110px 0;
    }

    .fx-philosophy-wrapper {
        padding: 60px 40px;
        border-radius: 30px;
    }

    .fx-philosophy-side-text {
        max-width: 100%;
    }

    .fx-philosophy-content h2 {
        letter-spacing: -2px;
    }
}

@media (max-width: 767px) {
    .fx-philosophy-section {
        padding: 80px 0;
    }

    .fx-philosophy-wrapper {
        padding: 45px 28px;
        border-radius: 24px;
    }

    .fx-philosophy-bg-text {
        display: none;
    }

    .fx-philosophy-side-text {
        font-size: 19px;
        margin-bottom: 35px;
    }

    .fx-philosophy-content h2 {
        font-size: 38px;
        letter-spacing: -1.5px;
    }

    .fx-philosophy-content p {
        font-size: 16px;
        line-height: 1.8;
    }

    .fx-philosophy-quote {
        font-size: 24px;
        line-height: 1.5;
    }
}


/* Final CTA Form Section */
.fx-final-cta {
    position: relative;
    padding: 140px 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 85% 15%, rgba(181, 142, 92, 0.12) 0%, rgba(181, 142, 92, 0) 35%),
        linear-gradient(135deg, #f9f6f1 0%, #ffffff 48%, #efe8dc 100%);
}

.fx-final-cta::before {
    content: "";
    position: absolute;
    left: -160px;
    bottom: -160px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(181, 142, 92, 0.08);
    filter: blur(12px);
}

.fx-final-cta .container {
    position: relative;
    z-index: 2;
}

.fx-contact-details {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 36px;
}

.fx-contact-details a {
    width: fit-content;
    font-size: 18px;
    line-height: 1.4;
    color: #191715;
    font-weight: 600;
    transition: all 0.3s ease;
}

.fx-contact-details a:hover {
    color: #b58e5c;
    transform: translateX(4px);
}

.fx-form-card {
    position: relative;
    padding: 48px;
    border: 1px solid rgba(181, 142, 92, 0.20);
    border-radius: 34px;
    background: rgba(255,255,255,0.82);
    box-shadow: 0 34px 100px rgba(50, 42, 32, 0.12);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    overflow: hidden;
}

.fx-form-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(145deg, rgba(181, 142, 92, 0.12), rgba(255,255,255,0) 45%);
    pointer-events: none;
}

.fx-form-card form {
    position: relative;
    z-index: 1;
}

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

.fx-form-card input,
.fx-form-card select,
.fx-form-card textarea {
    width: 100%;
    margin-bottom: 18px;
    padding: 18px 20px;
    border: 1px solid rgba(25, 23, 21, 0.10);
    border-radius: 16px;
    background: rgba(255,255,255,0.92);
    color: #191715;
    font-size: 15px;
    line-height: 1.4;
    outline: none;
    transition: all 0.3s ease;
}

.fx-form-card textarea {
    resize: none;
}

.fx-form-card input::placeholder,
.fx-form-card textarea::placeholder {
    color: rgba(25, 23, 21, 0.46);
}

.fx-form-card input:focus,
.fx-form-card select:focus,
.fx-form-card textarea:focus {
    border-color: rgba(181, 142, 92, 0.55);
    box-shadow: 0 0 0 4px rgba(181, 142, 92, 0.10);
}

.fx-submit-btn {
    width: 100%;
    min-height: 58px;
    border: none;
    border-radius: 100px;
    background: #191715;
    color: #ffffff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.3px;
    text-transform: uppercase;
    box-shadow: 0 20px 46px rgba(25, 23, 21, 0.18);
    transition: all 0.35s ease;
}

.fx-submit-btn:hover {
    transform: translateY(-3px);
    background: #b58e5c;
    box-shadow: 0 24px 54px rgba(181, 142, 92, 0.30);
}

@media (max-width: 1199px) {
    .fx-final-cta {
        padding: 115px 0;
    }
}

@media (max-width: 991px) {
    .fx-final-cta {
        padding: 90px 0;
    }

    .fx-form-card {
        padding: 38px;
    }
}

@media (max-width: 767px) {
    .fx-final-cta {
        padding: 80px 0;
    }

    .fx-form-card {
        padding: 30px 24px;
        border-radius: 24px;
    }

    .fx-form-row {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .fx-contact-details a {
        font-size: 16px;
    }
}


/* Offer Highlights Section */
.fx-offer-highlights {
    position: relative;
    padding: 125px 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 18%, rgba(181, 142, 92, 0.12) 0%, rgba(181, 142, 92, 0) 34%),
        linear-gradient(180deg, #f9f6f1 0%, #ffffff 100%);
}

.fx-offer-highlights::before {
    content: "";
    position: absolute;
    top: -160px;
    right: -140px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(181, 142, 92, 0.08);
    filter: blur(14px);
}

.fx-offer-highlights .container {
    position: relative;
    z-index: 2;
}

.fx-offers-eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.4px;
    text-transform: uppercase;
    color: #9b7447;
}

.fx-offers-eyebrow::before,
.fx-offers-eyebrow::after {
    content: "";
    width: 38px;
    height: 1px;
    background: rgba(181, 142, 92, 0.8);
}

.fx-offers-title {
    max-width: 820px;
    margin: 0 auto 24px;
    font-size: clamp(38px, 4.3vw, 64px);
    line-height: 1.04;
    letter-spacing: -0.6px;
    font-weight: 600;
    color: #191715;
}

.fx-offers-subtitle {
    max-width: 760px;
    margin: 0 auto;
    font-size: 18px;
    line-height: 1.78;
    color: #655f58;
}

.fx-offer-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
}

.fx-offer-card {
    position: relative;
    min-height: 330px;
    padding: 42px 38px;
    border: 1px solid rgba(181, 142, 92, 0.18);
    border-radius: 30px;
    background: rgba(255,255,255,0.82);
    box-shadow: 0 28px 80px rgba(50, 42, 32, 0.08);
    overflow: hidden;
    transition: all 0.4s ease;
}

.fx-offer-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(145deg, rgba(181, 142, 92, 0.16), rgba(255,255,255,0) 48%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.fx-offer-card:hover {
    transform: translateY(-8px);
    border-color: rgba(181, 142, 92, 0.38);
    box-shadow: 0 36px 95px rgba(50, 42, 32, 0.13);
}

.fx-offer-card:hover::before {
    opacity: 1;
}

.fx-offer-card-dark {
    background: #191715;
    border-color: rgba(255,255,255,0.10);
}

.fx-offer-card-featured {
    background:
        linear-gradient(145deg, rgba(181, 142, 92, 0.92), rgba(155, 116, 71, 0.96));
    border-color: rgba(181, 142, 92, 0.45);
    transform: translateY(-24px);
}

.fx-offer-card-featured:hover {
    transform: translateY(-32px);
}

.fx-offer-label {
    position: relative;
    z-index: 1;
    display: inline-block;
    margin-bottom: 42px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #b58e5c;
}

.fx-offer-label::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -18px;
    width: 42px;
    height: 1px;
    background: rgba(181, 142, 92, 0.55);
}

.fx-offer-card h3 {
    position: relative;
    z-index: 1;
    margin-bottom: 18px;
    font-size: clamp(42px, 4.5vw, 72px);
    line-height: 0.95;
    letter-spacing: -3px;
    font-weight: 600;
    color: #191715;
}

.fx-offer-card p {
    position: relative;
    z-index: 1;
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
    color: #655f58;
}

.fx-offer-card-dark h3,
.fx-offer-card-dark p {
    color: #ffffff;
}

.fx-offer-card-dark p {
    color: rgba(255,255,255,0.68);
}

.fx-offer-card-featured .fx-offer-label,
.fx-offer-card-featured h3,
.fx-offer-card-featured p {
    color: #ffffff;
}

.fx-offer-card-featured .fx-offer-label::after {
    background: rgba(255,255,255,0.5);
}

.fx-offer-card-featured p {
    color: rgba(255,255,255,0.78);
}

@media (max-width: 1199px) {
    .fx-offer-highlights {
        padding: 105px 0;
    }

    .fx-offer-cards {
        gap: 20px;
    }

    .fx-offer-card {
        padding: 36px 30px;
    }
}

@media (max-width: 991px) {
    .fx-offer-cards {
        grid-template-columns: 1fr;
    }

    .fx-offer-card,
    .fx-offer-card-featured,
    .fx-offer-card-featured:hover {
        transform: none;
    }

    .fx-offer-card {
        min-height: auto;
    }
}

@media (max-width: 767px) {
    .fx-offer-highlights {
        padding: 80px 0;
    }

    .fx-offers-title {
        letter-spacing: 1.6px;
    }

    .fx-offers-subtitle {
        font-size: 16px;
    }

    .fx-offer-card {
        padding: 32px 26px;
        border-radius: 24px;
    }
}


.fx-offers-page {
    background: #fbf8f3;
    color: #191715;
}

.fx-offers-hero {
    padding: 120px 0 90px;
    background: linear-gradient(135deg, #fbf8f3 0%, #ffffff 55%, #efe7dc 100%);
}

.fx-offers-hero-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 70px;
    align-items: center;
}

.fx-kicker {
    display: block;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.5px;
    color: #9b7447;
}

.fx-offers-copy h1 {
    margin-bottom: 26px;
    font-size: clamp(48px, 6vw, 86px);
    line-height: .95;
    letter-spacing: -4px;
    font-weight: 600;
}

.fx-lead {
    max-width: 560px;
    margin-bottom: 36px;
    font-size: 19px;
    line-height: 1.75;
    color: #5f5a54;
}

.fx-offer-box {
    width: fit-content;
    padding: 24px 34px;
    margin-bottom: 28px;
    border: 1px solid rgba(181,142,92,.28);
    border-radius: 24px;
    background: rgba(255,255,255,.72);
    box-shadow: 0 22px 60px rgba(50,42,32,.08);
}

.fx-offer-box span {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #9b7447;
}

.fx-offer-box strong {
    display: block;
    font-size: 64px;
    line-height: 1;
    letter-spacing: -3px;
    font-weight: 600;
}

.fx-offer-box p {
    margin: 4px 0 0;
    color: #5f5a54;
}

.fx-featured-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 180px));
    gap: 8px 22px;
    padding: 0;
    margin: 0 0 28px;
    list-style: none;
}

.fx-featured-list a {
    color: #191715;
    font-weight: 500;
}

.fx-bundle-note {
    margin-bottom: 34px;
    font-size: 20px;
    line-height: 1.5;
}

.fx-bundle-note strong {
    color: #9b7447;
}

.fx-hero-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

.fx-btn-primary,
.fx-btn-secondary,
.fx-btn-light {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 0 30px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.1px;
    transition: .35s ease;
}

.fx-btn-primary {
    background: #191715;
    color: #fff;
}

.fx-btn-secondary {
    border: 1px solid rgba(25,23,21,.22);
    color: #191715;
}

.fx-btn-light {
    background: #fff;
    color: #191715;
}

.fx-btn-primary:hover,
.fx-btn-secondary:hover,
.fx-btn-light:hover {
    transform: translateY(-3px);
    background: #b58e5c;
    border-color: #b58e5c;
    color: #fff;
}

.fx-offers-visual {
    position: relative;
    border-radius: 36px;
    overflow: hidden;
    box-shadow: 0 40px 120px rgba(50,42,32,.16);
}

.fx-offers-visual img {
    width: 100%;
    height: 720px;
    object-fit: cover;
    display: block;
}

.fx-floating-badge {
    position: absolute;
    left: 34px;
    bottom: 34px;
    padding: 22px 26px;
    border-radius: 20px;
    background: rgba(255,255,255,.82);
    backdrop-filter: blur(16px);
}

.fx-floating-badge span {
    display: block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #9b7447;
}

.fx-floating-badge strong {
    font-size: 24px;
    color: #191715;
}

.fx-products-section,
.fx-categories-section {
    padding: 105px 0;
    background: #fff;
}

.fx-section-head {
    max-width: 760px;
    margin: 0 auto 55px;
    text-align: center;
}

.fx-section-head span {
    display: block;
    margin-bottom: 14px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.4px;
    color: #9b7447;
}

.fx-section-head h2 {
    margin: 0;
    font-size: clamp(36px, 4vw, 60px);
    line-height: 1.05;
    letter-spacing: -2.4px;
    font-weight: 600;
}

.fx-product-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}

.fx-product-card {
    min-height: 260px;
    padding: 34px;
    border-radius: 28px;
    border: 1px solid rgba(181,142,92,.18);
    background: #fbf8f3;
    transition: .35s ease;
}

.fx-product-card:hover {
    transform: translateY(-8px);
    background: #191715;
}

.fx-product-card h3 {
    margin-bottom: 14px;
    font-size: 26px;
    color: #191715;
}

.fx-product-card p {
    margin: 0;
    line-height: 1.7;
    color: #655f58;
}

.fx-product-card:hover h3,
.fx-product-card:hover p {
    color: #fff;
}

.fx-upgrade-section {
    padding: 100px 0;
    background: #191715;
}

.fx-upgrade-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
    padding: 70px;
    border-radius: 36px;
    background: radial-gradient(circle at top right, rgba(181,142,92,.22), rgba(255,255,255,.04) 45%);
    border: 1px solid rgba(255,255,255,.08);
}

.fx-upgrade-box h2 {
    max-width: 720px;
    margin-bottom: 18px;
    font-size: clamp(38px, 4vw, 66px);
    line-height: 1.02;
    letter-spacing: -0.6px;
    color: #fff;
}

.fx-upgrade-box p {
    max-width: 680px;
    margin: 0;
    font-size: 18px;
    line-height: 1.75;
    color: rgba(255,255,255,.68);
}

.fx-category-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.fx-category-grid a {
    padding: 24px 26px;
    border-radius: 18px;
    background: #fbf8f3;
    color: #191715;
    font-weight: 600;
    transition: .3s ease;
}

.fx-category-grid a:hover {
    background: #191715;
    color: #fff;
    transform: translateY(-4px);
}

.fx-final-offer-cta {
    padding: 120px 0;
    text-align: center;
    background: linear-gradient(180deg, #fbf8f3 0%, #efe7dc 100%);
}

.fx-final-offer-cta h2 {
    max-width: 780px;
    margin: 0 auto 22px;
    font-size: clamp(38px, 4vw, 64px);
    line-height: 1.05;
    letter-spacing: -2.4px;
    font-weight: 600;
}

.fx-final-offer-cta p {
    max-width: 680px;
    margin: 0 auto 34px;
    font-size: 18px;
    line-height: 1.75;
    color: #655f58;
}

@media (max-width: 991px) {
    .fx-offers-hero-grid,
    .fx-product-grid,
    .fx-category-grid {
        grid-template-columns: 1fr 1fr;
    }

    .fx-offers-hero-grid {
        gap: 45px;
    }

    .fx-offers-visual img {
        height: 560px;
    }

    .fx-upgrade-box {
        display: block;
        padding: 50px;
    }

    .fx-upgrade-box .fx-btn-light {
        margin-top: 30px;
    }
}

@media (max-width: 767px) {
    .fx-offers-hero,
    .fx-products-section,
    .fx-categories-section,
    .fx-upgrade-section,
    .fx-final-offer-cta {
        padding: 75px 0;
    }

    .fx-offers-hero-grid,
    .fx-product-grid,
    .fx-category-grid {
        grid-template-columns: 1fr;
    }

    .fx-offers-copy h1,
    .fx-section-head h2,
    .fx-final-offer-cta h2 {
        letter-spacing: 1.6px;
    }

    .fx-offers-visual {
        border-radius: 24px;
    }

    .fx-offers-visual img {
        height: 430px;
    }

    .fx-featured-list {
        grid-template-columns: 1fr;
    }

    .fx-upgrade-box {
        padding: 34px 28px;
        border-radius: 26px;
    }
}


.fx-upgrade-section {
    padding: 110px 0;
    background: #191715;
}

.fx-upgrade-box {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 60px;
    padding: 40px;
    border-radius: 36px;
    background:
        radial-gradient(circle at top right,
        rgba(181,142,92,.22),
        rgba(255,255,255,.04) 45%);
    border: 1px solid rgba(255,255,255,.08);
}

.fx-upgrade-image {
    overflow: hidden;
    border-radius: 28px;
}

.fx-upgrade-image img {
    width: 100%;
    height: 520px;
    object-fit: cover;
    display: block;
}

.fx-upgrade-content h2 {
    max-width: 600px;
    margin-bottom: 20px;
    font-size: clamp(38px,4vw,66px);
    line-height: 1.02;
    letter-spacing: -2.5px;
    color: #fff;
}

.fx-upgrade-content p {
    max-width: 540px;
    margin-bottom: 35px;
    font-size: 18px;
    line-height: 1.8;
    color: rgba(255,255,255,.72);
}

@media (max-width:991px){

    .fx-upgrade-box{
        grid-template-columns:1fr;
        gap:40px;
        padding:30px;
    }

    .fx-upgrade-image img{
        height:420px;
    }

}

/* Klarna Intro Section */
.fx-klarna-intro {
    position: relative;
    padding: 125px 0;
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 18%, rgba(255, 179, 199, 0.22) 0%, rgba(255, 179, 199, 0) 34%),
        linear-gradient(135deg, #fffaf7 0%, #ffffff 50%, #f6eee8 100%);
}

.fx-klarna-intro .container {
    position: relative;
    z-index: 2;
}

.fx-klarna-intro-grid {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    gap: 70px;
    align-items: center;
}

.fx-klarna-kicker {
    display: block;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.5px;
    color: #9b7447;
}

.fx-klarna-copy h2 {
    max-width: 620px;
    margin-bottom: 26px;
    font-size: clamp(42px, 5vw, 76px);
    line-height: 1.02;
    letter-spacing: -3px;
    font-weight: 600;
    color: #191715;
}

.fx-klarna-copy p {
    max-width: 560px;
    margin-bottom: 42px;
    font-size: 18px;
    line-height: 1.8;
    color: #5f5a54;
}

.fx-klarna-benefits {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    max-width: 620px;
}

.fx-klarna-benefits div {
    padding: 24px 22px;
    border: 1px solid rgba(25, 23, 21, 0.08);
    border-radius: 22px;
    background: rgba(255,255,255,0.72);
    box-shadow: 0 22px 60px rgba(50, 42, 32, 0.06);
}

.fx-klarna-benefits span {
    display: block;
    margin-bottom: 14px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #d48aa2;
}

.fx-klarna-benefits strong {
    display: block;
    font-size: 15px;
    line-height: 1.45;
    color: #191715;
}

.fx-klarna-visual {
    position: relative;
    overflow: hidden;
    border-radius: 36px;
    box-shadow: 0 40px 120px rgba(50, 42, 32, 0.15);
}

.fx-klarna-visual img {
    display: block;
    width: 100%;
    height: 680px;
    object-fit: cover;
}

.fx-klarna-floating-card {
    position: absolute;
    right: 34px;
    bottom: 34px;
    width: 280px;
    padding: 28px;
    border-radius: 24px;
    background: rgba(255,255,255,0.86);
    box-shadow: 0 26px 70px rgba(0,0,0,0.14);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.fx-klarna-floating-card span {
    display: block;
    margin-bottom: 10px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #d48aa2;
}

.fx-klarna-floating-card strong {
    display: block;
    margin-bottom: 8px;
    font-size: 34px;
    line-height: 1.05;
    letter-spacing: -1.5px;
    color: #191715;
}

.fx-klarna-floating-card small {
    display: inline-block;
    padding: 7px 13px;
    border-radius: 10px;
    background: #ffb3c7;
    color: #191715;
    font-weight: 700;
}

@media (max-width: 991px) {
    .fx-klarna-intro {
        padding: 90px 0;
    }

    .fx-klarna-intro-grid {
        grid-template-columns: 1fr;
        gap: 45px;
    }

    .fx-klarna-visual img {
        height: 520px;
    }
}

@media (max-width: 767px) {
    .fx-klarna-intro {
        padding: 75px 0;
    }

    .fx-klarna-copy h2 {
        letter-spacing: -1.7px;
    }

    .fx-klarna-copy p {
        font-size: 16px;
    }

    .fx-klarna-benefits {
        grid-template-columns: 1fr;
    }

    .fx-klarna-visual {
        border-radius: 24px;
    }

    .fx-klarna-visual img {
        height: 420px;
    }

    .fx-klarna-floating-card {
        left: 20px;
        right: 20px;
        bottom: 20px;
        width: auto;
    }
}


/* KLARNA STEPS */
.fx-klarna-steps {
    padding: 130px 0;
    background: #ffffff;
}

.fx-section-title {
    max-width: 760px;
    margin: 0 auto 80px;
    text-align: center;
}

.fx-section-title span {
    display: block;
    margin-bottom: 16px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #d48aa2;
}

.fx-section-title h2 {
    margin-bottom: 20px;
    font-size: clamp(40px,4vw,64px);
    line-height: 1.05;
    letter-spacing: -2px;
    color: #191715;
}

.fx-section-title p {
    max-width: 600px;
    margin: 0 auto;
    font-size: 18px;
    line-height: 1.8;
    color: #666;
}

.fx-steps-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 30px;
}

.fx-step-card {
    position: relative;
    padding: 50px 40px;
    border-radius: 32px;
    background: #faf7f5;
    transition: .35s ease;
}

.fx-step-card:hover {
    transform: translateY(-8px);
}

.fx-step-featured {
    background: linear-gradient(
        135deg,
        #ffd8e5 0%,
        #fff3f7 100%
    );
}

.fx-step-number {
    margin-bottom: 40px;
    font-size: 72px;
    font-weight: 600;
    line-height: 1;
    letter-spacing: -3px;
    color: rgba(212,138,162,.25);
}

.fx-step-card h3 {
    margin-bottom: 18px;
    font-size: 28px;
    color: #191715;
}

.fx-step-card p {
    margin: 0;
    font-size: 16px;
    line-height: 1.8;
    color: #666;
}

@media(max-width:991px){

    .fx-steps-grid{
        grid-template-columns:1fr;
    }

}



/* WHY KLARNA */
.fx-klarna-benefits-section{
    padding:130px 0;
    background:#191715;
}

.fx-klarna-image{
    overflow:hidden;
    border-radius:32px;
}

.fx-klarna-image img{
    width:100%;
    height:700px;
    object-fit:cover;
    display:block;
}

.fx-benefits-kicker{
    display:block;
    margin-bottom:16px;
    font-size:12px;
    font-weight:700;
    letter-spacing:2px;
    color:#ffb3c7;
}

.fx-klarna-benefits-section h2{
    margin-bottom:24px;
    font-size:clamp(42px,4vw,68px);
    line-height:1.02;
    letter-spacing:-2px;
    color:#fff;
}

.fx-benefits-intro{
    margin-bottom:40px;
    font-size:18px;
    line-height:1.8;
    color:rgba(255,255,255,.75);
}

.fx-benefits-list{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.fx-benefit-item{
    display:flex;
    align-items:flex-start;
    gap:18px;
}

.fx-benefit-item span{
    width:34px;
    height:34px;
    border-radius:50%;
    background:#ffb3c7;
    color:#191715;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:700;
    flex-shrink:0;
}

.fx-benefit-item p{
    margin:0;
    font-size:17px;
    line-height:1.7;
    color:#fff;
}

@media(max-width:991px){

    .fx-klarna-benefits-section{
        padding:90px 0;
    }

    .fx-klarna-image{
        margin-bottom:40px;
    }

    .fx-klarna-image img{
        height:450px;
    }

}


/* KLARNA MEANING */
.fx-klarna-meaning {
    padding: 130px 0;
    background:
        radial-gradient(circle at 85% 15%, rgba(255, 179, 199, 0.20) 0%, rgba(255, 179, 199, 0) 34%),
        linear-gradient(180deg, #fffaf7 0%, #ffffff 100%);
}

.fx-meaning-header {
    max-width: 850px;
    margin: 0 auto 70px;
    text-align: center;
}

.fx-meaning-header span {
    display: block;
    margin-bottom: 16px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.4px;
    color: #d48aa2;
}

.fx-meaning-header h2 {
    margin-bottom: 22px;
    font-size: clamp(40px, 4vw, 66px);
    line-height: 1.05;
    letter-spacing: -2.5px;
    color: #191715;
}

.fx-meaning-header p {
    max-width: 680px;
    margin: 0 auto;
    font-size: 18px;
    line-height: 1.8;
    color: #666;
}

.fx-meaning-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.fx-meaning-card {
    min-height: 300px;
    padding: 42px 36px;
    border-radius: 30px;
    background: #ffffff;
    border: 1px solid rgba(25, 23, 21, 0.08);
    box-shadow: 0 28px 80px rgba(50, 42, 32, 0.07);
    transition: .35s ease;
}

.fx-meaning-card:hover {
    transform: translateY(-8px);
}

.fx-meaning-card span {
    display: block;
    margin-bottom: 44px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #d48aa2;
}

.fx-meaning-card h3 {
    margin-bottom: 14px;
    font-size: 27px;
    line-height: 1.2;
    color: #191715;
}

.fx-meaning-card p {
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
    color: #666;
}

@media(max-width:991px) {
    .fx-klarna-meaning {
        padding: 90px 0;
    }

    .fx-meaning-grid {
        grid-template-columns: 1fr;
    }

    .fx-meaning-card {
        min-height: auto;
    }
}


/* KLARNA FINAL CTA */
.fx-klarna-final {
    padding: 130px 0;
    background: #191715;
}

.fx-klarna-final-box {
    display: grid;
    grid-template-columns: 1.3fr 0.7fr;
    gap: 50px;
    align-items: end;
    padding: 75px;
    border-radius: 38px;
    background:
        radial-gradient(circle at top right, rgba(255, 179, 199, 0.22), rgba(255,255,255,0.04) 42%);
    border: 1px solid rgba(255,255,255,0.08);
}

.fx-klarna-final-content span {
    display: block;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.4px;
    color: #ffb3c7;
}

.fx-klarna-final-content h2 {
    max-width: 720px;
    margin-bottom: 24px;
    font-size: clamp(42px, 4.5vw, 74px);
    line-height: 1.02;
    letter-spacing: -3px;
    color: #ffffff;
}

.fx-klarna-final-content p {
    max-width: 650px;
    margin-bottom: 36px;
    font-size: 18px;
    line-height: 1.8;
    color: rgba(255,255,255,0.72);
}

.fx-klarna-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 34px;
    border-radius: 100px;
    background: #ffb3c7;
    color: #191715;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.2px;
    transition: .35s ease;
}

.fx-klarna-btn:hover {
    transform: translateY(-3px);
    background: #ffffff;
    color: #191715;
}

.fx-klarna-faq-note {
    padding: 34px;
    border-radius: 26px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.10);
}

.fx-klarna-faq-note strong {
    display: block;
    margin-bottom: 12px;
    font-size: 18px;
    color: #ffffff;
}

.fx-klarna-faq-note p {
    margin: 0;
    font-size: 15px;
    line-height: 1.75;
    color: rgba(255,255,255,0.66);
}

@media(max-width:991px) {
    .fx-klarna-final {
        padding: 90px 0;
    }

    .fx-klarna-final-box {
        grid-template-columns: 1fr;
        padding: 45px;
    }
}

@media(max-width:767px) {
    .fx-klarna-final-box {
        padding: 34px 26px;
        border-radius: 28px;
    }

    .fx-klarna-final-content h2 {
        letter-spacing: -1.8px;
    }
}



.flexy-hero-slide {
    min-height: 78vh;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

@media (max-width: 991px) {
    .flexy-hero-slide {
        min-height: 55vh;
    }
}


.flexy-categories-section {
    background: #fff;
    padding: 90px 0;
}

.flexy-categories-container {
    padding-left: 6%;
    padding-right: 6%;
}

.flexy-categories-heading {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 40px;
    margin-bottom: 50px;
}

.flexy-categories-heading span {
    display: block;
    margin-bottom: 18px;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 3px;
    color: #777;
    font-weight: 500;
}

.flexy-categories-heading h2 {
    margin: 0;
    font-size: clamp(34px, 4vw, 64px);
    line-height: 1.08;
    font-weight: 400;
    letter-spacing: -1.5px;
    color: #1f1f1f;
}

.flexy-categories-heading h2 strong {
    font-weight: 600;
}

.flexy-categories-heading p {
    max-width: 420px;
    margin: 0 0 10px;
    font-size: 18px;
    line-height: 1.65;
    color: #666;
}

.flexy-main-categories {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.flexy-category-card {
    display: block;
    text-decoration: none;
    color: inherit;
    background: #fff;
    border: 1px solid #eeeeee;
    border-radius: 8px;
    overflow: hidden;
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.flexy-category-card:hover {
    transform: translateY(-6px);
    border-color: #dedede;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.08);
}

.flexy-category-card img {
    width: 100%;
    height: 360px;
    object-fit: cover;
    display: block;
    transition: transform .6s ease;
}

.flexy-category-card:hover img {
    transform: scale(1.04);
}

.flexy-category-content {
    min-height: 135px;
    padding: 30px 34px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 25px;
    background: #fff;
}

.flexy-category-content h3 {
    margin: 0 0 10px;
    font-size: 25px;
    line-height: 1.2;
    font-weight: 500;
    color: #1f1f1f;
    letter-spacing: -0.5px;
}

.flexy-category-content p {
    margin: 0;
    font-size: 16px;
    line-height: 1.55;
    color: #666;
}

.flexy-category-content span,
.flexy-small-category > span {
    font-size: 28px;
    line-height: 1;
    color: #1f1f1f;
    transition: transform .3s ease;
}

.flexy-category-card:hover .flexy-category-content span,
.flexy-small-category:hover > span {
    transform: translateX(6px);
}

.flexy-secondary-categories {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 48px;
    border-top: 1px solid #ececec;
}

.flexy-small-category {
    min-height: 145px;
    display: grid;
    grid-template-columns: 70px 1fr auto;
    align-items: center;
    gap: 25px;
    padding: 30px 36px;
    text-decoration: none;
    color: inherit;
    border-right: 1px solid #ececec;
    transition: background .3s ease;
}

.flexy-small-category:last-child {
    border-right: 0;
}

.flexy-small-category:hover {
    background: #fafafa;
}

.flexy-small-icon {
    width: 54px;
    height: 54px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 42px;
    line-height: 1;
    color: #333;
}

.flexy-small-category h4 {
    margin: 0 0 8px;
    font-size: 21px;
    line-height: 1.25;
    font-weight: 500;
    color: #1f1f1f;
}

.flexy-small-category p {
    margin: 0;
    font-size: 15px;
    line-height: 1.5;
    color: #666;
}

@media (max-width: 1199px) {
    .flexy-category-card img {
        height: 300px;
    }
}

@media (max-width: 991px) {
    .flexy-categories-section {
        padding: 70px 0;
    }

    .flexy-categories-heading {
        display: block;
    }

    .flexy-categories-heading p {
        margin-top: 25px;
    }

    .flexy-main-categories,
    .flexy-secondary-categories {
        grid-template-columns: 1fr;
    }

    .flexy-small-category {
        border-right: 0;
        border-bottom: 1px solid #ececec;
    }

    .flexy-small-category:last-child {
        border-bottom: 0;
    }
}

@media (max-width: 575px) {
    .flexy-categories-container {
        padding-left: 22px;
        padding-right: 22px;
    }

    .flexy-category-card img {
        height: 260px;
    }

    .flexy-category-content {
        padding: 24px;
    }

    .flexy-small-category {
        grid-template-columns: 48px 1fr auto;
        gap: 18px;
        padding: 25px 0;
    }

    .flexy-small-icon {
        width: 42px;
        height: 42px;
        font-size: 32px;
    }
}



.flexy-why-section {
    background: #f7f4ef;
    overflow: hidden;
}

.flexy-why-grid {
    display: grid;
    grid-template-columns: 45% 55%;
    min-height: 720px;
}

.flexy-why-image {
    position: relative;
    overflow: hidden;
}

.flexy-why-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.flexy-why-content {
    background: #fbfaf7;
    padding: 90px 8vw 70px 6vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.flexy-eyebrow {
    display: inline-block;
    margin-bottom: 24px;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 3px;
    color: #2b2b2b;
    font-weight: 500;
}

.flexy-eyebrow::after {
    content: "";
    display: block;
    width: 50px;
    height: 1px;
    background: #b3945d;
    margin-top: 20px;
}

.flexy-why-content h2 {
    margin: 0 0 28px;
    font-size: clamp(42px, 4.2vw, 72px);
    line-height: 1.08;
    font-weight: 400;
    letter-spacing: -1.8px;
    color: #171717;
}

.flexy-why-content h2 strong {
    color: #a98c5a;
    font-weight: 500;
}

.flexy-why-content p {
    max-width: 720px;
    margin: 0 0 52px;
    font-size: 18px;
    line-height: 1.75;
    color: #4f4f4f;
}

.flexy-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    margin-bottom: 45px;
}

.flexy-stats > div {
    padding: 0 8px;
    border-right: 1px solid #ddd4c7;
}

.flexy-stats > div:first-child {
    padding-left: 0;
}

.flexy-stats > div:last-child {
    border-right: 0;
}

.flexy-stat-icon {
    display: block;
    margin-bottom: 16px;
    font-size: 24px;
    line-height: 1;
    color: #a98c5a;
}

.flexy-stats strong {
    display: block;
    margin-bottom: 8px;
    font-size: 22px;
    line-height: 1;
    font-weight: 500;
    color: #171717;
    letter-spacing: -1px;
}

.flexy-stats small {
    display: block;
    font-size: 11px;
    line-height: 1.55;
    letter-spacing: 1.1px;
    color: #444;
}

.flexy-why-btn {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    gap: 28px;
    padding: 18px 38px;
    background: #111;
    color: #fff;
    font-size: 13px;
    line-height: 1;
    letter-spacing: 2px;
    font-weight: 500;
    text-decoration: none;
    transition: all .3s ease;
}

.flexy-why-btn:hover {
    background: #a98c5a;
    color: #fff;
}

.flexy-why-btn span {
    font-size: 20px;
    line-height: 1;
}

.flexy-tech-strip {
    display: grid;
    grid-template-columns: 1.15fr repeat(4, 1fr);
    background: #f4f0e8;
    border-top: 1px solid #e4ddd1;
    padding: 38px 4.5vw;
}

.flexy-tech-title,
.flexy-tech-item {
    min-height: 95px;
    display: flex;
    align-items: center;
    border-right: 1px solid #ded6c8;
    padding: 0 34px;
}

.flexy-tech-title {
    padding-left: 0;
}

.flexy-tech-item:last-child {
    border-right: 0;
}

.flexy-tech-title span {
    font-size: 12px;
    line-height: 1;
    letter-spacing: 2.5px;
    color: #2b2b2b;
    font-weight: 500;
}

.flexy-tech-title span::after {
    content: "";
    display: block;
    width: 44px;
    height: 1px;
    background: #b3945d;
    margin-top: 18px;
}

.flexy-tech-item {
    gap: 22px;
}

.flexy-tech-item > span {
    min-width: 48px;
    font-size: 42px;
    line-height: 1;
    color: #a98c5a;
}

.flexy-tech-item strong {
    display: block;
    margin-bottom: 7px;
    font-size: 14px;
    letter-spacing: 2px;
    color: #171717;
    font-weight: 600;
}

.flexy-tech-item p {
    margin: 0;
    font-size: 15px;
    line-height: 1.45;
    color: #555;
}

@media (max-width: 1199px) {
    .flexy-why-grid {
        grid-template-columns: 1fr;
    }

    .flexy-why-image {
        height: 520px;
    }

    .flexy-tech-strip {
        grid-template-columns: repeat(2, 1fr);
    }

    .flexy-tech-title,
    .flexy-tech-item {
        border-bottom: 1px solid #ded6c8;
    }
}

@media (max-width: 767px) {
    .flexy-why-content {
        padding: 60px 28px;
    }

    .flexy-why-image {
        height: 390px;
    }

    .flexy-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: 30px 0;
    }

    .flexy-stats > div {
        padding: 0 20px 0 0;
    }

    .flexy-tech-strip {
        grid-template-columns: 1fr;
        padding: 30px 28px;
    }

    .flexy-tech-title,
    .flexy-tech-item {
        border-right: 0;
        padding: 25px 0;
    }
}


.flexy-best-section {
    background: #fbfaf7;
    padding: 95px 0 0;
}

.flexy-best-container {
    padding: 0 4.5vw;
}

.flexy-best-heading {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 40px;
    margin-bottom: 46px;
}

.flexy-best-heading span {
    display: block;
    margin-bottom: 18px;
    font-size: 12px;
    letter-spacing: 3px;
    color: #a98c5a;
    font-weight: 600;
}

.flexy-best-heading h2 {
    margin: 0 0 18px;
    font-size: clamp(38px, 4vw, 64px);
    line-height: 1.08;
    font-weight: 400;
    letter-spacing: -1.5px;
    color: #171717;
}

.flexy-best-heading p {
    max-width: 620px;
    margin: 0;
    font-size: 18px;
    line-height: 1.65;
    color: #555;
}

.flexy-best-heading > a {
    display: inline-flex;
    align-items: center;
    gap: 30px;
    padding-bottom: 10px;
    border-bottom: 1px solid #a98c5a;
    color: #171717;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 2.5px;
    font-weight: 600;
    white-space: nowrap;
}

.flexy-best-heading > a span {
    margin: 0;
    font-size: 28px;
    letter-spacing: 0;
    line-height: 1;
}

.flexy-products-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
}

.flexy-product-card {
    display: grid;
    grid-template-columns: 58% 42%;
    background: #fff;
    border: 1px solid #eee7dc;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.04);
}

.flexy-product-image {
    overflow: hidden;
}

.flexy-product-image img {
    width: 100%;
    height: 100%;
    min-height: 330px;
    object-fit: cover;
    display: block;
    transition: transform .6s ease;
}

.flexy-product-card:hover .flexy-product-image img {
    transform: scale(1.04);
}

.flexy-product-info {
    padding: 34px 34px 28px;
    display: flex;
    flex-direction: column;
}

.flexy-badge {
    width: fit-content;
    display: inline-block;
    margin-bottom: 24px;
    padding: 7px 13px;
    background: #b3945d;
    color: #fff;
    font-size: 11px;
    letter-spacing: 1.6px;
    font-weight: 600;
}

.flexy-product-info h3 {
    margin: 0 0 18px;
    font-size: 31px;
    line-height: 1.12;
    font-weight: 400;
    color: #171717;
    letter-spacing: -0.7px;
}

.flexy-firmness {
    margin: 0 0 25px;
    font-size: 15px;
    color: #555;
}

.flexy-firmness span {
    margin-left: 12px;
    color: #b3945d;
    font-size: 13px;
    letter-spacing: 4px;
}

.flexy-product-info ul {
    list-style: none;
    margin: 0;
    padding: 0 0 28px;
    border-bottom: 1px solid #e4ddd1;
}

.flexy-product-info li {
    position: relative;
    margin-bottom: 14px;
    padding-left: 22px;
    font-size: 15px;
    line-height: 1.45;
    color: #333;
}

.flexy-product-info li::before {
    content: "—";
    position: absolute;
    left: 0;
    top: 0;
    color: #a98c5a;
}

.flexy-product-info > a {
    margin-top: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 24px;
    color: #171717;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 1.8px;
    font-weight: 600;
}

.flexy-product-info > a span {
    font-size: 25px;
    color: #a98c5a;
    transition: transform .3s ease;
}

.flexy-product-info > a:hover span {
    transform: translateX(6px);
}

@media (max-width: 1199px) {
    .flexy-product-card {
        grid-template-columns: 1fr;
    }

    .flexy-product-image img {
        min-height: 300px;
    }
}

@media (max-width: 991px) {
    .flexy-best-heading {
        display: block;
    }

    .flexy-best-heading > a {
        margin-top: 30px;
    }

    .flexy-products-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575px) {
    .flexy-best-section {
        padding-top: 70px;
    }

    .flexy-best-container {
        padding: 0 22px;
    }

    .flexy-product-info {
        padding: 28px 24px;
    }

    .flexy-product-info h3 {
        font-size: 27px;
    }
}


.flexy-tech-mood-section {
    background: #fbfaf7;
    padding: 95px 4.5vw;
}

.flexy-tech-mood-bg {
    position: relative;
    min-height: 720px;
    border-radius: 18px;
    overflow: hidden;
    background-size: cover;
    background-position: center center;
}

.flexy-tech-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(10, 8, 6, 0.82) 0%, rgba(10, 8, 6, 0.62) 42%, rgba(10, 8, 6, 0.25) 100%);
}

.flexy-tech-mood-content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 860px;
    min-height: 720px;
    padding: 90px 7vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: #fff;
}

.flexy-tech-mood-content > span {
    display: block;
    margin-bottom: 24px;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 3px;
    color: #c8a66a;
    font-weight: 600;
}

.flexy-tech-mood-content h2 {
    margin: 0 0 28px;
    font-size: clamp(48px, 5.5vw, 86px);
    line-height: 1.05;
    font-weight: 400;
    letter-spacing: -2px;
    color: #fff;
}

.flexy-tech-mood-content p {
    max-width: 620px;
    margin: 0 0 48px;
    font-size: 18px;
    line-height: 1.75;
    color: rgba(255, 255, 255, 0.82);
}

.flexy-tech-features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 1px solid rgba(255,255,255,.22);
    border-bottom: 1px solid rgba(255,255,255,.22);
    margin-bottom: 42px;
}

.flexy-tech-features div {
    padding: 28px 24px;
    border-right: 1px solid rgba(255,255,255,.18);
}

.flexy-tech-features div:first-child {
    padding-left: 0;
}

.flexy-tech-features div:last-child {
    border-right: 0;
}

.flexy-tech-features strong {
    display: block;
    margin-bottom: 10px;
    font-size: 13px;
    line-height: 1.35;
    letter-spacing: 1.8px;
    color: #fff;
    font-weight: 600;
}

.flexy-tech-features small {
    display: block;
    font-size: 14px;
    line-height: 1.45;
    color: rgba(255,255,255,.72);
}

.flexy-tech-btn {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    gap: 30px;
    padding: 18px 36px;
    background: #fff;
    color: #171717;
    text-decoration: none;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 2px;
    font-weight: 600;
    transition: all .3s ease;
}

.flexy-tech-btn:hover {
    background: #c8a66a;
    color: #fff;
}

.flexy-tech-btn span {
    font-size: 22px;
    line-height: 1;
}

@media (max-width: 991px) {
    .flexy-tech-mood-section {
        padding: 70px 22px;
    }

    .flexy-tech-mood-bg {
        min-height: auto;
    }

    .flexy-tech-mood-content {
        min-height: 620px;
        padding: 65px 36px;
    }

    .flexy-tech-features {
        grid-template-columns: repeat(2, 1fr);
    }

    .flexy-tech-features div:nth-child(2) {
        border-right: 0;
    }
}

@media (max-width: 575px) {
    .flexy-tech-overlay {
        background: rgba(10, 8, 6, 0.72);
    }

    .flexy-tech-mood-content {
        padding: 55px 24px;
    }

    .flexy-tech-features {
        grid-template-columns: 1fr;
    }

    .flexy-tech-features div {
        border-right: 0;
        border-bottom: 1px solid rgba(255,255,255,.18);
        padding: 22px 0;
    }

    .flexy-tech-features div:last-child {
        border-bottom: 0;
    }
}



.flexy-showroom-section {
    background: #fbfaf7;
    padding: 95px 4.5vw;
}

.flexy-showroom-card {
    background: #fff;
    border: 1px solid #eee7dc;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 22px 70px rgba(0, 0, 0, 0.04);
}

.flexy-showroom-main {
    display: grid;
    grid-template-columns: 38% 62%;
    min-height: 760px;
}

.flexy-showroom-content {
    padding: 80px 5vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.flexy-showroom-eyebrow {
    display: block;
    margin-bottom: 28px;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 3px;
    color: #a98c5a;
    font-weight: 600;
}

.flexy-showroom-eyebrow::after {
    content: "";
    display: block;
    width: 48px;
    height: 1px;
    background: #a98c5a;
    margin-top: 20px;
}

.flexy-showroom-content h2 {
    margin: 0 0 28px;
    font-size: clamp(34px, 3.4vw, 58px);
    line-height: 0.98;
    font-weight: 400;
    letter-spacing: -2.2px;
    color: #171717;
}

.flexy-showroom-content h2 strong {
    color: #a98c5a;
    font-weight: 500;
}

.flexy-showroom-content p {
    max-width: 520px;
    margin: 0 0 38px;
    font-size: 17px;
    line-height: 1.75;
    color: #5d5d5d;
}

.flexy-showroom-actions {
    display: grid;
    gap: 16px;
    max-width: 420px;
    margin-bottom: 42px;
}

.flexy-showroom-actions a {
    min-height: 62px;
    padding: 0 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-decoration: none;
    font-size: 12px;
    line-height: 1.2;
    letter-spacing: 2px;
    font-weight: 600;
    transition: all .3s ease;
}

.flexy-showroom-btn-primary {
    background: #111;
    color: #fff;
}

.flexy-showroom-btn-primary:hover {
    background: #a98c5a;
    color: #fff;
}

.flexy-showroom-btn-secondary {
    background: transparent;
    color: #a98c5a;
    border: 1px solid #cdbb9d;
}

.flexy-showroom-btn-secondary:hover {
    background: #a98c5a;
    color: #fff;
    border-color: #a98c5a;
}

.flexy-showroom-actions span {
    font-size: 22px;
    line-height: 1;
}

.flexy-showroom-location {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-top: 10px;
}

.flexy-showroom-location span {
    font-size: 32px;
    color: #a98c5a;
    line-height: 1;
}

.flexy-showroom-location p {
    margin: 0;
    font-size: 12px;
    line-height: 1.4;
    letter-spacing: 2px;
    color: #333;
    font-weight: 600;
}

.flexy-showroom-image {
    overflow: hidden;
}

.flexy-showroom-image img {
    width: 100%;
    height: 100%;
    min-height: 760px;
    object-fit: cover;
    display: block;
    transition: transform .8s ease;
}

.flexy-showroom-card:hover .flexy-showroom-image img {
    transform: scale(1.035);
}

.flexy-showroom-benefits {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 1px solid #eee7dc;
    background: #fbfaf7;
}

.flexy-showroom-benefits div {
    min-height: 150px;
    display: grid;
    grid-template-columns: 54px 1fr;
    align-items: center;
    gap: 22px;
    padding: 34px 42px;
    border-right: 1px solid #eee7dc;
}

.flexy-showroom-benefits div:last-child {
    border-right: 0;
}

.flexy-showroom-benefits span {
    font-size: 38px;
    line-height: 1;
    color: #a98c5a;
}

.flexy-showroom-benefits p {
    margin: 0;
    font-size: 15px;
    line-height: 1.5;
    color: #555;
}

.flexy-showroom-benefits strong {
    color: #171717;
    font-weight: 600;
}

@media (max-width: 1199px) {
    .flexy-showroom-main {
        grid-template-columns: 1fr;
    }

    .flexy-showroom-image {
        order: -1;
    }

    .flexy-showroom-image img {
        min-height: 540px;
    }

    .flexy-showroom-benefits {
        grid-template-columns: repeat(2, 1fr);
    }

    .flexy-showroom-benefits div:nth-child(2) {
        border-right: 0;
    }

    .flexy-showroom-benefits div:nth-child(1),
    .flexy-showroom-benefits div:nth-child(2) {
        border-bottom: 1px solid #eee7dc;
    }
}

@media (max-width: 767px) {
    .flexy-showroom-section {
        padding: 70px 22px;
    }

    .flexy-showroom-content {
        padding: 55px 28px;
    }

    .flexy-showroom-content h2 {
        font-size: 52px;
    }

    .flexy-showroom-image img {
        min-height: 360px;
    }

    .flexy-showroom-benefits {
        grid-template-columns: 1fr;
    }

    .flexy-showroom-benefits div {
        grid-template-columns: 46px 1fr;
        padding: 28px 24px;
        border-right: 0;
        border-bottom: 1px solid #eee7dc;
    }

    .flexy-showroom-benefits div:last-child {
        border-bottom: 0;
    }
}


.flexy-video-brand-section {
    position: relative;
    min-height: 700px;
    overflow: hidden;
    background: #111;
}

.flexy-video-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.flexy-video-bg iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 120vw;
    height: 67.5vw;
    min-width: 100%;
    min-height: 100%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}

.flexy-video-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        90deg,
        rgba(0,0,0,.55) 0%,
        rgba(0,0,0,.40) 35%,
        rgba(0,0,0,.15) 70%,
        rgba(0,0,0,.05) 100%
    );
}

.flexy-video-content-wrap {
    position: relative;
    z-index: 2;
    min-height: 700px;
    display: flex;
    align-items: center;
    padding: 100px 0;
}

.flexy-video-content {
    max-width: 650px;
}

.flexy-video-eyebrow {
    display: block;
    margin-bottom: 25px;
    font-size: 13px;
    line-height: 1;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: #c8a977;
    font-weight: 600;
}

.flexy-video-content h2 {
    margin: 0 0 30px;
    font-size: 58px;
    line-height: 1.1;
    font-weight: 400;
    letter-spacing: -1.5px;
    color: #fff;
}

.flexy-video-content p {
    margin: 0;
    max-width: 540px;
    font-size: 19px;
    line-height: 1.9;
    color: rgba(255,255,255,.85);
}

@media (max-width: 991px) {

    .flexy-video-brand-section,
    .flexy-video-content-wrap {
        min-height: 600px;
    }

    .flexy-video-content-wrap {
        padding: 80px 0;
    }

    .flexy-video-content h2 {
        font-size: 46px;
        line-height: 1.15;
    }

    .flexy-video-content p {
        font-size: 18px;
    }
}

@media (max-width: 767px) {

    .flexy-video-brand-section,
    .flexy-video-content-wrap {
        min-height: 500px;
    }

    .flexy-video-content-wrap {
        padding: 70px 0;
    }

    .flexy-video-content h2 {
        font-size: 38px;
        line-height: 1.15;
    }

    .flexy-video-content p {
        font-size: 16px;
        line-height: 1.8;
    }
}


.flexy-best-section {
    padding: 140px 0;
    background: #f8f6f2;
}

.flexy-best-heading {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 60px;
    margin-bottom: 70px;
}

.flexy-best-heading h2 {
    font-size: 72px;
    line-height: 0.95;
    letter-spacing: -2px;
    margin: 15px 0 25px;
    color: #111;
}

.flexy-best-heading p {
    max-width: 520px;
    font-size: 18px;
    line-height: 1.8;
    color: #777;
}

.flexy-eyebrow {
    font-size: 12px;
    letter-spacing: 4px;
    color: #b89b63;
    text-transform: uppercase;
    font-weight: 600;
}

.flexy-view-all {
    color: #111;
    text-decoration: none;
    font-size: 13px;
    letter-spacing: 3px;
    text-transform: uppercase;
    white-space: nowrap;
    transition: .3s;
}

.flexy-view-all span {
    margin-left: 8px;
}

.flexy-products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}

.flexy-product-card {
    text-decoration: none;
    color: #111;
    display: block;
}

.flexy-product-card img {
    width: 100%;
    aspect-ratio: 1 / 1.15;
    object-fit: cover;
    border-radius: 26px;
    transition: .4s ease;
}

.flexy-product-card:hover img {
    transform: translateY(-6px);
}

.flexy-product-content {
    padding-top: 22px;
}

.flexy-product-content h3 {
    font-size: 30px;
    line-height: 1.15;
    font-weight: 400;
    margin-bottom: 12px;
    color: #111;
}

.flexy-product-content p {
    font-size: 14px;
    color: #8c8c8c;
    letter-spacing: .5px;
    margin: 0;
}

@media (max-width: 1199px) {

    .flexy-products-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .flexy-best-heading h2 {
        font-size: 56px;
    }
}

@media (max-width: 767px) {

    .flexy-best-section {
        padding: 90px 0;
    }

    .flexy-best-heading {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: 50px;
    }

    .flexy-best-heading h2 {
        font-size: 42px;
    }

    .flexy-products-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}


.flexy-best-section {
    background: #fbfaf7;
    padding: 100px 0;
}

.flexy-best-container {
    padding-left: 4.5vw;
    padding-right: 4.5vw;
}

.flexy-best-heading {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 60px;
    margin-bottom: 54px;
}

.flexy-best-eyebrow {
    display: block;
    font-size: 12px;
    letter-spacing: 4px;
    color: #b3945d;
    font-weight: 600;
    margin-bottom: 18px;
}

.flexy-best-eyebrow::after {
    content: "";
    display: block;
    width: 42px;
    height: 2px;
    background: #b3945d;
    margin-top: 16px;
}

.flexy-best-heading h2 {
    margin: 0 0 22px;
    font-size: clamp(48px, 4.8vw, 82px);
    line-height: .98;
    font-weight: 400;
    letter-spacing: -2.4px;
    color: #171717;
}

.flexy-best-heading h2 strong {
    color: #a98c5a;
    font-weight: 400;
}

.flexy-best-heading p {
    max-width: 620px;
    margin: 0;
    font-size: 18px;
    line-height: 1.7;
    color: #666;
}

.flexy-best-view-all {
    display: inline-flex;
    align-items: center;
    gap: 32px;
    color: #171717;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 3px;
    font-weight: 600;
    white-space: nowrap;
    padding-bottom: 12px;
    border-bottom: 1px solid #b3945d;
}

.flexy-best-view-all span {
    font-size: 26px;
    color: #b3945d;
}

.flexy-best-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 26px;
}

.flexy-best-card {
    display: block;
    background: #fff;
    color: #171717;
    text-decoration: none;
    border: 1px solid #eee7dc;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 22px 60px rgba(0, 0, 0, .045);
    transition: transform .35s ease, box-shadow .35s ease;
}

.flexy-best-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 28px 75px rgba(0, 0, 0, .07);
}

.flexy-best-image {
    position: relative;
    height: 320px;
    overflow: hidden;
}

.flexy-best-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .6s ease;
}

.flexy-best-card:hover .flexy-best-image img {
    transform: scale(1.04);
}

.flexy-best-badge {
    position: absolute;
    top: 28px;
    left: 28px;
    z-index: 2;
    padding: 10px 16px;
    background: #b3945d;
    color: #fff;
    font-size: 11px;
    line-height: 1;
    letter-spacing: 1.8px;
    font-weight: 600;
}

.flexy-best-info {
    padding: 26px 28px 28px;
}

.flexy-best-info h3 {
    margin: 0 0 14px;
    font-size: 28px;
    line-height: 1.08;
    font-weight: 400;
    letter-spacing: -1px;
    color: #171717;
}

.flexy-best-firmness {
    margin-bottom: 22px;
    font-size: 14px;
    color: #666;
}

.flexy-best-firmness span {
    display: inline-block;
    margin-left: 10px;
    color: #b3945d;
    font-size: 12px;
    letter-spacing: 4px;
}

.flexy-best-specs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    padding-bottom: 24px;
    margin-bottom: 22px;
    border-bottom: 1px solid #eee7dc;
}

.flexy-best-specs span {
    font-size: 13px;
    line-height: 1.4;
    color: #777;
}

.flexy-best-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    letter-spacing: 1.8px;
    font-weight: 600;
    color: #171717;
}

.flexy-best-link span {
    font-size: 24px;
    color: #b3945d;
    transition: transform .3s ease;
}

.flexy-best-card:hover .flexy-best-link span {
    transform: translateX(6px);
}

.flexy-best-bottom {
    display: flex;
    justify-content: center;
    gap: 60px;
    margin-top: 42px;
    color: #555;
    font-size: 12px;
    letter-spacing: 2.4px;
    font-weight: 600;
}

@media (max-width: 1199px) {
    .flexy-best-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .flexy-best-image {
        height: 340px;
    }
}

@media (max-width: 767px) {
    .flexy-best-section {
        padding: 75px 0;
    }

    .flexy-best-container {
        padding-left: 22px;
        padding-right: 22px;
    }

    .flexy-best-heading {
        display: block;
        margin-bottom: 42px;
    }

    .flexy-best-view-all {
        margin-top: 28px;
    }

    .flexy-best-grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .flexy-best-image {
        height: 280px;
    }

    .flexy-best-info h3 {
        font-size: 25px;
    }

    .flexy-best-bottom {
        display: block;
        text-align: center;
    }

    .flexy-best-bottom span {
        display: block;
        margin-bottom: 14px;
    }
}


.flexy-trust-section{
    padding:120px 0;
    background:#f7f5f1;
    border-top:1px solid #e8e3da;
}

.flexy-trust-heading{
    max-width:720px;
    margin:0 auto 80px;
    text-align:center;
}

.flexy-trust-heading span{
    display:block;
    font-size:11px;
    letter-spacing:3px;
    color:#b89a63;
    margin-bottom:20px;
    text-transform:uppercase;
}

.flexy-trust-heading h2{
    font-size:58px;
    line-height:1.05;
    font-weight:300;
    color:#111;
    margin-bottom:25px;
}

.flexy-trust-heading p{
    font-size:18px;
    line-height:1.9;
    color:#666;
    margin:0;
}

.flexy-trust-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:25px;
    margin-bottom:90px;
}

.flexy-trust-item{
    background:#fff;
    padding:40px;
    border:1px solid #ebe7de;
    border-radius:20px;
    transition:.3s;
}

.flexy-trust-item:hover{
    transform:translateY(-6px);
}

.flexy-trust-item h3{
    font-size:22px;
    margin-bottom:15px;
    color:#111;
}

.flexy-trust-item p{
    font-size:15px;
    line-height:1.8;
    color:#666;
    margin:0;
}

.flexy-trust-bottom{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    border-top:1px solid #ddd7ce;
    padding-top:50px;
}

.trust-stat{
    text-align:center;
}

.trust-stat strong{
    display:block;
    font-size:54px;
    font-weight:500;
    color:#111;
    margin-bottom:10px;
}

.trust-stat span{
    color:#777;
    font-size:14px;
    letter-spacing:1px;
    text-transform:uppercase;
}

@media(max-width:991px){

    .flexy-trust-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .flexy-trust-bottom{
        grid-template-columns:repeat(2,1fr);
        gap:40px;
    }

    .flexy-trust-heading h2{
        font-size:42px;
    }
}

@media(max-width:767px){

    .flexy-trust-grid{
        grid-template-columns:1fr;
    }

    .flexy-trust-bottom{
        grid-template-columns:1fr;
    }

    .flexy-trust-heading h2{
        font-size:34px;
    }
}

.flexy-why-section{
    padding-top:0 !important;
    padding-bottom:0 !important;
}
.fx-klarna-hero h1 {
  letter-spacing: 0 !important;
  word-spacing: 0.12em;
  font-kerning: normal;
  text-rendering: optimizeLegibility;
}


/* HERO IMAGE PATCH */

.mattress-hero.v4 .mattress-hero__media.v4 {
    align-items: flex-start !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 {
    aspect-ratio: auto !important;
    align-self: flex-start !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    object-position: top center !important;
    display: block !important;
}

/* HERO TOP ALIGN PATCH */

.mattress-hero.v4 .mattress-hero__grid.v4 {
    align-items: start !important;
}

.mattress-hero.v4 .mattress-hero__media.v4,
.mattress-hero.v4 .mattress-hero__card.v4 {
    align-self: start !important;
}

/* HERO IMAGE NO CROP / NO BOTTOM GAP PATCH */

.mattress-hero.v4 .mattress-hero__image-wrap.v4 {
    aspect-ratio: unset !important;
    height: auto !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
    transform: none !important;
}
/* HERO IMAGE HEIGHT PATCH */

.mattress-hero.v4 .mattress-hero__media.v4 {
    align-items: flex-start !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 {
    height: auto !important;
    align-self: flex-start !important;
    aspect-ratio: unset !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
}

/* HERO LEFT IMAGE FINAL PATCH */

.mattress-hero.v4 .mattress-hero__media.v4,
.mattress-hero.v4 .mattress-hero__image-wrap.v4 {
    height: fit-content !important;
    min-height: 0 !important;
    max-height: none !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 {
    aspect-ratio: unset !important;
}

.mattress-hero.v4 .mattress-hero__image-wrap.v4 img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    transform: none !important;
    display: block !important;
}

.medical-highlight{
    padding:100px 0;
}

.medical-highlight__box{
    background:linear-gradient(135deg,#b91c1c,#7f1d1d);
    color:#fff;
    border-radius:32px;
    padding:80px;
    text-align:center;
    position:relative;
    overflow:hidden;
}

.medical-highlight__box:before{
    content:"✓";
    position:absolute;
    right:-20px;
    top:-40px;
    font-size:240px;
    font-weight:700;
    opacity:.08;
    line-height:1;
}

.medical-highlight__eyebrow{
    display:inline-block;
    letter-spacing:3px;
    font-size:12px;
    font-weight:700;
    margin-bottom:15px;
    opacity:.85;
}

.medical-highlight h2{
    color:#fff;
    margin-bottom:20px;
    font-size:clamp(34px,4vw,58px);
}

.medical-highlight p{
    max-width:850px;
    margin:auto;
    opacity:.92;
    font-size:18px;
}
.winter-gel-highlights{
    padding:90px 0;
}

.winter-gel-highlights__grid{
    display:grid;
    grid-template-columns:1.45fr .9fr;
    gap:28px;
}

.winter-gel-card{
    position:relative;
    overflow:hidden;
    border-radius:32px;
    padding:64px;
    color:#fff;
    min-height:430px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}

.winter-gel-card--blue{
    background:linear-gradient(135deg,#0f5f9f 0%,#08395f 100%);
}

.winter-gel-card--red{
    background:linear-gradient(135deg,#b91c1c 0%,#7f1111 100%);
}

.winter-gel-card::before{
    position:absolute;
    right:-25px;
    top:-55px;
    font-size:220px;
    font-weight:800;
    line-height:1;
    opacity:.07;
}

.winter-gel-card--blue::before{
    content:"❄";
}

.winter-gel-card--red::before{
    content:"✓";
}

.winter-gel-card__eyebrow{
    display:inline-block;
    margin-bottom:18px;
    font-size:12px;
    font-weight:800;
    letter-spacing:3px;
    color:rgba(255,255,255,.78);
}

.winter-gel-card h2{
    color:#fff;
    max-width:760px;
    margin:0 0 22px;
    font-size:clamp(34px,4vw,58px);
    line-height:1.08;
    letter-spacing:-1.5px;
}

.winter-gel-card p{
    max-width:760px;
    margin:0;
    font-size:18px;
    line-height:1.75;
    color:rgba(255,255,255,.9);
}

.winter-gel-card__features{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:36px;
}

.winter-gel-card__features span{
    padding:11px 16px;
    border-radius:999px;
    background:rgba(255,255,255,.13);
    border:1px solid rgba(255,255,255,.18);
    color:#fff;
    font-size:14px;
    font-weight:700;
}

@media(max-width:991px){
    .winter-gel-highlights{
        padding:70px 0;
    }

    .winter-gel-highlights__grid{
        grid-template-columns:1fr;
    }

    .winter-gel-card{
        min-height:auto;
        padding:44px 30px;
        border-radius:26px;
    }
}

.winter-gel-highlights{
    padding:60px 0;
}

.winter-gel-highlights__grid{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:20px;
}

.winter-gel-card{
    border-radius:24px;
    padding:38px;
    min-height:auto;
}

.winter-gel-card::before{
    font-size:120px;
    right:-10px;
    top:-20px;
}

.winter-gel-card__eyebrow{
    margin-bottom:10px;
    font-size:11px;
    letter-spacing:2px;
}

.winter-gel-card h2{
    font-size:34px;
    margin-bottom:12px;
    line-height:1.15;
}

.winter-gel-card p{
    font-size:15px;
    line-height:1.6;
}

.winter-gel-card__features{
    margin-top:20px;
    gap:8px;
}

.winter-gel-card__features span{
    padding:8px 12px;
    font-size:12px;
}


/* Medical certification section - compact */

.medical-highlight{
    padding:50px 0 !important;
}

.medical-highlight__box{
    max-width:900px;
    margin:0 auto;
    padding:32px 40px !important;
    border-radius:20px;
}

.medical-highlight__eyebrow{
    font-size:11px;
    letter-spacing:2px;
    margin-bottom:10px;
}

.medical-highlight__box h2{
    font-size:32px;
    line-height:1.15;
    margin-bottom:12px;
}

.medical-highlight__box p{
    font-size:16px;
    line-height:1.7;
    margin-bottom:0;
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
}


.winter-gel-highlights{
    padding:45px 0 !important;
}

.winter-gel-highlights__grid{
    grid-template-columns:1.15fr .85fr !important;
    gap:18px !important;
}

.winter-gel-card{
    padding:34px !important;
    min-height:300px !important;
    border-radius:24px !important;
}

.winter-gel-card::before{
    font-size:110px !important;
    right:14px !important;
    top:8px !important;
    opacity:.045 !important;
}

.winter-gel-card h2{
    font-size:30px !important;
    line-height:1.15 !important;
    margin-bottom:14px !important;
    letter-spacing:-.8px;
}

.winter-gel-card p{
    font-size:15px !important;
    line-height:1.6 !important;
}

.winter-gel-card__features{
    margin-top:22px !important;
    gap:8px !important;
}

.winter-gel-card__features span{
    padding:8px 12px !important;
    font-size:12px !important;
    font-weight:600 !important;
}

.mattress-hero-highlights{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
    margin-top:16px;
}

.hero-highlight-card{
    background:#f5f1eb;
    border:1px solid #e8ddd2;
    border-radius:18px;
    padding:18px;
    transition:.3s ease;
}

.hero-highlight-card:hover{
    transform:translateY(-2px);
}

.hero-highlight-card__label{
    display:block;
    font-size:10px;
    font-weight:700;
    letter-spacing:2px;
    color:#8c725d;
    margin-bottom:8px;
}

.hero-highlight-card h4{
    font-size:18px;
    line-height:1.2;
    color:#5e4736;
    margin-bottom:6px;
}

.hero-highlight-card p{
    margin:0;
    font-size:14px;
    line-height:1.5;
    color:#7a6b5f;
}

@media(max-width:767px){

    .mattress-hero-highlights{
        grid-template-columns:1fr;
    }

}

.hero-mini-highlights{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    margin-top:18px;
}

.hero-mini-card{
    background:#f6f2ec;
    border:1px solid #e6ddd2;
    border-radius:18px;
    padding:18px;
}

.hero-mini-card span{
    display:block;
    font-size:11px;
    font-weight:700;
    letter-spacing:2px;
    color:#8b6d58;
    margin-bottom:8px;
}

.hero-mini-card h4{
    font-size:18px;
    line-height:1.2;
    margin-bottom:8px;
    color:#4f3a2c;
}

.hero-mini-card p{
    margin:0;
    font-size:14px;
    line-height:1.5;
    color:#7a6d62;
}

@media(max-width:767px){

    .hero-mini-highlights{
        grid-template-columns:1fr;
    }

}

.mattress-hero__media.v4{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
}

.mattress-hero__image-wrap.v4{
    width:100% !important;
}

.hero-mini-highlights{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    margin-top:16px;
    width:100%;
}

.hero-mini-card{
    min-height:140px;
}

.hero-mini-card--medical{
    border:1px solid rgba(199,33,39,.25);
}

.hero-medical-card{
    margin-top:18px;
    padding:24px 28px;
    background:#f7f3ee;
    border:1px solid rgba(199,33,39,.18);
    border-radius:18px;
    position:relative;
}

.hero-medical-card:before{
    content:"✓";
    position:absolute;
    right:22px;
    top:12px;
    font-size:42px;
    color:rgba(199,33,39,.10);
    font-weight:700;
}

.hero-medical-card__eyebrow{
    display:block;
    margin-bottom:10px;
    font-size:11px;
    letter-spacing:2px;
    text-transform:uppercase;
    font-weight:700;
    color:#c72127;
}

.hero-medical-card h3{
    font-size:28px;
    line-height:1.2;
    margin-bottom:10px;
    color:#4f4339;
}

.hero-medical-card p{
    margin:0;
    font-size:15px;
    line-height:1.75;
    color:#766d65;
}
.flexy-video-wrapper {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: 20px;
}

.flexy-video-wrapper iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.flexy-video-section {
    padding: 100px 0;
}

.flexy-video-wrapper {
    position: relative;
    width: 100%;
    max-width: 1180px;
    aspect-ratio: 16 / 9;
    margin: 45px auto 0;
    overflow: hidden;
    border-radius: 28px;
    background: #000;
}

.flexy-video-wrapper iframe {
    display: block;
    width: 100% !important;
    height: 100% !important;
    border: 0;
}
.fx-installments-page {
    background: #f7f3ee;
    color: #1d1d1d;
}

.fx-installments-page .container {
    max-width: 1220px;
}

.fx-installments-hero {
    padding: 90px 0;
    background: linear-gradient(135deg, #f7f3ee 0%, #eee6dc 100%);
}

.fx-installments-hero-grid {
    display: grid;
    grid-template-columns: 0.95fr 1.05fr;
    gap: 60px;
    align-items: center;
}

.fx-kicker {
    display: inline-block;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #8b8175;
}

.fx-installments-copy h1 {
    margin: 0 0 24px;
    font-size: clamp(40px, 4.8vw, 72px);
    line-height: 0.98;
    font-weight: 800;
    letter-spacing: -3px;
    color: #191919;
}

.fx-installments-copy p {
    max-width: 560px;
    margin: 0 0 34px;
    font-size: 19px;
    line-height: 1.7;
    color: #3b3936;
}

.fx-installments-values {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    max-width: 560px;
    margin-bottom: 34px;
}

.fx-installments-values div {
    padding: 24px 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.68);
    border: 1px solid rgba(0, 0, 0, 0.08);
    text-align: center;
}

.fx-installments-values strong {
    display: block;
    font-size: 34px;
    line-height: 1;
    font-weight: 800;
    color: #191919;
}

.fx-installments-values span {
    display: block;
    margin-top: 8px;
    font-size: 13px;
    font-weight: 700;
    color: #706860;
}

.fx-installments-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 14px 30px;
    border-radius: 999px;
    background: #191919;
    color: #fff;
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.25s ease;
}

.fx-installments-btn:hover {
    background: #3b3936;
    color: #fff;
    transform: translateY(-2px);
}

.fx-installments-visual {
    border-radius: 34px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 35px 80px rgba(0, 0, 0, 0.14);
}

.fx-installments-visual img {
    width: 100%;
    height: 620px;
    object-fit: cover;
    display: block;
}

.fx-installments-intro {
    padding: 70px 0;
    background: #fff;
}

.fx-installments-intro-box {
    max-width: 940px;
    margin: 0 auto;
    padding: 50px;
    border-radius: 32px;
    background: #f7f3ee;
    text-align: center;
}

.fx-installments-intro-box h2 {
    margin: 0 0 18px;
    font-size: clamp(30px, 3.5vw, 50px);
    line-height: 1.08;
    font-weight: 800;
    letter-spacing: -1.5px;
}

.fx-installments-intro-box p {
    max-width: 720px;
    margin: 0 auto;
    font-size: 18px;
    line-height: 1.7;
    color: #3b3936;
}

.fx-installments-faq {
    padding: 90px 0;
    background: #f7f3ee;
}

.fx-section-head {
    max-width: 760px;
    margin: 0 auto 45px;
    text-align: center;
}

.fx-section-head span {
    display: inline-block;
    margin-bottom: 14px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #8b8175;
}

.fx-section-head h2 {
    margin: 0;
    font-size: clamp(30px, 3.5vw, 52px);
    line-height: 1.08;
    font-weight: 800;
    letter-spacing: -1.5px;
}

.fx-installments-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.fx-installments-card {
    padding: 34px 30px;
    border-radius: 28px;
    background: #fff;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.06);
}

.fx-installments-card span {
    display: inline-flex;
    margin-bottom: 22px;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 1.5px;
    color: #8b8175;
}

.fx-installments-card h3 {
    margin: 0 0 16px;
    font-size: 22px;
    line-height: 1.25;
    font-weight: 800;
    letter-spacing: -0.5px;
}

.fx-installments-card p {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    color: #4b4742;
}

.fx-installments-bank {
    padding: 80px 0 95px;
    background: #fff;
}

.fx-installments-bank-box {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 45px;
    align-items: center;
    padding: 45px;
    border-radius: 32px;
    background: #f7f3ee;
}

.fx-installments-bank-logo {
    padding: 30px;
    border-radius: 26px;
    background: #fff;
    text-align: center;
}

.fx-installments-bank-logo img {
    max-width: 180px;
    height: auto;
}

.fx-installments-bank-content h2 {
    margin: 0 0 16px;
    font-size: clamp(28px, 3vw, 44px);
    line-height: 1.1;
    font-weight: 800;
    letter-spacing: -1px;
}

.fx-installments-bank-content p {
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
    color: #4b4742;
}

@media (max-width: 991px) {
    .fx-installments-hero-grid,
    .fx-installments-bank-box {
        grid-template-columns: 1fr;
    }

    .fx-installments-visual img {
        height: 460px;
    }

    .fx-installments-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .fx-installments-bank-box {
        text-align: center;
    }
}

@media (max-width: 575px) {
    .fx-installments-hero {
        padding: 60px 0;
    }

    .fx-installments-copy h1 {
        letter-spacing: -1.5px;
    }

    .fx-installments-values {
        grid-template-columns: 1fr;
    }

    .fx-installments-visual img {
        height: auto;
    }

    .fx-installments-intro-box {
        padding: 34px 24px;
    }

    .fx-installments-grid {
        grid-template-columns: 1fr;
    }

    .fx-installments-bank-box {
        padding: 30px 22px;
    }
}

.fx-installments-hero {
    padding-bottom: 100px;
    background: #f7f3ee;
}

.fx-installments-visual {
    width: 100%;
    margin-bottom: 80px;
}

.fx-installments-visual img {
    width: 100%;
    height: 700px;
    object-fit: cover;
    display: block;
}

.fx-installments-copy {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.fx-installments-copy h1 {
    margin: 15px 0 25px;
    font-size: clamp(42px, 5vw, 72px);
    line-height: 1;
    letter-spacing: -2px;
}

.fx-installments-copy p {
    max-width: 720px;
    margin: 0 auto 40px;
    font-size: 20px;
    line-height: 1.8;
}

.fx-installments-values {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin: 50px 0;
}

.fx-value-card {
    min-width: 180px;
    padding: 30px;
    border-radius: 24px;
    background: #fff;
}

.fx-value-card strong {
    display: block;
    font-size: 48px;
    line-height: 1;
    font-weight: 700;
}

.fx-value-card span {
    display: block;
    margin-top: 10px;
}

@media(max-width:991px){

    .fx-installments-visual img{
        height:500px;
    }

    .fx-installments-values{
        flex-direction:column;
        align-items:center;
    }

    .fx-value-card{
        width:100%;
        max-width:320px;
    }
}
.fx-installments-hero {
    padding: 80px 0 100px;
}

.fx-installments-visual {
    margin-bottom: 70px;
    border-radius: 32px;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0,0,0,.12);
}

.fx-installments-visual img {
    width: 100%;
    height: 650px;
    object-fit: cover;
    display: block;
}

.fx-installments-copy {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}
.fx-installments-values{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:20px;
}

.fx-value-card{
    width:180px;
    text-align:center;
}
.fx-installments-values{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:20px;
}


.fs-vacuum-packing{
    padding:120px 0;
    background:#faf8f5;
}

.fs-vacuum-packing__eyebrow{
    display:block;
    margin-bottom:15px;
    font-size:13px;
    letter-spacing:2px;
    text-transform:uppercase;
    color:#8a8178;
    font-weight:600;
}

.fs-vacuum-packing__title{
    margin-bottom:20px;
}

.fs-vacuum-packing__intro{
    max-width:760px;
    margin:0 auto 80px;
}

.fs-vacuum-packing__video{
    overflow:hidden;
    border-radius:24px;
    box-shadow:0 25px 60px rgba(0,0,0,.08);
}

.fs-vacuum-packing__video video{
    width:100%;
    display:block;
}

.fs-vacuum-packing__features{
    display:flex;
    flex-direction:column;
    gap:30px;
}

.fs-vacuum-feature{
    padding-bottom:25px;
    border-bottom:1px solid rgba(0,0,0,.08);
}

.fs-vacuum-feature:last-child{
    border-bottom:none;
    padding-bottom:0;
}

.fs-vacuum-feature h3{
    font-size:22px;
    margin-bottom:10px;
}

.fs-vacuum-feature p{
    margin:0;
    color:#666;
}
@media (max-width:767px){

    .flexy-hero-slide{
        height: 370px !important;
        min-height: 370px !important;
    }

}

@media (max-width:767px){
    .ipad-top-space-margin{
        margin-top:0 !important;
        padding-top:0 !important;
    }
}
.fx-special-days-page {
    background: #f7f3ee;
    color: #171717;
}

.fx-special-hero {
    padding: 70px 0 90px;
    background: #fff;
}

.fx-special-hero__image {
    max-width: 1180px;
    margin: 0 auto 70px;
    border-radius: 34px;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.12);
}

.fx-special-hero__image img {
    width: 100%;
    display: block;
}

.fx-special-hero__content {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.fx-special-eyebrow {
    display: inline-block;
    margin-bottom: 18px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #8a8178;
}

.fx-special-hero__content h1,
.fx-special-section-head h2,
.fx-special-cta h2 {
    margin: 0 0 24px;
    font-size: clamp(38px, 5vw, 72px);
    line-height: 1;
    font-weight: 800;
    letter-spacing: -2px;
}

.fx-special-hero__content p,
.fx-special-section-head p,
.fx-special-cta p {
    max-width: 760px;
    margin: 0 auto 20px;
    font-size: 19px;
    line-height: 1.75;
    color: #3c3a36;
}

.fx-special-hero__badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px;
    margin: 42px 0;
}

.fx-special-hero__badges span {
    padding: 12px 18px;
    border-radius: 999px;
    background: #f3ede4;
    font-size: 14px;
    font-weight: 800;
}

.fx-special-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 14px 30px;
    border-radius: 999px;
    background: #171717;
    color: #fff;
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.25s ease;
}

.fx-special-btn:hover {
    background: #3b3936;
    color: #fff;
    transform: translateY(-2px);
}

.fx-special-products {
    padding: 100px 0;
    background: #f7f3ee;
}

.fx-special-section-head {
    max-width: 860px;
    margin: 0 auto 60px;
    text-align: center;
}

.fx-special-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

.fx-special-card {
    position: relative;
    overflow: hidden;
    border-radius: 30px;
    background: #fff;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.07);
    transition: all 0.25s ease;
}

.fx-special-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 28px 65px rgba(0, 0, 0, 0.12);
}

.fx-special-card img {
    width: 100%;
    height: 260px;
    object-fit: contain;
    display: block;
    padding: 28px;
    background: #faf8f5;
}

.fx-special-card__content {
    padding: 28px 28px 32px;
    text-align: center;
}

.fx-special-discount {
    display: inline-flex;
    margin-bottom: 16px;
    padding: 8px 14px;
    border-radius: 999px;
    background: #171717;
    color: #fff;
    font-size: 13px;
    font-weight: 800;
}

.fx-special-card h3 {
    margin: 0 0 14px;
    font-size: 23px;
    font-weight: 800;
    letter-spacing: -0.5px;
}

.fx-special-card p {
    margin: 0 0 8px;
    font-size: 15px;
    line-height: 1.5;
    color: #4b4945;
}

.fx-special-card del {
    color: #8a8178;
}

.fx-special-card strong {
    font-size: 20px;
    color: #171717;
}

.fx-special-card small {
    display: block;
    margin-top: 14px;
    font-size: 11px;
    line-height: 1.4;
    color: #817870;
}

.fx-special-cta {
    padding: 95px 0;
    background: #fff;
    text-align: center;
}

@media (max-width: 991px) {
    .fx-special-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .fx-special-hero__content h1,
    .fx-special-section-head h2,
    .fx-special-cta h2 {
        font-size: 42px;
    }
}

@media (max-width: 575px) {
    .fx-special-hero {
        padding: 40px 0 60px;
    }

    .fx-special-hero__image {
        margin-bottom: 45px;
        border-radius: 22px;
    }

    .fx-special-grid {
        grid-template-columns: 1fr;
    }

    .fx-special-card img {
        height: 220px;
    }

    .fx-special-hero__badges {
        flex-direction: column;
    }
}
/* PATCH — Special Days full width thumbnails */
.fx-special-card > a {
    display: block !important;
    width: 100% !important;
    height: 300px !important;
    overflow: hidden !important;
    border-radius: 30px 30px 0 0 !important;
    background: #f7f3ee !important;
}

.fx-special-card > a img {
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    display: block !important;
    object-fit: cover !important;
    padding: 0 !important;
    margin: 0 !important;
}
.flexy-404-page{
    padding:120px 0;
    min-height:70vh;
    display:flex;
    align-items:center;
}

.flexy-404-content{
    max-width:760px;
    margin:0 auto;
    text-align:center;
}

.flexy-404-kicker{
    display:inline-block;
    margin-bottom:20px;
    font-size:13px;
    font-weight:700;
    letter-spacing:3px;
    color:#9a9a9a;
}

.flexy-404-content h1{
    font-size:clamp(42px,6vw,82px);
    line-height:1;
    margin-bottom:25px;
    font-weight:600;
    color:#1d1d1d;
}

.flexy-404-content p{
    max-width:620px;
    margin:0 auto 40px;
    font-size:18px;
    line-height:1.8;
    color:#6f6f6f;
}

.flexy-404-actions{
    display:flex;
    justify-content:center;
    gap:15px;
    flex-wrap:wrap;
    margin-bottom:45px;
}

.flexy-404-links{
    display:flex;
    justify-content:center;
    align-items:center;
    flex-wrap:wrap;
    gap:15px;
}

.flexy-404-links span{
    color:#c4c4c4;
}

.flexy-404-links a{
    color:#1d1d1d;
    font-weight:600;
    text-decoration:none;
    transition:.3s;
}

.flexy-404-links a:hover{
    color:#b99663;
}

@media (max-width:768px){

    .flexy-404-page{
        padding:80px 0;
    }

    .flexy-404-content p{
        font-size:16px;
    }

    .flexy-404-links{
        gap:10px;
    }
}
