/* ==========================================================================
   SASSE-CRM — Mobile-First Stylesheet
   No framework. Pure CSS. Professional CRM design.
   BEM notation: block__element--modifier
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. CSS Custom Properties (Variables)
   -------------------------------------------------------------------------- */
:root {
    /* Brand Colors */
    --color-primary: #2c3e50;
    --color-primary-light: #34495e;
    --color-primary-dark: #1a252f;
    --color-secondary: #3498db;
    --color-secondary-light: #5dade2;
    --color-secondary-dark: #2980b9;

    /* Semantic Colors */
    --color-success: #27ae60;
    --color-success-light: #2ecc71;
    --color-success-bg: #eafaf1;
    --color-warning: #f39c12;
    --color-warning-light: #f5b041;
    --color-warning-bg: #fef9e7;
    --color-error: #e74c3c;
    --color-error-light: #ec7063;
    --color-error-bg: #fdedec;
    --color-info: #3498db;
    --color-info-light: #5dade2;
    --color-info-bg: #ebf5fb;

    /* Neutrals */
    --color-background: #f5f6fa;
    --color-surface: #ffffff;
    --color-text: #2c3e50;
    --color-text-secondary: #636e72;
    --color-text-muted: #95a5a6;
    --color-border: #dcdde1;
    --color-border-light: #ecf0f1;

    /* Spacing */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-xxl: 3rem;

    /* Typography */
    --font-family: system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-xxl: 1.5rem;
    --font-size-xxxl: 2rem;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --line-height: 1.6;

    /* Layout */
    --sidebar-width: 260px;
    --sidebar-collapsed-width: 60px;
    --header-height: 60px;
    --border-radius: 6px;
    --border-radius-sm: 4px;
    --border-radius-lg: 10px;
    --border-radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07);
    --shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 40px rgba(0, 0, 0, 0.12);

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 350ms ease;

    /* Z-Index Scale */
    --z-dropdown: 100;
    --z-sidebar: 200;
    --z-header: 300;
    --z-overlay: 400;
    --z-modal: 500;
    --z-toast: 600;
}


/* --------------------------------------------------------------------------
   2. Reset & Base
   -------------------------------------------------------------------------- */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-normal);
    line-height: var(--line-height);
    color: var(--color-text);
    background-color: var(--color-background);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a {
    color: var(--color-secondary);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--color-secondary-dark);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

ul, ol {
    list-style: none;
}

input,
select,
textarea,
button {
    font-family: inherit;
    font-size: inherit;
}

::selection {
    background-color: var(--color-secondary);
    color: #fff;
}


/* --------------------------------------------------------------------------
   3. Typography
   -------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
    font-weight: var(--font-weight-semibold);
    line-height: 1.3;
    color: var(--color-primary);
    margin-bottom: var(--spacing-sm);
}

h1 {
    font-size: var(--font-size-xxxl);
    font-weight: var(--font-weight-bold);
}

h2 {
    font-size: var(--font-size-xxl);
}

h3 {
    font-size: var(--font-size-xl);
}

h4 {
    font-size: var(--font-size-lg);
}

h5 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
}

h6 {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-secondary);
}

p {
    margin-bottom: var(--spacing-md);
}

.text-muted {
    color: var(--color-text-muted);
}

.text-primary {
    color: var(--color-secondary);
}

.text-success {
    color: var(--color-success);
}

.text-danger,
.text--danger {
    color: var(--color-error);
}

.text-warning {
    color: var(--color-warning);
}

.text-center {
    text-align: center;
}

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

.text-pre {
    white-space: pre-wrap;
}

small, .text-sm {
    font-size: var(--font-size-sm);
}

.nowrap {
    white-space: nowrap;
}


/* --------------------------------------------------------------------------
   4. Spacing Utilities
   -------------------------------------------------------------------------- */
.mb-1 { margin-bottom: var(--spacing-sm); }
.mb-2 { margin-bottom: var(--spacing-md); }
.mb-3 { margin-bottom: var(--spacing-lg); }
.mb-4 { margin-bottom: var(--spacing-xl); }

.mt-1 { margin-top: var(--spacing-sm); }
.mt-2 { margin-top: var(--spacing-md); }
.mt-3 { margin-top: var(--spacing-lg); }
.mt-4 { margin-top: var(--spacing-xl); }

.mr-1 { margin-right: var(--spacing-sm); }
.mr-2 { margin-right: var(--spacing-md); }

.ml-1 { margin-left: var(--spacing-sm); }
.ml-2 { margin-left: var(--spacing-md); }

.p-1 { padding: var(--spacing-sm); }
.p-2 { padding: var(--spacing-md); }
.p-3 { padding: var(--spacing-lg); }

.d-flex { display: flex; }
.d-block { display: block; }
.d-none { display: none; }

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

.flex-center {
    display: flex;
    align-items: center;
    justify-content: center;
}

.gap-1 { gap: var(--spacing-sm); }
.gap-2 { gap: var(--spacing-md); }


/* --------------------------------------------------------------------------
   5. Layout — Header + Sidebar + Main Content
   -------------------------------------------------------------------------- */

/* === Layout wrapper (body class) === */
.layout {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.layout__body {
    display: flex;
    flex: 1;
    min-height: 0;
}

/* === Header === */
.header {
    position: sticky;
    top: 0;
    height: var(--header-height);
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 var(--spacing-md);
    z-index: var(--z-header);
    gap: var(--spacing-md);
}

.header__left {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.header__right {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.header__brand {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    text-decoration: none;
}

.header__brand:hover {
    color: var(--color-primary-dark);
}

/* Hamburger button */
.header__hamburger {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    width: 36px;
    height: 36px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-text);
    border-radius: var(--border-radius-sm);
    transition: background var(--transition-fast);
    padding: 0;
}

.header__hamburger:hover {
    background: var(--color-border-light);
}

.header__hamburger-line {
    display: block;
    width: 20px;
    height: 2px;
    background: var(--color-text);
    border-radius: 2px;
    transition: all var(--transition-fast);
}

/* Language switcher */
.header__lang {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.header__lang-item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.2em 0.5em;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-secondary);
    border-radius: var(--border-radius-sm);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.header__lang-item:hover {
    background: var(--color-border-light);
    color: var(--color-text);
}

.header__lang-item--active {
    background: var(--color-secondary);
    color: #fff;
    cursor: default;
}

.header__lang-item--active:hover {
    background: var(--color-secondary);
    color: #fff;
}

/* User menu */
.header__user {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.header__user-name {
    color: var(--color-text);
    font-weight: var(--font-weight-medium);
}

.header__user-link {
    color: var(--color-secondary);
    text-decoration: none;
    font-size: var(--font-size-sm);
}

.header__user-link:hover {
    color: var(--color-secondary-dark);
}

.header__user-link--logout {
    color: var(--color-error);
}

.header__user-link--logout:hover {
    color: #c0392b;
}

/* Header logout button — prominent, always visible */
.header__logout-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: 0.35rem 0.75rem;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-error);
    background: transparent;
    border: 1px solid var(--color-error);
    border-radius: var(--border-radius-sm);
    text-decoration: none;
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.header__logout-btn:hover {
    background: var(--color-error);
    color: #fff;
}

.header__logout-icon {
    font-size: var(--font-size-base);
    line-height: 1;
}

/* === Sidebar === */
.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: var(--sidebar-width);
    height: 100vh;
    background: var(--color-primary);
    color: #fff;
    z-index: var(--z-sidebar);
    display: flex;
    flex-direction: column;
    transition: transform var(--transition-base), width var(--transition-base);
    overflow-y: auto;
    overflow-x: hidden;
}

/* Mobile: sidebar hidden off-screen */
.sidebar {
    transform: translateX(-100%);
}

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

/* Sidebar overlay on mobile */
.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: calc(var(--z-sidebar) - 1);
}

.sidebar-overlay.active {
    display: block;
}

/* Sidebar navigation */
.sidebar__nav {
    flex: 1;
    padding: var(--spacing-md) 0;
}

/* Sidebar groups */
.sidebar__group {
    margin-bottom: var(--spacing-xs);
}

.sidebar__group-title {
    display: block;
    font-size: var(--font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.4);
    padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-xs);
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
    overflow: hidden;
}

/* Sidebar links */
.sidebar__link {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-lg);
    color: rgba(255, 255, 255, 0.7);
    font-size: var(--font-size-sm);
    border-left: 3px solid transparent;
    transition: all var(--transition-fast);
    white-space: nowrap;
    overflow: hidden;
    text-decoration: none;
    margin: 2px 0;
}

.sidebar__link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
}

.sidebar__link--active {
    color: #fff;
    background: rgba(255, 255, 255, 0.12);
    border-left-color: var(--color-secondary);
}

.sidebar__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
}

.sidebar__label {
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Sidebar footer (User + Logout) */
.sidebar__footer {
    margin-top: auto;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding: var(--spacing-sm) 0;
}

.sidebar__footer-user {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-lg);
    color: rgba(255, 255, 255, 0.6);
    font-size: var(--font-size-sm);
}

.sidebar__link--logout {
    color: rgba(255, 255, 255, 0.7);
}

.sidebar__link--logout:hover {
    background: rgba(231, 76, 60, 0.2);
    color: #e74c3c;
}

/* Sidebar collapse button */
.sidebar__collapse {
    display: none;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    background: none;
    border-left: none;
    border-right: none;
    border-bottom: none;
    color: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: color var(--transition-fast);
    flex-shrink: 0;
}

.sidebar__collapse:hover {
    color: #fff;
}

.sidebar__collapse-icon {
    font-size: var(--font-size-lg);
}

/* === Main Content === */
.main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    padding: var(--spacing-md);
}

.main__content {
    flex: 1;
}

/* === Footer === */
.footer {
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    text-align: center;
}

.footer__text {
    margin: 0;
}


/* --------------------------------------------------------------------------
   6. Cards
   -------------------------------------------------------------------------- */
.card {
    background: var(--color-surface);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
    overflow: hidden;
    transition: box-shadow var(--transition-fast);
    margin-bottom: var(--spacing-lg);
}

.card:hover {
    box-shadow: var(--shadow-md);
}

.card-header,
.card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--color-border-light);
}

.card-header h3,
.card-header h4,
.card__header h3,
.card__header h4 {
    margin-bottom: 0;
}

.card__title {
    margin-bottom: 0;
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
}

.card-body,
.card__body {
    padding: var(--spacing-lg);
}

.card-footer,
.card__footer {
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
    background: var(--color-background);
}


/* --------------------------------------------------------------------------
   7. Dashboard
   -------------------------------------------------------------------------- */
.dashboard {
    /* container */
}

.dashboard__welcome {
    margin-bottom: var(--spacing-lg);
}

.dashboard__title {
    font-size: var(--font-size-xxl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-xs);
}

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

/* Dashboard stat cards */
.dashboard__stats {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.dashboard__card {
    background: var(--color-surface);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

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

.dashboard__card-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--border-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-xl);
    flex-shrink: 0;
}

.dashboard__card--companies .dashboard__card-icon {
    background: var(--color-info-bg);
    color: var(--color-secondary);
}

.dashboard__card--contacts .dashboard__card-icon {
    background: var(--color-success-bg);
    color: var(--color-success);
}

.dashboard__card--quotes .dashboard__card-icon {
    background: var(--color-warning-bg);
    color: var(--color-warning);
}

.dashboard__card--translations .dashboard__card-icon {
    background: #f5eef8;
    color: #8e44ad;
}

.dashboard__card-body {
    flex: 1;
    min-width: 0;
}

.dashboard__card-value {
    display: block;
    font-size: var(--font-size-xxl);
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
    color: var(--color-primary);
}

.dashboard__card-label {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
}

/* Dashboard grid (activity + translations side by side) */
.dashboard__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
}

.dashboard__section {
    background: var(--color-surface);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
    padding: var(--spacing-lg);
}

.dashboard__section-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-md);
}

.dashboard__section-body {
    /* wrapper */
}

.dashboard__activity-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.dashboard__activity-item {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--color-border-light);
    font-size: var(--font-size-sm);
}

.dashboard__activity-item:last-child {
    border-bottom: none;
}

.dashboard__activity-text {
    flex: 1;
    min-width: 0;
}

.dashboard__activity-time {
    color: var(--color-text-muted);
    font-size: var(--font-size-xs);
    white-space: nowrap;
}

.dashboard__empty {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
    margin: 0;
}

/* Dashboard translations widget */
.dashboard__translation-widget {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.dashboard__translation-count {
    font-size: var(--font-size-xxl);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
}

.dashboard__translation-label {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.dashboard__translation-link {
    display: inline-block;
    font-size: var(--font-size-sm);
    color: var(--color-secondary);
}


/* --------------------------------------------------------------------------
   8. Tables
   -------------------------------------------------------------------------- */
.table-responsive {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--border-radius);
    border: 1px solid var(--color-border-light);
    margin-bottom: var(--spacing-md);
}

.table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-sm);
}

.table th,
.table td,
.table .table__th,
.table .table__td {
    padding: var(--spacing-sm) var(--spacing-md);
    text-align: left;
    vertical-align: middle;
    white-space: nowrap;
}

.table th,
.table .table__th {
    background: var(--color-background);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-secondary);
    font-size: var(--font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--color-border);
    position: sticky;
    top: 0;
}

.table td,
.table .table__td {
    border-bottom: 1px solid var(--color-border-light);
}

.table tbody tr:hover {
    background: rgba(52, 152, 219, 0.04);
}

/* Table alignment modifiers */
.table__th--right,
.table__td--right {
    text-align: right;
}

.table__th--center,
.table__td--center,
.table__center {
    text-align: center;
}

/* Table empty state */
.table__td--empty,
.table__empty {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--color-text-muted);
}

/* Table action cells */
.table__actions,
.table__actions-col {
    white-space: nowrap;
}

.table__actions {
    display: flex;
    gap: var(--spacing-xs);
}

.table__actions-col {
    text-align: right;
    width: 1%;
}

/* Table column sizes */
.table__col--narrow {
    width: 50px;
    text-align: center;
}

.table__col--number {
    text-align: right;
    width: 100px;
}

.table__col--action {
    text-align: right;
    width: 1%;
}

/* Table links */
.table__link {
    color: var(--color-secondary);
    font-weight: var(--font-weight-medium);
}

.table__link:hover {
    color: var(--color-secondary-dark);
}

.table__plugin-name {
    font-weight: var(--font-weight-semibold);
    vertical-align: top;
}

/* Striped rows */
.table-striped tbody tr:nth-child(even) {
    background: var(--color-background);
}

.table-striped tbody tr:nth-child(even):hover {
    background: rgba(52, 152, 219, 0.06);
}

/* Table variants */
.table--permissions {
    /* permissions matrix styling */
}

.table--items {
    /* quote items table styling */
}


/* --------------------------------------------------------------------------
   9. Forms
   -------------------------------------------------------------------------- */
.form {
    /* form wrapper */
}

.form__fieldset {
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.form__legend {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
    padding: 0 var(--spacing-sm);
}

/* Form group (legacy) */
.form-group {
    margin-bottom: var(--spacing-md);
}

.form-group label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.form-group-sm {
    max-width: 200px;
}

.form-group-lg {
    /* full width group */
}

.form-group--inline {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: 0;
}

.form-group--checkbox {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* BEM form group */
.form__group {
    margin-bottom: var(--spacing-md);
}

/* Form label (BEM) */
.form__label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.form__label .required,
.form__required {
    color: var(--color-error);
    margin-left: 2px;
}

.form__label--required::after {
    content: ' *';
    color: var(--color-error);
}

.form__label--checkbox {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    font-weight: var(--font-weight-normal);
}

/* Form controls (legacy class) */
.form-control {
    display: block;
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: var(--font-size-base);
    line-height: 1.5;
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    appearance: none;
}

.form-control:focus {
    outline: none;
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.15);
}

.form-control::placeholder {
    color: var(--color-text-muted);
}

.form-control.is-invalid {
    border-color: var(--color-error);
}

.form-control.is-invalid:focus {
    box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.15);
}

.form-control--select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23636e72' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    padding-right: 2rem;
}

.form-control--small {
    padding: 0.25rem 0.5rem;
    font-size: var(--font-size-sm);
}

.form-control--textarea {
    min-height: 100px;
    resize: vertical;
}

select.form-control {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23636e72' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    padding-right: 2rem;
}

textarea.form-control {
    min-height: 100px;
    resize: vertical;
}

.form-control-file {
    display: block;
    width: 100%;
    padding: var(--spacing-sm);
    font-size: var(--font-size-sm);
}

/* BEM form input / select / textarea */
.form__input {
    display: block;
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: var(--font-size-base);
    line-height: 1.5;
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    appearance: none;
}

.form__input:focus {
    outline: none;
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.15);
}

.form__input--sm {
    padding: 0.25rem 0.5rem;
    font-size: var(--font-size-sm);
}

.form__select {
    display: block;
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: var(--font-size-base);
    line-height: 1.5;
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23636e72' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    padding-right: 2rem;
}

.form__select:focus {
    outline: none;
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.15);
}

.form__textarea {
    display: block;
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: var(--font-size-base);
    line-height: 1.5;
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    min-height: 100px;
    resize: vertical;
}

.form__textarea:focus {
    outline: none;
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.15);
}

/* Checkbox/Radio */
.form__checkbox {
    width: 16px;
    height: 16px;
    accent-color: var(--color-secondary);
    cursor: pointer;
}

.form__checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    font-size: var(--font-size-sm);
}

.form__checkbox-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

/* Form check (legacy) */
.form-check {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.form-check input[type="checkbox"],
.form-check input[type="radio"] {
    width: 16px;
    height: 16px;
    accent-color: var(--color-secondary);
    cursor: pointer;
}

/* Form row / grid layouts */
.form-row,
.form__row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.form__row--grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.form__row--cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.form__row--cols-3 {
    grid-template-columns: repeat(3, 1fr);
}

.form__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

/* Form hints and errors */
.form-error,
.form__error {
    font-size: var(--font-size-xs);
    color: var(--color-error);
    margin-top: var(--spacing-xs);
}

.form-hint,
.form__hint,
.form-text {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
}

.form__help {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
}

.form__hint-actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-sm);
}

/* Fieldset (profile, grouped forms) */
.form-fieldset {
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    background: var(--color-surface);
}

.form-fieldset__legend {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    padding: 0 var(--spacing-sm);
}

/* Half-width form groups (used in form-row grid) */
.form-group--half {
    min-width: 0;
}

/* Profile roles badge list */
.profile-roles {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    padding-top: var(--spacing-xs);
}

/* --------------------------------------------------------------------------
   Avatar (used globally: header, sidebar, timeline, profile)
   -------------------------------------------------------------------------- */
.avatar {
    border-radius: 50%;
    object-fit: cover;
    vertical-align: middle;
    flex-shrink: 0;
}

.avatar--sm  { width: 24px; height: 24px; font-size: 10px; line-height: 24px; }
.avatar--md  { width: 32px; height: 32px; font-size: 13px; line-height: 32px; }
.avatar--lg  { width: 48px; height: 48px; font-size: 18px; line-height: 48px; }
.avatar--xl  { width: 80px; height: 80px; font-size: 28px; line-height: 80px; }

.avatar--initials {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-secondary);
    color: #fff;
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    user-select: none;
}

/* Profile avatar section */
.profile-avatar {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.profile-avatar__actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.profile-avatar__hint {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

/* Hidden file input (visible label acts as button) */
.form-control--file-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Form actions */
.form-actions,
.form__actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
    flex-wrap: wrap;
    align-items: center;
}

/* Form section */
.form__section {
    margin-bottom: var(--spacing-lg);
}

.form__section-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
    margin-bottom: var(--spacing-md);
}

/* Form totals (quote form) */
.form__totals {
    margin-left: auto;
    max-width: 300px;
    margin-top: var(--spacing-lg);
}

.form__totals-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: var(--spacing-xs) 0;
    font-size: var(--font-size-sm);
}

.form__totals-row--grand {
    border-top: 2px solid var(--color-primary);
    padding-top: var(--spacing-sm);
    margin-top: var(--spacing-xs);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
}

.form__totals-label {
    color: var(--color-text-secondary);
}

.form__totals-value {
    font-weight: var(--font-weight-semibold);
}

/* Inline forms */
.form-inline,
.form--inline {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.inline-form,
.form__inline {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
}


/* --------------------------------------------------------------------------
   10. Buttons
   -------------------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    padding: 0.5rem 1rem;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
    border: 1px solid transparent;
    border-radius: var(--border-radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    white-space: nowrap;
    text-decoration: none;
    color: var(--color-text);
    background: var(--color-surface);
    border-color: var(--color-border);
}

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

.btn:active {
    transform: translateY(1px);
}

.btn:disabled,
.btn--disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Primary button (both naming conventions) */
.btn-primary,
.btn--primary {
    background: var(--color-secondary);
    color: #fff;
    border-color: var(--color-secondary);
}

.btn-primary:hover,
.btn--primary:hover {
    background: var(--color-secondary-dark);
    border-color: var(--color-secondary-dark);
    color: #fff;
}

/* Secondary button */
.btn-secondary,
.btn--secondary {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.btn-secondary:hover,
.btn--secondary:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color: #fff;
}

/* Success button */
.btn-success,
.btn--success {
    background: var(--color-success);
    color: #fff;
    border-color: var(--color-success);
}

.btn-success:hover,
.btn--success:hover {
    background: #219a52;
    border-color: #219a52;
    color: #fff;
}

/* Danger button */
.btn-danger,
.btn--danger {
    background: var(--color-error);
    color: #fff;
    border-color: var(--color-error);
}

.btn-danger:hover,
.btn--danger:hover {
    background: #c0392b;
    border-color: #c0392b;
    color: #fff;
}

/* Outline variants */
.btn-outline-primary,
.btn--outline-primary {
    background: transparent;
    color: var(--color-secondary);
    border-color: var(--color-secondary);
}

.btn-outline-primary:hover,
.btn--outline-primary:hover {
    background: var(--color-secondary);
    color: #fff;
}

.btn-outline-danger,
.btn--outline-danger {
    background: transparent;
    color: var(--color-error);
    border-color: var(--color-error);
}

.btn-outline-danger:hover,
.btn--outline-danger:hover {
    background: var(--color-error);
    color: #fff;
}

/* Ghost/Link/Text buttons */
.btn-ghost,
.btn--ghost {
    background: transparent;
    border-color: transparent;
    color: var(--color-text-secondary);
}

.btn-ghost:hover,
.btn--ghost:hover {
    background: var(--color-border-light);
    color: var(--color-text);
}

.btn-link,
.btn--link {
    background: transparent;
    border-color: transparent;
    color: var(--color-secondary);
    padding-left: 0;
    padding-right: 0;
}

.btn-link:hover,
.btn--link:hover {
    color: var(--color-secondary-dark);
    background: transparent;
}

.btn--text {
    background: transparent;
    border-color: transparent;
    color: var(--color-text-muted);
}

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

/* Size variants */
.btn-sm,
.btn--sm,
.btn--small {
    padding: 0.25rem 0.625rem;
    font-size: var(--font-size-xs);
}

.btn-lg,
.btn--lg {
    padding: 0.75rem 1.5rem;
    font-size: var(--font-size-base);
}

.btn-block,
.btn--block {
    display: flex;
    width: 100%;
}

.btn-icon,
.btn--icon {
    width: 36px;
    height: 36px;
    padding: 0;
    border-radius: var(--border-radius-sm);
}


/* --------------------------------------------------------------------------
   11. Badges / Status Pills
   -------------------------------------------------------------------------- */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.15em 0.6em;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    border-radius: var(--border-radius-full);
    white-space: nowrap;
    line-height: 1.5;
}

/* BEM modifiers */
.badge--primary,
.badge-primary {
    background: var(--color-info-bg);
    color: var(--color-secondary);
}

.badge--success,
.badge-success {
    background: var(--color-success-bg);
    color: var(--color-success);
}

.badge--warning,
.badge-warning {
    background: var(--color-warning-bg);
    color: var(--color-warning);
}

.badge--danger,
.badge-danger {
    background: var(--color-error-bg);
    color: var(--color-error);
}

.badge--info,
.badge-info {
    background: var(--color-info-bg);
    color: var(--color-secondary);
}

/* Size modifiers */
.badge--large {
    font-size: var(--font-size-sm);
    padding: 0.3em 0.8em;
}

.badge--small {
    font-size: 0.65rem;
    padding: 0.1em 0.4em;
}

/* CRM-specific status badges */
.badge-lead,
.badge--lead {
    background: #eaf2f8;
    color: #2e86c1;
}

.badge-mql,
.badge--mql {
    background: #fef9e7;
    color: #d4ac0d;
}

.badge-sql,
.badge--sql {
    background: #f5eef8;
    color: #8e44ad;
}

.badge-customer,
.badge--customer {
    background: var(--color-success-bg);
    color: var(--color-success);
}

.badge-inactive,
.badge--inactive {
    background: var(--color-border-light);
    color: var(--color-text-muted);
}

/* Color-based badges (used in contacts/email templates) */
.badge-grey {
    background: var(--color-border-light);
    color: var(--color-text-secondary);
}

.badge-blue {
    background: var(--color-info-bg);
    color: var(--color-secondary);
}

.badge-orange {
    background: var(--color-warning-bg);
    color: var(--color-warning);
}

.badge-green {
    background: var(--color-success-bg);
    color: var(--color-success);
}

.badge-red {
    background: var(--color-error-bg);
    color: var(--color-error);
}

/* Quote status badges */
.badge--draft {
    background: var(--color-border-light);
    color: var(--color-text-secondary);
}

.badge--sent {
    background: var(--color-info-bg);
    color: var(--color-secondary);
}

.badge--accepted {
    background: var(--color-success-bg);
    color: var(--color-success);
}

.badge--rejected {
    background: var(--color-error-bg);
    color: var(--color-error);
}

.badge--expired {
    background: var(--color-warning-bg);
    color: var(--color-warning);
}


/* --------------------------------------------------------------------------
   12. Flash Messages
   -------------------------------------------------------------------------- */

/* BEM flash messages (core template) */
.flash-messages {
    position: fixed;
    top: calc(var(--header-height) + var(--spacing-md));
    right: var(--spacing-md);
    z-index: var(--z-toast);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    max-width: 420px;
    width: calc(100% - 2 * var(--spacing-md));
}

.flash-messages__item {
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
    animation: flash-slide-in 0.3s ease forwards;
    border-left: 4px solid transparent;
    background: var(--color-surface);
}

.flash-messages__item--success {
    background: var(--color-success-bg);
    color: #1e8449;
    border-left-color: var(--color-success);
}

.flash-messages__item--error {
    background: var(--color-error-bg);
    color: #c0392b;
    border-left-color: var(--color-error);
}

.flash-messages__item--warning {
    background: var(--color-warning-bg);
    color: #b7950b;
    border-left-color: var(--color-warning);
}

.flash-messages__item--info {
    background: var(--color-info-bg);
    color: #2471a3;
    border-left-color: var(--color-info);
}

.flash-messages__text {
    flex: 1;
}

.flash-messages__close {
    background: none;
    border: none;
    font-size: var(--font-size-lg);
    cursor: pointer;
    opacity: 0.6;
    line-height: 1;
    color: inherit;
    flex-shrink: 0;
    padding: 0;
}

.flash-messages__close:hover {
    opacity: 1;
}

@keyframes flash-slide-in {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes flash-slide-out {
    from {
        transform: translateX(0);
        opacity: 1;
    }
    to {
        transform: translateX(100%);
        opacity: 0;
    }
}

/* Alert (inline flash messages in plugin templates) */
.alert {
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--spacing-md);
    border-left: 4px solid transparent;
}

.alert ul {
    margin: var(--spacing-sm) 0 0 var(--spacing-lg);
    list-style: disc;
}

.alert__list {
    margin: var(--spacing-sm) 0 0 var(--spacing-lg);
    list-style: disc;
}

/* Alert variants (both naming conventions) */
.alert-success,
.alert--success {
    background: var(--color-success-bg);
    color: #1e8449;
    border-left-color: var(--color-success);
}

.alert-error,
.alert--error {
    background: var(--color-error-bg);
    color: #c0392b;
    border-left-color: var(--color-error);
}

.alert-warning,
.alert--warning {
    background: var(--color-warning-bg);
    color: #b7950b;
    border-left-color: var(--color-warning);
}

.alert-info,
.alert--info {
    background: var(--color-info-bg);
    color: #2471a3;
    border-left-color: var(--color-info);
}

.alert--danger {
    background: var(--color-error-bg);
    color: #c0392b;
    border-left-color: var(--color-error);
}

.alert--small {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-xs);
}


/* --------------------------------------------------------------------------
   13. Modal
   -------------------------------------------------------------------------- */
.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: var(--z-overlay);
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md);
    animation: fade-in 0.2s ease;
}

.modal-overlay.active {
    display: flex;
}

.modal {
    background: var(--color-surface);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-xl);
    width: 100%;
    max-width: 560px;
    max-height: 90vh;
    overflow-y: auto;
    animation: modal-scale-in 0.25s ease;
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border-light);
}

.modal-header h3 {
    margin-bottom: 0;
}

.modal-close {
    background: none;
    border: none;
    font-size: var(--font-size-xxl);
    cursor: pointer;
    color: var(--color-text-muted);
    line-height: 1;
    padding: 0;
    transition: color var(--transition-fast);
}

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

.modal-body {
    padding: var(--spacing-lg);
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
}

@keyframes fade-in {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes modal-scale-in {
    from {
        transform: scale(0.95);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}


/* --------------------------------------------------------------------------
   14. Search Bar
   -------------------------------------------------------------------------- */
.search-bar {
    margin-bottom: var(--spacing-lg);
}

.search-bar__form {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.search-bar__input {
    display: block;
    width: auto;
    flex: 1;
    min-width: 200px;
    padding: 0.5rem 0.75rem;
    font-size: var(--font-size-sm);
    line-height: 1.5;
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.search-bar__input:focus {
    outline: none;
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.15);
}

/* Search results (email, generic) */
.search-results-info {
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}


/* --------------------------------------------------------------------------
   15. Dropdown
   -------------------------------------------------------------------------- */
.dropdown {
    position: relative;
    display: inline-block;
}

.dropdown-toggle {
    cursor: pointer;
}

.dropdown-menu {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    min-width: 180px;
    background: var(--color-surface);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--color-border-light);
    z-index: var(--z-dropdown);
    padding: var(--spacing-xs) 0;
    animation: dropdown-in 0.15s ease;
}

.dropdown-menu.active {
    display: block;
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    white-space: nowrap;
    transition: background var(--transition-fast);
    cursor: pointer;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
}

.dropdown-item:hover {
    background: var(--color-background);
    color: var(--color-text);
}

.dropdown-item.danger {
    color: var(--color-error);
}

.dropdown-item.danger:hover {
    background: var(--color-error-bg);
}

.dropdown-divider {
    height: 1px;
    background: var(--color-border-light);
    margin: var(--spacing-xs) 0;
}

@keyframes dropdown-in {
    from {
        transform: translateY(-4px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}


/* --------------------------------------------------------------------------
   16. Pagination (BEM)
   -------------------------------------------------------------------------- */
.pagination {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    flex-wrap: wrap;
    margin-top: var(--spacing-lg);
}

.pagination__list {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    margin: 0;
}

.pagination__item {
    display: inline-flex;
}

.pagination__item--disabled {
    opacity: 0.4;
    pointer-events: none;
}

.pagination__item--active .pagination__link {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
    color: #fff;
    font-weight: var(--font-weight-medium);
}

.pagination__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    text-decoration: none;
}

.pagination__link:hover {
    background: var(--color-background);
    border-color: var(--color-secondary);
    color: var(--color-secondary);
}

.pagination__link--active {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
    color: #fff;
    font-weight: var(--font-weight-medium);
}

.pagination__link--disabled {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

.pagination__link--current {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
    color: #fff;
    font-weight: var(--font-weight-medium);
}

.pagination__ellipsis {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    color: var(--color-text-muted);
}

/* Legacy pagination classes (contacts/email templates) */
.pagination-nav {
    margin-top: var(--spacing-lg);
}

.pagination-info {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-top: var(--spacing-sm);
}

/* Legacy pagination list items */
.pagination li {
    display: inline-flex;
}

.pagination li a,
.pagination li span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.pagination li a:hover {
    background: var(--color-background);
    border-color: var(--color-secondary);
    color: var(--color-secondary);
}

.pagination li.active a,
.pagination li.active span {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
    color: #fff;
    font-weight: var(--font-weight-medium);
}

.pagination li.ellipsis span {
    border: none;
    background: none;
    color: var(--color-text-muted);
}


/* --------------------------------------------------------------------------
   17. Tabs (BEM)
   -------------------------------------------------------------------------- */
.tabs {
    margin-bottom: var(--spacing-lg);
}

.tabs--nested {
    margin-bottom: var(--spacing-md);
}

.tabs__nav {
    display: flex;
    border-bottom: 2px solid var(--color-border-light);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 0;
}

.tabs__tab {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-muted);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
}

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

.tabs__tab--active {
    color: var(--color-secondary);
    border-bottom-color: var(--color-secondary);
}

.tabs__panel {
    padding: var(--spacing-lg) 0;
}

.tabs__panel--active {
    display: block;
}


/* --------------------------------------------------------------------------
   18. Loading Spinner
   -------------------------------------------------------------------------- */
.spinner {
    display: inline-block;
    width: 24px;
    height: 24px;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-secondary);
    border-radius: 50%;
    animation: spin 0.7s linear infinite;
}

.spinner-sm {
    width: 16px;
    height: 16px;
    border-width: 2px;
}

.spinner-lg {
    width: 40px;
    height: 40px;
    border-width: 4px;
}

.spinner-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255, 255, 255, 0.7);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: var(--z-modal);
}

.spinner-overlay.active {
    display: flex;
}

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


/* --------------------------------------------------------------------------
   19. Login Page
   -------------------------------------------------------------------------- */
.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md);
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
}

.login {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 400px;
}

.login__card {
    background: var(--color-surface);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-xl);
    padding: var(--spacing-xl);
    width: 100%;
}

.login__header {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.login__brand {
    font-size: var(--font-size-xxl);
    color: var(--color-primary);
    margin-bottom: var(--spacing-xs);
}

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

.login__error {
    background: var(--color-error-bg);
    color: #c0392b;
    border-left: 4px solid var(--color-error);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--border-radius-sm);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-lg);
}

.login__form {
    margin-bottom: 0;
}

.login__field {
    margin-bottom: var(--spacing-lg);
}

.login__label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.login__input {
    display: block;
    width: 100%;
    padding: 0.625rem 0.75rem;
    font-size: var(--font-size-base);
    line-height: 1.5;
    color: var(--color-text);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.login__input:focus {
    outline: none;
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.15);
}

.login__submit {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    padding: 0.625rem 1rem;
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
    border: 1px solid var(--color-secondary);
    border-radius: var(--border-radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    background: var(--color-secondary);
    color: #fff;
    margin-top: var(--spacing-sm);
}

.login__submit:hover {
    background: var(--color-secondary-dark);
    border-color: var(--color-secondary-dark);
}

.login__footer {
    text-align: center;
    margin-top: var(--spacing-lg);
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.6);
}


/* --------------------------------------------------------------------------
   20. Page Header
   -------------------------------------------------------------------------- */
.page-header {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.page-header__title {
    margin-bottom: 0;
}

.page-header__left {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.page-header__right,
.page-header__actions {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.page-actions {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    margin-top: var(--spacing-lg);
}


/* --------------------------------------------------------------------------
   21. Empty State
   -------------------------------------------------------------------------- */
.empty-state {
    text-align: center;
    padding: var(--spacing-xxl) var(--spacing-lg);
    color: var(--color-text-muted);
}

.empty-state-icon {
    font-size: 3rem;
    margin-bottom: var(--spacing-md);
    opacity: 0.4;
}

.empty-state h3 {
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-sm);
}

.empty-state p {
    max-width: 400px;
    margin: 0 auto var(--spacing-lg);
}


/* --------------------------------------------------------------------------
   22. Products Plugin
   -------------------------------------------------------------------------- */
.products {
    /* container */
}

.products__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.products__title {
    margin-bottom: 0;
}

.products__filters {
    margin-bottom: var(--spacing-lg);
}

.products__filters-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.products__sku {
    font-family: monospace;
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}

.products__name-link {
    color: var(--color-secondary);
    font-weight: var(--font-weight-medium);
    display: block;
}

.products__name-link:hover {
    color: var(--color-secondary-dark);
}

.products__description {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: 2px;
}

.products__price {
    font-weight: var(--font-weight-medium);
    white-space: nowrap;
}

.products__actions {
    display: flex;
    gap: var(--spacing-xs);
    justify-content: flex-end;
}

.products__delete-form {
    display: inline;
}

.products__empty-addons {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

/* Product form */
.product-form {
    /* container */
}

.product-form__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.product-form__title {
    margin-bottom: 0;
}

/* Addon cards */
.addon-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.addon-card--new {
    border-color: var(--color-secondary-light);
    border-style: dashed;
}

.addon-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-md);
}

.addon-card__title {
    margin-bottom: 0;
    font-size: var(--font-size-lg);
}

.addon-card__delete-label {
    font-size: var(--font-size-sm);
}


/* --------------------------------------------------------------------------
   23. Documents Plugin
   -------------------------------------------------------------------------- */
.documents {
    /* container */
}

.documents__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.documents__title {
    margin-bottom: 0;
}

.documents__actions {
    display: flex;
    gap: var(--spacing-sm);
}

.documents__company-select {
    margin-bottom: var(--spacing-lg);
}

.documents__breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-lg);
    font-size: var(--font-size-sm);
}

.documents__breadcrumb-item {
    color: var(--color-secondary);
    text-decoration: none;
}

.documents__breadcrumb-item:hover {
    color: var(--color-secondary-dark);
}

.documents__breadcrumb-item--active {
    color: var(--color-text);
    font-weight: var(--font-weight-medium);
}

.documents__breadcrumb-separator {
    color: var(--color-text-muted);
}

.documents__layout {
    display: grid;
    grid-template-columns: 250px 1fr;
    gap: var(--spacing-lg);
}

.documents__folders {
    background: var(--color-surface);
    border-radius: var(--border-radius);
    border: 1px solid var(--color-border-light);
    padding: var(--spacing-md);
}

.documents__folders-title {
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-md);
}

.documents__folder-create {
    margin-bottom: var(--spacing-md);
}

.documents__folder-create-row {
    display: flex;
    gap: var(--spacing-xs);
}

.documents__folder-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.documents__folder-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-xs) 0;
    border-bottom: 1px solid var(--color-border-light);
    font-size: var(--font-size-sm);
}

.documents__folder-item:last-child {
    border-bottom: none;
}

.documents__folder-item--up {
    display: block;
    padding: var(--spacing-xs) 0;
    margin-bottom: var(--spacing-sm);
    color: var(--color-secondary);
    text-decoration: none;
    font-size: var(--font-size-sm);
}

.documents__folder-link {
    color: var(--color-text);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.documents__folder-link:hover {
    color: var(--color-secondary);
}

.documents__folder-icon {
    font-size: var(--font-size-base);
}

.documents__folder-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.documents__folder-rename-form {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.documents__files {
    /* right panel */
}

.documents__files-title {
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-md);
}

.documents__file-link {
    color: var(--color-secondary);
    font-weight: var(--font-weight-medium);
}

.documents__file-link:hover {
    color: var(--color-secondary-dark);
}

.documents__file-desc {
    display: block;
    color: var(--color-text-muted);
    margin-top: 2px;
}

.documents__empty-hint {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

/* Document upload */
.document-upload {
    /* container */
}

.document-upload__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.document-upload__title {
    margin-bottom: 0;
}

.document-upload__form {
    /* form wrapper */
}

.document-upload__dropzone {
    position: relative;
    border: 2px dashed var(--color-border);
    border-radius: var(--border-radius);
    padding: var(--spacing-xxl) var(--spacing-lg);
    text-align: center;
    cursor: pointer;
    transition: all var(--transition-fast);
    background: var(--color-background);
}

.document-upload__dropzone:hover,
.document-upload__dropzone--active {
    border-color: var(--color-secondary);
    background: var(--color-info-bg);
}

.document-upload__dropzone-content {
    pointer-events: none;
}

.document-upload__dropzone-text {
    font-size: var(--font-size-base);
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.document-upload__dropzone-hint {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-bottom: 0;
}

.document-upload__file-input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.document-upload__file-name {
    font-size: var(--font-size-sm);
    color: var(--color-secondary);
    margin-top: var(--spacing-sm);
}


/* --------------------------------------------------------------------------
   24. Email Plugin
   -------------------------------------------------------------------------- */
.email-conversation {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.email-item {
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
}

.email-item.email-incoming {
    border-left: 4px solid var(--color-info);
}

.email-item.email-outgoing {
    border-left: 4px solid var(--color-success);
}

.email-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-md);
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.email-meta {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.email-direction {
    font-weight: var(--font-weight-semibold);
}

.email-from,
.email-to,
.email-cc {
    color: var(--color-text-secondary);
}

.email-info {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.email-date {
    color: var(--color-text-muted);
}

.email-sent-by {
    color: var(--color-text-muted);
    font-size: var(--font-size-xs);
}

.email-subject {
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-base);
}

.email-body {
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-sm);
    line-height: 1.6;
    overflow-wrap: break-word;
}

.email-attachments {
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-sm);
}

.email-attachments ul {
    list-style: none;
    padding: 0;
    margin: var(--spacing-xs) 0 0;
}

.email-attachments li {
    padding: var(--spacing-xs) 0;
}

.email-actions {
    display: flex;
    gap: var(--spacing-sm);
}

/* Contact info bar */
.contact-info-bar {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    margin-bottom: var(--spacing-lg);
    font-size: var(--font-size-sm);
    flex-wrap: wrap;
}

.contact-name {
    font-weight: var(--font-weight-semibold);
}

.contact-email {
    color: var(--color-text-secondary);
}

.contact-company {
    color: var(--color-text-muted);
}

/* Template selector */
.template-selector {
    margin-bottom: var(--spacing-lg);
}

/* Rich editor placeholder (plain textarea) */
.rich-editor {
    min-height: 200px;
    font-family: var(--font-family);
}

/* Icon placeholders (inline text icons) */
.icon {
    display: inline;
}


/* --------------------------------------------------------------------------
   25. Sales Plugin
   -------------------------------------------------------------------------- */

/* Filters bar */
.filters {
    margin-bottom: var(--spacing-lg);
}

.filters__form {
    display: flex;
    align-items: flex-end;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

.filters__group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.filters__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
}

.filters__actions {
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
}

/* Quote status banner */
.quote-status {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
}

.quote-status__sent {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* Detail grid (quote view) */
.detail-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
}

.detail-grid--cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.detail-grid__section {
    /* section wrapper */
}

.detail-grid__title {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-xs);
    border-bottom: 1px solid var(--color-border-light);
}

/* Detail list (dl) */
.detail-list {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
}

.detail-list dt {
    color: var(--color-text-secondary);
    font-weight: var(--font-weight-medium);
}

.detail-list dd {
    color: var(--color-text);
    margin: 0;
}

/* Send summary (quote send) */
.send-summary {
    display: flex;
    gap: var(--spacing-lg);
    flex-wrap: wrap;
}

.send-summary__item {
    font-size: var(--font-size-sm);
}

/* Attachment list */
.attachment-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.attachment-list__item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-background);
    border-radius: var(--border-radius-sm);
    font-size: var(--font-size-sm);
}

.attachment-list__icon {
    font-size: var(--font-size-lg);
}

.attachment-list__name {
    color: var(--color-text);
}


/* --------------------------------------------------------------------------
   26. Miscellaneous Components
   -------------------------------------------------------------------------- */

/* Related section (company contacts, status history) */
.related-section {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
}

.related-section h2 {
    margin-bottom: var(--spacing-md);
}

/* Meta info (created_at, updated_at) */
.meta-info {
    margin-top: var(--spacing-lg);
    padding: var(--spacing-md);
    background: var(--color-background);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.meta-info p {
    margin-bottom: var(--spacing-xs);
}

.meta-info p:last-child {
    margin-bottom: 0;
}

/* Avatar */
.avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--color-secondary);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    flex-shrink: 0;
}

.avatar-sm {
    width: 28px;
    height: 28px;
    font-size: var(--font-size-xs);
}

.avatar-lg {
    width: 48px;
    height: 48px;
    font-size: var(--font-size-lg);
}

/* Divider */
.divider {
    border: none;
    border-top: 1px solid var(--color-border-light);
    margin: var(--spacing-lg) 0;
}

/* Tooltip */
.tooltip {
    position: relative;
}

.tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-primary);
    color: #fff;
    padding: 0.25em 0.5em;
    border-radius: var(--border-radius-sm);
    font-size: var(--font-size-xs);
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-fast);
    z-index: var(--z-dropdown);
}

.tooltip:hover::after {
    opacity: 1;
}

/* Truncate text */
.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Visually hidden (screen reader only) */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Actions cell inline */
.actions {
    white-space: nowrap;
}

.actions .btn {
    margin-right: 2px;
}

.actions .inline-form {
    display: inline;
}


/* ==========================================================================
   27. Responsive — Tablet (>= 768px)
   ========================================================================== */
@media (min-width: 768px) {

    .dashboard__stats {
        grid-template-columns: repeat(2, 1fr);
    }

    .dashboard__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .form-row,
    .form__row {
        grid-template-columns: repeat(2, 1fr);
    }

    .form__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .page-header {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .main {
        padding: var(--spacing-lg);
    }

    .login__card {
        padding: var(--spacing-xxl);
    }
}


/* ==========================================================================
   28. Responsive — Desktop (>= 1024px)
   ========================================================================== */
@media (min-width: 1024px) {

    /* Sidebar always visible */
    .sidebar {
        transform: translateX(0);
    }

    .sidebar-overlay {
        display: none !important;
    }

    /* Hamburger hidden on desktop */
    .header__hamburger {
        display: none;
    }

    /* Main content shifts right to accommodate sidebar */
    .layout__body {
        /* sidebar + main area */
    }

    .main {
        margin-left: var(--sidebar-width);
        transition: margin-left var(--transition-base);
    }

    /* Sidebar collapse button visible on desktop */
    .sidebar__collapse {
        display: flex;
    }

    /* Collapsed sidebar */
    .sidebar-collapsed .sidebar {
        width: var(--sidebar-collapsed-width);
    }

    .sidebar-collapsed .main {
        margin-left: var(--sidebar-collapsed-width);
    }

    .sidebar-collapsed .sidebar__label,
    .sidebar-collapsed .sidebar__group-title,
    .sidebar-collapsed .sidebar__collapse-icon,
    .sidebar-collapsed .sidebar__footer-user .sidebar__label {
        display: none;
    }

    .sidebar-collapsed .sidebar__link {
        justify-content: center;
        padding: var(--spacing-sm);
        border-left-width: 0;
    }

    .sidebar-collapsed .sidebar__collapse {
        justify-content: center;
        padding: var(--spacing-md);
    }

    .dashboard__stats {
        grid-template-columns: repeat(4, 1fr);
    }

    .main {
        padding: var(--spacing-xl);
    }

    .detail-grid--cols-2 {
        grid-template-columns: repeat(2, 1fr);
    }
}


/* ==========================================================================
   29. Responsive — Large (>= 1280px)
   ========================================================================== */
@media (min-width: 1280px) {

    .main {
        padding: var(--spacing-xl) var(--spacing-xxl);
    }
}


/* ==========================================================================
   30. Responsive — Mobile tweaks
   ========================================================================== */
@media (max-width: 767px) {

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

    .form__row--cols-2,
    .form__row--cols-3 {
        grid-template-columns: 1fr;
    }

    .detail-grid--cols-2 {
        grid-template-columns: 1fr;
    }

    .header__user-name {
        display: none;
    }

    .header__logout-text {
        display: none;
    }

    .header__logout-btn {
        padding: 0.35rem;
    }
}


/* ==========================================================================
   31. Print Styles
   ========================================================================== */
@media print {
    .sidebar,
    .sidebar-overlay,
    .header,
    .header__hamburger,
    .flash-messages,
    .modal-overlay,
    .spinner-overlay,
    .btn,
    .pagination,
    .search-bar {
        display: none !important;
    }

    .main {
        margin-left: 0 !important;
    }

    body {
        background: #fff;
        color: #000;
    }

    .card {
        box-shadow: none;
        border: 1px solid #ccc;
        break-inside: avoid;
    }
}
