:root{--bg:#f6f7fb;--panel:#fff;--text:#111827;--muted:#6b7280;--brand:#111827;--border:#e5e7eb;--soft:#f3f4f6;--ok:#16a34a;--bad:#dc2626}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit}.layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.side{background:#111827;color:#fff;padding:24px;display:flex;flex-direction:column;gap:18px}.logo{font-size:22px;font-weight:800;line-height:1.1}.side .muted{color:#cbd5e1}.nav a{display:block;padding:12px 14px;border-radius:12px;text-decoration:none;margin:4px 0;background:rgba(255,255,255,.06)}.main{padding:28px;max-width:1100px;width:100%;margin:0 auto}.card{background:var(--panel);border:1px solid var(--border);border-radius:22px;box-shadow:0 8px 30px rgba(15,23,42,.06);padding:22px}.chatbox{height:62vh;overflow:auto;padding:8px;display:flex;flex-direction:column;gap:14px}.msg{max-width:85%;padding:14px 16px;border-radius:18px;white-space:pre-wrap;line-height:1.45}.user{align-self:flex-end;background:#111827;color:#fff}.bot{align-self:flex-start;background:#fff;border:1px solid var(--border)}.composer{display:flex;gap:10px;margin-top:16px}.composer textarea{flex:1;min-height:58px;resize:vertical}.input,textarea,select{width:100%;border:1px solid var(--border);border-radius:14px;padding:12px 14px;font-size:15px;background:#fff}.btn{border:0;border-radius:14px;padding:12px 18px;background:#111827;color:#fff;font-weight:700;cursor:pointer}.btn.secondary{background:#e5e7eb;color:#111827}.btn.danger{background:#dc2626}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.stack{display:flex;flex-direction:column;gap:14px}.muted{color:var(--muted);font-size:14px}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:460px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid var(--border);padding:10px;text-align:left;vertical-align:top}.pill{display:inline-block;padding:4px 8px;background:var(--soft);border-radius:999px;font-size:12px}.feedback{display:flex;gap:8px;margin-top:8px}.notice{padding:12px;border-radius:14px;background:#ecfdf5;border:1px solid #bbf7d0;color:#166534}.error{padding:12px;border-radius:14px;background:#fef2f2;border:1px solid #fecaca;color:#991b1b}@media(max-width:800px){.layout{grid-template-columns:1fr}.side{position:static}.grid{grid-template-columns:1fr}.main{padding:16px}.msg{max-width:100%}}
.small{padding:8px 10px;border-radius:10px;font-size:12px}.actions{display:flex;flex-wrap:wrap;gap:6px}.table strong{font-weight:800}.table .error{font-size:12px;padding:8px}.btn[disabled]{opacity:.55;cursor:not-allowed}.nav a.active{background:rgba(255,255,255,.16)}

/* v1.4 voz + códigos */
.voice-composer{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:end}
.mic-btn{min-width:48px;font-size:18px}
.mic-btn.recording{box-shadow:0 0 0 3px rgba(220,38,38,.18);border-color:#dc2626}
.voice-status{margin-top:8px;font-size:13px}
.btn.mini{padding:6px 9px;font-size:12px;margin:2px}
@media(max-width:720px){.voice-composer{grid-template-columns:1fr auto}.voice-composer textarea{grid-column:1 / -1}}
/* v1.6 memoria de conversaciones + flujos */
.thread-panel{margin-top:14px;border-top:1px solid rgba(255,255,255,.14);padding-top:14px;display:flex;flex-direction:column;gap:10px}.btn.full{width:100%}.thread-title{font-size:12px;text-transform:uppercase;letter-spacing:.04em}.thread-list{display:flex;flex-direction:column;gap:6px;max-height:38vh;overflow:auto}.thread-item{border:0;text-align:left;border-radius:12px;padding:10px 11px;background:rgba(255,255,255,.06);color:#fff;cursor:pointer}.thread-item:hover,.thread-item.active{background:rgba(255,255,255,.16)}.thread-item strong{display:block;font-size:13px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thread-item span{display:block;font-size:11px;color:#cbd5e1;margin-top:4px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* v1.9 legibilidad Markdown + gestión de usuarios */
.msg.bot strong{font-weight:800;color:#0f172a}.msg.bot code{display:inline-block;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;padding:1px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.92em}.msg.bot{line-height:1.58}.msg.bot br+strong{display:inline-block;margin-top:8px}.user-cards{display:flex;flex-direction:column;gap:12px}.user-card{border:1px solid var(--border);border-radius:18px;background:#fff;overflow:hidden}.user-card summary{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;cursor:pointer}.user-card summary strong{display:block}.user-card summary small{display:block;color:var(--muted);margin-top:3px}.user-card[open] summary{border-bottom:1px solid var(--border);background:#fafafa}.user-edit-form{padding:16px}.user-edit-form label{font-weight:700;font-size:14px}.user-edit-form label input,.user-edit-form label select{margin-top:6px;font-weight:400}.checkline{display:flex;align-items:center;gap:8px;font-weight:700}.checkline input{width:auto}.full-row{grid-column:1/-1}.pill.ok{background:#dcfce7;color:#166534}.pill.off{background:#fee2e2;color:#991b1b}.actions.full-row{justify-content:flex-start}.btn.danger{background:#dc2626;color:#fff}
/* Actualización 1.11: Juanito + voz conversacional */
.logo-sub{font-size:14px;font-weight:700;opacity:.85}.hidden{display:none!important}.nav a.active{background:rgba(255,255,255,.14)}.voice-composer{display:grid;grid-template-columns:1fr auto auto auto;gap:10px;align-items:end}.mic-btn{min-width:96px;white-space:nowrap}.mic-btn.recording{box-shadow:0 0 0 3px rgba(220,38,38,.18);border:1px solid #dc2626}.voice-status{margin-top:8px;font-size:13px}.btn:disabled{opacity:.65;cursor:not-allowed}@media(max-width:720px){.voice-composer{grid-template-columns:1fr 1fr}.voice-composer textarea{grid-column:1 / -1}.voice-composer .btn{width:100%}}

/* Actualización 1.13: interfaz minimalista + branding */
:root{
  --bg:#f7f7f5;
  --panel:#ffffff;
  --text:#171717;
  --muted:#737373;
  --brand:#0a0a0a;
  --border:#e7e5e4;
  --soft:#f5f5f4;
}
body{background:var(--bg);color:var(--text)}
.layout{grid-template-columns:292px 1fr;background:var(--bg)}
.side{background:#ffffff;color:#171717;border-right:1px solid var(--border);padding:22px 18px;gap:18px;box-shadow:none}
.side .muted{color:#737373}.brand-block{min-height:56px;display:flex;align-items:center;margin-bottom:4px}.sidebar-logo-img{display:block;max-width:205px;max-height:58px;object-fit:contain}.logo{font-size:21px;font-weight:800;line-height:1.08;color:#111}.logo-sub{display:inline-block;margin-top:4px;color:#737373;opacity:1;font-size:13px;font-weight:700}.nav a{background:transparent;color:#262626;border-radius:12px;padding:10px 12px;font-weight:650}.nav a:hover{background:#f5f5f4}.nav a.active,.side .nav a.active{background:#eeeeec;color:#0a0a0a}.thread-panel{border-top:1px solid var(--border)}.thread-item{background:#fafaf9;color:#262626;border:1px solid #eeeeec}.thread-item:hover,.thread-item.active{background:#eeeeec;color:#111}.thread-item span{color:#78716c}.main{max-width:1040px;padding:28px 32px}.topbar{margin-bottom:14px}.topbar h1{margin:0;font-size:28px;letter-spacing:-.03em}.topbar p{margin:.35rem 0 0}.card{border-radius:24px;border:1px solid var(--border);box-shadow:0 14px 38px rgba(0,0,0,.035);background:#fff}.chatbox{height:calc(100vh - 265px);min-height:420px;padding:6px 4px 10px}.msg{border-radius:22px;line-height:1.62;font-size:15px}.msg.user{background:#111;color:#fff;border-bottom-right-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,.08)}.msg.bot{background:#fff;border:1px solid #eeeeec;border-bottom-left-radius:8px;box-shadow:none}.composer.voice-composer{display:grid;grid-template-columns:1fr 42px 54px;gap:8px;align-items:center;margin-top:14px;padding:8px;border:1px solid var(--border);border-radius:28px;background:#fff;box-shadow:0 10px 28px rgba(0,0,0,.045)}.composer textarea{min-height:42px;max-height:140px;resize:none;border:0;border-radius:20px;padding:10px 12px;background:transparent;outline:0;font-size:15px}.composer textarea:focus{box-shadow:none}.icon-btn{width:42px;height:42px;border:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .12s ease,background .12s ease,opacity .12s ease;background:transparent;color:#111;padding:0}.icon-btn:hover{background:#f5f5f4}.icon-btn:active{transform:scale(.96)}.icon-btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.send-circle{width:42px;height:42px;background:#0a0a0a;color:#fff;font-size:24px;font-weight:800;line-height:1}.send-circle:hover{background:#000}.send-circle span{transform:translateY(-1px)}.stop-btn{width:auto;min-width:54px;padding:0 14px;background:#fee2e2;color:#991b1b;font-weight:800;font-size:13px}.mic-btn{min-width:42px;font-size:0}.mic-btn.recording{background:#fee2e2;color:#991b1b;box-shadow:0 0 0 4px rgba(220,38,38,.10);border:0}.chat-disclaimer{margin:10px 0 0;text-align:center;color:#8a8a8a;font-size:12.5px}.voice-status{text-align:center;margin-top:5px;font-size:12px;color:#8a8a8a}.feedback{margin-left:4px}.feedback .btn{border-radius:999px;padding:8px 12px;font-size:12px}.btn{border-radius:999px;background:#111}.btn.secondary{background:#f0f0ee;color:#171717}.input,textarea,select{border-color:var(--border);border-radius:16px}.branding-settings{display:grid;grid-template-columns:220px 1fr;gap:18px;align-items:center}.logo-preview-box{min-height:96px;border:1px dashed var(--border);border-radius:18px;background:#fafaf9;display:grid;place-items:center;padding:14px}.logo-preview-box img{max-width:190px;max-height:68px;object-fit:contain}.login-wrap .brand-block{justify-content:center;margin-bottom:10px}.login-wrap .sidebar-logo-img{margin:auto;max-width:230px;max-height:72px}@media(max-width:800px){.layout{grid-template-columns:1fr}.side{border-right:0;border-bottom:1px solid var(--border)}.main{padding:16px}.chatbox{height:58vh;min-height:340px}.composer.voice-composer{grid-template-columns:1fr 42px 42px}.stop-btn{grid-column:auto}.branding-settings{grid-template-columns:1fr}.msg{max-width:100%}}

/* Actualización 1.14: corrección visual minimalista definitiva */
html, body {
  background: #ffffff !important;
  color: #111111 !important;
}
body {
  margin: 0 !important;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}
.layout {
  min-height: 100vh !important;
  display: grid !important;
  grid-template-columns: 280px minmax(0, 1fr) !important;
  background: #ffffff !important;
}
.side {
  background: #f8f8f7 !important;
  color: #111111 !important;
  border-right: 1px solid #ececea !important;
  box-shadow: none !important;
  padding: 20px 16px !important;
}
.side * { color: inherit; }
.side .muted,
.thread-item span,
.logo-sub {
  color: #777777 !important;
}
.brand-block {
  min-height: 54px !important;
  display: flex !important;
  align-items: center !important;
  margin-bottom: 8px !important;
}
.sidebar-logo-img {
  max-width: 210px !important;
  max-height: 56px !important;
  object-fit: contain !important;
}
.logo {
  color: #111111 !important;
  font-size: 21px !important;
  font-weight: 750 !important;
  letter-spacing: -0.02em !important;
}
.nav a {
  color: #262626 !important;
  background: transparent !important;
  display: block !important;
  border-radius: 12px !important;
  padding: 10px 12px !important;
  margin: 2px 0 !important;
  text-decoration: none !important;
  font-weight: 550 !important;
}
.nav a:hover,
.nav a.active,
.side .nav a.active {
  background: #eeeeec !important;
  color: #111111 !important;
}
.thread-panel {
  border-top: 1px solid #ececea !important;
}
.thread-item {
  width: 100% !important;
  border: 0 !important;
  background: transparent !important;
  color: #262626 !important;
  text-align: left !important;
  border-radius: 12px !important;
  padding: 10px 12px !important;
}
.thread-item:hover,
.thread-item.active {
  background: #eeeeec !important;
}
.main {
  background: #ffffff !important;
  max-width: 980px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 28px 30px !important;
}
.topbar h1 {
  color: #111111 !important;
  font-size: 27px !important;
  line-height: 1.1 !important;
  letter-spacing: -0.04em !important;
  margin: 0 !important;
}
.card {
  background: #ffffff !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}
.chatbox {
  height: calc(100vh - 245px) !important;
  min-height: 420px !important;
  overflow-y: auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  padding: 8px 2px 18px !important;
}
.msg {
  max-width: min(760px, 86%) !important;
  padding: 13px 16px !important;
  border-radius: 22px !important;
  line-height: 1.6 !important;
  font-size: 15px !important;
  white-space: pre-wrap !important;
}
.msg.user {
  align-self: flex-end !important;
  background: #111111 !important;
  color: #ffffff !important;
  border: 0 !important;
  border-bottom-right-radius: 6px !important;
}
.msg.bot {
  align-self: flex-start !important;
  background: #f7f7f6 !important;
  color: #171717 !important;
  border: 1px solid #eeeeec !important;
  border-bottom-left-radius: 6px !important;
  box-shadow: none !important;
}
.msg.bot strong { color: #111111 !important; font-weight: 750 !important; }
.chat-composer {
  width: 100% !important;
  display: flex !important;
  align-items: flex-end !important;
  gap: 10px !important;
  padding: 8px !important;
  border: 1px solid #ddddda !important;
  border-radius: 28px !important;
  background: #ffffff !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.035) !important;
  box-sizing: border-box !important;
}
.chat-composer textarea {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  min-height: 42px !important;
  max-height: 140px !important;
  resize: none !important;
  border: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  border-radius: 20px !important;
  padding: 11px 10px !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
  color: #111111 !important;
}
.chat-composer textarea::placeholder { color: #8a8a8a !important; }
.composer-actions {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.round-icon,
button.round-icon,
.chat-composer .round-icon {
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  max-width: 40px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
  line-height: 1 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  transition: background .12s ease, transform .12s ease, opacity .12s ease !important;
}
.round-icon svg,
.chat-composer button svg {
  width: 20px !important;
  height: 20px !important;
  display: block !important;
  flex: none !important;
}
.mic-btn,
button.mic-btn {
  background: transparent !important;
  color: #111111 !important;
}
.mic-btn:hover { background: #f0f0ee !important; }
.mic-btn.recording {
  background: #fee2e2 !important;
  color: #991b1b !important;
  box-shadow: 0 0 0 4px rgba(220, 38, 38, .10) !important;
}
.send-circle,
button.send-circle {
  background: #111111 !important;
  color: #ffffff !important;
}
.send-circle:hover { background: #000000 !important; }
.round-icon:active { transform: scale(.96) !important; }
.round-icon:disabled { opacity: .45 !important; cursor: not-allowed !important; }
.voice-stop,
button.voice-stop {
  height: 40px !important;
  min-width: 62px !important;
  padding: 0 13px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #fee2e2 !important;
  color: #991b1b !important;
  font-weight: 750 !important;
  cursor: pointer !important;
}
.chat-disclaimer {
  margin: 10px 0 0 !important;
  text-align: center !important;
  color: #8a8a8a !important;
  font-size: 12.5px !important;
}
.voice-status {
  margin: 5px 0 0 !important;
  text-align: center !important;
  color: #9a9a9a !important;
  font-size: 12px !important;
}
.feedback .btn {
  border-radius: 999px !important;
  padding: 8px 12px !important;
  font-size: 12px !important;
}
@media (max-width: 820px) {
  .layout { grid-template-columns: 1fr !important; }
  .side { border-right: 0 !important; border-bottom: 1px solid #ececea !important; position: static !important; }
  .main { max-width: none !important; padding: 18px 14px !important; }
  .chatbox { height: 58vh !important; min-height: 330px !important; }
  .msg { max-width: 100% !important; }
}

/* Actualización 1.15: responsive móvil con barra lateral flotante */
.mobile-menu-btn,
.mobile-close-btn,
.mobile-sidebar-overlay {
  display: none;
}

@media (max-width: 820px) {
  html, body {
    overflow-x: hidden !important;
  }
  .layout {
    display: block !important;
    grid-template-columns: none !important;
    min-height: 100vh !important;
    background: #ffffff !important;
  }
  .mobile-menu-btn {
    position: fixed !important;
    top: 14px !important;
    left: 14px !important;
    z-index: 950 !important;
    width: 42px !important;
    height: 42px !important;
    border: 1px solid #ececea !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.92) !important;
    color: #111111 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    box-shadow: 0 10px 28px rgba(0,0,0,.08) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
  }
  .mobile-menu-btn svg,
  .mobile-close-btn svg {
    width: 21px !important;
    height: 21px !important;
    display: block !important;
  }
  .mobile-close-btn {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    z-index: 1003 !important;
    width: 40px !important;
    height: 40px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: #f0f0ee !important;
    color: #111111 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
  }
  .mobile-sidebar-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 1000 !important;
    display: block !important;
    opacity: 0 !important;
    pointer-events: none !important;
    background: rgba(0,0,0,.24) !important;
    backdrop-filter: blur(2px) !important;
    -webkit-backdrop-filter: blur(2px) !important;
    transition: opacity .2s ease !important;
  }
  .side {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: min(86vw, 324px) !important;
    max-width: 324px !important;
    height: 100dvh !important;
    z-index: 1002 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 20px 16px 24px !important;
    padding-top: 68px !important;
    background: #ffffff !important;
    border-right: 1px solid #ececea !important;
    border-bottom: 0 !important;
    box-shadow: 18px 0 50px rgba(0,0,0,.14) !important;
    transform: translateX(-110%) !important;
    transition: transform .22s ease !important;
    will-change: transform !important;
  }
  body.sidebar-open .side {
    transform: translateX(0) !important;
  }
  body.sidebar-open .mobile-sidebar-overlay {
    opacity: 1 !important;
    pointer-events: auto !important;
  }
  body.sidebar-open .mobile-menu-btn {
    opacity: 0 !important;
    pointer-events: none !important;
  }
  .side .brand-block {
    margin-top: 0 !important;
  }
  .main {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 72px 14px 16px !important;
    background: #ffffff !important;
  }
  .topbar {
    margin-bottom: 10px !important;
    padding-left: 48px !important;
    min-height: 42px !important;
    display: flex !important;
    align-items: center !important;
  }
  .topbar h1 {
    font-size: 22px !important;
    line-height: 1.12 !important;
  }
  .topbar p {
    display: none !important;
  }
  .card {
    padding: 0 !important;
    border: 0 !important;
    box-shadow: none !important;
  }
  .chatbox {
    height: calc(100dvh - 230px) !important;
    min-height: 360px !important;
    padding: 8px 0 14px !important;
    gap: 12px !important;
  }
  .msg {
    max-width: 92% !important;
    padding: 12px 14px !important;
    font-size: 14.5px !important;
    line-height: 1.55 !important;
  }
  .msg.user {
    max-width: 88% !important;
  }
  .chat-composer {
    border-radius: 24px !important;
    padding: 7px !important;
    gap: 6px !important;
    position: sticky !important;
    bottom: 8px !important;
    z-index: 10 !important;
  }
  .chat-composer textarea {
    min-height: 40px !important;
    padding: 10px 8px !important;
    font-size: 15px !important;
  }
  .composer-actions {
    gap: 4px !important;
  }
  .round-icon,
  button.round-icon,
  .chat-composer .round-icon {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    max-width: 38px !important;
  }
  .round-icon svg,
  .chat-composer button svg {
    width: 19px !important;
    height: 19px !important;
  }
  .voice-stop,
  button.voice-stop {
    height: 38px !important;
    min-width: 54px !important;
    padding: 0 11px !important;
    font-size: 12px !important;
  }
  .chat-disclaimer {
    font-size: 11.5px !important;
    padding: 0 8px !important;
  }
  .voice-status {
    display: none !important;
  }
  .thread-panel {
    margin-top: 12px !important;
  }
}

/* Actualización 1.21: modo simple, revisión y panel de producción */
.admin-kpi-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
}
.admin-kpi {
  border: 1px solid #eeeeec !important;
  border-radius: 16px !important;
  padding: 14px !important;
  background: #fafaf9 !important;
}
.admin-kpi span {
  display: block !important;
  color: #777 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  margin-bottom: 6px !important;
}
.admin-kpi strong {
  font-size: 22px !important;
  letter-spacing: -0.03em !important;
}
.review-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.review-card {
  border: 1px solid #eeeeec !important;
  border-radius: 16px !important;
  background: #fff !important;
  overflow: hidden !important;
}
.review-card summary {
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 13px 15px !important;
}
.review-card summary small {
  display: block !important;
  color: #777 !important;
  margin-top: 4px !important;
  font-size: 12px !important;
}
.review-card[open] summary {
  border-bottom: 1px solid #eeeeec !important;
  background: #fafaf9 !important;
}
.review-body {
  padding: 15px !important;
  display: grid !important;
  gap: 10px !important;
}
.review-body h3 {
  margin: 4px 0 0 !important;
  font-size: 14px !important;
}
.review-body p {
  margin: 0 !important;
  line-height: 1.55 !important;
  color: #333 !important;
}
.pill.pending {
  background: #fef3c7 !important;
  color: #92400e !important;
}
.pill.reviewed {
  background: #dcfce7 !important;
  color: #166534 !important;
}
@media (max-width: 820px) {
  .admin-kpi-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .review-card summary {
    align-items: flex-start !important;
  }
}

/* Actualización 1.20: planes, límites y métricas */
.version-pill {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 30px !important;
  padding: 5px 10px !important;
  border-radius: 999px !important;
  background: #f0f0ee !important;
  color: #555 !important;
  font-size: 12px !important;
  font-weight: 750 !important;
  white-space: nowrap !important;
}
.table-wrap {
  width: 100% !important;
  overflow-x: auto !important;
}
.usage-table th,
.usage-table td {
  min-width: 110px !important;
}
.store-plan-form {
  display: grid !important;
  grid-template-columns: 92px 110px minmax(150px, 1fr) auto !important;
  gap: 8px !important;
  align-items: center !important;
  min-width: 520px !important;
}
.store-plan-form .input,
.store-plan-form select {
  padding: 8px 10px !important;
  border-radius: 12px !important;
  font-size: 13px !important;
}
.checkline.compact {
  font-size: 12px !important;
  font-weight: 650 !important;
}
.pill.near_limit {
  background: #fef3c7 !important;
  color: #92400e !important;
}
.pill.over_limit {
  background: #fee2e2 !important;
  color: #991b1b !important;
}
.pill.active {
  background: #dcfce7 !important;
  color: #166534 !important;
}
.plan-feature-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}
.plan-feature-card {
  border: 1px solid #eeeeec !important;
  border-radius: 16px !important;
  padding: 14px !important;
  background: #fafaf9 !important;
}
.plan-feature-card h3 {
  margin: 0 0 8px !important;
}
.plan-feature-card ul {
  margin: 0 !important;
  padding-left: 18px !important;
  color: #555 !important;
  line-height: 1.55 !important;
}
.price-table {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}
.price-row {
  display: grid !important;
  grid-template-columns: minmax(220px, 1.2fr) minmax(130px, .7fr) minmax(130px, .7fr) 90px !important;
  gap: 8px !important;
  align-items: center !important;
}
.price-head {
  color: #777 !important;
  font-size: 12px !important;
  font-weight: 750 !important;
  text-transform: uppercase !important;
}
.usage-chat-notice {
  max-width: min(760px, 86%) !important;
  align-self: center !important;
  font-size: 13px !important;
}
@media (max-width: 820px) {
  .topbar {
    gap: 8px !important;
    justify-content: space-between !important;
  }
  .version-pill {
    font-size: 11px !important;
    padding: 4px 8px !important;
  }
  .plan-feature-grid,
  .price-row {
    grid-template-columns: 1fr !important;
  }
}

/* Actualización 1.21.1: corrección estética minimalista */
.feedback {
  align-self: flex-start !important;
  margin: -4px 0 4px 6px !important;
  gap: 4px !important;
  opacity: .84 !important;
}
.feedback .btn,
.feedback .btn.secondary {
  background: transparent !important;
  color: #777 !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 5px 9px !important;
  font-size: 12px !important;
  font-weight: 560 !important;
  box-shadow: none !important;
}
.feedback .btn:hover,
.feedback .btn.secondary:hover {
  background: #f3f3f1 !important;
  color: #111 !important;
}
.admin-kpi-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  border-top: 1px solid #eeeeec !important;
  border-bottom: 1px solid #eeeeec !important;
}
.admin-kpi {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 14px 16px !important;
}
.admin-kpi + .admin-kpi {
  border-left: 1px solid #eeeeec !important;
}
.admin-kpi span {
  color: #8a8a8a !important;
  font-size: 11.5px !important;
  margin-bottom: 5px !important;
}
.admin-kpi strong {
  font-size: 19px !important;
  font-weight: 700 !important;
}
.review-list {
  gap: 0 !important;
  border-top: 1px solid #eeeeec !important;
}
.review-card {
  border: 0 !important;
  border-bottom: 1px solid #eeeeec !important;
  border-radius: 0 !important;
  background: transparent !important;
}
.review-card summary {
  padding: 12px 2px !important;
  border-radius: 0 !important;
}
.review-card[open] summary {
  background: transparent !important;
  border-bottom: 0 !important;
}
.review-body {
  padding: 2px 2px 16px !important;
}
.review-body h3 {
  color: #777 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.review-body p {
  max-width: 820px !important;
}
.pill.pending,
.pill.reviewed,
.pill.near_limit,
.pill.over_limit,
.pill.active,
.pill.ok,
.pill.off {
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 650 !important;
}
.table th {
  color: #777 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}
.table td {
  font-size: 13.5px !important;
}
@media (max-width: 820px) {
  .admin-kpi-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .admin-kpi:nth-child(odd) {
    border-left: 0 !important;
  }
  .admin-kpi:nth-child(n+3) {
    border-top: 1px solid #eeeeec !important;
  }
}
