:root {
  --bg: #f5f5f2;
  --card: #ffffff;
  --border: #e3e2dc;
  --text: #23231f;
  --text-secondary: #6f6e68;
  --text-muted: #a3a29b;
  --accent: #2f6fed;
  --accent-bg: #eaf1fe;
  --success-bg: #e3f7ea;
  --success-text: #1c7a3c;
  --warning-bg: #fff4e0;
  --warning-text: #a85d00;
  --danger-bg: #fdeceb;
  --danger-text: #c0392b;
  --radius: 10px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
}

a { color: var(--accent); text-decoration: none; }

.contenedor { max-width: 780px; margin: 0 auto; padding: 24px 16px 60px; }
.contenedor-angosto { max-width: 460px; margin: 60px auto; padding: 0 16px; }

/* Navegacion superior */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--card); border-bottom: 1px solid var(--border);
  padding: 12px 20px;
}
.nav .links { display: flex; gap: 18px; align-items: center; }
.nav .links a { color: var(--text-secondary); font-size: 14px; padding: 6px 10px; border-radius: 8px; }
.nav .links a.activo { color: var(--accent); background: var(--accent-bg); font-weight: 500; }
.nav .usuario { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--text-secondary); }
.nav button.link { background: none; border: none; color: var(--text-secondary); cursor: pointer; font-size: 13px; padding: 0; }

/* Tarjetas */
.card {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 14px 16px; margin-bottom: 10px;
}
.card-clicable { cursor: pointer; }
.card-clicable:hover { border-color: var(--accent); }

/* Formularios */
fieldset { border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; margin: 0 0 20px; background: var(--card); }
legend { padding: 0 6px; font-size: 13px; color: var(--text-secondary); }
label { font-size: 12px; color: var(--text-secondary); display: block; margin-bottom: 4px; }
input, select, textarea {
  width: 100%; padding: 8px 10px; margin-bottom: 12px; border: 1px solid var(--border);
  border-radius: 8px; font-size: 14px; background: #fff; color: var(--text);
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); }
button {
  background: var(--accent); color: #fff; border: none; border-radius: 8px;
  padding: 9px 16px; font-size: 14px; cursor: pointer;
}
button.secundario { background: var(--card); color: var(--text); border: 1px solid var(--border); }
button.peligro { background: var(--danger-text); }
button:disabled { opacity: 0.5; cursor: default; }

/* Badges de estado */
.badge { font-size: 11px; padding: 3px 10px; border-radius: 20px; white-space: nowrap; }
.badge-success { background: var(--success-bg); color: var(--success-text); }
.badge-warning { background: var(--warning-bg); color: var(--warning-text); }
.badge-danger { background: var(--danger-bg); color: var(--danger-text); }
.badge-neutral { background: var(--bg); color: var(--text-secondary); }

/* Avatares */
.avatar {
  width: 42px; height: 42px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 13px; background: var(--accent-bg); color: var(--accent); flex-shrink: 0;
}
.avatar.chico { width: 28px; height: 28px; font-size: 11px; }

/* Utilidades de layout */
.fila { display: flex; align-items: center; gap: 10px; }
.fila-entre { display: flex; align-items: center; justify-content: space-between; }
.columnas-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.columnas-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.texto-secundario { color: var(--text-secondary); font-size: 13px; }
.texto-muted { color: var(--text-muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.03em; }
.mensaje-error { color: var(--danger-text); font-size: 13px; margin: 8px 0; }
.mensaje-ok { color: var(--success-text); font-size: 13px; margin: 8px 0; }
.vacio { color: var(--text-muted); font-size: 14px; padding: 20px 0; text-align: center; }

.campos-tipo { display: none; }

/* Tabs */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--border); margin-bottom: 18px; }
.tabs button { background: none; color: var(--text-secondary); border: none; border-radius: 0; padding: 10px 4px; margin-right: 20px; border-bottom: 2px solid transparent; }
.tabs button.activo { color: var(--accent); border-bottom-color: var(--accent); font-weight: 500; }

/* Drag and drop del itinerario */
.dia-bloque { border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; margin-bottom: 16px; background: var(--card); }
.duerme { background: var(--accent-bg); color: var(--accent); border-radius: 8px; padding: 8px 12px; font-size: 13px; margin-bottom: 10px; }
.duerme.falta { background: var(--warning-bg); color: var(--warning-text); }
.hora-fija { background: var(--bg); border-radius: 8px; padding: 8px 12px; font-size: 13px; margin-bottom: 6px; }
.hora-fija.destacada { background: var(--warning-bg); border-left: 3px solid var(--warning-text); }
.col-drop { background: var(--bg); border-radius: 8px; padding: 8px; min-height: 50px; }
.col-drop.sobre { background: var(--accent-bg); }
.tarjeta-actividad { background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: 8px 10px; margin-bottom: 6px; font-size: 13px; cursor: grab; }
.tarjeta-actividad.destacada { border-color: var(--warning-text); border-width: 1px; background: var(--warning-bg); }

/* Modal simple */
.overlay { position: static; min-height: 100vh; background: rgba(0,0,0,0.4); display: flex; align-items: flex-start; justify-content: center; padding: 40px 16px; }
.overlay .card { width: 100%; max-width: 420px; }
