/* ── RESET & VARIABLES ── */
*{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#f0f2f5;--bg2:#fff;--border:#e5e7eb;--text:#111;--text2:#6b7280;--text3:#9ca3af;--primary:#4f6ef7;--primary-light:#eef2ff;--topbar:#1a1a2e;--card-shadow:0 1px 3px rgba(0,0,0,.06)}
.dark{--bg:#0f1117;--bg2:#1a1d27;--border:#2d3148;--text:#e5e7eb;--text2:#9ca3af;--text3:#6b7280;--primary:#6b84f8;--primary-light:#1e2340;--topbar:#0a0c14;--card-shadow:0 1px 3px rgba(0,0,0,.3)}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);min-height:100vh;color:var(--text);transition:background .2s,color .2s}

/* ── LOGIN ── */
.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:380px;text-align:center;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.login-logo{font-size:36px;margin-bottom:10px}
.login-title{font-size:22px;font-weight:700;margin-bottom:4px}
.login-sub{font-size:13px;color:var(--text3);margin-bottom:28px}
.login-box input{margin-bottom:12px;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;background:var(--bg2);color:var(--text);width:100%}
.login-box input:focus{outline:none;border-color:var(--primary)}
.login-err{font-size:12px;color:#dc2626;margin-top:-6px;margin-bottom:10px;min-height:16px}

/* ── TOPBAR ── */
.topbar{background:var(--topbar);padding:0 24px;height:54px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}
.topbar-left{display:flex;align-items:center;gap:10px}
.topbar-title{color:#fff;font-size:15px;font-weight:600}
.topbar-badge{font-size:11px;background:var(--primary);color:#fff;padding:2px 8px;border-radius:20px;font-weight:600}
.topbar-user{font-size:12px;color:#9ca3af;display:flex;align-items:center;gap:6px}
.topbar-user span{background:#2a2d3e;color:#e5e7eb;padding:3px 10px;border-radius:20px;font-weight:500}
.topbar-right{display:flex;align-items:center;gap:6px}
.topbar-btn{background:transparent;border:1px solid #444;color:#ccc;padding:5px 11px;border-radius:6px;font-size:12px;cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .15s}
.topbar-btn:hover{border-color:#888;color:#fff}
.topbar-btn.admin-btn{border-color:#f59e0b;color:#f59e0b}
.topbar-btn.admin-btn:hover{background:#f59e0b;color:#000}
.topbar-btn.danger{border-color:#5a2a2a;color:#f87171}
.topbar-btn.danger:hover{border-color:#f87171}

/* ── PROGRESS ── */
.progress-bar{background:var(--topbar);padding:0 24px 10px;display:flex}
.progress-step{display:flex;align-items:center;gap:5px;font-size:11px;color:#555;flex:1}
.progress-step.done{color:#4ade80}.progress-step.active{color:#fff}
.progress-dot{width:18px;height:18px;border-radius:50%;background:#2a2a3e;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;transition:background .3s,color .3s,border-color .3s,box-shadow .3s}
.progress-step.done .progress-dot{background:#4ade80;color:#000}
.progress-step.active .progress-dot{background:var(--primary);color:#fff}
.progress-line{flex:1;height:1px;background:#2a2a3e;margin:0 4px}
.progress-step.done .progress-line{background:#4ade80}

/* ── MAIN ── */
.main{max-width:800px;margin:0 auto;padding:24px 16px}
.section-label{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.section-label::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── CARDS ── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:14px;box-shadow:var(--card-shadow)}
.card:focus-within{border-color:#c7d2fe}
.card-hd{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.card-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.ic-blue{background:#e8f0fe}.ic-green{background:#e6f4ea}.ic-purple{background:#f0ebff}.ic-orange{background:#fff3e0}.ic-yellow{background:#fffbeb}
.dark .ic-blue{background:#1e2a4a}.dark .ic-green{background:#1a3025}.dark .ic-purple{background:#2a1f40}.dark .ic-orange{background:#3a2a10}.dark .ic-yellow{background:#3a3010}
.card-title{font-size:14px;font-weight:600}
.card-desc{font-size:12px;color:var(--text3);margin-top:1px}

/* ── FORM ── */
label{display:block;font-size:11px;color:var(--text2);margin-bottom:4px;margin-top:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
label:first-of-type{margin-top:0}
input,textarea,select{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:var(--bg2);transition:border .15s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,110,247,.1)}
textarea{resize:vertical;font-family:'SF Mono',monospace;font-size:13px;line-height:1.6}
.row{display:flex;gap:8px}.row input{flex:1}

/* ── BUTTONS ── */
.btn{position:relative;overflow:hidden;isolation:isolate;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:background .15s,border-color .15s,color .15s,box-shadow .15s,filter .15s,transform .15s;display:inline-flex;align-items:center;gap:5px}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{filter:brightness(1.1)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}
.btn-outline{background:transparent;border:1.5px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary-light)}
.btn-danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover{background:#fee2e2}
.btn-warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.btn-warning:hover{background:#fef3c7}
.btn-full{width:100%;padding:11px;font-size:14px;justify-content:center}
.btn-compact{font-size:12px;padding:4px 10px;margin-top:8px}
.admin-row-btn{font-size:12px;padding:5px 10px}
.pr-inline-row{display:flex;gap:6px;margin-bottom:6px}
.pr-number-input{max-width:130px}
.pr-inline-btn{font-size:12px;padding:6px 10px}
.rotina-btn{margin-top:10px}

/* ── TOGGLES ── */
.toggle-group{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.toggle-btn{padding:7px 18px;border-radius:8px;border:1.5px solid var(--border);background:var(--bg2);font-size:13px;cursor:pointer;color:var(--text2);font-weight:500;transition:background .15s,border-color .15s,color .15s,transform .15s}
.toggle-btn:hover{border-color:var(--primary);color:var(--primary)}
.toggle-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}

/* ── STATUS ── */
.status{font-size:12px;margin-top:6px;min-height:18px;font-weight:500}
.ok{color:#16a34a}.err{color:#dc2626}.loading{color:var(--text3)}

/* ── MISC ── */
.tag{font-size:11px;padding:2px 8px;border-radius:20px;background:#e8f0fe;color:#3d5ce8;font-weight:700;margin-left:6px}
.dark .tag{background:#1e2a4a;color:#6b84f8}
.check-row{display:flex;gap:20px;margin-top:10px;flex-wrap:wrap}
.check-row label{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text);margin:0;font-weight:500;cursor:pointer;text-transform:none;letter-spacing:0}
.check-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary)}
.divider{border:none;border-top:1px solid var(--border);margin:14px 0}
.ai-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 8px;border-radius:20px;background:#fef3c7;color:#92400e;font-weight:600;margin-left:8px}
.no-ai-notice{background:var(--primary-light);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text2);margin-bottom:12px}
.pr-block{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px;margin-top:10px}
.pr-block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.pr-block-title{font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.05em}

/* ── PREVIEW ── */
.preview-tabs{display:flex;gap:4px;margin-bottom:10px}
.preview-tab{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:var(--bg2);color:var(--text2)}
.preview-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}
.preview-area{width:100%;min-height:380px;font-family:'SF Mono',monospace;font-size:13px;line-height:1.7;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:14px;color:var(--text)}
.preview-rendered{display:none;min-height:380px;padding:16px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg);font-size:14px;line-height:1.8}

/* ── HISTORY ── */
.history-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--border);border-radius:8px;margin-bottom:8px;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s;background:var(--bg2)}
.history-item:hover{border-color:var(--primary)}
.history-title{font-size:13px;font-weight:600}
.history-meta{font-size:11px;color:var(--text3);margin-top:2px}
.history-badge{font-size:10px;padding:2px 7px;border-radius:20px;font-weight:700}
.history-arrow{color:var(--text3);font-size:18px}
.badge-evolutiva{background:#e8f0fe;color:#3d5ce8}
.badge-problema{background:#fef3c7;color:#92400e}
.badge-protocolize{background:#e6f4ea;color:#166534}
.badge-fisco{background:#fce7f3;color:#9d174d}
.history-search{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;margin-bottom:12px;background:var(--bg2);color:var(--text)}
.history-empty{text-align:center;color:var(--text3);font-size:13px;padding:24px}
.validation-box{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px;margin-top:12px;font-size:13px;color:#dc2626}

/* ── ADMIN ── */
.admin-screen{display:none;min-height:100vh;background:var(--bg)}
.admin-main{max-width:900px;margin:0 auto;padding:24px 16px}
.admin-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:12px}
.admin-tab{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text2);transition:background .15s,color .15s,transform .15s}
.admin-tab.active{background:var(--primary);color:#fff}
.user-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1px solid var(--border);border-radius:8px;margin-bottom:8px;background:var(--bg2)}
.user-info{display:flex;flex-direction:column;gap:2px}
.user-name{font-size:14px;font-weight:600}
.user-meta{font-size:12px;color:var(--text3)}
.user-actions{display:flex;gap:6px}
.role-badge{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:700}
.role-admin{background:#fef3c7;color:#92400e}
.role-user{background:#e8f0fe;color:#3d5ce8}
.hist-user-badge{font-size:11px;padding:2px 8px;border-radius:20px;background:#f0ebff;color:#6d28d9;font-weight:600;margin-left:6px}

/* ── MODAL ── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100;align-items:center;justify-content:center;padding:16px}
.overlay.open{display:flex}
.modal{background:var(--bg2);border-radius:16px;padding:28px;width:100%;max-width:520px;max-height:88vh;overflow-y:auto;border:1px solid var(--border)}
.modal-title{font-size:17px;font-weight:700;margin-bottom:4px}
.modal-sub{font-size:13px;color:var(--text3);margin-bottom:20px}
.modal-close{float:right;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text3);line-height:1}
.key-block{border:1.5px solid var(--border);border-radius:10px;padding:16px;margin-bottom:10px}
.key-block-title{font-size:13px;font-weight:700;margin-bottom:3px}
.key-block-desc{font-size:12px;color:var(--text3);margin-bottom:10px;line-height:1.5}
.key-block-desc a{color:var(--primary);text-decoration:none}
.saved-dot{width:7px;height:7px;border-radius:50%;background:#16a34a;display:inline-block;margin-right:4px}
.ai-stat-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin-bottom:6px}
.ai-stat-row span:first-child{font-weight:600}
.ai-stat-row span:last-child{font-size:12px;color:var(--text2)}
.ai-progress-bar{height:8px;background:var(--bg3);border-radius:999px;overflow:hidden;margin-bottom:4px}
.ai-progress-fill{height:100%;border-radius:999px;transition:width .6s cubic-bezier(.2,.9,.2,1);background:var(--primary)}
.ai-progress-fill.warn{background:#f5a623}
.ai-progress-fill.danger{background:#e53935}
.ai-stat-meta{font-size:11px;color:var(--text2);margin-bottom:14px}
.ai-rate-alert{display:none;background:#fee2e2;border:2px solid #ef4444;border-radius:14px;padding:16px 18px;margin-bottom:14px;animation:riseIn .4s cubic-bezier(.2,.9,.2,1) both}
.ai-rate-alert.show{display:block}
.ai-rate-alert-title{font-size:15px;font-weight:800;color:#b91c1c;margin-bottom:6px}
.ai-rate-alert-body{font-size:12px;color:#7f1d1d;line-height:1.6}
@media(prefers-color-scheme:dark){
  .ai-rate-alert{background:#3b0f0f;border-color:#dc2626}
  .ai-rate-alert-title{color:#fca5a5}
  .ai-rate-alert-body{color:#fecaca}
}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;right:24px;background:#1a1a2e;color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:500;z-index:999;transform:translateY(80px);opacity:0;transition:opacity .3s,transform .3s;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}

/* ── VISUAL REFRESH ── */
:root{
  --bg:#f6f7fb;
  --bg2:#fff;
  --bg3:#fbfcff;
  --border:#dfe5ef;
  --border-strong:#c9d3e3;
  --text:#162033;
  --text2:#647086;
  --text3:#94a0b5;
  --primary:#315fdc;
  --primary-dark:#2249b8;
  --primary-light:#edf3ff;
  --accent:#0f9f7a;
  --accent-light:#e9fbf5;
  --warning:#b7791f;
  --danger:#c73535;
  --topbar:#101827;
  --card-shadow:0 12px 34px rgba(22,32,51,.08);
  --card-shadow-hover:0 18px 44px rgba(22,32,51,.12);
}
.dark{
  --bg:#0d111a;
  --bg2:#151b27;
  --bg3:#111722;
  --border:#293244;
  --border-strong:#39445a;
  --text:#eef3fb;
  --text2:#b1bdd1;
  --text3:#79869b;
  --primary:#7ea2ff;
  --primary-dark:#a6bdff;
  --primary-light:#202b46;
  --accent:#4fd5ae;
  --accent-light:#16372e;
  --warning:#f5c26b;
  --danger:#ff7d7d;
  --topbar:#080c14;
  --card-shadow:0 16px 40px rgba(0,0,0,.32);
  --card-shadow-hover:0 22px 52px rgba(0,0,0,.42);
}
body{
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:
    linear-gradient(180deg,rgba(49,95,220,.09),rgba(49,95,220,0) 310px),
    radial-gradient(circle at 25% 0,rgba(15,159,122,.08),transparent 260px),
    var(--bg);
  letter-spacing:0;
}
.dark body,body.dark{
  background:
    linear-gradient(180deg,rgba(126,162,255,.10),rgba(126,162,255,0) 320px),
    radial-gradient(circle at 25% 0,rgba(79,213,174,.08),transparent 270px),
    var(--bg);
}
button,input,textarea,select{font:inherit}
::selection{background:rgba(49,95,220,.18)}

/* LOGIN */
.login-screen{
  background:
    linear-gradient(135deg,rgba(49,95,220,.14),rgba(15,159,122,.10)),
    var(--bg);
  padding:24px;
}
.login-box{
  max-width:410px;
  border:1px solid rgba(255,255,255,.72);
  border-radius:22px;
  padding:42px;
  text-align:left;
  box-shadow:0 24px 80px rgba(22,32,51,.16);
  position:relative;
  overflow:hidden;
}
.dark .login-box{border-color:var(--border);box-shadow:0 24px 80px rgba(0,0,0,.44)}
.login-box::before{
  content:"";
  display:block;
  width:48px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  margin-bottom:26px;
}
.login-logo{font-size:34px;margin-bottom:12px}
.login-title{font-size:28px;line-height:1.1;color:var(--text);letter-spacing:0}
.login-sub{font-size:14px;color:var(--text2);margin-bottom:26px}
.login-box input{height:46px;margin-bottom:12px;border-radius:12px;background:var(--bg3)}
.login-err{color:var(--danger);font-weight:600}

/* TOPBAR */
.topbar{
  min-height:62px;
  height:auto;
  padding:12px 28px;
  background:
    linear-gradient(90deg,rgba(16,24,39,.98),rgba(24,36,57,.98)),
    var(--topbar);
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 12px 30px rgba(8,12,20,.16);
  backdrop-filter:blur(16px);
}
.topbar-title{font-size:16px;font-weight:800;letter-spacing:0}
.topbar-badge{
  background:rgba(126,162,255,.16);
  border:1px solid rgba(126,162,255,.28);
  color:#dbe6ff;
  padding:4px 10px;
}
.topbar-user{color:#c8d0df}
.topbar-user span{background:rgba(255,255,255,.09);color:#fff;border:1px solid rgba(255,255,255,.08)}
.topbar-right{gap:8px;flex-wrap:wrap;justify-content:flex-end}
.topbar-btn{
  min-height:32px;
  border-radius:10px;
  border-color:rgba(255,255,255,.14);
  color:#d6deeb;
  background:rgba(255,255,255,.04);
}
.topbar-btn:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.28);transform:translateY(-1px)}
.topbar-btn.admin-btn{border-color:rgba(245,158,11,.42);background:rgba(245,158,11,.10);color:#ffd58a}
.topbar-btn.admin-btn:hover{background:#f5b544;color:#1b1200}
.topbar-btn.danger{border-color:rgba(248,113,113,.32);color:#ffabab;background:rgba(248,113,113,.08)}

/* PROGRESS */
.progress-bar{
  padding:13px 28px 14px;
  background:rgba(16,24,39,.96);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.progress-step{font-size:12px;color:#748197;font-weight:700}
.progress-step.active{color:#fff}.progress-step.done{color:#72e3b8}
.progress-dot{
  width:24px;
  height:24px;
  background:#253047;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.progress-step.active .progress-dot{background:linear-gradient(135deg,var(--primary),#6d8fff)}
.progress-step.done .progress-dot{background:linear-gradient(135deg,var(--accent),#80e7c8)}
.progress-line{background:#2d3850}

/* LAYOUT */
.main{max-width:920px;padding:34px 20px 54px}
.admin-main{max-width:1040px;padding:34px 20px 54px}
.section-label{
  margin:28px 2px 12px;
  color:var(--text2);
  font-size:11px;
}
.section-label:first-child{margin-top:0}
.section-label::after{background:linear-gradient(90deg,var(--border),transparent)}

/* CARDS */
.card{
  border-color:rgba(223,229,239,.86);
  border-radius:18px;
  padding:24px;
  background:linear-gradient(180deg,var(--bg2),var(--bg3));
  box-shadow:var(--card-shadow);
  transition:border-color .18s,box-shadow .18s,transform .18s;
}
.dark .card{border-color:var(--border);background:linear-gradient(180deg,var(--bg2),var(--bg3))}
.card:hover{box-shadow:var(--card-shadow-hover)}
.card:focus-within{border-color:rgba(49,95,220,.46);box-shadow:0 0 0 4px rgba(49,95,220,.08),var(--card-shadow)}
.card-hd{gap:13px;margin-bottom:19px}
.card-icon{
  width:42px;
  height:42px;
  border-radius:14px;
  font-size:18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5);
}
.ic-blue{background:#e8f1ff}.ic-green{background:#e5f9f1}.ic-purple{background:#f1edff}.ic-orange{background:#fff1df}.ic-yellow{background:#fff8dc}
.dark .ic-blue{background:#203457}.dark .ic-green{background:#183c31}.dark .ic-purple{background:#30284d}.dark .ic-orange{background:#3f2b18}.dark .ic-yellow{background:#403818}
.card-title{font-size:16px;font-weight:800;color:var(--text)}
.card-desc{font-size:13px;color:var(--text2);margin-top:3px}

/* FORM */
label{margin-top:15px;margin-bottom:6px;color:var(--text2);font-size:11px}
input,textarea,select{
  min-height:43px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--bg2);
  color:var(--text);
  box-shadow:0 1px 0 rgba(255,255,255,.62);
}
textarea{padding-top:12px}
input:hover,textarea:hover,select:hover{border-color:var(--border-strong)}
input:focus,textarea:focus,select:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(49,95,220,.11);
}
.dark input,.dark textarea,.dark select{box-shadow:none;background:#111722}
.row{gap:10px}

/* BUTTONS */
.btn{
  min-height:38px;
  border-radius:12px;
  padding:9px 15px;
  font-weight:800;
  box-shadow:0 1px 0 rgba(255,255,255,.42);
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{
  background:linear-gradient(135deg,var(--primary),#5f7ff0);
  color:#fff;
  box-shadow:0 10px 22px rgba(49,95,220,.24);
}
.btn-primary:hover{filter:none;background:linear-gradient(135deg,var(--primary-dark),#5274eb)}
.btn-secondary{background:var(--bg3);border:1px solid var(--border);color:var(--text)}
.btn-secondary:hover{border-color:var(--border-strong);color:var(--primary)}
.btn-outline{border:1px solid rgba(49,95,220,.36);background:rgba(49,95,220,.05);color:var(--primary)}
.btn-outline:hover{background:var(--primary-light)}
.btn-danger{background:#fff1f1;color:var(--danger);border-color:#ffd0d0}
.btn-warning{background:#fff8e8;color:#946210;border-color:#f5d58c}
.btn-full{min-height:44px}

/* TOGGLES AND STATUS */
.toggle-group{gap:10px}
.toggle-btn{
  min-height:38px;
  border-radius:999px;
  background:var(--bg3);
  color:var(--text2);
  border:1px solid var(--border);
  padding:8px 18px;
}
.toggle-btn.active{
  background:linear-gradient(135deg,var(--primary),#5d7df0);
  border-color:transparent;
  color:#fff;
  box-shadow:0 10px 22px rgba(49,95,220,.20);
}
.status{margin-top:9px}
.ok{color:#07845f}.err{color:var(--danger)}.loading{color:var(--primary)}

/* BLOCKS */
.tag,.history-badge,.role-badge,.hist-user-badge,.ai-badge{
  border-radius:999px;
  border:1px solid transparent;
}
.tag{background:var(--primary-light);border-color:rgba(49,95,220,.14);color:var(--primary)}
.ai-badge{background:#fff7df;border-color:#f5d78c;color:#946210}
.dark .ai-badge{background:#3b3019;border-color:#5f4a1f;color:#f5c26b}
.no-ai-notice{
  border-radius:14px;
  background:linear-gradient(135deg,var(--primary-light),var(--accent-light));
  border-color:rgba(49,95,220,.16);
  color:var(--text2);
}
.pr-block{
  border-radius:16px;
  background:rgba(246,247,251,.72);
  border-color:var(--border);
}
.dark .pr-block{background:rgba(13,17,26,.42)}
.divider{margin:18px 0;border-color:var(--border)}
.check-row label{
  padding:8px 12px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--bg3);
}

/* PREVIEW AND LISTS */
.preview-tabs{
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:14px;
  padding:4px;
  width:max-content;
  max-width:100%;
}
.preview-tab{border:0;border-radius:10px;background:transparent}
.preview-tab.active{background:var(--bg2);color:var(--primary);box-shadow:0 5px 14px rgba(22,32,51,.10)}
.preview-area,.preview-rendered{
  border-radius:15px;
  border-color:var(--border);
  background:var(--bg3);
}
.history-item,.user-row{
  border-radius:14px;
  padding:14px 16px;
  background:var(--bg3);
}
.history-item:hover,.user-row:hover{
  border-color:rgba(49,95,220,.34);
  box-shadow:0 10px 24px rgba(22,32,51,.07);
}
.history-title,.user-name{font-size:14px;color:var(--text)}
.history-search{min-height:42px;border-radius:12px;background:var(--bg3)}
.validation-box{border-radius:14px;color:var(--danger);background:#fff1f1}

/* ADMIN AND MODALS */
.admin-tabs{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:16px;
  padding:6px;
  box-shadow:var(--card-shadow);
}
.admin-tab{border-radius:12px}
.admin-tab.active{background:linear-gradient(135deg,var(--primary),#5d7df0)}
.overlay{background:rgba(8,12,20,.58);backdrop-filter:blur(8px)}
.modal{
  border-radius:22px;
  border-color:var(--border);
  box-shadow:0 30px 90px rgba(0,0,0,.28);
}
.modal-title{font-size:20px;color:var(--text)}
.modal-sub{color:var(--text2)}
.modal-close{
  width:34px;
  height:34px;
  border-radius:999px;
}
.modal-close:hover{background:var(--bg);color:var(--text)}
.key-block{border-radius:16px;background:var(--bg3);border-color:var(--border)}
.key-block-title{font-size:14px;color:var(--text)}

/* TOAST */
.toast{
  border-radius:14px;
  background:#101827;
  box-shadow:0 18px 44px rgba(0,0,0,.28);
}

@media (max-width:760px){
  .topbar{padding:12px 16px;align-items:flex-start;gap:12px;flex-direction:column}
  .topbar-left,.topbar-right{width:100%}
  .topbar-right{justify-content:flex-start}
  .topbar-btn{flex:1;justify-content:center;min-width:74px}
  .progress-bar{padding:12px 16px;overflow-x:auto}
  .progress-step{min-width:116px}
  .main,.admin-main{padding:24px 14px 40px}
  .card{padding:18px;border-radius:16px}
  .row{flex-direction:column}
  .btn{justify-content:center}
  .pr-block-header{align-items:flex-start;gap:10px;flex-direction:column}
  .modal{padding:22px}
  .user-row{align-items:flex-start;gap:12px;flex-direction:column}
  .user-actions{width:100%}
  .user-actions .btn{flex:1}
  #preview-card [style*="grid-template-columns"]{grid-template-columns:1fr 1fr!important}
}

/* ── RADICAL WORKSPACE THEME ── */
:root{
  --bg:#f5f7ff;
  --bg2:rgba(255,255,255,.82);
  --bg3:rgba(248,250,255,.88);
  --glass:rgba(255,255,255,.68);
  --border:rgba(135,151,185,.28);
  --border-strong:rgba(76,98,150,.36);
  --text:#12172a;
  --text2:#5d6681;
  --text3:#8d96ad;
  --primary:#3858ff;
  --primary-dark:#243ed0;
  --primary-light:rgba(56,88,255,.10);
  --accent:#00a987;
  --accent2:#ff7a45;
  --topbar:rgba(12,16,32,.86);
  --card-shadow:0 24px 70px rgba(34,47,95,.12);
  --card-shadow-hover:0 32px 90px rgba(34,47,95,.20);
}
.dark{
  --bg:#080b14;
  --bg2:rgba(18,24,40,.82);
  --bg3:rgba(14,20,34,.88);
  --glass:rgba(17,23,38,.66);
  --border:rgba(126,162,255,.18);
  --border-strong:rgba(126,162,255,.32);
  --text:#f5f7ff;
  --text2:#b8c2dc;
  --text3:#77829c;
  --primary:#86a1ff;
  --primary-dark:#b4c4ff;
  --primary-light:rgba(134,161,255,.15);
  --accent:#38e6bb;
  --accent2:#ff9b6f;
  --topbar:rgba(5,8,16,.88);
}
body{
  overflow-x:hidden;
  background:var(--bg);
}
.ambient-bg{
  position:fixed;
  inset:0;
  z-index:-1;
  overflow:hidden;
  pointer-events:none;
  background:
    radial-gradient(circle at var(--mx,20%) var(--my,10%),rgba(56,88,255,.18),transparent 22rem),
    linear-gradient(135deg,rgba(0,169,135,.10),transparent 34%),
    linear-gradient(225deg,rgba(255,122,69,.10),transparent 32%),
    var(--bg);
}
.ambient-orb{
  position:absolute;
  width:34rem;
  height:34rem;
  border-radius:999px;
  filter:blur(36px);
  opacity:.32;
  animation:floatOrb 18s ease-in-out infinite;
}
.orb-one{left:-10rem;top:4rem;background:#3858ff}
.orb-two{right:-12rem;top:18rem;background:#00a987;animation-delay:-7s}
.ambient-grid{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(90,108,154,.10) 1px,transparent 1px),
    linear-gradient(90deg,rgba(90,108,154,.10) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.72),transparent 78%);
}
@keyframes floatOrb{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(3rem,-2rem,0) scale(1.12)}
}

.login-screen{background:transparent}
.login-box,.card,.modal,.admin-tabs{
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
}
.login-box{
  animation:riseIn .65s cubic-bezier(.2,.9,.2,1) both;
  border:1px solid rgba(255,255,255,.62);
}
.login-box::after{
  content:"";
  position:absolute;
  inset:auto -20% -45% -20%;
  height:160px;
  background:linear-gradient(90deg,rgba(56,88,255,.24),rgba(0,169,135,.24),rgba(255,122,69,.20));
  filter:blur(28px);
}
.login-logo{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:20px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;
  box-shadow:0 20px 42px rgba(56,88,255,.26);
}

.topbar{
  border:1px solid rgba(255,255,255,.10);
  border-left:0;
  border-right:0;
  backdrop-filter:blur(22px);
}
.topbar-title::before{
  content:"";
  display:inline-block;
  width:10px;
  height:10px;
  margin-right:9px;
  border-radius:999px;
  background:var(--accent);
  box-shadow:0 0 0 6px rgba(56,230,187,.13),0 0 22px var(--accent);
}
.topbar-btn{position:relative;overflow:hidden;isolation:isolate}
.topbar-btn::after,.btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.22),transparent);
  transform:translateX(-120%);
  transition:transform .45s;
  pointer-events:none;
}
.topbar-btn:hover::after,.btn:hover::after{transform:translateX(120%)}

.progress-bar{
  gap:12px;
  background:rgba(12,16,32,.80);
  backdrop-filter:blur(18px);
}
.progress-step{
  position:relative;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
}
.progress-step.active{
  background:rgba(134,161,255,.16);
  box-shadow:0 0 0 1px rgba(134,161,255,.18),0 12px 30px rgba(0,0,0,.20);
}
.progress-step.active .progress-dot{animation:pulseStep 1.7s ease-in-out infinite}
@keyframes pulseStep{
  0%,100%{box-shadow:0 0 0 0 rgba(134,161,255,.42)}
  50%{box-shadow:0 0 0 8px rgba(134,161,255,0)}
}

.workspace-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) 280px;
  gap:22px;
  align-items:stretch;
  margin-bottom:28px;
  animation:riseIn .65s cubic-bezier(.2,.9,.2,1) both;
}
.workspace-hero>div:first-child{
  position:relative;
  overflow:hidden;
  min-height:190px;
  padding:28px;
  border:1px solid var(--border);
  border-radius:26px;
  background:
    linear-gradient(135deg,rgba(56,88,255,.16),rgba(0,169,135,.10)),
    var(--glass);
  box-shadow:var(--card-shadow);
  backdrop-filter:blur(22px);
}
.workspace-hero>div:first-child::after{
  content:"";
  position:absolute;
  right:24px;
  bottom:18px;
  width:170px;
  height:86px;
  border-radius:24px;
  background:
    linear-gradient(90deg,rgba(255,255,255,.72),rgba(255,255,255,.16)),
    repeating-linear-gradient(90deg,transparent 0 18px,rgba(56,88,255,.35) 18px 22px);
  opacity:.42;
  transform:skewY(-8deg);
}
.hero-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--primary);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}
.hero-kicker::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--accent);
  box-shadow:0 0 18px var(--accent);
}
.workspace-hero h1{
  max-width:540px;
  margin:14px 0 10px;
  font-size:42px;
  line-height:1;
  letter-spacing:0;
  color:var(--text);
}
.workspace-hero p{
  max-width:500px;
  color:var(--text2);
  font-size:15px;
  line-height:1.6;
}
.hero-panel{
  padding:22px;
  border:1px solid var(--border);
  border-radius:26px;
  background:linear-gradient(180deg,var(--bg2),var(--bg3));
  box-shadow:var(--card-shadow);
  backdrop-filter:blur(22px);
  animation:riseIn .65s cubic-bezier(.2,.9,.2,1) .08s both;
}
.hero-panel-line{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:48px;
  padding:12px;
  border-radius:18px;
  color:var(--text);
  background:rgba(0,169,135,.10);
}
.pulse-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  background:var(--accent);
  box-shadow:0 0 0 0 rgba(0,169,135,.42);
  animation:livePulse 1.6s ease-out infinite;
}
@keyframes livePulse{
  to{box-shadow:0 0 0 12px rgba(0,169,135,0)}
}
.hero-metrics{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-top:14px;
}
.hero-metrics span{
  min-height:72px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  border-radius:18px;
  color:var(--text2);
  background:rgba(255,255,255,.42);
  border:1px solid var(--border);
  font-size:12px;
}
.dark .hero-metrics span{background:rgba(255,255,255,.04)}
.hero-metrics b{font-size:25px;color:var(--text)}

.section-label{
  transform:translateX(0);
  animation:fadeSlide .55s ease both;
}
.card{
  position:relative;
  overflow:hidden;
  transform-style:preserve-3d;
  animation:riseIn .58s cubic-bezier(.2,.9,.2,1) both;
}
.card::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,20%),rgba(56,88,255,.18),transparent 18rem);
  transition:opacity .25s;
  pointer-events:none;
}
.card:hover::before{opacity:1}
.card:hover{transform:translateY(-4px)}
.card:nth-of-type(2){animation-delay:.04s}
.card:nth-of-type(3){animation-delay:.08s}
.card:nth-of-type(4){animation-delay:.12s}
.card-icon{
  position:relative;
  isolation:isolate;
}
.card-icon::after{
  content:"";
  position:absolute;
  inset:-5px;
  z-index:-1;
  border-radius:18px;
  background:inherit;
  opacity:.45;
  filter:blur(12px);
}
.card-title{font-size:17px}

input,textarea,select{
  transition:border-color .2s,box-shadow .2s,transform .2s,background .2s;
}
input:focus,textarea:focus,select:focus{transform:translateY(-1px)}
.toggle-btn,.preview-tab,.admin-tab,.history-item,.user-row{transition:background .22s ease,border-color .22s ease,color .22s ease,box-shadow .22s ease,transform .22s ease}
.toggle-btn:hover,.preview-tab:hover,.admin-tab:hover{transform:translateY(-1px)}
.history-item:hover,.user-row:hover{transform:translateX(4px)}
.pr-block{
  position:relative;
  overflow:hidden;
}
.pr-block::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  background:linear-gradient(var(--primary),var(--accent));
}
.preview-area{
  background:
    linear-gradient(rgba(56,88,255,.035) 1px,transparent 1px),
    var(--bg3);
  background-size:100% 28px;
}
.preview-rendered{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.20);
}
.modal{
  animation:modalPop .22s ease both;
}
.toast.show{animation:toastPop .28s ease both}

@keyframes riseIn{
  from{opacity:0;transform:translateY(18px) scale(.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes fadeSlide{
  from{opacity:0;transform:translateX(-10px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes modalPop{
  from{opacity:0;transform:translateY(10px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes toastPop{
  0%{transform:translateY(80px) scale(.95)}
  100%{transform:translateY(0) scale(1)}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}
  .dash-bar-fill,.gd-team-bar-fill,.gd-tc-bar-fill,#donut-arc,.gd-tc-arc{transition:none!important}
}
@media (max-width:860px){
  .workspace-hero{grid-template-columns:1fr}
  .workspace-hero h1{font-size:34px}
}
@media (max-width:560px){
  .workspace-hero>div:first-child,.hero-panel{border-radius:20px;padding:20px}
  .workspace-hero h1{font-size:29px}
  .hero-metrics{grid-template-columns:1fr 1fr 1fr}
  .hero-metrics span{min-height:62px}
}

/* ── STEPPED FLOW ── */
.step-panel{
  display:none;
  position:relative;
}
.step-panel.active{
  display:block;
  animation:stepReveal .46s cubic-bezier(.2,.9,.2,1) both;
}
.step-panel.active::before{
  content:"";
  position:absolute;
  left:20px;
  top:48px;
  bottom:10px;
  width:2px;
  border-radius:999px;
  background:linear-gradient(var(--primary),var(--accent),transparent);
  opacity:.22;
}
.step-panel .section-label,
.step-panel .card{
  margin-left:18px;
}
.progress-step{
  cursor:pointer;
  user-select:none;
}
.progress-step:hover{
  border-color:rgba(134,161,255,.30);
  background:rgba(134,161,255,.10);
}
.step-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid var(--border);
}
.step-actions .btn{
  min-width:148px;
}
body[data-current-step="1"] .workspace-hero .hero-panel-line strong::after{content:" · tarefa"}
body[data-current-step="2"] .workspace-hero .hero-panel-line strong::after{content:" · PRs"}
body[data-current-step="3"] .workspace-hero .hero-panel-line strong::after{content:" · revisão"}
body[data-current-step="4"] .workspace-hero .hero-panel-line strong::after{content:" · pronto"}

@keyframes stepReveal{
  from{opacity:0;transform:translateX(22px) scale(.985);filter:blur(4px)}
  to{opacity:1;transform:translateX(0) scale(1);filter:blur(0)}
}

@media (max-width:760px){
  .step-panel.active::before{left:6px}
  .step-panel .section-label,
  .step-panel .card{margin-left:0}
  .step-actions{flex-direction:column}
  .step-actions .btn{width:100%;min-width:0}
}

/* stat card donut */
#donut-arc{transition:stroke-dasharray .8s cubic-bezier(.2,.9,.2,1)}

/* ── GESTORA ── */
.topbar-btn.gestora-btn{border-color:rgba(139,92,246,.42);background:rgba(139,92,246,.10);color:#c4b5fd}
.topbar-btn.gestora-btn:hover{background:#8b5cf6;color:#fff}
.role-gestora{background:#f1edff;color:#6d28d9}
.dark .role-gestora{background:#30284d;color:#c4b5fd}
.badge-revisado{background:#d1fae5;color:#065f46;border-color:rgba(6,95,70,.2)}
.badge-pendente{background:#fef3c7;color:#92400e;border-color:rgba(146,64,14,.16)}
.dark .badge-revisado{background:#064e3b;color:#6ee7b7}
.dark .badge-pendente{background:#78350f;color:#fcd34d}
.gestora-filter-row{display:flex;gap:8px;margin-top:10px;margin-bottom:4px;flex-wrap:wrap}
.gestora-filter-row select{flex:1;min-width:140px}
.gestora-rel-item{align-items:flex-start;gap:10px}
.gestora-obs{font-size:12px;color:var(--text3);margin-top:5px;padding:4px 10px;border-left:2px solid var(--border);font-style:italic}
.pauta-banner{
  max-width:920px;
  margin:16px auto -8px;
  padding:14px 20px;
  background:var(--bg2);
  border:1.5px solid rgba(56,88,255,.30);
  border-radius:18px;
  backdrop-filter:blur(16px);
  animation:riseIn .4s ease both;
}
.pauta-banner-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:13px;
  font-weight:700;
  color:var(--text);
}
.pauta-banner-header button{
  background:none;border:none;font-size:20px;
  cursor:pointer;color:var(--text3);line-height:1;padding:0 4px;
}
.pauta-banner-header button:hover{color:var(--text)}
.pauta-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.pauta-num{font-size:12px;color:var(--text3);min-width:22px;text-align:right;flex-shrink:0}
.pauta-row input{flex:1;margin:0}
.pauta-empty{padding:12px 0}
.pauta-remove{font-size:12px;padding:5px 10px;min-height:unset}
.pauta-banner-list{margin:8px 0 0 20px;padding:0;font-size:13px;color:var(--text2);line-height:1.9}
.gestora-user-group{
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  margin-bottom:14px;
  background:var(--bg3);
}
.gestora-user-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:13px 16px;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
}
.gestora-user-nome{font-size:14px;font-weight:800;color:var(--text)}
.gestora-user-stats{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  color:var(--text3);
  font-weight:600;
  flex-shrink:0;
}
.gestora-progress-bar{
  width:80px;
  height:5px;
  border-radius:999px;
  background:var(--border);
  overflow:hidden;
}
.gestora-progress-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  transition:width .4s ease;
}
.gestora-user-body{padding:10px}
.gestora-user-body .history-item{margin-bottom:8px}
.gestora-user-body .history-item:last-child{margin-bottom:0}
@media (max-width:760px){
  .gestora-filter-row{flex-direction:column}
  .gestora-filter-row select{min-width:0}
  .gestora-progress-bar{display:none}
}

/* ── GLOBAL POLISH ── */
*{scroll-behavior:smooth}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:var(--primary)}
body{transition:background .25s,color .25s}
.admin-screen,.dash-main>div{transition:none}

@keyframes screenIn{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}
.screen-in{animation:screenIn .32s cubic-bezier(.2,.9,.2,1) both}

@keyframes countUp{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}
.stat-pop{animation:countUp .4s cubic-bezier(.2,.9,.2,1) both}

/* Enhanced stat cards */
.dash-stat-card{position:relative;overflow:hidden}
.dash-stat-card::after{
  content:"";position:absolute;top:0;right:0;
  width:60px;height:60px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.08),transparent);
  transform:translate(20px,-20px);
  pointer-events:none;
}

/* Better bar animation */
.dash-bar-fill{width:0;transition:width .7s cubic-bezier(.2,.9,.2,1)}

/* Donut chart */
.dash-donut-wrap{
  display:flex;align-items:center;justify-content:center;
  gap:14px;padding:4px 0;
}
.dash-donut-legend{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text2)}
.dash-donut-legend span{display:flex;align-items:center;gap:6px;font-weight:600}
.dash-donut-legend i{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}

/* Better card hover glow */
.dash-card{transition:box-shadow .22s,border-color .22s,transform .22s}
.dash-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.18);border-color:rgba(56,88,255,.30);transform:translateY(-2px)}

/* Better history item */
.hs-item{position:relative;overflow:hidden}
.hs-item::before{
  content:"";position:absolute;left:0;top:0;bottom:0;
  width:3px;border-radius:0 2px 2px 0;
  background:linear-gradient(var(--primary),var(--accent));
  opacity:0;transition:opacity .2s;
}
.hs-item:hover::before{opacity:1}

/* Stagger list entrance */
@keyframes listIn{
  from{opacity:0;transform:translateX(-8px)}
  to{opacity:1;transform:translateX(0)}
}
.hs-item{animation:listIn .3s ease both}

/* ── HISTORICO SCREEN ── */
.hs-main{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  padding:28px 20px 48px;
}
.hs-stats{margin-bottom:18px}
.hs-workspace{
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.hs-sidebar,.hs-content{
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--bg2);
  box-shadow:var(--card-shadow);
  padding:18px;
}
.hs-sidebar{
  position:sticky;
  top:74px;
}
.hs-sidebar-head,.hs-content-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:14px;
}
.hs-eyebrow{
  font-size:10px;
  font-weight:800;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.1em;
}
.hs-sidebar h2,.hs-content-head h2{
  margin:3px 0 0;
  color:var(--text);
  font-size:18px;
  line-height:1.2;
}
.hs-new-folder{
  display:grid;
  grid-template-columns:minmax(0,1fr) 82px auto;
  gap:8px;
  margin-bottom:14px;
}
.hs-new-folder input,.hs-new-folder select{min-width:0}
.hs-filter-row{
  display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;
}
.hs-filter-row input,.hs-filter-row select{min-width:130px;}
.hs-filter-compact{
  display:grid;
  grid-template-columns:minmax(220px,1.4fr) repeat(3,minmax(130px,1fr));
  gap:10px;
  margin-bottom:16px;
}
.hs-filter-compact input,.hs-filter-compact select{min-width:0}
.hs-hidden-select{display:none}
.hs-folder-grid{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:0;
}
.hs-folder{
  width:100%;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--bg2);
  color:var(--text);
  padding:12px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:4px 10px;
  text-align:left;
  cursor:pointer;
  transition:border-color .18s,background .18s,transform .18s;
}
.hs-folder:hover,.hs-folder.active{
  border-color:var(--primary);
  background:var(--primary-light);
}
.hs-folder span{font-size:22px;grid-row:span 2}
.hs-folder strong{font-size:13px;text-transform:capitalize}
.hs-folder small{color:var(--text3);font-weight:700;grid-column:2}
.hs-folder.empty{opacity:.72}
.hs-folder.empty small{color:var(--text3)}
.hs-item{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:14px;padding:16px 18px;
  border:1px solid var(--border);border-radius:16px;
  background:var(--bg2);margin-bottom:10px;
  transition:border-color .18s,box-shadow .18s;
}
.hs-item:hover{border-color:rgba(56,88,255,.35);box-shadow:0 6px 24px rgba(0,0,0,.10);}
.hs-item-info{flex:1;cursor:pointer;min-width:0;}
.hs-item-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.4;}
.hs-meta{margin-top:4px}
.hs-obs{margin-top:6px}
.hs-item-actions{display:flex;gap:8px;flex-shrink:0;align-items:center;}
.hs-move-input{width:132px;min-height:32px;font-size:12px;padding:5px 8px}
.hs-open-btn{font-size:12px;padding:6px 14px}
.hs-delete-btn{font-size:12px;padding:6px 12px;background:rgba(239,68,68,.12);color:#ef4444;border:1px solid rgba(239,68,68,.25)}
@media(max-width:600px){
  .hs-main{padding:22px 14px 40px}
  .hs-workspace{grid-template-columns:1fr}
  .hs-sidebar{position:static}
  .hs-filter-row{flex-direction:column;}
  .hs-filter-compact{display:grid;grid-template-columns:1fr}
  .hs-new-folder{grid-template-columns:1fr}
  .hs-item{flex-direction:column;}
  .hs-item-actions{width:100%;justify-content:flex-end;}
}
@media(min-width:601px) and (max-width:900px){
  .hs-workspace{grid-template-columns:1fr}
  .hs-sidebar{position:static}
  .hs-filter-compact{grid-template-columns:1fr 1fr}
}

/* ── HISTORY ACTIONS ── */
.hist-item-row{display:flex;align-items:center;gap:10px;cursor:default}
.hist-actions{display:flex;gap:6px;flex-shrink:0;opacity:0;transition:opacity .18s}
.hist-item-row:hover .hist-actions{opacity:1}
.hist-btn{
  width:32px;height:32px;border-radius:8px;border:1px solid var(--border);
  background:var(--bg2);color:var(--text2);font-size:15px;
  cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s;
}
.hist-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.hist-btn-del:hover{background:#ef4444;border-color:#ef4444;color:#fff}

/* ── PRINT DA SOLUÇÃO ── */
.print-sol-zone{
  position:relative;
  min-height:100px;
  border:2px dashed var(--border);
  border-radius:16px;
  padding:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  cursor:pointer;
  transition:border-color .2s,background .2s;
  background:var(--bg3);
}
.print-sol-zone:hover,.print-sol-zone.dragover{
  border-color:var(--primary);
  background:rgba(56,88,255,.06);
}
.print-sol-ph{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  color:var(--text2);
  font-size:13px;
  text-align:center;
  pointer-events:none;
}
.print-sol-gallery{
  width:100%;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:10px;
}
.print-thumb{
  position:relative;
  min-width:0;
  border:1px solid var(--border);
  border-radius:12px;
  padding:8px;
  background:var(--bg2);
  cursor:pointer;
  transition:border-color .18s,box-shadow .18s;
}
.print-thumb.selected{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-light);
}
.print-thumb input{
  position:absolute;
  top:8px;
  left:8px;
  width:16px;
  height:16px;
  accent-color:var(--primary);
  z-index:2;
}
.print-thumb img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  border-radius:8px;
  display:block;
  background:var(--bg3);
}
.print-thumb span{
  display:block;
  margin-top:6px;
  font-size:11px;
  color:var(--text2);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.print-thumb button{
  position:absolute;
  top:6px;
  right:6px;
  width:22px;
  height:22px;
  border:0;
  border-radius:999px;
  background:rgba(8,12,20,.72);
  color:#fff;
  cursor:pointer;
}
.print-selection-info{
  grid-column:1/-1;
  font-size:12px;
  color:var(--text2);
  font-weight:700;
}
.print-sol-clear{
  position:absolute;
  top:10px;
  right:10px;
  background:rgba(239,68,68,.15);
  border:1px solid rgba(239,68,68,.30);
  color:#ef4444;
  border-radius:8px;
  padding:4px 10px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  transition:background .2s;
}
.print-sol-clear:hover{background:rgba(239,68,68,.28);}

/* ── DASHBOARD ── */
#dashboard{
  min-height:100vh;
  background:var(--bg);
  display:flex;
  flex-direction:column;
}
#dashboard .topbar{
  position:sticky;
  top:0;
  z-index:100;
}
.dash-main{
  flex:1;
  max-width:1120px;
  width:100%;
  margin:0 auto;
  padding:28px 20px 48px;
}
.dash-greeting-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:24px;
  flex-wrap:wrap;
}
.dash-title{
  font-size:28px;
  font-weight:900;
  color:var(--text);
  margin:0 0 4px;
  letter-spacing:-.3px;
}
.dash-subtitle{
  font-size:14px;
  color:var(--text2);
  margin:0;
}
.dash-greeting-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.dash-stats-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-bottom:24px;
}
.dash-stat-card{
  padding:18px 20px;
  border:1px solid var(--border);
  border-radius:20px;
  background:var(--bg2);
  box-shadow:var(--card-shadow);
  display:flex;
  flex-direction:column;
  gap:4px;
  transition:transform .2s,box-shadow .2s;
  animation:riseIn .5s cubic-bezier(.2,.9,.2,1) both;
}
.dash-stat-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.22)}
.dash-stat-card:nth-child(2){animation-delay:.06s}
.dash-stat-card:nth-child(3){animation-delay:.10s}
.dash-stat-card:nth-child(4){animation-delay:.14s}
.dash-stat-card.dash-stat-accent{border-color:rgba(0,169,135,.35);background:linear-gradient(135deg,rgba(0,169,135,.12),var(--bg2))}
.dash-stat-card.dash-stat-warn{border-color:rgba(251,191,36,.35);background:linear-gradient(135deg,rgba(251,191,36,.10),var(--bg2))}
.dash-stat-num{
  font-size:34px;
  font-weight:900;
  color:var(--text);
  line-height:1;
}
.dash-stat-accent .dash-stat-num{color:var(--accent)}
.dash-stat-warn .dash-stat-num{color:#f59e0b}
.dash-stat-lbl{
  font-size:12px;
  color:var(--text3);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.dash-stat-icon{
  font-size:22px;
  margin-bottom:6px;
}
.dash-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.dash-grid-spaced{margin-top:28px}
.dash-card{
  padding:22px;
  border:1px solid var(--border);
  border-radius:22px;
  background:var(--bg2);
  box-shadow:var(--card-shadow);
  animation:riseIn .58s cubic-bezier(.2,.9,.2,1) .1s both;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.dash-card-title{
  font-size:14px;
  font-weight:800;
  color:var(--text);
  letter-spacing:-.1px;
  display:flex;
  align-items:center;
  gap:8px;
}
.dash-card-title span{
  font-size:18px;
}
.dash-section-label{
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.10em;
  color:var(--text3);
  margin-bottom:12px;
}
.dash-filter-row{
  display:grid;
  grid-template-columns:160px 150px minmax(180px,1fr) 170px;
  gap:10px;
  align-items:center;
  margin:0 0 18px;
}
.dash-filter-row input,
.dash-filter-row select{
  min-height:38px;
  border-radius:10px;
  font-size:12px;
  background:var(--bg2);
}
.dash-empty{
  font-size:13px;
  color:var(--text3);
  text-align:center;
  padding:18px 0;
}
/* Pauta items */
.dash-pauta-list{
  display:flex;
  flex-direction:column;
  gap:7px;
  max-height:240px;
  overflow-y:auto;
}
.dash-pauta-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  padding:7px 10px;
  border-radius:10px;
  border:1px solid transparent;
  transition:background .2s;
}
.dash-pauta-item.dash-pauta-ok{
  background:rgba(0,169,135,.10);
  border-color:rgba(0,169,135,.22);
  color:var(--text);
}
.dash-pauta-item.dash-pauta-pending{
  background:rgba(255,255,255,.03);
  border-color:var(--border);
  color:var(--text2);
}
.dash-pauta-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  flex-shrink:0;
}
.dash-pauta-ok .dash-pauta-dot{background:var(--accent);box-shadow:0 0 8px rgba(0,169,135,.5)}
.dash-pauta-pending .dash-pauta-dot{background:var(--border)}
/* Recentes */
.dash-recent-list{
  display:flex;
  flex-direction:column;
  gap:7px;
  max-height:260px;
  overflow-y:auto;
}
.dash-recent-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:12px;
  background:var(--bg3);
  border:1px solid var(--border);
  cursor:pointer;
  transition:background .18s,transform .18s;
}
.dash-recent-item:hover{background:rgba(134,161,255,.12);transform:translateX(3px)}
.dash-recent-title{
  font-size:13px;
  font-weight:700;
  color:var(--text);
  flex:1;
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.dash-recent-meta{
  font-size:11px;
  color:var(--text3);
  white-space:nowrap;
  flex-shrink:0;
}
.dash-skeleton{
  position:relative;
  overflow:hidden;
  min-height:34px;
  border-radius:12px;
  background:var(--bg3);
  border:1px solid var(--border);
}
.dash-skeleton::after{
  content:"";
  position:absolute;
  inset:0;
  transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  animation:skeletonSweep 1.2s ease-in-out infinite;
}
@keyframes skeletonSweep{
  to{transform:translateX(100%)}
}
.dash-error{
  color:#f87171;
  border-color:rgba(248,113,113,.25);
  background:rgba(248,113,113,.08);
}
/* Bar charts */
.dash-bar-list{
  display:flex;
  flex-direction:column;
  gap:9px;
}
.dash-bar-row{
  display:grid;
  grid-template-columns:110px 1fr 32px;
  align-items:center;
  gap:8px;
}
.dash-bar-label{
  font-size:12px;
  color:var(--text2);
  font-weight:600;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.dash-bar-track{
  height:8px;
  border-radius:999px;
  background:var(--border);
  overflow:hidden;
}
.dash-bar-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  transition:width .5s cubic-bezier(.2,.9,.2,1);
}
.dash-bar-count{
  font-size:12px;
  font-weight:700;
  color:var(--text3);
  text-align:right;
}
/* Gestora dashboard */
.gd-team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:14px;
  margin-bottom:24px;
  isolation:isolate;
}
.gd-team-card{
  padding:18px 16px 14px;
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--bg3);
  display:flex;
  flex-direction:column;
  gap:10px;
  transition:transform .2s,box-shadow .2s;
  cursor:default;
  animation:riseIn .5s cubic-bezier(.2,.9,.2,1) both;
}
.gd-team-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.20)}
.gd-team-card-nome{
  font-size:14px;
  font-weight:800;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.gd-team-card-stats{
  display:flex;
  gap:12px;
}
.gd-team-col{
  display:flex;
  flex-direction:column;
  align-items:center;
  flex:1;
}
.gd-team-num{
  font-size:22px;
  font-weight:900;
  color:var(--text);
  line-height:1;
}
.gd-team-lbl{
  font-size:10px;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:600;
}
.gd-team-sep{
  color:var(--text3);
  margin:0 2px;
}
.gd-team-bar-track{
  width:100%;
  height:5px;
  border-radius:999px;
  background:var(--border);
  overflow:hidden;
}
.gd-team-bar-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  transition:width .5s cubic-bezier(.2,.9,.2,1);
}
.gd-team-pct{
  font-size:11px;
  color:var(--text3);
  font-weight:600;
  text-align:right;
  margin-top:2px;
}
/* ── GESTORA TEAM CARDS (redesign) ── */
.gd-tc-card{
  padding:18px 16px 14px;
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--bg2);
  box-shadow:var(--card-shadow);
  display:flex;
  flex-direction:column;
  gap:10px;
  transition:transform .2s,box-shadow .2s;
  animation:riseIn .55s cubic-bezier(.2,.9,.2,1) both;
  isolation:isolate;
}
.gd-tc-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(0,0,0,.18)}
.gd-tc-top{
  display:flex;
  align-items:center;
  gap:10px;
}
.gd-tc-avatar{
  width:36px;
  height:36px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:800;
  color:#fff;
  flex-shrink:0;
  letter-spacing:.02em;
}
.gd-tc-name{
  font-size:14px;
  font-weight:700;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.gd-tc-mid{
  display:flex;
  align-items:center;
  gap:12px;
}
.gd-tc-arc{
  transition:stroke-dasharray .8s cubic-bezier(.2,.9,.2,1);
}
.gd-tc-nums{
  display:flex;
  flex-direction:column;
  gap:6px;
  flex:1;
}
.gd-tc-big{
  font-size:22px;
  font-weight:900;
  line-height:1;
  color:var(--text);
}
.gd-tc-sub{
  font-size:10px;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:600;
}
.gd-tc-bar-track{
  width:100%;
  height:5px;
  border-radius:999px;
  background:var(--border);
  overflow:hidden;
}
.gd-tc-bar-fill{
  height:100%;
  border-radius:999px;
  transition:width .7s cubic-bezier(.2,.9,.2,1);
}
.gd-tc-pct-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:11px;
  color:var(--text3);
}
.gd-tc-pct-row strong{
  font-weight:700;
  color:var(--text2);
}

/* Pending reviews list */
.gd-pending-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:280px;
  overflow-y:auto;
}
.gd-pending-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:14px;
  background:var(--bg3);
  border:1px solid rgba(251,191,36,.25);
  cursor:pointer;
  transition:background .18s;
}
.gd-pending-item:hover{background:rgba(251,191,36,.10)}
.gd-pending-nome{
  font-size:12px;
  font-weight:800;
  color:var(--text3);
}
.gd-pending-title{
  font-size:13px;
  font-weight:700;
  color:var(--text);
  flex:1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.gd-pending-date{
  font-size:11px;
  color:var(--text3);
  white-space:nowrap;
}
/* Pauta coverage in gestora dash */
.gd-pauta-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:240px;
  overflow-y:auto;
}
.gd-pauta-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  padding:8px 12px;
  border-radius:11px;
  border:1px solid transparent;
}
.gd-pauta-item.gd-pauta-ok{background:rgba(0,169,135,.10);border-color:rgba(0,169,135,.22);color:var(--text)}
.gd-pauta-item.gd-pauta-pending{background:rgba(255,255,255,.03);border-color:var(--border);color:var(--text2)}
.gd-pauta-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.gd-pauta-ok .gd-pauta-dot{background:var(--accent);box-shadow:0 0 8px rgba(0,169,135,.5)}
.gd-pauta-pending .gd-pauta-dot{background:var(--border)}
.gd-pauta-cov{margin-left:auto;font-size:11px;font-weight:700;color:var(--text3);white-space:nowrap}

/* Stable dark dashboard surfaces */
#dashboard.screen-in{
  animation:none;
}
#dashboard .dash-stat-card,
#dashboard .dash-card,
#dashboard .gd-tc-card{
  animation:none;
}
#dashboard .dash-stat-card::before,
#dashboard .dash-card::before,
#dashboard .gd-tc-card::before{
  content:none;
}
#dashboard .dash-stat-card::after{
  opacity:.45;
}
#dashboard .topbar-btn::after,
#dashboard .btn::after{
  content:none;
}
#dashboard .dash-card:hover,
#dashboard .dash-stat-card:hover,
#dashboard .gd-tc-card:hover{
  transform:none;
}
.dark #dashboard .dash-main{
  isolation:isolate;
}
.dark #dashboard .dash-stat-card,
.dark #dashboard .dash-card,
.dark #dashboard .gd-tc-card{
  background:#111827;
  border-color:rgba(126,162,255,.24);
  box-shadow:0 14px 34px rgba(0,0,0,.28);
}
.dark #dashboard .dash-stat-card.dash-stat-accent{
  background:linear-gradient(135deg,rgba(56,230,187,.13),#111827 62%);
  border-color:rgba(56,230,187,.32);
}
.dark #dashboard .dash-stat-card.dash-stat-warn{
  background:linear-gradient(135deg,rgba(245,158,11,.14),#111827 62%);
  border-color:rgba(245,158,11,.34);
}
.dark #dashboard .dash-stat-card:hover,
.dark #dashboard .dash-card:hover,
.dark #dashboard .gd-tc-card:hover{
  box-shadow:0 16px 38px rgba(0,0,0,.36);
  border-color:rgba(126,162,255,.34);
}
.dark #dashboard .dash-recent-item,
.dark #dashboard .dash-pauta-item.dash-pauta-pending,
.dark #dashboard .gd-pauta-item.gd-pauta-pending{
  background:#0b1220;
  border-color:rgba(126,162,255,.16);
}
.dark #dashboard .dash-recent-item:hover{
  background:#101a2e;
}
.dark #dashboard .history-empty{
  color:#8b98b3;
}
.dark #dashboard .dash-filter-row input,
.dark #dashboard .dash-filter-row select,
.dark #dashboard .dash-skeleton{
  background:#0b1220;
  border-color:rgba(126,162,255,.16);
}

/* Dashboard responsive */
@media (max-width:900px){
  .dash-stats-row{grid-template-columns:repeat(2,1fr)}
  .dash-grid{grid-template-columns:1fr}
  .dash-filter-row{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .dash-main{padding:16px 12px 36px}
  .dash-stats-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .dash-stat-card{padding:14px 14px}
  .dash-stat-num{font-size:26px}
  .dash-title{font-size:22px}
  .gd-team-grid{grid-template-columns:1fr 1fr}
  .dash-filter-row{grid-template-columns:1fr}
  .dash-bar-row{grid-template-columns:80px 1fr 28px}
  .dash-bar-label{font-size:11px}
}

/* ═══════════════════════════════════════════
   MOBILE — revisão completa (≤ 640px)
═══════════════════════════════════════════ */
@media (max-width:640px){

  /* ── Topbar: linha única com scroll horizontal nos botões ── */
  .topbar{
    padding:0 14px;
    height:52px;
    flex-direction:row;
    flex-wrap:nowrap;
    align-items:center;
    gap:0;
  }
  .topbar-left{flex-shrink:0;gap:6px}
  .topbar-right{
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    gap:5px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding:6px 0;
    flex:1;
    justify-content:flex-end;
    align-items:center;
  }
  .topbar-right::-webkit-scrollbar{display:none}
  .topbar-user{display:none}
  .topbar-btn{
    flex:0 0 auto;
    white-space:nowrap;
    min-width:0;
    padding:7px 11px;
    font-size:12px;
    min-height:36px;
  }
  .topbar-title{font-size:14px}
  .topbar-badge{font-size:10px;padding:2px 6px}

  /* ── Modais: bottom-sheet ── */
  .overlay{align-items:flex-end!important;padding:0!important}
  .modal{
    max-width:100%!important;
    width:100%!important;
    max-height:90vh!important;
    border-radius:22px 22px 0 0!important;
    padding:20px 16px 28px!important;
  }

  /* ── Histórico: truncar título longo ── */
  .history-title{
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:calc(100vw - 170px);
  }
  .hist-actions{opacity:1!important}

  /* ── Histórico screen ── */
  .hs-item-title{
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:calc(100vw - 130px);
  }
  .hs-item{gap:10px;padding:12px 14px}
  .hs-item-actions .btn{padding:7px 10px;font-size:12px}

  /* ── Dashboard últimos relatórios ── */
  .dash-main{padding:16px 12px 48px;overflow:hidden}
  .dash-recent-list{overflow:hidden;overflow-y:auto}
  .dash-recent-item{overflow:hidden;min-width:0}
  .dash-recent-title{min-width:0}
  .dash-recent-meta{max-width:120px;overflow:hidden;text-overflow:ellipsis}
  .dash-card{overflow:hidden}

  /* ── Formulário ── */
  .main{padding:16px 12px 60px}
  .card{padding:16px;border-radius:16px}
  .step-actions{flex-direction:column;gap:8px}
  .step-actions .btn{width:100%;justify-content:center;min-height:44px}
  .btn-full{min-height:48px;font-size:15px}

  /* ── Progress bar scrollável ── */
  .progress-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px 12px}
  .progress-bar::-webkit-scrollbar{display:none}
  .progress-step{min-width:100px;font-size:10px}

  /* ── Preview card botões full width ── */
  #preview-card .btn{min-height:44px}
  #preview-card [style*="grid-template-columns"]{grid-template-columns:1fr!important}

  /* ── Admin ── */
  .admin-main{padding:16px 12px 60px}
  .admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:4px}
  .admin-tab{white-space:nowrap;flex-shrink:0;padding:7px 14px;font-size:12px}

  /* ── Gestora ── */
  .gestora-main{padding:16px 12px 60px}
  .gestora-filter-row{flex-direction:column;gap:8px}
  .gestora-filter-row select,.gestora-filter-row input{width:100%}
  .revisar-modal-tabs{gap:4px}

  /* ── Touch targets ── */
  .btn{min-height:40px}
  input,select,textarea{font-size:16px!important} /* evita zoom no iOS */

  /* ── Cards do admin usuario ── */
  .user-row{flex-direction:column;gap:10px;align-items:flex-start;padding:14px}
  .user-actions{width:100%;display:flex;gap:6px}
  .user-actions .btn{flex:1;justify-content:center}
}
