:root {
  --verde-oscuro: #1c3d2e;
  --verde: #3a6b4a;
  --verde-claro: #6fae7a;
  --tierra: #7a5230;
  --fondo: #f4f1e8;
  --texto: #23241f;
  --borde: #d8d2bf;
  --blanco: #ffffff;
  --peligro: #b4423b;
  --amarillo: #d9a441;
  --radio: 10px;
  --sombra: 0 2px 8px rgba(0,0,0,.12);
}

* { box-sizing: border-box; }

html, body {
  height: 100%;
  margin: 0;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--fondo);
  color: var(--texto);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  padding-bottom: env(safe-area-inset-bottom);
}

.app-header {
  background: var(--verde-oscuro);
  color: var(--blanco);
  padding: 14px 16px;
  flex: 0 0 auto;
}

.app-header__logo {
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: .3px;
}

#views {
  flex: 1 1 auto;
  overflow: hidden;
  display: flex;
  position: relative;
}

.view {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
}

.view[hidden] { display: none; }

.view-toolbar {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  background: var(--blanco);
  border-bottom: 1px solid var(--borde);
  flex-wrap: wrap;
  flex: 0 0 auto;
}

.select {
  flex: 1 1 120px;
  min-width: 0;
  padding: 8px 10px;
  border-radius: var(--radio);
  border: 1px solid var(--borde);
  background: var(--fondo);
  font-size: .9rem;
}

.btn {
  border: none;
  border-radius: var(--radio);
  padding: 8px 14px;
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
}

.btn--primary {
  background: var(--verde);
  color: var(--blanco);
  flex: 0 0 auto;
  white-space: nowrap;
}

.btn--secondary {
  background: var(--fondo);
  color: var(--texto);
  border: 1px solid var(--borde);
}

.btn--peligro {
  background: var(--peligro);
  color: var(--blanco);
}

/* MAPA */
.mapa-container {
  flex: 1 1 auto;
  min-height: 0;
  background: #e9e4d4;
}

.leaflet-container {
  background: #e9e4d4;
  font-family: inherit;
}

/* PROYECTOS */
.lista-proyectos {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.proyecto-card {
  background: var(--blanco);
  border-radius: var(--radio);
  box-shadow: var(--sombra);
  padding: 12px 14px;
  border-left: 5px solid var(--verde-claro);
}

.proyecto-card[data-estado="idea"] { border-left-color: var(--amarillo); }
.proyecto-card[data-estado="en_construccion"] { border-left-color: #4a7fb5; }
.proyecto-card[data-estado="terminado"] { border-left-color: var(--verde); }

.proyecto-card__top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
}

.proyecto-card__nombre {
  font-weight: 700;
  font-size: 1rem;
}

.proyecto-card__estado {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--verde);
  font-weight: 700;
  white-space: nowrap;
}

.proyecto-card__meta {
  font-size: .82rem;
  color: #5c5c52;
  margin-top: 2px;
}

.proyecto-card__notas {
  font-size: .88rem;
  margin-top: 6px;
}

.proyecto-card__acciones {
  margin-top: 8px;
  display: flex;
  gap: 8px;
}

.vacio {
  padding: 40px 16px;
  text-align: center;
  color: #8a8a7d;
  font-size: .95rem;
}

/* CALCULADORA */
.calc-card {
  padding: 16px;
  overflow-y: auto;
}

.calc-hint {
  font-size: .85rem;
  color: #5c5c52;
  margin-top: 0;
}

.calc-block {
  background: var(--blanco);
  border-radius: var(--radio);
  box-shadow: var(--sombra);
  padding: 14px;
  margin-bottom: 14px;
}

.calc-block h3 {
  margin: 0 0 10px;
  font-size: .95rem;
  color: var(--verde-oscuro);
}

.calc-row {
  display: flex;
  gap: 10px;
}

.calc-row label {
  flex: 1;
  font-size: .8rem;
  color: #5c5c52;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.calc-row input {
  padding: 10px;
  border-radius: 8px;
  border: 1px solid var(--borde);
  font-size: 1rem;
}

.calc-resultado {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--fondo);
  border-radius: 8px;
  font-weight: 700;
  font-size: .95rem;
  color: var(--verde-oscuro);
}

/* TABBAR */
.tabbar {
  display: flex;
  background: var(--blanco);
  border-top: 1px solid var(--borde);
  flex: 0 0 auto;
}

.tabbar__btn {
  flex: 1;
  background: none;
  border: none;
  padding: 8px 4px 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: .72rem;
  color: #8a8a7d;
  cursor: pointer;
}

.tabbar__icon { font-size: 1.3rem; }

.tabbar__btn.is-active {
  color: var(--verde-oscuro);
  font-weight: 700;
}

/* MODAL */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  z-index: 1000;
}

.modal-overlay[hidden] { display: none; }

.modal {
  background: var(--blanco);
  width: 100%;
  max-width: 480px;
  border-radius: 16px 16px 0 0;
  padding: 18px 16px calc(18px + env(safe-area-inset-bottom));
  max-height: 88vh;
  overflow-y: auto;
}

.modal h2 {
  margin-top: 0;
  font-size: 1.1rem;
  color: var(--verde-oscuro);
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
  font-size: .85rem;
  color: #5c5c52;
}

.form-field input,
.form-field select,
.form-field textarea {
  padding: 10px;
  border-radius: 8px;
  border: 1px solid var(--borde);
  font-size: .95rem;
  font-family: inherit;
}

.form-field textarea { resize: vertical; min-height: 60px; }

.form-acciones {
  display: flex;
  gap: 10px;
  margin-top: 6px;
}

.form-acciones .btn { flex: 1; }

@media (min-width: 720px) {
  .app-header { padding: 16px 24px; }
  #views { padding: 0; }
  .view-toolbar, .lista-proyectos, .calc-card { padding-left: 24px; padding-right: 24px; }
  .lista-proyectos {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    align-content: start;
  }
  .calc-card { max-width: 640px; margin: 0 auto; width: 100%; }
}
