/* Global Styles */
body {
    background-color: #000000;
    color: #FFFFFF;
    font-family: 'Inter', sans-serif;
    margin: 0;
}

/* Typography */
h1, h2, h3 {
    color: #FFFFFF;
    font-weight: 700;
}

p {
    color: #CCCCCC;
    line-height: 1.6;
}

/* Strong tag styling */
p strong {
    color: #BA65FC;
    font-weight: 700;
}

/* --- Layout Utilities --- */

/* Dark Layout (for full pages) */
.dark-layout {
    background-color: #000000;
    color: #FFFFFF;
    width: 100%;
    height: 100%;
}

/* Header Layout */
.header-layout {
    padding-left: 50px !important;
    padding-right: 50px !important;
}

/* Page Title */
.page-title {
    color: #FFFFFF;
    font-size: 2.5rem;
    margin-bottom: 2rem;
    text-align: center;
}

/* Form Container */
.form-container {
    max-width: 400px;
    width: 100%;
    padding: var(--lumo-space-m);
}

.form-container.wide {
    max-width: 600px;
}

/* --- Global Component Styling --- */

/* Buttons - Applies to ALL buttons by default */
vaadin-button {
    background-color: #FFFFFF;
    color: #000000;
    font-weight: 700;
    font-size: 1.1rem;
    padding: 0 2rem;
    height: 3.5rem;
    border-radius: 5px;
    cursor: pointer;
    margin-top: 1.5rem;
    /* Ensure these styles override any default theme styles */
    --lumo-primary-color: #FFFFFF;
    --lumo-primary-text-color: #000000;
    --lumo-primary-contrast-color: #000000;
}

/* Specific override for the primary variant to ensure it matches our style */
vaadin-button[theme~="primary"] {
    background-color: #FFFFFF;
    color: #000000;
}

/* Big Card Button (for Identification Page) */
.big-card-button {
    min-width: 200px; /* Use min-width instead of fixed width */
    width: auto;      /* Allow it to grow */
    height: 150px;
    font-size: 1.5rem;
    white-space: normal; /* Allow text to wrap */
    text-align: center;
    padding: 1rem; /* Add padding for wrapped text */
}

/* Input Fields (Text, Email, Password, DatePicker, Select, TimePicker, IntegerField) */
vaadin-text-field,
vaadin-email-field,
vaadin-password-field,
vaadin-date-picker,
vaadin-select,
vaadin-time-picker,
vaadin-integer-field {
    width: 100%;
    
    /* Default State */
    --vaadin-input-field-background: #FFFFFF;
    --vaadin-input-field-value-color: #000000;
    --vaadin-input-field-label-color: #FFFFFF;
    
    /* Hover State - Force same as default */
    --lumo-contrast-10pct: transparent;
    --lumo-contrast-20pct: transparent;
    --lumo-contrast-30pct: transparent;
    --lumo-contrast-50pct: transparent;
    
    background-color: transparent; 
}

vaadin-text-field::part(input-field),
vaadin-email-field::part(input-field),
vaadin-password-field::part(input-field),
vaadin-date-picker::part(input-field),
vaadin-select::part(input-field),
vaadin-time-picker::part(input-field),
vaadin-integer-field::part(input-field) {
    background-color: #FFFFFF !important;
    color: #000000 !important;
}

vaadin-text-field::part(value),
vaadin-email-field::part(value),
vaadin-password-field::part(value),
vaadin-select::part(value),
vaadin-time-picker::part(value),
vaadin-integer-field::part(value) {
    color: #000000 !important;
    -webkit-text-fill-color: #000000 !important;
}

/* Force label color to white in all states */
vaadin-text-field::part(label),
vaadin-email-field::part(label),
vaadin-password-field::part(label),
vaadin-date-picker::part(label),
vaadin-select::part(label),
vaadin-time-picker::part(label),
vaadin-integer-field::part(label) {
    color: #FFFFFF !important;
}

/* Checkboxes */
vaadin-checkbox {
    color: #FFFFFF;
    --vaadin-checkbox-label-color: #FFFFFF;
    --vaadin-checkbox-background: #FFFFFF;
    --vaadin-checkbox-checkmark-color: #000000;
}

vaadin-checkbox::part(label) {
    color: #FFFFFF !important;
}

/* Force the checkbox square to be white */
vaadin-checkbox::part(checkbox) {
    background-color: #FFFFFF !important;
    border-color: #FFFFFF !important;
}

/* When checked, keep background white and show black checkmark */
vaadin-checkbox[checked]::part(checkbox) {
    background-color: #FFFFFF !important;
    color: #000000 !important; /* This controls the checkmark color */
}

/* Notifications */
vaadin-notification-card {
    /* We don't style the host directly to avoid the "bar" effect */
    --vaadin-notification-background: #BA65FC;
}

/* Target the overlay part which is the actual card */
vaadin-notification-card::part(overlay) {
    background-color: #BA65FC !important;
    color: #000000 !important;
    font-weight: 600;
}

/* --- Home Page Specifics --- */

/* Hero Section */
.hero-title {
    font-size: 3rem; /* Default for mobile */
    line-height: 1.1;
    text-align: left;
    color: #FFFFFF;
    font-weight: 800;
}

.hero-subtitle {
    font-size: 1.25rem;
    color: #CCCCCC;
    text-align: left;
    margin-top: 1rem;
}

/* Section Titles */
.section-title {
    font-size: 2rem; /* Default for mobile */
    color: #FFFFFF;
    font-weight: 700;
    text-align: left;
}

/* Responsive Breakpoints */
@media (min-width: 768px) {
    .hero-title {
        font-size: 6rem; /* Desktop size */
    }
    
    .section-title {
        font-size: 3rem; /* Desktop size */
    }
}

/* Divider */
.custom-divider {
    width: 100%;
    max-width: 1000px;
    border: 0;
    border-top: 1px solid #333;
    margin: 8rem auto;
}

/* Report Card Style */
.report-card {
    background-color: #FFFFFF;
    color: #000000;
    border-radius: 8px;
    padding: 1.5rem;
    margin-bottom: 1rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    width: 100%;
    max-width: 600px; /* Limit width on large screens */
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.report-card h4 {
    color: #000000; /* Override global h4 color */
    margin: 0;
    font-size: 1.2rem;
}

.report-card .meta-info {
    color: #666666;
    font-size: 0.9rem;
}

.report-card .status-badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
}

.report-card .status-badge.preparing {
    background-color: #f39c12;
    color: #ffffff;
}

.report-card .status-badge.finished {
    background-color: #27ae60;
    color: #ffffff;
}

.report-card .status-badge.error {
    background-color: #c0392b;
    color: #ffffff;
}
