/* =====================================================================
   DealDan — Brand & Modern UI Overlay
   ---------------------------------------------------------------------
   Loaded AFTER the theme (app-saas) so it only overrides styles.
   No markup, classes, IDs, JS, or names are changed by this file.
   Brand: Primary Blue #2541B2  ·  Accent Teal #00C2A8
   Organized in phases so each phase appends cleanly.
   ===================================================================== */

/* =====================================================================
   PHASE 0 — DESIGN TOKENS / FOUNDATION
   ===================================================================== */
:root,
[data-bs-theme="light"],
[data-bs-theme="dark"] {
    /* --- Brand palette --- */
    --brand-primary:        #2541B2;   /* blue  */
    --brand-primary-rgb:    37, 65, 178;
    --brand-primary-dark:   #1c3392;
    --brand-primary-light:  #eef1fb;

    --brand-accent:         #00C2A8;   /* teal  */
    --brand-accent-rgb:     0, 194, 168;
    --brand-accent-dark:    #009b86;
    --brand-accent-light:   #e6faf7;

    --brand-gradient:       linear-gradient(135deg, #2541B2 0%, #00C2A8 100%);
    --brand-gradient-soft:  linear-gradient(135deg, rgba(37,65,178,.10) 0%, rgba(0,194,168,.10) 100%);

    /* --- Modern surface tokens --- */
    --brand-radius:         14px;
    --brand-radius-sm:      10px;
    --brand-radius-lg:      20px;
    --brand-shadow:         0 2px 10px rgba(16, 24, 64, .06), 0 1px 3px rgba(16, 24, 64, .04);
    --brand-shadow-md:      0 8px 24px rgba(16, 24, 64, .08), 0 2px 6px rgba(16, 24, 64, .05);
    --brand-shadow-lg:      0 16px 40px rgba(16, 24, 64, .12);
    --brand-ring:           0 0 0 .2rem rgba(var(--brand-primary-rgb), .20);
}

/* Drive the whole Hyper theme from the brand color.
   The theme cascades every "primary" style from --theme-color / --ct-primary. */
:root,
[data-bs-theme] {
    --theme-color:               var(--brand-primary);

    --ct-primary:                var(--brand-primary);
    --ct-primary-rgb:            var(--brand-primary-rgb);
    --ct-link-color:             var(--brand-primary);
    --ct-link-hover-color:       var(--brand-primary-dark);
    --ct-component-active-bg:    var(--brand-primary);
    --ct-component-active-color: #fff;

    /* Secondary maps to the teal accent */
    --ct-secondary:              var(--brand-accent);
    --ct-secondary-rgb:          var(--brand-accent-rgb);

    /* Bootstrap-native tokens (used by some components) */
    --bs-primary:                var(--brand-primary);
    --bs-primary-rgb:            var(--brand-primary-rgb);
    --bs-link-color:             var(--brand-primary);
    --bs-link-color-rgb:         var(--brand-primary-rgb);
    --bs-link-hover-color:       var(--brand-primary-dark);
    --bs-secondary:              var(--brand-accent);
    --bs-secondary-rgb:          var(--brand-accent-rgb);
}

/* Smoother global typography */
body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: .1px;
}

/* Brand-colored selection + scrollbar accents (subtle, modern) */
::selection {
    background: rgba(var(--brand-primary-rgb), .18);
}
* {
    scrollbar-color: rgba(var(--brand-primary-rgb), .35) transparent;
}
*::-webkit-scrollbar { width: 9px; height: 9px; }
*::-webkit-scrollbar-thumb {
    background: rgba(var(--brand-primary-rgb), .30);
    border-radius: 20px;
}
*::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--brand-primary-rgb), .50);
}

/* Keep existing custom helpers consistent with the new brand */
.username { color: var(--brand-primary); }
.hashtag  { color: var(--brand-accent) !important; }


/* =====================================================================
   PHASE 1 — NAVIGATION SHELL (topbar + sidebar)
   ===================================================================== */

/* ---------- Topbar ---------- */
.navbar-custom {
    background-color: rgba(255, 255, 255, .85);
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    box-shadow: 0 1px 0 rgba(16, 24, 64, .06), 0 4px 16px rgba(16, 24, 64, .04);
    border-bottom: 1px solid rgba(16, 24, 64, .04);
}
[data-bs-theme="dark"] .navbar-custom {
    background-color: rgba(20, 24, 38, .80);
    box-shadow: 0 1px 0 rgba(0, 0, 0, .25);
    border-bottom-color: rgba(255, 255, 255, .04);
}

/* Topbar icon buttons -> soft rounded, brand on hover */
.navbar-custom .topbar-menu .nav-link {
    border-radius: 12px;
    transition: background-color .18s ease, color .18s ease;
}
.navbar-custom .topbar-menu > li > .nav-link:hover,
.navbar-custom .topbar-menu #light-dark-mode:hover {
    background-color: rgba(var(--brand-primary-rgb), .08);
    color: var(--brand-primary);
}

/* Profile chip in topbar */
.navbar-custom .nav-user {
    border-radius: 30px;
    transition: background-color .18s ease;
}
.navbar-custom .nav-user:hover {
    background-color: rgba(var(--brand-primary-rgb), .07);
}
.navbar-custom .nav-user h5 {
    font-weight: 600;
}

/* ---------- Sidebar ---------- */
.leftside-menu {
    box-shadow: 1px 0 0 rgba(16, 24, 64, .05);
    border-right: 0;
}
[data-bs-theme="dark"] .leftside-menu {
    box-shadow: 1px 0 0 rgba(255, 255, 255, .04);
}

/* Logo breathing room */
.leftside-menu .logo {
    padding-top: 4px;
}

/* Section titles */
.side-nav .side-nav-title {
    font-size: 10.5px;
    letter-spacing: .8px;
    text-transform: uppercase;
    font-weight: 700;
    opacity: .55;
    padding-top: 18px;
    padding-bottom: 6px;
}

/* Menu links -> pill shape, smooth transitions */
.side-nav .side-nav-item {
    margin: 2px 12px;
}
.side-nav .side-nav-link {
    border-radius: var(--brand-radius-sm);
    padding: 9px 12px;
    font-weight: 500;
    transition: background-color .18s ease, color .18s ease, transform .12s ease;
}
.side-nav .side-nav-link span {
    transition: transform .12s ease;
}
.side-nav .side-nav-link i {
    border-radius: 8px;
    transition: color .18s ease;
}

/* Hover state */
.side-nav .side-nav-item:not(.menuitem-active) > .side-nav-link:hover {
    background-color: rgba(var(--brand-primary-rgb), .07);
    color: var(--brand-primary);
}
.side-nav .side-nav-item:not(.menuitem-active) > .side-nav-link:hover i {
    color: var(--brand-primary);
}

/* Active state -> brand gradient pill */
.side-nav .menuitem-active > .side-nav-link,
.side-nav .side-nav-link.active,
.side-nav .side-nav-item.menuitem-active > a {
    background: var(--brand-gradient);
    color: #fff !important;
    box-shadow: 0 6px 16px rgba(var(--brand-primary-rgb), .28);
}
.side-nav .menuitem-active > .side-nav-link i,
.side-nav .side-nav-link.active i,
.side-nav .side-nav-item.menuitem-active > a i {
    color: #fff !important;
}

/* Badge inside menu (e.g. pending verifications) stays readable on gradient */
.side-nav .menuitem-active > .side-nav-link .badge {
    background-color: rgba(255, 255, 255, .25) !important;
    color: #fff !important;
}

/* Collapsed (condensed) sidebar: keep active pill tidy */
.side-nav .side-nav-second-level .side-nav-link {
    border-radius: var(--brand-radius-sm);
}


/* =====================================================================
   PHASE 2 — SURFACES (cards, panels, typography)
   ===================================================================== */

/* ---------- Cards ---------- */
.card {
    border: 1px solid rgba(16, 24, 64, .05);
    border-radius: var(--brand-radius);
    box-shadow: var(--brand-shadow);
    transition: box-shadow .22s ease, transform .22s ease;
}
.card:hover {
    box-shadow: var(--brand-shadow-md);
}
[data-bs-theme="dark"] .card {
    border-color: rgba(255, 255, 255, .06);
}

/* Card header -> lighter, modern, refined divider */
.card .card-header {
    background-color: transparent;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(16, 24, 64, .06) !important;
}
[data-bs-theme="dark"] .card .card-header {
    border-bottom-color: rgba(255, 255, 255, .06) !important;
}

/* Brand-colored card header keeps gradient flair */
.card .card-header.bg-primary {
    background: var(--brand-gradient) !important;
    border-bottom: 0 !important;
}

/* Card body breathing room */
.card .card-body {
    padding: 1.25rem;
}

/* ---------- Titles & typography ---------- */
.card-title,
.header-title {
    font-weight: 600;
    letter-spacing: .1px;
    color: var(--ct-body-color, inherit);
}
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-weight: 600;
    letter-spacing: .1px;
}

/* Main content gets a touch more vertical rhythm */
.content-page .content {
    padding-top: 8px;
}

/* Subtle, modern horizontal rules */
hr {
    border-top-color: rgba(16, 24, 64, .08);
    opacity: 1;
}
[data-bs-theme="dark"] hr {
    border-top-color: rgba(255, 255, 255, .08);
}

/* List groups & simple panels share the rounded language */
.list-group {
    border-radius: var(--brand-radius-sm);
}

/* Tooltips/popovers -> brand-aligned, softer */
.tooltip .tooltip-inner {
    border-radius: 8px;
    box-shadow: var(--brand-shadow-md);
}


/* =====================================================================
   PHASE 3 — CONTROLS (buttons, badges, forms)
   ===================================================================== */

/* ---------- Buttons ---------- */
.btn {
    border-radius: 10px;
    font-weight: 500;
    letter-spacing: .15px;
    transition: transform .12s ease, box-shadow .18s ease, filter .18s ease, background-color .18s ease;
}
.btn:active {
    transform: translateY(1px);
}

/* Primary -> brand gradient with soft glow */
.btn-primary {
    background-image: var(--brand-gradient);
    background-color: var(--brand-primary);
    border: 0;
    box-shadow: 0 4px 12px rgba(var(--brand-primary-rgb), .25);
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
.btn-primary:first-child:active,
.show > .btn-primary.dropdown-toggle {
    background-image: var(--brand-gradient);
    background-color: var(--brand-primary-dark);
    border: 0;
    filter: brightness(.96);
    box-shadow: 0 6px 18px rgba(var(--brand-primary-rgb), .35);
}
.btn-primary:focus,
.btn-primary:focus-visible {
    box-shadow: var(--brand-ring), 0 6px 18px rgba(var(--brand-primary-rgb), .30);
}

/* Outline primary follows brand */
.btn-outline-primary {
    color: var(--brand-primary);
    border-color: var(--brand-primary);
}
.btn-outline-primary:hover,
.btn-outline-primary:active {
    background-color: var(--brand-primary);
    border-color: var(--brand-primary);
    color: #fff;
}

/* Secondary -> teal accent */
.btn-secondary {
    background-color: var(--brand-accent);
    border-color: var(--brand-accent);
    color: #fff;
    box-shadow: 0 4px 12px rgba(var(--brand-accent-rgb), .22);
}
.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary:active,
.btn-secondary:first-child:active {
    background-color: var(--brand-accent-dark);
    border-color: var(--brand-accent-dark);
    color: #fff;
}
.btn-outline-secondary {
    color: var(--brand-accent-dark);
    border-color: var(--brand-accent);
}
.btn-outline-secondary:hover,
.btn-outline-secondary:active {
    background-color: var(--brand-accent);
    border-color: var(--brand-accent);
    color: #fff;
}

/* Light buttons: soft, modern */
.btn-light {
    background-color: #f3f5fb;
    border-color: #eceffa;
    color: #3a4252;
}
.btn-light:hover {
    background-color: #e8ecf8;
    border-color: #e1e6f5;
}
[data-bs-theme="dark"] .btn-light {
    background-color: rgba(255, 255, 255, .06);
    border-color: rgba(255, 255, 255, .08);
    color: #e9ecf3;
}

/* ---------- Badges ---------- */
.badge {
    border-radius: 30px;
    font-weight: 600;
    letter-spacing: .2px;
    padding: .38em .7em;
}
.badge.rounded-circle {
    border-radius: 50% !important;
}
.badge.border {
    border-color: rgba(16, 24, 64, .12) !important;
}
.badge.bg-primary {
    background: var(--brand-gradient) !important;
}
.badge.text-primary {
    color: var(--brand-primary) !important;
}

/* ---------- Form fields ---------- */
.form-control,
.form-select {
    border-radius: 10px;
    border-color: rgba(16, 24, 64, .14);
    transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
.form-control:hover,
.form-select:hover {
    border-color: rgba(var(--brand-primary-rgb), .35);
}
.form-control:focus,
.form-select:focus {
    border-color: var(--brand-primary);
    box-shadow: var(--brand-ring);
}
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    border-color: rgba(255, 255, 255, .12);
}

/* Input groups share the rounded language */
.input-group > .form-control,
.input-group > .form-select {
    border-radius: 10px;
}
.input-group > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.input-group > :not(:last-child):not(.dropdown-menu):not(.form-floating) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.input-group-text {
    border-radius: 10px;
    border-color: rgba(16, 24, 64, .14);
    background-color: rgba(var(--brand-primary-rgb), .05);
}

/* Checkboxes / radios / switches -> brand */
.form-check-input:checked {
    background-color: var(--brand-primary);
    border-color: var(--brand-primary);
}
.form-check-input:focus {
    border-color: var(--brand-primary);
    box-shadow: var(--brand-ring);
}
.form-switch .form-check-input:checked {
    background-color: var(--brand-accent);
    border-color: var(--brand-accent);
}

/* Labels a touch stronger */
.form-label,
label {
    font-weight: 500;
}

/* ---------- Select2 (used across forms) ---------- */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    border-radius: 10px !important;
    border-color: rgba(16, 24, 64, .14) !important;
    min-height: calc(1.5em + .9rem + 2px);
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--brand-primary) !important;
    box-shadow: var(--brand-ring);
}
.select2-dropdown {
    border-radius: 12px !important;
    border-color: rgba(16, 24, 64, .12) !important;
    box-shadow: var(--brand-shadow-md);
    overflow: hidden;
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted {
    background-color: var(--brand-primary) !important;
}
.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: rgba(var(--brand-primary-rgb), .10) !important;
    border-color: rgba(var(--brand-primary-rgb), .20) !important;
    color: var(--brand-primary) !important;
    border-radius: 20px !important;
}


/* =====================================================================
   PHASE 4 — TABLES & DATATABLES
   ===================================================================== */

/* ---------- Base tables ---------- */
.table {
    --bs-table-border-color: rgba(16, 24, 64, .06);
    margin-bottom: 0;
}
.table > :not(caption) > * > * {
    padding: .8rem 1rem;
    border-bottom-color: rgba(16, 24, 64, .06);
}
[data-bs-theme="dark"] .table {
    --bs-table-border-color: rgba(255, 255, 255, .06);
}
[data-bs-theme="dark"] .table > :not(caption) > * > * {
    border-bottom-color: rgba(255, 255, 255, .06);
}

/* Header -> modern, quiet, uppercase */
.table > thead th,
.table-light,
.table > thead.table-light th {
    background-color: rgba(var(--brand-primary-rgb), .045);
    color: #6c7488;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(16, 24, 64, .08);
    white-space: nowrap;
}
[data-bs-theme="dark"] .table > thead th,
[data-bs-theme="dark"] .table-light {
    background-color: rgba(255, 255, 255, .04);
    color: #aab1c4;
}

/* Hover rows -> subtle brand wash */
.table-hover > tbody > tr:hover > * {
    background-color: rgba(var(--brand-primary-rgb), .04);
    --bs-table-bg-state: transparent;
}

/* Striped rows softened */
.table-striped > tbody > tr:nth-of-type(odd) > * {
    --bs-table-bg-type: rgba(var(--brand-primary-rgb), .025);
}

/* ---------- DataTables chrome ---------- */
/* Length + filter controls */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    border-radius: 9px;
    border: 1px solid rgba(16, 24, 64, .14);
    padding: .35rem .6rem;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dataTables_wrapper .dataTables_length select:focus,
.dataTables_wrapper .dataTables_filter input:focus {
    border-color: var(--brand-primary);
    box-shadow: var(--brand-ring);
    outline: none;
}
.dataTables_wrapper .dataTables_info {
    color: #8a90a2;
    font-size: .82rem;
}

/* Pagination -> rounded, brand active */
.pagination {
    gap: 4px;
}
.page-link {
    border-radius: 9px !important;
    border: 1px solid transparent;
    color: #5a6273;
    transition: background-color .15s ease, color .15s ease;
}
.page-link:hover {
    background-color: rgba(var(--brand-primary-rgb), .08);
    color: var(--brand-primary);
}
.page-item.active .page-link,
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
    background: var(--brand-gradient) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(var(--brand-primary-rgb), .28);
}
.dataTables_wrapper .dataTables_paginate .paginate_button {
    border-radius: 9px !important;
    border: 0 !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    background: rgba(var(--brand-primary-rgb), .08) !important;
    color: var(--brand-primary) !important;
}
.page-item.disabled .page-link {
    color: #b7bccb;
}

/* DataTables sort indicators + processing bar use brand */
.dataTables_wrapper .dataTables_processing {
    border-radius: 10px;
    box-shadow: var(--brand-shadow-md);
}

/* Export / action buttons row spacing */
.dt-buttons .btn {
    margin-right: 6px;
}


/* =====================================================================
   PHASE 5 — DASHBOARD & WIDGETS
   ===================================================================== */

/* Rebrand the "subtle/lighten" tints used by .bg-primary-lighten /
   .bg-secondary-lighten (and badges) */
:root,
[data-bs-theme] {
    --ct-primary-bg-subtle:     var(--brand-primary-light);
    --ct-primary-border-subtle: rgba(var(--brand-primary-rgb), .22);
    --ct-primary-text-emphasis: var(--brand-primary-dark);

    --ct-secondary-bg-subtle:     var(--brand-accent-light);
    --ct-secondary-border-subtle: rgba(var(--brand-accent-rgb), .22);
    --ct-secondary-text-emphasis: var(--brand-accent-dark);
}
[data-bs-theme="dark"] {
    --ct-primary-bg-subtle:   rgba(var(--brand-primary-rgb), .16);
    --ct-secondary-bg-subtle: rgba(var(--brand-accent-rgb), .16);
}

/* ---------- Stat / KPI tiles ---------- */
.tilebox-one {
    position: relative;
}
.tilebox-one i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    font-size: 24px;
    border-radius: 14px;
    background: var(--brand-gradient-soft);
    color: var(--brand-primary);
    box-shadow: inset 0 0 0 1px rgba(var(--brand-primary-rgb), .10);
}

/* Big KPI numbers */
.tilebox-one + h5 + h2,
.card-body h2[id] {
    font-weight: 700;
    letter-spacing: -.5px;
}

/* The small round "open page" link badge on tiles */
.badge.bg-primary-lighten.text-primary {
    background: var(--brand-gradient-soft) !important;
    color: var(--brand-primary) !important;
    transition: transform .15s ease, box-shadow .15s ease;
}
.badge.bg-primary-lighten.text-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(var(--brand-primary-rgb), .25);
}

/* Sub-stat chips inside tiles -> softer rounded */
.card-body .badge.border {
    border-radius: 8px;
    background-color: rgba(var(--brand-primary-rgb), .03);
}

/* Month/year pickers in the analytics header */
.card-header select.picker {
    border-radius: 9px;
    border: 1px solid rgba(16, 24, 64, .14);
    padding: .3rem .55rem;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.card-header select.picker:focus {
    border-color: var(--brand-primary);
    box-shadow: var(--brand-ring);
    outline: none;
}

/* Apex charts: brand-aligned grid + tooltip */
.apex-charts text { font-family: inherit !important; }
.apexcharts-tooltip {
    border-radius: 10px !important;
    box-shadow: var(--brand-shadow-md) !important;
    border: 1px solid rgba(16, 24, 64, .08) !important;
}
.apexcharts-tooltip-title {
    background: rgba(var(--brand-primary-rgb), .06) !important;
    border-bottom: 1px solid rgba(16, 24, 64, .06) !important;
    font-weight: 600 !important;
}


/* =====================================================================
   PHASE 6 — AUTH / LOGIN
   ===================================================================== */

/* Brand gradient mesh backdrop */
.authentication-bg {
    background-color: #0f1a4d;
    background-image:
        radial-gradient(at 12% 18%, rgba(var(--brand-accent-rgb), .55) 0px, transparent 45%),
        radial-gradient(at 88% 12%, rgba(var(--brand-primary-rgb), .65) 0px, transparent 50%),
        radial-gradient(at 50% 95%, rgba(var(--brand-primary-rgb), .55) 0px, transparent 55%),
        linear-gradient(135deg, #2541B2 0%, #1b2e7e 55%, #00C2A8 160%);
    min-height: 100vh;
}

/* Make the decorative SVG circles glow softly over the gradient */
.authentication-bg > .position-absolute svg g {
    fill-opacity: .12;
}

/* Login card -> elevated, glassy, modern */
.account-pages .card {
    border: 1px solid rgba(255, 255, 255, .35);
    border-radius: var(--brand-radius-lg);
    box-shadow: 0 24px 60px rgba(8, 15, 52, .35);
    background-color: rgba(255, 255, 255, .98);
    backdrop-filter: blur(6px);
}
[data-bs-theme="dark"] .account-pages .card {
    background-color: rgba(24, 28, 44, .96);
    border-color: rgba(255, 255, 255, .08);
}

/* Header with brand gradient + logo breathing room */
.account-pages .card .card-header.bg-primary {
    background: var(--brand-gradient) !important;
    border-top-left-radius: var(--brand-radius-lg);
    border-top-right-radius: var(--brand-radius-lg);
    padding-top: 1.6rem;
    padding-bottom: 1.6rem;
}

/* Title + fields */
.account-pages .card-body h4 {
    letter-spacing: .2px;
}
.account-pages .form-control {
    padding: .6rem .85rem;
}

/* Password eye toggle aligned to the rounded merged input */
.account-pages .input-group-merge .input-group-text {
    background-color: transparent;
    border-left: 0;
    cursor: pointer;
}
.account-pages .input-group-merge .form-control {
    border-right: 0;
}

/* Full-width, prominent login button */
.account-pages form .btn-primary {
    width: 100%;
    padding: .65rem 1rem;
    font-size: .98rem;
    font-weight: 600;
    margin-top: .25rem;
}


/* =====================================================================
   PHASE 7 — OVERLAYS & DETAIL COMPONENTS
   ===================================================================== */

/* ---------- Modals ---------- */
.modal-content {
    border: 0;
    border-radius: var(--brand-radius-lg);
    box-shadow: var(--brand-shadow-lg);
    overflow: hidden;
}
.modal-header {
    background: var(--brand-gradient-soft);
    border-bottom: 1px solid rgba(16, 24, 64, .06);
    padding: 1rem 1.25rem;
}
.modal-header .modal-title {
    font-weight: 600;
    color: var(--brand-primary-dark);
}
[data-bs-theme="dark"] .modal-header .modal-title {
    color: #fff;
}
.modal-footer {
    border-top: 1px solid rgba(16, 24, 64, .06);
}
.modal-backdrop.show {
    background-color: #0c1336;
    opacity: .55;
}

/* ---------- Dropdown menus ---------- */
.dropdown-menu {
    border: 1px solid rgba(16, 24, 64, .07);
    border-radius: var(--brand-radius-sm);
    box-shadow: var(--brand-shadow-md);
    padding: 6px;
}
.dropdown-item {
    border-radius: 8px;
    padding: .5rem .75rem;
    transition: background-color .14s ease, color .14s ease;
}
.dropdown-item:hover,
.dropdown-item:focus {
    background-color: rgba(var(--brand-primary-rgb), .08);
    color: var(--brand-primary);
}
.dropdown-item.active,
.dropdown-item:active {
    background: var(--brand-gradient);
    color: #fff;
}

/* ---------- Tabs & pills ---------- */
.nav-pills .nav-link {
    border-radius: 9px;
    font-weight: 500;
    color: #5a6273;
    transition: background-color .15s ease, color .15s ease;
}
.nav-pills .nav-link:hover {
    background-color: rgba(var(--brand-primary-rgb), .08);
    color: var(--brand-primary);
}
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background: var(--brand-gradient);
    color: #fff;
    box-shadow: 0 4px 12px rgba(var(--brand-primary-rgb), .25);
}
.nav-tabs.nav-bordered .nav-link {
    font-weight: 500;
    border-width: 0 0 2px 0;
    transition: color .15s ease, border-color .15s ease;
}
.nav-tabs.nav-bordered .nav-link:hover {
    color: var(--brand-primary);
}
.nav-tabs.nav-bordered .nav-link.active {
    color: var(--brand-primary);
    border-bottom-color: var(--brand-primary) !important;
}

/* ---------- Alerts ---------- */
.alert {
    border: 0;
    border-radius: var(--brand-radius-sm);
    border-left: 4px solid transparent;
}
.alert-success {
    border-left-color: var(--brand-accent);
}
.alert-primary {
    border-left-color: var(--brand-primary);
}

/* ---------- Toasts (jquery-toast-plugin) ---------- */
.jq-toast-single {
    border-radius: var(--brand-radius-sm) !important;
    box-shadow: var(--brand-shadow-md) !important;
    font-family: inherit !important;
}

/* ---------- Avatars & images ---------- */
.avatar-lg, .avatar-md, .avatar-sm, .avatar-xs {
    border-radius: 12px;
}
.rounded-circle {
    box-shadow: 0 0 0 1px rgba(16, 24, 64, .04);
}

/* ---------- Progress bars ---------- */
.progress {
    border-radius: 30px;
    background-color: rgba(var(--brand-primary-rgb), .08);
    height: .6rem;
}
.progress-bar {
    background: var(--brand-gradient);
    border-radius: 30px;
}

/* ---------- Detail-page polish ---------- */
/* Definition-style detail rows look tidy with the new tints */
.table-borderless td, .table-borderless th {
    border: 0;
}
/* Quill / rich text containers share the rounded language */
.ql-toolbar.ql-snow,
.ql-container.ql-snow {
    border-color: rgba(16, 24, 64, .14) !important;
}
.ql-toolbar.ql-snow {
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}
.ql-container.ql-snow {
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
}


/* =====================================================================
   PHASE 8 — POLISH & QA
   ===================================================================== */

/* Swiper carousels (used in detail galleries) -> brand controls */
.swiper-pagination-bullet-active {
    background: var(--brand-primary) !important;
}
.swiper-button-next,
.swiper-button-prev {
    color: var(--brand-primary) !important;
}

/* "Brand" sidebar mode (data-menu-color="brand") -> gradient instead of flat */
[data-menu-color="brand"] .leftside-menu {
    background: linear-gradient(180deg, var(--brand-primary) 0%, var(--brand-primary-dark) 100%) !important;
}
[data-menu-color="brand"] .side-nav .menuitem-active > .side-nav-link,
[data-menu-color="brand"] .side-nav .side-nav-link.active {
    background: rgba(255, 255, 255, .16);
    box-shadow: none;
}
[data-menu-color="brand"] .side-nav .side-nav-item:not(.menuitem-active) > .side-nav-link:hover {
    background-color: rgba(255, 255, 255, .10);
    color: #fff;
}
[data-menu-color="brand"] .side-nav .side-nav-item:not(.menuitem-active) > .side-nav-link:hover i {
    color: #fff;
}

/* Date pickers (bootstrap-datepicker / daterangepicker) -> brand selection */
.datepicker table tr td.active,
.datepicker table tr td.active:hover,
.datepicker table tr td.today,
.daterangepicker td.active,
.daterangepicker td.active:hover {
    background: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    color: #fff !important;
}
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
}

/* Dropzone upload area -> dashed brand affordance */
.dropzone {
    border: 2px dashed rgba(var(--brand-primary-rgb), .30);
    border-radius: var(--brand-radius);
    background-color: rgba(var(--brand-primary-rgb), .02);
    transition: border-color .18s ease, background-color .18s ease;
}
.dropzone:hover {
    border-color: rgba(var(--brand-primary-rgb), .55);
    background-color: rgba(var(--brand-primary-rgb), .04);
}

/* Theme customizer offcanvas: brand the title */
#theme-settings-offcanvas .offcanvas-title {
    font-weight: 600;
}

/* Accessibility: visible brand focus outline for keyboard users */
a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.nav-link:focus-visible {
    outline: 2px solid rgba(var(--brand-primary-rgb), .55);
    outline-offset: 2px;
}

/* Text color helpers stay on-brand */
.text-primary { color: var(--brand-primary) !important; }
.link-primary { color: var(--brand-primary) !important; }
a { color: var(--brand-primary); }
a:hover { color: var(--brand-primary-dark); }
