:root {
  --fondo: #faf7ed;
  --fondo-app: #f4f1e7;
  --panel: #e3e3d8;
  --panel-oscuro: #d1d1c7;
  --texto: #2d2d2d;
  --texto-suave: #5f5f58;
  --linea: #2d2d2d;
  --blanco-calido: #fffdf4;
  --error: #8e0000;
}

* {
  box-sizing: border-box;
}

html {
  background: var(--fondo);
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--fondo);
  color: var(--texto);
  font-family: "IBM Plex Mono", monospace;
  font-size: 14px;
  letter-spacing: -0.03em;
}

button,
input,
textarea,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

.app {
  width: min(100%, 430px);
  min-height: 100vh;
  margin: 0 auto;
  background: var(--fondo-app);
  border-left: 1px solid var(--linea);
  border-right: 1px solid var(--linea);
}

/* ENCABEZADO */

.encabezado {
  position: relative;
  padding: 22px 18px 22px;
  background: var(--blanco-calido);
  border-bottom: 1px solid var(--linea);
  text-align: center;
  min-height: 132px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.marca {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  text-transform: uppercase;
  padding-top: 48px;
}

.sello {
  display: inline-block;
  padding: 4px 9px;
  background: var(--texto);
  color: var(--blanco-calido);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
}

.marca p {
  margin: 0;
  color: var(--texto-suave);
  font-size: 11px;
  letter-spacing: 0.12em;
}

.logo-proyecto {
  position: absolute;
  top: 18px;
  left: 50%;
  width: 42px;
  height: 42px;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-proyecto img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

/* CUENTA */

.cuenta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--panel);
  border-bottom: 1px solid var(--linea);
}

.cuenta > div {
  padding: 16px;
}

.cuenta > div:first-child {
  border-right: 1px solid var(--linea);
}

.etiqueta {
  display: block;
  margin-bottom: 7px;
  color: var(--texto-suave);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cuenta strong {
  display: block;
  font-size: 18px;
  font-weight: 700;
}

/* NAVEGACIÓN */

.navegacion {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-bottom: 1px solid var(--linea);
}

.pestana {
  min-height: 44px;
  padding: 12px 4px;
  border: 0;
  border-right: 1px solid var(--linea);
  background: transparent;
  color: var(--texto);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}

.pestana:last-child {
  border-right: 0;
}

.pestana.activa {
  background: var(--texto);
  color: var(--blanco-calido);
}

/* CONTENIDO */

.contenido {
  padding: 18px;
}

.vista {
  display: none;
}

.vista.activa {
  display: block;
}

.titulo-seccion {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.titulo-seccion h1 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.titulo-seccion span {
  min-width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--linea);
  background: var(--blanco-calido);
  font-size: 12px;
  font-weight: 700;
}

/* OBJETOS */

.lista-objetos {
  display: grid;
  gap: 14px;
}

.tarjeta-objeto {
  background: var(--blanco-calido);
  border: 1px solid var(--linea);
  padding: 14px;
}

.objeto-arriba {
  display: flex;
  gap: 13px;
  align-items: center;
}

.caja-imagen {
  width: 84px;
  height: 84px;
  flex: 0 0 84px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel);
  border: 1px solid var(--linea);
  overflow: hidden;
}

.imagen-falsa {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--linea);
  background: var(--fondo);
  font-size: 24px;
  font-weight: 700;
}

.imagen-respaldo {
  display: none;
}

.caja-imagen img {
  max-width: 78%;
  max-height: 78%;
  object-fit: contain;
  display: block;
}

.objeto-info {
  min-width: 0;
  width: 100%;
}

.nombre-objeto {
  margin: 0 0 7px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  text-transform: uppercase;
}

.descripcion-objeto {
  margin: 0;
  color: var(--texto-suave);
  font-size: 12px;
  line-height: 1.45;
}

.meta-objeto {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed var(--linea);
  color: var(--texto);
  font-size: 12px;
  line-height: 1.8;
}

.meta-objeto span {
  color: var(--texto-suave);
}

/* BOTONES */

.boton-principal,
.boton-secundario,
.boton-peligro {
  width: 100%;
  min-height: 43px;
  border: 1px solid var(--linea);
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.03em;
}

.boton-principal {
  margin-top: 14px;
  background: var(--texto);
  color: var(--blanco-calido);
}

.boton-principal:disabled {
  background: transparent;
  color: var(--texto-suave);
  border-color: var(--panel-oscuro);
  cursor: not-allowed;
}

.boton-secundario {
  background: transparent;
  color: var(--texto);
}

.boton-secundario:disabled {
  color: var(--texto-suave);
  border-color: var(--panel-oscuro);
  cursor: not-allowed;
}

.boton-peligro {
  background: transparent;
  color: var(--error);
  border-color: var(--error);
}

/* ESTADOS Y REGISTRO */

.estado-vacio {
  padding: 22px;
  border: 1px dashed var(--linea);
  background: var(--panel);
  color: var(--texto-suave);
  text-align: center;
  line-height: 1.5;
}

.registro {
  display: grid;
  gap: 10px;
}

.entrada-registro {
  padding: 12px;
  border: 1px solid var(--linea);
  background: var(--blanco-calido);
  font-size: 12px;
  line-height: 1.5;
}

.entrada-registro strong {
  display: block;
  margin-bottom: 4px;
  text-transform: uppercase;
}

/* ADMIN */

.panel-admin {
  display: grid;
  gap: 14px;
}

.nota {
  margin: 0;
  padding: 14px;
  background: var(--panel);
  border: 1px solid var(--linea);
  color: var(--texto-suave);
  font-size: 12px;
  line-height: 1.55;
}

.bloque-admin {
  padding: 14px;
  background: var(--blanco-calido);
  border: 1px solid var(--linea);
}

.fila-admin {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* FORMULARIOS */

.panel-acceso {
  display: grid;
  gap: 14px;
}

.form-acceso {
  display: grid;
  gap: 12px;
}

.campo-registro {
  display: grid;
  gap: 7px;
}

.input-texto {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid var(--linea);
  background: var(--blanco-calido);
  color: var(--texto);
  outline: none;
  font-size: 13px;
}

.input-texto:focus {
  background: #ffffff;
}

textarea.input-texto {
  resize: vertical;
  line-height: 1.5;
}

.mensaje-acceso {
  margin: 0;
  min-height: 18px;
  color: var(--error);
  font-size: 12px;
  line-height: 1.5;
}

.nota-acceso {
  margin-top: 4px;
}

.boton-cambio-acceso {
  margin-top: 0;
}

/* MODAL */

.modal-compra {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
}

.modal-compra.activa {
  display: flex;
}

.modal-fondo {
  position: absolute;
  inset: 0;
  background: rgba(45, 45, 45, 0.45);
}

.modal-caja {
  position: relative;
  z-index: 2;
  width: min(100%, 390px);
  background: var(--fondo-app);
  border: 1px solid var(--linea);
}

.modal-encabezado {
  min-height: 44px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--linea);
  background: var(--texto);
  color: var(--blanco-calido);
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 700;
}

.modal-cerrar {
  width: 28px;
  height: 28px;
  border: 1px solid var(--blanco-calido);
  background: transparent;
  color: var(--blanco-calido);
  line-height: 1;
}

.modal-cuerpo {
  padding: 14px;
}

.modal-aviso,
.modal-advertencia {
  margin: 0;
  font-size: 12px;
  line-height: 1.55;
  color: var(--texto-suave);
}

.modal-recibo {
  margin: 14px 0;
  border: 1px solid var(--linea);
  background: var(--blanco-calido);
}

.modal-recibo > div {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 10px;
  border-bottom: 1px dashed var(--linea);
  align-items: center;
}

.modal-recibo > div:last-child {
  border-bottom: 0;
}

.modal-recibo span {
  color: var(--texto-suave);
  font-size: 11px;
  text-transform: uppercase;
}

.modal-recibo strong {
  text-align: right;
  font-size: 12px;
}

.modal-advertencia {
  color: var(--error);
}

.modal-acciones {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.modal-confirmar {
  margin-top: 0;
}

/* RESPONSIVE */

@media (min-width: 700px) {
  body {
    padding: 30px 0;
  }

  .app {
    min-height: calc(100vh - 60px);
  }
}

@media (max-width: 380px) {
  .encabezado {
    min-height: 124px;
  }

  .marca {
    padding-top: 44px;
  }

  .logo-proyecto {
    width: 38px;
    height: 38px;
    top: 18px;
  }

  .sello {
    font-size: 11px;
  }

  .marca p {
    font-size: 10px;
  }
}