/* ============================================================================
   Brooks Warehouse — base.css
   Component library built on palette.css tokens. No hardcoded hex values here.
   Load order on every page: palette.css -> base.css -> <page>.css
   ============================================================================ */

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

html, body {
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-family-base);
    font-size: var(--fs-body);
    font-weight: 400;
    color: var(--font-color);
    background-color: var(--background-color);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

/* --- Headings: large + light --- */
h1, h2, h3, h4, h5, h6 { margin: 0 0 var(--sp-3); line-height: 1.2; color: var(--font-color); }
h1 { font-size: var(--fs-h1); font-weight: 300; letter-spacing: var(--ls-tight); }
h2 { font-size: var(--fs-h2); font-weight: 400; letter-spacing: var(--ls-tight); }
h3 { font-size: var(--fs-h3); font-weight: 500; }
h4 { font-size: var(--fs-h4); font-weight: 600; }

a { color: var(--link-color); text-decoration: none; }
a:hover { color: var(--link-hover-color); text-decoration: underline; }

.bbs-eyebrow {
    font-size: var(--fs-caption);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--ls-wider);
    color: var(--accent-color);
    margin: 0 0 var(--sp-2);
}
.bbs-muted { color: var(--text-muted); }
.bbs-faint { color: var(--text-faint); }
.bbs-num { font-variant-numeric: tabular-nums; }
.bbs-hidden { display: none !important; }

:focus-visible {
    outline: 2px solid var(--focus-ring-color);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* ============================================================================
   App shell — shared header / nav
   ============================================================================ */
.bbs-header {
    position: sticky;
    top: 0;
    z-index: var(--z-header);
    display: flex;
    align-items: center;
    gap: var(--sp-5);
    padding: 0 var(--sp-5);
    height: 64px;
    background: var(--header-bg);
    border-bottom: 1px solid var(--header-border);
}
.bbs-header__brand {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    text-decoration: none;
    flex-shrink: 0;
}
.bbs-header__brand img { height: 34px; width: auto; display: block; }
.bbs-header__brand:hover { text-decoration: none; }

.bbs-nav {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    flex: 1;
    overflow-x: auto;
    scrollbar-width: thin;
}
.bbs-nav__link {
    position: relative;
    padding: var(--sp-2) var(--sp-2);
    font-size: var(--fs-small);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    color: var(--nav-fg);
    white-space: nowrap;
    text-decoration: none;
    border-bottom: 2px solid transparent;
}
.bbs-nav__link:hover { color: var(--nav-fg-active); text-decoration: none; }
.bbs-nav__link.is-active {
    color: var(--nav-fg-active);
    border-bottom-color: var(--nav-underline);
}

.bbs-header__actions {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    flex-shrink: 0;
}

/* icon button (notification bell) */
.bbs-iconbtn {
    position: relative;
    width: 40px;
    height: 40px;
    border: none;
    background: transparent;
    border-radius: var(--radius-pill);
    cursor: pointer;
    font-size: 1.2rem;
    color: var(--text-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.bbs-iconbtn:hover { background: var(--surface-3); color: var(--font-color); }
.bbs-iconbtn__dot {
    position: absolute;
    top: 7px;
    right: 8px;
    width: 9px;
    height: 9px;
    background: var(--danger-color);
    border: 2px solid var(--surface);
    border-radius: var(--radius-pill);
}

/* user avatar + menu */
.bbs-avatar {
    width: 40px;
    height: 40px;
    border: none;
    border-radius: var(--radius-pill);
    background: var(--primary-color);
    color: var(--on-primary);
    font-weight: 700;
    font-size: 1rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.bbs-avatar:hover { background: var(--primary-hover); }

.bbs-menu {
    position: absolute;
    top: 56px;
    right: var(--sp-5);
    min-width: 200px;
    background: var(--surface);
    border: 1px solid var(--hairline);
    border-radius: var(--radius-md);
    box-shadow: var(--elev-3);
    padding: var(--sp-2);
    z-index: var(--z-dropdown);
}
.bbs-menu__user {
    padding: var(--sp-2) var(--sp-3);
    border-bottom: 1px solid var(--hairline);
    margin-bottom: var(--sp-2);
}
.bbs-menu__name { font-weight: 600; }
.bbs-menu__item {
    display: block;
    width: 100%;
    text-align: left;
    padding: var(--sp-2) var(--sp-3);
    border: none;
    background: transparent;
    color: var(--font-color);
    font-family: inherit;
    font-size: var(--fs-small);
    border-radius: var(--radius-sm);
    cursor: pointer;
}
.bbs-menu__item:hover { background: var(--surface-3); }
.bbs-menu__item--danger { color: var(--danger-fg); }

/* ============================================================================
   Page shell
   ============================================================================ */
.bbs-page {
    max-width: 1280px;
    margin: 0 auto;
    padding: var(--sp-6) var(--sp-5) var(--sp-8);
}
.bbs-page--wide { max-width: 1480px; }

.bbs-page__title {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--sp-4);
    margin-bottom: var(--sp-5);
    flex-wrap: wrap;
}
.bbs-page__title h1 { margin: 0; }

.bbs-card {
    background: var(--surface);
    border-radius: var(--radius-lg);
    padding: var(--sp-5);
    box-shadow: var(--elev-2);
}
.bbs-card + .bbs-card { margin-top: var(--sp-5); }

.bbs-toolbar {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    flex-wrap: wrap;
    margin-bottom: var(--sp-4);
}
.bbs-toolbar__spacer { flex: 1; }

/* ============================================================================
   Buttons
   ============================================================================ */
.bbs-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    min-height: 38px;
    padding: 0 var(--sp-4);
    font-family: inherit;
    font-size: var(--fs-small);
    font-weight: 600;
    letter-spacing: var(--ls-wide);
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease;
}
.bbs-btn:hover { text-decoration: none; }
.bbs-btn:disabled, .bbs-btn.is-disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }
.bbs-btn--lg { min-height: 46px; padding: 0 var(--sp-5); font-size: var(--fs-body); width: 100%; }

.bbs-btn--primary { background: var(--primary-color); color: var(--on-primary); }
.bbs-btn--primary:hover { background: var(--primary-hover); color: var(--on-primary); }

.bbs-btn--accent { background: var(--accent-color); color: var(--on-accent); }
.bbs-btn--accent:hover { background: var(--accent-hover); color: var(--on-accent); }

.bbs-btn--secondary {
    background: var(--surface);
    color: var(--font-color);
    border-color: var(--hairline-strong);
}
.bbs-btn--secondary:hover { background: var(--surface-3); }

.bbs-btn--ghost { background: transparent; color: var(--text-muted); }
.bbs-btn--ghost:hover { background: var(--surface-3); color: var(--font-color); }

.bbs-btn--danger { background: var(--danger-color); color: var(--on-danger); }
.bbs-btn--danger:hover { background: var(--danger-fg); color: var(--on-danger); }

.bbs-btn--dark { background: var(--dark-btn-bg); color: var(--on-dark-btn); }
.bbs-btn--dark:hover { background: var(--dark-btn-hover); color: var(--on-dark-btn); }

/* ============================================================================
   Forms
   ============================================================================ */
.bbs-field { margin-bottom: var(--sp-4); text-align: left; }
.bbs-label {
    display: block;
    font-size: var(--fs-small);
    font-weight: 600;
    color: var(--text-muted);
    margin-bottom: var(--sp-2);
}
.bbs-req::after { content: ' *'; color: var(--danger-color); }

.bbs-input, .bbs-select, .bbs-textarea {
    width: 100%;
    padding: 10px var(--sp-3);
    font-family: inherit;
    font-size: var(--fs-body);
    color: var(--font-color);
    background: var(--surface);
    border: 1px solid var(--hairline-strong);
    border-radius: var(--radius-md);
}
.bbs-input:focus, .bbs-select:focus, .bbs-textarea:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px var(--accent-wash);
}
.bbs-textarea { min-height: 90px; resize: vertical; }
.bbs-select { cursor: pointer; }

.bbs-field.is-invalid .bbs-input,
.bbs-field.is-invalid .bbs-select { border-color: var(--danger-color); }
.bbs-field__error { color: var(--danger-fg); font-size: var(--fs-small); margin-top: var(--sp-2); }

/* ============================================================================
   Tables — flat, no zebra
   ============================================================================ */
.bbs-table-wrap { width: 100%; overflow-x: auto; }
.bbs-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--fs-small);
}
.bbs-table th {
    text-align: left;
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    font-size: var(--fs-caption);
    font-weight: 600;
    color: var(--text-muted);
    padding: var(--sp-3) var(--sp-3);
    border-bottom: 2px solid var(--accent-wash);
    white-space: nowrap;
}
.bbs-table td {
    padding: var(--sp-3) var(--sp-3);
    border-bottom: 1px solid var(--hairline);
    vertical-align: middle;
}
.bbs-table tbody tr:hover { background: var(--row-hover-bg); }
.bbs-table tbody tr.is-selected { background: var(--row-selected-bg); }
.bbs-table .bbs-num { text-align: right; font-variant-numeric: tabular-nums; }

/* row status tints (verify page) */
.bbs-row--ok { background: var(--success-bg); }
.bbs-row--ok:hover { background: var(--success-bg); }
.bbs-row--over { background: var(--danger-bg); }
.bbs-row--over:hover { background: var(--danger-bg); }
.bbs-row--under { background: var(--warning-bg); }
.bbs-row--under:hover { background: var(--warning-bg); }

/* ============================================================================
   Badges & alerts
   ============================================================================ */
.bbs-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px var(--sp-2);
    font-size: var(--fs-caption);
    font-weight: 600;
    border-radius: var(--radius-pill);
}
.bbs-badge--success { background: var(--success-bg); color: var(--success-fg); }
.bbs-badge--warning { background: var(--warning-bg); color: var(--warning-fg); }
.bbs-badge--danger { background: var(--danger-bg); color: var(--danger-fg); }
.bbs-badge--info { background: var(--info-bg); color: var(--info-fg); }

.bbs-alert {
    padding: var(--sp-3) var(--sp-4);
    border-radius: var(--radius-md);
    font-size: var(--fs-small);
}
.bbs-alert--info { background: var(--info-bg); color: var(--info-fg); }
.bbs-alert--success { background: var(--success-bg); color: var(--success-fg); }
.bbs-alert--danger { background: var(--danger-bg); color: var(--danger-fg); }

.bbs-empty {
    text-align: center;
    color: var(--text-faint);
    padding: var(--sp-7) var(--sp-4);
}

/* ============================================================================
   Modal & drawer (used by ui.js / header.js)
   ============================================================================ */
.bbs-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(43, 47, 51, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-modal-backdrop);
    padding: var(--sp-4);
    opacity: 0;
    transition: opacity 0.15s ease;
}
.bbs-modal-backdrop.is-open { opacity: 1; }

.bbs-modal {
    background: var(--surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--elev-3);
    width: 100%;
    max-width: 480px;
    z-index: var(--z-modal);
    transform: translateY(8px);
    transition: transform 0.15s ease;
    display: flex;
    flex-direction: column;
    max-height: 90vh;
}
.bbs-modal-backdrop.is-open .bbs-modal { transform: translateY(0); }
.bbs-modal--narrow { max-width: 380px; }

.bbs-modal__head {
    padding: var(--sp-5) var(--sp-5) var(--sp-3);
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}
.bbs-modal__icon {
    width: 36px; height: 36px; flex-shrink: 0;
    border-radius: var(--radius-pill);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
}
.bbs-modal__icon--info { background: var(--info-bg); color: var(--info-fg); }
.bbs-modal__icon--success { background: var(--success-bg); color: var(--success-fg); }
.bbs-modal__icon--danger { background: var(--danger-bg); color: var(--danger-fg); }
.bbs-modal__title { font-size: var(--fs-h4); font-weight: 600; margin: 0; }
.bbs-modal__body { padding: 0 var(--sp-5) var(--sp-4); overflow-y: auto; }
.bbs-modal__body p { margin: 0 0 var(--sp-3); color: var(--text-muted); }
.bbs-modal__foot {
    padding: var(--sp-3) var(--sp-5) var(--sp-5);
    display: flex;
    justify-content: flex-end;
    gap: var(--sp-3);
}

/* right-side drawer (notifications) */
.bbs-drawer-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(43, 47, 51, 0.35);
    z-index: var(--z-modal-backdrop);
    opacity: 0;
    transition: opacity 0.15s ease;
}
.bbs-drawer-backdrop.is-open { opacity: 1; }
.bbs-drawer {
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    width: min(420px, 90vw);
    background: var(--surface);
    box-shadow: var(--elev-3);
    z-index: var(--z-modal);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.2s ease;
}
.bbs-drawer.is-open { transform: translateX(0); }
.bbs-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-5);
    border-bottom: 1px solid var(--hairline);
}
.bbs-drawer__head h2 { margin: 0; font-size: var(--fs-h3); }
.bbs-drawer__body { padding: var(--sp-4) var(--sp-5); overflow-y: auto; flex: 1; }

.bbs-noti {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    padding: var(--sp-3);
    border-radius: var(--radius-md);
    margin-bottom: var(--sp-2);
}
.bbs-noti--unread { background: var(--danger-bg); }
.bbs-noti--read { background: var(--surface-3); color: var(--text-muted); }

/* spinner */
.bbs-spinner {
    width: 28px; height: 28px;
    border: 3px solid var(--hairline-strong);
    border-top-color: var(--primary-color);
    border-radius: var(--radius-pill);
    animation: bbs-spin 0.8s linear infinite;
    margin: var(--sp-4) auto;
}
@keyframes bbs-spin { to { transform: rotate(360deg); } }

@media (max-width: 720px) {
    .bbs-header { gap: var(--sp-3); padding: 0 var(--sp-3); }
    .bbs-page { padding: var(--sp-4) var(--sp-3) var(--sp-7); }
    .bbs-menu { right: var(--sp-3); }
}
