@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--font:"Inter", system-ui, -apple-system, sans-serif;--primary:#1b3a5c;--primary-hover:#14304d;--primary-light:#e8f0f9;--blue:#2563eb;--blue-light:#eff6ff;--bg:#f7f9fc;--bg-alt:#f0f4f8;--white:#fff;--card-bg:#fff;--border:#dde4ee;--border-md:#c8d3e3;--text:#1a2a3a;--text-muted:#60748a;--text-light:#94a3b8;--success:#16a34a;--success-bg:#f0fff4;--error:#dc2626;--error-bg:#fff5f5;--warning:#d97706;--warning-bg:#fffbeb;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--accent:var(--blue);--accent-dark:var(--primary);--black:#1a2a3a}*{box-sizing:border-box}body,html,#root{min-height:100vh;font-family:var(--font);background:var(--bg);color:var(--text);margin:0;line-height:1.6}button{cursor:pointer;font-family:var(--font)}a{color:inherit}.navbar{z-index:100;background:var(--white);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:68px;padding:0 40px;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #0000000f}.navbar-logo{width:auto;height:40px;display:block}.navbar-hamburger{border:1.5px solid var(--border-md);border-radius:var(--radius);cursor:pointer;background:0 0;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:6px 8px;display:none}.navbar-hamburger span{background:var(--primary);border-radius:2px;height:2px;display:block}.navbar-mobile-menu{background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--shadow);z-index:99;flex-direction:column;display:flex;position:absolute;top:100%;left:0;right:0}.navbar-mobile-link{color:var(--text);border-bottom:1px solid var(--border);padding:14px 20px;font-size:15px;font-weight:600;text-decoration:none;transition:background .12s}.navbar-mobile-link.active{color:var(--primary);background:var(--primary-light);font-weight:700}.navbar-mobile-link:hover{background:var(--bg)}.navbar-links{align-items:center;gap:4px;display:flex}.navbar-link{border-radius:var(--radius);color:var(--text-muted);border:none;padding:7px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s}.navbar-link:hover{background:var(--bg-alt);color:var(--primary)}.navbar-link.active{background:var(--primary-light);color:var(--primary);font-weight:700}.page-container{max-width:1100px;margin:0 auto;padding:48px 24px 80px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:40px;display:flex}h1{color:var(--primary);margin:0;font-size:2.2rem;font-weight:800;line-height:1.2}h2{color:var(--text);margin:0 0 24px;font-size:1.4rem;font-weight:700}h3{color:var(--text);margin:0 0 16px;font-size:1.05rem;font-weight:700}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:28px 32px}.question-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;padding:20px 24px}.question-card.correct{border-left:4px solid var(--success)}.question-card.incorrect{border-left:4px solid var(--error)}.question-card.partiel{border-left:4px solid var(--warning)}.primary,.secondary,.danger,.button-link,button[type=submit]{font-family:var(--font);border-radius:var(--radius);cursor:pointer;letter-spacing:0;text-transform:none;border:none;align-items:center;gap:8px;padding:10px 22px;font-size:14px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.primary,button[type=submit]{background:var(--primary);color:var(--white);box-shadow:0 2px 6px #1b3a5c40}.primary:hover,button[type=submit]:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 10px #1b3a5c52}.primary:active,button[type=submit]:active{transform:translateY(0)}.secondary{background:var(--white);color:var(--primary);border:1.5px solid var(--border-md);box-shadow:var(--shadow-sm)}.secondary:hover{background:var(--primary-light);border-color:var(--primary);transform:translateY(-1px)}.danger{background:var(--white);color:var(--error);border:1.5px solid #fca5a5}.danger:hover{background:var(--error-bg);border-color:var(--error)}.button-link{background:var(--white);color:var(--primary);border:1.5px solid var(--border-md);box-shadow:var(--shadow-sm);font-size:13px}.form-card{flex-direction:column;gap:18px;display:flex}.password-field{position:relative}.password-field input{box-sizing:border-box;padding-right:44px}.password-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;line-height:1;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle:hover{color:var(--text)}.form-card>label{color:var(--text);flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}input[type=text],input[type=email],input[type=password],textarea,select{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--font);background:var(--white);color:var(--text);text-transform:none;letter-spacing:normal;outline:none;padding:10px 14px;font-size:15px;font-weight:400;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1b3a5c1a}textarea{resize:vertical;min-height:110px}select{cursor:pointer}.form-buttons{flex-wrap:wrap;gap:12px;margin-top:8px;display:flex}.choice-item{border-radius:var(--radius);background:var(--white);border:1.5px solid var(--border);cursor:pointer;align-items:center;gap:12px;margin-bottom:8px;padding:12px 16px;font-size:15px;font-weight:500;transition:all .12s;display:flex}.choice-item:hover{border-color:var(--primary);background:var(--primary-light)}:is(.choice-item:has(input[type=radio]:checked),.choice-item:has(input[type=checkbox]:checked)){background:var(--primary-light);border-color:var(--primary);font-weight:600}.choice-item input[type=radio],.choice-item input[type=checkbox]{width:17px;height:17px;accent-color:var(--primary);box-shadow:none;cursor:pointer;border:none;flex-shrink:0}.choice-admin{align-items:center;gap:10px;margin-bottom:10px;display:flex}.choice-admin input[type=text]{flex:1;margin:0}.checkbox-inline{white-space:nowrap;cursor:pointer;flex-shrink:0;align-items:center;gap:8px;font-size:12px;font-weight:600;display:inline-flex}.checkbox-inline input[type=checkbox]{width:16px;height:16px;box-shadow:none;accent-color:var(--primary);flex-shrink:0}.add-choice{background:var(--white);border:1.5px dashed var(--border-md);color:var(--text-muted);font-size:13px;font-family:var(--font);border-radius:var(--radius);cursor:pointer;margin-top:6px;padding:8px 16px;font-weight:500;transition:all .15s}.add-choice:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.remove-choice{color:var(--error);font-size:12px;font-family:var(--font);cursor:pointer;background:0 0;border:1.5px solid #fca5a5;border-radius:6px;flex-shrink:0;padding:5px 10px;font-weight:600;transition:all .15s}.remove-choice:hover{background:var(--error-bg)}.error{background:var(--error-bg);color:var(--error);border-radius:var(--radius);border:1px solid #fca5a5;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:600}.success{background:var(--success-bg);color:var(--success);border-radius:var(--radius);border:1px solid #86efac;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:600}.forgot-success{background:var(--success-bg);color:var(--success);border-radius:var(--radius);text-align:center;border:1px solid #86efac;padding:16px;font-size:14px;font-weight:600}.question-title{color:var(--text);margin:0 0 16px;font-size:1.05rem;font-weight:700}.status-line{text-transform:uppercase;letter-spacing:.06em;margin:8px 0;font-size:13px;font-weight:700}.detail-block{color:var(--text-muted);flex-direction:column;gap:6px;margin-top:14px;font-size:14px;display:flex}.question-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.result-summary{background:var(--primary);border-radius:var(--radius-lg);color:var(--white);box-shadow:var(--shadow);align-items:center;gap:24px;margin-bottom:28px;padding:24px 28px;font-size:1rem;font-weight:600;display:flex}.result-score{letter-spacing:-.03em;color:var(--white);font-size:3rem;font-weight:800}.result-cat-scores{flex-wrap:wrap;gap:16px;margin-bottom:28px;display:flex}.result-cat-score-item{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow-sm);flex-direction:column;flex:1;gap:4px;padding:16px 20px;display:flex}.result-cat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:11px;font-weight:700}.result-cat-value{color:var(--primary);font-size:1.7rem;font-weight:800}.home-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;display:grid}.home-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--text);flex-direction:column;gap:6px;padding:28px;font-size:1rem;font-weight:700;text-decoration:none;transition:all .15s;display:flex}.home-card:hover{border-color:var(--primary);box-shadow:var(--shadow);color:var(--primary);transform:translateY(-2px)}.home-card--admin{background:#f0f5ff;border-color:#c7d7f5}.home-card--admin:hover{border-color:var(--primary)}.home-card-icon{margin-bottom:4px;font-size:2rem}.home-card-desc{color:var(--text-muted);font-size:13px;font-weight:400}.home-card:hover .home-card-desc{color:var(--text-muted)}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-box{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:440px;padding:44px}.login-logo{width:160px;margin:0 auto 28px;display:block}.login-box h2{text-align:center;color:var(--primary);margin-bottom:24px}.login-tagline{text-align:center;color:var(--text-muted);margin:-8px 0 20px;font-size:13px;font-weight:500;line-height:1.5}.login-tagline a{color:var(--primary);font-weight:700;text-decoration:none}.forgot-link{color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);text-align:center;background:0 0;border:none;width:100%;margin-top:4px;padding:0;transition:color .15s;display:block}.forgot-link:hover{color:var(--primary)}.progress-text{color:var(--text-muted);margin-bottom:8px;font-size:13px;font-weight:600}.progress-bar-wrap{background:var(--bg-alt);border:1px solid var(--border);border-radius:999px;height:8px;margin-bottom:32px;overflow:hidden}.progress-bar-fill{background:var(--primary);border-radius:999px;height:100%;transition:width .4s}.category-badge{text-transform:uppercase;letter-spacing:.08em;background:var(--primary-light);color:var(--primary);border-radius:99px;margin-bottom:14px;padding:3px 12px;font-size:11px;font-weight:700;display:inline-block}.preview-card{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);margin-top:24px;padding:20px}.choices-preview{flex-direction:column;gap:8px;display:flex}.choice-preview{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);align-items:center;gap:10px;padding:10px 14px;font-size:14px;display:flex}.choice-preview.correct{background:var(--primary-light);border-color:var(--primary)}.choice-id{min-width:22px;color:var(--primary);font-weight:800}.correct-indicator{color:var(--primary);margin-left:auto;font-weight:700}.history-list,.questions-list,.results-list{flex-direction:column;gap:16px;display:flex}.history-chart-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:20px 24px 12px}.history-chart-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.history-chart-title{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-size:11px;font-weight:700}.history-filter-btns{flex-wrap:wrap;gap:6px;display:flex}.history-filter-btn{font-family:var(--font);border:1.5px solid var(--border);background:var(--white);color:var(--text-muted);cursor:pointer;border-radius:99px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .12s}.history-filter-btn:hover{border-color:var(--primary);color:var(--primary)}.history-filter-btn.active{background:var(--primary);border-color:var(--primary);color:var(--white);font-weight:700}.qcm-section{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden}.qcm-section-title{background:var(--primary);color:var(--white);text-transform:uppercase;letter-spacing:.12em;padding:8px 16px;font-size:11px;font-weight:700}.qcm-question{border-bottom:1px solid var(--bg-alt);padding:12px 16px}.qcm-question:last-child{border-bottom:none}.qcm-enonce{color:var(--text);margin:0 0 7px;font-size:14px;font-weight:600;line-height:1.5}.qcm-choices{flex-direction:column;gap:2px;display:flex}.qcm-choice{color:var(--text);cursor:pointer;align-items:flex-start;gap:7px;padding:2px 0;font-size:13.5px;line-height:1.4;display:flex}.qcm-choice input[type=radio],.qcm-choice input[type=checkbox]{accent-color:var(--primary);width:14px;height:14px;box-shadow:none;cursor:pointer;border:none;flex-shrink:0;margin-top:3px}.qcm-choice:has(input:checked) span{color:var(--primary);font-weight:700}.qcm-result-correct{border-left:3px solid var(--success)}.qcm-result-incorrect{border-left:3px solid var(--error)}.qcm-result-partiel{border-left:3px solid var(--warning)}.qcm-status{text-transform:uppercase;letter-spacing:.08em;margin:3px 0 6px;font-size:11px;font-weight:700}.qcm-status-correct{color:var(--success)}.qcm-status-incorrect{color:var(--error)}.qcm-status-partiel{color:var(--warning)}.qcm-detail{color:var(--text-muted);flex-direction:column;gap:2px;font-size:13px;display:flex}.qcm-commentaire{color:#6b7a8d;margin-top:4px;font-style:italic}.admin-table-cat-row td{background:var(--bg-alt);text-transform:uppercase;letter-spacing:.1em;color:var(--primary);border-top:1px solid var(--border);padding:6px 12px;font-size:11px;font-weight:700}.qf-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden}.qf-section-title{background:var(--primary);color:var(--white);text-transform:uppercase;letter-spacing:.12em;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;font-size:11px;font-weight:700;display:flex}.qf-title-controls{gap:8px;display:flex}.qf-title-controls select{font-family:var(--font);color:var(--white);cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:4px;outline:none;width:auto;padding:4px 8px;font-size:11px;font-weight:600}.qf-body{flex-direction:column;gap:8px;padding:14px 16px;display:flex}.qf-cat-bar{border-bottom:1px solid var(--border);display:flex}.qf-cat-option{color:var(--text-muted);cursor:pointer;border-right:1px solid var(--border);background:var(--bg);text-transform:uppercase;letter-spacing:.06em;flex:1;justify-content:center;align-items:center;gap:7px;padding:7px 12px;font-size:12px;font-weight:500;transition:background .1s;display:flex}.qf-cat-option:last-child{border-right:none}.qf-cat-option input[type=radio]{width:13px;height:13px;accent-color:var(--primary);box-shadow:none;cursor:pointer;border:none;flex-shrink:0}.qf-cat-active{background:var(--white);color:var(--primary);font-weight:700}.qf-enonce{width:100%;font-family:var(--font);color:var(--text);border:1.5px solid var(--border);resize:none;background:var(--white);box-shadow:none;border-radius:4px;outline:none;padding:9px 12px;font-size:14px;font-weight:600;line-height:1.5}.qf-enonce:focus{border-color:var(--primary)}.qf-choices{flex-direction:column;gap:4px;display:flex}.qf-choice{border:1.5px solid var(--border);background:var(--white);cursor:text;border-radius:4px;align-items:center;gap:10px;padding:7px 12px;display:flex}.qf-choice--correct{border-color:var(--primary);background:var(--primary-light)}.qf-choice input[type=radio],.qf-choice input[type=checkbox]{width:14px;min-width:14px;height:14px;accent-color:var(--primary);cursor:pointer;box-shadow:none;background:0 0;border:none;flex-shrink:0;padding:0}.qf-choice input[type=text].qf-choice-text{font-family:var(--font);color:var(--text);border-radius:0;outline:none;flex:1;width:auto;font-size:13.5px;box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.qf-remove{color:#ccc;cursor:pointer;box-shadow:none;background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:11px;line-height:1}.qf-remove:hover{color:var(--error)}.qf-add{font-family:var(--font);color:var(--text-muted);border:1px dashed var(--border-md);cursor:pointer;text-align:left;background:0 0;border-radius:4px;margin-top:2px;padding:4px 10px;font-size:12px;font-weight:500}.qf-add:hover{border-color:var(--primary);color:var(--primary)}.qf-commentaire{width:100%;font-family:var(--font);color:var(--text-muted);border:1.5px solid var(--border);resize:none;background:var(--white);box-shadow:none;border-radius:4px;outline:none;padding:7px 12px;font-size:13px}.qf-commentaire:focus{border-color:var(--primary)}.qf-actions{border-top:1px solid var(--border);background:var(--bg-alt);gap:10px;padding:10px 16px;display:flex}.qf-actions button[type=submit]{background:var(--primary);color:var(--white);box-shadow:none}.qf-actions button[type=submit]:hover{background:var(--primary-hover)}.site-footer{text-align:right;color:var(--text-light);border-top:1px solid var(--border);margin-top:40px;padding:16px 40px;font-size:12px}.site-footer a{color:var(--primary);font-weight:600;text-decoration:none}.site-footer a:hover{text-decoration:underline}.admin-page{max-width:1100px;margin:0 auto;padding:32px 40px 80px}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:28px;display:flex}.admin-header h1{margin:0;font-size:1.6rem}.admin-header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:24px 28px}.admin-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--primary);margin:0 0 18px;font-size:1rem;font-weight:700}.admin-form{flex-direction:column;gap:0;display:flex}.admin-field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.admin-field label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:12px;font-weight:600}.admin-field input,.admin-field select,.admin-field textarea{border:1.5px solid var(--border);font-family:var(--font);background:var(--bg);border-radius:6px;padding:9px 12px;font-size:14px}.admin-field textarea{resize:vertical;min-height:72px}.admin-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.admin-form-actions{flex-wrap:wrap;gap:10px;margin-top:6px;display:flex}.admin-form-actions button[type=submit]{background:var(--primary);color:var(--white);box-shadow:none}.admin-form-actions button[type=submit]:hover{background:var(--primary-hover)}.admin-choice-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.admin-choice-id{background:var(--primary-light);color:var(--primary);border:1px solid var(--border-md);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:800;display:flex}.admin-choice-row input[type=text]{border:1.5px solid var(--border);font-size:14px;font-family:var(--font);background:var(--bg);border-radius:6px;flex:1;padding:7px 10px}.admin-checkbox{color:var(--text-muted);white-space:nowrap;align-items:center;gap:5px;font-size:12px;font-weight:600;display:flex}.admin-checkbox input{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.admin-hint{color:var(--text-muted);text-transform:none;letter-spacing:0;margin-top:4px;font-size:11px}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table thead th{background:var(--primary);color:var(--white);text-transform:uppercase;letter-spacing:.07em;text-align:left;padding:10px 12px;font-size:11px;font-weight:700}.admin-table thead th:first-child{border-radius:8px 0 0}.admin-table thead th:last-child{border-radius:0 8px 0 0}.admin-table tbody tr{border-bottom:1px solid var(--border)}.admin-table tbody tr:hover{background:var(--bg)}.admin-table tbody td{vertical-align:middle;padding:10px 12px}.admin-table-enonce{max-width:380px;font-weight:600}.admin-table-actions{white-space:nowrap;gap:6px;display:flex}.admin-empty{text-align:center;color:var(--text-muted);padding:32px;font-weight:600}.admin-tag{text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--border-md);background:var(--bg-alt);color:var(--text-muted);border-radius:99px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.admin-alert{border-radius:var(--radius);margin-bottom:16px;padding:10px 14px;font-size:13px;font-weight:600}.admin-alert.success{background:var(--success-bg);color:var(--success);border:1px solid #86efac}.admin-alert.error{background:var(--error-bg);color:var(--error);border:1px solid #fca5a5}.admin-btn-primary{background:var(--primary);color:var(--white);border-radius:var(--radius);font-family:var(--font);cursor:pointer;border:none;padding:9px 20px;font-size:13px;font-weight:600;transition:background .15s}.admin-btn-primary:hover{background:var(--primary-hover)}.admin-btn-secondary{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);cursor:pointer;color:var(--text);padding:9px 20px;font-size:13px;font-weight:500}.admin-btn-secondary:hover{background:var(--bg-alt)}@media (width<=720px){h1{font-size:1.7rem}h2{font-size:1.2rem}.navbar{height:60px;padding:0 16px;position:sticky}.navbar-logo{height:34px}.navbar-links-desktop{display:none}.navbar-hamburger{display:flex}.login-box{padding:28px 20px}.login-tagline{font-size:12px}.card{padding:20px}.admin-page{padding:20px 16px 60px}.page-container{padding:24px 16px 60px}.home-grid{grid-template-columns:1fr;gap:14px}.question-actions,.form-buttons{flex-direction:column}.result-summary{flex-direction:column;gap:8px}.result-cat-scores{flex-direction:column}.admin-row{grid-template-columns:1fr}}
