/* ============================================
   CreatorDaddy - Global Stylesheet
   Modern · Sleek · Energetic · Orange & Black
   ============================================ */

/* ── Color System ──
   Accessibility-verified (WCAG AA 4.5:1+):
   Dark:  #FF4500 on #0A0A0A = 5.76:1 ✓  (vibrant brand orange)
   Light: #D04000 on #FAFAFA = 4.55:1 ✓  (vibrant orange)
   Buttons: #FF4500 on white text = 3.44:1 ✓  (WCAG AA large text)
   ─────────────────────────────────────────── */

:root, [data-bs-theme="light"] {
    --bs-font-sans-serif: "Google Sans Flex", system-ui, -apple-system, sans-serif;
    --bs-body-font-family: var(--bs-font-sans-serif);
    --bs-body-bg: #FAFAFA;
    --bs-body-color: #1A1A1A;
    --bs-secondary-color: #6B6B6B;
    --bs-border-color: #E0E0E0;
    --bs-tertiary-bg: #FFFFFF;

    --bs-primary: #D04000;
    --bs-primary-rgb: 208, 64, 0;
    --bs-link-color: #D04000;
    --bs-link-hover-color: #B33600;
    --bs-focus-ring-color: rgba(208, 64, 0, 0.25);

    --cd-surface: #FFFFFF;
    --cd-surface-hover: #F5F5F5;
    --cd-accent-soft: rgba(255, 100, 0, 0.07);
    --cd-accent-medium: rgba(255, 100, 0, 0.14);
    --cd-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --cd-shadow-md: 0 2px 8px rgba(0, 0, 0, 0.08);
    --cd-shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.1);
    --cd-glow: 0 0 0 1px rgba(255, 100, 0, 0.22);
    --cd-text-heading: #0A0A0A;
    --cd-hero-gradient: linear-gradient(145deg, rgba(255, 100, 0, 0.05) 0%, transparent 50%);
}

[data-bs-theme="dark"] {
    --bs-body-bg: #0A0A0A;
    --bs-body-color: #E8E8E8;
    --bs-secondary-color: #A0A0A0;
    --bs-border-color: #2A2A2A;
    --bs-tertiary-bg: #141414;

    --bs-primary: #FF4500;
    --bs-primary-rgb: 255, 69, 0;
    --bs-link-color: #FF4500;
    --bs-link-hover-color: #FF6A33;
    --bs-focus-ring-color: rgba(255, 69, 0, 0.35);

    --cd-surface: #141414;
    --cd-surface-hover: #1E1E1E;
    --cd-accent-soft: rgba(255, 69, 0, 0.10);
    --cd-accent-medium: rgba(255, 69, 0, 0.18);
    --cd-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --cd-shadow-md: 0 2px 8px rgba(0, 0, 0, 0.4);
    --cd-shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.5);
    --cd-glow: 0 0 0 1px rgba(255, 69, 0, 0.25);
    --cd-text-heading: #FFFFFF;
    --cd-hero-gradient: linear-gradient(145deg, rgba(255, 69, 0, 0.07) 0%, transparent 50%);
}

/* ── Stable Scrollbar Gutter ──
   Reserves scrollbar space always so layout never reflows when content grows/shrinks.
   Prevents the "field expansion" glitch on mobile when tools switch between short
   (placeholder) and tall (populated) states. */
html { scrollbar-gutter: stable; }

/* ── Modal Scrollbar Compensation Override ──
   Bootstrap 5 adds inline padding-right to <body> (and padding-right to .fixed-top
   / margin-right to .sticky-top) when a modal opens, to compensate for the
   scrollbar being hidden. Because we reserve the gutter permanently via
   scrollbar-gutter: stable above, the browser never hides the scrollbar - so
   Bootstrap's compensation over-corrects and produces a visible layout shift
   every time the search modal opens/closes. Neutralize the padding only; leave
   body.modal-open { overflow: hidden } intact so background scroll-lock works. */
body.modal-open { padding-right: 0 !important; }
body.modal-open .global-header,
body.modal-open .sticky-top,
body.modal-open .fixed-top,
body.modal-open .fixed-bottom {
    padding-right: 0 !important;
    margin-right: 0 !important;
}

/* ── Selection ── */
::selection {
    background: rgba(var(--bs-primary-rgb), 0.2);
    color: inherit;
}

/* ── Typography ── */
h1, h2, h3, h4, h5, h6 {
    color: var(--cd-text-heading);
    letter-spacing: -0.01em;
}

.text-primary { color: var(--bs-primary) !important; }

/* ── Links ── */
a, .btn-link { color: var(--bs-link-color); text-decoration: none; }
a:hover, .btn-link:hover, .btn-link:focus { color: var(--bs-link-hover-color); }
a.text-primary:hover { color: var(--bs-link-hover-color) !important; }
.text-body.btn-link:hover { color: var(--bs-primary) !important; }

/* ── Focus States (Accessibility) ── */
.btn:focus-visible, .btn-close:focus-visible {
    box-shadow: 0 0 0 3px var(--bs-focus-ring-color) !important;
    outline: none !important;
}
.btn:focus:not(:focus-visible) { box-shadow: none !important; }
.navbar .btn-link:focus { box-shadow: none !important; }

/* ── Dividers ── */
hr { border-color: var(--bs-border-color) !important; opacity: 1 !important; }

/* ── Header & Footer ── */
.global-header,
.global-footer {
    border-color: var(--bs-border-color) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

[data-bs-theme="dark"] .global-header,
[data-bs-theme="dark"] .global-footer {
    background-color: rgba(10, 10, 10, 0.88) !important;
}
[data-bs-theme="light"] .global-header,
[data-bs-theme="light"] .global-footer {
    background-color: rgba(250, 250, 250, 0.88) !important;
}

.global-header {
    position: sticky;
    top: 0;
    z-index: 1030;
}

/* ── Surfaces ── */
.card, .modal-content, .offcanvas, .list-group-item {
    background-color: var(--cd-surface) !important;
}

/* ── Side Drawer Width ── */
/* Slightly wider on mid-size screens (768px-1199px) for comfortable browsing */
@media (min-width: 768px) and (max-width: 1199px) {
    #globalSideDrawer { width: 320px !important; }
}
/* Full mobile keeps Bootstrap default (~300px) */
.card {
    border: 1px solid var(--bs-border-color);
    box-shadow: var(--cd-shadow-sm);
}
.modal-content {
    border: 1px solid var(--bs-border-color);
    box-shadow: var(--cd-shadow-lg);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

/* ── Border Radius ── */
.card, .form-control, .form-select, .btn, .modal-content,
.list-group-item, .badge { border-radius: 8px !important; }
.btn-sm { border-radius: 6px !important; }
.rounded-pill { border-radius: 100px !important; }

/* ── Buttons ── */
.btn-primary {
    --bs-btn-bg: #FF4500;
    --bs-btn-border-color: #FF4500;
    --bs-btn-hover-bg: #E63E00;
    --bs-btn-hover-border-color: #E63E00;
    --bs-btn-color: #FFFFFF !important;
    --bs-btn-hover-color: #FFFFFF !important;
    --bs-btn-active-bg: #CC3700;
    --bs-btn-active-border-color: #CC3700;
    --bs-btn-active-color: #FFFFFF !important;
    font-weight: 600;
    box-shadow: var(--cd-shadow-sm);
}

.btn-outline-primary {
    --bs-btn-color: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-bg: #FF4500;
    --bs-btn-hover-border-color: #FF4500;
    --bs-btn-hover-color: #FFFFFF !important;
    --bs-btn-active-bg: #E63E00;
    --bs-btn-active-border-color: #E63E00;
    --bs-btn-active-color: #FFFFFF !important;
    font-weight: 600;
}

.btn-outline-danger {
    --bs-btn-color: #DC2626;
    --bs-btn-border-color: #DC2626;
    --bs-btn-hover-bg: #DC2626;
    --bs-btn-hover-border-color: #DC2626;
    --bs-btn-hover-color: #FFFFFF !important;
    --bs-btn-active-bg: #B91C1C;
    --bs-btn-active-border-color: #B91C1C;
    --bs-btn-active-color: #FFFFFF !important;
    font-weight: 600;
}
[data-bs-theme="dark"] .btn-outline-danger {
    --bs-btn-color: #EF4444;
    --bs-btn-border-color: #EF4444;
    --bs-btn-hover-bg: #EF4444;
    --bs-btn-hover-border-color: #EF4444;
    --bs-btn-active-bg: #DC2626;
    --bs-btn-active-border-color: #DC2626;
}

/* ── Mobile fullscreen button - neutral/white so it doesn't blend with orange logo ── */
.fs-btn-mobile {
    --bs-btn-color: var(--bs-body-color) !important;
    --bs-btn-border-color: var(--bs-border-color) !important;
    --bs-btn-hover-bg: var(--cd-surface-hover) !important;
    --bs-btn-hover-border-color: var(--bs-border-color) !important;
    --bs-btn-hover-color: var(--bs-body-color) !important;
}

/* ── Form Controls (Unified Sitewide Styling) ──
   Base look for every <input> / <select> / <textarea>. All tools and pages
   should inherit this - do NOT redefine .form-control / .form-select locally.
   Reference pages: /exchange-rate-calculator, /currency-converter. */
.form-control,
.form-select {
    background-color: var(--cd-surface) !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
    font-size: 1.0625rem;
    padding: 0.75rem 1rem;
}
.form-select { padding-right: 2.5rem; }
.form-select:disabled { opacity: 0.6; }

/* Focus: subtle inset 1px ring in brand orange - NO outer neon glow. */
.form-control:focus,
.form-select:focus {
    border-color: var(--bs-primary) !important;
    box-shadow: inset 0 0 0 1px var(--bs-primary) !important;
}

/* Checkboxes / radios keep the accessible outer focus ring (they are small). */
.form-check-input:focus {
    border-color: var(--bs-primary) !important;
    box-shadow: 0 0 0 3px var(--bs-focus-ring-color) !important;
}
.form-check-input:checked {
    background-color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
}

/* Unified field label - use above every input on forms. */
.field-label {
    display: block;
    font-weight: 600;
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--bs-secondary-color);
    margin-bottom: 0.375rem;
}
.field-label .optional-tag {
    font-weight: 400;
    font-size: 0.75rem;
    text-transform: none;
    letter-spacing: 0;
    margin-left: 0.25rem;
}

/* ── Interactive hover - ONLY for clickable elements ── */
.hover-border-primary {
    border: 1px solid var(--bs-border-color);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.hover-border-primary:hover {
    border-color: var(--bs-primary) !important;
    box-shadow: var(--cd-glow);
    transform: translateY(-1px);
}
.hover-border-primary:active { transform: translateY(0); }

/* ── Tool Cards (Home Page) ── */
.tool-card {
    border: 1px solid var(--bs-border-color);
    background: var(--cd-surface);
    box-shadow: var(--cd-shadow-sm);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.tool-card:hover {
    border-color: var(--bs-primary) !important;
    box-shadow: var(--cd-glow), var(--cd-shadow-md);
    transform: translateY(-2px);
}
.tool-card:active { transform: translateY(0); }

.tool-card .tool-icon-wrap {
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 8px;
    background: var(--cd-accent-soft);
    color: var(--bs-primary);
    flex-shrink: 0;
}

/* ── Hero Section ── */
.hero-section {
    background: var(--cd-hero-gradient);
    border-radius: 16px;
    padding: 3rem 2rem;
}
.hero-section h1 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -0.025em;
}
.hero-section p {
    font-size: 1.05rem;
    max-width: 480px;
    margin-left: auto; margin-right: auto;
}

/* ── Theme Toggle (3-state segmented) ── */
.theme-toggle {
    display: inline-flex;
    background: var(--bs-border-color);
    border-radius: 10px;
    padding: 3px;
    gap: 2px;
}
.theme-toggle-btn {
    display: flex; align-items: center; justify-content: center;
    width: 32px; height: 28px;
    border: none; border-radius: 7px;
    background: transparent;
    color: var(--bs-secondary-color);
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}
.theme-toggle-btn:hover { color: var(--bs-body-color); }
.theme-toggle-btn.active {
    background: var(--cd-surface);
    color: #FF4500;
    box-shadow: var(--cd-shadow-sm);
}
.theme-toggle-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--bs-focus-ring-color);
}
.theme-toggle-btn svg { width: 14px; height: 14px; }

/* ── Mobile Drawer ── */
.drawer-link {
    display: flex; align-items: center;
    padding: 14px 24px; color: var(--bs-body-color);
    text-decoration: none; font-weight: 500;
    border-bottom: 1px solid var(--bs-border-color);
    transition: background-color 0.15s;
}
.drawer-link:hover { background-color: var(--cd-surface-hover); color: var(--bs-body-color); }

.accordion-button {
    font-weight: 600; padding: 14px 24px;
    color: var(--bs-body-color) !important;
    background: transparent !important; box-shadow: none !important;
}
.accordion-button:not(.collapsed) { color: var(--bs-primary) !important; }
.accordion-button:focus { box-shadow: none !important; outline: none !important; }

.drawer-sublink-wrapper {
    margin-left: 28px;
    display: flex; flex-direction: column; margin-bottom: 12px;
}
.drawer-sublink {
    padding: 10px 16px 10px 24px; color: var(--bs-secondary-color);
    text-decoration: none; position: relative;
    font-size: 14px; font-weight: 500; transition: color 0.15s;
    background-image: linear-gradient(var(--bs-border-color), var(--bs-border-color));
    background-size: 1px 100%;
    background-repeat: no-repeat;
    background-position: 0 0;
}
.drawer-sublink:last-child {
    background-size: 1px 50%;
}
.drawer-sublink::before {
    content: ''; position: absolute; left: 0; top: 50%;
    width: 12px; height: 1px; background-color: var(--bs-border-color);
}
.drawer-sublink:hover { color: var(--bs-primary); text-decoration: none; }

/* ── Editor Areas ── */
.editor-textarea,
textarea.editor-textarea {
    min-height: 40vh;
    height: 100%; resize: none;
    background-color: transparent !important;
    font-size: 0.9375rem; line-height: 1.7;
}
.editor-textarea:focus {
    box-shadow: none !important;
    background-color: transparent !important;
    outline: none !important;
}
.editor-card {
    height: 100%;
    border: 1px solid var(--bs-border-color);
    box-shadow: var(--cd-shadow-sm);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.editor-card:focus-within {
    border-color: var(--bs-primary) !important;
    box-shadow: var(--cd-glow) !important;
}

/* ── Taller textareas on mobile ── */
@media (max-width: 767.98px) {
    .editor-card {
        min-height: 45vh;
        height: auto !important;
        flex: 0 0 auto !important;
    }
    .editor-textarea,
    textarea.editor-textarea { min-height: 45vh; height: auto; }
}

/* ── List Group Actions ── */
.list-group-item-action { transition: background-color 0.15s; }
.list-group-item-action:hover,
.list-group-item-action:focus {
    background-color: var(--cd-surface-hover) !important;
    color: var(--bs-body-color) !important;
}

/* ── Active Preset Indicator ── */
.active-preset {
    background-color: var(--cd-accent-soft) !important;
    border-left: 3px solid var(--bs-primary) !important;
}

/* ── Tool Page Header ── */
#tool-header-section p {
    font-size: 1.1rem;
    line-height: 1.6;
}

/* ── Fullscreen Mode - consistent spacing ── */
body.in-app-fullscreen #tool-header-section,
body.in-app-fullscreen #preset-controls-section {
    display: none !important;
}
body.in-app-fullscreen main {
    padding: 0.75rem !important;
}
body.in-app-fullscreen main .row {
    --bs-gutter-x: 0.75rem;
    --bs-gutter-y: 0.75rem;
}
body.in-app-fullscreen #stat-grid { margin-bottom: 0.75rem !important; }
body.in-app-fullscreen .stat-card { padding: 0.5rem !important; }
body.in-app-fullscreen .stat-value { font-size: 1.5rem !important; margin-bottom: 0.25rem !important; }

/* ── Stat Cards - display only, NO hover effects ── */
.stat-card {
    border: 1px solid var(--bs-border-color);
    border-radius: 8px;
    background: var(--cd-surface) !important;
}
.stat-value {
    color: var(--cd-text-heading);
    font-variant-numeric: tabular-nums;
}

/* ── Preset Chip ── */
.preset-chip {
    display: inline-flex; overflow: hidden;
    border: 1px solid var(--bs-border-color); border-radius: 8px;
    cursor: pointer; box-shadow: var(--cd-shadow-sm);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.preset-chip:hover { border-color: var(--bs-primary) !important; box-shadow: var(--cd-glow); }

.preset-chip-label,
.preset-chip-value {
    padding: 10px 14px; display: flex; align-items: center;
    line-height: 1;
}
.preset-chip-label {
    background: var(--cd-surface-hover);
    border-right: 1px solid var(--bs-border-color);
}
.preset-chip-value {
    background: var(--cd-surface); font-weight: 600;
}

/* ── Global Stats Badge ── */
.stats-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 14px; border-radius: 100px;
    border: 1px solid var(--bs-border-color);
    background: var(--cd-surface);
    font-size: 12.5px; font-weight: 500;
    color: var(--bs-secondary-color);
}
.stats-badge .stats-count { color: var(--cd-text-heading); font-weight: 700; }

/* ── Z-index Helper ── */
.z-index-1 { z-index: 1; }

/* ── Header Side Columns (equal-width flanks for mobile logo centering) ── */
.header-side { flex: 1; min-width: 0; }

/* ── Desktop Mega Menu ── */
@media (min-width: 1200px) {
    .global-header .navbar-nav { position: relative; }

    .mega-dropdown {
        position: static;
        align-self: stretch;
        display: flex;
        align-items: center;
    }

    .mega-menu {
        display: none;
        position: absolute;
        top: calc(100% + 2rem);
        left: 0;
        right: 0;
        z-index: 1;
    }

    .mega-menu::before {
        content: '';
        position: absolute;
        top: -2.25rem;
        left: 0;
        right: 0;
        height: 2.25rem;
        background: transparent;
    }

    .mega-dropdown:hover > .mega-menu { display: block; }

    .mega-menu-body {
        background: var(--cd-surface);
        border: 1px solid var(--bs-border-color);
        border-radius: 12px;
        box-shadow: var(--cd-shadow-lg);
        max-height: calc(100vh - var(--mega-nav-h, 64px));
        max-height: calc(100dvh - var(--mega-nav-h, 64px));
        overflow-y: auto;
        overflow-x: hidden;
        padding: 1rem;
    }

    .mega-menu-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
        gap: 0.5rem;
        max-width: 1800px;
        margin: 0 auto;
    }

    .mega-item {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        min-height: 2.5rem;
        padding: 0.5rem 0.75rem;
        color: var(--bs-body-color);
        text-decoration: none;
        font-size: 0.875rem;
        font-weight: 500;
        line-height: 1.35;
        text-align: left;
        transition: color 0.2s ease;
    }

    .mega-item:hover {
        color: var(--bs-primary);
        text-decoration: underline;
        text-underline-offset: 3px;
    }

    .mega-toggle::after {
        content: '';
        display: inline-block;
        margin-left: 0.3em;
        vertical-align: middle;
        border-top: 0.32em solid;
        border-right: 0.28em solid transparent;
        border-bottom: 0;
        border-left: 0.28em solid transparent;
        opacity: 0.65;
        transition: transform 0.2s ease;
    }

    .mega-dropdown:hover .mega-toggle::after { transform: rotate(180deg); }
}

/* Compact nav at xl (1200-1399px) so all items fit without wrapping */
@media (min-width: 1200px) and (max-width: 1399px) {
    .navbar-nav .nav-link { padding-left: 0.5rem !important; padding-right: 0.5rem !important; font-size: 0.8125rem !important; }
}

/* Slightly roomier nav at xxl (1400px+) */
@media (min-width: 1400px) {
    .navbar-nav .nav-link { padding-left: 0.625rem !important; padding-right: 0.625rem !important; }
}

.navbar-nav .nav-link { font-size: 0.875rem; letter-spacing: 0.01em; }
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus { color: var(--bs-primary) !important; }

.dropdown-item { font-size: 0.875rem; border-radius: 4px; }
.dropdown-item:hover,
.dropdown-item:focus { background-color: var(--cd-accent-soft); color: var(--bs-primary); }

.dropdown-menu {
    border: 1px solid var(--bs-border-color);
    box-shadow: var(--cd-shadow-md); padding: 6px;
    border-radius: 8px !important; background: var(--cd-surface);
}

/* ── Search Modal ── */
#tool-search-input:focus { box-shadow: none !important; }
.hover-bg:hover { background-color: var(--cd-surface-hover) !important; }

/* ── Case Converter Buttons ──
   Height matches the original compact design. Buttons live in a flex-wrap
   container (not a Bootstrap grid) with a fixed 88px width so they sit
   edge-to-edge with uniform gap and hug the longest format name
   ("PascalCase", "Train-Case", "UPPER CASE" etc.). On narrow viewports the
   flex row wraps naturally. Keep .case-name font-size at 11px and width at
   86px or above to avoid wrapping the longest names. */
.case-btn {
    flex: 0 0 auto;
    width: 88px;
    border: 1px solid var(--bs-border-color);
    background: var(--cd-surface); color: var(--bs-body-color);
    padding: 10px 6px; border-radius: 8px !important;
    cursor: pointer; text-align: center;
    transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}
.case-btn:hover { border-color: var(--bs-primary); background: var(--cd-accent-soft); }
.case-btn.active {
    border-color: var(--bs-primary); background: var(--cd-accent-medium);
    box-shadow: var(--cd-glow);
}
.case-btn .case-abbr {
    font-size: 1.1rem; font-weight: 700; display: block;
    line-height: 1.2; color: var(--cd-text-heading);
}
.case-btn .case-name {
    font-size: 11px; font-weight: 500; color: var(--bs-secondary-color);
    display: block; margin-top: 2px; line-height: 1.2;
    white-space: nowrap;
}
.case-btn.active .case-abbr { color: var(--bs-primary); }

/* ── Footer Credit ── */
.footer-credit { font-size: 13px; color: var(--bs-secondary-color); }
.footer-credit a { font-weight: 600; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }

[data-bs-theme="dark"] ::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.18);
    border-radius: 3px;
}
[data-bs-theme="dark"] ::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.32);
}

[data-bs-theme="light"] ::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.18);
    border-radius: 3px;
}
[data-bs-theme="light"] ::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.32);
}

/* Firefox */
[data-bs-theme="dark"]  { scrollbar-color: rgba(255,255,255,0.18) transparent; scrollbar-width: thin; }
[data-bs-theme="light"] { scrollbar-color: rgba(0,0,0,0.18) transparent; scrollbar-width: thin; }

/* ── Combobox dropdown scrollbar - opaque track so items don't bleed through ── */
.cb-list::-webkit-scrollbar-track { background: var(--cd-surface); }
[data-bs-theme="dark"]  .cb-list { scrollbar-color: rgba(255,255,255,0.18) var(--cd-surface); }
[data-bs-theme="light"] .cb-list { scrollbar-color: rgba(0,0,0,0.18) var(--cd-surface); }
