/* Styles extracted from register.php */
.register-container { max-width: 600px; margin: 2rem auto; padding: 2rem; background: white; border-radius: 15px; box-shadow: 0 10px 30px rgba(0,0,0,0.1); }
.register-header { text-align: center; margin-bottom: 2rem; }
.register-header h1 { color: #2563eb; margin-bottom: 0.5rem; font-size: 2rem; }
.register-header p { color: #666; font-size: 1.1rem; }
.register-form { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.form-group { display:flex; flex-direction: column; }
.form-group.full-width { grid-column: 1 / -1; }
.form-group label { font-weight:600; color:#374151; margin-bottom:0.5rem; font-size:1rem; }
.form-group input, .form-group select { padding: 0.875rem 1rem; border: 2px solid #e5e7eb; border-radius: 8px; font-size:1rem; transition:all 0.3s ease; }
.form-group input:focus, .form-group select:focus { outline: none; border-color: #2563eb; box-shadow: 0 0 0 3px rgba(37,99,235,0.1); }
.register-btn { background: linear-gradient(135deg, #059669 0%, #10b981 100%); color:white; border:none; padding:1rem 2rem; border-radius:8px; font-size:1.1rem; font-weight:600; cursor:pointer; transition:all 0.3s ease; margin-top:1rem; grid-column:1 / -1; }
.register-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 20px rgba(5,150,105,0.3); }
.register-links { text-align:center; margin-top:2rem; padding-top:2rem; border-top:1px solid #e5e7eb; grid-column:1 / -1; }
.register-links a { color: #2563eb; text-decoration:none; font-weight:500; margin:0 1rem; transition:color 0.3s ease; }
.register-links a:hover { color:#1d4ed8; }
.benefits { background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%); border:1px solid #0ea5e9; border-radius:8px; padding:1.5rem; margin-bottom:2rem; text-align:center; }
.benefits h3 { color:#0c4a6e; margin-bottom:1rem; }
.benefits ul { list-style:none; padding:0; display:grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap:1rem; margin:0; }
.benefits li { color:#374151; font-weight:500; }
.benefits li:before { content: "✅ "; color:#059669; }
.register-error { background:#fef2f2; color:#dc2626; padding:1rem; border-radius:8px; margin-bottom:1rem; border-left:4px solid #dc2626; grid-column:1 / -1; }

/* Styles pour la sélection du type de compte */
.account-type-selection { margin: 2rem 0; }
.account-type-buttons { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.5rem; margin-top: 2rem; }
.account-type-btn { background: white; border: 3px solid #e5e7eb; border-radius: 12px; padding: 2rem; cursor: pointer; transition: all 0.3s ease; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 0.75rem; }
.account-type-btn:hover { transform: translateY(-4px); box-shadow: 0 10px 25px rgba(0,0,0,0.1); border-color: #2563eb; }
.account-type-btn .btn-icon { font-size: 3rem; margin-bottom: 0.5rem; }
.account-type-btn .btn-title { font-size: 1.5rem; font-weight: 700; color: #1e293b; }
.account-type-btn .btn-desc { font-size: 0.95rem; color: #64748b; }
.account-type-btn.student-btn:hover { border-color: #3b82f6; background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%); }
.account-type-btn.parent-btn:hover { border-color: #10b981; background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%); }
.form-wrapper { animation: fadeIn 0.3s ease-in; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.link-button { background: none; border: none; color: #2563eb; text-decoration: none; font-weight: 500; cursor: pointer; padding: 0.5rem 0; transition: color 0.3s ease; font-size: 1rem; }
.link-button:hover { color: #1d4ed8; text-decoration: underline; }

/* Styles pour les messages d'erreur et d'aide */
.form-error {
    display: block;
    color: #dc2626;
    font-size: 0.875rem;
    margin-top: 0.25rem;
    min-height: 1.25rem;
}

.form-help {
    display: block;
    color: #6b7280;
    font-size: 0.75rem;
    margin-top: 0.25rem;
    font-style: italic;
}

.required-asterisk {
    color: #dc2626;
    font-weight: bold;
    margin-left: 2px;
}

.form-group input.error,
.form-group input[aria-invalid="true"] {
    border-color: #dc2626 !important;
    background-color: #fef2f2;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1) !important;
}

.form-group input.error:focus,
.form-group input[aria-invalid="true"]:focus {
    outline: 2px solid #dc2626;
    outline-offset: 2px;
    border-color: #dc2626 !important;
}
