:root{--navy: #16324e;--navy-700: #1d3f60;--navy-800: #112637;--blue: #1c6ea4;--blue-600: #175d8c;--orange: #f5a623;--orange-600: #e0951c;--orange-050: #fef3df;--bg: #eef2f6;--surface: #ffffff;--ink: #1e2b3a;--muted: #64748b;--line: #e2e8f0;--danger: #d64545;--danger-050: #fbe9e9;--success: #2f9e6b;--success-050: #e7f5ee;--warn: #d98a1e;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(16, 42, 67, .08), 0 6px 18px rgba(16, 42, 67, .06);--shadow-lg: 0 12px 40px rgba(16, 42, 67, .18);--font: "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:var(--radius-sm);padding:10px 18px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--orange);color:#3b2600}.btn-primary:hover:not(:disabled){background:var(--orange-600)}.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover:not(:disabled){background:var(--navy-700)}.btn-ghost{background:transparent;color:var(--navy);border-color:var(--line)}.btn-ghost:hover:not(:disabled){background:#f4f7fa}.btn-danger{background:var(--danger-050);color:var(--danger);border-color:#f2cccc}.btn-danger:hover:not(:disabled){background:#f6dada}.btn-warn{background:var(--orange-050);color:var(--orange-600);border-color:#f3d9a6}.btn-warn:hover:not(:disabled){background:#fbe6c2}.btn-sm{padding:6px 12px;font-size:13px}.btn-block{width:100%}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;font-weight:600;color:var(--navy)}.field .hint{font-size:12px;color:var(--muted)}input,select,textarea{font-family:inherit;font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1c6ea426}textarea{resize:vertical;min-height:70px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:22px}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.2px}.badge:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.badge-planifiee{color:var(--blue-600);background:#e4f0f8}.badge-en_cours{color:var(--warn);background:var(--orange-050)}.badge-terminee{color:var(--success);background:var(--success-050)}.badge-annulee{color:var(--danger);background:var(--danger-050)}.alert{border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;font-weight:500;margin-bottom:14px}.alert-error{background:var(--danger-050);color:#a12626;border:1px solid #f2cccc}.alert-success{background:var(--success-050);color:#1c6e4a;border:1px solid #bfe4d2}.app-topbar{background:var(--navy);color:#fff;border-bottom:3px solid var(--orange);box-shadow:0 2px 10px #102a431f;position:sticky;top:0;z-index:40}.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-600));color:#3b2600;font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #f5a62366;flex:0 0 auto}.logout-btn{color:#fff!important;border-color:#ffffff47!important;background:#ffffff0f!important}.logout-btn:hover{background:#ffffff24!important}.app-topbar-inner{max-width:1500px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:flex;align-items:center;gap:12px}.brand img{height:44px;width:auto;background:#fff;border-radius:10px;padding:3px}.brand-text b{display:block;font-size:18px;letter-spacing:.5px;line-height:1.1}.brand-text span{font-size:12px;color:#bcd0e2}.topbar-user{display:flex;align-items:center;gap:16px}.topbar-user .who{display:flex;flex-direction:column;align-items:flex-end;line-height:1.25}.topbar-user .who b{font-size:14px;font-weight:600}.topbar-user .who span{font-size:11px;color:#a9c0d4;text-transform:capitalize;letter-spacing:.2px}.page{max-width:1500px;margin:0 auto;padding:24px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-head h1{margin:0;font-size:24px;color:var(--navy)}.page-head p{margin:4px 0 0;color:var(--muted);font-size:14px}.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}.login-hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-800) 100%);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-hero:after{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;border-radius:50%;border:40px solid var(--orange);opacity:.12}.login-hero .brand img{height:72px}.login-hero h2{font-size:34px;line-height:1.2;margin:0 0 12px}.login-hero .accent{color:var(--orange)}.login-hero p{color:#cdddea;font-size:16px;max-width:420px}.login-hero .secure-note{display:flex;align-items:center;gap:10px;font-size:13px;color:#bcd0e2}.login-panel{background:var(--surface);display:flex;align-items:center;justify-content:center;padding:40px}.login-box{width:100%;max-width:380px}.login-box h1{font-size:26px;color:var(--navy);margin:0 0 6px}.login-box .sub{color:var(--muted);margin:0 0 22px;font-size:14px}.role-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}.role-switch button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 10px;border:1.5px solid var(--line);background:#fff;border-radius:10px;font-weight:600;font-size:14px;color:var(--muted);cursor:pointer;transition:all .15s ease}.role-switch button svg{flex:0 0 auto}.role-switch button:hover{border-color:#cbd5e1}.role-switch button.active{border-color:var(--orange);background:var(--orange-050);color:var(--navy);box-shadow:0 0 0 3px #f5a62326}.pwd-rules{list-style:none;padding:0;margin:0 0 18px;font-size:13px}.pwd-rules li{color:var(--muted);padding:3px 0}.pwd-rules li.ok{color:var(--success);font-weight:600}.invite-link{display:flex;gap:8px;margin-top:10px}.invite-link input{font-size:12px;background:#fff}.invite-status{display:flex;align-items:flex-start;gap:8px;margin-top:8px;font-weight:400}.invite-status svg{flex:0 0 auto;margin-top:1px}.user-list{display:flex;flex-direction:column;gap:8px}.user-row{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:10px;padding:10px 12px;flex-wrap:wrap}.user-main{flex:1 1 180px;min-width:0}.user-main b{display:block;color:var(--navy);font-size:14px}.user-main span{font-size:12px;color:var(--muted);word-break:break-all}.user-meta{display:flex;align-items:center;gap:8px}.user-actions{display:flex;gap:6px;margin-left:auto}.ustatut{font-size:12px;font-weight:600;white-space:nowrap}.ustatut.ok{color:var(--success)}.ustatut.pending{color:var(--warn)}.ustatut.off{color:var(--muted)}.pwd-wrap{position:relative}.pwd-wrap input{padding-right:64px}.pwd-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--blue);font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px;width:auto}.login-foot{margin-top:22px;text-align:center;font-size:12px;color:var(--muted)}@media (max-width: 900px){.login-wrap{grid-template-columns:1fr}.login-hero{display:none}}.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}.stat{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.stat .n{font-size:28px;font-weight:800;color:var(--navy)}.stat .l{font-size:13px;color:var(--muted)}.stat.orange{border-left-color:var(--orange)}.stat.green{border-left-color:var(--success)}.stat.red{border-left-color:var(--danger)}.cal-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.cal-nav{display:flex;align-items:center;gap:8px}.cal-nav .week-label{font-weight:700;color:var(--navy);min-width:220px;text-align:center}.cal-nav .btn{background:var(--surface);border-color:#cdd8e3;color:var(--navy);font-weight:600;box-shadow:0 1px 2px #102a4314}.cal-nav .btn:hover:not(:disabled){background:#f4f7fa;border-color:var(--blue);color:var(--blue-600)}.cal-filter{display:flex;align-items:center;gap:8px}.cal-filter select{width:auto;min-width:200px}.calendar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.cal-scroll{overflow-x:auto}.cal-grid{display:grid;grid-template-columns:64px repeat(7,1fr)}.cal-corner,.cal-dayhead{background:#f7fafc;border-bottom:1px solid var(--line);border-left:1px solid var(--line);padding:8px 6px;text-align:center}.cal-corner{border-left:none;font-size:11px;color:var(--muted);display:flex;align-items:center;justify-content:center}.cal-dayhead b{display:block;font-size:14px;color:var(--navy);text-transform:capitalize}.cal-dayhead span{font-size:12px;color:var(--muted)}.cal-dayhead.today{background:var(--orange-050)}.cal-dayhead.today b{color:var(--orange-600)}.cal-body{position:relative;display:grid;grid-template-columns:64px repeat(7,1fr)}.cal-hours{display:grid}.cal-hour{height:56px;border-bottom:1px solid var(--line);font-size:11px;color:var(--muted);padding:2px 6px;text-align:right}.cal-daycol{position:relative;border-left:1px solid var(--line)}.cal-daycol.today{background:#f5a6230a}.cal-slot{height:56px;border-bottom:1px solid var(--line)}.cal-event{position:absolute;left:3px;right:3px;background:var(--blue);color:#fff;border-left:4px solid var(--orange);border-radius:6px;padding:3px 7px;font-size:11.5px;line-height:1.18;overflow:hidden;cursor:pointer;box-shadow:0 2px 6px #102a4340;transition:transform .1s,box-shadow .1s}.cal-event:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg);z-index:5}.cal-event .ev-title{font-weight:700;font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-event .ev-time{font-weight:600;font-size:10.5px;opacity:.92}.cal-event .ev-sub{font-size:10.5px;opacity:.82;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-event.st-en_cours{background:var(--orange-600);border-left-color:var(--navy);color:#fff}.cal-event.st-terminee{background:var(--success);border-left-color:#1c6e4a}.cal-event.st-annulee{background:#94a3b8;border-left-color:#64748b;text-decoration:line-through;opacity:.9}.cal-event.st-annulee:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M0 0 L100 100 M100 0 L0 100' stroke='white' stroke-width='2.5' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");background-size:100% 100%;opacity:.85}.cal-legend{display:flex;gap:18px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}.cal-legend span{display:inline-flex;align-items:center;gap:6px}.cal-legend i{width:12px;height:12px;border-radius:3px;display:inline-block}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1022338c;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:640px;animation:pop .14s ease}@keyframes pop{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;color:var(--navy);font-size:18px}.modal-close{background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer;width:auto;line-height:1}.modal-body{padding:22px}.modal-foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.form-grid .full{grid-column:1 / -1}.trajet{display:grid;grid-template-columns:24px 1fr;gap:4px 12px}.trajet .dot{display:flex;flex-direction:column;align-items:center}.trajet .dot i{width:12px;height:12px;border-radius:50%;border:3px solid var(--blue);background:#fff}.trajet .dot i.end{border-color:var(--orange)}.trajet .dot .line{flex:1;width:2px;background:var(--line);min-height:24px}.trajet .place b{color:var(--navy);font-size:14px}.trajet .place span{color:var(--muted);font-size:13px;display:block}.detail-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}.detail-row .k{color:var(--muted)}.detail-row .v{color:var(--ink);font-weight:600;text-align:right}.mission-list{display:flex;flex-direction:column;gap:12px}.mission-item{display:flex;gap:14px;padding:16px;background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:box-shadow .12s}.mission-item:hover{box-shadow:var(--shadow-lg)}.mission-item .time{text-align:center;min-width:58px}.mission-item .time b{display:block;font-size:17px;color:var(--navy)}.mission-item .time span{font-size:12px;color:var(--muted)}.mission-item .info{flex:1;min-width:0}.mission-item .info h4{margin:0 0 2px;color:var(--navy);font-size:16px}.mission-item .info .route{font-size:13px;color:var(--muted)}.empty{text-align:center;padding:48px 20px;color:var(--muted)}.empty .big{font-size:40px;margin-bottom:8px}.centered-loader{min-height:60vh;display:flex;align-items:center;justify-content:center;color:var(--muted)}.tabs{display:inline-flex;background:#e6edf3;border-radius:999px;padding:4px;gap:4px}.tabs button{border:none;background:transparent;padding:8px 18px;border-radius:999px;font-weight:600;font-size:14px;color:var(--navy);cursor:pointer;width:auto}.tabs button.active{background:var(--surface);box-shadow:var(--shadow);color:var(--blue-600)}.chip{display:inline-block;font-size:12px;padding:2px 9px;border-radius:6px;background:#eef2f6;color:var(--navy);font-weight:600}.cal-daynav{display:flex;align-items:center;gap:8px;margin-bottom:12px}.cal-daynav .d{flex:1;text-align:center;font-weight:700;color:var(--navy);font-size:15px;text-transform:capitalize}.cal-daynav .today-btn{flex:0 0 auto}.hide-on-mobile{display:flex}@media (max-width: 768px){.hide-on-mobile{display:none!important}.app-topbar-inner{padding:10px 12px;gap:8px}.brand{gap:9px;min-width:0}.brand img{height:36px}.brand-text b{font-size:15px;white-space:nowrap}.brand-text span{display:none}.topbar-user{gap:8px}.topbar-user .who{display:none}.page{padding:14px}.page-head{margin-bottom:16px}.page-head h1{font-size:20px}.page-head .btn{width:100%}.stat-row{grid-template-columns:1fr 1fr;gap:10px}.stat .n{font-size:22px}.cal-toolbar{gap:10px}.cal-nav{flex-wrap:wrap;justify-content:center;width:100%;gap:6px}.cal-nav .week-label{min-width:0;flex:1 1 100%;order:-1;font-size:15px;margin-bottom:2px}.cal-nav .btn{flex:1}.cal-filter{width:100%;flex-direction:column;align-items:stretch;gap:10px}.cal-filter .tabs{width:100%;justify-content:center}.cal-filter .tabs button{flex:1}.cal-filter select{width:100%;min-width:0}.modal-overlay{padding:0}.modal{max-width:none;min-height:100vh;border-radius:0}.form-grid{grid-template-columns:1fr}.modal-foot .btn{flex:1}.detail-row .v{max-width:60%}.mission-item{padding:12px;gap:10px}.mission-item .time{min-width:46px}.mission-item .time b{font-size:15px}.login-panel{padding:28px 20px;min-height:100vh}}@media (max-width: 380px){.stat-row{grid-template-columns:1fr}}
