/* ═══ PLYX — Style de l'application ═══ */
:root{
  --bg:#14171c;--bg2:#1b1f26;--card:#1f242c;--line:#2c333d;
  --ink:#eef1f4;--muted:#8a94a1;--accent:#5fe3ff;--accent-deep:#16a8c4;
  --danger:#e8483f;--ok:#3ecf6a;--warn:#e3a13a;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:"Segoe UI",system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:15px}

/* ── Connexion ── */
#login{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% -20%,#1d232c,#14171c)}
.login-box{background:var(--card);border:1px solid var(--line);border-radius:1rem;padding:2.4rem 2.8rem;width:340px;text-align:center;box-shadow:0 24px 80px #000a}
.login-logo{font-size:2.2rem;font-weight:800;color:var(--accent);letter-spacing:.04em}
.login-sub{color:var(--muted);margin:.2rem 0 1.4rem}
.login-box input{width:100%;padding:.65rem .8rem;border-radius:.5rem;border:1px solid var(--line);background:var(--bg);color:var(--ink);margin-bottom:.8rem;font-size:.95rem}
.login-box button{width:100%;padding:.65rem;border-radius:.5rem;border:none;background:var(--accent-deep);color:#fff;font-weight:700;cursor:pointer;font-size:.95rem}
#login-err{color:var(--danger);margin-top:.7rem;font-size:.85rem;min-height:1.2em}

/* ── Structure ── */
#app{display:flex;height:100vh}
#sidebar{width:215px;flex:none;background:var(--bg2);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:1rem .7rem}
#sidebar .brand{font-size:1.5rem;font-weight:800;color:var(--accent);padding:.2rem .6rem 1rem;letter-spacing:.04em}
#sidebar nav{flex:1;display:flex;flex-direction:column;gap:.15rem}
#sidebar nav a{display:flex;align-items:center;gap:.5rem;padding:.55rem .7rem;border-radius:.5rem;color:var(--ink);text-decoration:none;font-size:.92rem}
#sidebar nav a:hover{background:#ffffff10}
#sidebar nav a.active{background:var(--accent-deep);color:#fff;font-weight:700}
#sidebar nav a.soon{opacity:.45}
#sidebar nav a.soon span{margin-left:auto;font-size:.62rem;background:var(--line);border-radius:1rem;padding:.1rem .45rem}
.sync{margin-top:.8rem;padding:.5rem .7rem;border-radius:.5rem;font-size:.8rem;text-align:center;border:1px solid var(--line)}
.sync.ok{color:var(--ok)} .sync.pending{color:var(--warn)} .sync.off{color:var(--danger)}

#main{flex:1;display:flex;flex-direction:column;min-width:0}
#topbar{display:flex;align-items:center;gap:1rem;padding:.9rem 1.4rem;border-bottom:1px solid var(--line);background:var(--bg2)}
#topbar h1{font-size:1.15rem;flex:1}
#page{flex:1;overflow:auto;padding:1.3rem 1.4rem}

/* ── Composants ── */
.btn{padding:.5rem .9rem;border-radius:.5rem;border:1px solid var(--line);background:var(--card);color:var(--ink);cursor:pointer;font-size:.88rem}
.btn:hover{border-color:var(--accent-deep)}
.btn.primary{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff;font-weight:700}
.btn.danger{color:#ff9a94;border-color:#5a2a28}
.btn.sm{padding:.25rem .55rem;font-size:.8rem}
.btn:disabled{opacity:.45;cursor:not-allowed}
.search{padding:.5rem .8rem;border-radius:.5rem;border:1px solid var(--line);background:var(--bg);color:var(--ink);width:260px;font-size:.88rem}

.table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:.7rem;overflow:hidden}
.table th{padding:.6rem .8rem;text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--line)}
.table td{padding:.6rem .8rem;border-bottom:1px solid #ffffff08;font-size:.9rem}
.table tr:hover td{background:#ffffff06}
.mut{color:var(--muted);font-size:.82rem}
.chip{display:inline-block;background:#ffffff10;border:1px solid var(--line);border-radius:1rem;padding:.05rem .5rem;font-size:.75rem;margin:.05rem 0}
.hint{color:var(--muted);padding:1.5rem 0;max-width:600px;line-height:1.5}

.cards{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:.8rem;padding:1.1rem 1.6rem;min-width:150px;color:var(--muted);font-size:.85rem}
.card .big{font-size:2rem;font-weight:800;color:var(--ink)}
.panel{background:var(--card);border:1px solid var(--line);border-radius:.8rem;padding:1.2rem;max-width:520px}
.panel h3{margin-bottom:.8rem}
.panel .btn{margin-right:.6rem;margin-top:.6rem}

/* ── Modale ── */
.modal-ov{position:fixed;inset:0;z-index:900;background:#000000b8;display:flex;align-items:center;justify-content:center;padding:1rem}
.modal{background:var(--bg2);border:1px solid var(--line);border-radius:.9rem;padding:1.4rem;width:min(680px,96vw);max-height:92vh;overflow:auto;box-shadow:0 24px 80px #000c}
.modal h3{margin-bottom:1rem}
.modal h4{margin:1.1rem 0 .5rem;color:var(--muted)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.7rem .9rem}
.grid2 label{display:flex;flex-direction:column;gap:.25rem;font-size:.78rem;color:var(--muted)}
.grid2 .span2{grid-column:1/3}
.grid2 input,.grid2 select,.grid2 textarea{padding:.5rem .65rem;border-radius:.45rem;border:1px solid var(--line);background:var(--bg);color:var(--ink);font-size:.9rem;font-family:inherit}
.veh-row{display:flex;align-items:center;gap:.6rem;padding:.45rem .6rem;background:var(--card);border:1px solid var(--line);border-radius:.5rem;margin-bottom:.4rem;font-size:.88rem}
.veh-row button{margin-left:auto}
.modal-btns{display:flex;gap:.6rem;margin-top:1.3rem}

/* ── Toast ── */
#toast{position:fixed;bottom:1.4rem;left:50%;transform:translate(-50%,120%);background:var(--card);border:1px solid var(--line);border-radius:.6rem;padding:.7rem 1.2rem;font-size:.9rem;transition:transform .25s;z-index:999;box-shadow:0 10px 40px #000a}
#toast.show{transform:translate(-50%,0)}
#toast.err{border-color:var(--danger);color:#ffb3ae}