:root{--green: #4ab840;--green-dark: #318a20;--navy: #1a2332;--navy-light: #243347;--navy-lighter: #2e3f58;--gold: #D4A843;--danger: #e74c3c;--warning: #f39c12;--tab-h: 60px;--header-h: 56px}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{height:100%;height:-webkit-fill-available}body{height:100vh;height:-webkit-fill-available;overflow:hidden;font-family:DM Sans,sans-serif;color:#fff;background:var(--navy);-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none}#root{height:100%;display:flex;flex-direction:column;overflow:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.anim-fade-up{animation:fadeUp .25s ease both}.anim-fade-in{animation:fadeIn .2s ease both}.loader{width:32px;height:32px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.input{width:100%;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px 14px;color:#fff;font-family:DM Sans,sans-serif;font-size:.95rem;outline:none;transition:border-color .2s}.input:focus{border-color:var(--green)}.input::placeholder{color:#ffffff4d}.input:disabled{opacity:.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:10px;border:none;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--green);color:#fff}.btn-primary:active{background:var(--green-dark);transform:scale(.97)}.btn-secondary{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.12)}.btn-secondary:active{background:#ffffff24}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:8px 14px;font-size:.82rem}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-full{width:100%}.card{background:var(--navy-light);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:16px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600}.badge-planifiee{background:#d4a84326;color:var(--gold)}.badge-en_cours{background:#4ab84026;color:var(--green)}.badge-terminee{background:#ffffff14;color:#ffffff73}.badge-annulee{background:#e74c3c26;color:var(--danger)}.label{display:block;font-size:.75rem;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.bottom-tabs{display:flex;height:var(--tab-h);background:var(--navy-light);border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.bottom-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:none;color:#ffffff59;font-family:DM Sans,sans-serif;font-size:.68rem;font-weight:500;cursor:pointer;transition:color .2s;padding:0}.bottom-tab.active{color:var(--green)}.bottom-tab svg{width:22px;height:22px}.page{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.page-header{position:sticky;top:0;z-index:10;background:var(--navy);border-bottom:1px solid rgba(255,255,255,.07);padding:14px 16px;display:flex;align-items:center;gap:12px;min-height:var(--header-h)}.tabs-row{display:flex;border-bottom:1px solid rgba(255,255,255,.08);overflow-x:auto;flex-shrink:0}.tabs-row::-webkit-scrollbar{display:none}.tab-btn{padding:12px 16px;background:none;border:none;border-bottom:2px solid transparent;color:#fff6;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .18s;margin-bottom:-1px}.tab-btn.active{color:var(--green);border-bottom-color:var(--green)}.divider{height:1px;background:#ffffff12;margin:12px 0}.toast{position:fixed;bottom:calc(var(--tab-h) + 16px);left:50%;transform:translate(-50%) translateY(120px);opacity:0;background:#4ab840eb;color:#fff;padding:10px 24px;border-radius:20px;font-size:.85rem;font-weight:600;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .3s ease;z-index:9999;pointer-events:none;white-space:nowrap}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.section-title{font-size:.7rem;font-weight:700;color:#ffffff4d;text-transform:uppercase;letter-spacing:.08em;padding:0 16px;margin:16px 0 8px}
