﻿
:root{--bg:#080b12;--bg2:#0e1420;--bg3:#141b28;--card:#111827;--border:rgba(255,255,255,0.07);--accent:#6c63ff;--accent2:#ff6584;--accent3:#43e97b;--accent4:#f9ca24;--accent5:#fd79a8;--text:#f0f4ff;--text2:#8a9bc4;--text3:#4a5878;}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;min-height:100vh;overflow-x:hidden;font-size:15px;}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(108,99,255,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(108,99,255,0.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0;}

/* ===== LOGIN ===== */
#login-screen{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;}
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:18px;padding:36px 32px;width:360px;text-align:center;}
.login-logo{font-family:Georgia,serif;font-weight:800;font-size:26px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px;}
.login-sub{font-family:'Courier New',monospace;font-size:9px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;margin-bottom:28px;}
.member-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:9px;border:1px solid var(--border);background:var(--bg3);cursor:pointer;transition:all 0.15s;text-align:left;margin-bottom:8px;}
.member-btn:hover{border-color:rgba(108,99,255,0.4);background:rgba(108,99,255,0.08);}
.m-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0;}
.pin-section{display:none;}
.pin-section.show{display:block;}
.pw-input-wrap{position:relative;margin:14px 0 8px;}
.pw-input{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:18px;padding:10px 40px 10px 14px;border-radius:9px;outline:none;letter-spacing:2px;text-align:center;}
.pw-input:focus{border-color:var(--accent);}
.pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--text3);font-size:15px;background:none;border:none;}
.pw-toggle:hover{color:var(--text);}
.pin-error{color:var(--accent2);font-family:'Courier New',monospace;font-size:11px;margin-top:10px;min-height:16px;}
.login-back{font-family:'Courier New',monospace;font-size:10px;color:var(--text3);cursor:pointer;margin-top:12px;display:inline-block;}
.login-back:hover{color:var(--accent);}
/* Manual login tab */
.login-tabs{display:flex;gap:0;margin-bottom:18px;border-radius:8px;overflow:hidden;border:1px solid var(--border);}
.login-tab{flex:1;padding:7px;font-family:'Courier New',monospace;font-size:9px;text-transform:uppercase;letter-spacing:1px;cursor:pointer;background:transparent;color:var(--text3);border:none;transition:all 0.15s;}
.login-tab.active{background:rgba(108,99,255,0.15);color:var(--accent);}
.manual-login{display:none;}
.manual-login.show{display:block;}

/* ===== LIVE ALERT BANNER ===== */
#live-banner{display:none;position:fixed;bottom:20px;left:230px;z-index:200;background:linear-gradient(90deg,#ff0040,#ff6584);padding:6px 14px 6px 10px;border-radius:20px;align-items:center;gap:7px;animation:bannerPulse 2s infinite;box-shadow:0 4px 16px rgba(255,0,64,0.4);font-size:12px;font-weight:600;white-space:nowrap;}
@keyframes bannerPulse{0%,100%{opacity:1;box-shadow:0 4px 16px rgba(255,0,64,0.4)}50%{opacity:0.9;box-shadow:0 4px 22px rgba(255,0,64,0.65)}}
#live-banner.show{display:flex;}
.live-banner-dot{width:8px;height:8px;border-radius:50%;background:white;flex-shrink:0;animation:dotPulse 1s infinite;}
@keyframes dotPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.4)}}

/* ===== APP ===== */
#app{display:none;}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:215px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;overflow-y:auto;}
.logo{padding:20px 18px 14px;border-bottom:1px solid var(--border);}
.logo-title{font-family:Georgia,serif;font-weight:800;font-size:18px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.logo-sub{font-family:'Courier New',monospace;font-size:9px;color:var(--text3);letter-spacing:2px;margin-top:2px;text-transform:uppercase;}
.nav{padding:10px 8px;flex:1;}
.nav-section{margin-bottom:14px;}
.nav-label{font-family:'Courier New',monospace;font-size:11px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;padding:0 10px;margin-bottom:4px;}
.nav-item{display:flex;align-items:center;gap:7px;padding:9px 10px;border-radius:7px;cursor:pointer;color:var(--text2);font-size:13.5px;font-weight:500;transition:all 0.15s;border:1px solid transparent;position:relative;}
.nav-item:hover{background:rgba(108,99,255,0.08);color:var(--text);border-color:rgba(108,99,255,0.2);}
.nav-item.active{background:rgba(108,99,255,0.15);color:var(--accent);border-color:rgba(108,99,255,0.3);}
.nav-item.locked{opacity:0.35;cursor:not-allowed;pointer-events:none;}
.nav-badge{margin-left:auto;color:white;font-size:10px;font-family:'Courier New',monospace;padding:1px 6px;border-radius:20px;background:var(--accent);}
.nav-badge.red{background:var(--accent2);}
.nav-badge.live{background:#ff0040;animation:dotPulse 1s infinite;}
.unread-dot{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:var(--accent2);color:white;font-size:9px;font-weight:700;font-family:'Courier New',monospace;padding:0 5px;margin-left:auto;flex-shrink:0;animation:badgePulse 2s infinite;}
@keyframes badgePulse{0%,100%{box-shadow:0 0 0 0 rgba(255,101,132,0.6)}50%{box-shadow:0 0 0 5px rgba(255,101,132,0)}}
.chat-group-item .chat-unread{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:var(--accent2);color:white;font-size:9px;font-weight:700;font-family:'Courier New',monospace;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center;}
.session-bar{padding:12px 14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.session-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;flex-shrink:0;}
.session-info{flex:1;min-width:0;}
.session-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.session-role{font-family:'Courier New',monospace;font-size:9px;color:var(--text3);}
.logout-btn{font-size:11px;cursor:pointer;color:var(--text3);padding:4px 6px;border-radius:5px;font-family:'Courier New',monospace;border:1px solid transparent;}
.logout-btn:hover{color:var(--accent2);border-color:rgba(255,101,132,0.3);}
.main{margin-left:215px;min-height:100vh;position:relative;z-index:1;}
.topbar{padding:14px 24px;border-bottom:1px solid var(--border);background:rgba(8,11,18,0.9);backdrop-filter:blur(20px);position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;}
.page-title{font-family:Georgia,serif;font-weight:700;font-size:20px;}
.topbar-right{display:flex;gap:8px;align-items:center;}
.btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border-radius:7px;font-size:13px;font-family:'Courier New',monospace;cursor:pointer;border:1px solid var(--border);background:var(--bg3);color:var(--text2);transition:all 0.15s;}
.btn:hover{border-color:rgba(108,99,255,0.4);color:var(--text);background:rgba(108,99,255,0.1);}
.btn-primary{background:var(--accent);color:white;border-color:var(--accent);}
.btn-primary:hover{background:#7c74ff;color:white;}
.btn-danger{background:rgba(255,101,132,0.08);color:var(--accent2);border-color:rgba(255,101,132,0.3);}
.btn-danger:hover{background:rgba(255,101,132,0.2);}
.btn-success{background:rgba(67,233,123,0.1);color:var(--accent3);border-color:rgba(67,233,123,0.3);}
.btn-success:hover{background:rgba(67,233,123,0.2);}
.btn-warn{background:rgba(249,202,36,0.1);color:var(--accent4);border-color:rgba(249,202,36,0.3);}
.btn-warn:hover{background:rgba(249,202,36,0.2);}
.btn-sm{padding:4px 9px;font-size:11.5px;}
.section{display:none;padding:24px;animation:fadeIn 0.2s ease;}
.section.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.section-header{margin-bottom:20px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.section-title{font-family:Georgia,serif;font-weight:700;font-size:24px;margin-bottom:3px;}
.section-subtitle{color:var(--text2);font-size:14px;}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:11px;margin-bottom:18px;}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;position:relative;overflow:hidden;}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);}
.kpi-card.c2::before{background:var(--accent2);}
.kpi-card.c3::before{background:var(--accent3);}
.kpi-card.c4::before{background:var(--accent4);}
.kpi-card.c5::before{background:var(--accent5);}
.kpi-card.c6::before{background:#74b9ff;}
.kpi-label{font-family:'Courier New',monospace;font-size:11px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;}
.kpi-value{font-family:Georgia,serif;font-weight:800;font-size:30px;letter-spacing:-1px;line-height:1;margin-bottom:4px;}
.kpi-desc{font-size:13px;color:var(--text2);}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:14px;}
.grid-full{margin-bottom:14px;}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.card-title{font-family:Georgia,serif;font-weight:700;font-size:16px;}
.card-tag{font-family:'Courier New',monospace;font-size:10px;background:rgba(108,99,255,0.15);color:var(--accent);padding:2px 7px;border-radius:4px;}
.chart-wrap{position:relative;height:170px;}
.chart-wrap.sm{height:140px;}
.table-scroll{overflow-x:auto;max-height:360px;overflow-y:auto;}
.table-scroll::-webkit-scrollbar{width:3px;height:3px;}
.table-scroll::-webkit-scrollbar-thumb{background:var(--text3);border-radius:2px;}
.data-table{width:100%;border-collapse:collapse;font-size:14px;}
.data-table th{font-family:'Courier New',monospace;font-size:11.5px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;background:var(--card);z-index:2;}
.data-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,0.04);color:var(--text2);vertical-align:middle;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:rgba(255,255,255,0.02);}
.data-table td:first-child{color:var(--text);font-weight:500;}
.cell-edit{background:transparent;border:none;color:inherit;font-family:inherit;font-size:inherit;width:100%;outline:none;cursor:pointer;min-width:50px;}
.cell-edit:focus{background:rgba(108,99,255,0.1);border-radius:4px;padding:1px 4px;}
.cell-select{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:'Courier New',monospace;font-size:12px;padding:3px 5px;border-radius:4px;cursor:pointer;outline:none;}
.tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--border);}
.tab-btn{padding:9px 18px;font-size:13px;font-family:'Courier New',monospace;cursor:pointer;border:1px solid transparent;border-bottom:none;border-radius:7px 7px 0 0;color:var(--text2);background:transparent;transition:all 0.15s;position:relative;bottom:-1px;}
.tab-btn:hover{color:var(--text);background:rgba(108,99,255,0.06);}
.tab-btn.active{color:var(--accent);background:var(--card);border-color:var(--border);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

/* ===== DASHBOARD PRO (refonte) ===== */
.dash-hero{display:flex;align-items:center;gap:20px;padding:22px 26px;background:radial-gradient(120% 160% at 0% 0%,rgba(108,99,255,0.16) 0%,transparent 55%),radial-gradient(120% 160% at 100% 100%,rgba(255,101,132,0.12) 0%,transparent 55%),linear-gradient(135deg,#121a2e 0%,#0d1322 100%);border:1px solid rgba(108,99,255,0.22);border-radius:20px;margin-bottom:20px;position:relative;overflow:hidden;box-shadow:0 10px 40px -18px rgba(108,99,255,0.5);}
.dash-hero::before{content:'';position:absolute;top:-60px;right:18%;width:240px;height:240px;background:radial-gradient(circle,rgba(108,99,255,0.18) 0%,transparent 70%);pointer-events:none;animation:dashGlow 8s ease-in-out infinite;}
@keyframes dashGlow{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}
.dash-hero-left{flex:0 0 auto;position:relative;z-index:1;}
.dash-hero-title{font-family:Georgia,serif;font-weight:800;font-size:27px;line-height:1.05;color:var(--text);letter-spacing:-0.5px;}
.dash-hero-title span{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.dash-hero-date{font-family:'Courier New',monospace;font-size:11px;color:var(--text2);letter-spacing:.5px;margin-top:6px;text-transform:capitalize;display:inline-flex;align-items:center;gap:6px;}
.dash-hero-date::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent3);box-shadow:0 0 8px var(--accent3);animation:dotPulse 2s infinite;}
.dash-quick-stats{display:flex;gap:10px;flex:1;flex-wrap:wrap;position:relative;z-index:1;}
.dash-qs{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:14px;padding:12px 18px;min-width:104px;text-align:center;transition:transform 0.18s,border-color 0.18s,background 0.18s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);}
.dash-qs:hover{border-color:rgba(108,99,255,0.45);background:rgba(108,99,255,0.08);transform:translateY(-3px);}
.dash-qs-val{font-size:25px;font-weight:800;line-height:1.05;letter-spacing:-0.5px;}
.dash-qs-label{font-size:10.5px;color:var(--text2);margin-top:5px;font-family:'Courier New',monospace;white-space:nowrap;}
.dash-tabs-wrap{display:flex;gap:4px;flex:0 0 auto;position:relative;z-index:1;background:rgba(0,0,0,0.25);padding:4px;border-radius:13px;border:1px solid var(--border);}
.dash-tab-btn{padding:9px 18px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid transparent;border-radius:10px;color:var(--text2);background:transparent;transition:all 0.2s;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;white-space:nowrap;}
.dash-tab-btn:hover{color:var(--text);}
.dash-tab-btn.active{color:#fff;background:linear-gradient(135deg,var(--accent),#7c74ff);box-shadow:0 4px 14px -2px rgba(108,99,255,0.6);}
/* ── Stat cards (KPI) ── */
.dash-stat{background:linear-gradient(160deg,var(--card) 0%,rgba(255,255,255,0.015) 100%);border:1px solid var(--border);border-radius:16px;padding:16px 16px 15px;position:relative;overflow:hidden;transition:transform 0.18s,border-color 0.18s,box-shadow 0.18s;}
.dash-stat:hover{transform:translateY(-3px);border-color:rgba(108,99,255,0.35);box-shadow:0 12px 30px -14px rgba(0,0,0,0.7);}
.dash-stat::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--sc,var(--accent));opacity:.9;}
.dash-stat-ico{position:absolute;right:10px;top:8px;font-size:34px;opacity:.07;pointer-events:none;}
.dash-stat-badge{width:38px;height:38px;border-radius:11px;background:color-mix(in srgb,var(--sc,var(--accent)) 14%,transparent);border:1px solid color-mix(in srgb,var(--sc,var(--accent)) 32%,transparent);display:flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:11px;}
.dash-stat-label{font-size:8.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.9px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-stat-val{font-size:23px;font-weight:800;color:var(--sc,var(--accent));line-height:1;letter-spacing:-0.6px;}
.dash-stat-sub{font-size:9px;color:var(--text3);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-plat-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;transition:all 0.2s;position:relative;overflow:hidden;}
.dash-plat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3);}
.dash-plat-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.dash-kpi-big{background:linear-gradient(160deg,var(--card) 0%,rgba(255,255,255,0.015) 100%);border:1px solid var(--border);border-radius:14px;padding:18px 14px;text-align:center;transition:all 0.15s;}
.dash-kpi-big:hover{border-color:rgba(108,99,255,0.3);transform:translateY(-2px);box-shadow:0 10px 26px -14px rgba(0,0,0,0.7);}
.dash-section-label{font-family:'Courier New',monospace;font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:2px;margin-bottom:13px;padding-left:2px;display:flex;align-items:center;gap:10px;}
.dash-section-label::before{content:'';width:4px;height:13px;border-radius:3px;background:linear-gradient(var(--accent),var(--accent2));}
.dash-section-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent);}

/* ===== ORG CHART ===== */
.org-chart-outer{overflow-x:auto;overflow-y:visible;padding:20px 0 32px;width:100%;}
.org-chart-wrap{display:inline-flex;flex-direction:column;align-items:center;min-width:100%;padding:0 24px;}
.org-tree,.org-tree ul{padding:0;margin:0;list-style:none;}
.org-tree{display:flex;flex-direction:column;align-items:center;}
.org-tree ul{display:flex;align-items:flex-start;padding-top:24px;position:relative;gap:0;}
/* Vertical connector from parent down */
.org-tree ul::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:2px;height:24px;background:var(--border);}
/* Each li */
.org-tree li{list-style:none;text-align:center;position:relative;padding:24px 8px 0 8px;display:flex;flex-direction:column;align-items:center;}
/* Horizontal + vertical connector arms */
.org-tree li::before,.org-tree li::after{content:'';position:absolute;top:0;right:50%;border-top:2px solid var(--border);width:50%;height:24px;}
.org-tree li::after{right:auto;left:50%;border-left:2px solid var(--border);}
/* Single child: no arms */
.org-tree li:only-child::after,.org-tree li:only-child::before{display:none;}
.org-tree li:only-child{padding-top:0;}
/* First/last child: remove outer arm */
.org-tree li:first-child::before,.org-tree li:last-child::after{border:0 none;}
.org-tree li:last-child::before{border-right:2px solid var(--border);border-radius:0 4px 0 0;}
.org-tree li:first-child::after{border-radius:4px 0 0 0;}
/* CEO root li: no connectors */
.org-tree>li{padding-top:0;}
.org-tree>li::before,.org-tree>li::after{display:none;}
/* Node card */
.org-node-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 14px;width:160px;position:relative;text-align:left;transition:box-shadow 0.15s;flex-shrink:0;}
.org-node-card:hover{box-shadow:0 4px 20px rgba(0,0,0,0.5);}
.org-node-card.org-ceo{width:220px;padding:16px 20px;background:linear-gradient(135deg,var(--card) 0%,rgba(255,215,0,0.07) 100%);}
.org-node-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;font-family:'Courier New',monospace;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;}
.org-node-title.org-ceo-title{font-size:15px;letter-spacing:2px;white-space:nowrap;}
.org-member-row{display:flex;align-items:center;gap:6px;padding:4px 0;border-top:1px solid var(--border);}
.org-member-av{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;flex-shrink:0;}
.org-member-name{font-size:12px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.org-del-btn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:11px;padding:0;flex-shrink:0;line-height:1;}
.org-del-btn:hover{color:#ff6584;}
.org-vacant{font-size:10px;color:var(--text3);font-style:italic;padding:2px 0;}
.org-add-btn{width:100%;margin-top:7px;padding:4px 0;font-size:10px;background:transparent;border:1px dashed var(--border);border-radius:5px;color:var(--text3);cursor:pointer;transition:all 0.15s;}
.org-add-btn:hover{color:var(--accent);border-color:var(--accent);}
/* Branch header badge */
.org-branch-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-family:'Courier New',monospace;padding:4px 12px;border-radius:20px;margin-bottom:8px;white-space:nowrap;display:inline-block;}

.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;}
.team-card{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:14px;}
.team-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;margin-bottom:8px;}
.team-model-tag{font-family:'Courier New',monospace;font-size:9px;padding:2px 6px;border-radius:4px;border:1px solid var(--border);color:var(--text2);display:inline-block;margin:2px;}

/* ===== CHAT ===== */
.chat-layout{display:grid;grid-template-columns:220px 1fr;gap:14px;height:calc(100vh - 160px);min-height:400px;}
.chat-groups{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow-y:auto;display:flex;flex-direction:column;}
.chat-group-item{padding:10px 14px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.04);transition:all 0.15s;position:relative;}
.chat-group-item:hover{background:rgba(108,99,255,0.06);}
.chat-group-item.active{background:rgba(108,99,255,0.12);border-left:2px solid var(--accent);}
.chat-group-name{font-size:13px;font-weight:600;margin-bottom:2px;}
.chat-group-preview{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;}
.chat-unread{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:var(--accent2);color:white;font-size:9px;font-family:'Courier New',monospace;padding:1px 5px;border-radius:10px;}
.chat-window{background:var(--card);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;}
.chat-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.chat-header-title{font-weight:600;font-size:13px;}
.chat-header-info{font-family:'Courier New',monospace;font-size:10px;color:var(--text3);}
.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;}
.chat-messages::-webkit-scrollbar{width:3px;}
.chat-messages::-webkit-scrollbar-thumb{background:var(--text3);border-radius:2px;}
.msg-wrap{display:flex;gap:8px;align-items:flex-end;}
.msg-wrap.me{flex-direction:row-reverse;}
.msg-av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:9px;flex-shrink:0;}
.msg-bubble{max-width:70%;padding:9px 13px;border-radius:12px;font-size:13px;line-height:1.5;}
.msg-bubble.other{background:var(--bg3);border:1px solid var(--border);border-bottom-left-radius:4px;}
.msg-bubble.me{background:var(--accent);color:white;border-bottom-right-radius:4px;}
.msg-meta{font-size:9px;color:var(--text3);margin-top:3px;font-family:'Courier New',monospace;}
.msg-meta.me-meta{text-align:right;}
.msg-name{font-size:9px;font-weight:600;margin-bottom:2px;color:var(--text2);}
.chat-input-bar{padding:12px 14px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:flex-end;}
.chat-input{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:13px;padding:9px 13px;border-radius:8px;outline:none;resize:none;font-family:inherit;max-height:100px;}
.chat-input:focus{border-color:var(--accent);}

/* ===== VOCAL ===== */
.vocal-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:20px;text-align:center;}
.vocal-icon{font-size:36px;margin-bottom:10px;}
.vocal-title{font-family:Georgia,serif;font-weight:700;font-size:15px;margin-bottom:6px;}
.vocal-desc{font-size:11px;color:var(--text2);margin-bottom:14px;}

/* ===== NOTIFICATIONS LIVE ===== */
#notif-center{position:fixed;top:58px;right:16px;z-index:300;display:flex;flex-direction:column;gap:6px;max-width:260px;pointer-events:none;}
.notif-card{pointer-events:auto;background:var(--bg2);border:1px solid var(--border);border-left-width:3px;border-radius:8px;padding:7px 10px;display:flex;align-items:flex-start;gap:7px;animation:notifIn 0.3s ease;box-shadow:0 4px 16px rgba(0,0,0,0.35);}
@keyframes notifIn{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}
.notif-icon{font-size:14px;flex-shrink:0;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.notif-body{flex:1;min-width:0;}
.notif-title{font-weight:700;font-size:10.5px;margin-bottom:1px;}
.notif-msg{font-size:10px;color:var(--text2);line-height:1.35;}
.notif-time{font-family:'Courier New',monospace;font-size:8px;color:var(--text3);margin-top:2px;}
.notif-close{cursor:pointer;color:var(--text3);font-size:12px;padding:0 3px;}
.notif-close:hover{color:var(--text);}
.notif-blue{border-left-color:#3b82f6;}
.notif-blue .notif-icon{background:rgba(59,130,246,0.15);color:#3b82f6;}
.notif-yellow{border-left-color:var(--accent4);}
.notif-yellow .notif-icon{background:rgba(249,202,36,0.15);color:var(--accent4);}
.notif-orange{border-left-color:#ff9500;}
.notif-orange .notif-icon{background:rgba(255,149,0,0.15);color:#ff9500;}
.notif-red{border-left-color:#ff0040;animation:notifPulse 2s infinite;}
.notif-red .notif-icon{background:rgba(255,0,64,0.15);color:#ff0040;}
@keyframes notifPulse{0%,100%{box-shadow:0 8px 32px rgba(255,0,64,0.4)}50%{box-shadow:0 8px 32px rgba(255,0,64,0.7)}}
.notif-green{border-left-color:var(--accent3);animation:notifPulseGreen 2s infinite;}
.notif-green .notif-icon{background:rgba(67,233,123,0.15);color:var(--accent3);}
@keyframes notifPulseGreen{0%,100%{box-shadow:0 8px 32px rgba(67,233,123,0.3)}50%{box-shadow:0 8px 32px rgba(67,233,123,0.6)}}

/* ===== TYPE NOTIF DROITS ===== */
/* ===== TELEGRAM CONFIG ===== */
.tg-config{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:14px;}
.tg-label{font-family:'Courier New',monospace;font-size:9px;color:var(--accent);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;}
.tg-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;}
.tg-field{flex:1;min-width:130px;}
.tg-field label{font-family:'Courier New',monospace;font-size:9px;color:var(--text3);letter-spacing:1px;display:block;margin-bottom:4px;text-transform:uppercase;}
.tg-field input,.tg-field select{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:'Courier New',monospace;font-size:11px;padding:6px 9px;border-radius:6px;outline:none;}
.tg-field input:focus,.tg-field select:focus{border-color:var(--accent);}
.log-box{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px;font-family:'Courier New',monospace;font-size:10px;max-height:100px;overflow-y:auto;color:var(--text2);}
.log-ok{color:var(--accent3);}
.log-err{color:var(--accent2);}
.log-info{color:var(--accent);}
.time-cell{font-family:'Courier New',monospace;font-size:11px;color:var(--accent4);font-weight:700;}
.rappel-tc{font-family:'Courier New',monospace;font-size:10px;}
.sdot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px;}
.dot-a{background:var(--accent3);}
.dot-p{background:var(--text3);}

/* ===== KPI CHIFFRES ===== */
.kpi-entry{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:8px;display:flex;align-items:center;gap:12px;}
.kpi-entry-date{font-family:'Courier New',monospace;font-size:10px;color:var(--text3);min-width:70px;}
.kpi-entry-model{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;min-width:120px;}
.kpi-entry-val{font-family:Georgia,serif;font-weight:800;font-size:18px;color:var(--accent3);}
.kpi-entry-label{font-family:'Courier New',monospace;font-size:9px;color:var(--text3);}

/* ===== ROLES ===== */
.role-card{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:14px;display:flex;align-items:center;gap:14px;}
.role-icon-big{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.role-info{flex:1;}
.role-name{font-weight:600;font-size:13px;margin-bottom:3px;}
.role-sections{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;}
.role-section-tag{font-family:'Courier New',monospace;font-size:8px;padding:1px 5px;border-radius:3px;background:rgba(108,99,255,0.1);color:var(--accent);border:1px solid rgba(108,99,255,0.2);}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:1000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.modal-overlay.hidden{display:none;}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:24px;width:500px;max-width:94vw;max-height:90vh;overflow-y:auto;}
.modal.wide{width:620px;}
.modal-title{font-family:Georgia,serif;font-weight:700;font-size:16px;margin-bottom:16px;}
.form-group{margin-bottom:12px;}
.form-label{font-family:'Courier New',monospace;font-size:9px;color:var(--text3);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px;display:block;}
.form-input{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:12px;padding:7px 10px;border-radius:7px;outline:none;}
.form-input:focus{border-color:var(--accent);}
.form-select{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:'Courier New',monospace;font-size:11px;padding:7px 10px;border-radius:7px;outline:none;cursor:pointer;}
.form-select:focus{border-color:var(--accent);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.modal-actions{display:flex;gap:8px;margin-top:18px;justify-content:flex-end;}
.perm-table-wrap{overflow-x:auto;max-height:260px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;}
.perm-table{width:100%;border-collapse:collapse;}
.perm-table th{padding:5px 8px;text-align:left;font-family:'Courier New',monospace;font-size:9px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;position:sticky;top:0;background:var(--bg2);}
.perm-table td{padding:4px 8px;border-bottom:1px solid rgba(255,255,255,0.04);font-size:11px;color:var(--text2);}

.toast{position:fixed;bottom:20px;right:20px;background:var(--bg2);border:1px solid var(--accent);border-radius:9px;padding:9px 15px;font-family:'Courier New',monospace;font-size:11px;color:var(--accent);z-index:9000;animation:slideUp 0.3s ease;pointer-events:none;}
.toast.err{border-color:var(--accent2);color:var(--accent2);}
.toast.warn{border-color:var(--accent4);color:var(--accent4);}
@keyframes slideUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.ws-panel{animation:fadeIn 0.2s ease;}
.dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;}
.empty-state{text-align:center;padding:28px;color:var(--text3);font-family:'Courier New',monospace;font-size:11px;}
a.link{color:var(--accent);text-decoration:none;font-size:10px;font-family:'Courier New',monospace;}

/* ===== MOBILE RESPONSIVE ===== */

/* Hamburger â€” cachÃ© sur desktop */
.hamburger-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--bg3);cursor:pointer;font-size:20px;color:var(--text2);flex-shrink:0;margin-right:10px;transition:all 0.15s;}
.hamburger-btn:hover{border-color:rgba(108,99,255,0.4);color:var(--text);}

/* Overlay sidebar mobile */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:499;backdrop-filter:blur(2px);}
body.sidebar-open .sidebar-overlay{display:block;}

@media (max-width: 768px) {
  /* Affiche le hamburger */
  .hamburger-btn{display:flex;}

  /* Sidebar : slide-in depuis la gauche */
  .sidebar{transform:translateX(-215px);transition:transform 0.25s ease;z-index:500;}
  body.sidebar-open .sidebar{transform:translateX(0);box-shadow:6px 0 24px rgba(0,0,0,0.6);}

  /* Main : plus de marge gauche */
  .main{margin-left:0;}

  /* Topbar â€” safe area iOS (notch) */
  .topbar{padding:calc(env(safe-area-inset-top,0px) + 10px) 12px 10px;position:sticky;top:0;}
  .page-title{font-size:15px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .topbar-right{gap:4px;flex-shrink:0;}
  /* Boutons Export/Import : cache le texte, garde l'emoji */
  #btn-export .btn-label,#btn-import .btn-label{display:none;}
  #btn-export,#btn-import{padding:6px 10px;font-size:15px;}
  #sync-indicator{display:none;}

  /* Sections */
  .section{padding:12px;}
  .section-header{flex-direction:column;gap:8px;}
  .section-header > div:last-child{flex-wrap:wrap;}

  /* Grids */
  .grid-2,.grid-3{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}

  /* KPI */
  .kpi-grid{grid-template-columns:repeat(2,1fr);}

  /* â”€â”€ Dashboard hero â”€â”€ */
  .dash-hero{flex-direction:column;align-items:stretch;gap:10px;padding:12px;}
  .dash-hero-left{display:flex;align-items:center;justify-content:space-between;}
  .dash-quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
  .dash-qs{min-width:unset;padding:7px 8px;}
  .dash-qs-val{font-size:18px;}
  .dash-qs-label{font-size:9px;}
  .dash-tabs-wrap{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;}
  .dash-tabs-wrap::-webkit-scrollbar{height:2px;}
  .dash-tabs-wrap::-webkit-scrollbar-thumb{background:var(--text3);}
  .dash-tab-btn{white-space:nowrap;flex-shrink:0;}

  /* Stats 8 colonnes â†’ 4 sur mobile */
  .dash-stats-grid{grid-template-columns:repeat(4,1fr) !important;}

  /* Chat layout */
  .chat-layout{grid-template-columns:1fr;height:auto;}
  .chat-groups{max-height:200px;}

  /* Live banner */
  #live-banner{left:10px;right:10px;bottom:10px;white-space:normal;border-radius:12px;justify-content:center;}

  /* Modals */
  .modal{width:96vw;max-width:96vw;max-height:92vh;overflow-y:auto;margin:4vh auto;}

  /* Tables */
  .table-scroll{max-height:none;}

  /* Cards */
  .card{padding:12px 10px;}

  /* Toast */
  .toast{left:12px;right:12px;bottom:12px;text-align:center;}

  /* Org chart */
  .org-root{min-width:max-content;}

  /* Tabs scroll horizontal */
  .tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px;}
  .tabs::-webkit-scrollbar{height:2px;}
  .tabs::-webkit-scrollbar-thumb{background:var(--text3);}
}

@media (max-width: 480px) {
  .kpi-grid{grid-template-columns:repeat(2,1fr);}
  .kpi-value{font-size:22px;}
  .section-title{font-size:18px;}
  .btn{padding:6px 10px;font-size:11px;}
  .btn-sm{padding:4px 7px;font-size:10px;}
  .topbar{padding:calc(env(safe-area-inset-top,0px) + 8px) 10px 8px;}
  .section{padding:10px 8px;}
  .card{padding:10px 8px;}

  /* Stats 8 â†’ 2 colonnes sur petit Ã©cran */
  .dash-stats-grid{grid-template-columns:repeat(2,1fr) !important;}
  .dash-quick-stats{grid-template-columns:repeat(2,1fr);}
}
/* ==================== OBJECTIF SUB BANNER ==================== */
.objectif-sub-banner{
  background:linear-gradient(135deg,rgba(108,99,255,0.18),rgba(167,139,250,0.12));
  border:1.5px solid rgba(108,99,255,0.4);
  border-radius:12px;
  padding:16px 18px;
  margin-bottom:14px;
  position:relative;
  overflow:hidden;
  animation:objectif-pulse 3s ease-in-out infinite;
}
.objectif-sub-banner::before{
  content:'';
  position:absolute;
  top:-40%;left:-20%;
  width:60%;height:200%;
  background:rgba(255,255,255,0.03);
  transform:rotate(-15deg);
  pointer-events:none;
}
.objectif-sub-reached{
  background:linear-gradient(135deg,rgba(67,233,123,0.15),rgba(0,200,100,0.08));
  border-color:rgba(67,233,123,0.5);
  animation:none;
}
@keyframes objectif-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(108,99,255,0.15);}
  50%{box-shadow:0 0 16px 4px rgba(108,99,255,0.25);}
}

/* ==================== PHONE FARM ==================== */
.vphone-shell{
  position:relative;
  width:320px;
  height:680px;
  border-radius:44px;
  background:linear-gradient(145deg,#1a1a2e,#16213e);
  border:3px solid rgba(255,255,255,0.12);
  box-shadow:0 0 0 6px rgba(0,0,0,0.4),0 30px 60px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:14px 12px 20px;
  gap:8px;
}
.vphone-shell::before{
  content:'';
  position:absolute;
  top:14px;
  width:80px;height:18px;
  background:#0d0d1a;
  border-radius:10px;
  z-index:10;
  pointer-events:none;
}
.vphone-screen{
  width:100%;
  flex:1;
  border-radius:28px;
  overflow:hidden;
  background:#000;
  position:relative;
  margin-top:10px; /* espace sous le notch */
}
.vphone-screen iframe{
  width:100%;height:100%;border:none;
  transform-origin:top left;
}
.vphone-home-bar{
  width:100px;height:4px;
  background:rgba(255,255,255,0.3);
  border-radius:2px;
}
.phone-remote-card{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  transition:border-color .2s;
}
.phone-remote-card:hover{border-color:rgba(108,99,255,0.4);}
.phone-status-dot{
  width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px;
}
.phone-status-dot.online{background:#43e97b;box-shadow:0 0 6px #43e97b;}
.phone-status-dot.offline{background:#636e72;}
.phone-status-dot.busy{background:#fdcb6e;box-shadow:0 0 6px #fdcb6e;}
