/* =============================================================================
   Solodolo Gestion — Design System
   Palette: brun Solodolo + beige, inspirée du club.solodolo.com
   Fonts: Anton (titres/labels) + Work Sans (corps)
   ============================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Work+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

/* -----------------------------------------------------------------------------
   CSS Variables — palette Solodolo
   ----------------------------------------------------------------------------- */
:root {
    --sdl-brown:          #533d28;
    --sdl-brown-dark:     #3a2e24;
    --sdl-brown-light:    #7a6550;
    --sdl-beige:          #efe9e1;
    --sdl-beige-light:    #f9f6f1;
    --sdl-beige-dark:     #e0d5c8;
    --sdl-white:          #ffffff;
    --sdl-error:          #c0392b;
    --sdl-error-bg:       #fdecea;
    --sdl-success:        #2e7d32;
    --sdl-success-bg:     #e8f5e9;
    --sdl-warning:        #b45309;
    --sdl-warning-bg:     #fef3c7;

    /* Status palette */
    --status-brouillon:    #7a6550;
    --status-en_attente:      #1a5fa8;
    --status-signe:       #6b3fa0;
    --status-preparation:  #b45309;
    --status-expediee:     #0e6b80;
    --status-livree:       #2e7d32;
    --status-payee:        #1a5c33;
    --status-retard:       #c0392b;

    /* Typography */
    --sdl-font:       'Work Sans', system-ui, sans-serif;
    --sdl-font-title: 'Anton', Georgia, serif;
    --sdl-mono:       'Courier New', Courier, monospace;

    /* Layout */
    --sdl-nav-h:      60px;
    --sdl-logo-h:     76px;  /* logo row height: 44px logo + 32px padding */
    --sdl-radius:     4px;
    --sdl-radius-sm:  3px;
    --sdl-shadow:     0 1px 4px rgba(83,61,40,.08), 0 4px 16px rgba(83,61,40,.06);
    --sdl-shadow-md:  0 4px 12px rgba(83,61,40,.12), 0 12px 32px rgba(83,61,40,.08);
}

/* -----------------------------------------------------------------------------
   Base
   ----------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--sdl-font);
    font-size: 14px;
    line-height: 1.6;
    color: var(--sdl-brown-dark);
    background: var(--sdl-beige-light);
    -webkit-font-smoothing: antialiased;
    /* padding-top set by JS app.js — based on actual header.offsetHeight */
    /* Fixed header compensation — updated by JS via --sdl-header-h */
    padding-top: var(--sdl-header-h, 136px);
}

/* Bootstrap overrides */
.btn {
    font-family: var(--sdl-font);
    font-weight: 500;
    border-radius: var(--sdl-radius-sm);
    transition: background .15s, border-color .15s, transform .1s;
}
.form-control, .form-select {
    font-family: var(--sdl-font);
    border-radius: var(--sdl-radius-sm);
    border-color: var(--sdl-beige-dark);
    color: var(--sdl-brown-dark);
}
.form-control {
    background-color: var(--sdl-white);
}
/* .form-select: keep Bootstrap's background-image (dropdown arrow), only override color */
.form-select {
    background-color: var(--sdl-white);
}
.form-control:focus, .form-select:focus {
    border-color: var(--sdl-brown);
    box-shadow: 0 0 0 3px rgba(83,61,40,.1);
    outline: none;
}
.table { font-size: 14px; color: var(--sdl-brown-dark); }
.badge { font-family: var(--sdl-font); font-weight: 500; border-radius: 3px; }
.alert { border-radius: var(--sdl-radius); border: none; }
.card { border: 1px solid var(--sdl-beige-dark); border-radius: var(--sdl-radius); box-shadow: var(--sdl-shadow); }
.modal-content { border-radius: var(--sdl-radius); border: none; box-shadow: var(--sdl-shadow-md); }

/* Primary button — brun Solodolo */
.btn-primary {
    background: var(--sdl-brown);
    border-color: var(--sdl-brown);
    color: var(--sdl-beige) !important;
    font-family: var(--sdl-font-title);
    font-size: 13px;
    letter-spacing: .8px;
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--sdl-brown-dark);
    border-color: var(--sdl-brown-dark);
    color: var(--sdl-beige) !important;
    transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); }
.btn-primary:disabled, .btn-primary.disabled {
    --bs-btn-disabled-bg: var(--sdl-brown-light);
    --bs-btn-disabled-border-color: var(--sdl-brown-light);
    --bs-btn-disabled-color: var(--sdl-beige);
    opacity: .6;
}
.btn-outline-secondary:disabled, .btn-outline-secondary.disabled {
    --bs-btn-disabled-color: var(--sdl-brown-light);
    --bs-btn-disabled-border-color: var(--sdl-beige-dark);
    --bs-btn-disabled-bg: transparent;
    opacity: .55;
}
.btn-outline-danger:disabled, .btn-outline-danger.disabled {
    --bs-btn-disabled-color: #b91c1c;
    --bs-btn-disabled-border-color: #fca5a5;
    --bs-btn-disabled-bg: transparent;
    opacity: .55;
}

.btn-outline-secondary {
    color: var(--sdl-brown-light);
    border-color: var(--sdl-beige-dark);
}
.btn-outline-secondary:hover {
    background: var(--sdl-beige);
    border-color: var(--sdl-brown-light);
    color: var(--sdl-brown);
}

.sdl-mono { font-family: var(--sdl-mono); font-size: .9em; }
.form-control.sdl-mono:not(:placeholder-shown),
.form-control-sm.sdl-mono:not(:placeholder-shown) { font-weight: 800; }

/* -----------------------------------------------------------------------------
   Login pages
   ----------------------------------------------------------------------------- */
.sdl-login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sdl-beige);
    padding: 24px;
}

.sdl-login-libraire {
    background: var(--sdl-beige-light);
}

.sdl-login-wrapper {
    width: 100%;
    max-width: 400px;
}

.sdl-login-card {
    background: var(--sdl-white);
    border: 1px solid var(--sdl-beige-dark);
    border-radius: var(--sdl-radius);
    padding: 40px 36px;
    box-shadow: 0 2px 20px rgba(83,61,40,.10);
}

.sdl-login-logo {
    text-align: center;
    margin-bottom: 28px;
}

.sdl-login-brand {
    display: inline-block;
    font-family: var(--sdl-font-title);
    font-size: 28px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--sdl-brown);
}

.sdl-login-subtitle {
    margin: 6px 0 0;
    font-size: 12px;
    color: var(--sdl-brown-light);
    font-weight: 400;
    letter-spacing: .12em;
    text-transform: uppercase;
}

/* Login btn-primary override for full width */
.sdl-login-card .btn-primary {
    padding: 11px;
    font-size: 13px;
    letter-spacing: 1px;
}

.sdl-login-card .input-group-text {
    background: var(--sdl-beige);
    border-color: var(--sdl-beige-dark);
    color: var(--sdl-brown-light);
}

/* -----------------------------------------------------------------------------
   Site Header — logo row + sticky navbar
   ----------------------------------------------------------------------------- */

/* Outer header wrapper */
.sdl-site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
}

/* Logo row — full-width brown strip with centered logo */
.sdl-header-logo-row {
    background: var(--sdl-brown);
    padding: 16px 20px;
    text-align: center;
    border-bottom: 1px solid rgba(239,233,225,.08);
    overflow: hidden;
}
.sdl-site-header.scrolled .sdl-header-logo-row {
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    border-bottom: 0;     /* fix: removes the 1px gap when collapsed */
    opacity: 0;
    overflow: hidden;
    visibility: hidden;
}

.sdl-header-logo-link { display: inline-block; line-height: 1; }
.sdl-header-logo-img  { height: 44px; width: auto; display: block; }

/* Navbar strip */
.sdl-navbar {
    height: var(--sdl-nav-h);
    background: var(--sdl-brown);
    border-bottom: 1px solid rgba(239,233,225,.10);
}
.sdl-navbar-inner {
    max-width: 1280px;
    margin: 0 auto;
    height: 100%;
    display: flex;
    align-items: center;
    padding: 0 20px;
    gap: 4px;
}

/* Compact logo in navbar (shown only when scrolled) */
.sdl-navbar-compact-logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    opacity: 0;
    max-width: 0;
    margin-right: 0;
    overflow: hidden;
    transition: opacity .25s ease, max-width .3s ease, margin-right .3s ease;
}
.sdl-compact-logo-img { height: 28px; width: auto; display: block; }
.sdl-site-header.scrolled .sdl-navbar-compact-logo {
    opacity: 1;
    max-width: 120px;
    margin-right: 12px;
}

.sdl-nav-links {
    display: flex;
    align-items: center;
    gap: 2px;
    flex: 1;
    list-style: none;
    margin: 0;
    padding: 0;
    overflow-x: auto;
    scrollbar-width: none;
}
.sdl-nav-links::-webkit-scrollbar { display: none; }

.sdl-nav-link {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    color: rgba(239,233,225,.65);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    border-radius: 3px;
    white-space: nowrap;
    transition: color .15s, background .15s;
}
.sdl-nav-link i { font-size: 15px; }
.sdl-nav-link:hover { color: var(--sdl-beige); background: rgba(255,255,255,.08); }
.sdl-nav-link.active { color: var(--sdl-beige); background: rgba(255,255,255,.14); }
.sdl-navbar-right {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
    flex-shrink: 0;
    flex-wrap: nowrap;
}

/* Hamburger (mobile) */
.sdl-hamburger {
    display: none;
    background: none;
    border: none;
    color: rgba(239,233,225,.75);
    font-size: 20px;
    cursor: pointer;
    padding: 4px 8px;
}

/* Mobile drawer */
.sdl-drawer {
    position: fixed;
    top: var(--sdl-nav-h);
    left: 0; right: 0; bottom: 0;
    background: var(--sdl-brown);
    z-index: 999;
    padding: 16px;
    display: none;
    flex-direction: column;
    gap: 4px;
    overflow-y: auto;
}
.sdl-drawer.open { display: flex; }
.sdl-drawer .sdl-nav-link { font-size: 15px; padding: 10px 14px; }
.sdl-drawer-divider { height: 1px; background: rgba(239,233,225,.1); margin: 8px 0; }

/* -----------------------------------------------------------------------------
   Main Layout
   ----------------------------------------------------------------------------- */
.sdl-main {
    min-height: calc(100vh - var(--sdl-nav-h));
    padding: 28px 24px;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
}

/* Page header */
.sdl-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
    gap: 16px;
    flex-wrap: wrap;
}
.sdl-page-title {
    font-family: var(--sdl-font-title);
    font-size: 22px;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--sdl-brown);
    margin: 0;
}
.sdl-page-subtitle {
    font-size: 13px;
    color: var(--sdl-brown-light);
    margin: 2px 0 0;
}

/* -----------------------------------------------------------------------------
   Cards
   ----------------------------------------------------------------------------- */
.sdl-card {
    background: var(--sdl-white);
    border: 1px solid var(--sdl-beige-dark);
    border-radius: var(--sdl-radius);
    box-shadow: var(--sdl-shadow);
    overflow: hidden;
}
.sdl-card-header {
    padding: 14px 20px;
    border-bottom: 1px solid var(--sdl-beige-dark);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--sdl-beige-light);
}
.sdl-card-title {
    font-family: var(--sdl-font);
    font-size: 13.5px;
    font-weight: 600;
    color: var(--sdl-brown-dark);
    margin: 0;
}
.sdl-card-body { padding: 20px; }

/* Stat cards (dashboard) */
.sdl-stat-card {
    background: var(--sdl-white);
    border: 1px solid var(--sdl-beige-dark);
    border-radius: var(--sdl-radius);
    padding: 20px;
    box-shadow: var(--sdl-shadow);
    display: flex;
    align-items: flex-start;
    gap: 16px;
    transition: box-shadow .15s, transform .15s;
}
.sdl-stat-card:hover { box-shadow: var(--sdl-shadow-md); transform: translateY(-1px); }

.sdl-stat-icon {
    width: 44px; height: 44px;
    border-radius: var(--sdl-radius);
    display: flex; align-items: center; justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}
.sdl-stat-icon.accent  { background: rgba(83,61,40,.1);  color: var(--sdl-brown); }
.sdl-stat-icon.success { background: var(--sdl-success-bg); color: var(--sdl-success); }
.sdl-stat-icon.warning { background: var(--sdl-warning-bg); color: var(--sdl-warning); }
.sdl-stat-icon.danger  { background: var(--sdl-error-bg);   color: var(--sdl-error); }

.sdl-stat-value {
    font-family: var(--sdl-font-title);
    font-size: 26px;
    letter-spacing: .5px;
    line-height: 1;
    color: var(--sdl-brown);
}
.sdl-stat-label {
    font-size: 12.5px;
    color: var(--sdl-brown-light);
    margin-top: 4px;
}

/* -----------------------------------------------------------------------------
   Tables
   ----------------------------------------------------------------------------- */

.sdl-table {
    width: 100%;
    margin: 0;
    border-collapse: collapse;
    font-size: 13.5px;
}
.sdl-table thead th {
    background: var(--sdl-beige-light);
    padding: 10px 14px;
    font-family: var(--sdl-font);
    font-weight: 600;
    font-size: 11.5px;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--sdl-brown-light);
    border-bottom: 1px solid var(--sdl-beige-dark);
    white-space: nowrap;
}
.sdl-table tbody tr {
    border-bottom: 1px solid var(--sdl-beige-dark);
    transition: background .1s;
}
.sdl-table tbody tr:last-child { border-bottom: none; }
.sdl-table tbody tr:hover { background: var(--sdl-beige-light); }
.sdl-table tbody td {
    padding: 11px 14px;
    color: var(--sdl-brown-dark);
    vertical-align: middle;
}
.sdl-table tbody td.sdl-mono { color: var(--sdl-brown-light); }
.sdl-table-actions { display: flex; gap: 6px; align-items: center; }

/* -----------------------------------------------------------------------------
   Status Badges
   ----------------------------------------------------------------------------- */
.sdl-status {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}
.sdl-status::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
}

.sdl-status-brouillon   { background: #f0ebe4; color: var(--status-brouillon); }
.sdl-status-en_attente     { background: #dbeafe; color: var(--status-en_attente); }
.sdl-status-signe      { background: #ede9fe; color: var(--status-signe); }
.sdl-status-preparation { background: var(--sdl-warning-bg); color: var(--status-preparation); }
.sdl-status-expediee    { background: #cffafe; color: var(--status-expediee); }
.sdl-status-livree      { background: var(--sdl-success-bg); color: var(--status-livree); }
.sdl-status-payee       { background: #d1fae5; color: var(--status-payee); }
.sdl-status-retard      { background: var(--sdl-error-bg); color: var(--status-retard); }

/* -----------------------------------------------------------------------------
   Buttons (icon)
   ----------------------------------------------------------------------------- */
.btn-sdl-icon {
    width: 32px; height: 32px;
    padding: 0;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: var(--sdl-radius-sm);
    font-size: 14px;
    border: 1px solid var(--sdl-beige-dark);
    background: var(--sdl-white);
    color: var(--sdl-brown-light);
    transition: background .12s, color .12s, border-color .12s;
}
.btn-sdl-icon:hover { background: var(--sdl-beige); color: var(--sdl-brown); border-color: var(--sdl-beige-dark); }
.btn-sdl-icon.danger:hover { background: var(--sdl-error-bg); color: var(--sdl-error); border-color: var(--sdl-error); }

/* DataTables Buttons — override Bootstrap btn-secondary */
div.dt-buttons .btn.btn-secondary,
div.dt-buttons .btn {
    --bs-btn-color: var(--sdl-brown) !important;
    --bs-btn-bg: var(--sdl-white) !important;
    --bs-btn-border-color: var(--sdl-beige-dark) !important;
    --bs-btn-hover-color: var(--sdl-brown) !important;
    --bs-btn-hover-bg: var(--sdl-beige) !important;
    --bs-btn-hover-border-color: var(--sdl-brown-light) !important;
    --bs-btn-active-color: var(--sdl-brown) !important;
    --bs-btn-active-bg: var(--sdl-beige) !important;
    font-family: var(--sdl-font) !important;
    font-size: 13px !important;
    border-radius: var(--sdl-radius-sm) !important;
}

/* -----------------------------------------------------------------------------
   Forms
   ----------------------------------------------------------------------------- */
.sdl-form-section {
    margin-bottom: 28px;
    padding-bottom: 28px;
    border-bottom: 1px solid var(--sdl-beige-dark);
}
.sdl-form-section:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.sdl-form-section-title {
    font-family: var(--sdl-font-title);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--sdl-brown-light);
    margin-bottom: 16px;
}
.sdl-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--sdl-brown-dark);
    margin-bottom: 5px;
}

/* -----------------------------------------------------------------------------
   Libraire Nav (top bar — simplified)
   ----------------------------------------------------------------------------- */
.sdl-lib-navbar {
    height: var(--sdl-nav-h);
    background: var(--sdl-white);
    border-bottom: 1px solid var(--sdl-beige-dark);
    display: flex;
    align-items: center;
    padding: 0 20px;
    gap: 4px;
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    box-shadow: 0 1px 0 var(--sdl-beige-dark);
}
.sdl-lib-brand {
    font-family: var(--sdl-font-title);
    font-size: 16px;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--sdl-brown);
    text-decoration: none;
    margin-right: 20px;
}
.sdl-lib-nav-link {
    display: flex; align-items: center; gap: 6px;
    padding: 6px 12px;
    color: var(--sdl-brown-light);
    text-decoration: none;
    font-size: 13.5px;
    font-weight: 500;
    border-radius: 3px;
    white-space: nowrap;
    transition: color .15s, background .15s;
}
.sdl-lib-nav-link i { font-size: 15px; }
.sdl-lib-nav-link:hover { color: var(--sdl-brown); background: var(--sdl-beige); }
.sdl-lib-nav-link.active { color: var(--sdl-brown); background: var(--sdl-beige-dark); font-weight: 600; }

/* -----------------------------------------------------------------------------
   Pipeline statuts
   ----------------------------------------------------------------------------- */
.sdl-pipeline {
    display: flex; align-items: center; gap: 0;
    overflow-x: auto; padding: 4px 0;
    scrollbar-width: none;
}
.sdl-pipeline::-webkit-scrollbar { display: none; }
.sdl-pipeline-step {
    display: flex; flex-direction: column; align-items: center;
    flex: 1; min-width: 80px; position: relative;
}
.sdl-pipeline-step::before {
    content: '';
    position: absolute; top: 14px; left: -50%; width: 100%; height: 2px;
    background: var(--sdl-beige-dark); z-index: 0;
}
.sdl-pipeline-step:first-child::before { display: none; }
.sdl-pipeline-dot {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--sdl-beige-dark); border: 2px solid var(--sdl-beige-dark);
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; color: #fff; position: relative; z-index: 1;
    transition: all .2s;
}
.sdl-pipeline-step.done .sdl-pipeline-dot   { background: var(--sdl-success); border-color: var(--sdl-success); }
.sdl-pipeline-step.active .sdl-pipeline-dot { background: var(--sdl-brown); border-color: var(--sdl-brown); box-shadow: 0 0 0 4px rgba(83,61,40,.15); }
.sdl-pipeline-step.danger .sdl-pipeline-dot { background: var(--sdl-error); border-color: var(--sdl-error); }
.sdl-pipeline-step.done::before   { background: var(--sdl-success); }
.sdl-pipeline-step.active::before { background: var(--sdl-success); }
.sdl-pipeline-label {
    font-size: 10.5px; font-weight: 500; color: var(--sdl-brown-light);
    margin-top: 6px; text-align: center; white-space: nowrap;
}
.sdl-pipeline-step.done .sdl-pipeline-label   { color: var(--sdl-success); }
.sdl-pipeline-step.active .sdl-pipeline-label { color: var(--sdl-brown); font-weight: 700; }
.sdl-pipeline-step.danger .sdl-pipeline-label { color: var(--sdl-error); }

/* -----------------------------------------------------------------------------
   Flash messages
   ----------------------------------------------------------------------------- */
.sdl-flash {
    padding: 12px 16px;
    border-radius: var(--sdl-radius-sm);
    font-size: 13.5px;
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 20px;
    border: 1px solid transparent;
}
.sdl-flash-success { background: var(--sdl-success-bg); color: var(--sdl-success); border-color: #a5d6a7; }
.sdl-flash-error   { background: var(--sdl-error-bg);   color: var(--sdl-error);   border-color: #ef9a9a; }
.sdl-flash-warning { background: var(--sdl-warning-bg); color: var(--sdl-warning); border-color: #fde68a; }

/* -----------------------------------------------------------------------------
   Empty state
   ----------------------------------------------------------------------------- */
.sdl-empty { text-align: center; padding: 60px 24px; color: var(--sdl-brown-light); }
.sdl-empty i { font-size: 40px; margin-bottom: 12px; opacity: .4; }
.sdl-empty p { font-size: 14px; margin: 0; }


/* -----------------------------------------------------------------------------
   Link color overrides — all links use brown palette, not Bootstrap blue
   ----------------------------------------------------------------------------- */
a {
    color: var(--sdl-brown);
}
a:hover {
    color: var(--sdl-brown-dark);
}

/* Subtitle/breadcrumb links */
.sdl-page-subtitle a,
.sdl-page-subtitle a:hover {
    color: var(--sdl-brown-light);
    text-decoration: none;
}
.sdl-page-subtitle a:hover {
    color: var(--sdl-brown);
}

/* Table links */
.sdl-table a {
    color: var(--sdl-brown);
    text-decoration: none;
}
.sdl-table a:hover {
    color: var(--sdl-brown-dark);
    text-decoration: underline;
}

/* nav-tabs links */
.nav-tabs .nav-link {
    color: var(--sdl-brown-light);
}
.nav-tabs .nav-link.active,
.nav-tabs .nav-link:hover {
    color: var(--sdl-brown);
}

/* Alert links */
.alert a {
    color: inherit;
    font-weight: 600;
}

/* text-primary override */
.text-primary { color: var(--sdl-brown) !important; }
a.text-primary { color: var(--sdl-brown) !important; }

/* -----------------------------------------------------------------------------
   Button active/focus/checked states — override Bootstrap blue glow
   ----------------------------------------------------------------------------- */
.btn:focus,
.btn:focus-visible,
.btn-primary:focus,
.btn-primary:focus-visible {
    box-shadow: 0 0 0 3px rgba(83,61,40,.25) !important;
    outline: none;
}

.btn-primary:active,
.btn-primary.active,
.btn-check:checked + .btn-primary,
:not(.btn-check) + .btn-primary:active {
    background: var(--sdl-brown-dark) !important;
    border-color: var(--sdl-brown-dark) !important;
    color: var(--sdl-beige) !important;
}

.btn-outline-secondary:focus,
.btn-outline-secondary:focus-visible {
    box-shadow: 0 0 0 3px rgba(83,61,40,.15) !important;
    outline: none;
}

/* Form focus — already defined but reinforce */
.form-control:focus,
.form-select:focus {
    border-color: var(--sdl-brown) !important;
    box-shadow: 0 0 0 3px rgba(83,61,40,.10) !important;
}

/* Checkbox/radio focus */
.form-check-input:checked {
    background-color: var(--sdl-brown);
    border-color: var(--sdl-brown);
}
.form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(83,61,40,.20);
    border-color: var(--sdl-brown-light);
}

/* Pagination (DataTables) */
.page-link {
    color: var(--sdl-brown);
    border-color: var(--sdl-beige-dark);
}
.page-link:hover {
    color: var(--sdl-brown-dark);
    background: var(--sdl-beige);
    border-color: var(--sdl-beige-dark);
}
.page-item.active .page-link {
    background: var(--sdl-brown);
    border-color: var(--sdl-brown);
    color: var(--sdl-beige);
}

/* DataTables search box */
.dt-search input {
    border-color: var(--sdl-beige-dark);
    border-radius: var(--sdl-radius-sm);
    font-family: var(--sdl-font);
    font-size: 13.5px;
    color: var(--sdl-brown-dark);
}
.dt-search input:focus {
    border-color: var(--sdl-brown);
    box-shadow: 0 0 0 3px rgba(83,61,40,.10);
    outline: none;
}

/* -----------------------------------------------------------------------------
   Navbar logout button
   ----------------------------------------------------------------------------- */
.sdl-navbar-user {
    font-size: 13px;
    color: rgba(239,233,225,.6);
    white-space: nowrap;
    display: none;
}


.sdl-navbar-logout {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    color: rgba(239,233,225,.7);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    border-radius: 3px;
    border: 1px solid rgba(239,233,225,.2);
    transition: color .15s, background .15s, border-color .15s;
    white-space: nowrap;
}
.sdl-navbar-logout:hover {
    color: var(--sdl-beige);
    background: rgba(255,255,255,.1);
    border-color: rgba(239,233,225,.4);
}
.sdl-navbar-logout i { font-size: 15px; }
.sdl-navbar-logout-label { display: none; }


.sdl-navbar-settings {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 3px;
    color: rgba(239,233,225,.65);
    font-size: 16px;
    text-decoration: none;
    transition: color .15s, background .15s;
}
.sdl-navbar-settings:hover,
.sdl-navbar-settings.active {
    color: var(--sdl-beige);
    background: rgba(255,255,255,.1);
}

/* -----------------------------------------------------------------------------
   Flatpickr date picker — Solodolo theme
   ----------------------------------------------------------------------------- */
.flatpickr-calendar {
    font-family: var(--sdl-font) !important;
    border: 1px solid var(--sdl-beige-dark) !important;
    border-radius: var(--sdl-radius) !important;
    box-shadow: var(--sdl-shadow-md) !important;
}
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: var(--sdl-brown) !important;
    border-color: var(--sdl-brown) !important;
    color: var(--sdl-beige) !important;
}
.flatpickr-day:hover {
    background: var(--sdl-beige) !important;
    border-color: var(--sdl-beige-dark) !important;
    color: var(--sdl-brown-dark) !important;
}
.flatpickr-monthDropdown-months,
.flatpickr-current-month .numInputWrapper input {
    font-family: var(--sdl-font) !important;
    color: var(--sdl-brown-dark) !important;
}
.flatpickr-months .flatpickr-month {
    background: var(--sdl-beige-light) !important;
    color: var(--sdl-brown-dark) !important;
}
.flatpickr-weekday {
    color: var(--sdl-brown-light) !important;
    font-family: var(--sdl-font) !important;
}
.flatpickr-day.today {
    border-color: var(--sdl-brown-light) !important;
}

/* Remove default date input styling that shows browser picker */
input[type="date"].flatpickr-input {
    appearance: none;
    -webkit-appearance: none;
}

/* -----------------------------------------------------------------------------
   Form validation states — override Bootstrap blue/green
   ----------------------------------------------------------------------------- */
.form-control.is-valid,
.form-select.is-valid {
    border-color: var(--sdl-success) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z' fill='%232e7d32'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 16px;
    padding-right: 36px;
}
.form-control.is-invalid,
.form-select.is-invalid {
    border-color: var(--sdl-error) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z' fill='%23c0392b'/%3E%3Cpath d='M7.002 11a1 1 0 1 1 2 0 1 1 0 0 1-2 0zM7.1 4.995a.905.905 0 1 1 1.8 0l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 4.995z' fill='%23c0392b'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 16px;
    padding-right: 36px;
}
.form-control.is-valid:focus  { box-shadow: 0 0 0 3px rgba(46,125,50,.15) !important; }
.form-control.is-invalid:focus { box-shadow: 0 0 0 3px rgba(192,57,43,.15) !important; }
.invalid-feedback { color: var(--sdl-error); font-size: 12.5px; }
/* Show invalid-feedback when sibling has is-invalid (Bootstrap requires was-validated or explicit show) */
.is-invalid ~ .invalid-feedback { display: block; }
.valid-feedback   { color: var(--sdl-success); font-size: 12.5px; }

/* Input placeholder vs value differentiation */
.form-control::placeholder, .form-control-sm::placeholder { color: #b0a090; opacity: 1; }
.form-control:not(:placeholder-shown), .form-control-sm:not(:placeholder-shown) { color: var(--sdl-brown); font-weight: 500; }
