*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}h1,h2,h3,h4,h5,h6{overflow-wrap:break-word;line-height:1.2}p,li{overflow-wrap:break-word}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 1rem}@media(min-width:640px){.container{padding:0 1.5rem}}@media(min-width:1024px){.container{padding:0 2rem}}.session-warning-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-in-out}.session-warning-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0006;max-width:500px;width:90%;padding:2.5rem;text-align:center;animation:slideUp .3s ease-out}.session-warning-icon{font-size:4rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}.session-warning-modal h2{margin:0 0 1rem;color:#111827;font-size:1.75rem}.session-warning-message{color:#f59e0b;font-size:1.25rem;margin:0 0 1rem;font-weight:600}.session-warning-message strong{color:#dc2626;font-size:1.5rem}.session-warning-info{color:#6b7280;font-size:.95rem;margin:0 0 2rem;line-height:1.6}.session-warning-countdown{display:flex;justify-content:center;margin-bottom:2rem}.countdown-circle{position:relative;width:150px;height:150px}.countdown-circle svg{width:100%;height:100%}.countdown-progress{transition:stroke-dashoffset 1s linear}.countdown-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:700;color:#f59e0b}.session-warning-actions{display:flex;flex-direction:column;gap:1rem}.extend-button,.logout-button{padding:1rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.extend-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.extend-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #10b9814d}.logout-button{background:#fff;color:#dc2626;border:2px solid #dc2626}.logout-button:hover{background:#fef2f2}@media(max-width:600px){.session-warning-modal{padding:2rem}.session-warning-icon{font-size:3rem}.session-warning-modal h2{font-size:1.5rem}.session-warning-message{font-size:1.1rem}.countdown-circle{width:120px;height:120px}.countdown-text{font-size:1.5rem}}.consent-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.consent-modal{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.consent-modal-header{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;padding:1.5rem;border-radius:12px 12px 0 0;text-align:center}.consent-modal-header h2{margin:0;font-size:1.5rem;font-weight:700}.consent-modal-body{padding:2rem}.consent-warning-box{background:#fef2f2;border-left:4px solid #dc2626;padding:1.25rem;border-radius:8px;margin-bottom:1.5rem}.consent-warning-title{color:#dc2626;font-size:1.1rem;margin:0 0 .75rem}.consent-warning-box p{margin:0 0 .75rem;line-height:1.6;color:#374151}.consent-warning-box p:last-child{margin-bottom:0}.consent-recommendations{background:#f0f9ff;border-left:4px solid #3b82f6;padding:1.25rem;border-radius:8px;margin-bottom:1.5rem}.consent-recommendations p{margin:0 0 .75rem;color:#1e40af;font-weight:600}.consent-recommendations ul{margin:0;padding-left:1.5rem;color:#374151}.consent-recommendations li{margin-bottom:.5rem;line-height:1.6}.consent-checkbox-container{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:1.25rem}.consent-checkbox-label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.consent-checkbox{margin-top:.25rem;width:20px;height:20px;cursor:pointer;flex-shrink:0}.consent-checkbox-label span{line-height:1.6;color:#374151}.consent-link{color:#3b82f6;text-decoration:underline;font-weight:500}.consent-link:hover{color:#2563eb}.consent-modal-footer{padding:1.5rem 2rem;border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end}.consent-btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none}.consent-btn-cancel{background:#f3f4f6;color:#374151}.consent-btn-cancel:hover:not(:disabled){background:#e5e7eb}.consent-btn-accept{background:#fbbf24;color:#1e293b;box-shadow:0 4px 12px #fbbf244d}.consent-btn-accept:hover:not(:disabled){background:#fcd34d;transform:translateY(-2px);box-shadow:0 6px 16px #fbbf2466}.consent-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:640px){.consent-modal{max-height:95vh}.consent-modal-header h2{font-size:1.25rem}.consent-modal-body{padding:1.5rem}.consent-modal-footer{flex-direction:column;padding:1rem 1.5rem}.consent-btn{width:100%}}.cookie-consent-banner{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#1e293b,#334155);color:#fff;padding:1.5rem;box-shadow:0 -4px 20px #0000004d;z-index:9999;animation:slideUp .5s ease-out;border-top:3px solid #fbbf24}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-consent-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1.5rem}.cookie-icon{font-size:2.5rem;flex-shrink:0}.cookie-text{flex:1}.cookie-text p{margin:0 0 .5rem;line-height:1.6;font-size:.95rem}.cookie-text p:last-child{margin-bottom:0}.cookie-text strong{color:#fbbf24;font-weight:600}.cookie-note{font-size:.85rem;opacity:.9;margin-top:.5rem}.cookie-link{color:#fbbf24;text-decoration:underline;font-weight:500;transition:color .2s}.cookie-link:hover{color:#fcd34d}.cookie-accept-btn{background:#fbbf24;color:#1e293b;border:none;padding:.875rem 2rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;white-space:nowrap;box-shadow:0 4px 12px #fbbf244d}.cookie-accept-btn:hover{background:#fcd34d;transform:translateY(-2px);box-shadow:0 6px 16px #fbbf2466}.cookie-accept-btn:active{transform:translateY(0)}@media(max-width:768px){.cookie-consent-banner{padding:1rem}.cookie-consent-content{flex-direction:column;gap:1rem;text-align:center}.cookie-icon{font-size:2rem}.cookie-text p{font-size:.875rem}.cookie-note{font-size:.8rem}.cookie-accept-btn{width:100%;padding:.75rem 1.5rem}}@media(max-width:480px){.cookie-consent-banner{padding:.875rem}.cookie-icon{font-size:1.75rem}.cookie-text p{font-size:.8125rem}.cookie-accept-btn{font-size:.9375rem;padding:.625rem 1.25rem}}.smart-chatbot{background:linear-gradient(135deg,#f0fdfa,#ecfdf5);border:2px solid #14b8a6;border-radius:16px;padding:1.5rem;margin:2rem 0;box-shadow:0 4px 12px #14b8a61a;max-width:800px}.smart-chatbot-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #14b8a6}.smart-chatbot-header .chatbot-icon{font-size:2rem;animation:bounce 2s infinite}.smart-chatbot-header h3{margin:0;color:#0f766e;font-size:1.25rem;font-weight:700}.smart-chatbot-content{display:flex;flex-direction:column;gap:1rem}.search-label{display:block;margin-bottom:.75rem;color:#0f766e;font-size:1.1rem;font-weight:600}.smart-search-input{width:100%;padding:1rem 3rem 1rem 1.25rem;border:2px solid #cbd5e1;border-radius:12px;font-size:1rem;transition:all .2s;background:#fff}.smart-search-input:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.smart-search-input::placeholder{color:#94a3b8}.clear-btn{position:absolute;right:1rem;background:#e2e8f0;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;font-size:.875rem;transition:all .2s}.clear-btn:hover{background:#cbd5e1;color:#334155}.suggestions-list{margin-top:.75rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:.75rem;box-shadow:0 4px 12px #0000001a;max-height:400px;overflow-y:auto}.suggestions-header{margin:0 0 .75rem;padding:.5rem .75rem;color:#0f766e;font-size:.9rem;font-weight:600;background:#f0fdfa;border-radius:8px}.suggestion-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem 1.25rem;margin:.5rem 0;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;font-weight:600;color:#334155;cursor:pointer;transition:all .2s;text-align:left}.suggestion-item:hover{background:#fff;border-color:#14b8a6;color:#0f766e;transform:translate(4px);box-shadow:0 2px 8px #14b8a626}.suggestion-label{font-size:1rem}.no-results{margin-top:.75rem;padding:1.5rem;background:#fef2f2;border:2px solid #fecaca;border-radius:12px;text-align:center}.no-results p{margin:.5rem 0;color:#991b1b;font-weight:600}.no-results-hint{color:#dc2626!important;font-size:.9rem;font-weight:400!important}.help-message{background:#fff;padding:1.25rem;border-radius:12px;border-left:4px solid #14b8a6;box-shadow:0 2px 8px #0000000d}.help-message p{margin:0;color:#475569;font-size:.95rem;line-height:1.6}@media(max-width:768px){.smart-chatbot{padding:1rem;margin:1rem 0}.smart-chatbot-header h3{font-size:1.1rem}.smart-search-input{padding:.875rem 3rem .875rem 1rem;font-size:.95rem}.suggestion-item{padding:.875rem 1rem;font-size:.95rem}.suggestion-label{font-size:.95rem}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.guided-mode-modal .modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.guided-mode-modal .modal-header h2{margin:0;font-size:1.5rem;color:#111827}.modal-close{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background:#f3f4f6;color:#111827}.modal-body{padding:1.5rem}.guided-intro{background:#f0f9ff;border-left:4px solid #0ea5e9;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.guided-intro p{margin:0;color:#0c4a6e;line-height:1.6}.profile-warnings{background:#fef3c7;border-left:4px solid #f59e0b;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.profile-warnings h4{margin:0 0 .75rem;color:#92400e;font-size:1rem}.profile-warnings ul{margin:0;padding-left:1.5rem;color:#78350f;line-height:1.6}.profile-warnings li{margin-bottom:.5rem}.profile-warnings li:last-child{margin-bottom:0}.steps-selection h3{margin:0 0 .5rem;font-size:1.125rem;color:#111827}.selection-hint{color:#6b7280;font-size:.875rem;margin:0 0 1rem}.steps-list{display:flex;flex-direction:column;gap:.75rem}.step-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s}.step-item:hover,.step-item.selected{border-color:#14b8a6;background:#f0fdfa}.step-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#14b8a6}.step-icon{font-size:2rem;flex-shrink:0}.step-info{flex:1}.step-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.step-title-row h4{margin:0;font-size:1rem;color:#111827}.step-urgency{font-size:.75rem;font-weight:600;color:#fff;padding:.25rem .5rem;border-radius:4px;text-transform:uppercase}.step-description{margin:0 0 .5rem;color:#6b7280;font-size:.875rem}.step-meta{display:flex;gap:1rem;font-size:.875rem;color:#6b7280}.selection-summary{margin-top:1.5rem;padding:1rem;background:#f9fafb;border-radius:6px;text-align:center}.selection-summary p{margin:0;color:#374151}.modal-footer{padding:1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:1rem}.btn{padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.btn.primary{background:#14b8a6;color:#fff}.btn.primary:hover:not(:disabled){background:#0d9488}.btn.primary:disabled{background:#d1d5db;cursor:not-allowed}.btn.secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn.secondary:hover{background:#f9fafb}.guided-progress-container{background:linear-gradient(135deg,#0ea5e9,#14b8a6)!important;color:#fff!important;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 12px #0ea5e933}.guided-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.progress-info h3{margin:0 0 .25rem;font-size:1.25rem;font-weight:700}.progress-info p{margin:0;font-size:.875rem;opacity:.95}.guided-header-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-view-progress,.btn-exit-guided{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-view-progress:hover,.btn-exit-guided:hover{background:#ffffff4d;border-color:#ffffff80}.progress-bar-container{background:#fff3;height:12px;border-radius:6px;overflow:hidden;margin-bottom:1.5rem}.progress-bar-fill{background:#fff;height:100%;border-radius:6px;transition:width .5s ease;box-shadow:0 2px 8px #ffffff4d}.steps-timeline{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem}.timeline-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:100px;padding:.75rem;background:#ffffff1a;border-radius:8px;transition:all .3s}.timeline-step.completed{background:#ffffff40}.timeline-step.current{background:#ffffff4d;border:2px solid white;transform:scale(1.05)}.timeline-step.pending{opacity:.6}.timeline-step.clickable{cursor:pointer}.timeline-step.clickable:hover{transform:scale(1.1);background:#ffffff59;box-shadow:0 2px 8px #00000026}.timeline-icon{font-size:1.5rem}.timeline-label{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}.timeline-emoji{font-size:1.25rem}.timeline-title{font-size:.75rem;font-weight:600;line-height:1.2}@media(max-width:768px){.guided-progress-header{flex-direction:column;align-items:flex-start;gap:1rem}.steps-timeline{gap:.25rem}.timeline-step{min-width:80px;padding:.5rem}.timeline-title{font-size:.65rem}}.freemium-cta-banner{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 2rem;margin:2rem 0;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff}.freemium-cta-banner .cta-icon{font-size:2.5rem;flex-shrink:0}.freemium-cta-banner .cta-content{flex:1}.freemium-cta-banner .cta-content h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.freemium-cta-banner .cta-content p{margin:0;opacity:.95;font-size:.95rem}.freemium-cta-banner .cta-button{padding:.75rem 1.5rem;background:#fff;color:#667eea;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;white-space:nowrap}.freemium-cta-banner .cta-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.freemium-cta-card{max-width:500px;margin:2rem auto;padding:2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 8px 30px #667eea66;color:#fff;text-align:center}.freemium-cta-card .cta-header{margin-bottom:2rem}.freemium-cta-card .cta-icon-large{font-size:4rem;margin-bottom:1rem}.freemium-cta-card h2{margin:0 0 1rem;font-size:1.75rem;font-weight:700}.freemium-cta-card .cta-description{margin:0;opacity:.95;font-size:1rem;line-height:1.6}.freemium-cta-card .cta-features{list-style:none;padding:0;margin:2rem 0;text-align:left}.freemium-cta-card .cta-features li{padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.2);font-size:.95rem}.freemium-cta-card .cta-features li:last-child{border-bottom:none}.freemium-cta-card .cta-button-large{width:100%;padding:1rem 2rem;background:#fff;color:#667eea;border:none;border-radius:10px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .3s ease;margin-bottom:1rem}.freemium-cta-card .cta-button-large:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.freemium-cta-card .cta-footer{margin:1rem 0 0;font-size:.9rem;opacity:.9}.freemium-cta-card .cta-footer a{color:#fff;text-decoration:underline;cursor:pointer;font-weight:600}.freemium-cta-card .cta-footer a:hover{opacity:.8}@media(max-width:768px){.freemium-cta-banner{flex-direction:column;text-align:center;padding:1.5rem}.freemium-cta-banner .cta-button{width:100%}.freemium-cta-card{margin:1.5rem 1rem;padding:2rem 1.5rem}}.comparateur-page{max-width:1400px;margin:0 auto;padding:2rem}.page-description{font-size:1.1rem;color:#666}.ville-selector-section{background:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.ville-selector-section h2{font-size:1.3rem;color:#1a1a1a;margin-bottom:1.5rem}.ville-chips{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.ville-chip{background:#fff;border:2px solid #dee2e6;padding:.75rem 1.5rem;border-radius:25px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.ville-chip:hover:not(:disabled){border-color:#06c;transform:translateY(-2px)}.ville-chip.selected{background:linear-gradient(135deg,#06c,#004085);color:#fff;border-color:transparent}.ville-chip:disabled{opacity:.5;cursor:not-allowed}.ville-chip .check{font-size:1.2rem}.selection-info{color:#666;font-size:.95rem;margin-top:1rem}.category-btn{background:#fff;border:2px solid #dee2e6;padding:.75rem 1.5rem;border-radius:25px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease}.category-btn:hover{border-color:#06c;color:#06c}.category-btn.active{background:linear-gradient(135deg,#06c,#004085);color:#fff;border-color:transparent}.comparison-table-section{background:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.comparison-table{min-width:800px}.table-header{display:grid;grid-template-columns:200px repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #dee2e6}.criteria-column{font-weight:700;font-size:1.1rem;color:#1a1a1a}.ville-column{text-align:center}.ville-column h3{font-size:1.2rem;color:#06c;margin-bottom:.25rem}.ville-column .population{font-size:.9rem;color:#666}.category-section{margin-bottom:2.5rem}.category-title{font-size:1.3rem;color:#1a1a1a;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #f0f0f0}.comparison-row{display:grid;grid-template-columns:200px repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding:1rem 0;border-bottom:1px solid #f0f0f0;align-items:center}.comparison-row:last-child{border-bottom:none}.criteria-label{font-weight:600;color:#495057}.ville-value{text-align:center;color:#1a1a1a}.badge.niveau-5,.badge.niveau-4{background:#d4edda;color:#155724}.badge.niveau-6,.badge.niveau-7{background:#fff3cd;color:#856404}.badge.niveau-8,.badge.niveau-9,.badge.niveau-10{background:#f8d7da;color:#721c24}.secteurs-list{list-style:none;padding:0;margin:0;font-size:.9rem}.secteurs-list li{padding:.25rem 0}.pros-cons-section{margin-top:3rem}.pros-cons-section h2{font-size:1.8rem;color:#1a1a1a;margin-bottom:2rem;text-align:center}.pros-cons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.ville-pros-cons{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.ville-pros-cons h3{font-size:1.5rem;color:#06c;margin-bottom:1.5rem;text-align:center}.pros,.cons{margin-bottom:1.5rem}.pros h4{font-size:1.1rem;color:#155724;margin-bottom:.75rem}.cons h4{font-size:1.1rem;color:#856404;margin-bottom:.75rem}.pros ul,.cons ul{list-style:none;padding:0;margin:0}.pros li,.cons li{padding:.5rem 0 .5rem 1.5rem;position:relative;line-height:1.5;color:#495057}.pros li:before{content:"✓";position:absolute;left:0;color:#28a745;font-weight:700}.cons li:before{content:"•";position:absolute;left:0;color:#ffc107;font-weight:700}@media(max-width:768px){.comparateur-page{padding:1rem}.page-title{font-size:2rem}.ville-chips{flex-direction:column}.ville-chip{width:100%}.category-filters{flex-direction:column}.category-btn{width:100%}.comparison-table{min-width:600px}.table-header,.comparison-row{grid-template-columns:150px repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.pros-cons-grid{grid-template-columns:1fr}}.quiz-page{max-width:900px;margin:0 auto;padding:2rem}.page-header{text-align:center;margin-bottom:3rem}.page-title{font-size:2.5rem;color:#1a1a1a;margin-bottom:.5rem}.page-description{font-size:1.1rem;color:#666;max-width:700px;margin:0 auto}.quiz-container{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 2px 12px #0000001a}.progress-section{margin-bottom:2.5rem}.progress-bar{width:100%;height:12px;background:#e9ecef;border-radius:10px;overflow:hidden;margin-bottom:.75rem}.progress-fill{height:100%;background:linear-gradient(90deg,#06c,#004085);transition:width .4s ease}.progress-text{text-align:center;color:#666;font-size:.95rem;font-weight:500}.question-card{margin-bottom:2.5rem}.question-title{font-size:1.5rem;color:#1a1a1a;margin-bottom:2rem;line-height:1.5}.option-btn{background:#fff;border:2px solid #dee2e6;padding:1.25rem 1.5rem;border-radius:10px;cursor:pointer;font-size:1rem;text-align:left;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center}.option-btn:hover{border-color:#06c;transform:translate(5px);box-shadow:0 2px 8px #06c3}.option-btn.selected{background:linear-gradient(135deg,#06c,#004085);color:#fff;border-color:transparent;font-weight:600}.option-label{flex:1}.check-icon{font-size:1.3rem;margin-left:1rem}.quiz-navigation{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}.btn-nav,.btn-submit{padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-nav{background:#f8f9fa;color:#495057;border:2px solid #dee2e6}.btn-nav:hover:not(:disabled){background:#e9ecef;transform:translateY(-2px)}.btn-nav:disabled{opacity:.5;cursor:not-allowed}.btn-next{background:#06c;color:#fff;border:none}.btn-next:hover:not(:disabled){background:#0052a3}.btn-submit{background:linear-gradient(135deg,#28a745,#1e7e34);color:#fff;flex:1}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.results-container{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 2px 12px #0000001a}.results-summary{text-align:center;margin-bottom:2.5rem;font-size:1.1rem;color:#495057}.results-list{display:flex;flex-direction:column;gap:2rem;margin-bottom:2.5rem}.result-card{background:#fff;border:2px solid #dee2e6;border-radius:12px;padding:2rem;transition:all .3s ease}.result-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.result-card.rank-1{border-color:gold;background:linear-gradient(135deg,#fffef5,#fff)}.result-card.rank-2{border-color:silver}.result-card.rank-3{border-color:#cd7f32}.result-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.rank-badge{background:linear-gradient(135deg,#06c,#004085);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.result-card.rank-1 .rank-badge{background:linear-gradient(135deg,gold,#ffed4e);color:#1a1a1a}.result-header h2{flex:1;font-size:1.8rem;color:#1a1a1a;margin:0}.score-badge{background:#e7f3ff;color:#06c;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1.2rem}.result-card.rank-1 .score-badge{background:#fff3cd;color:#856404}.score-bar{width:100%;height:10px;background:#e9ecef;border-radius:10px;overflow:hidden;margin-bottom:1.5rem}.score-fill{height:100%;background:linear-gradient(90deg,#06c,#004085);transition:width .6s ease}.result-card.rank-1 .score-fill{background:linear-gradient(90deg,gold,#ffed4e)}.result-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item .label{font-size:.85rem;color:#6c757d;font-weight:500}.detail-item .value{font-size:1rem;color:#1a1a1a;font-weight:600}.top-avantages{background:#f8f9fa;padding:1.25rem;border-radius:8px}.top-avantages h4{font-size:1rem;color:#495057;margin-bottom:.75rem}.top-avantages ul{list-style:none;padding:0;margin:0}.top-avantages li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#495057}.top-avantages li:before{content:"✓";position:absolute;left:0;color:#28a745;font-weight:700}.btn-primary,.btn-secondary{padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-primary{background:linear-gradient(135deg,#06c,#004085);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0066cc4d}.btn-secondary{background:#fff;color:#495057;border:2px solid #dee2e6}.btn-secondary:hover{background:#f8f9fa;transform:translateY(-2px)}.loading-state,.error-state{text-align:center;padding:3rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid #0066cc;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-state p{color:#dc3545;font-size:1.1rem}@media(max-width:768px){.quiz-page{padding:1rem}.page-title{font-size:2rem}.quiz-container,.results-container{padding:1.5rem}.question-title{font-size:1.3rem}.quiz-navigation{flex-direction:column}.btn-nav,.btn-submit{width:100%}.result-details{grid-template-columns:1fr}.results-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.profil-page{min-height:100vh;background:#f5f7fa;padding:2rem 1rem}.profil-container{max-width:900px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.profil-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2.5rem 2rem;text-align:center}.profil-header h1{margin:0 0 .5rem;font-size:2rem}.profil-header p{margin:0;opacity:.9}.profil-content{padding:2rem}.profil-section{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid #e0e0e0}.profil-section:last-child{border-bottom:none;margin-bottom:0}.profil-section h2{font-size:1.4rem;color:#333;margin:0 0 1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.info-item.highlight{background:linear-gradient(135deg,#f8f9ff,#f0f2ff);border-color:#667eea}.info-label{font-size:.85rem;color:#666;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1.1rem;color:#333;font-weight:500}.edit-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#555}.form-group input,.form-group select{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;border:none}.btn.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn.small{padding:.5rem 1rem;font-size:.9rem}.success-message,.error-message{padding:1rem;border-radius:8px;text-align:center;font-weight:500;margin-top:1.5rem}.success-message{background:#d4edda;border:2px solid #c3e6cb;color:#155724}.error-message{background:#f8d7da;border:2px solid #f5c6cb;color:#721c24}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#666}.guided-progress-container{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.progress-header h3{margin:0;color:#0f172a;font-size:1.5rem;font-weight:700}.cloud-status{font-size:.9rem;color:#334155;font-weight:600}.no-guided-mode{text-align:center;padding:40px 20px;color:#7f8c8d;font-size:1.1rem}.progress-stats{display:flex;gap:30px;margin-bottom:20px;padding:20px;background:#f8fafc!important;border:3px solid #cbd5e1!important;border-radius:8px;box-shadow:0 1px 3px #0000001a}.stat-item{display:flex;flex-direction:column;gap:8px}.stat-label{font-size:.75rem!important;color:#475569!important;font-weight:700!important;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.stat-value{font-size:1.75rem!important;color:#000!important;font-weight:900!important;line-height:1}.progress-bar-container{margin-bottom:30px}.progress-bar{width:100%;height:12px;background:#ecf0f1;border-radius:6px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s ease}.steps-list{display:flex;flex-direction:column;gap:16px}.step-card{border:2px solid #ecf0f1;border-radius:8px;padding:16px;transition:all .3s ease;background:#fff!important}.step-card.completed{border-color:#2ecc71!important;background:#f0fff4!important}.step-card.pending{border-color:#3498db!important;background:#f0f8ff!important}.step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:1rem}.step-icon-title{display:flex;align-items:center;gap:10px}.step-icon{font-size:1.8rem}.step-title{margin:0;color:#0f172a;font-size:1.15rem;font-weight:700}.step-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.step-status{display:flex;align-items:center}.btn-go-to-step{background:linear-gradient(135deg,#0ea5e9,#14b8a6);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0ea5e933}.btn-go-to-step:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0ea5e94d}.btn-go-to-step:active{transform:translateY(0)}.status-badge{padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600}.status-badge.completed{background:#2ecc71;color:#fff}.status-badge.pending{background:#3498db;color:#fff}.step-checklist{margin:12px 0;padding:12px;background:#fff!important;border-radius:6px}.checklist-title{margin:0 0 10px;font-weight:600;color:#34495e!important;font-size:.9rem}.checklist-items{list-style:none;padding:0;margin:0}.checklist-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.95rem;color:#2c3e50!important}.checklist-item input[type=checkbox]{cursor:not-allowed}.completed-text{text-decoration:line-through;color:#95a5a6}.step-meta{display:flex;gap:15px;margin-top:12px;padding-top:12px;border-top:1px solid #ecf0f1}.urgency-badge{padding:4px 10px;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.urgency-badge.urgent{background:#e74c3c;color:#fff}.urgency-badge.important{background:#f39c12;color:#fff}.urgency-badge.normal{background:#95a5a6;color:#fff}.estimated-time{font-size:.85rem;color:#475569!important;font-weight:600}.completion-message{margin-top:30px;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;text-align:center;color:#fff}.completion-message h4{margin:0 0 10px;font-size:1.5rem}.completion-message p{margin:0;font-size:1.1rem}@media(max-width:768px){.guided-progress-container{padding:16px}.progress-header{flex-direction:column;align-items:flex-start;gap:10px}.progress-stats{flex-direction:column;gap:15px}.step-header{flex-direction:column;align-items:flex-start;gap:10px}.step-meta{flex-direction:column;gap:8px}}.test-api-page{max-width:1200px;margin:0 auto;padding:2rem}.test-api-header{text-align:center;margin-bottom:2rem}.test-api-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#1e293b}.test-api-header p{color:#64748b;font-size:1.1rem}.test-api-controls{display:flex;gap:1rem;align-items:flex-end;margin-bottom:2rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border:2px solid #e2e8f0}.control-group{display:flex;flex-direction:column;gap:.5rem;flex:1}.control-group label{font-weight:600;color:#475569;font-size:.9rem}.control-group select{padding:.75rem;border:2px solid #cbd5e1;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s}.control-group select:hover{border-color:#3b82f6}.control-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.refresh-btn,.retry-btn{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.refresh-btn:hover,.retry-btn:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.test-api-status{background:#f1f5f9;padding:1rem;border-radius:8px;margin-bottom:2rem;border-left:4px solid #3b82f6}.status-item{display:flex;gap:1rem;margin-bottom:.5rem}.status-item:last-child{margin-bottom:0}.status-label{font-weight:600;color:#475569;min-width:120px}.status-item code{background:#e2e8f0;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem}.test-api-loading{text-align:center;padding:3rem;background:#f8fafc;border-radius:12px;border:2px dashed #cbd5e1}.test-api-error{background:#fef2f2;border:2px solid #fecaca;border-radius:12px;padding:2rem}.test-api-error h3{color:#dc2626;margin-bottom:1rem}.test-api-error p{color:#991b1b;margin-bottom:1rem}.error-help{background:#fff;padding:1rem;border-radius:8px;margin:1rem 0}.error-help h4{color:#475569;margin-bottom:.5rem}.error-help ul{margin-left:1.5rem;color:#64748b}.error-help code{background:#f1f5f9;padding:.2rem .4rem;border-radius:4px;font-size:.9rem}.test-api-success{background:#f0fdf4;border:2px solid #86efac;border-radius:12px;padding:2rem}.success-header{text-align:center;margin-bottom:2rem}.success-header h3{color:#16a34a;font-size:1.8rem;margin-bottom:.5rem}.success-header p{color:#15803d}.data-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.summary-item{background:#fff;padding:1rem;border-radius:8px;display:flex;flex-direction:column;gap:.5rem}.summary-label{font-size:.9rem;color:#64748b;font-weight:600}.summary-value{font-size:1.2rem;color:#1e293b;font-weight:700}.data-preview{background:#fff;padding:1.5rem;border-radius:8px}.data-preview h4{color:#475569;margin-bottom:1rem}.data-preview pre{background:#1e293b;color:#e2e8f0;padding:1rem;border-radius:8px;overflow-x:auto;font-size:.9rem;line-height:1.6}.test-api-empty{text-align:center;padding:3rem;background:#f8fafc;border-radius:12px;border:2px dashed #cbd5e1;color:#64748b}.category-chatbot{background:linear-gradient(135deg,#f0fdfa,#ecfdf5);border:2px solid #14b8a6;border-radius:16px;padding:1.5rem;margin:2rem 0;box-shadow:0 4px 12px #14b8a61a;max-width:800px}.category-chatbot-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #14b8a6}.category-chatbot-header .chatbot-icon{font-size:2rem;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.category-chatbot-header h3{margin:0;color:#0f766e;font-size:1.25rem;font-weight:700}.category-chatbot-content{display:flex;flex-direction:column;gap:1rem}.search-section{position:relative}.search-label{display:block;font-size:1.1rem;font-weight:600;color:#0f766e;margin-bottom:.75rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.category-search-input{width:100%;padding:.875rem 2.5rem .875rem 1rem;border:2px solid #14b8a6;border-radius:12px;font-size:1rem;background:#fff;transition:all .3s ease}.category-search-input:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 3px #14b8a61a}.clear-btn{position:absolute;right:.75rem;background:none;border:none;color:#64748b;font-size:1.25rem;cursor:pointer;padding:.25rem;transition:color .2s}.clear-btn:hover{color:#0f766e}.suggestions-list{margin-top:.75rem;background:#fff;border:2px solid #14b8a6;border-radius:12px;padding:.75rem;max-height:300px;overflow-y:auto}.suggestions-header{font-size:.9rem;font-weight:600;color:#0f766e;margin:0 0 .5rem}.suggestion-item{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f0fdfa;border:1px solid #99f6e4;border-radius:8px;margin-bottom:.5rem;cursor:pointer;transition:all .2s;text-align:left}.suggestion-item:hover{background:#ccfbf1;border-color:#14b8a6;transform:translate(4px)}.suggestion-item:last-child{margin-bottom:0}.suggestion-label{font-weight:500;color:#0f766e}.suggestion-badge{background:#14b8a6;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.selected-subcategory{display:flex;flex-direction:column;gap:1.5rem}.back-btn{align-self:flex-start;padding:.5rem 1rem;background:#fff;border:2px solid #14b8a6;border-radius:8px;color:#0f766e;font-weight:600;cursor:pointer;transition:all .2s}.back-btn:hover{background:#f0fdfa;transform:translate(-4px)}.subcategory-info{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #14b8a6}.subcategory-info h4{margin:0 0 .5rem;color:#0f766e;font-size:1.25rem}.subcategory-info .info-message{margin:0 0 1rem;color:#64748b;font-size:1rem}.info-content{margin:1rem 0}.info-content p{margin:.5rem 0;color:#0f766e;font-size:.95rem;line-height:1.6}.info-links{margin-top:1.5rem}.info-links h5{margin:0 0 .75rem;color:#0f766e;font-size:1rem}.info-link-btn{display:inline-block;margin:.25rem .5rem .25rem 0;padding:.5rem 1rem;background:#14b8a6;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:.9rem;transition:all .2s}.info-link-btn:hover{background:#0f766e;transform:translateY(-2px)}.location-search{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #14b8a6}.location-search h5{margin:0 0 1rem;color:#0f766e;font-size:1.1rem}.search-type-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.toggle-btn{flex:1;padding:.75rem 1rem;background:#f0fdfa;border:2px solid #99f6e4;border-radius:8px;color:#0f766e;font-weight:600;cursor:pointer;transition:all .2s}.toggle-btn:hover{background:#ccfbf1;border-color:#14b8a6}.toggle-btn.active{background:#14b8a6;border-color:#14b8a6;color:#fff}.location-input-group{display:flex;gap:.5rem;margin-bottom:1rem}.location-input{flex:1;padding:.75rem 1rem;border:2px solid #14b8a6;border-radius:8px;font-size:1rem}.location-input:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 3px #14b8a61a}.search-location-btn{padding:.75rem 1.5rem;background:#14b8a6;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.search-location-btn:hover{background:#0f766e;transform:scale(1.05)}.location-results{margin-top:1rem}.results-count{font-weight:600;color:#0f766e;margin-bottom:1rem}.location-card{background:#f0fdfa;padding:1rem;border-radius:8px;border:1px solid #99f6e4;margin-bottom:.75rem}.location-card:last-child{margin-bottom:0}.location-card h6{margin:0 0 .5rem;color:#0f766e;font-size:1rem}.location-card p{margin:.25rem 0;color:#64748b;font-size:.9rem}.no-results{color:#64748b;font-style:italic;text-align:center;padding:1rem}@media(max-width:768px){.category-chatbot{padding:1rem;margin:1rem 0}.search-type-toggle,.location-input-group{flex-direction:column}.search-location-btn{width:100%}}.expand-search-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #14b8a633}.expand-search-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #14b8a64d;background:linear-gradient(135deg,#0d9488,#0f766e)}.expand-search-btn:active{transform:translateY(0)}.guided-next-step-container{position:sticky;bottom:0;left:0;right:0;background:linear-gradient(135deg,#0ea5e9,#14b8a6);color:#fff;padding:1.5rem;border-radius:12px 12px 0 0;box-shadow:0 -4px 20px #0ea5e94d;margin-top:3rem;z-index:100}.guided-step-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.current-step-badge{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1rem}.step-icon{font-size:1.5rem}.step-navigation-preview{display:flex;gap:1.5rem;flex-wrap:wrap}.previous-step-preview,.next-step-preview{display:flex;align-items:center;gap:.5rem;font-size:.875rem;opacity:.9}.previous-label,.next-label{font-weight:500}.previous-step-name,.next-step-name{font-weight:600;background:#fff3;padding:.25rem .75rem;border-radius:6px}.guided-navigation-buttons{display:flex;gap:1rem;flex-wrap:wrap}.btn-previous-step,.btn-next-step{flex:1;min-width:200px;background:#fff;color:#0ea5e9;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #0000001a}.btn-previous-step{background:#ffffffe6}.btn-previous-step:hover,.btn-next-step:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026;background:#f0f9ff}.btn-previous-step:active,.btn-next-step:active{transform:translateY(0)}.step-completed-badge{margin-top:.75rem;text-align:center;font-weight:600;font-size:.875rem;padding:.5rem;background:#fff3;border-radius:6px}@media(max-width:768px){.guided-next-step-container{padding:1rem;margin-top:2rem}.guided-step-info{flex-direction:column;align-items:flex-start}.current-step-badge{font-size:.875rem}.step-icon{font-size:1.25rem}.btn-previous-step,.btn-next-step{font-size:1rem;padding:.875rem 1.5rem;min-width:100%}.guided-navigation-buttons{flex-direction:column}}.demarche-page{max-width:1200px;margin:0 auto;padding:2rem}.demarche-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.header-content{display:flex;align-items:center;gap:1.5rem}.header-icon{font-size:3rem;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem;border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #667eea4d}.demarche-header h1{font-size:2rem;margin:0 0 .5rem;color:#1e293b}.demarche-header p{margin:0;color:#64748b;font-size:1.1rem}.city-selector{display:flex;align-items:center;gap:.75rem}.city-selector label{font-weight:600;color:#475569}.city-selector select{padding:.75rem 1rem;border:2px solid #cbd5e1;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s}.city-selector select:hover{border-color:#3b82f6}.city-selector select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.loading-state{text-align:center;padding:4rem 2rem}.spinner{width:50px;height:50px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.error-state{background:#fef2f2;border:2px solid #fecaca;border-radius:12px;padding:2rem;text-align:center}.error-state h3{color:#dc2626;margin-bottom:1rem}.error-state p{color:#991b1b;margin-bottom:1.5rem}.btn-retry{padding:.75rem 1.5rem;background:#dc2626;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-retry:hover{background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.demarche-content{margin-top:2rem}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.content-header h2{font-size:1.75rem;color:#1e293b;margin:0}.badge{background:#dbeafe;color:#1e40af;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.info-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:all .3s}.info-card:hover{border-color:#3b82f6;box-shadow:0 8px 24px #3b82f626;transform:translateY(-4px)}.card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.65rem}.card-header h3{font-size:1.05rem;color:#1e293b;margin:0;flex:1;font-weight:600}.price{background:#dcfce7;color:#166534;padding:.25rem .75rem;border-radius:6px;font-weight:600;font-size:.9rem;white-space:normal;word-wrap:break-word;max-width:250px;text-align:right}.card-description{color:#475569;line-height:1.5;margin-bottom:.75rem;font-size:.875rem}.card-section{margin-top:1rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.card-section h4{font-size:.875rem;color:#334155;margin:0 0 .5rem;font-weight:600}.card-section p{color:#64748b;margin:0;line-height:1.5;font-size:.875rem}.card-section ul{margin:0;padding-left:1.25rem;color:#64748b}.card-section li{margin-bottom:.35rem;line-height:1.4;font-size:.875rem}.prices-grid{display:grid;gap:.5rem}.price-item{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.5rem .65rem;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0;transition:all .2s}.price-item:hover{background:#f1f5f9;border-color:#cbd5e1}.price-label{color:#475569;font-weight:400;font-size:.8rem!important;flex:1;line-height:1.3;word-wrap:break-word}.price-value{color:#166534;font-weight:600;font-size:.8rem!important;background:#dcfce7;padding:.15rem .5rem;border-radius:4px;white-space:nowrap;flex-shrink:0;line-height:1.3}.useful-links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.useful-link{display:inline-block;padding:.75rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#3b82f6;text-decoration:none;font-weight:500;font-size:.9rem;transition:all .2s;text-align:center}.useful-link:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.btn-link{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s}.btn-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.empty-state{text-align:center;padding:4rem 2rem;color:#64748b;background:#f8fafc;border-radius:12px;border:2px dashed #cbd5e1}.steps-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:2rem;margin-bottom:2rem}.steps-section h3{font-size:1.5rem;color:#1e293b;margin:0 0 1.5rem}.steps-list{display:flex;flex-direction:column;gap:1rem}.step-item{display:flex;gap:1rem;align-items:start;padding:1rem;background:#f8fafc;border-radius:8px;transition:all .2s}.step-item:hover{background:#f1f5f9;transform:translate(4px)}.step-number{width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.step-content h4{margin:0;color:#334155;font-size:1.1rem}.tips-section{background:#fffbeb;border:2px solid #fde68a;border-radius:12px;padding:2rem;margin-bottom:2rem}.tips-section h3{font-size:1.5rem;color:#92400e;margin:0 0 1.5rem}.tips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.tip-card{background:#fff;padding:1rem;border-radius:8px;border-left:4px solid #f59e0b}.tip-card p{margin:0;color:#78350f;line-height:1.6}.resources-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:2rem}.resources-section h3{font-size:1.5rem;color:#1e293b;margin:0 0 1.5rem}.resources-list{display:flex;flex-direction:column;gap:.75rem}.resource-link{display:block;padding:1rem 1.5rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;color:#3b82f6;text-decoration:none;font-weight:600;transition:all .2s}.resource-link:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;transform:translate(4px)}.programmes-list{display:flex;flex-direction:column;gap:2rem}.programme-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:2rem;transition:all .3s ease}.programme-card:hover{border-color:#3b82f6;box-shadow:0 8px 24px #3b82f626}.programme-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.programme-header h3{font-size:1.5rem;color:#1e293b;margin:0;flex:1}.programme-organisme{background:#dbeafe;color:#1e40af;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;white-space:nowrap}.programme-description{color:#475569;line-height:1.6;margin:0 0 1.5rem;font-size:1rem}.programme-montant{background:#fef3c7;border:2px solid #fbbf24;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#78350f;font-size:1rem}.programme-montant strong{color:#92400e}.programme-section{margin-bottom:1.5rem}.programme-section h4{font-size:1.125rem;color:#334155;margin:0 0 .75rem}.programme-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.programme-section li{padding-left:1.5rem;position:relative;color:#475569;line-height:1.6}.programme-section li:before{content:"•";position:absolute;left:0;color:#3b82f6;font-weight:700;font-size:1.25rem}.programme-footer{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f1f5f9;flex-wrap:wrap}.programme-footer .btn{flex:1;min-width:200px;text-align:center}@media(max-width:1024px){.demarche-page{padding:1.5rem}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:768px){.demarche-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-content{flex-direction:column;align-items:flex-start}.header-icon{font-size:2rem;padding:.75rem}.demarche-header h1{font-size:1.5rem}.cards-grid,.tips-grid{grid-template-columns:1fr}.demarche-page{padding:1rem}.demarche-header,.header-content{flex-direction:column;align-items:flex-start;gap:1rem}.city-selector,.city-selector select{width:100%}.info-card{padding:1rem}.card-header h3{font-size:1.1rem}.price{font-size:.8rem;padding:.2rem .6rem}}.saaq-search-container{background-color:#e3f2fd;padding:1.25rem;border-radius:12px;margin-bottom:1.5rem;border:1px solid #2196F3}.saaq-search-input-container{display:flex;gap:.75rem;align-items:stretch}.saaq-search-input{flex:1;padding:.75rem 1rem;border:1px solid #2196F3;border-radius:8px;font-size:1rem;background-color:#fff;color:#333;transition:border-color .2s}.saaq-search-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #2196f31a}.saaq-search-input::placeholder{color:#999}.saaq-search-button{padding:.75rem 1.5rem;background-color:#2196f3;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s;white-space:nowrap}.saaq-search-button:hover{background-color:#1976d2;transform:translateY(-1px)}.saaq-search-button:active{transform:translateY(0)}.saaq-separator{display:flex;align-items:center;margin:1.5rem 0}.saaq-separator-line{flex:1;height:1px;background-color:#ddd}.saaq-separator-text{margin:0 1rem;font-size:.9rem;color:#999;font-weight:600}@media(max-width:768px){.saaq-search-input-container{flex-direction:column}.saaq-search-button{width:100%}}.premieres-courses{max-width:1200px;margin:0 auto;padding:2rem}.premieres-courses-header{text-align:center;margin-bottom:3rem}.premieres-courses-header h1{font-size:2.5rem;color:var(--primary);margin-bottom:.5rem}.premieres-courses-header p{font-size:1.125rem;color:var(--text-secondary)}.step-container{background:#fff;border-radius:12px;padding:2rem;box-shadow:var(--shadow-md)}.step-container h2{font-size:1.75rem;color:var(--primary);margin-bottom:1rem}.btn-back{background:none;border:none;color:var(--primary);font-size:1rem;cursor:pointer;margin-bottom:1rem}.input-help{font-size:.875rem;color:var(--text-secondary);margin-top:.5rem;font-style:italic}.btn-google-maps{width:100%;margin-top:1rem;margin-bottom:.5rem;font-size:1.125rem;font-weight:600;background:linear-gradient(135deg,#4285f4,#34a853);border:none;color:#fff;padding:1rem;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #4285f44d}.btn-google-maps:hover{transform:translateY(-2px);box-shadow:0 6px 12px #4285f466;background:linear-gradient(135deg,#3367d6,#2d8e47);padding:.5rem 0;transition:opacity .2s}.btn-back:hover{opacity:.7}.categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.category-card{background:#fff;border:2px solid var(--border-color);border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s}.category-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.category-icon{font-size:3rem;display:block;margin-bottom:1rem}.category-card h3{font-size:1.25rem;color:var(--primary);margin-bottom:.5rem}.category-card p{color:var(--text-secondary);font-size:.875rem}.items-list{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}.item-checkbox{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.item-checkbox:hover{border-color:var(--primary);background:var(--primary-lighter)}.item-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.item-icon{font-size:1.5rem}.item-name{font-size:1.125rem;font-weight:500}.budget-section,.location-section{margin:2rem 0}.budget-section h3,.location-section h3{font-size:1.25rem;color:var(--primary);margin-bottom:1rem}.budget-options{display:flex;flex-direction:column;gap:1rem}.budget-option{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.budget-option:hover{border-color:var(--primary)}.budget-option input[type=radio]{width:20px;height:20px;cursor:pointer}.budget-icon{font-size:1.5rem}.budget-range{display:block;font-size:.875rem;color:var(--text-secondary)}.location-input{width:100%;padding:1rem;font-size:1rem;border:2px solid var(--border-color);border-radius:8px;transition:border-color .2s}.location-input:focus{outline:none;border-color:var(--primary)}.error-message{color:#ef4444;margin-top:.5rem;font-size:.875rem}.btn-large{width:100%;padding:1rem 2rem;font-size:1.125rem;margin-top:2rem}.results-summary{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem}.no-results{text-align:center;padding:3rem}.recommendations-list{display:flex;flex-direction:column;gap:2rem}.recommendation-card{background:#fff;border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:box-shadow .3s}.recommendation-card:hover{box-shadow:var(--shadow-lg)}.rec-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.rec-title{display:flex;align-items:flex-start;gap:1rem;flex:1}.rec-icon{font-size:2rem}.rec-title h3{font-size:1.5rem;color:var(--primary);margin:0}.rec-store-name{font-size:1rem;color:var(--text-secondary);margin:.25rem 0 0}.rec-price{display:flex;flex-direction:column;align-items:flex-end;background:var(--primary-lighter);padding:.75rem 1rem;border-radius:8px}.price-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.price-value{font-size:1.5rem;font-weight:700;color:var(--primary)}.rec-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin:1rem 0;padding:1rem;background:var(--bg-secondary);border-radius:8px}.info-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.info-icon{font-size:1.25rem}.rec-description{color:var(--text-secondary);margin:1rem 0}.btn-toggle-details{width:100%;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:.875rem;color:var(--primary);font-weight:600;transition:all .2s;margin:1rem 0}.btn-toggle-details:hover{background:var(--primary-lighter)}.kit-details{margin-top:1rem;padding:1.5rem;background:var(--bg-secondary);border-radius:8px}.kit-details h4{font-size:1.125rem;color:var(--primary);margin-bottom:1rem}.kit-items{list-style:none;padding:0;margin:0 0 1rem}.kit-items li{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.kit-items li:last-child{border-bottom:none}.kit-total{display:flex;justify-content:space-between;padding:1rem 0;border-top:2px solid var(--primary);font-size:1.125rem;color:var(--primary)}.kit-pros,.kit-cons,.kit-tip,.store-tip{margin-top:1rem;padding:1rem;border-radius:8px}.kit-pros{background:#d1fae5;border-left:4px solid #10b981}.kit-cons{background:#fee2e2;border-left:4px solid #ef4444}.kit-tip,.store-tip{background:#dbeafe;border-left:4px solid #3b82f6}.kit-pros ul,.kit-cons ul{margin:.5rem 0 0 1.5rem;padding:0}.kit-pros li,.kit-cons li{margin:.25rem 0}.rec-actions{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.rec-actions .btn{flex:1;min-width:150px;text-align:center;text-decoration:none}@media(max-width:768px){.premieres-courses{padding:1rem}.premieres-courses-header h1{font-size:1.75rem}.categories-grid{grid-template-columns:1fr}.rec-header{flex-direction:column}.rec-price{align-self:stretch;align-items:center}.rec-info{grid-template-columns:1fr}.rec-actions{flex-direction:column}.rec-actions .btn{width:100%}}.vie-associative-page{max-width:1400px;margin:0 auto}.filters-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:2rem;margin-bottom:2rem}.filters-section h2{font-size:1.5rem;color:#1e293b;margin:0 0 1.5rem}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;align-items:end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-weight:600;color:#475569;font-size:.875rem}.filter-group select{padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s ease}.filter-group select:hover{border-color:#cbd5e1}.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.associations-list{display:flex;flex-direction:column;gap:2rem}.association-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:2rem;transition:all .3s ease}.association-card:hover{border-color:#3b82f6;box-shadow:0 8px 24px #3b82f626;transform:translateY(-2px)}.association-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.association-header h3{font-size:1.5rem;color:#1e293b;margin:0 0 .75rem}.association-meta{display:flex;flex-wrap:wrap;gap:.5rem}.badge{padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap}.region-badge{background:#dbeafe;color:#1e40af}.city-badge{background:#fef3c7;color:#92400e}.arrondissement-badge{background:#f3e8ff;color:#6b21a8}.success-badge{background:#dcfce7;color:#166534;margin-left:.5rem}.association-year{background:#f1f5f9;color:#475569;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;white-space:nowrap}.association-description{color:#475569;line-height:1.6;margin:0 0 1.5rem;font-size:1rem}.association-mission{background:#eff6ff;border-left:4px solid #3b82f6;padding:1rem;margin-bottom:1.5rem;border-radius:4px;color:#1e40af}.association-mission strong{color:#1e3a8a}.association-section{margin-bottom:1.5rem}.association-section h4{font-size:1.125rem;color:#334155;margin:0 0 .75rem}.services-list,.activities-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.5rem}.services-list li,.activities-list li{padding-left:1.5rem;position:relative;color:#475569;line-height:1.6;font-size:.9rem}.services-list li:before,.activities-list li:before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700;font-size:1rem}.more-items{color:#3b82f6!important;font-weight:600;font-style:italic}.more-items:before{content:"→"!important;color:#3b82f6!important}.association-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1.5rem 0;padding:1.5rem;background:#f8fafc;border-radius:8px}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item strong{color:#334155;font-size:.875rem}.info-item span{color:#475569;font-size:.9rem}.association-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f1f5f9;flex-wrap:wrap}.contact-buttons{display:flex;gap:.75rem;flex-wrap:wrap;flex:1}.contact-buttons .btn{flex:0 1 auto;white-space:nowrap}.benevoles-badge{background:#dcfce7;color:#166534;padding:.5rem 1rem;border-radius:6px;font-weight:600;font-size:.875rem;border:2px solid #86efac}@media(max-width:768px){.filters-grid{grid-template-columns:1fr}.association-header{flex-direction:column;align-items:flex-start}.association-year{align-self:flex-start}.association-info-grid,.services-list,.activities-list{grid-template-columns:1fr}.association-footer{flex-direction:column;align-items:flex-start}.contact-buttons{width:100%;flex-direction:column}.contact-buttons .btn{width:100%}.benevoles-badge{align-self:flex-start}}.immigration-page{max-width:1200px;margin:0 auto;padding:2rem}.immigration-header{text-align:center;margin-bottom:3rem}.immigration-header h1{font-size:2.5rem;color:#1a1a1a;margin-bottom:.5rem}.immigration-header .subtitle{font-size:1.2rem;color:#666}.immigration-content{display:flex;flex-direction:column;gap:3rem}.initial-question{background:linear-gradient(135deg,#667eea,#764ba2);padding:3rem;border-radius:16px;color:#fff}.initial-question h2{text-align:center;font-size:1.8rem;margin-bottom:2rem}.choice-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.choice-card{background:#fff;color:#1a1a1a;padding:2rem;border-radius:12px;text-align:center;cursor:pointer;transition:all .3s ease;border:3px solid transparent}.choice-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0003}.choice-card.selected{border-color:#667eea;box-shadow:0 10px 30px #667eea4d}.choice-icon{font-size:4rem;margin-bottom:1rem}.choice-card h3{font-size:1.5rem;margin-bottom:1rem;color:#1a1a1a}.choice-card p{color:#666;margin-bottom:1.5rem;line-height:1.6}.choice-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.choice-button:hover{transform:scale(1.05);box-shadow:0 5px 15px #667eea66}.info-section{background:#f8f9fa;padding:2rem;border-radius:12px}.info-section h3{font-size:1.5rem;margin-bottom:1.5rem;color:#1a1a1a}.info-item{display:flex;gap:1rem;align-items:flex-start}.info-icon{font-size:2rem;flex-shrink:0}.info-item h4{font-size:1.1rem;margin-bottom:.5rem;color:#1a1a1a}.info-item p{color:#666;font-size:.95rem;line-height:1.5}.quick-links{text-align:center}.quick-links h3{font-size:1.5rem;margin-bottom:1.5rem;color:#1a1a1a}.quick-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;max-width:800px;margin:0 auto}.quick-link-button{background:#fff;border:2px solid #667eea;color:#667eea;padding:1rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.quick-link-button:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.province-focus{background:linear-gradient(135deg,#f093fb,#f5576c);padding:2rem;border-radius:12px}.province-badge{display:flex;align-items:center;gap:1.5rem;background:#fff;padding:1.5rem;border-radius:8px}.province-flag{font-size:3rem;flex-shrink:0}.province-badge h4{font-size:1.3rem;margin-bottom:.5rem;color:#1a1a1a}.province-badge p{color:#666;line-height:1.6}@media(max-width:768px){.immigration-page{padding:1rem}.immigration-header h1{font-size:2rem}.initial-question{padding:2rem 1.5rem}.initial-question h2{font-size:1.4rem}.choice-cards,.info-grid,.quick-links-grid{grid-template-columns:1fr}.province-badge{flex-direction:column;text-align:center}}.programmes-list-page{max-width:1400px;margin:0 auto;padding:2rem}.programmes-header{text-align:center;margin-bottom:2rem;position:relative}.programmes-header h1{font-size:2.2rem;color:#1a1a1a;margin-bottom:.5rem}.programmes-header .subtitle{font-size:1.1rem;color:#666}.category-button:hover{border-color:#667eea;color:#667eea}.category-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.programmes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;margin-bottom:3rem}.programme-card{background:#fff;border:1px solid #dee2e6;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column}.programme-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a;border-color:#667eea}.programme-header h3{font-size:1.3rem;color:#1a1a1a;margin-bottom:.5rem}.ancien-nom{font-size:.85rem;color:#6c757d;font-style:italic;margin-bottom:1rem}.criteres-section,.admissibilite-section,.volets-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}.criteres-section h4,.admissibilite-section h4,.volets-section h4{font-size:.95rem;color:#667eea;margin-bottom:.5rem}.criteres-section ul,.admissibilite-section ul{list-style:none;padding:0;margin:0}.criteres-section li,.admissibilite-section li{font-size:.9rem;color:#495057;padding:.25rem 0 .25rem 1.5rem;position:relative}.criteres-section li:before,.admissibilite-section li:before{content:"•";position:absolute;left:.5rem;color:#667eea;font-weight:700}.voir-details-button{margin-top:auto;padding-top:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.voir-details-button:hover{transform:scale(1.02);box-shadow:0 5px 15px #667eea66}.help-section{background:linear-gradient(135deg,#f093fb,#f5576c);padding:2rem;border-radius:12px;text-align:center;color:#fff}.help-section h3{font-size:1.5rem;margin-bottom:.5rem}.help-section p{font-size:1.1rem;margin-bottom:1.5rem;opacity:.95}.questionnaire-button{background:#fff;color:#f5576c;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.questionnaire-button:hover{transform:scale(1.05);box-shadow:0 5px 15px #0003}.loading,.error,.no-programmes{text-align:center;padding:3rem;font-size:1.2rem;color:#666}@media(max-width:768px){.programmes-list-page{padding:1rem}.programmes-header h1{font-size:1.8rem;margin-top:2.5rem}.back-button{position:static;margin-bottom:1rem;width:100%}.category-filters{flex-direction:column}.category-button{width:100%}.programmes-grid{grid-template-columns:1fr}}.programme-details-page{max-width:1200px;margin:0 auto;padding:2rem}.programme-header{text-align:center;margin-bottom:2rem;position:relative}.programme-header h1{font-size:2.2rem;color:#1a1a1a;margin-bottom:.5rem}.ancien-nom{font-size:.95rem;color:#6c757d;font-style:italic;margin-bottom:1rem}.description{font-size:1.1rem;color:#495057;line-height:1.6;max-width:800px;margin:0 auto}.criteres-prioritaires{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem}.criteres-prioritaires h3{font-size:1.5rem;margin-bottom:1rem}.criteres-prioritaires ul{list-style:none;padding:0}.criteres-prioritaires li{padding:.5rem 0 .5rem 1.5rem;position:relative}.criteres-prioritaires li:before{content:"✓";position:absolute;left:0;font-weight:700;font-size:1.2rem}.sections-navigation{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;background:#f8f9fa;padding:1rem;border-radius:12px}.section-nav-button{background:#fff;border:2px solid #dee2e6;padding:.75rem 1rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.9rem;transition:all .3s ease;flex:1 1 auto;min-width:150px}.section-nav-button:hover{border-color:#667eea;transform:translateY(-2px)}.section-nav-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.section-icon{font-size:1.2rem}.section-label{font-weight:500}.section-content{background:#fff;border:1px solid #dee2e6;border-radius:12px;padding:2rem;min-height:400px}.content-section h2{font-size:1.8rem;color:#1a1a1a;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #667eea}.info-box{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.info-box p{margin:.5rem 0;color:#495057}.steps-list{counter-reset:step-counter;list-style:none;padding:0}.steps-list li{counter-increment:step-counter;margin-bottom:1.5rem;padding-left:3rem;position:relative}.steps-list li:before{content:counter(step-counter);position:absolute;left:0;top:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.steps-list h4{font-size:1.1rem;color:#1a1a1a;margin-bottom:.5rem}.steps-list p{color:#495057;line-height:1.6}.document-category,.conseil-category{margin-bottom:2rem}.document-category h3,.conseil-category h3{font-size:1.3rem;color:#667eea;margin-bottom:1rem}.document-category ul,.conseil-category ul{list-style:none;padding:0}.document-category li,.conseil-category li{padding:.75rem;margin-bottom:.5rem;background:#f8f9fa;border-radius:8px;border-left:3px solid #667eea}.info-text{font-size:.9rem;color:#6c757d;margin-top:.25rem}.details-list{margin-top:.5rem;padding-left:1.5rem}.details-list li{background:none;border:none;padding:.25rem 0;font-size:.9rem}.etape-card{background:#f8f9fa;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border-left:4px solid #667eea}.etape-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.etape-numero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.etape-header h3{font-size:1.3rem;color:#1a1a1a;margin:0}.etape-description{color:#495057;line-height:1.6;margin-bottom:1rem}.etape-info{display:flex;gap:2rem;margin-bottom:1rem}.etape-info p{color:#495057;font-size:.95rem}.etape-details,.etape-conseils{margin-top:1rem}.etape-details h4,.etape-conseils h4{font-size:1rem;color:#667eea;margin-bottom:.5rem}.etape-details ul,.etape-conseils ul{list-style:disc;padding-left:1.5rem}.etape-details li,.etape-conseils li{color:#495057;margin-bottom:.25rem;font-size:.95rem}.exemple-card{background:#f8f9fa;padding:2rem;border-radius:12px}.exemple-card h3{font-size:1.5rem;color:#667eea;margin-bottom:1rem}.profil-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.profil-details p{background:#fff;padding:.75rem;border-radius:8px;margin:0}.timeline{margin-top:1.5rem}.timeline-item{display:flex;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #dee2e6}.timeline-item:last-child{border-bottom:none}.timeline-date{background:#667eea;color:#fff;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.9rem;height:fit-content;white-space:nowrap}.timeline-content h5{font-size:1.1rem;color:#1a1a1a;margin-bottom:.5rem}.timeline-content p{color:#495057;line-height:1.6}.resultat-box{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;padding:1.5rem;border-radius:12px;margin-top:2rem}.resultat-box h4{font-size:1.3rem;margin-bottom:1rem}.resultat-box p{font-size:1.1rem;line-height:1.6}.delais-section,.suivi-section{margin-bottom:2rem}.delais-section h3,.suivi-section h3{font-size:1.3rem;color:#667eea;margin-bottom:1rem}.delais-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.delai-card{background:#f8f9fa;padding:1.5rem;border-radius:8px;border-left:4px solid #667eea}.delai-card h4{font-size:1.1rem;color:#1a1a1a;margin-bottom:.5rem}.delai-time{font-size:1.3rem;font-weight:600;color:#667eea;margin:.5rem 0}.delai-note{font-size:.9rem;color:#6c757d;font-style:italic}.suivi-section ol{padding-left:1.5rem}.suivi-section li{margin-bottom:.75rem;color:#495057;line-height:1.6}.liens-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.lien-card{background:#f8f9fa;padding:1.5rem;border-radius:12px;text-decoration:none;color:inherit;border:2px solid transparent;transition:all .3s ease;display:block}.lien-card:hover{border-color:#667eea;transform:translateY(-3px);box-shadow:0 5px 15px #667eea33}.lien-card h4{font-size:1.2rem;color:#1a1a1a;margin-bottom:.5rem}.lien-card p{color:#495057;margin-bottom:1rem;line-height:1.6}.lien-url{color:#667eea;font-size:.9rem;word-break:break-all}.motif-card{background:#fff3cd;border-left:4px solid #ffc107;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.motif-card h3{font-size:1.2rem;color:#856404;margin-bottom:1rem}.motif-details h4{font-size:1rem;color:#856404;margin-top:1rem;margin-bottom:.5rem}.motif-details p{color:#495057;line-height:1.6}.refus-info-box{background:#d1ecf1;border-left:4px solid #17a2b8;padding:1.5rem;border-radius:8px;margin-top:2rem}.refus-info-box h3{font-size:1.3rem;color:#0c5460;margin-bottom:1rem}.refus-info-box ol{padding-left:1.5rem}.refus-info-box li{color:#495057;margin-bottom:.75rem;line-height:1.6}.loi-card{background:#e7f3ff;border-left:4px solid #0066cc;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.loi-card h3{font-size:1.3rem;color:#004085;margin-bottom:.5rem}.loi-date{font-size:.9rem;color:#6c757d;margin-bottom:1rem}.loi-card p{color:#495057;line-height:1.6;margin-bottom:1rem}.loi-impact{background:#fff;padding:1rem;border-radius:8px;margin-top:1rem}.loi-impact h4{font-size:1rem;color:#06c;margin-bottom:.5rem}.loi-source{display:inline-block;margin-top:1rem;color:#06c;text-decoration:none;font-weight:600;transition:all .3s ease}.loi-source:hover{color:#004085;text-decoration:underline}@media(max-width:768px){.programme-details-page{padding:1rem}.programme-header h1{font-size:1.8rem;margin-top:2.5rem}.back-button{position:static;margin-bottom:1rem;width:100%}.sections-navigation{flex-direction:column}.section-nav-button{width:100%}.section-content{padding:1rem}.etape-info{flex-direction:column;gap:.5rem}.profil-details{grid-template-columns:1fr}.timeline-item{flex-direction:column;gap:.5rem}.delais-grid,.liens-grid{grid-template-columns:1fr}}.questionnaire-page{max-width:900px;margin:0 auto;padding:2rem;min-height:80vh}.questionnaire-container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000001a}.questionnaire-header{text-align:center;margin-bottom:2rem;position:relative}.questionnaire-header h1{font-size:2rem;color:#1a1a1a;margin-bottom:.5rem}.subtitle{font-size:1.1rem;color:#666}.progress-bar{background:#e9ecef;height:8px;border-radius:10px;margin-bottom:2rem;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;border-radius:10px;transition:width .3s ease}.progress-text{position:absolute;top:-25px;right:0;font-size:.9rem;color:#666;font-weight:500}.question-text{font-size:1.5rem;color:#1a1a1a;margin-bottom:1rem;line-height:1.4}.required-badge{display:inline-block;background:#dc3545;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;margin-bottom:1.5rem}.option-card{background:#f8f9fa;border:2px solid #dee2e6;border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .3s ease}.option-card:hover{border-color:#667eea;transform:translate(5px)}.option-card.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff}.option-content{display:flex;justify-content:space-between;align-items:center}.option-text{font-size:1.1rem;font-weight:500}.check-icon{font-size:1.5rem;font-weight:700}.nav-button{flex:1;padding:1rem 2rem;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.prev-button{background:#f8f9fa;color:#495057;border:2px solid #dee2e6}.prev-button:hover:not(:disabled){background:#e9ecef}.next-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.next-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.nav-button:disabled{opacity:.5;cursor:not-allowed}.results-container{text-align:center}.results-container h1{font-size:2.2rem;color:#1a1a1a;margin-bottom:1rem}.results-intro{font-size:1.1rem;color:#666;margin-bottom:2rem}.recommendations-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.recommendation-card{background:#fff;border:2px solid #dee2e6;border-radius:12px;padding:1.5rem;text-align:left;transition:all .3s ease}.recommendation-card:hover{border-color:#667eea;box-shadow:0 5px 15px #667eea33}.recommendation-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.rank-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;flex-shrink:0}.recommendation-header h3{flex:1;font-size:1.3rem;color:#1a1a1a;margin:0}.score-badge{background:#28a745;color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.95rem}.programme-description{color:#495057;line-height:1.6;margin-bottom:1rem}.voir-programme-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.voir-programme-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.no-recommendations{background:#fff3cd;border:2px solid #ffc107;border-radius:12px;padding:2rem;margin-bottom:2rem}.no-recommendations h3{color:#856404;margin-bottom:1rem}.no-recommendations p{color:#495057;line-height:1.6}.results-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.results-actions button{background:#fff;border:2px solid #667eea;color:#667eea;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.results-actions button:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.loading,.error{text-align:center;padding:3rem;font-size:1.2rem}@media(max-width:768px){.questionnaire-page{padding:1rem}.questionnaire-container{padding:1.5rem}.questionnaire-header h1{font-size:1.6rem;margin-top:2.5rem}.back-button{position:static;margin-bottom:1rem;width:100%}.question-text{font-size:1.2rem}.navigation-buttons{flex-direction:column}.recommendation-header{flex-wrap:wrap}.results-actions{flex-direction:column}.results-actions button{width:100%}}.questionnaire-preview-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.questionnaire-container{max-width:800px;margin:0 auto;background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 10px 40px #0003}.questionnaire-header{text-align:center;margin-bottom:2rem}.back-button{background:none;border:none;color:#667eea;font-size:1rem;cursor:pointer;margin-bottom:1rem;padding:.5rem 1rem;transition:all .3s ease}.back-button:hover{background:#f3f4f6;border-radius:8px}.questionnaire-header h1{margin:0 0 .5rem;color:#1f2937;font-size:2rem}.subtitle{color:#6b7280;font-size:1rem;margin:0}.progress-bar{background:#e5e7eb;height:8px;border-radius:4px;margin-bottom:2rem;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s ease;border-radius:4px}.progress-text{position:absolute;top:-1.5rem;right:0;font-size:.875rem;color:#6b7280;font-weight:500}.question-card{margin-bottom:2rem}.question-title{font-size:1.5rem;color:#1f2937;margin-bottom:1.5rem;font-weight:600}.options-list{display:flex;flex-direction:column;gap:1rem}.option-button{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .3s ease;font-size:1rem;text-align:left}.option-button:hover{background:#f3f4f6;border-color:#667eea;transform:translate(4px)}.option-button.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.option-text{flex:1}.check-icon{font-size:1.25rem;margin-left:1rem}.navigation-buttons{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}.btn-previous,.btn-next{padding:.875rem 2rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-previous{background:#f3f4f6;color:#6b7280}.btn-previous:hover:not(:disabled){background:#e5e7eb}.btn-previous:disabled{opacity:.5;cursor:not-allowed}.btn-next{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex:1}.btn-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-next:disabled{opacity:.5;cursor:not-allowed}.preview-results-container{max-width:900px;margin:0 auto}.preview-results-header{text-align:center;margin-bottom:3rem;background:#fff;padding:2.5rem;border-radius:16px;box-shadow:0 4px 20px #0000001a}.preview-results-header h1{margin:0 0 1rem;color:#1f2937;font-size:2.25rem}.preview-results-header p{color:#6b7280;font-size:1.125rem;margin:0}.preview-results-header p strong{color:#667eea;font-weight:700}.compatible-programs-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.program-teaser-item{display:flex;align-items:center;gap:1.5rem;background:#fff;padding:1.5rem 2rem;border-radius:12px;box-shadow:0 2px 10px #00000014;transition:all .3s ease}.program-teaser-item:hover{transform:translateY(-2px);box-shadow:0 4px 20px #667eea33}.program-icon{font-size:2.5rem;flex-shrink:0}.program-info{flex:1}.program-info h3{margin:0 0 .5rem;color:#1f2937;font-size:1.25rem;font-weight:600}.compatibility-badge{display:inline-block;padding:.375rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:.875rem;font-weight:600}.preview-programs-teaser{margin-bottom:3rem}.teaser-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 4px 20px #0000001a;position:relative;overflow:hidden}.blur-overlay{filter:blur(5px);opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}.lock-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:5rem;filter:blur(0);opacity:.9;z-index:10;pointer-events:none;text-shadow:0 2px 10px rgba(0,0,0,.2)}.teaser-card h3{margin:0 0 1rem;color:#1f2937;font-size:1.5rem}.teaser-card ul{list-style:none;padding:0;margin:0}.teaser-card li{padding:.75rem 0;color:#6b7280;font-size:1rem;border-bottom:1px solid #e5e7eb}.teaser-card li:last-child{border-bottom:none}.preview-actions{text-align:center;margin-top:2rem}.btn-secondary{padding:.875rem 2rem;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}@media(max-width:768px){.questionnaire-preview-page{padding:1rem}.questionnaire-container{padding:1.5rem}.question-title{font-size:1.25rem}.navigation-buttons{flex-direction:column}.btn-previous,.btn-next{width:100%}}.nouvelles-lois-page{max-width:1200px;margin:0 auto;padding:2rem}.lois-header{text-align:center;margin-bottom:2rem;position:relative}.back-button{position:absolute;left:0;top:0;background:#f8f9fa;border:1px solid #dee2e6;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease}.back-button:hover{background:#e9ecef;transform:translate(-3px)}.lois-header h1{font-size:2.2rem;color:#1a1a1a;margin-bottom:.5rem}.lois-header .subtitle{font-size:1.1rem;color:#666}.category-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;justify-content:center}.category-button{background:#fff;border:2px solid #dee2e6;padding:.75rem 1.5rem;border-radius:25px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease;color:#495057}.category-button:hover{border-color:#06c;color:#06c}.category-button.active{background:linear-gradient(135deg,#06c,#004085);color:#fff;border-color:transparent}.lois-list{display:flex;flex-direction:column;gap:2rem;margin-bottom:3rem}.loi-card{background:#fff;border:1px solid #dee2e6;border-radius:12px;padding:2rem;border-left:5px solid #0066cc;transition:all .3s ease}.loi-card:hover{box-shadow:0 5px 20px #0000001a;transform:translateY(-2px)}.loi-card.priority-critique{border-left-color:#dc3545;background:#fff5f5}.loi-card.priority-haute{border-left-color:#ffc107;background:#fffef5}.loi-card.priority-moyenne{border-left-color:#17a2b8}.loi-header h3{font-size:1.5rem;color:#1a1a1a;margin-bottom:.75rem}.loi-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.loi-date{font-size:.9rem;color:#6c757d}.loi-statut{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.statut-en-vigueur{background:#d4edda;color:#155724}.statut-à-venir{background:#fff3cd;color:#856404}.loi-priorite{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.priorite-critique{background:#f8d7da;color:#721c24}.priorite-haute{background:#fff3cd;color:#856404}.priorite-moyenne{background:#d1ecf1;color:#0c5460}.loi-resume{font-size:1.1rem;font-weight:600;color:#495057;margin-bottom:1rem;line-height:1.6}.loi-description{color:#495057;line-height:1.7;margin-bottom:1.5rem}.loi-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e9ecef}.loi-section h4{font-size:1.1rem;color:#06c;margin-bottom:.75rem}.loi-section ul,.loi-section ol{padding-left:1.5rem;margin:0}.loi-section li{color:#495057;margin-bottom:.5rem;line-height:1.6}.loi-impact-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-top:1.5rem}.impact-box{padding:1rem;border-radius:8px;border-left:4px solid}.impact-positif{background:#d4edda;border-left-color:#28a745}.impact-positif h4{color:#155724}.impact-negatif{background:#fff3cd;border-left-color:#ffc107}.impact-negatif h4{color:#856404}.impact-box h4{font-size:1rem;margin-bottom:.5rem}.impact-box ul{padding-left:1.5rem;margin:0}.impact-box li{font-size:.95rem;margin-bottom:.25rem}.action-section{background:#e7f3ff;padding:1.5rem;border-radius:8px;border-left:4px solid #0066cc}.action-section h4{color:#004085}.loi-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e9ecef}.source-link{display:inline-block;color:#06c;text-decoration:none;font-weight:600;transition:all .3s ease}.source-link:hover{color:#004085;text-decoration:underline}.conseils-generaux{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;border-radius:12px}.conseils-generaux h3{font-size:1.5rem;margin-bottom:1rem}.conseils-generaux ul{list-style:none;padding:0}.conseils-generaux li{padding:.5rem 0 .5rem 1.5rem;position:relative}.conseils-generaux li:before{content:"💡";position:absolute;left:0}.loading,.error,.no-lois{text-align:center;padding:3rem;font-size:1.2rem;color:#666}.error{color:#dc3545}@media(max-width:768px){.nouvelles-lois-page{padding:1rem}.lois-header h1{font-size:1.8rem;margin-top:2.5rem}.back-button{position:static;margin-bottom:1rem;width:100%}.category-filters{flex-direction:column}.category-button{width:100%}.loi-card{padding:1.5rem}.loi-meta{flex-direction:column;gap:.5rem}.loi-impact-section{grid-template-columns:1fr}}.create-profile-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 1rem;display:flex;align-items:center;justify-content:center}.create-profile-container{max-width:800px;width:100%;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.create-profile-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem;text-align:center;position:relative}.back-to-home-btn{position:absolute;top:1rem;left:1rem;background:#fff3;border:2px solid white;color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-to-home-btn:hover{background:#fff;color:#667eea;transform:translate(-5px)}.create-profile-header h1{margin:0 0 .5rem;font-size:2.5rem}.create-profile-header p{margin:0;font-size:1.1rem;opacity:.9}.create-profile-form{padding:2rem}.form-section{margin-bottom:2.5rem}.form-section h2{font-size:1.5rem;margin-bottom:1.5rem;color:#333;display:flex;align-items:center;gap:.5rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#555}.form-group input,.form-group select{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.profile-options{display:flex;flex-direction:column;gap:1rem}.profile-option{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s;background:#fff}.profile-option:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.profile-option.selected{border-color:#667eea;background:linear-gradient(135deg,#f8f9ff,#f0f2ff);box-shadow:0 4px 12px #667eea33}.profile-option input[type=radio]{margin-top:.25rem;width:20px;height:20px;cursor:pointer;accent-color:#667eea}.option-content{flex:1}.option-label{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:.25rem}.option-description{font-size:.9rem;color:#666}.error-message{background:#fee;border:2px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center;font-weight:500}.btn.large{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s}.btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.btn.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn.primary:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.create-profile-header h1{font-size:2rem}.create-profile-form{padding:1.5rem}.profile-option{padding:1rem}}.auth-required-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 1rem;display:flex;align-items:center;justify-content:center}.auth-required-container{max-width:700px;width:100%;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.auth-required-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem;text-align:center}.auth-required-header h1{margin:0 0 .5rem;font-size:2.5rem}.auth-required-header p{margin:0;font-size:1.1rem;opacity:.9}.auth-required-content{padding:2rem}.auth-benefits{margin-bottom:2rem}.auth-benefits h2{font-size:1.3rem;color:#333;margin-bottom:1.5rem}.auth-benefits ul{list-style:none;padding:0;margin:0}.auth-benefits li{display:flex;gap:1rem;padding:1rem;margin-bottom:1rem;background:#f8f9fa;border-radius:12px;border-left:4px solid #667eea;transition:transform .3s,box-shadow .3s}.auth-benefits li:hover{transform:translate(5px);box-shadow:0 4px 12px #667eea33}.benefit-icon{font-size:2rem;flex-shrink:0}.auth-benefits li strong{display:block;color:#333;margin-bottom:.25rem;font-size:1.1rem}.auth-benefits li p{margin:0;color:#666;font-size:.9rem}.auth-actions{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.auth-divider{text-align:center;position:relative;margin:.5rem 0}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:#ddd}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-divider span{background:#fff;padding:0 1rem;color:#999;font-size:.9rem}.btn.secondary{background:#f0f0f0;color:#333}.btn.secondary:hover{background:#e0e0e0}@media(max-width:768px){.auth-required-header h1{font-size:2rem}.auth-icon{font-size:3rem}.auth-required-content{padding:1.5rem}}.auth-choice-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 1rem;display:flex;align-items:center;justify-content:center}.auth-choice-container{max-width:1000px;width:100%;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.auth-choice-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem;text-align:center}.auth-icon{font-size:4rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.auth-choice-header h1{margin:0 0 .5rem;font-size:2.5rem}.auth-choice-header p{margin:0;font-size:1.1rem;opacity:.9}.auth-choice-content{padding:2rem}.auth-options{display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;margin-bottom:2rem}.auth-option{background:#f8f9fa;border-radius:16px;padding:2rem;text-align:center;border:3px solid transparent;transition:all .3s}.auth-option:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.auth-option.create-account{border-color:#667eea}.auth-option.create-account:hover{background:linear-gradient(135deg,#667eea0d,#764ba20d)}.auth-option.login{border-color:#14b8a6}.auth-option.login:hover{background:linear-gradient(135deg,#14b8a60d,#06b6d40d)}.option-icon{font-size:3rem;margin-bottom:1rem}.auth-option h2{margin:0 0 .5rem;font-size:1.8rem;color:#333}.auth-option p{margin:0 0 1.5rem;color:#666;font-size:1rem}.option-benefits{list-style:none;padding:0;margin:0 0 2rem;text-align:left}.option-benefits li{padding:.5rem 0;color:#555;font-size:.95rem}.login-form{width:100%;text-align:left}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:600;font-size:.95rem}.form-group input{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.forgot-password-link{display:block;margin-top:.5rem;color:#667eea;font-size:.875rem;text-decoration:none;transition:color .2s}.forgot-password-link:hover{color:#764ba2;text-decoration:underline}.login-error{background:#fee;border:2px solid #fcc;color:#c33;padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;text-align:center}.login-footer{text-align:center;margin-top:1rem}.forgot-password{color:#14b8a6;text-decoration:none;font-size:.9rem;transition:color .3s}.forgot-password:hover{color:#0d9488;text-decoration:underline}.auth-divider-vertical{display:flex;align-items:center;justify-content:center;position:relative}.auth-divider-vertical:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:2px;background:linear-gradient(to bottom,transparent,#ddd,transparent)}.auth-divider-vertical span{background:#fff;padding:1rem;border-radius:50%;border:2px solid #ddd;color:#999;font-weight:600;z-index:1;width:50px;height:50px;display:flex;align-items:center;justify-content:center}.auth-back{text-align:center;margin-bottom:1.5rem}.auth-note{background:#e3f2fd;border:2px solid #90caf9;border-radius:12px;padding:1rem;text-align:center}.auth-note p{margin:0;color:#1565c0;font-size:.9rem}.auth-note strong{color:#0d47a1}.btn.large{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s;border:none;text-decoration:none;display:inline-block;text-align:center}.btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn.secondary{background:linear-gradient(135deg,#14b8a6,#06b6d4);color:#fff}.btn.secondary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #14b8a666}.btn.tertiary{background:transparent;border:2px solid #ddd;color:#666;padding:.75rem 2rem;font-size:1rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s}.btn.tertiary:hover{border-color:#667eea;color:#667eea;background:#667eea0d}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:disabled:hover{transform:none;box-shadow:none}@media(max-width:768px){.auth-options{grid-template-columns:1fr;gap:1.5rem}.auth-divider-vertical{display:none}.auth-choice-header h1{font-size:2rem}.auth-icon{font-size:3rem}.auth-choice-content,.auth-option{padding:1.5rem}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.auth-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;padding:3rem}.auth-header{text-align:center;margin-bottom:2rem;position:relative;padding-top:2.5rem}.back-button{position:absolute;left:0;top:0;background:none;border:none;color:#667eea;font-size:1rem;cursor:pointer;padding:.5rem;transition:color .2s;z-index:10}.back-button:hover{color:#764ba2}.auth-header h1{margin:0 0 1rem;color:#111827;font-size:2rem;padding-top:.5rem}.auth-header p{margin:0;color:#6b7280;line-height:1.6}.auth-form{margin-bottom:2rem}.form-group input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s;box-sizing:border-box}.auth-footer{text-align:center;padding-top:1.5rem;border-top:1px solid #e5e7eb}.auth-footer p{margin:0;color:#6b7280}.link{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s}.link:hover{color:#764ba2}.checkbox-group{margin-bottom:1.5rem}.checkbox-label{display:flex;align-items:flex-start;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:20px;height:20px;margin-right:.75rem;margin-top:2px;cursor:pointer;flex-shrink:0}.checkbox-label span{color:#374151;line-height:1.6;font-size:.95rem}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed}.forgot-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.forgot-password-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;padding:3rem}.forgot-password-header{text-align:center;margin-bottom:2rem}.forgot-password-icon{font-size:4rem;margin-bottom:1rem}.forgot-password-header h1{margin:0 0 1rem;color:#111827;font-size:2rem}.forgot-password-header p{margin:0;color:#6b7280;line-height:1.6}.forgot-password-form{margin-bottom:2rem}.submit-button{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.forgot-password-footer{text-align:center;padding-top:1.5rem;border-top:1px solid #e5e7eb}.success-icon{font-size:5rem;text-align:center;margin-bottom:1rem}.success-message{text-align:center;color:#059669;font-size:1.125rem;margin-bottom:2rem;line-height:1.6}.success-instructions{background:#f0f9ff;border-left:4px solid #0ea5e9;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.success-instructions h3{margin:0 0 1rem;color:#0c4a6e}.success-instructions ol{margin:0 0 1rem;padding-left:1.5rem;color:#0c4a6e;line-height:1.8}.success-instructions .note{margin:1rem 0 0;padding-top:1rem;border-top:1px solid #bae6fd;color:#075985;font-size:.875rem}.back-button{display:inline-block;padding:.75rem 1.5rem;background:#667eea;color:#fff;text-decoration:none;border-radius:8px;font-weight:500;transition:all .2s}.back-button:hover{background:#764ba2;transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.reset-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.reset-password-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;padding:3rem}.reset-password-header{text-align:center;margin-bottom:2rem}.reset-password-icon,.loading-icon,.error-icon,.success-icon{font-size:4rem;margin-bottom:1rem;text-align:center}.reset-password-header h1,.reset-password-container h1{margin:0 0 1rem;color:#111827;font-size:2rem;text-align:center}.reset-password-header p,.reset-password-container>p{margin:0;color:#6b7280;line-height:1.6;text-align:center}.reset-password-form{margin-bottom:2rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500}.form-group input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f3f4f6;cursor:not-allowed}.field-hint{display:block;margin-top:.5rem;color:#6b7280;font-size:.875rem}.submit-button,.primary-button{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;text-decoration:none;display:inline-block;text-align:center}.submit-button:hover:not(:disabled),.primary-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.secondary-button{width:100%;padding:1rem;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;text-align:center;margin-top:1rem}.secondary-button:hover{background:#f3f4f6}.error-message{background:#fee2e2;border-left:4px solid #ef4444;color:#991b1b;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.reset-password-footer{text-align:center;padding-top:1.5rem;border-top:1px solid #e5e7eb}.back-link{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s}.back-link:hover{color:#764ba2}.error-text{color:#dc2626;font-size:1.125rem;margin-bottom:2rem}.error-actions{display:flex;flex-direction:column;gap:1rem}.success-message{color:#059669;font-size:1.125rem;margin-bottom:1.5rem}.redirect-message{color:#6b7280;font-size:.875rem;margin-bottom:2rem;font-style:italic}.privacy-policy-page{max-width:900px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.privacy-header{text-align:center;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--gray-200)}.privacy-header h1{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.last-updated{font-size:.875rem;color:var(--gray-500);font-style:italic;margin-bottom:1rem}.btn-print{background-color:#2563eb;color:#fff;border:2px solid #2563eb;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:1rem}.btn-print:hover{background-color:#1e40af;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}@media print{.btn-print{display:none}.privacy-header{border-bottom:2px solid #2563eb}}.privacy-content{line-height:1.8}.privacy-intro{font-size:1.125rem;color:var(--gray-700);margin-bottom:2rem;padding:1.5rem;background:var(--gray-50);border-left:4px solid var(--primary);border-radius:8px}.privacy-section{margin-bottom:2.5rem}.privacy-section h2{font-size:1.75rem;font-weight:600;color:var(--gray-900);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--gray-200)}.privacy-section h3{font-size:1.25rem;font-weight:600;color:var(--gray-800);margin-top:1.5rem;margin-bottom:.75rem}.privacy-section p{color:var(--gray-700);margin-bottom:1rem}.privacy-section ul{list-style:none;padding-left:0;margin-bottom:1rem}.privacy-section li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;color:var(--gray-700)}.privacy-section li:before{content:"•";position:absolute;left:0;color:var(--primary);font-weight:700;font-size:1.25rem}.privacy-section.highlight{background:linear-gradient(135deg,#e0f2fe,#dbeafe);padding:2rem;border-radius:12px;border:2px solid #3b82f6}.privacy-section.highlight h2{color:#1e40af;border-bottom-color:#3b82f6}.privacy-section.highlight h3{color:#1e3a8a}.contact-info{background:var(--gray-50);padding:1rem;border-radius:8px;margin-top:1rem}.contact-info a{color:var(--primary);text-decoration:none;font-weight:600}.contact-info a:hover{text-decoration:underline}.privacy-section a{color:var(--primary);text-decoration:none;font-weight:500}.privacy-section a:hover{text-decoration:underline}.privacy-footer{text-align:center;margin-top:3rem;padding-top:2rem;border-top:2px solid var(--gray-200)}.privacy-footer .btn{padding:.75rem 2rem;font-size:1rem}.legal-protection-section .important-box{background-color:#dbeafe;border-left:4px solid #2563eb;padding:1.5rem;border-radius:8px;margin:1.5rem 0}@media(max-width:768px){.privacy-policy-page{padding:1rem}.privacy-header h1{font-size:2rem}.privacy-section h2{font-size:1.5rem}.privacy-section h3{font-size:1.125rem}}.terms-container{min-height:100vh;background-color:#f5f5f5}.terms-header{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;padding:3rem 2rem 2rem;text-align:center}.back-link{display:inline-block;color:#fff;text-decoration:none;margin-bottom:1rem;font-size:.95rem;opacity:.9;transition:opacity .2s}.back-link:hover{opacity:1;text-decoration:underline}.terms-header h1{font-size:2.5rem;margin:0 0 .5rem;font-weight:700}.last-update{font-size:.9rem;opacity:.9;font-style:italic;margin-bottom:1rem}.btn-print{background-color:#fff;color:#2563eb;border:2px solid white;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:1rem}.btn-print:hover{background-color:#f0f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}@media print{.back-link,.btn-print{display:none}.terms-header{background:#fff;color:#000;border-bottom:2px solid #2563eb}.terms-container{background:#fff}}.terms-content{max-width:900px;margin:0 auto;padding:2rem;background:#fff;box-shadow:0 2px 8px #0000001a}.important-box{background-color:#fee2e2;border-left:4px solid #dc2626;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.important-box h2{color:#991b1b;font-size:1.25rem;margin:0 0 1rem}.important-box p{color:#991b1b;margin:0;line-height:1.6}.warning-box{background-color:#fef3c7;border-left:4px solid #f59e0b;padding:1.5rem;border-radius:8px;margin:1rem 0}.warning-box p,.warning-box ul{margin:.5rem 0}.warning-text{font-weight:600;color:#92400e}section{margin-bottom:2.5rem}section h2{color:#1e40af;font-size:1.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #dbeafe}section p{line-height:1.8;color:#333;margin-bottom:1rem}section ul{line-height:1.8;color:#333;margin-left:1.5rem;margin-bottom:1rem}section li{margin-bottom:.5rem}.contact-box{background-color:#f9fafb;border:1px solid #e5e7eb;padding:1.5rem;border-radius:8px;margin-top:1rem}.contact-box p{margin:.5rem 0}.footer-note{margin-top:3rem;padding:1.5rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:8px;text-align:center}.footer-note p{color:#1e40af;font-style:italic;margin:0;line-height:1.6}.legal-protection-section .important-box{background-color:#dbeafe;border-left:4px solid #2563eb}.legal-protection-section .important-box h3{color:#1e40af;font-size:1.1rem;margin:0 0 .75rem}.legal-protection-section .important-box p,.legal-protection-section .important-box ul{color:#1e3a8a}.protection-box{background-color:#f0fdf4;border-left:4px solid #16a34a;padding:1.5rem;border-radius:8px;margin:1.5rem 0}.protection-box h3{color:#15803d;font-size:1.1rem;margin:0 0 .75rem}.protection-box p,.protection-box ul{color:#166534;margin:.5rem 0}.retention-box{background-color:#fef3c7;border-left:4px solid #f59e0b;padding:1.5rem;border-radius:8px;margin:1.5rem 0}.retention-box h3{color:#92400e;font-size:1.1rem;margin:0 0 .75rem}.retention-box p{color:#92400e;margin:0}@media(max-width:768px){.terms-header{padding:2rem 1rem 1.5rem}.terms-header h1{font-size:1.75rem}.terms-content{padding:1.5rem}section h2{font-size:1.25rem}}.admin-dashboard{max-width:1400px;margin:0 auto;padding:2rem}.admin-header{margin-bottom:2rem}.admin-header h1{margin:0 0 .5rem;color:#111827;font-size:2.5rem}.admin-header p{margin:0;color:#6b7280;font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.quick-actions{margin-bottom:3rem}.quick-actions h2{margin:0 0 1rem;color:#111827;font-size:1.5rem}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.action-btn{background:#fff;border:2px solid #e5e7eb;padding:1.25rem;border-radius:12px;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .2s;font-size:1rem;font-weight:500;color:#374151}.action-btn:hover{border-color:#3b82f6;background:#f0f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f633}.action-icon{font-size:2rem}.action-btn span:last-child{flex:1;text-align:left}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 6px #0000001a;transition:transform .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.stat-icon{font-size:3rem}.stat-content h3{margin:0 0 .5rem;font-size:.9rem;opacity:.9;font-weight:500}.stat-value{margin:0;font-size:2.5rem;font-weight:700}.stats-section{margin-bottom:3rem}.stats-section h2{margin:0 0 1.5rem;color:#111827;font-size:1.5rem}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.mini-stat-card{background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:1.5rem;text-align:center;transition:all .2s}.mini-stat-card:hover{border-color:#667eea;box-shadow:0 4px 6px #667eea1a}.mini-stat-card h4{margin:0 0 .5rem;color:#6b7280;font-size:.9rem;font-weight:500}.mini-stat-value{margin:0;font-size:2rem;font-weight:700;color:#667eea}.users-section{margin-bottom:3rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0;color:#111827;font-size:1.5rem}.view-all-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.view-all-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.users-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.users-table tbody tr:hover{background:#f9fafb}.view-btn{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}@media(max-width:768px){.admin-dashboard{padding:1rem}.stats-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.users-table{overflow-x:auto}}.admin-users{max-width:1600px;margin:0 auto;padding:2rem}.filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-box{flex:1;min-width:300px}.search-box input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s}.search-box input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filters select{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s}.filters select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.users-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.users-table table{width:100%;border-collapse:collapse}.users-table thead{background:#f9fafb}.users-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;white-space:nowrap}.users-table td{padding:1rem;border-bottom:1px solid #e5e7eb;color:#6b7280}.users-table tbody tr.clickable-row{cursor:pointer;transition:all .2s}.users-table tbody tr.clickable-row:hover{background:#f0f9ff;transform:scale(1.01);box-shadow:0 2px 8px #2563eb1a}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge.active{background:#d1fae5;color:#065f46}.badge.inactive{background:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:.5rem}.view-btn{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.view-btn:hover{background:#5568d3}.delete-btn{background:#dc2626;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.no-results{text-align:center;padding:3rem;color:#6b7280}.no-results p{margin:0;font-size:1.1rem}@media(max-width:1024px){.users-table{overflow-x:auto}.users-table table{min-width:1000px}}@media(max-width:768px){.admin-users{padding:1rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.filters{flex-direction:column}.search-box{min-width:100%}.filters select{width:100%}.action-buttons{flex-direction:column}}.admin-user-details{max-width:1200px;margin:0 auto;padding:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{margin:0 0 .5rem;color:#111827;font-size:2rem}.admin-header p{margin:0;color:#6b7280;font-size:1rem}.back-btn{background:#6b7280;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.back-btn:hover{background:#4b5563}.user-info{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 4px #0000001a}.info-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #e5e7eb}.info-section:last-of-type{border-bottom:none}.info-section h2{margin:0 0 1.5rem;color:#111827;font-size:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item label{display:block;margin-bottom:.5rem;color:#6b7280;font-size:.9rem;font-weight:600}.info-item p{margin:0;color:#111827;font-size:1.1rem}.action-buttons{display:flex;gap:1rem;margin-top:2rem}.edit-btn{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.edit-btn:hover{background:#5568d3}.delete-btn{background:#dc2626;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.delete-btn:hover{background:#b91c1c}.edit-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 4px #0000001a}.form-section h2{margin:0 0 1.5rem;color:#111827;font-size:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:600}.form-group input,.form-group select{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-actions{display:flex;gap:1rem;margin-top:2rem}.save-btn{background:#10b981;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.save-btn:hover{background:#059669}.cancel-btn{background:#6b7280;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#4b5563}.loading,.error-message{text-align:center;padding:3rem}.error-message h2{color:#dc2626;margin-bottom:1rem}.error-message button{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;margin-top:1rem}@media(max-width:768px){.admin-user-details{padding:1rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.info-grid{grid-template-columns:1fr}.action-buttons,.form-actions{flex-direction:column}.action-buttons button,.form-actions button{width:100%}}.admin-consents-page{max-width:1400px;margin:0 auto;padding:2rem}.admin-consents-header{margin-bottom:2rem}.admin-consents-header h1{margin:0 0 .5rem;color:#1e293b;font-size:2rem}.admin-consents-subtitle{color:#64748b;margin:0 0 1rem}.admin-back-link{display:inline-block;color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s}.admin-back-link:hover{color:#2563eb}.admin-consents-content{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.consent-search-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #e5e7eb}.consent-search-section h2{margin:0 0 1rem;color:#1e293b;font-size:1.5rem}.consent-search-form{display:flex;gap:1rem;max-width:600px}.consent-search-input{flex:1;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s}.consent-search-input:focus{outline:none;border-color:#3b82f6}.consent-search-btn{padding:.75rem 2rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.consent-search-btn:hover:not(:disabled){background:#2563eb}.consent-search-btn:disabled{opacity:.5;cursor:not-allowed}.consent-debug-btn{padding:.75rem 1.5rem;background:#f59e0b;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.consent-debug-btn:hover:not(:disabled){background:#d97706}.consent-debug-btn:disabled{opacity:.5;cursor:not-allowed}.consent-error{background:#fef2f2;border-left:4px solid #dc2626;padding:1rem;border-radius:8px;color:#dc2626;margin-bottom:1.5rem}.consent-results{margin-bottom:2rem}.consent-results-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.consent-results h3{margin:0 0 .5rem;color:#1e293b}.consent-count{color:#64748b;margin:0}.btn-download-pdf{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #10b9814d;white-space:nowrap}.btn-download-pdf:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-download-pdf:active{transform:translateY(0)}.no-consents{color:#64748b;font-style:italic;padding:2rem;text-align:center;background:#f9fafb;border-radius:8px}.consents-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb}.consents-table{width:100%;border-collapse:collapse;font-size:.875rem}.consents-table thead{background:#f9fafb}.consents-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.consents-table td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;color:#1e293b}.consents-table tbody tr:hover{background:#f9fafb}.consent-date{white-space:nowrap;font-weight:500}.consent-ip code{background:#f1f5f9;padding:.25rem .5rem;border-radius:4px;font-size:.8125rem;color:#0f172a}.consent-type-badge{display:inline-block;padding:.25rem .75rem;background:#dbeafe;color:#1e40af;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.consent-description{font-size:.9rem;color:#4b5563;font-style:italic}.consent-fingerprint code{background:#fef3c7;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;color:#92400e}.consent-useragent small{color:#64748b}.consent-info-box{background:#f0f9ff;border-left:4px solid #3b82f6;padding:1.5rem;border-radius:8px}.consent-info-box h3{margin:0 0 1rem;color:#1e40af}.consent-info-box ul{margin:0;padding-left:1.5rem;color:#374151}.consent-info-box li{margin-bottom:.5rem;line-height:1.6}@media(max-width:768px){.admin-consents-page{padding:1rem}.admin-consents-content{padding:1.5rem}.consent-search-form{flex-direction:column}.consent-search-btn{width:100%}.consent-results-header{flex-direction:column;align-items:stretch}.btn-download-pdf{width:100%}.consents-table{font-size:.75rem}.consents-table th,.consents-table td{padding:.5rem}}:root{--sidebar-width: 280px;--primary: #0f766e;--primary-hover: #0d9488;--primary-light: #14b8a6;--primary-lighter: #ccfbf1;--primary-dark: #115e59;--accent: #0891b2;--accent-light: #06b6d4;--btn-login: #10b981;--btn-login-hover: #059669;--btn-login-light: #34d399;--btn-lang: #64748b;--btn-lang-hover: #475569;--btn-lang-active: #10b981;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}.app-layout{display:flex;flex-direction:column;min-height:100vh;background:var(--gray-50)}.sidebar{width:var(--sidebar-width);background:#fff;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;position:fixed;top:64px;left:0;height:calc(100vh - 64px);overflow-y:auto;z-index:100;transition:transform .3s ease}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--gray-200)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;color:var(--primary)}.sidebar-brand{font-size:1.125rem;font-weight:var(--font-bold);color:var(--gray-900)}.sidebar-tagline{font-size:.75rem;color:var(--gray-600)}.sidebar-nav{flex:1;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--gray-700);font-weight:var(--font-medium);text-decoration:none;transition:all .2s ease;cursor:pointer;position:relative}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.sidebar-label{flex:1}.sidebar-item:hover{background:var(--gray-100);color:var(--primary)}.sidebar-item.active{background:linear-gradient(135deg,var(--primary-lighter) 0%,#a7f3d0 100%);color:var(--primary-dark);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.sidebar-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:60%;background:var(--primary);border-radius:0 4px 4px 0}.sidebar-divider{height:1px;background:var(--gray-200);margin:var(--space-4) var(--space-6)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--gray-200);display:flex;flex-direction:column;gap:var(--space-3)}.sidebar-language{display:flex;gap:var(--space-2)}.lang-btn{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-lg);background:#fff;color:var(--btn-lang);cursor:pointer;font-size:.875rem;font-weight:var(--font-semibold);transition:all .2s ease;min-width:44px;height:36px;display:flex;align-items:center;justify-content:center}.lang-btn:hover{background:var(--gray-100);color:var(--btn-lang-hover);border-color:var(--btn-lang)}.lang-btn.active{background:var(--btn-lang-active);color:#fff;border-color:var(--btn-lang-active);box-shadow:var(--shadow-sm)}.sidebar-mobile-toggle{display:none;position:fixed;top:1.25rem;left:1rem;z-index:250;background:transparent;color:var(--gray-700);border:none;padding:.5rem;border-radius:var(--radius-md);font-size:1.5rem;cursor:pointer;transition:background .2s}.sidebar-mobile-toggle:hover{background:var(--gray-100)}.sidebar-overlay{display:none}.app-header{background:#fff;border-bottom:1px solid var(--gray-200);position:fixed;top:0;left:0;right:0;z-index:200;box-shadow:var(--shadow-sm);transition:all var(--transition-slow)}.header-content{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);max-width:100%;height:64px}.header-logo{display:flex;align-items:center;gap:var(--space-3)}.header-brand-text{display:flex;flex-direction:column}.header-brand{font-size:1.25rem;font-weight:var(--font-bold);color:var(--gray-900);line-height:1.2}.header-tagline{font-size:.75rem;color:var(--gray-500);font-weight:var(--font-medium)}.header-actions{display:flex;align-items:center;gap:var(--space-4)}.header-language{display:flex;gap:var(--space-2);padding:4px;background:var(--gray-100);border-radius:var(--radius-lg)}.header-user{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--gray-50);border-radius:var(--radius-lg)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);font-size:.875rem}.user-name{font-size:.875rem;font-weight:var(--font-medium);color:var(--gray-700)}.header-auth{display:flex;align-items:center}.header-auth-desktop-only{display:none!important}.breadcrumb{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200);font-size:.875rem;position:fixed;top:64px;left:var(--sidebar-width);right:0;z-index:40;height:40px;transition:all .3s ease}.breadcrumb-segment{display:flex;align-items:center;gap:.5rem}.breadcrumb-item{color:var(--gray-600);text-decoration:none;transition:color .2s ease;display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem;border-radius:var(--radius-md);font-weight:var(--font-medium)}.breadcrumb-item:hover{color:var(--primary);background:var(--gray-100)}.breadcrumb-item.active{color:var(--primary-dark);font-weight:var(--font-semibold);background:var(--primary-lighter)}.breadcrumb-home-icon{width:16px;height:16px}.breadcrumb-text{display:inline}.breadcrumb-separator{color:var(--gray-400);width:16px;height:16px;flex-shrink:0}.main-wrapper{flex:1;margin-left:var(--sidebar-width);margin-top:104px;display:flex;flex-direction:column;min-height:calc(100vh - 104px)}.main-content{flex:1;padding:var(--space-8);max-width:1400px;width:100%;margin:0 auto}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:2rem;font-weight:var(--font-bold);color:var(--gray-900);margin-bottom:var(--space-3)}.page-description{font-size:1.125rem;color:var(--gray-600)}.section-title{font-size:1.5rem;font-weight:var(--font-semibold);color:var(--gray-900);margin-bottom:var(--space-6)}.footer{background:#fff;border-top:1px solid var(--gray-200);padding:var(--space-8) var(--space-6);margin-top:auto}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);max-width:1400px;margin:0 auto}.footer-section h3,.footer-section h4{color:var(--gray-900);margin-bottom:var(--space-3)}.footer-section p,.footer-section a{color:var(--gray-600);text-decoration:none}.footer-section ul{list-style:none;padding:0}.footer-section li{margin-bottom:var(--space-2)}.footer-section a:hover{color:var(--primary)}.footer-bottom{text-align:center;margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--gray-200);color:var(--gray-600);font-size:.875rem}@media(max-width:1024px){.sidebar{transform:translate(-100%);top:104px;z-index:200}.sidebar-mobile-open{transform:translate(0)}.sidebar-mobile-toggle{display:block}.sidebar-overlay{display:block;position:fixed;inset:104px 0 0;background:#00000080;z-index:150}.breadcrumb{left:0;padding:.5rem 1rem .5rem 4rem}.main-wrapper{margin-left:0}.main-content{padding:var(--space-6) var(--space-4)}.header-content{padding:var(--space-3) var(--space-4);padding-left:4rem}.header-logo svg{width:36px;height:36px}.header-brand{font-size:1.1rem}.header-tagline{font-size:.7rem}.header-user .user-name{display:none}}@media(max-width:640px){.header-content{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:space-between;padding:.5rem .5rem .5rem 3rem;gap:.5rem;height:56px;overflow:visible;min-width:0}.header-logo{display:flex;align-items:center;gap:0;flex-shrink:0;min-width:32px}.header-logo svg{width:32px;height:32px;flex-shrink:0}.header-brand-text{display:none!important}.header-actions{display:flex;flex-direction:row;align-items:center;gap:.375rem;flex-shrink:0;flex-wrap:nowrap;min-width:0}.header-language{display:flex;flex-direction:row;gap:2px;padding:2px;background:var(--gray-100);border-radius:6px;flex-shrink:0;align-items:center}.lang-btn,.header-auth .btn-login,.header-auth .btn-logout-mobile{padding:.5rem .75rem!important;font-size:.75rem!important;font-weight:var(--font-bold)!important;min-width:44px!important;max-width:44px!important;min-height:36px!important;max-height:36px!important;height:36px!important;border-radius:6px!important;flex-shrink:0!important;display:flex!important;align-items:center!important;justify-content:center!important;white-space:nowrap!important;box-sizing:border-box!important}.lang-btn.active{background:var(--btn-lang-active);color:#fff}.header-user{display:none!important}.header-auth{display:flex;flex-shrink:0;align-items:center}.header-auth-desktop-only{display:flex!important}.btn-logout-mobile{background:#ef4444!important;color:#fff!important;border:none!important;cursor:pointer!important;font-size:1.25rem!important;padding:.5rem!important;transition:background .2s!important}.btn-logout-mobile:hover{background:#dc2626!important}.main-content{padding:var(--space-4) var(--space-3)}.sidebar-mobile-toggle{display:block;top:.875rem;left:.5rem;padding:.375rem;font-size:1.25rem}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;padding:4rem 2rem;border-radius:var(--radius-xl);margin-bottom:var(--space-8);text-align:center;box-shadow:var(--shadow-lg)}.hero-title{font-size:3rem;font-weight:var(--font-bold);margin-bottom:var(--space-4);line-height:1.2}@media(max-width:768px){.hero-title{font-size:2rem}}@media(max-width:480px){.hero-title{font-size:1.5rem}}.gradient-text{background:linear-gradient(135deg,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;margin-bottom:var(--space-6);opacity:.9}.cta-button{display:inline-block;background:#fff;color:var(--primary);padding:1rem 2rem;border-radius:var(--radius-lg);font-weight:var(--font-semibold);text-decoration:none;transition:transform .2s}.cta-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0003}.steps-section{margin-bottom:var(--space-8)}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6)}.step-card{background:#fff;padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--gray-200);text-align:center}.step-icon{font-size:3rem;margin-bottom:var(--space-4)}.quick-links-section{margin-bottom:var(--space-8)}.quick-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.quick-link-card{background:#fff;padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--gray-200);text-decoration:none;color:var(--gray-900);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);transition:all .2s}.quick-link-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 4px 12px #2563eb1a}.quick-link-icon{font-size:2.5rem}.quick-link-text{font-weight:var(--font-semibold)}.explorer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-6)}.explorer-card{background:#fff;padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--gray-200);text-decoration:none;color:var(--gray-900);transition:all .2s;display:flex;flex-direction:column}.explorer-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 16px #2563eb26}.explorer-card-icon{font-size:3rem;margin-bottom:var(--space-4)}.explorer-card-title{font-size:1.25rem;font-weight:var(--font-semibold);margin-bottom:var(--space-3)}.explorer-card-description{color:var(--gray-600);margin-bottom:var(--space-4);flex:1}.explorer-card-footer{display:flex;justify-content:flex-start}.explorer-card-badge{background:var(--primary-lighter);color:var(--primary);padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:var(--font-medium)}.demarches-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-6)}.demarche-card{background:#fff;padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--gray-200);cursor:pointer;transition:all .3s ease;display:block;color:inherit}.demarche-card-icon{font-size:3rem;margin-bottom:var(--space-4)}.demarche-card-title{font-size:1.25rem;font-weight:var(--font-semibold);margin-bottom:var(--space-3)}.demarche-card-description{color:var(--gray-600);margin-bottom:var(--space-4)}.demarche-details{margin-top:var(--space-4)}.demarche-summary{cursor:pointer;padding:var(--space-3);background:var(--gray-100);border-radius:var(--radius-lg);font-weight:var(--font-medium);color:var(--primary)}.demarche-summary:hover{background:var(--primary-lighter)}.demarche-content{padding:var(--space-4);margin-top:var(--space-3)}.compte-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.compte-card{background:#fff;padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--gray-200);text-decoration:none;color:var(--gray-900);transition:all .2s;display:flex;flex-direction:column;align-items:center;text-align:center}.compte-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 16px #2563eb26}.compte-card-icon{font-size:3rem;margin-bottom:var(--space-4)}.compte-card-title{font-size:1.125rem;font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.compte-card-description{color:var(--gray-600);font-size:.875rem}.dashboard-preview{background:#fff;padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.profil-form,.parametres-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-weight:var(--font-medium);color:var(--gray-700)}.form-group input,.form-group select{padding:var(--space-3);border:1px solid var(--gray-200);border-radius:var(--radius-lg);font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-lighter)}.form-group.checkbox{flex-direction:row;align-items:center}.form-group.checkbox input{width:auto;margin-right:var(--space-2)}.save-button{background:var(--primary);color:#fff;padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-lg);font-weight:var(--font-semibold);cursor:pointer;transition:all .2s}.save-button:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-lg);font-weight:var(--font-semibold);font-size:.875rem;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap}.btn.primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff;box-shadow:var(--shadow-sm)}.btn.primary:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn.secondary{background:#fff;color:var(--primary);border:2px solid var(--primary)}.btn.secondary:hover{background:var(--primary-lighter)}.btn-login{background:linear-gradient(135deg,var(--btn-login) 0%,var(--btn-login-light) 100%);color:#fff;box-shadow:var(--shadow-md);font-weight:var(--font-bold);min-width:44px;height:36px;display:flex;align-items:center;justify-content:center}.btn-login:hover{background:linear-gradient(135deg,var(--btn-login-hover) 0%,var(--btn-login) 100%);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-logout{background:#fff;color:var(--btn-login);border:2px solid var(--btn-login)}.btn-logout:hover{background:#d1fae5;border-color:var(--btn-login-hover);color:var(--btn-login-hover)}.btn.danger{background:#ef4444;color:#fff}.btn.danger:hover{background:#dc2626}.btn.small{padding:var(--space-2) var(--space-4);font-size:.8125rem}.btn.large{padding:var(--space-4) var(--space-8);font-size:1rem}.grid{display:grid;gap:var(--space-6)}.grid.two{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid.three{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid.four{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.feature-card,.quick-link-card,.tool-card,.demarche-card,.account-card{background:#fff;padding:var(--space-6);border-radius:var(--radius-xl);border:1px solid var(--gray-200);transition:all .3s ease;cursor:pointer;text-decoration:none;color:inherit;display:block}.feature-card:hover,.quick-link-card:hover,.tool-card:hover,.demarche-card:hover,.account-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.feature-icon,.quick-link-icon,.tool-icon,.demarche-icon,.account-icon{font-size:2.5rem;margin-bottom:var(--space-4);display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:linear-gradient(135deg,var(--primary-lighter) 0%,#a7f3d0 100%);border-radius:var(--radius-lg)}.quick-link-card,.account-card{display:flex;align-items:center;gap:var(--space-4)}.badge{display:inline-block;padding:var(--space-2) var(--space-3);background:var(--primary-lighter);color:var(--primary-dark);border-radius:var(--radius-md);font-size:.75rem;font-weight:var(--font-semibold);margin-top:var(--space-3)}.badge.official{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.section{margin-bottom:var(--space-8)}.section-title{font-size:1.75rem;font-weight:var(--font-bold);color:var(--gray-900);margin-bottom:var(--space-6)}.page-container{padding:var(--space-6)}.page-title{font-size:2.5rem;font-weight:var(--font-bold);color:var(--gray-900);margin-bottom:var(--space-3)}.page-description{font-size:1.125rem;color:var(--gray-600);margin-bottom:var(--space-8)}@media(max-width:1024px){.hero{padding:3rem 1.5rem}.steps-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.hero{padding:2.5rem 1.25rem}.hero-title{font-size:2.25rem}.steps-grid{grid-template-columns:1fr}.quick-links-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.btn-login:not(.header-auth .btn-login),.btn-logout:not(.header-auth .btn-logout-mobile){padding:.5rem .75rem;font-size:.875rem}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:1rem}.page-title{font-size:1.75rem}.page-description{font-size:1rem}.hero{padding:2rem 1rem}.quick-links-grid{grid-template-columns:1fr;gap:var(--space-3)}.section-title{font-size:1.25rem}.cta-button{padding:.875rem 1.5rem;font-size:.9375rem}}.resource-card{background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-6);transition:all .3s ease;display:flex;flex-direction:column;height:100%}.resource-card:hover{border-color:var(--primary);box-shadow:0 8px 24px #2563eb26;transform:translateY(-4px)}.resource-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:2px solid var(--gray-100)}.resource-icon{font-size:2.5rem;display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:linear-gradient(135deg,var(--primary-lighter) 0%,#a7f3d0 100%);border-radius:var(--radius-lg);flex-shrink:0}.resource-header h3{font-size:1.5rem;color:var(--gray-900);margin:0;font-weight:var(--font-bold)}.resource-list{list-style:none;padding:0;margin:0 0 var(--space-6) 0;flex-grow:1}.resource-list li{padding:var(--space-3) 0;color:var(--gray-700);border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:var(--space-2)}.resource-list li:last-child{border-bottom:none}.resource-list li:before{content:"✓";color:var(--primary);font-weight:var(--font-bold);font-size:1.25rem}.resource-card .btn{margin-top:auto;width:100%;text-align:center;text-decoration:none;display:inline-block}.help-section{margin-top:var(--space-8)}.help-card{background:linear-gradient(135deg,var(--primary-lighter) 0%,#dbeafe 100%);border:2px solid var(--primary-light);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center}.help-card h2{font-size:2rem;color:var(--gray-900);margin:0 0 var(--space-4) 0}.help-card p{font-size:1.125rem;color:var(--gray-700);margin:0 0 var(--space-6) 0;max-width:600px;margin-left:auto;margin-right:auto}@media(max-width:768px){.header-content{display:flex!important;align-items:center!important;justify-content:space-between!important}.header-actions{display:flex!important;align-items:center!important;gap:.375rem!important}.header-language,.header-auth{display:flex!important;align-items:center!important}.header-actions .header-language .lang-btn,.app-header .header-content .header-actions .lang-btn{min-width:44px!important;max-width:44px!important;width:44px!important;min-height:36px!important;max-height:36px!important;height:36px!important;padding:.5rem .75rem!important;margin:0!important;font-size:.75rem!important;font-weight:600!important;line-height:1!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;border-radius:6px!important;white-space:nowrap!important;box-sizing:border-box!important;transform:none!important}.header-actions .header-auth .btn-login,.app-header .header-content .header-actions .btn-login{min-width:85px!important;max-width:85px!important;width:85px!important;min-height:36px!important;max-height:36px!important;height:36px!important;padding:.5rem .75rem!important;margin:0!important;font-size:.75rem!important;font-weight:600!important;line-height:1!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;border-radius:6px!important;white-space:nowrap!important;box-sizing:border-box!important;transform:none!important}.header-actions .header-auth .btn-logout-mobile,.app-header .header-content .header-actions .btn-logout-mobile{min-width:44px!important;max-width:44px!important;width:44px!important;min-height:36px!important;max-height:36px!important;height:36px!important;padding:.5rem .75rem!important;margin:0!important;font-size:.75rem!important;font-weight:600!important;line-height:1!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;border-radius:6px!important;white-space:nowrap!important;box-sizing:border-box!important;transform:none!important}.header-actions .header-auth .btn-logout-mobile,.app-header .header-content .header-actions .btn-logout-mobile{font-size:1.25rem!important;padding:.5rem!important;background:#ef4444!important;color:#fff!important;border:none!important}.btn-logout-mobile:hover{background:#dc2626!important}.header-actions .lang-btn:hover,.header-actions .btn-login:hover,.header-actions .btn-logout-mobile:hover{transform:none!important}}@media(max-width:640px){.header-content{padding:.5rem .5rem .5rem 3rem!important}.header-actions{gap:.375rem!important}}:root{--bg: #f7f7fb;--card: #ffffff;--border: #e5e7eb;--text: #111827;--muted: #6b7280;--primary: #2563eb;--primary-hover: #1d4ed8}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}.container{max-width:920px;margin:0 auto;padding:16px}.header{display:flex;gap:10px;align-items:baseline;justify-content:space-between;margin-bottom:14px}.title{font-size:24px;margin:0}.subtitle{margin:0;color:var(--muted);font-size:14px}.grid{display:grid;gap:14px}@media(min-width:860px){.grid.two{grid-template-columns:1.1fr .9fr;align-items:start}}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:0 1px 2px #0000000d}.card h2,.card h3{margin:0 0 10px;font-size:18px}.divider{height:1px;background:var(--border);margin:12px 0}.btn{background:var(--primary);color:#fff;border:none;border-radius:10px;padding:10px 12px;cursor:pointer;font-weight:600}.btn:hover{background:var(--primary-hover)}.btn.secondary{background:#111827}.btn.secondary:hover{background:#0b1220}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.small{font-size:12px;color:var(--muted)}@media(max-width:768px){.container{padding:12px}.title{font-size:20px}.card{padding:12px}.btn{padding:8px 10px;font-size:14px}.row{flex-direction:column;align-items:stretch}}@media(max-width:480px){.container{padding:8px}.title{font-size:18px}.card{padding:10px}.card h2,.card h3{font-size:16px}}.grid{display:grid;gap:var(--space-6, 1.5rem)}.grid-1{grid-template-columns:1fr}.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card{padding:var(--space-6, 1.5rem);border-radius:var(--radius-lg, .75rem);background:#fff;border:1px solid var(--gray-200, #e2e8f0)}.text-responsive{font-size:clamp(.875rem,2vw,1rem)}.heading-responsive{font-size:clamp(1.5rem,4vw,2.5rem)}.section-spacing{padding:clamp(2rem,5vw,4rem) clamp(1rem,3vw,2rem)}@media(max-width:768px){button,.btn,a.btn{min-height:44px;min-width:44px;padding:.75rem 1rem}.sidebar-item,.nav-item{min-height:48px}.grid{gap:var(--space-4, 1rem)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.card{padding:var(--space-4, 1rem)}body,input,select,textarea{font-size:16px}}@media(max-width:480px){.grid{gap:var(--space-3, .75rem)}.card{padding:var(--space-3, .75rem)}.section-title{font-size:1.25rem}.page-title{font-size:1.5rem}}@media(min-width:769px)and (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-height:500px)and (orientation:landscape){.sidebar{height:100vh;overflow-y:auto}.main-content{padding:var(--space-4, 1rem)}}@media print{.sidebar,.header,.footer,.sidebar-mobile-toggle,button{display:none!important}.main-wrapper{margin-left:0!important;margin-top:0!important}}@media(max-width:768px){.header-actions .lang-btn,.header-actions .btn-login,.header-auth .btn-login,.header-auth .btn-logout-mobile{min-height:36px!important;max-height:36px!important;height:36px!important;min-width:44px!important;max-width:44px!important;padding:.5rem .75rem!important;font-size:.75rem!important;border-radius:6px!important;font-weight:600!important;flex-shrink:0!important;white-space:nowrap!important;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important}.header-auth .btn-logout-mobile{font-size:1.25rem!important;padding:.5rem!important;min-width:44px!important;max-width:44px!important;height:36px!important}button:not(.lang-btn):not(.header-actions button):not(.sidebar-mobile-toggle):not(.btn-logout-mobile),.btn:not(.lang-btn):not(.btn-login):not(.btn-logout-mobile),.button,a.btn,a.button,input[type=submit],input[type=button],[role=button]{min-height:48px!important;min-width:48px!important;padding:.875rem 1.25rem!important;font-size:1rem!important;border-radius:10px!important;font-weight:600!important;touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.1)}.btn-primary,.btn.primary,.submit-button,.cta-button,.btn-next-step{min-height:52px!important;padding:1rem 1.5rem!important;font-size:1.0625rem!important}.btn-secondary,.btn.secondary{min-height:48px!important;padding:.875rem 1.25rem!important}.btn-small,.btn.small,button.small{min-height:44px!important;min-width:44px!important;padding:.75rem 1rem!important;font-size:.9375rem!important}.btn-large,.btn.large,.hero .cta-button{min-height:56px!important;padding:1.125rem 2rem!important;font-size:1.125rem!important}.btn-login:not(.header-auth .btn-login),.btn-logout:not(.btn-logout-mobile){min-height:48px!important;padding:.875rem 1.25rem!important;font-size:1rem!important}button[aria-label]:not(:has(span)),.icon-button,.btn-icon{min-height:44px!important;min-width:44px!important;padding:.75rem!important}.btn-previous,.btn-next,.navigation-button{min-height:48px!important;padding:.875rem 1.5rem!important}.btn-block,.btn-full-width,.modal-footer .btn,.form-actions .btn{width:100%!important;justify-content:center!important}.button-group,.btn-group,.form-actions,.modal-footer{display:flex!important;flex-direction:column!important;gap:.75rem!important;width:100%!important}.button-group>*,.btn-group>*,.form-actions>*,.modal-footer>*{width:100%!important}.contact-buttons{flex-direction:column!important;gap:.75rem!important}.contact-buttons .btn{width:100%!important}.quick-link-button,.quick-links-grid button,.quick-links-grid a{min-height:56px!important;padding:1rem 1.25rem!important;font-size:1rem!important}button+button,.btn+.btn{margin-top:.75rem!important}}@media(max-width:480px){button,.btn,.button{padding:.75rem 1rem!important;font-size:.9375rem!important}.btn-primary,.btn.primary,.submit-button{padding:.875rem 1.25rem!important}}
