/* ============================================================
   Posteiro — style.css
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg: #0a0a0a; --surface: #111111; --card: #161616; --card2: #1c1c1c;
  --border: #2a2a2a; --border2: #383838;
  --blue: #3b82f6; --blue-dim: rgba(59,130,246,0.1); --blue-border: rgba(59,130,246,0.22);
  --green: #22c55e; --green-dim: rgba(34,197,94,0.1);
  --pink: #f472b6; --yellow: #fbbf24; --orange: #f97316;
  --text: #ffffff; --muted: #b3b3b3; --muted2: #555555;
  --font: 'Inter', sans-serif;
}
html, body { height: 100%; }
body { background: var(--bg); color: var(--text); font-family: var(--font); font-size: 14px; line-height: 1.5; overflow: hidden; display: flex; flex-direction: column; }

/* ─── TOPBAR ───────────────────────────────────────────────── */
.topbar { display:flex; align-items:center; justify-content:space-between; padding:0 16px; height:48px; border-bottom:1px solid var(--border); background:rgba(10,10,10,0.97); flex-shrink:0; gap:12px; }
.logo { font-size:0.92rem; font-weight:600; letter-spacing:-0.02em; white-space:nowrap; }
.logo span { color:var(--blue); }

/* Seletor de projeto */
.project-selector { display:flex; align-items:center; gap:6px; position:relative; }
.project-btn { display:flex; align-items:center; gap:6px; padding:4px 10px; background:var(--card); border:1px solid var(--border); border-radius:7px; font-size:0.78rem; color:var(--text); cursor:pointer; transition:border-color 0.15s; font-family:var(--font); white-space:nowrap; max-width:200px; overflow:hidden; text-overflow:ellipsis; }
.project-btn:hover { border-color:var(--blue); }
.project-btn .arrow { color:var(--muted2); font-size:0.65rem; }
.project-dropdown { position:absolute; top:calc(100% + 6px); left:0; background:var(--card); border:1px solid var(--border); border-radius:9px; padding:5px; z-index:200; min-width:200px; box-shadow:0 8px 24px rgba(0,0,0,0.4); display:none; }
.project-dropdown.open { display:block; }
.project-dd-item { padding:7px 10px; border-radius:6px; font-size:0.8rem; cursor:pointer; color:var(--muted); transition:all 0.12s; display:flex; align-items:center; gap:7px; }
.project-dd-item:hover { background:var(--card2); color:var(--text); }
.project-dd-item.active { color:var(--blue); }
.project-dd-divider { border-top:1px solid var(--border); margin:4px 0; }
.project-dd-new { color:var(--green); font-weight:500; }

.topbar-right { display:flex; align-items:center; gap:8px; }
.user-chip { display:flex; align-items:center; gap:7px; padding:4px 10px 4px 4px; background:var(--card); border:1px solid var(--border); border-radius:999px; font-size:0.73rem; color:var(--muted); cursor:pointer; transition:border-color 0.15s; white-space:nowrap; }
.user-chip:hover { border-color:var(--blue); }
.avatar { width:24px; height:24px; background:var(--blue); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.6rem; font-weight:700; color:#fff; overflow:hidden; flex-shrink:0; }
.avatar img { width:100%; height:100%; object-fit:cover; }
.profile-dot { width:7px; height:7px; border-radius:50%; background:var(--muted2); flex-shrink:0; }

/* ─── LAYOUT ───────────────────────────────────────────────── */
.layout { display:flex; flex:1; overflow:hidden; }
.sidebar { width:185px; border-right:1px solid var(--border); background:var(--surface); padding:14px 10px; display:flex; flex-direction:column; gap:1px; flex-shrink:0; overflow-y:auto; }
.nav-section { font-size:0.63rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--muted2); padding:10px 8px 5px; }
.nav-item { display:flex; align-items:center; gap:8px; padding:7px 9px; border-radius:6px; cursor:pointer; color:var(--muted); font-size:0.82rem; transition:all 0.12s; border:1px solid transparent; }
.nav-item:hover { background:var(--card); color:var(--text); }
.nav-item.active { background:var(--card); color:var(--text); border-color:var(--border); font-weight:500; }
.nav-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.nav-badge { margin-left:auto; font-size:0.6rem; background:var(--orange); color:#fff; padding:1px 5px; border-radius:999px; font-weight:700; }

.main { flex:1; overflow-y:auto; padding:26px 26px 40px; }
.page-title { font-size:1.2rem; font-weight:700; letter-spacing:-0.02em; margin-bottom:3px; }
.page-sub { font-size:0.8rem; color:var(--muted); margin-bottom:22px; }
.view { display:none; }
.view.active { display:block; }

/* ─── ONBOARDING ALERT ─────────────────────────────────────── */
.onboard-alert { display:flex; align-items:center; gap:12px; background:rgba(249,115,22,0.08); border:1px solid rgba(249,115,22,0.25); border-radius:8px; padding:12px 16px; margin-bottom:20px; }
.onboard-alert span { font-size:0.8rem; color:#fdba74; flex:1; }
.onboard-alert button { background:var(--orange); color:#fff; border:none; border-radius:6px; padding:5px 12px; font-size:0.75rem; font-weight:600; font-family:var(--font); cursor:pointer; white-space:nowrap; }

/* ─── ONBOARDING WIZARD ─────────────────────────────────────── */
.wizard-overlay { position:fixed; inset:0; background:rgba(10,10,10,0.96); z-index:1000; display:flex; align-items:center; justify-content:center; padding:20px; }
.wizard-box { background:var(--card); border:1px solid var(--border); border-radius:16px; width:100%; max-width:560px; overflow:hidden; }
.wizard-header { padding:24px 28px 0; }
.wizard-step-label { font-size:0.68rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--muted2); margin-bottom:6px; }
.wizard-title { font-size:1.1rem; font-weight:700; letter-spacing:-0.02em; margin-bottom:4px; }
.wizard-sub { font-size:0.8rem; color:var(--muted); }
.wizard-progress { display:flex; gap:4px; margin:20px 28px 0; }
.wizard-prog-step { flex:1; height:3px; border-radius:999px; background:var(--border); transition:background 0.3s; }
.wizard-prog-step.done { background:var(--green); }
.wizard-prog-step.active { background:var(--blue); }
.wizard-body { padding:20px 28px 28px; }
.wizard-footer { display:flex; justify-content:space-between; align-items:center; padding:0 28px 24px; }
.wizard-back { background:transparent; border:1px solid var(--border); border-radius:7px; padding:8px 16px; font-size:0.82rem; color:var(--muted); cursor:pointer; font-family:var(--font); }
.wizard-back:hover { border-color:var(--blue); color:var(--blue); }
.wizard-next { background:var(--blue); border:none; border-radius:7px; padding:9px 22px; font-size:0.83rem; font-weight:600; color:#fff; cursor:pointer; font-family:var(--font); transition:background 0.15s; }
.wizard-next:hover { background:#2563eb; }
.wizard-next:disabled { opacity:0.4; cursor:not-allowed; }

/* Gatilhos no wizard */
.gatilhos-grid { display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.gatilho-card { display:flex; align-items:flex-start; gap:9px; background:var(--surface); border:1px solid var(--border); border-radius:8px; padding:10px 12px; cursor:pointer; transition:all 0.15s; }
.gatilho-card.selected { border-color:var(--blue); background:var(--blue-dim); }
.gatilho-card input[type=checkbox] { accent-color:var(--blue); margin-top:2px; flex-shrink:0; }
.gatilho-card label { font-size:0.78rem; color:var(--muted); cursor:pointer; line-height:1.4; }
.gatilho-card.selected label { color:var(--text); }

/* Pautas geradas no wizard */
.wizard-pautas-grid { display:grid; grid-template-columns:1fr 1fr; gap:7px; max-height:320px; overflow-y:auto; }
.wizard-pauta-item { background:var(--surface); border:1px solid var(--border); border-radius:8px; padding:10px 12px; }
.wizard-pauta-tipo { font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:0.07em; margin-bottom:4px; }
.wizard-pauta-titulo { font-size:0.8rem; font-weight:500; line-height:1.4; }
.wizard-loading { display:flex; flex-direction:column; align-items:center; gap:16px; padding:40px 0; color:var(--muted); font-size:0.85rem; }
.wizard-spinner { width:32px; height:32px; border:2px solid var(--border); border-top-color:var(--blue); border-radius:50%; animation:spin 0.8s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ─── AGUARDANDO APROVAÇÃO ─────────────────────────────────── */
.pending-overlay { position:fixed; inset:0; background:rgba(10,10,10,0.98); z-index:9999; display:flex; align-items:center; justify-content:center; }
.pending-box { text-align:center; max-width:380px; padding:20px; }
.pending-icon { font-size:2.5rem; margin-bottom:16px; }
.pending-title { font-size:1.1rem; font-weight:700; margin-bottom:8px; }
.pending-sub { font-size:0.82rem; color:var(--muted); line-height:1.6; }
.pending-logout { margin-top:20px; background:transparent; border:1px solid var(--border); border-radius:7px; padding:7px 16px; font-size:0.8rem; color:var(--muted); cursor:pointer; font-family:var(--font); }

/* ─── FLOW BAR ─────────────────────────────────────────────── */
.flow-bar { display:flex; align-items:center; gap:0; margin-bottom:24px; }
.fstep { display:flex; align-items:center; gap:6px; font-size:0.72rem; color:var(--muted2); }
.fstep.active { color:var(--blue); font-weight:600; }
.fstep.done { color:var(--green); }
.fnum { width:18px; height:18px; border-radius:50%; border:1px solid currentColor; display:flex; align-items:center; justify-content:center; font-size:0.6rem; font-weight:700; }
.fstep.done .fnum { background:var(--green); border-color:var(--green); color:#000; }
.fstep.active .fnum { background:var(--blue); border-color:var(--blue); color:#fff; }
.farrow { margin:0 7px; color:var(--border2); font-size:0.68rem; }

/* ─── FILTER BAR ───────────────────────────────────────────── */
.filter-bar { display:flex; gap:5px; margin-bottom:16px; flex-wrap:wrap; align-items:center; }
.fbtn { padding:4px 12px; border-radius:999px; border:1px solid var(--border); background:transparent; color:var(--muted); font-family:var(--font); font-size:0.73rem; cursor:pointer; transition:all 0.12s; }
.fbtn:hover, .fbtn.active { border-color:var(--blue); color:var(--blue); background:var(--blue-dim); }
.filter-bar .spacer { flex:1; }

/* ─── PAUTAS ───────────────────────────────────────────────── */
.pautas-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(220px,1fr)); gap:9px; }
.pautas-empty { text-align:center; padding:60px 20px; color:var(--muted2); }
.pautas-empty h3 { font-size:1rem; margin-bottom:8px; color:var(--muted); }
.pautas-empty p { font-size:0.8rem; line-height:1.6; }
.pcard { background:var(--card); border:1px solid var(--border); border-radius:9px; padding:14px; cursor:pointer; transition:all 0.15s; position:relative; overflow:hidden; }
.pcard:hover { border-color:var(--blue); background:var(--card2); }
.ptipo { display:inline-flex; align-items:center; gap:4px; font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.07em; padding:2px 8px; border-radius:999px; margin-bottom:8px; }
.t-dica    { background:var(--blue-dim); color:var(--blue); border:1px solid var(--blue-border); }
.t-case    { background:var(--green-dim); color:var(--green); border:1px solid rgba(34,197,94,0.2); }
.t-opiniao { background:rgba(251,191,36,0.1); color:var(--yellow); border:1px solid rgba(251,191,36,0.2); }
.t-lista   { background:rgba(244,114,182,0.1); color:var(--pink); border:1px solid rgba(244,114,182,0.2); }
.t-reflexao{ background:rgba(249,115,22,0.1); color:var(--orange); border:1px solid rgba(249,115,22,0.2); }
.pcard h4 { font-size:0.83rem; font-weight:600; line-height:1.4; margin-bottom:5px; }
.pcard p { font-size:0.75rem; color:var(--muted); line-height:1.5; margin-bottom:9px; }
.predes { display:flex; gap:4px; }
.rtag { font-size:0.63rem; font-weight:600; padding:1px 7px; border-radius:999px; }
.r-li { background:rgba(59,130,246,0.1); color:#60a5fa; }
.r-ig { background:rgba(244,114,182,0.1); color:#f472b6; }
.pcard-actions { position:absolute; bottom:11px; right:11px; display:flex; gap:5px; opacity:0; transition:opacity 0.15s; }
.pcard:hover .pcard-actions { opacity:1; }
.usar-btn   { background:var(--blue); color:#fff; border:none; border-radius:5px; padding:3px 10px; font-size:0.7rem; font-weight:600; font-family:var(--font); cursor:pointer; }
.arquivar-btn { background:var(--surface); color:var(--muted); border:1px solid var(--border); border-radius:5px; padding:3px 7px; font-size:0.7rem; font-family:var(--font); cursor:pointer; }
.arquivar-btn:hover { border-color:#ef4444; color:#ef4444; }

/* ─── PANELS ───────────────────────────────────────────────── */
.pgrid { display:grid; grid-template-columns:320px 1fr; gap:16px; }
.panel { background:var(--card); border:1px solid var(--border); border-radius:10px; padding:18px; }
.panel h3 { font-size:0.85rem; font-weight:600; margin-bottom:14px; }

/* ─── FORMS ────────────────────────────────────────────────── */
.frow { margin-bottom:13px; }
.flabel { font-size:0.73rem; color:var(--muted); margin-bottom:5px; display:block; font-weight:500; }
.flabel-hint { font-size:0.68rem; color:var(--muted2); margin-left:6px; font-weight:400; }
.fctrl { width:100%; background:var(--surface); border:1px solid var(--border); border-radius:6px; padding:7px 10px; color:var(--text); font-family:var(--font); font-size:0.82rem; transition:border-color 0.15s; outline:none; }
.fctrl:focus { border-color:var(--blue); }
textarea.fctrl { resize:vertical; min-height:68px; }
select.fctrl option { background:var(--surface); }
.rede-toggle { display:flex; gap:5px; }
.rbtn { flex:1; padding:7px; border-radius:6px; border:1px solid var(--border); background:transparent; font-family:var(--font); font-size:0.77rem; font-weight:600; cursor:pointer; transition:all 0.15s; color:var(--muted); }
.rbtn.li.active { background:rgba(59,130,246,0.1); border-color:#3b82f6; color:#60a5fa; }
.rbtn.ig.active { background:rgba(244,114,182,0.1); border-color:#f472b6; color:#f472b6; }

/* ─── GATILHOS BADGE ───────────────────────────────────────── */
.gatilho-preview { background:rgba(59,130,246,0.06); border:1px solid var(--blue-border); border-radius:7px; padding:9px 12px; margin-bottom:13px; }
.gatilho-preview-label { font-size:0.65rem; color:var(--blue); font-weight:600; text-transform:uppercase; letter-spacing:0.07em; margin-bottom:5px; }
.gatilho-tags { display:flex; flex-wrap:wrap; gap:4px; }
.gtag { font-size:0.65rem; padding:2px 8px; border-radius:999px; background:var(--blue-dim); color:#93c5fd; border:1px solid var(--blue-border); }

/* ─── BUTTONS ──────────────────────────────────────────────── */
.btn-p { width:100%; padding:9px; border-radius:7px; border:none; background:var(--blue); color:#fff; font-family:var(--font); font-size:0.83rem; font-weight:600; cursor:pointer; transition:all 0.15s; margin-top:5px; }
.btn-p:hover { background:#2563eb; }
.btn-p:disabled { opacity:0.45; cursor:not-allowed; }
.btn-g { width:100%; padding:9px; border-radius:7px; border:none; background:var(--green); color:#000; font-family:var(--font); font-size:0.83rem; font-weight:700; cursor:pointer; transition:all 0.15s; margin-top:5px; }
.btn-g:hover { background:#16a34a; color:#fff; }
.btn-g:disabled { opacity:0.45; cursor:not-allowed; }
.btn-s { padding:6px 12px; border-radius:6px; border:1px solid var(--border); background:transparent; color:var(--muted); font-family:var(--font); font-size:0.76rem; cursor:pointer; transition:all 0.12s; }
.btn-s:hover { border-color:var(--blue); color:var(--blue); }
.btn-danger { padding:6px 12px; border-radius:6px; border:1px solid rgba(239,68,68,0.3); background:transparent; color:#f87171; font-family:var(--font); font-size:0.76rem; cursor:pointer; transition:all 0.12s; }
.btn-danger:hover { border-color:#ef4444; background:rgba(239,68,68,0.08); }

.obox { background:var(--surface); border:1px solid var(--border); border-radius:7px; padding:13px; font-size:0.82rem; line-height:1.75; color:var(--text); min-height:150px; white-space:pre-wrap; }
.oplaceholder { color:var(--muted2); font-style:italic; font-size:0.78rem; }
.oactions { display:flex; gap:5px; margin-top:9px; flex-wrap:wrap; }
.next-banner { display:flex; align-items:center; justify-content:space-between; background:var(--blue-dim); border:1px solid var(--blue-border); border-radius:7px; padding:9px 13px; margin-top:12px; }
.next-banner span { font-size:0.78rem; color:var(--blue); font-weight:500; }
.img-prev { background:var(--surface); border:1px solid var(--border); border-radius:7px; min-height:200px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.img-ph { color:var(--muted2); font-style:italic; font-size:0.78rem; text-align:center; padding:20px; }

/* ─── CALENDÁRIO ───────────────────────────────────────────── */
.cal-hrow { display:grid; grid-template-columns:70px repeat(7,1fr); gap:4px; margin-bottom:3px; }
.cal-hcell { font-size:0.62rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--muted2); text-align:center; }
.cal-wrow { display:grid; grid-template-columns:70px repeat(7,1fr); gap:4px; margin-bottom:4px; }
.cal-wlabel { font-size:0.65rem; color:var(--muted2); display:flex; align-items:flex-start; padding-top:6px; }
.cal-cell { background:var(--card); border:1px solid var(--border); border-radius:7px; padding:6px; min-height:70px; }
.cal-cell.today { border-color:var(--blue); }
.cal-date { font-size:0.62rem; color:var(--muted2); margin-bottom:4px; font-weight:500; }
.cal-date.tod { color:var(--blue); font-weight:700; }
.cal-ptag { font-size:0.62rem; padding:2px 5px; border-radius:4px; margin-bottom:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cal-ptag.li { background:rgba(59,130,246,0.12); color:#60a5fa; }
.cal-ptag.ig { background:rgba(244,114,182,0.1); color:#f472b6; }
.cal-add { font-size:0.58rem; color:var(--border2); cursor:pointer; margin-top:3px; }
.cal-add:hover { color:var(--blue); }

/* ─── HISTÓRICO ────────────────────────────────────────────── */
.hlist { display:flex; flex-direction:column; gap:7px; }
.hitem { background:var(--card); border:1px solid var(--border); border-radius:9px; padding:13px 15px; display:flex; gap:12px; align-items:flex-start; }
.hmeta { display:flex; flex-direction:column; gap:4px; min-width:76px; }
.hrede { font-size:0.65rem; font-weight:700; padding:2px 7px; border-radius:999px; text-align:center; }
.htipo { font-size:0.63rem; padding:2px 7px; border-radius:999px; text-align:center; }
.hdate { font-size:0.65rem; color:var(--muted2); }
.hbody { flex:1; min-width:0; }
.htitle { font-size:0.83rem; font-weight:600; margin-bottom:4px; }
.hpreview { font-size:0.76rem; color:var(--muted); line-height:1.5; }
.himg { width:58px; height:58px; border-radius:6px; object-fit:cover; flex-shrink:0; border:1px solid var(--border); }
.hactions { display:flex; gap:5px; margin-top:8px; }

/* ─── PERFIL ───────────────────────────────────────────────── */
.perfil-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.perfil-section { background:var(--card); border:1px solid var(--border); border-radius:10px; padding:18px; }
.perfil-section h3 { font-size:0.85rem; font-weight:600; margin-bottom:4px; }
.perfil-section .psub { font-size:0.75rem; color:var(--muted); margin-bottom:14px; }
.save-btn { background:var(--green); color:#000; border:none; border-radius:7px; padding:9px 20px; font-family:var(--font); font-size:0.83rem; font-weight:700; cursor:pointer; transition:all 0.15s; margin-top:16px; }
.save-btn:hover { background:#16a34a; color:#fff; }
.checkbox-row { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.checkbox-row input { accent-color:var(--blue); cursor:pointer; width:14px; height:14px; }
.checkbox-row label { font-size:0.8rem; color:var(--muted); cursor:pointer; }
.perfil-status { display:flex; align-items:center; gap:6px; font-size:0.75rem; color:var(--muted2); margin-top:8px; }
.perfil-status.ok { color:var(--green); }

/* ─── ADMIN ────────────────────────────────────────────────── */
.admin-section { max-width:900px; }
.admin-toolbar { display:flex; align-items:center; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.admin-toolbar h3 { font-size:0.9rem; font-weight:600; flex:1; }

/* Tabela de usuários */
.admin-table { width:100%; border-collapse:collapse; font-size:0.82rem; }
.admin-table th { text-align:left; padding:8px 12px; border-bottom:1px solid var(--border); font-size:0.72rem; font-weight:500; color:var(--muted2); text-transform:uppercase; letter-spacing:0.06em; }
.admin-table td { padding:10px 12px; border-bottom:1px solid var(--border); vertical-align:middle; }
.admin-table tr:last-child td { border-bottom:none; }
.admin-table tr:hover td { background:rgba(255,255,255,0.02); }
.status-pill { display:inline-flex; align-items:center; gap:4px; font-size:0.7rem; font-weight:600; padding:2px 8px; border-radius:999px; }
.status-active { background:var(--green-dim); color:var(--green); border:1px solid rgba(34,197,94,0.2); }
.status-pending { background:rgba(251,191,36,0.1); color:var(--yellow); border:1px solid rgba(251,191,36,0.2); }

/* Lista de prompts */
.prompt-list { display:flex; flex-direction:column; gap:7px; margin-bottom:20px; }
.prompt-item { background:var(--card); border:1px solid var(--border); border-radius:9px; padding:13px 16px; display:flex; align-items:center; gap:12px; }
.prompt-item-dot { width:8px; height:8px; border-radius:50%; background:var(--green); flex-shrink:0; }
.prompt-item-dot.off { background:var(--muted2); }
.prompt-item-info { flex:1; min-width:0; }
.prompt-item-nome { font-size:0.85rem; font-weight:600; margin-bottom:2px; }
.prompt-item-meta { font-size:0.73rem; color:var(--muted2); }
.prompt-type-badge { font-size:0.65rem; font-weight:600; padding:1px 7px; border-radius:999px; background:var(--surface); border:1px solid var(--border); color:var(--muted); }

/* Editor de prompt */
.prompt-editor { background:var(--card); border:1px solid var(--border); border-radius:10px; padding:20px; }
.prompt-editor h3 { font-size:0.9rem; font-weight:600; margin-bottom:16px; }
.prompt-vars { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:10px; }
.prompt-var { font-size:0.68rem; font-weight:600; padding:2px 8px; border-radius:4px; background:var(--blue-dim); color:#93c5fd; border:1px solid var(--blue-border); font-family:monospace; cursor:pointer; }
.prompt-var:hover { background:var(--blue); color:#fff; }
textarea.prompt-template { font-family:monospace; font-size:0.78rem; line-height:1.7; min-height:300px; }

/* Painel de teste */
.test-panel { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:16px; margin-top:16px; }
.test-panel h4 { font-size:0.82rem; font-weight:600; margin-bottom:12px; color:var(--muted); }
.test-result { background:var(--card); border:1px solid var(--border); border-radius:7px; padding:12px; font-size:0.8rem; line-height:1.7; white-space:pre-wrap; min-height:80px; margin-top:10px; color:var(--text); }

/* ─── LOADING ──────────────────────────────────────────────── */
.ldots span { animation:blink 1.2s infinite; display:inline-block; }
.ldots span:nth-child(2){ animation-delay:.2s; }
.ldots span:nth-child(3){ animation-delay:.4s; }
@keyframes blink{0%,80%,100%{opacity:.1}40%{opacity:1}}

/* ─── TOAST ────────────────────────────────────────────────── */
.toast { position:fixed; bottom:20px; right:20px; background:var(--green); color:#000; font-weight:700; font-size:0.8rem; padding:8px 16px; border-radius:999px; transform:translateY(60px); opacity:0; transition:all .25s; z-index:9000; pointer-events:none; }
.toast.show { transform:translateY(0); opacity:1; }
.toast.error { background:#ef4444; color:#fff; }

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

/* ─── LOGIN ────────────────────────────────────────────────── */
.login-overlay { position:fixed; inset:0; background:rgba(10,10,10,0.97); z-index:9999; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px); }
.login-box { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:44px 40px; width:420px; text-align:center; box-shadow:0 24px 60px rgba(0,0,0,0.5); }
.login-logo { font-size:1.6rem; font-weight:700; letter-spacing:-0.03em; margin-bottom:8px; }
.login-logo span { color:var(--blue); }
.login-sub { font-size:0.82rem; color:var(--muted); margin-bottom:28px; line-height:1.6; }
.login-error { font-size:0.78rem; color:#f87171; margin-top:8px; min-height:20px; }
.g_id_signin { display:flex; justify-content:center; margin:8px 0 4px; }

/* ─── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:860px){
  .pgrid{grid-template-columns:1fr;}
  .sidebar{width:155px;}
  .perfil-grid{grid-template-columns:1fr;}
  .project-btn{max-width:130px;}
  .wizard-pautas-grid{grid-template-columns:1fr;}
  .gatilhos-grid{grid-template-columns:1fr;}
}
