

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

:root {
    /* sidebar / brand (stays dark) */
    --navy:        #1a2a72;
    --navy-mid:    #162033;
    --navy-light:  #1e2f45;
    --navy-card:   #1a2840;

    /* accent */
    --gold:        #fc7f10;
    --gold-light:  #fc7f10;
    --gold-dim:    rgba(252, 127, 16, 0.10);

    /* semantic colours */
    --teal:        #0d9488;
    --red:         #dc2626;
    --green:       #16a34a;
    --amber:       #d97706;

    /* light surface palette */
    --bg:             #f5f6f8;
    --surface:        #ffffff;
    --surface-alt:    #f9fafb;
    --surface-raised: #ffffff;

    /* text */
    --text:        #111827;
    --text-muted:  #6b7280;
    --text-dim:    #9ca3af;

    /* borders & shadows */
    --border:      #e5e7eb;
    --border-gold: rgba(252, 127, 16, 0.35);
    --shadow:      0 2px 12px rgba(0, 0, 0, 0.07);
    --shadow-md:   0 4px 24px rgba(0, 0, 0, 0.10);

    /* sidebar-specific tokens (dark sidebar on light page) */
    --sidebar-text:       #e2e8f0;
    --sidebar-text-muted: #7c93ae;
    --sidebar-text-dim:   #4a6080;
    --sidebar-border:     rgba(255, 255, 255, 0.07);

    /* shape */
    --radius:    12px;
    --radius-sm: 8px;

    /* layout */
    --sidebar-w: 260px;

    /* typography */
    --font-serif: 'DM Serif Display', Georgia, serif;
    --font-sans:  'DM Sans', system-ui, sans-serif;
}


/* ── 2. Base & Body ─────────────────────────────────────── */

html { font-size: 15px; }

body {
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    display: flex;
    line-height: 1.6;
}


/* ── 3. Sidebar (stays dark) ────────────────────────────── */

.sidebar {
    width: var(--sidebar-w);
    background: var(--navy-mid);
    border-right: 1px solid var(--sidebar-border);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    z-index: 100;
    transition: transform .3s ease;
}

.sidebar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 24px 20px;
    border-bottom: 1px solid var(--sidebar-border);
}

.brand-logo {
    width: 42px;
    height: 42px;
    background: linear-gradient(135deg, var(--gold-light), #f5bc4a);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-serif);
    font-size: 1.4rem;
    color: var(--navy);
    font-weight: bold;
    flex-shrink: 0;
}

.brand-name {
    display: block;
    font-weight: 700;
    font-size: 1rem;
    color: var(--sidebar-text);
    letter-spacing: .3px;
}

.brand-sub {
    display: block;
    font-size: .72rem;
    color: var(--sidebar-text-muted);
    letter-spacing: .5px;
}

.nav-list {
    list-style: none;
    padding: 12px 0;
    flex: 1;
    overflow-y: auto;
}

.nav-item a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 20px;
    color: var(--sidebar-text-muted);
    text-decoration: none;
    font-size: .88rem;
    font-weight: 500;
    border-left: 3px solid transparent;
    transition: all .18s ease;
}

.nav-item a svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.nav-item a:hover {
    color: var(--sidebar-text);
    background: rgba(255, 255, 255, 0.05);
}

.nav-item.active a {
    color: var(--gold-light);
    border-left-color: var(--gold-light);
    background: rgba(232, 160, 32, 0.12);
}

.sidebar-footer {
    padding: 16px 20px;
    border-top: 1px solid var(--sidebar-border);
}

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

.company-info span {
    font-size: .72rem;
    color: var(--sidebar-text-dim);
}


/* ── 4. Main Wrapper & Topbar ───────────────────────────── */

.main-wrapper {
    margin-left: var(--sidebar-w);
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.topbar {
    height: 64px;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 28px;
    position: sticky;
    top: 0;
    z-index: 50;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}

.topbar-left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.page-title {
    font-family: var(--font-serif);
    font-size: 1.3rem;
    color: var(--text);
    font-style: italic;
}

.topbar-date {
    font-size: .8rem;
    color: var(--text-muted);
}

.menu-toggle {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-muted);
    display: none;
}

.menu-toggle svg {
    width: 22px;
    height: 22px;
}


/* ── 5. Main Content ────────────────────────────────────── */

.main-content {
    padding: 28px;
    flex: 1;
}


/* ── 6. Cards ───────────────────────────────────────────── */

.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
    box-shadow: var(--shadow);
}

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

.card-title {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    color: var(--text);
    font-style: italic;
}


/* ── 7. Stat Grid ───────────────────────────────────────── */

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.stat-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px 22px;
    position: relative;
    overflow: hidden;
    transition: transform .2s, box-shadow .2s;
}

.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--gold), transparent);
}

.stat-label {
    font-size: .78rem;
    color: var(--text-muted);
    letter-spacing: .6px;
    text-transform: uppercase;
    margin-bottom: 8px;
}

.stat-value {
    font-family: var(--font-serif);
    font-size: 1.7rem;
    color: var(--text);
    line-height: 1.2;
}

.stat-sub {
    font-size: .75rem;
    color: var(--text-dim);
    margin-top: 6px;
}

.stat-icon {
    position: absolute;
    right: 16px;
    top: 16px;
    opacity: .08;
}

.stat-icon svg {
    width: 40px;
    height: 40px;
}


/* ── 8. Tables ──────────────────────────────────────────── */

.table-wrap { overflow-x: auto; }

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

thead th {
    text-align: left;
    padding: 10px 14px;
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .8px;
    text-transform: uppercase;
    color: var(--text-muted);
    background: var(--surface-alt);
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
}

tbody td {
    padding: 13px 14px;
    font-size: .88rem;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
    color: var(--text);
}

tbody tr:last-child td { border-bottom: none; }
tbody tr:hover { background: #f9fafb; }

.td-actions { display: flex; gap: 6px; }


/* ── 9. Badges ──────────────────────────────────────────── */

.badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: .73rem;
    font-weight: 600;
    letter-spacing: .3px;
}

.badge-draft     { background: #f3f4f6; color: #6b7280; }
.badge-pending   { background: #fef3c7; color: #92400e; }
.badge-invoiced  { background: #ccfbf1; color: #0f766e; }
.badge-paid      { background: #dcfce7; color: #15803d; }
.badge-unpaid    { background: #fef3c7; color: #92400e; }
.badge-overdue   { background: #fee2e2; color: #b91c1c; }
.badge-cancelled { background: #f3f4f6; color: #6b7280; }


/* ── 10. Buttons ────────────────────────────────────────── */

.btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: .85rem;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: all .18s ease;
    text-decoration: none;
    white-space: nowrap;
}

.btn svg { width: 15px; height: 15px; }

.btn-primary { background: linear-gradient(135deg, var(--gold), var(--gold-light)); color: #fff; }
.btn-primary:hover { filter: brightness(1.08); transform: translateY(-1px); }

.btn-outline { background: transparent; border: 1px solid var(--border-gold); color: var(--gold); }
.btn-outline:hover { background: var(--gold-dim); }

.btn-ghost { background: #f3f4f6; color: var(--text); border: 1px solid var(--border); }
.btn-ghost:hover { background: #e9eaec; }

.btn-danger { background: #fee2e2; color: var(--red); border: 1px solid #fca5a5; }
.btn-danger:hover { background: #fecaca; }

.btn-sm   { padding: 5px 12px; font-size: .78rem; }
.btn-icon { padding: 7px; }


/* ── 11. Forms ──────────────────────────────────────────── */

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

.form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.form-group label {
    font-size: .78rem;
    font-weight: 600;
    color: var(--text-muted);
    letter-spacing: .4px;
    text-transform: uppercase;
}

input, select, textarea {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-family: var(--font-sans);
    font-size: .9rem;
    padding: 10px 14px;
    width: 100%;
    transition: border-color .18s, box-shadow .18s;
    outline: none;
}

input:focus, select:focus, textarea:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px var(--gold-dim);
}

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

select option { background: var(--surface); color: var(--text); }


/* ── 12. Items Table (Order Form) ───────────────────────── */

.items-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 12px;
}

.items-table th {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .6px;
    text-transform: uppercase;
    color: var(--text-muted);
    padding: 8px 10px;
    border-bottom: 1px solid var(--border);
    text-align: left;
}

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

.items-table input,
.items-table select { padding: 7px 10px; font-size: .85rem; }

.items-table .td-del { text-align: center; width: 36px; }

.items-table .td-del button {
    background: none;
    border: none;
    color: var(--red);
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background .15s;
}

.items-table .td-del button:hover { background: #fee2e2; }


/* ── 13. Summary Box ────────────────────────────────────── */

.summary-box {
    background: var(--surface-alt);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 16px 20px;
    min-width: 280px;
}

.summary-row {
    display: flex;
    justify-content: space-between;
    padding: 5px 0;
    font-size: .88rem;
    color: var(--text);
}

.summary-row.total {
    border-top: 1px solid var(--border);
    margin-top: 6px;
    padding-top: 10px;
    font-weight: 700;
    font-size: 1rem;
    color: var(--gold);
}


/* ── 14. Modal ──────────────────────────────────────────── */

.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .35);
    z-index: 200;
    backdrop-filter: blur(3px);
}

.modal {
    display: none;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 32px;
    z-index: 201;
    width: 90%;
    max-width: 560px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .15);
    animation: modalIn .2s ease;
}

@keyframes modalIn {
    from { opacity: 0; transform: translate(-50%, -48%); }
}

.modal.active,
.modal-overlay.active { display: block; }

.modal-close {
    position: absolute;
    top: 14px;
    right: 16px;
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.4rem;
    cursor: pointer;
    line-height: 1;
}

.modal-close:hover { color: var(--text); }

.modal-title {
    font-family: var(--font-serif);
    font-size: 1.2rem;
    margin-bottom: 20px;
    font-style: italic;
    color: var(--text);
}


/* ── 15. Toast ──────────────────────────────────────────── */

.toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 4px solid var(--green);
    border-radius: var(--radius-sm);
    padding: 14px 20px;
    font-size: .88rem;
    color: var(--text);
    z-index: 300;
    opacity: 0;
    transform: translateY(10px);
    transition: all .25s ease;
    pointer-events: none;
    max-width: 320px;
    box-shadow: var(--shadow-md);
}

.toast.show  { opacity: 1; transform: translateY(0); }
.toast.error { border-left-color: var(--red); }


/* ── 16. Empty State ────────────────────────────────────── */

.empty-state {
    text-align: center;
    padding: 50px 20px;
    color: var(--text-dim);
}

.empty-state svg {
    width: 48px;
    height: 48px;
    opacity: .25;
    margin-bottom: 12px;
}

.empty-state p { font-size: .9rem; }


/* ── 17. Section Header ─────────────────────────────────── */

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

.section-title {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    color: var(--text);
    font-style: italic;
}


/* ── 18. Search / Filter Bar ────────────────────────────── */

.filter-bar {
    display: flex;
    gap: 10px;
    margin-bottom: 16px;
    flex-wrap: wrap;
    padding: 18px;
}

.search-input {
    flex: 1;
    min-width: 180px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    padding: 9px 14px;
    font-size: .88rem;
    outline: none;
    transition: border-color .18s;
}

.search-input:focus { border-color: var(--gold); }


/* ── 19. Print / Invoice & Receipt ─────────────────────── */

.print-doc {
    max-width: 800px;
    margin: 0 auto;
    background: #fff;
    color: #111;
    padding: 48px 52px;
    font-family: var(--font-sans);
    font-size: 13px;
    line-height: 1.6;
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
}

.print-doc .doc-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    border-bottom: 3px solid #0d1b2a;
    padding-bottom: 24px;
    margin-bottom: 28px;
}

.print-doc .company-logo { display: flex; align-items: center; gap: 12px; }

.print-doc .logo-box {
    width: 48px;
    height: 48px;
    background: #0d1b2a;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-serif);
    font-size: 1.5rem;
    color: #fc7f10;
    font-weight: bold;
}

.print-doc .company-name    { font-family: var(--font-serif); font-size: 1.3rem; color: #0d1b2a; }
.print-doc .company-details { font-size: .8rem; color: #555; margin-top: 2px; }
.print-doc .doc-type-box    { text-align: right; }

.print-doc .doc-type {
    font-family: var(--font-serif);
    font-size: 2rem;
    color: #0d1b2a;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.print-doc .doc-number { font-size: .9rem; color: #888; }

.print-doc .doc-status-paid,
.print-doc .doc-status-unpaid {
    display: inline-block;
    border-radius: 8px;
    padding: 4px 16px;
    font-weight: 700;
    font-size: .85rem;
    margin-top: 8px;
    letter-spacing: 1px;
}

.print-doc .doc-status-paid   { background: #dcfce7; color: #16a34a; border: 2px solid #16a34a; }
.print-doc .doc-status-unpaid { background: #fef9c3; color: #b45309; border: 2px solid #d97706; }

.print-doc .doc-meta {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 28px;
}

.print-doc .meta-section h4 {
    font-size: .75rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #888;
    margin-bottom: 6px;
    font-weight: 600;
}

.print-doc .meta-section p      { font-size: .88rem; color: #222; }
.print-doc .meta-section strong { color: #0d1b2a; }

.print-doc .doc-table { width: 100%; border-collapse: collapse; margin-bottom: 24px; }

.print-doc .doc-table thead th {
    background: #0d1b2a;
    color: #fc7f10;
    padding: 10px 12px;
    font-size: .78rem;
    letter-spacing: .6px;
    text-transform: uppercase;
    text-align: left;
}

.print-doc .doc-table thead th:last-child,
.print-doc .doc-table tbody td:last-child { text-align: right; }

.print-doc .doc-table tbody td {
    padding: 10px 12px;
    border-bottom: 1px solid #eee;
    font-size: .88rem;
}

.print-doc .doc-table tbody tr:nth-child(even) td { background: #f9f9f9; }

.print-doc .doc-totals { display: flex; justify-content: flex-end; margin-bottom: 28px; }
.print-doc .totals-box { width: 300px; }

.print-doc .totals-row {
    display: flex;
    justify-content: space-between;
    padding: 5px 0;
    font-size: .88rem;
    color: #444;
}

.print-doc .totals-row.grand {
    border-top: 2px solid #0d1b2a;
    margin-top: 6px;
    padding-top: 10px;
    font-size: 1.05rem;
    font-weight: 700;
    color: #0d1b2a;
}

.print-doc .doc-footer {
    border-top: 1px solid #eee;
    padding-top: 16px;
    text-align: center;
    font-size: .8rem;
    color: #888;
}

.print-doc .doc-payment-info {
    background: #f0f9ff;
    border: 1px solid #bae6fd;
    border-radius: 8px;
    padding: 14px 16px;
    margin-bottom: 24px;
    font-size: .85rem;
}

.print-doc .doc-payment-info h4 {
    font-size: .75rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #0369a1;
    margin-bottom: 6px;
}

.doc-actions { display: flex; gap: 10px; margin-bottom: 20px; }


/* ── 20. Users Page ─────────────────────────────────────── */

.users-toolbar {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.users-stats-grid {
    grid-template-columns: repeat(4, minmax(140px, 1fr));
    margin-bottom: 20px;
}

.users-filter-bar  { align-items: center; }

.users-filter-select {
    flex: 0 0 auto;
    width: auto;
    min-width: 130px;
}

.users-row-num    { color: var(--text-dim); font-size: .8rem; }
.users-last-login { font-size: .82rem; color: var(--text-muted); }
.users-never      { color: var(--text-dim); }

.users-pagination {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    padding: 16px 0 4px;
}

.users-page-info {
    font-size: .82rem;
    color: var(--text-muted);
    padding: 0 4px;
}

.users-form-grid  { gap: 14px; }
.users-full-col   { grid-column: 1 / -1; }

.users-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 20px;
}


/* ── 21. Settings Page ──────────────────────────────────── */

.settings-alert {
    border-radius: var(--radius);
    padding: 14px 16px;
    margin-bottom: 20px;
    font-weight: 600;
    font-size: .9rem;
}

.settings-alert-success {
    background: #f0fdf4;
    color: var(--green);
    border: 1px solid #bbf7d0;
}

.settings-alert-danger {
    background: #fef2f2;
    color: var(--red);
    border: 1px solid #fecaca;
}

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

.settings-full-col { grid-column: 1 / -1; }

.settings-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.settings-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
    background: var(--surface-alt);
}

.settings-card-title {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-style: italic;
    color: var(--text);
}

.settings-card-body { padding: 18px; }

.settings-card .settings-full-col { grid-column: 1 / -1; }

.settings-hint {
    font-size: .78rem;
    color: var(--text-dim);
    margin-top: 4px;
    display: block;
}

.settings-logo-wrap {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    flex-wrap: wrap;
}

.settings-logo-preview {
    width: 120px;
    height: 120px;
    flex-shrink: 0;
    border: 1px dashed var(--border-gold);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: var(--surface-alt);
}

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

.settings-logo-placeholder {
    font-size: .78rem;
    color: var(--text-dim);
    text-align: center;
    padding: 8px;
}

.settings-logo-hidden { display: none; }

.settings-logo-fields {
    flex: 1;
    min-width: 220px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.settings-actions-bar {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
}


/* ── 22. Email Settings Page ────────────────────────────── */

.email-info-box {
    grid-column: 1 / -1;
    padding: 14px 16px;
    border-radius: var(--radius-sm);
    background: #f0fdfa;
    border: 1px solid #99f6e4;
    color: var(--teal);
    font-size: .86rem;
    line-height: 1.7;
}

.email-code-hint {
    display: block;
    background: var(--surface-alt);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    font-family: 'Courier New', monospace;
    font-size: .84rem;
    color: var(--gold);
    margin: 6px 0;
    letter-spacing: .3px;
}


/* ── 23. Login Page ─────────────────────────────────────── */

body.login-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 24px;
    background: var(--bg);
}

.login-card {
    width: 100%;
    max-width: 420px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    padding: 36px 32px 40px;
    animation: loginFadeIn .3s ease;
}

@keyframes loginFadeIn {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

.login-card-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 30px;
}

.login-card .brand-name { color: var(--text); }
.login-card .brand-sub  { color: var(--text-muted); }

.login-alert {
    border-radius: var(--radius-sm);
    padding: 12px 14px;
    margin-bottom: 18px;
    font-weight: 600;
    font-size: .88rem;
    line-height: 1.5;
}

.login-alert-danger {
    background: #fef2f2;
    color: var(--red);
    border: 1px solid #fecaca;
}

.login-alert-info {
    background: #f0fdfa;
    color: var(--teal);
    border: 1px solid #99f6e4;
}

.login-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.login-submit {
    width: 100%;
    justify-content: center;
    padding: 13px 16px;
    font-size: .95rem;
    margin-top: 4px;
}


/* ── 24. Email Logs Page ────────────────────────────────── */

.logs-stats-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    margin-bottom: 20px;
}

.logs-filter-bar  { align-items: center; }

.logs-filter-select {
    flex: 0 0 auto;
    width: auto;
    min-width: 130px;
}

.logs-error {
    white-space: pre-wrap;
    word-break: break-word;
    margin: 0;
    font-size: .78rem;
    color: var(--red);
    font-family: 'Courier New', monospace;
    max-width: 220px;
}


/* ── 25. Responsive ─────────────────────────────────────── */

@media (max-width: 1100px) {
    .logs-stats-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .users-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .settings-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    :root { --sidebar-w: 0px; }
    .sidebar { transform: translateX(-260px); width: 260px; }
    .sidebar.open { transform: translateX(0); }
    .main-wrapper { margin-left: 0; }
    .menu-toggle { display: flex; }
    .main-content { padding: 16px; }
    .stats-grid { grid-template-columns: 1fr 1fr; }
    .topbar { padding: 0 16px; }
}

@media (max-width: 700px) {
    .logs-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .logs-filter-select,
    .users-filter-select {
        width: 100%;
    }
}

@media (max-width: 580px) {
    .users-stats-grid {
        grid-template-columns: 1fr 1fr;
    }
}


/* ── 26. Print Media ────────────────────────────────────── */

@media print {
    body { background: #fff; color: #111; font-size: 12px; }
    .sidebar, .topbar, .doc-actions, .btn, nav { display: none !important; }
    .main-wrapper { margin-left: 0; }
    .main-content { padding: 0; }
    .print-doc { box-shadow: none; border-radius: 0; padding: 0; }
    .card { border: none; padding: 0; box-shadow: none; background: transparent; }
    a { text-decoration: none; }
}
/* ============================================================
   HEADER ADDITIONS  (append to style.css)
   ============================================================ */

/* brand logo image (when a real logo file is set) */
.brand-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 8px;
}

/* Font Awesome icons inside nav links */
.nav-item a i {
    width: 18px;
    text-align: center;
    font-size: .95rem;
    flex-shrink: 0;
}

/* Font Awesome icons inside sidebar footer */
.company-info span i {
    width: 14px;
    font-size: .72rem;
    margin-right: 4px;
    opacity: .7;
}

/* menu-toggle now uses an <i> tag instead of SVG */
.menu-toggle i { font-size: 1.1rem; }

/* ── Topbar right side ─────────────────────────────────── */

.topbar-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

.topbar-date i {
    margin-right: 5px;
    opacity: .6;
}

/* User block */
.topbar-user {
    display: flex;
    align-items: center;
    gap: 10px;
}

.topbar-avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), var(--gold-light));
    color: var(--navy);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .88rem;
    flex-shrink: 0;
}

.topbar-user-info {
    display: flex;
    flex-direction: column;
    line-height: 1.3;
}

.topbar-user-name {
    font-size: .85rem;
    font-weight: 600;
    color: var(--text);
}

.topbar-user-role {
    font-size: .72rem;
    color: var(--text-muted);
    text-transform: capitalize;
}

.topbar-logout {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    background: #fee2e2;
    color: var(--red);
    text-decoration: none;
    font-size: .9rem;
    transition: background .18s;
    flex-shrink: 0;
}

.topbar-logout:hover { background: #fecaca; }

/* hide user-info text on small screens, keep avatar + logout */
@media (max-width: 600px) {
    .topbar-user-info { display: none; }
    .topbar-date      { display: none; }
}

/* ============================================================
   UNIHUB INVOICE VIEW  (moved from invoice_view.php)
   ============================================================ */
/* ── Action bar ─────────────────────────────── */
.uh-actions{
    display:flex;gap:10px;flex-wrap:wrap;
    margin-bottom:20px;
}

/* ── Paper wrapper ──────────────────────────── */
.uh-paper{
    position:relative;
    max-width:860px;
    margin:0 auto;
    background:#ffffff;
    border-radius:0;
    box-shadow:0 8px 40px rgba(26,42,114,.10);
    overflow:hidden;
    font-family:'Arial',sans-serif;
    font-size:13px;
    color:#1e293b;
}

/* Watermark logo */
.uh-watermark{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    pointer-events:none;
    z-index:0;
    opacity:.04;
}
.uh-watermark img{
    width:320px;
    max-width:65%;
    height:auto;
    object-fit:contain;
}
.uh-paper > *:not(.uh-watermark){ position:relative; z-index:1; }

/* ── Header band ────────────────────────────── */
.uh-header{
    background:#1a2a72;
    padding:22px 36px 22px 28px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
}

.uh-brand{
    display:flex;
    align-items:center;
    gap:14px;
}
.uh-icon-box{
    width:56px;height:56px;
    background:#fc7f10;
    border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.uh-icon-box img{ width:42px;height:42px;object-fit:contain;display:block; }
.uh-wordmark{ line-height:1.1; }
.uh-wordmark-main{
    font-family:'Arial Narrow',Arial,sans-serif;
    font-weight:700;
    font-size:2rem;
    letter-spacing:-.5px;
    line-height:1;
}
.uh-wordmark-main span.or{ color:#fc7f10; }
.uh-wordmark-main span.wh{ color:#ffffff; }
.uh-wordmark-sub{
    font-size:.68rem;
    font-weight:600;
    letter-spacing:3px;
    color:rgba(255,255,255,.5);
    text-transform:uppercase;
}

.uh-doc-badge{
    background:#fc7f10;
    border-radius:5px;
    padding:8px 20px;
    font-family:'Arial Narrow',Arial,sans-serif;
    font-weight:900;
    font-size:1.3rem;
    color:#ffffff;
    letter-spacing:2px;
    text-transform:uppercase;
}

/* ── Meta bar ───────────────────────────────── */
.uh-meta-bar{
    background:#e8ebf7;
    padding:10px 36px;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:8px;
}
.uh-meta-item label{
    display:block;
    font-size:.65rem;
    font-weight:700;
    letter-spacing:1.5px;
    text-transform:uppercase;
    color:#64748b;
    margin-bottom:3px;
}
.uh-meta-item .val{
    font-size:.88rem;
    font-weight:700;
    color:#1a2a72;
}
.uh-meta-item .val.status-badge{
    display:inline-block;
    padding:2px 10px;
    border-radius:20px;
    font-size:.72rem;
}

/* ── From / Bill-to ─────────────────────────── */
.uh-parties{
    display:grid;
    grid-template-columns:1fr 1px 1fr;
    gap:0;
    padding:20px 36px;
    border-bottom:1px solid #e2e8f0;
}
.uh-party-divider{ background:#e2e8f0; }
.uh-party{ padding:0 20px; }
.uh-party:first-child{ padding-left:0; }
.uh-party:last-child{ padding-right:0; }
.uh-party-label{
    font-size:.7rem;
    font-weight:700;
    letter-spacing:2px;
    color:#fc7f10;
    text-transform:uppercase;
    margin-bottom:6px;
}
.uh-party-name{
    font-size:.95rem;
    font-weight:700;
    color:#1a2a72;
    margin-bottom:3px;
}
.uh-party-detail{ font-size:.82rem; color:#64748b; line-height:1.6; }

/* ── Items table ────────────────────────────── */
.uh-table-wrap{ padding:0 36px 0; }

.uh-table{
    width:100%;
    border-collapse:collapse;
    margin-bottom:0;
}
.uh-table thead tr{
    background:#1a2a72;
}
.uh-table thead th{
    padding:10px 12px;
    font-size:.72rem;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    color:#1a2a72;
    text-align:left;
}
.uh-table thead th.r{ text-align:right; }

.uh-table tbody tr:nth-child(even){ background:#f8fafc; }
.uh-table tbody tr:nth-child(odd) { background:#ffffff; }
.uh-table tbody td{
    padding:11px 12px;
    font-size:.88rem;
    color:#475569;
    border-bottom:1px solid #e2e8f0;
    vertical-align:middle;
}
.uh-table tbody td.r{ text-align:right; }
.uh-table tbody tr:last-child td{ border-bottom:none; }

/* ── Totals ─────────────────────────────────── */
.uh-totals-section{
    display:flex;
    justify-content:flex-end;
    padding:18px 36px;
    border-top:1.5px solid #1a2a72;
}
.uh-totals{
    width:310px;
}
.uh-totals-row{
    display:flex;
    justify-content:space-between;
    padding:5px 0;
    font-size:.88rem;
    color:#64748b;
    border-bottom:1px solid #e2e8f0;
}
.uh-totals-row:last-child{ border-bottom:none; }
.uh-totals-row.grand{
    margin-top:6px;
    padding-top:10px;
    border-top:1.5px solid #1a2a72;
    border-bottom:none;
    font-size:1rem;
    font-weight:700;
}
.uh-totals-row.grand .lbl{ color:#1a2a72; }
.uh-totals-row.grand .amt{
    color:#fc7f10;
    font-family:'Arial Narrow',Arial,sans-serif;
    font-size:1.1rem;
    font-weight:900;
}

/* ── Payment instructions ───────────────────── */
.uh-payment{
    padding:0 36px 20px;
}
.uh-section-label{
    font-size:.7rem;
    font-weight:700;
    letter-spacing:2px;
    color:#fc7f10;
    text-transform:uppercase;
    margin-bottom:7px;
    border-top:1px solid #e2e8f0;
    padding-top:16px;
}
.uh-payment-detail{ font-size:.85rem; color:#64748b; line-height:1.7; }

/* ── Notes ──────────────────────────────────── */
.uh-notes{
    margin:0 36px 20px;
    border:1px dashed #cbd5e1;
    border-radius:6px;
    padding:12px 16px;
    background:#fafbfd;
}
.uh-notes p{ font-size:.85rem; color:#475569; line-height:1.6; }

/* ── Receipt history ────────────────────────── */
.uh-receipts{
    margin:0 36px 20px;
    border:1px solid #e2e8f0;
    border-radius:8px;
    overflow:hidden;
}
.uh-receipts-title{
    background:#f8fafc;
    padding:10px 16px;
    font-size:.78rem;
    font-weight:700;
    letter-spacing:1.5px;
    text-transform:uppercase;
    color:#1a2a72;
    border-bottom:1px solid #e2e8f0;
}
.uh-receipts table{ width:100%;border-collapse:collapse; }
.uh-receipts table th{
    padding:9px 12px;
    font-size:.72rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.8px;
    color:#64748b;
    background:#f8fafc;
    border-bottom:1px solid #e2e8f0;
    text-align:left;
}
.uh-receipts table td{
    padding:9px 12px;
    font-size:.85rem;
    color:#475569;
    border-bottom:1px solid #f1f5f9;
}
.uh-receipts table tr:last-child td{ border-bottom:none; }

/* ── Signature ──────────────────────────────── */
.uh-signature{
    padding:16px 36px 24px;
    display:flex;
    justify-content:flex-end;
}
.uh-sig-box{
    width:260px;
    text-align:center;
}
.uh-sig-line{
    border-top:1px solid #1a2a72;
    padding-top:8px;
    font-size:.82rem;
    color:#475569;
}
.uh-sig-for{
    font-size:.82rem;
    font-weight:700;
    color:#1a2a72;
    margin-top:2px;
}

/* ── Footer band ────────────────────────────── */
.uh-footer{
    background:#1a2a72;
    border-top:3px solid #fc7f10;
    padding:12px 36px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    font-size:.78rem;
}
.uh-footer .left{ color:rgba(255,255,255,.5); }
.uh-footer .right{ color:#fc7f10; }

/* ── Print ──────────────────────────────────── */
@media print{
    .uh-actions,.sidebar,.topbar,nav,.no-print{ display:none!important; }
    body{ background:#fff!important; }
    .uh-paper{ box-shadow:none; }
}

.uh-status-badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: .72rem;
    border: 1px solid transparent;
}
.uh-status-paid { background:#e8f5e9; color:#2e7d32; border-color:rgba(46,125,50,.18); }
.uh-status-void { background:#f1f5f9; color:#64748b; border-color:rgba(100,116,139,.18); }
.uh-status-partial { background:#fff7e6; color:#b45309; border-color:rgba(180,83,9,.18); }
.uh-status-default { background:#fff3e0; color:#e65100; border-color:rgba(230,81,0,.18); }
.uh-col-num { width:36px; }
.uh-col-qty,
.uh-col-vat { width:70px; }
.uh-col-money { width:140px; }
.uh-empty-row { text-align:center; color:#94a3b8; padding:24px; }
.uh-notes .uh-section-label { border-top:none; padding-top:0; margin-bottom:6px; }
.uh-sig-spacer { height:48px; }



/* ============================================================
   RECEIPT VIEW ADDITIONS - receipt_view.php
   Uses shared UNIHUB invoice/receipt classes
   Secondary brand color: #fc7f10
   ============================================================ */

.uh-doc-badge-rcpt {
    background: #2e7d32;
    border-radius: 5px;
    padding: 8px 20px;
    font-family: 'Arial Narrow', Arial, sans-serif;
    font-weight: 900;
    font-size: 1.3rem;
    color: #ffffff;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.uh-logo-img {
    width: 42px;
    height: 42px;
    object-fit: contain;
    display: block;
}

.uh-paid-bar {
    background: #e8f5e9;
    border-left: 4px solid #2e7d32;
    padding: 8px 36px;
    font-size: .9rem;
    font-weight: 700;
    color: #1b5e20;
    display: flex;
    align-items: center;
    gap: 8px;
}

.uh-table .uh-col-num { width: 36px; }
.uh-table .uh-col-qty { width: 70px; }
.uh-table .uh-col-price { width: 140px; }
.uh-table .uh-col-vat { width: 70px; }
.uh-table .uh-col-total { width: 140px; }

.uh-totals-row.paid-row .lbl {
    color: #2e7d32;
    font-weight: 700;
}

.uh-totals-row.paid-row .amt {
    color: #2e7d32;
    font-family: 'Arial Narrow', Arial, sans-serif;
    font-size: 1.1rem;
    font-weight: 900;
}

.uh-sig-stamp {
    padding: 20px 36px 28px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    align-items: end;
    border-top: 1px solid #e2e8f0;
    margin-top: 8px;
}

.uh-sig-area-label,
.uh-stamp-label {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: 2px;
    color: #fc7f10;
    text-transform: uppercase;
    margin-bottom: 12px;
}

.uh-sig-image-area {
    min-height: 70px;
    display: flex;
    align-items: flex-end;
    padding-bottom: 6px;
}

.uh-sig-image-area img {
    max-width: 180px;
    max-height: 70px;
    object-fit: contain;
}

.uh-sig-placeholder {
    color: #94a3b8;
    font-size: .85rem;
}

.uh-sig-line-box { margin-top: 8px; }

.uh-sig-underline {
    border-top: 1px solid #1a2a72;
    padding-top: 7px;
    font-size: .82rem;
    color: #475569;
}

.uh-sig-name {
    font-size: .85rem;
    font-weight: 700;
    color: #1a2a72;
    margin-top: 2px;
}

.uh-sig-date {
    font-size: .78rem;
    color: #64748b;
    margin-top: 2px;
}

.uh-stamp-area {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
}

.uh-stamp-label { align-self: flex-start; }

.uh-stamp-svg-wrap svg {
    width: 150px;
    height: 150px;
}

@media (max-width: 700px) {
    .uh-meta-bar { grid-template-columns: 1fr 1fr; }
    .uh-parties { grid-template-columns: 1fr; gap: 16px; }
    .uh-party-divider { display: none; }
    .uh-sig-stamp { grid-template-columns: 1fr; }
}


/* ============================================================
   QUOTATIONS PAGE STYLES
   Moved from quotations.php to shared style.css
   ============================================================ */
@page { margin: 24px; }

        body {
            font-family: DejaVu Sans, Arial, sans-serif;
            font-size: 12px;
            color: #1f2937;
            margin: 0;
            padding: 0;
        }

        .doc {
            position: relative;
            background: #ffffff;
            padding: 6px;
        }

        .watermark {
            position: fixed;
            top: 22%;
            left: 14%;
            width: 460px;
            opacity: 0.05;
            z-index: 0;
        }

        .content {
            position: relative;
            z-index: 1;
        }

        .header {
            border-bottom: 2px solid #e5e7eb;
            padding-bottom: 14px;
            margin-bottom: 18px;
        }

        .header-table,
        .meta,
        .items,
        .totals,
        .signatures {
            width: 100%;
            border-collapse: collapse;
        }

        .header-table td {
            vertical-align: top;
        }

        .logo {
            width: 66px;
            height: 66px;
            object-fit: contain;
        }

        .company-name {
            font-size: 18px;
            font-weight: bold;
            color: #111827;
            margin-bottom: 4px;
        }

        .muted {
            color: #6b7280;
            font-size: 11px;
            line-height: 1.55;
        }

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

        .doc-type {
            font-size: 21px;
            font-weight: bold;
            color: #111827;
        }

        .doc-no {
            margin-top: 4px;
            color: #4b5563;
            font-size: 12px;
            font-weight: 600;
        }

        .paid {
            margin-top: 8px;
            display: inline-block;
            padding: 5px 12px;
            border: 1px solid #16a34a;
            color: #16a34a;
            font-weight: bold;
            border-radius: 999px;
            font-size: 11px;
        }

        .meta {
            margin-bottom: 18px;
        }

        .meta td {
            width: 50%;
            vertical-align: top;
            padding: 8px 14px 8px 0;
        }

        .meta h4 {
            margin: 0 0 8px;
            font-size: 13px;
            border-bottom: 1px solid #e5e7eb;
            padding-bottom: 5px;
            color: #334155;
        }

        .meta p {
            margin: 0;
            line-height: 1.7;
        }

        .items {
            margin-top: 8px;
        }

        .items th,
        .items td {
            border: 1px solid #dbe2ea;
            padding: 8px;
            font-size: 11px;
        }

        .items th {
            background: #f8fafc;
            text-align: left;
            color: #334155;
        }

        .right {
            text-align: right;
        }

        .totals {
            width: 330px;
            margin-left: auto;
            margin-top: 18px;
        }

        .totals td {
            padding: 8px 0;
            font-size: 12px;
        }

        .totals .label {
            text-align: left;
            color: #374151;
        }

        .totals .value {
            text-align: right;
            font-weight: 600;
            color: #111827;
        }

        .totals .grand td {
            border-top: 2px solid #111827;
            padding-top: 10px;
            font-weight: bold;
        }

        .totals .paid-row td {
            color: #16a34a;
            font-size: 14px;
            font-weight: bold;
            border-top: 1px dashed #cbd5e1;
            padding-top: 10px;
        }

        .notes {
            margin-top: 18px;
            font-size: 11px;
            color: #374151;
            line-height: 1.6;
        }

        .signatures {
            margin-top: 34px;
        }

        .signatures td {
            width: 50%;
            text-align: center;
            vertical-align: bottom;
            padding: 10px 18px 0 0;
        }

        .signature-image {
            max-width: 190px;
            max-height: 70px;
            object-fit: contain;
            margin-bottom: 8px;
        }

        .signature-name {
            font-size: 11px;
            font-weight: bold;
            color: #111827;
            margin-bottom: 4px;
        }

        .signature-date {
            font-size: 10px;
            color: #6b7280;
            margin-bottom: 6px;
        }

        .sign-line {
            border-top: 1px solid #9ca3af;
            padding-top: 6px;
            font-size: 11px;
            color: #6b7280;
        }

        .footer {
            margin-top: 24px;
            text-align: center;
            font-size: 10px;
            color: #6b7280;
            border-top: 1px solid #e5e7eb;
            padding-top: 10px;
            line-height: 1.6;
        }

/* ── Quotations Page ───────────────────────────────────── */
.quote-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.quote-section-icon {
    margin-right: 8px;
    color: var(--gold);
}

.quote-status-form,
.quote-row-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.quote-status-select { max-width: 160px; }
.quote-actions-col { min-width: 220px; }
.quote-number-link { color: var(--gold); }
.quote-empty-cell { text-align: center; color: #64748b; padding: 24px; }
.quote-form-divider { margin: 18px 0; border: 0; border-top: 1px solid #e5e7eb; }
.quote-add-item-btn { margin-top: 10px; }
.quote-preview-totals { margin-top: 18px; }
.quote-notes-field { margin-top: 16px; }
.quote-terms-field { margin-top: 14px; }
.quote-notes-box { margin-top: 20px; }
.quote-terms-box { margin-top: 14px; }

.quote-col-num { width: 50px; }
.quote-col-qty,
.quote-col-unit,
.quote-col-vat { width: 90px; }
.quote-col-price { width: 130px; }
.quote-col-total { width: 150px; }

.quote-signature-wrap {
    display: flex;
    justify-content: flex-end;
    margin-top: 44px;
}

.quote-signature-box {
    width: 260px;
    text-align: center;
}

.quote-signature-line {
    border-top: 1px solid #94a3b8;
    padding-top: 8px;
    font-weight: 700;
}

.quote-signature-for {
    font-size: .82rem;
    color: #64748b;
    margin-top: 4px;
}


.quote-brand-table { border-collapse: collapse; }
.quote-brand-logo-cell { width: 76px; vertical-align: top; }
.quote-form-col-num { width: 35px; }
.quote-form-col-qty,
.quote-form-col-vat { width: 60px; }
.quote-form-col-price { width: 95px; }
.quote-form-col-amount { width: 100px; }


/* ── Quotations full shared styles ─────────────────────── */
.quote-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.quote-grid{display:block}
.quote-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:18px;box-shadow:0 10px 25px rgba(15,23,42,.05)}
.quote-title{font-weight:800;font-size:1.05rem;margin-bottom:14px;color:#111827}
.quote-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.quote-form-group label{display:block;font-weight:700;font-size:.84rem;margin-bottom:6px;color:#374151}
.quote-form-group input,.quote-form-group select,.quote-form-group textarea{width:100%}
.quote-item-row{display:grid;grid-template-columns:1.1fr 1.7fr .6fr .65fr .8fr .65fr 44px;gap:10px;margin-bottom:10px;align-items:end}
.quote-table{width:100%;border-collapse:collapse}
.quote-table th,.quote-table td{border:1px solid #e5e7eb;padding:10px;vertical-align:top}
.quote-table th{background:#f8fafc;text-align:left;font-size:.82rem;text-transform:uppercase;color:#475569}
.text-right{text-align:right}
.status-pill{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:.76rem;font-weight:800;text-transform:uppercase}
.status-draft{background:#f1f5f9;color:#334155}.status-sent{background:#eff6ff;color:#1d4ed8}.status-accepted{background:#ecfdf5;color:#047857}.status-rejected{background:#fef2f2;color:#b91c1c}.status-expired{background:#fff7ed;color:#c2410c}
.print-quote{background:#fff;border-radius:18px;padding:32px;box-shadow:0 10px 28px rgba(15,23,42,.06);position:relative;overflow:hidden}
.print-quote::before{content:"";position:absolute;inset:0;background:url('assets/img/logo.png') no-repeat center;background-size:360px;opacity:.045;pointer-events:none}
.print-quote>*{position:relative;z-index:1}
.quote-header{display:flex;justify-content:space-between;gap:20px;border-bottom:1px solid #e5e7eb;padding-bottom:18px;margin-bottom:22px}
.quote-brand{display:flex;gap:14px;align-items:flex-start}.quote-brand img{width:64px;height:64px;object-fit:contain}.quote-company{font-weight:900;font-size:1.15rem}.quote-muted{color:#64748b;font-size:.88rem;line-height:1.6}.quote-doc-title{text-align:right}.quote-doc-title h2{margin:0;font-size:1.4rem;letter-spacing:.06em}
.quote-meta{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}.quote-box{border:1px solid #e5e7eb;border-radius:14px;background:#f8fafc;padding:14px}.quote-box-title{font-size:.75rem;font-weight:900;text-transform:uppercase;color:#64748b;margin-bottom:8px}
.quote-totals{width:340px;margin-left:auto;margin-top:18px;border:1px solid #e5e7eb;border-radius:14px;padding:14px}.quote-total-row{display:flex;justify-content:space-between;padding:7px 0}.quote-total-row.grand{border-top:2px solid #111827;margin-top:6px;padding-top:12px;font-weight:900}
.quote-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;z-index:99999;padding:20px}.quote-modal-backdrop.show{display:flex}.quote-modal{width:100%;max-width:1100px;max-height:92vh;overflow:auto;background:#fff;border-radius:18px;box-shadow:0 25px 70px rgba(0,0,0,.22)}.quote-modal-header,.quote-modal-footer{padding:16px 20px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;gap:12px}.quote-modal-footer{border-bottom:0;border-top:1px solid #e5e7eb}.quote-modal-header h3{margin:0;font-size:1.05rem;font-weight:800}.quote-modal-close{border:0;background:transparent;cursor:pointer;color:#64748b;font-size:18px}.quote-modal-body{padding:20px}
@media(max-width:1100px){.quote-item-row{grid-template-columns:1fr}}@media(max-width:900px){.quote-meta,.quote-form-grid{grid-template-columns:1fr}.quote-doc-title{text-align:left}}@media print{.no-print,.doc-actions,.quote-actions,header,nav,.sidebar,.topbar,footer{display:none!important}.print-quote{box-shadow:none;border-radius:0;padding:0}}
