*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#f0f4f8;--sf:#fff;--sf2:#f6f8fb;--sf3:#eaeff5;--bd:#dde3ec;--bd2:#e8edf4;--ink:#0a1628;--ink2:#3a4a62;--ink3:#6b7d96;--ink4:#9baab8;--ac:#0066ff;--ac2:#0052cc;--acS:#e5f0ff;--gn:#10b759;--gnS:#e6f9ef;--rd:#e5333b;--rdS:#fde8e9;--am:#f0a500;--amS:#fef4db;--pu:#7c3aed;--puS:#f0ebff;--cy:#0891b2;--cyS:#e0f7fa;--tl:#059669;--tlS:#d1fae5;--or:#ea580c;--orS:#fff4ed;--font:'DM Sans',system-ui,sans-serif;--sidebar:250px;--sidebar-mini:64px;--topbar:54px;--rl:12px;--sh:0 1px 3px rgba(0,20,60,.06);--shM:0 4px 16px rgba(0,20,60,.08);--shL:0 12px 40px rgba(0,20,60,.12);--tr:all .2s ease;--mo-bg:#fff;--mo-overlay:rgba(5,15,35,.65);--sb-bg:linear-gradient(178deg,#0a1628 0%,#0f2140 60%,#0b1a30 100%);--sb-on:#6db3ff;--sb-on-bg:rgba(0,102,255,.1)}
[data-theme="dark"]{--bg:#0d1117;--sf:#161b22;--sf2:#1c2129;--sf3:#21262d;--bd:#30363d;--bd2:#262c36;--ink:#e6edf3;--ink2:#b1bac4;--ink3:#8b949e;--ink4:#6e7681;--acS:#0d2240;--gnS:#0a2e1a;--rdS:#3d1214;--amS:#3d2e08;--puS:#1e0f3d;--cyS:#0a2833;--tlS:#0a2e22;--orS:#3d1f08;--sh:0 1px 3px rgba(0,0,0,.3);--shM:0 4px 16px rgba(0,0,0,.4);--shL:0 12px 40px rgba(0,0,0,.5);--mo-bg:#161b22;--mo-overlay:rgba(0,0,0,.78)}
/* Cores accent customizáveis: muda --ac, sidebar e tokens correlacionados */
[data-accent="cyan"]{--ac:#06b6d4;--ac2:#0891b2;--acS:#cffafe;--sb-bg:linear-gradient(178deg,#0a2429 0%,#0e3138 60%,#0a262c 100%);--sb-on:#67e8f9;--sb-on-bg:rgba(6,182,212,.16)}
[data-accent="cyan"][data-theme="dark"]{--acS:#083344}
[data-accent="purple"]{--ac:#8b5cf6;--ac2:#7c3aed;--acS:#ede9fe;--sb-bg:linear-gradient(178deg,#1d1235 0%,#2e1c52 60%,#1f133b 100%);--sb-on:#c4b5fd;--sb-on-bg:rgba(139,92,246,.16)}
[data-accent="purple"][data-theme="dark"]{--acS:#2e1065}
[data-accent="teal"]{--ac:#10b981;--ac2:#059669;--acS:#d1fae5;--sb-bg:linear-gradient(178deg,#0a2620 0%,#0d3829 60%,#0a2a22 100%);--sb-on:#6ee7b7;--sb-on-bg:rgba(16,185,129,.16)}
[data-accent="teal"][data-theme="dark"]{--acS:#064e3b}
[data-accent="rose"]{--ac:#e11d48;--ac2:#be123c;--acS:#ffe4e6;--sb-bg:linear-gradient(178deg,#2e0a18 0%,#3d0d24 60%,#330a1a 100%);--sb-on:#fda4af;--sb-on-bg:rgba(225,29,72,.14)}
[data-accent="rose"][data-theme="dark"]{--acS:#3d0d18}
[data-accent="amber"]{--ac:#f59e0b;--ac2:#d97706;--acS:#fef3c7;--sb-bg:linear-gradient(178deg,#2e1f0a 0%,#3d2a0d 60%,#33220a 100%);--sb-on:#fcd34d;--sb-on-bg:rgba(245,158,11,.16)}
[data-accent="amber"][data-theme="dark"]{--acS:#451a03}
[data-accent="gray"]{--ac:#18181b;--ac2:#000000;--acS:#f4f4f5;--sb-bg:linear-gradient(178deg,#0a0a0a 0%,#1c1c1f 60%,#0d0d0f 100%);--sb-on:#fafafa;--sb-on-bg:rgba(255,255,255,.10)}
[data-accent="gray"][data-theme="dark"]{--ac:#a1a1aa;--ac2:#71717a;--acS:#27272a;--sb-on:#fafafa;--sb-on-bg:rgba(255,255,255,.10)}
html{font-size:13.5px;-webkit-font-smoothing:antialiased;scrollbar-width:thin;scrollbar-color:var(--ink4) transparent}body{font-family:var(--font);background:var(--bg);color:var(--ink);min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}input,select,textarea,button{font-family:var(--font)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--ink4);border-radius:3px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:var(--ink3)}::selection{background:var(--acS);color:var(--ac)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.app{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:var(--sidebar);background:var(--sb-bg);color:#fff;position:fixed;top:0;left:0;bottom:0;z-index:800;display:flex;flex-direction:column;transition:width .28s cubic-bezier(.4,0,.2,1),transform .28s cubic-bezier(.4,0,.2,1),background .3s;overflow:hidden}
.sidebar.mini{width:var(--sidebar-mini)}
.sidebar.mini .sb-brand-txt,.sidebar.mini .sb-ur,.sidebar.mini .nb-c,.sidebar.mini .sb-sec,.sidebar.mini .nb-lbl,.sidebar.mini .sb-un,.sidebar.mini .nb-chev{display:none}
.sidebar.mini .nb-child{display:none}
.sidebar.mini .sb-brand{padding:14px 16px;justify-content:center;gap:0}.sidebar.mini .sb-logo svg{height:26px}.sidebar.mini .sb-logo img{height:24px}
.sidebar.mini .sb-user{padding:8px;margin:6px 4px;justify-content:center;gap:0}.sidebar.mini .sb-user>div:last-child{display:none}
.sidebar.mini .nb{justify-content:center;padding:10px;gap:0}.sidebar.mini .nb svg{margin:0}
.sidebar.mini .sb-collapse button span{display:none}
.sb-brand{padding:16px 20px 14px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;gap:10px}
.sb-logo svg{height:32px;width:auto;transition:height .2s}
.sb-brand-txt{display:flex;align-items:center;gap:10px}
.sb-brand-txt small{display:block;font-size:8.5px;color:rgba(255,255,255,.3);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}
.sb-user{padding:10px 14px;margin:8px 10px;background:rgba(255,255,255,.04);border-radius:10px;display:flex;align-items:center;gap:10px;transition:var(--tr)}
.sb-av{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#0066ff,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.sb-un{font-size:11.5px;font-weight:600;color:rgba(255,255,255,.85)}.sb-ur{font-size:9px;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.06em}
.sb-nav{flex:1;padding:6px 8px;overflow-y:auto}
.sb-sec{font-size:8px;color:rgba(255,255,255,.16);letter-spacing:.14em;text-transform:uppercase;padding:14px 14px 4px;font-weight:700;transition:var(--tr)}
.nb{width:100%;display:flex;align-items:center;gap:10px;padding:8px 14px;border:none;border-radius:9px;background:transparent;color:rgba(255,255,255,.4);font-size:12px;font-weight:500;cursor:pointer;transition:var(--tr);text-align:left;margin-bottom:1px;position:relative}
.nb:hover{color:rgba(255,255,255,.7);background:rgba(255,255,255,.04)}.nb.on{color:var(--sb-on);background:var(--sb-on-bg);font-weight:600}.nb.on::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--ac);border-radius:0 3px 3px 0}.nb svg{flex-shrink:0;opacity:.45;width:16px;height:16px}.nb.on svg{opacity:.85}.nb-c{margin-left:auto;font-size:9px;background:rgba(255,255,255,.06);padding:1px 7px;border-radius:10px;font-weight:600;color:rgba(255,255,255,.3)}
.sb-ft{padding:10px 16px;border-top:1px solid rgba(255,255,255,.04);font-size:8px;color:rgba(255,255,255,.1);text-align:center;transition:var(--tr)}
.sb-collapse{padding:6px 8px;border-top:1px solid rgba(255,255,255,.04)}.sb-collapse button{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:6px;border:none;border-radius:8px;background:rgba(255,255,255,.04);color:rgba(255,255,255,.3);font-size:10px;cursor:pointer;transition:var(--tr);font-family:var(--font)}.sb-collapse button:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.6)}

.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--rd);color:#fff;font-size:8px;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none}
.notif-dd{position:absolute;top:100%;right:0;margin-top:6px;background:var(--sf);border:1px solid var(--bd2);border-radius:10px;box-shadow:var(--shM);width:360px;max-height:400px;overflow:hidden;z-index:200;animation:fadeIn .15s ease}
.notif-dd-h{padding:12px 14px;border-bottom:1px solid var(--bd2);font-size:12px;font-weight:700;color:var(--ink)}
.notif-dd-b{max-height:340px;overflow-y:auto}
.notif-dd-i{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--bd2);cursor:pointer;transition:var(--tr);font-size:11px}
.notif-dd-i:hover{background:var(--sf2)}
.notif-dd-i:last-child{border-bottom:none}
.notif-empty{padding:30px;text-align:center;color:var(--ink4);font-size:11px}
.toast{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:10px;font-size:12px;font-weight:600;color:#fff;z-index:9999;animation:slideUp .3s ease,fadeOut .3s ease 2.7s;pointer-events:none;font-family:var(--font);box-shadow:var(--shM)}.toast.ok{background:#10b759}.toast.err{background:#e5333b}.toast.warn{background:#f0a500}.toast.info{background:#0066ff}@keyframes fadeOut{to{opacity:0}}
/* === UX: Skeleton loading === */
.skl{display:inline-block;background:linear-gradient(90deg,var(--bd2) 0%,var(--bd) 50%,var(--bd2) 100%);background-size:200% 100%;animation:sklShim 1.2s infinite;border-radius:4px;height:12px;width:100%}
@keyframes sklShim{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* === UX: Command palette === */
.cp-ov{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh}
.cp-box{width:min(600px,92%);background:var(--sf);border:1px solid var(--bd);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.35);overflow:hidden;display:flex;flex-direction:column;max-height:70vh}
.cp-in{width:100%;padding:14px 18px;border:none;outline:none;background:transparent;color:var(--ink);font-size:15px;font-family:var(--font);border-bottom:1px solid var(--bd2)}
.cp-list{flex:1;overflow-y:auto;padding:6px 0}
.cp-group{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink4);padding:8px 18px 4px}
.cp-it{padding:8px 18px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--ink2);border-left:2px solid transparent}
.cp-it:hover,.cp-it.on{background:var(--sf2);border-left-color:var(--ac);color:var(--ink)}
.cp-it-meta{font-size:10px;color:var(--ink4);margin-left:auto}
.cp-empty{padding:30px 18px;text-align:center;color:var(--ink4);font-size:12px}
/* === UX: Loading badge === */
.api-loading{position:fixed;top:12px;left:50%;transform:translateX(-50%);background:var(--ac);color:#fff;padding:6px 14px;border-radius:20px;font-size:11px;font-weight:600;box-shadow:0 4px 14px rgba(0,0,0,.25);z-index:9998;display:flex;align-items:center;gap:8px}
.api-loading svg{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* === UX: Draggable columns === */
.tb th[data-colk]{cursor:grab}
.tb th[data-colk].drag-over{background:var(--acS)!important;border-left:2px solid var(--ac)}
.usr-dd{position:absolute;top:100%;right:0;margin-top:6px;background:var(--sf);border:1px solid var(--bd2);border-radius:10px;box-shadow:var(--shM);min-width:160px;z-index:200;overflow:hidden;animation:fadeIn .15s ease}.usr-dd button{width:100%;display:flex;align-items:center;gap:8px;padding:10px 14px;border:none;background:transparent;color:var(--ink2);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font);transition:var(--tr)}.usr-dd button:hover{background:var(--sf2);color:var(--ink)}.usr-dd button.logout{color:var(--rd)}.usr-dd button.logout:hover{background:var(--rdS)}
/* MAIN */
.main{flex:1;margin-left:var(--sidebar);min-height:100vh;display:flex;flex-direction:column;transition:margin-left .28s cubic-bezier(.4,0,.2,1)}
.main.mini{margin-left:var(--sidebar-mini)}
.topbar{height:var(--topbar);padding:0 22px;display:flex;align-items:center;justify-content:space-between;background:var(--sf);backdrop-filter:blur(16px);border-bottom:1px solid var(--bd2);position:sticky;top:0;z-index:100;transition:background .3s}
.tb-l{display:flex;align-items:center;gap:10px}.tb-tog{display:none;background:none;border:none;cursor:pointer;padding:3px;color:var(--ink2)}
.tb-s{display:flex;align-items:center;gap:7px;padding:6px 13px;background:var(--sf2);border:1px solid var(--bd2);border-radius:9px;min-width:260px;transition:var(--tr)}.tb-s input{border:none;background:transparent;outline:none;font-size:12px;flex:1;color:var(--ink)}.tb-s svg{color:var(--ink4);flex-shrink:0}
.tb-r{display:flex;align-items:center;gap:6px}
.tb-icon{background:none;border:1px solid var(--bd2);border-radius:8px;padding:6px;cursor:pointer;color:var(--ink3);transition:var(--tr);display:flex;align-items:center;justify-content:center}.tb-icon:hover{background:var(--sf2);color:var(--ink)}
.pg{padding:14px 16px;max-width:1600px;margin:0 auto;width:100%;animation:slideUp .22s ease}

/* COMPONENTS */
.cd{background:var(--sf);border:1px solid var(--bd2);border-radius:var(--rl);box-shadow:var(--sh);overflow:hidden;transition:background .3s,border-color .3s}.cd-h{padding:12px 16px;border-bottom:1px solid var(--bd2);display:flex;align-items:center;justify-content:space-between;gap:8px}.cd-h h3{font-size:13.5px;font-weight:700}.cd-b{padding:14px 16px}.cd-b.np{padding:0}
.bg{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;font-size:9.5px;font-weight:700;letter-spacing:.02em;white-space:nowrap}
.bt{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border:none;border-radius:8px;font-size:11.5px;font-weight:600;cursor:pointer;transition:var(--tr);white-space:nowrap}.bt:hover:not(:disabled){filter:brightness(.92)}.bt:active:not(:disabled){transform:scale(.97)}.bt-p{background:var(--ac);color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.12)}.bt-s{background:var(--sf2);color:var(--ink2);border:1px solid var(--bd)}.bt-d{background:var(--rdS);color:var(--rd)}.bt-g{background:var(--gnS);color:var(--gn)}.bt-gh{background:transparent;color:var(--ac);padding:5px 7px}.bt-sm{padding:4px 9px;font-size:10px;border-radius:6px}
.inp{padding:7px 11px;border:1.5px solid var(--bd);border-radius:8px;font-size:11.5px;background:var(--sf);outline:none;transition:border .2s,background .3s;width:100%;color:var(--ink)}.inp:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(0,0,0,.08)}@supports (color: color-mix(in srgb, red, blue)){.inp:focus{box-shadow:0 0 0 3px color-mix(in srgb, var(--ac) 18%, transparent)}}input:not(.inp):not([type=checkbox]):not([type=radio]):focus-visible,select:not(.inp):focus-visible,textarea:not(.inp):focus-visible{outline:none;border-color:var(--ac);box-shadow:0 0 0 3px rgba(0,0,0,.08)}@supports (color: color-mix(in srgb, red, blue)){input:not(.inp):not([type=checkbox]):not([type=radio]):focus-visible,select:not(.inp):focus-visible,textarea:not(.inp):focus-visible{box-shadow:0 0 0 3px color-mix(in srgb, var(--ac) 18%, transparent)}}select.inp{cursor:pointer}
.lbl{display:block;font-size:9.5px;font-weight:600;color:var(--ink3);margin-bottom:2px;letter-spacing:.04em;text-transform:uppercase}
.fg{display:flex;flex-direction:column;gap:2px}.fr{display:grid;gap:10px}.fr2{grid-template-columns:1fr 1fr}.fr3{grid-template-columns:1fr 1fr 1fr}.fr4{grid-template-columns:1fr 1fr 1fr 1fr}.fr5{grid-template-columns:1fr 1fr 1fr 1fr 1fr}.fr6{grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr}.sp2{grid-column:span 2}.sp3{grid-column:span 3}
.sr{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}
.st{padding:14px 15px;display:flex;align-items:center;gap:11px}.st-ic{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.st-lb{font-size:9.5px;color:var(--ink3);font-weight:500}.st-vl{font-size:19px;font-weight:800;letter-spacing:-.03em;margin-top:1px}
.ph{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap;gap:10px}.ph-t{font-size:20px;font-weight:800;letter-spacing:-.03em}.ph-s{font-size:11px;color:var(--ink3);margin-top:2px}.ph-a{display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.li{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid var(--bd2);transition:background .1s;flex-wrap:wrap}.li:last-child{border-bottom:none}.li:hover{background:var(--sf2)}.li-i{flex:1;min-width:120px}.li-n{font-size:12px;font-weight:650}.li-m{font-size:10px;color:var(--ink3);margin-top:1px}.li-a{display:flex;gap:3px;flex-shrink:0}
.em{text-align:center;padding:36px 20px;color:var(--ink4)}.em h4{font-size:13px;color:var(--ink3)}.em p{font-size:11px}
.tb{width:100%;border-collapse:collapse;font-size:11px}.tb th{padding:8px 10px;text-align:left;font-weight:650;color:var(--ink3);background:var(--sf2);border-bottom:1px solid var(--bd);font-size:9.5px;text-transform:uppercase;letter-spacing:.04em}.tb td{padding:8px 10px;border-bottom:1px solid var(--bd2)}.tb tr:hover td{background:var(--sf2)}.tb tr{cursor:pointer}
.tabs{display:flex;gap:2px;background:var(--sf3);border-radius:9px;padding:2px;margin-bottom:12px}.tab{flex:1;padding:6px 10px;border:none;border-radius:7px;font-size:10.5px;font-weight:600;cursor:pointer;background:transparent;color:var(--ink3);transition:var(--tr);font-family:var(--font);text-align:center}.tab.on{background:var(--sf);color:var(--ac);box-shadow:0 1px 2px rgba(0,0,0,.05)}
.mo{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--mo-overlay);animation:fadeIn .1s;padding:20px 0}.mo-box{background:var(--mo-bg);border-radius:var(--rl);width:min(780px,96%);box-shadow:var(--shL);animation:slideUp .18s;display:flex;flex-direction:column;max-height:calc(100vh - 40px)}.mo-box.wide{width:min(960px,96%)}.mo-h{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--bd2);background:var(--mo-bg);border-radius:var(--rl) var(--rl) 0 0;flex-shrink:0}.mo-h h3{font-size:15px;font-weight:750}.mx{background:none;border:none;cursor:pointer;color:var(--ink3);padding:3px;border-radius:7px}.mx:hover{color:var(--ink);background:var(--sf3)}.mo-b{padding:16px 18px;overflow-y:auto;flex:1 1 auto;min-height:0}.mf{display:flex;gap:7px;justify-content:flex-end;padding:12px 18px;border-top:1px solid var(--bd2);flex-shrink:0;background:var(--mo-bg)}
.exp{border:1px solid var(--bd2);border-radius:var(--rl);margin-bottom:10px;overflow:hidden;transition:border-color .3s}.exp-h{padding:10px 14px;background:var(--sf2);cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;color:var(--ink2);user-select:none;transition:background .15s}.exp-h:hover{background:var(--sf3)}.exp-h svg{transition:transform .2s;flex-shrink:0}.exp-h.open svg{transform:rotate(180deg)}.exp-b{padding:12px 14px;display:none;border-top:1px solid var(--bd2)}.exp-b.open{display:block}
.tl{position:relative;padding-left:22px}.tl::before{content:'';position:absolute;left:7px;top:4px;bottom:4px;width:2px;background:var(--bd)}.tl-i{position:relative;padding:0 0 14px}.tl-d{position:absolute;left:-18px;top:3px;width:10px;height:10px;border-radius:50%;border:2.5px solid var(--ac);background:var(--sf);z-index:1}.tl-d.gn{border-color:var(--gn)}.tl-d.rd{border-color:var(--rd)}.tl-dt{font-size:9px;color:var(--ink4);margin-bottom:1px}.tl-tx{font-size:11px;color:var(--ink2)}.tl-tx strong{color:var(--ink);font-weight:600}
.fbar{padding:10px 14px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.pgn{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--bd2);font-size:11px;color:var(--ink3);flex-wrap:wrap;gap:8px}
.pgn-info{display:flex;align-items:center;gap:6px}.pgn-info select{padding:2px 6px;border:1px solid var(--bd);border-radius:5px;font-size:10px;background:var(--sf);color:var(--ink);cursor:pointer}
.pgn-nav{display:flex;gap:3px}.pgn-btn{width:28px;height:28px;border:1px solid var(--bd);border-radius:7px;background:var(--sf);color:var(--ink3);font-size:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--tr)}.pgn-btn:hover{background:var(--sf2);color:var(--ink)}.pgn-btn.on{background:var(--ac);color:#fff;border-color:var(--ac)}.pgn-btn:disabled{opacity:.3;cursor:default}
.ftag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--acS);color:var(--ac);border-radius:6px;font-size:10px;font-weight:600}.ftag button{background:none;border:none;cursor:pointer;color:var(--ac);font-size:13px;line-height:1;padding:0 2px}
.tog{position:relative;width:36px;height:20px;display:inline-block}.tog input{opacity:0;width:0;height:0}.tog-sl{position:absolute;inset:0;background:var(--bd);border-radius:10px;cursor:pointer;transition:.2s}.tog-sl::before{content:'';position:absolute;width:16px;height:16px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.2s}.tog input:checked+.tog-sl{background:var(--ac)}.tog input:checked+.tog-sl::before{transform:translateX(16px)}
@media(max-width:800px){.sidebar{transform:translateX(-100%);width:var(--sidebar)!important}.sidebar.open{transform:translateX(0)}.sidebar.mini{width:var(--sidebar)!important}.main{margin-left:0!important}.tb-tog{display:flex!important}.tb-s{min-width:0;flex:1}.fr2,.fr3,.fr4,.fr5,.fr6{grid-template-columns:1fr}.sp2,.sp3{grid-column:span 1}.sr{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.sr{grid-template-columns:1fr}}
/* === Polish #2: Empty states melhores (.em-bx) e Tooltip CSS-only (.tt) === */
.em-bx{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center;color:var(--ink3)}
.em-bx .em-ic{width:48px;height:48px;border-radius:50%;background:var(--bd2);display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:22px;color:var(--ink4)}
.em-bx .em-tt{font-size:13px;font-weight:700;color:var(--ink2);margin-bottom:4px}
.em-bx .em-sb{font-size:11px;color:var(--ink4);margin-bottom:14px;max-width:280px;line-height:1.4}
.em-bx .em-cta{margin-top:4px}
.tt{position:relative}
.tt::after{content:attr(data-tt);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--ink);color:var(--bg);font-size:10px;font-weight:600;padding:4px 8px;border-radius:4px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s,transform .15s;z-index:9999;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.tt::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%) translateY(4px);border:4px solid transparent;border-top-color:var(--ink);pointer-events:none;opacity:0;transition:opacity .15s,transform .15s;z-index:9999}
.tt:hover::after,.tt:hover::before{opacity:1;transform:translateX(-50%) translateY(0)}
.tt[data-tt-pos=bottom]::after{bottom:auto;top:calc(100% + 6px)}
.tt[data-tt-pos=bottom]::before{bottom:auto;top:calc(100% + 2px);border-top-color:transparent;border-bottom-color:var(--ink)}