@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --bg:#0a0e17;--s1:#0f1421;--s2:#141926;--s3:#1a2030;--s4:#1f2638;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.1);
  --accent:#6366f1;--accent2:#818cf8;--accent-glow:rgba(99,102,241,0.2);
  --cyan:#22d3ee;--green:#10b981;--yellow:#f59e0b;--red:#ef4444;--purple:#a855f7;--orange:#f97316;
  --text:#e2e8f0;--text2:#94a3b8;--text3:#475569;
  --font:'Plus Jakarta Sans',sans-serif;--mono:'JetBrains Mono',monospace;
}
[data-theme="light"] {
  --bg:#f1f5f9;--s1:#ffffff;--s2:#f8fafc;--s3:#f1f5f9;--s4:#e2e8f0;
  --border:rgba(0,0,0,0.07);--border2:rgba(0,0,0,0.12);
  --text:#0f172a;--text2:#475569;--text3:#94a3b8;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);overflow:hidden}

/* ── LOGIN ── */
#login-screen{position:fixed;inset:0;background:var(--bg);z-index:100;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2rem}
.login-card{background:var(--s1);border:1px solid var(--border2);border-radius:20px;padding:2.5rem;width:380px;box-shadow:0 25px 80px rgba(0,0,0,.4)}
.login-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}
.login-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.login-brand{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}
.login-brand span{color:var(--accent2)}
.login-sub{font-size:.75rem;color:var(--text2);margin-top:.1rem;font-family:var(--mono)}
.login-title{font-size:1rem;font-weight:600;margin-bottom:1.5rem}
.lf{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.lf label{font-size:.75rem;font-weight:500;color:var(--text2)}
.lf input{background:var(--s3);border:1px solid var(--border2);color:var(--text);padding:.65rem .9rem;border-radius:10px;font-size:.875rem;font-family:var(--font);outline:none;transition:border-color .15s}
.lf input:focus{border-color:var(--accent)}
.login-btn{width:100%;background:linear-gradient(135deg,var(--accent),var(--purple));color:#fff;border:none;padding:.7rem;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;font-family:var(--font);margin-top:.5rem;transition:opacity .15s}
.login-btn:hover{opacity:.9}
.login-error{font-size:.78rem;color:var(--red);text-align:center;margin-top:.5rem;min-height:1.2em}
.login-hint{font-size:.72rem;color:var(--text3);text-align:center;margin-top:.75rem;font-family:var(--mono)}

/* ── SHELL ── */
.app{display:flex;height:100vh}

/* ── SIDEBAR ── */
.sidebar{width:220px;background:var(--s1);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s}
.sidebar.collapsed{width:56px}
.sb-top{padding:1rem .85rem .75rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.sb-brand{display:flex;align-items:center;gap:.6rem;overflow:hidden}
.sb-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}
.sb-name{font-size:.82rem;font-weight:700;white-space:nowrap;letter-spacing:-.01em}
.sb-name span{color:var(--accent2)}
.sb-toggle{background:none;border:none;color:var(--text3);cursor:pointer;font-size:.85rem;padding:.2rem;border-radius:4px;flex-shrink:0}
.sb-toggle:hover{color:var(--text);background:var(--s3)}
.sb-nav{flex:1;overflow-y:auto;padding:.5rem .5rem}
.sb-section{font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);padding:.5rem .5rem .25rem;white-space:nowrap;overflow:hidden}
.nav-item{display:flex;align-items:center;gap:.65rem;padding:.55rem .6rem;border-radius:8px;cursor:pointer;transition:all .15s;margin-bottom:.15rem;white-space:nowrap;overflow:hidden;position:relative;text-decoration:none;color:var(--text)}
.nav-item:hover{background:var(--s3)}
.nav-item.active{background:var(--accent-glow);color:var(--accent2)}
.nav-item.active .ni-icon{color:var(--accent2)}
.ni-icon{font-size:.95rem;flex-shrink:0;width:20px;text-align:center}
.ni-label{font-size:.8rem;font-weight:500;overflow:hidden;text-overflow:ellipsis}
.ni-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;padding:.1rem .45rem;border-radius:20px;flex-shrink:0}
.ni-badge.red{background:var(--red)}
.sb-bottom{padding:.75rem .5rem;border-top:1px solid var(--border)}
.user-chip{display:flex;align-items:center;gap:.65rem;padding:.5rem .6rem;border-radius:8px;cursor:pointer;transition:background .15s;overflow:hidden;text-decoration:none;color:var(--text)}
.user-chip:hover{background:var(--s3)}
.uc-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}
.uc-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.uc-info{overflow:hidden}
.uc-name{font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.uc-role{font-size:.65rem;color:var(--text2);white-space:nowrap}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:50px;background:var(--s1);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;flex-shrink:0}
.tb-title{font-size:.9rem;font-weight:600;flex:1}
.tb-actions{display:flex;align-items:center;gap:.6rem}
.tb-btn{background:var(--s3);border:1px solid var(--border2);color:var(--text2);padding:.35rem .75rem;border-radius:7px;font-size:.75rem;cursor:pointer;font-family:var(--font);transition:all .15s;display:flex;align-items:center;gap:.35rem;text-decoration:none}
.tb-btn:hover{border-color:var(--accent);color:var(--accent2)}
.tb-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.tb-btn.primary:hover{background:var(--accent2);border-color:var(--accent2);color:#fff}
.content{flex:1;overflow-y:auto;padding:1.5rem}

/* ── COMPONENTS ── */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.kpi{background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:1.1rem 1.25rem;position:relative;overflow:hidden;transition:border-color .2s,transform .15s}
.kpi:hover{border-color:var(--border2);transform:translateY(-2px)}
.kpi-accent{position:absolute;top:0;left:0;right:0;height:2px}
.kpi-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text2);margin-bottom:.5rem;font-weight:600}
.kpi-val{font-size:1.9rem;font-weight:700;font-family:var(--mono);line-height:1}
.kpi-sub{font-size:.7rem;color:var(--text2);margin-top:.35rem}
.kpi-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:1.8rem;opacity:.12}

.card{background:var(--s1);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.card-hdr{padding:.85rem 1.1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.5rem}
.card-body{padding:1rem 1.1rem}

.sla-item{margin-bottom:1rem}
.sla-item:last-child{margin-bottom:0}
.sla-top{display:flex;justify-content:space-between;font-size:.78rem;margin-bottom:.4rem}
.sla-name{color:var(--text2)}
.sla-pct{font-family:var(--mono);font-weight:600}
.sla-track{height:7px;background:var(--s3);border-radius:4px;overflow:hidden}
.sla-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.19,1,.22,1)}

.timeline-item{display:flex;gap:.85rem;padding-bottom:.9rem;position:relative}
.timeline-item::before{content:'';position:absolute;left:14px;top:22px;bottom:0;width:1px;background:var(--border)}
.timeline-item:last-child::before{display:none}
.tl-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;z-index:1}
.tl-body{flex:1;padding-top:.2rem}
.tl-title{font-size:.8rem;font-weight:500;margin-bottom:.15rem}
.tl-meta{font-size:.7rem;color:var(--text2)}

.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:20px;font-size:.68rem;font-weight:600;gap:.3rem}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor}
.b-open{background:rgba(99,102,241,.15);color:var(--accent2)}
.b-progress{background:rgba(245,158,11,.15);color:var(--yellow)}
.b-done{background:rgba(16,185,129,.15);color:var(--green)}
.b-urgent{background:rgba(239,68,68,.15);color:var(--red)}
.b-info{background:rgba(34,211,238,.12);color:var(--cyan)}

.data-table{width:100%;border-collapse:collapse}
.data-table th{background:var(--s2);padding:.6rem .9rem;text-align:left;font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);border-bottom:1px solid var(--border);font-weight:600}
.data-table td{padding:.75rem .9rem;font-size:.8rem;border-bottom:1px solid var(--border)}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr{transition:background .1s;cursor:pointer}
.data-table tbody tr:hover td{background:var(--s2)}

.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .95rem;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;border:none;font-family:var(--font);transition:all .15s;text-decoration:none}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent2)}
.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--text2)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent2)}
.btn-danger{background:transparent;border:1px solid transparent;color:var(--red)}
.btn-danger:hover{background:rgba(239,68,68,.1);border-color:var(--red)}
.btn-sm{padding:.3rem .65rem;font-size:.73rem}
.btn-green{background:rgba(16,185,129,.15);color:var(--green);border:1px solid rgba(16,185,129,.3)}
.btn-whats{background:#25d366;color:#fff;border:none}
.btn-whats:hover{background:#1ebe57}

.fg{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.9rem}
.fg label{font-size:.75rem;font-weight:500;color:var(--text2)}
.fg input,.fg select,.fg textarea{background:var(--s3);border:1px solid var(--border2);color:var(--text);padding:.55rem .8rem;border-radius:8px;font-size:.82rem;font-family:var(--font);outline:none;transition:border-color .15s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent)}
.fg textarea{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.fg select option{background:var(--s3);color:var(--text)}

.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:50;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.overlay.open{display:flex}
.modal{background:var(--s2);border:1px solid var(--border2);border-radius:16px;width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 30px 100px rgba(0,0,0,.5)}
.modal-hdr{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--s2);z-index:1}
.modal-ttl{font-size:.95rem;font-weight:600}
.modal-x{background:none;border:none;color:var(--text2);cursor:pointer;font-size:1.1rem;padding:.2rem .4rem;border-radius:5px}
.modal-x:hover{color:var(--text)}
.modal-body{padding:1.5rem}
.modal-ftr{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.65rem}

.kanban{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem;min-height:500px}
.kanban-col{width:260px;flex-shrink:0;background:var(--s2);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;max-height:600px}
.kc-hdr{padding:.75rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.kc-title{font-size:.78rem;font-weight:600;display:flex;align-items:center;gap:.5rem}
.kc-count{background:var(--s4);color:var(--text2);font-size:.65rem;padding:.1rem .45rem;border-radius:20px;font-family:var(--mono)}
.kc-body{padding:.65rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:.55rem}
.k-card{background:var(--s1);border:1px solid var(--border);border-radius:9px;padding:.8rem .9rem;cursor:pointer;transition:all .15s}
.k-card:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(99,102,241,.15);transform:translateY(-1px)}
.k-card-title{font-size:.8rem;font-weight:600;margin-bottom:.4rem;line-height:1.3}
.k-card-meta{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;margin-bottom:.5rem}
.k-label{font-size:.62rem;padding:.15rem .5rem;border-radius:4px;font-weight:600}
.k-progress{margin-top:.5rem}
.k-prog-bar{height:4px;background:var(--s3);border-radius:2px;overflow:hidden;margin-top:.3rem}
.k-prog-fill{height:100%;background:var(--accent);border-radius:2px}
.k-prog-label{font-size:.65rem;color:var(--text2);display:flex;justify-content:space-between}
.k-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.55rem;padding-top:.55rem;border-top:1px solid var(--border)}
.k-assignee{display:flex;align-items:center;gap:.35rem;font-size:.68rem;color:var(--text2)}
.k-av{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:.55rem;color:#fff;font-weight:700}
.k-date{font-size:.65rem;color:var(--text2);font-family:var(--mono)}
.kc-add{margin:.65rem;margin-top:.25rem}
.kc-add-btn{width:100%;background:transparent;border:1px dashed var(--border2);color:var(--text3);padding:.45rem;border-radius:7px;font-size:.75rem;cursor:pointer;font-family:var(--font);transition:all .15s}
.kc-add-btn:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-glow)}

.tv-panel-page{background:#060910;min-height:calc(100vh - 110px);display:flex;flex-direction:column;margin:-1.5rem;padding:1.25rem 1.5rem}
.tv-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}
.tv-title{font-size:.9rem;color:rgba(255,255,255,.4);font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase}
.tv-clock{font-size:1.2rem;font-family:var(--mono);color:rgba(255,255,255,.7)}
.tv-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;flex:1}
.tv-col-title{font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;margin-bottom:.75rem;font-family:var(--mono)}
.tv-ticket{display:flex;gap:.75rem;align-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:.65rem .85rem;margin-bottom:.5rem}
.tv-ticket.em-and{border-color:rgba(245,158,11,.25);background:rgba(245,158,11,.06)}
.tv-ticket.mine{border-color:rgba(99,102,241,.4);background:rgba(99,102,241,.08)}
.tv-n{font-family:var(--mono);font-size:1rem;font-weight:600;width:28px;text-align:center;flex-shrink:0}
.tv-info{flex:1;min-width:0}
.tv-ti{font-size:.75rem;font-weight:500;color:rgba(255,255,255,.8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.15rem}
.tv-ts{font-size:.65rem;color:rgba(255,255,255,.35)}
.tv-timer{font-family:var(--mono);font-size:.68rem;color:rgba(255,255,255,.3);flex-shrink:0}
.tv-ticker{background:rgba(99,102,241,.08);border-top:1px solid rgba(99,102,241,.2);padding:.45rem 1.5rem;overflow:hidden;white-space:nowrap;margin:1.25rem -1.5rem -1.25rem}
.tv-ticker-text{font-size:.7rem;color:rgba(255,255,255,.4);font-family:var(--mono);animation:tvscroll 40s linear infinite;display:inline-block}
@keyframes tvscroll{0%{transform:translateX(100vw)}100%{transform:translateX(-100%)}}

.vault-card{background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem;display:flex;gap:.9rem;align-items:flex-start;transition:all .15s;margin-bottom:.65rem}
.vault-card:hover{border-color:var(--border2);box-shadow:0 3px 12px rgba(0,0,0,.2)}
.vault-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.vault-info{flex:1;min-width:0}
.vault-name{font-size:.85rem;font-weight:600;margin-bottom:.15rem}
.vault-fields{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}
.vault-field{background:var(--s3);border-radius:6px;padding:.4rem .65rem;display:flex;align-items:center;justify-content:space-between}
.vf-label{font-size:.62rem;color:var(--text2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.1rem}
.vf-val{font-size:.75rem;font-family:var(--mono);color:var(--text)}
.vf-val.msk{color:var(--text3);letter-spacing:.1em}
.vf-btns{display:flex;gap:.25rem}
.icbtn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:.78rem;padding:.15rem .3rem;border-radius:4px;transition:all .1s}
.icbtn:hover{color:var(--text);background:var(--s4)}

.eq-card{background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem;display:flex;gap:.9rem;align-items:flex-start;transition:all .15s;margin-bottom:.65rem}
.eq-card:hover{border-color:var(--border2)}
.eq-tag{font-family:var(--mono);font-size:.68rem;background:var(--accent-glow);color:var(--accent2);border:1px solid rgba(99,102,241,.3);padding:.2rem .6rem;border-radius:5px}

.os-card{background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem;margin-bottom:.75rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}

.config-section{background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-bottom:1rem}
.cs-title{font-size:.82rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.user-card{display:flex;align-items:center;gap:.85rem;padding:.75rem;border-radius:9px;transition:background .1s;cursor:pointer}
.user-card:hover{background:var(--s3)}
.ua{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;color:#fff;flex-shrink:0}
.role-chip{font-size:.62rem;padding:.15rem .55rem;border-radius:20px;font-weight:600}
.rc-admin{background:rgba(99,102,241,.15);color:var(--accent2)}
.rc-tech{background:rgba(34,211,238,.12);color:var(--cyan)}
.rc-client{background:rgba(16,185,129,.12);color:var(--green)}

.chat-area{display:flex;flex-direction:column;height:320px}
.chat-msgs{flex:1;overflow-y:auto;padding:.85rem;display:flex;flex-direction:column;gap:.65rem}
.msg{max-width:82%}
.msg-me{align-self:flex-end}
.msg-other{align-self:flex-start}
.msg-bubble{padding:.55rem .85rem;border-radius:10px;font-size:.8rem;line-height:1.5}
.msg-me .msg-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:2px}
.msg-other .msg-bubble{background:var(--s3);border:1px solid var(--border);border-bottom-left-radius:2px}
.msg-meta{font-size:.62rem;color:var(--text3);margin-top:.2rem}
.msg-me .msg-meta{text-align:right}
.msg-sender{font-size:.65rem;color:var(--text2);margin-bottom:.15rem}
.chat-input-row{padding:.65rem .85rem;border-top:1px solid var(--border);display:flex;gap:.6rem;flex-shrink:0}
.chat-input{flex:1;background:var(--s3);border:1px solid var(--border2);color:var(--text);padding:.5rem .8rem;border-radius:8px;font-size:.8rem;font-family:var(--font);outline:none}
.chat-input:focus{border-color:var(--accent)}

.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--s4);border:1px solid var(--border2);border-left:3px solid var(--green);color:var(--text);padding:.85rem 1.1rem;border-radius:10px;font-size:.8rem;z-index:999;opacity:0;transform:translateY(6px);transition:all .22s;pointer-events:none;max-width:320px}
.toast.show{opacity:1;transform:translateY(0)}

::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s4);border-radius:2px}

.custo-row{display:flex;align-items:center;gap:.75rem;padding:.75rem .9rem;border-bottom:1px solid var(--border);font-size:.8rem;transition:background .1s;cursor:pointer}
.custo-row:hover{background:var(--s2)}
.custo-row:last-child{border-bottom:none}
.cr-cat{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* Alert de erro/sucesso nas páginas */
.alert{padding:.75rem 1rem;border-radius:8px;font-size:.8rem;margin-bottom:1rem}
.alert-danger{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--red)}
.alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:var(--green)}

/* Animação de entrada de página */
.page-enter{animation:fin .2s ease}
@keyframes fin{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
