/* ================================
   Global Overrides & Utilities
   ================================ */

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-sans);
    color: var(--color-text);
    background: var(--color-bg);
    font-weight: 400;
    letter-spacing: -0.01em;
}

/* ===== Typography ===== */
h1, h2, h3, .font-display {
    font-family: var(--font-sans);
    letter-spacing: -0.025em;
    font-weight: 600;
    color: var(--color-text);
}

/* ===== Code Blocks ===== */
pre code {
    font-family: var(--font-mono);
    font-size: 0.875rem;
    line-height: 1.6;
}

/* ===== Dropzone Customization ===== */
.dropzone {
    min-height: 200px;
    background: transparent;
}

.dropzone .dz-preview {
    margin: var(--space-4);
    background: var(--color-bg-subtle) !important;
    border: 1px solid var(--color-border);
    padding: var(--space-2);
}

.dropzone .dz-preview .dz-progress {
    height: 3px;
    overflow: hidden;
    background: var(--color-border-subtle) !important;
}

.dropzone .dz-preview .dz-progress .dz-upload {
    background: var(--color-primary) !important;
}

.dropzone .dz-preview .dz-error-message {
    background: #ef4444 !important;
    color: #f8fafc;
}

/* .dropzone .dz-preview .dz-success-mark,
.dropzone .dz-preview .dz-error-mark {
    background: var(--color-surface) !important;
} */

.dropzone .dz-preview .dz-details {
    color: var(--color-text) !important;
    background: transparent !important;
}

.dropzone .dz-preview .dz-filename,
.dropzone .dz-preview .dz-size {
    color: var(--color-text) !important;
}

/* .dropzone .dz-preview .dz-filename span,
.dropzone .dz-preview .dz-size span {
    background: var(--color-bg-subtle) !important;
    border: 1px solid var(--color-border);
    color: var(--color-text) !important;
    padding: var(--space-1) var(--space-2);
} */

.dropzone .dz-preview .dz-remove {
    color: #ef4444 !important;
    text-decoration: none;
    font-size: 0.75rem;
    background: rgba(239, 68, 68, 0.08);
    padding: var(--space-1) var(--space-3);
    border: 1px solid rgba(239, 68, 68, 0.2);
    transition: all var(--transition-base);
}

.dropzone .dz-preview .dz-remove:hover {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.4);
}

/* ===== Scrollbar ===== */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

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

::-webkit-scrollbar-thumb {
    background: var(--color-border);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--color-text-secondary);
}

/* ===== Details/Summary ===== */
details {
    cursor: pointer;
}

details summary {
    list-style: none;
}

details summary::-webkit-details-marker {
    display: none;
}

details summary::after {
    content: '+';
    float: right;
    font-weight: 600;
    font-size: 1.5rem;
    color: var(--color-primary);
    transition: transform var(--transition-base);
}

details[open] summary::after {
    transform: rotate(45deg);
}

/* ===== Accessibility ===== */
*:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* ===== Media ===== */
video, img {
    width: 100%;
    height: 100%;
}

/* ===== Print ===== */
@media print {
    nav, footer, #notification-container {
        display: none;
    }
}

/* ===== Responsive Typography ===== */
@media (max-width: 640px) {
    .text-4xl {
        font-size: 2rem;
        line-height: 2.5rem;
    }
    
    .text-5xl {
        font-size: 2.5rem;
        line-height: 3rem;
    }
}
