:root {
    --theme-bg-1: #06070b;
    --theme-bg-2: #0e1018;
    --theme-panel: rgba(16, 18, 26, 0.72);
    --theme-text: #e4eaf2;
    --theme-muted: #8a9cb8;
    --theme-line: rgba(255, 255, 255, 0.07);
    --theme-brand: #e63946;
    --theme-brand-2: #ff6b6b;
    --theme-brand-3: #d62e3b;
    --theme-ok: #22c55e;
    --theme-danger: #f43f5e;
    --theme-shadow: 0 20px 50px rgba(0, 0, 0, 0.7);
    --theme-glass-border: rgba(255, 255, 255, 0.06);
    --theme-glow: 0 0 30px rgba(230, 57, 70, 0.15);

    /* Compatibility variables used by older per-page styles */
    --bg: var(--theme-bg-2);
    --dark: var(--theme-bg-2);
    --panel: var(--theme-panel);
    --ink: var(--theme-text);
    --ink-strong: #ffffff;
    --muted: var(--theme-muted);
    --line: var(--theme-line);
    --accent: var(--theme-brand);
    --accent-soft: var(--theme-brand-2);
}

html {
    -webkit-text-size-adjust: 100%;
}

body {
    overflow-x: hidden;
}

img,
video {
    max-width: 100%;
    height: auto;
}


.table-wrap,
.table-container,
.cart-table-wrap,
.table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

table,
.roster-table,
.orders-table,
.data-table {
    max-width: 100%;
}

* {
    scrollbar-width: thin;
    scrollbar-color: rgba(32, 16, 0, 0.32) transparent;
}

body {
    font-family: "Manrope", "Segoe UI", sans-serif;
    color: var(--theme-text);
    background:
        radial-gradient(ellipse at 10% -8%, rgba(230, 57, 70, 0.12), transparent 36%),
        radial-gradient(ellipse at 90% 2%, rgba(214, 46, 59, 0.08), transparent 30%),
        radial-gradient(ellipse at 50% 100%, rgba(230, 57, 70, 0.04), transparent 50%),
        linear-gradient(165deg, var(--theme-bg-1) 0%, var(--theme-bg-2) 100%);
    min-height: 100vh;
}

/* Shared inline field validation (used by auth pages) */
.field-error {
    display: none;
    margin-top: 6px;
    font-size: 12px;
    color: var(--theme-danger);
}

.field-error.is-visible {
    display: block;
}

input.is-invalid,
textarea.is-invalid,
select.is-invalid,
.otp-input.is-invalid {
    border-color: var(--theme-danger);
}

.topbar,
.admin-sidebar {
    backdrop-filter: saturate(150%) blur(12px);
    -webkit-backdrop-filter: saturate(150%) blur(12px);
}

header {
    backdrop-filter: saturate(150%) blur(12px);
    -webkit-backdrop-filter: saturate(150%) blur(12px);
    position: sticky;
    top: 0;
    z-index: 100;
}

/* Uniform customer top navigation */
header .nav {
    max-width: 1180px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    min-height: 74px;
}

header .logo-wrap {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
    color: #ffffff;
    flex-shrink: 0;
    min-height: 56px;
}

header .logo-wrap img {
    width: 56px;
    height: 56px;
    object-fit: contain;
    display: block;
}

header nav {
    flex: 1;
    display: flex;
    justify-content: center;
}

header nav ul {
    display: flex;
    align-items: center;
    gap: 0;
    min-height: 50px;
}

header .nav-shop-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    border-bottom: 0;
    padding: 6px 12px;
    line-height: 1;
    min-height: 50px;
    position: relative;
    transition: transform 0.22s ease, color 0.22s ease, text-shadow 0.22s ease;
}

header .nav-shop-link::after {
    content: "";
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: -4px;
    height: 2px;
    background: linear-gradient(90deg, var(--theme-brand-2), #ffedd5, var(--theme-brand-3));
    transform: scaleX(0.25);
    transform-origin: center;
    opacity: 0;
    transition: transform 0.24s ease, opacity 0.24s ease;
}

header .nav-shop-link:hover {
    border-bottom: 0;
    opacity: 1;
    color: #ffedd5;
    transform: translateY(-2px);
    text-shadow: 0 0 16px color-mix(in srgb, var(--theme-brand-2) 55%, transparent);
}

header .nav-shop-link:hover::after {
    transform: scaleX(1);
    opacity: 1;
}

header .nav-icons {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
    min-height: 50px;
}

header .nav-contact-link {
    color: #ffffff;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
    opacity: 0.92;
    padding: 6px 8px;
    border-radius: 999px;
    border: 1px solid transparent;
    transition: background-color 0.22s ease, border-color 0.22s ease, transform 0.22s ease, color 0.22s ease;
}

header .nav-contact-link:hover {
    opacity: 1;
    color: var(--theme-brand-2);
    background: rgba(230, 57, 70, 0.1);
    border-color: rgba(230, 57, 70, 0.3);
    transform: translateY(-1px);
}

/* Keep header typography stable even when web fonts load at different times */
header .logo-wrap span,
header .nav-shop-link,
header .nav-contact-link,
header .nav-login-btn-link,
header .nav-logout-btn-link {
    font-family: "Segoe UI", "Trebuchet MS", Arial, sans-serif;
    font-synthesis: none;
}

header,
.topbar {
    background: rgba(9, 10, 15, 0.7);
    border-bottom: 1px solid var(--theme-glass-border);
}

.admin-sidebar {
    background: linear-gradient(180deg, #090a0f 0%, #12141c 55%, #181b24 100%);
}

.admin-sidebar .sidebar-brand {
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

.admin-sidebar .nav-item {
    color: rgba(255, 255, 255, 0.92);
}

.admin-sidebar .nav-item:hover {
    background: color-mix(in srgb, var(--theme-brand) 18%, transparent);
}

.admin-sidebar .nav-item.active {
    background: color-mix(in srgb, var(--theme-brand) 24%, transparent);
    border-left-color: var(--theme-brand-2);
}

.topbar .topbar-title {
    color: rgba(255, 255, 255, 0.94);
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.42);
}

/* Themed dialog (used instead of browser alert()) */
.av-dialog-backdrop {
    position: fixed;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 22px;
    background: rgba(0, 0, 0, 0.62);
    z-index: 9999;
}

.av-dialog {
    width: min(520px, 92vw);
    max-height: min(70vh, 560px);
    border-radius: 18px;
    background: rgba(16, 18, 26, 0.92);
    border: 1px solid var(--theme-glass-border);
    box-shadow: var(--theme-shadow);
    display: grid;
    gap: 10px;
    padding: 22px 22px 18px;
    position: relative;
    color: var(--theme-text);
    backdrop-filter: saturate(150%) blur(14px);
    -webkit-backdrop-filter: saturate(150%) blur(14px);
}

.av-dialog-title {
    text-align: center;
    color: rgba(255, 255, 255, 0.96);
    font-weight: 900;
    letter-spacing: 0.8px;
    text-transform: none;
    font-size: 22px;
}

.av-dialog-desc {
    color: var(--theme-muted);
    font-size: 14px;
    line-height: 1.55;
    white-space: normal;
    text-align: center;
    opacity: 1;
    overflow: auto;
    max-height: min(36vh, 280px);
}

.av-dialog-desc a {
    color: var(--theme-brand-2);
    font-weight: 800;
}

.av-dialog-close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid var(--theme-glass-border);
    background: rgba(0, 0, 0, 0.18);
    color: rgba(255, 255, 255, 0.82);
    cursor: pointer;
    display: grid;
    place-items: center;
    font-size: 20px;
    line-height: 1;
}

.av-dialog-close:hover {
    background: rgba(255, 255, 255, 0.08);
}

.av-dialog-close:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(230, 57, 70, 0.25);
}

.av-dialog-icon {
    width: 66px;
    height: 66px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    margin: 4px auto 2px;
    background: color-mix(in srgb, var(--theme-brand) 16%, rgba(0, 0, 0, 0.08));
}

.av-dialog-icon svg {
    width: 34px;
    height: 34px;
    fill: rgba(255, 255, 255, 0.84);
}

.av-dialog--success .av-dialog-icon {
    background: rgba(11, 143, 98, 0.12);
}

.av-dialog--success .av-dialog-icon svg {
    fill: var(--theme-ok);
}

.av-dialog--danger .av-dialog-icon {
    background: rgba(179, 53, 45, 0.12);
}

.av-dialog--danger .av-dialog-icon svg {
    fill: var(--theme-danger);
}

.av-dialog--warning .av-dialog-icon {
    background: rgba(199, 155, 109, 0.18);
}

.av-dialog--warning .av-dialog-icon svg {
    fill: var(--theme-brand-3);
}

.av-dialog-actions {
    padding-top: 6px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.av-dialog-actions--confirm {
    grid-template-columns: 1fr 1fr;
}

.av-dialog-btn {
    border: 1px solid var(--theme-line);
    border-radius: 12px;
    padding: 12px 16px;
    font-weight: 800;
    letter-spacing: 0.4px;
    text-transform: none;
    cursor: pointer;
    width: 100%;
}

.av-dialog-btn--cancel {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.9);
}

.av-dialog-btn--cancel:hover {
    background: rgba(255, 255, 255, 0.1);
}

.av-dialog-btn--primary {
    background: var(--theme-brand);
    color: #ffffff;
}

.av-dialog--success .av-dialog-btn--primary {
    background: var(--theme-ok);
    border-color: rgba(11, 143, 98, 0.3);
    color: rgba(255, 255, 255, 0.96);
}

.av-dialog--danger .av-dialog-btn--primary {
    background: var(--theme-danger);
    border-color: rgba(179, 53, 45, 0.28);
    color: rgba(255, 255, 255, 0.96);
}

.av-dialog--warning .av-dialog-btn--primary {
    background: var(--theme-brand-3);
    border-color: rgba(181, 131, 93, 0.32);
    color: rgba(255, 255, 255, 0.96);
}

.av-dialog--confirm .av-dialog-btn--primary {
    background: var(--theme-brand);
    border-color: rgba(230, 57, 70, 0.3);
    color: #ffffff;
}

.av-dialog--confirm.av-dialog--destructive .av-dialog-btn--primary {
    background: var(--theme-danger);
    border-color: rgba(179, 53, 45, 0.28);
    color: rgba(255, 255, 255, 0.96);
}

.av-dialog-btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(230, 57, 70, 0.25);
}

/* Toast notifications (used for "Order added" etc.) */
.av-toast-stack {
    position: fixed;
    top: 80px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    z-index: 10000;
    display: grid;
    gap: 10px;
    width: min(520px, calc(100vw - 40px));
}

.av-toast {
    --av-toast-accent: var(--theme-brand);
    --av-toast-bg: rgba(36, 25, 20, 0.92);
    display: grid;
    grid-template-columns: 34px 1fr 44px;
    align-items: center;
    gap: 12px;
    padding: 12px 12px;
    border-radius: 16px;
    background: var(--av-toast-bg);
    border: 1px solid color-mix(in srgb, var(--av-toast-accent) 58%, transparent);
    box-shadow:
        0 18px 40px rgba(0, 0, 0, 0.42),
        inset 0 0 0 1px rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.94);
    animation: avToastIn 0.22s ease;
}

.av-toast.is-hiding {
    animation: avToastOut 0.18s ease forwards;
}

.av-toast-message {
    display: grid;
    gap: 2px;
    line-height: 1.25;
}

.av-toast-title {
    font-weight: 800;
    letter-spacing: 0.2px;
    color: color-mix(in srgb, var(--av-toast-accent) 78%, rgba(255, 255, 255, 0.95));
}

.av-toast-sub {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.72);
    font-weight: 600;
}

.av-toast-close {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--av-toast-accent) 28%, rgba(255, 255, 255, 0.18));
    background: rgba(0, 0, 0, 0.12);
    color: rgba(255, 255, 255, 0.86);
    cursor: pointer;
    display: grid;
    place-items: center;
    font-size: 18px;
    line-height: 1;
}

.av-toast-close:hover {
    background: rgba(255, 255, 255, 0.08);
}

.av-toast-close:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(224, 192, 144, 0.28);
}

.av-toast-icon {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: color-mix(in srgb, var(--av-toast-accent) 22%, rgba(0, 0, 0, 0.18));
    border: 1px solid color-mix(in srgb, var(--av-toast-accent) 58%, transparent);
    color: color-mix(in srgb, var(--av-toast-accent) 78%, rgba(255, 255, 255, 0.95));
    font-size: 14px;
    font-weight: 900;
    line-height: 1;
}

.av-toast--success {
    --av-toast-accent: var(--theme-brand-2);
}

.av-toast--danger {
    --av-toast-accent: var(--theme-danger);
}

.av-toast--warning {
    --av-toast-accent: var(--theme-brand-2);
}

.av-toast--info {
    --av-toast-accent: var(--theme-brand-3);
}

.av-toast--success .av-toast-icon::before {
    content: "✓";
    font-weight: 900;
}

.av-toast--danger .av-toast-icon::before {
    content: "!";
    font-weight: 900;
}

.av-toast--warning .av-toast-icon::before {
    content: "!";
    font-weight: 900;
}

.av-toast--info .av-toast-icon::before {
    content: "i";
    font-weight: 900;
}

@keyframes avToastIn {
    from {
        opacity: 0;
        transform: translateX(10px) translateY(-2px);
    }
    to {
        opacity: 1;
        transform: translateX(0) translateY(0);
    }
}

@keyframes avToastOut {
    from {
        opacity: 1;
        transform: translateX(0);
    }
    to {
        opacity: 0;
        transform: translateX(10px);
    }
}

main,
.page,
.page-content,
.content,
.form-card,
.order-panel,
.product-preview,
.catalog,
.sidebar,
.search-section,
.table-wrap,
.table-container,
.cta,
.hero,
.section,
.login-panel,
.admin-login-card,
.card,
.settings-card,
.panel {
    border-radius: 16px;
}

h1,
h2,
h3,
.brand,
.page-title,
.topbar-title,
.logo-wrap span,
.section-title {
    font-family: "Bebas Neue", "Arial Narrow", sans-serif;
    letter-spacing: 1.2px;
}

.logo-wrap span,
.brand {
    letter-spacing: 2px;
}

a,
.btn,
.order-btn,
.submit-btn,
.nav-login-btn-link,
.nav-logout-btn-link,
.nav-item,
.sidebar-item,
.icon-btn,
.admin-login-btn {
    transition: all 0.22s ease;
}

.nav-login-btn-link,
.nav-logout-btn-link,
.btn,
.order-btn,
.submit-btn,
.admin-login-btn,
.mini-btn,
.toggle-btn.active {
    background: var(--theme-brand);
    color: #ffffff;
    border-color: var(--theme-brand-3);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
    font-weight: 700;
    text-shadow: none;
}

.btn:hover,
.order-btn:hover,
.submit-btn:hover,
.admin-login-btn:hover,
.mini-btn:hover,
.nav-login-btn-link:hover,
.nav-logout-btn-link:hover {
    transform: translateY(-2px);
    background: var(--theme-brand-2);
    box-shadow: 0 8px 20px rgba(230, 57, 70, 0.25);
}

.btn.secondary,
.toggle-btn,
.mini-btn.secondary {
    background: rgba(255, 255, 255, 0.05);
    color: #e2e8f0;
    border-color: var(--theme-line);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(4px);
}

.btn.secondary:hover,
.toggle-btn:hover,
.mini-btn.secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    box-shadow: 0 12px 22px rgba(0, 0, 0, 0.3);
}

nav a.active,
.nav-item.active,
.sidebar-item.active {
    box-shadow: inset 0 -2px 0 var(--theme-brand-2);
}

input,
select,
textarea,
.search-input {
    border-radius: 10px;
    border: 1px solid var(--theme-line);
    background: rgba(15, 17, 23, 0.6);
    color: var(--theme-text);
}

input:focus,
select:focus,
textarea:focus,
.search-input:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--theme-brand-2) 55%, rgba(255, 255, 255, 0.12));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--theme-brand) 24%, transparent);
}

::placeholder {
    color: color-mix(in srgb, var(--theme-muted) 72%, transparent);
}

.product-card,
.action-card,
.step-card,
.stat-card,
.order-header-item,
.activity-item,
.admin-login-card,
.form-card,
.catalog,
.sidebar,
.search-section,
.table-container,
.settings-card,
.panel,
.card {
    border: 1px solid var(--theme-line);
    background: var(--theme-panel);
    box-shadow: var(--theme-shadow);
}

.table-container thead {
    background: color-mix(in srgb, var(--theme-panel) 80%, rgba(0, 0, 0, 0.32));
    border-bottom: 1px solid var(--theme-line);
}

.table-container th {
    background: transparent;
    color: rgba(255, 255, 255, 0.92);
}

.table-container td {
    color: rgba(228, 234, 242, 0.88);
}

.table-container tbody tr:hover {
    background: rgba(255, 255, 255, 0.04);
}

.tab-btn,
.action-btn {
    background: rgba(255, 255, 255, 0.04);
    color: var(--theme-text);
    border-color: var(--theme-line);
}

.tab-btn:hover,
.action-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: color-mix(in srgb, var(--theme-brand-2) 55%, rgba(255, 255, 255, 0.12));
    color: var(--theme-text);
}

.tab-btn.active {
    background: var(--theme-brand);
    border-color: var(--theme-brand-3);
    color: #ffffff;
}

.af-input {
    background: rgba(15, 17, 23, 0.6);
    color: var(--theme-text);
    border-color: var(--theme-line);
}

.af-input:focus {
    border-color: color-mix(in srgb, var(--theme-brand-2) 55%, rgba(255, 255, 255, 0.12));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--theme-brand) 24%, transparent);
}

.settings-card {
    color: var(--theme-text);
}

.field-group input,
.field-group textarea {
    background: rgba(15, 17, 23, 0.6);
    border-color: var(--theme-line);
    color: var(--theme-text);
}

.field-group input:focus,
.field-group textarea:focus {
    border-color: color-mix(in srgb, var(--theme-brand-2) 55%, rgba(255, 255, 255, 0.12));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--theme-brand) 24%, transparent);
}

.nav-account-dropdown {
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.45);
}

.nav-account-dropdown a:not(.nav-logout-btn-link) {
    color: rgba(15, 23, 42, 0.92);
}

.nav-account-dropdown a:not(.nav-logout-btn-link) svg {
    stroke: rgba(15, 23, 42, 0.7);
}

.nav-account-dropdown a:not(.nav-logout-btn-link):hover {
    background: rgba(230, 57, 70, 0.1);
    color: rgba(15, 23, 42, 0.92);
}

.address-suggestions {
    background: color-mix(in srgb, var(--theme-panel) 88%, rgba(6, 7, 11, 0.75));
    border-color: var(--theme-line);
    box-shadow: var(--theme-shadow);
}

.address-suggestion {
    color: var(--theme-text);
}

.address-suggestion:hover,
.address-suggestion:focus {
    background: rgba(255, 255, 255, 0.06);
}

.product-image,
.image-placeholder,
.banner,
.upload-box {
    background: linear-gradient(135deg, rgba(20, 22, 28, 0.8), rgba(15, 17, 23, 0.6));
    border: 1px solid var(--theme-glass-border);
}

.hero {
    background:
    radial-gradient(circle at 15% 12%, color-mix(in srgb, var(--theme-brand) 22%, transparent), transparent 28%),
    radial-gradient(circle at 85% 8%, color-mix(in srgb, var(--theme-brand-3) 16%, transparent), transparent 24%),
    linear-gradient(145deg, rgba(20, 22, 28, 0.8), rgba(15, 17, 23, 0.9));
}

.hero h1,
.page-title,
.topbar-title {
    color: #ffffff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.8);
}

.action-card,
.step-card,
.process-step,
.product-card,
.order-header-item {
    position: relative;
    overflow: hidden;
}

.action-card::after,
.step-card::after,
.product-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 55%, color-mix(in srgb, var(--theme-brand) 18%, transparent) 100%);
    pointer-events: none;
}

.action-card.dark {
    background: linear-gradient(140deg, #1f222e, #14161c);
    color: #ffffff;
}

.process {
    background: linear-gradient(180deg, rgba(20, 22, 28, 0.8), rgba(15, 17, 23, 0.9));
    border: 1px solid var(--theme-glass-border);
}

.site-footer .footer-col h3,
.site-footer .footer-col h4 {
    color: var(--theme-brand-2);
}

table,
.roster-table,
.orders-table {
    border-radius: 12px;
    overflow: hidden;
}

th,
.roster-table th,
.orders-table th {
    background: linear-gradient(92deg, #14161c, #1f222e);
    color: #ffffff;
    border-color: var(--theme-line);
}

tr:nth-child(even),
.roster-table tr:nth-child(even),
.orders-table tr:nth-child(even) {
    background: rgba(255, 255, 255, 0.02);
}

.site-footer {
    background: #06070b;
    color: #94a3b8;
    
}

.site-footer a {
    color: var(--theme-brand-2);
}

.login-btn,
.register-btn,
.verify-btn,
.send-btn,
.reset-btn {
    background: var(--theme-brand);
    color: #ffffff;
    border: 1px solid rgba(230, 57, 70, 0.3);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
    font-weight: 700;
}

.login-btn:hover,
.register-btn:hover,
.verify-btn:hover,
.send-btn:hover,
.reset-btn:hover {
    transform: translateY(-2px);
    background: var(--theme-brand-2);
    box-shadow: 0 8px 20px rgba(230, 57, 70, 0.25);
    opacity: 1;
}

.resend-btn {
    border-color: rgba(230, 57, 70, 0.3);
    color: var(--theme-brand-2);
    background: rgba(255, 255, 255, 0.05);
}

.resend-btn:hover:not(:disabled) {
    background: rgba(230, 57, 70, 0.12);
    color: #ffffff;
}

.form-card,
.terms-box,
.login-panel,
.register-panel,
.otp-panel,
.verify-panel,
.forgot-panel,
.reset-panel {
    border: 1px solid var(--theme-glass-border);
    border-radius: 14px;
    background: rgba(20, 22, 28, 0.8);
    backdrop-filter: blur(12px);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.4);
    color: #ffffff;
}

.title-line {
    background: linear-gradient(90deg, transparent, rgba(230, 57, 70, 0.45), transparent);
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
.password-wrap input,
.otp-input {
    border: 1px solid var(--theme-line);
    background: rgba(15, 17, 23, 0.6);
    color: #ffffff;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
.password-wrap input:focus,
.otp-input:focus {
    border-color: rgba(230, 57, 70, 0.5);
    box-shadow: 0 0 0 3px rgba(230, 57, 70, 0.15);
}

main > * {
    animation: riseIn 0.44s ease both;
}

main > *:nth-child(2) {
    animation-delay: 0.05s;
}

main > *:nth-child(3) {
    animation-delay: 0.1s;
}

main > *:nth-child(4) {
    animation-delay: 0.15s;
}

@keyframes riseIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 900px) {
    body {
        background:
            radial-gradient(circle at 80% 0%, rgba(224, 192, 144, 0.2), transparent 25%),
            linear-gradient(180deg, var(--theme-bg-1), var(--theme-bg-2));
    }

    .logo-wrap span,
    .brand {
        letter-spacing: 1px;
    }

    header .nav {
        gap: 10px;
    }

    header .logo-wrap img {
        width: 52px;
        height: 52px;
    }

    header .logo-wrap span {
        display: inline;
        white-space: nowrap;
    }

    header nav ul {
        display: flex !important;
    }

    header .nav-shop-link {
        font-size: 18px;
        letter-spacing: 1px;
        padding: 4px 6px;
    }

    header .nav-contact-link {
        font-size: 11px;
        padding: 4px;
    }

    header .nav-login-btn-link {
        padding: 6px 10px;
    }

    main,
    .page-content,
    .content {
        padding-left: 14px;
        padding-right: 14px;
    }
}

/* Admin pages intentionally use the same dark theme as customer pages. */

/* ═══════════════════════════════════════════════════════════════
   ADMIN PAGES — dark/grey/red readability overrides
   Fixes remaining hard-coded light surfaces from admin-homepage.css
   ═══════════════════════════════════════════════════════════════ */

body.admin-page {
    color: var(--theme-text);
}

body.admin-page .topbar {
    background: rgba(9, 10, 15, 0.7);
    border-bottom: 1px solid var(--theme-glass-border);
}

body.admin-page .topbar-title {
    color: rgba(255, 255, 255, 0.94);
}

body.admin-page .search-input,
body.admin-page .field-input,
body.admin-page .comment-input,
body.admin-page .message-reply-input {
    background: rgba(15, 17, 23, 0.65);
    border-color: var(--theme-line);
    color: var(--theme-text);
}

body.admin-page .search-input::placeholder,
body.admin-page .field-input::placeholder,
body.admin-page .comment-input::placeholder,
body.admin-page .message-reply-input::placeholder {
    color: color-mix(in srgb, var(--theme-muted) 70%, transparent);
}

body.admin-page .search-input:focus,
body.admin-page .field-input:focus,
body.admin-page .comment-input:focus,
body.admin-page .message-reply-input:focus {
    border-color: color-mix(in srgb, var(--theme-brand-2) 55%, rgba(255, 255, 255, 0.12));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--theme-brand) 22%, transparent);
}

body.admin-page .search-icon {
    stroke: color-mix(in srgb, var(--theme-muted) 80%, transparent);
}

body.admin-page .icon-btn,
body.admin-page .admin-menu {
    background: rgba(255, 255, 255, 0.04);
    border-color: var(--theme-line);
}

body.admin-page .icon-btn:hover,
body.admin-page .admin-menu:hover {
    border-color: color-mix(in srgb, var(--theme-brand-2) 55%, rgba(255, 255, 255, 0.12));
    background: rgba(255, 255, 255, 0.07);
}

body.admin-page .icon-svg {
    stroke: rgba(228, 234, 242, 0.82);
}

body.admin-page .admin-name {
    color: rgba(255, 255, 255, 0.92);
}

body.admin-page .panel,
body.admin-page .admin-catalog-card,
body.admin-page .message-details-box,
body.admin-page .receipt-panel,
body.admin-page .comment-card,
body.admin-page .summary-item,
body.admin-page .stat-card {
    background: var(--theme-panel);
    border-color: var(--theme-line);
    box-shadow: var(--theme-shadow);
    color: var(--theme-text);
}

body.admin-page .action-card {
    border-color: var(--theme-line);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.9);
}

body.admin-page .action-card:hover {
    background: rgba(255, 255, 255, 0.07);
    box-shadow: var(--theme-shadow);
}

body.admin-page .order-stepper .dot {
    background: rgba(255, 255, 255, 0.03);
    border-color: var(--theme-line);
}

body.admin-page .order-stepper .step.is-active .dot {
    box-shadow: 0 0 0 4px rgba(230, 57, 70, 0.16);
}

body.admin-page .upload-card-box,
body.admin-page .reference-tile {
    background: rgba(255, 255, 255, 0.04);
    border-color: var(--theme-line);
}

body.admin-page .message-details-row td {
    background: rgba(255, 255, 255, 0.03);
}

body.admin-page .order-contents-notice-links a {
    background: rgba(255, 255, 255, 0.04);
    border-color: var(--theme-line);
    color: rgba(255, 255, 255, 0.9);
}

body.admin-page .order-contents-notice-links a:hover {
    background: rgba(255, 255, 255, 0.07);
    border-color: var(--theme-brand);
    color: rgba(255, 255, 255, 0.95);
}

body.admin-page .admin-catalog-empty {
    background: rgba(15, 17, 23, 0.55);
    border-color: color-mix(in srgb, var(--theme-line) 70%, transparent);
    color: var(--theme-muted);
}

body.admin-page .admin-catalog-media {
    background: rgba(255, 255, 255, 0.03);
    border-bottom: 1px solid var(--theme-line);
}

body.admin-page .admin-catalog-thumb {
    background: rgba(255, 255, 255, 0.04);
}

body.admin-page .admin-catalog-thumb--empty {
    color: var(--theme-muted);
}

body.admin-page .panel-head {
    border-color: var(--theme-line);
}

body.admin-page .panel-title,
body.admin-page .admin-catalog-name,
body.admin-page .receipt-title,
body.admin-page .comment-author {
    color: rgba(255, 255, 255, 0.94);
}

body.admin-page .field-label,
body.admin-page .order-meta-k,
body.admin-page .order-header-k,
body.admin-page .upload-card-title,
body.admin-page .reference-tile-label,
body.admin-page .pricing-title,
body.admin-page .sidebar-section-title,
body.admin-page .summary-k,
body.admin-page .stat-label {
    color: color-mix(in srgb, var(--theme-muted) 85%, transparent);
}

body.admin-page .order-header-v,
body.admin-page .order-meta-v,
body.admin-page .summary-v,
body.admin-page .stat-value,
body.admin-page .checkline {
    color: rgba(228, 234, 242, 0.9);
}

body.admin-page .data-table thead th {
    background: rgba(255, 255, 255, 0.03);
    color: color-mix(in srgb, var(--theme-muted) 85%, transparent);
    border-color: var(--theme-line);
}

body.admin-page .data-table tbody td {
    color: rgba(228, 234, 242, 0.88);
    border-color: var(--theme-line);
}

body.admin-page .data-table tbody tr:hover td {
    background: rgba(255, 255, 255, 0.04);
}

body.admin-page .table-btn {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--theme-line);
    color: rgba(228, 234, 242, 0.9);
}

body.admin-page .table-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: color-mix(in srgb, var(--theme-brand-2) 55%, rgba(255, 255, 255, 0.12));
}

body.admin-page .table-btn.is-danger {
    border-color: color-mix(in srgb, var(--theme-danger) 70%, var(--theme-line));
    color: var(--theme-danger);
}

body.admin-page .table-btn.is-danger:hover {
    border-color: var(--theme-danger);
    background: color-mix(in srgb, var(--theme-danger) 12%, rgba(255, 255, 255, 0.06));
}

body.admin-page .status-pill--pending,
body.admin-page .status-pill--payment,
body.admin-page .status-pill--final-payment,
body.admin-page .status-pill--proofing,
body.admin-page .status-pill--progress,
body.admin-page .status-pill--ready,
body.admin-page .status-pill--transit,
body.admin-page .status-pill--completed,
body.admin-page .status-pill--revision,
body.admin-page .status-pill--rejected,
body.admin-page .status-pill--cancelled {
    background: color-mix(in srgb, var(--status-fg) 14%, rgba(15, 17, 23, 0.6));
    border-color: color-mix(in srgb, var(--status-fg) 32%, var(--theme-line));
}
