:root{
  --bg:#f4f6fa; --panel:#ffffff; --panel-2:#f8fafc; --panel-3:#eef2f7;
  --line:#e4e8ef; --line-2:#eef1f6;
  --ink:#0f172a; --muted:#5b6675; --dim:#94a3b8;
  --accent:#0e9f88; --accent-ink:#0b6e60; --accent-soft:#d7f5ee; --accent-deep:#0b8773;
  --ok:#16a34a; --ok-soft:#dcfce7; --ok-line:#bbf7d0;
  --off:#dc2626; --off-soft:#fee2e2; --off-line:#fecaca;
  --warn:#d97706; --warn-soft:#fef3c7; --warn-line:#fde68a;
  --info:#2563eb; --info-soft:#dbeafe;
  --violet:#7c3aed; --violet-soft:#ede9fe;
  --sans:"Geist", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --shadow:0 1px 2px 0 #0f172a0a, 0 1px 3px 0 #0f172a08;
  --shadow-lg:0 10px 30px -8px #0f172a26, 0 4px 10px -4px #0f172a14;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased}
body{font-size:14px;line-height:1.5}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,select{font:inherit}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:#cbd3df;border-radius:99px;border:3px solid var(--bg)}

/* ===== Layout shell ===== */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:#0f1729;color:#cbd5e1;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:11px;padding:20px 20px 18px}
.side-brand .mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#0e9f88,#16d3b0);display:grid;place-items:center;color:#04201a;font-weight:700;font-size:15px;letter-spacing:-.02em;box-shadow:0 2px 8px #0e9f8855}
.side-brand .nm{display:flex;flex-direction:column;line-height:1.15}
.side-brand .nm b{font-size:14.5px;font-weight:600;color:#fff;letter-spacing:-.01em}
.side-brand .nm small{font-family:var(--mono);font-size:9px;color:#64748b;letter-spacing:.16em;text-transform:uppercase;margin-top:2px}
.side-sec{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#475569;padding:18px 22px 8px;font-weight:600}
.side-nav{display:flex;flex-direction:column;gap:2px;padding:0 12px}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:9px;color:#94a3b8;font-size:13.5px;font-weight:500;transition:.13s;position:relative}
.nav-item:hover{background:#1e293b;color:#e2e8f0}
.nav-item.on{background:#1e2a44;color:#fff}
.nav-item.on::before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:99px;background:var(--accent);box-shadow:0 0 10px #0e9f88}
.nav-item svg{width:17px;height:17px;flex-shrink:0}
.nav-item .badge{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:600;padding:1px 7px;border-radius:99px;background:#334155;color:#cbd5e1}
.nav-item.on .badge{background:var(--accent);color:#04201a}
.nav-item .badge.alert{background:var(--off);color:#fff}
.side-foot{margin-top:auto;padding:16px;border-top:1px solid #1e293b;font-family:var(--mono);font-size:10px;color:#475569;letter-spacing:.04em;line-height:1.6}
.side-foot .dot{display:inline-block;width:6px;height:6px;border-radius:99px;background:var(--ok);margin-right:6px;box-shadow:0 0 6px var(--ok)}
.side-foot .logout{margin-top:10px;color:#64748b;display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:11.5px;font-weight:500;transition:.13s}
.side-foot .logout:hover{color:#e2e8f0}
.side-foot .logout svg{width:13px;height:13px}

/* Topbar */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{position:sticky;top:0;z-index:30;background:#ffffffd9;backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:0 28px;height:62px;display:flex;align-items:center;gap:18px}
.topbar h1{margin:0;font-size:18px;font-weight:600;letter-spacing:-.02em}
.topbar .crumb{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.04em}
.admin{margin-left:auto;display:flex;align-items:center;gap:10px;padding:5px 7px 5px 12px;border-radius:99px;border:1px solid var(--line);background:var(--panel)}
.admin .who{text-align:right;line-height:1.2}
.admin .who b{font-size:12.5px;font-weight:600;display:block}
.admin .who small{font-family:var(--mono);font-size:9.5px;color:var(--dim);letter-spacing:.04em}
.admin .av{width:32px;height:32px;border-radius:99px;background:linear-gradient(135deg,#0f766e,#0e9f88);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700;font-family:var(--mono)}

.view{padding:26px 28px 60px;max-width:1380px;width:100%}
.screen{display:none;animation:fade .25s ease}
.screen.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ===== Shared bits ===== */
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:9px;font-size:13px;font-weight:500;border:1px solid var(--line);background:var(--panel);transition:.14s;white-space:nowrap}
.btn:hover{background:var(--panel-2);border-color:#cbd5e1}
.btn svg{width:14px;height:14px}
.btn.primary{background:var(--accent);color:#fff;border-color:transparent;font-weight:600;box-shadow:0 1px 2px #0e9f8833}
.btn.primary:hover{background:var(--accent-deep)}
.btn.danger{color:var(--off);border-color:var(--off-line);background:var(--off-soft)}
.btn.danger:hover{background:#fde0e0}
.btn.sm{padding:6px 11px;font-size:12px;border-radius:8px}
.btn:disabled{opacity:.45;cursor:not-allowed}

.badge-st{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:99px;font-size:11.5px;font-weight:600;letter-spacing:.01em}
.badge-st .d{width:6px;height:6px;border-radius:99px;background:currentColor}
.badge-st.ok{background:var(--ok-soft);color:#15803d;border:1px solid var(--ok-line)}
.badge-st.off{background:var(--off-soft);color:#b91c1c;border:1px solid var(--off-line)}
.badge-st.warn{background:var(--warn-soft);color:#b45309;border:1px solid var(--warn-line)}
.badge-st.neutral{background:var(--panel-3);color:var(--muted);border:1px solid var(--line)}

/* Toggle switch */
.sw{position:relative;width:40px;height:23px;border-radius:99px;background:#cbd5e1;transition:.18s;flex-shrink:0;cursor:pointer;border:0}
.sw::after{content:"";position:absolute;top:2.5px;left:2.5px;width:18px;height:18px;border-radius:99px;background:#fff;box-shadow:0 1px 3px #0f172a40;transition:.18s}
.sw.on{background:var(--accent)}
.sw.on::after{transform:translateX(17px)}
.sw:disabled{opacity:.5;cursor:not-allowed}

table{width:100%;border-collapse:collapse}
thead th{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);font-weight:600;text-align:left;padding:11px 16px;background:var(--panel-2);border-bottom:1px solid var(--line);white-space:nowrap}
thead th.r{text-align:right}
tbody td{padding:13px 16px;font-size:13px;border-bottom:1px solid var(--line-2);vertical-align:middle}
tbody tr:last-child td{border-bottom:0}
tbody tr{transition:background .1s}
tbody tr:hover{background:var(--panel-2)}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:.01em}

.cell-name{font-weight:600;letter-spacing:-.005em}
.cell-sub{font-family:var(--mono);font-size:10.5px;color:var(--dim);margin-top:2px;letter-spacing:.02em}
.av-sm{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;color:#fff;font-family:var(--mono);font-size:9px;font-weight:700;flex-shrink:0}
.av-c0{background:linear-gradient(135deg,#0f766e,#14b8a6)}
.av-c1{background:linear-gradient(135deg,#1d4ed8,#3b82f6)}
.av-c2{background:linear-gradient(135deg,#7c3aed,#a855f7)}
.av-c3{background:linear-gradient(135deg,#be185d,#ec4899)}
.av-c4{background:linear-gradient(135deg,#b45309,#f59e0b)}
.av-c5{background:linear-gradient(135deg,#0369a1,#0ea5e9)}

.rowacts{display:flex;align-items:center;justify-content:flex-end;gap:8px}

/* ===== Dashboard ===== */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{padding:18px 20px;position:relative;overflow:hidden}
.stat .k{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:14px}
.stat .k .ic{width:26px;height:26px;border-radius:8px;display:grid;place-items:center}
.stat .k .ic svg{width:14px;height:14px}
.stat.s-clients .ic{background:var(--accent-soft);color:var(--accent-ink)}
.stat.s-phones .ic{background:var(--info-soft);color:var(--info)}
.stat.s-active .ic{background:var(--ok-soft);color:var(--ok)}
.stat.s-events .ic{background:var(--violet-soft);color:var(--violet)}
.stat .big{font-family:var(--mono);font-size:34px;font-weight:300;letter-spacing:-.04em;line-height:1;display:flex;align-items:baseline;gap:8px}
.stat .big .sub{font-size:15px;color:var(--dim);font-weight:400}
.stat .meta{margin-top:10px;display:flex;align-items:center;gap:10px;font-size:11.5px;color:var(--muted)}
.stat .meta .pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:99px}
.stat .meta .pill.up{background:var(--ok-soft);color:#15803d}
.stat .meta .pill.down{background:var(--off-soft);color:#b91c1c}
.stat .meta .pill.neutral{background:var(--panel-3);color:var(--muted)}

.dash-grid{display:grid;grid-template-columns:1fr 372px;gap:14px}
.panel-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line-2)}
.panel-head h2{margin:0;font-size:14.5px;font-weight:600;letter-spacing:-.01em}
.panel-head .sub{font-family:var(--mono);font-size:10.5px;color:var(--dim);letter-spacing:.04em}
.panel-head .aux{margin-left:auto;display:flex;gap:6px}

/* Breakdown bars (connexions par resultat) */
.brk{padding:18px 20px;display:flex;flex-direction:column;gap:14px}
.brk-row{display:flex;flex-direction:column;gap:6px}
.brk-row .top{display:flex;align-items:center;gap:9px;font-size:12.5px}
.brk-row .top .lbl{font-weight:500}
.brk-row .top .n{margin-left:auto;font-family:var(--mono);font-weight:600}
.brk-row .top .pct{font-family:var(--mono);font-size:11px;color:var(--dim);width:46px;text-align:right}
.brk-bar{height:8px;border-radius:99px;background:var(--panel-3);overflow:hidden}
.brk-bar .fill{height:100%;border-radius:99px;transition:width .4s ease}
.brk-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0}

.alerts{display:flex;flex-direction:column}
.alert{display:flex;align-items:flex-start;gap:12px;padding:13px 18px;border-bottom:1px solid var(--line-2)}
.alert:last-child{border-bottom:0}
.alert .ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.alert .ic svg{width:15px;height:15px}
.alert.warn .ic{background:var(--warn-soft);color:var(--warn)}
.alert.off .ic{background:var(--off-soft);color:var(--off)}
.alert.info .ic{background:var(--info-soft);color:var(--info)}
.alert .body{flex:1;min-width:0}
.alert .t{font-size:13px;font-weight:500;line-height:1.4}
.alert .t b{font-weight:600}
.alert .when{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:3px;letter-spacing:.02em}

.feed{display:flex;flex-direction:column}
.feed-row{display:grid;grid-template-columns:24px 1fr auto;gap:11px;padding:11px 20px;border-bottom:1px solid var(--line-2);align-items:center}
.feed-row:last-child{border-bottom:0}
.feed-row .ic{width:24px;height:24px;border-radius:99px;display:grid;place-items:center}
.feed-row .ic svg{width:11px;height:11px}
.feed-row.ok .ic{background:var(--ok-soft);color:var(--ok)}
.feed-row.off .ic{background:var(--off-soft);color:var(--off)}
.feed-row.warn .ic{background:var(--warn-soft);color:var(--warn)}
.feed-row .txt{font-size:12.5px;line-height:1.4}
.feed-row .txt b{font-weight:600}
.feed-row .txt small{display:block;font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:1px}
.feed-row .ts{font-family:var(--mono);font-size:10px;color:var(--dim)}

/* ===== Toolbar (lists) ===== */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.toolbar .ttl{font-size:13px;color:var(--muted)}
.toolbar .ttl b{color:var(--ink);font-weight:600}
.toolbar .right{margin-left:auto;display:flex;align-items:center;gap:10px}
.filterpill{display:inline-flex;align-items:center;gap:8px;padding:8px 13px;border-radius:9px;border:1px solid var(--line);background:var(--panel);font-size:12.5px;color:var(--muted);font-weight:500}
.filterpill svg{width:13px;height:13px;color:var(--dim)}
.filterpill.active{border-color:#0e9f8855;background:var(--accent-soft);color:var(--accent-ink)}
.listsearch{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:9px;background:var(--panel);border:1px solid var(--line);width:240px}
.listsearch svg{width:14px;height:14px;color:var(--dim)}
.listsearch input{border:0;background:none;outline:none;flex:1;font-size:13px}

/* ===== Client detail ===== */
.detail-top{display:grid;grid-template-columns:1fr 320px;gap:14px;margin-bottom:16px}
.client-hero{padding:22px 24px}
.client-hero .row1{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.client-hero .logo{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;color:#fff;font-family:var(--mono);font-size:16px;font-weight:700}
.client-hero h2{margin:0;font-size:22px;font-weight:600;letter-spacing:-.02em}
.client-hero .id{font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-top:3px;letter-spacing:.04em}
.field-grid{display:grid;grid-template-columns:1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);font-weight:600}
.field .inp{padding:9px 13px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);font-size:13px;display:flex;align-items:center;gap:9px}
.field .inp.mono{font-family:var(--mono);font-size:12px}
.field .inp svg{width:13px;height:13px;color:var(--dim);flex-shrink:0}
.field input.inp{outline:none;color:var(--ink)}
.field input.inp:focus{border-color:#0e9f8866;background:#fff}
.field textarea{padding:10px 13px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);font-size:13px;font-family:var(--sans);resize:vertical;min-height:62px;outline:none;line-height:1.5;color:var(--ink)}
.field textarea:focus{border-color:#0e9f8866;background:#fff}

.control-card{padding:20px 22px;display:flex;flex-direction:column;gap:0}
.bigtoggle{display:flex;align-items:center;gap:14px;padding:14px;border-radius:11px;border:1px solid var(--ok-line);background:var(--ok-soft);margin-bottom:16px}
.bigtoggle .info{flex:1}
.bigtoggle .info .s{font-size:14px;font-weight:600;color:#15803d}
.bigtoggle .info .d{font-size:11.5px;color:#15803d;opacity:.85;margin-top:2px}
.bigtoggle .sw{width:48px;height:27px}
.bigtoggle .sw::after{width:22px;height:22px}
.bigtoggle .sw.on::after{transform:translateX(21px)}
.ctl-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 0;border-top:1px solid var(--line-2)}
.ctl-row .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);font-weight:600}
.ctl-row .v{font-size:13px;font-weight:500;display:flex;align-items:center;gap:9px}
.ctl-row .v.mono{font-family:var(--mono);font-size:12.5px}
.editlink{font-size:11.5px;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.editlink svg{width:11px;height:11px}

/* Tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:0;padding:0 4px}
.tab{padding:12px 16px;font-size:13.5px;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:.13s;display:inline-flex;align-items:center;gap:8px}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--accent-ink);border-bottom-color:var(--accent);font-weight:600}
.tab .ct{font-family:var(--mono);font-size:10px;font-weight:600;padding:1px 7px;border-radius:99px;background:var(--panel-3);color:var(--muted)}
.tab.on .ct{background:var(--accent-soft);color:var(--accent-ink)}
.tabpanel{display:none}
.tabpanel.on{display:block}
.keyrow-pref{font-family:var(--mono);font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:8px}
.keyrow-pref .dots{color:var(--dim);letter-spacing:1px}

/* ===== Modal ===== */
.overlay{position:fixed;inset:0;background:#0f172a66;backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:100;padding:24px}
.overlay.on{display:flex;animation:fade .15s ease}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:460px;overflow:hidden;animation:pop .18s cubic-bezier(.2,.9,.3,1.2)}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:flex-start;gap:14px;padding:22px 24px 16px}
.modal-head .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.modal-head .ic svg{width:21px;height:21px}
.modal-head.danger .ic{background:var(--off-soft);color:var(--off)}
.modal-head.warn .ic{background:var(--warn-soft);color:var(--warn)}
.modal-head.ok .ic{background:var(--accent-soft);color:var(--accent-ink)}
.modal-head h3{margin:0;font-size:16.5px;font-weight:600;letter-spacing:-.01em}
.modal-head p{margin:5px 0 0;font-size:13px;color:var(--muted);line-height:1.5}
.modal-body{padding:0 24px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:18px 24px 22px}
.modal .field{margin-bottom:14px}
.modal .field input.inp{background:var(--panel-2)}

.warnbox{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:10px;background:var(--warn-soft);border:1px solid var(--warn-line);font-size:12.5px;color:#92400e;line-height:1.5;margin-bottom:4px}
.warnbox svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}
.keyreveal{display:flex;align-items:center;gap:10px;padding:13px 15px;border-radius:10px;background:#0f1729;margin:14px 0 6px}
.keyreveal code{font-family:var(--mono);font-size:13px;color:#5eead4;flex:1;word-break:break-all;letter-spacing:.01em}
.keyreveal .copy{padding:7px 12px;border-radius:8px;background:#1e293b;color:#cbd5e1;font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.keyreveal .copy:hover{background:#334155}
.keyreveal .copy svg{width:12px;height:12px}
.confirm-input{margin-top:14px}
.confirm-input label{font-size:12px;color:var(--muted);display:block;margin-bottom:6px}
.confirm-input label b{font-family:var(--mono);color:var(--ink)}
.confirm-input input{width:100%;padding:9px 13px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);font-size:13px;font-family:var(--mono);outline:none}
.confirm-input input:focus{border-color:var(--off);background:#fff;box-shadow:0 0 0 3px #dc262618}

.empty{padding:48px 20px;text-align:center;color:var(--dim)}
.empty svg{width:34px;height:34px;margin-bottom:10px;opacity:.6}
.empty .t{font-size:13.5px;font-weight:500;color:var(--muted)}
.loadrow{padding:36px;text-align:center;color:var(--dim);font-family:var(--mono);font-size:12px}

/* ===== Login ===== */
.login{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,#13243f 0%,#0b1220 55%,#080d18 100%)}
.login.on{display:flex}
.login-card{width:100%;max-width:392px;background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:0 30px 80px -20px #00000066;overflow:hidden}
.login-top{padding:30px 32px 6px;text-align:center}
.login-top .mark{width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,#0e9f88,#16d3b0);display:grid;place-items:center;color:#04201a;font-weight:700;font-size:19px;margin:0 auto 16px;box-shadow:0 6px 18px #0e9f8855}
.login-top h1{margin:0;font-size:19px;font-weight:600;letter-spacing:-.02em}
.login-top p{margin:6px 0 0;font-size:12.5px;color:var(--muted)}
.login-top p b{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.login-form{padding:22px 32px 30px;display:flex;flex-direction:column;gap:14px}
.login-form .field .lbl{margin-bottom:0}
.login-form input{width:100%;padding:11px 14px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);font-size:14px;outline:none;transition:.15s}
.login-form input:focus{border-color:#0e9f8866;background:#fff;box-shadow:0 0 0 3px #0e9f8818}
.login-form .btn.primary{justify-content:center;padding:12px;font-size:14px;margin-top:4px}
.login-err{display:none;align-items:center;gap:9px;padding:10px 13px;border-radius:10px;background:var(--off-soft);border:1px solid var(--off-line);color:#b91c1c;font-size:12.5px;font-weight:500}
.login-err.on{display:flex}
.login-err svg{width:15px;height:15px;flex-shrink:0}
.login-foot{padding:14px 32px;border-top:1px solid var(--line-2);text-align:center;font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:.04em}

/* ===== Toasts ===== */
.toasts{position:fixed;right:22px;bottom:22px;z-index:300;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
.toast{display:flex;align-items:flex-start;gap:11px;padding:13px 16px;border-radius:12px;background:#0f1729;color:#e2e8f0;box-shadow:var(--shadow-lg);font-size:13px;max-width:360px;animation:toastin .2s ease;border:1px solid #1e293b}
@keyframes toastin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.toast .ic{width:20px;height:20px;flex-shrink:0;display:grid;place-items:center}
.toast .ic svg{width:18px;height:18px}
.toast.ok .ic{color:#34d399}
.toast.err .ic{color:#f87171}
.toast .tx{line-height:1.4}
.toast .tx b{font-weight:600;display:block;margin-bottom:1px}
.toast .tx small{color:#94a3b8;font-size:11.5px}

@media (max-width:1080px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:-260px}
  .stat-grid{grid-template-columns:1fr 1fr}
  .dash-grid,.detail-top{grid-template-columns:1fr}
}

/* ===== Champs de formulaire (modals) ===== */
.field input.finp, .field textarea.finp{width:100%;padding:10px 13px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);font-size:13.5px;font-family:var(--sans);outline:none;color:var(--ink);transition:.15s}
.field input.finp.mono{font-family:var(--mono);font-size:12.5px}
.field input.finp:focus, .field textarea.finp:focus{border-color:#0e9f8866;background:#fff;box-shadow:0 0 0 3px #0e9f8818}
.field .hint{font-size:11px;color:var(--dim);margin-top:-1px}

/* ===== Select-filtre type pill (ecran Telephones) ===== */
.pillselect{position:relative;display:inline-flex;align-items:center}
.pillselect .ic{position:absolute;left:11px;width:13px;height:13px;color:var(--dim);pointer-events:none}
.pillselect .chev{position:absolute;right:9px;width:13px;height:13px;color:var(--dim);pointer-events:none}
.pillselect select{appearance:none;-webkit-appearance:none;padding:8px 28px 8px 31px;border-radius:9px;border:1px solid var(--line);background:var(--panel);font-size:12.5px;font-weight:500;color:var(--muted);font-family:var(--sans);cursor:pointer;outline:none;max-width:240px;white-space:nowrap;text-overflow:ellipsis}
.pillselect select:hover{border-color:#cbd5e1}
.pillselect select:focus{border-color:#0e9f8866}
.pillselect.active select{border-color:#0e9f8855;background:var(--accent-soft);color:var(--accent-ink)}
.pillselect.active .ic,.pillselect.active .chev{color:var(--accent-ink)}

/* ===== Pagination (journal) ===== */
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-top:1px solid var(--line-2)}
.pager .info{font-family:var(--mono);font-size:11.5px;color:var(--muted);font-variant-numeric:tabular-nums}
.pager .nav{display:flex;gap:8px}
.pager:empty{display:none}

/* ===== Segment (bascule Connexions / Actions admin) ===== */
.seg{display:inline-flex;gap:2px;padding:3px;background:var(--panel-3);border-radius:8px}
.seg button{padding:5px 13px;border-radius:6px;font-size:12.5px;font-weight:500;color:var(--muted);transition:.13s}
.seg button:hover{color:var(--ink)}
.seg button.on{background:var(--panel);color:var(--ink);font-weight:600;box-shadow:0 1px 2px #0f172a14}
