@import "variables-tKXh0by.css";
@import "../icons/fontawesome/all.min-LzHfJlU.css";

@layer reset, base, components;

/* ── Reset ──────────────────────────────────────────────────────────── */

@layer reset {

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

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

button, input, textarea, select {
    font: inherit;
    color: inherit;
}

} /* end @layer reset */

/* ── Utilities (unlayered — always win over layered component styles) ── */

[data-hidden], [hidden] {
    display: none;
}

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

/* ── Base (element defaults + layout helpers) ─────────────────────────── */

@layer base {

body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: var(--weight-normal);
    line-height: var(--leading-normal);
    color: var(--color-text);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: var(--weight-bold);
    line-height: var(--leading-tight);
}

a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.container {
    --container-max: var(--container-lg);

    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--space-4);
}

.container[data-size="narrow"] {
    --container-max: var(--container-md);
}

.container[data-size="wide"] {
    --container-max: var(--container-xl);
}

.grid {
    display: grid;
    gap: var(--space-6);
    grid-template-columns: repeat(var(--columns, 1), 1fr);
}

@media (min-width: 768px) {
    .grid[data-columns="2"] {
        --columns: 2;
    }
}

.stack {
    display: flex;
    flex-direction: column;
    gap: var(--gap, var(--space-4));
}

.page {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.page-main {
    flex: 1;
}

} /* end @layer base */

/* ── Navbar ──────────────────────────────────────────────────────────── */

@layer components {

.navbar {
    --navbar-bg: var(--color-primary);
    --navbar-text: var(--color-text-inverse);
    --navbar-hover: var(--color-primary-light);

    background-color: var(--navbar-bg);
    color: var(--navbar-text);
    box-shadow: var(--shadow-md);
}

.navbar-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 4rem;
    max-width: var(--container-xl);
    margin-inline: auto;
    padding-inline: var(--space-4);
}

.navbar-brand {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    letter-spacing: -0.025em;
}

.navbar-links {
    display: flex;
    align-items: center;
    gap: var(--space-6);
}

.navbar-links a:hover {
    color: var(--navbar-hover);
}

.navbar-locale {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-left: var(--space-4);
    padding-left: var(--space-4);
    border-left: 1px solid rgb(255 255 255 / 0.25);
}

.navbar-locale a {
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    text-transform: uppercase;
}

.navbar-mobile-toggle {
    display: none;
    background: none;
    border: none;
    color: inherit;
    cursor: pointer;
}

.navbar-mobile-menu {
    padding: 0 var(--space-4) var(--space-4);
}

.navbar-mobile-menu a {
    display: block;
    padding: var(--space-2) 0;
}

.navbar-mobile-menu a:hover {
    color: var(--navbar-hover);
}

@media (min-width: 768px) {
    .navbar-mobile-toggle {
        display: none;
    }

    .navbar-links {
        display: flex;
    }
}

@media (max-width: 767px) {
    .navbar-links {
        display: none;
    }

    .navbar-mobile-toggle {
        display: block;
    }
}

/* ── Page header (colored banner) ────────────────────────────────────── */

.page-header {
    --page-header-bg: var(--color-primary);
    --page-header-text: var(--color-text-inverse);

    background-color: var(--page-header-bg);
    color: var(--page-header-text);
    padding: var(--space-16) 0;
}

.page-header h1 {
    font-size: var(--text-4xl);
}

/* ── Section ─────────────────────────────────────────────────────────── */

.section {
    padding: var(--space-16) 0;
}

/* ── Hero ─────────────────────────────────────────────────────────────── */

.hero {
    --hero-bg: var(--color-neutral-900);
    --hero-text: var(--color-text-inverse);

    position: relative;
    height: 100vh;
    overflow: hidden;
    background-color: var(--hero-bg);
    color: var(--hero-text);
}

.hero-overlay {
    position: absolute;
    inset: 0;
}

.hero-gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 50%, black 60%);
}

.hero-content {
    position: relative;
    z-index: var(--z-dropdown);
    height: 100%;
    display: flex;
    align-items: flex-end;
}

.hero-text {
    width: 100%;
    padding: var(--space-8);
}

.hero-text h1 {
    font-size: var(--text-4xl);
    font-weight: var(--weight-light);
    line-height: var(--leading-tight);
}

.hero-text > p {
    margin-top: var(--space-4);
    font-size: var(--text-lg);
    opacity: 0.8;
    max-width: var(--container-sm);
}

@media (min-width: 768px) {
    .hero-gradient {
        background: linear-gradient(to right, transparent 50%, black 60%);
    }

    .hero-content {
        align-items: center;
        justify-content: flex-end;
    }

    .hero-text {
        width: 50%;
        padding: var(--space-16);
    }

    .hero-text h1 {
        font-size: var(--text-4xl);
    }
}

/* ── Contact info ────────────────────────────────────────────────────── */

.contact-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

.contact-info h3 {
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    color: var(--color-text);
    margin-bottom: var(--space-2);
}

.contact-info p {
    color: var(--color-text-muted);
}

/* ── Form ─────────────────────────────────────────────────────────────── */

.form-card {
    --form-card-bg: var(--color-bg-alt);
    --form-card-radius: var(--radius-lg);

    background-color: var(--form-card-bg);
    border-radius: var(--form-card-radius);
    padding: var(--space-8);
}

.form-group {
    /* No external margin — parent controls spacing via gap */
}

.form-label {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--color-text);
    margin-bottom: var(--space-1);
}

.form-label[data-variant="caps"] {
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.form-input {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    outline: none;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

.form-input[data-size="sm"] {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    font-weight: var(--weight-semibold);
    padding: var(--space-3) var(--space-6);
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}

.btn[data-variant="primary"] {
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
}

.btn[data-variant="primary"]:hover {
    background-color: var(--color-primary-dark);
}

.btn[data-variant="outline"] {
    background-color: transparent;
    border-color: var(--color-border-strong);
    color: var(--color-text);
}

.btn[data-variant="outline"]:hover {
    background-color: var(--color-bg-alt);
}

.btn[data-variant="ghost"] {
    background-color: transparent;
    border-color: transparent;
    color: var(--color-text-muted);
}

.btn[data-variant="ghost"]:hover {
    background-color: var(--color-bg-alt);
    color: var(--color-text);
}

.btn[data-size="sm"] {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
}

.btn[data-full] {
    width: 100%;
}

/* ── Badge (status pill) ─────────────────────────────────────────────── */

.badge {
    display: inline-flex;
    align-items: center;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    white-space: nowrap;
    background-color: var(--color-surface-alt);
    color: var(--color-text-muted);
}

.badge[data-variant="success"] {
    background-color: color-mix(in srgb, var(--color-success) 15%, transparent);
    color: color-mix(in srgb, var(--color-success) 70%, #000);
}

.badge[data-variant="warning"] {
    background-color: color-mix(in srgb, var(--color-warning) 15%, transparent);
    color: color-mix(in srgb, var(--color-warning) 70%, #000);
}

.badge[data-variant="info"] {
    background-color: color-mix(in srgb, var(--color-info) 15%, transparent);
    color: color-mix(in srgb, var(--color-info) 70%, #000);
}

.badge[data-variant="secondary"] {
    background-color: color-mix(in srgb, var(--color-secondary) 15%, transparent);
    color: var(--color-secondary-dark);
}

/* ── Avatar (circular initial / image badge) ─────────────────────────── */

.avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: var(--radius-full);
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    flex-shrink: 0;
}

/* ── Shop header (logo + customer meta + user + logout) ──────────────── */

.shop-header {
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    background-color: var(--color-bg);
    border-block-end: 1px solid var(--color-border);
}

.shop-header-inner {
    display: flex;
    align-items: center;
    gap: var(--space-8);
    padding: var(--space-2) var(--space-6);
}

.shop-header-logo {
    min-width: 6rem;
}

.shop-header-logo img {
    max-height: 2rem;
    width: auto;
}

.shop-header-meta {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.shop-header-greeting {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.shop-header-greeting strong {
    color: var(--color-text);
    font-weight: var(--weight-semibold);
}

.shop-header-divider {
    display: block;
    width: 1px;
    height: 1.25rem;
    background-color: var(--color-border-strong);
}

.shop-header-actions {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-inline-start: auto;
}

.shop-header-cart {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-2);
    border-radius: var(--radius-md);
    color: var(--color-text);
    font-size: var(--text-xl);
    transition: background-color var(--transition-fast);
}

.shop-header-cart:hover {
    background-color: var(--color-bg-alt);
}

.shop-header-cart-count {
    position: absolute;
    inset-block-start: 0;
    inset-inline-end: 0;
    transform: translate(30%, 8%);
    min-width: 1.25rem;
    height: 1.25rem;
    padding-inline: var(--space-1);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    line-height: 1;
}

.shop-header-user {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.shop-header-user-info {
    line-height: var(--leading-tight);
}

.shop-header-user-name {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
}

.shop-header-user-company {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.shop-header-toggle {
    display: none;
    padding: var(--space-2);
    background: none;
    border: none;
    color: inherit;
    cursor: pointer;
    font-size: var(--text-xl);
}

.shop-header-mobile,
.shop-header-backdrop {
    display: none;
}

@media (max-width: 1300px) {
    .shop-header-meta {
        display: none;
    }
}

@media (max-width: 800px) {
    .shop-header-user-info,
    .shop-header-logout {
        display: none;
    }

    .shop-header-toggle {
        display: inline-flex;
    }

    .shop-header-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        background-color: rgb(0 0 0 / 0.5);
        opacity: 0;
        pointer-events: none;
        transition: opacity var(--transition-normal);
        z-index: var(--z-modal);
    }

    .shop-header[data-open] .shop-header-backdrop {
        opacity: 1;
        pointer-events: auto;
    }

    .shop-header-mobile {
        display: flex;
        flex-direction: column;
        gap: var(--space-3);
        position: fixed;
        inset-block: 0;
        inset-inline-end: 0;
        width: min(20rem, 80vw);
        padding: var(--space-6);
        padding-top: var(--space-3);
        background-color: var(--color-bg);
        box-shadow: var(--shadow-xl);
        transform: translateX(100%);
        transition: transform var(--transition-normal);
        z-index: calc(var(--z-modal) + 1);
    }

    .shop-header[data-open] .shop-header-mobile {
        transform: translateX(0);
    }

    .shop-header-mobile-close {
        align-self: flex-end;
        padding-right: var(--space-2);
        background: none;
        border: none;
        color: var(--color-text);
        cursor: pointer;
        font-size: var(--text-xl);
    }

    .shop-header-inner {
        gap: var(--space-3);
    } 
}

/* ── Shop menu (primary-colored search + nav bar) ────────────────────── */

.shop-menu {
    --menu-item-bg-hover: rgb(255 255 255 / 0.12);
    --menu-item-bg-active: rgb(0 0 0 / 0.18);
    --menu-item-fg-active: inherit;

    background-color: var(--color-primary);
    color: var(--color-text-inverse);
    box-shadow: var(--shadow-md);
}

.shop-menu-inner {
    display: flex;
    align-items: stretch;
    gap: var(--space-4);
    padding-inline: var(--space-6);
}

.shop-menu-search {
    display: flex;
    align-items: center;
    flex: 1;
    max-width: 28rem;
    padding-block: 0;
}

.shop-menu-search .input-group {
    width: 100%;
}

.shop-menu-search .input-group-icon {
    color: var(--color-text-inverse);
}

.shop-menu-search input {
    background-color: var(--color-primary-light);
    border: 1px solid rgba(255,255,255,.2);
    border-top: none;
    border-bottom: none;
    color: var(--color-text-inverse);
    border-radius: 0;
    padding: .8em var(--space-3);
    font-size: var(--text-sm);
}

.shop-menu-search input::placeholder {
    opacity: .8;
    color: var(--color-text-inverse);
}

.shop-menu-items {
    display: flex;
    align-items: stretch;
    list-style: none;
}

@media (max-width: 800px) {
    
    .shop-menu-search {
        max-width: unset;
    }

    
    .shop-menu-items {
        display: none;
    }
}

/* ── Menu item (used in shop-menu bar and mobile drawer) ─────────────── */

.shop-menu-item {
    --menu-item-bg: transparent;
    --menu-item-fg: inherit;
    --menu-item-bg-hover: var(--color-primary-light);
    --menu-item-bg-active: var(--color-primary-light);
    --menu-item-fg-active: var(--color-primary);

    display: flex;
    height: 100%;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-5);
    color: var(--menu-item-fg);
    background-color: var(--menu-item-bg);
    font-weight: var(--weight-medium);
    font-size: var(--text-sm);
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.shop-menu-item:hover {
    --menu-item-bg: var(--menu-item-bg-hover);
}

.shop-menu-item[data-active] {
    --menu-item-bg: var(--menu-item-bg-active);
}

/* ── Mobile drawer menu list ─────────────────────────────────────────── */

.shop-header-mobile-items {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.shop-header-mobile-items .shop-menu-item {
    padding-inline: var(--space-3);
    border-radius: var(--radius-md);
}

/* ── Content sections (imprint, about prose) ─────────────────────────── */

.content-section > div > h2 {
    font-size: var(--text-xl);
    font-weight: var(--weight-semibold);
    color: var(--color-text);
    margin-bottom: var(--space-2);
}

.content-section p {
    color: var(--color-text-muted);
}

.prose {
    font-size: var(--text-xl);
    color: var(--color-text-muted);
    line-height: var(--leading-relaxed);
}

/* ── Footer ──────────────────────────────────────────────────────────── */

.footer {
    --footer-bg: var(--color-neutral-800);
    --footer-text: var(--color-neutral-300);
    --footer-hover: var(--color-text-inverse);

    background-color: var(--footer-bg);
    color: var(--footer-text);
}

.footer-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
    max-width: var(--container-xl);
    margin-inline: auto;
    padding: var(--space-8) var(--space-4);
}

.footer-copy {
    font-size: var(--text-sm);
}

.footer-links {
    display: flex;
    gap: var(--space-6);
}

.footer-links a {
    font-size: var(--text-sm);
    transition: color var(--transition-fast);
}

.footer-links a:hover {
    color: var(--footer-hover);
}

@media (min-width: 768px) {
    .footer-inner {
        flex-direction: row;
        justify-content: space-between;
    }
}

/* ── Stat card (metric display) ──────────────────────────────────────── */

.stat-card {
    --stat-card-bg: var(--color-surface);
    --stat-card-border: var(--color-border);

    background: var(--stat-card-bg);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid var(--stat-card-border);
}

.stat-card-label {
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-faint);
    font-weight: var(--weight-bold);
    margin-block-end: var(--space-3);
}

.stat-card-value {
    font-size: var(--text-2xl);
    font-weight: var(--weight-bold);
    letter-spacing: -0.03em;
}

.stat-card-sub {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-block-start: var(--space-1);
}

/* ── Section label (standalone section headline) ─────────────────────── */

.section-label {
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-faint);
    font-weight: var(--weight-bold);
    margin-block-end: var(--space-4);
}

/* ── Info card (surface card with labeled header) ────────────────────── */

.info-card {
    --info-card-bg: var(--color-surface);
    --info-card-border: var(--color-border);

    background: var(--info-card-bg);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid var(--info-card-border);
    margin-block-end: var(--space-6);
}

.info-card[data-variant="danger"] {
    --info-card-border: color-mix(in srgb, var(--color-danger) 20%, transparent);
}

.info-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-block-end: var(--space-5);
    padding-block-end: var(--space-4);
    border-block-end: 1px solid var(--color-border);
}

.info-card-header h3 {
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: var(--weight-bold);
}

.info-card-header h3[data-variant="danger"] {
    color: var(--color-danger);
}

.info-card-body {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-block-end: var(--space-4);
}

.info-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-block-start: var(--space-5);
    padding-block-start: var(--space-5);
    border-block-start: 1px solid var(--color-border);
}

/* ── Detail row (key-value pair in a dl) ─────────────────────────────── */

.detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-block: var(--space-3);
    border-block-end: 1px solid var(--color-border);
    font-size: var(--text-sm);
}

.detail-row:last-child {
    border-block-end: none;
    padding-block-end: 0;
}

.detail-row-label {
    color: var(--color-text-muted);
}

.detail-row-value {
    font-weight: var(--weight-medium);
    text-align: end;
}

/* ── Auth pages (login, 2FA verify) ──────────────────────────────────── */

.auth-page {
    --auth-bg: var(--color-bg-alt);

    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background-color: var(--auth-bg);
}

.auth-wrapper {
    width: 100%;
    max-width: 28rem;
    padding: var(--space-4);
}

.auth-wrapper > .auth-footer {
    margin-top: var(--space-4);
}

.auth-card {
    --auth-card-bg: var(--color-surface);

    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    background-color: var(--auth-card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    padding: var(--space-8);
}

.auth-header {
    text-align: center;
}

.auth-header[data-align="start"] {
    text-align: start;
}

.auth-header h1 {
    font-size: var(--text-3xl);
    color: var(--color-text);
}

.auth-header p {
    color: var(--color-text-muted);
    margin-top: var(--space-2);
}

.auth-footer {
    text-align: center;
    color: var(--color-text-faint);
    font-size: var(--text-sm);
}

.auth-description {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

/* ── Auth split layout (brand aside + form panel; aside hidden on mobile) ─ */

.auth-split {
    display: grid;
    grid-template-columns: 1fr;
    min-height: 100vh;
}

.auth-aside {
    display: none;
    position: relative;
    isolation: isolate;
    overflow: hidden;
    background-color: var(--color-neutral-800);
    color: #ffffff;
}

.auth-aside-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
}

.auth-brand {
    position: absolute;
    inset-block-end: 0;
    inset-inline: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding: var(--space-12);
    background: linear-gradient(to top, rgb(0 0 0 / 0.7), transparent);
}

.auth-brand-eyebrow {
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    opacity: 0.85;
}

.auth-brand-title {
    font-size: var(--text-3xl);
    font-weight: var(--weight-bold);
    letter-spacing: -0.02em;
}

.auth-brand-tagline {
    font-size: var(--text-sm);
    opacity: 0.85;
}

.auth-main {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: var(--space-8);
    background-color: var(--color-bg);
    color: var(--color-text);
    border-block-start: 6px solid var(--color-primary);
}

.auth-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    width: 100%;
    max-width: 26rem;
    margin-inline: auto;
}

.auth-content > .auth-logo {
    margin-bottom: 1.9rem;
}

.auth-logo {
    max-height: 2.5rem;
    width: auto;
}


.auth-link-center {
    text-align: center;
    font-size: var(--text-sm);
}

@media (min-width: 768px) {
    .auth-split {
        grid-template-columns: 3fr 2fr;
    }

    .auth-aside {
        display: block;
    }
}

/* ── Input group (form input with leading icon / trailing action) ─────── */

.input-group {
    position: relative;
    display: flex;
    align-items: center;
}

.input-group-icon {
    position: absolute;
    inset-inline-start: var(--space-4);
    color: var(--color-text-muted);
    pointer-events: none;
}

.input-group-action {
    position: absolute;
    inset-inline-end: var(--space-2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-2);
    background: none;
    border: none;
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    cursor: pointer;
    transition: color var(--transition-fast);
}

.input-group-action:hover {
    color: var(--color-text);
}

.input-group:has(> .input-group-icon) > .form-input {
    padding-inline-start: var(--space-10);
}

.input-group:has(> .input-group-action) > .form-input {
    padding-inline-end: var(--space-10);
}

.alert[data-type="error"] {
    background-color: #fef2f2;
    border: 1px solid #fecaca;
    color: var(--color-danger);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
}

.text-hint {
    font-size: var(--text-xs);
    color: var(--color-text-faint);
    margin-top: var(--space-1);
}

.text-link-muted {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    transition: color var(--transition-fast);
}

.text-link-muted:hover {
    color: var(--color-primary);
}

/* ── Shop page layout (sidebar + main content) ───────────────────────── */

.shop-page {
    --shop-sidebar-width: 16rem;

    display: grid;
    grid-template-columns: 1fr;
}

/* ── Shop sidebar (filter column, sticky on desktop) ─────────────────── */

.shop-sidebar {
    display: none;
    flex-direction: column;
    gap: var(--space-6);
    background-color: var(--color-bg);
    padding: var(--space-6);
    border-block-end: 1px solid var(--color-border);
}

.shop-page[data-filters-open] .shop-sidebar {
    display: flex;
}

.shop-filter-toggle {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background-color: var(--color-surface);
    color: var(--color-text);
    font-size: var(--text-sm);
    cursor: pointer;
    transition: color var(--transition-fast), border-color var(--transition-fast);
}

.shop-filter-toggle:hover {
    color: var(--color-text);
    border-color: var(--color-border-strong);
}

.shop-page[data-filters-open] .shop-filter-toggle {
    color: var(--color-primary);
    border-color: var(--color-primary);
}

@media (min-width: 900px) {
    .shop-page {
        grid-template-columns: var(--shop-sidebar-width) 1fr;
    }

    .shop-sidebar {
        display: flex;
        border-block-end: none;
        position: sticky;
        inset-block-start: var(--shop-header-h, 0px);
        align-self: start;
        max-height: calc(100vh - var(--shop-header-h, 0px));
        overflow-y: auto;
    }

    .shop-filter-toggle {
        display: none;
    }
}

.shop-filter {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.shop-filter-label {
    font-size: var(--text-xs);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-faint);
}

/* ── Brand filter list ───────────────────────────────────────────────── */

.brand-filter {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.brand-filter-item {
    --brand-bg: transparent;
    --brand-fg: var(--color-text);

    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    background-color: var(--brand-bg);
    color: var(--brand-fg);
    font-size: var(--text-sm);
    transition: background-color var(--transition-fast);
}

.brand-filter-item:hover {
    --brand-bg: var(--color-bg-alt);
}

.brand-filter-item[data-active] {
    --brand-bg: var(--color-surface-alt);
    font-weight: var(--weight-bold);
}

.brand-filter-name {
    font-weight: inherit;
}

.brand-filter-count {
    flex-shrink: 0;
    min-width: 1.5rem;
    padding-inline: var(--space-2);
    text-align: center;
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    color: var(--color-text-muted);
}

/* ── Price filter (native range slider + min/max labels) ─────────────── */

.price-filter-range {
    width: 100%;
    accent-color: var(--color-primary);
    cursor: pointer;
}

.price-filter-labels {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.price-filter-labels :last-child {
    color: var(--color-primary);
    font-weight: var(--weight-semibold);
}

/* ── Shop results header (count + sort dropdown) ─────────────────────── */

.shop-main {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    background-color: var(--color-bg-alt);
    padding: var(--space-6);
    min-height: 100vh;
}

@media (min-width: 900px) {
    .shop-main {
        padding-inline: var(--space-8);
    }
}

.shop-results-header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.shop-results-count {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    flex: 1;
}

.shop-results-controls {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.shop-sort {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-muted);
}

.shop-sort-select {
    padding: var(--space-2) var(--space-8) var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background-color: var(--color-surface);
    color: var(--color-text);
    font-size: var(--text-sm);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path fill='none' stroke='%2371717a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M3 4.5l3 3 3-3'/></svg>");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    background-size: 0.75rem;
}

.shop-sort-select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

/* ── Product grid (auto-fill responsive) ─────────────────────────────── */

.product-grid {
    list-style: none;
    display: grid;
    gap: var(--space-5);
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 16rem), 1fr));
}

/* ── Product card ────────────────────────────────────────────────────── */

.product-card {
    --product-card-bg: var(--color-surface);
    --product-card-border: var(--color-border);
    --product-card-radius: var(--radius-md);

    display: flex;
    flex-direction: column;
    height: 100%;
    background-color: var(--product-card-bg);
    border: 1px solid var(--product-card-border);
    border-radius: var(--product-card-radius);
    overflow: hidden;
    transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.product-card:hover {
    border-color: var(--color-border-strong);
    box-shadow: var(--shadow-md);
}

.product-card-link {
    display: flex;
    flex-direction: column;
    flex: 1;
    color: inherit;
}

.product-card-link:hover .product-card-title {
    color: var(--color-primary);
}

.product-card-image {
    aspect-ratio: 4 / 3;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-bg);
    color: var(--color-text-faint);
    font-size: var(--text-3xl);
    border-block-end: 1px solid var(--product-card-border);
}

.product-card-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: var(--space-4);
}

.product-card-body {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-4);
    flex: 1;
}

.product-card-meta {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    letter-spacing: 0.02em;
}

.product-card-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    flex: 1;
}

.product-card-title {
    flex: 1;
    min-width: 0;
    font-size: var(--text-sm);
    font-weight: var(--weight-bold);
    line-height: var(--leading-tight);
    color: var(--color-text);
    transition: color var(--transition-fast);
}

.product-card-price {
    flex-shrink: 0;
    text-align: end;
    line-height: var(--leading-tight);
}

.product-card-price strong {
    display: block;
    font-size: var(--text-base);
    color: var(--color-text);
    font-weight: var(--weight-bold);
}

.product-card-unit {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.product-card-actions {
    display: flex;
    align-items: stretch;
    gap: var(--space-2);
    padding: 0 var(--space-4) var(--space-4);
}

.product-card-actions .btn {
    flex: 1;
    padding-inline: var(--space-3);
    font-size: var(--text-sm);
}

/* ── Shop grid: infinite scroll spinner + sentinel ───────────────────── */

.shop-grid-sentinel {
    height: 1px;
}

.shop-grid-spinner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding-block: var(--space-6);
}

.shop-grid-spinner-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background-color: var(--color-primary);
    animation: shop-grid-bounce 1.2s ease-in-out infinite both;
}

.shop-grid-spinner-dot:nth-child(2) { animation-delay: 0.16s; }
.shop-grid-spinner-dot:nth-child(3) { animation-delay: 0.32s; }

@keyframes shop-grid-bounce {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40%           { transform: scale(1);   opacity: 1; }
}

/* ── Quantity stepper (number input with native spin buttons) ────────── */

.qty-stepper {
    display: inline-flex;
    align-items: stretch;
    flex-shrink: 0;
}

.qty-stepper input {
    width: 3.5rem;
    padding: var(--space-2) var(--space-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    text-align: start;
    font-size: var(--text-sm);
    background-color: var(--color-surface);
    color: var(--color-text);
}

.qty-stepper input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

/* Qty stepper — explicit -/+ buttons flanking the input. */
.qty-stepper[data-variant="buttons"] {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    background-color: var(--color-surface);
}

.qty-stepper[data-variant="buttons"] button {
    width: 2.5rem;
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: var(--text-xl);
    line-height: 1;
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.qty-stepper[data-variant="buttons"] button:hover {
    background-color: var(--color-bg-alt);
    color: var(--color-text);
}

.qty-stepper[data-variant="buttons"] input {
    width: 3.5rem;
    height: 100%;
    padding-block: 0;
    border: none;
    border-radius: 0;
    text-align: center;
    appearance: textfield;
    -moz-appearance: textfield;
}

.qty-stepper[data-variant="buttons"] input::-webkit-outer-spin-button,
.qty-stepper[data-variant="buttons"] input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.qty-stepper[data-variant="buttons"] input:focus {
    box-shadow: none;
}

/* ── Article detail page ─────────────────────────────────────────────── */

.article-page {
    background-color: var(--color-bg-alt);
    padding: var(--space-6);
    min-height: 100vh;
}

.article-back {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    align-self: flex-start;
    font-size: var(--text-sm);
    color: var(--color-text);
}

.article-back:hover {
    color: var(--color-primary);
}

/* ── Article card (white surface, used for hero + specs) ─────────────── */

.article-card {
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
}

/* ── Article hero (image + info two-column) ──────────────────────────── */

.article-hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
    align-items: stretch;
}

@media (min-width: 800px) {
    .article-hero {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-10);
    }
}

.article-hero-image {
    aspect-ratio: 4 / 3;
    max-height: 24rem;
    width: 100%;
    max-width: calc(24rem * 4 / 3);
    justify-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-faint);
    font-size: var(--text-4xl);
}

.article-hero-image img {
    max-width: 60%;
    max-height: 100%;
    object-fit: contain;
}

.article-hero-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.article-meta {
    font-size: var(--text-sm);
    color: var(--color-text-faint);
}

.article-title {
    font-size: var(--text-3xl);
    font-weight: var(--weight-bold);
    color: var(--color-text);
}

.article-description {
    color: var(--color-text-muted);
    line-height: var(--leading-relaxed);
}

.article-stock {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-primary);
    font-weight: var(--weight-medium);
}

.article-price {
    display: flex;
    align-items: baseline;
    gap: var(--space-2);
    margin-block-start: var(--space-2);
    transition: opacity var(--transition-fast);
}

[data-price-loading] .article-price {
    opacity: 0.5;
}

.article-price strong {
    font-size: var(--text-3xl);
    color: var(--color-text);
    font-weight: var(--weight-bold);
}

.article-price > span {
    color: var(--color-text-muted);
}

.article-price-total {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-block-start: var(--space-1);

    & strong {
        color: var(--color-text);
        font-weight: var(--weight-semibold);
    }
}

.article-vat-note {
    font-size: var(--text-xs);
    color: var(--color-text-faint);
}

.article-actions {
    display: flex;
    align-items: stretch;
    gap: var(--space-3);
    margin-block-start: auto;
    padding-block-start: var(--space-4);
}

.article-actions .btn {
    flex: 1;
}

/* ── Article specs (technical details grid) ──────────────────────────── */

.article-specs-title {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    color: var(--color-text);
    margin-block-end: var(--space-6);
}

.article-specs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
    gap: var(--space-6) var(--space-8);
}

.article-specs-item {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.article-specs-label {
    font-size: var(--text-xs);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-faint);
}

.article-specs-value {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-text);
}

/* ── Shop content inner (max-width constraint, shared across shop pages) */

.shop-page-inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    max-width: var(--container-xl);
}

/* ── Cart page ───────────────────────────────────────────────────────── */

.cart-page {
    background-color: var(--color-bg-alt);
    padding: var(--space-6);
    min-height: 100vh;
}

.cart-heading {
    font-size: var(--text-2xl);
    font-weight: var(--weight-bold);
    color: var(--color-text);
}

/* The items card has no padding so the table header bg can run edge-to-edge. */
.cart-items-card {
    padding: 0;
    overflow-x: auto;
}

/* Horizontal-scroll wrapper for tables that overflow on narrow viewports. */
.table-scroll {
    overflow-x: auto;
}

/* ── Cart table ──────────────────────────────────────────────────────── */

.cart-table {
    width: 100%;
    border-collapse: collapse;
}

.cart-table thead {
    background-color: var(--color-bg-alt);
}

.cart-table th {
    font-size: var(--text-xs);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-faint);
    text-align: start;
    padding: var(--space-4);
}

.cart-table td {
    padding: var(--space-4);
    border-block-start: 1px solid var(--color-border);
    vertical-align: middle;
    font-size: var(--text-sm);
}

.cart-table th[data-align="end"],
.cart-table td[data-align="end"] {
    text-align: end;
}

.cart-table th[data-align="center"],
.cart-table td[data-align="center"] {
    text-align: center;
}

.cart-table th:first-child,
.cart-table td:first-child {
    padding-inline-start: var(--space-6);
}

.cart-table th:last-child,
.cart-table td:last-child {
    padding-inline-end: var(--space-6);
}

/* Product cell (thumb + meta + name, links to article detail). */
.cart-product {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    color: inherit;
}

.cart-product:hover .cart-product-name {
    color: var(--color-primary);
}

.cart-thumb {
    flex-shrink: 0;
    width: 4rem;
    height: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background-color: var(--color-bg);
    color: var(--color-text-faint);
    overflow: hidden;
}

.cart-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: var(--space-1);
}

.cart-product-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.cart-product-meta {
    font-size: var(--text-xs);
    color: var(--color-text-faint);
    letter-spacing: 0.02em;
}

.cart-product-name {
    font-size: var(--text-sm);
    font-weight: var(--weight-bold);
    color: var(--color-text);
}

/* ── Cart delete (trash icon button) ─────────────────────────────────── */

.cart-delete {
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-2);
    border-radius: var(--radius-sm);
    color: var(--color-text-faint);
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.cart-delete:hover {
    background-color: var(--color-bg-alt);
    color: var(--color-danger);
}

/* ── Cart order type (fieldset with radio "buttons") ─────────────────── */

.cart-order-type {
    border: none;
    padding: 0;
}

.cart-order-type legend {
    display: block;
    margin-block-end: var(--space-4);
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
}

.cart-order-type-options {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
}

@media (min-width: 600px) {
    .cart-order-type-options {
        grid-template-columns: 1fr 1fr;
    }
}

.cart-order-type-option {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-3) var(--space-6);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    color: var(--color-text-muted);
    cursor: pointer;
    user-select: none;
    transition: border-color var(--transition-fast), background-color var(--transition-fast), color var(--transition-fast);
}

.cart-order-type-option:hover {
    border-color: var(--color-primary);
    color: var(--color-text);
}

.cart-order-type-option input {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.cart-order-type-option:has(input:checked) {
    border-color: var(--color-primary);
    background-color: color-mix(in srgb, var(--color-primary) 8%, transparent);
    color: var(--color-primary);
}

.cart-order-type-option:focus-within {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

/* ── Cart footer (note + summary side-by-side at bottom) ─────────────── */

.cart-footer {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
    align-items: start;
}

@media (min-width: 800px) {
    .cart-footer {
        grid-template-columns: 1fr minmax(20rem, 26rem);
    }
}

.cart-note-heading {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-text);
    margin-block-end: var(--space-2);
}

.cart-note-text {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.cart-summary {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.cart-summary-list {
    display: flex;
    flex-direction: column;
}

.cart-summary-list > div {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: var(--space-3);
    padding-block: var(--space-3);
    font-size: var(--text-sm);
}

.cart-summary-list dt {
    color: var(--color-text-muted);
}

.cart-summary-list dd {
    color: var(--color-text);
    font-weight: var(--weight-medium);
}

.cart-summary-list > div[data-variant="total"] {
    border-block-start: 1px solid var(--color-border);
}

.cart-summary-list > div[data-variant="total"] dt,
.cart-summary-list > div[data-variant="total"] dd {
    font-size: var(--text-lg);
    font-weight: var(--weight-bold);
    color: var(--color-text);
}

.cart-summary-actions {
    display: flex;
    gap: var(--space-3);
    justify-content: flex-end;
}

/* ── Orders page ─────────────────────────────────────────────────────── */

.orders-page {
    background-color: var(--color-bg-alt);
    padding: var(--space-6);
    min-height: 100vh;
}

.orders-vat-note {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

/* ── Order card ───────────────────────────────────────────────────────── */

.order-card {
    padding: 0;
    overflow: clip;
}

.order-card-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--space-6);
    padding: var(--space-5) var(--space-6);
}

.order-card-main {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4) var(--space-6);
}

.order-meta {
    display: flex;
    gap: var(--space-3) var(--space-8);
    flex-wrap: wrap;
    align-items: start;
}

.order-meta-item dt {
    font-size: var(--text-xs);
    color: var(--color-text-faint);
    margin-block-end: var(--space-1);
}

.order-meta-item dd {
    font-size: var(--text-sm);
    font-weight: var(--weight-bold);
    color: var(--color-text);
}

.order-card-controls {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.order-badges {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.order-toggle i {
    transition: transform var(--transition-fast);
}

.order-card[data-open] .order-toggle i {
    transform: rotate(180deg);
}

/* ── Order items table (shown when card is expanded) ─────────────────── */

.order-card-items {
    display: none;
    border-block-start: 1px solid var(--color-border);
    overflow-x: auto;
}

.order-card[data-open] .order-card-items {
    display: block;
}

.order-items-table {
    width: 100%;
    border-collapse: collapse;
}

.order-items-table thead {
    background-color: var(--color-bg-alt);
}

.order-items-table th {
    font-size: var(--text-xs);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-faint);
    text-align: start;
    padding: var(--space-3) var(--space-4);
    white-space: nowrap;
}

.order-items-table td {
    padding: var(--space-3) var(--space-4);
    border-block-start: 1px solid var(--color-border);
    vertical-align: middle;
    font-size: var(--text-sm);
    white-space: nowrap;
}

.order-items-table th[data-align="end"],
.order-items-table td[data-align="end"] {
    text-align: end;
}

.order-items-table th:first-child,
.order-items-table td:first-child {
    padding-inline-start: var(--space-6);
    width: 100%;
}

.order-items-table td:first-child {
    max-width: 0;
    min-width: 12rem;
    overflow: hidden;
}

.order-items-table th:last-child,
.order-items-table td:last-child {
    padding-inline-end: var(--space-6);
}

.order-item-product {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    min-width: 0;
}

.order-thumb {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background-color: var(--color-bg);
    color: var(--color-text-faint);
    font-size: var(--text-sm);
    overflow: hidden;
}

.order-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: var(--space-1);
}

.order-item-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    min-width: 0;
    overflow: hidden;
}

.order-item-no {
    font-size: var(--text-xs);
    color: var(--color-text-faint);
}

.order-item-name {
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--color-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Quick entry page ────────────────────────────────────────────────── */

.quick-entry-page {
    background-color: var(--color-bg-alt);
    padding: var(--space-6);
    min-height: 100vh;
}

.quick-entry-page form {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

/* ── Shop page header (icon + title + subtitle) ───────────────────────── */

.shop-page-header {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.shop-page-icon {
    --shop-page-icon-bg: var(--color-secondary-dark);

    flex-shrink: 0;
    width: 3.5rem;
    height: 3.5rem;
    border-radius: var(--radius-md);
    background-color: var(--shop-page-icon-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-inverse);
    font-size: var(--text-xl);
}

.shop-page-header-title {
    font-size: var(--text-2xl);
    font-weight: var(--weight-bold);
    line-height: var(--leading-tight);
}

.shop-page-header-subtitle {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-block-start: var(--space-1);
}

/* ── Quick entry card (edge-to-edge table + add-row footer) ───────────── */

.quick-entry-card {
    padding: 0;
    overflow: hidden;
}

.quick-entry-table {
    width: 100%;
    border-collapse: collapse;
}

.quick-entry-table thead {
    background-color: var(--color-bg-alt);
}

.quick-entry-table th {
    font-size: var(--text-xs);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-faint);
    text-align: start;
    padding: var(--space-4);
    white-space: nowrap;
}

.quick-entry-table td {
    padding: var(--space-3) var(--space-4);
    border-block-start: 1px solid var(--color-border);
    vertical-align: middle;
    font-size: var(--text-sm);
}

.quick-entry-table th[data-align="end"],
.quick-entry-table td[data-align="end"] {
    text-align: end;
}

.quick-entry-table th:first-child,
.quick-entry-table td:first-child {
    padding-inline-start: var(--space-6);
    width: 14rem;
}

.quick-entry-table th:last-child,
.quick-entry-table td:last-child {
    padding-inline-end: var(--space-6);
    width: 3rem;
}

.quick-entry-table th:nth-child(3),
.quick-entry-table td:nth-child(3) {
    width: 8rem;
}

.quick-entry-table th:nth-child(4),
.quick-entry-table td:nth-child(4) {
    width: 9rem;
}

.quick-entry-article-no {
    width: 100%;
    font-size: var(--text-sm);
}

.quick-entry-description[data-empty] {
    color: var(--color-text-faint);
    font-style: italic;
}

.quick-entry-price[data-empty] {
    color: var(--color-text-faint);
}

.quick-entry-qty {
    width: 5.5rem;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    font-family: inherit;
    text-align: end;
    background-color: var(--color-surface);
    color: var(--color-text);
}

.quick-entry-qty:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: 1px;
    border-color: transparent;
}

.quick-entry-add {
    padding: var(--space-3) var(--space-6);
    border-block-start: 1px solid var(--color-border);
}

.quick-entry-add-row {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--color-secondary);
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-1) 0;
    transition: color var(--transition-fast);
}

.quick-entry-add-row:hover {
    color: var(--color-secondary-dark);
}

/* ── Quick entry footer (status + submit) ────────────────────────────── */

.quick-entry-footer {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.quick-entry-footer .btn {
    margin-inline-start: auto;
}

.quick-entry-status {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

/* ── Add-to-cart button animation ────────────────────────────────────── */

.atc-btn {
    position: relative;
    overflow: hidden;
}

.atc-idle {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.atc-success {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0.5);
    pointer-events: none;
    transition: opacity 0.22s ease 0.12s, transform 0.22s ease 0.12s;
}

.atc-btn[data-atc-success] .atc-idle {
    opacity: 0;
    transform: scale(0.75);
}

.atc-btn[data-atc-success] .atc-success {
    opacity: 1;
    transform: scale(1);
}

.atc-btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        105deg,
        transparent 20%,
        rgb(255 255 255 / 0.22) 50%,
        transparent 80%
    );
    background-size: 250% 100%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.35s ease;
}

.atc-btn[data-atc-success]::after {
    opacity: 1;
    animation: atc-shimmer 0.65s ease-out both;
}

@keyframes atc-shimmer {
    from { background-position: 160% 0; }
    to   { background-position: -60% 0; }
}

} /* end @layer components */
