:root {
  --marca: #eb4d2f;
  --marca-oscura: #c83c24;
  --texto: #231f20;
  --suave: #fff5f2;
  --borde: #f3d5ce;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: radial-gradient(circle at top left, #fff0ec 0, #ffffff 42%, #fff8f6 100%);
  color: var(--texto);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.contenedor {
  width: min(100%, 440px);
}

.logo {
  text-align: center;
  margin-bottom: 18px;
}

.logo-marca {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 76px;
  border-radius: 24px;
  background: var(--marca);
  color: white;
  font-size: 32px;
  font-weight: 900;
  box-shadow: 0 18px 40px rgba(235, 77, 47, .26);
}

.logo h1 {
  margin: 14px 0 4px;
  font-size: 30px;
  letter-spacing: -0.04em;
}

.logo p {
  margin: 0;
  color: #736c69;
}

.tarjeta {
  background: rgba(255,255,255,.92);
  border: 1px solid var(--borde);
  border-radius: 28px;
  padding: 28px;
  box-shadow: 0 24px 70px rgba(42, 27, 23, .10);
  backdrop-filter: blur(10px);
}

.titulo {
  margin: 0 0 8px;
  font-size: 24px;
  letter-spacing: -0.03em;
}

.subtitulo {
  margin: 0 0 22px;
  color: #746a66;
  line-height: 1.45;
}

.campo {
  margin-bottom: 14px;
}

label {
  display: block;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 7px;
}

input, select {
  width: 100%;
  border: 1px solid #efd0c8;
  background: #fff;
  border-radius: 16px;
  padding: 14px 15px;
  font-size: 15px;
  outline: none;
  transition: border .18s ease, box-shadow .18s ease;
}

input:focus, select:focus {
  border-color: var(--marca);
  box-shadow: 0 0 0 4px rgba(235, 77, 47, .12);
}

.fila {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.boton {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  border: 0;
  background: var(--marca);
  color: white;
  border-radius: 999px;
  padding: 15px 18px;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 14px 30px rgba(235, 77, 47, .24);
  transition: transform .15s ease, background .15s ease;
}

.boton:hover {
  transform: translateY(-1px);
  background: var(--marca-oscura);
}

.enlace {
  color: var(--marca);
  font-weight: 800;
  text-decoration: none;
}

.enlaces {
  margin-top: 18px;
  text-align: center;
  color: #6f6561;
  font-size: 14px;
  line-height: 1.8;
}

.alerta {
  border-radius: 16px;
  padding: 12px 14px;
  margin-bottom: 16px;
  font-size: 14px;
  line-height: 1.35;
}

.alerta.error {
  background: #fff0ee;
  border: 1px solid #ffbfaf;
  color: #9c2b18;
}

.alerta.ok {
  background: #f1fff7;
  border: 1px solid #b9efcf;
  color: #116b3a;
}

.codigo {
  overflow-wrap: anywhere;
  padding: 12px;
  background: var(--suave);
  border-radius: 14px;
  border: 1px solid var(--borde);
  font-size: 12px;
}

@media (max-width: 520px) {
  body { padding: 14px; }
  .tarjeta { padding: 22px; border-radius: 24px; }
  .fila { grid-template-columns: 1fr; }
}

.form-secundario { margin-top: 12px; }
.boton-secundario {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  border: 1px solid var(--marca);
  background: white;
  color: var(--marca);
  border-radius: 999px;
  padding: 13px 18px;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
}
.pie { margin-top: 16px; color: #746a66; font-size: 13px; line-height: 1.45; text-align: center; }

/* =========================================================
   PANEL DE CUENTA + MODO OSCURO
   ========================================================= */
.boton-tema {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 10;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid var(--borde);
  background: rgba(255,255,255,.85);
  color: var(--texto);
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(42, 27, 23, .08);
}

.contenedor-panel {
  width: min(100%, 980px);
}

.logo-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  text-align: left;
}

.logo-panel .logo-marca {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  font-size: 26px;
}

.logo-panel h1 { margin: 0; }
.logo-panel p { margin-top: 2px; }

.nav-panel {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 16px 0 18px;
}

.nav-panel a {
  text-decoration: none;
  color: var(--marca);
  font-weight: 800;
  font-size: 14px;
  background: rgba(255,255,255,.8);
  border: 1px solid var(--borde);
  border-radius: 999px;
  padding: 10px 14px;
}

.tarjeta-panel {
  padding: 30px;
}

.cabecera-panel {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.estado-cuenta, .pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  background: var(--suave);
  color: var(--marca);
  border: 1px solid var(--borde);
}

.grid-panel {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 18px 0 24px;
}

.mini-card {
  border: 1px solid var(--borde);
  background: rgba(255, 245, 242, .55);
  border-radius: 20px;
  padding: 16px;
  min-height: 110px;
}

.mini-label {
  display: block;
  color: #756a66;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.mini-card strong {
  display: block;
  overflow-wrap: anywhere;
  font-size: 16px;
}

.mini-card small,
.fila-panel small,
.subtexto {
  display: block;
  margin-top: 6px;
  color: #756a66;
}

.seccion-titulo {
  font-size: 18px;
  margin: 18px 0 12px;
}

.lista-panel {
  display: grid;
  gap: 10px;
}

.fila-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border: 1px solid var(--borde);
  border-radius: 18px;
  padding: 14px;
  background: rgba(255,255,255,.58);
}

.bloque-seguridad {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 18px;
  align-items: center;
  border: 1px solid var(--borde);
  background: rgba(255, 245, 242, .55);
  border-radius: 22px;
  padding: 18px;
}

.bloque-seguridad h3 { margin: 0 0 6px; }
.bloque-seguridad p { margin: 0; color: #756a66; line-height: 1.45; }

.separador {
  border: 0;
  border-top: 1px solid var(--borde);
  margin: 24px 0;
}

.tema-oscuro {
  --texto: #fff6f3;
  --suave: #301a15;
  --borde: #5c2c23;
}

.tema-oscuro body {
  background: radial-gradient(circle at top left, #391912 0, #120d0c 44%, #21100d 100%);
  color: var(--texto);
}

.tema-oscuro .tarjeta,
.tema-oscuro .nav-panel a,
.tema-oscuro .boton-tema {
  background: rgba(31, 21, 19, .92);
  border-color: var(--borde);
  color: var(--texto);
}

.tema-oscuro input,
.tema-oscuro select {
  background: #160f0e;
  color: var(--texto);
  border-color: var(--borde);
}

.tema-oscuro .mini-card,
.tema-oscuro .fila-panel,
.tema-oscuro .bloque-seguridad,
.tema-oscuro .codigo {
  background: rgba(48, 26, 21, .65);
  border-color: var(--borde);
}

.tema-oscuro .subtitulo,
.tema-oscuro .logo p,
.tema-oscuro .mini-label,
.tema-oscuro .mini-card small,
.tema-oscuro .fila-panel small,
.tema-oscuro .subtexto,
.tema-oscuro .bloque-seguridad p {
  color: #d7bdb6;
}

@media (max-width: 760px) {
  .grid-panel { grid-template-columns: 1fr; }
  .cabecera-panel { flex-direction: column; }
  .bloque-seguridad { grid-template-columns: 1fr; }
}

/* =========================================================
   VILLAR.DO DEVELOPER
   ========================================================= */
.boton-mini {
  width: auto;
  padding: 9px 13px;
  font-size: 13px;
  box-shadow: none;
  text-decoration: none;
}
.form-inline {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}
.acciones-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  justify-content: flex-end;
}
.acciones-inline form { margin: 0; }
.margen-top { margin-top: 12px; }
.checks-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 18px;
}
.check-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px;
  border: 1px solid var(--borde);
  background: rgba(255, 245, 242, .45);
  border-radius: 16px;
  padding: 12px;
  margin: 0;
}
.check-card input { width: auto; margin-top: 3px; }
.check-card span { font-weight: 900; }
.check-card small {
  grid-column: 2;
  color: #756a66;
  line-height: 1.35;
}
.codigo-grande {
  font-size: 15px;
  padding: 16px;
  margin: 14px 0;
}
.tema-oscuro .check-card { background: rgba(48, 26, 21, .65); border-color: var(--borde); }
.tema-oscuro .check-card small { color: #d7bdb6; }
@media (max-width: 760px) {
  .checks-grid, .form-inline { grid-template-columns: 1fr; }
  .acciones-inline { justify-content: flex-start; }
}

/* =========================================================
   VILLAR.DO DEVELOPER - SIDEBAR SIMPLE APP KEYS
   ========================================================= */
.body-developer {
  align-items: stretch;
  justify-content: stretch;
  padding: 0;
  overflow-x: hidden;
}

.developer-layout {
  width: 100%;
  min-height: 100vh;
  display: grid;
  grid-template-columns: 292px minmax(0, 1fr);
}

.developer-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 22px;
  border-right: 1px solid var(--borde);
  background: rgba(255, 255, 255, .72);
  backdrop-filter: blur(16px);
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.developer-brand {
  display: flex;
  align-items: center;
  gap: 13px;
  padding: 8px 4px 18px;
  border-bottom: 1px solid var(--borde);
}

.developer-brand .logo-marca {
  width: 52px;
  height: 52px;
  border-radius: 17px;
  font-size: 24px;
}

.developer-brand h1 {
  margin: 0;
  font-size: 24px;
  letter-spacing: -0.04em;
}

.developer-brand p {
  margin: 1px 0 0;
  color: #746a66;
  font-weight: 800;
}

.developer-menu {
  display: grid;
  gap: 8px;
}

.developer-menu a {
  display: flex;
  align-items: center;
  min-height: 46px;
  padding: 12px 14px;
  border-radius: 16px;
  color: var(--texto);
  text-decoration: none;
  font-weight: 850;
  border: 1px solid transparent;
}

.developer-menu a:hover,
.developer-menu a.activo {
  color: var(--marca);
  background: var(--suave);
  border-color: var(--borde);
}

.developer-sidebar-footer {
  margin-top: auto;
  display: grid;
  gap: 7px;
  padding: 16px;
  border: 1px solid var(--borde);
  border-radius: 22px;
  background: rgba(255, 245, 242, .58);
}

.developer-sidebar-footer strong,
.developer-sidebar-footer span {
  overflow-wrap: anywhere;
}

.developer-sidebar-footer span {
  color: #746a66;
  font-size: 13px;
}

.sidebar-pill {
  justify-self: start;
  margin-top: 4px;
}

.developer-salir {
  margin-top: 8px;
  color: var(--marca);
  font-weight: 900;
  text-decoration: none;
}

.developer-main {
  min-width: 0;
  padding: 34px;
}

.developer-content {
  width: min(100%, 1080px);
  margin: 0 auto;
}

.hero-developer {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, .8fr);
  gap: 18px;
  align-items: stretch;
  margin-bottom: 18px;
}

.hero-card {
  border: 1px solid var(--borde);
  border-radius: 26px;
  padding: 22px;
  background: linear-gradient(135deg, rgba(255,245,242,.9), rgba(255,255,255,.68));
}

.hero-card h2 {
  margin: 0 0 8px;
  font-size: 32px;
  letter-spacing: -0.05em;
}

.hero-card p {
  margin: 0;
  color: #746a66;
  line-height: 1.5;
}

.key-form-simple {
  display: grid;
  gap: 14px;
}

.form-card {
  border: 1px solid var(--borde);
  border-radius: 24px;
  padding: 18px;
  background: rgba(255,255,255,.56);
}

.key-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.key-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--borde);
  border-radius: 20px;
  padding: 15px;
  background: rgba(255,255,255,.58);
}

.key-row strong,
.key-row small {
  display: block;
  overflow-wrap: anywhere;
}

.key-row small {
  margin-top: 6px;
  color: #756a66;
}

.key-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.key-actions form { margin: 0; }

.key-secret-box {
  margin: 16px 0;
  border: 1px solid var(--borde);
  border-radius: 24px;
  padding: 18px;
  background: var(--suave);
}

.key-secret-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #756a66;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.key-secret {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 14px;
  overflow-wrap: anywhere;
  line-height: 1.45;
}

.key-created-actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 14px;
}

.estado-activa { color: #118247; }
.estado-suspendida { color: #9d6500; }
.estado-revocada { color: #9c2b18; }

.tema-oscuro .developer-sidebar {
  background: rgba(24, 14, 12, .78);
  border-color: var(--borde);
}

.tema-oscuro .developer-brand p,
.tema-oscuro .developer-sidebar-footer span,
.tema-oscuro .hero-card p,
.tema-oscuro .key-row small,
.tema-oscuro .key-secret-label {
  color: #d7bdb6;
}

.tema-oscuro .developer-sidebar-footer,
.tema-oscuro .hero-card,
.tema-oscuro .form-card,
.tema-oscuro .key-row,
.tema-oscuro .key-secret-box {
  background: rgba(48, 26, 21, .65);
  border-color: var(--borde);
}

@media (max-width: 920px) {
  .developer-layout { grid-template-columns: 1fr; }
  .developer-sidebar {
    position: relative;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid var(--borde);
  }
  .developer-main { padding: 18px; }
  .hero-developer, .key-grid { grid-template-columns: 1fr; }
  .key-created-actions { grid-template-columns: 1fr; }
}

/* =========================================================
   DEVELOPER IAM + SCOPES
   ========================================================= */
.key-row-vertical {
  align-items: stretch;
  flex-direction: column;
  gap: 16px;
}

.key-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.scopes-box {
  border: 1px solid var(--borde);
  background: rgba(255,255,255,.55);
  border-radius: 20px;
  padding: 16px;
}

.scopes-header,
.iam-resource-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.checks-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin: 12px 0 20px;
}

.checks-grid.compact {
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  margin-bottom: 0;
}

.check-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  border: 1px solid var(--borde);
  border-radius: 16px;
  padding: 12px;
  background: rgba(255,255,255,.72);
  cursor: pointer;
  min-height: 76px;
}

.check-card.tiny {
  min-height: auto;
  padding: 10px;
}

.check-card input {
  width: auto;
  margin: 0 0 3px;
}

.check-card span {
  font-weight: 800;
  font-size: 13px;
  color: var(--texto);
}

.check-card small,
.iam-resource-head small,
.small-bottom {
  color: #766b67;
  font-size: 12px;
}

.iam-resource-card {
  border: 1px solid var(--borde);
  background: rgba(255, 245, 242, .56);
  border-radius: 20px;
  padding: 16px;
  margin-bottom: 14px;
}

.iam-resource-card.soft {
  background: rgba(255,255,255,.55);
}

.estado-activa { color: #0f8a47; font-weight: 800; }
.estado-suspendida,
.estado-desactivada { color: #b66a00; font-weight: 800; }
.estado-revocada { color: #a72818; font-weight: 800; }
.estado-expirada { color: #6f6561; font-weight: 800; }

html.tema-oscuro .scopes-box,
html.tema-oscuro .check-card,
html.tema-oscuro .iam-resource-card,
html.tema-oscuro .iam-resource-card.soft {
  background: rgba(25, 15, 13, .74);
  border-color: rgba(235, 77, 47, .30);
}

html.tema-oscuro .check-card small,
html.tema-oscuro .iam-resource-head small,
html.tema-oscuro .small-bottom {
  color: #cbb9b3;
}

/* =========================================================
   DEVELOPER FIX - PERMISOS EN MODAL FLOTANTE
   ========================================================= */
.key-row-simple {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.key-scope-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.key-scope-pills span {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(235, 77, 47, .28);
  background: rgba(235, 77, 47, .08);
  color: var(--texto);
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 11px;
  font-weight: 800;
}

.modal-bloqueado {
  overflow: hidden;
}

.modal-flotante {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}

.modal-flotante.abierta {
  display: block;
}

.modal-fondo {
  position: absolute;
  inset: 0;
  background: rgba(13, 6, 4, .62);
  backdrop-filter: blur(8px);
}

.modal-caja {
  position: relative;
  width: min(720px, calc(100vw - 32px));
  max-height: calc(100vh - 56px);
  overflow: auto;
  margin: 28px auto;
  border: 1px solid rgba(235, 77, 47, .32);
  border-radius: 28px;
  padding: 22px;
  background: rgba(255, 250, 248, .96);
  box-shadow: 0 24px 70px rgba(40, 14, 8, .28);
}

.modal-caja-grande {
  width: min(980px, calc(100vw - 32px));
}

.modal-cabecera {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 18px;
}

.modal-cabecera h3 {
  margin: 0 0 5px;
  font-size: 24px;
}

.modal-cabecera p {
  margin: 0;
  color: #756a66;
  font-size: 13px;
  font-weight: 700;
}

.modal-cerrar {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid var(--borde);
  background: rgba(255,255,255,.76);
  color: var(--texto);
  font-size: 26px;
  font-weight: 800;
  cursor: pointer;
}

.modal-scopes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 12px;
}

.scope-card-modal em {
  color: #857671;
  font-size: 11px;
  font-style: normal;
  line-height: 1.35;
}

.modal-acciones {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--borde);
}

html.tema-oscuro .modal-fondo {
  background: rgba(5, 2, 1, .74);
}

html.tema-oscuro .modal-caja {
  background: rgba(31, 17, 14, .97);
  border-color: rgba(235, 77, 47, .34);
  box-shadow: 0 26px 80px rgba(0, 0, 0, .52);
}

html.tema-oscuro .modal-cabecera p,
html.tema-oscuro .scope-card-modal em {
  color: #d1b7af;
}

html.tema-oscuro .modal-cerrar {
  background: rgba(54, 29, 23, .88);
  border-color: rgba(235, 77, 47, .28);
  color: #fff8f6;
}

html.tema-oscuro .key-scope-pills span {
  background: rgba(235, 77, 47, .12);
  color: #fff8f6;
}

@media (max-width: 720px) {
  .key-row-simple {
    grid-template-columns: 1fr;
  }
  .key-actions {
    justify-content: flex-start;
  }
  .modal-acciones {
    flex-direction: column-reverse;
  }
}

/* =========================================================
   Developer IAM refinado: invitaciones + permisos limpios
   ========================================================= */
.iam-form { display: grid; gap: 18px; }
.iam-step-card {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  padding: 18px;
  border: 1px solid var(--borde);
  border-radius: 24px;
  background: rgba(255,255,255,.62);
  box-shadow: 0 16px 50px rgba(235,77,47,.08);
}
.iam-step-number {
  width: 36px;
  height: 36px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: var(--marca);
  color: #fff;
  font-weight: 900;
}
.iam-step-body h3 { margin: 0 0 6px; }
.iam-step-body p { margin: 0 0 14px; color: #736c69; }
.rol-preview {
  margin-top: 14px;
  padding: 14px;
  border-radius: 20px;
  border: 1px dashed var(--borde);
  background: rgba(235,77,47,.055);
}
.rol-preview small { display: block; margin-top: 4px; color: #736c69; }
.rol-preview-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.rol-preview-pills span,
.pill.warning {
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(235,77,47,.12);
  color: var(--marca);
  border: 1px solid rgba(235,77,47,.25);
  font-size: 12px;
  font-weight: 800;
}
.iam-section-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}
.switch-line {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 999px;
  border: 1px solid var(--borde);
  cursor: pointer;
  font-weight: 800;
}
.switch-line input { width: auto; }
.permiso-panel { margin-top: 14px; }
.permission-grid.pretty,
.permission-grid.compact-pretty {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}
.permission-grid.compact-pretty { grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); }
.permission-tile,
.permission-chip-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--borde);
  border-radius: 18px;
  background: rgba(255,255,255,.72);
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.permission-tile:hover,
.permission-chip-card:hover { transform: translateY(-1px); border-color: rgba(235,77,47,.45); }
.permission-tile input,
.permission-chip-card input { display: none; }
.permission-icon {
  width: 25px;
  height: 25px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  border: 1px solid var(--borde);
  color: transparent;
  background: rgba(255,255,255,.75);
  flex: 0 0 auto;
}
.permission-tile input:checked + .permission-icon,
.permission-chip-card input:checked + span {
  background: var(--marca);
  color: #fff;
  border-color: var(--marca);
}
.permission-main { display: grid; gap: 2px; }
.permission-main strong { font-size: 13px; }
.permission-main small { color: #736c69; font-size: 12px; }
.permission-chip-card span {
  display: block;
  width: 100%;
  text-align: center;
  padding: 9px 10px;
  border-radius: 999px;
  border: 1px solid var(--borde);
  font-size: 12px;
  font-weight: 900;
}
.app-access-list,
.key-access-list { display: grid; gap: 12px; }
.access-card,
.key-access-card {
  border: 1px solid var(--borde);
  border-radius: 22px;
  padding: 14px;
  background: rgba(255,255,255,.58);
}
.key-access-card { border-radius: 18px; background: rgba(235,77,47,.035); }
.access-card-head { display: flex; justify-content: space-between; align-items: center; }
.access-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  width: 100%;
}
.access-toggle input { display: none; }
.fake-toggle {
  width: 44px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid var(--borde);
  background: rgba(120,120,120,.18);
  position: relative;
  flex: 0 0 auto;
}
.fake-toggle:after {
  content: '';
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  top: 3px;
  left: 4px;
  box-shadow: 0 4px 10px rgba(0,0,0,.15);
  transition: transform .18s ease;
}
.access-toggle input:checked + .fake-toggle { background: var(--marca); border-color: var(--marca); }
.access-toggle input:checked + .fake-toggle:after { transform: translateX(17px); }
.access-toggle strong { display: block; }
.access-toggle small { display: block; color: #736c69; margin-top: 2px; }
.access-details { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--borde); }
.access-details.nested { margin-top: 12px; }
.mini-alert { margin-top: 10px; }
.collaborator-row { align-items: center; }
html.tema-oscuro .iam-step-card,
html.tema-oscuro .permission-tile,
html.tema-oscuro .permission-chip-card,
html.tema-oscuro .access-card,
html.tema-oscuro .key-access-card,
html.tema-oscuro .rol-preview {
  background: rgba(48,26,21,.62);
}
html.tema-oscuro .permission-icon { background: rgba(255,255,255,.08); }
@media (max-width: 760px) {
  .iam-step-card { grid-template-columns: 1fr; }
  .iam-section-head { align-items: flex-start; flex-direction: column; }
}


/* =========================================================
   Developer IAM CSS fix: personalizado automático + estados activos
   ========================================================= */
.switch-line-soft {
  opacity: .92;
}
.switch-line-soft input:checked + span,
.switch-line input:checked + span {
  color: var(--marca);
}
.access-card.activo,
.key-access-card.activo {
  border-color: rgba(235, 77, 47, .62);
  background: linear-gradient(135deg, rgba(235, 77, 47, .13), rgba(255, 255, 255, .76));
  box-shadow: 0 14px 38px rgba(235, 77, 47, .12);
}
.key-access-card.activo {
  background: linear-gradient(135deg, rgba(235, 77, 47, .16), rgba(255, 255, 255, .68));
}
.access-card.activo .access-toggle > span:last-child strong,
.key-access-card.activo .access-toggle > span:last-child strong {
  color: var(--marca);
}
.access-toggle input:checked + .fake-toggle {
  background: var(--marca) !important;
  border-color: var(--marca) !important;
  box-shadow: 0 0 0 4px rgba(235, 77, 47, .12);
}
.access-toggle input:checked + .fake-toggle:after {
  transform: translateX(17px);
}
html.tema-oscuro .access-card.activo,
html.tema-oscuro .key-access-card.activo {
  background: linear-gradient(135deg, rgba(235, 77, 47, .24), rgba(48, 26, 21, .82));
  border-color: rgba(235, 77, 47, .62);
}
html.tema-oscuro .access-toggle input:checked + .fake-toggle {
  background: var(--marca) !important;
}


/* =========================================================
   Developer IAM toggle hard fix
   Fuerza estado naranja aunque el navegador no aplique :checked + span
   ========================================================= */
.access-toggle .fake-toggle.encendido,
.access-toggle input:checked + .fake-toggle,
.access-card.activo .access-toggle > .fake-toggle,
.key-access-card.activo .access-toggle > .fake-toggle {
  background: #eb4d2f !important;
  border-color: #eb4d2f !important;
  box-shadow: 0 0 0 4px rgba(235, 77, 47, .16), 0 10px 22px rgba(235, 77, 47, .22) !important;
}

.access-toggle .fake-toggle.encendido::after,
.access-toggle input:checked + .fake-toggle::after,
.access-card.activo .access-toggle > .fake-toggle::after,
.key-access-card.activo .access-toggle > .fake-toggle::after {
  transform: translateX(17px) !important;
  background: #ffffff !important;
}

.access-card.activo,
.key-access-card.activo {
  background: linear-gradient(135deg, rgba(235, 77, 47, .18), rgba(235, 77, 47, .08)) !important;
  border-color: rgba(235, 77, 47, .75) !important;
}

html.tema-oscuro .access-card.activo,
html.tema-oscuro .key-access-card.activo {
  background: linear-gradient(135deg, rgba(235, 77, 47, .28), rgba(24, 12, 10, .88)) !important;
  border-color: rgba(235, 77, 47, .78) !important;
}

/* =========================================================
   Developer IAM: quitar switch de permisos globales
   ========================================================= */
.permiso-panel-global {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(235, 77, 47, .18);
}
.mini-section-title {
  font-weight: 900;
  color: var(--texto);
  margin-bottom: 6px;
  letter-spacing: -.01em;
}
html.tema-oscuro .permiso-panel-global {
  border-top-color: rgba(235, 77, 47, .32);
}

/* =========================================================
   Developer IAM simplificado por rol
   ========================================================= */
.iam-clean-form .compact-role-card {
  position: relative;
}
.role-explainer {
  margin-top: 14px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(235, 77, 47, .24);
  background: linear-gradient(135deg, rgba(235,77,47,.10), rgba(255,255,255,.62));
}
.role-explainer-icon {
  width: 30px;
  height: 30px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #eb4d2f;
  color: white;
  font-weight: 900;
  flex: 0 0 auto;
}
.role-explainer strong { display: block; margin-bottom: 3px; }
.role-explainer p { margin: 0 !important; }
.rol-preview.simplified {
  background: rgba(235,77,47,.045);
  border-style: solid;
}
.rol-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.rol-preview-pills.collapsed {
  max-height: 0;
  overflow: hidden;
  margin-top: 0;
}
.boton-secundario.ghost {
  background: transparent;
}
.role-only-info {
  background: linear-gradient(135deg, rgba(235,77,47,.075), rgba(255,255,255,.58));
}
.clean-head {
  margin-bottom: 14px;
}
.row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}
.clean-access-card,
.clean-key-card {
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.clean-access-card:hover,
.clean-key-card:hover {
  transform: translateY(-1px);
}
.key-row-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.key-help-chip {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .02em;
  color: #736c69;
  border: 1px solid var(--borde);
  border-radius: 999px;
  padding: 6px 9px;
  background: rgba(255,255,255,.52);
  white-space: nowrap;
}
.key-access-card.activo .key-help-chip,
.access-card.activo .key-help-chip {
  color: #eb4d2f;
  border-color: rgba(235,77,47,.4);
  background: rgba(235,77,47,.12);
}
.key-permission-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(235,77,47,.07);
  border: 1px solid rgba(235,77,47,.12);
}
.key-permission-head strong,
.key-permission-head small {
  display: block;
}
.key-permission-head small {
  color: #736c69;
  margin-top: 2px;
}
.clean-chip input:checked + span,
.clean-check input:checked + .permission-icon {
  background: #eb4d2f !important;
  border-color: #eb4d2f !important;
  color: white !important;
  box-shadow: 0 8px 18px rgba(235,77,47,.18);
}
.clean-chip:has(input:checked),
.clean-check:has(input:checked) {
  border-color: rgba(235,77,47,.48);
  background: rgba(235,77,47,.08);
}
.permission-grid.key-permission-grid {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}
html.tema-oscuro .role-explainer,
html.tema-oscuro .role-only-info,
html.tema-oscuro .key-permission-head {
  background: linear-gradient(135deg, rgba(235,77,47,.18), rgba(48,26,21,.62));
}
html.tema-oscuro .key-help-chip {
  background: rgba(255,255,255,.06);
}
@media (max-width: 760px) {
  .rol-preview-head,
  .key-row-main,
  .key-permission-head,
  .clean-head {
    align-items: flex-start;
    flex-direction: column;
  }
  .row-actions {
    justify-content: flex-start;
  }
}

/* =========================================================
   Developer cuenta separada y colaboradores
   ========================================================= */
.developer-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 22px;
  padding: 22px;
}
.developer-sidebar {
  position: sticky;
  top: 22px;
  height: calc(100vh - 44px);
  border: 1px solid rgba(235,77,47,.28);
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(16px);
  border-radius: 28px;
  padding: 20px;
  box-shadow: 0 20px 60px rgba(235,77,47,.12);
  display: flex;
  flex-direction: column;
}
.tema-oscuro .developer-sidebar {
  background: rgba(28, 12, 10, .88);
  border-color: rgba(235,77,47,.38);
}
.dev-brand { display:flex; align-items:center; gap:12px; margin-bottom:22px; }
.dev-brand h1 { margin:0; font-size:22px; }
.dev-brand p { margin:0; opacity:.7; font-weight:700; }
.dev-menu { display:flex; flex-direction:column; gap:10px; }
.dev-menu a, .dev-sidebar-footer a {
  text-decoration:none;
  color: inherit;
  padding: 12px 14px;
  border-radius: 16px;
  font-weight: 800;
  border: 1px solid transparent;
}
.dev-menu a:hover, .dev-menu a.activo {
  color:#fff;
  background:#eb4d2f;
  border-color:#eb4d2f;
  box-shadow:0 12px 28px rgba(235,77,47,.28);
}
.dev-sidebar-footer { margin-top:auto; display:flex; flex-direction:column; gap:8px; }
.dev-sidebar-footer a { opacity:.78; border-color:rgba(235,77,47,.18); }
.developer-content { min-height: calc(100vh - 44px); padding: 28px; overflow: visible; }
.grid-dos { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:18px; }
.separador { border:0; border-top:1px solid rgba(235,77,47,.22); margin:22px 0; }
.boton-peligro {
  border: 1px solid rgba(190, 30, 30, .35);
  background: rgba(190, 30, 30, .1);
  color: #be1e1e;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor:pointer;
}
.boton-peligro:hover { background:#be1e1e; color:#fff; }
.tema-oscuro .boton-peligro { color:#ffb4ac; border-color:rgba(255,180,172,.35); }
.tema-oscuro .boton-peligro:hover { background:#eb4d2f; color:#fff; }
.mini { font-size: 13px; }
@media (max-width: 900px) {
  .developer-shell { grid-template-columns: 1fr; padding: 12px; }
  .developer-sidebar { position:relative; height:auto; top:auto; }
  .grid-dos { grid-template-columns:1fr; }
}

/* =========================================================
   FIX FINAL - Sidebar Developer fijo
   Mantiene el menu lateral anclado mientras se desplaza el contenido.
   ========================================================= */
body:has(.developer-shell) {
  overflow-x: hidden;
}

.developer-shell {
  display: block !important;
  min-height: 100vh !important;
  padding: 0 !important;
}

.developer-sidebar {
  position: fixed !important;
  left: 48px !important;
  top: 44px !important;
  bottom: 44px !important;
  width: 280px !important;
  height: auto !important;
  z-index: 20 !important;
  overflow-y: auto !important;
  scrollbar-width: thin;
}

.developer-content {
  margin-left: 374px !important;
  width: calc(100% - 430px) !important;
  min-height: calc(100vh - 88px) !important;
  margin-top: 44px !important;
  margin-bottom: 44px !important;
  padding: 28px !important;
}

.boton-tema {
  position: fixed !important;
  top: 22px !important;
  right: 22px !important;
  z-index: 60 !important;
}

@media (max-width: 1100px) {
  .developer-sidebar {
    left: 18px !important;
    top: 18px !important;
    bottom: 18px !important;
    width: 250px !important;
  }

  .developer-content {
    margin-left: 298px !important;
    width: calc(100% - 330px) !important;
    margin-top: 18px !important;
    margin-bottom: 18px !important;
  }
}

@media (max-width: 900px) {
  .developer-shell {
    display: grid !important;
    grid-template-columns: 1fr !important;
    padding: 12px !important;
  }

  .developer-sidebar {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: auto !important;
    height: auto !important;
  }

  .developer-content {
    margin-left: 0 !important;
    width: auto !important;
    margin-top: 12px !important;
    margin-bottom: 12px !important;
  }
}

/* Developer: acciones de estado de App Key */
.app-state-panel {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto;
  gap: 16px;
  align-items: stretch;
}
.app-state-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}
.boton-peligro {
  border: 1px solid rgba(191, 55, 39, .45);
  background: rgba(235, 77, 47, .08);
  color: #bf3727;
  border-radius: 999px;
  font-weight: 900;
  cursor: pointer;
}
.boton-peligro:hover {
  background: rgba(235, 77, 47, .16);
}
.estado-archivada {
  color: #a36500;
}
.estado-eliminada {
  color: #b42318;
}
body.modo-oscuro .boton-peligro {
  color: #ffb3a5;
  border-color: rgba(235, 77, 47, .55);
  background: rgba(235, 77, 47, .12);
}
@media (max-width: 900px) {
  .app-state-panel { grid-template-columns: 1fr; }
  .app-state-actions { justify-content: flex-start; }
}

/* =========================================================
   FIX Developer Apps: ancho completo y tarjetas claras
   ========================================================= */
.developer-content:has(.developer-apps-page) {
  max-width: none !important;
  width: calc(100% - 430px) !important;
}

.developer-apps-page {
  width: min(100%, 980px) !important;
  margin: 0 auto !important;
  display: grid;
  gap: 16px;
}

.apps-header-card {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
  border: 1px solid var(--borde);
  border-radius: 26px;
  padding: 22px;
  background: linear-gradient(135deg, rgba(255,245,242,.88), rgba(255,255,255,.72));
  box-shadow: 0 18px 44px rgba(235,77,47,.08);
}

.apps-header-card .titulo,
.apps-header-card .subtitulo {
  margin-left: 0 !important;
}

.eyebrow {
  margin: 0 0 8px;
  color: var(--marca);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.apps-new-button {
  width: auto !important;
  min-width: 126px;
  white-space: nowrap;
  padding: 13px 18px !important;
}

.apps-grid-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 12px;
  width: 100%;
}

.app-list-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  border: 1px solid var(--borde);
  border-radius: 22px;
  padding: 14px;
  background: rgba(255,255,255,.64);
  box-shadow: 0 12px 32px rgba(235,77,47,.06);
}

.app-list-card.estado-archivada,
.app-list-card.estado-eliminada,
.app-list-card.estado-desactivada,
.app-list-card.estado-suspendida {
  opacity: .72;
}

.app-card-main {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 0;
}

.app-icon {
  width: 44px;
  height: 44px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  color: #fff;
  background: var(--marca);
  font-weight: 950;
  box-shadow: 0 14px 32px rgba(235,77,47,.24);
}

.app-card-main strong,
.app-card-main small {
  display: block;
  overflow-wrap: anywhere;
}

.app-card-main small {
  margin-top: 5px;
  color: #756a66;
  line-height: 1.35;
}

.apps-empty-card {
  grid-column: 1 / -1;
  border: 1px solid var(--borde);
  border-radius: 24px;
  padding: 22px;
  background: rgba(255,245,242,.58);
}

.apps-empty-card p {
  margin: 6px 0 14px;
  color: #756a66;
}

.tema-oscuro .apps-header-card {
  background: linear-gradient(135deg, rgba(48,26,21,.9), rgba(28,12,10,.78));
}
.tema-oscuro .app-list-card,
.tema-oscuro .apps-empty-card {
  background: rgba(28,12,10,.72);
}
.tema-oscuro .app-card-main small,
.tema-oscuro .apps-empty-card p {
  color: #d7bdb6;
}

@media (max-width: 1100px) {
  .developer-content:has(.developer-apps-page) {
    width: calc(100% - 330px) !important;
  }
  .developer-apps-page { width: 100% !important; }
}

@media (max-width: 900px) {
  .developer-content:has(.developer-apps-page) {
    width: auto !important;
  }
  .apps-header-card,
  .app-list-card {
    grid-template-columns: 1fr;
  }
  .apps-new-button,
  .app-list-card .boton {
    justify-self: stretch;
    text-align: center;
  }
}

/* Developer usuarios / baneos */
.dev-search-card{display:flex;gap:14px;align-items:center;border:1px solid var(--borde);border-radius:24px;padding:16px;margin:18px 0;background:rgba(255,255,255,.78)}
.dev-search-card input{flex:1;min-width:260px}
.dev-lista-usuarios{display:grid;gap:12px}
.dev-row-card{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid var(--borde);border-radius:22px;padding:18px;background:rgba(255,255,255,.78)}
.dev-row-card p{margin:5px 0 0;color:#736c69;font-size:14px}
.dev-row-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.dev-row-actions-wide{flex:1;max-width:720px}
.badge{display:inline-flex;align-items:center;border:1px solid var(--borde);border-radius:999px;padding:8px 14px;font-size:12px;font-weight:800;text-transform:uppercase}
.badge-ok{color:#0a8a44;background:#ecfff4;border-color:#bff0d3}
.badge-danger{color:#b52412;background:#fff1ee;border-color:#ffc2b8}
.boton.peligro{background:#b52412;color:white;box-shadow:none}
.boton.secundario{background:white;color:var(--marca);border:1px solid var(--marca)}
.boton.mini{padding:10px 16px;font-size:13px;border-radius:999px;text-decoration:none}
.dev-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:18px 0}
.dev-card-soft,.dev-section-block{border:1px solid var(--borde);border-radius:24px;background:rgba(255,255,255,.78);padding:22px;margin:18px 0}
.dev-card-soft h3,.dev-section-block h3{margin:0 0 8px}
.stack{display:grid;gap:12px;margin-top:14px}
.stack textarea{min-height:94px;resize:vertical}
.info-line{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--borde)}
.info-line:last-child{border-bottom:0}
.inline-ban-form{display:flex;gap:8px;align-items:center;flex-wrap:nowrap}
.inline-ban-form input{min-width:230px;padding:10px 12px;border-radius:999px}
.dev-app-ban-list{display:grid;gap:12px;margin-top:14px}
@media (max-width: 980px){.dev-grid-2{grid-template-columns:1fr}.dev-row-card{align-items:flex-start;flex-direction:column}.dev-row-actions-wide{max-width:none;width:100%}.inline-ban-form{width:100%;flex-direction:column;align-items:stretch}.inline-ban-form input{min-width:0;width:100%}.dev-search-card{flex-direction:column;align-items:stretch}.dev-search-card input{min-width:0}}

/* =========================================================
   Villar.do Home estilo ecosistema + apps públicas
   ========================================================= */
.home-apple-hero{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  border:1px solid var(--borde);
  border-radius:32px;
  padding:26px;
  background:linear-gradient(135deg,rgba(255,255,255,.88),rgba(255,244,241,.72));
  box-shadow:0 24px 70px rgba(235,77,47,.10);
  margin-bottom:18px;
}
.home-avatar{
  width:68px;height:68px;border-radius:24px;background:var(--marca);color:white;
  display:grid;place-items:center;font-size:28px;font-weight:950;box-shadow:0 18px 42px rgba(235,77,47,.24)
}
.home-apple-hero h2{margin:0;font-size:34px;letter-spacing:-.04em}.home-apple-hero p{margin:4px 0 0;color:#6d625f}
.home-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:18px 0}.glassy{background:rgba(255,255,255,.68)!important;backdrop-filter:blur(18px)}
.ecosystem-section{border:1px solid var(--borde);border-radius:30px;padding:22px;margin:18px 0;background:rgba(255,255,255,.62)}
.section-title-row{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:16px}.section-title-row h3{margin:0;font-size:22px}.section-title-row p{margin:4px 0 0;color:#736c69}
.app-search-form{display:flex;gap:8px}.app-search-form input{min-width:260px;border-radius:999px;padding:12px 16px}
.apple-app-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.apple-app-card{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;border:1px solid var(--borde);border-radius:26px;padding:16px;background:linear-gradient(135deg,rgba(255,255,255,.88),rgba(255,250,249,.65));box-shadow:0 16px 46px rgba(235,77,47,.07)}
.apple-app-card.app-banned{opacity:.68;background:rgba(255,241,238,.8)}
.apple-app-icon,.apple-app-icon-img{width:58px;height:58px;border-radius:18px;object-fit:cover;display:grid;place-items:center;background:var(--marca);color:#fff;font-weight:950;font-size:18px;box-shadow:0 16px 34px rgba(235,77,47,.20)}
.apple-app-info strong,.apple-app-info small{display:block}.apple-app-info small{color:#756a66;margin:4px 0 7px;line-height:1.35}.disabled{opacity:.58;pointer-events:none}.discover-section{background:linear-gradient(135deg,rgba(255,244,241,.62),rgba(255,255,255,.7))}
.app-icon-img{width:44px;height:44px;border-radius:15px;object-fit:cover;box-shadow:0 14px 32px rgba(235,77,47,.15)}
.app-icon-xl{width:72px;height:72px;border-radius:24px;font-size:24px}.app-public-card{border:1px solid var(--borde);border-radius:30px;padding:22px;margin:18px 0;background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(255,244,241,.70));box-shadow:0 22px 60px rgba(235,77,47,.08)}
.app-public-preview{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center}.app-public-preview img{width:72px;height:72px;border-radius:24px;object-fit:cover}.app-public-preview h3{margin:0;font-size:24px}.app-public-preview p{margin:6px 0;color:#6d625f}.app-public-links{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.metadata-details{margin-top:18px;border-top:1px solid var(--borde);padding-top:14px}.metadata-details summary{cursor:pointer;font-weight:950;color:var(--marca)}.metadata-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.metadata-full{grid-column:1/-1}.apple-form-card{border:1px solid var(--borde);border-radius:30px;padding:24px;background:rgba(255,255,255,.76);display:grid;gap:14px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.catalog-toggle-row{border:1px solid var(--borde);border-radius:22px;padding:14px;background:rgba(255,245,242,.7)}.switch-line-card{display:grid!important;grid-template-columns:auto auto 1fr;gap:10px;align-items:center}.switch-line-card small{grid-column:3;color:#756a66}
.app-access-card.estado-baneado{background:#fff1ee;border-color:#ffb9ad}.app-access-card.estado-activo{background:#f6fff9;border-color:#bdebcf}
.tema-oscuro .home-apple-hero,.tema-oscuro .ecosystem-section,.tema-oscuro .apple-app-card,.tema-oscuro .app-public-card,.tema-oscuro .apple-form-card{background:linear-gradient(135deg,rgba(48,26,21,.86),rgba(20,9,7,.74));}.tema-oscuro .home-apple-hero p,.tema-oscuro .section-title-row p,.tema-oscuro .apple-app-info small,.tema-oscuro .app-public-preview p{color:#d7bdb6}
@media(max-width:900px){.home-apple-hero,.apple-app-card,.app-public-preview{grid-template-columns:1fr}.home-summary-grid,.form-grid-2,.form-grid-3,.metadata-form-grid{grid-template-columns:1fr}.section-title-row{align-items:stretch;flex-direction:column}.app-search-form{flex-direction:column}.app-search-form input{min-width:0}.apple-app-card .boton,.apple-app-card .boton-secundario{justify-self:stretch;text-align:center}}

/* =========================================================
   Villar.do App Launcher: estilo Apple/Odoo con colores Villar
   ========================================================= */
.launcher-hero{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px;
  align-items:center;
  padding:24px;
  border:1px solid var(--borde);
  border-radius:32px;
  background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(255,245,242,.64));
  box-shadow:0 22px 64px rgba(235,77,47,.08);
  margin-bottom:18px;
}
.launcher-user-badge{
  width:70px;height:70px;border-radius:22px;display:grid;place-items:center;
  background:linear-gradient(135deg,#ff5a37,#eb4d2f);color:#fff;font-weight:950;font-size:30px;
  box-shadow:0 20px 40px rgba(235,77,47,.22);
}
.launcher-hero h2{margin:0;font-size:34px;letter-spacing:-.045em}.launcher-hero p{margin:4px 0 0;color:#6d625f}
.launcher-panel{
  border:1px solid var(--borde);
  border-radius:34px;
  padding:28px;
  background:radial-gradient(circle at 50% 0%,rgba(235,77,47,.10),transparent 34%),rgba(255,255,255,.72);
  box-shadow:0 28px 80px rgba(48,27,21,.10);
}
.launcher-search-wrap{
  max-width:780px;margin:0 auto 28px;position:relative;
}
.launcher-search{
  width:100%;height:62px;border-radius:18px;border:1px solid rgba(235,77,47,.20);
  background:rgba(35,38,50,.94);color:#fff;padding:0 58px 0 26px;
  font-size:20px;outline:none;box-shadow:0 18px 48px rgba(0,0,0,.16);
}
.launcher-search::placeholder{color:rgba(255,255,255,.74)}
.launcher-search:focus{border-color:rgba(235,77,47,.72);box-shadow:0 20px 54px rgba(235,77,47,.18)}
.launcher-search-icon{position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:30px;color:rgba(255,255,255,.78);line-height:1}
.launcher-results-title{text-align:center;text-transform:uppercase;letter-spacing:.14em;color:#756a66;font-size:12px;font-weight:900;margin:0 0 18px}
.launcher-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(112px,1fr));
  gap:24px 18px;
  align-items:start;
}
.launcher-app{
  display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;color:var(--texto);
  min-height:122px;border-radius:24px;padding:12px 8px;transition:transform .16s ease, background .16s ease, box-shadow .16s ease;
}
.launcher-app:hover{transform:translateY(-3px);background:rgba(235,77,47,.07);box-shadow:0 16px 34px rgba(235,77,47,.10)}
.launcher-icon-shell{
  width:72px;height:72px;border-radius:22px;display:grid;place-items:center;overflow:hidden;
  background:linear-gradient(135deg,#ff5a37,#eb4d2f);color:#fff;font-weight:950;font-size:22px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),0 18px 30px rgba(235,77,47,.20);
}
.launcher-icon-shell img{width:100%;height:100%;object-fit:cover;display:block}
.launcher-app-name{margin-top:10px;font-size:14px;font-weight:800;line-height:1.22;max-width:112px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.launcher-app-disabled{opacity:.48;cursor:not-allowed;pointer-events:none}.launcher-empty{text-align:center;padding:24px;color:#756a66;font-weight:800}
.launcher-account-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.launcher-account-strip article{border:1px solid var(--borde);border-radius:24px;padding:18px;background:rgba(255,255,255,.66)}
.launcher-account-strip span{display:block;text-transform:uppercase;font-size:12px;font-weight:900;color:#756a66;margin-bottom:8px}.launcher-account-strip strong{display:block}.launcher-account-strip small{color:#756a66;display:block;margin-top:6px}
.tema-oscuro .launcher-hero,.tema-oscuro .launcher-panel,.tema-oscuro .launcher-account-strip article{background:linear-gradient(135deg,rgba(48,26,21,.86),rgba(20,9,7,.74));}
.tema-oscuro .launcher-hero p,.tema-oscuro .launcher-results-title,.tema-oscuro .launcher-empty,.tema-oscuro .launcher-account-strip span,.tema-oscuro .launcher-account-strip small{color:#d7bdb6}
.tema-oscuro .launcher-search{background:rgba(13,16,26,.94);border-color:rgba(255,255,255,.12)}
@media(max-width:760px){.launcher-hero{grid-template-columns:1fr;text-align:center}.launcher-user-badge{margin:auto}.launcher-account-strip{grid-template-columns:1fr}.launcher-panel{padding:20px}.launcher-grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:18px 12px}.launcher-icon-shell{width:64px;height:64px}.launcher-search{font-size:17px;height:56px}}
