/* =============================================================================
   custom.css — Art Nexus Suite: Prompt Builder
   Dark Atelier Theme — merged from inline <style> + former custom.css
   v2026.03.18

   
   ============================================================================= */


/* ============================================================
   CSS CUSTOM PROPERTIES — Dark Atelier palette
   ============================================================ */
:root {
    --da-bg: #161412;
    --da-surface: #1e1b18;
    --da-card: #252018;
    --da-card-alt: #2a2520;
    --da-border: #3a3428;
    --da-border-light: #2e2820;
    --da-text: #ede8df;
    --da-text-dim: #b8ad9e;
    --da-muted: #7a7060;
    --da-accent: #d4944a;
    --da-accent-soft: #e8b87a;
    --da-accent-glow: rgba(212, 148, 74, 0.18);
    --da-accent-glow2: rgba(212, 148, 74, 0.06);
    --da-input: #1a1714;
    --da-input-focus: #1f1c18;
    --da-shadow: rgba(0, 0, 0, 0.5);
    --da-shadow-soft: rgba(0, 0, 0, 0.3);

    /* Compatibility aliases for external JS */
    --accent: var(--da-accent);
    --bg: var(--da-bg);
    --card: var(--da-card);
    --text: var(--da-text);
}


/* ============================================================
   BASE RESET + BODY
   ============================================================ */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    height: 100%;
}

body {
    font-family: 'Source Serif 4', Georgia, serif !important;
    font-size: 0.875rem;
    background-color: var(--da-bg) !important;
    color: var(--da-text) !important;
    padding: 1rem;
    /* Subtle canvas-grain overlay */
    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E") !important;
}

@media (min-width: 768px) {
    body {
        padding: 2rem;
    }
}


/* ============================================================
   MAIN CONTAINER
   ============================================================ */
.container.mx-auto {
    background-color: var(--da-surface) !important;
    border: 1px solid var(--da-border) !important;
    box-shadow: 0 32px 64px -12px var(--da-shadow), 0 0 0 1px var(--da-border-light) !important;
    padding: 1.5rem;
    border-radius: 0.75rem;
}


/* ============================================================
   HEADER / TITLE
   ============================================================ */
header h1 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 700 !important;
    color: var(--da-text) !important;
    letter-spacing: -0.02em;
    text-align: center;
    margin: 0;
    padding: 0 0 0.5rem 0;
}

#updateStatus {
    font-size: 0.75rem;
    color: #fff;
    text-align: center;
    font-weight: 400;
    letter-spacing: 0.06em;
    margin: 0;
    padding: 0;
}

#openHelpModalButton {
    margin-left: 15px;
    background-color: var(--da-card) !important;
    border: 1px solid var(--da-border) !important;
    color: var(--da-text-dim) !important;
    transition: all 0.2s !important;
}

#openHelpModalButton:hover {
    background-color: var(--da-card-alt) !important;
    border-color: var(--da-accent) !important;
    color: var(--da-accent) !important;
}


/* ============================================================
   LAYOUT UTILITIES  (replaces Tailwind — no external dependency)
   ============================================================ */

/* Display */
.hidden {
    display: none !important;
}

.block {
    display: block;
}

.flex {
    display: flex;
}

.grid {
    display: grid;
}

.inline-flex {
    display: inline-flex;
}

/* Flex helpers */
.flex-col {
    flex-direction: column;
}

.flex-1 {
    flex: 1 1 0%;
}

.flex-grow {
    flex-grow: 1;
}

.flex-wrap {
    flex-wrap: wrap;
}

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

.justify-between {
    justify-content: space-between;
}

.justify-center {
    justify-content: center;
}

/* Grid */
.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

.gap-1 {
    gap: 0.25rem;
}

.gap-2 {
    gap: 0.5rem;
}

.gap-4 {
    gap: 1rem;
}

.gap-6 {
    gap: 1.5rem;
}

.space-y-2>*+* {
    margin-top: 0.5rem;
}

.space-y-4>*+* {
    margin-top: 1rem;
}

.space-y-8>*+* {
    margin-top: 2rem;
}

.space-x-6>*+* {
    margin-left: 1.5rem;
}

/* Sizing */
.w-full {
    width: 100%;
}

.h-5 {
    height: 1.25rem;
}

.w-5 {
    width: 1.25rem;
}

.max-w-7xl {
    max-width: 80rem;
}

.max-w-2xl {
    max-width: 42rem;
}

.max-w-6xl {
    max-width: 72rem;
}

.max-h-48 {
    max-height: 12rem;
}

.max-h-\[85vh\] {
    max-height: 85vh;
}

.max-h-\[90vh\] {
    max-height: 90vh;
}

.overflow-hidden {
    overflow: hidden;
}

.overflow-y-auto {
    overflow-y: auto;
}

/* Position */
.relative {
    position: relative;
}

.absolute {
    position: absolute;
}

.fixed {
    position: fixed;
}

.inset-0 {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.top-3 {
    top: 0.75rem;
}

.right-3 {
    right: 0.75rem;
}

/* Z-index */
.z-40 {
    z-index: 40;
}

.z-50 {
    z-index: 50;
}

.z-60 {
    z-index: 60;
}

/* Spacing */
.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.mt-1 {
    margin-top: 0.25rem;
}

.mt-2 {
    margin-top: 0.5rem;
}

.mt-4 {
    margin-top: 1rem;
}

.mt-8 {
    margin-top: 2rem;
}

.mb-2 {
    margin-bottom: 0.5rem;
}

.mb-8 {
    margin-bottom: 2rem;
}

.ml-2 {
    margin-left: 0.5rem;
}

.mr-2 {
    margin-right: 0.5rem;
}

.p-3 {
    padding: 0.75rem;
}

.p-4 {
    padding: 1rem;
}

.p-6 {
    padding: 1.5rem;
}

.p-2\.5 {
    padding: 0.625rem;
}

.px-1 {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

.px-3 {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.pt-3 {
    padding-top: 0.75rem;
}

.pt-6 {
    padding-top: 1.5rem;
}

/* Typography */
.text-center {
    text-align: center;
}

.uppercase {
    text-transform: uppercase;
}

.italic {
    font-style: italic;
}

.font-medium {
    font-weight: 500;
}

.font-semibold {
    font-weight: 600;
}

.font-bold {
    font-weight: 700;
}

.font-black {
    font-weight: 900;
}

.text-xs {
    font-size: 0.75rem;
}

.text-sm {
    font-size: 0.875rem;
}

.text-lg {
    font-size: 1.125rem;
}

.text-xl {
    font-size: 1.25rem;
}

.text-3xl {
    font-size: 1.875rem;
}

.text-\[9px\] {
    font-size: 9px;
}

.text-\[10px\] {
    font-size: 10px;
}

.text-\[11px\] {
    font-size: 11px;
}

.text-\[12px\] {
    font-size: 12px;
}

.tracking-wider {
    letter-spacing: 0.05em;
}

.tracking-tight {
    letter-spacing: -0.025em;
}

/* Background — DA theme overrides */
.bg-white,
.bg-gray-50 {
    background-color: var(--da-card);
}

.bg-gray-100 {
    background-color: var(--da-bg);
}

.bg-black {
    background-color: rgba(0, 0, 0, 0.82);
}

.bg-red-50 {
    background-color: #4a1a1a;
}

.bg-gray-300 {
    background-color: var(--da-card-alt);
}

/* Text colors */
.text-white {
    color: #fff;
}

.text-gray-800,
.text-gray-700 {
    color: var(--da-text);
}

.text-gray-600,
.text-gray-500 {
    color: var(--da-text-dim);
}

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

.text-indigo-600,
.text-indigo-500 {
    color: var(--da-accent);
}

.text-indigo-800 {
    color: var(--da-accent-soft);
}

.text-red-600 {
    color: #f87171;
}

.text-red-700 {
    color: #fca5a5;
}

/* Borders */
.border {
    border: 1px solid var(--da-border);
}

.border-b {
    border-bottom: 1px solid var(--da-border);
}

.border-t {
    border-top: 1px solid var(--da-border);
}

.border-gray-200,
.border-gray-100,
.border-red-100 {
    border-color: var(--da-border);
}

.rounded-lg {
    border-radius: 0.5rem;
}

.rounded-xl {
    border-radius: 0.75rem;
}

.rounded-xxl {
    border-radius: 2.5rem;
}

.rounded-t-lg {
    border-radius: 0.5rem 0.5rem 0 0;
}

.outline-none {
    outline: none;
}

/* Misc utilities */
.cursor-pointer {
    cursor: pointer;
}

.cursor-move {
    cursor: move;
}

.shadow-sm {
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.shadow-md {
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
}

.shadow-2xl {
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.6);
}

.shadow-2x2 {
    box-shadow: 0 45px 70px -12px rgba(0, 0, 0, 0.6);
}

.transition-all {
    transition: all 0.15s ease;
}

.transition-colors {
    transition: color 0.15s, background-color 0.15s, border-color 0.15s;
}

.duration-150 {
    transition-duration: 150ms;
}

.boldtext {
    font-weight: bold;
}

/* Hover states */
.hover\:underline:hover {
    text-decoration: underline;
}

.hover\:text-red-500:hover {
    color: #f87171;
}

.hover\:text-red-600:hover {
    color: #fca5a5;
}

.hover\:text-red-700:hover {
    color: #fca5a5;
}

.hover\:text-indigo-600:hover,
.hover\:text-indigo-800:hover {
    color: var(--da-accent-soft);
}

.hover\:bg-red-100:hover {
    background-color: rgba(239, 68, 68, 0.15);
}

.hover\:bg-red-700:hover {
    background-color: #b91c1c;
}

.hover\:bg-gray-400:hover {
    background-color: var(--da-card-alt);
}

.hover\:border-indigo-200:hover {
    border-color: var(--da-accent);
}

/* Responsive breakpoints */
@media (min-width: 768px) {
    .md\:flex-row-reverse {
        flex-direction: row-reverse;
    }

    .md\:p-8 {
        padding: 2rem;
    }

    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .md\:text-4xl {
        font-size: 2.25rem;
    }

    .sm\:inline {
        display: inline;
    }
}

@media (min-width: 1024px) {
    .lg\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1280px) {
    .xl\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

/* Hide sm:inline items by default on mobile */
.sm\:inline {
    display: none;
}


/* ============================================================
   MOBILE OVERRIDES  (≤767px)
   ============================================================ */
@media only screen and (max-width: 767px) {
    body {
        padding: 5px;
        font-size: smaller;
    }

    header h1 {
        font-size: 1.5rem;
    }

    #copyMessage {
        font-family: 'Source Serif 4', serif !important;
        font-style: italic;
        letter-spacing: 0.03em;
        margin-top: 40px;
    }
}


/* ============================================================
   LABELS, TEXTAREAS, INPUTS, SELECTS
   ============================================================ */
label.block {
    color: var(--da-text-dim) !important;
    font-weight: 600;
    letter-spacing: 0.02em;
}

textarea {
    background-color: var(--da-input) !important;
    border-color: var(--da-border) !important;
    color: var(--da-text) !important;
    font-family: 'Source Serif 4', Georgia, serif !important;
    font-size: 0.9rem !important;
    line-height: 1.7 !important;
    transition: border-color 0.2s, box-shadow 0.2s;
    resize: vertical;
    width: 100%;
    padding: 0.75rem;
    border-width: 1px;
    border-style: solid;
    border-radius: 0.5rem;
    display: block;
}

textarea:focus {
    border-color: var(--da-accent) !important;
    box-shadow: 0 0 0 3px var(--da-accent-glow) !important;
    background-color: var(--da-input-focus) !important;
    outline: none !important;
}

textarea::placeholder {
    color: var(--da-muted) !important;
    font-style: italic;
}

input[type="text"],
select {
    background-color: var(--da-input) !important;
    border-color: var(--da-border) !important;
    color: var(--da-text) !important;
}

input[type="text"]:focus,
select:focus {
    border-color: var(--da-accent) !important;
    box-shadow: 0 0 0 3px var(--da-accent-glow) !important;
    outline: none !important;
}

input[type="text"]::placeholder {
    color: var(--da-muted) !important;
    font-style: italic;
}


/* ============================================================
   TEXTAREA CONTAINER + CLEAR ICON
   ============================================================ */
.textarea-container {
    position: relative;
}

.clear-icon {
    position: absolute;
    top: 8px;
    right: 8px;
    cursor: pointer;
    color: var(--da-muted);
    transition: color 0.2s ease-in-out;
}

.clear-icon:hover {
    color: #ef4444;
}


/* ============================================================
   BUTTONS — Copy Prompt, Copy Settings, Copy Complete & Open Menus
     (also used for Save/Open Library buttons, but not the red Confirm/Cancel modal buttons)
     Note: the .btn-primary and .btn-secondary classes are not used in the HTML,
     but defined here for potential future use or consistency.
     The specific IDs (#copyPromptButton, etc.) are targeted to ensure the correct styles
     are applied to these key action buttons.
     The hover states include a subtle darkening and an elevated box-shadow to create a tactile,
     interactive feel that fits the DA aesthetic.
   ============================================================ */
.btn-primary,
.btn.btn-primary,
#copyPromptButton,
#copySettingsButton,
#copyCompletePromptButton,
.btn-secondary,
.btn.btn-secondary,
#openMenusButton {
    background-color: #000 !important;
    border: none !important;
    color: #fff !important;
    font-family: 'Source Serif 4', serif !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em;
    box-shadow: 0 4px 14px rgba(212, 148, 74, 0.3) !important;
    transition: all 0.2s !important;
}

.btn-primary:hover,
#copyPromptButton:hover,
#copySettingsButton:hover,
#copyCompletePromptButton:hover,
#openMenusButton:hover {
    background-color: #333 !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(212, 148, 74, 0.4) !important;
}



/* ---- Small text action buttons ---- */
#savePromptLibraryButton,
#savePresetButton {
    background: transparent !important;
    color: var(--da-accent) !important;
    font-family: 'Source Serif 4', serif !important;
    transition: color 0.15s !important;
}

#savePromptLibraryButton:hover,
#savePresetButton:hover {
    color: var(--da-text) !important;
}

#openPromptLibraryButton,
#openLibraryButton,
#openModifierArchitectButton,
#openModifierArchitectButton a {
    background: transparent !important;
    color: var(--da-text-dim) !important;
    font-family: 'Source Serif 4', serif !important;
    transition: color 0.15s !important;
    text-decoration: none !important;
}

#openPromptLibraryButton:hover,
#openLibraryButton:hover,
#openModifierArchitectButton:hover,
#openModifierArchitectButton a:hover {
    color: var(--da-accent) !important;
}


/* ---- Confirmation modal buttons ---- */
#modalConfirmButton {
    background-color: #dc2626;
    color: #fff;
    font-weight: 600;
    border: none;
    border-radius: 0.5rem;
    padding: 0.5rem 1rem;
    cursor: pointer;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
    transition: background-color 0.15s;
}

#modalConfirmButton:hover {
    background-color: #b91c1c;
}

#modalCancelButton {
    background-color: var(--da-card-alt);
    color: var(--da-text-dim);
    font-weight: 600;
    border: 1px solid var(--da-border);
    border-radius: 0.5rem;
    padding: 0.5rem 1rem;
    cursor: pointer;
    transition: background-color 0.15s;
}

#modalCancelButton:hover {
    background-color: var(--da-border);
}


/* ============================================================
   COPY MESSAGE TOAST
   ============================================================ */
#copyMessage {
    margin-top: 0.75rem;
    padding: 0;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
    text-align: center;
    font-weight: bold;
}

#copyMessage.show {
    opacity: 1;
}

#copyMessage.success {
    color: #e8ebea;
}

#copyMessage.error {
    color: #deef44;
}


/* ============================================================
   CHAR COUNT
   ============================================================ */
#promptCharCount {
    color: var(--da-muted) !important;
    font-style: italic;
}

#promptCharCount.limit-reached {
    color: #caef44;
    font-weight: bold;
}


/* ============================================================
   RANDOM PROMPT / MODIFIER LINKS
   ============================================================ */
#randomprompts,
#randommodifiers {
    color: #fff !important;
    opacity: 0.8;
    font-style: italic;
    cursor: pointer;
}

#randomprompts:hover,
#randommodifiers:hover {
    opacity: 1;
}


/* ============================================================
   FORM SECTION DIVIDERS
   ============================================================ */
.border-t.pt-3,
.border-t.pt-6 {
    border-color: var(--da-border) !important;
}


/* ============================================================
   CHECKBOX CONTAINERS
   ============================================================ */
.checkbox-container {
    overflow-y: auto;
    padding-right: 10px;
}

.checkbox-container label {
    cursor: pointer;
    transition: all 0.2s ease-in-out;
}

.checkbox-container label:hover {
    background-color: var(--da-card-alt);
}

.checkbox-container input[type="checkbox"]+span {
    color: var(--da-text-dim);
    font-weight: normal;
}

.checkbox-container input[type="checkbox"]:checked+span {
    font-weight: bold;
}

.checkbox-container input[type="checkbox"],
.checkbox-list input[type="checkbox"] {
    accent-color: var(--da-accent);
}

.checkbox-container label,
.checkbox-list label {
    color: var(--da-text-dim) !important;
}

/* Animation for checkbox sorting */
.fade-out {
    opacity: 0;
    transition: opacity 1s ease;
}


/* ============================================================
   BULK-DELETE BAR
   ============================================================ */
#bulkDeleteBar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: rgba(239, 68, 68, 0.1);
    padding: 0.5rem;
    border-radius: 0.5rem;
    border: 1px solid rgba(239, 68, 68, 0.25);
}

#bulkDeleteBar .text-red-700 {
    color: #fca5a5;
}

#bulkDeleteBar button {
    color: #f87171;
    font-weight: 700;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.25rem 0.75rem;
    border-radius: 0.25rem;
    transition: background 0.15s;
}

#bulkDeleteBar button:hover {
    background-color: rgba(239, 68, 68, 0.15);
}


/* ============================================================
   MODIFIER MENUS MODAL
   ============================================================ */
#menusModal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    background: rgba(0, 0, 0, 0.82) !important;
    backdrop-filter: blur(8px);
    z-index: 40;
}

#menusModal.hidden {
    display: none !important;
}

#menusModalContent {
    display: flex;
    flex-direction: column;
    background-color: var(--da-surface) !important;
    border: 1px solid var(--da-border) !important;
    box-shadow: 0 40px 80px -20px var(--da-shadow) !important;
    color: var(--da-text) !important;
    min-width: 320px;
    max-width: 95vw;
}

#menusModalHeader {
    background-color: var(--da-card) !important;
    border-color: var(--da-border) !important;
}

#menusModalHeader h2 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 700;
    color: var(--da-text) !important;
    font-size: 1.15rem;
}

#resetFiltersButton {
    color: var(--da-muted) !important;
}

#resetFiltersButton:hover {
    color: var(--da-accent) !important;
}

#closeMenusModalButton {
    color: var(--da-muted) !important;
}

#closeMenusModalButton:hover {
    color: #ef4444 !important;
}

/* Modifier menu card grid */
#menucontainer>div {
    background-color: var(--da-card) !important;
    border-color: var(--da-border) !important;
}

#menucontainer>div:hover {
    border-color: var(--da-accent) !important;
    background-color: var(--da-card-alt) !important;
}

#menucontainer label {
    color: var(--da-accent) !important;
}

/* Category card grid */
.modal-grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1.5rem;
    padding: 1rem;
    overflow-y: auto;
    align-content: start;
}

.category-card {
    background-color: var(--da-card) !important;
    border: 1px solid var(--da-border) !important;
    border-radius: 0.75rem;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    max-height: 400px;
}

.category-card h3 {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--da-accent) !important;
    letter-spacing: 0.08em;
    margin-bottom: 0.75rem;
    border-bottom: 1px solid var(--da-border) !important;
    padding-bottom: 0.5rem;
    font-family: 'Source Serif 4', serif;
}

.checkbox-list {
    overflow-y: auto;
    flex: 1;
}

/* Resize handle */
#resizeHandle {
    position: absolute;
    bottom: 5px;
    right: 5px;
    width: 15px;
    height: 15px;
    cursor: nwse-resize;
    background-image:
        linear-gradient(135deg, var(--da-border) 25%, transparent 25%),
        linear-gradient(225deg, var(--da-border) 25%, transparent 25%),
        linear-gradient(315deg, var(--da-border) 25%, transparent 25%),
        linear-gradient(45deg, var(--da-border) 25%, transparent 25%);
    background-size: 8px 8px;
    z-index: 60;
}


/* ============================================================
   PRESET / PROMPT LIBRARY MODALS + HELP MODAL
   ============================================================ */
#presetModal,
#promptModal,
#helpModal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    background: rgba(0, 0, 0, 0.82) !important;
    backdrop-filter: blur(8px);
    z-index: 50;
}

#presetModal.hidden,
#promptModal.hidden,
#helpModal.hidden {
    display: none !important;
}

#presetModal>div,
#promptModal>div {
    background-color: var(--da-surface) !important;
    border: 1px solid var(--da-border) !important;
}

#presetModal .border-b,
#promptModal .border-b,
#presetModal .border-t,
#promptModal .border-t {
    border-color: var(--da-border) !important;
}

#presetModal .bg-gray-50,
#promptModal .bg-gray-50,
#presetModal .bg-white,
#promptModal .bg-white {
    background-color: var(--da-card) !important;
}

#presetModal h2,
#promptModal h2 {
    font-family: 'Playfair Display', Georgia, serif !important;
    color: var(--da-text) !important;
}

#closePresetModal,
#closePromptModal {
    color: var(--da-muted) !important;
}

#closePresetModal:hover,
#closePromptModal:hover {
    color: #ef4444 !important;
}

#presetSearch {
    background-color: var(--da-input) !important;
    color: var(--da-text) !important;
}

#presetSort {
    background-color: var(--da-input) !important;
    color: var(--da-text) !important;
}

#presetListContainer,
#promptListContainer {
    background-color: var(--da-surface) !important;
}

#exportPromptsCSVBtn {
    color: var(--da-text-dim) !important;
    transition: color 0.15s !important;
}

#exportPromptsCSVBtn:hover {
    color: var(--da-accent) !important;
    text-decoration: none !important;
}

#clearPromptHistoryBtn {
    color: var(--da-text-dim) !important;
    transition: color 0.15s !important;
}

#clearPromptHistoryBtn:hover {
    color: #ef4444 !important;
    text-decoration: none !important;
}


/* ============================================================
   CONFIRMATION MODAL
   ============================================================ */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.82) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal-content {
    background-color: var(--da-surface) !important;
    border: 1px solid var(--da-border) !important;
    color: var(--da-text) !important;
    padding: 12px;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.4);
    width: 90%;
    max-width: 400px;
    text-align: center;
}

.modal-message {
    color: var(--da-text) !important;
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.modal-buttons {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
}


/* ============================================================
   MATERIAL ICONS
   ============================================================ */
.material-icons {
    font-family: 'Material Icons';
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
}


/* ============================================================
   SCROLLBARS — subtle dark
   ============================================================ */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: var(--da-bg);
}

::-webkit-scrollbar-thumb {
    background: var(--da-border);
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--da-accent);
}

* {
    scrollbar-width: thin;
    scrollbar-color: var(--da-border) var(--da-bg);
}


/* ============================================================
   MODIFIER ARCHITECT — sticky header (modifier-architect.html)
   ============================================================ */
.architect-header {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: var(--da-card);
    border-bottom: 1px solid var(--da-border);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
}