/* ============================================================
   Central de Controle — Very Software
   App styles. Built on the Torque Design System foundations.
   Light mode · IBM Plex · azure primary · amber signal.
   ============================================================ */
@import url('colors_and_type.css');

/* Suaviza o texto principal e o vermelho (tom menos pesado que o padrão do DS) */
:root{
  --fg-1: oklch(0.41 0.014 258);
  --danger: oklch(0.62 0.165 27);
  --danger-hover: oklch(0.56 0.165 27);
  --canvas: oklch(0.955 0.004 255);
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--font-sans);background:var(--canvas);color:var(--fg-1);font-size:14px;
     -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button{font-family:inherit}
::selection{background:var(--primary-weak-2)}
.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.right{text-align:right}
.muted{color:var(--fg-3)}
.sub{color:var(--fg-3);font-size:12px}

/* scrollbars */
*::-webkit-scrollbar{width:11px;height:11px}
*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px;border:3px solid var(--canvas)}
.content *::-webkit-scrollbar-thumb{border-color:var(--surface)}
*::-webkit-scrollbar-thumb:hover{background:var(--fg-3)}

/* ============================================================
   APP SHELL — collapsible rail + topbar
   ============================================================ */
.app{display:grid;grid-template-columns:236px 1fr;height:100vh;overflow:hidden;
     transition:grid-template-columns .18s ease}
.app.collapsed{grid-template-columns:68px 1fr}

.rail{
  background: linear-gradient(175deg, oklch(0.22 0.11 254) 0%, oklch(0.14 0.07 260) 100%);
  border-right:none;
  display:flex;flex-direction:column;
  padding:14px 12px;overflow:hidden;
  box-shadow: 2px 0 12px oklch(0.12 0.06 258 / 0.18);
}

/* Brand / logo */
.rail .brand{display:flex;align-items:center;justify-content:center;padding:16px 8px 20px;overflow:hidden;min-height:72px}
.rail .brand-logo-full{
  width:100%;max-width:168px;display:block;
  transition:opacity .18s;
}
.rail .brand-logo-icon{
  display:none;width:36px;height:36px;object-fit:contain;
  transition:opacity .18s;
}
.app.collapsed .rail .brand-logo-full{display:none}
.app.collapsed .rail .brand-logo-icon{display:block}

/* Nav links */
.nav{display:flex;flex-direction:column;gap:4px}
.nav a{
  display:flex;align-items:center;gap:13px;padding:11px 13px;border-radius:var(--r-md);
  color:oklch(0.74 0.04 252);
  font-weight:500;font-size:14px;cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:background .14s,color .14s;
}
.nav a svg{flex:none}
.nav a:hover{background:rgba(255,255,255,0.10);color:#fff}
.nav a.active{
  background:rgba(255,255,255,0.16);
  color:#fff;
  font-weight:600;
  box-shadow:inset 3px 0 0 oklch(0.74 0.155 64);
}
.nav a.active svg{color:#fff}
.app.collapsed .nav a .lbl{opacity:0;width:0;overflow:hidden}
.nav .grp{
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:oklch(0.50 0.05 252);
  padding:14px 11px 6px;
}
.app.collapsed .nav .grp{opacity:0;height:0;padding:0;overflow:hidden}

/* Footer do rail */
.rail .spacer{flex:1}
.rail .me{
  display:flex;align-items:center;gap:10px;padding:9px 8px;
  border-top:1px solid rgba(255,255,255,0.10);
  margin-top:8px;white-space:nowrap;
}
.rail .me .meinfo > div:first-child{color:#fff}
.rail .me .sub{color:oklch(0.60 0.04 252)}
.avatar{width:32px;height:32px;border-radius:50%;background:oklch(0.50 0.155 252);color:#fff;display:flex;
        align-items:center;justify-content:center;font-weight:600;font-size:12px;flex:none;
        box-shadow:0 0 0 2px rgba(255,255,255,0.15)}
.app.collapsed .rail .me .meinfo{opacity:0;width:0;overflow:hidden}

/* Iconbtn ghost dentro do rail */
.rail .iconbtn.ghost{color:oklch(0.65 0.04 252);border-color:transparent;background:transparent}
.rail .iconbtn.ghost:hover{background:rgba(255,255,255,0.12);color:#fff}

.main{display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:62px;flex:none;border-bottom:1px solid oklch(0.86 0.022 252);
        background:linear-gradient(90deg, oklch(0.93 0.022 252) 0%, oklch(0.97 0.010 252) 60%, oklch(0.99 0.004 255) 100%);
        display:flex;align-items:center;gap:14px;padding:0 22px}
.topbar .collapse{margin-right:2px}
.topbar .iconbtn{background:transparent;border-color:oklch(0.82 0.025 252 / 0.6)}
.topbar .iconbtn:hover{background:oklch(0.88 0.030 252);border-color:oklch(0.78 0.030 252)}
.topbar h1{font-size:19px;font-weight:600;margin:0;letter-spacing:-.01em;white-space:nowrap}
.topbar .crumb{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3);
               margin-bottom:1px;white-space:nowrap}
.topbar > div{min-width:0}
.topbar .spacer{flex:1}
.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:22px 24px 40px}
.page{max-width:1560px;margin:0 auto}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.scrim,.modal,.dd-pop{animation:none}}

.page-head{display:flex;align-items:flex-end;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-head .lead{flex:1;min-width:220px}
.page-head h2{margin:0;font-size:22px;font-weight:700;letter-spacing:-.02em}
.page-head p{margin:4px 0 0;color:var(--fg-2);font-size:13.5px}

/* ============================================================
   BUTTONS / ICON BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;padding:9px 14px;
     border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;line-height:1;white-space:nowrap;
     transition:background .12s,border-color .12s,color .12s}
.btn:active{transform:translateY(.5px)}
.btn:disabled{opacity:.45;pointer-events:none}
.btn-primary{background:var(--primary);color:var(--fg-on-accent)}
.btn-primary:hover{background:var(--primary-hover)}
.btn-primary:active{background:var(--primary-press)}
.btn-secondary{background:var(--surface);color:var(--fg-1);border-color:var(--border-strong)}
.btn-secondary:hover{background:var(--surface-3)}
.btn-ghost{background:transparent;color:var(--fg-2)}
.btn-ghost:hover{background:var(--surface-3);color:var(--fg-1)}
.btn-sm{padding:6px 10px;font-size:13px}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-md);
     border:1px solid var(--border);background:var(--surface);color:var(--fg-2);cursor:pointer;
     transition:background .12s,color .12s;flex:none}
.iconbtn:hover{background:var(--surface-3);color:var(--fg-1)}
.iconbtn.ghost{border-color:transparent;background:transparent}
.iconbtn.ghost:hover{background:var(--surface-3)}

/* ============================================================
   DROPDOWN (period filter, menus)
   ============================================================ */
.dd{position:relative}
.dd-trigger{display:inline-flex;align-items:center;gap:9px;background:var(--surface);
     border:1px solid var(--border-strong);border-radius:var(--r-md);padding:8px 12px;cursor:pointer;
     font-size:13.5px;font-weight:500;color:var(--fg-1);transition:background .12s,border-color .12s}
.dd-trigger:hover{background:var(--surface-3)}
.dd-trigger .dim{color:var(--fg-3);font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.dd-pop{position:absolute;top:calc(100% + 6px);right:0;z-index:40;background:var(--surface);
     border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
     min-width:240px;padding:6px;animation:pop .14s ease-out}
.dd-pop .item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r-sm);
     cursor:pointer;font-size:13.5px;color:var(--fg-1);transition:background .1s}
.dd-pop .item:hover{background:var(--surface-3)}
.dd-pop .item.on{background:var(--primary-weak);color:var(--primary);font-weight:600}
.dd-pop .item .ck{margin-left:auto;color:var(--primary)}
.dd-pop .sep{height:1px;background:var(--border);margin:6px 4px}
.dd-pop .lab{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--fg-3);padding:8px 11px 4px}
@keyframes pop{from{opacity:0;transform:scale(.98) translateY(-4px)}to{opacity:1;transform:none}}

/* ============================================================
   CARDS
   ============================================================ */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.card-h{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--border)}
.card-h h3{margin:0;font-size:14.5px;font-weight:600;letter-spacing:-.005em}
.card-h .ttl-ic{width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;
     background:var(--surface-3);color:var(--fg-2);flex:none}
.card-h .sub{font-size:12px;color:var(--fg-3);font-weight:400}
.card-h .spacer{flex:1}
.card-b{padding:18px}
.card-b.tight{padding:10px}

/* ============================================================
   KPI TILES
   ============================================================ */
.kpi{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
     box-shadow:var(--shadow-sm);padding:16px 17px;overflow:hidden;transition:box-shadow .15s,border-color .15s}
.kpi:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.kpi .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.kpi .lab{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-2)}
.kpi .ic{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex:none}
.kpi .num{font-family:var(--font-sans);font-weight:500;font-size:27px;letter-spacing:-.02em;line-height:1;
     color:var(--fg-1);font-variant-numeric:tabular-nums}
.kpi .foot{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:12px;color:var(--fg-3)}
.delta{display:inline-flex;align-items:center;gap:3px;font-weight:600;font-family:var(--font-mono);font-size:12px;
     padding:2px 6px;border-radius:var(--r-xs)}
.delta.up{color:var(--success);background:var(--success-weak)}
.delta.down{color:var(--danger);background:var(--danger-weak)}
.delta.flat{color:var(--fg-2);background:var(--surface-3)}

/* ============================================================
   GRID HELPERS
   ============================================================ */
.grid{display:grid;gap:16px}
.g-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.g-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.g-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1180px){.g-4{grid-template-columns:repeat(2,minmax(0,1fr))}.g-3{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.g-4,.g-3,.g-2{grid-template-columns:1fr}}

/* ============================================================
   BADGES / PILLS
   ============================================================ */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 9px;
     border-radius:var(--r-pill);white-space:nowrap}
.badge .dot{width:6px;height:6px;border-radius:50%}
.badge.info{background:var(--info-weak);color:var(--info)} .badge.info .dot{background:var(--info)}
.badge.warn{background:var(--warning-weak);color:var(--signal-strong)} .badge.warn .dot{background:var(--warning)}
.badge.danger{background:var(--danger-weak);color:var(--danger)} .badge.danger .dot{background:var(--danger)}
.badge.success{background:var(--success-weak);color:var(--success)} .badge.success .dot{background:var(--success)}
.badge.neutral{background:var(--surface-3);color:var(--fg-2)} .badge.neutral .dot{background:var(--fg-3)}
.tag-a{background:var(--primary-weak);color:var(--primary);font-weight:700;font-family:var(--font-mono);
     font-size:11px;padding:2px 7px;border-radius:var(--r-xs)}

/* ============================================================
   TABLES (premium: search, sort, paginate, export)
   ============================================================ */
.tbl-tools{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.tbl-search{flex:1;min-width:180px;max-width:340px;display:flex;align-items:center;gap:8px;background:var(--surface-2);
     border:1px solid var(--border);border-radius:var(--r-md);padding:7px 11px}
.tbl-search input{border:0;background:none;outline:0;font-size:13.5px;width:100%;color:var(--fg-1);font-family:inherit}
.tbl-search input::placeholder{color:var(--fg-3)}
.tbl-search svg{color:var(--fg-3);flex:none}
.tbl-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse}
.tbl thead th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-3);
     text-align:left;padding:11px 16px;background:var(--surface-2);border-bottom:1px solid var(--border);
     white-space:nowrap;user-select:none}
.tbl thead th.sortable{cursor:pointer}
.tbl thead th.sortable:hover{color:var(--fg-1)}
.tbl thead th .th-in{display:inline-flex;align-items:center;gap:5px}
.tbl thead th.right .th-in{flex-direction:row-reverse}
.tbl thead th .sort-ic{opacity:.35;transition:opacity .1s}
.tbl thead th.act .sort-ic{opacity:1;color:var(--primary)}
.tbl td{padding:11px 16px;border-bottom:1px solid var(--border);font-size:13.5px;color:var(--fg-1);vertical-align:middle}
.tbl tbody tr{transition:background .1s}
.tbl tbody tr:hover{background:var(--surface-3)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl .right{text-align:right;font-variant-numeric:tabular-nums}
.tbl .rank{color:var(--fg-3);font-family:var(--font-mono);font-weight:600;width:34px}
.pagin{display:flex;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid var(--border);
     font-size:13px;color:var(--fg-2);flex-wrap:wrap}
.pagin .spacer{flex:1}
.pagin .pg{display:flex;align-items:center;gap:4px}
.pagin .pgbtn{width:30px;height:30px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);
     color:var(--fg-2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:13px;
     font-family:var(--font-mono)}
.pagin .pgbtn:hover{background:var(--surface-3);color:var(--fg-1)}
.pagin .pgbtn.on{background:var(--primary);border-color:var(--primary);color:#fff}
.pagin .pgbtn:disabled{opacity:.4;pointer-events:none}

/* mini progress bar inside cells/rows */
.mbar{height:6px;border-radius:99px;background:var(--surface-3);overflow:hidden;min-width:60px}
.mbar > span{display:block;height:100%;border-radius:99px;background:var(--primary)}

/* ============================================================
   SKELETON LOADING
   ============================================================ */
.sk{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 37%,var(--surface-2) 63%);
    background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:var(--r-sm)}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
@media (prefers-reduced-motion:reduce){.sk{animation:none}}

/* ============================================================
   CHART bits
   ============================================================ */
.legend{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:4px}
.legend .it{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--fg-2)}
.legend .sw{width:10px;height:10px;border-radius:3px;flex:none}
.chart-tip{position:absolute;pointer-events:none;background:var(--fg-1);color:#fff;font-size:12px;
     padding:7px 10px;border-radius:var(--r-sm);box-shadow:var(--shadow-md);white-space:nowrap;z-index:5;
     transform:translate(-50%,-115%);transition:opacity .08s;line-height:1.45}
.chart-tip .tv{font-family:var(--font-mono);font-weight:600}
.chart-tip .tk{color:var(--surface-3);font-size:11px}

/* progress / meta rows */
.prow{display:grid;grid-template-columns:140px 1fr auto;gap:14px;align-items:center;padding:10px 0}
.prow + .prow{border-top:1px solid var(--border)}
.prow .nm{font-weight:600;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prow .nm .sub{font-weight:400}
.ptrack{position:relative;height:10px;border-radius:99px;background:var(--surface-3);overflow:visible}
.ptrack > .fill{position:absolute;left:0;top:0;height:100%;border-radius:99px;transition:width .5s ease}
.ptrack > .goal{position:absolute;top:-3px;width:2px;height:16px;background:var(--fg-1);border-radius:2px}
.prow .pct{font-family:var(--font-mono);font-weight:600;font-size:13px;min-width:120px;text-align:right}

/* segmented control */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:3px}
.seg button{border:0;background:none;font-family:inherit;font-size:13px;font-weight:600;color:var(--fg-2);
     padding:6px 13px;border-radius:var(--r-sm);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.12s}
.seg button:hover{color:var(--fg-1)}
.seg button.on{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-xs)}

.empty{text-align:center;padding:46px 20px;color:var(--fg-3)}
.divline{height:1px;background:var(--border)}

/* ---------- sombra dos cards (Tweaks) ---------- */
.app.cards-sutil .card, .app.cards-sutil .kpi{box-shadow:0 1px 2px oklch(0.45 0.02 258 / 0.05)}
.app.cards-plana .card, .app.cards-plana .kpi{box-shadow:none}
.app.cards-plana .kpi:hover, .app.cards-sutil .kpi:hover{box-shadow:var(--shadow-sm)}

/* ---------- density (Tweaks) ---------- */
.app.dense .content{padding:16px 18px 32px}
.app.dense .card-b{padding:13px}
.app.dense .card-h{padding:11px 15px}
.app.dense .kpi{padding:12px 14px}
.app.dense .kpi .num{font-size:24px}
.app.dense .tbl td{padding:8px 14px}
.app.dense .tbl thead th{padding:9px 14px}
.app.dense .grid{gap:12px}
.app.dense .page > .grid{margin-bottom:12px !important}

/* ══════════════════════════════════════════════════════════════
   PWA Lifecycle — animações de banner
   ══════════════════════════════════════════════════════════════ */
@keyframes pwaSlideUp {
  from { transform: translateX(-50%) translateY(80px); opacity: 0; }
  to   { transform: translateX(-50%) translateY(0);    opacity: 1; }
}
@keyframes pwaSlideDown {
  from { transform: translateX(-50%) translateY(-40px); opacity: 0; }
  to   { transform: translateX(-50%) translateY(0);     opacity: 1; }
}
