/* ============================================================
   THÈME — App Analyse (direction « Cockpit néon lisible » = A3)
   ============================================================ */
:root{
  --card:rgba(20,28,52,.55);--line:rgba(120,140,200,.16);
  --ink:#eaf0ff;--ink2:#9aa6cf;--ink3:#6b76a3;
  --cyan:#22d3ee;--violet:#a78bfa;--green:#34d399;--amber:#fbbf24;--red:#fb7185;--blue:#60a5fa;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);
  background:radial-gradient(1100px 600px at 12% -8%,rgba(34,211,238,.16),transparent 60%),
    radial-gradient(900px 600px at 105% 0%,rgba(167,139,250,.18),transparent 55%),
    linear-gradient(180deg,#070b16,#070a13);min-height:100vh}
h1,h2,h3{font-family:'Space Grotesk','Inter',sans-serif}
.glass{background:var(--card);border:1px solid var(--line);border-radius:20px;backdrop-filter:blur(14px);
  box-shadow:0 18px 50px -24px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.05)}
.tnum{font-family:'Space Grotesk'}
.pos{color:var(--green)}.neg{color:var(--red)}
.spacer{flex:1}
img.logo{object-fit:cover;display:block}
/* Champs date/mois : calendrier natif bien visible sur fond sombre */
.input[type=date],.input[type=month]{color-scheme:dark;cursor:pointer}
.input::-webkit-calendar-picker-indicator{filter:invert(1) brightness(1.4);opacity:.85;cursor:pointer;font-size:15px;padding-left:4px}
.input::-webkit-calendar-picker-indicator:hover{opacity:1}

/* ----- Connexion ----- */
.login{min-height:100vh;display:grid;place-items:center;padding:24px}
.login .box{width:100%;max-width:380px;padding:30px 28px;border-radius:22px}
.login .logo{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-family:'Space Grotesk';font-weight:800;font-size:20px;color:#06121a;margin:0 auto 16px;
  background:linear-gradient(135deg,var(--cyan),var(--violet));box-shadow:0 0 26px rgba(34,211,238,.5)}
.login h1{text-align:center;font-size:21px;margin:0 0 4px;letter-spacing:.02em}
.login .sub{text-align:center;color:var(--ink2);font-size:13px;margin-bottom:20px}
.field{margin-bottom:12px}
.field label{display:block;font-size:12px;color:var(--ink2);font-weight:600;margin-bottom:5px}
.input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:rgba(10,16,34,.6);color:var(--ink);font:inherit;font-size:14px}
.input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.15)}
.btn{width:100%;padding:13px;border:0;border-radius:12px;font:inherit;font-weight:700;font-size:14.5px;color:#06121a;cursor:pointer;
  background:linear-gradient(135deg,var(--cyan),var(--violet));box-shadow:0 0 18px rgba(34,211,238,.4)}
.btn:disabled{opacity:.6;cursor:default}
.linkbtn{background:none;border:0;color:var(--ink2);font:inherit;font-size:12.5px;cursor:pointer;text-decoration:underline;margin-top:12px;display:block;width:100%;text-align:center}
.err{color:var(--red);font-size:13px;text-align:center;margin-top:10px;min-height:18px}

/* ----- Layout plateforme ----- */
.app{display:flex;min-height:100vh}
.side{width:248px;flex:0 0 248px;padding:22px 16px;border-right:1px solid var(--line);
  background:linear-gradient(180deg,rgba(12,18,38,.7),rgba(8,12,24,.4));position:sticky;top:0;height:100vh;overflow:auto}
.brand{display:flex;align-items:center;gap:12px;font-family:'Space Grotesk';font-weight:700;font-size:17px;letter-spacing:.04em;margin-bottom:6px;padding:0 6px}
.brand .logo{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;font-weight:800;color:#06121a;
  background:linear-gradient(135deg,var(--cyan),var(--violet));box-shadow:0 0 22px rgba(34,211,238,.5)}
.brand small{display:block;font-family:'Inter';font-weight:500;font-size:10px;color:var(--ink2);letter-spacing:.2em;margin-top:1px}
.navlbl{font-size:10px;color:var(--ink3);letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin:18px 8px 8px}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--ink2);
  text-decoration:none;font-size:13.5px;font-weight:600;margin-bottom:3px;cursor:pointer;border:1px solid transparent}
.nav a .ic{width:20px;text-align:center}
.nav a:hover{background:rgba(34,211,238,.06);color:var(--ink)}
.nav a.on{color:var(--ink);background:linear-gradient(135deg,rgba(34,211,238,.18),rgba(167,139,250,.16));border-color:var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.nav a.soon{opacity:.55}
.nav a .badge{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.06em;color:var(--amber);background:rgba(251,191,36,.12);padding:2px 7px;border-radius:999px}
.who{margin-top:18px;padding:12px;border-radius:13px;border:1px solid var(--line);background:rgba(10,16,34,.5);font-size:12px;color:var(--ink2)}
.who b{color:var(--ink)}
.logoutb{margin-top:10px;width:100%;border:1px solid var(--line);background:rgba(10,16,34,.5);color:var(--ink2);font:inherit;font-size:12.5px;font-weight:600;padding:9px;border-radius:11px;cursor:pointer}
.logoutb:hover{color:var(--ink)}

.main{flex:1;min-width:0;padding:22px 26px 60px}
.top{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.h1{font-size:22px;font-weight:700;letter-spacing:-.3px}
.h1 .sub{display:block;font-size:12.5px;color:var(--ink3);font-weight:500;font-family:'Inter';margin-top:2px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:12px;border:1px solid var(--line);
  background:rgba(15,22,44,.6);color:var(--ink);font-size:13px;font-weight:600}
.pill b{color:var(--cyan)}
.pill select,.pill input{border:0;background:transparent;color:var(--ink);font:inherit;font-weight:700;cursor:pointer}
.pill select option{background:#0b1124;color:var(--ink)}
.pill input{cursor:text;color-scheme:dark}
.periodbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:20px}
.seg{display:inline-flex;background:rgba(10,16,34,.7);border:1px solid var(--line);border-radius:12px;padding:4px}
.seg button{border:0;background:transparent;color:var(--ink2);font:inherit;font-weight:600;font-size:13px;padding:8px 14px;border-radius:9px;cursor:pointer}
.seg button.on{color:#06121a;background:linear-gradient(135deg,var(--cyan),var(--violet));box-shadow:0 0 16px rgba(34,211,238,.45)}
.seg.alt button.on{background:linear-gradient(135deg,var(--violet),var(--blue))}
.lbl{font-size:11px;color:var(--ink3);letter-spacing:.12em;text-transform:uppercase;font-weight:600}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.kpi{grid-column:span 3;padding:18px 20px}
.kpi .k{font-size:12px;color:var(--ink2);letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.kpi .v{font-size:32px;font-weight:700;margin:8px 0 4px;letter-spacing:-.5px;font-family:'Space Grotesk'}
.kpi .v .u{font-size:17px;color:var(--ink2)}
.trend{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px}
.trend.up{color:var(--green);background:rgba(52,211,153,.12)}
.trend.down{color:var(--red);background:rgba(251,113,133,.12)}
.trend.flat{color:var(--ink2);background:rgba(120,140,200,.12)}
.kpisub{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.panel{padding:18px 20px}
.panel h3{margin:0 0 4px;font-size:15px;font-weight:600}
.panel .psub{font-size:12px;color:var(--ink3);margin-bottom:8px}
.tag{font-size:10.5px;font-weight:700;letter-spacing:.12em;color:var(--violet);text-transform:uppercase}
.c8{grid-column:span 8}.c4{grid-column:span 4}.c6{grid-column:span 6}.c12{grid-column:span 12}
.h300{height:300px}.h260{height:260px}
.toggles{display:flex;gap:8px;flex-wrap:wrap;margin:2px 0 10px}
.tgl{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink2);
  border:1px solid var(--line);background:rgba(10,16,34,.5);padding:5px 10px;border-radius:999px;cursor:pointer;user-select:none}
.tgl .sw{width:9px;height:9px;border-radius:3px}.tgl.on .sw{box-shadow:0 0 8px currentColor}
table{width:100%;border-collapse:collapse}
th,td{text-align:right;padding:10px 8px;font-size:13px;border-bottom:1px solid var(--line)}
th{color:var(--ink3);font-weight:600;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase}
td:first-child,th:first-child{text-align:left;font-weight:600}
tr:last-child td{border-bottom:0}
.tot td{font-weight:800;color:var(--cyan);border-top:2px solid var(--line)}
.empty{padding:40px 20px;text-align:center;color:var(--ink3);font-size:13.5px;line-height:1.6}
.loading{padding:50px;text-align:center;color:var(--ink2);font-size:14px}
.soonpanel{padding:60px 28px;text-align:center}
.soonpanel .big{font-size:40px;margin-bottom:12px}
.soonpanel h3{font-size:18px;margin:0 0 8px}
.soonpanel p{color:var(--ink2);font-size:13.5px;max-width:520px;margin:0 auto;line-height:1.6}
.note{font-size:11px;color:var(--ink3);margin-top:16px;text-align:center}
@media(max-width:1100px){.side{display:none}.kpi{grid-column:span 6}.c8,.c4,.c6{grid-column:span 12}}
