/**
 * Schlaustart Login/Register Plugin Styles - REDESIGNED
 */

:root {
    --schlaustart-primary-color: #00A99D;
    --schlaustart-secondary-color: #4A7B9D;
    --schlaustart-accent-red: #E63946;
    --schlaustart-accent-yellow: #FFCA28;
    --schlaustart-light-gray: #f8f9fa;
    --schlaustart-medium-gray: #e9ecef;
    --schlaustart-dark-gray: #6c757d;
    --schlaustart-success-color: #28a745;
    --schlaustart-danger-color: #dc3545;
    --schlaustart-border-radius: 0.4rem; /* Slightly smaller radius */
}

.schlaustart-modern-form-wrapper {
    max-width: 500px;
    /* margin-left: auto;
    margin-right: auto; */
}


.schlaustart-form-container.card {
    padding: 1rem;
    border: none;
    border-radius: var(--schlaustart-border-radius);
    overflow: hidden;
}

.schlaustart-logo {
    max-height: 100px; /* Adjust height */
    max-width: 200px; /* Add max width to avoid overly wide logos */
    width: auto;
    height: auto;
}

.schlaustart-form-title {
    color: #333;
    font-weight: 600;
    font-size: 1.3rem; /* Slightly smaller title */
}

/* Tab Styling */
.nav-tabs .nav-link {
    border: none;
    border-bottom: 3px solid transparent;
    color: var(--schlaustart-dark-gray);
    font-weight: 500;
    padding: 0.8rem 1.2rem; /* Reduced padding */
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
    color: var(--schlaustart-primary-color);
    border-bottom-color: var(--schlaustart-primary-color);
    background-color: transparent;
}

.nav-tabs {
    border-bottom: 1px solid var(--schlaustart-medium-gray);
    margin-bottom: 1rem; /* Reduced from 1.5rem */
}

.tab-content > .tab-pane {
    padding: 0.8rem; /* Reduced from 1.5rem */
}

.form-section-title {
    font-size: 1.3rem; /* Reduced from 1.5rem */
    font-weight: 500;
    color: #444;
}

/* Form Inputs and Labels */
.form-label {
    font-weight: 500;
    margin-bottom: 0.25rem; /* Reduced from 0.3rem */
    color: #555;
    font-size: 0.9rem; /* Slightly smaller label */
}

.form-control,
.form-select {
    border-radius: var(--schlaustart-border-radius);
    padding: 0.6rem 0.9rem; /* Reduced padding */
    border: 1px solid #ced4da;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}
.form-control:focus,
.form-select:focus {
    border-color: var(--schlaustart-primary-color);
    box-shadow: 0 0 0 0.2rem rgba(0, 169, 157, 0.25); /* Reduced shadow size */
}

.position-relative .form-control { padding-right: 2.2rem; }
.password-toggle-icon {
    position: absolute;
    top: 50%;
    right: 0.8rem; /* Reduced from 1rem */
    transform: translateY(-50%);
    cursor: pointer;
    color: var(--schlaustart-dark-gray);
    line-height: 1;
}
.mb-3.position-relative .password-toggle-icon { top: calc(50% + 0.4em); }


/* Buttons */
.btn {
    border-radius: var(--schlaustart-border-radius);
    padding: 0.6rem 1.2rem; /* Reduced padding */
    font-weight: 500;
    transition: all 0.2s ease-in-out;
}
.btn-lg { /* Ensure btn-lg is also slightly smaller if used */
    padding: 0.7rem 1.4rem;
    font-size: 1.1rem;
}

.btn-primary {
    background-color: var(--schlaustart-primary-color);
    border-color: var(--schlaustart-primary-color);
}
.btn-primary:hover {
    background-color: #008F82; /* Darken primary */
    border-color: #008F82;
}

/* Registration Progress Bar */
#registration-progress {
    height: 8px;
    border-radius: var(--schlaustart-border-radius);
    background-color: var(--schlaustart-medium-gray);
}
#registration-progress .progress-bar {
    background-color: var(--schlaustart-primary-color);
    transition: width .3s ease;
}

/* Multi-step form specific styling */
/* Renamed from .schlaustart-step to .registration-step */
.registration-step {
    padding-bottom: 0.8rem; /* Reduced from 1rem */
}
.step-description {
    color: var(--schlaustart-dark-gray);
    font-size: 0.9rem; /* Reduced from 0.95rem */
    margin-bottom: 1rem !important; /* Reduced from 1.5rem */
}

/* THE CRITICAL FIX IS HERE: */
/* Changed from .schlaustart-step.d-none to .registration-step.d-none */
.registration-step.d-none {
    display: none; /* REMOVED !important */
    visibility: hidden;
}

/* Add this rule to explicitly show the active step */
.registration-step.active {
    display: block !important; /* Ensure this overrides everything for the active step */
    visibility: visible !important;
}

/* Avatar Selection Enhanced */
.avatar-selection-container .form-check-input[name="avatar"] {
    position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;
}
.avatar-selection-container .form-check-label {
    display: flex; flex-direction: column; align-items: center; cursor: pointer;
    padding: 0.4rem; border: 2px solid transparent; /* Reduced padding */
    border-radius: var(--schlaustart-border-radius);
    transition: all 0.2s ease-in-out;
}
.avatar-selection-container .custom-avatar-size {
    width: 80px; height: 80px; /* Reduced from 100px */
    object-fit: cover; border-radius: 50%;
    margin-bottom: 0.4rem; /* Reduced from 0.5rem */
    border: 3px solid var(--schlaustart-medium-gray);
    transition: border-color 0.2s ease-in-out;
}
.avatar-selection-container .form-check-input[name="avatar"]:checked + .form-check-label .custom-avatar-size {
    border-color: var(--schlaustart-primary-color);
    box-shadow: 0 0 8px rgba(0, 169, 157, 0.4); /* Reduced shadow */
}
.avatar-selection-container .form-check-input[name="avatar"]:checked + .form-check-label span {
    color: var(--schlaustart-primary-color); font-weight: bold;
}
.avatar-selection-container .form-check-label:hover .custom-avatar-size {
    border-color: var(--schlaustart-secondary-color);
}

/* Role Selection Buttons */
.role-selector-btn {
    font-size: 1rem; /* Reduced from 1.1rem */
    padding: 0.7rem 1.2rem; /* Reduced padding */
    border-width: 2px; /* Make border slightly thicker for emphasis */
}
.role-selector-btn.active {
    /* Use the primary color from the existing root variables */
    background-color: var(--schlaustart-primary-color);
    color: white;
    border-color: var(--schlaustart-primary-color);
}
.role-selector-btn:hover {
    /* Darken primary color slightly on hover, or use secondary color */
    background-color: #008F82; /* A slightly darker shade of --schlaustart-primary-color */
    border-color: #008F82;
    color: white; /* Ensure text remains white on hover when active */
}
/* Ensure outline-primary uses the primary color for non-active state */
.btn-outline-primary {
    color: var(--schlaustart-primary-color);
    border-color: var(--schlaustart-primary-color);
}
.btn-outline-primary:hover {
    background-color: var(--schlaustart-primary-color);
    color: white;
}


/* School Search Results */
#school-search-results {
    max-height: 180px; /* Reduced from 200px */
    overflow-y: auto; border: 1px solid var(--schlaustart-medium-gray);
    border-radius: var(--schlaustart-border-radius);
}
#school-search-results .list-group-item { cursor: pointer; padding: 0.6rem 1rem; } /* Reduced padding */
#school-search-results .list-group-item:hover { background-color: var(--schlaustart-light-gray); }

/* Alert Messages */
#schlaustart-messages-container {
    min-height: 40px; /* Reduced from 60px */
}
#schlaustart-messages {
    text-align: center; font-weight: 500;
    padding: 0.6rem 1rem; /* Reduced padding */
    border-radius: var(--schlaustart-border-radius);
    font-size: 0.9rem; /* Smaller font for messages */
}
/* ... (alert-success, alert-danger styles remain the same as your original file) ... */

/* Validation Feedback */
.invalid-feedback {
    display: none; color: var(--schlaustart-danger-color);
    font-size: 0.8em; /* Reduced from 0.875em */
    margin-top: .2rem; /* Reduced from .25rem */
}
/* ... (is-invalid styles remain the same as your original file) ... */

/* Terms and Conditions Checkbox Area - Enhanced */
.consent-checkbox-area {
    background-color: var(--schlaustart-light-gray);
    border: 1px solid var(--schlaustart-medium-gray);
    padding: 1.2rem; /* Increased padding */
    border-radius: var(--schlaustart-border-radius);
    display: flex;
    align-items: flex-start; /* Align checkbox to top of text */
}

.consent-checkbox-area .form-check-input {
    margin-top: 0.4rem; /* Adjust alignment if needed */
    flex-shrink: 0; /* Prevent checkbox from shrinking */
    width: 1.25em; /* Make checkbox slightly larger */
    height: 1.25em;
    border-color: var(--schlaustart-dark-gray); /* Default border color */
}

.consent-checkbox-area .form-check-input:checked {
    background-color: var(--schlaustart-primary-color);
    border-color: var(--schlaustart-primary-color);
}

.consent-checkbox-area .form-check-label {
    font-size: 0.95rem; /* Slightly larger font size */
    color: #333;
    line-height: 1.4;
}

.consent-checkbox-area .form-check-label a {
    color: var(--schlaustart-primary-color); /* Link color matches primary */
    font-weight: 600;
    text-decoration: none;
}
.consent-checkbox-area .form-check-label a:hover {
    text-decoration: underline;
    color: #008F82; /* Darker primary on hover */
}

/* Specific styling for the 'complete registration' button */
#register-submit-btn {
    background-color: var(--schlaustart-success-color);
    border-color: var(--schlaustart-success-color);
    font-size: 1.15rem; /* Slightly larger text for final button */
    padding: 0.8rem 1.5rem; /* More generous padding */
}
#register-submit-btn:hover {
    background-color: #218838; /* Darken success color */
    border-color: #1e7e34;
}

#reg-step-terms-finalize .form-check-label { font-size: 0.9rem; } /* Reduced font size */