*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#0f172a;--color-surface:#1e293b;--color-border:#334155;--color-primary:#6366f1;--color-primary-hover:#4f46e5;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-error:#ef4444;--color-success:#22c55e;--radius:8px}body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:system-ui,-apple-system,sans-serif}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);width:100%;max-width:400px;padding:2rem}.auth-card h1{color:var(--color-primary);margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.auth-card h2{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:1.05rem;font-weight:400}.auth-link{text-align:center;color:var(--color-text-muted);margin-top:1.25rem;font-size:.875rem}.auth-link a{color:var(--color-primary);text-decoration:none}.success-msg{color:var(--color-success);border:1px solid var(--color-success);border-radius:var(--radius);margin-bottom:1rem;padding:.5rem .75rem;font-size:.875rem}.app-layout{flex-direction:column;min-height:100vh;display:flex}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.875rem 1.5rem;display:flex}.brand{color:var(--color-primary);letter-spacing:.05em;font-size:1.25rem;font-weight:700;text-decoration:none}.nav-links{align-items:center;gap:1.25rem;display:flex}.nav-links a{color:var(--color-text-muted);font-size:.9rem;text-decoration:none;transition:color .15s}.nav-links a:hover{color:var(--color-text)}.user-email{color:var(--color-text-muted);font-size:.8rem}.main-content{flex:1;width:100%;max-width:1024px;margin:0 auto;padding:2rem 1.5rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page h1,.page-header h1{font-size:1.5rem;font-weight:600}.page h1{margin-bottom:1rem}.page-header h1{margin-bottom:0}.subtitle{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:.9rem}.welcome{color:var(--color-text-muted);margin-bottom:1.5rem}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:.25rem;padding:1.25rem;display:flex}.stat-value{color:var(--color-primary);font-size:2rem;font-weight:700}.stat-label{color:var(--color-text-muted);font-size:.8rem}.cta-group{flex-wrap:wrap;gap:.75rem;display:flex}.form-group{flex-direction:column;gap:.375rem;margin-bottom:1rem;display:flex}.form-group label{color:var(--color-text-muted);font-size:.875rem;font-weight:500}.form-group input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);outline:none;padding:.625rem .75rem;font-family:inherit;font-size:.95rem;transition:border-color .15s}.form-group input:focus{border-color:var(--color-primary)}.form-group input::placeholder{color:var(--color-text-muted)}.event-form{max-width:480px}.form-actions{gap:.75rem;margin-top:1.25rem;display:flex}.btn-primary{background:var(--color-primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:.625rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:500;line-height:1.5;text-decoration:none;transition:background .15s;display:inline-block}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.625rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:500;line-height:1.5;text-decoration:none;transition:border-color .15s,color .15s;display:inline-block}.btn-secondary:hover{border-color:var(--color-text-muted);color:var(--color-text)}.btn-sm{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);white-space:nowrap;background:0 0;padding:.375rem .75rem;font-size:.8rem;text-decoration:none;transition:border-color .15s,color .15s;display:inline-block}.btn-sm:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-logout{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.875rem;transition:color .15s}.btn-logout:hover{color:var(--color-error)}.event-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.event-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.event-meta{color:var(--color-text-muted);margin-top:.2rem;font-size:.8rem;display:block}.plan-result{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.plan-content{white-space:pre-wrap;word-break:break-word;color:var(--color-text-muted);font-family:Menlo,Monaco,Consolas,monospace;font-size:.85rem;line-height:1.65}.loading{color:var(--color-text-muted);text-align:center;padding:2rem 0}.error{color:var(--color-error);margin:.5rem 0;font-size:.875rem}.empty{color:var(--color-text-muted);padding:2rem 0}.empty a{color:var(--color-primary);text-decoration:none}.form-section{border-bottom:1px solid var(--color-border);margin-bottom:2rem;padding-bottom:1.5rem}.form-section:last-of-type{border-bottom:none}.section-title{color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:1.25rem;font-size:.8rem;font-weight:600}.terrain-section .section-title{color:#34d399}.form-row{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;display:grid}.checkbox-group{flex-wrap:wrap;gap:.5rem;margin-top:.25rem;display:flex}.checkbox-item{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:6px;align-items:center;gap:.4rem;padding:.35rem .6rem;font-size:.85rem;transition:border-color .15s;display:flex}.checkbox-item:has(input:checked){border-color:var(--color-primary);color:var(--color-text)}.checkbox-item input{width:14px;height:14px;accent-color:var(--color-primary)}.relay-list{flex-direction:column;gap:.5rem;display:flex}.relay-item{align-items:flex-start;gap:.5rem;display:flex}.relay-fields{flex:1;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem;display:grid}.relay-fields input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);outline:none;padding:.4rem .6rem;font-family:inherit;font-size:.85rem}.relay-fields input:focus{border-color:var(--color-primary)}.relay-fields input::placeholder{color:var(--color-text-muted)}.btn-remove{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-error);cursor:pointer;background:0 0;flex-shrink:0;padding:.3rem .5rem;font-size:.75rem;transition:background .15s}.btn-remove:hover{background:#ef44441a}.btn-add-relay{border:1px dashed var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;background:0 0;width:fit-content;margin-top:.25rem;padding:.5rem 1rem;font-family:inherit;font-size:.85rem;transition:border-color .15s,color .15s}.btn-add-relay:hover{border-color:var(--color-primary);color:var(--color-primary)}.form-select,.form-textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);outline:none;width:100%;padding:.625rem .75rem;font-family:inherit;font-size:.95rem;transition:border-color .15s}.form-select:focus,.form-textarea:focus{border-color:var(--color-primary)}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.mob-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;margin-left:.5rem;padding:.15rem .45rem;font-size:.7rem;font-weight:600;display:inline-block}.badge-fort{color:#22c55e;background:#22c55e26;border:1px solid #22c55e4d}.badge-moyen{color:#f59e0b;background:#f59e0b26;border:1px solid #f59e0b4d}.badge-faible{color:#ef4444;background:#ef444426;border:1px solid #ef44444d}.event-name-row{flex-wrap:wrap;align-items:center;display:flex}.event-info{flex-direction:column;display:flex}.diagnostic-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=720px){.diagnostic-grid{grid-template-columns:1fr}.relay-fields{grid-template-columns:1fr 1fr}}.diag-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.card-title{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:0;font-size:.8rem;font-weight:600}.score-ring{align-items:baseline;gap:.3rem;margin:.5rem 0;display:flex}.score-number{font-size:3rem;font-weight:700;line-height:1}.score-label{color:var(--color-text-muted);font-size:1rem}.terrain-block h3{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem;font-size:.8rem;font-weight:600}.risk-list{flex-wrap:wrap;gap:.4rem;list-style:none;display:flex}.risk-item{color:#ef4444;background:#ef44441a;border:1px solid #ef444440;border-radius:4px;padding:.2rem .5rem;font-size:.8rem}.reco-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.reco-list li{color:var(--color-text-muted);padding-left:.75rem;font-size:.85rem;position:relative}.reco-list li:before{content:"→";color:var(--color-primary);position:absolute;left:0}.checklist{flex-direction:column;gap:.35rem;list-style:none;display:flex}.checklist-item{align-items:center;gap:.5rem;font-size:.875rem;display:flex}.checklist-item.done{color:var(--color-text)}.checklist-item.todo{color:var(--color-text-muted)}.check-icon{text-align:center;width:1.2rem;font-size:.9rem}.checklist-item.done .check-icon{color:#22c55e}.checklist-item.todo .check-icon{color:var(--color-border)}.scores-row{gap:1.5rem;display:flex}.mini-score{flex-direction:column;align-items:center;display:flex}.mini-score span:first-child{font-size:1.75rem;font-weight:700}.mini-score span:last-child{color:var(--color-text-muted);font-size:.75rem}.btn-sm-block{align-self:flex-start;margin-top:.5rem}.btn-pdf{color:#6366f1;border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:#1e293b;border:1px solid #6366f1;padding:.625rem 1.1rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .15s,color .15s}.btn-pdf:hover{color:#fff;background:#6366f1}.btn-pdf:disabled{opacity:.55;cursor:not-allowed}:root{--sidebar-w:240px;--bottom-nav-h:60px;--color-warning:#f59e0b;--color-info:#3b82f6;--radius-lg:12px;--shadow-card:0 1px 3px #0000004d, 0 1px 2px #0006;--transition:.15s ease}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;flex-shrink:0;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-brand{color:var(--color-primary);letter-spacing:.06em;padding:1.25rem 1.25rem .5rem;font-size:1.4rem;font-weight:800;text-decoration:none;display:block}.sidebar-subtitle{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--color-border);padding:0 1.25rem 1.25rem;font-size:.7rem}.sidebar-section{padding:.75rem 0}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);opacity:.6;padding:0 1.25rem .35rem;font-size:.65rem;font-weight:600}.sidebar-link{color:var(--color-text-muted);transition:background var(--transition), color var(--transition);align-items:center;gap:.65rem;padding:.6rem 1.25rem;font-size:.9rem;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{color:var(--color-text);background:#6366f114}.sidebar-link.active{color:var(--color-primary);background:#6366f11f;font-weight:600}.sidebar-link.active:before{content:"";background:var(--color-primary);border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.sidebar-icon{text-align:center;width:1.4rem;font-size:1.1rem}.sidebar-link-sub{color:var(--color-text-muted);opacity:.7;font-size:.72rem}.sidebar-footer{border-top:1px solid var(--color-border);flex-direction:column;gap:.35rem;margin-top:auto;padding:1rem 1.25rem;display:flex}.sidebar-user-email{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.btn-logout-sidebar{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;transition:border-color var(--transition), color var(--transition);text-align:left;background:0 0;padding:.4rem .75rem;font-family:inherit;font-size:.8rem}.btn-logout-sidebar:hover{border-color:var(--color-error);color:var(--color-error)}.shell-main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.bottom-nav{height:var(--bottom-nav-h);background:var(--color-surface);border-top:1px solid var(--color-border);z-index:200;align-items:stretch;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--color-text-muted);transition:color var(--transition);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.15rem;padding:.25rem 0;font-size:.65rem;text-decoration:none;display:flex}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-icon{font-size:1.25rem;line-height:1}.fab{bottom:calc(var(--bottom-nav-h) + 1rem);background:var(--color-primary);color:#fff;cursor:pointer;z-index:201;width:52px;height:52px;transition:background var(--transition), transform var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;text-decoration:none;display:none;position:fixed;right:1rem;box-shadow:0 4px 12px #6366f166}.fab:hover{background:var(--color-primary-hover);transform:scale(1.05)}.toast-container{z-index:1000;flex-direction:column;gap:.5rem;max-width:340px;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:var(--radius);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-card);justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.875rem;animation:.2s slideUp;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-error)}.toast-warning{border-left:3px solid var(--color-warning)}.toast-info{border-left:3px solid var(--color-info)}.toast-close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:.85rem}.toast-close:hover{color:var(--color-text)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition);padding:1.25rem}.card:hover{border-color:#6366f159}.stats-grid-4{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem;display:grid}.stat-card-v2{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;gap:.25rem;padding:1rem 1.25rem;display:flex}.stat-card-v2 .stat-icon{margin-bottom:.25rem;font-size:1.25rem}.stat-card-v2 .stat-value-v2{color:var(--color-text);font-size:1.75rem;font-weight:700;line-height:1}.stat-card-v2 .stat-label-v2{color:var(--color-text-muted);font-size:.75rem}.events-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.event-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition), transform var(--transition);flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.event-card:hover{border-color:#6366f159;transform:translateY(-1px)}.event-card-name{color:var(--color-text);font-size:1rem;font-weight:600;line-height:1.3}.event-card-meta{color:var(--color-text-muted);flex-direction:column;gap:.2rem;font-size:.8rem;display:flex}.event-card-actions{gap:.5rem;margin-top:auto;display:flex}.stepper{align-items:center;gap:0;margin-bottom:2rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.step-item{flex-shrink:0;align-items:center;display:flex}.step-dot{border:2px solid var(--color-border);width:28px;height:28px;color:var(--color-text-muted);background:var(--color-bg);transition:all var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.step-dot.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.step-dot.done{border-color:var(--color-success);background:var(--color-success);color:#fff}.step-label{flex-direction:column;margin-left:.5rem;display:flex}.step-label-text{color:var(--color-text-muted);white-space:nowrap;font-size:.75rem;font-weight:600}.step-label-text.active{color:var(--color-primary)}.step-label-text.done{color:var(--color-success)}.step-connector{background:var(--color-border);flex:1;min-width:1.5rem;max-width:3rem;height:2px;margin:0 .5rem}.step-connector.done{background:var(--color-success)}.wizard-body{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1rem;padding:1.75rem}.wizard-nav{justify-content:space-between;align-items:center;gap:.75rem;padding-top:1rem;display:flex}.plan-timeline{flex-direction:column;gap:.75rem;display:flex}.plan-phase{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.plan-phase-header{color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;background:#6366f114;padding:.6rem 1rem;font-size:.8rem;font-weight:600}.plan-phase-body{flex-direction:column;gap:.4rem;padding:.75rem 1rem;display:flex}.plan-task{color:var(--color-text);align-items:flex-start;gap:.5rem;font-size:.875rem;display:flex}.plan-task:before{content:"→";color:var(--color-primary);flex-shrink:0;margin-top:.05rem}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;display:flex}.empty-icon{opacity:.4;font-size:3rem}.empty-title{color:var(--color-text);font-size:1.1rem;font-weight:600}.empty-desc{color:var(--color-text-muted);max-width:320px;font-size:.9rem}.help-tip{border-radius:var(--radius);color:var(--color-text-muted);background:#6366f10f;border:1px solid #6366f133;margin-top:.35rem;padding:.6rem .875rem;font-size:.8rem}.score-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:.35rem;padding:.2rem .6rem;font-size:.8rem;font-weight:700;display:inline-flex}.score-badge.high{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e4d}.score-badge.mid{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b4d}.score-badge.low{color:#ef4444;background:#ef44441f;border:1px solid #ef44444d}.loader-inline{border:2px solid var(--color-border);border-top-color:var(--color-primary);vertical-align:middle;border-radius:50%;width:16px;height:16px;margin-right:.4rem;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-block{color:var(--color-text-muted);align-items:center;gap:.5rem;padding:1.5rem;font-size:.9rem;display:flex}@media (width<=768px){.sidebar{display:none}.shell-main{padding-bottom:var(--bottom-nav-h);margin-left:0}.bottom-nav,.fab{display:flex}.toast-container{bottom:calc(var(--bottom-nav-h) + .75rem);max-width:100%;left:.75rem;right:.75rem}.stats-grid-4{grid-template-columns:repeat(2,1fr)}.events-grid,.diagnostic-grid{grid-template-columns:1fr}.form-row{flex-direction:column}.stepper{gap:0}.step-label{display:none}.page{padding:1rem}.page-header{flex-wrap:wrap;gap:.5rem}.wizard-body{padding:1.25rem}}@media (width<=480px){.auth-card{padding:1.5rem}.stats-grid-4{grid-template-columns:repeat(2,1fr)}}
