:root{
  --navy:#0e2350; --navy2:#0a1838; --blue:#2f6df0; --blue-d:#1b49c0; --blue-l:#6fa0f5;
  --gold:#e0a93d; --teal:#1fb6a6; --green:#1faa59; --red:#e0533d; --orange:#f0902f; --purple:#7b54d4;
  --bg1:#eef1f9; --bg2:#e4e9f5; --card:#ffffff; --text:#16203f; --muted:#7e89aa; --line:#e9edf7;
  --sh-sm:0 1px 2px rgba(16,32,80,.05);
  --sh:0 6px 18px rgba(16,32,80,.07),0 2px 5px rgba(16,32,80,.05);
  --sh-lg:0 22px 48px rgba(16,32,80,.18),0 6px 14px rgba(16,32,80,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Montserrat',system-ui,Arial,sans-serif;background:linear-gradient(165deg,var(--bg1),var(--bg2));color:var(--text);font-size:14px;min-height:100vh}
a{text-decoration:none;color:inherit}
.app{display:grid;grid-template-columns:250px 1fr;min-height:100vh;transition:grid-template-columns .26s cubic-bezier(.4,0,.2,1)}
.app.collapsed{grid-template-columns:76px 1fr}

/* SIDEBAR */
.sidebar{background:linear-gradient(180deg,#16306e,var(--navy) 45%,var(--navy2));color:#fff;position:fixed;inset:0 auto 0 0;width:250px;height:100dvh;padding:20px 14px;display:flex;flex-direction:column;gap:5px;box-shadow:4px 0 24px rgba(10,24,56,.25);z-index:30;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.28) transparent}
.sidebar::-webkit-scrollbar{width:7px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.24);border-radius:999px}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 18px;white-space:nowrap}
.logo{width:44px;height:44px;border-radius:13px;background:linear-gradient(135deg,#fff,#dfe7fb);color:var(--navy);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;letter-spacing:-1px;flex-shrink:0;box-shadow:0 6px 16px rgba(0,0,0,.3),inset 0 1px 1px #fff}
.brand h1{font-size:13.5px;font-weight:800;line-height:1.15;letter-spacing:.4px}
.brand p{font-size:9px;color:#9fb0d8;font-weight:500;letter-spacing:1.6px;text-transform:uppercase;margin-top:3px}
.nav-label{font-size:9.5px;color:#6f83b8;text-transform:uppercase;letter-spacing:1.6px;margin:15px 12px 5px;font-weight:700;white-space:nowrap}
.nav-item{display:flex;align-items:center;gap:13px;padding:11px 12px;border-radius:12px;color:#c3cfee;cursor:pointer;font-weight:500;transition:.18s;font-size:13.5px;white-space:nowrap;position:relative}
.nav-item svg{width:19px;height:19px;flex-shrink:0;opacity:.92}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:linear-gradient(95deg,var(--blue),var(--blue-d));color:#fff;box-shadow:0 8px 20px rgba(47,109,240,.45),inset 0 1px 1px rgba(255,255,255,.25)}
.side-foot{margin-top:auto;padding:14px 12px 2px;border-top:1px solid rgba(255,255,255,.1);font-size:11px;color:#8497c4;white-space:nowrap}
.app.collapsed .brand h1,.app.collapsed .brand p,.app.collapsed .nav-item .tx,.app.collapsed .nav-label,.app.collapsed .side-foot{display:none}
.app.collapsed .sidebar{width:76px}
.app.collapsed .nav-item{justify-content:center;padding:12px}
.app.collapsed .brand{justify-content:center;padding:6px 0 18px}

/* MAIN */
.main{grid-column:2;display:flex;flex-direction:column;min-width:0}
.topbar{background:#fff;position:sticky;top:0;z-index:25;display:flex;align-items:center;justify-content:space-between;padding:13px 26px;border-bottom:1px solid var(--line);box-shadow:0 2px 12px rgba(16,32,80,.05)}
.tb-left{display:flex;align-items:center;gap:16px}
.burger{width:40px;height:40px;border-radius:11px;border:none;background:#eef1fa;cursor:pointer;display:grid;place-items:center;transition:.15s;color:var(--navy)}
.burger:hover{background:#e2e8f8;transform:translateY(-1px)}
.topbar h2{font-size:18.5px;font-weight:800;letter-spacing:-.3px}
.topbar .crumb{font-size:11.5px;color:var(--muted);margin-top:2px;font-weight:500}
.top-right{display:flex;align-items:center;gap:16px}
.seg{display:inline-flex;background:#e8edf8;border-radius:12px;padding:4px;box-shadow:inset 0 1px 3px rgba(16,32,80,.08)}
.seg button{border:none;background:none;font-family:inherit;font-size:12px;font-weight:700;color:var(--muted);padding:7px 14px;border-radius:9px;cursor:pointer;transition:.15s}
.seg button.active{background:#fff;color:var(--navy);box-shadow:var(--sh-sm),0 2px 6px rgba(16,32,80,.1)}
.datenav{display:inline-flex;align-items:center;gap:3px;background:#eef1fa;border-radius:11px;padding:3px;position:relative}
.datenav button{border:none;background:none;font-family:inherit;font-size:18px;font-weight:800;color:var(--navy);width:30px;height:30px;border-radius:8px;cursor:pointer;line-height:1;display:grid;place-items:center}
.datenav button:hover{background:#fff;box-shadow:var(--sh-sm)}
.datenav .lbl{font-size:12px;font-weight:700;color:var(--text);min-width:128px;text-align:center;text-transform:capitalize}
.datenav .calbtn svg{width:16px;height:16px}
.calpop{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-lg);padding:14px;z-index:60;width:262px;display:none}
.calpop.open{display:block}
.calhead{display:flex;gap:8px;margin-bottom:10px}
.calhead select{flex:1;font-family:inherit;font-weight:700;font-size:12px;padding:8px;border:1.5px solid var(--line);border-radius:9px;background:#f8faff;color:var(--text);cursor:pointer}
.calgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.calgrid .cdow{font-size:9px;font-weight:800;color:var(--muted);text-align:center;padding:3px 0}
.calgrid .cday{font-size:12px;font-weight:600;text-align:center;padding:7px 0;border-radius:8px;cursor:pointer;color:var(--text)}
.calgrid .cday:hover{background:#eef1fa}
.calgrid .cday.sel{background:var(--blue);color:#fff;font-weight:800}
.calgrid .cday.empty{cursor:default}
.calfoot{display:flex;gap:8px;margin-top:11px}
.calfoot button{flex:1;font-family:inherit;font-size:11px;font-weight:700;padding:9px;border:1px solid var(--line);border-radius:9px;background:#eef1fa;color:var(--navy);cursor:pointer}
.calfoot button:hover{background:#e2e8f8}
.fc-banner{background:linear-gradient(90deg,#eef4ff,#fff);border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:0 12px 12px 0;padding:14px 18px;font-size:12.5px;font-weight:500;color:#41507a;margin-bottom:22px}
.autopills{display:flex;flex-wrap:wrap;gap:10px}
.autopill{background:linear-gradient(165deg,#f3f8ff,#fff);border:1px solid var(--line);border-radius:13px;padding:12px 16px;min-width:96px;box-shadow:0 2px 6px rgba(20,40,90,.04)}
.autopill .n{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.autopill .v{font-size:19px;font-weight:800;margin-top:3px}
.chipset{display:flex;flex-wrap:wrap;gap:8px}
.chipsel{padding:8px 15px;border-radius:20px;font-size:12px;font-weight:600;background:#eef1fa;color:#5a6a92;cursor:pointer;border:1.5px solid transparent;user-select:none;transition:.12s}
.chipsel:hover{background:#e2e8f8}
.chipsel.on{background:#e7eefe;color:#2052c0;border-color:var(--blue)}
.objcount{display:inline-flex;align-items:center;gap:3px;background:#e7eefe;color:#2052c0;padding:7px 13px;border-radius:20px;font-size:12px;font-weight:700;margin:0 8px 8px 0}.objcount b{font-weight:800}
.fld{display:flex;flex-direction:column;gap:6px;font-size:11px;font-weight:700;color:var(--muted)}
.fld input,.fld select,.fld textarea{font-family:inherit;font-size:13px;font-weight:600;color:var(--text);padding:10px 13px;border:1.5px solid var(--line);border-radius:11px;background:#f8faff;width:100%;transition:border-color .15s,box-shadow .15s,background .15s}
.fld textarea{min-height:64px;resize:vertical}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(47,109,240,.1)}
.fcrow{display:grid;grid-template-columns:1.3fr auto 1.7fr;gap:13px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}
.fcrow:last-child{border:none}
.fcrow .cli{font-weight:700;font-size:13px}.fcrow .cli small{display:block;color:var(--muted);font-weight:600;font-size:11px}
.miniseg{display:inline-flex;background:#eef1fa;border-radius:9px;padding:3px}
.miniseg button{border:none;background:none;font-family:inherit;font-size:11.5px;font-weight:700;color:var(--muted);padding:6px 13px;border-radius:7px;cursor:pointer}
.miniseg button.on-y{background:var(--green);color:#fff}.miniseg button.on-n{background:var(--red);color:#fff}
.det-sim{display:grid;grid-template-columns:1.5fr .8fr;gap:8px}
.det select,.det input{font-family:inherit;font-size:12.5px;font-weight:600;color:var(--text);padding:8px 10px;border:1.5px solid var(--line);border-radius:9px;background:#f8faff;width:100%}
.switch{display:inline-flex;align-items:center;gap:11px;cursor:pointer;font-weight:700;font-size:13px;user-select:none}
.switch .tg{width:42px;height:24px;border-radius:20px;background:#cfd8ee;position:relative;transition:.15s;flex-shrink:0}
.switch .tg::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.15s;box-shadow:var(--sh-sm)}
.switch.on .tg{background:var(--green)}.switch.on .tg::after{left:21px}
.fc-grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fc-save{display:flex;justify-content:flex-end;gap:12px;margin-top:12px;padding-top:20px;border-top:1px solid var(--line)}
.fc-status{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.4px}
.fc-status::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.fc-status.aberto{background:#fff4e5;color:#b9772a}
.fc-status.rascunho{background:#eef1fa;color:#5a6a92}
.fc-status.fechado{background:#e7f7ee;color:#1e9e5a}
.fc-status.vazio{background:#f0f2f7;color:#8a93a8}
.fc-sublabel{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:18px 0 10px}
.fc-sublabel span{display:block;text-transform:none;letter-spacing:0;font-weight:600;font-size:11px;color:#9aa3b8;margin-top:3px}
.fc-tag{display:inline-block;background:#eef4ff;color:#3a5a9a;font-size:10px;font-weight:800;padding:2px 7px;border-radius:6px;margin-left:8px;vertical-align:1px}
.fc-valid{background:#fdf2f2;border:1px solid #f3c9c9;border-left:4px solid var(--red);border-radius:0 12px 12px 0;padding:13px 16px;font-size:12.5px;font-weight:600;color:#b0463a;margin-bottom:14px;line-height:1.7}
.fc-valid b{font-weight:800}
.fc-empty{text-align:center;padding:38px 20px;color:var(--muted)}
.fc-empty svg{width:46px;height:46px;stroke:#c4ccdc;fill:none;margin-bottom:12px}
.fc-empty h4{margin:0 0 6px;font-size:16px;color:var(--text)}
.fc-empty p{margin:0;font-size:13px;max-width:360px;margin-inline:auto;line-height:1.6}
.fc-toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:#16223e;color:#fff;padding:13px 22px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 14px 34px rgba(0,0,0,.28);opacity:0;pointer-events:none;transition:.25s;z-index:200;display:flex;align-items:center;gap:9px}
.fc-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.fc-toast svg{width:18px;height:18px;stroke:#4ade80;fill:none}
.fc2{padding:17px 19px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(170deg,#fbfcff,#fff);margin-bottom:12px;transition:border-color .15s,box-shadow .15s}
.fc2:last-child{margin-bottom:0}
.fc2:hover{border-color:#d3e0f7;box-shadow:0 5px 16px rgba(20,40,90,.06)}
.fc2-top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.fc2 .cli{font-weight:700;font-size:13px;color:var(--text)}
.fc2 .cli small{display:block;color:var(--muted);font-weight:600;font-size:11px;margin-top:3px}
.fc-tag.pick{cursor:pointer;transition:.12s}
.fc-tag.pick:hover{background:#dbe6ff;box-shadow:0 0 0 1px var(--blue-l) inset}
.fc-tag.empty{background:#fff4e5;color:#b9772a}
.fc-pop{position:absolute;z-index:60;background:#fff;border:1px solid var(--line);border-radius:11px;box-shadow:0 14px 32px rgba(20,30,60,.18);padding:6px;min-width:160px}
.fc-pop button{display:block;width:100%;text-align:left;border:none;background:none;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--text);padding:9px 12px;border-radius:8px;cursor:pointer}
.fc-pop button:hover{background:#eef3ff;color:var(--blue-d)}
.fc-pop button.sel{background:#e7eefe;color:var(--blue-d)}
.fc-pop button.np{color:var(--muted);border-top:1px solid var(--line);margin-top:3px;padding-top:9px}
.prosp-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr .7fr;gap:9px 12px;align-items:center}
.prosp-h{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);padding-bottom:3px}
.prosp-h.r{text-align:center}
.prosp-canal{font-size:13px;font-weight:700;color:var(--text)}
.prosp-grid input.prosp-in{font-family:inherit;font-size:13px;font-weight:600;color:var(--text);padding:8px;border:1.5px solid var(--line);border-radius:9px;background:#f8faff;width:100%;text-align:center}
.prosp-grid input.prosp-in:focus{outline:none;border-color:var(--blue);background:#fff}
.prosp-taxa{font-size:13px;font-weight:800;color:var(--blue-d);text-align:center}
.prosp-tot{font-size:13px;font-weight:800;color:var(--text);text-align:center}
.prosp-tline{border-top:1.5px solid var(--line);padding-top:11px;margin-top:3px}
.autopills.g3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}
.autopills.g2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
.autopills.g3 .autopill,.autopills.g2 .autopill{min-width:0}
.autopills.g6{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}
.autopills.g6 .autopill{min-width:0;padding:9px 9px}
.autopills.g6 .autopill .n{font-size:9px;letter-spacing:.2px}
.fcage-row{display:grid;grid-template-columns:2.6fr 1fr;gap:16px;align-items:start}
@media(max-width:1050px){.fcage-row{grid-template-columns:1fr}}
.profcount{display:inline-flex;align-items:center;gap:5px;background:#e7f7ee;color:#1e9e5a;padding:7px 13px;border-radius:20px;font-size:12px;font-weight:700;margin:0 8px 8px 0}
.profcount b{font-weight:800;font-size:13px}
.profcount.aguard{background:#fff4e5;color:#b9772a}
.prof-src{font-size:11.5px;color:var(--muted);font-weight:600;margin-top:2px}
.prof-add{margin-top:15px;display:flex;align-items:center;flex-wrap:wrap;gap:8px;border-top:1px solid var(--line);padding-top:14px}
.prof-add-lbl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-right:2px}
.prof-add-btn{cursor:pointer;background:#eef1fa;color:#5a6a92;border:1.5px solid transparent;padding:7px 13px;border-radius:20px;font-size:12px;font-weight:600;user-select:none;transition:.12s}
.prof-add-btn:hover{background:#e7eefe;color:#2052c0;border-color:var(--blue-l)}
.profcount.manual{background:#eef1fa;color:#5a6a92;padding-right:7px}
.prof-x{border:none;background:none;color:#9aa3b8;font-size:15px;font-weight:800;line-height:1;cursor:pointer;padding:0 1px 0 5px;margin-left:1px}
.prof-x:hover{color:var(--red)}
.decband{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
@media(max-width:1100px){.decband{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.decband{grid-template-columns:1fr}}
@media(max-width:600px){.ds-body{grid-template-columns:1fr}.ds-metric{justify-self:stretch;align-items:flex-start;text-align:left;min-width:0}}
.deccard{border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:13px;padding:14px 16px;background:#fcfdff}
.deccard.warn{border-left-color:var(--orange)}
.deccard.bad{border-left-color:var(--red)}
.deccard.ok{border-left-color:var(--green)}
.deccard .dl{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.deccard .dv{font-size:17px;font-weight:800;color:var(--text);margin:7px 0 5px}
.deccard .dd{font-size:12px;font-weight:600;color:#5a6a92;line-height:1.45}
.deccard .da{font-size:11.5px;font-weight:800;color:var(--blue-d);margin-top:9px;cursor:pointer;display:inline-block}
.deccard .da:hover{text-decoration:underline}
.vitals{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
@media(max-width:900px){.vitals{grid-template-columns:repeat(2,1fr)}}
.vital{border:1px solid var(--line);border-radius:12px;padding:12px 15px;background:#fff}
.vital .vn{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--muted)}
.vital .vrow{display:flex;align-items:baseline;justify-content:space-between;margin:6px 0 9px;gap:8px}
.vital .vv{font-size:20px;font-weight:800;color:var(--text)}
.vital .vd{font-size:12px;font-weight:800;white-space:nowrap}
.vital .vd.up{color:var(--green)}.vital .vd.down{color:var(--red)}
.vital svg.spark2{width:100%;height:34px;display:block}
.dh{position:relative;overflow:hidden;border-radius:20px;padding:28px 32px;background:linear-gradient(135deg,#0c1d44,#0a1838 55%,#11254f);color:#fff;box-shadow:0 18px 50px rgba(10,24,56,.32)}
.dh-glow{position:absolute;top:-90px;right:-50px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(224,169,61,.20),transparent 70%);pointer-events:none}
.dh-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;position:relative;z-index:1}
.dh-eyebrow{font-size:11px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:#8095c0}
.dh-status{font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#f3c468;background:rgba(224,169,61,.13);border:1px solid rgba(224,169,61,.32);padding:5px 14px;border-radius:20px;display:inline-flex;align-items:center;gap:8px}
.dh-status::before{content:"";width:6px;height:6px;border-radius:50%;background:#f0902f;box-shadow:0 0 0 3px rgba(240,144,47,.25)}
.dh-status.ahead{color:#5fd3c6;background:rgba(31,182,166,.13);border-color:rgba(31,182,166,.32)}
.dh-status.ahead::before{background:#1fb6a6;box-shadow:0 0 0 3px rgba(31,182,166,.25)}
.dh-body{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;align-items:center;margin:24px 0;position:relative;z-index:1}
@media(max-width:860px){.dh-body{grid-template-columns:1fr;gap:20px}}
.dh-figure{display:flex;flex-direction:column}
.dh-flabel{font-size:11.5px;font-weight:600;color:#8095c0;text-transform:uppercase;letter-spacing:.9px}
.dh-fnum{font-size:56px;font-weight:800;line-height:1;letter-spacing:-1.5px;color:#f0c674;margin:9px 0 13px}
.dh-fnum i{font-size:34px;font-weight:600;font-style:normal;color:#c79c4d;letter-spacing:0}
.dh-fsub{font-size:13px;font-weight:500;color:#a6b4d4;line-height:1.6;max-width:450px}
.dh-stats{display:flex;flex-direction:column;border-left:1px solid rgba(255,255,255,.1);padding-left:28px}
@media(max-width:860px){.dh-stats{border-left:none;border-top:1px solid rgba(255,255,255,.1);padding-left:0;padding-top:14px}}
.dh-stat{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.dh-stat:last-child{border:none}
.dh-stat .l{font-size:12px;font-weight:600;color:#8095c0}
.dh-stat .v{font-size:18px;font-weight:800;color:#fff;white-space:nowrap}
.dh-stat .v.gold{color:#f0c674}
.dh-stat .v i{font-size:11px;font-weight:600;font-style:normal;color:#8095c0}
.dh-track{position:relative;z-index:1;display:flex;height:9px;border-radius:6px;overflow:hidden;background:rgba(255,255,255,.1);margin-bottom:13px}
.dh-track>div{height:100%}
.dh-real{background:linear-gradient(90deg,#d99e37,#f0c674)}
.dh-proj{background:repeating-linear-gradient(45deg,rgba(224,169,61,.4) 0,rgba(224,169,61,.4) 5px,rgba(224,169,61,.13) 5px,rgba(224,169,61,.13) 10px)}
.dh-leg{position:relative;z-index:1;display:flex;gap:22px;flex-wrap:wrap;font-size:11.5px;font-weight:600;color:#8095c0}
.dh-leg i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:6px}
.dh-leg .real{background:#e0a93d}.dh-leg .proj{background:rgba(224,169,61,.42)}.dh-leg .meta{background:#5e74a8}
.df{position:relative;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 4px 16px rgba(20,40,90,.05);transition:.2s;overflow:hidden}
.df:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(20,40,90,.12)}
.df::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--blue)}
.df.bad::before{background:var(--red)}.df.warn::before{background:var(--orange)}
.df-h{display:flex;align-items:center;gap:10px;margin-bottom:15px}
.df-ic{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:#eef3ff;flex:none}
.df-ic svg{width:18px;height:18px;stroke:var(--blue-d);fill:none;stroke-width:2}
.df.bad .df-ic{background:#fdecea}.df.bad .df-ic svg{stroke:var(--red)}
.df.warn .df-ic{background:#fff4e5}.df.warn .df-ic svg{stroke:var(--orange)}
.df-lbl{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.df-focal{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.3px;margin-bottom:9px}
.df-focal small{font-size:13px;font-weight:700;color:var(--muted);letter-spacing:0}
.df p{font-size:12.5px;color:#5a6a92;font-weight:500;line-height:1.5;margin:0 0 16px}
.df p b{color:var(--text);font-weight:700}
.df-act{font-size:12px;font-weight:800;color:var(--blue-d);cursor:pointer;display:inline-block}
.df-act:hover{text-decoration:underline}
.ds{display:flex;flex-direction:column}
.ds-row{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line)}
.ds-row:last-child{border:none}
.ds-ic{flex:none;width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center}
.ds-row>div{min-width:0;flex:1}
.ds-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(160px,210px);gap:16px;align-items:center}
.ds-main{min-width:0}
.ds-metric{justify-self:end;display:flex;flex-direction:column;align-items:flex-end;gap:4px;padding:9px 12px;border-radius:12px;background:#f5f8ff;border:1px solid var(--line);min-width:160px;text-align:right}
.ds-metric strong{font-size:19px;line-height:1;font-weight:900;color:var(--text);letter-spacing:-.2px}
.ds-metric em{font-style:normal;font-size:10.5px;line-height:1.25;font-weight:800;color:#637298}
.ds-row.up .ds-metric{background:#edf9f3;border-color:#cfeedd}.ds-row.up .ds-metric em{color:#168449}
.ds-row.down .ds-metric{background:#fff1ef;border-color:#f5d2ce}.ds-row.down .ds-metric em{color:#ba493d}
.ds-row.watch .ds-metric{background:#fff8eb;border-color:#f3dfb9}.ds-row.watch .ds-metric em{color:#a06a13}
.ds-ic svg{width:19px;height:19px;fill:none;stroke-width:2.3}
.ds-row.up .ds-ic{background:#e7f7ee}.ds-row.up .ds-ic svg{stroke:var(--green)}
.ds-row.down .ds-ic{background:#fdecea}.ds-row.down .ds-ic svg{stroke:var(--red)}
.ds-row.watch .ds-ic{background:#fff4e5}.ds-row.watch .ds-ic svg{stroke:var(--orange)}
.ds-row b{display:block;font-size:13.5px;font-weight:800;color:var(--text);margin-bottom:3px}
.ds-row span{font-size:12.5px;color:#5a6a92;font-weight:500;line-height:1.5}
.dec-act-flow{display:flex;align-items:stretch;gap:10px;flex-wrap:wrap}
.dec-act-tile{flex:1;min-width:118px;background:#f7f9fe;border:1px solid var(--line);border-radius:13px;padding:13px 15px;display:flex;flex-direction:column;gap:3px}
.dec-act-tile.goal{background:#fff8ec;border-color:#f0dcb0}
.dec-act-tile.result{background:linear-gradient(135deg,#0e2350,#16306e);border:none}
.dec-act-tile .t{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.dec-act-tile.result .t{color:#9fb0d6}
.dec-act-tile .n{font-size:21px;font-weight:800;color:var(--text);letter-spacing:-.3px}
.dec-act-tile.goal .n{color:#b9772a}.dec-act-tile.result .n{color:#f0c674}
.dec-act-tile .n i{font-size:10.5px;font-weight:600;font-style:normal;color:var(--muted)}
.dec-act-tile.result .n i{color:#9fb0d6}
.dec-act-tile .c{font-size:11px;font-weight:700;color:var(--muted)}
.dec-act-tile .c.down{color:var(--orange)}.dec-act-tile.result .c{color:#9fb0d6}
.dec-act-tile .c.muted{color:#8c99b8}
.dec-act-arrow{display:flex;align-items:center;color:#c3cfe8;font-size:17px;font-weight:800}
@media(max-width:760px){.dec-act-arrow{display:none}.dec-act-tile{min-width:calc(50% - 5px)}}
@keyframes decUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
#view-decisao.active .dh,#view-decisao.active .dec-act,#view-decisao.active .sectitle,#view-decisao.active .df,#view-decisao.active>.card:last-child{animation:decUp .5s cubic-bezier(.2,.7,.3,1) both}
#view-decisao.active .dec-act{animation-delay:.08s}
#view-decisao.active .sectitle{animation-delay:.15s}
#view-decisao.active .df:nth-child(1){animation-delay:.2s}
#view-decisao.active .df:nth-child(2){animation-delay:.26s}
#view-decisao.active .df:nth-child(3){animation-delay:.32s}
#view-decisao.active>.card:last-child{animation-delay:.4s}
.ch{position:relative;overflow:hidden;display:grid;grid-template-columns:1.4fr 1.2fr;gap:30px;align-items:center;border-radius:20px;padding:24px 30px;background:linear-gradient(120deg,#0a1838,#0e2350 58%,#13294f);color:#fff;box-shadow:0 16px 44px rgba(10,24,56,.30)}
@media(max-width:880px){.ch{grid-template-columns:1fr;gap:20px}}
.ch-glow{position:absolute;top:-110px;left:28%;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(47,109,240,.22),transparent 70%);pointer-events:none}
.ch-main{position:relative;z-index:1}
.ch-eyebrow{font-size:11px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:#8095c0}
.ch-figrow{display:flex;align-items:flex-end;gap:16px;margin:12px 0 15px;flex-wrap:wrap}
.ch-fnum{font-size:46px;font-weight:800;line-height:.95;letter-spacing:-1.5px;color:#fff}
.ch-fnum i{font-size:28px;font-weight:600;font-style:normal;color:#9fb0d6}
.ch-fctx{font-size:12.5px;font-weight:500;color:#a6b4d4;line-height:1.5;padding-bottom:4px}
.ch-fctx b{color:#f0c674;font-weight:800}
.ch-bar{position:relative;z-index:1;height:9px;border-radius:6px;background:rgba(255,255,255,.1);overflow:hidden}
.ch-bar i{display:block;height:100%;background:linear-gradient(90deg,#d99e37,#f0c674)}
.ch-stats{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:6px 26px}
.ch-stat{display:flex;flex-direction:column;gap:3px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.ch-stat .l{font-size:11px;font-weight:600;color:#8095c0;text-transform:uppercase;letter-spacing:.4px}
.ch-stat .v{font-size:21px;font-weight:800;color:#fff}
.ch-stat .v i{font-size:12px;font-weight:600;font-style:normal;color:#8095c0}
@keyframes chUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
#view-central.active .ch{animation:chUp .55s cubic-bezier(.2,.7,.3,1) both}
#view-central.active #teamKpis{animation:chUp .55s cubic-bezier(.2,.7,.3,1) both;animation-delay:.1s}
.card:hover{box-shadow:0 14px 34px rgba(20,40,90,.13)}
.kpi:hover{box-shadow:0 14px 30px rgba(20,40,90,.13)}
.fc2-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:11px;align-items:end}
.fc-fld{display:flex;flex-direction:column;gap:5px;font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.fc-fld.wide{grid-column:span 2}
.fc-fld>select,.fc-fld>input{font-family:inherit;font-size:13px;font-weight:600;color:var(--text);padding:8px 11px;border:1.5px solid var(--line);border-radius:9px;background:#f8faff;width:100%}
.fc-fld>select:focus,.fc-fld>input:focus{outline:none;border-color:var(--blue);background:#fff}
.money-wrap,.pct-wrap{display:flex;align-items:stretch;border:1.5px solid var(--line);border-radius:9px;overflow:hidden;background:#f8faff}
.money-wrap span,.pct-wrap span{display:flex;align-items:center;padding:0 9px;background:#eef2fb;color:var(--muted);font-weight:800;font-size:12px}
.money-wrap input,.pct-wrap input{border:none;background:none;padding:8px 10px;width:100%;font-family:inherit;font-size:13px;font-weight:600;color:var(--text)}
.money-wrap input:focus,.pct-wrap input:focus{outline:none}
.money-wrap:focus-within,.pct-wrap:focus-within{border-color:var(--blue);background:#fff}
.money-wrap:focus-within span,.pct-wrap:focus-within span{background:#e7eefe}
@media(max-width:900px){.fc-grid2{grid-template-columns:1fr}.fcrow{grid-template-columns:1fr;gap:8px}}
.datechip{font-size:12px;color:var(--muted);font-weight:500;text-align:right}
.datechip b{display:block;color:var(--text);font-size:12.5px;text-transform:capitalize}
.user{display:flex;align-items:center;gap:10px}
.avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--navy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13.5px;box-shadow:var(--sh)}
.user .nm{font-size:13px;font-weight:700;line-height:1.2}
.user .rl{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.maquete{background:linear-gradient(135deg,var(--gold),#f0c66b);color:#3a2a00;font-size:10px;font-weight:800;padding:4px 10px;border-radius:20px;letter-spacing:.4px;box-shadow:var(--sh-sm)}

.content{padding:30px 36px 56px;overflow-x:hidden}
.view{display:none;animation:fade .4s cubic-bezier(.4,0,.2,1)}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.sectitle{font-size:12.5px;font-weight:800;text-transform:uppercase;letter-spacing:1.1px;color:var(--text);margin:14px 2px 16px;display:flex;align-items:center;gap:11px}
.sectitle::before{content:"";width:22px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--gold),#f3c879)}

/* GRID + CARDS */
.grid{display:grid;gap:22px}
.kpis{grid-template-columns:repeat(6,minmax(0,1fr))}
.cols-2{grid-template-columns:minmax(0,1.45fr) minmax(0,1fr)}.cols-2b{grid-template-columns:minmax(0,1fr) minmax(0,1.3fr)}
.cols-2e{grid-template-columns:repeat(2,minmax(0,1fr))}.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:1300px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1050px){.cols-2,.cols-2b,.cols-2e,.cols-3{grid-template-columns:1fr}}
.mb{margin-bottom:24px}
.card{background:var(--card);border-radius:18px;padding:24px;box-shadow:var(--sh);border:1px solid rgba(255,255,255,.7);transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.card h3{font-size:13.5px;font-weight:800;display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;letter-spacing:-.2px}
.card h3 .sub{font-size:11px;color:var(--muted);font-weight:600}
.ic{width:15px;height:15px;vertical-align:-3px;flex-shrink:0}.hic{width:17px;height:17px;vertical-align:-3px;flex-shrink:0}
.ht{display:inline-flex;align-items:center;gap:8px}

/* KPI */
.kpi{background:var(--card);border-radius:17px;padding:15px 17px 12px;box-shadow:var(--sh);position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.7);transition:transform .2s,box-shadow .2s}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(var(--blue),var(--blue-d))}
.kpi.g::before{background:linear-gradient(var(--green),#127a3e)}.kpi.o::before{background:linear-gradient(var(--orange),#cf6f15)}
.kpi.gold::before{background:linear-gradient(var(--gold),#c98f22)}.kpi.t::before{background:linear-gradient(var(--teal),#138a7d)}
.kpi.r::before{background:linear-gradient(var(--red),#c0392b)}.kpi.p::before{background:linear-gradient(var(--purple),#5c3bb0)}
.kpi .top{display:flex;justify-content:space-between;align-items:flex-start}
.kpi .lab{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;font-weight:700}
.kpi .val{font-size:25px;font-weight:800;margin:6px 0 4px;letter-spacing:-.7px}
.kpi .val small{font-size:13px;font-weight:700;color:var(--muted)}
.trend{font-size:10.5px;font-weight:800;display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px}
.trend.up{background:#e4f6ec;color:var(--green)}.trend.down{background:#fdeae6;color:var(--red)}
.spark{margin-top:6px;display:block;width:100%;height:30px;cursor:crosshair}
.spark2{cursor:crosshair}
#sparkTip{position:fixed;z-index:999;display:none;background:var(--navy);color:#fff;font-size:11px;font-weight:700;padding:5px 9px;border-radius:8px;box-shadow:var(--sh-lg);pointer-events:none;white-space:nowrap}
#sparkTip b{color:#9fc0ff}

/* FUNNEL */
.funnel{display:flex;flex-direction:column;gap:8px}
.fbar{height:44px;border-radius:10px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;color:#fff;font-weight:700;box-shadow:0 4px 12px rgba(16,32,80,.18);transition:width .5s}
.fbar .n{font-size:12px;font-weight:600;opacity:.95}.fbar .v{font-size:18px;font-weight:800}
.frate{font-size:10.5px;color:var(--muted);text-align:right;margin:1px 6px -1px 0;font-weight:700}

/* GAUGE */
.gauges{display:flex;justify-content:space-around;gap:10px;flex-wrap:wrap}
.gauge{position:relative;width:118px;height:118px;border-radius:50%;display:grid;place-items:center;filter:drop-shadow(0 8px 14px rgba(16,32,80,.14))}
.gauge::after{content:"";position:absolute;inset:13px;background:#fff;border-radius:50%;box-shadow:inset 0 2px 6px rgba(16,32,80,.08)}
.gauge .gv{position:relative;z-index:1;text-align:center}
.gauge .gv b{font-size:21px;font-weight:800;display:block;letter-spacing:-.5px}
.gauge .gv span{font-size:9.5px;color:var(--muted);font-weight:700;text-transform:uppercase}
.glabel{text-align:center;font-size:11.5px;font-weight:700;margin-top:9px}
.glabel small{display:block;color:var(--muted);font-weight:600;font-size:10.5px}

/* LEADERBOARD */
.lb{display:flex;flex-direction:column;gap:3px}
.lrow{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:12px;cursor:pointer;transition:.15s}
.lrow:hover{background:#f4f8ff;transform:translateX(2px)}
.rank{width:24px;font-weight:800;color:#aab4d2;font-size:13px;text-align:center}
.rank.top{color:var(--gold)}
.av{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:13px;flex-shrink:0;box-shadow:var(--sh-sm)}
.lrow .info{flex:1;min-width:0}
.lrow .nm{font-weight:700;font-size:13px}
.lrow .mt{font-size:10.5px;color:var(--muted);font-weight:600}
.lrow .nm,.lrow .mt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lrow .spark2{width:64px;height:26px;flex-shrink:0}
.lrow .big{font-weight:800;font-size:14.5px;text-align:right;min-width:74px;flex-shrink:0}
.lrow .big small{display:block;font-size:9.5px;color:var(--muted);font-weight:700}
.leader-empty{min-height:190px;display:grid;place-items:center;text-align:center;color:var(--muted);font-size:12px;font-weight:700}
@media(max-width:1180px){.lrow{gap:9px}.lrow .spark2{width:54px}.lrow .big{min-width:62px}}

/* CHARTS */
.chartbox{position:relative;height:248px}.chartbox.sm{height:210px}.chartbox.xs{height:180px}
.chart-empty{position:absolute;inset:0;display:none;align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:12px;font-weight:700;pointer-events:none}
.chartbox.is-empty canvas{opacity:.18}
.chartbox.is-empty .chart-empty{display:flex}

/* HEATMAP */
.heat{display:grid;grid-template-columns:54px repeat(6,1fr);gap:5px;align-items:center}
.heat .hh{font-size:10px;font-weight:700;color:var(--muted);text-align:center}
.heat .hr{font-size:10.5px;font-weight:700;color:var(--muted)}
.heat .hc{height:34px;border-radius:8px;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;transition:.15s}
.heat .hc:hover{transform:scale(1.08)}
.heat .hc.no-base{background:#edf2fb!important;color:#98a4bf!important}
.heat-leg{display:flex;align-items:center;gap:7px;justify-content:flex-end;margin-top:12px;font-size:10px;color:var(--muted);font-weight:600}
.heat-leg i{width:34px;height:9px;border-radius:5px;background:linear-gradient(90deg,#dbe6fb,#2f6df0,#0e2350)}

/* CHIPS / BADGES */
.chip{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:20px;font-size:11.5px;font-weight:700;margin:3px 5px 3px 0}
.chip.green{background:#e4f6ec;color:#157a40}.chip.amber{background:#fdf0db;color:#94650a}
.chip.blue{background:#e7eefe;color:#2052c0}
.badge{padding:3px 10px;border-radius:20px;font-size:10.5px;font-weight:800;white-space:nowrap}
.b-comp{background:#e4f6ec;color:#157a40}.b-nao{background:#fdeae6;color:#c0392b}.b-nq{background:#e6eaf5;color:#33406b}
.b-sq{background:#fff4d6;color:#9a7400}

/* TABLE */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:800;padding:12px 12px 11px;border-bottom:2px solid var(--line)}
td{padding:14px 12px;border-bottom:1px solid var(--line);font-size:13px;font-weight:500}
table tr:hover td{background:#f6f9ff}
tr:last-child td{border-bottom:none}.cli{font-weight:700}.muted-sm{color:var(--muted);font-size:11.5px}
.sct td,.sct th{white-space:nowrap}.sct tbody tr{transition:.12s}.sct tbody tr:hover{background:#f6f9ff}
.sct td.name{font-weight:700;cursor:pointer;color:var(--navy)}.sct td.name:hover{color:var(--blue)}
.sct tr.tot td{font-weight:800;border-top:2px solid var(--line);background:#f4f7ff;border-bottom:none}
.cell-g{color:#157a40;font-weight:800}.cell-a{color:#b5760a;font-weight:800}.cell-r{color:#c0392b;font-weight:800}
.metacell{display:flex;align-items:center;gap:8px;min-width:118px}.metacell .mb2{flex:1;height:7px;background:#e9edf7;border-radius:5px;overflow:hidden}.metacell .mb2 i{display:block;height:100%;border-radius:5px}
.th-sort{cursor:pointer;user-select:none}.th-sort:hover{color:var(--navy)}.th-sort .ar{opacity:.4;font-size:9px}
.av-sm{width:30px;height:30px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:11px;margin-right:9px;vertical-align:middle}
.atl{display:grid;grid-template-columns:46px 13px 1fr auto;align-items:center;gap:11px;padding:9px 2px;border-bottom:1px solid var(--line)}
.atl:last-child{border:none}.atl .tm{font-weight:800;font-size:12px;color:var(--navy)}
.atl .pip{width:11px;height:11px;border-radius:50%;justify-self:center;box-shadow:0 0 0 4px rgba(0,0,0,.05)}
.atl .cc{font-weight:700;font-size:12.5px}.atl .cc small{display:block;color:var(--muted);font-weight:600;font-size:10.5px}
.pip-comp{background:var(--green)}.pip-nao{background:var(--red)}.pip-nq{background:#33406b}.pip-neg{background:var(--gold)}
.pipe{display:flex;flex-direction:column;gap:9px}
.pipe-row{display:flex;align-items:center;justify-content:space-between;padding:10px 13px;background:linear-gradient(90deg,#f6f9ff,#fff);border:1px solid var(--line);border-radius:11px}
.pipe-row .l{font-weight:700;font-size:12.5px}.pipe-row .l small{display:block;color:var(--muted);font-weight:600;font-size:10.5px}
.pipe-row .r{text-align:right}.pipe-row .r b{font-size:14px;font-weight:800;color:var(--navy)}
.prob{font-size:9.5px;font-weight:800;padding:2px 7px;border-radius:20px}.prob.alta{background:#e4f6ec;color:#157a40}.prob.media{background:#fdf0db;color:#94650a}.prob.baixa{background:#fdeae6;color:#c0392b}
.aor{display:grid;grid-template-columns:1fr 30px 1fr 30px 1fr;align-items:stretch}
@media(max-width:900px){.aor{grid-template-columns:1fr}.aor-arrow{display:none!important}}
.aor-col{padding:15px 16px;border-radius:14px}
.aor>.aor-col:nth-child(1){background:linear-gradient(160deg,#eef4ff,#f9fbff)}
.aor>.aor-col:nth-child(3){background:linear-gradient(160deg,#fff8ec,#fffefb)}
.aor>.aor-col:nth-child(5){background:linear-gradient(160deg,#eef8f1,#f9fdfb)}
.aor-band{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;padding:6px 11px;border-radius:9px;display:inline-block;margin-bottom:10px}
.aor-band.a{background:#e7eefe;color:#2052c0}.aor-band.o{background:#fff4d6;color:#9a7400}.aor-band.r{background:#eaf6ee;color:#157a40}
.aor-arrow{display:flex;align-items:center;justify-content:center;color:#c3cfe8;font-size:24px;font-weight:800}
.aor-m{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.aor-m:last-child{border:none}
.aor-m .ml{font-size:12px;font-weight:600}.aor-m .ml small{display:block;color:var(--muted);font-size:10px;font-weight:600;margin-top:1px}
.aor-m .mr{font-weight:800;font-size:13.5px;display:flex;align-items:center;gap:8px}
.sdot{width:9px;height:9px;border-radius:50%;box-shadow:0 0 0 3px rgba(0,0,0,.04)}
.diag{margin-top:16px;padding:14px 16px;border-radius:12px;background:linear-gradient(90deg,#fff8f0,#fff);border-left:4px solid var(--orange);font-size:12.5px;font-weight:500;line-height:1.55}.diag b{font-weight:800}
.diag-row{display:flex;gap:11px;align-items:flex-start;margin-bottom:9px}.diag-row:last-child{margin:0}
.diag-tag{flex-shrink:0;font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;border-radius:7px;background:#fde9d6;color:#b5651b;margin-top:1px}
.diag-tag.act{background:#e7eefe;color:#2052c0}
.diag.ok{border-color:var(--green);background:linear-gradient(90deg,#f1fbf5,#fff)}
.diag.bad{border-color:var(--red);background:linear-gradient(90deg,#fdf1ef,#fff)}
.trend-seg{display:inline-flex;background:#e8edf8;border-radius:11px;padding:4px;box-shadow:inset 0 1px 3px rgba(16,32,80,.08);flex-wrap:wrap;gap:2px}
.trend-seg button{border:none;background:none;font-family:inherit;font-size:11.5px;font-weight:700;color:var(--muted);padding:6px 12px;border-radius:8px;cursor:pointer;transition:.15s}
.trend-seg button.active{background:#fff;color:var(--navy);box-shadow:var(--sh-sm),0 2px 6px rgba(16,32,80,.1)}
.plan-inputs{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.plan-inputs.plan-inputs-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.plan-inputs.plan-inputs-5{grid-template-columns:repeat(5,minmax(0,1fr))}
.plan-inputs label{display:flex;flex-direction:column;font-size:11px;font-weight:700;color:var(--muted);gap:6px;line-height:1.3}
.plan-inputs input{font-family:inherit;font-size:15px;font-weight:800;color:var(--text);padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;background:#f8faff;width:100%}
.plan-inputs input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(47,109,240,.12)}
.plan-prem{background:#f6f9ff;border:1px solid var(--line);border-radius:13px;padding:16px}
.plan-premise-strip{margin-top:56px;padding-top:20px;border-top:1px solid rgba(128,143,184,.26);position:relative}
.plan-premise-strip:before{content:"";position:absolute;top:-1px;left:0;width:76px;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--blue),rgba(47,109,240,0))}
.pps-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.pps-head span{font-size:11px;font-weight:900;color:var(--navy);text-transform:uppercase;letter-spacing:.45px}
.pps-head small{font-size:10.5px;font-weight:700;color:var(--muted)}
.pps-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.pps-grid div{background:#f8faff;border:1px solid #e4e9f5;border-radius:10px;padding:10px 11px}
.pps-grid span{display:block;font-size:9.5px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.35px}
.pps-grid b{display:block;margin-top:4px;font-size:15px;font-weight:900;color:var(--navy);line-height:1}
.plan-note{font-size:10.5px;color:var(--muted);font-weight:500;margin-top:16px;line-height:1.5}
.plan-step{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line)}
.plan-step .pl{font-size:12.5px;font-weight:600}.plan-step .pl small{display:block;color:var(--muted);font-weight:600;font-size:10.5px;margin-top:1px}
.plan-step .pv{font-weight:800;font-size:16px;color:var(--navy)}
.plan-band{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;padding:5px 11px;border-radius:8px;display:inline-block;margin:12px 0 4px}
.plan-band.r{background:#eaf6ee;color:#157a40}.plan-band.o{background:#fff4d6;color:#9a7400}.plan-band.a{background:#e7eefe;color:#2052c0}
.plan-verdict{margin-top:16px;padding:13px 16px;border-radius:12px;font-size:12.5px;font-weight:600;line-height:1.55}
.plan-verdict.ok{background:#f1fbf5;border-left:4px solid var(--green)}.plan-verdict.warn{background:#fff8ef;border-left:4px solid var(--orange)}.plan-verdict.bad{background:#fdf1ef;border-left:4px solid var(--red)}
.pp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
@media(max-width:1100px){.plan-inputs.plan-inputs-4,.plan-inputs.plan-inputs-5{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.pp-grid{grid-template-columns:1fr 1fr}.plan-inputs,.plan-inputs.plan-inputs-4,.plan-inputs.plan-inputs-5,.pps-grid{grid-template-columns:1fr}}
.pp{background:linear-gradient(135deg,#f6f9ff,#fff);border:1px solid var(--line);border-radius:13px;padding:14px}
.pp .l{font-size:10.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.pp .v{font-size:21px;font-weight:800;margin-top:6px}.pp .v small{font-size:11px;color:var(--muted);font-weight:700}
.pp .tag{font-size:10px;font-weight:800;margin-top:7px;display:inline-block;padding:3px 9px;border-radius:20px}
.pp .tag.ok{background:#e4f6ec;color:#157a40}.pp .tag.warn{background:#fff2d9;color:#b56b00}.pp .tag.bad{background:#fdeae6;color:#c0392b}
.plan-group{border-radius:14px;padding:15px 17px;border:1px solid var(--line)}
.plan-group.r{background:linear-gradient(160deg,#edf8f1,#f9fdfb);border-color:#d6ecdd}
.plan-group.o{background:linear-gradient(160deg,#fff8ec,#fffefb);border-color:#f0e2c0}
.plan-group.a{background:linear-gradient(160deg,#eef4ff,#f9fbff);border-color:#d8e3fa}
.plan-tag{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;padding:4px 11px;border-radius:8px;display:inline-block;margin-bottom:7px}
.plan-tag.r{background:#d7ecdd;color:#157a40}.plan-tag.o{background:#f6e8c5;color:#9a7400}.plan-tag.a{background:#dde7fc;color:#2052c0}
.pm{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid rgba(20,40,90,.06)}
.pm:last-child{border:none}
.pm .pl{font-size:12px;font-weight:600;color:var(--text)}
.pm .pl small{display:block;color:var(--muted);font-weight:500;font-size:10.5px;margin-top:2px}
.pm .pv{font-size:19px;font-weight:800;color:var(--navy);white-space:nowrap;letter-spacing:-.3px}
.plan-down{text-align:center;color:#c3cfe8;font-size:14px;font-weight:800;margin:7px 0}

/* NOTE */
.note{border-left:4px solid var(--blue);background:linear-gradient(90deg,#f6f9ff,#fff);border-radius:0 12px 12px 0;padding:14px 16px}
.note.good{border-color:var(--green);background:linear-gradient(90deg,#f1fbf5,#fff)}
.note.bad{border-color:var(--orange);background:linear-gradient(90deg,#fff8f0,#fff)}
.note h4{font-size:12px;font-weight:800;margin-bottom:8px;display:flex;align-items:center;gap:7px}.note p{font-size:12.5px;color:#41507a;line-height:1.5;font-weight:500}

/* GOAL bars */
.goal{margin-bottom:15px}.goal:last-child{margin:0}
.goal .gt{display:flex;justify-content:space-between;font-size:12px;font-weight:700;margin-bottom:6px}.goal .gt b{font-weight:800}
.gbar{height:9px;background:#e9edf7;border-radius:6px;overflow:hidden;box-shadow:inset 0 1px 2px rgba(16,32,80,.08)}
.gbar i{display:block;height:100%;border-radius:6px}

/* ALERTS */
.alert{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:12px;font-size:12px;font-weight:600;margin-bottom:8px}
.alert:last-child{margin:0}.alert .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 4px rgba(0,0,0,.04)}
.alert.warn{background:#fff8ef}.alert.warn .dot{background:var(--orange)}
.alert.bad{background:#fdf1ef}.alert.bad .dot{background:var(--red)}
.alert.ok{background:#f1fbf5}.alert.ok .dot{background:var(--green)}

/* report / misc */
.rep-actions{display:flex;gap:10px}
.rep-target{min-width:250px;display:flex;align-items:center}
.rep-target select{height:42px;width:100%;font-family:inherit;font-size:13px;font-weight:700;color:var(--text);padding:0 42px 0 15px;border:1.5px solid var(--line);border-radius:11px;background:#f8faff;box-shadow:none}
.rep-target select:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(47,109,240,.1)}
.btn{padding:10px 16px;border-radius:11px;font-weight:800;font-size:12.5px;cursor:pointer;border:none;font-family:inherit;transition:.15s}
.btn.primary{background:linear-gradient(135deg,var(--navy),#16306e);color:#fff;box-shadow:var(--sh)}
.btn.primary:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn.ghost{background:#eef1fa;color:var(--navy)}
.act-prof{display:flex;flex-direction:column;gap:10px}
.actrow{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:linear-gradient(90deg,#f6f9ff,#fff);border-radius:12px;border:1px solid var(--line)}
.actrow .l{font-size:12.5px;font-weight:700}.actrow .l small{display:block;color:var(--muted);font-weight:500;font-size:11px;margin-top:2px}
.actrow .r{font-weight:800;font-size:17px;color:var(--navy)}.actrow .r small{font-size:11px;color:var(--green);font-weight:800;margin-left:4px}
.back{font-size:12px;color:var(--blue);font-weight:700;cursor:pointer;margin-bottom:14px;display:inline-block}
.statcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:12px}
.mini{background:linear-gradient(135deg,#f6f9ff,#fff);border:1px solid var(--line);border-radius:13px;padding:13px 14px}
.mini .l{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.mini .v{font-size:19px;font-weight:800;margin-top:5px}.mini .v small{font-size:11px;color:var(--green);font-weight:800}


/* ==== */

/* ====== CAMADA DO APP REAL (login, config, usuarios, estados) ====== */
/* Classes novas, prefixadas, para nao colidir com o mockup. */

/* LOGIN */
.auth-overlay{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(150deg,#0c1d44,#0a1838 55%,#11254f);overflow:auto}
.auth-overlay::before{content:"";position:absolute;top:-160px;right:-80px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(224,169,61,.18),transparent 70%);pointer-events:none}
.auth-overlay::after{content:"";position:absolute;bottom:-180px;left:-90px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(47,109,240,.20),transparent 70%);pointer-events:none}
.auth-card{position:relative;z-index:1;width:100%;max-width:392px;background:#fff;border-radius:22px;padding:34px 32px 30px;box-shadow:0 30px 70px rgba(8,18,44,.55),0 8px 20px rgba(8,18,44,.3);animation:authIn .5s cubic-bezier(.2,.7,.3,1) both}
@keyframes authIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.auth-brand{display:flex;align-items:center;gap:13px;margin-bottom:24px}
.auth-logo{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--navy),#16306e);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:17px;letter-spacing:-1px;box-shadow:0 8px 18px rgba(14,35,80,.4),inset 0 1px 1px rgba(255,255,255,.25)}
.auth-brand h1{font-size:15px;font-weight:800;letter-spacing:.3px;line-height:1.15}
.auth-brand p{font-size:9.5px;color:var(--muted);font-weight:600;letter-spacing:1.4px;text-transform:uppercase;margin-top:3px}
.auth-title{font-size:19px;font-weight:800;letter-spacing:-.3px;margin-bottom:5px}
.auth-sub{font-size:12.5px;color:var(--muted);font-weight:500;margin-bottom:22px;line-height:1.5}
.auth-fld{display:flex;flex-direction:column;gap:6px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:14px}
.auth-fld input{font-family:inherit;font-size:14px;font-weight:600;color:var(--text);padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;background:#f8faff;width:100%;transition:border-color .15s,box-shadow .15s,background .15s}
.auth-fld input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(47,109,240,.12)}
.auth-btn{width:100%;margin-top:6px;padding:13px 16px;border-radius:12px;border:none;font-family:inherit;font-weight:800;font-size:14px;color:#fff;cursor:pointer;background:linear-gradient(135deg,var(--navy),#16306e);box-shadow:0 10px 24px rgba(14,35,80,.32);transition:.15s;display:flex;align-items:center;justify-content:center;gap:9px}
.auth-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 32px rgba(14,35,80,.4)}
.auth-btn:disabled{opacity:.7;cursor:default}
.auth-err{display:none;background:#fdf2f2;border:1px solid #f3c9c9;border-left:4px solid var(--red);border-radius:0 11px 11px 0;padding:11px 14px;font-size:12.5px;font-weight:600;color:#b0463a;margin-bottom:16px;line-height:1.5}
.auth-err.show{display:block}
.auth-foot{margin-top:20px;text-align:center;font-size:11px;color:var(--muted);font-weight:500;line-height:1.6}
.auth-foot b{color:var(--text);font-weight:700}
.app-spin{width:16px;height:16px;border-radius:50%;border:2.4px solid rgba(255,255,255,.4);border-top-color:#fff;animation:appspin .7s linear infinite;display:inline-block}
@keyframes appspin{to{transform:rotate(360deg)}}

/* BOTOES DO TOPBAR (atualizar) */
.app-iconbtn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:11px;border:none;background:#eef1fa;color:var(--navy);font-family:inherit;font-weight:700;font-size:12.5px;cursor:pointer;transition:.15s}
.app-iconbtn:hover{background:#e2e8f8;transform:translateY(-1px)}
.app-iconbtn:disabled{opacity:.6;cursor:default;transform:none}
.app-iconbtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.2}
.app-iconbtn.spinning svg{animation:appspin .8s linear infinite}
.app-spin-navy{width:15px;height:15px;border-radius:50%;border:2.3px solid rgba(14,35,80,.25);border-top-color:var(--navy);animation:appspin .7s linear infinite;display:inline-block}
.app-logout{height:40px;padding:0 14px;border:1px solid #dbe2f0;border-radius:11px;background:#fff;color:var(--muted);font-family:inherit;font-size:12px;font-weight:800;cursor:pointer;transition:.15s}
.app-logout:hover{border-color:#c9d4e8;color:var(--navy);background:#f8faff;transform:translateY(-1px)}

/* ESTADOS carregando / erro */
.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:13px;padding:60px 20px;color:var(--muted);font-weight:600;font-size:13px}
.app-loading .app-spin-navy{width:26px;height:26px;border-width:3px}
.app-error{background:#fdf2f2;border:1px solid #f3c9c9;border-left:4px solid var(--red);border-radius:0 12px 12px 0;padding:16px 18px;font-size:13px;font-weight:600;color:#b0463a;line-height:1.6;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.app-error .btn{flex-shrink:0}
.app-viewbusy{position:relative}
.app-viewbusy::after{content:"";position:absolute;inset:0;background:rgba(248,250,255,.28);z-index:5;border-radius:18px;pointer-events:none}
.app-viewspin{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:6;width:34px;height:34px;border-radius:50%;border:3px solid rgba(14,35,80,.18);border-top-color:var(--navy);animation:appspin .7s linear infinite}

/* CONFIGURACOES + USUARIOS (reaproveita .card/.btn/.fld do mockup) */
.cfg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px}
.cfg-status{display:inline-flex;align-items:center;gap:7px;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.4px}
.cfg-status::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.cfg-status.on{background:#e7f7ee;color:#1e9e5a}
.cfg-status.off{background:#fff4e5;color:#b9772a}
.cfg-help{font-size:12px;color:var(--muted);font-weight:500;line-height:1.55;margin:4px 0 16px}
.cfg-form{display:flex;flex-direction:column;gap:13px}
.cfg-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.cfg-ro{font-size:14px;font-weight:700;color:var(--text);padding:11px 14px;border:1.5px solid var(--line);border-radius:11px;background:#f1f3f9}
.usr-rointro{font-size:12px;color:var(--muted);font-weight:500;line-height:1.55;margin-top:6px}
.badge.role-admin{background:#efe6fb;color:#5c3bb0}
.badge.role-gestor{background:#e7eefe;color:#2052c0}
.badge.role-comercial{background:#e4f6ec;color:#157a40}
.badge.role-agendador{background:#fff4d6;color:#9a7400}
.badge.usr-on{background:#e4f6ec;color:#157a40}
.badge.usr-off{background:#f0f2f7;color:#8a93a8}
.usr-act{display:inline-flex;gap:6px}
.usr-linkbtn{border:none;background:none;font-family:inherit;font-size:12px;font-weight:800;cursor:pointer;padding:4px 6px;border-radius:7px;color:var(--blue-d)}
.usr-linkbtn:hover{background:#eef3ff}
.usr-linkbtn.danger{color:var(--red)}
.usr-linkbtn.danger:hover{background:#fdecea}
.usr-modal-bg{position:fixed;inset:0;z-index:300;background:rgba(10,22,50,.5);display:none;align-items:center;justify-content:center;padding:22px}
.usr-modal-bg.open{display:flex}
.usr-modal{width:100%;max-width:440px;background:#fff;border-radius:18px;padding:24px;box-shadow:var(--sh-lg);animation:authIn .3s cubic-bezier(.2,.7,.3,1) both;max-height:90vh;overflow:auto}
.usr-modal h3{font-size:16px;font-weight:800;margin-bottom:4px}
.usr-modal .crumb{font-size:12px;color:var(--muted);font-weight:500;margin-bottom:18px}
.usr-modal .cfg-form{gap:13px}
.usr-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:18px;border-top:1px solid var(--line)}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVO / MOBILE
   Escala de breakpoints uniforme: 1024 / 768 / 480 / 360 (adaptacao
   "para baixo" sobre o layout desktop existente). Mudancas aditivas:
   preservam a identidade visual (navy/dourado, Montserrat, cards) e so
   reorganizam para telas pequenas. Sem scroll horizontal na pagina.
   ════════════════════════════════════════════════════════════════ */
html,body{max-width:100%;overflow-x:hidden}
img{max-width:100%;height:auto}
body.nav-locked{overflow:hidden}

/* Backdrop do drawer (so visivel com o menu aberto, ate 1024px) */
.nav-backdrop{position:fixed;inset:0;background:rgba(8,18,44,.5);z-index:55;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}
@media(min-width:1025px){.nav-backdrop{display:none}}

/* ── ate 1024px: a sidebar vira menu off-canvas (drawer) ── */
@media(max-width:1024px){
  .app,.app.collapsed{grid-template-columns:1fr}
  .main{grid-column:1}
  .sidebar{position:fixed;top:0;left:0;height:100dvh;width:min(82vw,290px);
    transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
    z-index:60;padding-top:max(20px,env(safe-area-inset-top));box-shadow:8px 0 40px rgba(8,18,44,.4)}
  .app.nav-open .sidebar{transform:translateX(0)}
  .app.nav-open .nav-backdrop{opacity:1;visibility:visible}
  /* anula o modo "colapsado" do desktop dentro do drawer */
  .app.collapsed .brand h1,.app.collapsed .brand p,.app.collapsed .nav-label,.app.collapsed .side-foot{display:block}
  .app.collapsed .nav-item .tx{display:inline}
  .app.collapsed .nav-item{justify-content:flex-start;padding:11px 12px}
  .app.collapsed .brand{justify-content:flex-start;padding:6px 4px 18px}
}

/* ── ate 768px: topbar empilha, conteudo com padding menor ── */
@media(max-width:768px){
  .topbar{flex-wrap:wrap;gap:10px 12px;padding:10px 16px;padding-top:max(10px,env(safe-area-inset-top))}
  .tb-left{flex:1 1 auto;min-width:0}
  .tb-left h2{font-size:clamp(15px,4.6vw,18.5px);line-height:1.15;white-space:normal}
  .top-right{flex:1 1 100%;flex-wrap:wrap;gap:8px;justify-content:flex-start}
  .top-right .user{display:none}
  #btnSync .tx{display:none}
  #btnSync{min-height:44px;min-width:44px;justify-content:center;margin-left:auto}
  .seg{flex:1 1 100%}
  .seg button{flex:1;min-height:40px}
  .datenav{flex:1 1 auto}
  .datenav .lbl{flex:1;min-width:0;text-align:center}
  .datenav button{min-height:40px;min-width:40px}

  .content{padding:18px 16px calc(36px + env(safe-area-inset-bottom))}
  .grid{gap:14px}
  .mb{margin-bottom:16px}
  .card{padding:16px}

  /* heros com numero focal escalonado (KPIs ficam 3-col ate o telefone) */
  .ch,.dh{padding:20px}
  .ch-fnum{font-size:clamp(34px,12vw,46px)}
  .dh-fnum{font-size:clamp(34px,12vw,48px)}

  /* tabelas rolam dentro do card (a pagina nao quebra) */
  .content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;max-width:100%}

  /* alvos de toque >=44px e inputs com >=16px (evita zoom automatico no iOS).
     !important porque varias classes de input definem 13px com mais especificidade. */
  .nav-item{min-height:46px;font-size:14.5px}
  .btn,.app-iconbtn,.seg button,.datenav button,.miniseg button,
  input,select,textarea{min-height:44px}
  input,select,textarea{font-size:16px!important}
  .calpop{width:min(92vw,288px);right:auto;left:0}
}

/* ── ate 480px: ainda mais compacto ── */
@media(max-width:480px){
  .content{padding:14px 12px calc(30px + env(safe-area-inset-bottom))}
  .card{padding:14px}
  .pp-grid{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* ── ate 360px: tudo em 1 coluna ── */
@media(max-width:360px){
  .kpis{grid-template-columns:1fr}
}
