/* ═══════════════ RESET & VARIABLES ═══════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Paleta JGP — Dashboard Analista */
  --bg:#F6F6F5;--card:#FFFFFF;--surface:#E7E8E3;--border:#D5D7CE;--border-lt:#E7E8E3;
  --accent:#16164D;--accent-h:#5C5D81;--accent-bg:#DCDCE4;
  --t1:#000000;--t2:#4D4C4D;--t3:#999999;
  --done:#1a7a00;--done-bg:#DFF3DB;--wip:#16164D;--wip-bg:#DCDCE4;
  --rip:#B91C1C;--rip-bg:#FDE8E8;--hold:#856404;--hold-bg:#FFF3CD;
  --review:#5B21B6;--review-bg:#EDE9FE;--pending-c:#4D4C4D;--pending-bg:#E7E8E3;
  --p1:#B91C1C;--p2:#A2A2B7;--p3:#5C5D81;--p4:#16164D;--p5:#C3C6B9;
  --sb-bg:#16164D;--sb-hover:#2a2a50;--sb-active:#5C5D81;
  --sb-text:rgba(255,255,255,.65);--sb-text-a:#fff;
  --topbar:48px;--sb-w:220px;--r:4px;
  --shadow:0 1px 3px rgba(0,0,0,.08);--shadow-lg:0 8px 24px rgba(0,0,0,.15);
  --tr:.15s ease;
  --warn-bg:#FFF8E1;
  --ag-ho:#D1E7FF;--ag-fr:#DFF3DB;--ag-lm:#FDE8E8;--ag-ext:#FFF3CD;--ag-fg:#EDE9FE;--ag-vg:#CCFBF1;--ag-tr:#F0F4C3;
}

/* ═══════════════ DARK MODE ═══════════════ */
[data-theme="dark"]{
  --bg:#121222;--card:#1e1e36;--surface:#252540;--border:#35355a;--border-lt:#35355a;
  --accent:#b8b8e0;--accent-h:#9999c2;--accent-bg:#2a2a50;
  --t1:#e0e0e0;--t2:#bbb;--t3:#888;
  --done:#4cb83a;--done-bg:#1a3d14;--wip:#b8b8e0;--wip-bg:#2a2a50;
  --rip:#ef5350;--rip-bg:#3d1818;--hold:#ffd54f;--hold-bg:#3d3518;
  --review:#c4b5fd;--review-bg:#1e1535;--pending-c:#888;--pending-bg:#252540;
  --p1:#ef5350;--p2:#9999c2;--p3:#6e6e9a;--p4:#b8b8e0;--p5:#45456a;
  --sb-bg:#0e0e1e;--sb-hover:#1a1a30;--sb-active:#2a2a50;
  --shadow:0 1px 3px rgba(0,0,0,.3);--shadow-lg:0 8px 24px rgba(0,0,0,.5);
  --warn-bg:#3d3518;
  --ag-ho:#1a3050;--ag-fr:#1a3d14;--ag-lm:#3d1818;--ag-ext:#3d3518;--ag-fg:#1e1535;--ag-vg:#0f2e2a;--ag-tr:#2a2a18;
}
[data-theme="dark"] .logo{color:var(--accent)}
[data-theme="dark"] .nav-item.active{border-left-color:var(--accent)}
[data-theme="dark"] .nav-badge{background:var(--accent);color:#1e1e36}
[data-theme="dark"] .login-screen{background:var(--bg)}
[data-theme="dark"] .login-box{background:var(--card);box-shadow:var(--shadow-lg)}
[data-theme="dark"] .ag-table thead th{background:#1a1a30}
[data-theme="dark"] tbody tr.row-overdue{background:rgba(239,83,80,.18)}
[data-theme="dark"] tbody tr.row-warning{background:rgba(255,213,79,.12)}
[data-theme="dark"] .tag-red{background:rgba(239,83,80,.22);color:#ff6b6b}
[data-theme="dark"] .tag-orange{background:rgba(255,213,79,.18);color:#ffd54f}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--t1);font-size:13px;line-height:1.5;overflow:hidden;height:100vh}
.mono{font-family:'IBM Plex Mono',monospace}

/* ═══════════════ LOGIN ═══════════════ */
.login-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}
.login-box{background:var(--card);padding:40px;border-radius:8px;box-shadow:var(--shadow-lg);width:380px;text-align:center}
.login-logo{font-size:36px;font-weight:700;color:var(--accent);letter-spacing:3px;margin-bottom:4px}
.login-sub{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:3px;margin-bottom:30px}
.login-box .fg{margin-bottom:16px;text-align:left}
.login-box input{padding:10px 14px;font-size:14px}
.login-box .btn{width:100%;padding:12px;font-size:14px;margin-top:6px}
.login-err{color:var(--rip);font-size:12px;margin-top:10px;min-height:18px}
.login-msg{color:var(--accent);font-size:12px;margin-top:10px;min-height:18px}
.login-hint{font-size:11px;color:var(--t3);margin-top:16px}
.login-back{font-size:12px;margin-top:14px;text-align:center}
.login-back a{color:var(--accent);text-decoration:none;cursor:pointer}
.login-back a:hover{text-decoration:underline}
.code-input{font-size:28px!important;letter-spacing:12px;text-align:center;font-weight:700;font-family:monospace}

/* ═══════════════ LAYOUT ═══════════════ */
.app{display:none;height:100vh}
.app.active{display:flex}
.sidebar{width:var(--sb-w);background:var(--sb-bg);display:flex;flex-direction:column;flex-shrink:0}
.sb-head{padding:20px;border-bottom:1px solid rgba(255,255,255,.08)}
.logo{font-size:22px;font-weight:700;color:var(--accent);letter-spacing:2px}
.logo-sub{font-size:10px;color:var(--sb-text);text-transform:uppercase;letter-spacing:3px;margin-top:2px}
.sb-nav{padding:12px 0;flex:1}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--sb-text);cursor:pointer;font-size:13px;font-weight:500;border-left:3px solid transparent;transition:var(--tr);text-decoration:none}
.nav-item:hover{color:var(--sb-text-a);background:var(--sb-hover)}
.nav-item.active{color:var(--sb-text-a);background:var(--sb-active);border-left-color:var(--accent)}
.nav-item.hidden{display:none}
.nav-icon{font-size:16px;width:20px;text-align:center}
.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:8px;min-width:18px;text-align:center}
.sb-user{padding:12px 20px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between}
.sb-user-info{display:flex;flex-direction:column}
.sb-user-name{font-size:12px;color:var(--sb-text-a);font-weight:600}
.sb-user-role{font-size:10px;color:var(--sb-text);text-transform:uppercase;letter-spacing:1px}
.sb-logout{background:none;border:none;color:var(--sb-text);cursor:pointer;font-size:14px;padding:4px 8px;border-radius:var(--r)}
.sb-logout:hover{color:var(--accent);background:rgba(255,255,255,.1)}

.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:var(--topbar);background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0}
.breadcrumb{font-size:14px;font-weight:600;color:var(--t1)}
.topbar-r{display:flex;align-items:center;gap:16px}
.date-presets .chip{padding:2px 8px;font-size:10px;border-radius:3px;min-width:28px;text-align:center}
.search-box input{width:220px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--r);font-size:12px;background:var(--bg);color:var(--t1)}
.search-box input:focus{outline:none;border-color:var(--accent)}
.clock{font-size:12px;color:var(--t3);font-variant-numeric:tabular-nums}
.content{flex:1;overflow-y:auto;padding:20px}
.page{display:none}.page.active{display:block}

/* ═══════════════ BUTTONS & FORMS ═══════════════ */
.btn{padding:7px 14px;border-radius:var(--r);font-size:12px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:var(--tr);display:inline-flex;align-items:center;gap:6px;font-family:inherit}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-h)}
.btn-outline{background:var(--card);color:var(--t2);border-color:var(--border)}.btn-outline:hover{background:var(--surface)}
.btn-success{background:var(--done);color:#fff}.btn-success:hover{background:#24693b}
.btn-danger{background:var(--rip);color:#fff}.btn-danger:hover{background:#6e2d2d}
.btn-sm{padding:4px 10px;font-size:11px}
.btn-icon{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:var(--r);color:var(--t3);transition:var(--tr);font-size:14px}
.btn-icon:hover{color:var(--accent);background:var(--surface)}
.btn-icon.del:hover{color:var(--rip)}

select,input[type=text],input[type=email],input[type=password],input[type=date],input[type=number],textarea{
  padding:7px 10px;border:1px solid var(--border);border-radius:var(--r);font-size:12px;
  color:var(--t1);background:var(--card);transition:var(--tr);font-family:inherit;width:100%}
select:focus,input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(22,22,77,.12)}
textarea{resize:vertical}
label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--t2);margin-bottom:3px}

/* ═══════════════ CARDS & KPI ═══════════════ */
.card{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid var(--border-lt)}
.card-hd{padding:12px 16px;border-bottom:1px solid var(--border-lt);display:flex;justify-content:space-between;align-items:center}
.card-hd h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t2)}
.card-bd{padding:16px}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--card);border-radius:var(--r);padding:16px;box-shadow:var(--shadow);border:1px solid var(--border-lt);border-left:4px solid var(--accent);transition:transform .15s ease,box-shadow .15s ease}
.kpi[style*="cursor"]:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.15)}
.kpi.green{border-left-color:var(--done)}.kpi.red{border-left-color:var(--rip)}
.kpi.blue{border-left-color:var(--wip)}.kpi.orange{border-left-color:var(--hold)}
.kpi.purple{border-left-color:var(--review)}
.kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);margin-bottom:4px;font-weight:600}
.kpi-val{font-size:26px;font-weight:700;color:var(--t1);font-variant-numeric:tabular-nums}
.ov-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.ov-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:14px}

/* ═══════════════ TABLES ═══════════════ */
.page-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.toolbar-left{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.toolbar-right{display:flex;gap:8px;align-items:center}
.chip{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--t2);transition:var(--tr)}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);font-weight:600}
.table-wrap{overflow-x:auto;background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid var(--border-lt)}
table{width:100%;border-collapse:collapse;font-size:12.5px}
thead th{background:var(--surface);padding:8px 12px;text-align:left;font-weight:700;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--t2);border-bottom:2px solid var(--border);white-space:nowrap;cursor:pointer;user-select:none;position:sticky;top:0;z-index:1}
thead th:hover{color:var(--accent)}
thead th .sort-arrow{font-size:10px;margin-left:3px;color:var(--t3);opacity:0;transition:opacity .15s}
thead th:hover .sort-arrow{opacity:.5}
thead th.sort-active{color:var(--accent)}
thead th.sort-active .sort-arrow{opacity:1;color:var(--accent)}
tbody td{padding:6px 12px;border-bottom:1px solid var(--border-lt);white-space:nowrap;height:36px;vertical-align:middle}
tbody tr:hover{background:rgba(22,22,77,.03)}
tbody tr.row-overdue{background:var(--rip-bg)}
tbody tr.row-warning{background:var(--warn-bg)}

.status-badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.st-done{background:var(--done-bg);color:var(--done)}.st-wip{background:var(--wip-bg);color:var(--wip)}
.st-rip{background:var(--rip-bg);color:var(--rip)}.st-on-hold,.st-on_hold,.st-aguardando{background:var(--hold-bg);color:var(--hold)}
.st-review,.st-em-revisao,.st-em-revisão{background:var(--review-bg);color:var(--review)}.st-pending,.st-pendente{background:var(--pending-bg);color:var(--pending-c)}
.st-allocated,.st-alocada{background:var(--done-bg);color:var(--done)}.st-discarded,.st-descartada{background:var(--rip-bg);color:var(--rip)}
.st-aguardando-docs{background:#FFF3E0;color:#E65100}

/* ═══════════════ DETAIL MODAL (wider) ═══════════════ */
.modal-box.modal-wide{width:720px;max-width:95vw}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px;margin-bottom:18px}
.detail-field{font-size:12px}
.detail-field .dl{color:var(--t3);font-size:10px;text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px;font-weight:600}
.detail-field .dv{color:var(--t1);font-weight:500}
.detail-full{grid-column:1/-1}
.status-select-inline{padding:2px 6px;border-radius:3px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border:1px solid var(--border);cursor:pointer;background:var(--card)}
.op-name-link{cursor:pointer;color:var(--accent);text-decoration:none;font-weight:500}
.op-name-link:hover{text-decoration:underline}

/* ═══════════════ COMMENTS & ACTIVITY LOG ═══════════════ */
.comment-thread{max-height:300px;overflow-y:auto;margin-bottom:12px}
.comment-item{padding:8px 12px;border-bottom:1px solid var(--border-lt);font-size:12px}
.comment-item:last-child{border-bottom:none}
.comment-meta{font-size:10px;color:var(--t3);margin-bottom:2px;display:flex;gap:6px;align-items:center}
.comment-meta strong{color:var(--t2);font-size:11px}
.comment-text{color:var(--t1);line-height:1.5}
.comment-form{display:flex;gap:8px;margin-top:8px}
.comment-form textarea{flex:1;resize:none;min-height:36px}
.log-item{padding:8px 0;border-bottom:1px solid var(--border-lt);font-size:12px;display:flex;justify-content:space-between;align-items:center}
.log-item:last-child{border-bottom:none}
.log-action{font-weight:600;color:var(--accent)}
.log-time{font-size:10px;color:var(--t3);white-space:nowrap}
.wl-summary{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.wl-chip{font-size:10px;padding:2px 8px;border-radius:8px;font-weight:600}
.wl-chip.ok{background:var(--done-bg);color:var(--done)}
.wl-chip.warn{background:var(--hold-bg);color:var(--hold)}
.wl-chip.crit{background:var(--rip-bg);color:var(--rip)}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.prod-card{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid var(--border-lt);overflow:hidden}
.prod-card-hd{padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-lt);background:var(--surface)}
.prod-card-hd .user-avatar{width:34px;height:34px;font-size:13px}
.prod-card-bd{padding:12px 16px}
.prod-stat{display:flex;justify-content:space-between;padding:4px 0;font-size:12px;border-bottom:1px solid var(--border-lt)}
.prod-stat:last-child{border-bottom:none}
.prod-stat-label{color:var(--t3)}
.prod-stat-val{font-weight:700}

.pri{font-weight:700;text-align:center;width:28px;display:inline-block;border-radius:3px;padding:1px 0;font-size:12px}
.pri-1{color:#fff;background:var(--p1)}.pri-2{color:#fff;background:var(--p2)}
.pri-3{color:#fff;background:var(--p3)}.pri-4{color:#fff;background:var(--p4)}
.pri-5{color:var(--t2);background:var(--p5)}

.action-cell{display:flex;gap:4px;align-items:center}
.empty-st{padding:32px;text-align:center;color:var(--t3);font-size:13px}
.trunc{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:middle}

/* ═══════════════ DRAWER ═══════════════ */
.drawer-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.35);z-index:900;opacity:0;visibility:hidden;transition:var(--tr)}
.drawer-backdrop.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:-480px;width:480px;height:100vh;background:var(--card);box-shadow:var(--shadow-lg);z-index:910;display:flex;flex-direction:column;transition:right .25s ease}
.drawer.open{right:0}
.drawer-hd{padding:16px 20px;border-bottom:1px solid var(--border-lt);display:flex;justify-content:space-between;align-items:center}
.drawer-hd h2{font-size:15px;font-weight:600}
.drawer-bd{flex:1;overflow-y:auto;padding:20px}
.drawer-ft{padding:14px 20px;border-top:1px solid var(--border-lt);display:flex;justify-content:flex-end;gap:10px}
.fg{margin-bottom:14px}.fg label{display:block;margin-bottom:4px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ═══════════════ MODAL ═══════════════ */
.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:var(--tr)}
.modal-backdrop.open{opacity:1;visibility:visible}
.modal-box{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow-lg);width:480px;max-width:95vw;max-height:85vh;overflow-y:auto;transform:translateY(20px);transition:.2s ease}
.modal-backdrop.open .modal-box{transform:translateY(0)}
.modal-hd{padding:14px 20px;border-bottom:1px solid var(--border-lt);display:flex;justify-content:space-between;align-items:center}
.modal-hd h2{font-size:14px;font-weight:600}
.modal-bd{padding:20px}
.modal-ft{padding:12px 20px;border-top:1px solid var(--border-lt);display:flex;justify-content:flex-end;gap:10px}
.close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:var(--t3);padding:2px 6px;border-radius:var(--r)}
.close-btn:hover{color:var(--t1);background:var(--surface)}

/* ═══════════════ AGENDA ═══════════════ */
.ag-controls{display:flex;gap:10px;align-items:center;margin-bottom:14px}
.ag-table{border-collapse:collapse;font-size:11.5px;width:100%}
.ag-table th,.ag-table td{padding:4px 6px;border:1px solid var(--border-lt);text-align:center;min-width:38px;white-space:nowrap}
.ag-table thead th{background:var(--sb-bg);color:#fff;font-size:9.5px;font-weight:600;text-transform:uppercase;position:sticky;top:0;z-index:1}
.ag-table thead th.wkend{background:#354960}
.ag-table .an-col{position:sticky;left:0;background:var(--card);font-weight:600;text-align:left;min-width:120px;z-index:2;border-right:2px solid var(--border);font-size:12px}
.ag-table thead .an-col{background:var(--sb-bg);z-index:3}
.ag-cell{cursor:pointer;transition:var(--tr);height:30px;font-weight:600;font-size:10.5px}
.ag-cell:hover{background:var(--surface)}
.ag-cell.wkend{background:#F0F0EA;cursor:default}
.ag-cell.today{outline:2px solid var(--accent);outline-offset:-2px}
.ag-cell[data-st="HO"]{background:var(--ag-ho);color:#1565c0}
.ag-cell[data-st="WORK"]{background:var(--surface);color:var(--t2)}
.ag-cell[data-st="FR"]{background:var(--ag-fr);color:#2e7d32}
.ag-cell[data-st="LM"]{background:var(--ag-lm);color:#c62828}
.ag-cell[data-st="EXT"]{background:var(--ag-ext);color:#e65100}
.ag-cell[data-st="FG"]{background:var(--ag-fg);color:#6a1b9a}
.ag-cell[data-st="VG"]{background:var(--ag-vg);color:#00695c}
.ag-cell[data-st="TR"]{background:var(--ag-tr);color:#827717}
.ag-legend{display:flex;gap:14px;margin-top:10px;font-size:11px;color:var(--t2);flex-wrap:wrap}
.ag-legend-item{display:flex;align-items:center;gap:5px}
.ag-legend-c{width:16px;height:11px;border-radius:2px}

/* ═══════════════ SETTINGS ═══════════════ */
.set-list{list-style:none}
.set-list li{padding:8px 12px;border-bottom:1px solid var(--border-lt);display:flex;justify-content:space-between;align-items:center;font-size:12px}
.set-list li:last-child{border-bottom:none}
.user-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid var(--border-lt)}
.user-row:last-child{border-bottom:none}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.user-info{flex:1}
.user-name{font-weight:600;font-size:13px}
.user-email{font-size:11px;color:var(--t3)}
.user-role-badge{padding:2px 8px;border-radius:3px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.role-admin{background:#DCDCE4;color:#16164D}
.role-analyst{background:#DFF3DB;color:#1a7a00}
.role-gestor{background:#EDE9FE;color:#5B21B6}

/* ═══════════════ SIDEBAR VIEW-AS DROPDOWN (ADMIN) ═══════════════ */
.sb-view-as{margin-top:12px}
.sb-view-as select{width:100%;padding:6px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:#fff;font-size:11px;font-weight:500;cursor:pointer;appearance:auto;outline:none}
.sb-view-as select option{background:#1e1e36;color:#f0f0f5;padding:6px 8px}
.sb-view-as select:hover{border-color:var(--accent)}
.sb-view-as select:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(0,102,255,.2)}
.user-status{font-size:11px;padding:2px 8px;border-radius:3px}
.st-ativo{background:var(--done-bg);color:var(--done)}
.st-inativo{background:var(--rip-bg);color:var(--rip)}
.set-inline-add{display:flex;gap:8px;margin-top:10px}
.set-inline-add input{flex:1}

/* ═══════════════ ALERTS & LISTS ═══════════════ */
.alert-list{list-style:none}
.alert-list li{padding:7px 0;border-bottom:1px solid var(--border-lt);font-size:12px;display:flex;justify-content:space-between;align-items:center;transition:background .12s ease;border-radius:4px}
.alert-list li[style*="cursor"]:hover{background:var(--bg)}
.alert-list li:last-child{border-bottom:none}
.tag{display:inline-block;padding:2px 8px;border-radius:3px;font-size:10px;font-weight:600;letter-spacing:.3px}
.tag-red{background:var(--rip-bg);color:var(--rip)}.tag-green{background:var(--done-bg);color:var(--done)}
.tag-blue{background:var(--wip-bg);color:var(--wip)}.tag-orange{background:var(--hold-bg);color:var(--hold)}
.workload-item{display:flex;align-items:center;gap:10px;margin-bottom:6px;transition:background .12s ease;border-radius:4px;padding:2px 4px}
.workload-item[style*="cursor"]:hover{background:var(--bg)}
.wl-name{min-width:100px;font-size:12px;color:var(--t2);font-weight:500}
.wl-bar{flex:1;height:16px;background:var(--bg);border-radius:3px;overflow:hidden}
.wl-fill{height:100%;background:var(--accent);border-radius:3px;display:flex;align-items:center;justify-content:flex-end;padding-right:6px;font-size:9.5px;color:#fff;font-weight:700;transition:width .5s ease}

/* ═══════════════ TOASTS ═══════════════ */
.toast-c{position:fixed;top:56px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:6px}
.toast{padding:10px 16px;border-radius:var(--r);font-size:12px;background:var(--card);box-shadow:var(--shadow-lg);border-left:4px solid var(--done);animation:slideIn .3s ease,fadeOut .3s ease 2.5s forwards}
.toast.err{border-left-color:var(--rip)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}}
@keyframes fadeOut{to{opacity:0;transform:translateX(50px)}}

/* ═══════════════ AVALIAÇÃO / PERFORMANCE ═══════════════ */
.av-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:16px}
.av-tab{padding:10px 20px;font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--t3);transition:var(--tr)}
.av-tab:hover{color:var(--t1)}
.av-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.av-panel{display:none}.av-panel.active{display:block}

.av-filters{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.av-filters select,.av-filters input{width:auto;min-width:120px}

.av-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px;margin-bottom:16px}
.av-analyst-card{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid var(--border-lt);overflow:hidden}
.av-analyst-hd{padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-lt);background:var(--surface)}
.av-analyst-hd .user-avatar{width:40px;height:40px;font-size:15px}
.av-analyst-name{font-size:14px;font-weight:700}
.av-analyst-stats{display:flex;gap:6px;margin-left:auto}
.av-mini-stat{font-size:11px;font-weight:700;padding:2px 8px;border-radius:3px}
.av-mini-pos{background:#EBF5EE;color:#2D7D46}
.av-mini-neg{background:#FAE8E8;color:#8B3A3A}
.av-mini-neu{background:#F0F0EA;color:#6B6B5F}
.av-analyst-bd{padding:14px 16px}

.av-dim-bars{margin-bottom:12px}
.av-dim-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:11px}
.av-dim-label{min-width:120px;color:var(--t2);font-weight:500}
.av-dim-bar{flex:1;height:14px;background:#eee;border-radius:3px;overflow:hidden;display:flex}
.av-dim-pos{background:var(--done);height:100%}
.av-dim-neg{background:var(--rip);height:100%}
.av-dim-neu{background:var(--border);height:100%}
.av-dim-count{min-width:24px;text-align:right;font-weight:600;color:var(--t3);font-size:10px}

.av-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--t3);margin:10px 0 6px 0}
.av-strength{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;font-size:10.5px;font-weight:600;margin:2px 3px 2px 0}
.av-strength.pos{background:#EBF5EE;color:#2D7D46}
.av-strength.neg{background:#FAE8E8;color:#8B3A3A}

.av-note-list{list-style:none}
.av-note-item{padding:10px 14px;border-bottom:1px solid var(--border-lt);display:flex;gap:12px;align-items:flex-start}
.av-note-item:last-child{border-bottom:none}
.av-note-item:hover{background:rgba(255,102,0,.02)}
.av-note-sent{width:4px;border-radius:2px;min-height:36px;flex-shrink:0}
.av-note-sent.pos{background:var(--done)}.av-note-sent.neg{background:var(--rip)}.av-note-sent.neu{background:var(--border)}
.av-note-body{flex:1;min-width:0}
.av-note-title{font-weight:600;font-size:13px;margin-bottom:2px}
.av-note-meta{font-size:11px;color:var(--t3);display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.av-note-desc{font-size:12px;color:var(--t2);line-height:1.5;white-space:pre-line}
.av-note-dims{margin-top:4px;display:flex;gap:4px;flex-wrap:wrap}
.av-note-dim{font-size:9.5px;padding:1px 6px;border-radius:8px;background:var(--surface);color:var(--t2);font-weight:500}
.av-note-actions{display:flex;gap:2px;flex-shrink:0}

.av-empty{text-align:center;padding:40px 20px;color:var(--t3)}
.av-empty-icon{font-size:40px;margin-bottom:10px}
.av-empty-text{font-size:14px;margin-bottom:4px}
.av-empty-sub{font-size:12px}

/* multi-select checkboxes */
.chk-grid{display:flex;flex-wrap:wrap;gap:6px}
.chk-item{display:flex;align-items:center;gap:4px;font-size:12px;cursor:pointer;padding:4px 10px;border:1px solid var(--border);border-radius:var(--r);transition:var(--tr)}
.chk-item:hover{border-color:var(--accent)}
.chk-item.checked{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);font-weight:600}
.chk-item input{display:none}

/* ═══════════════ KANBAN BOARD ═══════════════ */
.kanban-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.kanban-container{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;min-height:calc(100vh - 190px)}
.kanban-col{min-width:240px;max-width:260px;flex:1 0 240px;display:flex;flex-direction:column;background:var(--surface);border-radius:var(--r);border:1px solid var(--border-lt)}
.kanban-col-hd{padding:10px 12px;display:flex;justify-content:space-between;align-items:center;border-radius:var(--r) var(--r) 0 0;border-bottom:2px solid}
.kanban-col-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.kanban-col-count{font-size:10px;font-weight:700;padding:1px 7px;border-radius:8px;min-width:18px;text-align:center;color:#fff}
.kanban-col-body{flex:1;padding:8px;overflow-y:auto;min-height:100px;transition:background .15s}
.kanban-col-body.drag-over{background:rgba(255,102,0,.06);outline:2px dashed var(--accent);outline-offset:-4px;border-radius:0 0 var(--r) var(--r)}

.kanban-col[data-col="inbox"] .kanban-col-hd{background:#F0F0EA;border-color:#B0B0A8;color:#6B6B5F}
.kanban-col[data-col="inbox"] .kanban-col-count{background:#6B6B5F}
.kanban-col[data-col="em_andamento"] .kanban-col-hd{background:#E8F0FA;border-color:#1565C0;color:#1565C0}
.kanban-col[data-col="em_andamento"] .kanban-col-count{background:#1565C0}
.kanban-col[data-col="aguardando"] .kanban-col-hd{background:#FFF8D6;border-color:#F9A825;color:#7A6500}
.kanban-col[data-col="aguardando"] .kanban-col-count{background:#F9A825}
.kanban-col[data-col="concluido"] .kanban-col-hd{background:#EBF5EE;border-color:#2D7D46;color:#2D7D46}
.kanban-col[data-col="concluido"] .kanban-col-count{background:#2D7D46}
.kanban-col[data-col="descartado"] .kanban-col-hd{background:#FAE8E8;border-color:#8B3A3A;color:#8B3A3A}
.kanban-col[data-col="descartado"] .kanban-col-count{background:#8B3A3A}
.kanban-col[data-col="comites"] .kanban-col-hd{background:#E3F2FD;border-color:#1565C0;color:#0D47A1}
.kanban-col[data-col="comites"] .kanban-col-count{background:#1565C0}

.kanban-card{background:var(--card);border-radius:var(--r);padding:10px 12px;margin-bottom:8px;box-shadow:var(--shadow);border:1px solid var(--border-lt);cursor:grab;transition:box-shadow .15s,transform .15s}
.kanban-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.kanban-card.dragging{opacity:.5;transform:rotate(2deg)}
.kanban-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:6px;margin-bottom:2px}
.kanban-card-title{font-size:12px;font-weight:600;color:var(--t1);line-height:1.4;flex:1;cursor:pointer}
.kanban-card-title:hover{color:var(--accent)}
.kanban-card-pri{font-size:9px;font-weight:800;padding:1px 5px;border-radius:2px;flex-shrink:0}
.kanban-card-pri.p1{background:var(--p1);color:#fff}
.kanban-card-pri.p2{background:var(--p2);color:#fff}
.kanban-card-pri.p3{background:var(--p3);color:var(--t1)}
.kanban-card-pri.p4{background:var(--p4);color:#fff}
.kanban-card-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-top:4px}
.kanban-card-deadline{font-size:10px;color:var(--t3);display:flex;align-items:center;gap:3px}
.kanban-card-deadline.overdue{color:var(--rip);font-weight:600}
.kanban-card-labels{display:flex;gap:3px;flex-wrap:wrap}
.kanban-card-label{font-size:9px;padding:1px 6px;border-radius:8px;background:var(--accent-bg);color:var(--accent);font-weight:600}
.kanban-card-checklist{font-size:10px;color:var(--t3);display:flex;align-items:center;gap:4px}
.kanban-card-checklist-bar{width:40px;height:4px;background:var(--border);border-radius:2px;overflow:hidden;display:inline-block}
.kanban-card-checklist-fill{height:100%;background:var(--done);border-radius:2px;display:block}
.kanban-card-link{font-size:9px;color:var(--wip);font-weight:600}
.kanban-empty{text-align:center;padding:24px 8px;color:var(--t3);font-size:11px}

/* ═══════════════ NOTIFICATION BELL ═══════════════ */
.bell-wrap{position:relative;cursor:pointer}
.bell-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:var(--r);color:var(--t2);transition:var(--tr);position:relative}
.bell-btn:hover{color:var(--accent);background:var(--surface)}
.bell-badge{position:absolute;top:0;right:2px;background:var(--rip);color:#fff;font-size:9px;font-weight:700;padding:0 5px;border-radius:8px;min-width:16px;text-align:center;line-height:16px;display:none}
.bell-badge.show{display:block}
.bell-dropdown{position:absolute;top:100%;right:0;width:380px;max-height:420px;overflow-y:auto;background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:999;display:none}
.bell-dropdown.open{display:block}
.bell-dd-hd{padding:10px 14px;border-bottom:1px solid var(--border-lt);display:flex;justify-content:space-between;align-items:center}
.bell-dd-hd h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--t2)}
.bell-dd-item{padding:10px 14px;border-bottom:1px solid var(--border-lt);cursor:pointer;transition:var(--tr);display:flex;gap:10px;align-items:flex-start}
.bell-dd-item:hover{background:var(--surface)}
.bell-dd-item.unread{background:var(--accent-bg)}
.bell-dd-item .n-icon{font-size:16px;flex-shrink:0;margin-top:2px}
.bell-dd-item .n-body{flex:1;min-width:0}
.bell-dd-item .n-title{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bell-dd-item .n-msg{font-size:11px;color:var(--t2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bell-dd-item .n-time{font-size:10px;color:var(--t3);margin-top:2px}
.bell-dd-empty{text-align:center;padding:24px;color:var(--t3);font-size:12px}
.bell-dd-footer{padding:8px 14px;border-top:1px solid var(--border-lt);text-align:center}
.bell-dd-footer a{color:var(--accent);font-size:12px;font-weight:600;text-decoration:none}
.bell-dd-footer a:hover{text-decoration:underline}

/* ═══════════════ MESSAGES PAGE ═══════════════ */
.msg-thread-list{display:flex;flex-direction:column;gap:0}
.msg-thread{background:var(--card);border:1px solid var(--border-lt);border-radius:var(--r);margin-bottom:8px;overflow:hidden;transition:var(--tr)}
.msg-thread:hover{box-shadow:var(--shadow)}
.msg-thread-hd{padding:12px 16px;display:flex;gap:12px;align-items:center;cursor:pointer;transition:var(--tr)}
.msg-thread-hd:hover{background:var(--surface)}
.msg-thread.has-unread .msg-thread-hd{border-left:3px solid var(--accent)}
.msg-thread-icon{font-size:20px;flex-shrink:0}
.msg-thread-info{flex:1;min-width:0}
.msg-thread-name{font-size:13px;font-weight:700;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msg-thread-preview{font-size:11px;color:var(--t2);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msg-thread-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.msg-thread-time{font-size:10px;color:var(--t3)}
.msg-thread-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:8px;min-width:18px;text-align:center}
.msg-thread-body{display:none;border-top:1px solid var(--border-lt);padding:14px 16px;background:var(--bg)}
.msg-thread.expanded .msg-thread-body{display:block}
.msg-notif-item{padding:8px 12px;border-bottom:1px solid var(--border-lt);background:var(--card);border-radius:var(--r);margin-bottom:6px;font-size:12px;display:flex;gap:10px;align-items:flex-start}
.msg-notif-item.unread{border-left:3px solid var(--accent)}
.msg-notif-item .n-sender{font-weight:600;color:var(--t1)}
.msg-notif-item .n-text{color:var(--t2);line-height:1.5;flex:1}
.msg-notif-item .n-ts{font-size:10px;color:var(--t3);white-space:nowrap;flex-shrink:0}
.msg-reply-form{display:flex;gap:8px;margin-top:10px}
.msg-reply-form textarea{flex:1;min-height:40px;resize:none}
.msg-type-icon{font-size:14px;flex-shrink:0;margin-top:2px}

/* Board card notification badge */
.kanban-card-notif{font-size:10px;color:var(--accent);font-weight:700;display:flex;align-items:center;gap:3px}

/* ═══════════════ RESPONSIVE ═══════════════ */

/* Hamburger button — hidden on desktop */
.sb-toggle{display:none;background:none;border:none;font-size:22px;cursor:pointer;padding:4px 8px;color:var(--t1);border-radius:var(--r)}
.sb-toggle:hover{background:var(--surface)}

/* Overlay for mobile sidebar */
.sb-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:800}
.sb-overlay.open{display:block}

/* ── Tablet (≤1100px) ── */
@media(max-width:1100px){
  .ov-grid,.ov-grid-3{grid-template-columns:1fr}
  .fg-row{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .av-card-grid{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .detail-grid{grid-template-columns:1fr}
  .search-box input{width:160px}
}

/* ── Mobile (≤768px) ── */
@media(max-width:768px){
  :root{--sb-w:260px;--topbar:44px}

  /* Sidebar: off-canvas */
  .sidebar{position:fixed;left:-280px;top:0;bottom:0;width:var(--sb-w);z-index:850;transition:left .25s ease;box-shadow:none}
  .sidebar.open{left:0;box-shadow:var(--shadow-lg)}
  .sb-toggle{display:block}
  .sb-overlay.open{display:block}

  /* Main area takes full width */
  .main{margin-left:0}
  .content{padding:12px}

  /* Topbar: compact layout */
  .topbar{padding:0 10px;gap:6px;flex-wrap:nowrap;overflow-x:auto}
  .breadcrumb{font-size:13px;white-space:nowrap}
  .topbar-r{gap:6px}
  .date-filter{display:none!important}
  .search-box{display:none}
  .clock{display:none}

  /* Tables: horizontal scroll */
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:700px}
  tbody td{padding:5px 8px;font-size:11.5px}

  /* KPI grid */
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .kpi{padding:10px}
  .kpi-val{font-size:20px}
  .kpi-label{font-size:9px}

  /* Cards */
  .ov-grid,.ov-grid-3{grid-template-columns:1fr;gap:10px}

  /* Drawer: full width */
  .drawer{width:100vw;right:-100vw}
  .drawer.open{right:0}

  /* Modal: full width */
  .modal-box{width:95vw;max-height:90vh}
  .modal-box.modal-wide{width:95vw}

  /* Kanban: narrower columns */
  .kanban-container{min-height:auto;padding-bottom:80px}
  .kanban-col{min-width:200px;max-width:220px;flex:0 0 200px}

  /* Bell dropdown */
  .bell-dropdown{width:300px;right:-40px}

  /* Agenda: freeze first column, scroll rest */
  .ag-table{font-size:10.5px}
  .ag-table th,.ag-table td{padding:3px 4px;min-width:32px}
  .ag-table .an-col{min-width:90px;font-size:11px}

  /* Page toolbar: stack */
  .page-toolbar{flex-direction:column;align-items:stretch;gap:6px}
  .toolbar-left,.toolbar-right{flex-wrap:wrap}

  /* Suggestions */
  .av-card-grid{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:1fr}

  /* Messages */
  .msg-reply-form{flex-direction:column}
  .msg-thread-name{font-size:12px}
}

/* ── Small phone (≤480px) ── */
@media(max-width:480px){
  :root{--topbar:40px}
  .content{padding:8px}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:6px}
  .kpi{padding:8px}
  .kpi-val{font-size:18px}
  .kanban-col{min-width:180px;max-width:200px;flex:0 0 180px}
  .bell-dropdown{width:calc(100vw - 20px);right:-60px}
  .login-box{width:90vw;padding:24px}
  .login-logo{font-size:28px}
  .code-input{font-size:22px!important;letter-spacing:8px}
  .chip{padding:3px 8px;font-size:10px}
  .av-tabs{overflow-x:auto}
  .av-tab{padding:8px 12px;font-size:12px;white-space:nowrap}
  .ag-controls{flex-wrap:wrap}
}
