/* ===========================================================================
   SIA — Command Center · tema dark premium
   =========================================================================== */
:root{
  --bg:#0a0e16; --bg2:#0d1320; --panel:#121a28; --panel2:#172132; --panel3:#1d2940;
  --bd:#243149; --bd2:#2e3d59; --tx:#e6edf6; --mut:#8a98ad; --mut2:#5f6d82;
  --acc:#38bdf8; --acc2:#0ea5e9; --brand:#3ee0c8;
  --green:#22c55e; --blue:#3b82f6; --yellow:#f59e0b; --red:#ef4444; --gray:#5b6677;
  --green-bg:rgba(34,197,94,.16); --blue-bg:rgba(59,130,246,.16);
  --yellow-bg:rgba(245,158,11,.16); --red-bg:rgba(239,68,68,.16); --gray-bg:rgba(91,102,119,.16);
  --radius:12px; --shadow:0 8px 28px rgba(0,0,0,.45);
  --sidebar-w:212px;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Inter,sans-serif;
  background:radial-gradient(1200px 700px at 70% -10%,#13203a 0%,var(--bg) 55%);
  color:var(--tx); font-size:13.5px; -webkit-font-smoothing:antialiased;
}
a{color:var(--acc);text-decoration:none}
button{font-family:inherit;cursor:pointer}
.hidden{display:none !important}
.logo-mark{color:var(--brand);font-weight:900;letter-spacing:-2px}

/* ===== Login ===== */
.login-body{display:grid;place-items:center}
.login-card{background:var(--panel);border:1px solid var(--bd);border-radius:16px;
  padding:34px 30px;width:330px;box-shadow:var(--shadow)}
.login-logo{font-size:30px;font-weight:800;letter-spacing:4px;text-align:center}
.login-sub{color:var(--mut);text-align:center;margin:6px 0 20px;font-size:12px;letter-spacing:1px}
.login-card label{display:block;color:var(--mut);font-size:12px;margin:12px 0 5px}
.login-card input{width:100%;padding:11px 12px;background:var(--bg2);border:1px solid var(--bd2);
  border-radius:9px;color:var(--tx);font-size:14px;outline:none}
.login-card input:focus{border-color:var(--acc)}
.login-card button{width:100%;margin-top:20px;padding:12px;background:var(--acc2);border:0;
  border-radius:9px;color:#03121d;font-weight:700;font-size:14px}
.login-card button:hover{background:var(--acc)}
.login-error{background:var(--red-bg);border:1px solid var(--red);color:#fecaca;
  padding:9px 11px;border-radius:8px;font-size:12.5px;margin-bottom:8px}
.login-foot{color:var(--mut2);text-align:center;font-size:11px;margin-top:18px}

/* ===== Shell ===== */
#shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh;overflow:hidden}
#sidebar{background:linear-gradient(180deg,var(--bg2),var(--bg));border-right:1px solid var(--bd);
  display:flex;flex-direction:column;padding:14px 10px}
.brand{display:flex;align-items:center;gap:9px;font-size:24px;font-weight:800;letter-spacing:3px;
  padding:6px 8px 14px}
.brand-name{background:linear-gradient(90deg,#fff,#9fe9dc);-webkit-background-clip:text;
  background-clip:text;color:transparent}
#nav{display:flex;flex-direction:column;gap:2px;flex:1}
#nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;color:var(--mut);
  font-weight:600;font-size:13px;position:relative}
#nav a i{font-style:normal;width:18px;text-align:center;font-size:15px;opacity:.9}
#nav a:hover{background:var(--panel);color:var(--tx)}
#nav a.active{background:var(--panel3);color:#fff}
#nav a.active::before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:3px;
  background:var(--brand);border-radius:3px}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10.5px;font-weight:700;
  min-width:18px;height:18px;border-radius:9px;display:none;align-items:center;justify-content:center;padding:0 5px}
.nav-badge.on{display:flex}
.side-foot{border-top:1px solid var(--bd);padding-top:11px;margin-top:8px}
.side-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tx);font-weight:600}
.side-user{color:var(--mut);font-size:11.5px;margin-top:6px}

#main{display:grid;grid-template-rows:auto 1fr auto;min-width:0;overflow:hidden}

/* ===== Top cards ===== */
#topbar{padding:12px 16px 4px}
.cards{display:grid;grid-template-columns:repeat(9,1fr);gap:10px}
.card{background:var(--panel);border:1px solid var(--bd);border-radius:var(--radius);padding:11px 13px;
  position:relative;overflow:hidden;min-width:0}
.card .c-lbl{color:var(--mut);font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .c-val{font-size:23px;font-weight:800;margin-top:3px;line-height:1.1}
.card .c-sub{color:var(--mut2);font-size:11px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card.accent .c-val{color:var(--brand)}
.card.warn{border-color:rgba(245,158,11,.4)} .card.warn .c-val{color:var(--yellow)}
.card.danger{border-color:rgba(239,68,68,.4)} .card.danger .c-val{color:var(--red)}
.card .spark{position:absolute;right:8px;bottom:6px;opacity:.5}
@media(max-width:1500px){.cards{grid-template-columns:repeat(4,1fr)}}
/* Comercial — linhas compactas de métricas por período (Hoje / 7 dias) */
.per-block{margin-bottom:12px} .per-block:last-child{margin-bottom:0}
.per-h{color:var(--mut);font-size:11px;text-transform:uppercase;letter-spacing:.6px;font-weight:700;margin:0 0 6px}
.cards.cards-sm{grid-template-columns:repeat(7,1fr);gap:8px}
.cards.cards-sm .card{padding:8px 10px}
.cards.cards-sm .card .c-val{font-size:17px}
@media(max-width:1500px){.cards.cards-sm{grid-template-columns:repeat(4,1fr)}}
@media(max-width:760px){.cards.cards-sm{grid-template-columns:repeat(2,1fr)}}
/* Indicadores — gauges (anel conic) + painéis Grafana embutidos */
.gauges{display:flex;gap:22px;flex-wrap:wrap}
.gauge-wrap{text-align:center}
.gauge{width:108px;height:108px;border-radius:50%;background:conic-gradient(var(--gc) var(--deg),var(--bd) 0);display:flex;align-items:center;justify-content:center}
.gauge-c{width:80px;height:80px;border-radius:50%;background:var(--panel);display:flex;align-items:center;justify-content:center}
.gauge-v{font-size:25px;font-weight:800;line-height:1}.gauge-v small{font-size:11px;font-weight:600;opacity:.7;margin-left:1px}
.gauge-l{margin-top:8px;color:var(--mut);font-size:12px;text-transform:uppercase;letter-spacing:.6px;font-weight:700}
.gpanels{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px}
.gpanel{background:var(--panel);border:1px solid var(--bd);border-radius:var(--radius);padding:9px}
.gp-t{color:var(--mut);font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:700;margin-bottom:7px}
.gpanel img{width:100%;height:auto;border-radius:4px;display:block;background:#fff}
.gp-img{min-height:130px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.02);border-radius:4px}
.gp-spin{color:var(--mut2);font-size:12px;letter-spacing:.4px}
.gp-spin::before{content:'';display:inline-block;width:11px;height:11px;margin-right:7px;vertical-align:-1px;border:2px solid var(--bd);border-top-color:var(--brand);border-radius:50%;animation:gpspin .8s linear infinite}
@keyframes gpspin{to{transform:rotate(360deg)}}
.gp-err{color:var(--mut2);padding:24px;text-align:center;font-size:12px}
/* Books — geração sob demanda */
.book-gen-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}
.book-gen-row select{background:var(--panel2,var(--panel));color:var(--fg,inherit);border:1px solid var(--bd);border-radius:6px;padding:6px 9px;font:inherit}
@media(max-width:760px){.gauges{justify-content:space-around;gap:10px}.gauge{width:88px;height:88px}.gauge-c{width:64px;height:64px}.gauge-v{font-size:20px}}
/* Clientes — visão consolidada (cartão por cliente, com drill-down) */
.cli-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:1100px){.cli-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.cli-grid{grid-template-columns:1fr}}
.cli-card{background:var(--panel);border:1px solid var(--bd);border-radius:var(--radius);min-width:0}
.cli-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 13px;cursor:pointer}
.cli-head b{font-size:15px}
.cli-head-l{min-width:0}
.cli-counts{color:var(--mut);font-size:12px;margin-top:4px}
.cli-counts span{font-weight:800;font-size:14px}
.cli-sla-none{text-align:center;font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.4px;line-height:1.5;flex-shrink:0}
.gauge.sm{width:62px;height:62px;flex-shrink:0}.gauge.sm .gauge-c{width:46px;height:46px}
.gauge.sm .gauge-v{font-size:14px}.gauge.sm .gauge-v small{font-size:8px}
.cli-row{display:flex;justify-content:space-between;gap:10px;padding:10px 13px;flex-wrap:wrap;align-items:center}
.cli-n{font-size:20px;font-weight:800}
.cli-drill{padding:2px 13px 12px;border-top:1px solid var(--bd);overflow-x:auto}
.cli-sec{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;font-weight:700;margin:10px 0 4px}
/* Notificações proativas — sino no topo-direito + dropdown */
#bell-wrap{position:fixed;top:12px;right:16px;z-index:300}
#bell{background:var(--panel2);border:1px solid var(--bd2);color:var(--tx);width:38px;height:38px;border-radius:10px;font-size:17px;cursor:pointer;position:relative;line-height:1}
#bell:hover{border-color:var(--blue)}
#bell-count{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;font-size:10px;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:none;align-items:center;justify-content:center;padding:0 4px}
#bell-count.on{display:flex}
#bell-menu{position:absolute;top:46px;right:0;width:330px;background:var(--panel);border:1px solid var(--bd2);border-radius:10px;box-shadow:0 10px 34px rgba(0,0,0,.55);overflow:hidden}
#bell-menu.hidden{display:none}
.bn-head{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--bd);font-weight:700;font-size:13px}
.bn-list{max-height:360px;overflow-y:auto}
.bn-item{display:flex;gap:9px;padding:9px 12px;border-bottom:1px solid var(--bd);cursor:pointer}
.bn-item:hover{background:var(--panel2)}
.bn-ic{font-size:14px;flex-shrink:0;margin-top:1px}
.bn-t{font-size:12.5px;font-weight:600;line-height:1.25}
.bn-s{font-size:11px;color:var(--mut)}
.bn-time{font-size:10px;color:var(--mut2);margin-top:1px}
.bn-foot{display:flex;gap:16px;padding:9px 12px;border-top:1px solid var(--bd);font-size:11.5px;color:var(--mut)}
.bn-foot label{display:flex;align-items:center;gap:5px;cursor:pointer}
/* Drawer do agente — banner de atenção + botão reprocessar */
.dr-help{background:var(--red-bg);border:1px solid var(--red);color:#fecaca;border-radius:8px;padding:8px 10px;font-size:12px;margin-top:10px}
.dr-retry{border-color:var(--red)!important;color:#fecaca!important}
.dr-retry:hover{background:var(--red-bg)!important}

/* ===== Content / pages ===== */
#content{position:relative;overflow:hidden;min-height:0}
.page{position:absolute;inset:0;display:none;overflow:auto}
.page.active{display:block}
#page-escritorio.active{display:grid;grid-template-columns:1fr 340px;gap:12px;padding:8px 16px 12px;overflow:hidden}
.page-pad{padding:14px 18px 40px}
.page-pad h2,.office-head h2{margin:2px 0 14px;font-size:18px;font-weight:700}

/* ===== Office ===== */
.office-col{display:flex;flex-direction:column;min-width:0;min-height:0}
.office-head{display:flex;align-items:center;gap:14px;justify-content:space-between;flex-wrap:wrap}
.edit-toolbar{display:flex;gap:6px;flex-wrap:wrap}
.edit-toolbar button{background:var(--panel);border:1px solid var(--bd);color:var(--mut);
  padding:6px 11px;border-radius:8px;font-size:12px;font-weight:600}
.edit-toolbar button:hover{color:var(--tx);border-color:var(--bd2)}
.edit-toolbar button.active{background:var(--panel3);color:#fff;border-color:var(--bd2)}
.btn-primary{background:var(--acc2) !important;color:#03121d !important;border-color:var(--acc2) !important}
#office-stage{position:relative;flex:1;margin-top:10px;background:#070b12;border:1px solid var(--bd);
  border-radius:var(--radius);overflow:hidden;display:grid;place-items:center;min-height:0}
#office{image-rendering:pixelated;display:block;max-width:100%;max-height:100%}
/* Escritório = iframe do Pixel Agents (preenche a célula 1fr do grid) */
#office-frame{width:100%;height:100%;border:0;border-radius:10px;background:#0b1020;display:block;min-width:0;min-height:0}
/* Comercial (CRM da Aline) */
.com-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:1100px){.com-grid{grid-template-columns:1fr}}
.fn-row{display:flex;align-items:center;gap:10px;margin:7px 0}
.fn-lbl{flex:none;width:120px;font-size:12.5px;color:var(--mut)}
.fn-bar{position:relative;flex:1;height:22px;background:var(--panel2);border:1px solid var(--bd);border-radius:6px;overflow:hidden}
.fn-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--brand),#2563eb);opacity:.55}
.fn-n{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:12px;font-weight:700;color:#eaf2ff}
.com-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.com-filters input{flex:1;min-width:220px}
.com-filters input,.com-filters select{background:var(--panel2);border:1px solid var(--bd2);border-radius:8px;color:var(--tx);padding:8px 10px;font-size:13px}
.com-pager{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:12px;font-size:13px;color:var(--mut)}
.com-pager button{background:var(--panel2);border:1px solid var(--bd2);border-radius:8px;color:var(--tx);padding:6px 12px;cursor:pointer}
.com-pager button:disabled{opacity:.4;cursor:default}

/* ===== Mobile / responsivo ===== */
#nav-toggle{display:none;background:var(--panel2);border:1px solid var(--bd2);color:var(--tx);border-radius:9px;width:42px;height:38px;font-size:19px;line-height:1;flex:none}
#nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:40}
@media(max-width:760px){
  body{font-size:13px}
  #shell{grid-template-columns:1fr;height:auto;min-height:100dvh;overflow:visible}
  #sidebar{position:fixed;left:0;top:0;bottom:0;width:248px;z-index:50;transform:translateX(-100%);
    transition:transform .22s ease;box-shadow:0 0 44px rgba(0,0,0,.65)}
  body.nav-open #sidebar{transform:translateX(0)}
  body.nav-open #nav-backdrop{display:block}
  #nav-toggle{display:flex;align-items:center;justify-content:center}
  #main{overflow:visible;grid-template-rows:auto auto auto;min-width:0}
  #topbar{display:flex;align-items:center;gap:10px;padding:10px 12px 4px}
  #topbar #cards{flex:1;min-width:0}
  .cards{grid-template-columns:repeat(2,1fr);gap:8px}
  .card .c-val{font-size:19px}
  #content{overflow:visible;min-width:0}
  .page{position:static;inset:auto;overflow:visible;min-width:0}
  .page-pad>*{max-width:100%}
  .page-pad{padding:12px;overflow-x:auto}
  #page-escritorio.active{display:block;padding:8px 10px 14px;overflow:visible}
  #office-frame{height:60vh;min-height:340px;margin-bottom:12px}
  #rightpanels{display:flex;flex-direction:column;gap:10px}
  .panel-b{overflow-x:auto}
  .tbl{min-width:560px}
  #drawer{width:100%!important;max-width:100%}
  .com-filters input{min-width:140px}
  .login-card{width:92vw;max-width:360px}
}
#labels{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.agent-label{position:absolute;transform:translate(-50%,0);display:flex;flex-direction:column;
  align-items:center;gap:2px;will-change:transform;white-space:nowrap}
.agent-name{background:rgba(8,12,20,.82);border:1px solid var(--bd2);border-radius:7px;
  padding:1px 7px;font-size:10.5px;font-weight:700;line-height:1.5;color:#fff}
.agent-chip{display:inline-flex;align-items:center;gap:5px;border-radius:7px;padding:1px 7px;
  font-size:10px;font-weight:700;line-height:1.6;white-space:nowrap;width:max-content;max-width:none}
.agent-bubble{position:absolute;transform:translate(-50%,-100%);background:#fff;color:#0a0e16;
  font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:9px;max-width:160px;
  white-space:normal;text-align:center;line-height:1.25;box-shadow:0 4px 10px rgba(0,0,0,.4);will-change:transform}
.agent-bubble::after{content:"";position:absolute;left:50%;bottom:-5px;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:#fff}
.edit-palette{position:absolute;top:10px;left:10px;background:rgba(10,14,22,.94);border:1px solid var(--bd2);
  border-radius:10px;padding:8px;display:flex;flex-wrap:wrap;gap:6px;max-width:230px;z-index:5}
.edit-palette button{background:var(--panel2);border:1px solid var(--bd);color:var(--tx);
  border-radius:7px;padding:6px 9px;font-size:11px}
.edit-palette button.sel{outline:2px solid var(--acc)}
.edit-hint{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(10,14,22,.92);
  border:1px solid var(--bd2);border-radius:8px;padding:6px 12px;font-size:11.5px;color:var(--mut);z-index:5}

/* status colors (halo/chip) */
.st-success,.st-available{--sc:var(--green);--scb:var(--green-bg)}
.st-running{--sc:var(--blue);--scb:var(--blue-bg)}
.st-waiting{--sc:var(--yellow);--scb:var(--yellow-bg)}
.st-error{--sc:var(--red);--scb:var(--red-bg)}
.st-offline{--sc:var(--gray);--scb:var(--gray-bg)}
.agent-chip{background:var(--scb);color:var(--sc);border:1px solid var(--sc)}
.agent-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--sc)}

/* ===== Right panels ===== */
#rightpanels{display:flex;flex-direction:column;gap:10px;min-height:0;overflow:hidden}
.panel{background:var(--panel);border:1px solid var(--bd);border-radius:var(--radius);
  display:flex;flex-direction:column;min-height:0}
.panel-grow{flex:1}
.panel-h{padding:9px 13px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  color:var(--mut);border-bottom:1px solid var(--bd)}
.panel-b{padding:8px 10px;overflow:auto;min-height:0}
.empty{color:var(--mut2);font-size:12px;text-align:center;padding:18px 6px;font-style:italic}

.fa-row{display:flex;align-items:center;gap:9px;padding:7px 6px;border-bottom:1px solid var(--bd2)}
.fa-row:last-child{border:0}
.fa-av{width:26px;height:26px;border-radius:7px;background:var(--panel3);display:grid;place-items:center;
  font-size:13px;flex:none}
.fa-info{min-width:0;flex:1}
.fa-name{font-weight:700;font-size:12.5px}
.fa-flow{color:var(--mut);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fa-meta{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex:none}
.fa-time{color:var(--mut2);font-size:10px;white-space:nowrap}

.counters{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.counter{background:var(--panel2);border:1px solid var(--bd);border-radius:10px;padding:10px;
  display:flex;align-items:center;gap:10px}
.counter .cval{font-size:22px;font-weight:800;line-height:1}
.counter .clbl{font-size:11px;color:var(--mut);font-weight:600}
.counter .cbar{width:6px;align-self:stretch;border-radius:3px}

.err-row{padding:7px 6px;border-bottom:1px solid var(--bd2)}
.err-row:last-child{border:0}
.err-top{display:flex;justify-content:space-between;gap:8px}
.err-name{font-weight:700;font-size:12.5px;color:var(--red)}
.err-wf{color:var(--mut);font-size:11px;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.err-msg{color:var(--mut);font-size:11px;margin-top:3px;max-height:30px;overflow:hidden}
.err-row .lnk{font-size:11px}

.tl-row{display:flex;gap:9px;padding:6px 4px;border-bottom:1px solid var(--bd2)}
.tl-row:last-child{border:0}
.tl-ic{width:9px;height:9px;border-radius:50%;margin-top:4px;flex:none}
.tl-txt{min-width:0;flex:1;font-size:12px}
.tl-sub{color:var(--mut2);font-size:10.5px;margin-top:1px}

/* ===== Systems bar ===== */
#systembar{border-top:1px solid var(--bd);padding:8px 16px;background:var(--bg2)}
.systems{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.sys{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--bd);
  border-radius:9px;padding:6px 11px;font-size:12px}
.sys .dot{width:9px;height:9px;border-radius:50%}
.sys b{font-weight:700}
.sys .ss{color:var(--mut);font-size:11px}
.dot-green{background:var(--green);box-shadow:0 0 7px var(--green)}
.dot-yellow{background:var(--yellow);box-shadow:0 0 7px var(--yellow)}
.dot-red{background:var(--red)}
.dot-gray{background:var(--gray)}

/* ===== Tables / generic ===== */
.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl th{text-align:left;color:var(--mut);font-weight:600;font-size:11px;text-transform:uppercase;
  letter-spacing:.4px;padding:8px 10px;border-bottom:1px solid var(--bd)}
.tbl td{padding:8px 10px;border-bottom:1px solid var(--bd2);vertical-align:top}
.tbl tr:hover td{background:var(--panel)}
.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:20px;font-size:11px;
  font-weight:700;width:max-content}
.badge .dot{width:7px;height:7px;border-radius:50%}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.filters select,.filters input{background:var(--bg2);border:1px solid var(--bd2);color:var(--tx);
  padding:7px 10px;border-radius:8px;font-size:12.5px;outline:none}
.notice{background:var(--panel);border:1px dashed var(--bd2);border-radius:10px;padding:16px;
  color:var(--mut);font-size:13px}
.notice b{color:var(--tx)}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.gc{background:var(--panel);border:1px solid var(--bd);border-radius:12px;padding:14px}
.gc h3{margin:0 0 4px;font-size:14px}
.gc .muted{color:var(--mut);font-size:12px}
.sec-title{font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;
  margin:18px 0 8px;font-weight:700}
.btn{background:var(--panel2);border:1px solid var(--bd2);color:var(--tx);padding:6px 12px;
  border-radius:8px;font-size:12px;font-weight:600}
.btn:hover{border-color:var(--acc)}
.btn-sm{padding:3px 9px;font-size:11px}

/* ===== Drawer ===== */
#drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:40}
#drawer{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:92vw;background:var(--bg2);
  border-left:1px solid var(--bd);z-index:41;box-shadow:-12px 0 40px rgba(0,0,0,.5);
  display:flex;flex-direction:column;animation:slidein .18s ease}
@keyframes slidein{from{transform:translateX(30px);opacity:.4}to{transform:none;opacity:1}}
.dr-head{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--bd)}
.dr-av{width:46px;height:46px;border-radius:11px;background:var(--panel3);display:grid;place-items:center;font-size:22px}
.dr-h-info{flex:1;min-width:0}
.dr-name{font-size:17px;font-weight:800}
.dr-frente{color:var(--mut);font-size:12px}
.dr-close{background:none;border:0;color:var(--mut);font-size:22px;line-height:1}
.dr-body{padding:16px;overflow:auto;flex:1}
.dr-kv{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid var(--bd2);font-size:13px}
.dr-kv .k{color:var(--mut)}
.dr-kv .v{font-weight:600;text-align:right;max-width:62%}
.dr-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:12px 0}
.dr-stat{background:var(--panel);border:1px solid var(--bd);border-radius:10px;padding:10px;text-align:center}
.dr-stat .n{font-size:20px;font-weight:800}
.dr-stat .l{font-size:10.5px;color:var(--mut)}
.dr-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.dr-today{margin-top:14px;border-top:1px solid var(--bd2);padding-top:10px}
.dr-today-h{font-size:12px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}
.dr-today-counts{font-size:13px}
.dr-today-list{list-style:none;margin:8px 0 0;padding:0;max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.dr-today-list li{display:flex;align-items:center;gap:8px;font-size:12.5px;padding:4px 0;border-bottom:1px solid var(--bd)}
.dr-today-list .t{color:var(--mut);font-variant-numeric:tabular-nums;flex:none}
.dr-today-list .dot{width:7px;height:7px;border-radius:50%;background:var(--bd2);flex:none}
.dr-today-list .dot.ok{background:var(--green)}
.dr-today-list .dot.er{background:var(--red)}
.dr-today-list .wf{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.menu-dots{position:absolute;background:var(--panel2);border:1px solid var(--bd2);border-radius:10px;
  padding:6px;z-index:42;box-shadow:var(--shadow);min-width:190px}
.menu-dots .mi{padding:8px 10px;border-radius:7px;font-size:12.5px;cursor:pointer}
.menu-dots .mi:hover{background:var(--panel3)}
.menu-dots .mhd{font-size:10.5px;color:var(--mut);padding:4px 10px;text-transform:uppercase;letter-spacing:.4px}

.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--panel3);
  border:1px solid var(--bd2);color:var(--tx);padding:10px 16px;border-radius:10px;z-index:60;
  box-shadow:var(--shadow);font-size:13px;animation:slidein .18s ease}
.scroll-thin::-webkit-scrollbar{width:8px;height:8px}
.scroll-thin::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:6px}
*::-webkit-scrollbar{width:9px;height:9px}
*::-webkit-scrollbar-thumb{background:#22304a;border-radius:6px}
*::-webkit-scrollbar-track{background:transparent}

/* ===== Logos Sinaia ===== */
.login-sinaia{display:block;width:218px;max-width:100%;margin:2px auto 16px;
  filter:drop-shadow(0 3px 8px rgba(0,0,0,.55))}
.login-logo{font-size:25px;letter-spacing:3px}
.login-cc{font-size:12px;font-weight:800;letter-spacing:3px;color:var(--brand);
  text-transform:uppercase;text-align:center;margin-top:4px}
.brand{font-size:22px}
.brand-shield{width:36px;height:36px;flex:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}
.brand-tx{display:flex;flex-direction:column;line-height:1.02;gap:1px}
.brand-by{font-size:9px;font-weight:800;letter-spacing:1.8px;color:var(--mut);text-transform:uppercase}
.side-sinaia{display:block;width:154px;max-width:100%;margin:0 auto 11px;opacity:.94;
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}

/* ===== Retratos dos agentes (personagens LimeZu) ===== */
.char-portrait{display:inline-block;background-repeat:no-repeat;image-rendering:pixelated;vertical-align:bottom}
.fa-av{overflow:hidden} .fa-av .char-portrait{display:block;margin:auto}
.dr-av{overflow:hidden;padding:0;display:grid;place-items:center}
.dr-showcase{display:flex;gap:14px;align-items:stretch;margin-bottom:14px;
  background:var(--panel);border:1px solid var(--bd);border-radius:12px;padding:12px}
.dr-portrait{flex:none;width:86px;height:148px;display:grid;place-items:end center;
  border:1px solid var(--bd2);border-radius:10px;overflow:hidden}
.dr-portrait .char-portrait{display:block}
.dr-sc-info{min-width:0;flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px}
.dr-sc-frente{font-size:13.5px;font-weight:700}
.dr-sc-wf{font-size:12px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ===== Construtor de cenário (editor LimeZu) ===== */
.ed-host{height:100%}
.ed-wrap{display:flex;flex-direction:column;height:100%;gap:8px;padding:8px 14px 10px}
.ed-top{display:flex;flex-direction:column;gap:7px}
.ed-tools,.ed-cats{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.ed-tools button,.ed-cats button{background:var(--panel);border:1px solid var(--bd);color:var(--mut);
  padding:6px 11px;border-radius:8px;font-size:12.5px;font-weight:600;cursor:pointer}
.ed-tools button:hover,.ed-cats button:hover{color:var(--tx);border-color:var(--bd2)}
.ed-tools button.active,.ed-cats button.active{background:var(--panel3);color:#fff;border-color:var(--bd2)}
.ed-sep{width:1px;height:20px;background:var(--bd2);margin:0 4px}
.ed-status{font-size:12px;color:var(--mut);margin-left:8px}
.ed-body{display:flex;gap:10px;flex:1;min-height:0}
.ed-palette{width:256px;flex:none;overflow-y:auto;display:grid;grid-template-columns:repeat(4,1fr);
  gap:6px;align-content:start;background:var(--panel);border:1px solid var(--bd);border-radius:10px;padding:8px}
.pal-item{background:var(--panel2);border:1px solid var(--bd);border-radius:7px;height:56px;display:grid;
  place-items:center;cursor:pointer;overflow:hidden}
.pal-item:hover{border-color:var(--bd2)}
.pal-item.sel{outline:2px solid var(--brand);border-color:var(--brand)}
.pal-spr,.pal-floor{image-rendering:pixelated}
.pal-spr{max-width:42px;max-height:50px}
.pal-floor{width:44px;height:44px}
.pal-agent{grid-column:span 2;height:auto;min-height:64px;padding:6px 4px;grid-auto-rows:min-content;gap:2px;align-content:center}
.pal-agent b{font-size:10px;font-weight:700;color:var(--tx);line-height:1.05;text-align:center}
.ed-stage{flex:1;min-width:0;overflow:auto;background:#070b12;border:1px solid var(--bd);border-radius:10px;
  display:grid;place-items:center;padding:6px}
#ed-canvas{image-rendering:pixelated;max-width:100%;max-height:100%;height:auto}
.ed-hint{font-size:11.5px;color:var(--mut2);text-align:center}
