:root {
    --bg: #ffffff;
    --surface: #f6f7f9;
    --surface-2: #eef5f2;
    --ink: #151515;
    --muted: #667085;
    --line: #e4e7ec;
    --brand: #ff6f61;
    --brand-dark: #d94f43;
    --teal: #0f766e;
    --yellow: #f5c84b;
    --dark: #20242b;
    --shadow: 0 20px 50px rgba(16, 24, 40, 0.13);
    --radius: 8px;
    --section-space: 84px;
}


* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: Inter, Arial, sans-serif;
    color: var(--ink);
    background: var(--bg);
    letter-spacing: 0;
    overflow-x: hidden;
    -webkit-tap-highlight-color: transparent;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    touch-action: manipulation;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
select {
    font: inherit;
}

button {
    cursor: pointer;
}

img {
    display: block;
    max-width: 100%;
}

.container {
    width: min(1240px, calc(100% - 36px));
    margin: 0 auto;
}

.topbar {
    color: var(--white);
    background: var(--dark);
    font-size: 13px;
    padding-left: env(safe-area-inset-left, 0px);
    padding-right: env(safe-area-inset-right, 0px);
}

.topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 40px;
}

.topbar span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.site-header {
    position: sticky;
    top: 12px;
    z-index: 20;
    width: min(1280px, calc(100% - 28px));
    margin: 10px auto 0;
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 14px 34px rgba(16, 24, 40, 0.08);
    backdrop-filter: blur(18px);
}

.site-header .container {
    width: min(1240px, calc(100% - 32px));
}

.header-main {
    position: relative;
    display: grid;
    grid-template-columns: 190px minmax(380px, 1fr) auto;
    align-items: center;
    gap: 24px;
    min-height: 88px;
}

.logo {
    display: inline-flex;
    align-items: center;
    gap: 0;
    min-width: 170px;
}

.logo__mark {
    display: grid;
    width: 46px;
    height: 46px;
    place-items: center;
    color: #fff;
    background: var(--ink);
    border-radius: 8px;
    font-weight: 800;
}

.logo strong,
.logo small {
    display: block;
    line-height: 1.2;
}

.logo strong {
    font-size: 22px;
    letter-spacing: 0;
    white-space: nowrap;
}

.logo small {
    margin-top: 3px;
    color: var(--muted);
    font-size: 10px;
    font-style: italic;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0;
}








.search {
    position: relative;
    z-index: 35;
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) auto;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
}

.search i {
    color: var(--muted);
    text-align: center;
}

.search input {
    width: 100%;
    min-width: 0;
    height: 52px;
    font-size: 16px;
    border: 0;
    outline: 0;
    color: var(--ink);
    background: transparent;
}

.search button {
    height: 44px;
    margin-right: 5px;
    padding: 0 21px;
    color: #fff;
    border: 0;
    border-radius: 6px;
    background: var(--brand);
    font-weight: 800;
}

.search-results {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    left: 0;
    z-index: 80;
    display: none;
    padding: 8px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    max-height: min(420px, 70vh);
    overflow: auto;
}

.search-results.is-open {
    display: grid;
    gap: 6px;
}

.search-result {
    display: grid;
    grid-template-columns: 46px 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border-radius: 6px;
}

.search-result:hover {
    background: var(--surface);
}

.search-result img {
    width: 46px;
    height: 46px;
    border-radius: 6px;
    object-fit: cover;
}

.search-result strong,
.search-result small {
    display: block;
}

.search-result small {
    margin-top: 4px;
    color: var(--muted);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-action,
.cart-button,
.icon-btn {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--card-bg);
}

.header-action,
.cart-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 46px;
    padding: 0 14px;
    color: var(--ink);
    font-size: 14px;
    font-weight: 800;
}

.cart-button {
    position: relative;
}

.cart-button strong {
    display: grid;
    min-width: 20px;
    height: 20px;
    place-items: center;
    color: var(--badge-text);
    background: var(--brand);
    border-radius: 999px;
    font-size: 11px;
}

.cart-button.is-just-added {
    animation: cartButtonPulse 0.62s ease;
}

.cart-feedback-badge {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 10px;
    color: #fff;
    background: var(--ink);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-6px) scale(0.92);
    transition: opacity 0.22s ease, transform 0.22s ease;
}

.cart-feedback-badge.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.cart-feedback-badge.is-error {
    background: #b42318;
}

.cart-flyer {
    --cart-fly-x: 0px;
    --cart-fly-y: 0px;
    position: fixed;
    z-index: 120;
    display: grid;
    place-items: center;
    object-fit: cover;
    border-radius: 12px;
    pointer-events: none;
    box-shadow: 0 16px 28px rgba(16, 24, 40, 0.22);
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
    opacity: 0.96;
}

.cart-flyer:not(img) {
    color: var(--white);
    background: linear-gradient(135deg, var(--brand), #ff8a7a);
}

.cart-flyer.is-moving {
    animation: cartFlyToIcon 0.74s cubic-bezier(0.2, 0.72, 0.2, 1) forwards;
}

@keyframes cartFlyToIcon {
    0% {
        transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
        opacity: 0.96;
    }
    68% {
        opacity: 1;
    }
    100% {
        transform: translate3d(var(--cart-fly-x), var(--cart-fly-y), 0) scale(0.22) rotate(12deg);
        opacity: 0.08;
    }
}

@keyframes cartButtonPulse {
    0% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(255, 111, 97, 0);
    }
    40% {
        transform: scale(1.06);
        box-shadow: 0 0 0 8px rgba(255, 111, 97, 0.16);
    }
    100% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(255, 111, 97, 0);
    }
}

.icon-btn {
    display: grid;
    width: 46px;
    height: 46px;
    place-items: center;
    color: var(--ink);
}

.mobile-menu-btn {
    display: none;
}

.nav-wrap {
    border-top: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.86);
    border-radius: 0 0 var(--radius) var(--radius);
}

.nav {
    display: flex;
    align-items: center;
    gap: 30px;
    min-height: 50px;
    font-size: 14px;
    font-weight: 700;
}

.nav a {
    color: #30343b;
}

.nav a:hover {
    color: var(--link-hover);
}

.hero {
    position: relative;
    overflow: hidden;
    padding: 64px 0 44px;
    background: linear-gradient(115deg, #fff 0%, #fff4f2 46%, #edf8f5 100%);
}

.hero__grid {
    display: grid;
    grid-template-columns: minmax(480px, 0.9fr) minmax(520px, 1.1fr);
    align-items: center;
    gap: 40px;
}

.eyebrow {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    padding: 0 12px;
    color: var(--brand-dark);
    background: #fff0ed;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    text-align: center;
}

.hero h1,
.section h2 {
    margin: 14px 0 0;
    line-height: 1.04;
    letter-spacing: 0;
}

.hero h1 {
    max-width: 640px;
    font-size: clamp(46px, 4.6vw, 66px);
    overflow-wrap: anywhere;
}

.hero h1 span {
    display: block;
}

.hero p {
    max-width: 590px;
    margin: 20px 0 0;
    color: #475467;
    font-size: 18px;
    line-height: 1.7;
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 28px;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    min-height: 50px;
    padding: 0 21px;
    border: 0;
    border-radius: var(--radius);
    font-weight: 800;
}

.btn-primary {
    color: var(--button-primary-text);
    background: var(--brand);
}

.btn-primary:hover {
    color: var(--button-hover-text);
    background: var(--button-hover-bg);
}

.btn-ghost {
    color: var(--button-ghost-text);
    background: var(--button-ghost-bg);
    border: 1px solid var(--line);
}

.btn-dark {
    color: #fff;
    background: var(--dark);
}

.full {
    width: 100%;
}

.hero__stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    max-width: 640px;
    margin-top: 32px;
}

.hero__stats span {
    padding: 16px;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(255, 255, 255, 0.9);
    border-radius: var(--radius);
    color: var(--muted);
    font-size: 14px;
}

.hero__stats strong {
    display: block;
    margin-bottom: 3px;
    color: var(--ink);
    font-size: 23px;
}

.hero__media {
    position: relative;
    min-height: 540px;
    border-radius: 8px;
}

.hero__media img {
    width: 100%;
    height: 540px;
    border-radius: 8px;
    box-shadow: var(--shadow);
    object-fit: cover;
}

.floating-card {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 13px 16px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(255, 255, 255, 0.95);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    font-size: 15px;
    font-weight: 800;
}

.floating-card i {
    color: var(--teal);
}

.floating-card--top {
    top: 18px;
    left: 18px;
}

.floating-card--bottom {
    right: 18px;
    bottom: 18px;
}

.trust-strip {
    background: var(--ink);
}

.trust-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
}

.trust-grid div {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 84px;
    color: #fff;
    font-weight: 700;
}

.trust-grid i {
    color: var(--yellow);
}

.section {
    padding: var(--section-space) 0;
}

.section-muted {
    background: var(--surface);
}

.section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 28px;
    margin-bottom: 30px;
}

.section h2 {
    font-size: clamp(34px, 3vw, 48px);
}

.link-more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--teal);
    font-weight: 800;
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.category-card {
    display: grid;
    gap: 10px;
    min-height: 180px;
    padding: 24px;
    background: var(--card-bg);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.category-card:hover {
    background: var(--card-hover-bg);
    border-color: var(--card-hover-border);
    box-shadow: var(--shadow);
}

.category-card__icon {
    display: grid;
    width: 56px;
    height: 56px;
    place-items: center;
    color: var(--teal);
    background: var(--surface-2);
    border-radius: 8px;
    font-size: 23px;
}

.category-card strong {
    align-self: end;
    font-size: 20px;
}

.category-card small {
    color: var(--muted);
    font-size: 14px;
}

.segmented {
    display: inline-flex;
    padding: 5px;
    background: var(--card-bg);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.segmented button {
    min-height: 40px;
    padding: 0 16px;
    border: 0;
    border-radius: 6px;
    background: transparent;
    color: var(--muted);
    font-weight: 800;
}

.segmented button.active {
    color: var(--white);
    background: var(--ink);
}

.product-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.product-card {
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
    background: var(--card-bg);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    content-visibility: auto;
    contain-intrinsic-size: 360px 460px;
    cursor: pointer;
}

.product-card:focus-visible {
    outline: 3px solid rgba(15, 118, 110, 0.28);
    outline-offset: 3px;
}

.product-card:hover {
    background: var(--card-hover-bg);
    box-shadow: var(--shadow);
    transform: translateY(-2px);
    transition: 0.18s ease;
}

.product-card__image {
    position: relative;
    display: block;
    aspect-ratio: 1.22 / 1;
    overflow: hidden;
    background: #eef0f2;
}

.product-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.25s ease;
}

.product-card:hover .product-card__image img {
    transform: scale(1.04);
}

.product-card__image span {
    position: absolute;
    top: 14px;
    left: 14px;
    padding: 8px 11px;
    color: var(--badge-text);
    background: var(--brand);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
}

.wishlist {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 1;
    display: grid;
    width: 42px;
    height: 42px;
    place-items: center;
    color: var(--ink);
    background: var(--card-bg);
    border: 1px solid var(--line);
    border-radius: 999px;
}

.product-card__body {
    display: grid;
    grid-template-rows: auto auto auto 1fr auto;
    padding: 19px;
}

.product-card__body small {
    color: var(--teal);
    font-weight: 800;
    font-size: 14px;
    min-height: 20px;
}

.product-card h3 {
    min-height: 56px;
    margin: 9px 0 11px;
    font-size: 20px;
    line-height: 1.35;
}

.rating {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--muted);
    font-size: 14px;
}

.rating i {
    color: #ffb020;
}

.rating strong {
    color: var(--ink);
}

.chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-height: 66px;
    margin-top: 14px;
}

.chips span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    color: #475467;
    background: var(--surface);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
}

.product-card__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 16px;
}

.price strong,
.price del {
    display: block;
}

.price strong {
    font-size: 22px;
}

.price del {
    margin-top: 4px;
    color: var(--muted);
    font-size: 14px;
}

.mini-cart {
    display: grid;
    width: 50px;
    height: 50px;
    place-items: center;
    color: #fff;
    background: var(--ink);
    border: 0;
    border-radius: var(--radius);
}

.mini-cart.is-disabled,
.btn.is-disabled,
.mini-cart:disabled,
.btn:disabled {
    cursor: not-allowed;
    opacity: 0.52;
}

.stock-indicator {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    margin-top: 8px;
    padding: 0 9px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
}

.stock-indicator--in {
    color: #027a48;
    background: #ecfdf3;
}

.stock-indicator--low {
    color: #b54708;
    background: #fffaeb;
}

.stock-indicator--out {
    color: #b42318;
    background: #fef3f2;
}

.detail-stock-row {
    margin-top: 10px;
}

.customizer-section {
    background: linear-gradient(180deg, #fff 0%, #fff8f6 100%);
}

.customizer-grid {
    display: grid;
    grid-template-columns: minmax(390px, 0.8fr) minmax(560px, 1.2fr);
    gap: 40px;
    align-items: center;
}

.customizer-copy p,
.corporate p,
.footer p {
    color: var(--muted);
    line-height: 1.7;
    font-size: 16px;
}

.process-list {
    display: grid;
    gap: 12px;
    margin-top: 26px;
}

.process-list div {
    display: grid;
    grid-template-columns: 52px 1fr;
    column-gap: 14px;
    padding: 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.process-list span {
    display: grid;
    grid-row: span 2;
    width: 46px;
    height: 46px;
    place-items: center;
    color: #fff;
    background: var(--ink);
    border-radius: 8px;
    font-weight: 800;
}

.process-list small {
    margin-top: 4px;
    color: var(--muted);
    font-size: 14px;
}

.designer {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: 18px;
    padding: 19px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.designer__preview {
    display: grid;
    grid-template-rows: 1fr auto;
    min-height: 480px;
    padding: 21px;
    background: #f4f6f8;
    border-radius: var(--radius);
}

.mock-product {
    position: relative;
    display: grid;
    align-self: center;
    justify-self: center;
    width: min(290px, 76%);
    aspect-ratio: 1 / 1;
    place-items: center;
    background:
        radial-gradient(circle at 32% 20%, rgba(255, 255, 255, 0.72), transparent 28%),
        linear-gradient(145deg, #ff6f61, #d94f43);
    border-radius: 50% 50% 44% 44%;
    box-shadow: inset -18px -24px 42px rgba(0, 0, 0, 0.18), 0 28px 50px rgba(16, 24, 40, 0.2);
}

.mock-product::after {
    content: "";
    position: absolute;
    right: -62px;
    width: 92px;
    height: 132px;
    border: 20px solid currentColor;
    border-left: 0;
    border-radius: 0 70px 70px 0;
    color: rgba(255, 111, 97, 0.84);
}

.mock-product__label {
    position: relative;
    z-index: 1;
    max-width: 70%;
    padding: 12px 18px;
    color: #fff;
    border: 2px solid rgba(255, 255, 255, 0.72);
    border-radius: 8px;
    font-size: clamp(23px, 2.7vw, 38px);
    font-weight: 800;
    text-align: center;
    overflow-wrap: anywhere;
}

.preview-tools {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 58px;
    padding-top: 16px;
    border-top: 1px solid var(--line);
}

.preview-tools span {
    color: var(--muted);
    font-weight: 700;
}

.preview-tools strong {
    font-size: 24px;
}

.designer__form {
    display: grid;
    gap: 14px;
    align-content: start;
}

.designer__form label,
.field-group {
    display: grid;
    gap: 8px;
    color: #344054;
    font-size: 14px;
    font-weight: 800;
}

.designer__form input[type="text"],
.designer__form select,
.quote-form input,
.quote-form select,
.newsletter input {
    width: 100%;
    height: 48px;
    padding: 0 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    outline: 0;
    background: #fff;
}

.designer__form input:focus,
.designer__form select:focus,
.quote-form input:focus,
.quote-form select:focus,
.newsletter input:focus {
    border-color: var(--brand);
}

.swatches {
    display: flex;
    gap: 10px;
}

.swatches button {
    width: 38px;
    height: 38px;
    border: 3px solid #fff;
    border-radius: 999px;
    box-shadow: 0 0 0 1px var(--line);
}

.swatches button.active {
    box-shadow: 0 0 0 2px var(--ink);
}

.swatches button:nth-child(1) {
    background: #ff6f61;
}

.swatches button:nth-child(2) {
    background: #0f766e;
}

.swatches button:nth-child(3) {
    background: #222;
}

.swatches button:nth-child(4) {
    background: #f5c84b;
}

.toggle-row,
.check-row {
    padding: 13px;
    background: var(--surface);
    border-radius: var(--radius);
}

.toggle-row {
    display: grid;
    gap: 11px;
}

.toggle-row label,
.check-row {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--ink);
    font-size: 14px;
    font-weight: 800;
}

.campaign-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.campaign-card {
    min-height: 230px;
    padding: 28px;
    border-radius: var(--radius);
    color: #fff;
}

.campaign-card span {
    display: inline-block;
    color: rgba(255, 255, 255, 0.82);
    font-size: 14px;
    font-weight: 800;
    text-transform: uppercase;
    text-align: center;
}

.campaign-card p {
    max-width: 330px;
    margin: 22px 0 30px;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.15;
}

.campaign-card a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 800;
}

.campaign-card--warm {
    background: linear-gradient(135deg, var(--brand), #f5a05b);
}

.campaign-card--cool {
    background: linear-gradient(135deg, var(--teal), #1da1a1);
}

.campaign-card--dark {
    background: linear-gradient(135deg, var(--dark), #4a5568);
}

.campaign-page-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 18px;
    align-items: start;
}

.campaign-page-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.campaign-page-grid .campaign-card {
    min-height: 260px;
}

.campaign-page-side {
    display: grid;
    gap: 14px;
    position: sticky;
    top: 118px;
}

.campaign-page-note,
.campaign-page-actions {
    display: grid;
    gap: 10px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.campaign-page-note p {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.campaign-page-actions .btn {
    width: 100%;
}

.campaign-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 18px;
    align-items: start;
}

.campaign-detail-main,
.campaign-detail-side {
    min-width: 0;
}

.campaign-detail-main {
    display: grid;
    gap: 16px;
}

.campaign-detail-cover {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius);
    min-height: 280px;
    display: grid;
    align-items: end;
}

.campaign-detail-cover img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.28;
}

.campaign-detail-cover__content {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 12px;
    padding: 28px;
    color: #fff;
}

.campaign-detail-cover__content span {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
    padding: 7px 11px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    font-size: 12px;
    font-weight: 700;
}

.campaign-detail-cover__content strong {
    font-size: 31px;
    line-height: 1.12;
}

.campaign-detail-cover__content p {
    max-width: 620px;
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 15px;
    line-height: 1.65;
}

.campaign-detail-copy {
    display: grid;
    gap: 14px;
    padding: 22px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.campaign-detail-copy h2 {
    margin: 0;
    font-size: 22px;
}

.campaign-detail-copy p,
.campaign-detail-copy ul {
    margin: 0;
    color: var(--muted);
    line-height: 1.75;
}

.campaign-detail-copy ul {
    padding-left: 20px;
}

.campaign-detail-side {
    display: grid;
    gap: 14px;
    position: sticky;
    top: 118px;
}

@media (max-width: 980px) {
    .campaign-page-grid {
        grid-template-columns: 1fr;
    }

    .campaign-page-side,
    .campaign-detail-side {
        position: static;
    }

    .campaign-detail-layout {
        grid-template-columns: 1fr;
    }
}

.corporate {
    color: #fff;
    background: var(--dark);
}

.corporate .eyebrow {
    color: var(--yellow);
    background: rgba(245, 200, 75, 0.13);
}

.corporate__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    align-items: center;
    gap: 40px;
}

.corporate p {
    color: rgba(255, 255, 255, 0.72);
}

.quote-form {
    display: grid;
    gap: 14px;
    padding: 21px;
    background: #fff;
    border-radius: var(--radius);
}

.footer {
    padding: 60px 0;
    background: #0e1116;
    color: #fff;
}

.footer__grid {
    display: grid;
    grid-template-columns: 1.3fr 0.7fr 0.7fr 1fr;
    gap: 40px;
}

.footer a {
    display: block;
    margin-top: 10px;
    color: rgba(255, 255, 255, 0.74);
}

.logo--footer {
    min-width: 0;
}

.logo--footer .logo__mark {
    background: var(--brand);
}

.logo--footer small,
.footer p {
    color: rgba(255, 255, 255, 0.66);
}

.newsletter {
    display: grid;
    grid-template-columns: 1fr 46px;
    gap: 8px;
}

.newsletter input {
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.16);
}

.newsletter button {
    color: #fff;
    background: var(--brand);
    border: 0;
    border-radius: var(--radius);
}

.nav a.is-active,
.header-action.is-active {
    color: var(--brand);
}

.page-hero {
    padding: 64px 0 48px;
    background: linear-gradient(115deg, #fff 0%, #fff4f2 52%, #eef8f5 100%);
}

.page-hero--compact {
    padding: 54px 0 44px;
}

.page-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    align-items: center;
    gap: 40px;
}

.breadcrumb {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.breadcrumb a {
    color: var(--teal);
}

.page-hero h1 {
    max-width: 760px;
    margin: 12px 0 0;
    font-size: clamp(38px, 4vw, 58px);
    line-height: 1.04;
}

.page-hero p {
    max-width: 720px;
    margin: 16px 0 0;
    color: #475467;
    font-size: 18px;
    line-height: 1.65;
}

.page-hero__panel {
    display: grid;
    gap: 8px;
    padding: 24px;
    color: #fff;
    background: var(--dark);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.page-hero__panel span,
.page-hero__panel small {
    color: rgba(255, 255, 255, 0.72);
}

.page-hero__panel strong {
    font-size: 34px;
}

.page-section {
    padding: 58px 0 76px;
    background: #fff;
}

.shop-layout {
    display: grid;
    grid-template-columns: 286px minmax(0, 1fr);
    align-items: start;
    gap: 24px;
}

.filter-panel,
.shop-toolbar,
.checkout-summary,
.auth-card,
.tracking-card,
.timeline-card,
.contact-form,
.map-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.filter-panel {
    position: sticky;
    top: 128px;
    display: grid;
    gap: 18px;
    padding: 18px;
}

.filter-panel__head,
.shop-toolbar,
.summary-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.filter-panel__head strong {
    font-size: 20px;
}

.filter-panel__head a,
.account-form a {
    color: var(--teal);
    font-weight: 800;
}

.filter-block {
    display: grid;
    gap: 10px;
    padding-top: 16px;
    border-top: 1px solid var(--line);
}

.filter-block span,
.detail-options span,
.coupon-box,
.checkout-form label,
.account-form label,
.tracking-card label,
.contact-form label {
    color: #344054;
    font-size: 14px;
    font-weight: 800;
}

.filter-block label,
.option-grid label {
    display: flex;
    align-items: center;
    gap: 9px;
    color: #475467;
    font-size: 14px;
    font-weight: 700;
}

.price-range {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.price-range input,
.shop-toolbar select,
.detail-options input[type="text"],
.checkout-form input,
.checkout-form select,
.checkout-form textarea,
.coupon-box input,
.account-form input,
.tracking-card input,
.contact-form input,
.contact-form select,
.contact-form textarea {
    width: 100%;
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    outline: 0;
    background: #fff;
}

.price-range input,
.shop-toolbar select,
.detail-options input[type="text"],
.checkout-form input,
.checkout-form select,
.coupon-box input,
.account-form input,
.tracking-card input,
.contact-form input,
.contact-form select {
    height: 46px;
    padding: 0 12px;
    -webkit-appearance: none;
    appearance: none;
}

.checkout-form textarea,
.contact-form textarea {
    min-height: 112px;
    padding: 12px;
    resize: vertical;
}

.filter-cta {
    display: grid;
    gap: 8px;
    padding: 16px;
    color: #fff;
    background: linear-gradient(135deg, var(--teal), #20242b);
    border-radius: var(--radius);
}

.filter-cta i {
    font-size: 22px;
}

.filter-cta small {
    color: rgba(255, 255, 255, 0.72);
    line-height: 1.5;
}

.filter-cta a {
    display: inline-flex;
    justify-content: center;
    min-height: 38px;
    align-items: center;
    color: var(--ink);
    background: #fff;
    border-radius: var(--radius);
    font-weight: 800;
}

.shop-content {
    display: grid;
    gap: 18px;
}

.shop-toolbar {
    padding: 16px;
}

.shop-toolbar strong,
.shop-toolbar span {
    display: block;
}

.shop-toolbar span {
    margin-top: 4px;
    color: var(--muted);
    font-size: 14px;
}

.shop-toolbar select {
    width: 220px;
}

.category-pills {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 2px;
}

.category-pills a {
    flex: 0 0 auto;
    min-height: 38px;
    padding: 0 13px;
    display: inline-flex;
    align-items: center;
    color: #475467;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
}

.category-pills a.active,
.category-pills a:hover {
    color: #fff;
    background: var(--ink);
    border-color: var(--ink);
}

.product-grid--catalog {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.product-detail {
    display: grid;
    grid-template-columns: minmax(420px, 0.95fr) minmax(440px, 1.05fr);
    gap: 34px;
    margin-top: 18px;
}

.product-gallery {
    display: grid;
    gap: 7px;
    align-content: start;
}

.product-gallery__main {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.product-gallery__main img,
.product-gallery__thumbs img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-gallery__main img {
    transition: opacity 0.18s ease;
}

.product-gallery__main span {
    position: absolute;
    top: 16px;
    left: 16px;
    padding: 8px 12px;
    color: #fff;
    background: var(--brand);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
}

.product-gallery__thumbs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
}

.product-gallery__thumbs button {
    overflow: hidden;
    aspect-ratio: 1.45 / 1;
    padding: 0;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    transition: border-color 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

.product-gallery__thumbs button:hover,
.product-gallery__thumbs button.is-active {
    border-color: var(--ink);
    box-shadow: inset 0 0 0 1px var(--ink);
}

.product-gallery__thumbs button:not(.is-active) {
    opacity: 0.76;
}

.product-summary {
    display: grid;
    align-content: start;
    gap: 18px;
}

.product-summary h1 {
    margin: 0;
    font-size: clamp(34px, 3.2vw, 48px);
    line-height: 1.08;
}

.rating--large {
    font-size: 15px;
}

.detail-price {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.detail-price strong {
    font-size: 34px;
}

.detail-price del {
    color: var(--muted);
}

.detail-price span {
    padding: 7px 10px;
    color: var(--brand-dark);
    background: #fff0ed;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
}

.product-summary p,
.detail-info-grid p,
.map-card span,
.contact-cards span,
.account-dashboard span {
    color: var(--muted);
    line-height: 1.6;
}

.detail-options {
    display: grid;
    gap: 14px;
    padding: 16px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.detail-options label {
    display: grid;
    gap: 8px;
}

.customizer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 2px 0 6px;
}

.customizer-head strong,
.customizer-head span,
.customizer-head small {
    display: block;
}

.customizer-head strong {
    margin-top: 3px;
    font-size: 18px;
}

.customizer-head small {
    color: var(--teal);
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.customizer-step {
    display: grid;
    gap: 10px;
    min-width: 0;
    padding: 12px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.customizer-step--inline {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
}

.step-label {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    color: #344054;
    font-size: 13px;
    font-weight: 800;
}

.step-label b {
    display: grid;
    width: 24px;
    height: 24px;
    flex: 0 0 auto;
    place-items: center;
    color: #fff;
    background: var(--ink);
    border-radius: 7px;
    font-size: 11px;
}

.step-label span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.option-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 8px;
}

.customizer-step .option-grid {
    margin-top: 0;
}

.option-grid label,
.delivery-grid label {
    min-height: 44px;
    padding: 0 10px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.option-grid .custom-choice {
    min-width: 0;
    min-height: 0;
    padding: 0;
    background: transparent;
    border: 0;
}

.custom-choice input,
.print-mode-grid input,
.upload-field input {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.custom-choice__content {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-height: 66px;
    padding: 10px;
    color: #344054;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.custom-choice__content > i,
.upload-field > i {
    display: grid;
    width: 34px;
    height: 34px;
    place-items: center;
    color: var(--teal);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
}

.custom-choice__content strong,
.custom-choice__content small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.custom-choice__content strong {
    font-size: 12px;
}

.custom-choice__content small {
    margin-top: 2px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
}

.custom-choice__content em {
    display: grid;
    width: 20px;
    height: 20px;
    place-items: center;
    color: #fff;
    background: #d0d5dd;
    border-radius: 999px;
    font-size: 10px;
    font-style: normal;
}

.custom-choice__aside {
    display: grid;
    justify-items: end;
    gap: 6px;
    min-width: 0;
}

.choice-badge {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--line);
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    white-space: nowrap;
}

.choice-price {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    background: #edf7f5;
    color: var(--teal);
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
    white-space: nowrap;
}

.choice-price.is-positive {
    background: #eef8f4;
    color: #0f766e;
}

.choice-price.is-negative {
    background: #fff2ed;
    color: #c2410c;
}

.choice-price.is-neutral {
    background: #f4f6f8;
    color: #667085;
}

.custom-choice input:checked + .custom-choice__content {
    background: var(--surface-2);
    border-color: rgba(15, 118, 110, 0.34);
    box-shadow: inset 0 0 0 1px rgba(15, 118, 110, 0.1);
}

.custom-choice input:checked + .custom-choice__content em {
    background: var(--teal);
}

.custom-input-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(160px, 0.72fr);
    gap: 8px;
    min-width: 0;
}

.engrave-field,
.upload-field {
    min-width: 0;
    min-height: 84px;
    padding: 11px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.engrave-field > span,
.engrave-field > small,
.upload-field small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.engrave-field strong {
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    align-items: center;
    min-height: 38px;
    margin-top: 3px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
}

.engrave-field strong i {
    color: var(--teal);
    text-align: center;
}

.engrave-field input[type="text"],
.engrave-field input[type="date"] {
    width: 100%;
    min-width: 0;
    height: 36px;
    padding: 0 10px 0 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--ink);
    font-weight: 800;
}

.engrave-field textarea {
    width: 100%;
    min-width: 0;
    min-height: 84px;
    margin-top: 6px;
    padding: 10px;
    color: var(--ink);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    resize: vertical;
    outline: 0;
    font-weight: 700;
}

.customization-input-field--wide {
    grid-column: 1 / -1;
}

.upload-field {
    align-content: center;
    justify-items: start;
    gap: 5px;
    cursor: pointer;
}

.upload-field span {
    color: var(--ink);
    font-size: 12px;
    font-weight: 800;
}

.print-mode-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.print-mode-grid label {
    min-width: 0;
    min-height: 38px;
    padding: 0;
    background: transparent;
    border: 0;
}

.print-mode-grid span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 38px;
    padding: 0 10px;
    color: #475467;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    font-size: 12px;
    font-weight: 800;
    text-align: center;
}

.print-mode-grid input:checked + span {
    color: #fff;
    background: var(--ink);
    border-color: var(--ink);
}

.swatches--named {
    justify-content: flex-end;
    gap: 8px;
    min-width: 0;
}

.swatches--named button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: auto;
    height: 36px;
    min-width: 0;
    padding: 0 9px 0 5px;
    background: #fff !important;
    border: 1px solid var(--line);
    border-radius: 999px;
    box-shadow: none;
}

.swatches--named button.active {
    border-color: var(--ink);
    box-shadow: inset 0 0 0 1px var(--ink);
}

.swatches--named span {
    display: block;
    width: 24px;
    height: 24px;
    border-radius: 999px;
}

.swatches--named button:nth-child(1) span {
    background: #ff6f61;
}

.swatches--named button:nth-child(2) span {
    background: #0f766e;
}

.swatches--named button:nth-child(3) span {
    background: #222;
}

.swatches--named button:nth-child(4) span {
    background: #f5c84b;
}

.swatches--named em {
    color: #344054;
    font-size: 11px;
    font-style: normal;
    font-weight: 800;
    white-space: nowrap;
}

.customizer-note {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    align-items: center;
    gap: 9px;
    min-height: 46px;
    padding: 10px;
    color: #344054;
    background: #fff;
    border: 1px dashed rgba(15, 118, 110, 0.36);
    border-radius: var(--radius);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.4;
}

.customizer-note i {
    display: grid;
    width: 34px;
    height: 34px;
    place-items: center;
    color: var(--teal);
    background: var(--surface-2);
    border-radius: 8px;
}

.detail-actions {
    display: grid;
    grid-template-columns: 1fr 180px;
    gap: 10px;
}

.service-grid,
.detail-info-grid,
.account-dashboard,
.contact-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.service-grid div,
.detail-info-grid article,
.account-dashboard article,
.contact-cards article {
    display: grid;
    gap: 8px;
    padding: 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.service-grid i,
.account-dashboard i,
.contact-cards i {
    color: var(--teal);
    font-size: 20px;
}

.detail-info-grid {
    margin-top: 28px;
}

.related-head {
    margin-top: 52px;
}

.product-grid--related {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cart-page-grid,
.checkout-layout,
.account-layout,
.orders-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    align-items: start;
    gap: 24px;
}

.cart-page-list {
    display: grid;
    gap: 12px;
}

.cart-page-item {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr) 110px 128px;
    align-items: center;
    gap: 16px;
    padding: 14px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.cart-page-item img {
    width: 92px;
    height: 92px;
    border-radius: var(--radius);
    object-fit: cover;
}

.cart-page-item span,
.cart-page-item small {
    color: var(--muted);
}

.cart-page-item strong,
.cart-page-item small {
    display: block;
    margin-top: 5px;
}

.qty-control {
    display: grid;
    grid-template-columns: 32px 1fr 32px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.qty-control button {
    width: 32px;
    height: 36px;
    border: 0;
    background: transparent;
    font-weight: 800;
}

.qty-control strong {
    margin: 0;
    text-align: center;
}

.checkout-summary {
    display: grid;
    gap: 14px;
    padding: 18px;
}

.checkout-summary > strong {
    font-size: 20px;
}

.checkout-summary div {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: var(--muted);
}

.checkout-summary b {
    color: var(--ink);
}

.coupon-box {
    display: grid;
    gap: 8px;
}

.coupon-box span {
    display: grid;
    grid-template-columns: 1fr 86px;
    gap: 8px;
}

.coupon-box button {
    color: #fff;
    background: var(--ink);
    border: 0;
    border-radius: var(--radius);
    font-weight: 800;
}

.summary-total {
    padding-top: 14px;
    border-top: 1px solid var(--line);
}

.summary-total b {
    font-size: 22px;
}

.checkout-flow {
    display: grid;
    gap: 18px;
}

.stepper {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.stepper span,
.stepper button {
    display: grid;
    min-height: 44px;
    place-items: center;
    color: var(--muted);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    font-size: 13px;
    font-weight: 800;
    text-align: center;
    cursor: pointer;
}

.stepper button {
    appearance: none;
    font-family: inherit;
}

.stepper span.active,
.stepper button.active {
    color: #fff;
    background: var(--teal);
    border-color: var(--teal);
}

.stepper button.is-done {
    color: var(--teal);
    background: #e8f6f4;
    border-color: rgba(15, 118, 110, 0.24);
}

.checkout-form,
.account-form,
.tracking-card,
.contact-form {
    display: grid;
    gap: 14px;
}

.checkout-form,
.payment-box {
    padding: 18px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.checkout-block {
    display: grid;
    gap: 12px;
    padding: 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.checkout-block[data-checkout-panel] {
    display: none;
}

.checkout-block[data-checkout-panel].is-active {
    display: grid;
}

.checkout-block-head {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
}

.checkout-block-head > span {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    color: #fff;
    background: var(--ink);
    font-weight: 800;
}

.checkout-block-head strong,
.checkout-block-head small {
    display: block;
}

.checkout-block-head small {
    margin-top: 2px;
    color: var(--muted);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.checkout-form label,
.account-form label,
.tracking-card label,
.contact-form label {
    display: grid;
    gap: 8px;
}

.delivery-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.delivery-grid label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    min-height: 58px;
}

.delivery-method-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.delivery-method-card {
    position: relative;
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 10px;
    min-height: 164px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
    cursor: pointer;
}

.delivery-method-card input {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 18px;
    height: 18px;
}

.delivery-method-card__icon {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 8px;
    color: var(--teal);
    background: #fff;
}

.delivery-method-card__body {
    display: grid;
    gap: 4px;
    padding-right: 22px;
}

.delivery-method-card__body strong,
.delivery-method-card__body small,
.delivery-method-card__body em,
.delivery-method-card__price strong,
.delivery-method-card__price small {
    display: block;
}

.delivery-method-card__body small,
.delivery-method-card__body em {
    color: var(--muted);
    line-height: 1.4;
}

.delivery-method-card__body em {
    font-size: 12px;
    font-style: normal;
}

.delivery-method-card__price {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: auto;
    padding-top: 10px;
    border-top: 1px solid var(--line);
}

.delivery-method-card__price small {
    padding: 5px 8px;
    border-radius: 999px;
    color: var(--teal);
    background: #e8f6f4;
    font-weight: 800;
}

.delivery-method-card:has(input:checked) {
    border-color: var(--teal);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
}

.payment-box {
    display: grid;
    gap: 12px;
    background: var(--surface);
}

.payment-method-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.payment-method-card {
    position: relative;
    display: grid !important;
    gap: 7px;
    align-content: start;
    min-height: 150px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
    cursor: pointer;
}

.payment-method-card input {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 18px;
    height: 18px;
}

.payment-method-card > span {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 8px;
    color: var(--teal);
    background: #fff;
}

.payment-method-card strong,
.payment-method-card small,
.payment-method-card em {
    display: block;
}

.payment-method-card small {
    color: var(--muted);
    line-height: 1.45;
}

.payment-method-card em {
    justify-self: start;
    padding: 5px 8px;
    border-radius: 999px;
    color: var(--teal);
    background: #e8f6f4;
    font-size: 12px;
    font-style: normal;
    font-weight: 800;
}

.payment-method-card:has(input:checked) {
    border-color: var(--teal);
    box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
    background: #fff;
}

.bank-account-box {
    display: grid;
    gap: 7px;
    padding: 11px;
    border: 1px dashed rgba(15, 118, 110, 0.35);
    border-radius: var(--radius);
    background: #f7fbfa;
}

.bank-account-box strong,
.bank-account-box span {
    display: block;
}

.bank-account-box span {
    color: var(--muted);
    line-height: 1.45;
}

.checkout-step-actions {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    padding-top: 4px;
}

.checkout-step-actions .btn {
    min-width: 160px;
}

.checkout-step-actions .btn-primary {
    margin-left: auto;
}

.checkout-summary--sticky {
    position: sticky;
    top: 128px;
}

.checkout-summary small {
    color: var(--muted);
    line-height: 1.5;
}

.account-layout {
    grid-template-columns: 390px minmax(0, 1fr);
}

.auth-card {
    padding: 18px;
}

.tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-bottom: 16px;
    padding: 5px;
    background: var(--surface);
    border-radius: var(--radius);
}

.tabs button {
    min-height: 40px;
    border: 0;
    border-radius: 6px;
    background: transparent;
    font-weight: 800;
}

.tabs button.active {
    color: #fff;
    background: var(--ink);
}

.account-dashboard {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.account-dashboard article {
    min-height: 160px;
    align-content: start;
}

.orders-layout {
    grid-template-columns: 360px minmax(0, 1fr);
}

.order-tracking-layout {
    display: grid;
    grid-template-columns: 340px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.tracking-card,
.timeline-card,
.contact-form {
    padding: 18px;
}

.tracking-search-card {
    grid-column: 1;
    grid-row: 1 / span 2;
    position: sticky;
    top: 128px;
    display: grid;
    gap: 14px;
    align-self: start;
    z-index: 2;
}

.tracking-search-card form {
    display: grid;
    gap: 12px;
}

.tracking-search-card form label {
    display: grid;
    gap: 7px;
}

.tracking-search-card form small[data-order-track-message] {
    min-height: 20px;
    color: var(--muted);
    line-height: 1.45;
}

.tracking-card-head,
.tracking-info-head {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
}

.tracking-card-head i,
.tracking-info-head i {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 8px;
    color: var(--teal);
    background: var(--surface-2);
}

.tracking-card-head strong,
.tracking-card-head span,
.tracking-info-head strong,
.tracking-info-head span {
    display: block;
}

.tracking-card-head span,
.tracking-info-head span {
    color: var(--muted);
    line-height: 1.45;
}

.tracking-help {
    display: grid;
    gap: 8px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
}

.tracking-help span {
    display: flex;
    gap: 8px;
    color: var(--muted);
    line-height: 1.45;
}

.tracking-result-panel {
    grid-column: 2;
    grid-row: 1;
    display: grid;
    gap: 14px;
    min-width: 0;
}

.tracking-empty-state,
.tracking-overview,
.tracking-info-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.tracking-empty-state {
    display: grid;
    justify-items: center;
    gap: 8px;
    padding: 42px 20px;
    text-align: center;
}

.tracking-empty-state i {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 12px;
    color: var(--teal);
    background: var(--surface-2);
    font-size: 22px;
}

.tracking-empty-state span {
    max-width: 520px;
    color: var(--muted);
}

.tracking-result-content {
    display: grid;
    gap: 14px;
}

.tracking-overview {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    border: 0;
    background: transparent;
}

.tracking-overview-card {
    display: grid;
    gap: 6px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.tracking-overview__label,
.tracking-overview__meta {
    color: var(--muted);
}

.tracking-overview__value {
    font-size: 18px;
    line-height: 1.3;
}

.tracking-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
}

.tracking-status-pill.is-done {
    color: #0f766e;
    background: #e8f6f4;
}

.tracking-status-pill.is-active {
    color: #b54708;
    background: #fff3e2;
}

.tracking-status-pill.is-pending {
    color: #475467;
    background: #f2f4f7;
}

.tracking-timeline {
    padding: 18px;
}

.tracking-section-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--line);
    margin-bottom: 14px;
}

.tracking-section-head strong,
.tracking-section-head span {
    display: block;
}

.tracking-section-head span {
    margin-top: 4px;
    color: var(--muted);
    line-height: 1.45;
}

.tracking-timeline-list {
    display: grid;
}

.tracking-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.tracking-info-card {
    display: grid;
    gap: 12px;
    padding: 14px;
}

.tracking-info-list {
    display: grid;
    gap: 8px;
}

.tracking-info-list span,
.tracking-info-list a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 9px 0;
    border-top: 1px solid var(--line);
    color: var(--muted);
}

.tracking-info-list b {
    color: var(--ink);
    font-weight: 700;
}

.tracking-info-list em {
    color: var(--ink);
    font-style: normal;
    text-align: right;
}

.tracking-info-list a {
    color: var(--teal);
    font-weight: 700;
}

.tracking-item-list {
    display: grid;
    gap: 8px;
}

.tracking-item-list article {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 70px 110px;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}

.tracking-item-main {
    min-width: 0;
}

.tracking-item-list strong,
.tracking-item-list span {
    display: block;
}

.tracking-item-list span,
.tracking-item-list small {
    color: var(--muted);
}

.tracking-item-qty {
    text-align: center;
}

.tracking-item-total {
    text-align: right;
}

.tracking-card > strong {
    font-size: 20px;
}

.timeline-card {
    display: grid;
    gap: 0;
}

.timeline-item {
    position: relative;
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 14px;
    padding: 0 0 24px;
}

.timeline-item:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 44px;
    bottom: 0;
    left: 21px;
    width: 2px;
    background: var(--line);
}

.timeline-item span {
    position: relative;
    z-index: 1;
    display: grid;
    width: 44px;
    height: 44px;
    place-items: center;
    color: var(--muted);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 999px;
}

.timeline-item.done span,
.timeline-item.active span {
    color: #fff;
    background: var(--teal);
    border-color: var(--teal);
}

.timeline-item strong,
.timeline-item small {
    display: block;
}

.timeline-item small {
    margin-top: 5px;
    color: var(--muted);
}

.contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    gap: 24px;
}

.contact-cards {
    grid-column: 1 / -1;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.contact-cards article {
    min-height: 134px;
}

.map-card {
    display: grid;
    align-content: center;
    gap: 10px;
    min-height: 100%;
    padding: 28px;
    color: #fff;
    background:
        linear-gradient(rgba(32, 36, 43, 0.78), rgba(32, 36, 43, 0.78)),
        url("assets/hero-personalized-products.png") center / cover;
}

.map-card i {
    font-size: 34px;
    color: var(--yellow);
}

.map-card span {
    color: rgba(255, 255, 255, 0.74);
}

.cart-drawer {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 60;
    display: none;
    grid-template-rows: auto 1fr auto;
    width: min(420px, 100%);
    height: 100dvh;
    background: #fff;
    box-shadow: -20px 0 50px rgba(16, 24, 40, 0.18);
    transform: translateX(105%);
    transition: transform 0.22s ease;
}

.cart-drawer.is-open {
    display: grid;
    transform: translateX(0);
}

.cart-drawer__head,
.cart-summary {
    padding: 18px;
    border-bottom: 1px solid var(--line);
}

.cart-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.cart-items {
    overflow: auto;
    padding: 14px;
}

.cart-line {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--line);
}

.cart-line img {
    width: 72px;
    height: 72px;
    border-radius: var(--radius);
    object-fit: cover;
}

.cart-line strong,
.cart-line small {
    display: block;
}

.cart-line small {
    margin-top: 6px;
    color: var(--muted);
}

.cart-line button {
    width: 32px;
    height: 32px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
}

.empty-cart {
    display: grid;
    min-height: 220px;
    place-items: center;
    align-content: center;
    gap: 12px;
    color: var(--muted);
}

.empty-cart i {
    font-size: 32px;
}

.cart-summary {
    display: grid;
    gap: 14px;
    border-top: 1px solid var(--line);
    border-bottom: 0;
}

.cart-summary div {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.overlay {
    position: fixed;
    inset: 0;
    z-index: 50;
    display: none;
    background: rgba(0, 0, 0, 0.46);
}

.overlay.is-open {
    display: block;
}

.checkout-success-modal {
    position: fixed;
    inset: 0;
    z-index: 90;
    display: grid;
    place-items: center;
    padding: 20px;
    background: rgba(15, 23, 42, 0.18);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s ease, visibility 0.28s ease, background 0.28s ease;
}

.checkout-success-modal.is-open {
    background: rgba(15, 23, 42, 0.48);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.checkout-success-card {
    position: relative;
    display: grid;
    gap: 14px;
    width: min(440px, 100%);
    padding: 28px;
    background: #fff;
    border-radius: var(--radius);
    box-shadow: 0 28px 72px rgba(15, 23, 42, 0.22);
    text-align: center;
    transform: translateY(32px) scale(0.92);
    opacity: 0;
    transition: transform 0.34s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.24s ease;
}

.checkout-success-modal.is-open .checkout-success-card {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.checkout-success-close {
    position: absolute;
    top: 14px;
    right: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    color: #475467;
    background: #f8fafc;
    border: 1px solid var(--line);
    border-radius: 999px;
    transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.checkout-success-close:hover {
    color: var(--ink);
    background: #eef2f6;
    transform: rotate(90deg);
}

.checkout-success-icon {
    position: relative;
    display: grid;
    width: 64px;
    height: 64px;
    margin: 0 auto;
    place-items: center;
    color: var(--teal);
    background: #e8f6f4;
    border-radius: 20px;
    font-size: 24px;
    overflow: visible;
    animation: successPulse 2.4s ease-out infinite;
}

.checkout-success-icon__ring {
    position: absolute;
    inset: -8px;
    border: 1px solid rgba(15, 118, 110, 0.22);
    border-radius: 28px;
    animation: successRing 2.2s ease-out infinite;
}

.checkout-success-icon__ring--delay {
    animation-delay: 0.45s;
}

.checkout-success-card strong {
    font-size: 24px;
    line-height: 1.1;
}

.checkout-success-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.checkout-success-actions {
    display: grid;
    gap: 10px;
    margin-top: 4px;
}

.payment-frame-layout,
.payment-result-layout {
    display: grid;
}

.payment-frame-card,
.payment-result-card {
    display: grid;
    gap: 18px;
    padding: 22px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--card-bg, #fff);
}

.payment-frame-card--redirect,
.payment-result-card {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
}

.payment-provider-frame {
    width: 100%;
    min-height: 720px;
    border: 0;
    border-radius: 8px;
    background: #fff;
}

.payment-result-card__icon {
    display: inline-grid;
    place-items: center;
    width: 68px;
    height: 68px;
    margin: 0 auto;
    border-radius: 999px;
    font-size: 28px;
}

.payment-result-card__icon.is-success {
    color: var(--teal);
    background: rgba(15, 118, 110, 0.12);
}

.payment-result-card__icon.is-fail {
    color: var(--brand);
    background: rgba(255, 111, 97, 0.12);
}

@media (max-width: 768px) {
    .payment-frame-card,
    .payment-result-card {
        padding: 16px;
    }

    .payment-provider-frame {
        min-height: 620px;
    }
}

.confirm-modal {
    position: fixed;
    inset: 0;
    z-index: 95;
    display: grid;
    place-items: center;
    padding: 20px;
    background: rgba(15, 23, 42, 0.18);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.24s ease, visibility 0.24s ease, background 0.24s ease;
}

.confirm-modal.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    background: rgba(15, 23, 42, 0.42);
}

.confirm-modal__card {
    display: grid;
    gap: 14px;
    width: min(420px, 100%);
    padding: 26px;
    border: 1px solid rgba(228, 231, 236, 0.9);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: 0 28px 72px rgba(15, 23, 42, 0.22);
    text-align: center;
    transform: translateY(24px) scale(0.94);
    opacity: 0;
    transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.22s ease;
}

.confirm-modal.is-open .confirm-modal__card {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.confirm-modal__icon {
    display: grid;
    place-items: center;
    width: 60px;
    height: 60px;
    margin: 0 auto;
    color: #b54708;
    background: #fff3e2;
    border-radius: 18px;
    font-size: 22px;
}

.confirm-modal__card strong {
    font-size: 22px;
    line-height: 1.15;
}

.confirm-modal__card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.confirm-modal__actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.notice-modal__icon {
    color: #155eef;
    background: #eaf2ff;
}

.notice-modal__actions {
    grid-template-columns: minmax(0, 1fr);
}

[data-reveal] {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity 0.56s ease, transform 0.56s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--reveal-delay, 0ms);
    will-change: opacity, transform;
}

[data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}

.page-hero .container[data-reveal],
.checkout-summary[data-reveal] {
    transform: translateY(18px);
}

@keyframes successPulse {
    0%,
    100% {
        transform: scale(1);
    }
    18% {
        transform: scale(1.06);
    }
    32% {
        transform: scale(0.98);
    }
    46% {
        transform: scale(1.02);
    }
}

@keyframes successRing {
    0% {
        opacity: 0;
        transform: scale(0.84);
    }
    26% {
        opacity: 0.55;
    }
    100% {
        opacity: 0;
        transform: scale(1.18);
    }
}

@media (prefers-reduced-motion: reduce) {
    .checkout-success-modal,
    .checkout-success-card,
    .checkout-success-close,
    .checkout-success-icon,
    .checkout-success-icon__ring,
    .confirm-modal,
    .confirm-modal__card,
    [data-reveal] {
        animation: none !important;
        transition: none !important;
        transform: none !important;
    }

    [data-reveal] {
        opacity: 1 !important;
    }
}

.mobile-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 60;
    display: grid;
    grid-template-rows: auto 1fr auto;
    width: min(370px, calc(100% - 28px));
    height: 100dvh;
    background: #fff;
    box-shadow: 24px 0 58px rgba(16, 24, 40, 0.18);
    transform: translateX(-105%);
    transition: transform 0.22s ease;
    overscroll-behavior: contain;
}

.mobile-sidebar.is-open {
    transform: translateX(0);
}

.mobile-sidebar__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px;
    border-bottom: 1px solid var(--line);
}

.mobile-sidebar__head .logo {
    min-width: 0;
}

.mobile-sidebar__head .logo__mark {
    width: 44px;
    height: 44px;
}

.mobile-sidebar__head .logo strong {
    font-size: 22px;
}

.mobile-sidebar__body {
    display: grid;
    align-content: start;
    gap: 18px;
    overflow: auto;
    padding: 16px;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}

.mobile-sidebar__actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.mobile-action {
    display: grid;
    min-width: 0;
    min-height: 64px;
    place-items: center;
    gap: 6px;
    padding: 8px;
    color: var(--ink);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    font-size: 12px;
    font-weight: 800;
    text-align: center;
}

button.mobile-action {
    appearance: none;
}

.mobile-action i {
    font-size: 17px;
}

.mobile-sidebar__section {
    display: grid;
    gap: 9px;
}

.sidebar-title {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    text-align: center;
}

.mobile-nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 48px;
    padding: 0 12px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    font-weight: 800;
}

button.mobile-nav-link {
    width: 100%;
    color: var(--ink);
    font: inherit;
    cursor: pointer;
}

.mobile-nav-link i {
    color: var(--muted);
    font-size: 12px;
}

.mobile-accordion,
.mobile-category-list,
.mobile-feature-list {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.mobile-nav-link--accordion i,
.mobile-category__trigger > i {
    transition: transform 0.2s ease;
}

.mobile-accordion.is-open > .mobile-nav-link--accordion > i,
.mobile-category.is-open > .mobile-category__trigger > i {
    transform: rotate(180deg);
}

.mobile-accordion__panel {
    display: none;
    min-width: 0;
    padding: 0 0 2px;
}

.mobile-accordion.is-open > .mobile-accordion__panel {
    display: grid;
    gap: 8px;
}

.mobile-category {
    overflow: hidden;
    min-width: 0;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.mobile-category__trigger {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) 16px;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-height: 50px;
    padding: 8px 10px;
    color: var(--ink);
    background: transparent;
    border: 0;
    font: inherit;
    text-align: left;
    cursor: pointer;
}

.mobile-category__icon {
    display: grid;
    width: 34px;
    height: 34px;
    place-items: center;
    color: var(--teal);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
}

.mobile-category__trigger span,
.mobile-subcategory-link span,
.mobile-feature-link span {
    min-width: 0;
}

.mobile-category__trigger strong,
.mobile-category__trigger small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-category__trigger strong {
    font-size: 13px;
    line-height: 1.25;
}

.mobile-category__trigger small {
    margin-top: 2px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.mobile-category__trigger > i {
    color: var(--muted);
    font-size: 12px;
}

.mobile-category__panel {
    display: none;
    gap: 6px;
    padding: 0 8px 8px 52px;
}

.mobile-category.is-open > .mobile-category__panel {
    display: grid;
}

.mobile-subcategory-link,
.mobile-feature-link {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    padding: 0 10px;
    color: #344054;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    font-size: 12px;
    font-weight: 800;
}

.mobile-subcategory-link em,
.mobile-feature-link em {
    color: var(--muted);
    font-style: normal;
    font-size: 10px;
    font-weight: 800;
    white-space: nowrap;
}

.mobile-subcategory-link.is-active {
    color: #fff;
    background: var(--ink);
    border-color: var(--ink);
}

.mobile-subcategory-link.is-active em {
    color: rgba(255, 255, 255, 0.74);
}

.mobile-subcategory-link--all {
    min-height: 40px;
    background: var(--surface);
}

.mobile-feature-link {
    grid-template-columns: 30px minmax(0, 1fr) auto;
    min-height: 44px;
    background: var(--surface);
}

.mobile-feature-link i {
    display: grid;
    width: 30px;
    height: 30px;
    place-items: center;
    color: var(--teal);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    font-size: 13px;
}

.sidebar-category-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.sidebar-category-grid a {
    display: grid;
    align-content: center;
    gap: 8px;
    min-height: 92px;
    padding: 12px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    font-size: 13px;
    font-weight: 800;
}

.sidebar-category-grid i {
    display: grid;
    width: 34px;
    height: 34px;
    place-items: center;
    color: var(--teal);
    background: var(--surface-2);
    border-radius: 8px;
}

.mobile-sidebar__promo {
    display: grid;
    gap: 6px;
    padding: 16px;
    color: #fff;
    background: linear-gradient(135deg, var(--dark), #344054);
    border-radius: var(--radius);
}

.mobile-sidebar__promo span,
.mobile-sidebar__promo small {
    color: rgba(255, 255, 255, 0.74);
}

.mobile-sidebar__promo span {
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    text-align: center;
}

.mobile-sidebar__foot {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 14px 16px;
    border-top: 1px solid var(--line);
}

.mobile-sidebar__foot a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 10px;
    color: #fff;
    background: var(--brand);
    border-radius: var(--radius);
    font-size: 13px;
    font-weight: 800;
}

.mobile-sidebar__foot a:first-child {
    color: var(--ink);
    background: var(--surface);
    border: 1px solid var(--line);
}

body.drawer-open {
    overflow: hidden;
}

.cookie {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 35;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 18px;
    width: min(560px, calc(100% - 36px));
    padding: 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.cookie p {
    margin: 7px 0 0;
    color: var(--muted);
    line-height: 1.5;
}

.cookie.is-hidden {
    display: none;
}

@media (max-width: 680px) {
    .cookie {
        right: 10px;
        bottom: 10px;
        width: calc(100% - 20px);
        gap: 10px;
        padding: 12px;
        grid-template-columns: 1fr;
    }

    .cookie p {
        margin-top: 6px;
        font-size: 13px;
        line-height: 1.45;
    }

    .cookie .btn {
        width: 100%;
        min-height: 42px;
    }

    .page--cart .cookie,
    .page--checkout .cookie,
    .page--payment-frame .cookie,
    .page--payment-result .cookie {
        left: 10px;
        right: 10px;
        bottom: 8px;
        width: auto;
        padding: 10px 12px;
        gap: 8px;
        border-radius: 10px;
        box-shadow: 0 10px 30px rgba(15, 23, 42, 0.12);
    }

    .page--cart .cookie p,
    .page--checkout .cookie p,
    .page--payment-frame .cookie p,
    .page--payment-result .cookie p {
        font-size: 12px;
        line-height: 1.4;
    }

    .page--cart .cookie .btn,
    .page--checkout .cookie .btn,
    .page--payment-frame .cookie .btn,
    .page--payment-result .cookie .btn {
        min-height: 40px;
    }
}

@media (max-width: 1180px) {
    .topbar__inner span:nth-child(2) {
        display: none;
    }

    .header-main {
        grid-template-columns: 50px minmax(0, 1fr) auto;
        row-gap: 12px;
        min-height: auto;
        padding: 12px 0;
    }

    .mobile-menu-btn {
        display: grid;
        grid-column: 1;
        grid-row: 1;
    }

    .logo {
        grid-column: 2;
        grid-row: 1;
        min-width: 0;
        justify-self: start;
    }

    .search {
        grid-column: 1 / -1;
        grid-row: 2;
        order: 0;
    }

    .header-actions {
        display: flex;
        grid-column: 3;
        grid-row: 1;
        justify-self: end;
    }

    .header-actions .header-action {
        display: none;
    }

    .nav-wrap {
        display: none;
    }

    .nav {
        flex-wrap: wrap;
        gap: 10px 18px;
        padding: 12px 0;
    }

    .hero__grid,
    .customizer-grid,
    .corporate__grid {
        grid-template-columns: 1fr;
    }

    .hero__media,
    .hero__media img {
        height: auto;
        min-height: 0;
    }

    .hero__media img {
        aspect-ratio: 1.15 / 1;
    }

    .category-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .product-grid,
    .campaign-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .designer {
        grid-template-columns: 1fr;
    }

    .designer__preview {
        min-height: 360px;
    }

    .footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .page-hero__grid,
    .shop-layout,
    .product-detail,
    .cart-page-grid,
    .checkout-layout,
    .account-layout,
    .orders-layout,
    .contact-layout {
        grid-template-columns: 1fr;
    }

    .filter-panel,
    .checkout-summary--sticky {
        position: static;
    }

    .filter-panel {
        order: 2;
    }

    .shop-content {
        order: 1;
    }

    .product-grid--catalog,
    .product-grid--related {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .contact-cards {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .container {
        width: min(100% - 22px, 1320px);
    }

    .topbar {
        display: none;
    }

    .site-header {
        top: 8px;
        width: calc(100% - 16px);
        margin-top: 8px;
    }

    .site-header .container {
        width: calc(100% - 18px);
    }

    .header-main {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 10px;
        row-gap: 10px;
        min-height: auto;
        padding: 10px 0 12px;
    }

    .mobile-menu-btn {
        flex: 0 0 46px;
        order: 1;
        justify-self: start;
    }

    .logo {
        flex: 1 1 0;
        order: 2;
        min-width: 0;
    }

    .header-actions {
        display: flex;
        flex: 0 0 auto;
        order: 3;
        gap: 0;
    }

    .header-actions .header-action {
        display: none;
    }

    .cart-button {
        display: grid;
        width: 46px;
        min-height: 46px;
        place-items: center;
        padding: 0;
    }

    .cart-button strong {
        position: absolute;
        top: 4px;
        right: 3px;
        min-width: 18px;
        height: 18px;
    }

    .mobile-sidebar {
        width: min(360px, calc(100% - 18px));
    }

    .logo strong {
        font-size: 19px;
    }

    .logo small {
        display: none;
    }

    .cart-button span {
        display: none;
    }

    .search {
        flex: 0 0 100%;
        order: 4;
        grid-template-columns: 42px minmax(0, 1fr);
        box-shadow: inset 0 0 0 1px rgba(16, 24, 40, 0.02);
    }

    .search input {
        height: 48px;
    }

    .search button {
        display: none;
    }

    .hero {
        padding-top: 22px;
    }

    .hero__content,
    .hero__grid,
    .customizer-grid,
    .corporate__grid {
        min-width: 0;
    }

    .hero__content {
        max-width: 100%;
        display: grid;
        gap: 14px;
        order: 2;
    }

    .hero__grid {
        gap: 18px;
    }

    .hero h1 {
        margin-top: 0;
        max-width: 100%;
        font-size: 30px;
        line-height: 1.12;
        overflow-wrap: anywhere;
        text-wrap: balance;
    }

    .hero h1 span {
        display: inline;
    }

    .hero h1 span + span::before {
        content: " ";
    }

    .hero p {
        margin-top: 0;
        max-width: 100%;
        font-size: 15px;
        line-height: 1.6;
    }

    .hero__media {
        order: 1;
        min-height: 0;
        border-radius: 12px;
        overflow: hidden;
    }

    .hero__media img {
        width: 100%;
        height: auto;
        aspect-ratio: 1 / 1.02;
        min-height: 0;
        border-radius: 12px;
    }

    .floating-card {
        gap: 8px;
        max-width: calc(100% - 22px);
        padding: 10px 12px;
        border-radius: 10px;
        font-size: 12px;
        line-height: 1.3;
    }

    .floating-card--top {
        top: 10px;
        left: 10px;
    }

    .floating-card--bottom {
        right: 10px;
        bottom: 10px;
    }

    .floating-card i {
        font-size: 12px;
    }

    .hero__actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
        margin-top: 2px;
    }

    .hero__actions .btn {
        width: 100%;
        max-width: none;
        min-height: 48px;
    }

    .footer__grid {
        grid-template-columns: 1fr;
    }

    .hero__stats {
        grid-template-columns: 1fr;
        gap: 10px;
        margin-top: 2px;
    }

    .hero__stats span {
        padding: 13px 14px;
        font-size: 13px;
    }

    .hero__stats strong {
        margin-bottom: 4px;
        font-size: 20px;
    }

    .trust-grid,
    .category-grid,
    .product-grid,
    .campaign-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .trust-grid {
        gap: 1px;
    }

    .trust-grid div {
        min-height: 68px;
        padding: 0 8px;
        font-size: 12px;
        text-align: center;
    }

    .category-grid,
    .product-grid,
    .campaign-grid {
        gap: 12px;
    }

    .category-card {
        min-height: 124px;
        padding: 14px;
        gap: 8px;
    }

    .category-card__icon {
        width: 40px;
        height: 40px;
        font-size: 17px;
    }

    .category-card strong {
        font-size: 14px;
        line-height: 1.25;
    }

    .category-card small {
        font-size: 12px;
    }

    .product-card__image {
        aspect-ratio: 1 / 1;
    }

    .product-card__image span {
        top: 8px;
        left: 8px;
        padding: 6px 8px;
        font-size: 10px;
    }

    .wishlist {
        top: 8px;
        right: 8px;
        width: 34px;
        height: 34px;
        font-size: 13px;
    }

    .product-card__body {
        padding: 12px;
    }

    .product-card__body small {
        min-height: 0;
        font-size: 11px;
    }

    .floating-card {
        position: static;
        margin-top: 10px;
        width: 100%;
        justify-content: center;
    }

    .section {
        padding: 52px 0;
    }

    .section-head {
        display: grid;
        align-items: start;
    }

    .segmented {
        overflow-x: auto;
        width: 100%;
    }

    .segmented button {
        flex: 1 0 auto;
    }

    .product-card h3 {
        min-height: 38px;
        margin: 7px 0 8px;
        font-size: 14px;
        line-height: 1.28;
    }

    .chips {
        gap: 5px;
        min-height: 26px;
        margin-top: 9px;
    }

    .chips span {
        min-height: 22px;
        padding: 0 7px;
        font-size: 10px;
    }

    .chips span:nth-child(n+3) {
        display: none;
    }

    .rating {
        gap: 4px;
        font-size: 11px;
    }

    .product-card__bottom {
        gap: 8px;
        margin-top: 10px;
    }

    .price strong {
        font-size: 15px;
    }

    .price del {
        font-size: 11px;
    }

    .mini-cart {
        width: 36px;
        height: 36px;
        font-size: 13px;
    }

    .campaign-card {
        min-height: 150px;
        padding: 16px;
    }

    .campaign-card p {
        margin: 14px 0 18px;
        font-size: 18px;
    }

    .corporate__grid {
        gap: 24px;
    }

    .corporate__grid,
    .quote-form {
        min-width: 0;
    }

    .cookie {
        grid-template-columns: 1fr;
        right: 10px;
        bottom: 10px;
        width: calc(100% - 20px);
        gap: 10px;
        padding: 12px;
    }

    .cookie p {
        margin-top: 6px;
        font-size: 13px;
        line-height: 1.45;
    }

    .cookie .btn {
        width: 100%;
        min-height: 42px;
    }

    .page-hero,
    .page-hero--compact {
        padding: 34px 0 30px;
    }

    .page-hero h1 {
        font-size: 32px;
        line-height: 1.1;
    }

    .page-hero p {
        font-size: 15px;
        line-height: 1.55;
    }

    .page-hero__panel {
        padding: 16px;
    }

    .page-hero__panel strong {
        font-size: 26px;
    }

    .page-section {
        padding: 34px 0 50px;
    }

    .shop-layout,
    .shop-content,
    .product-detail,
    .cart-page-grid,
    .checkout-layout,
    .account-layout,
    .orders-layout,
    .contact-layout {
        gap: 16px;
    }

    .filter-panel {
        padding: 14px;
    }

    .filter-block {
        gap: 8px;
        padding-top: 12px;
    }

    .shop-toolbar {
        display: grid;
        align-items: start;
        padding: 13px;
    }

    .shop-toolbar select {
        width: 100%;
    }

    .category-pills {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        overflow: visible;
    }

    .category-pills a {
        justify-content: center;
        min-width: 0;
        min-height: 36px;
        padding: 0 8px;
        font-size: 11px;
        text-align: center;
    }

    .product-grid--catalog,
    .product-grid--related {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .product-detail-page .breadcrumb {
        margin-bottom: 10px;
    }

    .product-summary {
        gap: 14px;
    }

    .product-summary h1 {
        font-size: 30px;
    }

    .detail-price strong {
        font-size: 27px;
    }

    .option-grid,
    .service-grid,
    .detail-info-grid,
    .form-grid,
    .delivery-grid,
    .account-dashboard,
    .contact-cards {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .detail-actions {
        grid-template-columns: 1fr;
    }

    .service-grid div,
    .detail-info-grid article,
    .account-dashboard article,
    .contact-cards article {
        padding: 13px;
    }

    .cart-page-item {
        grid-template-columns: 72px minmax(0, 1fr);
        gap: 12px;
        padding: 12px;
    }

    .cart-page-item img {
        width: 72px;
        height: 72px;
    }

    .cart-page-item .qty-control,
    .cart-page-item b {
        grid-column: 2;
    }

    .qty-control {
        max-width: 116px;
    }

    .checkout-summary,
    .checkout-form,
    .payment-box,
    .auth-card,
    .tracking-card,
    .timeline-card,
    .contact-form {
        padding: 14px;
    }

    .stepper {
        gap: 6px;
    }

    .stepper span,
    .stepper button {
        min-height: 40px;
        padding: 0 6px;
        font-size: 11px;
        text-align: center;
    }

    .orders-layout {
        gap: 18px;
    }

    .timeline-item {
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 12px;
        padding-bottom: 20px;
    }

    .timeline-item span {
        width: 38px;
        height: 38px;
    }

    .timeline-item:not(:last-child)::after {
        top: 38px;
        left: 18px;
    }

    .contact-cards {
        grid-column: auto;
    }

    .map-card {
        min-height: 260px;
        padding: 20px;
    }
}

/* Compact catalog revision */
:root {
    --section-space: 54px;
    --shadow: 0 12px 28px rgba(16, 24, 40, 0.09);
}

body {
    font-size: 14px;
}

.container {
    width: min(1320px, calc(100% - 32px));
}

.topbar {
    font-size: 12px;
}

.topbar__inner {
    min-height: 32px;
}

.site-header {
    top: 6px;
    margin-top: 6px;
    width: min(1360px, calc(100% - 20px));
}

.header-main {
    grid-template-columns: 170px minmax(320px, 1fr) auto;
    gap: 16px;
    min-height: 68px;
}

.logo {
    min-width: 150px;
}

.logo__mark {
    width: 38px;
    height: 38px;
}

.logo strong {
    font-size: 21px;
}

.logo small {
    font-size: 10px;
    text-align: center;
}

.search {
    grid-template-columns: 42px minmax(0, 1fr) auto;
}

.search input {
    height: 42px;
    font-size: 14px;
}

.search button {
    height: 34px;
    padding: 0 16px;
    font-size: 13px;
}

.header-action,
.cart-button {
    min-height: 38px;
    padding: 0 11px;
    font-size: 13px;
}

.nav {
    gap: 22px;
    min-height: 40px;
    font-size: 13px;
}

.hero {
    padding: 38px 0 30px;
}

.hero__grid {
    grid-template-columns: minmax(420px, 0.92fr) minmax(460px, 1.08fr);
    gap: 30px;
}

.hero h1 {
    max-width: 520px;
    font-size: clamp(34px, 3.1vw, 48px);
}

.hero p {
    max-width: 520px;
    margin-top: 14px;
    font-size: 15px;
    line-height: 1.55;
}

.hero__actions {
    gap: 10px;
    margin-top: 20px;
}

.btn {
    min-height: 40px;
    padding: 0 16px;
    font-size: 13px;
}

.hero__stats {
    gap: 8px;
    max-width: 520px;
    margin-top: 22px;
}

.hero__stats span {
    padding: 11px;
    font-size: 12px;
}

.hero__stats strong {
    font-size: 18px;
}

.hero__media {
    min-height: 390px;
}

.hero__media img {
    height: 390px;
}

.floating-card {
    padding: 10px 12px;
    font-size: 12px;
}

.trust-grid div {
    min-height: 58px;
    font-size: 13px;
}

.section {
    padding: var(--section-space) 0;
}

.section-head {
    margin-bottom: 20px;
}

.section h2 {
    font-size: clamp(26px, 2.2vw, 36px);
}

.eyebrow {
    min-height: 24px;
    padding: 0 9px;
    font-size: 10px;
    text-align: center;
}

.category-grid {
    gap: 12px;
}

.category-card {
    min-height: 126px;
    padding: 16px;
}

.category-card__icon {
    width: 42px;
    height: 42px;
    font-size: 18px;
}

.category-card strong {
    font-size: 16px;
}

.product-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.product-card__image {
    aspect-ratio: 1.08 / 1;
}

.product-card__image span {
    top: 10px;
    left: 10px;
    padding: 6px 8px;
    font-size: 10px;
    text-align: center;
}

.wishlist {
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    font-size: 12px;
}

.product-card__body {
    padding: 12px;
}

.product-card__body small {
    min-height: 0;
    font-size: 11px;
}

.product-card h3 {
    min-height: 40px;
    margin: 6px 0 8px;
    font-size: 14px;
    line-height: 1.3;
}

.rating {
    gap: 4px;
    font-size: 11px;
}

.chips {
    gap: 5px;
    min-height: 24px;
    margin-top: 8px;
}

.chips span {
    min-height: 20px;
    padding: 0 7px;
    font-size: 10px;
    text-align: center;
}

.chips span:nth-child(n+3) {
    display: none;
}

.product-card__bottom {
    gap: 8px;
    margin-top: 10px;
}

.price strong {
    font-size: 16px;
}

.price del {
    font-size: 11px;
}

.mini-cart {
    width: 34px;
    height: 34px;
    font-size: 12px;
}

.campaign-card {
    min-height: 160px;
    padding: 20px;
}

.campaign-card p {
    margin: 14px 0 18px;
    font-size: 20px;
}

.corporate__grid {
    grid-template-columns: minmax(0, 1fr) 360px;
}

.footer {
    padding: 42px 0;
}

.footer__grid {
    gap: 28px;
}

.page-hero,
.page-hero--compact {
    padding: 34px 0 30px;
}

.page-hero h1 {
    font-size: clamp(30px, 3vw, 44px);
}

.page-hero p {
    font-size: 15px;
}

.page-section {
    padding: 42px 0 58px;
}

.catalog-head {
    padding: 28px 0 18px;
    background: linear-gradient(115deg, #fff 0%, #fff7f5 52%, #f0f7f5 100%);
}

.catalog-head__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.7fr);
    align-items: end;
    gap: 22px;
}

.catalog-head__title h1 {
    max-width: 620px;
    margin: 8px 0 0;
    font-size: clamp(28px, 2.6vw, 40px);
    line-height: 1.08;
}

.catalog-head__title p {
    max-width: 640px;
    margin: 10px 0 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
}

.catalog-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.catalog-stats div {
    display: grid;
    gap: 3px;
    min-height: 70px;
    align-content: center;
    padding: 10px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.catalog-stats strong {
    font-size: 22px;
}

.catalog-stats span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.page-section--catalog {
    padding-top: 18px;
}

.shop-layout {
    grid-template-columns: 248px minmax(0, 1fr);
    gap: 16px;
}

.filter-panel {
    top: 104px;
    gap: 12px;
    padding: 12px;
}

.filter-panel__head strong {
    font-size: 16px;
}

.filter-search {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    align-items: center;
    min-height: 38px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
}

.filter-search i {
    color: var(--muted);
    text-align: center;
}

.filter-search input {
    min-width: 0;
    height: 36px;
    border: 0;
    outline: 0;
    background: transparent;
    font-size: 16px;
}

.filter-block {
    gap: 8px;
    padding-top: 11px;
}

.filter-block span,
.detail-options span,
.coupon-box,
.checkout-form label,
.account-form label,
.tracking-card label,
.contact-form label {
    font-size: 12px;
}

.filter-block label {
    justify-content: space-between;
    gap: 8px;
    font-size: 12px;
}

.filter-choice {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 30px;
    padding: 0 8px;
    color: #475467;
    background: #fff;
    border: 1px solid transparent;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 800;
}

.filter-choice:hover,
.filter-choice.is-active {
    color: var(--teal);
    background: var(--surface-2);
    border-color: rgba(15, 118, 110, 0.18);
}

.filter-choice b {
    color: var(--muted);
    font-size: 11px;
}

.filter-block label span {
    flex: 1;
    color: #475467;
    font-size: 12px;
}

.filter-block label b {
    color: var(--muted);
    font-size: 11px;
}

.price-range input,
.shop-toolbar select,
.catalog-controls select,
.detail-options input[type="text"],
.checkout-form input,
.checkout-form select,
.coupon-box input,
.account-form input,
.tracking-card input,
.contact-form input,
.contact-form select {
    height: 38px;
    font-size: 16px;
}

.filter-cta {
    padding: 12px;
}

.filter-cta i {
    font-size: 18px;
}

.filter-cta small {
    font-size: 12px;
}

.shop-content {
    gap: 12px;
}

.catalog-controlbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.catalog-controlbar strong,
.catalog-controlbar span {
    display: block;
}

.catalog-controlbar strong {
    font-size: 15px;
}

.catalog-controlbar span {
    margin-top: 2px;
    color: var(--muted);
    font-size: 12px;
}

.catalog-controls {
    display: flex;
    align-items: center;
    gap: 8px;
}

.catalog-controls select {
    width: 142px;
    padding: 0 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.icon-view {
    display: grid;
    width: 38px;
    height: 38px;
    place-items: center;
    color: var(--muted);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.icon-view.is-active {
    color: #fff;
    background: var(--ink);
    border-color: var(--ink);
}

.category-pills {
    gap: 6px;
}

.category-pills a {
    min-height: 32px;
    padding: 0 10px;
    font-size: 12px;
}

.active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.active-filters span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 9px;
    color: var(--teal);
    background: var(--surface-2);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
}

.product-grid--catalog {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    content-visibility: auto;
    contain-intrinsic-size: 1200px;
}

.product-grid--catalog .product-card__image {
    aspect-ratio: 1.02 / 1;
}

.product-grid--catalog .product-card {
    contain: layout paint;
}

.product-grid--catalog .product-card__body {
    padding: 10px;
}

.product-grid--catalog .product-card h3 {
    min-height: 38px;
    font-size: 13px;
}

.catalog-empty {
    grid-column: 1 / -1;
    display: grid;
    min-height: 220px;
    place-items: center;
    align-content: center;
    gap: 10px;
    padding: 24px;
    color: var(--muted);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.catalog-empty i {
    font-size: 30px;
}

.catalog-empty strong {
    color: var(--ink);
}

.catalog-empty a {
    color: var(--teal);
    font-weight: 800;
}

.pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding-top: 10px;
}

.pagination a,
.pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 10px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    color: #475467;
    font-size: 12px;
    font-weight: 800;
}

.pagination a.is-active {
    color: #fff;
    background: var(--ink);
    border-color: var(--ink);
}

.pagination__next {
    gap: 6px;
}

.product-detail {
    grid-template-columns: minmax(360px, 0.8fr) minmax(420px, 1fr);
}

.product-summary h1 {
    font-size: clamp(28px, 2.6vw, 40px);
}

.detail-price strong {
    font-size: 28px;
}

.detail-actions {
    grid-template-columns: 1fr 150px;
}

@media (max-width: 1180px) {
    .product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .product-grid--catalog {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .catalog-head__grid,
    .shop-layout {
        grid-template-columns: 1fr;
    }

    .filter-panel {
        position: static;
        order: 1;
    }

    .shop-content {
        order: 2;
    }

    .filter-panel {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        align-items: start;
    }

    .filter-panel__head,
    .filter-search,
    .filter-cta {
        grid-column: 1 / -1;
    }
}

@media (max-width: 680px) {
    .container {
        width: min(100% - 18px, 1320px);
    }

    .site-header {
        width: calc(100% - 14px);
    }

    .header-main {
        gap: 8px;
        padding: 8px 0 10px;
    }

    .mobile-menu-btn,
    .cart-button {
        width: 40px;
        min-height: 40px;
        flex-basis: 40px;
    }

    .logo__mark {
        width: 40px;
        height: 40px;
    }

    .logo strong {
        font-size: 17px;
    }

    .search input {
        height: 42px;
        font-size: 13px;
    }

    .hero {
        padding-top: 24px;
    }

    .hero__grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .hero__content {
        max-width: none;
        display: grid;
        gap: 14px;
        order: 2;
        padding: 2px 2px 0;
    }

    .hero h1 {
        margin-top: 0;
        font-size: 28px;
        line-height: 1.1;
        text-wrap: balance;
    }

    .hero h1 span {
        display: inline;
    }

    .hero h1 span + span::before {
        content: " ";
    }

    .hero p {
        margin-top: 0;
        font-size: 14px;
        line-height: 1.55;
        max-width: 34ch;
    }

    .hero__actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
        margin-top: 2px;
    }

    .hero__actions .btn {
        width: 100%;
    }

    .hero__stats {
        grid-template-columns: 1fr;
        gap: 10px;
        margin-top: 2px;
    }

    .hero__stats span {
        padding: 13px 14px;
    }

    .hero__stats strong {
        font-size: 19px;
    }

    .hero__media {
        display: none;
    }

    .hero__stats span {
        border-color: rgba(228, 231, 236, 0.95);
        background: #fff;
    }

    .hero__stats strong {
        font-size: 18px;
    }

    .hero__actions .btn {
        min-height: 46px;
        font-size: 13px;
    }

    .hero__content > .eyebrow {
        width: fit-content;
    }

    .hero__content > p {
        padding-right: 6px;
    }

    .hero {
        padding-bottom: 8px;
    }

    .trust-strip {
        margin-top: 4px;
    }

    .trust-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .trust-grid div {
        min-height: 58px;
        padding: 10px 8px;
        font-size: 12px;
        line-height: 1.25;
        text-align: center;
    }

    .trust-grid i {
        font-size: 12px;
    }

    .hero__grid {
        align-items: start;
    }

    .hero__content {
        align-content: start;
    }

    .hero h1 {
        max-width: 11ch;
    }

    .hero p {
        max-width: 38ch;
    }

    .hero__actions {
        margin-top: 0;
    }

    .hero__stats {
        margin-top: 0;
    }

    .hero__stats span {
        display: grid;
        gap: 2px;
        min-height: 78px;
        font-size: 12px;
    }

    .section {
        padding: 38px 0;
    }

    .section h2 {
        font-size: 25px;
    }

    .trust-grid,
    .category-grid,
    .product-grid,
    .campaign-grid,
    .product-grid--catalog,
    .product-grid--related {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
    }

    .catalog-head {
        padding: 22px 0 14px;
    }

    .catalog-head__title h1 {
        font-size: 26px;
    }

    .catalog-head__title p {
        font-size: 13px;
    }

    .catalog-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .catalog-stats div {
        min-height: 58px;
    }

    .catalog-stats strong {
        font-size: 18px;
    }

    .page-section--catalog {
        padding-top: 12px;
    }

    .filter-panel {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
        padding: 10px;
    }

    .filter-block {
        padding-top: 9px;
    }

    .filter-block:nth-of-type(2),
    .filter-block:nth-of-type(3) {
        grid-column: span 1;
    }

    .filter-block:nth-of-type(4) {
        grid-column: 1 / -1;
    }

    .catalog-controlbar {
        display: grid;
        padding: 10px;
    }

    .catalog-controls {
        display: grid;
        grid-template-columns: 38px 38px 1fr 1fr;
        gap: 6px;
    }

    .catalog-controls select {
        width: 100%;
        padding: 0 6px;
        font-size: 11px;
    }

    .category-pills {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 7px;
    }

    .category-pills a {
        min-height: 32px;
        font-size: 11px;
    }

    .product-card__body,
    .product-grid--catalog .product-card__body {
        padding: 9px;
    }

    .product-card h3,
    .product-grid--catalog .product-card h3 {
        min-height: 36px;
        font-size: 12px;
    }

    .price strong {
        font-size: 14px;
    }

    .mini-cart {
        width: 32px;
        height: 32px;
    }

    .pagination {
        justify-content: flex-start;
    }

    .pagination__next {
        flex: 1 1 100%;
    }

    .detail-actions {
        grid-template-columns: 1fr;
    }
}

.filter-panel__head span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.filter-close,
.catalog-filter-toggle {
    display: none;
}

@media (max-width: 680px) {
    .shop-layout {
        display: block;
    }

    .filter-panel {
        position: fixed;
        inset: 0 auto 0 0;
        z-index: 70;
        display: grid;
        grid-template-columns: 1fr;
        align-content: start;
        width: min(340px, calc(100% - 26px));
        height: 100dvh;
        overflow: auto;
        border-radius: 0;
        box-shadow: 24px 0 58px rgba(16, 24, 40, 0.2);
        transform: translateX(-105%);
        transition: transform 0.22s ease;
    }

    .filter-panel.is-open {
        transform: translateX(0);
    }

    .filter-close {
        display: grid;
        width: 32px;
        height: 32px;
        place-items: center;
        border: 1px solid var(--line);
        border-radius: var(--radius);
        background: #fff;
    }

    .catalog-filter-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        min-height: 38px;
        padding: 0 10px;
        color: #fff;
        background: var(--teal);
        border: 0;
        border-radius: var(--radius);
        font-size: 12px;
        font-weight: 800;
    }

    .catalog-controls {
        grid-template-columns: 74px 38px 38px 1fr 1fr;
    }

    .filter-block:nth-of-type(2),
    .filter-block:nth-of-type(3),
    .filter-block:nth-of-type(4) {
        grid-column: auto;
    }
}

/* Wide header, dropdown navigation, WhatsApp bubble */
.site-header {
    width: 100%;
    max-width: none;
    top: 0;
    margin: 0;
    border-right: 0;
    border-left: 0;
    border-radius: 0;
}

.site-header .container {
    width: min(1480px, calc(100% - 48px));
}

.header-main {
    grid-template-columns: 180px minmax(420px, 1fr) auto;
}

.nav {
    position: relative;
    gap: 0;
}

.nav a,
.nav-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 42px;
    padding: 0 14px;
    color: #30343b;
    border-radius: 6px;
}

.nav-link i {
    color: var(--muted);
    font-size: 10px;
    text-align: center;
}

.nav a:hover,
.nav-link:hover,
.nav a.is-active,
.nav-link.is-active {
    color: var(--brand);
    background: #fff4f2;
}

.nav-item {
    position: relative;
}

.nav-item--mega {
    position: static;
}

.dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 45;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity 0.16s ease, transform 0.16s ease, visibility 0.16s ease;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.nav-item:hover > .dropdown,
.nav-item:focus-within > .dropdown {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.mega-menu {
    right: 0;
    left: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 230px;
    gap: 16px;
    padding: 16px;
}

.mega-menu__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.mega-category {
    display: grid;
    gap: 8px;
    padding: 12px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.mega-category__head {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 0;
    background: transparent;
}

.mega-category__head span {
    display: grid;
    width: 34px;
    height: 34px;
    place-items: center;
    color: var(--teal);
    background: var(--surface-2);
    border-radius: 8px;
}

.mega-category__head strong {
    font-size: 13px;
}

.mega-category__head small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.mega-category div {
    display: grid;
    gap: 3px;
}

.mega-category div a,
.mega-menu__side a,
.dropdown--compact a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 30px;
    padding: 0 8px;
    color: #475467;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 800;
}

.mega-category div a:hover,
.mega-menu__side a:hover,
.dropdown--compact a:hover {
    color: var(--ink);
    background: #fff;
}

.mega-category em {
    color: var(--muted);
    font-style: normal;
    font-size: 11px;
}

.mega-menu__side {
    display: grid;
    align-content: start;
    gap: 8px;
    padding: 14px;
    color: #fff;
    background: linear-gradient(135deg, var(--dark), #0f766e);
    border-radius: var(--radius);
}

.mega-menu__side strong {
    font-size: 16px;
}

.mega-menu__side a {
    color: #fff;
    background: rgba(255, 255, 255, 0.12);
}

.mega-menu__side a:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.18);
}

.dropdown--compact {
    display: grid;
    width: 250px;
    gap: 5px;
    padding: 10px;
}

.dropdown--compact a {
    justify-content: flex-start;
    min-height: 36px;
    font-size: 13px;
}

.dropdown--compact i {
    width: 18px;
    color: var(--teal);
}

.sidebar-category-grid small {
    color: var(--muted);
    font-size: 10px;
    line-height: 1.35;
}

.whatsapp-bubble {
    position: fixed;
    right: 18px;
    bottom: 28px;
    z-index: 34;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 46px;
    padding: 0 14px;
    color: #fff;
    background: #25d366;
    border-radius: 999px;
    box-shadow: 0 16px 34px rgba(37, 211, 102, 0.32);
    font-size: 13px;
    font-weight: 800;
}

.whatsapp-bubble i {
    font-size: 21px;
}

@media (max-width: 1180px) {
    .site-header {
        width: calc(100% - 16px);
        margin: 8px auto 0;
        border: 1px solid var(--line);
        border-radius: var(--radius);
    }

    .site-header .container {
        width: calc(100% - 18px);
    }

    .header-main {
        grid-template-columns: 150px minmax(0, 1fr) auto;
        gap: 10px;
    }

    .search {
        min-width: 0;
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .search button {
        display: none;
    }

    .header-actions {
        min-width: 0;
        gap: 6px;
    }

    .dropdown {
        display: none;
    }

    .product-detail,
    .cart-page-grid,
    .checkout-layout,
    .account-layout,
    .orders-layout,
    .campaign-page-layout,
    .campaign-detail-layout,
    .order-tracking-layout,
    .contact-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 18px;
        min-width: 0;
    }

    .product-gallery,
    .product-summary,
    .checkout-flow,
    .cart-page-list,
    .campaign-page-grid,
    .checkout-summary,
    .auth-card,
    .tracking-card,
    .timeline-card,
    .contact-form,
    .map-card {
        min-width: 0;
    }
}

@media (max-width: 680px) {
    .whatsapp-bubble {
        right: 14px;
        bottom: 28px;
        width: 48px;
        min-height: 48px;
        justify-content: center;
        padding: 0;
    }

    .whatsapp-bubble span {
        display: none;
    }

    .checkout-form .form-grid,
    .checkout-step-actions {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .checkout-step-actions {
        display: grid;
    }

    .checkout-step-actions .btn {
        width: 100%;
        min-width: 0;
    }

    .stepper button {
        min-width: 0;
        padding: 0 4px;
        font-size: 10px;
        line-height: 1.15;
    }
}

/* Final mobile hardening for all transactional pages */
@media (max-width: 680px) {
    html,
    body,
    main {
        max-width: 100%;
        overflow-x: hidden;
    }

    .product-detail-page,
    .page-section,
    .page-hero {
        overflow-x: hidden;
    }

    .product-detail,
    .cart-page-grid,
    .checkout-layout,
    .account-layout,
    .orders-layout,
    .campaign-page-layout,
    .campaign-detail-layout,
    .order-tracking-layout,
    .contact-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 14px;
        min-width: 0;
    }

    .product-gallery,
    .product-summary,
    .checkout-flow,
    .cart-page-list,
    .campaign-page-grid,
    .campaign-detail-main,
    .checkout-summary,
    .auth-card,
    .tracking-card,
    .timeline-card,
    .contact-form,
    .map-card {
        min-width: 0;
    }

    .product-gallery__main {
        aspect-ratio: 1 / 1;
    }

    .product-gallery__main span {
        top: 10px;
        left: 10px;
        padding: 6px 8px;
        font-size: 10px;
    }

    .product-gallery__thumbs {
        gap: 8px;
    }

    .product-summary h1 {
        font-size: 24px;
        line-height: 1.16;
        overflow-wrap: anywhere;
    }

    .detail-price {
        gap: 8px;
    }

    .detail-price strong {
        font-size: 23px;
    }

    .detail-options {
        padding: 12px;
    }

    .option-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .option-grid label {
        min-width: 0;
        padding: 8px;
        font-size: 12px;
        line-height: 1.25;
    }

    .customizer-head {
        align-items: flex-start;
    }

    .customizer-head strong {
        font-size: 16px;
    }

    .customizer-step {
        gap: 9px;
        padding: 10px;
    }

    .customizer-step--inline {
        grid-template-columns: minmax(0, 1fr);
    }

    .customizer-step .option-grid label,
    .print-mode-grid label {
        padding: 0;
    }

    .custom-choice__content {
        grid-template-columns: 30px minmax(0, 1fr) auto;
        min-height: 62px;
        padding: 8px;
    }

    .custom-choice__aside {
        gap: 4px;
    }

    .choice-badge,
    .choice-price {
        min-height: 22px;
        padding: 0 8px;
        font-size: 10px;
    }

    .custom-choice__content > i,
    .upload-field > i {
        width: 30px;
        height: 30px;
    }

    .custom-input-grid,
    .print-mode-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .print-mode-grid label:last-child {
        grid-column: 1 / -1;
    }

    .swatches--named {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        justify-content: stretch;
    }

    .swatches--named button {
        justify-content: flex-start;
        width: 100%;
    }

    .customizer-note {
        align-items: flex-start;
        font-size: 11px;
    }

    .service-grid,
    .detail-info-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .related-head {
        margin-top: 32px;
    }

    .product-grid--related {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 480px) {
    .form-grid,
    .delivery-grid,
    .contact-cards,
    .account-dashboard {
        grid-template-columns: minmax(0, 1fr);
    }

    .delivery-grid label {
        align-items: flex-start;
    }

    .stepper {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 5px;
    }

    .checkout-step-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .checkout-step-actions .btn {
        width: 100%;
        min-width: 0;
    }

    .cart-page-item {
        grid-template-columns: 68px minmax(0, 1fr);
    }

    .cart-page-item img {
        width: 68px;
        height: 68px;
    }
}

.is-hidden {
    display: none !important;
}

.wishlist.is-active {
    background: #102323;
    color: #fff;
}

.account-form textarea,
.account-form select {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 11px 12px;
    background: #fff;
}

.account-form textarea {
    min-height: 96px;
    resize: vertical;
}

.custom-select-field {
    display: block;
}

.custom-select-field select {
    width: 100%;
    min-height: 50px;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 0 14px;
    background: #fff;
    color: var(--ink);
    font-weight: 800;
}

.coupon-box small,
.account-form small,
.form-hint {
    display: block;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
}

.region-status {
    display: none;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
}

.region-status.is-visible {
    display: block;
}

.region-status.is-ok {
    border-color: rgba(15, 118, 110, 0.2);
    background: rgba(15, 118, 110, 0.08);
    color: #0f766e;
}

.region-status.is-bad {
    border-color: rgba(217, 79, 67, 0.22);
    background: rgba(255, 111, 97, 0.1);
    color: #b42318;
}

.coupon-box button + button {
    background: #eef4f3;
    color: var(--ink);
}

.remember-row {
    display: flex !important;
    align-items: center;
    gap: 10px;
    font-weight: 700;
}

.remember-row input {
    width: 18px !important;
    height: 18px;
}

.account-dashboard--wide {
    grid-column: 1 / -1;
}

.account-panel-grid {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 18px;
}

.account-orders-card {
    grid-column: 1 / -1;
}

.panel-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.panel-title-row strong {
    font-size: 18px;
}

.panel-title-row span,
.panel-title-row a {
    color: var(--muted);
    font-weight: 800;
}

.account-list {
    display: grid;
    gap: 10px;
}

.account-list article {
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 12px;
    background: #fff;
}

.account-list article strong,
.account-list article span,
.account-list article small {
    display: block;
}

.account-list article span,
.account-list article small,
.account-list article p {
    color: var(--muted);
    line-height: 1.45;
}

.account-list article p {
    margin: 7px 0 0;
}

.account-list--orders {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.account-track-list {
    grid-column: 2;
    grid-row: 2;
    display: grid;
    gap: 10px;
    min-width: 0;
}

.account-track-list > strong {
    font-size: 18px;
}

.account-track-link {
    display: grid;
    gap: 3px;
    width: 100%;
    padding: 10px 0;
    color: inherit;
    text-align: left;
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--line);
    transition: color 0.18s ease, transform 0.18s ease;
}

.account-track-link:last-child {
    border-bottom: 0;
}

.account-track-list span,
.account-track-list small {
    color: var(--muted);
}

.account-track-link:hover {
    color: var(--teal);
    transform: translateX(2px);
}

@media (max-width: 960px) {
    .account-panel-grid,
    .account-list--orders {
        grid-template-columns: 1fr;
    }
}

.account-layout {
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
}

.account-auth-shell {
    display: grid;
    grid-template-columns: 360px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.account-auth-card,
.account-benefit-panel,
.account-overview,
.account-profile-card,
.account-stat-grid article {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.account-auth-card {
    padding: 16px;
}

.account-benefit-panel {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
    overflow: hidden;
}

.account-benefit-panel article {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr);
    gap: 10px;
    padding: 15px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.account-benefit-panel article:nth-child(2n) {
    border-right: 0;
}

.account-benefit-panel article:nth-last-child(-n + 2) {
    border-bottom: 0;
}

.account-benefit-panel i,
.account-profile-card > span {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 8px;
    background: var(--surface-2);
    color: var(--teal);
}

.account-benefit-panel strong,
.account-benefit-panel span {
    display: block;
}

.account-benefit-panel strong,
.account-profile-card strong,
.account-stat-grid strong {
    font-weight: 800;
}

.account-benefit-panel span,
.account-profile-card small,
.account-stat-grid span {
    color: var(--muted);
    line-height: 1.45;
}

.account-overview {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 14px;
    padding: 14px;
}

.account-profile-card {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 12px;
}

.account-profile-card > span {
    width: 42px;
    height: 42px;
    background: var(--ink);
    color: #fff;
    font-weight: 800;
}

.account-profile-card strong,
.account-profile-card small {
    display: block;
}

.account-stat-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.account-stat-grid article {
    display: grid;
    gap: 3px;
    padding: 12px;
}

.account-stat-grid strong {
    font-size: 20px;
}

.account-address-card .account-form {
    gap: 10px;
}

.account-list--orders {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.account-list--favorites {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.account-list--favorites article {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr) 28px;
    align-items: center;
    gap: 10px;
}

.account-list--favorites img {
    width: 54px;
    height: 54px;
    object-fit: cover;
    border-radius: 8px;
}

.account-list--favorites a {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: var(--surface);
}

@media (max-width: 980px) {
    .account-auth-shell,
    .account-overview {
        grid-template-columns: 1fr;
    }

    .account-list--favorites {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .account-auth-card,
    .auth-card {
        padding: 14px;
    }

    .account-benefit-panel,
    .account-stat-grid,
    .account-list--orders,
    .account-list--favorites {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .account-profile-card {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .account-profile-card .btn {
        grid-column: 1 / -1;
        justify-self: start;
    }

    .account-benefit-panel article {
        grid-template-columns: 1fr;
        padding: 12px;
    }
}

@media (max-width: 420px) {
    .account-list--favorites article {
        grid-template-columns: 46px minmax(0, 1fr);
    }

    .account-list--favorites a {
        grid-column: 2;
        justify-self: start;
    }
}

.account-console {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

.account-console__side {
    display: grid;
    gap: 12px;
    position: sticky;
    top: 118px;
}

.account-member-card,
.account-last-order,
.account-section,
.account-side-stats article {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.account-member-card {
    display: grid;
    gap: 8px;
    padding: 15px;
}

.account-member-card > span {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 8px;
    color: #fff;
    background: var(--ink);
    font-weight: 800;
}

.account-member-card strong,
.account-member-card small,
.account-last-order span,
.account-last-order strong,
.account-last-order small {
    display: block;
}

.account-member-card strong {
    font-size: 18px;
}

.account-member-card small,
.account-last-order span,
.account-last-order small,
.account-section-head span,
.account-order-table small,
.account-order-table em,
.account-address-list span,
.account-address-list small,
.account-address-list p,
.account-favorite-strip span,
.account-favorite-strip small,
.account-side-stats span {
    color: var(--muted);
}

.account-side-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.account-side-stats article {
    display: grid;
    gap: 2px;
    padding: 10px;
}

.account-side-stats strong {
    font-size: 20px;
}

.account-last-order {
    display: grid;
    gap: 5px;
    padding: 13px;
}

.account-console__main {
    display: grid;
    gap: 14px;
}

.account-section {
    padding: 14px;
}

.account-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.account-section-head strong {
    display: block;
    font-size: 17px;
}

.account-section-head a {
    color: var(--teal);
    font-weight: 800;
}

.account-order-table {
    display: grid;
    gap: 8px;
    content-visibility: auto;
    contain-intrinsic-size: 420px;
}

.account-order-table article,
.account-order-link {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) 130px 110px 90px;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.account-order-link {
    width: 100%;
    color: inherit;
    text-align: left;
    border-width: 1px;
    cursor: pointer;
    transition: border-color 0.18s ease, transform 0.18s ease, background 0.18s ease;
}

.account-order-link:hover {
    background: #fff;
    border-color: #cfd9d7;
    transform: translateY(-1px);
}

.account-order-table strong,
.account-order-table small {
    display: block;
}

.account-order-table span {
    justify-self: start;
    padding: 5px 8px;
    border-radius: 999px;
    background: #e8f6f4;
    color: var(--teal);
    font-weight: 800;
    font-size: 12px;
}

.account-order-table b {
    text-align: right;
}

.account-order-table em {
    font-style: normal;
    text-align: right;
}

.account-content-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 14px;
    align-items: start;
}

.account-address-list {
    display: grid;
    gap: 8px;
}

.account-address-list article {
    display: grid;
    gap: 5px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.account-address-head {
    display: grid;
    gap: 6px;
}

.account-address-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.account-address-list strong,
.account-address-list span,
.account-address-list small {
    display: block;
}

.account-address-list p {
    margin: 0;
    line-height: 1.45;
}

.account-address-form {
    gap: 10px;
}

.account-address-form-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.account-form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.account-favorite-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    content-visibility: auto;
    contain-intrinsic-size: 360px;
}

.account-favorite-strip article {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr) 30px;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.account-favorite-strip img {
    width: 58px;
    height: 58px;
    object-fit: cover;
    border-radius: 8px;
}

.account-favorite-strip strong,
.account-favorite-strip span,
.account-favorite-strip small {
    display: block;
}

.account-favorite-strip a {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: #fff;
}

@media (max-width: 1080px) {
    .account-console,
    .account-content-grid {
        grid-template-columns: 1fr;
    }

    .account-console__side {
        position: static;
        grid-template-columns: minmax(0, 1fr) 260px;
    }

    .account-side-stats {
        grid-column: 1 / -1;
    }

    .account-favorite-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .order-tracking-layout {
        grid-template-columns: 1fr;
    }

    .tracking-search-card {
        grid-column: auto;
        grid-row: auto;
        position: static;
        z-index: auto;
    }

    .tracking-result-panel,
    .account-track-list {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 720px) {
    .account-console__side {
        grid-template-columns: 1fr;
    }

    .account-order-table article {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .account-order-table b,
    .account-order-table em {
        text-align: left;
    }

    .account-form-row {
        grid-template-columns: 1fr;
    }

    .payment-method-grid {
        grid-template-columns: 1fr;
    }

    .account-address-form-actions {
        grid-template-columns: 1fr;
    }

    .delivery-method-grid,
    .tracking-overview,
    .tracking-detail-grid {
        grid-template-columns: 1fr;
    }

    .tracking-item-list article {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .tracking-item-total {
        grid-column: 1 / -1;
        text-align: left;
    }
}

@media (max-width: 560px) {
    .tracking-info-list span,
    .tracking-info-list a {
        display: grid;
        justify-content: stretch;
    }

    .tracking-info-list em,
    .tracking-item-qty,
    .tracking-item-total {
        text-align: left;
    }

    .tracking-item-list article {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 520px) {
    .account-side-stats,
    .account-favorite-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .account-section,
    .account-member-card,
    .account-last-order {
        padding: 12px;
    }

    .account-section-head {
        display: grid;
    }

    .account-favorite-strip article {
        grid-template-columns: 50px minmax(0, 1fr);
    }

    .account-favorite-strip a {
        grid-column: 2;
        justify-self: start;
    }
}

.content-page-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    align-items: start;
    gap: 24px;
}

.content-prose {
    border: 1px solid var(--line);
    background: #fff;
    border-radius: var(--radius);
    padding: 34px;
    box-shadow: var(--shadow-soft);
}

.content-prose h2 {
    margin: 0 0 12px;
    color: var(--ink);
    font-size: 24px;
    line-height: 1.2;
}

.content-prose h2:not(:first-child) {
    margin-top: 30px;
}

.content-prose p,
.content-prose li {
    color: var(--muted);
    font-size: 15px;
    line-height: 1.75;
}

.content-prose p {
    margin: 0 0 16px;
}

.content-prose ul {
    margin: 0 0 18px;
    padding-left: 20px;
}

.content-page-nav {
    position: sticky;
    top: 118px;
    display: grid;
    gap: 8px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 16px;
    box-shadow: var(--shadow-soft);
}

.content-page-nav strong {
    color: var(--ink);
    font-size: 15px;
    margin-bottom: 4px;
}

.content-page-nav a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: var(--muted);
    border: 1px solid transparent;
    border-radius: 8px;
    padding: 10px 11px;
    font-size: 14px;
    font-weight: 700;
}

.content-page-nav a:hover,
.content-page-nav a.active {
    color: var(--ink);
    border-color: var(--line);
    background: #f7faf9;
}

@media (max-width: 980px) {
    .content-page-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .content-page-nav {
        position: static;
        order: -1;
    }
}

@media (max-width: 640px) {
    .content-prose {
        padding: 22px;
    }

    .content-prose h2 {
        font-size: 20px;
    }
}



/* ===== CHECKOUT AUTH MODAL ===== */
.checkout-auth-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(0,0,0,0.55);
}
.checkout-auth-modal.is-open {
    display: flex;
}
.checkout-auth-open {
    overflow: hidden;
}

.checkout-auth-modal__card {
    position: relative;
    width: 100%;
    max-width: 440px;
    background: #fff;
    border-radius: 16px;
    padding: 28px 24px 24px;
    box-shadow: 0 24px 48px rgba(0,0,0,0.25);
    max-height: 90vh;
    overflow-y: auto;
}

.checkout-auth-modal__close {
    position: absolute;
    top: 12px;
    right: 14px;
    width: 32px;
    height: 32px;
    border: 0;
    background: transparent;
    font-size: 24px;
    color: #667085;
    cursor: pointer;
    border-radius: 8px;
    display: grid;
    place-items: center;
}
.checkout-auth-modal__close:hover {
    background: #f3f4f6;
    color: #151515;
}

.checkout-auth-tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px;
    margin-bottom: 20px;
    background: #f3f4f6;
    border-radius: 10px;
    padding: 4px;
}
.checkout-auth-tab {
    padding: 10px;
    border: 0;
    background: transparent;
    border-radius: 8px;
    font-weight: 700;
    font-size: 14px;
    color: #667085;
    cursor: pointer;
    transition: all 0.15s;
}
.checkout-auth-tab.is-active {
    background: #fff;
    color: #151515;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.checkout-auth-form {
    display: grid;
    gap: 14px;
}
.checkout-auth-form label {
    display: grid;
    gap: 4px;
    font-size: 13px;
    font-weight: 700;
    color: #374151;
}
.checkout-auth-form input {
    width: 100%;
    height: 46px;
    padding: 0 12px;
    border: 1px solid var(--line);
    border-radius: 10px;
    font-size: 15px;
    background: #fff;
    outline: none;
}
.checkout-auth-form input:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 3px rgba(255,111,97,0.15);
}
.checkout-auth-form small {
    text-align: center;
    font-size: 13px;
    color: var(--muted);
}

/* Checkout login banner */
.checkout-login-required {
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 12px;
    padding: 20px;
    text-align: center;
    margin: 12px 0;
}
.checkout-login-required__icon {
    font-size: 28px;
    margin-bottom: 6px;
}
.checkout-login-required strong {
    display: block;
    font-size: 16px;
    color: #dc2626;
    margin-bottom: 4px;
}
.checkout-login-required p {
    font-size: 13px;
    color: #667085;
    margin: 0 0 14px;
}
.checkout-login-required__actions {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
}

.btn--brand {
    background: var(--brand);
    color: #fff;
    border: 0;
    min-height: 44px;
    padding: 0 20px;
    border-radius: 10px;
    font-weight: 800;
    font-size: 14px;
    cursor: pointer;
    min-width: 120px;
}
.btn--dark {
    background: var(--ink);
    color: #fff;
    border: 0;
    min-height: 44px;
    padding: 0 20px;
    border-radius: 10px;
    font-weight: 800;
    font-size: 14px;
    cursor: pointer;
    min-width: 120px;
}
.btn.full {
    width: 100%;
}

/* Mobile */
@media (max-width: 480px) {
    .checkout-auth-modal__card {
        padding: 20px 16px 16px;
        max-height: 95vh;
    }
    .checkout-login-required__actions {
        flex-direction: column;
    }
    .btn--brand,
    .btn--dark {
        width: 100%;
    }
}
