:root{--navy:#1B2B5E;--amber:#D4831A;--red:#CC3333;--green:#2A7A3E;--orange:#E07B20;--bg:#F4F5F8;--bg2:#FFFFFF;--bg3:#EBEDF4;--text:#1A1A2E;--text2:#4A5568;--text3:#8492A6;--border:#D0D5E8;--font:"Calibri",sans-serif;--radius:8px;--radius-lg:12px;--shadow:0 2px 8px rgba(27,43,94,.1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.nav{background:var(--navy);color:#fff;padding:0 16px;display:flex;align-items:center;gap:0;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0003}.nav-brand{font-size:16px;font-weight:700;padding:12px 16px 12px 0;border-right:1px solid rgba(255,255,255,.15);margin-right:8px;white-space:nowrap}.nav-brand span{color:var(--amber)}.nav-tabs{display:flex;flex:1;overflow-x:auto;scrollbar-width:none}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{padding:14px;font-size:12px;font-weight:600;color:#fff9;cursor:pointer;border:none;background:none;font-family:var(--font);white-space:nowrap;display:flex;align-items:center;gap:5px;transition:all .15s;border-bottom:3px solid transparent;text-decoration:none}.nav-tab:hover{color:#fff;background:#ffffff0d}.nav-tab.active{color:#fff;border-bottom-color:var(--amber)}.nav-tab i{font-size:16px}.nav-right{display:flex;align-items:center;gap:8px;padding-left:8px;border-left:1px solid rgba(255,255,255,.15);margin-left:8px}.nav-save-btn{padding:6px 12px;background:var(--amber);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:11px;font-weight:700;font-family:var(--font);display:flex;align-items:center;gap:4px;transition:opacity .15s}.nav-save-btn:hover{opacity:.9}.nav-save-status{font-size:10px;color:#ffffff80;white-space:nowrap}.nav-proj-name{font-size:11px;color:#ffffffb3;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main{flex:1;padding:16px;max-width:1400px;margin:0 auto;width:100%}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}.card-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:12px;display:flex;align-items:center;gap:8px}.card-title i{color:var(--amber);font-size:16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:#fff;border-radius:var(--radius-lg);padding:24px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:16px;display:flex;align-items:center;gap:8px}.modal-title i{color:var(--amber)}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13px;color:var(--text);background:var(--bg2);transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--navy)}.form-group textarea{resize:vertical;min-height:60px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-row.full{grid-template-columns:1fr}.btn{padding:8px 16px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:all .15s}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:#253d7e}.btn-amber{background:var(--amber);color:#fff}.btn-amber:hover{opacity:.9}.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{opacity:.9}.btn-green{background:#2e7d32;color:#fff}.btn-green:hover{opacity:.9}.btn-red{background:#c33;color:#fff}.btn-red:hover{opacity:.9}.btn-secondary{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--navy);color:var(--navy)}.btn-danger{background:#fff5f5;color:var(--red);border:1px solid #ffd0d0}.btn-danger:hover{background:#ffe0e0}.btn-sm{padding:5px 10px;font-size:11px}.btn-group{display:flex;gap:8px;flex-wrap:wrap}.tabs{display:flex;gap:4px;margin-bottom:12px;border-bottom:2px solid var(--border);padding-bottom:0}.tab{padding:8px 14px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;border:none;background:none;font-family:var(--font);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;display:flex;align-items:center;gap:5px}.tab:hover{color:var(--navy)}.tab.active{color:var(--navy);border-bottom-color:var(--navy)}.tab.amber{color:var(--amber)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:12px}th{background:var(--navy);color:#fff;padding:8px 10px;text-align:left;font-weight:600;white-space:nowrap}td{padding:7px 10px;border-bottom:1px solid var(--border);vertical-align:top}tr:hover td{background:var(--bg3)}tr:nth-child(2n) td{background:#fafbfd}tr:nth-child(2n):hover td{background:var(--bg3)}.carto-filter{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.carto-filter select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-family:var(--font);background:var(--bg2)}.carto-block{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:8px;overflow:hidden}.carto-type-hdr{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none;transition:background .15s}.carto-type-hdr:hover{background:var(--bg3)}.carto-type-name{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}.carto-type-count{font-size:10px;padding:2px 7px;border-radius:4px;background:var(--amber);color:#fff;font-weight:700}.carto-facteur{border-top:1px solid var(--border)}.carto-facteur-hdr{padding:7px 14px 7px 28px;background:var(--bg3);font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border)}.carto-risk{display:flex;align-items:flex-start;gap:10px;padding:7px 14px 7px 28px;border-bottom:1px solid var(--border);transition:background .1s}.carto-risk:hover{background:var(--bg3)}.carto-risk:last-child{border-bottom:none}.carto-risk-text{flex:1;font-size:12px;line-height:1.4}.carto-check{width:16px;height:16px;cursor:pointer;accent-color:var(--amber);flex-shrink:0;margin-top:2px}.carto-stats{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.carto-stat-pill{padding:5px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;font-size:12px;display:flex;align-items:center;gap:5px}.carto-stat-pill strong{color:var(--navy)}.plan-table-wrap{overflow-x:auto}.plan-table{width:100%;border-collapse:collapse;font-size:11px;min-width:900px}.plan-table th{background:var(--navy);color:#fff;padding:8px 6px;text-align:left;font-weight:600;white-space:nowrap;font-size:10px}.plan-table td{padding:6px;border-bottom:1px solid var(--border);vertical-align:top}.plan-table tr:nth-child(2n) td{background:#fafbfd}.plan-table tr:hover td{background:#f0f4ff}.plan-table input,.plan-table select{width:100%;border:none;border-bottom:1px solid #D0D5E8;background:transparent;font-size:10px;font-family:var(--font);padding:2px 3px;color:var(--text);border-radius:0}.plan-table textarea{width:100%;border:1px solid #D0D5E8;border-radius:4px;background:#fff;font-size:10px;font-family:var(--font);padding:3px 5px;color:var(--text);min-height:28px;resize:vertical}.plan-table input:focus,.plan-table textarea:focus{outline:none;border-color:var(--navy);background:#f7f9ff;border-radius:3px}.plan-table select:focus{outline:1px solid var(--navy);border-radius:2px;background:#fff}.plan-table input::placeholder,.plan-table textarea::placeholder{color:#b0bac9;font-style:italic}.prio-1{background:#fcc;color:var(--red);font-weight:700;text-align:center;border-radius:3px;padding:1px 4px}.prio-2{background:#ffe0b2;color:#950;font-weight:700;text-align:center;border-radius:3px;padding:1px 4px}.prio-3{background:#c8e6c9;color:var(--green);font-weight:700;text-align:center;border-radius:3px;padding:1px 4px}.stat-realise{background:#c8e6c9}.stat-cours{background:#fff9c4}.stat-bloque{background:#fcc}.stat-cloture{background:#e3f2fd}.ech-depasse{background:#fcc;color:var(--red);font-weight:700}.ech-proche{background:#ffe0b2}.ech-ok{background:#c8e6c9}.plan-add-row{padding:10px;text-align:center;cursor:pointer;color:var(--amber);font-size:12px;font-weight:600;border-top:2px dashed var(--border)}.plan-add-row:hover{background:#fffde7}.plan-totaux td{background:var(--navy)!important;color:#fff;font-weight:700}.analyse-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--navy),#2a3f8f);color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;font-family:var(--font);font-size:14px;font-weight:600;display:flex;align-items:center;gap:12px;margin-top:12px;transition:all .2s;box-shadow:0 4px 12px #1b2b5e40}.analyse-btn:hover{transform:translateY(-1px)}.analyse-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.analyse-result{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:12px;overflow:hidden}.analyse-result-hdr{background:var(--navy);color:#fff;padding:10px 14px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}.analyse-section{padding:12px 14px;border-bottom:1px solid var(--border)}.analyse-section:last-child{border-bottom:none}.analyse-section-title{font-size:11px;font-weight:700;color:var(--amber);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.analyse-section-body{font-size:12px;line-height:1.6;white-space:pre-wrap}.analyse-tag{display:inline-block;font-size:10px;font-weight:700;padding:1px 7px;border-radius:8px;margin-right:4px;background:#f4f5f8;color:#555}.analyse-tag.red{background:#ffebee;color:#c33}.analyse-tag.orange{background:#fff3e0;color:#d4831a}.analyse-tag.navy{background:#e8ebf4;color:#1b2b5e}.analyse-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.export-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.export-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;text-align:center;cursor:pointer;transition:all .2s}.export-card:hover{border-color:var(--amber);background:#fffde7;transform:translateY(-2px)}.export-card i{font-size:36px;color:var(--amber);display:block;margin-bottom:8px}.export-card-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px}.export-card-sub{font-size:11px;color:var(--text3)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:16px}.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;text-align:center}.kpi-val{font-size:28px;font-weight:700;color:var(--navy)}.kpi-val.red{color:var(--red)}.kpi-val.amber{color:var(--amber)}.kpi-val.green{color:var(--green)}.kpi-label{font-size:11px;color:var(--text3);margin-top:4px}.progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;border-radius:3px;transition:width .5s}.badge{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600}.badge-red{background:#fcc;color:var(--red)}.badge-orange{background:#ffe0b2;color:#950}.badge-green{background:#c8e6c9;color:var(--green)}.badge-navy{background:#e8ebf4;color:var(--navy)}.section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}.section-hdr h2{font-size:16px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px}.section-hdr h2 i{color:var(--amber)}.empty-state{text-align:center;padding:40px;color:var(--text3)}.empty-state i{font-size:40px;display:block;margin-bottom:12px}.toast-container{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:2000}.toast{background:var(--navy);color:#fff;padding:10px 16px;border-radius:var(--radius);font-size:12px;animation:slideup .3s;box-shadow:0 4px 12px #0000004d}.toast.success{background:var(--green)}.toast.error{background:var(--red)}@keyframes slideup{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy),#2a3f8f);padding:16px}.auth-card{width:100%;max-width:380px;margin:0}.auth-logo{font-size:22px;font-weight:700;color:var(--navy);text-align:center;margin-bottom:16px}.auth-logo span{color:var(--amber)}.auth-error{background:#fff0f0;color:var(--red);border:1px solid #ffd0d0;border-radius:var(--radius);padding:8px 10px;font-size:12px;margin-bottom:12px}.auth-switch{text-align:center;font-size:12px;color:var(--text2);margin-top:12px}.auth-switch a{color:var(--amber);font-weight:600;cursor:pointer;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.loading-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite}.feature-locked{padding:24px;text-align:center;background:var(--bg3);border-radius:var(--radius-lg);border:1px dashed var(--border)}.feature-locked-icon{font-size:32px;margin-bottom:8px}.feature-locked-title{font-weight:700;color:var(--navy);margin-bottom:4px}.feature-locked-sub{font-size:13px;color:var(--text3)}.home-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.home-title{font-size:22px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px}.home-title i{color:var(--amber);font-size:24px}.home-subtitle{font-size:12px;color:var(--text3);margin-top:4px}.home-stats{display:flex;gap:16px}.home-stat{text-align:center;background:#fff;border-radius:var(--radius);padding:10px 16px;box-shadow:var(--shadow)}.home-stat strong{display:block;font-size:22px;font-weight:700;color:var(--navy)}.home-stat span{font-size:11px;color:var(--text3)}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:32px}.proj-card{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border);transition:box-shadow .15s,border-color .15s;position:relative}.proj-card:hover{box-shadow:0 4px 16px #1b2b5e26;border-color:var(--navy)}.proj-card.status-termine{opacity:.8;border-style:dashed}.proj-add{background:#fff;border-radius:var(--radius-lg);padding:32px 20px;box-shadow:var(--shadow);border:2px dashed var(--border);cursor:pointer;text-align:center;transition:all .15s;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px}.proj-add:hover{border-color:var(--navy);background:#f0f2fa}.proj-add-title{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px}.proj-add-sub{font-size:11px;color:var(--text3)}.proj-empty{text-align:center;padding:60px 24px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);color:var(--text2)}.proj-etab{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-finess{font-size:11px;color:var(--text3);margin-bottom:8px}.proj-meta{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}.proj-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;white-space:nowrap}.proj-badge.type{background:var(--bg3);color:var(--navy)}.proj-dates{font-size:10px;color:var(--text3);margin-bottom:8px}.proj-actions{display:flex;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.proj-btn{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);display:flex;align-items:center;gap:4px;transition:opacity .15s;background:var(--bg3);color:var(--navy)}.proj-btn:hover{opacity:.85}.proj-btn.primary{background:var(--navy);color:#fff}.proj-btn.amber{background:var(--amber);color:#fff}.proj-btn.danger{background:var(--red);color:#fff;padding:6px 10px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:#fff;border-radius:var(--radius-lg);padding:24px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-title{font-size:16px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px;margin-bottom:16px}
