/* ===================================================================
   RESET / BASE
=================================================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: var(--font-primary);
}

html { scroll-behavior: smooth; }

body {
    background: var(--grey-800) url('/assets/background.png') repeat;
    color: var(--text-primary);
    line-height: 1.5;
    overflow-x: hidden;
    padding-top: 140px;
}

a {
    color: var(--accent-green);
    text-decoration: none;
}

a:hover {
    color: #fff;
}

/* ===================================================================
   VARIABLES
=================================================================== */
:root {
    /* === ACCENT COLORS === */
    --accent-red: #D64949;
    --accent-green: #98c46e;

    /* === GREY SCALE === */
    --grey-100: #eee;
    --grey-200: #ccc;
    --grey-300: #999;
    --grey-400: #666;
    --grey-500: #444;
    --grey-600: #333;
    --grey-700: #222;
    --grey-800: #1a1a1a;

    /* === SEMANTIC ALIASES (use greys above) === */
    --light-grey: var(--grey-200);
    --dark-grey: var(--grey-400);
    
    /* === TILE SYSTEM (2-tier) === */
    --tile-outer-bg: rgba(255,255,255,0.12);
    --tile-outer-border: rgba(255,255,255,0.2);
    --tile-outer-hover: var(--accent-green);
    --tile-inner-bg: var(--grey-700);
    --tile-inner-border: var(--grey-500);
    --tile-inner-hover: var(--accent-green);
    
    /* Legacy aliases - use tile system above */
    --card-bg: var(--tile-outer-bg);
    --card-border: var(--tile-outer-border);
    --card-bg-dark: var(--tile-inner-bg);
    --card-border-dark: var(--tile-inner-border);
    
    --input-bg: #fff;
    --input-bg-dark: #fff;
    --input-text: #333;
    --input-border: #ccc;
    --input-border-dark: #ccc;

    /* === TYPOGRAPHY === */
    --font-primary: 'Roboto', Arial, sans-serif;
    --font-heading: 'Roboto', Arial, sans-serif;
    
    /* Text colors - USE THESE, never hardcode #666, #888 etc. 
       --text-primary:   White - headings, important text
       --text-secondary: Light grey - body text, descriptions  
       --text-muted:     Medium grey - hints, placeholders, disabled */
    --text-primary: #fff;
    --text-secondary: var(--grey-200);
    --text-muted: var(--grey-300);
    
    /* Font sizes - 7 step scale */
    --font-xs: 11px;
    --font-sm: 13px;
    --font-base: 16px;
    --font-md: 18px;
    --font-lg: 22px;
    --font-xl: 28px;
    --font-2xl: 36px;

    /* === SPACING === */
    --spacing-sm: 12px;
    --spacing-md: 20px;
    --spacing-lg: 28px;
}

/* ===================================================================
   TYPOGRAPHY
=================================================================== */
h1, h2, h3 {
    margin-bottom: 20px;
    font-weight: 600;
    font-family: var(--font-heading);
    color: var(--text-primary);
}
h1 { font-size: var(--font-2xl); }
h2 { font-size: var(--font-xl); }
h3 { font-size: var(--font-lg); }

p, label, span { font-size: var(--font-base); }

/* ===================================================================
   LAYOUT
=================================================================== */
.page-container {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 20px;
}

/* ===================================================================
   GLOBAL LINK STYLES
=================================================================== */

/* === SITE HEADER === */
.site-header {
    position: relative;
    z-index: 100;
}

/* === COMBINED STICKY NAV BAR === */
.main-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    padding: 0 24px;
    height: 140px;
    background: rgba(30, 30, 30, 0.88);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--grey-600);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 500;
}

.nav-logo {
    display: flex;
    align-items: center;
    margin-right: clamp(12px, 1.5vw, 20px);
    flex-shrink: 0;
}
.nav-logo img {
    height: 120px;
    width: auto;
    filter: drop-shadow(0 0 3px rgba(0,0,0,0.4));
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.nav-left {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.nav-links {
    display: flex;
    align-items: center;
    gap: clamp(14px, 2vw, 28px);
    list-style: none;
    padding: 0;
    margin: 0;
}

.nav-links a {
    color: #ffffff;
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    white-space: nowrap;
    transition: color 0.15s ease;
}

.nav-links a:hover {
    color: var(--accent-green);
}

.nav-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    white-space: nowrap;
}

.nav-info-item {
    color: var(--accent-green);
    font-size: 16px;
    white-space: nowrap;
}

.nav-phone {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.nav-phone svg {
    flex-shrink: 0;
}

.nav-info-divider {
    color: rgba(255,255,255,0.25);
    font-size: 16px;
}

/* Hide old elements that no longer exist */
.desktop-info-bar { display: none; }
.logo-header { display: none; }

/* Mobile logo — hidden on desktop, shown on mobile */
.mobile-logo-header {
    display: none;
    width: 100%;
    text-align: center;
    padding: 20px 0 10px;
}
.mobile-logo-header img {
    width: 280px;
    max-width: 70%;
    height: auto;
    filter: drop-shadow(0 0 4px rgba(0,0,0,0.5));
    border: none !important;
}

/* ===================================================================
   MOBILE CALL BUTTON — SHOWN ONLY ON MOBILE
=================================================================== */
.mobile-call-btn {
    display: none;
    margin: 0 auto 12px;
    padding: 14px 26px;
    background: var(--accent-green);
    color: #fff;
    border: 1px solid #fff;
    font-size: var(--font-base);
    font-weight: 500;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.mobile-call-btn:hover,
.mobile-call-btn:active {
    background: var(--accent-green);
    color: #fff;
}

a.mobile-call-btn,
a.mobile-call-btn:visited,
a.mobile-call-btn:hover,
a.mobile-call-btn:active {
    color: #fff;
}

.mobile-call-btn svg {
    display: inline-block;
    vertical-align: middle;
    margin-right: 8px;
}

@media (max-width: 850px) {
    .mobile-call-btn {
        display: block;
        width: fit-content;
        margin-left: auto;
        margin-right: auto;
    }
    .mobile-call-btn:last-of-type {
        margin-bottom: 30px;
    }
}

/* ===================================================================
   MOBILE MENU — CUSTOMER NAV SYSTEM
=================================================================== */
.mobile-fab {
    display: none;
    position: fixed;
    top: 18px;
    right: 20px;
    font-size: var(--font-xl);
    color: white;
    cursor: pointer;
    z-index: 900;
}

.mobile-menu {
    display: flex;
    flex-direction: column;
    background: rgba(0,0,0,0.92);
    padding: 40px 20px;
    position: fixed;
    top: 0;
    right: 0;
    width: 70%;
    height: 100%;
    z-index: 1999;
    transform: translateX(100%);
    transition: transform 0.3s ease;
}

.mobile-menu.open {
    transform: translateX(0);
}

.mobile-menu a {
    color: #fff;
    margin-bottom: 25px;
    font-size: var(--font-md);
}

/* ===================================================================
   FORM ELEMENTS
=================================================================== */
label {
    margin-bottom: 6px;
    font-weight: 500;
}

.form-row {
    display: flex;
    gap: 15px;
}

.form-row .form-group {
    flex: 1;
}

.form-row .form-group label {
    display: block;
}

/* Standalone form-group: label above input */
.form-group {
    margin-bottom: 15px;
}

.form-group label {
    display: block;
    margin-bottom: 6px;
}

.form-group input,
.form-group textarea,
.form-group select {
    margin-bottom: 0;
}

/* Email form alignment */
.email-form .btn {
    margin-bottom: 0;
}

@media (max-width: 600px) {
    .form-row {
        flex-direction: column;
        gap: 0;
    }
}

input,
textarea,
select {
    width: 100%;
    padding: 12px;
    margin-bottom: 20px;
    background: var(--input-bg);
    color: var(--input-text);
    border: 1px solid var(--input-border);
    font-size: var(--font-base);
}

input:focus,
textarea:focus,
select:focus {
    outline: none;
    border-color: var(--grey-400);
}

/* Override browser autofill styles */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill,
select:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px #fff inset !important;
    -webkit-text-fill-color: #333 !important;
    box-shadow: 0 0 0 1000px #fff inset !important;
    caret-color: #333 !important;
    transition: background-color 5000s ease-in-out 0s;
}

/* Admin autofill: dark bg instead of white */
body.admin-page input:-webkit-autofill,
body.admin-page input:-webkit-autofill:hover,
body.admin-page input:-webkit-autofill:focus,
body.admin-page input:-webkit-autofill:active,
body.admin-page textarea:-webkit-autofill,
body.admin-page select:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px var(--grey-700) inset !important;
    -webkit-text-fill-color: #fff !important;
    box-shadow: 0 0 0 1000px var(--grey-700) inset !important;
    caret-color: #fff !important;
}

/* Admin selects: light arrow on dark bg */
body.admin-page select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
    color-scheme: dark;
}

input::placeholder,
textarea::placeholder {
    color: var(--grey-300);
}

select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23666' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
    color-scheme: light;
}

select option {
    background-color: #fff !important;
    color: #333 !important;
}

select option:checked,
select option:hover,
select option:focus {
    background-color: #eee !important;
    color: #333 !important;
}

/* Date/Time input styling */
input[type="date"],
input[type="time"],
input[type="datetime-local"] {
    color-scheme: light;
}

input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator {
    cursor: pointer;
    opacity: 0.7;
}

input[type="date"]::-webkit-calendar-picker-indicator:hover,
input[type="time"]::-webkit-calendar-picker-indicator:hover,
input[type="datetime-local"]::-webkit-calendar-picker-indicator:hover {
    opacity: 1;
}

/* Selection highlight color */
::selection {
    background: var(--accent-green);
    color: var(--grey-800);
}

::-moz-selection {
    background: var(--accent-green);
    color: var(--grey-800);
}

textarea { min-height: 120px; }

/* ===================================================================
   SECTION LABEL (green uppercase eyebrow text)
   Use for all section headings, taglines, category labels
=================================================================== */
.section-label {
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--accent-green);
    font-weight: 600;
    margin-bottom: 12px;
}

/* ===================================================================
   BUTTONS
   Unified button style — dark bg + white outline, green on hover
=================================================================== */
.btn {
    display: inline-block;
    padding: 16px 32px;
    font-size: 16px;
    font-weight: 600;
    color: #fff;
    background: var(--grey-700);
    border: 1px solid #fff;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s;
    margin-bottom: 14px;
}

.btn:hover {
    background: rgba(152, 196, 110, 0.8);
    color: #fff;
}

.btn.active,
.btn.current {
    background: var(--grey-700);
    color: #fff;
}

/* Override global link colors for button links */
a.btn,
a.btn:visited,
a.btn:hover,
a.btn:active {
    color: #fff;
    text-decoration: none;
}

.btn.small {
    padding: 8px 16px;
    font-size: var(--font-sm);
}

.fullwidth-btn {
    width: 100%;
    margin-top: var(--spacing-sm);
}

/* Small red × delete / remove buttons */
.btn-delete {
    width: 28px;
    height: 28px;
    background: var(--accent-red);
    border: 1px solid #fff;
    color: #fff;
    font-size: var(--font-base);
    font-weight: bold;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 0;
    flex-shrink: 0;
}

/* ===================================================================
   CARDS
=================================================================== */
.card {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    padding: var(--spacing-md);
    backdrop-filter: blur(6px);
    margin-bottom: var(--spacing-md);
    transition: border-color 0.2s ease;
}

.card:hover {
    border-color: var(--tile-outer-hover);
}

/* Inner card - use inside .card for nested tiles */
.card-inner {
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

/* Tile classes - semantic alternatives */
.tile {
    background: var(--tile-outer-bg);
    border: 1px solid var(--tile-outer-border);
    padding: var(--spacing-md);
    backdrop-filter: blur(6px);
    transition: border-color 0.2s ease;
}

.tile:hover {
    border-color: var(--tile-outer-hover);
}

.tile-inner {
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
    padding: var(--spacing-md);
}

.card.dark {
    background: var(--card-bg-dark);
    border-color: var(--card-border-dark);
}

.card.card-light {
    background: #ffffff;
    border-color: var(--grey-200);
}

.card.card-light h3 {
    color: var(--grey-800);
}

.card.card-light .artwork-name {
    color: var(--grey-400);
}

.other-files {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--grey-200);
}

.file-row-light {
    padding: 10px 0;
}

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

.file-link:hover {
    color: var(--accent-green);
    text-decoration: underline;
}

.artwork-footer {
    margin-top: 6px;
}

.file-row-light {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* ===================================================================
   SLIDER (Homepage)
=================================================================== */
.fade-slider {
    position: relative;
    width: 100%;
    height: 420px;
    overflow: hidden;
    margin-bottom: 20px;
}

.fade-slide {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 1.5s;
}

.fade-slide.active { opacity: 1; }

.fade-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.75);
}

.slide-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 1;
}

.slide-content {
    position: absolute;
    bottom: 110px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 700px;
    text-align: center;
    opacity: 0;
    transition: opacity 1.5s;
    z-index: 2;
}

.fade-slide.active .slide-content {
    opacity: 1;
}

/* ===================================================================
   FOOTER
=================================================================== */
footer {
    width: 100%;
    text-align: center;
    padding: 40px 0;
    margin-top: 40px;
    color: #ffffff;
    opacity: 0.8;
}

footer a {
    color: var(--accent-green);
}
footer a:hover {
    color: var(--accent-green);
}

/* ===================================================================
   TIDIO CHAT WIDGET
=================================================================== */
#tidio-chat-iframe {
    border-radius: 0 !important;
}

@media (max-width: 850px) {
    #tidio-chat-iframe {
        filter: drop-shadow(0 0 6px rgba(152, 196, 110, 0.6)) !important;
        animation: tidio-pulse 3s ease-in-out infinite !important;
    }
}

@keyframes tidio-pulse {
    0%, 100% { filter: drop-shadow(0 0 4px rgba(152, 196, 110, 0.4)) !important; }
    50% { filter: drop-shadow(0 0 10px rgba(152, 196, 110, 0.7)) !important; }
}

/* ===================================================================
   IMAGES
=================================================================== */
img {
    border: 1px solid var(--card-border);
}

/* ===================================================================
   RESPONSIVE — CUSTOMER NAV
=================================================================== */
@media (max-width: 850px) {
    .main-nav {
        display: none;
    }
    .mobile-fab {
        display: block !important;
    }
    .mobile-logo-header {
        display: block !important;
    }
    .nav-logo {
        display: none;
    }
    body {
        padding-top: 0;
    }
}

/* ===================================================================
   ADMIN TOOLBAR SYSTEM
=================================================================== */
.admin-toolbar {
    width: 100%;
    background: rgba(0,0,0,0.55);
    border-top: 1px solid rgba(255,255,255,0.2);
    padding: 14px 0;
    display: flex;
    justify-content: center;
    gap: 22px;
    position: sticky;
    top: 0;
    z-index: 1200;
}

.admin-toolbar .btn {
    margin: 0;
}

/* ===================================================================
   ADMIN BOTTOM NAVIGATION
=================================================================== */
.admin-bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(26,26,26,0.95);
    border-top: 1px solid rgba(255,255,255,0.15);
    z-index: 1500;
    padding: var(--spacing-sm) 0;
}

.admin-nav-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

.btn.admin-nav-btn {
    margin: 0;
    background: var(--grey-700);
    color: #fff;
    border: 1px solid #fff;
    padding: 10px 20px;
    min-width: 120px;
    text-align: center;
    font-size: var(--font-sm);
}

.btn.admin-nav-btn:hover,
.btn.admin-nav-btn.active,
.btn.admin-nav-btn.current {
    background: rgba(152, 196, 110, 0.8);
}

body.admin-page {
    padding-bottom: 70px;
}

/* Admin pages: dark inputs instead of white */
body.admin-page input,
body.admin-page textarea,
body.admin-page select {
    background: var(--grey-700);
    color: var(--text-primary);
    border-color: var(--grey-500);
}

body.admin-page input:focus,
body.admin-page textarea:focus,
body.admin-page select:focus {
    border-color: var(--accent-green);
}

body.admin-page input::placeholder,
body.admin-page textarea::placeholder {
    color: var(--text-muted);
}

/* Admin cards: no hover glow (they're containers, not clickable tiles) */
body.admin-page .card:hover {
    border-color: var(--card-border);
}

/* Admin header (presale edit view, etc.) */
.admin-header {
    margin-bottom: var(--spacing-md);
}

.admin-header h1 {
    margin-bottom: 6px;
}

.admin-header p {
    color: var(--text-muted);
    font-size: var(--font-sm);
    margin-bottom: 0;
}

/* ===================================================================
   JOBS LIST (Dashboard) - Card Layout
=================================================================== */
.jobs-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.job-card {
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
    padding: 12px 15px;
    cursor: pointer;
    display: grid;
    grid-template-columns: 20px 90px 200px auto 160px 40px;
    align-items: center;
    gap: 15px;
    min-height: 50px;
    transition: opacity 0.2s, transform 0.2s, background 0.2s;
}

.job-card.archived-job {
    grid-template-columns: 90px 200px auto 160px 40px;
    opacity: 0.8;
    border-left: 3px solid var(--grey-400);
}

.job-card:hover {
    background: var(--grey-600);
}

.job-card.dragging {
    opacity: 0.5;
    background: var(--grey-600);
}

.job-card.drag-over {
    border-top: 2px solid var(--accent-green);
}

.job-card.has-notes {
    border-left: 3px solid var(--accent-green);
}

.job-drag-handle {
    cursor: grab;
    color: var(--text-muted);
    font-size: var(--font-sm);
    user-select: none;
    display: flex;
    align-items: center;
    height: 34px;
}

.job-drag-handle:active {
    cursor: grabbing;
}

.job-ticket {
    font-weight: 600;
    font-size: var(--font-base);
    display: flex;
    align-items: center;
    height: 34px;
}

.job-customer {
    font-size: var(--font-base);
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    height: 34px;
}

.job-date {
    font-size: var(--font-base);
    color: var(--accent-green);
    display: flex;
    align-items: center;
    height: 34px;
}

.job-label {
    color: var(--accent-green);
    font-size: var(--font-base);
    margin-right: 5px;
}

.job-status {
    display: flex;
    align-items: center;
    height: 34px;
}

.job-delete {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    height: 34px;
}

/* Status Dropdown - size overrides for job cards */
.status-dropdown {
    height: 40px !important;
    padding: 10px 36px 10px 12px !important;
    margin: 0;
    box-sizing: border-box;
    vertical-align: middle;
    line-height: 1.4 !important;
    font-size: 14px !important;
}

/* Mobile: stack layout */
@media (max-width: 768px) {
    .job-card {
        grid-template-columns: 20px 1fr auto;
        grid-template-rows: auto auto auto auto;
        gap: 10px;
        position: relative;
    }
    
    .job-card.archived-job {
        grid-template-columns: 1fr auto;
        grid-template-rows: auto auto auto auto;
    }
    
    .job-drag-handle {
        grid-column: 1;
        grid-row: 1 / -1;
        align-self: flex-start;
        margin-top: 2px;
    }
    
    .job-card.archived-job .job-ticket,
    .job-ticket {
        grid-column: 2;
        grid-row: 1;
    }
    
    .job-card.archived-job .job-ticket {
        grid-column: 1;
    }
    
    .job-delete {
        grid-column: 3;
        grid-row: 1;
        position: absolute;
        top: 8px;
        right: 8px;
    }
    
    .job-card.archived-job .job-delete {
        grid-column: 2;
    }
    
    .job-customer {
        grid-column: 2 / -1;
        grid-row: 2;
        padding-right: 40px; /* Make room for delete button */
    }
    
    .job-card.archived-job .job-customer {
        grid-column: 1 / -1;
    }
    
    .job-date {
        grid-column: 2 / -1;
        grid-row: 3;
    }
    
    .job-card.archived-job .job-date {
        grid-column: 1 / -1;
    }
    
    .job-status {
        grid-column: 2 / -1;
        grid-row: 4;
        margin-top: 5px;
    }
    
    .job-card.archived-job .job-status {
        grid-column: 1 / -1;
    }
    
    .status-dropdown {
        width: 100%;
        max-width: 200px;
        height: 40px !important;
        font-size: 14px !important;
        padding: 10px 36px 10px 12px !important;
    }
}

/* Legacy badge styles (for non-dropdown use) */
.status-badge {
    display: inline-block;
    padding: 4px 10px;
    font-size: var(--font-xs);
    font-weight: 600;
    text-transform: uppercase;
}

.status-progress {
    background: rgba(255,210,127,0.2);
    color: var(--accent-green);
}

.status-pending {
    background: rgba(255,210,127,0.2);
    color: var(--accent-green);
}

.status-complete {
    background: rgba(152,196,110,0.2);
    color: var(--accent-green);
}

@media (max-width: 768px) {
    .admin-bottom-nav {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .admin-nav-inner {
        gap: 6px;
        flex-wrap: nowrap;
        justify-content: flex-start;
        padding: 0 var(--spacing-sm);
        min-width: max-content;
    }
    
    .admin-nav-btn {
        padding: 8px 14px;
        font-size: var(--font-xs);
        white-space: nowrap;
        flex-shrink: 0;
        min-width: 100px;
    }
    
    body.admin-page {
        padding-bottom: 70px;
    }

    /* Dashboard card mobile */
    body.admin-page .page-container {
        padding: 10px;
    }
    
    body.admin-page .card {
        margin: 10px auto;
        padding: 15px;
    }
    
    body.admin-page .card h2 {
        font-size: var(--font-md);
        margin-bottom: 15px;
    }
}

.admin-fab {
    display: none;
    position: fixed;
    top: 20px;
    right: 20px;
    font-size: var(--font-xl);
    color: white;
    cursor: pointer;
    z-index: 2000;
}

.admin-toolbar-menu {
    display: none;
    flex-direction: column;
    background: rgba(0,0,0,0.92);
    position: fixed;
    top: 0;
    right: 0;
    width: 70%;
    height: 100%;
    padding: 40px 20px;
    z-index: 1999;
}

.admin-toolbar-menu a {
    margin-bottom: 25px;
    color: #fff;
    font-size: var(--font-md);
}

@media (max-width: 850px) {
    .admin-toolbar {
        display: none !important;
    }
    .admin-fab {
        display: block !important;
    }
}

/* ===================================================================
   CUSTOMER PORTAL — PROOF SECTION
=================================================================== */
.proof-card {
    padding: 28px;
}

#proofContent img {
    width: 100%;
    max-width: 800px;
    display: block;
    margin: 0 auto;
    border: 1px solid var(--card-border);
}

/* ===================================================================
   CUSTOMER PORTAL — SIZE CHART
=================================================================== */
.sizes-card {
    padding: var(--spacing-md);
}

.sizes-title {
    color: #fff;
    margin-bottom: 18px;
    font-size: var(--font-lg);
    font-weight: 600;
}

.size-rows {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.size-row {
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
    padding: var(--spacing-md) var(--spacing-sm) var(--spacing-sm);
    transition: border-color 0.2s ease;
}

.size-row:hover {
    border-color: var(--tile-inner-hover);
}

.size-row-header {
    display: flex;
    gap: 12px;
    margin-bottom: 12px;
    align-items: center;
}

.size-row-header .style-picker-wrapper {
    position: relative;
    flex: 1;
}

.size-row-header .style-picker-wrapper input {
    width: 100%;
    height: 34px;
    margin-bottom: 0;
}

.size-row-header .btn-delete {
    width: 34px;
    height: 34px;
    margin: 0;
}

.size-row-selection {
    display: none;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.size-row-selection .style-info {
    flex: 1;
    color: #fff;
    font-weight: 600;
    font-size: var(--font-sm);
}

.size-row-selection .color-select {
    width: 200px;
    height: 34px;
    padding: 0 10px;
    flex-shrink: 0;
}

.style-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-top: none;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
}

.style-result {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    cursor: pointer;
}

.style-result:hover {
    background: var(--tile-inner-bg);
}

.style-result img {
    width: 40px;
    height: 40px;
    object-fit: cover;
}

.style-result-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.style-result-info strong {
    color: var(--text-primary);
}

.style-result-info span {
    color: var(--text-secondary);
    font-size: var(--font-xs);
}

.style-info {
    flex: 1;
    color: var(--text-primary);
    font-size: var(--font-sm);
}

.color-picker-wrapper label {
    font-size: var(--font-sm);
    color: var(--text-primary);
    white-space: nowrap;
}

.color-select {
    flex: 1;
    padding: 10px 12px;
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    color: var(--input-text);
    font-size: var(--font-sm);
    height: 40px;
}

.color-select:focus {
    outline: none;
    border-color: var(--accent-green);
}

.size-table-container {
    width: 100%;
    overflow-x: auto;
}

.size-availability {
    font-size: var(--font-xs);
    color: var(--text-secondary);
}

.availability {
    text-align: center;
    font-weight: bold;
}

.availability.available {
    color: var(--accent-green);
}

.availability.unavailable {
    color: var(--accent-red);
}

.style-loading,
.style-no-results,
.style-error {
    padding: 10px;
    text-align: center;
    color: var(--text-secondary);
    font-style: italic;
}

.size-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin-top: 10px;
    text-align: center;
}

.size-table th {
    font-size: var(--font-xs);
    text-transform: uppercase;
    color: #fff;
    font-weight: 600;
    padding: 8px 6px;
    background: var(--grey-600);
    border: 1px solid var(--tile-inner-border);
    border-bottom: none;
}

.size-table td {
    width: 60px;
    min-width: 60px;
    max-width: 60px;
    padding: 0;
    border: 1px solid var(--tile-inner-border);
}

.size-table input.qty {
    width: 100%;
    text-align: center;
    padding: 10px 6px;
    box-sizing: border-box;
    margin-bottom: 0;
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    color: var(--input-text);
    font-size: var(--font-base);
}

.size-table input.qty:focus {
    outline: none;
    border-color: var(--grey-300);
}

.row-total {
    width: 70px;
    min-width: 70px;
    max-width: 70px;
    font-weight: 600;
    color: var(--accent-green);
    background: rgba(152,196,110,0.1);
    padding: 10px 6px;
}

@media (max-width: 600px) {
    .size-table th,
    .size-table td {
        width: 42px;
        min-width: 42px;
    }
    .row-total {
        width: 50px;
        min-width: 50px;
        max-width: 50px;
    }
}

.grand-total-box {
    margin-top: var(--spacing-md);
    padding: 12px;
    background: rgba(152,196,110,0.1);
    border: 1px solid var(--accent-green);
    font-weight: 600;
    font-size: var(--font-base);
    color: var(--accent-green);
    text-align: center;
}

.sizes-saved-msg {
    margin-top: 12px;
    font-size: var(--font-sm);
    color: var(--accent-green);
    text-align: center;
}

/* ===================================================================
   INVOICE STATUS CARD
=================================================================== */
.invoice-status-card {
    padding: var(--spacing-md);
}

.invoice-status-content {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.invoice-info {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.invoice-number {
    font-family: monospace;
    font-size: var(--font-base);
    color: #fff;
}

.invoice-status-badge {
    padding: 4px 12px;
    border-radius: 4px;
    font-size: var(--font-xs);
    font-weight: 600;
    text-transform: uppercase;
}

.invoice-status-badge.sent {
    background: rgba(66, 153, 225, 0.2);
    color: #4299e5;
    border: 1px solid rgba(66, 153, 225, 0.4);
}

.invoice-status-badge.paid {
    background: rgba(152, 196, 110, 0.2);
    color: var(--accent-green);
    border: 1px solid rgba(152, 196, 110, 0.4);
}

.invoice-status-badge.open {
    background: rgba(236, 201, 75, 0.2);
    color: #ecc94b;
    border: 1px solid rgba(236, 201, 75, 0.4);
}

.invoice-status-badge.draft {
    background: rgba(160, 174, 192, 0.2);
    color: #a0aec0;
    border: 1px solid rgba(160, 174, 192, 0.4);
}

.invoice-status-badge.void,
.invoice-status-badge.uncollectible {
    background: rgba(214, 73, 73, 0.2);
    color: var(--accent-red);
    border: 1px solid rgba(214, 73, 73, 0.4);
}

.invoice-amount {
    font-size: var(--font-lg);
    font-weight: 600;
    color: #fff;
}

.invoice-actions {
    margin-top: 5px;
}

/* ===================================================================
   FINANCIALS CARD (Imported Tickets)
=================================================================== */
.financials-card {
    padding: var(--spacing-md);
}

.financials-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-bottom: 15px;
}

.financials-grid .form-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.financials-grid label {
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.financials-grid input,
.financials-grid select {
    height: 38px;
    padding: 0 10px;
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
    color: #fff;
    font-size: var(--font-base);
}

.financials-grid select {
    cursor: pointer;
}

.input-prefix {
    display: flex;
    align-items: center;
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
}

.input-prefix span {
    padding: 0 8px;
    color: var(--text-muted);
    font-size: var(--font-base);
    user-select: none;
}

.input-prefix input {
    border: none !important;
    background: transparent !important;
    flex: 1;
    min-width: 0;
}

.financials-profit {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-top: 1px solid var(--card-border);
    margin-bottom: 15px;
}

.financials-profit .detail-label {
    font-size: var(--font-base);
    font-weight: 600;
    color: var(--text-muted);
}

.financials-profit .detail-value {
    font-size: var(--font-lg);
    font-weight: 700;
}

.financials-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* ===================================================================
   CUSTOMER PORTAL — STICKY ACTION BAR
=================================================================== */
.sticky-actions {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 15px 18px;
    display: flex;
    gap: 12px;
    justify-content: center;
    z-index: 999;
    background: rgba(26,26,26,0.95);
    border-top: 1px solid rgba(255,255,255,0.15);
    backdrop-filter: blur(8px);
}

.sticky-actions .sticky-btn {
    flex: 1;
    max-width: 240px;
    text-align: center;
}

@media (max-width: 780px) {
    .sticky-actions {
        display: none;
    }
}

/* ===================================================================
   CUSTOMER PORTAL — MOBILE MENU ACTION BUTTONS
=================================================================== */
.mobile-menu .menu-actions {
    margin-top: 20px;
    border-top: 1px solid rgba(255,255,255,0.25);
    padding-top: 15px;
}

.mobile-menu .menu-actions a {
    display: block;
    padding: 12px 0;
    font-size: var(--font-md);
}
/* ===================================================================
   ADMIN — FILE LIST & DELETE BUTTONS
=================================================================== */

.file-name {
    cursor: pointer;
    color: var(--accent-green);
    text-decoration: none;
}

.file-name:hover {
    color: var(--accent-green);
}

/* ===================================================================
   ADMIN — PROOF PREVIEW
=================================================================== */

.proof-image {
    max-width: 100%;
    display: block;
    margin-top: 10px;
    border: 1px solid var(--card-border);
}

.proof-pdf-link {
    display: inline-block;
    margin-top: 10px;
}
/* Clean delete button styling for line items */
.del-cell {
    width: 50px;
    text-align: center;
    vertical-align: middle;
}

/* ======================================================
   SIZE TABLE STYLING — MTC THEME
   ====================================================== */

.size-table-block {
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
    padding: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    transition: border-color 0.2s ease;
}

.size-table-block:hover {
    border-color: var(--tile-inner-hover);
}

.size-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--font-base);
    margin-bottom: 14px;
    color: var(--light-grey);
}

.size-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
    gap: 10px;
}

.size-cell {
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    padding: 10px 8px;
    text-align: center;
}

.size-label {
    color: var(--accent-green);
    font-size: var(--font-sm);
    font-weight: 600;
    margin-bottom: 4px;
}

.size-value {
    font-size: var(--font-base);
    font-weight: 600;
    color: var(--light-grey);
}

/* ======================================================
   EDITOR MODE
   ====================================================== */

.size-edit-block {
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
    padding: var(--spacing-sm);
    transition: border-color 0.2s ease;
}

.size-edit-block:hover {
    border-color: var(--tile-inner-hover);
}

.size-edit-block label {
    display: block;
    font-size: var(--font-sm);
    color: var(--light-grey);
    margin-bottom: 4px;
}

.size-edit-block input[type="text"],
size-edit-block input[type="number"] {
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  color: var(--input-text);
  padding: 6px;
  width: 100%;
}

.size-edit-block input[type="number"] {
    text-align: center;
}

.size-edit-block div div {
    min-width: 65px;
}
/* Inline field errors */
input.invalid,
select.invalid,
textarea.invalid,
.invalid {
  border: 2px solid var(--accent-red) !important;
  margin-bottom: 4px;
}

input.invalid:focus,
select.invalid:focus,
textarea.invalid:focus {
  border-color: var(--accent-red) !important;
  outline: none;
}

.error-msg {
  color: var(--accent-red);
  font-size: var(--font-sm);
  margin-top: 2px;
  margin-bottom: 12px;
}

/* ── Field hints (focus-reveal) ── */
.field-hint-wrap {
  position: relative;
  padding-bottom: 22px; /* reserve space for hint/error below field */
}

/* Error messages inside hint wraps: absolute, same spot as hint */
.field-hint-wrap > .error-msg {
  position: absolute;
  bottom: 2px;
  left: 0;
  margin: 0;
}

.field-hint-wrap > input,
.field-hint-wrap > select,
.field-hint-wrap > textarea {
  margin-bottom: 0;
}

.field-hint {
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: var(--font-xs);
  color: var(--accent-green);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
  white-space: nowrap;
}

.field-hint-wrap:focus-within > .field-hint {
  opacity: 1;
}

/* Hide hint when an error message is present */
.field-hint-wrap > .error-msg ~ .field-hint,
.field-hint-wrap:has(> .error-msg) > .field-hint {
  opacity: 0 !important;
}

/* Inside .form-row the hint anchors to each .form-group */
.form-row .field-hint-wrap {
  position: relative;
}

/* Mobile: same approach, below field */
@media (max-width: 850px) {
  .field-hint {
    white-space: normal;
  }
}

/* Form loading indicator */
.form-loading {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: var(--spacing-sm) 0;
  padding: 12px 16px;
  font-size: var(--font-base);
  color: #fff;
  background: rgba(0,0,0,0.5);
  border-radius: 6px;
}

.form-loading.hidden {
  display: none;
}

.spinner {
  width: 22px;
  height: 22px;
  border: 3px solid rgba(255,255,255,0.3);
  border-top-color: var(--accent-green);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

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

.tax-exempt-below {
  margin-top: 10px;
}

.tax-exempt-label {
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  font-size: var(--font-sm);
  color: var(--light-grey);
}

.tax-exempt-label input {
  margin: 0;
}

/* ===================================================================
   TICKET DETAIL ROWS
=================================================================== */

/* Ticket Info Card - enhanced styling */
.ticket-detail-page .card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  overflow: hidden;
  transition: border-color 0.2s ease;
}

.ticket-detail-page .card:hover {
  border-color: var(--tile-outer-hover) !important;
}

.ticket-detail-page .card h3 {
  background: var(--grey-700);
  color: var(--accent-green);
  font-size: var(--font-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 12px var(--spacing-md);
  margin: calc(-1 * var(--spacing-md));
  margin-bottom: var(--spacing-md);
}

.ticket-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-sm) var(--spacing-lg);
}

@media (max-width: 768px) {
  .ticket-info-grid {
    grid-template-columns: 1fr;
  }
}

.detail-row {
  display: flex;
  flex-direction: column;
  padding: 10px 14px;
  background: var(--tile-inner-bg);
  border-left: 3px solid var(--accent-green);
  transition: background 0.2s;
}

.detail-row:hover {
  background: var(--grey-600);
}

.detail-label {
  color: var(--accent-green);
  font-size: var(--font-xs);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 4px;
  font-weight: 600;
}

.detail-value {
  color: #ffffff;
  font-size: var(--font-base);
  font-weight: 500;
}

.editable-field {
  display: flex;
  align-items: center;
  gap: 8px;
}

.edit-field-btn {
  background: none;
  border: none;
  color: var(--accent-green);
  cursor: pointer;
  font-size: 14px;
  padding: 0;
  opacity: 0.6;
  transition: opacity 0.2s;
}

.edit-field-btn:hover {
  opacity: 1;
}

.inline-edit-input {
  background: var(--tile-inner-bg);
  border: 1px solid var(--accent-green);
  color: #fff;
  padding: 4px 8px;
  font-size: var(--font-base);
  flex: 1;
  min-width: 0;
}

/* Full-width notes row */
.detail-row-full {
  margin-top: var(--spacing-sm);
  padding-top: var(--spacing-sm);
  border-top: 1px solid var(--card-border);
}

/* Ticket Detail Page Layout - Base */
.ticket-detail-page .page-title {
  margin-bottom: var(--spacing-lg);
  font-size: var(--font-lg);
  color: #fff;
}

.sizes-actions {
  display: flex;
  gap: 12px;
  margin-top: var(--spacing-md);
}

.sizes-actions .btn {
  flex: 1;
  margin-bottom: 0;
}

/* ===================================================================
   TICKET DETAIL - MOBILE RESPONSIVE
=================================================================== */
@media (max-width: 768px) {
  .ticket-detail-page {
    padding: 10px;
    padding-bottom: 100px;
  }

  .ticket-detail-page .page-title {
    font-size: var(--font-md);
    margin-bottom: var(--spacing-md);
    text-align: center;
  }

  .ticket-detail-page .card {
    padding: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
  }

  .ticket-detail-page .card h3 {
    font-size: var(--font-sm);
    padding: 10px var(--spacing-sm);
    margin: calc(-1 * var(--spacing-sm));
    margin-bottom: var(--spacing-sm);
  }

  .ticket-info-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-xs);
  }

  .detail-row {
    padding: 8px 10px;
    border-left-width: 2px;
  }

  .detail-label {
    font-size: var(--font-xs);
  }

  .detail-value {
    font-size: var(--font-sm);
  }

  /* Sizes card mobile */
  .sizes-card {
    padding: var(--spacing-sm);
  }

  .financials-grid {
    grid-template-columns: 1fr;
  }

  .size-row-header .style-picker-wrapper {
    flex: 1;
  }

  .size-row-selection {
    flex-wrap: wrap;
    gap: 8px;
  }

  .size-row-selection .style-info {
    width: 100%;
  }

  .size-row-selection .color-select {
    width: 100%;
  }

  .ticket-detail-page .btn-delete {
    position: absolute;
    top: 8px;
    right: 8px;
  }

  .size-row {
    position: relative;
    padding-right: 40px;
  }

  /* Mobile size table - convert to grid */
  .size-table-container {
    overflow-x: visible;
  }

  .size-table {
    display: block;
    width: 100%;
  }

  .size-table tr.size-headers {
    display: none;
  }

  .size-table tr.size-inputs {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
    width: 100%;
  }

  .size-table td {
    width: auto;
    min-width: auto;
    max-width: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    border: none;
  }

  .size-table td::before {
    content: attr(data-label);
    font-size: var(--font-xs);
    text-transform: uppercase;
    color: #fff;
    font-weight: 600;
    padding: 6px 8px;
    background: var(--grey-600);
    border: 1px solid var(--tile-inner-border);
    border-bottom: none;
    width: 100%;
    box-sizing: border-box;
    text-align: center;
    display: block;
    margin-bottom: 0;
  }

  .size-table input.qty {
    width: 100%;
    padding: 10px 4px;
    font-size: var(--font-base);
    border: 1px solid var(--input-border);
  }

  .size-table td.row-total {
    grid-column: span 5;
    flex-direction: row;
    justify-content: center;
    gap: 8px;
    padding: 12px;
    background: rgba(152,196,110,0.1);
    border: 1px solid var(--accent-green);
    margin-top: 8px;
    font-size: var(--font-sm);
    color: var(--accent-green);
    font-weight: 600;
  }

  .size-table td.row-total::before {
    content: "Row Total:";
    margin-bottom: 0;
    background: none;
    border: none;
    padding: 0;
    width: auto;
    color: var(--accent-green);
  }

  .sizes-actions {
    flex-direction: column;
    gap: 8px;
  }

  .sizes-actions .btn {
    width: 100%;
  }

  /* Artwork grid mobile */
  .artwork-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
  }

  .artwork-img {
    max-width: 100%;
  }

  /* Files section mobile */
  .file-row-admin {
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px 0;
  }

  .file-name {
    flex-basis: 100%;
    word-break: break-all;
  }
}

@media (max-width: 480px) {
  .ticket-detail-page {
    padding: 8px;
    padding-bottom: 90px;
  }

  /* Smaller screens: 4 columns instead of 5 */
  .size-table tr.size-inputs {
    grid-template-columns: repeat(4, 1fr);
  }

  .size-table td.row-total {
    grid-column: span 4;
  }

  .artwork-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ===================================================================
   ARTWORK / FILE GRID
=================================================================== */
.artwork-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: var(--spacing-md);
  margin-top: var(--spacing-sm);
}

.artwork-item {
  position: relative;
  text-align: center;
}

.artwork-item .btn-delete {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 10;
  background: var(--accent-red);
  border: none;
}

.artwork-img {
  width: 100%;
  max-width: 200px;
  height: auto;
  border: 1px solid var(--card-border);
  cursor: pointer;
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.artwork-img:hover {
  transform: scale(1.02);
  border-color: var(--accent-green);
}

.artwork-name {
  font-size: var(--font-sm);
  color: var(--light-grey);
  margin-top: 6px;
  word-break: break-all;
}

.file-row-admin {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
}

.file-row-admin .file-link {
  flex: 1;
  color: var(--accent-green);
  text-decoration: none;
  font-size: var(--font-sm);
  word-break: break-all;
}

.file-row-admin .file-link:hover {
  color: var(--accent-green);
}

.field-row {
  margin-bottom: 6px;
}

.field-group {
  margin: 10px 0;
  padding-left: var(--spacing-sm);
  border-left: 2px solid var(--dark-grey);
}

.field-group-title {
  font-weight: 600;
  margin-bottom: 4px;
}

.field-sub-row {
  font-size: var(--font-sm);
  color: var(--grey-200);
  margin-left: 8px;
}

.field-sub-row .label {
  color: var(--grey-300);
  margin-right: 6px;
}

/* ===================================================================
   IMAGE LIGHTBOX
=================================================================== */
.lightbox-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  cursor: zoom-out;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease;
}

.lightbox-overlay.active {
  opacity: 1;
  visibility: visible;
}

.lightbox-overlay img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  box-shadow: 0 0 40px rgba(0, 0, 0, 0.5);
}

.lightbox-close {
  position: absolute;
  top: 20px;
  right: 30px;
  color: #fff;
  font-size: 36px;
  font-weight: 300;
  cursor: pointer;
  opacity: 0.7;
  transition: opacity 0.2s;
}

.lightbox-close:hover {
  opacity: 1;
}

/* Make proof images clickable */
.proof-image {
  cursor: zoom-in;
  transition: opacity 0.2s;
}

.proof-image:hover {
  opacity: 0.9;
}

/* ===================================================================
   INVOICE MODAL
=================================================================== */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  padding: 20px;
}

.modal-content {
  background: var(--grey-800);
  border: 1px solid var(--grey-600);
  max-width: 500px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  padding: 24px 28px;
}

/* Invoice Modal - wider and full control */
.modal-content.invoice-modal {
  max-width: 800px !important;
  width: calc(100vw - 40px) !important;
}

.invoice-modal * {
  box-sizing: border-box;
}

.invoice-modal .modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 30px;
  border-bottom: 1px solid var(--grey-600);
  background: var(--grey-800);
}

.invoice-modal .modal-header h3 {
  margin: 0;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
}

.invoice-modal .modal-close {
  background: none;
  border: none;
  color: var(--grey-400);
  font-size: 28px;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}

.invoice-modal .modal-close:hover {
  color: #fff;
}

/* Invoice Form */
.invoice-modal .invoice-form {
  padding: 0;
}

.invoice-modal .invoice-section {
  padding: 25px 30px;
  border-bottom: 1px solid var(--grey-700);
}

.invoice-modal .invoice-section h4 {
  color: var(--grey-300);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0 0 20px 0;
  font-weight: 600;
}

.invoice-modal .section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.invoice-modal .section-header h4 {
  margin-bottom: 0;
}

/* Form Grid */
.invoice-modal .form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 25px;
}

.invoice-modal .form-grid.address-grid {
  grid-template-columns: 2fr 1fr 1fr;
  margin-top: 15px;
}

.invoice-modal .form-row {
  margin-bottom: 0;
}

.invoice-modal .form-row label {
  display: block;
  margin-bottom: 8px;
  color: var(--grey-300);
  font-size: 14px;
  font-weight: 500;
}

.invoice-modal input[type="text"],
.invoice-modal input[type="email"],
.invoice-modal input[type="number"] {
  width: 100% !important;
  padding: 12px 14px !important;
  background: var(--grey-700) !important;
  border: 1px solid var(--grey-600) !important;
  color: #fff !important;
  font-size: 15px !important;
  border-radius: 0 !important;
  height: auto !important;
  min-width: 0 !important;
}

.invoice-modal input:focus {
  outline: none !important;
  border-color: var(--accent-green) !important;
}

.invoice-modal input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  margin-right: 10px;
  cursor: pointer;
}

/* Test Mode Banner */
.invoice-modal .test-mode-banner {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 15px 30px;
  background: rgba(214, 73, 73, 0.1);
  border-bottom: 1px solid var(--grey-600);
}

.invoice-modal .test-mode-banner label {
  display: flex;
  align-items: center;
  cursor: pointer;
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 0;
}

.invoice-modal .test-mode-banner label span {
  color: var(--accent-red);
}

.invoice-modal .test-mode-hint {
  color: var(--grey-400);
  font-size: 13px;
}

/* Line Items */
.invoice-modal .line-items-header {
  display: flex;
  gap: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--grey-700);
  margin-bottom: 15px;
}

.invoice-modal .line-items-header span {
  font-size: 11px;
  color: var(--grey-400);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}

.invoice-modal .line-items-header .col-desc {
  flex: 1;
  min-width: 200px;
}

.invoice-modal .line-items-header .col-amount {
  width: 140px;
  flex-shrink: 0;
}

.invoice-modal .line-items-header .col-action {
  width: 36px;
  flex-shrink: 0;
}

.invoice-modal .invoice-line-item {
  display: flex;
  gap: 15px;
  margin-bottom: 12px;
  align-items: center;
}

.invoice-modal .invoice-line-item .line-desc {
  flex: 1;
  min-width: 200px;
}

.invoice-modal .invoice-line-item .line-amount {
  width: 140px !important;
  flex-shrink: 0;
}

.invoice-modal .btn-remove-line {
  background: transparent;
  border: 1px solid var(--grey-600);
  color: var(--grey-400);
  width: 36px;
  height: 36px;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.invoice-modal .btn-remove-line:hover {
  background: var(--accent-red);
  border-color: var(--accent-red);
  color: #fff;
}

/* Total Bar */
.invoice-modal .invoice-total-bar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 25px;
  padding: 20px 30px;
  background: var(--grey-700);
}

.invoice-modal .total-label {
  color: var(--grey-300);
  font-size: 15px;
}

.invoice-modal .total-amount {
  font-size: 24px;
  font-weight: 700;
  color: #fff;
}

.invoice-modal .modal-actions {
  display: flex;
  gap: 15px;
  justify-content: flex-end;
  padding: 20px 30px;
  border-top: 1px solid var(--grey-600);
  background: var(--grey-800);
}

/* Tax Toggle Buttons */
.invoice-modal .toggle-buttons {
  display: flex;
  gap: 0;
}

.invoice-modal .toggle-btn {
  flex: 1;
  padding: 12px 20px;
  border: 1px solid var(--grey-600);
  background: var(--grey-700);
  color: var(--grey-400);
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  transition: all 0.15s ease;
}

.invoice-modal .toggle-btn:first-child {
  border-right: none;
}

.invoice-modal .toggle-btn:hover {
  background: var(--grey-600);
  color: #fff;
}

.invoice-modal .toggle-btn.active {
  background: var(--grey-500);
  color: #fff;
  border-color: var(--grey-500);
  font-weight: 600;
}

@media (max-width: 700px) {
  .invoice-modal .form-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .invoice-modal .form-grid.address-grid {
    grid-template-columns: 1fr 1fr;
  }
  
  .invoice-modal .form-grid.address-grid .form-row:first-child {
    grid-column: 1 / -1;
  }
  
  .invoice-modal .line-items-header .col-desc {
    min-width: 120px;
  }
  
  .invoice-modal .invoice-line-item .line-desc {
    min-width: 120px;
  }
}

/* ===================================================================
   S&S STYLE PICKER
=================================================================== */
.style-picker-wrapper {
  position: relative;
}

.style-results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--card-bg-dark);
  border: 1px solid var(--card-border-dark);
  max-height: 350px;
  overflow-y: auto;
  z-index: 100;
  display: none;
}

.style-loading,
.style-no-results {
  padding: 15px;
  text-align: center;
  color: var(--dark-grey);
}

.selected-style {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  margin-top: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
  padding: var(--spacing-md);
  background: var(--grey-800);
  border: 1px solid var(--border-color);
}

.selected-style img {
  width: 70px;
  height: 70px;
  object-fit: contain;
  background: #fff;
  padding: 4px;
}

.selected-style .style-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.selected-style .style-info strong {
  color: var(--accent-green);
  font-size: var(--font-base);
  font-weight: 600;
}

.selected-style .style-info span {
  color: var(--light-grey);
  font-size: var(--font-sm);
  line-height: 1.4;
}

/* Garment rows container */
.garment-row {
  margin-bottom: var(--spacing-md);
}

.garment-row:last-child {
  margin-bottom: 0;
}

.wholesale-price {
  display: block;
  margin-top: 4px;
  color: var(--accent-green);
  font-weight: 600;
  font-size: var(--font-sm);
}

/* Line items table */
.line-items-table {
  width: 100%;
  border-collapse: collapse;
}

.line-items-table th {
  padding: 8px 6px;
  text-align: left;
  font-size: var(--font-sm);
  color: #fff;
  font-weight: 500;
}

.line-items-table td {
  padding: 6px;
  vertical-align: middle;
}

.line-items-table td input {
  width: 100%;
  box-sizing: border-box;
  background: #fff;
  color: var(--input-text);
  border: 1px solid var(--input-border);
}

.line-items-table td input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.line-items-table td input[type="number"]::-webkit-inner-spin-button,
.line-items-table td input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: inner-spin-button;
  opacity: 1;
  height: auto;
}

.line-items-table td.del-cell {
  text-align: center;
  width: 40px;
  vertical-align: middle;
}

.line-items-table .btn-delete {
  vertical-align: middle;
}

/* ===================================================================
   ADMIN PAGES - MOBILE RESPONSIVE ENHANCEMENTS
=================================================================== */

/* Option Card Headers */
.option-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.option-card-header h3 {
  margin-bottom: 0;
}

/* Totals Row - ensure proper layout */
.totals-row {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 12px;
}

.totals-row label {
  min-width: 100px;
  margin-bottom: 0;
}

.totals-row input,
.totals-row select {
  flex: 1;
  max-width: 200px;
}

/* Page Header Row - flex layout for title + action buttons */
.page-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
  margin-bottom: var(--spacing-md);
}

.page-header-row h2 {
  margin-bottom: 0;
}

/* ===================================================================
   ADMIN MOBILE RESPONSIVE (max-width: 768px)
=================================================================== */
@media (max-width: 768px) {
  /* Page header stacks on mobile */
  .page-header-row {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .page-header-row .btn {
    width: 100%;
  }
  
  /* === GENERAL ADMIN PAGE FIXES === */
  body.admin-page .page-container {
    padding: var(--spacing-sm);
    max-width: 100%;
  }
  
  body.admin-page .card {
    margin: var(--spacing-sm) 0;
    padding: var(--spacing-sm);
  }
  
  body.admin-page .card h2,
  body.admin-page .card h3 {
    font-size: var(--font-md);
    margin-bottom: var(--spacing-sm);
  }
  
  /* === LINE ITEMS TABLE - MOBILE CARD LAYOUT === */
  .line-items-table {
    display: block;
    width: 100%;
  }
  
  .line-items-table thead {
    display: none;
  }
  
  .line-items-table tbody {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  
  .line-items-table tr {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    padding: 12px;
    background: var(--tile-inner-bg);
    border: 1px solid var(--tile-inner-border);
  }
  
  .line-items-table td {
    padding: 4px 0;
    border: none;
  }
  
  /* Description spans full width on first row */
  .line-items-table td:first-child {
    grid-column: 1 / -1;
    margin-bottom: 8px;
  }
  
  .line-items-table td:first-child input {
    width: 100%;
    font-size: var(--font-base);
  }
  
  /* Qty, Rate, Total in row */
  .line-items-table td:nth-child(2),
  .line-items-table td:nth-child(3),
  .line-items-table td:nth-child(4) {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  
  .line-items-table td:nth-child(2)::before {
    content: 'Qty';
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 4px;
  }
  
  .line-items-table td:nth-child(3)::before {
    content: 'Rate';
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 4px;
  }
  
  .line-items-table td:nth-child(4)::before {
    content: 'Total';
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 4px;
  }
  
  .line-items-table td:nth-child(2) input,
  .line-items-table td:nth-child(3) input,
  .line-items-table td:nth-child(4) input {
    width: 80px;
  }
  
  /* Delete button */
  .line-items-table td.del-cell {
    grid-column: 2;
    grid-row: 1;
    width: auto;
    justify-self: end;
    align-self: start;
  }
  
  /* === TOTALS ROW - MOBILE === */
  .totals-row {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }
  
  .totals-row label {
    min-width: unset;
    font-size: var(--font-sm);
  }
  
  .totals-row input,
  .totals-row select {
    max-width: 100%;
    width: 100%;
  }
  
  /* === GARMENT PICKER - MOBILE === */
  .selected-style {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm);
  }
  
  .selected-style img {
    width: 60px;
    height: 60px;
  }
  
  .selected-style .style-info {
    width: 100%;
  }
  
  .selected-style .btn-delete {
    align-self: flex-end;
    margin-top: -50px;
  }
  
  .garment-row .style-picker-wrapper input {
    font-size: var(--font-base);
    padding: 12px;
  }
  
  /* === FORM INPUTS - MOBILE === */
  body.admin-page input[type="text"],
  body.admin-page input[type="email"],
  body.admin-page input[type="tel"],
  body.admin-page input[type="number"],
  body.admin-page input[type="date"],
  body.admin-page select,
  body.admin-page textarea {
    font-size: 16px; /* Prevents iOS zoom on focus */
    padding: 12px;
  }
  
  body.admin-page label {
    font-size: var(--font-sm);
    margin-bottom: 4px;
  }
  
  /* === BUTTONS - MOBILE === */
  body.admin-page .btn {
    padding: 12px 16px;
    font-size: var(--font-sm);
    width: 100%;
    margin-bottom: 8px;
  }
  
  body.admin-page .btn + .btn {
    margin-left: 0;
  }
  
  /* Keep inline buttons side by side where needed */
  body.admin-page .sizes-actions {
    flex-direction: row;
  }
  
  body.admin-page .sizes-actions .btn {
    width: auto;
    flex: 1;
    margin-bottom: 0;
  }
  
  /* === INVOICE MODAL - MOBILE === */
  .modal-content.invoice-modal {
    max-width: 100% !important;
    width: 100% !important;
    max-height: 100%;
    height: 100%;
    border: none;
  }
  
  .invoice-modal .modal-header {
    padding: 15px;
  }
  
  .invoice-modal .invoice-section {
    padding: 15px;
  }
  
  .invoice-modal .test-mode-banner {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 12px 15px;
  }
  
  .invoice-modal .toggle-buttons {
    flex-direction: column;
    width: 100%;
  }
  
  .invoice-modal .toggle-btn {
    border: 1px solid var(--grey-600) !important;
  }
  
  .invoice-modal .toggle-btn:first-child {
    border-right: 1px solid var(--grey-600) !important;
    border-bottom: none !important;
  }
  
  .invoice-modal .line-items-header {
    display: none;
  }
  
  .invoice-modal .invoice-line-item {
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    background: var(--grey-700);
    margin-bottom: 10px;
  }
  
  .invoice-modal .invoice-line-item .line-desc {
    min-width: 100%;
  }
  
  .invoice-modal .invoice-line-item .line-desc::before {
    content: 'Description';
    display: block;
    font-size: var(--font-xs);
    color: var(--grey-400);
    text-transform: uppercase;
    margin-bottom: 4px;
  }
  
  .invoice-modal .invoice-line-item .line-amount {
    width: 100% !important;
  }
  
  .invoice-modal .invoice-line-item .line-amount::before {
    content: 'Amount';
    display: block;
    font-size: var(--font-xs);
    color: var(--grey-400);
    text-transform: uppercase;
    margin-bottom: 4px;
  }
  
  .invoice-modal .btn-remove-line {
    align-self: flex-end;
    margin-top: -60px;
  }
  
  .invoice-modal .invoice-total-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 15px;
  }
  
  .invoice-modal .modal-actions {
    flex-direction: column;
    gap: 10px;
    padding: 15px;
  }
  
  .invoice-modal .modal-actions .btn {
    width: 100%;
    margin: 0;
  }
}

/* ===================================================================
   ADMIN MOBILE - SMALLER SCREENS (max-width: 480px)
=================================================================== */
@media (max-width: 480px) {
  body.admin-page .page-container {
    padding: 8px;
  }
  
  body.admin-page .card {
    padding: 10px;
    margin: 8px 0;
  }
  
  body.admin-page .card h2,
  body.admin-page .card h3 {
    font-size: var(--font-base);
  }
  
  /* Line items even more compact */
  .line-items-table tr {
    padding: 10px;
    gap: 6px;
  }
  
  .line-items-table td:nth-child(2) input,
  .line-items-table td:nth-child(3) input,
  .line-items-table td:nth-child(4) input {
    width: 70px;
  }
  
  /* Admin nav */
  .admin-nav-btn {
    padding: 6px 10px !important;
    min-width: 80px !important;
    font-size: 11px !important;
  }
  
  /* Smaller headings */
  body.admin-page h1 {
    font-size: var(--font-lg);
  }
}

/* ===================================================================
   ARTICLES ADMIN - MOBILE RESPONSIVE
=================================================================== */
@media (max-width: 768px) {
  .articles-admin {
    padding: 0 10px;
    margin: 20px auto;
  }
  
  .admin-section-header {
    flex-direction: column;
    gap: 15px;
    align-items: flex-start;
  }
  
  .admin-section-header h1 {
    font-size: var(--font-lg);
  }
  
  .article-form {
    padding: 15px;
    margin-bottom: 20px;
  }
  
  .article-form h2 {
    font-size: var(--font-md);
    margin-bottom: 15px;
  }
  
  .form-row {
    grid-template-columns: 1fr !important;
    gap: 0;
  }
  
  .form-group input[type="text"],
  .form-group textarea {
    padding: 10px 12px;
    font-size: 16px; /* Prevents iOS zoom */
  }
  
  .form-group textarea {
    min-height: 200px;
  }
  
  .form-actions {
    flex-direction: column;
    gap: 10px;
  }
  
  .form-actions .btn {
    width: 100%;
  }
  
  .article-list-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 15px;
  }
  
  .article-list-info {
    width: 100%;
  }
  
  .article-list-info h4 {
    font-size: var(--font-base);
  }
  
  .article-list-actions {
    width: 100%;
    display: flex;
    gap: 10px;
  }
  
  .article-list-actions .btn {
    flex: 1;
  }
}

/* ===================================================================
   ADDITIONAL ADMIN MOBILE FIXES
=================================================================== */
@media (max-width: 768px) {
  /* Fix inline flex headers that can overflow */
  body.admin-page [style*="display:flex"][style*="justify-content:space-between"],
  body.admin-page [style*="display: flex"][style*="justify-content: space-between"] {
    flex-wrap: wrap !important;
    gap: 12px !important;
  }
  
  /* Custom Email Card Mobile */
  .custom-email-card {
    padding: var(--spacing-sm);
  }
  
  .custom-email-card h3 {
    font-size: var(--font-sm);
  }
  
  .custom-email-card .email-form input,
  .custom-email-card .email-form textarea {
    font-size: 16px; /* Prevents iOS zoom */
  }
  
  .custom-email-card .email-form .btn {
    width: 100%;
  }
  
  /* Proof Card Mobile */
  .proof-card {
    padding: var(--spacing-sm);
  }
  
  #proofContent img,
  #proofPreview img {
    max-width: 100%;
    height: auto;
  }
  
  /* Invoice Status Card Mobile */
  .invoice-status-card {
    padding: var(--spacing-sm);
  }
  
  .invoice-status-content {
    gap: 8px;
  }
  
  .invoice-info {
    flex-wrap: wrap;
    gap: 8px;
  }
  
  /* Modal Overlay - Better mobile handling */
  .modal-overlay {
    padding: 0 !important;
  }
  
  .modal-content {
    max-width: 100% !important;
    width: 100% !important;
    max-height: 100vh;
    border-radius: 0;
    margin: 0;
  }
  
  /* Proof Modal Mobile */
  #proofModal .modal-content {
    padding: 15px;
  }
  
  #proofModal .form-row {
    margin-bottom: 12px;
  }
  
  #proofModal .modal-actions {
    flex-direction: column;
    gap: 10px;
  }
  
  #proofModal .modal-actions .btn {
    width: 100%;
  }
  
  /* Sizes table horizontal scroll indicator */
  .size-table-container {
    position: relative;
  }
  
  .size-table-container::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 20px;
    height: 100%;
    background: linear-gradient(to left, rgba(0,0,0,0.3), transparent);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
  }
  
  .size-table-container.has-scroll::after {
    opacity: 1;
  }
}

/* ===================================================================
   TOUCH-FRIENDLY ENHANCEMENTS
=================================================================== */
@media (max-width: 768px) {
  /* Larger touch targets for checkboxes */
  body.admin-page input[type="checkbox"] {
    width: 22px !important;
    height: 22px !important;
  }
  
  /* Better spacing for clickable rows */
  .job-card {
    min-height: 60px;
    padding: 15px;
  }
  
  /* Delete buttons easier to tap */
  .btn-delete,
  .btn-remove-line {
    min-width: 36px !important;
    min-height: 36px !important;
  }
}

/* ===================================================================
   UTILITY CLASSES
=================================================================== */

/* Display */
.d-none        { display: none; }
.d-inline      { display: inline; }
.d-block       { display: block; }

/* Text alignment */
.text-center   { text-align: center; }
.text-right    { text-align: right; }
.text-left     { text-align: left; }

/* Overflow */
.overflow-x-auto { overflow-x: auto; }

/* Width */
.w-full        { width: 100%; }

/* Font weight */
.font-bold     { font-weight: bold; }
.font-600      { font-weight: 600; }

/* Colors */
.text-light    { color: var(--light-grey); }
.text-white    { color: #fff; }
.color-muted   { color: var(--text-muted); }
.color-secondary { color: var(--text-secondary); }
.color-primary { color: var(--text-primary); }
.text-green    { color: var(--accent-green); }
.text-red      { color: var(--accent-red); }

/* Margin top */
.mt-0   { margin-top: 0; }

/* Margin bottom */
.mb-0   { margin-bottom: 0; }
.m-0    { margin: 0; }

/* Centering */
.mx-auto { margin-left: auto; margin-right: auto; }

/* Card width modifiers */
.card-narrow  { max-width: 400px; margin-left: auto; margin-right: auto; }
.card-medium  { max-width: 500px; margin-left: auto; margin-right: auto; }
.card-standard { max-width: 600px; }
.card-wide    { max-width: 900px; }
.card-xl      { max-width: 1000px; }
.card-xxl     { max-width: 1100px; }
.card-full    { max-width: 1200px; }
.card-centered { margin: 40px auto; }
.card-auto-center { margin: 30px auto; }

/* Flex helpers */
.flex-row      { display: flex; gap: 8px; }
.flex-row-wrap { display: flex; gap: 15px; flex-wrap: wrap; }
.flex-between  { display: flex; justify-content: space-between; align-items: center; }
.flex-center   { display: flex; align-items: center; justify-content: center; }

/* Page section spacing */
.page-section-spacing { margin-top: 60px; margin-bottom: 80px; }

/* Loading / status messages */
.loading-message { text-align: center; padding: 40px; color: var(--text-secondary); }
.status-message  { margin-top: 15px; text-align: center; }
.msg-info  { color: var(--accent-blue); }
.msg-success { color: var(--accent-green); }
.msg-error { color: var(--accent-red); }

/* Small muted text */
.hint-text { color: var(--text-muted); font-size: var(--font-sm); margin-bottom: var(--spacing-md); }
.hint-xs   { font-size: var(--font-xs); color: var(--text-muted); }
.inline-hint { font-size: var(--font-xs); color: var(--text-muted); padding: var(--spacing-sm); }
.inline-hint-error { font-size: var(--font-xs); color: var(--accent-red); padding: var(--spacing-sm); }

/* ===================================================================
   FINANCIAL SUMMARY PAGE
=================================================================== */
.fin-heading       { margin-bottom: 30px; color: var(--text-primary); }
.fin-filters       { margin-bottom: 30px; padding: 20px; background: var(--tile-bg); border-radius: 8px; }
.fin-filter-grid   { display: grid; grid-template-columns: auto 1fr 1fr auto; gap: 20px; align-items: end; }
.fin-filter-label  { display: block; margin-bottom: 8px; font-weight: 600; }
.fin-filter-input  { width: 100%; padding: 10px; background: #ffffff !important; border: 1px solid #cccccc !important; color: #333333 !important; border-radius: 4px; font-size: 16px; }
.fin-summary-grid  { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; margin-bottom: 30px; }

.summary-card       { color: white; padding: 20px; border-radius: 8px; text-align: center; }
.summary-card--blue   { background: linear-gradient(135deg, var(--accent-blue), #4a90e2); }
.summary-card--green  { background: linear-gradient(135deg, var(--accent-green), #50c878); }
.summary-card--orange { background: linear-gradient(135deg, var(--accent-orange), #ff8c42); }
.summary-card--purple { background: linear-gradient(135deg, var(--accent-purple), #9b59b6); }
.summary-card h3     { margin: 0 0 10px 0; font-size: 14px; text-transform: uppercase; letter-spacing: 1px; opacity: 0.9; }
.summary-card-value  { font-size: 28px; font-weight: bold; }

.fin-metrics-grid  { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 15px; margin-bottom: 30px; }
.fin-metric-tile   { background: var(--tile-bg); padding: 15px; border-radius: 8px; text-align: center; }
.fin-metric-value  { font-size: 18px; font-weight: bold; color: var(--text-primary); }
.fin-metric-label  { font-size: 12px; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 1px; }

.fin-table          { width: 100%; border-collapse: collapse; background: var(--tile-bg); border-radius: 8px; overflow: hidden; }
.fin-table thead tr { background: var(--tile-header-bg); }
.fin-table th       { padding: 12px; text-align: left; font-weight: 600; color: var(--text-primary); border-bottom: 1px solid var(--tile-border); }
.fin-table th.text-right { text-align: right; }
.fin-table td       { padding: 12px; color: var(--text-primary); }
.fin-table td.text-right { text-align: right; font-weight: 500; }
.fin-table tbody tr { border-bottom: 1px solid var(--tile-border); }

/* ===================================================================
   TICKET DETAIL PAGE
=================================================================== */
.proof-preview     { text-align: center; }
.fin-notes-group   { margin-bottom: 15px; }
.fin-notes-label   { font-size: var(--font-xs); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600; margin-bottom: 5px; display: block; }
.fin-notes-textarea { width: 100%; background: var(--tile-inner-bg); border: 1px solid var(--tile-inner-border); color: #fff; padding: 10px; font-size: var(--font-base); resize: vertical; }
.email-status      { margin-top: 15px; }
.proof-modal-content { max-width: 400px; }
.proof-modal-desc  { color: var(--light-grey); margin-bottom: 20px; }
.proof-checkbox-row { margin-bottom: 15px; }
.proof-checkbox-row-last { margin-bottom: 20px; }
.proof-checkbox-label { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.proof-checkbox    { width: 18px; height: 18px; }

/* ===================================================================
   QUOTE LANDING PAGE
=================================================================== */
.quote-hero-section  { text-align: center; margin-bottom: 50px; }
.quote-hero-subtitle { color: var(--light-grey); max-width: 600px; margin: 0 auto; }
.steps-heading       { text-align: center; margin-bottom: 10px; }
.steps-subtitle      { text-align: center; color: var(--light-grey); margin-bottom: 30px; }
.portal-cta-card     { margin-top: 50px; text-align: center; }
.portal-cta-wrapper  { margin-top: 30px; max-width: 400px; margin-left: auto; margin-right: auto; }
.portal-cta-text     { text-align: center; color: var(--text-secondary); margin-bottom: 15px; }
.contact-card        { margin-top: 40px; }
.contact-return      { margin-top: 25px; max-width: 400px; }

/* ===================================================================
   CUSTOMER HOME / PORTAL
=================================================================== */
.portal-page-top     { margin-top: 40px; }
.proof-actions       { margin-top: 20px; }
.proof-status-msg    { color: var(--light-grey); font-size: 13px; margin-top: 10px; }
.quote-desc          { color: var(--light-grey); margin-bottom: 20px; }
.quote-actions-row   { display: flex; gap: 15px; flex-wrap: wrap; align-items: center; }
.quote-status-msg    { color: var(--light-grey); font-size: 13px; margin-top: 15px; }
.contact-status      { margin-top: 15px; text-align: center; }
.contact-info-card   { margin-bottom: 100px; }
.contact-info-text   { color: var(--light-grey); }
.contact-strong      { color: #fff; }
.portal-login-card   { max-width: 400px; margin: 0 auto; }
.portal-login-heading { text-align: center; }
.portal-link-group   { text-align: center; margin-top: 15px; }
.portal-hint-group   { text-align: center; margin-top: 10px; }
.portal-hint-text    { color: var(--text-secondary); font-size: 14px; }
.portal-empty-msg    { margin-bottom: 15px; }
.portal-empty-detail { color: var(--light-grey); font-size: 14px; }

/* --- Signup / password form --- */
.pass-field-wrap     { position: relative; }
.pass-input          { padding-right: 45px; }
.pass-toggle-btn     { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; color: #232323; font-size: 14px; }
.strength-bar        { height: 6px; border-radius: 3px; background: rgba(255,255,255,0.2); margin-top: 8px; overflow: hidden; }
.strength-fill       { height: 100%; width: 0%; transition: all 0.3s ease; }
.strength-text       { font-size: 12px; margin-top: 4px; color: #ccc; }
.pass-requirements   { font-size: 13px; margin-top: 10px; padding: 10px; background: rgba(255,255,255,0.1); border-radius: 6px; border: 1px solid rgba(255,255,255,0.2); }
.pass-req-item       { color: #aaa; }
.pass-confirm-label  { margin-top: 15px; }
.pass-match-status   { font-size: 13px; margin-top: 6px; }
.captcha-label       { margin-top: 15px; }
.captcha-box         { background: rgba(255,255,255,0.1); padding: 15px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.2); }
.captcha-question    { font-size: 16px; font-weight: 500; color: #fff; }
.captcha-input       { margin-top: 10px; }
.signup-status       { margin-top: 10px; }
.signup-login-link   { margin-top: 15px; text-align: center; }

/* ===================================================================
   CONTACT / PAYMENT THANKS PAGES
=================================================================== */
.thanks-hero         { text-align: center; margin-bottom: 40px; }
.thanks-card         { text-align: center; max-width: 560px; margin: 0 auto; padding: 50px 40px; }
.thanks-heading      { margin-bottom: 15px; color: #fff; }
.thanks-desc         { color: var(--light-grey); font-size: 1.1rem; line-height: 1.6; margin-bottom: 25px; }
.thanks-info         { color: var(--light-grey); margin-bottom: 30px; }
.thanks-small        { color: var(--light-grey); font-size: 0.95rem; margin-bottom: 30px; }
.thanks-cta          { max-width: 300px; margin: 0 auto; }
.confirmation-icon   { width: 48px; height: 48px; margin: 0 auto 20px; }
.confirmation-icon svg { width: 100%; height: 100%; fill: var(--accent-green); }
.ticket-ref          { font-family: monospace; background: var(--grey-700); padding: 3px 10px; border-radius: 4px; }

/* ===================================================================
   CREATE QUOTE / INVOICE PAGES
=================================================================== */
.quote-spacer        { margin-top: 8px; margin-bottom: 25px; }
.quote-actions       { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; align-items: center; }

/* Preset line-item dropdown — inherits .btn style, overrides select globals */
.preset-line-select {
    width: auto;
    margin-bottom: 0;
    padding-right: 36px;
}
.quote-totals        { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--card-border); }
.items-table         { width: 100%; border-collapse: collapse; }
.col-desc            { width: 250px; }
.col-qty             { width: 80px; }
.col-rate            { width: 90px; }
.col-total           { width: 110px; }
.col-action          { width: 40px; }
.col-qty-wide        { width: 90px; }
.col-rate-wide       { width: 120px; }
.col-total-wide      { width: 120px; }
.col-action-wide     { width: 50px; }
.pdf-link            { margin-top: 10px; }

/* ===================================================================
   IMPORT ORDERS PAGE
=================================================================== */
.import-loading      { text-align: center; padding: 40px; color: var(--text-muted); }
.import-status       { color: var(--text-muted); font-size: 14px; }
.import-center       { text-align: center; margin-bottom: 30px; }
.import-needs-num    { color: var(--text-muted); }
.import-view-link    { color: var(--accent-green); font-size: 12px; }

/* ===================================================================
   INDEX / HOMEPAGE
=================================================================== */
.welcome-top         { margin-top: 60px; }
.product-images      { margin-top: 30px; }
.product-img-left    { padding-right: 20px; }
.product-img-right   { padding-left: 20px; }
.product-img         { width: 100%; display: block; }
.quote-section-top   { margin-top: 80px; }
.contact-section-spacing { margin-top: 80px; margin-bottom: 80px; }
.quote-intro-text    { color: var(--grey-300); margin-bottom: 30px; line-height: 1.7; }

/* Quote section header */
.quote-section-header { text-align: center; margin-bottom: 30px; }

/* ===================================================================
   JOB SUMMARY PAGE
=================================================================== */
.job-summary-card    { margin-top: 20px; }
.job-summary-card-lg { margin-top: 30px; }
.txn-totals          { margin-top: 20px; font-weight: bold; }

/* ===================================================================
   CREATE TICKET PAGE
=================================================================== */
.create-ticket-card  { max-width: 600px; margin: 40px auto; }
.create-ticket-heading { margin-bottom: 20px; }
.create-ticket-msg   { margin-top: 15px; text-align: center; }

/* ===================================================================
   DASHBOARD PAGE
=================================================================== */
.dashboard-card      { max-width: 900px; margin: 40px auto; }
.dashboard-loading   { color: var(--text-secondary); }

/* ===================================================================
   PRESALE SETUP PAGE
=================================================================== */
.presale-inline-form { display: inline; }
.presale-cancel-btn  { border-color: var(--grey-400); color: var(--text-muted); }
.presale-color-flex  { display: flex; gap: var(--spacing-sm); align-items: center; flex-wrap: wrap; }
.presale-product-actions { margin-top: var(--spacing-sm); display: flex; gap: 8px; }

/* Form overrides for presale admin grids */
.presale-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-md); margin-bottom: var(--spacing-md); }
.presale-form-row .form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 0; }
.presale-form-row .form-group.full { grid-column: 1 / -1; }
.presale-form-row .form-group label { font-size: var(--font-sm); font-weight: 600; color: var(--text-secondary); }
.presale-form-row .form-group input { margin-bottom: 0; }

.slug-preview     { font-size: var(--font-sm); color: var(--text-muted); margin-top: 4px; }
.slug-preview span { color: var(--accent-green); }

/* Search dropdown */
#searchCard { position: relative; z-index: 10; }
.search-input { width: 100%; padding: 12px; background: var(--grey-700); border: 1px solid var(--grey-500); color: var(--text-primary); font-size: var(--font-base); }
.search-input:focus { outline: none; border-color: var(--accent-green); }
.search-input::placeholder { color: var(--text-muted); }
.search-container  { position: relative; margin-bottom: var(--spacing-md); z-index: 200; }
.search-results    { position: absolute; top: 100%; left: 0; right: 0; background: var(--grey-700); border: 1px solid var(--grey-500); max-height: 400px; overflow-y: auto; z-index: 100; display: none; }
.search-results.open { display: block; }

.search-result-item { display: flex; align-items: center; gap: var(--spacing-sm); padding: var(--spacing-sm); border-bottom: 1px solid var(--grey-600); cursor: pointer; transition: background 0.2s; }
.search-result-item:hover    { background: var(--grey-600); }
.search-result-item.selected { background: rgba(152, 196, 110, 0.15); border-left: 3px solid var(--accent-green); }
.search-result-img   { width: 50px; height: 50px; object-fit: contain; background: #fff; flex-shrink: 0; }
.search-result-info  { flex: 1; min-width: 0; }
.search-result-info strong { display: block; font-size: var(--font-sm); }
.search-result-info span   { font-size: var(--font-xs); color: var(--text-muted); }
.search-result-check { color: var(--accent-green); font-weight: bold; font-size: var(--font-lg); display: none; }
.search-result-item.selected .search-result-check { display: block; }

/* Design library */
.design-library-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--spacing-sm); margin-top: var(--spacing-sm); }
.design-thumb     { background: var(--tile-inner-bg); border: 1px solid var(--tile-inner-border); padding: var(--spacing-sm); text-align: center; position: relative; }
.design-thumb img { width: 100%; height: 120px; object-fit: contain; background: var(--grey-800); }
.design-thumb .design-label  { font-size: var(--font-sm); color: var(--text-secondary); margin-top: 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.design-thumb .design-delete { position: absolute; top: 4px; right: 4px; background: var(--accent-red); border: none; color: #fff; width: 22px; height: 22px; cursor: pointer; font-size: 12px; display: flex; align-items: center; justify-content: center; }

.design-upload-area { border: 2px dashed var(--grey-500); padding: var(--spacing-lg); text-align: center; cursor: pointer; transition: border-color 0.2s; margin-bottom: var(--spacing-sm); }
.design-upload-area:hover { border-color: var(--accent-green); }
.design-upload-area .upload-hint        { font-size: var(--font-sm); color: var(--text-muted); margin-top: 6px; }
.design-upload-area .transparency-note  { font-size: var(--font-xs); color: var(--text-muted); margin-top: 4px; opacity: 0.7; }

/* Presale product cards */
.product-grid          { display: flex; flex-direction: column; gap: var(--spacing-md); }
.admin-page .product-card { background: var(--tile-inner-bg); border: 1px solid var(--tile-inner-border); padding: var(--spacing-md); cursor: default; transition: none; overflow: visible; }
.admin-page .product-card:hover { transform: none; border-color: var(--tile-inner-border); }
.product-card-header   { display: flex; align-items: center; gap: var(--spacing-sm); margin-bottom: var(--spacing-md); }
.product-card-thumb    { width: 56px; height: 56px; object-fit: contain; background: #fff; flex-shrink: 0; }
.product-card-info     { flex: 1; min-width: 0; }
.product-card-info .product-name  { font-size: var(--font-md); font-weight: 600; }
.product-card-info .product-brand { font-size: var(--font-sm); color: var(--text-muted); }
.product-card-remove   { background: var(--accent-red); border: none; color: #fff; width: 28px; height: 28px; cursor: pointer; font-size: var(--font-base); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* Inline field editing */
.inline-field { width: 100%; padding: 6px 8px; font-size: var(--font-sm); font-family: inherit; background: var(--grey-800); border: 1px solid var(--grey-500); color: var(--text-primary); margin-top: 6px; }
.inline-field:focus { outline: none; border-color: var(--accent-green); }
.inline-field::placeholder { color: var(--text-muted); font-style: italic; }
.field-saved      { font-size: var(--font-xs); color: var(--accent-green); margin-top: 2px; opacity: 0; transition: opacity 0.3s; }
.field-saved.show { opacity: 1; }

.price-row       { display: flex; align-items: center; gap: var(--spacing-sm); margin-top: 6px; }
.price-row label { font-size: var(--font-sm); color: var(--text-muted); white-space: nowrap; }
.price-row input { width: 100px; padding: 6px 8px; font-size: var(--font-sm); font-family: inherit; background: var(--grey-800); border: 1px solid var(--grey-500); color: var(--text-primary); margin: 0; }
.price-row input:focus { outline: none; border-color: var(--accent-green); }

/* Admin section labels (smaller than global .section-label) */
.admin-page .section-label { font-size: var(--font-sm); font-weight: 600; color: var(--text-secondary); margin-bottom: 8px; letter-spacing: 0; text-transform: none; }

/* Color swatches (admin — smaller than products page) */
.color-swatch-row { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 4px; }
.admin-page .color-swatch { width: 28px; height: 28px; border: 2px solid var(--grey-500); cursor: pointer; padding: 0; background-size: cover; background-position: center; background-color: var(--grey-600); }
.admin-page .color-swatch:hover  { border-color: var(--accent-green); }
.admin-page .color-swatch.active { border-color: var(--accent-green); outline: 2px solid rgba(152, 196, 110, 0.4); outline-offset: 1px; }
.color-label { font-size: var(--font-xs); color: var(--text-muted); margin-bottom: var(--spacing-md); min-height: 16px; }

/* View tabs */
.view-tabs { display: flex; gap: 0; flex-wrap: wrap; margin-bottom: var(--spacing-md); }
.view-tab  { padding: 8px 16px; font-size: var(--font-sm); font-family: inherit; background: var(--grey-700); border: 1px solid var(--grey-500); color: var(--text-muted); cursor: pointer; transition: background 0.2s, color 0.2s, border-color 0.2s; }
.view-tab + .view-tab { border-left: none; }
.view-tab:hover  { background: var(--grey-600); color: var(--text-primary); }
.view-tab.active { background: var(--grey-800); border-color: var(--accent-green); color: var(--accent-green); z-index: 1; }
.view-tab .tab-dot { width: 6px; height: 6px; display: inline-block; margin-left: 6px; background: var(--accent-green); border-radius: 50%; vertical-align: middle; }

/* Designer area */
.designer-layout { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-lg); margin-top: var(--spacing-sm); padding-top: var(--spacing-md); border-top: 1px solid var(--tile-inner-border); }
.designer-canvas-area { display: flex; align-items: flex-start; justify-content: center; }
.placement-canvas-wrap { position: relative; background: #fff; display: inline-block; max-width: 100%; }
.placement-canvas-wrap canvas { display: block; width: 100%; max-width: 360px; height: auto; cursor: move; }
.designer-sidebar { display: flex; flex-direction: column; gap: var(--spacing-md); }

.design-picker-list { display: flex; flex-wrap: wrap; gap: 8px; }
.design-picker-item { width: 64px; height: 64px; border: 2px solid var(--grey-500); cursor: pointer; padding: 4px; transition: border-color 0.2s; }
.design-picker-item:hover  { border-color: var(--accent-green); }
.design-picker-item.active { border-color: var(--accent-green); background: rgba(152, 196, 110, 0.1); }
.design-picker-item img { width: 100%; height: 100%; object-fit: contain; background: var(--grey-800); }

.designer-controls { display: flex; flex-direction: column; gap: 10px; }
.control-row       { display: flex; align-items: center; gap: 10px; }
.control-row label { font-size: var(--font-sm); color: var(--text-muted); min-width: 75px; }
.control-row input[type="range"] { flex: 1; }

.view-design-status { display: flex; gap: var(--spacing-sm); flex-wrap: wrap; font-size: var(--font-xs); align-items: center; }
.view-status-item   { color: var(--text-muted); display: inline-flex; align-items: center; gap: 4px; }
.view-status-item .status-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--grey-500); display: inline-block; }
.view-status-item.has-design  { color: var(--accent-green); }
.view-status-item.has-design .status-dot { background: var(--accent-green); }

.remove-design-btn { background: none; border: 1px solid var(--accent-red); color: var(--accent-red); font-size: var(--font-xs); font-family: inherit; padding: 4px 10px; cursor: pointer; transition: background 0.2s, color 0.2s; }
.remove-design-btn:hover    { background: var(--accent-red); color: #fff; }
.remove-design-btn:disabled { opacity: 0.3; cursor: default; pointer-events: none; }

/* Presale list */
.presale-item { display: flex; flex-direction: column; gap: var(--spacing-sm); padding: var(--spacing-md); background: var(--tile-inner-bg); border: 1px solid var(--tile-inner-border); margin-bottom: var(--spacing-sm); position: relative; }
.presale-info    { min-width: 0; }
.presale-info h3 { margin: 0 0 4px; font-size: var(--font-md); }
.presale-meta    { display: flex; flex-wrap: wrap; gap: 8px 16px; font-size: var(--font-sm); color: var(--text-muted); }
.presale-meta a  { color: var(--accent-green); }
.presale-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.admin-page .status-badge { position: absolute; top: var(--spacing-sm); right: var(--spacing-sm); }
.status-badge.active { background: rgba(152, 196, 110, 0.2); color: var(--accent-green); border: 1px solid var(--accent-green); }
.status-badge.draft  { background: rgba(255, 255, 255, 0.1); color: var(--text-muted); border: 1px solid var(--grey-500); }

.empty-state  { text-align: center; padding: 40px; color: var(--text-muted); }
.success-msg  { background: rgba(152, 196, 110, 0.1); border: 1px solid var(--accent-green); color: var(--accent-green); padding: var(--spacing-sm); margin-bottom: var(--spacing-md); }
.presale-error-msg { background: rgba(214, 73, 73, 0.1); border: 1px solid var(--accent-red); color: var(--accent-red); padding: var(--spacing-sm); margin-bottom: var(--spacing-md); }

.card-header-row    { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--spacing-md); }
.card-header-row h2 { margin: 0; }

/* Staging area (selected products bar) */
.staging-area  { background: var(--grey-700); border: 1px solid var(--grey-500); padding: var(--spacing-md); margin-top: var(--spacing-md); }
.staging-count { font-size: var(--font-sm); color: var(--text-secondary); margin-bottom: var(--spacing-sm); }

.add-product-tile { background: transparent; border: 2px dashed var(--grey-500); padding: var(--spacing-md); text-align: center; cursor: pointer; transition: border-color 0.2s, background 0.2s; display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 80px; }
.add-product-tile:hover { border-color: var(--accent-green); background: rgba(152, 196, 110, 0.05); }
.add-product-tile .add-icon  { font-size: 32px; color: var(--text-muted); line-height: 1; margin-bottom: 8px; }
.add-product-tile:hover .add-icon  { color: var(--accent-green); }
.add-product-tile .add-label { font-size: var(--font-sm); color: var(--text-muted); }
.add-product-tile:hover .add-label { color: var(--accent-green); }

/* Edit details modal */
.edit-details-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: 10000;
  align-items: center;
  justify-content: center;
}
.edit-details-modal {
  background: var(--grey-700);
  border: 1px solid var(--grey-500);
  padding: var(--spacing-lg);
  max-width: 560px;
  width: 90%;
  margin: auto;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}
.edit-details-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-md);
}
.edit-details-close {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 24px;
  cursor: pointer;
  padding: 4px 8px;
}
.edit-details-actions {
  display: flex;
  gap: 8px;
  margin-top: var(--spacing-md);
}

/* Presale responsive */
@media (max-width: 768px) {
  .presale-form-row { grid-template-columns: 1fr; }
  .designer-layout  { grid-template-columns: 1fr; }
  .design-library-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); }
}

/* ===================================================================
   STORE PAGE
=================================================================== */
.store-error-page    { text-align: center; padding: 80px 20px; }
.store-error-msg     { color: var(--text-muted); margin-bottom: var(--spacing-md); }
.store-page-container { max-width: 1100px; }

/* ===================================================================
   ARTICLE CTA
=================================================================== */
.article-cta         { text-align: center; margin-top: var(--spacing-lg); }
.no-results-full { grid-column: 1 / -1; }
.approval-confirmed {
  text-align: center;
  padding: 30px;
}
.approval-confirmed h3 {
  color: var(--accent-green);
  margin-bottom: 15px;
}
.approval-confirmed p {
  color: #ccc;
  line-height: 1.6;
}

/* ===================================================================
   PRODUCTS / APPAREL PAGE
=================================================================== */

.products-page {
  background: #1a1a1a url('/assets/background.png') repeat;
  min-height: 100vh;
}

.products-hero {
  background: linear-gradient(135deg, var(--grey-800) 0%, var(--grey-900) 100%);
  padding: 60px 20px;
  text-align: center;
  border-bottom: 1px solid var(--grey-700);
}

.products-hero h1 {
  font-size: clamp(28px, 5vw, 48px);
  color: #fff;
  margin: 0 0 15px 0;
  font-weight: 700;
}

.products-hero p {
  color: var(--grey-300);
  font-size: 18px;
  max-width: 600px;
  margin: 0 auto;
}

/* Search & Filters */
.products-controls {
  max-width: 1400px;
  margin: 0 auto;
  padding: 20px;
  background: var(--grey-800);
  border-bottom: 1px solid var(--grey-700);
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.filter-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.filter-label {
  font-size: 11px;
  color: var(--grey-400);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.search-box {
  flex: 1;
  min-width: 200px;
  max-width: 300px;
}

.search-box input {
  width: 100%;
  padding: 10px 14px;
  background: var(--grey-700);
  border: 1px solid var(--grey-600);
  color: #fff;
  font-size: 14px;
}

.search-box input::placeholder { color: var(--grey-400); }
.search-box input:focus        { outline: none; border-color: var(--accent-green); }

.filter-select {
  padding: 10px 32px 10px 14px;
  background: var(--grey-700);
  border: 1px solid var(--grey-600);
  color: #fff;
  font-size: 14px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  min-width: 150px;
}

.filter-select:focus     { outline: none; border-color: var(--accent-green); }
.filter-select.has-value { border-color: var(--accent-green); background-color: rgba(152, 196, 110, 0.1); }

.results-info  { margin-left: auto; text-align: right; }
.results-count { color: #fff; font-size: 14px; font-weight: 600; }
.active-filters { color: var(--accent-green); font-size: 12px; margin-top: 2px; }

.clear-filters {
  background: none;
  border: none;
  color: var(--grey-400);
  font-size: 12px;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
  margin-top: 4px;
}

.clear-filters:hover { color: #fff; }

/* Products Grid */
.products-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 30px 20px 60px;
}

.products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 25px;
}

/* Product Card */
.product-card {
  background: var(--grey-800);
  border: 1px solid var(--grey-700);
  overflow: hidden;
  transition: transform 0.2s, border-color 0.2s;
  cursor: pointer;
}

.product-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent-green);
}

.product-image {
  aspect-ratio: 1;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.product-image img {
  max-width: 90%;
  max-height: 90%;
  object-fit: contain;
}

.product-info    { padding: 20px; }

.product-brand {
  color: var(--accent-green);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}

.product-title {
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 8px;
  line-height: 1.3;
}

.product-style {
  color: var(--grey-400);
  font-size: 13px;
  margin-bottom: 12px;
}

.product-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.product-colors { display: flex; gap: 4px; }

.color-dot {
  width: 16px;
  height: 16px;
  border: 1px solid rgba(255,255,255,0.2);
}

.color-more {
  color: var(--grey-400);
  font-size: 12px;
  line-height: 16px;
}

.product-price {
  color: var(--grey-300);
  font-size: 13px;
}

/* Loading State — large spinner variant */
.loading-spinner {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 300px;
}

.loading-spinner .spinner {
  width: 50px;
  height: 50px;
  border-color: var(--grey-700);
  border-top-color: var(--accent-green);
}

/* No Results */
.no-results     { text-align: center; padding: 60px 20px; color: var(--grey-400); }
.no-results h3  { color: #fff; margin-bottom: 10px; }

/* Product Modal */
.product-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.9);
  z-index: 1000;
  overflow-y: auto;
  padding: 40px 20px;
}

.product-modal.active { display: block; }

.product-modal .modal-content {
  max-width: 1000px;
  margin: 0 auto;
  background: var(--grey-800);
  border: 1px solid var(--grey-700);
  padding: 0;
}

.product-modal .modal-close {
  position: fixed;
  top: 20px;
  left: 20px;
  width: 50px;
  height: 50px;
  background: var(--grey-800);
  border: 1px solid var(--grey-700);
  color: #fff;
  font-size: 28px;
  cursor: pointer;
  z-index: 1001;
  display: flex;
  align-items: center;
  justify-content: center;
}

.product-modal .modal-close:hover { background: var(--grey-700); }

.modal-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.modal-image {
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  padding: 40px;
}

.modal-image img {
  max-width: 100%;
  max-height: 500px;
  object-fit: contain;
}

.modal-details { padding: 40px; }

.modal-brand {
  color: var(--accent-green);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 10px;
}

.modal-title {
  color: #fff;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 8px;
}

.modal-style {
  color: var(--grey-400);
  font-size: 15px;
  margin-bottom: 25px;
}

.modal-section       { margin-bottom: 25px; }

.modal-section-title {
  color: var(--grey-300);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
}

.color-swatches { display: flex; flex-wrap: wrap; gap: 8px; }

.color-swatch {
  width: 40px;
  height: 40px;
  border: 2px solid transparent;
  cursor: pointer;
  position: relative;
}

.color-swatch:hover,
.color-swatch.selected { border-color: var(--accent-green); }

.color-swatch img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.selected-color-name {
  color: var(--grey-300);
  font-size: 14px;
  margin-top: 10px;
}

.modal-price        { font-size: 18px; color: var(--grey-300); margin-bottom: 25px; }
.modal-price strong { color: #fff; }

.modal-description {
  color: var(--grey-400);
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 25px;
}

/* Load More */
.load-more-container { text-align: center; padding: 40px 20px; }

/* Products responsive */
@media (max-width: 768px) {
  .filter-row        { flex-direction: column; align-items: stretch; }
  .filter-group      { width: 100%; }
  .filter-select     { width: 100%; min-width: unset; }
  .search-box        { min-width: unset; max-width: none; width: 100%; }

  .results-info {
    margin-left: 0;
    text-align: center;
    width: 100%;
    padding-top: 10px;
    border-top: 1px solid var(--grey-700);
    margin-top: 5px;
  }

  .modal-body       { grid-template-columns: 1fr; }
  .modal-image      { min-height: 300px; }

  .products-grid    { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; }
  .product-info     { padding: 12px; }
  .product-title    { font-size: 14px; }
  .products-hero    { padding: 40px 20px; }
  .products-hero h1 { font-size: 24px; }
  .products-hero p  { font-size: 16px; }
}
