*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--n:#0e0e0e;--bg:#f4efe6;--oc:#c89230;--och:#b5832a;--gr:#f8f6f2;--bd:#e2dbd0;--w:#fff;--mt:#6b6560;--lt:#9a938b;--vt:#2a9d5c;--rd:#c0392b;--bl:#2563eb;--sidebar-w:258px;--header-h:64px}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--n);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit}

/* LOGIN */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--n);position:relative;overflow:hidden}
.login-screen::before{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(200,146,48,.12) 0%,transparent 70%);border-radius:50%}
.login-screen::after{content:'';position:absolute;bottom:-15%;left:-8%;width:500px;height:500px;background:radial-gradient(circle,rgba(200,146,48,.08) 0%,transparent 70%);border-radius:50%}
.login-box{width:100%;max-width:420px;padding:48px 40px;background:rgba(244,239,230,.03);border:1px solid rgba(244,239,230,.08);border-radius:20px;position:relative;z-index:1;backdrop-filter:blur(20px)}
.login-logo{text-align:center;margin-bottom:36px}
.login-logo img{height:40px;width:auto;margin-bottom:12px}
.login-logo p{font-size:.72rem;color:rgba(244,239,230,.35);font-weight:500;margin-top:6px;letter-spacing:.08em;text-transform:uppercase}
.login-field{margin-bottom:16px}
.login-label{display:block;font-size:.68rem;font-weight:700;color:rgba(244,239,230,.4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px}
.login-input{width:100%;padding:13px 16px;background:rgba(244,239,230,.05);border:1.5px solid rgba(244,239,230,.1);border-radius:10px;font-size:.85rem;color:var(--bg);transition:all .2s}
.login-input:focus{outline:none;border-color:var(--oc);background:rgba(200,146,48,.05)}
.login-input::placeholder{color:rgba(244,239,230,.25)}
.login-select{width:100%;padding:13px 16px;background:rgba(244,239,230,.05);border:1.5px solid rgba(244,239,230,.1);border-radius:10px;font-size:.85rem;color:var(--bg);cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a938b' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.login-select:focus{outline:none;border-color:var(--oc)}.login-select option{background:var(--n);color:var(--bg)}
.login-btn{width:100%;padding:14px;background:var(--oc);color:var(--w);border:none;border-radius:10px;font-size:.88rem;font-weight:700;cursor:pointer;transition:all .3s;margin-top:8px}
.login-btn:hover{background:var(--och);transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,146,48,.35)}
.login-footer{text-align:center;margin-top:24px;font-size:.7rem;color:rgba(244,239,230,.25)}
.login-footer a{color:var(--oc);font-weight:600}
.login-error{display:none;padding:10px 14px;background:rgba(192,57,43,.15);border:1px solid rgba(192,57,43,.3);border-radius:8px;font-size:.76rem;color:#ff6b6b;margin-bottom:16px}
.login-api{margin-top:16px;padding-top:16px;border-top:1px solid rgba(244,239,230,.06)}
.login-api-toggle{display:flex;align-items:center;gap:8px;font-size:.7rem;color:rgba(244,239,230,.3);cursor:pointer;margin-bottom:10px}
.login-api-toggle:hover{color:var(--oc)}
.login-api-field{display:none}.login-api-field.show{display:block}

/* APP */
.app{display:none;min-height:100vh}.app.visible{display:flex}.login-screen.hidden{display:none}
.sidebar{width:var(--sidebar-w);background:var(--n);color:var(--bg);position:fixed;top:0;left:0;bottom:0;z-index:50;display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.sidebar-header{padding:20px 24px 16px;border-bottom:1px solid rgba(244,239,230,.08)}
.sidebar-header img{height:28px;width:auto;display:block;margin-bottom:8px}
.sidebar-badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.sidebar-badge.client{background:rgba(200,146,48,.15);color:var(--oc)}.sidebar-badge.admin{background:rgba(192,57,43,.2);color:#ff6b6b}
.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}
.nav-section{margin-bottom:20px}
.nav-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(244,239,230,.25);padding:0 12px;margin-bottom:8px}
.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:.82rem;font-weight:500;color:rgba(244,239,230,.5);transition:all .2s;margin-bottom:2px}
.nav-link:hover{color:var(--bg);background:rgba(244,239,230,.06)}
.nav-link.active{color:var(--bg);background:rgba(200,146,48,.15)}.nav-link.active svg{stroke:var(--oc)}
.nav-link svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.nav-count{margin-left:auto;color:var(--w);font-size:.58rem;font-weight:700;padding:2px 7px;border-radius:100px}
.nav-count.oc{background:var(--oc)}.nav-count.rd{background:var(--rd)}
.sidebar-footer{padding:14px 20px;border-top:1px solid rgba(244,239,230,.08)}
.user-card{display:flex;align-items:center;gap:10px}
.user-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:800;color:var(--w)}
.user-info{flex:1;min-width:0}.user-name{font-size:.78rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.6rem;color:rgba(244,239,230,.35);font-weight:500}
.logout-btn{width:100%;margin-top:10px;padding:8px;border-radius:8px;border:1px solid rgba(244,239,230,.1);background:transparent;color:rgba(244,239,230,.4);font-size:.72rem;font-weight:600;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}
.logout-btn:hover{border-color:var(--rd);color:var(--rd);background:rgba(192,57,43,.08)}
.logout-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.main{flex:1;margin-left:var(--sidebar-w);min-height:100vh;background:var(--gr)}
.header{height:var(--header-h);background:var(--w);border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:40}
.header-left{display:flex;align-items:center;gap:16px}
.mob-toggle{display:none;width:38px;height:38px;border-radius:10px;border:1px solid var(--bd);align-items:center;justify-content:center;background:var(--w)}
.mob-toggle span{display:block;width:16px;height:2px;background:var(--n);border-radius:2px}.mob-toggle span+span{margin-top:4px}
.header-title{font-size:1rem;font-weight:700}.header-title em{color:var(--mt);font-weight:400;font-size:.85rem;font-style:normal}
.header-right{display:flex;align-items:center;gap:10px}
.h-btn{display:flex;align-items:center;gap:6px;padding:9px 18px;border-radius:100px;font-size:.76rem;font-weight:600;transition:all .2s}
.h-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.h-btn-oc{background:var(--oc);color:var(--w)}.h-btn-oc:hover{background:var(--och);transform:translateY(-1px);box-shadow:0 4px 14px rgba(200,146,48,.3)}
.h-btn-o{background:transparent;border:1.5px solid var(--bd);color:var(--n)}.h-btn-o:hover{border-color:var(--n)}
.notif-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;position:relative;background:var(--w);transition:all .2s}
.notif-btn:hover{border-color:var(--n);background:var(--n)}.notif-btn:hover svg{stroke:var(--bg)}
.notif-btn svg{width:16px;height:16px;stroke:var(--n);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.notif-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;background:var(--rd);border-radius:50%;border:2px solid var(--w)}
.content{padding:28px 32px 60px}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(14,14,14,.5);z-index:45;opacity:0;transition:opacity .3s}.sidebar-overlay.show{display:block;opacity:1}

/* COMPONENTS */
.grid{display:grid;gap:16px;margin-bottom:22px}
.g-4{grid-template-columns:repeat(4,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}.g-2{grid-template-columns:repeat(2,1fr)}.g-1-2{grid-template-columns:1fr 2fr}.g-2-1{grid-template-columns:2fr 1fr}
.card{background:var(--w);border:1px solid var(--bd);border-radius:14px;padding:22px;transition:all .3s}.card:hover{box-shadow:0 6px 20px rgba(14,14,14,.04)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:8px}
.card-title{font-size:.88rem;font-weight:700}.card-sub{font-size:.68rem;color:var(--lt);margin-top:2px}
.welcome{background:var(--n);border-radius:16px;padding:32px 36px;color:var(--bg);margin-bottom:28px;position:relative;overflow:hidden}
.welcome::before{content:'';position:absolute;top:-40%;right:-5%;width:300px;height:300px;background:radial-gradient(circle,rgba(200,146,48,.2) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.welcome-row{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.welcome-text{flex:1;min-width:240px}
.welcome-tag{display:inline-block;padding:4px 12px;background:rgba(200,146,48,.15);color:var(--oc);border-radius:100px;font-size:.63rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px}
.welcome h2{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}
.welcome p{font-size:.83rem;color:rgba(244,239,230,.5);max-width:520px}
.welcome-logo{flex-shrink:0;opacity:.18}.welcome-logo img{height:32px;width:auto}
.welcome-stats{display:flex;gap:32px;margin-top:20px;flex-wrap:wrap}
.w-stat{border-left:2px solid rgba(200,146,48,.3);padding-left:14px}
.w-stat-val{font-size:1.25rem;font-weight:800;color:var(--oc)}.w-stat-label{font-size:.66rem;color:rgba(244,239,230,.35);font-weight:500;margin-top:2px}
.period-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}
.period-tabs{display:flex;gap:4px;background:var(--w);border:1px solid var(--bd);border-radius:10px;padding:3px}
.p-tab{padding:7px 16px;border-radius:8px;font-size:.74rem;font-weight:600;color:var(--mt);transition:all .2s}.p-tab:hover{color:var(--n)}.p-tab.active{background:var(--n);color:var(--bg)}
.period-info{font-size:.74rem;color:var(--lt);font-weight:500}
.kpi{position:relative;overflow:hidden}.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--oc);transform:scaleX(0);transform-origin:left;transition:transform .4s}.kpi:hover::before{transform:scaleX(1)}
.kpi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.kpi-icon svg{width:18px;height:18px;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;fill:none}
.kpi-icon.oc{background:rgba(200,146,48,.08)}.kpi-icon.oc svg{stroke:var(--oc)}.kpi-icon.vt{background:rgba(42,157,92,.08)}.kpi-icon.vt svg{stroke:var(--vt)}.kpi-icon.rd{background:rgba(192,57,43,.08)}.kpi-icon.rd svg{stroke:var(--rd)}.kpi-icon.n{background:rgba(14,14,14,.05)}.kpi-icon.n svg{stroke:var(--n)}.kpi-icon.bl{background:rgba(37,99,235,.08)}.kpi-icon.bl svg{stroke:var(--bl)}
.kpi-badge{font-size:.6rem;font-weight:700;padding:3px 8px;border-radius:100px}.kpi-badge.up{background:rgba(42,157,92,.08);color:var(--vt)}.kpi-badge.down{background:rgba(192,57,43,.08);color:var(--rd)}.kpi-badge.neutral{background:rgba(14,14,14,.05);color:var(--mt)}
.kpi-val{font-size:1.55rem;font-weight:800;letter-spacing:-.02em;margin-bottom:2px}.kpi-label{font-size:.72rem;color:var(--mt);font-weight:500}
.kpi-bar{height:4px;background:var(--gr);border-radius:4px;margin-top:14px;overflow:hidden}.kpi-bar-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1)}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:190px;padding:10px 0;border-bottom:1px solid var(--bd)}.bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.bar-container{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;gap:3px}
.bar{border-radius:4px 4px 0 0;min-height:4px;transition:height .6s cubic-bezier(.4,0,.2,1);width:45%;max-width:28px}.bar.single{width:70%;max-width:36px}.bar.rev{background:var(--oc)}.bar.dep{background:var(--n)}.bar-label{font-size:.58rem;color:var(--lt);font-weight:600;text-transform:uppercase}
.chart-legend{display:flex;gap:16px}.legend-item{display:flex;align-items:center;gap:6px;font-size:.68rem;color:var(--mt);font-weight:500}.legend-dot{width:8px;height:8px;border-radius:3px}
.tbl-card{padding:0;overflow:hidden}.tbl-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--bd);flex-wrap:wrap;gap:8px}.tbl-title{font-size:.88rem;font-weight:700}.tbl-count{font-size:.63rem;font-weight:600;color:var(--lt);background:var(--gr);padding:3px 10px;border-radius:100px}
.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--lt);padding:11px 22px;background:var(--gr);border-bottom:1px solid var(--bd);white-space:nowrap}.tbl td{padding:13px 22px;font-size:.78rem;border-bottom:1px solid var(--bd);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:rgba(200,146,48,.02)}
.status{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:100px;font-size:.66rem;font-weight:700}.status.paid,.status.active{background:rgba(42,157,92,.08);color:var(--vt)}.status.pending,.status.warning{background:rgba(200,146,48,.1);color:var(--oc)}.status.overdue,.status.danger{background:rgba(192,57,43,.08);color:var(--rd)}.status.draft,.status.inactive{background:rgba(14,14,14,.05);color:var(--mt)}.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.obl-list{display:flex;flex-direction:column;gap:10px}.obl-item{display:flex;align-items:center;gap:12px;padding:13px 15px;background:var(--gr);border-radius:10px;transition:all .2s}.obl-item:hover{background:rgba(200,146,48,.05)}
.obl-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.obl-icon svg{width:16px;height:16px;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;fill:none}
.obl-icon.green{background:rgba(42,157,92,.1)}.obl-icon.green svg{stroke:var(--vt)}.obl-icon.orange{background:rgba(200,146,48,.1)}.obl-icon.orange svg{stroke:var(--oc)}.obl-icon.red{background:rgba(192,57,43,.1)}.obl-icon.red svg{stroke:var(--rd)}
.obl-text{flex:1;min-width:0}.obl-name{font-size:.78rem;font-weight:700}.obl-date{font-size:.66rem;color:var(--lt);margin-top:1px}
.obl-tag{font-size:.58rem;font-weight:700;padding:3px 8px;border-radius:100px;white-space:nowrap}.obl-tag.done{background:rgba(42,157,92,.08);color:var(--vt)}.obl-tag.soon{background:rgba(200,146,48,.1);color:var(--oc)}.obl-tag.late{background:rgba(192,57,43,.08);color:var(--rd)}
.act-list{display:flex;flex-direction:column}.act-item{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid var(--bd)}.act-item:last-child{border-bottom:none}
.act-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}.act-dot.oc{background:var(--oc)}.act-dot.vt{background:var(--vt)}.act-dot.n{background:var(--n)}
.act-avatar{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.54rem;font-weight:800;color:var(--w);flex-shrink:0;margin-top:2px}
.act-text{font-size:.76rem;color:var(--mt);line-height:1.5}.act-text strong{color:var(--n);font-weight:600}.act-time{font-size:.6rem;color:var(--lt);margin-top:1px}
.pie-wrapper{display:flex;align-items:center;gap:20px;padding:8px 0}.pie{width:115px;height:115px;border-radius:50%;position:relative;flex-shrink:0}.pie-center{position:absolute;inset:22px;background:var(--w);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column}.pie-center-val{font-size:.95rem;font-weight:800}.pie-center-label{font-size:.52rem;color:var(--lt);font-weight:500}
.pie-legend{display:flex;flex-direction:column;gap:7px;flex:1}.pie-leg-item{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--mt);font-weight:500}.pie-leg-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.pie-leg-val{margin-left:auto;font-weight:700;color:var(--n)}
.contact-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--gr);border-radius:10px;margin-bottom:12px}
.contact-avatar{width:44px;height:44px;border-radius:10px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--n)}.contact-avatar img{height:22px;width:auto}
.contact-name{font-size:.85rem;font-weight:700}.contact-sub{font-size:.68rem;color:var(--lt)}
.contact-row{display:flex;align-items:center;gap:8px;font-size:.76rem;color:var(--mt);margin-bottom:6px}
.contact-row svg{width:15px;height:15px;stroke:var(--oc);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.btn-block{width:100%;margin-top:16px;padding:11px;border-radius:10px;background:var(--n);color:var(--bg);font-size:.78rem;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:all .2s}.btn-block:hover{background:#1a1a1a}
.search-bar{display:flex;gap:10px;margin-bottom:22px;flex-wrap:wrap}
.search-input{flex:1;min-width:200px;padding:10px 16px 10px 40px;border:1.5px solid var(--bd);border-radius:10px;font-size:.82rem;color:var(--n);transition:border-color .2s;background:var(--w) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239a938b' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") 14px center no-repeat}
.search-input:focus{outline:none;border-color:var(--oc)}.search-input::placeholder{color:var(--lt)}
.filter-select{padding:10px 16px;border:1.5px solid var(--bd);border-radius:10px;font-size:.82rem;background:var(--w);color:var(--n);cursor:pointer;min-width:140px}.filter-select:focus{outline:none;border-color:var(--oc)}
.client-cell{display:flex;align-items:center;gap:10px}.client-avatar{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:800;color:var(--w);flex-shrink:0}.client-name{font-weight:700;font-size:.8rem}.client-company{font-size:.66rem;color:var(--lt)}
.metier-tag{display:inline-block;padding:3px 9px;border-radius:100px;font-size:.6rem;font-weight:700}.metier-tag.vtc{background:rgba(200,146,48,.1);color:var(--oc)}.metier-tag.taxi{background:rgba(14,14,14,.06);color:var(--n)}.metier-tag.vmdtr{background:rgba(37,99,235,.08);color:var(--bl)}.metier-tag.formation{background:rgba(42,157,92,.08);color:var(--vt)}
.progress-bar{width:55px;height:5px;background:var(--gr);border-radius:5px;overflow:hidden;display:inline-block;vertical-align:middle;margin-right:5px}.progress-fill{height:100%;border-radius:5px}
.task-list{display:flex;flex-direction:column;gap:8px}.task-item{display:flex;align-items:center;gap:10px;padding:11px 13px;background:var(--gr);border-radius:10px;transition:all .2s}.task-item:hover{background:rgba(200,146,48,.05)}
.task-priority{width:4px;height:30px;border-radius:4px;flex-shrink:0}.task-priority.high{background:var(--rd)}.task-priority.medium{background:var(--oc)}.task-priority.low{background:var(--vt)}
.task-text{flex:1;min-width:0}.task-name{font-size:.78rem;font-weight:600}.task-meta{font-size:.64rem;color:var(--lt);margin-top:1px}
.task-due{font-size:.58rem;font-weight:700;padding:3px 8px;border-radius:100px;white-space:nowrap}.task-due.urgent{background:rgba(192,57,43,.08);color:var(--rd)}.task-due.normal{background:rgba(200,146,48,.1);color:var(--oc)}.task-due.ok{background:rgba(42,157,92,.08);color:var(--vt)}
.task-check{width:20px;height:20px;border:2px solid var(--bd);border-radius:6px;flex-shrink:0;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.task-check:hover{border-color:var(--vt);background:rgba(42,157,92,.06)}.task-check.done{border-color:var(--vt);background:var(--vt)}.task-check.done::after{content:'';width:6px;height:10px;border:solid var(--w);border-width:0 2px 2px 0;transform:rotate(45deg);margin-top:-2px}

/* AI CHATBOT */
.ai-fab{position:fixed;bottom:28px;right:28px;z-index:200;width:58px;height:58px;border-radius:50%;background:var(--oc);color:var(--w);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px 28px rgba(200,146,48,.4);transition:all .3s;border:none}
.ai-fab:hover{transform:scale(1.08);box-shadow:0 8px 36px rgba(200,146,48,.5)}.ai-fab svg{width:26px;height:26px;stroke:var(--w);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s}.ai-fab.open svg{transform:rotate(45deg)}
.ai-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--oc);animation:aiPulse 2s infinite;pointer-events:none}
@keyframes aiPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.4);opacity:0}}
.ai-panel{position:fixed;bottom:100px;right:28px;z-index:199;width:400px;max-height:560px;background:var(--w);border:1px solid var(--bd);border-radius:18px;box-shadow:0 20px 60px rgba(14,14,14,.15);display:flex;flex-direction:column;transform:translateY(20px) scale(.95);opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}
.ai-panel.open{transform:translateY(0) scale(1);opacity:1;visibility:visible}
.ai-header{padding:18px 20px;background:var(--n);color:var(--bg);display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(244,239,230,.08)}
.ai-header-icon{width:38px;height:38px;border-radius:10px;background:var(--oc);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.ai-header-icon img{height:20px;width:auto}
.ai-header-text{flex:1}.ai-header-title{font-size:.88rem;font-weight:700}.ai-header-sub{font-size:.64rem;color:rgba(244,239,230,.4);margin-top:1px}
.ai-header-close{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:transparent;border:none}.ai-header-close:hover{background:rgba(244,239,230,.1)}.ai-header-close svg{width:16px;height:16px;stroke:rgba(244,239,230,.5);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ai-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px;min-height:280px;max-height:380px}
.ai-msg{max-width:88%;padding:12px 16px;border-radius:14px;font-size:.8rem;line-height:1.6;animation:fadeUp .3s ease both}.ai-msg.bot{background:var(--gr);color:var(--n);align-self:flex-start;border-bottom-left-radius:4px}.ai-msg.user{background:var(--n);color:var(--bg);align-self:flex-end;border-bottom-right-radius:4px}.ai-msg.bot strong{color:var(--oc);font-weight:700}
.ai-msg.typing{display:flex;gap:4px;align-items:center;padding:14px 18px}.ai-msg.typing span{width:7px;height:7px;border-radius:50%;background:var(--lt);animation:typDot .8s infinite}.ai-msg.typing span:nth-child(2){animation-delay:.15s}.ai-msg.typing span:nth-child(3){animation-delay:.3s}
@keyframes typDot{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}
.ai-suggestions{display:flex;flex-wrap:wrap;gap:6px;padding:0 20px 12px}.ai-sug{padding:6px 12px;background:var(--gr);border:1px solid var(--bd);border-radius:100px;font-size:.68rem;font-weight:600;color:var(--mt);cursor:pointer;transition:all .2s}.ai-sug:hover{border-color:var(--oc);color:var(--oc);background:rgba(200,146,48,.05)}
.ai-input-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--bd);background:var(--w)}
.ai-input{flex:1;padding:10px 14px;border:1.5px solid var(--bd);border-radius:10px;font-size:.82rem;color:var(--n);background:var(--gr);resize:none;height:40px;transition:border-color .2s}.ai-input:focus{outline:none;border-color:var(--oc)}.ai-input::placeholder{color:var(--lt)}
.ai-send{width:40px;height:40px;border-radius:10px;background:var(--oc);display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s;flex-shrink:0}.ai-send:hover{background:var(--och);transform:scale(1.05)}.ai-send:disabled{background:var(--bd);cursor:not-allowed;transform:none}.ai-send svg{width:16px;height:16px;stroke:var(--w);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.ai-key-warning{padding:10px 16px;background:rgba(200,146,48,.08);border-bottom:1px solid var(--bd);font-size:.68rem;color:var(--oc);text-align:center}.ai-key-warning a{font-weight:700;text-decoration:underline;cursor:pointer}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd);border-radius:10px}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeUp .5s cubic-bezier(.4,0,.2,1) both}.anim-d1{animation-delay:.06s}.anim-d2{animation-delay:.12s}.anim-d3{animation-delay:.18s}.anim-d4{animation-delay:.24s}.anim-d5{animation-delay:.3s}

@media(max-width:1100px){.g-4{grid-template-columns:repeat(2,1fr)}.g-3,.g-1-2,.g-2-1{grid-template-columns:1fr}}
@media(max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.content{padding:20px 16px 60px}.header{padding:0 16px}.mob-toggle{display:flex}.g-4,.g-2{grid-template-columns:1fr 1fr}.welcome{padding:24px 20px}.welcome h2{font-size:1.1rem}.welcome-stats{gap:16px}.h-btn .desk{display:none}.bar-chart{height:150px}.search-bar{flex-direction:column}.filter-select{width:100%}.tbl th,.tbl td{padding:10px 14px;font-size:.72rem}.login-box{margin:20px;padding:32px 24px}.ai-panel{right:12px;left:12px;width:auto;bottom:90px;max-height:480px}.ai-fab{bottom:20px;right:20px;width:52px;height:52px}}
@media(max-width:480px){.g-4,.g-2{grid-template-columns:1fr}.kpi-val{font-size:1.25rem}.w-stat-val{font-size:1rem}}

/* WHATSAPP */
.wa-fab{position:fixed;bottom:28px;left:28px;z-index:190;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:all .3s;text-decoration:none}
.wa-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.5)}
.wa-fab svg{width:30px;height:30px}
@media(max-width:768px){.wa-fab{bottom:20px;left:20px;width:50px;height:50px}.wa-fab svg{width:26px;height:26px}}
