:root{
  --bg:#F5F5F7;
  --card:#FFFFFF;
  --cardBg:#FFFFFF;
  --cardBorder:#E0E0E0;
  --elevated:#F0F0F2;
  --primary:#5B6EF5;
  --primaryDim:rgba(91,110,245,0.10);
  --accent:#34A853;
  --accentDim:rgba(52,168,83,0.10);
  --blue:#2B7DE9;
  --blueDim:rgba(43,125,233,0.10);
  --danger:#EA4335;
  --dangerDim:rgba(234,67,53,0.08);
  --warning:#F29D0B;
  --warningDim:rgba(242,157,11,0.10);
  --white:#FFFFFF;
  --textPrimary:#1A1A1A;
  --textSecondary:#5F6368;
  --textMuted:#9AA0A6;
  --border:#DADCE0;
  --inputBg:#FFFFFF;
  --shadowSm:0 1px 3px rgba(0,0,0,0.06);
  --shadowMd:0 4px 16px rgba(0,0,0,0.08);
  --overlayBg:rgba(0,0,0,0.25);
  --codeBg:#F0F0F2;
}

[data-theme="dark"]{
  --bg:#0D0D0D;
  --card:#161616;
  --cardBg:#161616;
  --cardBorder:#282828;
  --elevated:#1C1C1C;
  --primary:#7B8EFF;
  --primaryDim:rgba(123,142,255,0.14);
  --accent:#5DDB6A;
  --accentDim:rgba(93,219,106,0.14);
  --blue:#5CB8FF;
  --blueDim:rgba(92,184,255,0.14);
  --danger:#FF5B52;
  --dangerDim:rgba(255,91,82,0.10);
  --warning:#FFB84D;
  --warningDim:rgba(255,184,77,0.14);
  --white:#FFFFFF;
  --textPrimary:#EFEFEF;
  --textSecondary:#B8B8B8;
  --textMuted:#8A8A8A;
  --border:#333333;
  --inputBg:#111111;
  --shadowSm:0 1px 3px rgba(0,0,0,0.3);
  --shadowMd:0 4px 16px rgba(0,0,0,0.4);
  --overlayBg:rgba(0,0,0,0.55);
  --codeBg:rgba(255,255,255,0.08);
}

*{box-sizing:border-box;margin:0;padding:0}
html{height:100%}
body{
  min-height:100%;
  background:var(--bg);
  color:var(--textPrimary);
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,sans-serif;
  font-size:15px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
code{
  background:var(--codeBg);
  border:1px solid var(--border);
  padding:2px 8px;
  border-radius:8px;
  font-size:12px;
  color:var(--textSecondary);
}

/* ── Top Bar ─────────────────────────── */
.topBar{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.topBar .logo{display:flex;align-items:center;gap:10px}
.topBar .logo img{width:34px;height:34px;border-radius:10px;border:1px solid var(--border)}
.topBar .logo span{font-weight:800;font-size:16px;letter-spacing:.02em}
.topBar .actions{display:flex;align-items:center;gap:8px}
.bellBtn{
  width:40px;height:40px;border-radius:12px;border:1px solid var(--border);
  background:var(--card);display:flex;align-items:center;justify-content:center;
  cursor:pointer;position:relative;
}
.bellBtn svg{width:20px;height:20px;fill:var(--textPrimary)}
.bellBtn .dot{
  position:absolute;top:6px;right:6px;width:8px;height:8px;
  border-radius:50%;background:var(--primary);
}
.logoutBtn{text-decoration:none}
.licenseBadge{
  display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:10px;
  background:var(--card);border:1px solid var(--border);color:var(--textSecondary);
  font-size:12px;font-weight:700;white-space:nowrap;
}
.licenseBadge svg{color:var(--textSecondary);flex-shrink:0}
.licenseBadge.licenseExpiring{
  background:rgba(234,67,53,0.10);border-color:rgba(234,67,53,0.40);color:var(--danger);
}
.licenseBadge.licenseExpiring svg{color:var(--danger)}
[data-theme="dark"] .licenseBadge.licenseExpiring{
  background:rgba(255,107,53,0.12);border-color:rgba(255,107,53,0.45);color:#ffb28a;
}
[data-theme="dark"] .licenseBadge.licenseExpiring svg{color:#ffb28a}
.renewBtn{
  background:#FF6B35;color:#fff;padding:8px 12px;border-radius:10px;
  font-size:12px;font-weight:800;text-decoration:none;white-space:nowrap;
  transition:filter .15s;
}
.renewBtn:hover{filter:brightness(1.1)}
@media (max-width:520px){
  .licenseBadge{padding:6px 8px;font-size:11px}
  .licenseBadge svg{width:12px;height:12px}
  .renewBtn{padding:7px 10px;font-size:11px}
}

/* ── Wrap ────────────────────────────── */
.wrap{max-width:520px;margin:0 auto;padding:18px 18px 100px}

/* ── Section titles ──────────────────── */
.sectionLabel{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--textMuted);margin-bottom:10px;
}

/* ── Card ────────────────────────────── */
.card{
  background:var(--card);
  border:1px solid var(--cardBorder);
  border-radius:16px;
  padding:14px;
  margin-bottom:14px;
}

/* ── Active App strip (7 colunas iguais, espaçamento simétrico) ── */
.appStrip{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  column-gap:8px;
  row-gap:0;
  align-items:start;
  width:100%;
  padding:6px 0 12px;
  box-sizing:border-box;
}
.appChip{
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  gap:6px;
  min-width:0;
  width:100%;
  cursor:pointer;
}
.appChip img{
  width:52px;height:52px;max-width:100%;
  border-radius:14px;
  border:2px solid var(--border);background:var(--elevated);
  transition:border-color .15s;
  flex-shrink:0;
}
.appChip.active img{border-color:var(--accent)}
.appChip.used img{border-color:var(--accent);box-shadow:0 0 0 3px var(--accentDim)}
.appChipMeta{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  width:100%;min-width:0;text-align:center;
}
.appChipSlot{
  font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  color:var(--textPrimary);line-height:1.2;
  width:100%;
}
.appChipTitle{
  font-size:9px;color:var(--textSecondary);width:100%;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.25;
}
.appChipTitleEmpty{color:var(--textMuted);font-weight:600}

.appChip.off{
  cursor:pointer;text-decoration:none;opacity:.55;
  transition:opacity .15s;
}
.appChip.off:hover{opacity:.85}
.appChipOff{
  width:52px;height:52px;max-width:100%;
  border-radius:14px;
  border:2px dashed var(--border);
  background:var(--elevated);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;letter-spacing:.06em;
  color:var(--textMuted);
  flex-shrink:0;
}
.appChipTitleOff{
  color:var(--blue);font-weight:700;font-size:9px;
}

@media (max-width:480px){
  .appStrip{
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    justify-content:flex-start;
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
    padding:6px 2px 12px;
  }
  .appStrip::-webkit-scrollbar{height:4px}
  .appStrip::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
  .appChip{
    flex:0 0 auto;
    width:64px;
  }
  .appChipSlot{font-size:8px}
  .appChipTitle{font-size:8px}
}

/* ── Mode Tabs ───────────────────────── */
.modeTabs{
  display:flex;gap:4px;
  background:var(--elevated);
  border:1px solid var(--border);
  border-radius:14px;
  padding:4px;
  margin-bottom:14px;
}
.modeTab{
  flex:1;
  padding:10px 8px;
  border:none;border-radius:11px;
  background:transparent;
  color:var(--textMuted);
  font-size:13px;font-weight:700;
  cursor:pointer;
  transition:all .15s;
  text-align:center;
}
.modeTab.active{
  background:var(--primary);
  color:#fff;
  box-shadow:0 2px 10px rgba(91,110,245,0.35);
}
.modeTab:not(.active):hover{color:var(--textPrimary)}

.modePanel{display:none}
.modePanel.active{display:block}

/* ── Form fields ─────────────────────── */
.fieldHint{
  font-size:12px;line-height:1.45;color:var(--textMuted);
  margin:-4px 0 10px;
  padding:0 2px;
}
.fieldHint code{font-size:11px;padding:1px 6px}
.fieldHintWarn{
  border-left:3px solid var(--warning);
  padding:10px 12px;margin:10px 0 0;
  background:var(--warningDim);
  border-radius:0 10px 10px 0;
}
.fieldHintWarn strong{color:var(--textPrimary)}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.field .lbl{
  font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--textMuted);
}
input,select,textarea{
  width:100%;
  background:var(--inputBg);
  border:1px solid var(--border);
  border-radius:14px;
  padding:12px 14px;
  color:var(--textPrimary);
  font-size:15px;
  outline:none;
  transition:border-color .15s;
}
input:focus,select:focus,textarea:focus{border-color:var(--primary)}
textarea{min-height:80px;resize:vertical}
select{appearance:none;cursor:pointer}

/* ── Settings row ────────────────────── */
.settingsRow{display:flex;gap:10px;flex-wrap:wrap}
.settingsRow .field{flex:1;min-width:120px}

/* ── Inline add row ──────────────────── */
.inlineAdd{
  display:flex;gap:8px;align-items:center;margin-bottom:12px;
}
.inlineAdd input{flex:1}

.fieldInline{
  display:flex;gap:8px;align-items:center;
}
.fieldInline input{flex:1}

/* ── Buttons ─────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:14px;
  padding:12px 18px;font-size:14px;font-weight:700;
  cursor:pointer;transition:opacity .12s,transform .08s;
  letter-spacing:.02em;
}
.btn:active{transform:scale(.97)}
.btnPrimary{background:var(--primary);color:#fff}
.btnPrimary:hover{opacity:.88}
.btnAccent{background:var(--accent);color:#fff}
.btnAccent:hover{opacity:.88}
.btnDanger{background:var(--danger);color:#fff;padding:8px 14px;font-size:12px;border-radius:10px}
.btnGhost{
  background:transparent;border:1px solid var(--border);
  color:var(--textPrimary);
}
.btnGhost:hover{border-color:var(--textMuted)}
.btnBlock{width:100%}
.btnSm{padding:8px 14px;font-size:12px;border-radius:10px}

/* ── Fixed footer ────────────────────── */
.fixedFooter{
  position:fixed;bottom:0;left:0;right:0;z-index:8;
  padding:12px 18px 22px;
  background:linear-gradient(transparent,var(--bg) 30%);
}
.fixedFooter .inner{max-width:520px;margin:0 auto}

/* ── Sidebar (histórico) ─────────────── */
.overlay{
  position:fixed;inset:0;z-index:20;
  background:var(--overlayBg);
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.overlay.open{opacity:1;pointer-events:auto}
.sidebar{
  position:fixed;top:0;right:-100%;bottom:0;width:min(340px,88vw);z-index:21;
  background:var(--bg);border-left:1px solid var(--border);
  display:flex;flex-direction:column;
  transition:right .25s cubic-bezier(.4,0,.2,1);
}
.sidebar.open{right:0}
.sidebarHead{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;border-bottom:1px solid var(--border);
}
.sidebarHead h3{font-size:16px;font-weight:800}
.closeBtn{
  width:36px;height:36px;border-radius:10px;border:1px solid var(--border);
  background:var(--card);display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--textPrimary);font-size:18px;
}
.sidebarBody{flex:1;overflow-y:auto;padding:14px 18px}
.histItem{
  background:var(--card);border:1px solid var(--cardBorder);border-radius:14px;
  padding:12px;margin-bottom:10px;cursor:pointer;
  transition:border-color .15s;
}
.histItem:hover{border-color:var(--primary)}
.histItem .histTitle{font-weight:700;font-size:14px;color:var(--textPrimary);margin-bottom:4px}
.histItem .histMsg{font-size:13px;color:var(--textSecondary);margin-bottom:4px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.histItem .histMeta{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  margin-top:6px;
}
.histItem .histComment{font-size:11px;color:var(--textMuted)}
.histItem .histTime{font-size:11px;color:var(--textMuted)}
.histActions{display:flex;gap:6px;margin-top:8px}
.historyLoadMore{
  width:100%;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--textPrimary);
  border-radius:12px;
  padding:11px 12px;
  font-weight:800;
  cursor:pointer;
}
.historyLoadMore:disabled{opacity:.65;cursor:not-allowed}

/* ── Result toast ────────────────────── */
.toast{
  position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:30;
  padding:12px 20px;border-radius:14px;font-size:14px;font-weight:600;
  box-shadow:var(--shadowMd);
  opacity:0;pointer-events:none;transition:opacity .3s;
  max-width:90vw;text-align:center;
}
.toast.show{opacity:1}
.toast.ok{background:var(--accent);color:#fff}
.toast.err{background:var(--danger);color:#fff}

/* ── Model cards (variado) ───────────── */
.modelCard{
  background:var(--elevated);
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px;
  margin-bottom:8px;
}
.modelCard input{
  margin-bottom:6px;
  background:var(--inputBg);
  padding:10px 12px;
  font-size:14px;
}
.modelMsgRow{
  display:flex;gap:8px;align-items:stretch;
  margin-bottom:6px;
}
.modelMsgRow input{
  flex:1;min-width:0;margin-bottom:0 !important;
}
.btnInsertValor{
  flex-shrink:0;align-self:stretch;
  padding:0 12px;min-width:52px;
  border-radius:12px;border:1px solid rgba(91,110,245,0.35);
  background:var(--primaryDim);
  color:var(--primary);
  font-size:12px;font-weight:800;
  cursor:pointer;white-space:nowrap;
  transition:background .15s,border-color .15s;
}
.btnInsertValor:hover{
  background:rgba(91,110,245,0.22);
  border-color:rgba(91,110,245,0.55);
}
.btnInsertValor:active{transform:scale(0.98)}
.modelHead{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;
}
.modelIdx{
  font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--textMuted);
}
.btnRemove{
  width:28px;height:28px;border-radius:8px;
  border:1px solid var(--border);background:var(--card);
  color:var(--danger);font-size:16px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.btnRemove:hover{background:var(--dangerDim)}

/* ── Value chips ─────────────────────── */
.chipsRow{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;
  min-height:28px;
}
.chip{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--primaryDim);
  border:1px solid rgba(91,110,245,0.25);
  border-radius:20px;
  padding:5px 10px;
  font-size:12px;font-weight:600;
  color:var(--primary);
}
.chip button{
  background:none;border:none;color:var(--primary);
  font-size:14px;cursor:pointer;padding:0;
  width:auto;
  line-height:1;
}
.chip button:hover{color:var(--danger)}

/* ── Template chips ──────────────────── */
.templateChips{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;
}
.templateChip{
  background:var(--card);
  border:1px solid var(--cardBorder);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
  transition:border-color .15s;
  position:relative;
  display:flex;flex-direction:column;gap:2px;
  min-width:140px;
}
.templateChip:hover{border-color:var(--primary)}
.tplName{font-weight:700;font-size:13px;color:var(--textPrimary)}
.tplMeta{font-size:11px;color:var(--textMuted)}
.tplDel{
  position:absolute;top:6px;right:6px;
  width:22px;height:22px;border-radius:6px;
  border:1px solid var(--border);background:var(--elevated);
  color:var(--danger);font-size:14px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .15s;
}
.templateChip:hover .tplDel{opacity:1}

/* ── Painel de agendamentos (dashboard, sempre visível) ── */
.schedulesDashboard{
  margin-bottom:16px;
}
.schedulesDashHead{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  margin-bottom:14px;
}
.schedulesDashSub{
  font-size:12px;color:var(--textMuted);margin:0;line-height:1.4;max-width:280px;
}
.schDashBtn{flex-shrink:0}
.schDashBlock{margin-bottom:16px}
.schDashBlock:last-child{margin-bottom:0}
.schSubLabel{
  font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
  margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.schSubLive{color:var(--accent)}
.liveDot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 0 rgba(76,175,80,0.6);
  animation:liveBreath 2s ease-in-out infinite;
}
.liveDot.pulse{animation:liveBlip .6s ease-out, liveBreath 2s ease-in-out 1s infinite}
@keyframes liveBreath{
  0%,100%{box-shadow:0 0 0 0 rgba(76,175,80,0.55)}
  50%{box-shadow:0 0 0 5px rgba(76,175,80,0)}
}
@keyframes liveBlip{
  0%{transform:scale(1);box-shadow:0 0 0 0 rgba(76,175,80,0.8)}
  70%{transform:scale(1.6);box-shadow:0 0 0 10px rgba(76,175,80,0)}
  100%{transform:scale(1);box-shadow:0 0 0 0 rgba(76,175,80,0)}
}
.schSubQueue{color:var(--blue)}
.schDashEmpty{
  font-size:13px;color:var(--textMuted);margin:0;padding:8px 0 4px;line-height:1.45;
}
.scheduleCard.schLive{
  border-color:rgba(76,175,80,0.45);
  box-shadow:0 0 0 1px rgba(76,175,80,0.12);
}
.schDashBlockQueue .scheduleCard{margin-bottom:10px}
.schDashBlockQueue .scheduleCard:last-child{margin-bottom:0}

/* ── Schedule cards ──────────────────── */
.scheduleCard{
  background:var(--card);
  border:1px solid var(--cardBorder);
  border-radius:14px;
  padding:14px;
  margin-bottom:10px;
}
.scheduleCard.done{opacity:.5}
.scheduleCard.cancelled{opacity:.4}
.schHeader{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;
}
.schType{
  font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--textMuted);
}
.schStatus{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;
  padding:3px 8px;border-radius:6px;
}
.st-pending{background:var(--warningDim);color:var(--warning)}
.st-running{background:var(--primaryDim);color:var(--primary)}
.st-done{background:var(--accentDim);color:var(--accent)}
.st-cancelled{background:var(--dangerDim);color:var(--danger)}
.schBody{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.schRow{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:var(--textSecondary);
}
.schLabel{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;
  color:var(--textMuted);min-width:70px;
}
.schDateVal{
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:12px;color:var(--textMuted);
}

/* ── Progress bar ────────────────────── */
.progressBar{
  width:100%;height:6px;
  background:var(--elevated);
  border-radius:3px;
  overflow:hidden;
  margin-top:4px;
}
.progressFill{
  height:100%;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  border-radius:3px;
  transition:width .3s;
}

/* ── Detail card (app info) ───────────── */
.detailsInner{
  display:flex;align-items:center;gap:14px;
  margin-top:12px;
}
.detailIcon{flex-shrink:0}
.detailIcon img{
  width:56px;height:56px;border-radius:14px;
  border:2px solid var(--border);background:var(--elevated);
}
.detailInfo{display:flex;flex-direction:column;gap:6px;flex:1}
.detailName{font-weight:800;font-size:15px;color:var(--textPrimary)}
.detailRow{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:var(--textSecondary);
}
.detailLabel{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;
  color:var(--textMuted);min-width:60px;
}
.detailMono{
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:11px;color:var(--textMuted);
}

/* ── Empty state ─────────────────────── */
.empty{text-align:center;padding:40px 20px;color:var(--textMuted);font-size:14px}

/* ── No-user state ───────────────────── */
.hero{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 20px;text-align:center;gap:16px;
}
.hero h2{font-size:22px;font-weight:800}
.hero p{color:var(--textSecondary);font-size:14px;max-width:320px}

/* ── Tutorial ─────────────────────────── */
.tutorial .sidebarBody{padding:14px 18px}
.tutCard{
  display:flex;gap:12px;
  background:var(--card);border:1px solid var(--cardBorder);border-radius:14px;
  padding:14px;margin-bottom:12px;
}
.tutCard.alertCard{
  border-color:rgba(255,59,48,.25);
  background:rgba(255,59,48,.06);
}
.tutIcon{
  flex-shrink:0;width:32px;height:32px;border-radius:10px;
  background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:14px;
}
.tutContent{flex:1}
.tutTitle{font-weight:700;font-size:14px;margin-bottom:6px}
.tutContent p{font-size:13px;color:var(--textSecondary);line-height:1.5;margin-bottom:8px}
.tutContent p:last-child{margin-bottom:0}
.tutSteps{
  margin:8px 0;padding-left:20px;
  font-size:13px;color:var(--textSecondary);line-height:1.7;
}
.tutSteps li{margin-bottom:4px}
.tutSteps li strong{color:var(--textPrimary)}
.tutNote{
  font-size:12px;color:var(--textMuted);
  padding:8px 10px;border-radius:10px;
  background:var(--elevated);
  border:1px solid var(--border);
}

/* ── Badge ────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;
  padding:2px 8px;margin-left:6px;
  border-radius:999px;font-size:11px;font-weight:600;
}
.badge.warn{background:var(--warningDim);color:var(--warning);border:1px solid rgba(245,166,35,.2)}

/* ── KV grid (legacy) ────────────────── */
.kv{display:grid;gap:6px;margin-top:10px}
.kv div{display:grid;grid-template-columns:90px 1fr;gap:8px;align-items:baseline}
.kv dt{font-size:11px;color:var(--textMuted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.kv dd{font-size:13px;color:var(--textSecondary);word-break:break-all}

/* ── Icon swap (trocar ícone remoto — seção dedicada) ── */
.iconSwapSection{margin-bottom:18px}
.iconSwapHead{margin-bottom:10px}
.iconSwapSub{
  color:var(--textMuted);font-size:12px;line-height:1.5;margin:0;
}
.pendingIconCard{
  background:rgba(242,157,11,0.08);border:1px solid rgba(242,157,11,0.30);
  color:#a66900;padding:10px 12px;border-radius:10px;font-size:13px;
  margin:10px 0;
}
.pendingIconCard code{
  background:var(--codeBg);padding:1px 6px;border-radius:6px;font-size:12px;
  color:var(--textSecondary);
}
[data-theme="dark"] .pendingIconCard{
  background:rgba(255,107,53,0.10);border-color:rgba(255,107,53,0.35);color:#ffb28a;
}
[data-theme="dark"] .pendingIconCard code{
  background:rgba(0,0,0,0.35);color:#ffd0b8;
}
.pendingIconHint{font-size:11px;color:var(--textMuted);margin-top:4px}
.iconSwapGrid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;
}
.iconSwapGrid select{
  width:100%;padding:10px 12px;border-radius:10px;
  border:1px solid var(--border);background:var(--card);color:var(--textPrimary);
  font-size:13px;
}
.iconSwapPreviewRow{
  display:flex;align-items:center;justify-content:center;gap:18px;
  margin:16px 0;
}
.iconSwapPreviewBox{display:flex;flex-direction:column;align-items:center;gap:6px}
.iconSwapPreviewLabel{
  font-size:10px;color:var(--textMuted);text-transform:uppercase;letter-spacing:.08em;font-weight:700;
}
.iconSwapPreview{
  width:72px;height:72px;border-radius:16px;
  background:var(--card);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.iconSwapPreview img{width:100%;height:100%;object-fit:cover}
.iconSwapEmpty{font-size:11px;color:var(--textMuted)}
.iconSwapArrow{font-size:22px;color:var(--textMuted);line-height:1}
.iconSwapSection .btn:disabled{opacity:.5;cursor:not-allowed}

@media(max-width:420px){
  .iconSwapGrid{grid-template-columns:1fr}
}

/* ── Theme toggle ───────────────────── */
.themeToggle{
  width:40px;height:40px;border-radius:12px;border:1px solid var(--border);
  background:var(--card);display:flex;align-items:center;justify-content:center;
  cursor:pointer;position:relative;transition:background .2s,border-color .2s;
}
.themeToggle svg{width:20px;height:20px;fill:var(--textPrimary);transition:fill .2s}
.themeToggle:hover{border-color:var(--textMuted)}
.themeToggle .iconSun{display:block}
.themeToggle .iconMoon{display:none}
[data-theme="dark"] .themeToggle .iconSun{display:none}
[data-theme="dark"] .themeToggle .iconMoon{display:block}

/* ── Light-mode card shadow ─────────── */
:root .card{box-shadow:var(--shadowSm)}
:root .card:hover{box-shadow:var(--shadowMd)}
[data-theme="dark"] .card{box-shadow:none}
[data-theme="dark"] .card:hover{box-shadow:none}

/* ── Light fixes ────────────────────── */
:root .bellBtn{background:var(--card);box-shadow:var(--shadowSm)}
:root .topBar{background:var(--bg);box-shadow:var(--shadowSm)}
:root .fixedFooter{background:linear-gradient(transparent,var(--bg) 30%)}
:root select{background:var(--card)}
:root .iconSwapGrid select{background:var(--card)}

/* ── Responsive ──────────────────────── */
@media(max-width:560px){
  .wrap{padding:14px 14px 100px}
  .topBar{padding:10px 14px}
  .modeTabs{border-radius:12px;padding:3px}
  .modeTab{padding:8px 6px;font-size:12px}
  .settingsRow{flex-direction:column}
  .settingsRow .field{min-width:0}
}
