:root {
    --ox-blue: #0b3090;
    --ox-red: #de3034;
    --ox-text: #5f5f5f;
    --ox-muted: #717171;
    --ox-border: rgba(15, 23, 42, 0.10);
    --ox-surface: #ffffff;
    --ox-soft: #f6f8fc;
    --ox-shadow: 0 18px 50px rgba(11, 48, 144, 0.12);
}

* {
    box-sizing: border-box;
}

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

html {
    scroll-behavior: smooth;
    font-size: 14px;
}

body.oxymed-site {
    margin: 0;
    color: var(--ox-text);
    font-family: Poppins, system-ui, sans-serif;
    font-size: 1rem;
    line-height: 1.6;
    background: #fff;
    overflow-x: hidden;
}

body.oxymed-site * {
    font-family: inherit;
}

a {
    color: inherit;
    text-decoration: none;
}

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

.container {
    width: min(1340px, calc(100% - 3rem));
    margin: 0 auto;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 20;
    background: #fff;
    border-bottom: 1px solid rgba(15, 23, 42, 0.12);
}

.site-header__inner {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    min-height: 80px;
}

.site-brand {
    display: inline-flex;
    align-items: center;
    min-width: 0;
}

.site-brand__logo {
    width: 176px;
    height: auto;
}

.site-header__cart {
    display: none;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-left: auto;
    color: #8e8e8e;
}

.site-header__cart svg {
    width: 28px;
    height: 28px;
}

.site-nav {
    display: flex;
    align-items: center;
    gap: .35rem;
    margin-left: auto;
}

.site-nav--mobile {
    display: none;
}

.site-nav a,
.site-nav summary {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .5rem .7rem;
    border-radius: 999px;
    font-family: Montserrat, system-ui, sans-serif;
    font-size: 13px;
    font-weight: 600;
    line-height: 13px;
    letter-spacing: 0;
    text-transform: uppercase;
    color: #444444;
    min-height: 38px;
}

.site-nav a:hover,
.site-nav summary:hover,
.site-nav a.is-active {
    color: #444444;
    background: rgba(7, 54, 153, 0.06);
}

.site-nav__group {
    position: relative;
}

.site-nav__group > summary {
    list-style: none;
    cursor: pointer;
    user-select: none;
}

.site-nav__label {
    display: inline-flex;
    align-items: center;
}

.site-nav__chevron {
    width: 12px;
    height: 12px;
    margin-left: .15rem;
    color: #444444;
    transition: transform .2s ease, color .2s ease;
}

.site-nav__group > summary::-webkit-details-marker {
    display: none;
}

.site-nav__group[open] > summary .site-nav__chevron {
    transform: rotate(180deg);
}

.site-nav__submenu {
    position: absolute;
    top: calc(100% + .5rem);
    left: 0;
    min-width: 240px;
    display: grid;
    gap: .25rem;
    padding: .75rem;
    border: 1px solid var(--ox-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, .99);
    box-shadow: var(--ox-shadow);
    z-index: 15;
}

.site-nav__submenu a {
    padding: .72rem .85rem;
    text-transform: none;
    font-family: Montserrat, system-ui, sans-serif;
    font-size: 13px;
    font-weight: 600;
    line-height: 13px;
    border-radius: .75rem;
}

.site-header__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 1rem;
    width: 150px;
    height: 42px;
    padding: 0 .85rem;
    border-radius: 999px;
    background: #303e3a;
    color: #fff;
    font-family: Montserrat, system-ui, sans-serif;
    font-size: 13px;
    font-weight: 600;
    line-height: 13px;
    letter-spacing: 0;
    text-transform: uppercase;
    box-sizing: border-box;
    border: 0;
    text-decoration: none;
    appearance: none;
    cursor: pointer;
}

.site-nav-toggle {
    display: none;
    margin-left: auto;
    position: relative;
}

.site-nav-toggle summary {
    list-style: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .45rem .55rem;
    border: 0;
    border-radius: .75rem;
    background: transparent;
    color: #444444;
    font: inherit;
}

.site-nav-toggle summary::-webkit-details-marker {
    display: none;
}

.site-nav-toggle__icon {
    display: grid;
    gap: 3px;
    width: 24px;
}

.site-nav-toggle__icon span {
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: #444444;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.hero--home {
    padding: 0;
}

.hero__inner {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: 1rem;
    align-items: center;
    min-height: 560px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.78)),
        radial-gradient(circle at 10% 20%, rgba(179, 187, 207, 0.14), transparent 18%),
        radial-gradient(circle at 86% 28%, rgba(179, 187, 207, 0.13), transparent 16%),
        linear-gradient(135deg, #f8fafc 0%, #f7f9fb 100%);
    border-bottom-left-radius: 2rem;
    border-bottom-right-radius: 2rem;
    overflow: hidden;
    position: relative;
}

.hero__inner::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(120deg, transparent 0 18%, rgba(144, 150, 198, 0.18) 18.5%, transparent 19% 49%, rgba(144, 150, 198, 0.16) 49.5%, transparent 50% 74%, rgba(144, 150, 198, 0.12) 74.5%, transparent 75%);
    opacity: .6;
    pointer-events: none;
}

.hero__copy,
.hero__visual {
    position: relative;
    z-index: 1;
}

.hero__copy {
    padding: 2rem 0 2rem 1rem;
    text-align: center;
}

.hero__kicker {
    margin: 0 0 1.1rem;
    font-size: clamp(1.8rem, 2.8vw, 2rem);
    font-weight: 500;
    color: #444444;
}

.hero__copy h1 {
    margin: 0;
    color: #0b3090;
    line-height: .95;
    font-size: clamp(4rem, 7vw, 4.5rem);
    font-weight: 800;
    letter-spacing: -.04em;
}

.hero__copy h2 {
    margin: 1.4rem 0 0;
    color: #444444;
    font-size: clamp(1.55rem, 2.8vw, 2rem);
    font-weight: 500;
    line-height: 1.2;
}

.hero__subcopy {
    margin: 1rem 0 0;
    color: #444444;
    font-size: clamp(1.15rem, 1.7vw, 1.21rem);
    font-weight: 500;
}

.hero__subcopy strong {
    font-weight: 700;
}

.hero__actions {
    display: flex;
    justify-content: center;
    gap: .85rem;
    margin-top: 2rem;
}

.hero__actions--secondary {
    justify-content: flex-start;
}

.hero__visual {
    display: grid;
    place-items: center;
    align-self: stretch;
    padding: .25rem 0 0;
}

.hero__visual img {
    width: auto;
    max-height: 760px;
    max-width: 100%;
    object-fit: contain;
    filter: drop-shadow(0 26px 30px rgba(0, 0, 0, 0.18));
    transform: translateX(3.5%);
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    color: var(--ox-blue);
    font-size: .86rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.page-hero--policy .container {
    text-align: center;
}

.page-hero--policy h1 {
    color: #000;
    margin-left: auto;
    margin-right: auto;
}

.page-hero--policy .page-hero__lead {
    margin-left: auto;
    margin-right: auto;
}

.page-hero--policy + .section {
    padding-top: .75rem;
}

.prose--policy h2 {
    color: #000;
}

.feature-strip {
    margin-top: 2.5rem;
    padding: 0 0 0;
}

.feature-strip__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.2rem;
    transform: translateY(-2.75rem);
}

.feature-strip__item {
    display: flex;
    align-items: center;
    gap: .85rem;
    min-height: 68px;
    padding: .65rem .9rem;
    border-radius: .6rem;
    background: rgba(255, 255, 255, .95);
    box-shadow: 0 16px 32px rgba(15, 23, 42, 0.06);
}

.feature-strip__item img {
    width: 34px;
    height: 34px;
    flex: 0 0 auto;
}

.feature-strip__item h3 {
    margin: 0;
    color: #5f5f5f;
    font-size: .93rem;
    font-weight: 700;
}

.showcase,
.feature-callout,
.catalog {
    padding: 3.25rem 0;
}

.showcase .container {
    width: min(1300px, calc(100% - 3rem));
}

.showcase {
    background: #fff;
}

.showcase--reverse {
    background: #f8fbff;
}

.showcase--cure {
    padding: 20px 0 30px;
    background: #f6f6f6;
}

.showcase__grid {
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
    gap: 1.5rem;
    align-items: center;
}

.showcase--reverse .showcase__grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
}

.showcase--reverse .showcase__content {
    display: grid;
    align-content: center;
    justify-items: center;
    text-align: center;
    padding: 0 1rem 0 0;
}

.showcase--reverse .showcase__lead {
    margin-inline: auto;
}

.showcase--reverse .button {
    margin-inline: auto;
}

.showcase--portable .showcase__content {
    display: grid;
    align-content: center;
    justify-items: center;
    text-align: center;
    padding: 0 1rem;
}

.showcase--portable .showcase__content h2 span {
    display: inline;
    color: var(--ox-blue);
    font-size: inherit;
    line-height: inherit;
}

.showcase--portable .showcase__lead {
    margin-inline: auto;
    max-width: 960px;
}

.showcase--portable .button {
    margin-inline: auto;
}

.showcase__media {
    display: grid;
    justify-items: center;
}

.showcase__media img {
    width: min(100%, 760px);
    max-height: 520px;
    object-fit: contain;
}

.showcase--cure .showcase__grid {
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: 2rem;
    min-height: 527px;
}

.showcase--cure .showcase__media img {
    width: 92%;
    max-width: 750px;
    max-height: 620px;
}

.showcase__content {
    padding: 0 1rem;
}

.showcase__content h2 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(2.2rem, 3vw, 2.9rem);
    line-height: 1.08;
    letter-spacing: -.03em;
}

.showcase__content h2 span {
    display: block;
    color: #5f5f5f;
    font-size: clamp(1.2rem, 1.8vw, 1.5rem);
    line-height: 1.1;
}

.showcase--cure .showcase__content h2 {
    font-size: 40px;
    font-weight: 600;
    line-height: 48px;
    color: #1a1a1a;
}

.showcase--cure .showcase__content h2 span {
    color: #0b3090;
}

.showcase__lead {
    margin: 1.15rem 0 1.25rem;
    color: #5f5f5f;
    line-height: 1.8;
    font-size: 1.07rem;
    max-width: 60ch;
}

.showcase--cure .showcase__lead {
    margin: 1.2rem 0 1.5rem;
    max-width: 690px;
    color: #5f5f5f;
    font-size: 16px;
    line-height: 26px;
}

.checklist {
    margin: 0 0 1.5rem;
    padding-left: 1.15rem;
    display: grid;
    gap: .8rem;
    color: #5f5f5f;
}

.showcase--cure .checklist {
    padding-left: 0;
    gap: .9rem;
    margin-bottom: 1.65rem;
    list-style: none;
}

.checklist li {
    line-height: 1.5;
}

.showcase--cure .checklist li {
    display: flex;
    align-items: center;
    gap: .75rem;
    color: #5f5f5f;
    font-size: 16px;
    line-height: 26px;
}

.showcase--cure .checklist li::before {
    content: "✓";
    flex: 0 0 17px;
    width: 17px;
    height: 17px;
    border-radius: 50%;
    border: 2px solid #49b63f;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #49b63f;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

.feature-callout {
    padding: 30px 0 40px;
    background: #fff;
}

.feature-callout .container {
    width: min(1300px, calc(100% - 3rem));
}

.feature-callout__grid {
    display: grid;
    grid-template-columns: minmax(0, 45%) minmax(0, 55%);
    gap: 0;
    align-items: center;
    min-height: 546.79px;
}

.feature-callout__content {
    padding-top: 20px;
}

.feature-callout__item {
    position: relative;
    margin-bottom: 52px;
    padding-right: var(--callout-padding-right, 70px);
    text-align: right;
}

.feature-callout__copy {
    position: relative;
    z-index: 1;
    display: inline-block;
    max-width: 100%;
    text-align: right;
}

.feature-callout__copy h6 {
    margin: 0 0 5px;
    color: #3c4858;
    font-family: Montserrat, system-ui, sans-serif;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.feature-callout__copy p {
    margin: 0;
    color: #5f5f5f;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.5;
    text-transform: none;
}

.feature-callout__rule {
    position: absolute;
    top: 19px;
    right: var(--callout-line-right, -78%);
    width: var(--callout-line-width, 90%);
    height: 1px;
    background: #0b3090;
}

.feature-callout__rule::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 10px;
    height: 10px;
    margin-top: -5px;
    border-radius: 50%;
    background: #0b3090;
}

.feature-callout__media {
    display: grid;
    justify-items: end;
    align-items: center;
}

.feature-callout__media img {
    width: 100%;
    max-width: 750px;
    max-height: 556px;
    object-fit: contain;
}

.catalog {
    background: #fff;
}

.catalog__heading {
    margin-bottom: 2.5rem;
    text-align: center;
}

.catalog__heading h2 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(2.25rem, 3vw, 3rem);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -.03em;
}

.catalog__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.2rem;
}

.catalog-card {
    overflow: hidden;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--ox-border);
    border-radius: 1.5rem;
    background: #fff;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.06);
}

.catalog-card__link {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}

.catalog-card__image {
    display: grid;
    place-items: center;
    aspect-ratio: 1 / 1;
    padding: 1rem;
    background: linear-gradient(180deg, #fff, #f8fbff);
}

.catalog-card__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.catalog-card__body {
    display: grid;
    gap: .7rem;
    padding: 1rem 1.1rem 1.15rem;
}

.catalog-card__footer {
    margin-top: auto;
    padding: 0 1.1rem 1.15rem;
}

.catalog-card__body h3 {
    margin: 0;
    color: #1a1a1a;
    font-size: 1.29rem;
    line-height: 1.4;
}

.catalog-card__price {
    color: #5f5f5f;
    font-size: 1.05rem;
    font-weight: 500;
    line-height: 1.2;
}

.catalog-card__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-width: 180px;
    height: 46px;
    padding: 0 1rem;
    border-radius: 999px;
    background: #303e3a;
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    box-shadow: none;
}

.product-band {
    padding: 3.5rem 0 4.5rem;
}

.section-heading--compact {
    margin-bottom: 1rem;
}

.section-heading--compact span {
    color: var(--ox-blue);
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: .78rem;
    font-weight: 700;
}

.product-band__card {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 1.5rem;
    align-items: center;
    padding: 1.5rem;
    border: 1px solid var(--ox-border);
    border-radius: 1.5rem;
    background: #fff;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.06);
}

.product-band__copy p {
    margin: 0;
    color: var(--ox-muted);
    line-height: 1.8;
    max-width: 56ch;
}

.product-band__image {
    display: grid;
    justify-items: center;
}

.product-band__image img {
    max-height: 420px;
    object-fit: contain;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    padding: .95rem 1.35rem;
    border-radius: 999px;
    font-weight: 700;
    border: 1px solid transparent;
    cursor: pointer;
}

.button--buy {
    min-width: 220px;
    background: #44a84f;
    color: #fff;
    border-color: #2d6c33;
    box-shadow: 0 8px 0 rgba(31, 79, 34, 0.35);
}

.button--buy:hover {
    transform: translateY(-1px);
}

.button--buy-dark {
    min-width: 0;
    width: 190px;
    height: 50px;
    padding: 0 1.2rem 0 1.35rem;
    background: #303e3a;
    border-color: #303e3a;
    border-width: 2px;
    color: #fff;
    box-shadow: none;
    font-size: 13px;
    font-weight: 500;
    line-height: 13px;
    gap: .9rem;
}

.button--buy-dark::after {
    content: "";
    width: .45rem;
    height: .45rem;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    transform: rotate(45deg);
    margin-top: -1px;
}

.button--buy-dark:hover {
    transform: none;
}

.button--outline {
    background: #fff;
    border-color: rgba(15, 23, 42, 0.14);
    color: #334155;
}

.section {
    padding: 3rem 0;
}

.section--muted {
    background: var(--ox-soft);
}

.section__heading {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    margin-bottom: 1.25rem;
}

.section__heading h2,
.panel h2,
.prose h2 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(1.7rem, 2.4vw, 2.2rem);
}

.card-grid {
    display: grid;
    gap: 1.25rem;
}

.card-grid--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.tile,
.panel,
.product-card,
.mini-card {
    border: 1px solid var(--ox-border);
    border-radius: 1.4rem;
    background: rgba(255, 255, 255, .9);
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.05);
}

.tile,
.panel {
    padding: 1.35rem;
}

.tile h3,
.product-card h3,
.mini-card strong {
    margin: 0 0 .5rem;
    color: #1a1a1a;
    font-size: 1.14rem;
}

.tile p,
.product-card p,
.mini-card {
    color: #5f5f5f;
}

.product-card {
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.product-card__image {
    aspect-ratio: 4 / 3;
    padding: 1rem;
    background: linear-gradient(180deg, #fff, #f8fbff);
}

.product-card__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.product-card__body {
    padding: 1.2rem;
}

.split,
.contact-grid,
.product-details {
    display: grid;
    gap: 1.25rem;
}

.split {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
    align-items: center;
}

.stat-list {
    display: grid;
    gap: 1rem;
}

.stat {
    padding: 1.15rem 1.25rem;
    border-left: 4px solid var(--ox-blue);
    background: rgba(255, 255, 255, .8);
    border-radius: 1rem;
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.04);
}

.stat strong {
    display: block;
    margin-bottom: .15rem;
    color: #1a1a1a;
    font-size: 1.14rem;
}

.mini-card {
    padding: 1rem;
    display: grid;
    gap: .85rem;
}

.mini-card img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
}

.prose {
    max-width: 920px;
}

.prose__block + .prose__block {
    margin-top: 2rem;
}

.prose p,
.prose li,
.panel p,
.contact-list span {
    color: #5f5f5f;
    line-height: 1.75;
}

.prose ul,
.feature-list {
    padding-left: 1.15rem;
}

.prose--policy p,
.prose--policy li {
    color: #000;
    font-family: Poppins, system-ui, sans-serif;
    font-size: 17px;
    font-style: normal;
    font-weight: 300;
    line-height: 27.506px;
}

.contact-grid,
.product-details {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-list {
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
}

.contact-list a {
    display: grid;
    gap: .15rem;
    padding: .9rem 1rem;
    border: 1px solid var(--ox-border);
    border-radius: 1rem;
    background: #fff;
}

.contact-form {
    display: grid;
    gap: 1rem;
}

.contact-form__error {
    color: #b42318;
    font-size: .84rem;
    font-weight: 500;
}

.contact-form label {
    display: grid;
    gap: .45rem;
    font-size: 1rem;
    font-weight: 600;
    color: #4f4f51;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
    width: 100%;
    padding: .9rem 1rem;
    border: 1px solid var(--ox-border);
    border-radius: .9rem;
    font: inherit;
    background: #fff;
}

.contact-form textarea {
    resize: vertical;
    min-height: 120px;
}

.contact-form--modal {
    gap: 1.1rem;
}

.contact-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: grid;
    place-items: center;
    padding: 1.25rem;
}

.contact-modal[hidden] {
    display: none !important;
}

.contact-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(16, 16, 16, 0.78);
}

.contact-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(620px, 100%);
    max-height: calc(100vh - 2.5rem);
    overflow: auto;
    border-radius: 1rem;
    background: #fff;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.3);
}

.contact-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.4rem 1.6rem;
    background: linear-gradient(135deg, #0f63d4, #126fe5);
    color: #fff;
}

.contact-modal__header h2 {
    margin: 0;
    font-size: clamp(1.9rem, 2.8vw, 2.5rem);
    font-weight: 600;
    color: inherit;
}

.contact-modal__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #fff;
    font-size: 2.1rem;
    line-height: 1;
    cursor: pointer;
}

.contact-modal__body {
    padding: 1.4rem 1.6rem 1.7rem;
}

.contact-form__submit.button--primary {
    background: #111;
    color: #fff;
}

.contact-form__submit.button--primary:hover,
.contact-form__submit.button--primary:focus-visible {
    background: #000;
}

.contact-modal__success {
    margin-bottom: 1rem;
    padding: .9rem 1rem;
    border-radius: .85rem;
    background: rgba(18, 111, 229, 0.08);
    color: var(--ox-blue);
    font-weight: 600;
}

body.contact-modal-open {
    overflow: hidden;
}

.contact-map-section {
    padding-top: 0;
}

.contact-map {
    overflow: hidden;
    border: 1px solid var(--ox-border);
    border-radius: 1.25rem;
    background: #fff;
    box-shadow: var(--ox-shadow);
}

.contact-map iframe {
    display: block;
    width: 100%;
    height: 420px;
    border: 0;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    padding: .95rem 1.35rem;
    border-radius: 999px;
    font-weight: 700;
    border: 1px solid transparent;
    cursor: pointer;
}

.button--primary {
    color: #fff;
    background: linear-gradient(135deg, var(--ox-blue), var(--ox-red));
}

.button--ghost {
    border-color: rgba(11, 48, 144, 0.18);
    background: #fff;
    color: var(--ox-blue);
}

.spec-list {
    display: grid;
    gap: .85rem;
    margin: 0;
}

.spec-list div {
    padding-bottom: .75rem;
    border-bottom: 1px solid var(--ox-border);
}

.spec-list dt {
    font-weight: 700;
    color: var(--ox-blue);
}

.spec-list dd {
    margin: .25rem 0 0;
    color: var(--ox-muted);
}

.site-footer {
    margin-top: 2rem;
    background: #f6f6f6;
    border-top: 1px solid rgba(15, 23, 42, 0.12);
}

.site-footer__main {
    display: flex;
    justify-content: space-between;
    gap: 4rem;
    padding: 4rem 0 3rem;
    align-items: start;
}

.site-footer__brand {
    flex: 0 1 35%;
    max-width: 35%;
}

.site-footer__links-block {
    flex: 0 1 26%;
    max-width: 26%;
}

.site-footer__contact-block {
    flex: 0 1 31%;
    max-width: 31%;
}

.site-footer__logo img {
    width: 240px;
    height: auto;
}

.site-footer__description {
    margin: 1.45rem 0 0;
    color: #5F5F5F;
    font-family: Poppins, system-ui, sans-serif;
    font-size: 15px;
    font-weight: 400;
    line-height: 24.27px;
}

.site-footer__links-block h3,
.site-footer__contact-block h3 {
    margin: 0 0 1.2rem;
    color: #4f4f51;
    font-size: 1.29rem;
    font-weight: 700;
}

.site-footer__links-list {
    margin: 0;
    padding: 0 0 0 1.1rem;
    display: grid;
    gap: .9rem;
    color: #5F5F5F;
    font-family: Poppins, system-ui, sans-serif;
    font-size: 15px;
    font-weight: 400;
    line-height: 24.27px;
}

.site-footer__links-list a {
    color: inherit;
}

.site-footer__contact {
    color: #5F5F5F;
    font-family: Poppins, system-ui, sans-serif;
    font-size: 15px;
    font-weight: 400;
    line-height: 24.27px;
}

.site-footer__contact-line {
    display: flex;
    gap: .8rem;
    margin: 0;
}

.site-footer__contact-line::before {
    content: "";
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    margin-top: .3rem;
    border-radius: 3px;
    background: #0c3f9a;
    box-shadow:
        inset 0 0 0 2px #0c3f9a,
        inset 0 6px 0 0 #fff;
}

.site-footer__bar {
    border-top: 1px solid rgba(15, 23, 42, 0.16);
    background: #f5f5f5;
}

.site-footer__bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.25rem 0;
}

.site-footer__policy-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0;
    color: #4f4f51;
    font-family: Poppins, system-ui, sans-serif;
    font-size: 15px;
    font-weight: 400;
    line-height: 24.27px;
}

.site-footer__policy-links a {
    padding: 0 .85rem;
    border-right: 1px solid rgba(68, 68, 68, 0.55);
}

.site-footer__policy-links a:first-child {
    padding-left: 0;
}

.site-footer__policy-links a:last-child {
    border-right: 0;
    padding-right: 0;
}

.site-footer__copyright {
    margin: 0;
    color: #526072;
    font-family: Poppins, system-ui, sans-serif;
    font-size: 16px;
    font-weight: 400;
}

.site-brand--footer {
    margin-bottom: .85rem;
}

@media (max-width: 1100px) {
    .card-grid--four,
    .card-grid--three,
    .split,
    .contact-grid,
    .product-details,
    .hero__grid,
    .product-hero__grid {
        grid-template-columns: 1fr;
    }

    .hero__inner,
    .feature-strip__grid,
    .showcase__grid,
    .feature-callout__grid,
    .catalog__grid {
        grid-template-columns: 1fr;
    }

    .site-footer__main {
        flex-direction: column;
    }

    .hero__inner {
        min-height: auto;
        padding: 2rem 0 1rem;
    }

    .hero__copy {
        padding: 1rem 0 0;
    }

    .hero__visual img {
        width: min(100%, 540px);
        transform: none;
    }

    .feature-strip__grid {
        transform: none;
    }

    .showcase__content {
        padding: 0;
    }

    .showcase__media img,
    .feature-callout__media img {
        max-height: 420px;
    }

    .site-nav--desktop {
        display: none;
    }

    .site-header__cart {
        display: inline-flex;
    }

    .site-nav-toggle {
        display: inline-flex;
        width: auto;
    }

    .site-header__cta {
        margin-left: auto;
        min-width: auto;
        width: auto;
        height: auto;
        display: inline-flex;
    }

    .site-footer__bar-inner {
        flex-direction: column;
        align-items: center;
    }

    .site-footer__brand,
    .site-footer__links-block,
    .site-footer__contact-block {
        max-width: 100%;
        flex-basis: auto;
    }
}

@media (max-width: 768px) {
    .hero,
    .page-hero,
    .product-hero,
    .section {
        padding: 2.25rem 0;
    }

    .feature-strip {
        margin-top: 1.1rem;
    }

    .feature-strip__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .7rem;
        transform: none;
    }

    .feature-strip__item {
        min-height: 56px;
        padding: .55rem .65rem;
        gap: .6rem;
    }

    .feature-strip__item img {
        width: 28px;
        height: 28px;
    }

    .feature-strip__item h3 {
        font-size: .82rem;
        line-height: 1.1;
    }

    .showcase,
    .feature-callout,
    .catalog {
        padding: 2rem 0;
    }

    .showcase .container,
    .feature-callout .container {
        width: min(100%, calc(100% - 1.5rem));
    }

    .page-hero--policy {
        padding-bottom: .75rem;
    }

    .page-hero--policy + .section {
        padding-top: .25rem;
    }

    .showcase__grid,
    .feature-callout__grid {
        display: flex;
        flex-direction: column;
        gap: 1.1rem;
        min-height: auto;
    }

    .showcase__content,
    .showcase--reverse .showcase__content,
    .showcase--portable .showcase__content {
        padding: 0;
        text-align: left;
        justify-items: start;
    }

    .showcase__content h2,
    .showcase--cure .showcase__content h2 {
        font-size: clamp(1.6rem, 7.4vw, 2.25rem);
        line-height: 1.1;
    }

    .showcase__content h2 span {
        display: inline;
        font-size: inherit;
        line-height: inherit;
    }

    .showcase__lead,
    .showcase--cure .showcase__lead,
    .showcase--portable .showcase__lead {
        max-width: none;
        margin: .85rem 0 1.05rem;
        font-size: .98rem;
        line-height: 1.65;
    }

    .showcase__media {
        order: 0;
    }

    .showcase__content {
        order: 1;
    }

    .showcase--cure .showcase__grid,
    .showcase--reverse .showcase__grid,
    .showcase--portable .showcase__grid {
        display: flex;
        flex-direction: column;
    }

    .showcase--cure .checklist {
        width: 100%;
        gap: .7rem;
        margin-bottom: 1.2rem;
    }

    .showcase--cure .checklist li {
        font-size: .95rem;
        line-height: 1.55;
    }

    .showcase__media,
    .feature-callout__media {
        justify-items: center;
    }

    .showcase__media img,
    .showcase--cure .showcase__media img,
    .feature-callout__media img {
        width: 100%;
        max-width: 420px;
        max-height: 320px;
    }

    .feature-callout__content {
        padding-top: 0;
    }

    .feature-callout__item {
        margin-bottom: 1.15rem;
        padding-right: 0;
        text-align: left;
    }

    .feature-callout__copy {
        text-align: left;
    }

    .feature-callout__rule {
        display: none;
    }

    .catalog__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .85rem;
    }

    .catalog__heading {
        margin-bottom: 1.25rem;
    }

    .catalog__heading h2 {
        font-size: clamp(1.65rem, 7.4vw, 2.15rem);
    }

    .catalog-card {
        border-radius: 1rem;
    }

    .catalog-card__image {
        padding: .75rem;
    }

    .catalog-card__body {
        gap: .45rem;
        padding: .8rem .8rem .9rem;
    }

    .catalog-card__body h3 {
        font-size: .92rem;
        line-height: 1.3;
    }

    .catalog-card__price {
        font-size: .88rem;
    }

    .catalog-card__action {
        min-width: 0;
        width: 100%;
        height: 38px;
        font-size: .84rem;
    }

    .site-header__inner {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-areas:
            "brand cart"
            "menu cta";
        column-gap: .75rem;
        row-gap: .65rem;
        align-items: center;
        min-height: auto;
        padding: .75rem 0;
    }

    .site-brand {
        grid-area: brand;
    }

    .site-header__cart {
        grid-area: cart;
        margin-left: 0;
        justify-self: end;
    }

    .site-nav-toggle {
        grid-area: menu;
        order: unset;
        width: auto;
        margin-left: 0;
        justify-self: start;
    }

    .site-header__cta {
        grid-area: cta;
        justify-self: end;
        margin-left: 0;
        display: inline-flex;
        width: auto;
        min-width: 0;
        height: 28px;
        padding: 0 .85rem;
    }

    .site-header:has(.site-nav-toggle[open]) .site-header__cta {
        display: none;
    }

    .site-header:has(.site-nav-toggle[open]) .site-nav-toggle {
        grid-column: 1 / -1;
        display: block;
        width: 100%;
    }

    .site-nav__submenu {
        position: static;
        box-shadow: none;
        margin-left: .5rem;
    }

    .site-nav-toggle summary:focus,
    .site-nav-toggle summary:focus-visible {
        outline: none;
    }

    .site-nav-toggle[open] > summary {
        width: 28px;
        height: 28px;
        padding: 0;
        margin-bottom: 0;
        border: 1px solid rgba(15, 23, 42, 0.18);
        border-radius: .45rem;
        background: #fff;
        justify-content: center;
        align-items: center;
        position: absolute;
        left: 0;
        top: .9rem;
        z-index: 2;
        box-shadow: 0 0 0 1px rgba(48, 62, 58, 0.04);
    }

    .site-nav-toggle[open] .site-nav-toggle__icon {
        position: relative;
        width: 14px;
        height: 14px;
        gap: 0;
    }

    .site-nav-toggle[open] .site-nav-toggle__icon span {
        position: absolute;
        left: 0;
        top: 50%;
        margin-top: -1px;
        background: #444444;
    }

    .site-nav-toggle[open] .site-nav-toggle__icon span:nth-child(1) {
        transform: rotate(45deg);
    }

    .site-nav-toggle[open] .site-nav-toggle__icon span:nth-child(2) {
        opacity: 0;
    }

    .site-nav-toggle[open] .site-nav-toggle__icon span:nth-child(3) {
        transform: rotate(-45deg);
    }

    .site-nav-toggle__panel {
        display: none;
        width: 100%;
        padding: 2.55rem 1rem 0;
    }

    .site-nav-toggle[open] .site-nav-toggle__panel {
        display: block;
    }

    .site-nav-toggle__utility {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        padding-bottom: .65rem;
    }

    .site-nav--mobile {
        display: block;
        grid-template-columns: 1fr;
        gap: 0;
        padding: 0;
        margin: 0;
        border-top: 0;
    }

    .site-nav--mobile > a.site-nav__home-link.is-active {
        display: inline-flex;
        align-items: center;
        min-height: 38px;
        padding: .7rem 1rem;
        border-radius: 999px;
        background: transparent;
        color: #444444;
        border-bottom: 0;
        margin-bottom: .25rem;
        width: fit-content;
        justify-content: flex-start;
    }

    .site-nav--mobile a,
    .site-nav--mobile summary {
        width: 100%;
        min-height: 0;
        padding: .8rem 0;
        border-radius: 0;
        justify-content: space-between;
        border-bottom: 1px solid rgba(15, 23, 42, 0.12);
        background: #fff;
    }

    .site-nav--mobile a.is-active {
        background: transparent;
        border-radius: 0;
        margin: 0;
        padding-left: 0;
        padding-right: 0;
        justify-content: space-between;
    }

    .site-nav--mobile .site-nav__submenu a.is-active {
        padding: .8rem 1rem;
        border-bottom: 0;
        border-radius: 999px;
        background: rgba(7, 54, 153, 0.06);
        width: 100%;
        margin-bottom: .45rem;
    }

    .site-nav--mobile .site-nav__group {
        width: 100%;
    }

    .site-nav--mobile .site-nav__submenu {
        margin: 0;
        padding: 0;
        border: 0;
        box-shadow: none;
    }

    .site-nav--mobile .site-nav__submenu a {
        padding: .85rem 0 .85rem 1rem;
        border-bottom: 1px solid rgba(15, 23, 42, 0.10);
    }

    .site-header__cta--mobile {
        min-width: 0;
        width: auto;
        height: 28px;
        padding: 0 .85rem;
        margin-left: 0;
        justify-self: end;
    }

    .site-brand__logo {
        width: 160px;
    }

    .site-nav a,
    .site-nav summary {
        font-size: 13px;
    }

    .site-header__cta {
        display: inline-flex;
        font-size: 13px;
    }

    .hero__kicker {
        font-size: 1.43rem;
    }

    .hero__copy h1 {
        font-size: clamp(2.15rem, 12vw, 3rem);
    }

    .hero__copy h2 {
        font-size: clamp(1.43rem, 7vw, 1.86rem);
    }

    .hero__actions,
    .hero__actions--secondary {
        justify-content: center;
        flex-direction: column;
    }

    .button--buy {
        width: 100%;
        min-width: 0;
    }

    .product-band__card {
        padding: 1.2rem;
    }

    .site-footer__main {
        gap: 2rem;
        padding: 3rem 0 2.5rem;
    }

    .site-footer__logo img {
        width: 190px;
    }

    .site-footer__description,
    .site-footer__links-list,
    .site-footer__contact {
        font-size: 15px;
        line-height: 24.27px;
    }

    .site-footer__links-block h3,
    .site-footer__contact-block h3 {
        font-size: 1.29rem;
    }

    .site-footer__policy-links {
        gap: .25rem 0;
        justify-content: center;
        text-align: center;
    }

    .site-footer__policy-links a {
        padding: 0 .55rem;
    }

    .site-footer__copyright {
        text-align: center;
    }

    .showcase,
    .feature-callout,
    .catalog {
        padding: 3rem 0;
    }

    .catalog__grid {
        gap: 1rem;
    }

    .feature-callout__content {
        padding-top: 0;
    }

    .feature-callout__item {
        margin-bottom: 2rem;
        padding-right: 0;
        text-align: left;
    }

    .feature-callout__copy {
        text-align: left;
    }

    .feature-callout__rule {
        display: none;
    }

    .feature-callout__media {
        justify-items: center;
        margin-top: .5rem;
    }
}

.product-page {
    background: #fff;
    color: var(--ox-text);
    font-family: Poppins, system-ui, sans-serif;
}

.product-page__hero {
    padding: 2.5rem 0 2rem;
}

.product-page__hero-grid {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: 2rem;
    align-items: center;
}

.product-page__hero-copy {
    padding: 1rem 0;
}

.product-page__eyebrow {
    margin: 0 0 .85rem;
    color: var(--ox-blue);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.product-page__hero-copy h1 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(2.4rem, 4.6vw, 3.9rem);
    line-height: 1.06;
    font-weight: 800;
    letter-spacing: -.04em;
}

.product-page__lede {
    margin: 1.15rem 0 0;
    color: #5f5f5f;
    font-size: 1.06rem;
    line-height: 1.8;
    max-width: 48rem;
}

.product-page__pricing {
    display: flex;
    gap: 1.5rem 2rem;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-top: 1.4rem;
}

.product-page__price-block {
    display: grid;
    gap: .2rem;
}

.product-page__price-label {
    color: #7c7c7c;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.product-page__price {
    color: #1a1a1a;
    font-size: clamp(1.85rem, 3vw, 2.45rem);
    line-height: 1.1;
    font-weight: 800;
}

.product-page__price--range {
    color: #b80b07;
}

.product-page__button.button--buy-dark {
    width: 170px;
    min-width: 0;
    height: 42px;
    margin-top: 1.6rem;
    padding: 0 1.05rem 0 1.2rem;
    font-size: 13px;
    line-height: 13px;
}

.product-page__button.is-disabled {
    opacity: .45;
    pointer-events: none;
    filter: grayscale(.2);
}

.product-page__pricing--variable {
    display: grid;
    gap: 1rem;
}

.product-page__variants {
    display: grid;
    gap: .7rem;
}

.product-page__variant-label {
    color: #7c7c7c;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.product-page__variant-options {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
}

.product-page__variant-option,
.product-page__variant-clear {
    border: 1px solid #a9a9a9;
    border-radius: .35rem;
    background: #fff;
    color: #1a1a1a;
    font: inherit;
    line-height: 1;
    transition: all .18s ease;
}

.product-page__variant-option {
    padding: .85rem 1rem;
    min-height: 42px;
    font-size: 1rem;
}

.product-page__variant-option.is-active {
    border-color: #122f9e;
    background: #122f9e;
    color: #fff;
    box-shadow: 0 0 0 1px #122f9e;
}

.product-page__variant-clear {
    width: fit-content;
    padding: 0;
    border: 0;
    background: transparent;
    color: #2046a8;
    font-size: 1rem;
    text-align: left;
}

.product-page__selected-price {
    color: #a89a00;
    font-size: clamp(1.55rem, 2.4vw, 2.05rem);
    line-height: 1.1;
    font-weight: 500;
    margin-top: .9rem;
}

.product-page__purchase {
    display: flex;
    align-items: flex-end;
    gap: .9rem;
    flex-wrap: wrap;
    margin-top: 1.4rem;
}

.product-page__qty {
    display: grid;
    gap: .35rem;
}

.product-page__qty-label {
    color: #7c7c7c;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.product-page__qty input {
    width: 82px;
    height: 42px;
    border: 1px solid #d7d7d7;
    border-radius: .85rem;
    background: #fff;
    color: #1a1a1a;
    font-size: 1rem;
    font-weight: 600;
    text-align: center;
}

.product-page__hero-media {
    display: grid;
    justify-items: center;
}

.product-page__hero-media img {
    width: min(100%, 760px);
    max-height: 560px;
    object-fit: contain;
    filter: drop-shadow(0 26px 30px rgba(0, 0, 0, 0.16));
}

.product-page__section {
    padding: 3.1rem 0;
}

.product-page__section--alt {
    background: #f8fbff;
}

.product-page__summary-copy {
    max-width: 860px;
    text-align: center;
}

.product-page__summary-copy h2 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(2rem, 3.2vw, 2.8rem);
    line-height: 1.12;
    font-weight: 700;
}

.product-page__summary-copy p {
    margin: 1rem auto 0;
    color: #5f5f5f;
    font-size: 1.06rem;
    line-height: 1.8;
    max-width: 760px;
}

.product-page__split {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 2.2rem;
    align-items: center;
}

.product-page__split--reverse {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.product-page__media {
    display: grid;
    justify-items: center;
    gap: .9rem;
}

.product-page__media img {
    width: min(100%, 760px);
    max-height: 500px;
    object-fit: contain;
}

.product-page__media--framed {
    padding: 1rem;
    border: 1px solid rgba(15, 23, 42, 0.09);
    border-radius: 1.4rem;
    background: #fff;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
}

.product-page__brochure {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    padding: .72rem 1rem;
    border-radius: 999px;
    background: var(--ox-blue);
    color: #fff;
    font-size: .92rem;
    font-weight: 600;
    line-height: 1;
}

.product-page__brochure-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: .65rem;
    background: rgba(255, 255, 255, 0.16);
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
}

.product-page__content {
    padding: 0 1rem;
}

.product-page__content h2 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(1.9rem, 3vw, 2.8rem);
    line-height: 1.08;
    font-weight: 700;
    letter-spacing: -.03em;
}

.product-page__intro,
.product-page__text {
    margin: 1rem 0 0;
    color: #5f5f5f;
    font-size: 1.03rem;
    line-height: 1.75;
}

.product-page__checklist {
    list-style: none;
    margin: 1.2rem 0 0;
    padding: 0;
    display: grid;
    gap: .8rem;
}

.product-page__checklist li {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    color: #5f5f5f;
    font-size: 1.01rem;
    line-height: 1.6;
}

.product-page__checklist li::before {
    content: "✓";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 1.15rem;
    width: 1.15rem;
    height: 1.15rem;
    margin-top: .2rem;
    border: 2px solid #49b63f;
    border-radius: 50%;
    color: #49b63f;
    font-size: .74rem;
    font-weight: 700;
    line-height: 1;
}

.product-page__price-section {
    padding-top: 2.5rem;
    padding-bottom: 2rem;
}

.product-page__price-copy {
    text-align: center;
    max-width: 920px;
}

.product-page__price-copy h2 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(2rem, 3vw, 2.7rem);
    line-height: 1.12;
    font-weight: 700;
}

.product-page__price-copy p {
    margin: 1rem auto 0;
    color: #5f5f5f;
    font-size: 1.08rem;
    line-height: 1.8;
    max-width: 760px;
}

.product-page__support-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.4rem;
}

.product-page__support-card {
    border: 1px solid rgba(15, 23, 42, 0.09);
    border-radius: 1.35rem;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.product-page__support-card-media {
    padding: 1.15rem 1.15rem 0;
}

.product-page__support-card-media img {
    width: 100%;
    height: 300px;
    object-fit: contain;
    object-position: center center;
    display: block;
}

.product-page__support-card-body {
    padding: .7rem 1.15rem 1.2rem;
}

.product-page__support-card h3 {
    margin: 0;
    color: #1a1a1a;
    font-size: 1.32rem;
    font-weight: 700;
}

.product-page__support-card p {
    margin: .5rem 0 0;
    color: #5f5f5f;
    font-size: 1rem;
    line-height: 1.7;
}

.product-page__heading {
    text-align: center;
    margin-bottom: 1.5rem;
}

.product-page__heading h2 {
    margin: 0;
    color: #1a1a1a;
    font-size: clamp(2rem, 3vw, 2.6rem);
    line-height: 1.12;
    font-weight: 700;
}

.product-page__highlights-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.2rem 2rem;
    align-items: start;
}

.product-page__accordion-col {
    display: grid;
    gap: .6rem;
}

.product-page__accordion-item {
    border-top: 1px solid rgba(15, 23, 42, 0.12);
    padding-top: .15rem;
}

.product-page__accordion-item summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .85rem 0;
    color: #445266;
    font-size: 1.03rem;
    font-weight: 700;
}

.product-page__accordion-item summary::-webkit-details-marker {
    display: none;
}

.product-page__accordion-icon {
    flex: 0 0 14px;
    width: 14px;
    height: 14px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    transition: transform .2s ease;
    margin-left: .5rem;
}

.product-page__accordion-item[open] .product-page__accordion-icon {
    transform: rotate(225deg);
}

.product-page__accordion-body {
    padding: 0 0 1rem;
}

.product-page__accordion-body p {
    margin: 0;
    color: #5f5f5f;
    font-size: 1rem;
    line-height: 1.75;
}

.product-page__box-grid {
    display: grid;
    grid-template-columns: minmax(320px, 440px) minmax(0, 640px);
    justify-content: center;
    gap: clamp(2rem, 4vw, 4.5rem);
    align-items: center;
    max-width: 1140px;
    margin: 0 auto;
}

.product-page__box-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: .7rem;
    max-width: 100%;
}

.product-page__box-list li {
    display: flex;
    align-items: center;
    gap: .7rem;
    color: #5f5f5f;
    font-size: 1rem;
    line-height: 1.5;
}

.product-page__check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.15rem;
    height: 1.15rem;
    border-radius: 50%;
    border: 2px solid #49b63f;
    color: #49b63f;
    font-size: .74rem;
    font-weight: 700;
    flex: 0 0 1.15rem;
}

.product-page__box-image {
    display: grid;
    justify-items: center;
    align-items: center;
}

.product-page__box-image img {
    width: min(100%, 660px);
    max-height: 520px;
    object-fit: contain;
}

.product-page__flow-grid {
    display: grid;
    justify-items: center;
    gap: 2.2rem;
}

.product-page__flow-table-wrap {
    width: min(100%, 1180px);
}

.product-page__flow-table {
    width: 100%;
    border-collapse: collapse;
    text-align: center;
    font-size: 1rem;
    color: #6a6a6a;
}

.product-page__flow-table thead th {
    padding: 1.05rem 1rem;
    background: #5e5e5e;
    color: #fff;
    font-size: 1.02rem;
    font-weight: 500;
    letter-spacing: 0;
    border: 3px solid #d9d9d9;
}

.product-page__flow-table tbody td {
    padding: .95rem 1rem;
    border: 3px solid #d9d9d9;
    background: #fff;
    font-size: 1rem;
    line-height: 1.35;
}

.product-page__flow-table--compact {
    width: min(100%, 900px);
    margin: 0 auto;
}

.product-page__flow-note {
    margin: .25rem auto 0;
    max-width: 980px;
    text-align: center;
    color: #6d6d6d;
    font-size: .98rem;
    line-height: 1.65;
}

.product-page__spec-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.4rem;
}

.product-page__spec-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 1rem;
}

.product-page__spec-table tr:nth-child(odd) {
    background: #f3f3f3;
}

.product-page__spec-table td {
    padding: 1rem 1.1rem;
    vertical-align: middle;
    color: #5f5f5f;
    border-bottom: 1px solid #e9e9e9;
}

.product-page__spec-table td:first-child {
    width: 58%;
}

.product-page__spec-table td:last-child {
    text-align: right;
    color: #1a1a1a;
}

.product-page__spec-table strong {
    font-weight: 700;
    color: #1a1a1a;
}

.product-page__yes {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 50%;
    background: #49b63f;
    color: #fff;
    font-size: .85rem;
    font-weight: 700;
}

@media (max-width: 1100px) {
    .product-page__hero-grid,
    .product-page__split,
    .product-page__box-grid,
    .product-page__spec-grid,
    .product-page__highlights-grid,
    .product-page__support-grid {
        grid-template-columns: 1fr;
    }

    .product-page__hero-media {
        order: -1;
    }

    .product-page__split .product-page__media {
        order: -1;
    }

    .product-page__split--reverse .product-page__media {
        order: -1;
    }

    .product-page__hero,
    .product-page__section {
        padding: 2.25rem 0;
    }

    .product-page__hero-grid {
        gap: 1.5rem;
    }

    .product-page__hero-copy {
        text-align: center;
    }

    .product-page__pricing {
        justify-content: center;
    }

    .product-page__purchase {
        justify-content: center;
    }

    .product-page__button.button--buy-dark {
        margin-inline: auto;
    }

    .product-page__content {
        padding: 0;
    }

    .product-page__media img,
    .product-page__hero-media img,
    .product-page__box-image img {
        width: 100%;
        max-width: 640px;
        height: auto;
        max-height: none;
    }

    .product-page__support-card-media img {
        height: 220px;
    }

    .product-page__box-grid {
        gap: 1.2rem;
    }

    .product-page__flow-table thead th,
    .product-page__flow-table tbody td {
        padding: .8rem .75rem;
        border-width: 2px;
        font-size: .95rem;
    }

    .product-page__flow-table,
    .product-page__spec-table {
        table-layout: fixed;
    }

    .product-page__flow-table th,
    .product-page__flow-table td,
    .product-page__spec-table td {
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .product-page__spec-table td:first-child {
        width: 52%;
    }
}

@media (max-width: 768px) {
    .product-page .container {
        width: min(100%, calc(100% - 1.5rem));
    }

    .product-page__hero-copy h1 {
        font-size: clamp(2.2rem, 10vw, 3rem);
    }

    .product-page__hero-media img {
        max-height: 340px;
    }

    .product-page__lede,
    .product-page__intro,
    .product-page__text,
    .product-page__price-copy p,
    .product-page__checklist li,
    .product-page__support-card p,
    .product-page__accordion-body p,
    .product-page__spec-table td {
        font-size: .98rem;
        line-height: 1.65;
    }

    .product-page__button.button--buy-dark {
        width: 160px;
        height: 40px;
    }

    .product-page__heading {
        margin-bottom: 1rem;
    }

    .product-page__heading h2 {
        font-size: clamp(1.7rem, 7vw, 2.2rem);
    }

    .product-page__box-list li {
        font-size: .98rem;
    }

    .product-page__qty input {
        height: 40px;
    }

    .product-page__split {
        gap: 1rem;
    }

    .product-page__support-grid {
        gap: 1rem;
    }

    .product-page__support-card {
        border-radius: 1.1rem;
    }

    .product-page__support-card-media {
        padding: .95rem .95rem 0;
    }

    .product-page__support-card-media img {
        height: 190px;
    }

    .product-page__support-card-body {
        padding: .6rem .95rem 1rem;
    }

    .product-page__accordion-item summary {
        padding: .75rem 0;
        font-size: .98rem;
    }

    .product-page__flow-grid {
        gap: 1.4rem;
    }

    .product-page__flow-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .product-page__flow-table {
        min-width: 520px;
    }

    .product-page__spec-grid {
        gap: 1rem;
    }

    .product-page__spec-table {
        min-width: 100%;
    }

    .product-page__flow-note {
        font-size: .95rem;
    }

    .product-page__spec-table td {
        padding: .85rem .8rem;
    }
}

.site-header__cart {
    position: relative;
}

.site-header__cart-count {
    position: absolute;
    top: 1px;
    right: 1px;
    min-width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
    border-radius: 999px;
    background: var(--ox-red);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    line-height: 1;
}

.page-hero--cart,
.page-hero--checkout {
    background: linear-gradient(135deg, #0f3192, #1c43ab);
    color: #fff;
}

.page-hero--cart .container,
.page-hero--checkout .container,
.section--cart .container,
.section--checkout .container {
    width: min(1340px, calc(100% - 3rem));
}

.page-hero--cart .eyebrow,
.page-hero--checkout .eyebrow,
.page-hero--cart h1,
.page-hero--checkout h1,
.page-hero--cart .page-hero__lead,
.page-hero--checkout .page-hero__lead {
    color: inherit;
}

.section--cart,
.section--checkout {
    background:
        radial-gradient(circle at top right, rgba(11, 48, 144, 0.07), transparent 26%),
        linear-gradient(180deg, #f7f9ff 0%, #ffffff 38%);
}

.cart-notice {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    padding: 1rem 1.2rem;
    border: 2px solid rgba(11, 48, 144, 0.9);
    border-radius: 1rem;
    background: #fff;
    color: #334155;
    box-shadow: var(--ox-shadow);
}

.cart-notice a {
    color: var(--ox-blue);
    font-weight: 600;
}

.cart-notice--success {
    border-color: rgba(21, 128, 61, 0.9);
}

.cart-empty {
    display: grid;
    gap: 1rem;
    justify-items: start;
    padding: 2rem;
    border: 1px solid var(--ox-border);
    border-radius: 1.4rem;
    background: #fff;
    box-shadow: var(--ox-shadow);
}

.cart-empty h2,
.cart-summary h2,
.checkout-card h2,
.checkout-card h3 {
    margin: 0;
    color: #1f2937;
}

.cart-layout,
.checkout-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.8fr) minmax(320px, .9fr);
    gap: 1.5rem;
    align-items: start;
}

.cart-card,
.cart-summary,
.checkout-card {
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 1.4rem;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: var(--ox-shadow);
}

.cart-table__head,
.cart-table__row {
    display: grid;
    grid-template-columns: minmax(0, 2.2fr) minmax(110px, .8fr) minmax(160px, .9fr) minmax(120px, .8fr);
    gap: 1rem;
    align-items: center;
    padding: 1.4rem 1.6rem;
}

.cart-table__head {
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    color: #22315e;
    font-family: Montserrat, system-ui, sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
}

.cart-table__row + .cart-table__row {
    border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.cart-table__product {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.cart-remove {
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.06);
    color: #7c869b;
    font-size: 1.65rem;
    line-height: 1;
    cursor: pointer;
}

.cart-product {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.cart-product__image {
    width: 92px;
    height: 92px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .5rem;
    border-radius: 1rem;
    background: #f8fbff;
}

.cart-product__image img {
    max-height: 100%;
    object-fit: contain;
}

.cart-product__name,
.cart-table__price,
.cart-table__total {
    color: #24314e;
    font-size: 1.05rem;
    font-weight: 600;
}

.qty-stepper {
    display: inline-grid;
    grid-template-columns: 40px 64px 40px;
    align-items: center;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: .95rem;
    background: #fff;
}

.qty-stepper__button {
    width: 40px;
    height: 44px;
    border: 0;
    background: #f6f8fc;
    color: #6b7280;
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
}

.qty-stepper input {
    width: 64px;
    height: 44px;
    border: 0;
    border-left: 1px solid rgba(15, 23, 42, 0.08);
    border-right: 1px solid rgba(15, 23, 42, 0.08);
    text-align: center;
    font-size: 1rem;
    font-weight: 600;
    color: #24314e;
}

.cart-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.4rem 1.6rem 1.6rem;
}

.cart-link {
    color: var(--ox-blue);
    font-weight: 600;
}

.cart-summary {
    padding: 1.6rem;
}

.cart-summary__line,
.checkout-summary__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 0;
    color: #24314e;
}

.cart-summary__line + .cart-summary__line,
.checkout-summary__item + .checkout-summary__item {
    border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.cart-summary__button,
.checkout-summary__button {
    width: 100%;
    margin-top: 1.1rem;
}

.checkout-form {
    display: grid;
    gap: 1.5rem;
}

.checkout-card {
    padding: 1.6rem;
}

.checkout-card__header {
    margin-bottom: 1rem;
}

.checkout-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, .95fr);
    gap: 1.8rem;
}

.checkout-column {
    display: grid;
    gap: .95rem;
    align-content: start;
}

.checkout-column label,
.checkout-form__row {
    display: grid;
    gap: .45rem;
}

.checkout-form__row--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.checkout-column span {
    color: #4b5563;
    font-size: .95rem;
    font-weight: 500;
}

.checkout-column em {
    color: #cf2024;
    font-style: normal;
}

.checkout-column input,
.checkout-column select,
.checkout-column textarea {
    width: 100%;
    min-height: 48px;
    padding: .9rem 1rem;
    border: 1px solid rgba(15, 23, 42, 0.14);
    border-radius: .95rem;
    background: #fff;
    color: #24314e;
    font: inherit;
}

.checkout-column textarea {
    min-height: 140px;
    resize: vertical;
}

.checkout-payment {
    display: flex;
    align-items: center;
    gap: .7rem;
    color: #24314e;
    font-size: 1rem;
    font-weight: 500;
}

.checkout-payment__note {
    margin-top: .9rem;
    padding: .95rem 1rem;
    border-radius: .9rem;
    background: #0f3192;
    color: #fff;
}

.checkout-summary {
    display: grid;
    gap: 1.5rem;
}

.checkout-summary__item--total {
    font-size: 1.05rem;
    font-weight: 700;
}

@media (max-width: 980px) {
    .cart-layout,
    .checkout-layout,
    .checkout-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .cart-notice,
    .cart-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .cart-table__head {
        display: none;
    }

    .cart-table__row {
        grid-template-columns: 1fr;
        gap: .85rem;
    }

    .cart-table__price::before,
    .cart-table__quantity::before,
    .cart-table__total::before {
        display: block;
        margin-bottom: .25rem;
        color: #7c869b;
        font-size: .78rem;
        font-weight: 700;
        letter-spacing: .08em;
        text-transform: uppercase;
    }

    .cart-table__price::before {
        content: "Price";
    }

    .cart-table__quantity::before {
        content: "Quantity";
    }

    .cart-table__total::before {
        content: "Total";
    }

    .checkout-form__row--two {
        grid-template-columns: 1fr;
    }
}
