/* ═══════════════════════════════════════════════════════
   GIRARELACIONAMENTO · DESIGN SYSTEM v2
   Cresci e Perdi — azul-marca estrutural, amarelo-girafa
   em microdetalhes, verde/âmbar/vermelho semânticos.
═══════════════════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0B3057; --navy2:#004C8C; --navy3:#0E3A66;
  --gira:#FFD54F; --laranja:#FF6B42;
  --ink:#16202B; --ink2:#44525F; --ink3:#7A8794;
  --surf:#FFFFFF; --surf2:#F4F6F8; --surf3:#E9EDF1; --bg:#F0F3F5;
  --line:#E3E8ED; --line2:#D2DAE1;
  --green:#16A06B; --greend:#0E7B51; --greenl:#E2F5EC;
  --amber:#E8A413; --ambl:#FFF3D6; --ambd:#9A6C00;
  --red:#D8442B; --redl:#FCEAE6;
  --blue:#1E6FD9; --bluel:#E4EEFB;
  --pur:#7C4DC4; --purl:#F0E9FB;
  --disp:'Bricolage Grotesque',sans-serif;
  --font:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --r1:8px; --r2:12px; --r3:16px;
  --sh1:0 1px 2px rgba(11,48,87,.06);
  --sh2:0 6px 18px rgba(11,48,87,.10);
  --sh3:0 16px 44px rgba(11,48,87,.18);
}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
.hidden{display:none!important}
button{font-family:var(--font)}
::selection{background:var(--gira);color:var(--navy)}

/* ── LOGIN ── */
#s-login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 70%,#0E5A9E 100%)}
.login-wrap{width:100%;max-width:380px}
.login-card{background:var(--surf);border-radius:20px;padding:34px 30px;box-shadow:var(--sh3);text-align:center}
.lg-logo{font-size:42px;margin-bottom:8px}
.lg-t{font-family:var(--disp);font-size:23px;font-weight:800;letter-spacing:-.02em;color:var(--navy)}
.lg-s{font-size:12.5px;color:var(--ink3);margin-top:3px}
.lg-form{display:flex;flex-direction:column;gap:10px;margin-top:20px;text-align:left}
.lg-inp{background:var(--surf2);border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;font-size:14px;font-family:var(--font);color:var(--ink);outline:none;width:100%}
.lg-inp:focus{border-color:var(--navy2);background:var(--surf)}
.lg-btn{background:var(--navy2);color:#fff;border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s}
.lg-btn:hover{background:var(--navy)}
.lg-err{color:var(--red);font-size:12.5px;text-align:center;min-height:16px}

/* ── SHELL ── */
#s-app{display:none;min-height:100vh}
#s-app:not(.hidden){display:flex}
.sidebar{width:228px;flex-shrink:0;background:linear-gradient(180deg,var(--navy) 0%,var(--navy3) 100%);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sb-brand{display:flex;align-items:center;gap:10px;padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.10)}
.sb-emoji{font-size:26px}
.sb-t{font-family:var(--disp);font-size:15.5px;font-weight:800;letter-spacing:-.01em;line-height:1.15}
.sb-s{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gira);margin-top:2px}
.sb-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.sb-it{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;color:rgba(255,255,255,.72);font-size:13.5px;font-weight:500;padding:9px 12px;border-radius:9px;cursor:pointer;transition:all .12s}
.sb-it:hover{background:rgba(255,255,255,.08);color:#fff}
.sb-it.on{background:rgba(255,255,255,.13);color:#fff;font-weight:600;box-shadow:inset 3px 0 0 var(--gira)}
.sb-ic{font-size:15px;width:20px;text-align:center}
.sb-user{display:flex;align-items:center;gap:9px;padding:13px 14px;border-top:1px solid rgba(255,255,255,.10)}
.su-av{width:32px;height:32px;border-radius:50%;background:var(--gira);color:var(--navy);font-size:11.5px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.su-i{flex:1;min-width:0}
.su-n{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-r{font-size:10px;color:rgba(255,255,255,.55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-out{background:none;border:none;color:rgba(255,255,255,.5);font-size:16px;cursor:pointer;padding:4px}
.su-out:hover{color:#fff}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 26px;background:var(--surf);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.tb-l{font-family:var(--disp);font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--navy)}
.tb-r{display:flex;align-items:center;gap:10px}
.content{flex:1;padding:22px 26px 60px;max-width:1280px;width:100%}
.tb-apres{background:var(--surf2);border:1px solid var(--line2);border-radius:18px;padding:6px 13px;font-size:11.5px;font-weight:600;color:var(--ink2);cursor:pointer}
body.apres .tb-apres{background:var(--amber);color:#fff;border-color:var(--amber)}
.wk-nav{display:flex;align-items:center;gap:7px}
.wk-btn{width:27px;height:27px;border-radius:8px;border:1px solid var(--line2);background:var(--surf);cursor:pointer;font-size:13px;color:var(--ink2)}
.wk-btn:hover{border-color:var(--navy2);color:var(--navy2)}
.wk-lbl{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--ink2);white-space:nowrap}
.cart-sel{background:var(--surf2);border:1px solid var(--line2);border-radius:9px;padding:7px 10px;font-size:12.5px;font-family:var(--font);color:var(--ink);outline:none;max-width:210px}
.apres-banner{display:none;position:fixed;top:0;left:0;right:0;background:var(--amber);color:#fff;text-align:center;font-size:11px;font-weight:700;letter-spacing:.1em;padding:4px;z-index:200;font-family:var(--mono)}
body.apres .apres-banner{display:block}
body.apres .sens{display:none!important}

/* ── PRIMITIVOS ── */
.card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);box-shadow:var(--sh1)}
.sec-t{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--ink3);margin:4px 0 10px}
.empty{padding:48px 18px;text-align:center;color:var(--ink3);font-size:13.5px;line-height:1.65;background:var(--surf);border:1px dashed var(--line2);border-radius:var(--r2)}
.empty b{color:var(--ink2)}
.loading{display:flex;align-items:center;justify-content:center;padding:60px 0;color:var(--ink3);font-size:13px;gap:10px}
.spin{width:16px;height:16px;border:2px solid var(--line2);border-top-color:var(--navy2);border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.bbk{background:none;border:none;color:var(--ink3);font-size:12.5px;font-weight:600;cursor:pointer;padding:0 0 12px;display:block}
.bbk:hover{color:var(--navy2)}

/* ── HOJE ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:14px 16px 13px;box-shadow:var(--sh1);position:relative;overflow:hidden;transition:transform .13s,box-shadow .13s}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--sh2)}
.kpi-bar{position:absolute;top:0;left:0;right:0;height:3px}
.kpi-v{font-family:var(--disp);font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--navy)}
.kpi-t{font-size:11.5px;color:var(--ink3);font-weight:500;margin-top:1px}
.next-card{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);color:#fff;border-radius:var(--r3);padding:20px 22px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;box-shadow:var(--sh2)}
.nc-l{flex:1;min-width:200px}
.nc-k{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.14em;color:var(--gira)}
.nc-t{font-family:var(--disp);font-size:21px;font-weight:800;letter-spacing:-.02em;margin-top:4px}
.nc-s{font-size:12.5px;opacity:.82;margin-top:3px}
.nc-go{background:var(--gira);color:var(--navy);border:none;border-radius:10px;padding:11px 18px;font-size:13.5px;font-weight:700;cursor:pointer;transition:transform .12s}
.nc-go:hover{transform:scale(1.03)}
.slot-row{display:flex;align-items:center;gap:12px;background:var(--surf);border:1px solid var(--line);border-radius:var(--r1);padding:10px 14px;margin-bottom:7px;cursor:pointer;transition:border .12s}
.slot-row:hover{border-color:var(--navy2)}
.slot-row.done{opacity:.55}
.sr-h{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--navy2);width:46px}
.sr-tag{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.08em;border-radius:5px;padding:3px 7px}
.sr-n{flex:1;font-weight:600;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-st{font-size:11.5px;color:var(--ink3);font-weight:600}
.al-it{background:var(--surf);border:1px solid var(--line);border-left:3px solid var(--red);border-radius:var(--r1);padding:10px 14px;font-size:13px;margin-bottom:7px;cursor:pointer;color:var(--ink2)}
.al-it:hover{border-color:var(--red)}
.al-it b{color:var(--ink)}

/* ── CHECKLIST ── */
.ck-topbar{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:14px 18px;margin-bottom:14px;display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;box-shadow:var(--sh1)}
.ck-date{font-family:var(--disp);font-size:17px;font-weight:800;letter-spacing:-.01em;color:var(--navy)}
.ck-date-sub{font-size:11.5px;color:var(--ink3)}
.ck-pills{display:flex;gap:7px;flex-wrap:wrap}
.ck-pill{font-family:var(--mono);font-size:10.5px;font-weight:700;border-radius:14px;padding:4px 11px}
.ck-pill.ok{background:var(--greenl);color:var(--greend)}
.ck-pill.warn{background:var(--surf3);color:var(--ink2)}
.ck-pill.err{background:var(--redl);color:var(--red)}
.ck-filters{display:flex;gap:5px;flex-wrap:wrap}
.ckf{background:var(--surf2);border:1px solid var(--line2);border-radius:16px;padding:5px 12px;font-size:11.5px;font-weight:600;color:var(--ink2);cursor:pointer}
.ckf.on{background:var(--navy2);border-color:var(--navy2);color:#fff}
.ckf.on.red{background:var(--red);border-color:var(--red)}
.ck-wrap{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);overflow:auto;box-shadow:var(--sh1)}
.ck-tbl{width:100%;border-collapse:collapse;min-width:760px}
.ck-tbl th{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink3);padding:11px 8px;border-bottom:1px solid var(--line2);text-align:center;background:var(--surf2);position:sticky;top:0;line-height:1.35}
.ck-tbl th.left{text-align:left;padding-left:16px}
.ck-tbl td{padding:9px 8px;border-bottom:1px solid var(--line);vertical-align:middle}
.ck-tbl tr:hover td{background:var(--surf2)}
.row-crit td{background:#FFF8F6}
.td-nm{font-weight:600;font-size:13px;padding-left:8px}
.td-city{font-size:10.5px;color:var(--ink3);padding-left:8px}
.td-con{font-size:11.5px;color:var(--ink2)}
.td-c{text-align:center}
.cbtn{width:30px;height:30px;border-radius:8px;border:1.5px solid var(--line2);background:var(--surf);font-size:14px;font-weight:700;color:var(--ink3);cursor:pointer;transition:all .1s}
.cbtn:hover{border-color:var(--navy2)}
.cbtn.sim{background:var(--green);border-color:var(--green);color:#fff}
.cbtn.nao{background:var(--red);border-color:var(--red);color:#fff}
.obs-tr td{background:var(--ambl)!important;padding:6px 16px 12px}
.obs-inp{width:100%;background:var(--surf);border:1.5px solid var(--amber);border-radius:8px;padding:8px 11px;font-size:12.5px;font-family:var(--font);color:var(--ink);outline:none;resize:vertical}
.sbar-ck{position:fixed;bottom:0;left:228px;right:0;background:var(--surf);border-top:1px solid var(--line2);padding:11px 26px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:50;font-size:12px;color:var(--ink3);box-shadow:0 -4px 16px rgba(11,48,87,.07)}
.btn-sv{background:var(--navy2);color:#fff;border:none;border-radius:10px;padding:11px 20px;font-size:13.5px;font-weight:700;cursor:pointer}
.btn-sv:hover{background:var(--navy)}
.co-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px}
.co-card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:14px 16px;cursor:pointer;box-shadow:var(--sh1);transition:transform .12s}
.co-card:hover{transform:translateY(-2px);box-shadow:var(--sh2)}
.co-top{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.co-av{width:34px;height:34px;border-radius:10px;background:var(--bluel);color:var(--navy2);font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.co-nm{font-weight:700;font-size:13.5px;letter-spacing:-.01em}
.co-ct{font-size:11px;color:var(--ink3)}
.co-bar{height:5px;background:var(--surf3);border-radius:4px;overflow:hidden;margin-top:8px}
.co-fill{height:100%;border-radius:4px;transition:width .3s}

/* ── AGENDA ── */
.ag-wrap{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);overflow:auto;box-shadow:var(--sh1)}
.ag-tbl{width:100%;border-collapse:collapse;min-width:880px}
.ag-tbl th{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.09em;color:var(--ink3);padding:11px 10px;background:var(--surf2);border-bottom:1px solid var(--line2);text-align:left}
.ag-tbl td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);vertical-align:top}
.ag-slot{font-family:var(--mono);font-size:11.5px;font-weight:700;color:var(--navy2);padding:12px 10px;background:var(--surf2);width:62px}
.ag-cell{padding:10px 12px;cursor:pointer;transition:background .1s;min-width:150px}
.ag-cell:hover{background:var(--bluel)}
.ag-cell.done{background:var(--greenl)}
.ag-cell.miss{background:var(--surf3);opacity:.6}
.ag-n{font-weight:600;font-size:12.5px;letter-spacing:-.01em;line-height:1.25}
.ag-s{font-size:10.5px;color:var(--ink3);margin-top:2px}
.ag-empty{padding:12px;color:var(--line2);text-align:center}
.ag-sex{background:var(--greenl);text-align:center;vertical-align:middle!important;padding:10px;width:44px}

/* ── CARTEIRA ── */
.uc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:12px}
.uc{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:14px 15px;cursor:pointer;transition:transform .12s,box-shadow .12s;box-shadow:var(--sh1)}
.uc:hover{transform:translateY(-2px);box-shadow:var(--sh2);border-color:var(--navy2)}
.uc-vip{border-color:var(--gira);box-shadow:0 0 0 1px var(--gira),var(--sh1)}
.uc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.uc-n{font-weight:700;font-size:13.5px;letter-spacing:-.01em;line-height:1.25}
.uc-rot{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:var(--bluel);color:var(--navy2);border-radius:5px;padding:3px 7px;flex-shrink:0}
.uc-c{font-size:11px;color:var(--ink3);margin:2px 0 9px}
.uc-kpis{display:flex;gap:10px;flex-wrap:wrap;font-size:11px;color:var(--ink3);margin-bottom:8px}
.uc-kpis b{color:var(--ink);font-weight:600}
.uc-bar{height:5px;background:var(--surf3);border-radius:4px;overflow:hidden}
.uc-fill{height:100%;border-radius:4px;transition:width .3s}
.uc-pct{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--ink3);margin-top:5px}

/* ── KANBAN ── */
.kb-wrap{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}
.kb-col{min-width:215px;flex:1}
.kb-h{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);border-top:3px solid;padding:9px 4px 8px;display:flex;justify-content:space-between;align-items:center}
.kb-n{background:var(--surf3);border-radius:10px;padding:1px 8px;font-size:10px}
.kb-card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r1);padding:10px 12px;margin-bottom:7px;cursor:pointer;box-shadow:var(--sh1);transition:transform .1s}
.kb-card:hover{transform:translateY(-1px);border-color:var(--navy2)}
.kb-t{font-weight:600;font-size:12.5px;letter-spacing:-.01em;line-height:1.3}
.kb-s{font-size:10.5px;color:var(--ink3);margin-top:3px}

/* ── UNIDADE ── */
.u-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);color:#fff;border-radius:var(--r3);padding:22px 24px;margin-bottom:18px;box-shadow:var(--sh2)}
.uh-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.uh-n{font-family:var(--disp);font-size:24px;font-weight:800;letter-spacing:-.02em}
.uh-c{font-size:12.5px;opacity:.78;margin-top:2px}
.uh-badges{display:flex;gap:7px;flex-wrap:wrap}
.uh-bad{font-family:var(--mono);font-size:10px;font-weight:700;border-radius:14px;padding:5px 11px;color:#fff}
.uh-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:8px;margin-top:18px}
.uh-k{background:rgba(255,255,255,.10);border-radius:10px;padding:11px 13px;backdrop-filter:blur(4px)}
.uh-kv{font-family:var(--disp);font-size:17px;font-weight:800;letter-spacing:-.01em;white-space:nowrap}
.uh-kt{font-size:10px;opacity:.72;margin-top:1px}
.uh-actions{display:flex;gap:9px;flex-wrap:wrap;align-items:center;margin-top:16px}
.uh-go{background:var(--gira);color:var(--navy);border:none;border-radius:10px;padding:11px 17px;font-size:13px;font-weight:700;cursor:pointer;transition:transform .12s}
.uh-go:hover{transform:scale(1.03)}
.uh-go.sec{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.28)}
.u-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start}
.u-grid .card{padding:16px}
.tl-it{display:flex;gap:11px;padding:9px 0;border-bottom:1px solid var(--line)}
.tl-it:last-child{border-bottom:none}
.tl-dot{width:9px;height:9px;border-radius:50%;margin-top:5px;flex-shrink:0}
.tl-t{font-size:13px;font-weight:600;line-height:1.4}
.tl-s{font-size:12px;color:var(--ink3);margin-top:2px;line-height:1.5}
#u-dossie .card{margin-bottom:16px}

/* ── R1 WIZARD ── */
.wz{background:var(--surf);border:1px solid var(--line);border-radius:var(--r3);padding:24px 26px;box-shadow:var(--sh1);max-width:780px}
.wz-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.wz-k{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.13em}
.wz-steps{display:flex;gap:6px}
.ws{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line2);background:var(--surf);font-size:11.5px;font-weight:700;color:var(--ink3);cursor:pointer}
.ws.on{background:var(--navy2);border-color:var(--navy2);color:#fff}
.ws.done{background:var(--greenl);border-color:var(--green);color:var(--greend)}
.wz-t{font-family:var(--disp);font-size:21px;font-weight:800;letter-spacing:-.02em;color:var(--navy)}
.wz-s{font-size:13px;color:var(--ink3);margin-top:3px}
.fala-box{background:var(--bluel);border-left:3px solid var(--navy2);border-radius:0 10px 10px 0;padding:12px 15px;font-size:13.5px;line-height:1.6;margin-top:14px;font-style:italic;color:var(--ink)}
.porq-box{background:var(--surf2);border-radius:10px;padding:12px 15px;font-size:12.5px;line-height:1.6;margin-top:10px;color:var(--ink2)}
.fb-k{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.13em;color:var(--ink3);margin-bottom:5px;font-style:normal}
.calc-box{background:var(--surf2);border:1px solid var(--line2);border-radius:var(--r2);padding:15px 17px;margin-top:14px}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.calc-grid label{font-size:11px;font-weight:600;color:var(--ink2);display:flex;flex-direction:column;gap:5px}
.calc-out{margin-top:13px;display:flex;flex-direction:column;gap:5px;font-size:13.5px}
.calc-out b{font-family:var(--mono)}
.wzr{display:flex;gap:8px;flex-wrap:wrap}
.wzr-b{background:var(--surf2);border:1.5px solid var(--line2);border-radius:10px;padding:10px 15px;font-size:12.5px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .1s}
.wzr-b:hover{border-color:var(--navy2)}
.wzr-b.on{background:var(--navy2);border-color:var(--navy2);color:#fff}
.wz-foot{display:flex;align-items:center;justify-content:space-between;margin-top:22px;padding-top:16px;border-top:1px solid var(--line)}

/* ── R2 ── */
.reinc-banner{background:var(--redl);border:1px solid var(--red);color:var(--red);border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600;margin:10px 0}
.r2b{border:1px solid var(--line);border-radius:var(--r2);padding:14px 16px;margin-top:11px;background:var(--surf)}
.r2b-t{font-weight:700;font-size:14px;letter-spacing:-.01em}
.r2b-s{font-weight:400;font-size:11.5px;color:var(--ink3);margin-left:8px}
.r2b-btns{display:flex;gap:8px;margin-top:10px}
.r2y,.r2n{flex:1;border-radius:10px;padding:10px;font-size:13px;font-weight:700;cursor:pointer;border:1.5px solid var(--line2);background:var(--surf2);color:var(--ink2);transition:all .1s}
.r2y.on{background:var(--green);border-color:var(--green);color:#fff}
.r2n.on{background:var(--red);border-color:var(--red);color:#fff}
.r2-mot{display:grid;grid-template-columns:1.4fr 1fr;gap:8px;margin-top:9px}

/* ── MODAL ── */
.modal-bg{position:fixed;inset:0;background:rgba(11,48,87,.5);backdrop-filter:blur(3px);z-index:120;display:none;align-items:center;justify-content:center;padding:18px}
.modal-bg.on{display:flex}
.modal{background:var(--surf);border-radius:var(--r3);box-shadow:var(--sh3);width:min(460px,94vw);max-height:88vh;overflow:auto;padding:24px}
.modal h3{font-family:var(--disp);font-size:18px;font-weight:800;letter-spacing:-.01em;color:var(--navy);margin-bottom:3px}
.m-sub{font-size:12.5px;color:var(--ink3);margin-bottom:14px}
.m-lbl{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--ink3);margin:12px 0 6px}
.m-inp,.m-sel{width:100%;background:var(--surf2);border:1.5px solid var(--line);border-radius:9px;padding:9px 12px;font-size:13.5px;font-family:var(--font);color:var(--ink);outline:none}
.m-inp:focus,.m-sel:focus{border-color:var(--navy2);background:var(--surf)}
.m-row{display:flex;gap:9px;justify-content:flex-end;margin-top:18px}
.m-btn{border:none;border-radius:9px;padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer}
.m-btn.pri{background:var(--navy2);color:#fff}
.m-btn.pri:hover{background:var(--navy)}
.m-btn.sec{background:var(--surf3);color:var(--ink2)}

/* ── ADMIN ── */
.adm-sec{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:18px 20px;margin-bottom:14px;box-shadow:var(--sh1)}
.adm-sec h3{font-family:var(--disp);font-size:15.5px;font-weight:800;letter-spacing:-.01em;color:var(--navy);margin-bottom:12px}
.adm-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);flex-wrap:wrap;font-size:13px}
.adm-row:last-child{border-bottom:none}
.adm-row .m-inp,.adm-row .m-sel{width:auto}

/* ── DRAWER FALAS ── */
.fab{position:fixed;bottom:22px;right:22px;width:52px;height:52px;border-radius:50%;background:var(--navy2);color:var(--gira);border:none;font-size:21px;cursor:pointer;box-shadow:var(--sh2);z-index:90;transition:transform .14s}
.fab:hover{transform:scale(1.08)}
.drawer-bg{position:fixed;inset:0;background:rgba(11,48,87,.4);z-index:100;opacity:0;pointer-events:none;transition:opacity .2s}
.drawer-bg.on{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:-420px;width:min(400px,92vw);height:100vh;background:var(--surf);box-shadow:var(--sh3);z-index:110;display:flex;flex-direction:column;transition:right .22s ease}
.drawer.on{right:0}
.dr-head{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 12px}
.dr-t{font-family:var(--disp);font-size:17px;font-weight:800;color:var(--navy)}
.dr-close{background:var(--surf3);border:none;border-radius:8px;width:28px;height:28px;cursor:pointer;color:var(--ink2);font-size:13px}
.dr-search{margin:0 18px 10px;background:var(--surf2);border:1.5px solid var(--line);border-radius:9px;padding:9px 12px;font-size:13px;font-family:var(--font);outline:none}
.dr-search:focus{border-color:var(--navy2)}
.dr-body{flex:1;overflow-y:auto;padding:0 18px 24px}
.dr-sec{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin:16px 0 7px}
.dr-it{background:var(--surf2);border:1px solid var(--line);border-radius:var(--r1);margin-bottom:6px;overflow:hidden}
.dr-it-h{display:flex;justify-content:space-between;align-items:center;padding:10px 13px;font-size:12.5px;font-weight:600;cursor:pointer}
.dr-it-b{display:none;padding:0 13px 12px}
.dr-it.open .dr-it-b{display:block}
.dr-fala{background:var(--surf);border-left:3px solid var(--navy2);border-radius:0 8px 8px 0;padding:10px 12px;font-size:12.5px;font-style:italic;line-height:1.55;margin-top:8px;position:relative}
.dr-cp{display:block;margin-top:8px;background:var(--bluel);color:var(--navy2);border:none;border-radius:7px;padding:5px 11px;font-size:11px;font-weight:700;cursor:pointer;font-style:normal}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,16px);background:var(--navy);color:#fff;border-radius:12px;padding:12px 20px;font-size:13px;font-weight:600;box-shadow:var(--sh3);z-index:300;opacity:0;pointer-events:none;transition:all .22s;max-width:90vw;text-align:center}
#toast.show{opacity:1;transform:translate(-50%,0)}


/* ── USUÁRIOS ── */
.usr-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px;background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:12px 14px;box-shadow:var(--sh1)}
.usr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:10px}
.usr-card{display:flex;align-items:center;gap:11px;background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:11px 13px;cursor:pointer;transition:border .12s,box-shadow .12s;box-shadow:var(--sh1);position:relative}
.usr-card:hover{border-color:var(--navy2);box-shadow:var(--sh2)}
.usr-card.sel{border-color:var(--navy2);background:#F2F7FD;box-shadow:0 0 0 1px var(--navy2),var(--sh1)}
.usr-check{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--line2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;background:var(--surf)}
.usr-card.sel .usr-check{background:var(--navy2);border-color:var(--navy2)}
.usr-av{width:38px;height:38px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}
.usr-main{flex:1;min-width:0}
.usr-nm{font-weight:700;font-size:13.5px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.usr-nologin{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.06em;background:var(--ambl);color:var(--ambd);border-radius:5px;padding:1px 6px;vertical-align:middle}
.usr-meta{font-size:11.5px;color:var(--ink3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.usr-lig{font-size:11px;color:var(--greend);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.usr-tags{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}
.usr-tipo{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.05em;color:#fff;border-radius:6px;padding:3px 8px;white-space:nowrap}
.usr-role{font-family:var(--mono);font-size:8px;font-weight:600;background:var(--surf3);color:var(--ink2);border-radius:4px;padding:2px 6px;margin-left:3px}
.usr-pag{display:flex;align-items:center;justify-content:center;gap:10px;padding:18px 0 4px}
.wk-btn:disabled{opacity:.35;cursor:not-allowed}
@media (max-width:560px){.usr-grid{grid-template-columns:1fr}.usr-tags{display:none}}


.usr-eqbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;width:100%;margin-top:10px;padding-top:10px;border-top:1px dashed var(--line2)}
.usr-eqlbl{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-right:2px}
.eqchip{background:var(--surf2);border:1px solid var(--line2);border-radius:14px;padding:4px 11px;font-size:11px;font-weight:600;color:var(--ink2);cursor:pointer;white-space:nowrap}
.eqchip:hover{border-color:var(--blue)}
.eqchip.on{background:var(--blue);border-color:var(--blue);color:#fff}
.usr-eqs{font-size:11px;color:var(--blue);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}


/* ── REUNIÕES (iframe GiraBot) ── */
.rn-wrap{display:flex;flex-direction:column;height:calc(100vh - 110px);min-height:520px}
.rn-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;background:var(--surf);border:1px solid var(--line);border-radius:var(--r2) var(--r2) 0 0;padding:8px 12px;box-shadow:var(--sh1)}
.rn-tabs{display:flex;gap:6px;flex-wrap:wrap}
.rn-tab{background:var(--surf2);border:1px solid var(--line2);border-radius:9px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--ink2);cursor:pointer}
.rn-tab:hover{border-color:var(--navy2)}
.rn-tab.on{background:var(--navy2);border-color:var(--navy2);color:#fff}
.rn-actions{display:flex;gap:6px}
.rn-act{width:34px;height:34px;border-radius:8px;border:1px solid var(--line2);background:var(--surf2);cursor:pointer;font-size:15px;color:var(--ink2);display:flex;align-items:center;justify-content:center}
.rn-act:hover{border-color:var(--navy2);color:var(--navy2)}
.rn-act:last-child{width:auto;padding:0 12px;font-size:12.5px;font-weight:600;gap:4px}
.rn-frame-box{flex:1;position:relative;border:1px solid var(--line);border-top:none;border-radius:0 0 var(--r2) var(--r2);overflow:hidden;background:var(--surf2)}
.rn-frame{width:100%;height:100%;border:none;display:block;background:#fff}
.rn-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--ink3);font-size:13px;background:var(--surf2);z-index:2}
.rn-foot:empty{display:none}
.rn-block{background:var(--ambl);border:1px solid var(--amber);border-radius:0 0 var(--r2) var(--r2);padding:10px 14px;font-size:12.5px;color:var(--ambd);display:flex;align-items:center;flex-wrap:wrap}
@media (max-width:940px){.rn-wrap{height:calc(100vh - 150px)}}


.rn-launch{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;background:linear-gradient(160deg,var(--surf) 0%,var(--surf2) 100%)}
.rn-launch-t{font-family:var(--disp);font-size:20px;font-weight:800;color:var(--navy);letter-spacing:-.02em}
.rn-launch-s{font-size:13px;color:var(--ink3);max-width:420px;line-height:1.6;margin:8px 0 18px}
.rn-launch-btn{background:var(--navy2);color:#fff;border:none;border-radius:11px;padding:13px 26px;font-size:14px;font-weight:700;cursor:pointer;transition:transform .12s}
.rn-launch-btn:hover{transform:scale(1.04);background:var(--navy)}
.rn-launch-alt{margin-top:14px}
.rn-launch-alt button{background:none;border:none;color:var(--ink3);font-size:12px;text-decoration:underline;cursor:pointer}
.rn-launch-alt button:hover{color:var(--navy2)}

/* ── RESPONSIVO ── */
@media (max-width:940px){
  #s-app:not(.hidden){flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;flex-direction:row;align-items:center;gap:4px;padding-right:8px}
  .sb-brand{border-bottom:none;padding:12px 14px;flex-shrink:0}
  .sb-brand>div .sb-s{display:none}
  .sb-nav{flex-direction:row;overflow-x:auto;padding:8px 4px;gap:3px}
  .sb-it{white-space:nowrap;padding:8px 11px}
  .sb-it.on{box-shadow:inset 0 -3px 0 var(--gira)}
  .sb-user{border-top:none;padding:8px}
  .su-i{display:none}
  .topbar,.content{padding-left:16px;padding-right:16px}
  .sbar-ck{left:0}
  .u-grid{grid-template-columns:1fr}
  .calc-grid,.r2-mot{grid-template-columns:1fr}
  .wz{padding:18px 16px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ═══════════ (a) VER COMO ═══════════ */
.vc-faixa{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(90deg,#E8A413,#F0B73E);color:#3a2c05;font-size:13px;font-weight:600;text-align:center;padding:8px 16px;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.vc-faixa b{font-weight:800}
.vc-faixa button{margin-left:12px;background:rgba(0,0,0,.18);color:#fff;border:none;border-radius:7px;padding:4px 12px;font-size:12px;font-weight:700;cursor:pointer}
.vc-faixa button:hover{background:rgba(0,0,0,.3)}
body:has(.vc-faixa){padding-top:38px}
.vc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.vc-card{text-align:left;background:var(--surf);border:1.5px solid var(--line2);border-radius:12px;padding:14px;cursor:pointer;transition:all .12s}
.vc-card:hover{border-color:var(--blue);box-shadow:var(--sh2);transform:translateY(-1px)}
.vc-card.on{border-color:var(--blue);background:#F2F7FD;box-shadow:0 0 0 1px var(--blue)}
.vc-ic{font-size:22px;margin-bottom:6px}
.vc-nm{font-weight:700;font-size:14px;margin-bottom:3px}
.vc-ds{font-size:11.5px;color:var(--ink3);line-height:1.45}

/* ═══════════ (b) PAINEL EXECUTIVO ═══════════ */
.pn-wrap{display:flex;flex-direction:column;gap:14px}
.pn-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px}
.pn-kpi{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:16px 18px;box-shadow:var(--sh1)}
.pn-kpi-ic{font-size:20px;margin-bottom:6px}
.pn-kpi-val{font-family:var(--disp);font-weight:800;font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--navy)}
.pn-kpi-lb{font-weight:600;font-size:13px;margin-top:4px}
.pn-kpi-sub{font-size:11px;color:var(--ink3);margin-top:2px}
.pn-card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r2);padding:16px 18px;box-shadow:var(--sh1)}
.pn-card-h{font-family:var(--disp);font-weight:700;font-size:15px;margin-bottom:14px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.pn-sub{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--ink3);background:var(--surf3);border-radius:5px;padding:2px 7px;letter-spacing:.03em}
.pn-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pn-empty{font-size:12.5px;color:var(--ink3);background:var(--surf2);border-radius:10px;padding:14px;line-height:1.55;text-align:center}
.pn-bars{display:flex;flex-direction:column;gap:14px}
.pn-bar-top{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:5px;font-weight:500}
.pn-bar-track{height:10px;background:var(--surf3);border-radius:6px;overflow:hidden}
.pn-bar-track>div{height:100%;border-radius:6px;transition:width .5s}
/* mapa */
.pn-mapa-wrap{display:flex;justify-content:center}
.pn-mapa{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;max-width:330px;width:100%}
.pn-mc{aspect-ratio:1;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--mono);position:relative;transition:transform .1s;cursor:default}
.pn-mc:hover{transform:scale(1.08);z-index:2;box-shadow:var(--sh2)}
.pn-mc-empty{background:transparent!important;pointer-events:none}
.pn-mc-uf{font-size:9px;font-weight:700;letter-spacing:.02em}
.pn-mc-n{font-size:10px;font-weight:800;margin-top:1px}
.pn-legend{display:flex;align-items:center;gap:5px;justify-content:center;font-size:10.5px;color:var(--ink3);margin-top:12px}
.pn-lg{width:13px;height:13px;border-radius:3px;display:inline-block;margin-left:8px}
.pn-lg:first-child{margin-left:0}
/* ranking */
.pn-rank{display:flex;flex-direction:column;gap:5px}
.pn-rk-row{display:flex;align-items:center;gap:8px;font-size:12.5px}
.pn-rk-pos{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--ink3);width:18px;text-align:right}
.pn-rk-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.pn-rk-nm{font-weight:600;min-width:0;flex-shrink:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.pn-rk-uf{font-family:var(--mono);font-size:9px;font-weight:700;color:var(--ink3);background:var(--surf3);border-radius:4px;padding:1px 5px}
.pn-rk-bar{flex:1;height:7px;background:var(--surf3);border-radius:4px;overflow:hidden;min-width:40px}
.pn-rk-bar>div{height:100%;border-radius:4px}
.pn-rk-val{font-family:var(--mono);font-weight:700;font-size:12px;width:30px;text-align:right}
.pn-rk-an{font-size:10px;width:54px;text-align:right;color:var(--ink3)}
.pn-more{font-size:11.5px;color:var(--ink3);text-align:center;margin-top:8px}
/* por uf */
.pn-uf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.pn-uf{background:var(--surf2);border:1px solid var(--line);border-radius:9px;padding:9px 11px}
.pn-uf-sigla{font-family:var(--mono);font-weight:800;font-size:13px;color:var(--navy)}
.pn-uf-nm{font-size:11px;color:var(--ink2);margin:1px 0 3px}
.pn-uf-n{font-size:11px;color:var(--ink3)}
.pn-uf-n b{color:var(--ink1);font-size:12px}
@media (max-width:880px){.pn-2col{grid-template-columns:1fr}}

/* ═══════════ PAINEL · Atenção Financeira (GiraFin) ═══════════ */
.pn-fin{background:linear-gradient(180deg,#FFF8F3,var(--surf));border:1px solid #F0D0BC;border-radius:var(--r2);padding:16px 18px;box-shadow:var(--sh1)}
.pn-fin-h{font-family:var(--disp);font-weight:700;font-size:15px;margin-bottom:14px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.pn-fin-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:14px}
.pn-fin-kpi{background:var(--surf);border:1px solid var(--line);border-radius:11px;padding:13px 15px;box-shadow:var(--sh1)}
.pn-fin-ic{font-size:17px;margin-bottom:4px}
.pn-fin-val{font-family:var(--disp);font-weight:800;font-size:27px;line-height:1;letter-spacing:-.02em}
.pn-fin-lb{font-weight:600;font-size:12.5px;margin-top:3px}
.pn-fin-reg{font-weight:600;font-size:12.5px;min-width:0;flex-shrink:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.pn-fin-tags{display:flex;gap:5px;flex-wrap:wrap;margin-left:auto;justify-content:flex-end}
.pn-tag{font-size:10px;font-weight:600;border-radius:5px;padding:2px 7px;white-space:nowrap}
.pn-tag-red{background:#FBE8E4;color:#A3271A}
.pn-tag-org{background:#FCEEDD;color:#9A5410}
.pn-tag-down{background:#FAE5DC;color:#9A3412}
.pn-crit{display:flex;flex-direction:column;gap:6px}
.pn-crit-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;background:var(--surf);border:1px solid var(--line);border-radius:9px;font-size:12.5px}
.pn-crit-main{display:flex;align-items:center;gap:7px;min-width:0;flex-shrink:1}
.pn-crit-main b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.pn-crit-reg{font-size:10.5px;color:var(--ink3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px}
.pn-crit-nums{display:flex;align-items:center;gap:8px;flex-shrink:0}
.pn-crit-fat{font-family:var(--mono);font-weight:600;font-size:11.5px;color:var(--ink2)}
.pn-crit-prej{font-family:var(--mono);font-weight:700;font-size:11.5px;color:#C2410C}
.pn-crit-var{font-family:var(--mono);font-weight:700;font-size:11px;border-radius:4px;padding:1px 6px}
.pn-crit-var.neg{background:#FBE8E4;color:#A3271A}
.pn-crit-var.pos{background:#E3F4EC;color:#15803D}

/* ═══════════ Editor de roteiros (R1-R4) ═══════════ */
.rot-grupo{border:1px solid var(--line);border-radius:11px;padding:12px;margin-bottom:10px;background:var(--surf2)}
.rot-grupo-h{display:flex;justify-content:space-between;align-items:center;font-family:var(--disp);font-weight:700;font-size:13.5px;margin-bottom:8px}
.rot-count{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--ink3);background:var(--surf3);border-radius:5px;padding:2px 7px}
.rot-bloco{display:flex;align-items:center;gap:9px;background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:8px 11px;margin-bottom:5px}
.rot-ic{font-size:16px;width:22px;text-align:center}
.rot-info{flex:1;min-width:0;display:flex;flex-direction:column}
.rot-info b{font-size:13px;font-weight:600}
.rot-info span{font-size:11px;color:var(--ink3)}
.rot-edit{background:var(--surf3);border:none;border-radius:6px;padding:5px 11px;font-size:11.5px;font-weight:600;color:var(--ink2);cursor:pointer}
.rot-edit:hover{background:var(--navy2);color:#fff}
.rot-del{background:none;border:none;color:var(--ink3);cursor:pointer;font-size:13px;padding:4px 6px}
.rot-del:hover{color:var(--red)}
.rot-add{width:100%;background:none;border:1px dashed var(--line2);border-radius:8px;padding:8px;font-size:12px;color:var(--ink3);cursor:pointer;margin-top:3px}
.rot-add:hover{border-color:var(--blue);color:var(--blue)}
/* métricas */
.met-grid{display:flex;flex-direction:column;gap:8px}
.met-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surf2);border:1px solid var(--line);border-radius:9px;padding:10px 13px}
.met-lb{display:flex;flex-direction:column}
.met-lb b{font-size:13px;font-weight:600}
.met-lb span{font-size:11px;color:var(--ink3)}
/* modal genérico */
.modal-bg{position:fixed;inset:0;background:rgba(11,48,87,.45);display:none;align-items:center;justify-content:center;z-index:10000;padding:20px}
.modal-bg.on{display:flex}
.modal-card{background:var(--surf);border-radius:16px;max-width:460px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-h{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surf)}
.modal-h b{font-family:var(--disp);font-size:16px}
.modal-h button{background:none;border:none;font-size:18px;cursor:pointer;color:var(--ink3)}
.modal-form{padding:16px 18px;display:flex;flex-direction:column;gap:4px}
.modal-form label{font-size:11.5px;font-weight:600;color:var(--ink2);margin-top:8px}
.modal-form textarea.m-inp{resize:vertical;font-family:inherit}
.modal-acts{display:flex;gap:8px;justify-content:flex-end;padding:14px 18px;border-top:1px solid var(--line)}
/* VIP star + fase no card */
.uc{position:relative}
.uc-star{position:absolute;top:8px;right:8px;background:none;border:none;font-size:18px;cursor:pointer;z-index:2;line-height:1;padding:2px;color:var(--amber)}
.uc-star:hover{transform:scale(1.2)}
.uc-star.on{filter:drop-shadow(0 1px 2px rgba(232,164,19,.4))}
.uc-fase{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.03em;border-radius:5px;padding:1px 6px;margin-left:4px;white-space:nowrap}

/* ═══════════ Config de rotação ═══════════ */
.rot-cfg-bloco{background:var(--surf);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:12px}
.rot-cfg-t{font-family:var(--disp);font-weight:700;font-size:13.5px;margin-bottom:10px;color:var(--navy)}
.rot-warn{font-size:11.5px;color:#9a5410;background:#FCEEDD;border-radius:8px;padding:8px 11px;margin-top:8px;line-height:1.5}
/* pesos (sliders) */
.peso-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid var(--line)}
.peso-row:last-of-type{border-bottom:none}
.peso-lb{display:flex;flex-direction:column;min-width:0;flex:1}
.peso-lb b{font-size:13px;font-weight:600}
.peso-lb span{font-size:11px;color:var(--ink3)}
.peso-ctrl{display:flex;align-items:center;gap:10px;min-width:170px}
.peso-ctrl input[type=range]{flex:1;accent-color:var(--green)}
.peso-pct{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--green);width:38px;text-align:right}
.rot-toggles{margin-top:10px;display:flex;flex-direction:column;gap:6px}
.tg-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:6px 0}
.tg-sw{width:42px;height:24px;border-radius:13px;background:var(--line2);border:none;position:relative;cursor:pointer;transition:background .15s;flex-shrink:0}
.tg-sw::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:left .15s}
.tg-sw.on{background:var(--green)}
.tg-sw.on::after{left:20px}
/* turmas/slots */
.rot-turma{background:var(--surf2);border:1px solid var(--line);border-radius:10px;padding:11px;margin-bottom:8px}
.rot-turma-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.rot-turma-h b{font-family:var(--disp);font-size:13px}
.rot-turma-dias{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--ink3);background:var(--surf3);border-radius:5px;padding:2px 7px}
.rot-slot{display:flex;align-items:center;gap:9px;background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:7px 10px;margin-bottom:4px}
.rot-slot-h{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--navy);width:48px}
.rot-slot-d{font-size:11.5px;color:var(--ink2);flex:1}
.rot-slot-off{font-size:10px;font-weight:600;color:var(--ink3);background:var(--surf3);border-radius:4px;padding:1px 6px}

/* ═══════════ PAINEL · Destaques positivos ═══════════ */
.pn-bom{background:linear-gradient(180deg,#F1FAF5,var(--surf));border:1px solid #BFE6D2;border-radius:var(--r2);padding:16px 18px;box-shadow:var(--sh1)}
.pn-bom-h{font-family:var(--disp);font-weight:700;font-size:15px;margin-bottom:14px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}

/* ═══════════ Botão "Entrar na reunião" (vídeo) ═══════════ */
.uh-go.vid{background:linear-gradient(135deg,#2D8CFF,#1E6FD9);color:#fff;display:inline-flex;align-items:center;gap:7px}
.uh-go.vid:hover{transform:scale(1.03);box-shadow:0 4px 14px rgba(45,140,255,.35)}
.uh-go.vid:disabled{opacity:.7;cursor:wait;transform:none}
.spin-sm{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;vertical-align:middle}

/* ═══════════ Tela NATIVA de Reuniões ═══════════ */
.rn2-load{display:flex;align-items:center;gap:10px;justify-content:center;padding:50px;color:var(--ink3);font-size:14px}
.rn2-wrap{max-width:920px;margin:0 auto}
.rn2-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.rn2-tt{font-family:var(--disp);font-weight:800;font-size:22px;letter-spacing:-.02em}
.rn2-sub{font-size:13px;color:var(--ink3);margin-top:3px}
.rn2-kpis{display:flex;gap:8px}
.rn2-kpi{font-size:12.5px;background:var(--surf2);border:1px solid var(--line);border-radius:20px;padding:6px 13px;color:var(--ink2)}
.rn2-kpi b{font-size:15px;color:var(--navy)}
.rn2-kpi.ok b{color:var(--green)}
.rn2-list{display:flex;flex-direction:column;gap:9px}
.rn2-card{display:flex;align-items:center;gap:14px;background:var(--surf);border:1px solid var(--line);border-radius:13px;padding:13px 15px;transition:box-shadow .14s,transform .14s}
.rn2-card:hover{box-shadow:var(--sh1)}
.rn2-card.feita{opacity:.62}
.rn2-when{text-align:center;min-width:62px;flex-shrink:0}
.rn2-dia{font-size:11px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.04em}
.rn2-hora{font-family:var(--mono);font-weight:700;font-size:15px;color:var(--navy)}
.rn2-mid{flex:1;min-width:0;cursor:pointer}
.rn2-nome{font-family:var(--disp);font-weight:700;font-size:15.5px;letter-spacing:-.01em}
.rn2-meta{font-size:12px;color:var(--ink3);margin-top:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.rn2-tag{color:#fff;font-weight:700;font-size:10.5px;border-radius:5px;padding:2px 7px;letter-spacing:.02em}
.rn2-act{display:flex;align-items:center;gap:7px;flex-shrink:0}
.rn2-enter{background:linear-gradient(135deg,#2D8CFF,#1E6FD9);color:#fff;border:none;border-radius:10px;padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:transform .12s,box-shadow .12s;white-space:nowrap}
.rn2-enter:hover{transform:scale(1.04);box-shadow:0 4px 14px rgba(45,140,255,.35)}
.rn2-enter:disabled{opacity:.7;cursor:wait;transform:none}
.rn2-done{font-size:13px;font-weight:700;color:var(--green);padding:0 8px}
.rn2-open{background:var(--surf2);border:1px solid var(--line);color:var(--ink2);width:36px;height:36px;border-radius:9px;font-size:17px;cursor:pointer;transition:background .12s}
.rn2-open:hover{background:var(--surf3)}

/* ═══════════ Sala de vídeo (LiveKit) ═══════════ */
.lk-wrap{display:flex;flex-direction:column;height:calc(100vh - 130px);min-height:480px;gap:12px}
.lk-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.lk-title{font-family:var(--disp);font-weight:800;font-size:18px;letter-spacing:-.01em}
.lk-rec{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:#E5484D;background:#FDEEEE;border:1px solid #F5C6C7;border-radius:20px;padding:5px 12px}
.lk-rec-dot{width:9px;height:9px;border-radius:50%;background:#E5484D;animation:lkpulse 1.4s infinite}
@keyframes lkpulse{0%,100%{opacity:1}50%{opacity:.25}}
.lk-stage{flex:1;display:grid;grid-template-columns:1fr;gap:10px;background:#0E1726;border-radius:16px;padding:12px;overflow:auto;align-content:center}
.lk-tile{position:relative;background:#1A2436;border-radius:12px;overflow:hidden;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;min-height:160px}
.lk-tile.local{outline:2px solid var(--gira)}
.lk-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000}
.lk-tile-ph{width:74px;height:74px;border-radius:50%;background:linear-gradient(135deg,#2D8CFF,#1E6FD9);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-weight:700;font-size:30px}
.lk-tile-nome{position:absolute;left:10px;bottom:9px;background:rgba(0,0,0,.6);color:#fff;font-size:12px;font-weight:600;padding:3px 9px;border-radius:7px;z-index:2}
.lk-connecting,.lk-erro{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#cdd6e4;font-size:14px;text-align:center;padding:40px}
.lk-erro b{color:#fff}
.lk-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:6px}
.lk-ctrl{display:flex;flex-direction:column;align-items:center;gap:3px;background:var(--surf2);border:1px solid var(--line);border-radius:13px;padding:10px 16px;font-size:20px;cursor:pointer;transition:transform .1s,background .12s;min-width:62px}
.lk-ctrl span{font-size:11px;font-weight:600;color:var(--ink2)}
.lk-ctrl:hover{transform:translateY(-1px)}
.lk-ctrl.off{background:#FDEEEE;border-color:#F5C6C7}
.lk-ctrl.off span{color:#E5484D}
.lk-ctrl.leave{background:#E5484D;border-color:#E5484D}
.lk-ctrl.leave span{color:#fff}
@media(max-width:640px){.lk-wrap{height:calc(100vh - 110px)}.lk-ctrl{padding:9px 12px;min-width:54px}}

/* ═══════════════════════════════════════════════════════════
   MOBILE-FIRST — experiência de app (tab bar + bottom sheet)
   ═══════════════════════════════════════════════════════════ */
/* elementos mobile escondidos por padrão (desktop) */
.tabbar,.tb-brand-m,.sheet,.sheet-bg{display:none}

/* marca compacta no topo (só mobile) */
.tb-brand-m{align-items:center;gap:8px}
.tb-emoji-m{font-size:20px}
.tb-name-m{font-family:var(--disp);font-weight:800;font-size:16px;letter-spacing:-.02em;color:var(--navy)}

/* TAB BAR inferior */
.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:90;background:var(--surf);
  border-top:1px solid var(--line);display:flex;justify-content:space-around;align-items:stretch;
  padding:5px 4px calc(5px + env(safe-area-inset-bottom)) 4px;box-shadow:0 -2px 14px rgba(11,48,87,.07)}
.tab-it{flex:1;background:none;border:none;cursor:pointer;display:flex;flex-direction:column;
  align-items:center;gap:2px;padding:5px 2px;border-radius:12px;color:var(--ink3);transition:color .12s;min-height:50px;justify-content:center}
.tab-ic{font-size:21px;line-height:1}
.tab-lb{font-size:10px;font-weight:600;letter-spacing:-.01em}
.tab-it.on{color:var(--navy2)}
.tab-it.on .tab-ic{transform:translateY(-1px)}
.tab-it:active{background:var(--surf2)}

/* BOTTOM SHEET (menu "Mais") */
.sheet-bg{position:fixed;inset:0;background:rgba(11,32,43,.45);z-index:95;opacity:0;transition:opacity .2s}
.sheet-bg.on{display:block;opacity:1}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:96;background:var(--surf);
  border-radius:22px 22px 0 0;padding:8px 18px calc(20px + env(safe-area-inset-bottom));
  transform:translateY(100%);transition:transform .26s cubic-bezier(.32,.72,0,1);max-height:80vh;overflow:auto;box-shadow:0 -8px 40px rgba(11,32,43,.25)}
.sheet.on{display:block;transform:translateY(0)}
.sheet-handle{width:40px;height:4px;border-radius:3px;background:var(--line2);margin:8px auto 14px}
.sheet-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.sheet-head span{font-family:var(--disp);font-weight:800;font-size:18px;color:var(--navy)}
.sheet-x{background:var(--surf2);border:none;width:32px;height:32px;border-radius:50%;font-size:15px;color:var(--ink2);cursor:pointer}
.sheet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.sheet-it{background:var(--surf2);border:1px solid var(--line);border-radius:14px;padding:16px 8px;
  display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;color:var(--ink2);font-size:12px;font-weight:600;transition:all .12s}
.sheet-it:active{transform:scale(.96)}
.sheet-it.on{background:var(--navy2);color:#fff;border-color:var(--navy2)}
.sheet-ic{font-size:24px}
.sheet-user{border-top:1px solid var(--line);padding-top:12px}

/* ───────── BREAKPOINT: vira app no celular/tablet estreito ───────── */
@media (max-width:820px){
  /* esconde o menu lateral, conteúdo ocupa tudo */
  .sidebar{display:none}
  .tabbar{display:flex}
  .tb-brand-m{display:flex}
  /* header compacto: marca à esquerda, título some (a tab bar já indica onde está) */
  .topbar{padding:10px 16px;gap:10px}
  .tb-l{display:none}
  .tb-apres{display:none} /* apresentação não faz sentido no celular */
  /* dá respiro embaixo pra não cobrir conteúdo com a tab bar */
  .content{padding:16px 14px calc(80px + env(safe-area-inset-bottom))}
  /* week-nav e carteira-sel continuam acessíveis no header, mais compactos */
  .wk-lbl{font-size:11px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .cart-sel{max-width:150px}
  /* FAB de falas sobe pra não colidir com a tab bar */
  .fab{bottom:calc(74px + env(safe-area-inset-bottom))!important}
}

/* telas bem pequenas: aperta um pouco mais */
@media (max-width:380px){
  .tab-lb{font-size:9px}
  .tab-ic{font-size:19px}
  .tb-name-m{font-size:14px}
  .sheet-grid{grid-template-columns:repeat(2,1fr)}
}

/* ───────── Telas internas no mobile (tabelas/boards viram tátil) ───────── */
@media (max-width:820px){
  /* AGENDA: a tabela semanal rola na horizontal com toque suave */
  .ag-wrap{-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;border-radius:14px}
  .ag-cell,.ag-tbl th{min-width:124px;scroll-snap-align:start}
  .ag-tbl th{font-size:11px;padding:8px 10px}
  .ag-cell{padding:9px 10px}
  .ag-n{font-size:13px}
  .ag-s{font-size:10.5px}

  /* KANBAN: colunas em carrossel horizontal com snap (cada coluna ~80% da tela) */
  .kb-board{display:flex;gap:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;padding-bottom:8px;margin:0 -14px;padding-left:14px;padding-right:14px}
  .kb-col{min-width:78vw;max-width:78vw;flex:0 0 auto;scroll-snap-align:center}

  /* PAINEL: as 2 colunas viram 1 empilhada */
  .pn-2col{grid-template-columns:1fr!important}
  .pn-fin-kpis{grid-template-columns:repeat(2,1fr)!important}

  /* CARTEIRA / listas de cartões: 1 coluna cheia */
  .uc-grid,.cards-grid{grid-template-columns:1fr!important}

  /* qualquer tabela solta rola em vez de estourar a tela */
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}

  /* modais ocupam quase a tela toda, mais confortável no dedo */
  .modal{width:calc(100vw - 24px)!important;max-width:none!important;max-height:88vh;overflow:auto}

  /* títulos de tela um pouco menores */
  .pn-tt,.rn2-tt,.uh-nome{font-size:19px}

  /* áreas de toque mínimas (acessibilidade) */
  button,.tab-it,.sheet-it,select,.m-btn{min-height:40px}
}

/* ═══════════ PWA — botão instalar + instrução iOS ═══════════ */
.pwa-install{position:fixed;right:16px;bottom:calc(86px + env(safe-area-inset-bottom));z-index:88;
  background:linear-gradient(135deg,#FFD54F,#FFC107);color:#0B3057;border:none;border-radius:24px;
  padding:11px 18px;font-size:13.5px;font-weight:800;font-family:var(--font);cursor:pointer;
  box-shadow:0 6px 20px rgba(11,48,87,.28);display:flex;align-items:center;gap:6px;animation:pwaIn .4s ease}
.pwa-install:active{transform:scale(.96)}
@keyframes pwaIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
/* no desktop, o botão fica mais discreto embaixo à direita */
@media (min-width:821px){ .pwa-install{bottom:24px} }

.pwa-ios-bg{position:fixed;inset:0;background:rgba(11,32,43,.55);z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:pwaIn .25s ease}
.pwa-ios-card{background:#fff;border-radius:22px 22px 0 0;padding:26px 22px calc(26px + env(safe-area-inset-bottom));max-width:480px;width:100%;box-shadow:0 -10px 40px rgba(0,0,0,.3)}
@media (min-width:560px){ .pwa-ios-bg{align-items:center} .pwa-ios-card{border-radius:22px;margin-bottom:0} }
.pwa-ios-h{font-family:var(--disp);font-weight:800;font-size:19px;color:var(--navy);margin-bottom:12px}
.pwa-ios-b{font-size:14px;color:var(--ink2);line-height:1.65}
.pwa-ios-x{margin-top:18px;width:100%;background:var(--navy);color:#fff;border:none;border-radius:12px;padding:13px;font-size:14px;font-weight:700;cursor:pointer}

/* botão de ativar notificações (no menu Mais) */
.mais-notif{margin-top:12px;width:100%;background:var(--surf2);border:1.5px solid var(--navy2);color:var(--navy2);
  border-radius:12px;padding:11px;font-size:13.5px;font-weight:700;font-family:var(--font);cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:7px;transition:all .12s}
.mais-notif:active{transform:scale(.97);background:var(--navy2);color:#fff}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVIDADE TOTAL — corrige cortes e cobre todas as telas
   ═══════════════════════════════════════════════════════════ */
@media (max-width:820px){
  /* o header não comporta marca+título+select+semana juntos:
     o select de regional e a navegação de semana descem pra linha própria */
  .topbar{flex-wrap:wrap;row-gap:8px}
  .tb-r{width:100%;justify-content:space-between;order:3;flex-wrap:wrap;gap:8px}
  .cart-sel{max-width:none;flex:1;min-width:140px}
  .wk-nav{flex:0 0 auto}
  .tb-brand-m{flex:1;min-width:0}
  .tb-name-m{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
}

/* TABLET (821–1100): conteúdo respira */
@media (min-width:821px) and (max-width:1100px){
  .content{padding:20px 20px 60px}
}

/* telas pequenas (≤360px): aperta com cuidado */
@media (max-width:360px){
  .content{padding:12px 10px calc(80px + env(safe-area-inset-bottom))}
  .tb-name-m{font-size:13px}
  .tb-emoji-m{font-size:17px}
  .kpi{padding:11px 12px}
  .modal{width:calc(100vw - 16px)!important;padding:18px}
  .lk-tile{min-height:130px}
  .sheet-grid{grid-template-columns:repeat(2,1fr)}
}

/* desktop wide (≥1500): limita largura central */
@media (min-width:1500px){
  .content{max-width:1360px;margin-left:auto;margin-right:auto}
}

/* PAISAGEM no celular (altura baixa): barras mais finas */
@media (max-height:480px) and (orientation:landscape){
  .topbar{padding:7px 14px}
  .tabbar{padding:3px 4px calc(3px + env(safe-area-inset-bottom))}
  .tab-it{min-height:42px}
  .tab-ic{font-size:18px}
  .tab-lb{font-size:9px}
}

/* anti-overflow universal — nada estoura a largura da tela */
*{max-width:100%}
img,video,svg,canvas{max-width:100%;height:auto}
input,select,textarea{max-width:100%}
