/* ==========================================================================
   NexiBook Design System — Polish Pass v1
   Date: 2026-04-19
   Scope: tenant + trainer + customer surfaces (all of booking app)

   Goal: visual refinement ONLY. Zero HTML mutations, zero new routes,
         zero business-logic impact. Applies on top of legacy CSS as a
         last-loaded stylesheet — wins the cascade naturally without
         !important on anything except where Bootstrap brute-forces a bg.

   Load order (per partials/header.ejs and customer/layout.ejs):
     /ds/colors_and_type.css    (tokens + Inter/DM Serif/Plus Jakarta)
     /ds/admin_palette.css      (admin surfaces only — indigo override)
     /css/style.css             (legacy)
     /css/sintra-theme.css      (legacy)
     /css/dashboard-premium.css (legacy)
     /css/design-system/tokens.css + components.css + animations.css (older DS)
     /css/theme-utilities.css
     /css/components/*.css
     /css/design-system/polish-v1.css  ← THIS FILE (last, wins)

   To remove: delete the two <link> tags referencing this file from
     views/partials/header.ejs and views/customer/layout.ejs.
   ========================================================================== */


/* ───────────────────────────────────────────────────────────────────────────
   Global typography smoothing
   ─────────────────────────────────────────────────────────────────────────── */
body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6 {
    letter-spacing: var(--nb-track-heading, -0.01em);
    line-height: var(--nb-line-heading, 1.15);
}


/* ───────────────────────────────────────────────────────────────────────────
   Cards (Bootstrap .card + generic cards)
   ─────────────────────────────────────────────────────────────────────────── */
.card {
    border: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.10));
    border-radius: var(--nb-radius-lg, 16px);
    background: var(--nb-bg-surface, #0f0f10);
    transition: border-color 0.2s var(--nb-ease-smooth, cubic-bezier(0.4, 0, 0.2, 1)),
                transform 0.2s var(--nb-ease-smooth, cubic-bezier(0.4, 0, 0.2, 1));
}

.card-header,
.card > .card-header {
    background: transparent;
    border-bottom: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.08));
    font-weight: var(--nb-weight-semi, 600);
    padding-block: 14px;
}

.card-footer {
    background: transparent;
    border-top: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.08));
}


/* ───────────────────────────────────────────────────────────────────────────
   Buttons (Bootstrap .btn family + generic buttons)
   ─────────────────────────────────────────────────────────────────────────── */
.btn {
    border-radius: var(--nb-radius-sm, 8px);
    font-weight: var(--nb-weight-semi, 600);
    letter-spacing: 0.01em;
    transition: transform 0.15s var(--nb-ease-smooth, ease),
                box-shadow 0.15s var(--nb-ease-smooth, ease),
                filter 0.15s ease;
}

.btn:hover:not(:disabled):not(.disabled):not([aria-disabled="true"]) {
    transform: translateY(-1px);
    filter: brightness(1.05);
}

.btn:active:not(:disabled):not(.disabled) {
    transform: translateY(0);
    filter: brightness(0.95);
}

.btn:disabled,
.btn.disabled,
.btn[aria-disabled="true"] {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
    filter: none;
}

/* Outline buttons — align with brand color even when legacy uses Bootstrap defaults */
.btn-outline-primary,
.btn-outline-success {
    color: var(--color-primary, var(--nb-gold, #FFD700));
    border-color: var(--color-primary, var(--nb-gold, #FFD700));
}

.btn-outline-primary:hover,
.btn-outline-success:hover {
    background: var(--color-primary, var(--nb-gold, #FFD700));
    color: var(--color-primary-text, #000);
}


/* ───────────────────────────────────────────────────────────────────────────
   Form inputs
   ─────────────────────────────────────────────────────────────────────────── */
.form-control,
.form-select,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
textarea {
    background: var(--nb-bg-surface, #0f0f10);
    border: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.12));
    border-radius: var(--nb-radius-sm, 8px);
    color: var(--nb-text-main, #ffffff);
    padding-block: 0.55rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.form-control:focus,
.form-select:focus,
input:focus,
textarea:focus {
    border-color: var(--color-primary, var(--nb-gold, #FFD700));
    box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb, 255, 215, 0), 0.14);
    outline: none;
}

.form-control::placeholder,
input::placeholder,
textarea::placeholder {
    color: var(--nb-text-secondary, #909090);
    opacity: 1;
}

.form-label {
    font-weight: var(--nb-weight-medium, 500);
    color: var(--nb-text-muted, #c0c0c0);
    font-size: 0.88rem;
    margin-bottom: 6px;
}


/* ───────────────────────────────────────────────────────────────────────────
   Badges / pills
   ─────────────────────────────────────────────────────────────────────────── */
.badge {
    border-radius: var(--nb-radius-full, 999px);
    font-weight: var(--nb-weight-semi, 600);
    padding: 4px 10px;
    letter-spacing: 0.02em;
    font-size: 0.75rem;
}


/* ───────────────────────────────────────────────────────────────────────────
   Tables
   ─────────────────────────────────────────────────────────────────────────── */
.table {
    color: var(--nb-text-main, #ffffff);
    border-color: var(--nb-border-light, rgba(255, 255, 255, 0.08));
}

.table > :not(caption) > * > * {
    background-color: transparent;
    color: inherit;
}

.table thead th,
.table > thead > tr > th {
    border-bottom: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.12));
    color: var(--nb-text-muted, #c0c0c0);
    font-weight: var(--nb-weight-semi, 600);
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding-block: 12px;
}

.table tbody tr {
    transition: background 0.15s ease;
}

.table tbody tr:hover {
    background: rgba(255, 255, 255, 0.025);
}

.table > :not(:first-child) {
    border-top: 0;
}


/* ───────────────────────────────────────────────────────────────────────────
   Modals
   ─────────────────────────────────────────────────────────────────────────── */
.modal-content {
    background: var(--nb-bg-surface, #0f0f10);
    border: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.1));
    border-radius: var(--nb-radius-xl, 24px);
    color: var(--nb-text-main, #ffffff);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
}

.modal-header {
    border-bottom: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.08));
    padding: 1.1rem 1.4rem;
}

.modal-footer {
    border-top: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.08));
    padding: 0.9rem 1.4rem;
}

.modal-backdrop.show {
    opacity: 0.75;
}


/* ───────────────────────────────────────────────────────────────────────────
   Dropdown menus
   ─────────────────────────────────────────────────────────────────────────── */
.dropdown-menu {
    background: var(--nb-bg-surface, #0f0f10);
    border: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.12));
    border-radius: var(--nb-radius-md, 12px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.5);
    padding: 6px;
}

.dropdown-item {
    color: var(--nb-text-main, #ffffff);
    padding: 8px 14px;
    border-radius: var(--nb-radius-sm, 8px);
    transition: background 0.15s ease, color 0.15s ease;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background: rgba(255, 255, 255, 0.06);
    color: var(--nb-text-main, #ffffff);
}

.dropdown-item.active,
.dropdown-item:active {
    background: var(--color-primary, var(--nb-gold, #FFD700));
    color: var(--color-primary-text, #000);
}

.dropdown-divider {
    border-top-color: var(--nb-border-light, rgba(255, 255, 255, 0.08));
    margin: 6px 0;
}


/* ───────────────────────────────────────────────────────────────────────────
   Alerts / toasts
   ─────────────────────────────────────────────────────────────────────────── */
.alert {
    border-radius: var(--nb-radius-md, 12px);
    border: 1px solid var(--nb-border-light, rgba(255, 255, 255, 0.1));
    padding: 14px 18px;
}

.alert-success {
    background: rgba(16, 185, 129, 0.10);
    border-color: rgba(16, 185, 129, 0.30);
    color: var(--nb-app-success, #10b981);
}

.alert-warning,
.alert-warn {
    background: rgba(245, 158, 11, 0.10);
    border-color: rgba(245, 158, 11, 0.30);
    color: var(--nb-app-cta, #f59e0b);
}

.alert-danger,
.alert-error {
    background: rgba(248, 113, 113, 0.10);
    border-color: rgba(248, 113, 113, 0.30);
    color: var(--nb-danger, #f87171);
}

.alert-info {
    background: rgba(99, 102, 241, 0.10);
    border-color: rgba(99, 102, 241, 0.30);
    color: #a5b4fc;
}


/* ───────────────────────────────────────────────────────────────────────────
   Progress bars
   ─────────────────────────────────────────────────────────────────────────── */
.progress {
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--nb-radius-full, 999px);
    overflow: hidden;
    height: 8px;
}

.progress-bar {
    background: var(--color-primary, var(--nb-gold, #FFD700));
    transition: width 0.3s ease;
}


/* ───────────────────────────────────────────────────────────────────────────
   Scrollbars — subtle dark, matches surface
   ─────────────────────────────────────────────────────────────────────────── */
*::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

*::-webkit-scrollbar-track {
    background: transparent;
}

*::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 5px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

*::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.18);
    background-clip: padding-box;
    border: 2px solid transparent;
}

/* Firefox */
html {
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.12) transparent;
}


/* ───────────────────────────────────────────────────────────────────────────
   Focus rings — accessibility + brand consistency
   ─────────────────────────────────────────────────────────────────────────── */
*:focus-visible {
    outline: 2px solid var(--color-primary, var(--nb-gold, #FFD700));
    outline-offset: 2px;
    border-radius: 4px;
}

button:focus-visible,
a:focus-visible,
.btn:focus-visible {
    outline-offset: 3px;
}

input:focus-visible,
textarea:focus-visible,
select:focus-visible,
.form-control:focus-visible {
    outline: none; /* already styled via box-shadow above */
}


/* ───────────────────────────────────────────────────────────────────────────
   Links in body copy
   ─────────────────────────────────────────────────────────────────────────── */
a {
    transition: color 0.15s ease;
}

.card a:not(.btn):not(.dropdown-item):not(.nav-link),
.modal-body a:not(.btn):not(.dropdown-item) {
    color: var(--color-primary, var(--nb-gold, #FFD700));
    text-decoration: none;
    border-bottom: 1px solid transparent;
}

.card a:not(.btn):not(.dropdown-item):not(.nav-link):hover,
.modal-body a:not(.btn):not(.dropdown-item):hover {
    border-bottom-color: currentColor;
}


/* ───────────────────────────────────────────────────────────────────────────
   Reduced-motion preference
   ─────────────────────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .btn:hover:not(:disabled):not(.disabled),
    .card,
    .dropdown-item,
    .progress-bar,
    a {
        transition: none !important;
        transform: none !important;
    }
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
