:root {
    --color-text: #222529;
    --color-muted: #777;
    --color-line: #e7e7e7;
    --color-accent: #0088cc;
    --color-secondary: #ff7272;
    --color-bg: #fff;
    --color-panel: #fff;
    --color-soft: #f5f5f5;
    --color-focus: #105f7f;
    --color-dark: #222529;
    --color-price: #444;
    --container-width: 1200px;
    --mobile-sticky-safe-area-bottom: clamp(0px, env(safe-area-inset-bottom, 0px), 34px);
    --mobile-sticky-cta-bottom-gap: 10px;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    background: var(--color-bg);
    color: var(--color-text);
    font-family: "Figtree", Arial, Helvetica, sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 1.714;
}

a,
button,
input,
select,
textarea {
    min-width: 0;
}

.storefront {
    background: #fff;
}

.site-footer {
    width: min(var(--container-width), calc(100% - 32px));
    margin: 0 auto;
}

.site-header {
    width: 100%;
    border-bottom: 1px solid var(--color-line);
}

.site-header-inner,
.site-nav {
    width: min(var(--container-width), calc(100% - 32px));
    margin: 0 auto;
}

.site-brand,
.contact-chip {
    overflow-wrap: anywhere;
}

.site-header-inner {
    display: grid;
    grid-template-columns: auto minmax(280px, 1fr) auto;
    gap: 22px;
    align-items: center;
    min-height: 92px;
}

.site-brand {
    display: inline-flex;
    align-items: center;
    color: var(--color-text);
    font-size: 20px;
    font-weight: 900;
    text-decoration: none;
}

.site-brand img {
    display: block;
    width: auto;
    max-width: 250px;
    max-height: 70px;
    object-fit: contain;
}

.mobile-nav-toggle {
    position: relative;
    display: none;
    align-items: center;
    justify-content: center;
    width: 44px;
    min-height: 42px;
    border-color: var(--color-line);
    background: #fff;
    padding: 0;
}

.mobile-nav-toggle span {
    position: absolute;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: var(--color-text);
    transition: transform .2s ease, opacity .2s ease;
}

.mobile-nav-toggle span:nth-child(1) {
    transform: translateY(-6px);
}

.mobile-nav-toggle span:nth-child(3) {
    transform: translateY(6px);
}

.site-header.is-mobile-nav-open .mobile-nav-toggle span:nth-child(1) {
    transform: rotate(45deg);
}

.site-header.is-mobile-nav-open .mobile-nav-toggle span:nth-child(2) {
    opacity: 0;
}

.site-header.is-mobile-nav-open .mobile-nav-toggle span:nth-child(3) {
    transform: rotate(-45deg);
}

.site-nav {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px 18px;
    flex-wrap: wrap;
    min-height: 50px;
}

.site-nav-bar {
    border-top: 1px solid var(--color-line);
    background: #fff;
}

.site-nav-item {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 50px;
}

.site-nav-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.site-nav-item.has-dropdown > .site-nav-link::before {
    width: 0;
    height: 0;
    margin-right: 2px;
    border-top: 4px solid currentColor;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
    opacity: .65;
    content: "";
}

.site-nav-dropdown {
    position: absolute;
    z-index: 40;
    top: 100%;
    left: 0;
    display: grid;
    gap: 2px;
    min-width: 230px;
    max-width: min(360px, 88vw);
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 42px rgba(0, 0, 0, .14);
    padding: 8px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
}

.site-nav-item:hover > .site-nav-dropdown,
.site-nav-item:focus-within > .site-nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.site-nav-dropdown a {
    display: grid;
    gap: 2px;
    border-radius: 6px;
    color: var(--color-text);
    padding: 9px 10px;
    text-transform: none;
}

.site-nav-dropdown a:hover,
.site-nav-dropdown a.is-active {
    background: #f4f8fb;
    color: var(--color-accent);
}

.site-nav-dropdown a::after {
    content: none;
}

.site-nav-dropdown span {
    color: var(--color-muted);
    font-size: 11px;
    font-weight: 700;
}

.site-nav-dropdown-sub {
    display: grid;
    margin: -2px 0 4px 10px;
    border-left: 2px solid var(--color-line);
    padding-left: 8px;
}

.site-nav-nested-link {
    font-size: 12px;
}

.site-nav-mega {
    grid-template-columns: repeat(2, minmax(160px, 1fr));
    min-width: min(520px, 88vw);
}

.site-nav-catalog .site-nav-dropdown {
    right: 0;
    left: auto;
}

.site-nav-all-link {
    grid-column: 1 / -1;
    border-top: 1px solid var(--color-line);
    margin-top: 4px;
}

.site-tools {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.contact-chip {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    border: 1px solid var(--color-line);
    border-radius: 6px;
    background: #fff;
    color: var(--color-text);
    padding: 0 10px;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
}

.cart-chip {
    border-color: var(--color-accent);
    background: var(--color-accent);
    color: #fff;
}

.contact-chip:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.cart-chip:hover {
    background: #0077b3;
    color: #fff;
}

.site-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0;
    margin: 0;
    min-width: 0;
}

.site-search input {
    width: 100%;
    border-radius: 6px 0 0 6px;
    border-right: 0;
}

.site-search button {
    min-height: 42px;
    border-radius: 0 6px 6px 0;
}

.live-search-field {
    position: relative;
    display: block;
}

.live-search-results {
    position: absolute;
    z-index: 20;
    top: calc(100% + 8px);
    right: 0;
    width: min(360px, 88vw);
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 40px rgba(0, 0, 0, .12);
    padding: 8px;
}

.live-search-item {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    border-radius: 6px;
    color: var(--color-text);
    padding: 8px;
    text-decoration: none;
}

.live-search-item:hover {
    background: #f4f8fb;
}

.live-search-item img,
.live-search-placeholder {
    width: 54px;
    height: 54px;
    object-fit: contain;
    border-radius: 6px;
    background: #f1f3f5;
}

.live-search-item strong,
.live-search-item em {
    display: block;
}

.live-search-item strong {
    font-size: 13px;
    line-height: 1.35;
}

.live-search-item em {
    margin-top: 4px;
    color: var(--color-accent);
    font-size: 12px;
    font-style: normal;
    font-weight: 800;
}

.site-nav a,
.site-footer a {
    color: var(--color-muted);
    font-weight: 700;
    text-decoration: none;
}

.site-nav a {
    color: #555;
    font-size: 13px;
    letter-spacing: 0;
    text-transform: uppercase;
}

.site-nav a:hover,
.site-nav a.is-active,
.site-footer a:hover {
    color: var(--color-accent);
}

.site-nav a.is-active {
    position: relative;
}

.site-nav a.is-active::after {
    position: absolute;
    right: 0;
    bottom: -17px;
    left: 0;
    height: 3px;
    background: var(--color-accent);
    content: "";
}

.site-nav .site-nav-dropdown a {
    color: var(--color-text);
    font-size: 13px;
    text-transform: none;
}

.site-nav .site-nav-dropdown a::after {
    display: none;
    content: none;
}

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

.store-main {
    width: min(var(--container-width), calc(100% - 32px));
    margin: 0 auto;
    padding: 34px 0 58px;
}

.store-hero {
    display: grid;
    align-items: center;
    min-height: 390px;
    margin-bottom: 34px;
    border-radius: 8px;
    background: #f5f5f5;
    border: 1px solid var(--color-line);
    padding: 48px;
}

.store-hero h1,
.page-title h1 {
    max-width: 760px;
    font-size: 42px;
    line-height: 1.22;
    color: #222529;
}

.store-hero p,
.page-title p {
    max-width: 640px;
}

.home-design-strip {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    min-height: 74px;
    margin: 0 0 18px;
    border-radius: 8px;
    background: #e12d2d;
    color: #fff;
    padding: 16px 22px;
    text-decoration: none;
    box-shadow: 0 14px 34px rgba(225, 45, 45, .18);
}

.home-design-strip span,
.home-design-strip em {
    font-size: 12px;
    font-style: normal;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.home-design-strip strong {
    min-width: 0;
    overflow-wrap: anywhere;
    font-size: 20px;
    line-height: 1.25;
}

.home-design-strip em {
    justify-self: end;
    border: 1px solid rgba(255, 255, 255, .42);
    border-radius: 999px;
    padding: 8px 12px;
}

.home-design-strip-secondary {
    margin: 38px 0;
}

.home-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 500px);
    gap: 36px;
    align-items: center;
    min-height: 470px;
    margin-bottom: 18px;
    border-radius: 8px;
    background: linear-gradient(135deg, #17191c 0%, #2d3035 58%, #4d1e1e 100%);
    color: #fff;
    padding: 46px 48px;
    overflow: hidden;
}

.home-hero-copy h1 {
    max-width: 720px;
    margin-bottom: 14px;
    color: #fff;
    font-size: 54px;
    line-height: 1.04;
}

.home-hero-copy p {
    max-width: 680px;
    margin: 0;
    color: rgba(255, 255, 255, .78);
    font-size: 15px;
}

.home-hero-points {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 24px;
}

.home-hero-points span,
.stock-pill {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    color: #fff;
    padding: 0 11px;
    font-size: 12px;
    font-weight: 800;
}

.home-hero-visual {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 340px;
    color: var(--color-text);
    text-decoration: none;
}

.home-hero-visual img {
    width: 100%;
    height: 100%;
    max-height: 360px;
    object-fit: cover;
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
    box-shadow: 0 22px 54px rgba(0, 0, 0, .34);
}

.home-hero-card {
    position: absolute;
    left: 18px;
    bottom: 18px;
    display: grid;
    gap: 4px;
    width: min(330px, calc(100% - 36px));
    border-left: 4px solid var(--color-secondary);
    border-radius: 6px;
    background: rgba(255, 255, 255, .95);
    padding: 14px 16px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .14);
}

.home-hero-card span,
.home-promo span {
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.home-hero-card strong,
.home-promo strong {
    color: var(--color-text);
    line-height: 1.35;
}

.home-hero-card em,
.home-promo em {
    color: var(--color-accent);
    font-style: normal;
    font-weight: 900;
}

.home-benefits {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0 0 38px;
    border-top: 1px solid var(--color-line);
    border-bottom: 1px solid var(--color-line);
    background: #fff;
}

.home-benefits div {
    display: grid;
    gap: 4px;
    min-height: 92px;
    border-right: 1px solid var(--color-line);
    padding: 18px 20px;
}

.home-benefits div:last-child {
    border-right: 0;
}

.home-benefits strong {
    color: #222529;
    font-size: 15px;
}

.home-benefits span {
    color: var(--color-muted);
    font-size: 13px;
    line-height: 1.55;
}

.home-category-showcase {
    display: grid;
    grid-template-columns: minmax(260px, .82fr) minmax(0, 1.18fr);
    gap: 16px;
}

.home-category-band {
    margin-top: 42px;
}

.home-category-mosaic {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-auto-rows: minmax(210px, auto);
    gap: 14px;
}

.home-category-panel {
    position: relative;
    display: grid;
    align-content: end;
    min-height: 210px;
    overflow: hidden;
    border-radius: 8px;
    background: #222529;
    color: #fff;
    padding: 18px;
    text-decoration: none;
}

.home-category-panel::before {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, rgba(0, 0, 0, .04), rgba(0, 0, 0, .72));
    content: "";
}

.home-category-panel img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: .88;
    transition: transform .28s ease, opacity .28s ease;
}

.home-category-panel:hover img {
    opacity: 1;
    transform: scale(1.04);
}

.home-category-panel span,
.home-category-panel strong,
.home-category-panel em {
    position: relative;
    z-index: 2;
    display: block;
    overflow-wrap: anywhere;
}

.home-category-panel span {
    color: rgba(255, 255, 255, .74);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.home-category-panel strong {
    margin-top: 5px;
    font-size: 22px;
    line-height: 1.12;
}

.home-category-panel em {
    margin-top: 8px;
    color: rgba(255, 255, 255, .82);
    font-style: normal;
    font-weight: 700;
}

.home-category-panel.is-large {
    grid-column: span 2;
    grid-row: span 2;
}

.home-category-panel.is-large strong {
    max-width: 420px;
    font-size: 34px;
}

.compact-category-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.category-tile-featured {
    min-height: 100%;
    align-content: end;
    background: #222529;
    color: #fff;
}

.category-tile-featured:hover {
    border-color: #222529;
}

.category-tile-featured img {
    aspect-ratio: 16 / 11;
    background: rgba(255, 255, 255, .08);
}

.category-tile-featured strong {
    color: #fff;
    font-size: 22px;
}

.category-tile-featured span,
.category-tile-featured em {
    color: rgba(255, 255, 255, .72);
    font-style: normal;
    font-weight: 800;
}

.home-promo-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin: 38px 0;
}

.home-promo {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    min-height: 118px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    color: var(--color-text);
    padding: 12px;
    text-decoration: none;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.home-featured-products .product-grid {
    gap: 18px;
}

.home-featured-products .product-card {
    border-radius: 8px;
}

.product-image {
    position: relative;
}

.product-badge {
    position: absolute;
    z-index: 2;
    top: 10px;
    left: 10px;
    border-radius: 999px;
    background: var(--color-secondary);
    color: #fff;
    padding: 5px 9px;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.home-brand-story {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 34px;
    align-items: center;
    margin: 44px 0;
    border-radius: 8px;
    background: #16191d;
    color: #fff;
    padding: 44px;
}

.home-brand-copy h2,
.home-spec-card h2,
.home-process-card h2 {
    margin: 0 0 14px;
    color: inherit;
    font-size: 38px;
    line-height: 1.12;
}

.home-brand-copy p:not(.eyebrow) {
    max-width: 580px;
    color: rgba(255, 255, 255, .76);
}

.home-brand-features {
    display: grid;
    gap: 14px;
}

.home-brand-features article {
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 8px;
    background: rgba(255, 255, 255, .05);
    padding: 18px;
}

.home-brand-features span,
.home-spec-card .eyebrow,
.home-process-card .eyebrow {
    color: var(--color-secondary);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.home-brand-features h3 {
    margin: 5px 0 8px;
    color: #fff;
    font-size: 22px;
}

.home-brand-features p {
    margin: 0;
    color: rgba(255, 255, 255, .7);
}

.home-order-system {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 22px;
    margin: 44px 0;
}

.home-spec-card,
.home-process-card {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 28px;
}

.home-spec-card dl {
    display: grid;
    gap: 0;
    margin: 20px 0 0;
}

.home-spec-card dl div {
    display: grid;
    grid-template-columns: minmax(0, .8fr) minmax(0, 1fr);
    gap: 12px;
    border-top: 1px solid var(--color-line);
    padding: 13px 0;
}

.home-spec-card dt {
    color: var(--color-muted);
    font-weight: 800;
}

.home-spec-card dd {
    margin: 0;
    font-weight: 900;
}

.home-process-card ol {
    display: grid;
    gap: 14px;
    margin: 22px 0;
    padding: 0;
    list-style: none;
}

.home-process-card li {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 0 14px;
}

.home-process-card li span {
    grid-row: span 3;
    color: var(--color-accent);
    font-size: 28px;
    font-weight: 900;
    line-height: 1;
}

.home-process-card strong {
    font-size: 17px;
}

.home-process-card p {
    margin: 3px 0 0;
    color: var(--color-muted);
}

.home-promo:hover {
    border-color: rgba(0, 136, 204, .35);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .06);
    transform: translateY(-2px);
}

.home-promo img {
    width: 96px;
    height: 96px;
    object-fit: cover;
    border-radius: 6px;
    background: #f3f5f7;
}

.home-promo img,
.promo-placeholder {
    grid-row: 1 / span 3;
}

.home-promo span:not(.promo-placeholder),
.home-promo strong,
.home-promo em {
    grid-column: 2;
}

.promo-placeholder {
    display: grid;
    place-items: center;
    width: 96px;
    height: 96px;
    border-radius: 6px;
    background: #f3f5f7;
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 800;
}

.store-section,
.page-title {
    margin: 34px 0;
}

.shop-filters {
    display: block;
    margin: 0;
    border: 0;
    border-radius: 0;
    background: #fff;
    padding: 0;
}

.shop-filters label {
    margin: 0;
}

.filter-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.store-layout {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 32px;
    align-items: start;
}

.store-layout:not(.has-mobile-filters) {
    grid-template-columns: 1fr;
}

.store-sidebar {
    position: sticky;
    top: 18px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 22px;
}

.filter-group {
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--color-line);
}

.filter-group:last-of-type {
    margin-bottom: 0;
}

.filter-group h4 {
    margin: 0 0 12px;
    color: #222529;
    font-size: 15px;
    font-weight: 700;
}

.filter-group input[type="search"],
.filter-group input[type="text"],
.filter-group select {
    width: 100%;
}

.price-range {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 8px;
    align-items: center;
}

.store-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 22px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 18px 20px;
}

.store-header h1 {
    margin: 0;
    font-size: 34px;
    line-height: 1.12;
}

.store-header .description {
    margin: 5px 0 0;
}

.store-header-tools {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.filter-toggle {
    display: none;
}

.store-sort {
    display: flex;
    align-items: center;
    gap: 8px;
}

.active-filter-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin: -4px 0 18px;
}

.active-filter-bar span,
.active-filter-bar a {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    border: 1px solid var(--color-line);
    border-radius: 999px;
    background: #fff;
    padding: 0 10px;
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
}

.active-filter-bar a {
    border-color: rgba(0, 136, 204, .24);
    color: var(--color-accent);
}

.catalog-search-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: end;
    margin: -4px 0 22px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 18px;
}

.catalog-search-panel label {
    margin: 0;
}

.product-grid-wrapper {
    position: relative;
    transition: opacity .22s ease;
}

.is-loading .product-grid-wrapper {
    opacity: .35;
    pointer-events: none;
}

.shop-loading-indicator {
    display: grid;
    place-items: center;
    padding: 28px;
}

.shop-loading-indicator span {
    width: 38px;
    height: 38px;
    border: 3px solid var(--color-line);
    border-top-color: var(--color-accent);
    border-radius: 50%;
    animation: spin .8s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

.section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 16px;
}

.section-head h2,
.store-section h2 {
    margin: 0;
    font-size: 24px;
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.category-directory {
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
}

.category-tile {
    display: grid;
    align-content: start;
    gap: 8px;
    min-height: 96px;
    border: 1px solid var(--color-line);
    border-radius: 6px;
    background: #fff;
    padding: 16px;
    color: var(--color-text);
    text-decoration: none;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.category-tile:hover {
    border-color: rgba(0, 136, 204, .35);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .06);
    transform: translateY(-2px);
}

.category-tile img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: contain;
    border-radius: 6px;
    background: #f3f5f7;
}

.category-image-placeholder {
    display: grid;
    place-items: center;
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 6px;
    background: #f3f5f7;
    color: var(--color-accent);
    font-size: 34px;
    font-weight: 900;
}

.category-tile strong,
.category-tile span,
.category-tile em {
    display: block;
    overflow-wrap: anywhere;
}

.category-tile em {
    min-height: 40px;
    color: var(--color-muted);
    font-size: 12px;
    font-style: normal;
    line-height: 1.5;
}

.category-tile span {
    margin-top: 8px;
    color: var(--color-muted);
}

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

.product-card {
    display: grid;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.product-card:hover {
    border-color: rgba(0, 136, 204, .35);
    box-shadow: 0 10px 30px rgba(0, 0, 0, .08);
    transform: translateY(-2px);
}

.product-card-link {
    display: grid;
    color: var(--color-text);
    text-decoration: none;
}

.product-image {
    display: grid;
    place-items: center;
    aspect-ratio: 1 / 1;
    background: #f5f5f5;
    overflow: hidden;
}

.product-image img,
.detail-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .28s ease;
}

.product-card:hover .product-image img {
    transform: scale(1.035);
}

.image-placeholder {
    color: var(--color-muted);
}

.product-info {
    display: grid;
    gap: 8px;
    padding: 15px 15px 12px;
}

.product-info strong {
    color: #222529;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.product-actions,
.detail-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.product-actions {
    border-top: 1px solid #f0f0f0;
    padding: 0 15px 15px;
}

.product-actions form,
.detail-actions form {
    margin: 0;
}

.mini-button {
    min-height: 30px;
    border: 0;
    background: #f5f7f9;
    color: var(--color-muted);
    padding: 0 9px;
    font-size: 11px;
    font-weight: 700;
}

.mini-button:hover,
.button-light:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.price,
.detail-price strong {
    color: #222529;
    font-size: 18px;
    font-weight: 900;
}

.product-card-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: max-content;
    max-width: 100%;
    min-height: 34px;
    border-radius: 999px;
    background: var(--color-accent);
    color: #fff;
    padding: 0 13px;
    font-size: 12px;
    font-weight: 900;
}

.product-card:hover .product-card-cta {
    background: #0077b3;
}

.old-price,
.detail-price span {
    color: var(--color-muted);
    text-decoration: line-through;
}

.product-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin: 0 0 22px;
    color: var(--color-muted);
    font-size: 13px;
}

.product-breadcrumb a {
    color: var(--color-muted);
    font-weight: 700;
    text-decoration: none;
}

.product-breadcrumb a:hover {
    color: var(--color-accent);
}

.product-breadcrumb strong {
    color: var(--color-text);
    font-weight: 800;
}

.product-design-strip {
    margin-bottom: 22px;
}

.product-detail {
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(360px, 4fr);
    gap: 32px;
    align-items: start;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 24px;
}

.detail-assurance-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0 0 24px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}

.detail-assurance-strip span {
    display: grid;
    gap: 3px;
    min-height: 78px;
    border-right: 1px solid var(--color-line);
    padding: 14px 16px;
    color: var(--color-muted);
    font-size: 12px;
    line-height: 1.5;
}

.detail-assurance-strip span:last-child {
    border-right: 0;
}

.detail-assurance-strip strong {
    color: var(--color-text);
    font-size: 13px;
}

.product-gallery {
    display: grid;
    gap: 12px;
}

.detail-image {
    display: grid;
    place-items: center;
    aspect-ratio: 1 / 1;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #f7f7f7;
    overflow: hidden;
}

.gallery-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(74px, 1fr));
    gap: 10px;
}

.gallery-thumb {
    display: grid;
    place-items: center;
    min-height: 0;
    aspect-ratio: 1 / 1;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 0;
    overflow: hidden;
}

.gallery-thumb.active,
.gallery-thumb:hover {
    border-color: var(--color-accent);
}

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

.detail-info {
    position: sticky;
    top: 18px;
    border-left: 0;
    border-radius: 8px;
    background: #fff;
    padding: 4px 0;
}

.detail-info h1 {
    margin-bottom: 12px;
    font-size: 38px;
    line-height: 1.12;
}

.detail-popular-badge {
    display: inline-flex;
    align-items: center;
    width: max-content;
    max-width: 100%;
    min-height: 28px;
    margin: 0 0 10px;
    border-radius: 999px;
    background: var(--color-secondary);
    color: #fff;
    padding: 0 10px;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.detail-meta-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin: 0 0 16px;
    color: var(--color-muted);
    font-size: 13px;
    font-weight: 800;
}

.stock-pill {
    background: #eef8fd;
    color: var(--color-accent);
}

.stock-instock {
    background: #e9f8ef;
    color: #157347;
}

.stock-outofstock {
    background: #fff0f0;
    color: #b42318;
}

.stock-onbackorder {
    background: #fff7d6;
    color: #8a5a00;
}

.detail-price {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin: 18px 0;
}

.detail-price strong {
    color: #222529;
    font-size: 34px;
}

.catalog-callout {
    display: grid;
    gap: 3px;
    margin: 18px 0;
    border-left: 4px solid var(--color-secondary);
    background: #fff6f6;
    padding: 12px 14px;
}

.catalog-callout strong {
    color: var(--color-text);
}

.catalog-callout span {
    color: var(--color-muted);
    font-size: 13px;
}

.detail-short-description {
    margin: 0 0 18px;
}

.detail-highlight-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 18px 0 0;
}

.detail-highlight-grid span {
    display: grid;
    gap: 4px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #f8fbfd;
    padding: 12px;
}

.detail-highlight-grid strong {
    color: var(--color-text);
    font-size: 13px;
}

.detail-highlight-grid em {
    color: var(--color-muted);
    font-size: 12px;
    font-style: normal;
    line-height: 1.5;
}

.product-meta-list {
    display: grid;
    gap: 10px;
    margin: 18px 0 0;
    border-top: 1px solid var(--color-line);
    border-bottom: 1px solid var(--color-line);
    padding: 14px 0;
}

.product-meta-list div {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 12px;
}

.product-meta-list dt {
    color: var(--color-muted);
    font-weight: 800;
}

.product-meta-list dd {
    margin: 0;
    color: var(--color-text);
    font-weight: 700;
}

.product-meta-list a {
    color: var(--color-accent);
    text-decoration: none;
}

.product-meta-list a:hover {
    text-decoration: underline;
}

.detail-actions {
    display: grid;
    gap: 10px;
    margin-top: 20px;
}

.detail-action-panel {
    display: grid;
    gap: 10px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #f6f9fb;
    padding: 16px;
}

.detail-action-panel > strong {
    color: var(--color-text);
    font-size: 18px;
}

.detail-action-panel > span {
    color: var(--color-muted);
    font-size: 12px;
    line-height: 1.55;
}

.detail-cart-form {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 8px;
    width: 100%;
    margin: 0;
}

.detail-cart-form input {
    min-width: 0;
}

.detail-secondary-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.detail-secondary-actions form {
    display: block;
}

.detail-secondary-actions .button {
    width: 100%;
}

.wide-action {
    width: 100%;
}

.detail-service-grid {
    display: grid;
    gap: 10px;
    margin-top: 20px;
}

.detail-service-grid span {
    display: block;
    border-top: 1px solid var(--color-line);
    color: var(--color-muted);
    padding-top: 10px;
    font-size: 13px;
    line-height: 1.55;
}

.detail-service-grid strong {
    display: block;
    color: var(--color-text);
}

.product-tabs {
    margin-top: 48px;
}

.product-tab-list {
    display: flex;
    gap: 28px;
    border-bottom: 1px solid var(--color-line);
}

.product-tab-list span {
    display: inline-flex;
    min-height: 46px;
    align-items: center;
    border-bottom: 3px solid var(--color-accent);
    color: var(--color-text);
    font-weight: 900;
}

.product-tab-list span + span {
    border-bottom-color: transparent;
    color: var(--color-muted);
}

.product-tab-panels {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
    gap: 24px;
    align-items: start;
    padding-top: 24px;
}

.product-tab-panel {
    min-width: 0;
    border: 1px solid var(--color-line);
    border-radius: 6px;
    background: #fff;
    padding: 24px;
}

.product-tab-panel h2 {
    margin: 0 0 14px;
}

.order-note-panel {
    background: #f7fbfd;
}

.order-note-panel ul {
    margin: 12px 0 0;
    padding-left: 18px;
    color: var(--color-muted);
    line-height: 1.7;
}

.related-products {
    margin-top: 56px;
}

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

.compare-card {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 14px;
}

.compare-card a {
    color: var(--color-text);
    text-decoration: none;
}

.compare-card img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 6px;
    background: #f5f5f5;
}

.compare-card h2 {
    font-size: 16px;
    line-height: 1.35;
}

.compare-card dl {
    display: grid;
    gap: 0;
    margin: 14px 0;
    border-top: 1px solid var(--color-line);
    border-bottom: 1px solid var(--color-line);
}

.compare-specs div {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 10px;
    border-bottom: 1px solid var(--color-line);
    padding: 10px 0;
}

.compare-specs div:last-child {
    border-bottom: 0;
}

.compare-card dt {
    color: var(--color-muted);
    font-weight: 800;
}

.compare-card dd {
    min-width: 0;
    margin: 0;
    overflow-wrap: anywhere;
    font-weight: 700;
}

.rich-text {
    color: var(--color-text);
    line-height: 1.75;
}

.rich-text img {
    max-width: 100%;
    height: auto;
}

.faq-section {
    max-width: 820px;
    margin-right: auto;
    margin-left: auto;
}

.faq-accordion {
    display: grid;
    gap: 12px;
}

.faq-item {
    overflow: hidden;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
}

.faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 68px;
    padding: 18px 22px;
    color: var(--color-text);
    cursor: pointer;
    font-size: 16px;
    font-weight: 900;
    list-style: none;
}

.faq-question::-webkit-details-marker {
    display: none;
}

.faq-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 30px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #eef8fd;
    color: var(--color-accent);
    font-size: 20px;
    line-height: 1;
    transition: transform .2s ease;
}

.faq-item[open] .faq-question {
    border-bottom: 1px solid var(--color-line);
}

.faq-item[open] .faq-icon {
    transform: rotate(45deg);
}

.faq-answer {
    padding: 18px 22px 20px;
    background: #fafafa;
    color: #444;
}

.content-note {
    display: grid;
    gap: 10px;
    max-width: 680px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: var(--color-soft);
    padding: 18px;
}

.content-note strong {
    font-size: 18px;
}

.content-note p {
    margin: 0;
}

.site-footer {
    display: grid;
    grid-template-columns: minmax(230px, 1fr) minmax(360px, 1.45fr) minmax(220px, .9fr) minmax(180px, .75fr);
    gap: 24px;
    align-items: start;
    padding: 32px 0;
    border-top: 1px solid var(--color-line);
    color: var(--color-muted);
}

.footer-brand,
.footer-link-groups,
.footer-link-group,
.footer-contact,
.footer-social {
    display: grid;
    gap: 9px;
}

.footer-logo {
    width: max-content;
    max-width: 100%;
}

.footer-brand p {
    max-width: 360px;
    margin: 0;
}

.footer-brand small {
    color: var(--color-muted);
}

.footer-link-groups {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.footer-link-group strong,
.footer-contact strong,
.footer-social strong {
    color: var(--color-text);
    font-size: 14px;
}

.footer-link-group a,
.footer-contact a {
    width: max-content;
    max-width: 100%;
}

.footer-contact {
    font-style: normal;
}

.footer-contact-card,
.footer-social-card {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 14px;
}

.footer-contact span {
    display: block;
}

.social-link-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.social-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    border: 1px solid var(--color-line);
    border-radius: 999px;
    background: #fff;
    padding: 0 10px 0 6px;
    color: var(--color-text);
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
}

.social-link span {
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--color-accent);
    color: #fff;
    font-size: 10px;
    font-weight: 900;
}

.social-link-whatsapp span {
    background: #25D366;
}

.social-link-instagram span {
    background: #E4405F;
}

.social-link-facebook span {
    background: #1877F2;
}

.social-link:hover {
    border-color: rgba(0, 136, 204, .35);
}

.footer-social .social-link {
    width: max-content;
    max-width: 100%;
}

.mobile-contact-bar {
    position: fixed;
    right: max(12px, env(safe-area-inset-right));
    bottom: 10px;
    bottom: calc(var(--mobile-sticky-cta-bottom-gap, 10px) + var(--mobile-sticky-safe-area-bottom, 0px));
    left: max(12px, env(safe-area-inset-left));
    z-index: 1200;
    display: none;
    grid-template-columns: minmax(104px, .72fr) minmax(0, 1.36fr);
    gap: 8px;
    width: auto;
    max-width: 520px;
    margin: 0 auto;
    padding: 8px;
    border: 1px solid rgba(226, 232, 240, .92);
    border-radius: 999px;
    background: rgba(255, 255, 255, .96);
    box-shadow: 0 18px 44px rgba(15, 23, 42, .18), 0 2px 10px rgba(15, 23, 42, .08);
    opacity: 0;
    pointer-events: none;
    transform: translateY(calc(100% + 22px));
    transition: transform .24s ease, opacity .2s ease;
    backdrop-filter: blur(14px);
}

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

.mobile-contact-bar-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    min-height: 58px;
    gap: 10px;
    padding: 0 14px;
    border-radius: 999px;
    color: #111827;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.1;
    text-decoration: none;
    white-space: nowrap;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.mobile-contact-bar-link svg {
    width: 28px;
    height: 28px;
    flex: 0 0 auto;
}

.mobile-contact-bar-link:active {
    transform: scale(.98);
}

.mobile-contact-bar-whatsapp {
    background: linear-gradient(180deg, #18bf58, #0f8f41);
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .22), 0 12px 24px rgba(15, 143, 65, .24);
}

.mobile-contact-bar-call {
    border: 1px solid #dfe5ec;
    background: #fff;
    color: #111827;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .75);
}

.mobile-contact-bar-call svg {
    color: #13a955;
}

body.is-mobile-sticky-cta-visible .mobile-contact-bar {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .mobile-contact-bar {
        transition: none;
    }
}

@media (max-width: 360px) {
    .mobile-contact-bar {
        grid-template-columns: 86px minmax(0, 1fr);
        gap: 7px;
        padding: 7px;
    }

    .mobile-contact-bar-link {
        min-height: 54px;
        gap: 7px;
        padding: 0 10px;
        font-size: 14px;
    }

    .mobile-contact-bar-link svg {
        width: 24px;
        height: 24px;
    }
}

.shell {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 24px;
}

.panel {
    width: min(720px, 100%);
    background: var(--color-panel);
    border: 1px solid var(--color-line);
    border-radius: 8px;
    padding: 32px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, .06);
}

.eyebrow {
    margin: 0 0 10px;
    color: var(--color-accent);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

h1 {
    margin: 0 0 12px;
    font-size: 32px;
    line-height: 1.15;
}

p {
    color: var(--color-muted);
    line-height: 1.6;
}

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

.button,
button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    border: 1px solid var(--color-accent);
    border-radius: 6px;
    background: var(--color-accent);
    color: #fff;
    padding: 0 16px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}

.button:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
a:focus-visible {
    outline: 3px solid rgba(0, 136, 204, .22);
    outline-offset: 2px;
}

.button-light {
    background: #fff;
    color: var(--color-accent);
}

.button-block {
    width: 100%;
}

button.button-light {
    border-color: var(--color-line);
    color: var(--color-text);
}

.alert {
    margin: 18px 0 0;
    padding: 12px 14px;
    border: 1px solid #ffd2d2;
    border-radius: 6px;
    background: #fff4f4;
    color: #b42318;
    font-size: 14px;
}

.notice {
    margin: 0 0 18px;
    padding: 12px 14px;
    border: 1px solid #b8e6c5;
    border-radius: 6px;
    background: #f0fff4;
    color: #157347;
    font-size: 14px;
    font-weight: 700;
}

.notice-error {
    border-color: #ffd2d2;
    background: #fff4f4;
    color: #9d1f1f;
}

.notice-list {
    margin: 8px 0 0;
    padding-left: 20px;
}

.login-panel {
    width: min(420px, 100%);
}

form {
    display: grid;
    gap: 14px;
    margin-top: 20px;
}

label {
    display: grid;
    gap: 7px;
    color: var(--color-muted);
    font-size: 14px;
}

input {
    width: 100%;
    height: 42px;
    border: 1px solid var(--color-line);
    border-radius: 6px;
    padding: 0 12px;
    font: inherit;
}

input[type="color"] {
    padding: 4px;
}

select,
textarea {
    width: 100%;
    border: 1px solid var(--color-line);
    border-radius: 6px;
    padding: 10px 12px;
    font: inherit;
}

select {
    height: 42px;
    background: #fff;
}

select[multiple],
.multi-select {
    height: 180px;
}

textarea {
    min-height: 110px;
    resize: vertical;
}

.doc-view {
    max-height: 70vh;
    overflow: auto;
    margin: 20px 0 0;
    padding: 18px;
    border: 1px solid var(--color-line);
    border-radius: 6px;
    background: #fafafa;
    color: #333;
    font-size: 13px;
    line-height: 1.6;
    white-space: pre-wrap;
}

.admin-page {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    background: var(--color-bg);
}

.sidebar {
    position: sticky;
    top: 0;
    align-self: start;
    height: 100vh;
    overflow: auto;
    border-right: 1px solid var(--color-line);
    background: #fff;
    padding: 24px;
}

.brand {
    margin-bottom: 28px;
    font-size: 20px;
    font-weight: 800;
}

.sidebar nav {
    display: grid;
    gap: 6px;
}

.sidebar a {
    display: block;
    border-radius: 6px;
    padding: 11px 12px;
    color: var(--color-muted);
    font-weight: 700;
    text-decoration: none;
}

.sidebar a.active,
.sidebar a:hover {
    background: #eef8fd;
    color: var(--color-accent);
}

.workspace {
    padding: 28px;
}

.topbar {
    position: sticky;
    top: 0;
    z-index: 12;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin: -28px -28px 22px;
    border-bottom: 1px solid var(--color-line);
    background: rgba(247, 248, 250, .94);
    padding: 22px 28px;
    backdrop-filter: blur(12px);
}

.topbar h1 {
    margin-bottom: 0;
}

.topbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
}

.stat-card {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 18px;
}

.stat-card span {
    display: block;
    margin-bottom: 10px;
    color: var(--color-muted);
    font-size: 13px;
    font-weight: 700;
}

.stat-card strong {
    font-size: 34px;
}

.wide-panel {
    width: 100%;
}

.table-wrap {
    overflow: auto;
}

.list-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.bulk-toolbar {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}

.bulk-toolbar select {
    min-width: 150px;
}

.list-summary {
    margin: 0 0 12px;
    color: var(--color-muted);
    font-size: 13px;
    font-weight: 800;
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

th {
    padding: 0 14px 12px;
    border-bottom: 1px solid var(--color-line);
    color: var(--color-muted);
    text-align: left;
}

td {
    padding: 14px;
    border-bottom: 1px solid var(--color-line);
    vertical-align: top;
}

td strong {
    display: block;
}

td span {
    display: block;
    margin-top: 4px;
    color: var(--color-muted);
    font-size: 12px;
}

.select-column {
    width: 42px;
    padding-right: 0;
}

.select-column input {
    width: 18px;
    height: 18px;
}

.empty-table {
    color: var(--color-muted);
    font-weight: 800;
    text-align: center;
}

.empty-state {
    display: grid;
    justify-items: start;
    gap: 12px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 28px;
}

.empty-state h2,
.empty-state p {
    margin: 0;
}

.catalog-empty {
    min-height: 220px;
    align-content: center;
}

.list-page-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin: -8px 0 18px;
    border-top: 1px solid var(--color-line);
    border-bottom: 1px solid var(--color-line);
    padding: 12px 0;
}

.list-page-toolbar span {
    color: var(--color-muted);
    font-weight: 800;
}

.data-table tfoot td {
    background: #fafafa;
}

.badge {
    display: inline-flex;
    align-items: center;
    width: max-content;
    max-width: 100%;
    border-radius: 999px;
    padding: 5px 9px;
    font-size: 12px;
    font-weight: 800;
}

.badge-pending {
    background: #fff7d6;
    color: #8a5a00;
}

.badge-processing {
    background: #e6f1ff;
    color: #1754a6;
}

.badge-shipped {
    background: #ecebff;
    color: #4232a8;
}

.badge-completed {
    background: #dcf8e8;
    color: #126b3d;
}

.badge-cancelled {
    background: #ffe5e5;
    color: #a32727;
}

.pagination {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 16px;
}

.pagination span {
    color: var(--color-muted);
    font-size: 13px;
    font-weight: 800;
}

.button.disabled {
    pointer-events: none;
    opacity: .45;
}

.status-pill {
    display: inline-flex;
    width: auto;
    margin-top: 0;
    border-radius: 999px;
    background: #eef8fd;
    color: var(--color-accent);
    padding: 5px 9px;
    font-weight: 700;
}

.text-link {
    color: var(--color-accent);
    font-weight: 800;
    text-decoration: none;
}

.text-link:hover {
    text-decoration: underline;
}

.text-right {
    text-align: right;
}

.row-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.row-actions form {
    display: inline;
    margin: 0;
}

.draft-status-form {
    display: flex;
    gap: 8px;
    margin: 0;
}

.draft-status-form select {
    width: auto;
    min-width: 170px;
    height: 34px;
    padding: 4px 8px;
    font-size: 13px;
}

.link-button {
    min-height: 0;
    border: 0;
    background: transparent;
    color: var(--color-accent);
    padding: 0;
    font: inherit;
    font-weight: 800;
    text-decoration: none;
}

.link-button:hover {
    text-decoration: underline;
}

.inline-search {
    display: flex;
    gap: 8px;
    margin: 0;
}

.inline-search input {
    min-width: 260px;
}

.inline-search select {
    width: auto;
    min-width: 150px;
}

.editor-form {
    margin-top: 0;
}

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

.editor-stack {
    display: grid;
    gap: 22px;
}

.editor-section {
    min-width: 0;
    border: 0;
    border-top: 1px solid var(--color-line);
    margin: 0;
    padding: 24px 0 0;
}

.editor-section:first-child {
    border-top: 0;
    padding-top: 0;
}

.editor-section legend {
    grid-column: 1 / -1;
    margin: 0 0 4px;
    padding: 0;
    color: var(--color-text);
    font-size: 18px;
    font-weight: 900;
}

.content-cleaner {
    display: grid;
    gap: 16px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: var(--color-soft);
    padding: 18px;
}

.content-cleaner h3 {
    margin: 0 0 6px;
    font-size: 18px;
}

.content-cleaner p {
    margin: 0;
}

.content-report {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
}

.content-report div {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 12px;
}

.content-report dt {
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 800;
}

.content-report dd {
    margin: 6px 0 0;
    font-size: 22px;
    font-weight: 900;
}

.clean-preview {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 12px;
}

.clean-preview summary {
    cursor: pointer;
    font-weight: 900;
}

.clean-preview .rich-text {
    max-height: 360px;
    overflow: auto;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--color-line);
}

.block-help {
    margin: 0;
    color: var(--color-muted);
    font-size: 14px;
}

.content-block-editor {
    display: grid;
    gap: 14px;
}

.block-type-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 10px;
}

.block-list {
    display: grid;
    gap: 14px;
}

.block-card {
    display: grid;
    gap: 12px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 14px;
}

.block-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.block-fields-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.button-small {
    min-height: 30px;
    padding: 0 10px;
    font-size: 12px;
}

.danger-button {
    border-color: #f4b9b9;
    color: #b42318;
}

.code-textarea {
    min-height: 190px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 13px;
    line-height: 1.55;
}

.add-block-button {
    display: grid;
    gap: 6px;
    min-height: 96px;
    border: 2px dashed var(--color-line);
    background: #fff;
    color: var(--color-text);
}

.add-block-button span {
    color: var(--color-accent);
    font-size: 24px;
    line-height: 1;
}

.content-block + .content-block,
.homepage-block + .homepage-block,
.prepared-block + .prepared-block {
    margin-top: 24px;
}

.prepared-block {
    border-radius: 8px;
}

.prepared-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr);
    gap: 26px;
    align-items: center;
    border: 1px solid var(--color-line);
    background: #f2f7fa;
    padding: 36px;
}

.prepared-hero:not(.has-media) {
    grid-template-columns: minmax(0, 760px);
}

.prepared-hero h2 {
    max-width: 760px;
    margin: 0 0 12px;
    font-size: 40px;
    line-height: 1.12;
}

.prepared-hero p {
    max-width: 660px;
}

.prepared-hero figure {
    margin: 0;
}

.prepared-hero img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 8px;
    background: #fff;
}

.prepared-cta {
    border: 1px solid var(--color-line);
    background: #102a33;
    color: #fff;
    padding: 30px;
}

.prepared-cta > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.prepared-cta h2 {
    margin: 0 0 8px;
    font-size: 28px;
}

.prepared-cta p {
    max-width: 720px;
    margin: 0;
    color: rgba(255, 255, 255, .78);
}

.prepared-cta .button {
    flex-shrink: 0;
    border-color: #fff;
    background: #fff;
    color: #102a33;
}

.block-section-head {
    align-items: flex-start;
}

.block-section-head p {
    max-width: 720px;
    margin: 7px 0 0;
}

.span-2 {
    grid-column: span 2;
}

.checkbox-line {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    margin-top: 24px;
}

.checkbox-line input {
    width: 18px;
    height: 18px;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
}

.filterable-select {
    align-self: start;
}

.select-filter {
    margin-bottom: 6px;
    background: #fbfcfd;
}

.contact-section {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    padding: 24px;
    background: #fff;
}

.commerce-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.8fr) minmax(300px, .8fr);
    gap: 24px;
    align-items: start;
}

.cart-items,
.checkout-panel,
.order-summary-card {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
}

.cart-items {
    display: grid;
}

.cart-line {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr) minmax(150px, 190px) minmax(110px, auto) auto;
    gap: 14px;
    align-items: center;
    padding: 14px;
    border-bottom: 1px solid var(--color-line);
}

.cart-line:last-child {
    border-bottom: 0;
}

.cart-line-media {
    display: grid;
    place-items: center;
    aspect-ratio: 1;
    border-radius: 8px;
    background: #f3f5f7;
    overflow: hidden;
}

.cart-line-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cart-line-info {
    display: grid;
    gap: 6px;
}

.cart-line-info a {
    color: var(--color-text);
    font-weight: 900;
    line-height: 1.35;
    overflow-wrap: anywhere;
    text-decoration: none;
}

.cart-line-info span,
.summary-note {
    color: var(--color-muted);
    font-size: 13px;
}

.quantity-form {
    display: grid;
    grid-template-columns: minmax(70px, 1fr) auto;
    gap: 8px;
    align-items: end;
    margin: 0;
}

.quantity-form label {
    margin: 0;
}

.quantity-form input {
    height: 36px;
}

.cart-line-total {
    text-align: right;
}

.remove-form {
    margin: 0;
}

.order-summary-card,
.checkout-panel {
    padding: 22px;
}

.order-summary-card {
    position: sticky;
    top: 96px;
    display: grid;
    gap: 14px;
}

.order-summary-card h2,
.checkout-panel h2 {
    margin: 0;
    font-size: 22px;
}

.checkout-panel .form-subtitle {
    margin-top: 26px;
    padding-top: 22px;
    border-top: 1px solid var(--color-line);
    font-size: 18px;
}

.order-summary-card dl,
.meta-list {
    display: grid;
    gap: 10px;
    margin: 0;
}

.order-summary-card dl div,
.meta-list div {
    display: flex;
    justify-content: space-between;
    gap: 14px;
}

.order-summary-card dt,
.meta-list dt {
    color: var(--color-muted);
    font-weight: 800;
}

.order-summary-card dd,
.meta-list dd {
    margin: 0;
    font-weight: 900;
    text-align: right;
}

.summary-total {
    border-top: 1px solid var(--color-line);
    padding-top: 12px;
}

.checkout-form {
    margin-top: 0;
}

.checkout-items {
    display: grid;
    gap: 10px;
    border-bottom: 1px solid var(--color-line);
    padding-bottom: 14px;
}

.checkout-item {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    font-size: 13px;
}

.checkout-item span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.checkout-item strong {
    flex: 0 0 auto;
}

.summary-note {
    margin: 0;
}

.order-success {
    display: grid;
    justify-items: center;
    max-width: 680px;
    margin: 40px auto 64px;
    border: 1px solid #b8e6c5;
    border-radius: 8px;
    background: #f0fff4;
    padding: 38px;
    text-align: center;
}

.order-success-detail {
    max-width: 920px;
}

.order-success h1,
.order-success p {
    margin: 0 0 10px;
}

.order-success h2 {
    margin: 0 0 12px;
    font-size: 18px;
}

.order-success-status-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    width: 100%;
    margin: 18px 0;
}

.order-success-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    width: 100%;
    margin: 18px 0;
}

.order-success-status-grid div,
.order-success-meta div {
    display: grid;
    gap: 6px;
    justify-items: center;
    min-width: 0;
    border: 1px solid rgba(21, 115, 71, .18);
    border-radius: 8px;
    background: #fff;
    padding: 12px;
}

.order-success-status-grid span,
.order-success-meta dt {
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.order-success-status-grid strong,
.order-success-meta dd {
    max-width: 100%;
    margin: 0;
    overflow-wrap: anywhere;
    font-weight: 900;
}

.order-success-followup,
.order-success-lines,
.order-success-timeline {
    width: 100%;
    margin-top: 16px;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    padding: 18px;
    text-align: left;
}

.order-success-followup dl {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 0 0 14px;
}

.order-success-followup dl div {
    min-width: 0;
}

.order-success-followup dt {
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 800;
}

.order-success-followup dd {
    margin: 4px 0 0;
    overflow-wrap: anywhere;
    font-weight: 900;
}

.order-success-lines div {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 9px 0;
    border-top: 1px solid var(--color-line);
}

.order-success-lines span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.order-success-total {
    font-size: 18px;
}

.order-success-timeline ol {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.order-success-timeline li {
    display: grid;
    gap: 3px;
    border-left: 3px solid var(--color-accent);
    padding-left: 12px;
}

.order-success-timeline span,
.order-success-timeline small {
    color: var(--color-muted);
}

.order-success-timeline small {
    font-size: 12px;
    font-weight: 800;
}

.success-mark {
    display: grid;
    place-items: center;
    width: 58px;
    height: 58px;
    margin-bottom: 14px;
    border-radius: 50%;
    background: #157347;
    color: #fff;
    font-size: 32px;
    font-weight: 900;
}

.order-admin-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(300px, .8fr);
    gap: 22px;
    align-items: start;
}

.stack-form {
    display: grid;
    gap: 14px;
    margin: 0 0 18px;
}

.operation-form {
    margin-top: 16px;
}

.operation-meta {
    margin-top: 12px;
}

.operation-meta div {
    align-items: flex-start;
}

.operation-meta dd {
    max-width: 170px;
    overflow-wrap: anywhere;
}

.mini-status-list {
    display: grid;
    gap: 3px;
    min-width: 150px;
    color: var(--color-muted);
    font-size: 12px;
    line-height: 1.35;
}

.mini-status-list strong {
    color: var(--color-text);
}

.note-box {
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fafafa;
    padding: 14px;
    line-height: 1.7;
}

.status-history {
    display: grid;
    gap: 12px;
    margin: 14px 0 0;
    padding: 0;
    list-style: none;
}

.status-history li {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: start;
    border-left: 3px solid var(--color-accent);
    border-radius: 6px;
    background: #fafafa;
    padding: 12px 14px;
}

.status-history strong,
.status-history span,
.status-history small {
    display: block;
}

.status-history span {
    color: var(--color-muted);
}

.status-history small {
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 800;
    text-align: right;
    white-space: nowrap;
}

.admin-address {
    display: grid;
    gap: 8px;
    font-style: normal;
}

.admin-address a {
    color: var(--color-accent);
    font-weight: 800;
    text-decoration: none;
}

.contact-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-top: 0;
}

.content-page-main iframe,
.content-page-main embed,
.content-page-main object,
.contact-section iframe {
    max-width: 100%;
}

.hidden-field {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
    padding: 0 !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    border: 0 !important;
    white-space: nowrap !important;
}

.message-detail dl {
    display: grid;
    grid-template-columns: 140px minmax(0, 1fr);
    gap: 10px 16px;
    margin: 0 0 22px;
}

.message-detail dt {
    color: var(--color-muted);
    font-weight: 800;
}

.message-detail dd {
    margin: 0;
}

.message-body {
    border-top: 1px solid var(--color-line);
    padding-top: 22px;
    line-height: 1.7;
}

.integration-links {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    padding: 16px;
    background: #fafafa;
}

.integration-links h2 {
    width: 100%;
    margin: 0;
    font-size: 18px;
}

.menu-editor {
    display: grid;
    gap: 14px;
}

.menu-editor h2 {
    margin: 0;
    font-size: 18px;
}

.menu-row {
    display: grid;
    grid-template-columns: minmax(160px, 1.1fr) minmax(220px, 1.4fr) minmax(140px, 1fr) 90px 120px 110px 70px;
    gap: 10px;
    align-items: end;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    padding: 12px;
    background: #fff;
}

.menu-row label {
    margin: 0;
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    color: var(--color-muted);
    font-weight: 800;
}

.checkbox-label input {
    width: 18px;
    height: 18px;
}

.media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.media-card {
    position: relative;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}

.media-library-panel {
    margin-top: 18px;
}

.select-all-line {
    display: flex;
    align-items: center;
    gap: 8px;
    width: max-content;
    max-width: 100%;
    min-height: 34px;
    margin: 0 0 12px;
    color: var(--color-muted);
    font-weight: 800;
}

.select-all-line input {
    width: 18px;
    height: 18px;
}

.media-select {
    position: absolute;
    z-index: 2;
    top: 10px;
    left: 10px;
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border: 1px solid var(--color-line);
    border-radius: 6px;
    background: rgba(255, 255, 255, .92);
    box-shadow: 0 8px 18px rgba(0, 0, 0, .12);
}

.media-select input {
    width: 18px;
    height: 18px;
}

.media-card a {
    display: grid;
    gap: 8px;
    color: var(--color-text);
    padding: 10px;
    text-decoration: none;
}

.media-thumb {
    display: grid;
    place-items: center;
    aspect-ratio: 1;
    background: #f3f5f7;
}

.media-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.media-card strong {
    min-height: 40px;
    font-size: 13px;
    line-height: 1.4;
}

.media-card span:last-child {
    color: var(--color-muted);
    font-size: 12px;
}

.media-detail {
    display: grid;
    grid-template-columns: minmax(220px, 360px) minmax(0, 1fr);
    gap: 22px;
    align-items: start;
}

.media-detail img,
.media-preview img {
    width: 100%;
    max-height: 360px;
    object-fit: contain;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: #f3f5f7;
}

.media-detail dl {
    display: grid;
    grid-template-columns: 100px minmax(0, 1fr);
    gap: 10px 14px;
    margin: 0;
}

.media-detail dt {
    color: var(--color-muted);
    font-weight: 800;
}

.media-detail dd {
    min-width: 0;
    margin: 0;
    overflow-wrap: anywhere;
}

.media-preview {
    display: grid;
    grid-template-columns: 160px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
}

.media-preview img {
    max-height: 120px;
}

.gallery-preview {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(92px, 1fr));
    gap: 10px;
}

.gallery-preview a {
    display: grid;
    place-items: center;
    aspect-ratio: 1;
    border: 1px solid var(--color-line);
    border-radius: 8px;
    background: var(--color-soft);
    overflow: hidden;
}

.gallery-preview img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

@media (max-width: 640px) {
    .panel {
        padding: 24px;
    }

    h1 {
        font-size: 26px;
    }

    .admin-page {
        grid-template-columns: 1fr;
    }

    .sidebar {
        position: static;
        height: auto;
        border-right: 0;
        border-bottom: 1px solid var(--color-line);
    }

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

    .topbar {
        align-items: flex-start;
        flex-direction: column;
        margin: -28px -28px 22px;
    }

    .form-grid,
    .editor-section,
    .block-fields-grid {
        grid-template-columns: 1fr;
    }

    .content-report {
        grid-template-columns: 1fr;
    }

    .contact-form {
        grid-template-columns: 1fr;
    }

    .content-page-main iframe,
    .content-page-main embed,
    .content-page-main object,
    .contact-section iframe {
        width: 100% !important;
        max-width: 100% !important;
    }

    .commerce-grid,
    .order-admin-grid {
        grid-template-columns: 1fr;
    }

    .cart-line {
        grid-template-columns: 76px minmax(0, 1fr);
        gap: 12px;
    }

    .quantity-form,
    .cart-line-total,
    .remove-form {
        grid-column: 1 / -1;
    }

    .quantity-form {
        grid-template-columns: minmax(0, 1fr);
    }

    .cart-line-total {
        text-align: left;
    }

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

    .order-success {
        padding: 26px 18px;
    }

    .order-success-status-grid,
    .order-success-meta,
    .order-success-followup dl {
        grid-template-columns: 1fr;
    }

    .order-success-lines div {
        align-items: flex-start;
        flex-direction: column;
        gap: 4px;
    }

    .menu-row {
        grid-template-columns: 1fr;
    }

    .inline-search {
        width: 100%;
        flex-direction: column;
    }

    .inline-search input,
    .inline-search select {
        min-width: 0;
        width: 100%;
    }

    .list-toolbar,
    .bulk-toolbar,
    .pagination {
        align-items: stretch;
        flex-direction: column;
    }

    .media-detail,
    .media-preview {
        grid-template-columns: 1fr;
    }

    .span-2 {
        grid-column: span 1;
    }

    .message-detail dl {
        grid-template-columns: 1fr;
    }

    .site-footer {
        width: min(100% - 24px, 1200px);
    }

    .site-header-inner {
        width: min(100% - 24px, 1200px);
        justify-items: stretch;
        min-height: 0;
        padding: 14px 0;
    }

    .site-header-inner {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 12px;
    }

    .site-brand {
        min-width: 0;
    }

    .site-brand img {
        max-width: min(210px, 100%);
        max-height: 58px;
    }

    .mobile-nav-toggle {
        display: inline-flex;
        justify-self: end;
    }

    .js-ready .site-nav-bar {
        display: none;
    }

    .js-ready .site-header.is-mobile-nav-open .site-nav-bar {
        display: block;
    }

    .site-nav {
        width: min(100% - 24px, 1200px);
        display: grid;
        gap: 0;
        padding: 8px 0;
    }

    .site-nav-item {
        display: grid;
        min-height: 0;
        border-bottom: 1px solid var(--color-line);
    }

    .site-nav-link,
    .site-nav a {
        position: relative;
        padding: 12px 0;
    }

    .site-nav-link.is-active::after,
    .site-nav a.is-active::after {
        top: 12px;
        right: auto;
        bottom: 12px;
        left: -12px;
        width: 3px;
        height: auto;
    }

    .site-nav-item:last-of-type {
        border-bottom: 0;
    }

    .site-nav-dropdown {
        position: static;
        display: grid;
        min-width: 0;
        max-width: none;
        border: 0;
        border-left: 2px solid var(--color-line);
        border-radius: 0;
        box-shadow: none;
        padding: 0 0 10px 12px;
        opacity: 1;
        visibility: visible;
        transform: none;
    }

    .site-nav-mega {
        grid-template-columns: 1fr;
    }

    .site-nav-dropdown a {
        border-bottom: 0;
        padding: 8px 0;
    }

    .site-nav-dropdown-sub {
        margin-left: 4px;
    }

    .site-nav-mobile-tools {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        padding: 12px 0 6px;
    }

    .site-nav-mobile-tools a {
        justify-content: center;
        min-height: 38px;
        border: 1px solid var(--color-line);
        border-radius: 6px;
        padding: 0 8px;
        color: var(--color-text);
        font-size: 12px;
        text-align: center;
    }

    .site-nav-mobile-tools a::after {
        display: none;
    }

    .site-tools {
        grid-column: 1 / -1;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
    }

    .contact-chip {
        justify-content: center;
        min-height: 42px;
        padding: 0 8px;
        font-size: 11px;
        line-height: 1.25;
        text-align: center;
    }

    .site-search {
        grid-column: 1 / -1;
        width: 100%;
    }

    .site-search input {
        width: 100%;
    }

    .live-search-field {
        width: 100%;
    }

    .live-search-results {
        left: 0;
        right: auto;
        width: 100%;
    }

    .store-main {
        width: min(100% - 24px, 1200px);
        padding-top: 18px;
        padding-bottom: 78px;
    }

    .store-hero {
        min-height: auto;
        padding: 26px;
    }

    .home-design-strip {
        grid-template-columns: 1fr;
        justify-items: start;
        padding: 18px;
    }

    .home-design-strip strong {
        font-size: 18px;
    }

    .home-design-strip em {
        justify-self: stretch;
        text-align: center;
    }

    .home-hero {
        grid-template-columns: 1fr;
        min-height: auto;
        padding: 26px;
    }

    .home-hero-copy h1 {
        font-size: 30px;
    }

    .home-hero-visual {
        min-height: 240px;
    }

    .home-hero-card {
        position: static;
        width: 100%;
        margin-top: 12px;
    }

    .home-benefits,
    .home-category-showcase,
    .compact-category-grid,
    .home-promo-row,
    .home-category-mosaic,
    .home-brand-story,
    .home-order-system,
    .product-tab-panels,
    .detail-assurance-strip,
    .detail-highlight-grid,
    .detail-secondary-actions {
        grid-template-columns: 1fr;
    }

    .home-category-panel,
    .home-category-panel.is-large {
        grid-column: auto;
        grid-row: auto;
        min-height: 230px;
    }

    .home-category-panel.is-large strong,
    .home-brand-copy h2,
    .home-spec-card h2,
    .home-process-card h2 {
        font-size: 28px;
    }

    .home-brand-story,
    .home-spec-card,
    .home-process-card {
        padding: 24px;
    }

    .home-spec-card dl div {
        grid-template-columns: 1fr;
        gap: 3px;
    }

    .detail-assurance-strip span {
        border-right: 0;
        border-bottom: 1px solid var(--color-line);
    }

    .detail-assurance-strip span:last-child {
        border-bottom: 0;
    }

    .home-benefits div {
        border-right: 0;
        border-bottom: 1px solid var(--color-line);
    }

    .home-benefits div:last-child {
        border-bottom: 0;
    }

    .store-layout {
        grid-template-columns: 1fr;
    }

    .store-sidebar {
        position: static;
    }

    .store-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .store-header-tools,
    .store-sort,
    .filter-toggle {
        width: 100%;
    }

    .filter-toggle {
        display: inline-flex;
    }

    .store-sort {
        justify-content: space-between;
    }

    .js-ready .store-layout.has-mobile-filters .store-sidebar {
        display: none;
    }

    .js-ready .store-layout.has-mobile-filters.is-filter-open .store-sidebar {
        display: block;
    }

    .active-filter-bar {
        margin-top: 0;
    }

    .list-page-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .catalog-search-panel {
        grid-template-columns: 1fr;
    }

    .prepared-hero {
        grid-template-columns: 1fr;
        padding: 26px;
    }

    .prepared-hero h2 {
        font-size: 30px;
    }

    .prepared-cta > div {
        align-items: flex-start;
        flex-direction: column;
    }

    .shop-filters {
        grid-template-columns: 1fr;
    }

    .store-hero h1,
    .page-title h1 {
        font-size: 30px;
    }

    .category-grid,
    .product-grid,
    .product-detail,
    .compare-table,
    .site-footer {
        grid-template-columns: 1fr;
    }

    .footer-link-groups {
        grid-template-columns: 1fr;
    }

    .social-link-row {
        align-items: stretch;
        flex-direction: column;
    }

    .footer-social .social-link {
        width: 100%;
    }

    .detail-info {
        position: static;
        border-left: 0;
        padding: 0;
    }

    .detail-info h1 {
        font-size: 28px;
    }

    .product-meta-list div {
        grid-template-columns: 1fr;
        gap: 2px;
    }

    .compare-specs div {
        grid-template-columns: 1fr;
        gap: 2px;
    }

    .product-tab-panel {
        padding: 18px;
    }

    .status-history li {
        grid-template-columns: 1fr;
    }

    .status-history small {
        text-align: left;
        white-space: normal;
    }

    .section-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .mobile-contact-bar {
        display: grid;
    }

    body.has-mobile-sticky-cta {
        padding-bottom: calc(94px + var(--mobile-sticky-safe-area-bottom, 0px));
    }
}
