:root{
  --tl:#1ec8c8;--bl:#1a7fcf;--mi:#17b3c9;
  --gr:linear-gradient(135deg,#1ec8c8 0%,#17b3c9 45%,#1a7fcf 100%);
  --gs:linear-gradient(135deg,rgba(30,200,200,.1),rgba(26,127,207,.1));
  --bg:#f0f4f8;--sf:#fff;--s2:#f7fafc;--s3:#eef2f7;
  --bd:#e2e8f0;--b2:#cbd5e0;--b3:#a0aec0;
  --tx:#1a202c;--t2:#4a5568;--mu:#718096;--m2:#a0aec0;
  --sh:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.06);
  --sm:0 4px 24px rgba(26,127,207,.14),0 1px 4px rgba(0,0,0,.06);
  --sl:0 12px 48px rgba(26,127,207,.2);
  --r:14px;--sw:236px;
  --green:#38a169;--orange:#dd6b20;--red:#e53e3e;--purple:#805ad5;
}
*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden;max-width:100vw}
body{font-family:'Nunito Sans',sans-serif;background:var(--bg);color:var(--tx);display:flex;height:100vh;overflow:hidden;overflow-x:hidden;font-size:14px;max-width:100vw}
#app-root{display:none;flex:1;min-width:0}

/* ─── SIDEBAR ─── */
.sb{width:var(--sw);background:var(--sf);border-right:1px solid var(--bd);display:flex;flex-direction:column;flex-shrink:0;transition:width .25s}
.sb-logo{padding:18px 16px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--bd)}
.sb-ic{width:38px;height:38px;background:var(--gr);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:'Nunito',sans-serif;font-weight:900;font-size:18px;color:#fff;box-shadow:0 4px 14px rgba(26,127,207,.32);flex-shrink:0}
.sb-nm{font-family:'Nunito',sans-serif;font-weight:900;font-size:16px;line-height:1.1}
.sb-sb{font-size:10px;font-weight:700;color:var(--mu);letter-spacing:.06em;text-transform:uppercase}
.sbn{flex:1;padding:10px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.sbs{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--m2);padding:10px 12px 4px}
.ni{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:10px;cursor:pointer;transition:all .15s;color:var(--t2);font-weight:600;font-size:13px;position:relative;user-select:none}
.ni:hover{background:var(--bg);color:var(--tx)}
.ni.on{background:var(--gs);color:var(--bl)}
.ni.on::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--gr);border-radius:0 3px 3px 0}
.ni-ic{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ni.on .ni-ic{background:#fff;box-shadow:0 2px 8px rgba(26,127,207,.15)}
.nbg{margin-left:auto;background:var(--gr);color:#fff;font-size:10px;font-weight:800;padding:1px 6px;border-radius:20px;min-width:18px;text-align:center}
.nbg.red{background:#f56565}
.sb-usr{padding:12px 14px;border-top:1px solid var(--bd);display:flex;align-items:center;gap:9px;flex-shrink:0}
.uav{width:32px;height:32px;border-radius:50%;background:var(--gr);display:flex;align-items:center;justify-content:center;font-family:'Nunito',sans-serif;font-weight:800;font-size:12px;color:#fff;flex-shrink:0}
.unm{font-weight:700;font-size:13px}.url{font-size:11px;color:var(--mu)}

/* ─── MAIN ─── */
.main{flex:1;display:flex;flex-direction:column;overflow:visible}
.topbar{height:58px;background:var(--sf);border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0;box-shadow:0 1px 0 var(--bd)}
.tb-bk{width:30px;height:30px;border-radius:8px;background:var(--bg);border:1.5px solid var(--bd);display:none;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--t2);transition:all .15s;flex-shrink:0}
.tb-bk:hover{background:var(--bd)}
.tb-ttl{font-family:'Nunito',sans-serif;font-weight:900;font-size:17px;flex:1;display:flex;align-items:center;gap:10px}
.tb-act{display:flex;gap:8px;align-items:center}
.cnt{flex:1;overflow-y:auto;padding:24px}

/* ─── VIEWS ─── */
.vw{display:none;animation:fu .22s ease}
.vw.on{display:block}
@keyframes fu{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:9px;font-family:'Nunito',sans-serif;font-weight:700;font-size:13px;cursor:pointer;border:none;transition:all .18s;line-height:1;white-space:nowrap}
.bp{background:var(--gr);color:#fff;box-shadow:0 3px 12px rgba(26,127,207,.28)}
.bp:hover{box-shadow:0 6px 20px rgba(26,127,207,.4);transform:translateY(-1px)}
.bg{background:transparent;color:var(--t2);border:1.5px solid var(--b2)}
.bg:hover{background:var(--bg);color:var(--tx);border-color:var(--mu)}
.bd{background:transparent;color:var(--red);border:1.5px solid #fed7d7}
.bd:hover{background:#fff5f5}
.bsm{padding:6px 12px;font-size:12px}
.ibt{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--bd);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .15s}
.ibt:hover{background:var(--bg)}
.nd{position:relative}.nd::after{content:'';position:absolute;top:5px;right:5px;width:7px;height:7px;background:#f56565;border-radius:50%;border:2px solid #fff}

/* ─── LAYOUT HELPERS ─── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gauto{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.flex{display:flex}.fac{align-items:center}.fj{justify-content:space-between}.fg{flex:1}.fgap{gap:10px}.fwrap{flex-wrap:wrap}
.col{display:flex;flex-direction:column}
.c2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}
.c3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:14px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.mb24{margin-bottom:24px}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.p0{padding:0}

/* ─── CARDS ─── */
.card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh)}
.ch{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--bd)}
.ch.nb{border-bottom:none;padding-bottom:0}
.ct{font-family:'Nunito',sans-serif;font-weight:800;font-size:14px;display:flex;align-items:center;gap:8px}
.cb{padding:16px 20px}
.cb.pt0{padding-top:0}

/* ─── STAT CARDS ─── */
.sc{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:16px 18px;box-shadow:var(--sh);position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s;cursor:pointer}
.sc:hover{transform:translateY(-2px);box-shadow:var(--sm)}
.sc::after{content:'';position:absolute;top:0;right:0;width:50px;height:50px;border-radius:0 var(--r) 0 50px;opacity:.08}
.sc.ct::after{background:var(--tl)}.sc.cb::after{background:var(--bl)}.sc.cg::after{background:#48bb78}.sc.co::after{background:#ed8936}.sc.cp::after{background:#9f7aea}.sc.cr::after{background:#f56565}
.si{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:10px}
.sc.ct .si{background:rgba(30,200,200,.1)}.sc.cb .si{background:rgba(26,127,207,.1)}.sc.cg .si{background:rgba(72,187,120,.1)}.sc.co .si{background:rgba(237,137,54,.1)}.sc.cp .si{background:rgba(159,122,234,.1)}.sc.cr .si{background:rgba(245,101,101,.1)}
.sn{font-family:'Nunito',sans-serif;font-weight:900;font-size:26px;line-height:1;margin-bottom:3px}
.sl{font-size:12px;color:var(--mu);font-weight:600}
.sd{font-size:11px;margin-top:2px}

/* ─── BADGES ─── */
.bdg{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;line-height:1.6}
.b-plan{background:#ebf8ff;color:#2b6cb0}.b-act{background:#f0fff4;color:#276749}
.b-done{background:#e9d8fd;color:#553c9a}.b-arch{background:#f7fafc;color:var(--mu);border:1px solid var(--bd)}
.b-urg{background:#fff5f5;color:#c53030}.b-high{background:#fffbeb;color:#b7791f}
.b-norm{background:#ebf8ff;color:#2b6cb0}.b-low{background:#f0fff4;color:#276749}
.b-pend{background:#fffbeb;color:#b7791f}.b-prog{background:#ebf8ff;color:#2b6cb0}
.b-ok{background:#f0fff4;color:#276749}.b-late{background:#fff5f5;color:#c53030}
.b-maint{background:#faf5ff;color:#6b46c1}.b-event{background:rgba(30,200,200,.1);color:var(--bl)}
.b-rsv{background:#fffbeb;color:#b7791f}.b-in{background:#f0fff4;color:#276749}
.b-sign{background:#f0fff4;color:#276749}.b-draft{background:#fffbeb;color:#b7791f}
.b-sent{background:#ebf8ff;color:#2b6cb0}.b-canc{background:#fff5f5;color:#c53030}

/* ─── PROGRESS ─── */
.pb{height:5px;background:var(--bd);border-radius:3px;overflow:hidden}
.pf{height:100%;border-radius:3px;background:var(--gr);transition:width .4s}
.pb.thick{height:8px}
.pf.green{background:linear-gradient(90deg,#48bb78,#38a169)}
.pf.orange{background:linear-gradient(90deg,#f6ad55,#dd6b20)}
.pf.red{background:linear-gradient(90deg,#fc8181,#e53e3e)}

/* ─── AVATAR GROUP ─── */
.avs{display:flex}
.av{width:24px;height:24px;border-radius:50%;border:2px solid #fff;margin-left:-5px;display:flex;align-items:center;justify-content:center;font-family:'Nunito',sans-serif;font-weight:800;font-size:9px;color:#fff;flex-shrink:0}
.av:first-child{margin-left:0}
.av-md{width:34px;height:34px;font-size:12px;margin-left:-7px}
.av-lg{width:42px;height:42px;font-size:14px;margin-left:0;border-radius:50%}

/* ─── FILTERS / SEARCH ─── */
.fbar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.fb{padding:5px 13px;border-radius:8px;font-size:12px;font-weight:700;border:1.5px solid var(--bd);background:#fff;color:var(--t2);cursor:pointer;transition:all .15s;font-family:'Nunito',sans-serif}
.fb:hover,.fb.on{border-color:var(--mi);color:var(--bl);background:var(--gs)}
.srch{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--bd);border-radius:10px;padding:8px 14px;flex:1}
.srch input{border:none;background:none;font-family:'Nunito Sans',sans-serif;font-size:13px;color:var(--tx);outline:none;flex:1}
.srch input::placeholder{color:var(--m2)}
.srch-row{display:flex;gap:10px;margin-bottom:16px}

/* ─── SECTION HEADER ─── */
.sh{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px}
.sh-t{font-family:'Nunito',sans-serif;font-weight:900;font-size:22px}
.sh-s{font-size:13px;color:var(--mu);margin-top:3px}
.sh-a{display:flex;gap:8px;flex-shrink:0;align-items:center}

/* ─── TABLE ─── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mu);padding:10px 16px;text-align:left;border-bottom:2px solid var(--bd);white-space:nowrap}
.tbl td{padding:11px 16px;font-size:13px;color:var(--t2);border-bottom:1px solid var(--bd);vertical-align:middle}
.tbl tbody tr{cursor:pointer;transition:background .12s}
.tbl tbody tr:hover td{background:var(--bg)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl td.bold{font-weight:700;color:var(--tx)}

/* ─── TABS ─── */
.tabs{display:flex;gap:2px;background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:4px;margin-bottom:18px;box-shadow:var(--sh);overflow-x:auto}
.tab{flex:1;padding:8px 4px;text-align:center;border-radius:8px;cursor:pointer;font-family:'Nunito',sans-serif;font-weight:700;font-size:11.5px;color:var(--mu);transition:all .15s;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:4px;min-width:70px}
.tab:hover{color:var(--t2);background:var(--bg)}
.tab.on{background:var(--gr);color:#fff;box-shadow:0 2px 8px rgba(26,127,207,.28)}
.tc{border-radius:10px;padding:1px 5px;font-size:10px;font-weight:800}
.tab.on .tc{background:rgba(255,255,255,.22)}.tab:not(.on) .tc{background:var(--bd);color:var(--mu)}
.tp{display:none}.tp.on{display:block;animation:fu .2s ease}

/* ─── FORM ─── */
.fg{margin-bottom:14px}
.lbl{display:block;font-size:11px;font-weight:700;color:var(--t2);letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px}
.inp,.sel,.ta{width:100%;padding:9px 12px;border:1.5px solid var(--bd);border-radius:9px;font-family:'Nunito Sans',sans-serif;font-size:13px;color:var(--tx);background:#fff;outline:none;appearance:none;transition:border-color .15s,box-shadow .15s}
.inp:focus,.sel:focus,.ta:focus{border-color:var(--mi);box-shadow:0 0 0 3px rgba(30,200,200,.12)}
.ta{min-height:72px;resize:vertical}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.pills{display:flex;flex-wrap:wrap;gap:6px}
.pill{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:700;border:2px solid var(--bd);color:var(--t2);cursor:pointer;transition:all .15s;background:#fff;user-select:none}
.pill.on{background:var(--gs);border-color:var(--mi);color:var(--bl)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--bd)}
.toggle-row:last-child{border-bottom:none}
.tgg{width:40px;height:22px;border-radius:11px;background:var(--bd);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.tgg.on{background:var(--gr)}
.tgg::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:2px;left:2px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.tgg.on::after{left:20px}

/* ─── DROP ZONE ─── */
.dz{border:2px dashed var(--b2);border-radius:12px;padding:26px 16px;text-align:center;cursor:pointer;transition:all .16s;background:var(--s2)}
.dz:hover,.dz.drag{border-color:var(--mi);background:var(--gs)}
.dz-ic{font-size:30px;margin-bottom:7px;opacity:.6}
.dz-t{font-family:'Nunito',sans-serif;font-weight:700;font-size:13px;margin-bottom:3px}
.dz-s{font-size:11.5px;color:var(--mu)}

/* ─── MODAL ─── */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.42);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:400;opacity:0;pointer-events:none;transition:opacity .18s}
.ov.on{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:16px;width:580px;max-height:88vh;overflow-y:auto;box-shadow:0 20px 64px rgba(0,0,0,.2);transform:translateY(18px) scale(.98);transition:transform .22s}
.ov.on .modal{transform:translateY(0) scale(1)}
.modal.sm{width:440px}.modal.lg{width:720px}.modal.xl{width:860px}
.mh{padding:18px 24px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}
.mt{font-family:'Nunito',sans-serif;font-weight:900;font-size:16px}
.mcl{width:28px;height:28px;border-radius:7px;border:none;background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--mu);transition:all .15s}
.mcl:hover{background:var(--bd)}
.mb{padding:20px 24px}
.mf{padding:12px 24px 18px;display:flex;justify-content:flex-end;gap:8px;border-top:1px solid var(--bd)}

/* ─── HERO BANNER ─── */
.hero{background:var(--gr);border-radius:var(--r);padding:24px 28px;color:#fff;position:relative;overflow:hidden;margin-bottom:20px;box-shadow:var(--sl)}
.hero::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.07)}
.hero::after{content:'';position:absolute;bottom:-50px;right:100px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.04)}
.h-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:12px;position:relative;z-index:1}
.h-nm{font-family:'Nunito',sans-serif;font-weight:900;font-size:24px;line-height:1.1;margin-bottom:4px}
.h-sub{font-size:13px;opacity:.85}
.h-btns{display:flex;gap:7px;flex-shrink:0}
.h-btn{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(8px);padding:6px 13px;border-radius:8px;font-family:'Nunito',sans-serif;font-weight:700;font-size:12px;cursor:pointer;transition:all .15s}
.h-btn:hover{background:rgba(255,255,255,.3)}
.h-chips{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1}
.hc{background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;flex:1;min-width:100px}
.hc-l{font-size:10px;font-weight:700;opacity:.75;text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px}
.hc-v{font-family:'Nunito',sans-serif;font-weight:800;font-size:14px}
.hc-d{font-size:11px;opacity:.8}

/* ─── MISC ─── */
.empty{text-align:center;padding:36px 16px;color:var(--mu)}
.ei{font-size:36px;margin-bottom:8px;opacity:.5}
.et{font-size:13px;font-weight:600;margin-bottom:12px}
.sep{height:1px;background:var(--bd);margin:12px 0}
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600;background:var(--s2);border:1px solid var(--bd);color:var(--t2)}
.warn-box{background:#fffbeb;border:1px solid #f6e05e;border-radius:10px;padding:12px 16px;font-size:12.5px;color:#744210;display:flex;align-items:flex-start;gap:8px}
.info-box{background:#ebf8ff;border:1px solid #90cdf4;border-radius:10px;padding:12px 16px;font-size:12.5px;color:#2c5282;display:flex;align-items:flex-start;gap:8px}
.suc-box{background:#f0fff4;border:1px solid #9ae6b4;border-radius:10px;padding:12px 16px;font-size:12.5px;color:#1c4532;display:flex;align-items:flex-start;gap:8px}

/* ─── TOAST ─── */
.toast-el{position:fixed;bottom:22px;right:22px;background:var(--tx);color:#fff;padding:11px 18px;border-radius:10px;font-family:'Nunito',sans-serif;font-weight:700;font-size:13px;box-shadow:var(--sl);z-index:9999;transform:translateY(60px);opacity:0;transition:all .28s;display:flex;align-items:center;gap:7px}
.toast-el.on{transform:translateY(0);opacity:1}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:3px}

/* ─── CALENDAR ─── */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-day-h{text-align:center;font-size:11px;font-weight:700;color:var(--mu);padding:6px 0}
.cal-day{min-height:72px;min-width:0;overflow:hidden;background:var(--sf);border:1px solid var(--bd);border-radius:8px;padding:6px;transition:all .15s;cursor:pointer}
.cal-day:hover{border-color:var(--mi);background:var(--gs)}
.cal-day.today{border-color:var(--bl);background:rgba(26,127,207,.04)}
.cal-day.other-month{opacity:.4}
.cal-day.feriado{background:rgba(229,62,62,.04);border-color:#fed7d7}
.cal-dn{font-size:12px;font-weight:700;margin-bottom:4px}
.cal-day.today .cal-dn{color:var(--bl)}
.cal-day.feriado .cal-dn{color:#e53e3e}
.cal-feriado{font-size:9px;font-weight:800;color:#e53e3e;text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;line-height:1.2}
.cal-ev{font-size:10px;font-weight:700;padding:2px 4px;margin:0 -6px 2px;border-radius:0;white-space:normal;word-break:break-word;overflow:hidden;min-height:15px;line-height:1.3}
.cal-ev.ev-solo{border-radius:4px;margin-left:0;margin-right:0}
.cal-ev.ev-start{border-radius:4px 0 0 4px;margin-left:0}
.cal-ev.ev-end{border-radius:0 4px 4px 0;margin-right:0}
.cal-ev.mount{background:#ede9fe;color:#5b21b6}
.cal-ev.event{background:#dcfce7;color:#15803d}
.cal-ev.demount{background:#ffedd5;color:#c2410c}

/* ─── CHECKLIST CATEGORIES GRID ─── */
.cl-cats-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ─── INVENTORY ─── */
.inv-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden;transition:all .18s;cursor:pointer}
.inv-card:hover{transform:translateY(-2px);box-shadow:var(--sm);border-color:rgba(30,200,200,.3)}
.inv-img{height:110px;display:flex;align-items:center;justify-content:center;font-size:44px;background:var(--s3);position:relative}
.inv-status-dot{position:absolute;top:8px;right:8px;width:10px;height:10px;border-radius:50%;border:2px solid #fff}
.inv-body{padding:12px 14px}
.inv-name{font-family:'Nunito',sans-serif;font-weight:800;font-size:13px;margin-bottom:3px}
.inv-code{font-size:11px;color:var(--mu);margin-bottom:6px}
.inv-meta{display:flex;justify-content:space-between;align-items:center}
.inv-qty{font-family:'Nunito',sans-serif;font-weight:900;font-size:18px;color:var(--tx)}
.inv-qtl{font-size:10px;color:var(--mu)}

/* ─── KANBAN ─── */
.kan{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}
.kcol{background:var(--s2);border:1px solid var(--bd);border-radius:12px;padding:12px}
.kch{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.kct{font-family:'Nunito',sans-serif;font-weight:800;font-size:13px;display:flex;align-items:center;gap:7px}
.kcn{width:20px;height:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff}
.ktk{background:var(--sf);border:1px solid var(--bd);border-radius:9px;padding:12px;margin-bottom:8px;box-shadow:0 1px 4px rgba(0,0,0,.05);transition:all .15s;cursor:pointer}
.ktk:hover{box-shadow:var(--sm);border-color:rgba(26,127,207,.2)}
.ktk-t{font-weight:700;font-size:12.5px;margin-bottom:6px}
.ktk-m{display:flex;align-items:center;justify-content:space-between}

/* ─── GANTT / TIMELINE ─── */
.gantt-row{display:flex;align-items:center;gap:0;margin-bottom:4px;min-height:36px}
.gantt-label{width:160px;flex-shrink:0;font-size:12px;font-weight:700;color:var(--t2);padding:4px 10px 4px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-track{flex:1;position:relative;height:28px}
.gantt-bar{position:absolute;height:22px;top:3px;border-radius:6px;display:flex;align-items:center;padding:0 8px;font-size:10px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .2s}

/* ─── CONTRACT CARD ─── */
.ctr-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);transition:all .18s;cursor:pointer;overflow:hidden}
.ctr-card:hover{transform:translateY(-2px);box-shadow:var(--sm)}
.ctr-side{width:4px;border-radius:4px 0 0 4px}
.ctr-body{padding:14px 16px}

/* ─── SUPPLIER CARD ─── */
.sup-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);padding:16px 18px;transition:all .18s;cursor:pointer}
.sup-card:hover{transform:translateY(-2px);box-shadow:var(--sm)}

/* ─── CHART BARS (pure CSS) ─── */
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:100px}
.bc-bar{flex:1;border-radius:6px 6px 0 0;position:relative;min-height:4px;transition:height .6s ease;cursor:pointer}
.bc-bar::after{content:attr(data-val);position:absolute;top:-18px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:800;color:var(--t2);white-space:nowrap}
.bc-label{font-size:10px;color:var(--mu);text-align:center;margin-top:4px;font-weight:600}

/* ─── PERM MATRIX ─── */
.perm-tbl{width:100%;border-collapse:collapse}
.perm-tbl th{font-size:11px;font-weight:700;color:var(--mu);padding:8px 12px;text-align:center;border-bottom:2px solid var(--bd)}
.perm-tbl th:first-child{text-align:left}
.perm-tbl td{padding:8px 12px;border-bottom:1px solid var(--bd);text-align:center;vertical-align:middle}
.perm-tbl td:first-child{text-align:left;font-weight:600;font-size:12.5px}
.perm-tbl tbody tr:hover td{background:var(--bg)}

    @keyframes shake {
      0%,100%{transform:translateX(0)}
      20%,60%{transform:translateX(-8px)}
      40%,80%{transform:translateX(8px)}
    }

/* ─── MOBILE ─── */
#sb-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.46);z-index:399;-webkit-tap-highlight-color:transparent}
.tb-ham{display:none;width:32px;height:32px;border-radius:8px;border:1.5px solid var(--bd);background:#fff;align-items:center;justify-content:center;cursor:pointer;font-size:18px;flex-shrink:0;color:var(--t2);-webkit-tap-highlight-color:transparent}
/* ─── TABLET (769px – 1024px) ─── */
@media(min-width:769px) and (max-width:1024px){
  :root{--sw:196px}
  .cnt{padding:16px}
  /* Grids */
  .g3{grid-template-columns:1fr 1fr}
  .g4{grid-template-columns:1fr 1fr}
  .c3{grid-template-columns:1fr 1fr}
  /* Kanban 2 colunas */
  .kan{grid-template-columns:1fr 1fr}
  /* Seção header compacto */
  .sh-t{font-size:20px}
  .sh-a{flex-wrap:wrap;gap:6px}
  /* Topbar */
  .topbar{padding:0 16px}
  /* Calendário */
  .cal-day{min-height:60px}
}

@media(max-width:768px){
  /* Sidebar → drawer deslizante */
  .sb{position:fixed;left:0;top:0;bottom:0;width:82%;max-width:288px;z-index:400;transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);border-right:none;box-shadow:none}
  .sb.mob-open{transform:translateX(0);box-shadow:6px 0 40px rgba(0,0,0,.2)}
  #sb-backdrop.on{display:block}
  /* Main ocupa largura total */
  .main{width:100%;min-width:0}
  /* Topbar compacto */
  .topbar{padding:0 10px;height:52px;gap:8px}
  .tb-ham{display:flex}
  .tb-ttl{gap:6px;font-size:15px;min-width:0;flex:1}
  #tb-btn{font-size:12px;padding:6px 11px}
  #tb-ttl-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  /* Conteúdo com padding para a nav inferior */
  .cnt{padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}
  /* Grids responsivos */
  .g2{grid-template-columns:1fr 1fr}
  .g3{grid-template-columns:1fr}
  .g4{grid-template-columns:1fr}
  .c2,.c3{grid-template-columns:1fr}
  .fr{grid-template-columns:1fr}
  .fr3{grid-template-columns:1fr}
  /* Kanban → 1 coluna */
  .kan{grid-template-columns:1fr}
  /* Cards */
  .ch{padding:12px 14px}
  .cb{padding:12px 14px;overflow-x:auto;-webkit-overflow-scrolling:touch}
  /* Tabelas com scroll horizontal */
  .tbl{min-width:480px}
  /* Cabeçalhos de seção */
  .sh{flex-direction:column;gap:8px;margin-bottom:14px}
  .sh-t{font-size:18px}
  .sh-a{width:100%;flex-wrap:wrap;gap:6px}
  .sh-a .btn{flex:1;justify-content:center;font-size:12px;padding:7px 10px}
  /* Linha de busca */
  .srch-row{flex-direction:column}
  /* Modais → bottom sheet */
  .ov{align-items:flex-end}
  .modal{width:100%;max-width:100%;border-radius:20px 20px 0 0;max-height:92vh;margin:0}
  .modal.sm,.modal.lg,.modal.xl{width:100%;max-width:100%}
  /* Toast acima da nav */
  .toast-el{bottom:70px;right:12px;left:12px;justify-content:center;text-align:center}
  /* Events grid — 1 coluna */
  .ev-grid{grid-template-columns:1fr!important}
  /* Event card */
  .ev-card-nm{overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;white-space:normal}
  /* Hero mobile */
  .hero{padding:14px}
  .h-top{flex-direction:column;gap:8px;align-items:flex-start}
  .h-btns{width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:2px}
  .h-btn{font-size:11px;padding:5px 10px;white-space:nowrap;flex-shrink:0}
  .h-nm{font-size:18px!important}
  .h-sub{font-size:12px!important}
  .hc{min-width:100%;flex:1 1 100%}
  /* Calendário: scroll horizontal com largura mínima confortável */
  .cal-grid{min-width:420px}
  #cal-export-card .cb{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-left:8px;padding-right:8px}
  .cal-day{min-height:52px;padding:4px}
  .cal-dn{font-size:11px;margin-bottom:2px}
  .cal-ev{font-size:8px;padding:1px 2px;white-space:nowrap;text-overflow:ellipsis}
  .cal-day-h{font-size:9px;padding:3px 0}
  /* Tabs scroll suave */
  .tabs{-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
  .tab{scroll-snap-align:start}
  /* Esconde tabs no mobile — nav inferior assume essa função */
  #ev-tabs{display:none}
  /* Checklist categorias → 1 coluna */
  .cl-cats-grid{grid-template-columns:1fr}
  /* Checklist item: observações sem min-width fixo */
  .cl-cats-grid input[placeholder="Observações..."]{min-width:60px}
  /* Stat cards: texto menor */
  .sn{font-size:22px}
  .sl{font-size:11px}
  /* Filtros em scroll horizontal */
  .fbar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;margin-bottom:10px}
  .fb{flex-shrink:0}
}

@keyframes splash-bar{0%{width:0;margin-left:0}50%{width:100%;margin-left:0}100%{width:0;margin-left:100%}}
