body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--pg-night:#040d1a;--pg-deep:#071428;--pg-card:#081428e0;--pg-blue:#3b9eff;--pg-blue-mid:#1a6fc4;--pg-blue-glow:#3b9eff2e;--pg-amber:#f5a623;--pg-amber-glow:#f5a62340;--pg-green:#22c55e;--pg-red:#e24b4a;--pg-text:#e8f0fe;--pg-text-sec:#7a9cc4;--pg-text-muted:#3d5a7a;--pg-border:#3b9eff1f;--pg-border-hover:#3b9eff59;--pg-input-bg:#ffffff0a}.pg-page{align-items:center;background:#040d1a;background:var(--pg-night);color:#e8f0fe;color:var(--pg-text);display:flex;font-family:DM Sans,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;padding:1.5rem;position:relative}.scene{inset:0;overflow:hidden;pointer-events:none;position:fixed}.sky{background:radial-gradient(ellipse 80% 60% at 50% -10%,#0d2744 0,#040d1a 60%)}.sky,.stars{inset:0;position:absolute}.stars{animation:starTwinkle 4s ease-in-out infinite alternate;background-image:radial-gradient(1px 1px at 10% 15%,#fffc 0,#0000 100%),radial-gradient(1px 1px at 25% 8%,#fff9 0,#0000 100%),radial-gradient(1.5px 1.5px at 40% 20%,#ffffffe6 0,#0000 100%),radial-gradient(1px 1px at 55% 5%,#ffffffb3 0,#0000 100%),radial-gradient(1px 1px at 70% 12%,#ffffff80 0,#0000 100%),radial-gradient(1px 1px at 85% 18%,#fffc 0,#0000 100%),radial-gradient(1px 1px at 92% 7%,#fff9 0,#0000 100%),radial-gradient(1px 1px at 15% 30%,#fff6 0,#0000 100%),radial-gradient(1px 1px at 60% 25%,#ffffffb3 0,#0000 100%),radial-gradient(1px 1px at 78% 28%,#ffffff80 0,#0000 100%),radial-gradient(1.5px 1.5px at 48% 10%,#c8dcffe6 0,#0000 100%),radial-gradient(1px 1px at 5% 22%,#fff9 0,#0000 100%),radial-gradient(1px 1px at 95% 30%,#fff6 0,#0000 100%)}@keyframes starTwinkle{0%{opacity:.7}to{opacity:1}}.buildings{align-items:flex-end;bottom:44%;display:flex;gap:2px;left:0;padding:0 5%;position:absolute;right:0}.building{background:#060f1c;border-top:1px solid #3b9eff0f;flex-shrink:0}.horizon{background:linear-gradient(90deg,#0000,#3b9eff14 20%,#3b9eff26 50%,#3b9eff14 80%,#0000);bottom:44%;height:2px;left:0;position:absolute;right:0}.ground{background:linear-gradient(180deg,#071220,#050e1a 40%,#030a12)}.asphalt,.ground{bottom:0;height:45%;left:0;position:absolute;right:0}.asphalt{background-image:repeating-linear-gradient(90deg,#0000,#0000 48px,hsla(0,0%,100%,.025) 0,hsla(0,0%,100%,.025) 50px)}.lamp-pole{background:linear-gradient(0deg,#1a2d40,#253d54);border-radius:2px;bottom:40%;position:absolute;width:4px}.lamp-head{background:#1e3449;border-radius:4px 4px 0 0;height:10px;top:-14px;width:24px}.lamp-head,.lamp-light{left:50%;position:absolute;transform:translateX(-50%)}.lamp-light{animation:lampFlicker 6s ease-in-out infinite;background:#f5a623;background:var(--pg-amber);border-radius:50%;box-shadow:0 0 20px 8px #f5a62340,0 0 60px 20px #f5a6231a;box-shadow:0 0 20px 8px var(--pg-amber-glow),0 0 60px 20px #f5a6231a;height:6px;top:-4px;width:16px}@keyframes lampFlicker{0%,90%,to{opacity:1}92%{opacity:.85}94%{opacity:1}96%{opacity:.9}}.lamp-cone{border-bottom:300px solid #f5a6230a;border-left:70px solid #0000;border-right:70px solid #0000;bottom:0;filter:blur(8px);height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.truck-wrap{animation:truckDrive 18s linear infinite;bottom:40%;left:-340px;position:absolute}@keyframes truckDrive{0%{left:-340px}to{left:110%}}.truck{height:90px;position:relative;width:320px}.truck-trailer{background:linear-gradient(180deg,#1e3a5f,#152d4a 60%,#0f2035);border:1px solid #2a4d72;border-radius:4px 4px 0 0;bottom:20px;height:62px;left:0;position:absolute;width:220px}.truck-trailer:before{color:#3b9eff73;content:"PARKGUARD";font-family:Syne,sans-serif;font-size:11px;font-weight:700;left:50%;letter-spacing:3px;position:absolute;top:50%;transform:translate(-50%,-50%)}.truck-trailer:after{border:1px solid #3b9eff1a;border-radius:2px;bottom:8px;content:"";left:8px;position:absolute;right:8px;top:8px}.truck-cabin{background:linear-gradient(135deg,#1a4268,#0f2d4a);border:1px solid #2a5070;border-radius:6px 10px 0 0;bottom:20px;height:70px;position:absolute;right:0;width:90px}.truck-windshield{background:linear-gradient(135deg,#64b4ff40,#2864b426);border:1px solid #64b4ff33;border-radius:4px 6px 0 0;bottom:20px;left:10px;position:absolute;right:14px;top:10px}.headlight{background:#fffbe6;border-radius:2px;box-shadow:0 0 20px 6px #fff0b4e6,0 0 80px 40px #ffeb9626;height:14px;position:absolute;right:-6px;width:6px}.headlight-top{bottom:52px}.headlight-bottom{bottom:32px}.truck-base{background:#0a1e30;bottom:14px;height:10px;left:0;position:absolute;width:320px}.wheel{background:radial-gradient(circle at 35% 35%,#2a3a4a,#0d1820);border:3px solid #1a2d40;border-radius:50%;bottom:0;height:22px;position:absolute;width:22px}.wheel:after{background:#253545;border:1px solid #3a5060;border-radius:50%;content:"";height:8px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:8px}.w1{left:20px}.w2{left:56px}.w3{left:96px}.w4{left:184px}.w5{left:214px}.w6{right:20px}.truck-shadow{background:#0006;border-radius:50%;bottom:-4px;filter:blur(6px);height:8px;left:20px;position:absolute;right:20px}.pg-card{animation:cardIn .8s cubic-bezier(.16,1,.3,1) both;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:#081428e0;background:var(--pg-card);border:1px solid #3b9eff1f;border:1px solid var(--pg-border);border-radius:20px;box-shadow:0 0 0 1px #3b9eff0d,0 32px 64px #0009,inset 0 0 80px #3b9eff0f;max-width:420px;padding:2.5rem 2.25rem 2rem;position:relative;width:100%;z-index:10}@keyframes cardIn{0%{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.logo-wrap{align-items:center;animation:cardIn .8s cubic-bezier(.16,1,.3,1) .1s both;display:flex;justify-content:center;margin-bottom:2rem}.logo-icon{flex-shrink:0;height:52px;margin-right:12px;width:52px}.logo-icon svg{filter:drop-shadow(0 0 8px rgba(59,158,255,.5));height:100%;width:100%}.logo-text{display:flex;flex-direction:column;line-height:1}.logo-name{color:#e8f0fe;color:var(--pg-text);font-family:Syne,sans-serif;font-size:1.75rem;font-weight:800;letter-spacing:-.02em}.logo-name span{color:#3b9eff;color:var(--pg-blue)}.logo-sub{color:#3d5a7a;color:var(--pg-text-muted);font-size:10px;font-weight:400;letter-spacing:.18em;margin-top:4px;text-transform:uppercase}.form-title{animation:cardIn .8s cubic-bezier(.16,1,.3,1) .15s both;color:#7a9cc4;color:var(--pg-text-sec);font-family:Syne,sans-serif;font-size:1.05rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.role-grid{grid-gap:8px;animation:cardIn .8s cubic-bezier(.16,1,.3,1) .2s both;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.role-btn{align-items:center;background:#ffffff0a;background:var(--pg-input-bg);border:1px solid #3b9eff1f;border:1px solid var(--pg-border);border-radius:10px;color:#3d5a7a;color:var(--pg-text-muted);cursor:pointer;display:flex;flex-direction:column;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;gap:4px;padding:10px 4px;transition:border-color .2s,color .2s,background .2s,box-shadow .2s}.role-btn:hover{background:#3b9eff0f;border-color:#3b9eff59;border-color:var(--pg-border-hover);color:#7a9cc4;color:var(--pg-text-sec)}.role-btn.active{background:#3b9eff1f;border-color:#3b9eff;border-color:var(--pg-blue);box-shadow:0 0 12px #3b9eff26;color:#3b9eff;color:var(--pg-blue)}.role-icon{font-size:18px;line-height:1}.error-banner{animation:cardIn .3s ease both;background:#e24b4a1f;border:1px solid #e24b4a4d;border-radius:10px;color:#f08080;font-size:13px;margin-bottom:1rem;padding:10px 14px;text-align:center}.field{animation:cardIn .8s cubic-bezier(.16,1,.3,1) both;margin-bottom:1.1rem}.field:first-child{animation-delay:.25s}.field:nth-child(2){animation-delay:.3s}.field label{color:#3d5a7a;color:var(--pg-text-muted);display:block;font-size:11px;font-weight:500;letter-spacing:.1em;margin-bottom:7px;text-transform:uppercase}.input-wrap{position:relative}.input-wrap svg{color:#3d5a7a;color:var(--pg-text-muted);height:16px;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:color .2s;width:16px}.input-wrap:focus-within svg{color:#3b9eff;color:var(--pg-blue)}.input-wrap input{background:#ffffff0a;background:var(--pg-input-bg);border:1px solid #3b9eff1f;border:1px solid var(--pg-border);border-radius:12px;color:#e8f0fe;color:var(--pg-text);font-family:DM Sans,sans-serif;font-size:14px;height:48px;outline:none;padding:0 14px 0 44px;transition:border-color .2s,background .2s,box-shadow .2s;width:100%}.input-wrap input::placeholder{color:#3d5a7a;color:var(--pg-text-muted)}.input-wrap input:focus{background:#3b9eff0d;border-color:#1a6fc4;border-color:var(--pg-blue-mid);box-shadow:0 0 0 3px #3b9eff1a}.input-wrap input.error{animation:shake .35s ease;border-color:#e24b4a;border-color:var(--pg-red);box-shadow:0 0 0 3px #e24b4a26}@keyframes shake{0%,to{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}.input-wrap input:disabled{cursor:not-allowed;opacity:.5}.btn-submit{animation:cardIn .8s cubic-bezier(.16,1,.3,1) .35s both;background:#1a6fc4;background:var(--pg-blue-mid);border:none;border-radius:12px;box-shadow:0 4px 20px #1a6fc459;color:#fff;cursor:pointer;font-family:Syne,sans-serif;font-size:15px;font-weight:700;height:50px;letter-spacing:.04em;margin-bottom:1rem;overflow:hidden;position:relative;transition:background .2s,transform .15s,box-shadow .2s;width:100%}.btn-submit:before{background:linear-gradient(135deg,#ffffff1f,#0000 60%);content:"";inset:0;pointer-events:none;position:absolute}.btn-submit:hover:not(:disabled){background:#3b9eff;background:var(--pg-blue);box-shadow:0 8px 28px #3b9eff66;transform:translateY(-1px)}.btn-submit:active:not(:disabled){transform:translateY(0) scale(.99)}.btn-submit:disabled{cursor:not-allowed;opacity:.7}.btn-spinner,.btn-text{transition:opacity .2s}.btn-spinner{align-items:center;display:flex;inset:0;justify-content:center;opacity:0;position:absolute}.btn-submit.loading .btn-text{opacity:0}.btn-submit.loading .btn-spinner{opacity:1}.spinner-ring{animation:spin .7s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:22px;width:22px}@keyframes spin{to{transform:rotate(1turn)}}.success-overlay{align-items:center;background:#081428f5;border-radius:20px;display:flex;flex-direction:column;gap:12px;inset:0;justify-content:center;opacity:0;pointer-events:none;position:absolute;transition:opacity .4s;z-index:20}.success-overlay.show{opacity:1;pointer-events:all}.success-check{align-items:center;animation:popIn .5s cubic-bezier(.16,1,.3,1);background:#22c55e26;border:2px solid #22c55e;border:2px solid var(--pg-green);border-radius:50%;display:flex;height:56px;justify-content:center;width:56px}.success-check svg{color:#22c55e;color:var(--pg-green);height:28px;width:28px}@keyframes popIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.success-label{color:#e8f0fe;color:var(--pg-text);font-family:Syne,sans-serif;font-size:1.1rem;font-weight:700}.success-sub{color:#7a9cc4;color:var(--pg-text-sec);font-size:13px}.footer-note{animation:cardIn .8s cubic-bezier(.16,1,.3,1) .4s both;color:#3d5a7a;color:var(--pg-text-muted);font-size:11px;text-align:center}@media (max-width:480px){.pg-page{align-items:flex-end;padding:0}.pg-card{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border-radius:20px 20px 0 0;max-width:100%;padding:2rem 1.5rem 2.5rem}.logo-name{font-size:1.5rem}.logo-icon{height:44px;width:44px}}@media (min-height:800px) and (max-width:480px){.pg-page{align-items:center;padding:1.5rem}.pg-card{border-radius:20px;max-width:420px}}@media (min-width:768px){.pg-page{padding:2rem}}.vv-app[data-theme=dark],:root{--pg-night:#040d1a;--pg-surface:#0a1929;--pg-surface2:#0d2040;--pg-blue:#3b9eff;--pg-blue-mid:#1a6fc4;--pg-blue-dim:#3b9eff1f;--pg-amber:#f5a623;--pg-amber-dim:#f5a62326;--pg-green:#22c55e;--pg-green-dim:#22c55e1f;--pg-red:#ef4444;--pg-red-dim:#ef44441f;--pg-orange:#f97316;--pg-text:#e8f0fe;--pg-text-sec:#7a9cc4;--pg-text-muted:#3d5a7a;--pg-border:#3b9eff1a;--pg-border-md:#3b9eff38;--pg-input-bg:#ffffff08;--pg-row-bg:hsla(0,0%,100%,.025);--pg-shadow:0 8px 32px #0006}.vv-app[data-theme=light]{--pg-night:#f0f4f8;--pg-surface:#fff;--pg-surface2:#e8f0fa;--pg-blue:#1a6fc4;--pg-blue-mid:#1558a0;--pg-blue-dim:#1a6fc417;--pg-amber:#b45d00;--pg-amber-dim:#b45d0017;--pg-green:#16a34a;--pg-green-dim:#16a34a17;--pg-red:#dc2626;--pg-red-dim:#dc262617;--pg-orange:#ea580c;--pg-text:#0f1c2e;--pg-text-sec:#3a5a80;--pg-text-muted:#8ba5be;--pg-border:#1a6fc424;--pg-border-md:#1a6fc447;--pg-input-bg:rgba(0,0,0,.025);--pg-row-bg:rgba(0,0,0,.018);--pg-shadow:0 4px 20px #00000014}.vv-theme-btn{align-items:center;background:#3b9eff1f;background:var(--pg-blue-dim);border:1px solid #3b9eff38;border:1px solid var(--pg-border-md);border-radius:8px;color:#3b9eff;color:var(--pg-blue);cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:background .2s,border-color .2s,transform .2s;width:36px}.vv-theme-btn:hover{background:#3b9eff33;transform:scale(1.05)}.vv-theme-btn svg{height:16px;transition:transform .4s ease;width:16px}.vv-theme-btn:hover svg{transform:rotate(25deg)}.vv-app{background:#040d1a;background:var(--pg-night);color:#e8f0fe;color:var(--pg-text);display:grid;font-family:DM Sans,sans-serif;grid-template-rows:56px 1fr;height:100vh;overflow:hidden}.vv-topbar{background:#0a1929;background:var(--pg-surface);border-bottom:1px solid #3b9eff1a;border-bottom:1px solid var(--pg-border);gap:1rem;padding:0 1.25rem;z-index:50}.vv-logo,.vv-topbar{align-items:center;display:flex}.vv-logo{color:#e8f0fe;color:var(--pg-text);flex-shrink:0;font-family:Syne,sans-serif;font-size:1rem;font-weight:800;gap:8px;text-decoration:none}.vv-logo svg{filter:drop-shadow(0 0 4px rgba(59,158,255,.5));height:30px;width:26px}.vv-logo span{color:#3b9eff;color:var(--pg-blue)}.vv-divider{background:#3b9eff1a;background:var(--pg-border);flex-shrink:0;height:24px;width:1px}.vv-badge{align-items:center;color:#7a9cc4;color:var(--pg-text-sec);display:flex;font-size:12px;gap:6px}.vv-badge-dot{animation:pgPulse 2s ease-in-out infinite;background:#22c55e;background:var(--pg-green);border-radius:50%;box-shadow:0 0 6px #22c55e;box-shadow:0 0 6px var(--pg-green);height:7px;width:7px}@keyframes pgPulse{0%,to{box-shadow:0 0 6px #22c55e;box-shadow:0 0 6px var(--pg-green)}50%{box-shadow:0 0 14px #22c55e;box-shadow:0 0 14px var(--pg-green);opacity:.8}}.vv-clock{color:#e8f0fe;color:var(--pg-text);flex-shrink:0;font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;letter-spacing:.04em;margin-left:auto}.vv-date{color:#3d5a7a;color:var(--pg-text-muted);font-size:11px;font-weight:400;margin-left:8px}.vv-btn-urgence{align-items:center;animation:urgPulse 3s ease-in-out infinite;background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;color:#f87171;cursor:pointer;display:flex;flex-shrink:0;font-family:Syne,sans-serif;font-size:12px;font-weight:700;gap:6px;letter-spacing:.05em;padding:6px 14px;transition:all .2s}@keyframes urgPulse{0%,to{box-shadow:none}50%{box-shadow:0 0 16px #ef444440}}.vv-btn-urgence:hover{background:#ef444433;border-color:#ef444480;transform:scale(1.02)}.vv-btn-urgence svg{height:14px;width:14px}.vv-body{display:grid;grid-template-columns:260px 1fr;overflow:hidden}.vv-sidebar{background:#0a1929;background:var(--pg-surface);border-right:1px solid #3b9eff1a;border-right:1px solid var(--pg-border);display:flex;flex-direction:column;overflow-y:auto;padding:1rem 0}.vv-compteur{background:#0d2040;background:var(--pg-surface2);border:1px solid #3b9eff38;border:1px solid var(--pg-border-md);border-radius:16px;margin:0 1rem 1.25rem;padding:1rem 1.1rem}.vv-compteur-label{color:#3d5a7a;color:var(--pg-text-muted);font-size:10px;font-weight:500;letter-spacing:.12em;margin-bottom:8px;text-transform:uppercase}.vv-compteur-numbers{align-items:baseline;display:flex;gap:4px;margin-bottom:10px}.vv-compteur-current{color:#3b9eff;color:var(--pg-blue);font-family:Syne,sans-serif;font-size:2rem;font-weight:800;line-height:1}.vv-compteur-sep{color:#3d5a7a;color:var(--pg-text-muted);font-size:1.2rem}.vv-compteur-total{color:#7a9cc4;color:var(--pg-text-sec);font-family:Syne,sans-serif;font-size:1.2rem;font-weight:600}.vv-compteur-bar-wrap{background:#ffffff0f;border-radius:99px;height:6px;margin-bottom:6px;overflow:hidden}.vv-compteur-bar{background:#3b9eff;background:var(--pg-blue);border-radius:99px;height:100%;transition:width .5s ease}.vv-compteur-bar.warn{background:#f97316;background:var(--pg-orange)}.vv-compteur-bar.full{background:#ef4444;background:var(--pg-red)}.vv-compteur-dispo{color:#7a9cc4;color:var(--pg-text-sec);font-size:11px}.vv-compteur-dispo strong{color:#22c55e;color:var(--pg-green)}.vv-nav-section{margin-bottom:.5rem;padding:0 .75rem}.vv-nav-label{color:#3d5a7a;color:var(--pg-text-muted);display:block;font-size:10px;letter-spacing:.12em;margin-bottom:4px;padding:0 .5rem;text-transform:uppercase}.vv-nav-item{align-items:center;background:none;border:1px solid #0000;border-radius:8px;color:#7a9cc4;color:var(--pg-text-sec);cursor:pointer;display:flex;font-size:13.5px;font-weight:400;gap:10px;margin-bottom:2px;padding:9px 12px;text-align:left;transition:all .15s;width:100%}.vv-nav-item:hover{border-color:#3b9eff1a;border-color:var(--pg-border);color:#e8f0fe;color:var(--pg-text)}.vv-nav-item.active,.vv-nav-item:hover{background:#3b9eff1f;background:var(--pg-blue-dim)}.vv-nav-item.active{border-color:#3b9eff33;color:#3b9eff;color:var(--pg-blue);font-weight:500}.vv-nav-item svg{flex-shrink:0;height:16px;width:16px}.vv-nav-badge{background:#3b9eff1f;background:var(--pg-blue-dim);border-radius:99px;color:#3b9eff;color:var(--pg-blue);font-size:10px;font-weight:600;margin-left:auto;padding:2px 7px}.vv-nav-badge.orange{background:#f5a62326;background:var(--pg-amber-dim);color:#f5a623;color:var(--pg-amber)}.vv-sidebar-footer{border-top:1px solid #3b9eff1a;border-top:1px solid var(--pg-border);margin-top:auto;padding:1rem}.vv-user-chip{gap:10px}.vv-avatar,.vv-user-chip{align-items:center;display:flex}.vv-avatar{background:#3b9eff1f;background:var(--pg-blue-dim);border:1px solid #3b9eff40;border-radius:50%;color:#3b9eff;color:var(--pg-blue);flex-shrink:0;font-family:Syne,sans-serif;font-size:13px;font-weight:700;height:34px;justify-content:center;width:34px}.vv-user-info{flex:1 1;min-width:0}.vv-user-name{color:#e8f0fe;color:var(--pg-text);font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vv-user-role{font-size:11px}.vv-logout,.vv-user-role{color:#3d5a7a;color:var(--pg-text-muted)}.vv-logout{align-items:center;background:none;border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:6px;cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:all .15s;width:28px}.vv-logout:hover{background:#ef44441f;background:var(--pg-red-dim);border-color:#ef44444d;color:#ef4444;color:var(--pg-red)}.vv-logout svg{height:14px;width:14px}.vv-main{display:flex;flex-direction:column;overflow:hidden}.vv-page-header{align-items:flex-start;display:flex;flex-shrink:0;gap:1rem;justify-content:space-between;padding:1.25rem 1.5rem 0}.vv-page-title{color:#e8f0fe;color:var(--pg-text);font-family:Syne,sans-serif;font-size:1.3rem;font-weight:700}.vv-page-sub{color:#3d5a7a;color:var(--pg-text-muted);font-size:12px;margin-top:3px}.vv-content{display:flex;flex:1 1;flex-direction:column;gap:1rem;overflow-y:auto;padding:1rem 1.5rem 1.5rem}.vv-panel{animation:vvSlideDown .3s cubic-bezier(.16,1,.3,1);background:#0a1929;background:var(--pg-surface);border:1px solid #3b9eff38;border:1px solid var(--pg-border-md);border-radius:20px;padding:1.5rem}@keyframes vvSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.vv-panel-title{align-items:center;color:#e8f0fe;color:var(--pg-text);display:flex;font-family:Syne,sans-serif;font-size:1rem;font-weight:700;gap:8px;margin-bottom:1.25rem}.vv-panel-title svg{color:#3b9eff;color:var(--pg-blue);height:18px;width:18px}.vv-form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.vv-form-full{grid-column:1/-1}.vv-field-label{color:#3d5a7a;color:var(--pg-text-muted);display:block;font-size:11px;font-weight:500;letter-spacing:.08em;margin-bottom:6px;text-transform:uppercase}.vv-input{background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;color:#e8f0fe;color:var(--pg-text);font-family:DM Sans,sans-serif;font-size:14px;height:44px;outline:none;padding:0 12px;transition:border-color .2s,box-shadow .2s;width:100%}.vv-input::placeholder{color:#3d5a7a;color:var(--pg-text-muted)}.vv-input:focus{border-color:#1a6fc4;border-color:var(--pg-blue-mid);box-shadow:0 0 0 3px #3b9eff1a}.vv-input:disabled{cursor:not-allowed;opacity:.6}.vv-input.plaque{font-family:Syne,sans-serif;font-size:18px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.vv-select{background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;color:#e8f0fe;color:var(--pg-text);cursor:pointer;font-family:DM Sans,sans-serif;font-size:14px;height:44px;outline:none;padding:0 12px;transition:border-color .2s;width:100%}.vv-select:focus{border-color:#1a6fc4;border-color:var(--pg-blue-mid)}.vv-select option{background:#0a1929;background:var(--pg-surface)}.vv-textarea{background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;color:#e8f0fe;color:var(--pg-text);font-family:DM Sans,sans-serif;font-size:14px;min-height:90px;outline:none;padding:10px 12px;resize:vertical;transition:border-color .2s;width:100%}.vv-textarea:focus{border-color:#1a6fc4;border-color:var(--pg-blue-mid)}.vv-textarea::placeholder{color:#3d5a7a;color:var(--pg-text-muted)}.vv-reglement-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.vv-reglement-btn{align-items:center;background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;color:#3d5a7a;color:var(--pg-text-muted);cursor:pointer;display:flex;font-family:DM Sans,sans-serif;font-size:13px;gap:6px;justify-content:center;padding:10px;text-align:center;transition:all .15s}.vv-reglement-btn svg{height:15px;width:15px}.vv-reglement-btn:hover{border-color:#3b9eff38;border-color:var(--pg-border-md);color:#7a9cc4;color:var(--pg-text-sec)}.vv-reglement-btn.active{background:#3b9eff1f;background:var(--pg-blue-dim);border-color:#3b9eff;border-color:var(--pg-blue);color:#3b9eff;color:var(--pg-blue)}.vv-heure-display{align-items:center;background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;cursor:pointer;display:flex;height:44px;justify-content:space-between;padding:0 12px;transition:border-color .2s}.vv-heure-display:hover{border-color:#3b9eff38;border-color:var(--pg-border-md)}.vv-heure-val{color:#3b9eff;color:var(--pg-blue);font-family:Syne,sans-serif;font-size:15px;font-weight:700}.vv-heure-val.empty{color:#3d5a7a;color:var(--pg-text-muted);font-family:DM Sans,sans-serif;font-size:14px;font-weight:400}.vv-heure-display svg{color:#3d5a7a;color:var(--pg-text-muted);height:14px;width:14px}.vv-heure-picker{animation:vvSlideDown .2s ease;background:#0d2040;background:var(--pg-surface2);border:1px solid #3b9eff38;border:1px solid var(--pg-border-md);border-radius:12px;margin-top:8px;padding:1rem}.vv-heure-picker-label{color:#3d5a7a;color:var(--pg-text-muted);display:block;font-size:11px;letter-spacing:.1em;margin-bottom:8px;text-transform:uppercase}.vv-heure-grid{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(6,1fr);margin-bottom:10px}.vv-heure-grid.mins{grid-template-columns:repeat(4,1fr)}.vv-heure-cell{background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:6px;color:#7a9cc4;color:var(--pg-text-sec);cursor:pointer;font-size:12px;font-weight:500;padding:7px 4px;text-align:center;transition:all .12s}.vv-heure-cell:hover{border-color:#3b9eff38;border-color:var(--pg-border-md);color:#e8f0fe;color:var(--pg-text)}.vv-heure-cell.selected{background:#3b9eff1f;background:var(--pg-blue-dim);border-color:#3b9eff;border-color:var(--pg-blue);color:#3b9eff;color:var(--pg-blue);font-weight:700}.vv-btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .15s}.vv-btn svg{height:14px;width:14px}.vv-btn-primary{background:#1a6fc4;background:var(--pg-blue-mid);box-shadow:0 4px 14px #1a6fc44d;color:#fff}.vv-btn-primary:hover{background:#3b9eff;background:var(--pg-blue);box-shadow:0 6px 20px #3b9eff59;transform:translateY(-1px)}.vv-btn-ghost{background:#3b9eff1f;background:var(--pg-blue-dim);border-color:#3b9eff33;color:#3b9eff;color:var(--pg-blue)}.vv-btn-ghost:hover{background:#3b9eff33}.vv-btn-warn{background:#f5a62326;background:var(--pg-amber-dim);border-color:#f5a62333;color:#f5a623;color:var(--pg-amber)}.vv-btn-warn:hover{background:#f5a62333}.vv-btn-danger{background:#ef44441f;background:var(--pg-red-dim);border-color:#ef44444d;color:#f87171}.vv-btn-danger:hover{background:#ef444433}.vv-form-actions{border-top:1px solid #3b9eff1a;border-top:1px solid var(--pg-border);display:flex;gap:8px;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.vv-tabs{background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;display:flex;gap:4px;margin-bottom:.75rem;padding:3px}.vv-tab{border:1px solid #0000;border-radius:5px;color:#3d5a7a;color:var(--pg-text-muted);cursor:pointer;flex:1 1;font-size:12px;font-weight:500;padding:6px 8px;text-align:center;transition:all .15s}.vv-tab.active{background:#0d2040;background:var(--pg-surface2);border-color:#3b9eff1a;border-color:var(--pg-border);color:#e8f0fe;color:var(--pg-text)}.vv-search{align-items:center;background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;display:flex;gap:8px;height:38px;margin-bottom:.75rem;padding:0 12px;transition:border-color .2s}.vv-search:focus-within{border-color:#3b9eff38;border-color:var(--pg-border-md)}.vv-search svg{color:#3d5a7a;color:var(--pg-text-muted);flex-shrink:0;height:14px;width:14px}.vv-search input{background:none;border:none;color:#e8f0fe;color:var(--pg-text);flex:1 1;font-family:DM Sans,sans-serif;font-size:13px;outline:none}.vv-search input::placeholder{color:#3d5a7a;color:var(--pg-text-muted)}.vv-camion-list{display:flex;flex-direction:column;gap:6px}.vv-camion-row{grid-gap:12px;align-items:center;background:hsla(0,0%,100%,.025);background:var(--pg-row-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:12px;cursor:default;display:grid;gap:12px;grid-template-columns:auto 1fr auto auto;padding:10px 14px;transition:all .15s}.vv-camion-row:hover{background:#3b9eff1f;background:var(--pg-blue-dim);border-color:#3b9eff33}.vv-status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.vv-status-dot.present{background:#22c55e;background:var(--pg-green);box-shadow:0 0 6px #22c55e;box-shadow:0 0 6px var(--pg-green)}.vv-status-dot.alerte{background:#f5a623;background:var(--pg-amber);box-shadow:0 0 6px #f5a623;box-shadow:0 0 6px var(--pg-amber)}.vv-camion-plaque{color:#e8f0fe;color:var(--pg-text);font-family:Syne,sans-serif;font-size:14px;font-weight:700;letter-spacing:.04em}.vv-camion-meta{color:#3d5a7a;color:var(--pg-text-muted);font-size:11px;margin-top:1px}.vv-depart-time{color:#f5a623;color:var(--pg-amber);font-family:Syne,sans-serif;font-size:13px;font-weight:700;text-align:right}.vv-depart-time.depasse{color:#ef4444;color:var(--pg-red)}.vv-depart-label{font-size:10px;text-align:right}.vv-btn-sortie,.vv-depart-label{color:#3d5a7a;color:var(--pg-text-muted)}.vv-btn-sortie{align-items:center;background:none;border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:6px;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:5px;padding:5px 10px;transition:all .15s;white-space:nowrap}.vv-btn-sortie svg{height:11px;width:11px}.vv-btn-sortie:hover{background:#ef44441f;background:var(--pg-red-dim);border-color:#ef444466;color:#f87171}.vv-niveau-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr 1fr}.vv-modal-overlay{align-items:center;animation:vvFadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#040d1ad9;display:flex;inset:0;justify-content:center;padding:1.5rem;position:fixed;z-index:100}@keyframes vvFadeIn{0%{opacity:0}to{opacity:1}}.vv-modal{animation:vvSlideDown .35s cubic-bezier(.16,1,.3,1);background:#0a1929;background:var(--pg-surface);border:1px solid #3b9eff38;border:1px solid var(--pg-border-md);border-radius:20px;max-width:480px;padding:1.75rem;width:100%}.vv-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.vv-modal-title{align-items:center;color:#e8f0fe;color:var(--pg-text);display:flex;font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700;gap:8px}.vv-modal-close{align-items:center;background:none;border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:6px;color:#3d5a7a;color:var(--pg-text-muted);cursor:pointer;display:flex;font-size:18px;height:30px;justify-content:center;line-height:1;transition:all .15s;width:30px}.vv-modal-close:hover{border-color:#3b9eff38;border-color:var(--pg-border-md);color:#e8f0fe;color:var(--pg-text)}.vv-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:1.25rem}.vv-alert{align-items:flex-start;border-radius:8px;display:flex;font-size:12px;gap:8px;margin-bottom:1rem;padding:10px 14px}.vv-alert.danger{background:#ef44440f;border:1px solid #ef444426;color:#f87171}.vv-alert svg{flex-shrink:0;height:14px;margin-top:1px;width:14px}.vv-radio-list{display:flex;flex-direction:column;gap:6px}.vv-radio-label{align-items:center;background:#ffffff08;background:var(--pg-input-bg);border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:8px;color:#7a9cc4;color:var(--pg-text-sec);cursor:pointer;display:flex;font-size:13px;gap:8px;padding:9px 12px;transition:border-color .15s}.vv-radio-label:hover{border-color:#3b9eff38;border-color:var(--pg-border-md)}.vv-radio-label input{accent-color:#3b9eff;accent-color:var(--pg-blue)}.vv-photo-drop{align-items:center;background:#ffffff08;background:var(--pg-input-bg);border:2px dashed #3b9eff33;border-radius:12px;color:#3d5a7a;color:var(--pg-text-muted);cursor:pointer;display:flex;flex-direction:column;font-size:13px;gap:6px;height:90px;justify-content:center;margin-bottom:1rem;transition:all .2s}.vv-photo-drop:hover{background:#3b9eff0a;border-color:#3b9eff66}.vv-photo-drop svg{height:24px;width:24px}.vv-urgence-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-top:1rem}.vv-urgence-card{border:1px solid;border-radius:12px;cursor:pointer;padding:14px;text-align:center;transition:all .15s}.vv-urgence-card:hover{transform:translateY(-2px)}.vv-urgence-card.gendarmerie{background:#3b9eff14;border-color:#3b9eff40;color:#3b9eff;color:var(--pg-blue)}.vv-urgence-card.samu{background:#ef44441f;background:var(--pg-red-dim);border-color:#ef44444d;color:#f87171}.vv-urgence-card.pompiers{background:#f5a62326;background:var(--pg-amber-dim);border-color:#f5a6234d;color:#f5a623;color:var(--pg-amber)}.vv-urgence-card.responsable{background:#22c55e1f;background:var(--pg-green-dim);border-color:#22c55e4d;color:#22c55e;color:var(--pg-green)}.vv-urgence-icon{display:block;font-size:22px;margin-bottom:4px}.vv-urgence-label{font-size:12px;font-weight:500}.vv-urgence-num{display:block;font-family:Syne,sans-serif;font-size:1.3rem;font-weight:800;margin-top:6px}.vv-content::-webkit-scrollbar,.vv-sidebar::-webkit-scrollbar{width:4px}.vv-content::-webkit-scrollbar-thumb,.vv-sidebar::-webkit-scrollbar-thumb{background:#3b9eff33;border-radius:99px}.vv-burger{align-items:center;background:#3b9eff1f;background:var(--pg-blue-dim);border:1px solid #3b9eff38;border:1px solid var(--pg-border-md);border-radius:8px;color:#3b9eff;color:var(--pg-blue);cursor:pointer;display:none;flex-shrink:0;height:38px;justify-content:center;transition:background .15s,border-color .15s;width:38px}.vv-burger:hover{background:#3b9eff33;border-color:#3b9eff59}.vv-burger:active{transform:scale(.95)}.vv-drawer-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#040d1ab3;inset:0;opacity:0;pointer-events:none;position:fixed;transition:opacity .3s ease;z-index:200}.vv-drawer-backdrop.open{opacity:1;pointer-events:all}.vv-drawer{background:#0a1929;background:var(--pg-surface);border-right:1px solid #3b9eff38;border-right:1px solid var(--pg-border-md);bottom:0;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;transform:translateX(-100%);transition:transform .32s cubic-bezier(.16,1,.3,1);width:280px;z-index:201}.vv-drawer.open{transform:translateX(0)}.vv-drawer-header{align-items:center;border-bottom:1px solid #3b9eff1a;border-bottom:1px solid var(--pg-border);display:flex;flex-shrink:0;height:56px;justify-content:space-between;padding:0 1rem}.vv-drawer-close{align-items:center;background:none;border:1px solid #3b9eff1a;border:1px solid var(--pg-border);border-radius:6px;color:#3d5a7a;color:var(--pg-text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s;width:32px}.vv-drawer-close:hover{background:#3b9eff1f;background:var(--pg-blue-dim);border-color:#3b9eff38;border-color:var(--pg-border-md);color:#e8f0fe;color:var(--pg-text)}.vv-drawer-close svg{height:16px;width:16px}.vv-drawer-body{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:1rem 0}.vv-drawer-body .vv-sidebar-footer{margin-top:auto}@media (max-width:768px){.vv-burger{display:flex}.vv-sidebar{display:none}.vv-desktop-only{display:none!important}.vv-urgence-txt{display:none}.vv-body,.vv-form-grid{grid-template-columns:1fr}.vv-app{height:auto;min-height:100vh;overflow:auto}.vv-content,.vv-main{overflow:visible}.vv-topbar{gap:.5rem}.vv-logo{flex:1 1}.vv-clock{font-size:.85rem}}@media (min-width:769px){.vv-burger,.vv-drawer,.vv-drawer-backdrop{display:none!important}.vv-urgence-txt{display:inline}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}:root{--night:#040d1a;--surface:#0a1929;--surface2:#0d2040;--blue:#3b9eff;--blue-mid:#1a6fc4;--blue-dim:#3b9eff1f;--amber:#f5a623;--amber-dim:#f5a62326;--green:#22c55e;--red:#ef4444;--text:#e8f0fe;--text-sec:#7a9cc4;--text-muted:#3d5a7a;--border:#3b9eff1a;--border-md:#3b9eff38;--r-sm:8px;--r-md:12px;--r-lg:16px}*{box-sizing:border-box;margin:0;padding:0}body{background:#040d1a;background:var(--night);color:#e8f0fe;color:var(--text);font-family:DM Sans,sans-serif;overflow:hidden}
/*# sourceMappingURL=main.c810c8f5.css.map*/