/* ===========================================================
   Brújula — Gestor de vida
   Sistema visual: tonos tierra, cálido y zen
   =========================================================== */

:root {
  /* Superficies cálidas */
  --cream:    oklch(0.975 0.010 78);
  --cream-2:  oklch(0.960 0.014 75);
  --paper:    oklch(0.995 0.005 85);
  --paper-2:  oklch(0.980 0.010 80);

  /* Tinta (texto) */
  --ink:       oklch(0.275 0.018 55);
  --ink-soft:  oklch(0.460 0.020 55);
  --ink-faint: oklch(0.610 0.016 60);
  --ink-ghost: oklch(0.730 0.012 65);

  /* Líneas */
  --line:      oklch(0.905 0.012 72);
  --line-soft: oklch(0.940 0.010 75);

  /* Acentos tierra — ladrillo + mostaza (favoritos de Jero) */
  --terracotta:      oklch(0.555 0.130 36);   /* ladrillo */
  --terracotta-deep: oklch(0.470 0.120 36);
  --terracotta-soft: oklch(0.918 0.045 42);
  --ochre:           oklch(0.770 0.140 88);   /* mostaza amarillenta */
  --ochre-soft:      oklch(0.935 0.062 90);
  --sage:            oklch(0.660 0.058 150);
  --sage-soft:       oklch(0.935 0.030 150);

  /* Colores de área (hue variable, chroma contenida → cohesión) */
  --cat-mente:       oklch(0.700 0.115 85);
  --cat-mente-tint:  oklch(0.945 0.055 88);
  --cat-cuerpo:      oklch(0.560 0.130 36);
  --cat-cuerpo-tint: oklch(0.920 0.048 40);
  --cat-alma:        oklch(0.560 0.072 330);
  --cat-alma-tint:   oklch(0.940 0.030 330);

  /* Prioridades de tareas */
  --prio-alta:  oklch(0.555 0.130 36);   /* ladrillo */
  --prio-media: oklch(0.700 0.130 78);   /* mostaza */
  --prio-baja:  oklch(0.660 0.050 150);  /* salvia */

  /* Sombras suaves */
  --sh-sm: 0 1px 2px oklch(0.40 0.03 55 / 0.05), 0 1px 3px oklch(0.40 0.03 55 / 0.04);
  --sh-md: 0 2px 6px oklch(0.40 0.03 55 / 0.06), 0 8px 24px oklch(0.40 0.03 55 / 0.06);
  --sh-lg: 0 4px 12px oklch(0.40 0.03 55 / 0.08), 0 18px 48px oklch(0.40 0.03 55 / 0.10);

  /* Radios */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 28px;

  /* Tipografía */
  --sans: "Outfit", ui-sans-serif, system-ui, sans-serif;
  --mono: "DM Mono", ui-monospace, monospace;
}

/* ===========================================================
   Tema oscuro — cálido (no negro puro), conserva los acentos tierra
   =========================================================== */
[data-theme="dark"] {
  --cream:    oklch(0.205 0.012 60);
  --cream-2:  oklch(0.250 0.014 60);
  --paper:    oklch(0.235 0.013 60);
  --paper-2:  oklch(0.280 0.014 62);

  --ink:       oklch(0.945 0.010 78);
  --ink-soft:  oklch(0.800 0.014 72);
  --ink-faint: oklch(0.660 0.014 68);
  --ink-ghost: oklch(0.520 0.012 64);

  --line:      oklch(0.345 0.014 62);
  --line-soft: oklch(0.300 0.012 62);

  --terracotta:      oklch(0.660 0.130 38);
  --terracotta-deep: oklch(0.740 0.120 40);
  --terracotta-soft: oklch(0.360 0.060 38);
  --ochre:           oklch(0.790 0.135 88);
  --ochre-soft:      oklch(0.360 0.055 88);
  --sage:            oklch(0.700 0.060 150);
  --sage-soft:       oklch(0.340 0.035 150);

  --cat-mente:       oklch(0.770 0.115 86);
  --cat-mente-tint:  oklch(0.345 0.050 86);
  --cat-cuerpo:      oklch(0.680 0.130 38);
  --cat-cuerpo-tint: oklch(0.350 0.055 40);
  --cat-alma:        oklch(0.700 0.075 330);
  --cat-alma-tint:   oklch(0.340 0.040 330);

  --prio-alta:  oklch(0.680 0.130 38);
  --prio-media: oklch(0.780 0.130 80);
  --prio-baja:  oklch(0.700 0.055 150);

  --sh-sm: 0 1px 2px oklch(0 0 0 / 0.25), 0 1px 3px oklch(0 0 0 / 0.22);
  --sh-md: 0 2px 6px oklch(0 0 0 / 0.30), 0 8px 24px oklch(0 0 0 / 0.30);
  --sh-lg: 0 4px 12px oklch(0 0 0 / 0.35), 0 18px 48px oklch(0 0 0 / 0.42);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  height: 100%;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

#root { height: 100%; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, textarea { font-family: inherit; }

::selection { background: var(--terracotta-soft); }

/* Etiquetas mono pequeñas */
.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  font-weight: 500;
}

/* ---------------- Layout principal ---------------- */
.app {
  display: grid;
  grid-template-columns: 256px 1fr;
  height: 100%;
  overflow: hidden;
}
.app.nav-collapsed { grid-template-columns: 76px 1fr; }

/* ---------------- Sidebar ---------------- */
.sidebar {
  background: var(--cream-2);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  padding: 22px 16px 18px;
  overflow-y: auto;
  overflow-x: hidden;
  min-width: 0;
}

/* botón de colapso */
.nav-toggle {
  width: 32px; height: 32px; border-radius: 9px;
  display: grid; place-items: center; color: var(--ink-faint);
  transition: background .15s ease, color .15s ease; flex-shrink: 0;
}
.nav-toggle:hover { background: oklch(0.93 0.012 72); color: var(--ink); }

.brand {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 0 4px 4px;
  margin-bottom: 24px;
}
.brand-mark { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; flex-shrink: 0; overflow: hidden; }
.brand-mark-logo { box-shadow: 0 2px 8px color-mix(in oklab, var(--terracotta), transparent 70%); }
.brand-mark img { width: 100%; height: 100%; object-fit: contain; }
.brand-text { min-width: 0; }
.app:not(.nav-collapsed) .brand-text { overflow: visible; }
.brand-name { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.1; white-space: nowrap; }
.brand-sub  { font-size: 11px; color: var(--ink-faint); letter-spacing: 0.02em; white-space: nowrap; }

/* en estado colapsado, ocultar textos y badges, centrar iconos */
.app.nav-collapsed .brand { justify-content: center; padding: 0 0 4px; }
.app.nav-collapsed .brand-text,
.app.nav-collapsed .nav-label,
.app.nav-collapsed .nav-item span:not(.nav-ico):not(.nav-badge),
.app.nav-collapsed .area-item span:not(.area-dot),
.app.nav-collapsed .nav-badge,
.app.nav-collapsed .user-card > div:not(.avatar) { display: none; }
.app.nav-collapsed .nav-item,
.app.nav-collapsed .area-item { justify-content: center; padding-left: 0; padding-right: 0; gap: 0; }
.app.nav-collapsed .user-card { justify-content: center; padding: 8px; }
.app.nav-collapsed .area-dot { width: 11px; height: 11px; }

/* overlay para móvil (off-canvas) */
.nav-scrim { display: none; }

.nav-group { margin-bottom: 22px; }
.nav-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  padding: 0 12px;
  margin-bottom: 8px;
}

.nav-item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 12px;
  border-radius: var(--r-sm);
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ink-soft);
  transition: background .16s ease, color .16s ease;
  text-align: left;
}
.nav-item:hover { background: oklch(0.93 0.012 72); color: var(--ink); }
.nav-item.active {
  background: var(--paper);
  color: var(--ink);
  box-shadow: var(--sh-sm);
}
.nav-item.active .nav-ico { color: var(--terracotta); }
.nav-item { position: relative; }
.nav-grip {
  color: var(--ink-ghost); display: grid; place-items: center; flex-shrink: 0; cursor: grab;
  width: 0; opacity: 0; margin-left: -8px; overflow: hidden; touch-action: none;
  transition: opacity .15s ease, width .15s ease, margin-left .15s ease;
}
.nav-group:hover .nav-grip { width: 14px; opacity: .4; margin-left: 0; }
.nav-item:hover .nav-grip { opacity: .85; color: var(--terracotta); }
.nav-item.nav-over { box-shadow: inset 0 0 0 1.5px var(--terracotta); }
.nav-item.nav-dragging { opacity: .4; }
.app.nav-collapsed .nav-grip { display: none; }
.nav-ico { color: var(--ink-faint); display: grid; place-items: center; flex-shrink: 0; }
.nav-badge {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-faint);
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 1px 8px;
}

.area-item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 7px 12px;
  border-radius: var(--r-sm);
  font-size: 13.5px;
  color: var(--ink-soft);
  transition: background .16s ease;
  text-align: left;
}
.area-item:hover { background: oklch(0.93 0.012 72); }
.area-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.area-pct { margin-left: auto; font-family: var(--mono); font-size: 11px; color: var(--ink-ghost); }

.sidebar-foot { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--line); }
.settings-item { margin-bottom: 10px; }
.user-card {
  display: flex; align-items: center; gap: 11px; width: 100%; text-align: left;
  padding: 9px 10px;
  border-radius: var(--r-md);
  background: var(--paper);
  box-shadow: var(--sh-sm); cursor: pointer; border: 1px solid transparent;
  transition: border-color .15s ease, background .15s ease;
}
.user-card:hover { border-color: var(--line); }
.user-card.active { border-color: var(--terracotta); }
.avatar-img { object-fit: cover; }
.avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(150deg, var(--cat-alma), var(--terracotta));
  color: white; display: grid; place-items: center;
  font-weight: 600; font-size: 14px; flex-shrink: 0;
}
.user-name { font-size: 13.5px; font-weight: 600; line-height: 1.2; }
.user-meta { font-size: 11.5px; color: var(--ink-faint); }

/* ---------------- Área de contenido ---------------- */
.main { overflow-y: auto; height: 100%; }
.main-inner { max-width: 1180px; margin: 0 auto; padding: 40px 48px 80px; }

.topbar {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 34px;
}
.greeting { flex-shrink: 0; }
.greeting h1 { font-size: 30px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.15; white-space: nowrap; }
.greeting .date { color: var(--ink-faint); font-size: 14.5px; margin-top: 6px; }
.topbar-actions { display: flex; align-items: center; gap: 12px; }

.streak-pill {
  display: flex; align-items: center; gap: 9px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 40px;
  padding: 9px 16px 9px 13px;
  box-shadow: var(--sh-sm);
}
.streak-num { font-size: 17px; font-weight: 700; color: var(--terracotta); }
.streak-lbl { font-size: 12.5px; color: var(--ink-soft); line-height: 1.1; white-space: nowrap; }

.btn-primary {
  display: flex; align-items: center; gap: 8px;
  background: var(--terracotta);
  color: white;
  font-weight: 600; font-size: 14px;
  padding: 11px 18px;
  border-radius: 40px;
  box-shadow: var(--sh-sm);
  transition: background .16s ease, transform .1s ease;
  white-space: nowrap;
}
.btn-primary:hover { background: var(--terracotta-deep); }
.btn-primary:active { transform: translateY(1px); }

/* ---------------- Cards / grid ---------------- */
.grid { display: grid; gap: 20px; }
.card {
  background: var(--paper);
  border: 1px solid var(--line-soft);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: var(--sh-sm);
}
.card-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px; gap: 12px;
}
.card-title { font-size: 16px; font-weight: 600; letter-spacing: -0.01em; white-space: nowrap; }
.card-link {
  font-size: 13px; font-weight: 500; color: var(--terracotta);
  display: inline-flex; align-items: center; gap: 4px;
  transition: gap .16s ease; white-space: nowrap;
}
.card-link:hover { gap: 7px; }

/* Hero */
.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(120% 140% at 100% 0%, var(--ochre-soft) 0%, transparent 55%),
    linear-gradient(135deg, oklch(0.985 0.012 60), var(--paper));
  border: 1px solid var(--line-soft);
  border-radius: var(--r-xl);
  padding: 30px 32px;
}
.hero-quote { font-size: 22px; font-weight: 500; line-height: 1.35; letter-spacing: -0.01em; max-width: 640px; text-wrap: balance; }
.hero-quote .accent { color: var(--terracotta); }
.hero-foot { display: flex; align-items: center; gap: 22px; margin-top: 22px; flex-wrap: wrap; }
.hero-stat { display: flex; flex-direction: column; }
.hero-stat .n { font-size: 24px; font-weight: 700; letter-spacing: -0.02em; }
.hero-stat .l { font-size: 12px; color: var(--ink-faint); margin-top: 1px; }
.hero-divider { width: 1px; height: 34px; background: var(--line); }

/* Tareas de hoy */
.task {
  display: flex; align-items: center; gap: 13px;
  padding: 11px 4px;
  border-bottom: 1px solid var(--line-soft);
  transition: opacity .2s ease;
}
.task:last-child { border-bottom: none; }
.check {
  width: 21px; height: 21px; border-radius: 7px;
  border: 2px solid var(--line);
  display: grid; place-items: center;
  flex-shrink: 0; transition: all .16s ease;
  background: var(--paper);
}
.check:hover { border-color: var(--terracotta); }
.check.done { background: var(--sage); border-color: var(--sage); }
.task-body { flex: 1; min-width: 0; }
.task-name { font-size: 14.5px; font-weight: 500; transition: color .2s ease; }
.task.done .task-name { color: var(--ink-ghost); text-decoration: line-through; text-decoration-color: var(--ink-ghost); }
.task-meta { font-size: 12px; color: var(--ink-faint); margin-top: 2px; display: flex; align-items: center; gap: 8px; }
.tag {
  font-size: 11px; font-weight: 500;
  padding: 2px 9px; border-radius: 20px;
  display: inline-flex; align-items: center; gap: 5px; white-space: nowrap;
}
.due { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); }
.due.urgent { color: var(--terracotta); }

/* Metas (cascada) */
.goal {
  border: 1px solid var(--line-soft);
  border-radius: var(--r-md);
  padding: 18px 20px;
  background: var(--paper);
  transition: box-shadow .18s ease, border-color .18s ease;
}
.goal + .goal { margin-top: 14px; }
.goal:hover { box-shadow: var(--sh-md); border-color: var(--line); }
.goal-top { display: flex; align-items: flex-start; gap: 14px; }
.goal-icon {
  width: 40px; height: 40px; border-radius: 12px;
  display: grid; place-items: center; flex-shrink: 0;
}
.goal-name { font-size: 15.5px; font-weight: 600; letter-spacing: -0.01em; }
.goal-area { font-size: 12px; color: var(--ink-faint); margin-top: 2px; }
.goal-pct { font-family: var(--mono); font-size: 15px; font-weight: 500; }
.bar { height: 7px; border-radius: 6px; background: var(--cream-2); overflow: hidden; margin-top: 14px; }
.bar > span { display: block; height: 100%; border-radius: 6px; transition: width .5s cubic-bezier(.4,0,.2,1); }
.goal-sub { display: flex; gap: 16px; margin-top: 12px; font-size: 12.5px; color: var(--ink-faint); }
.goal-sub b { color: var(--ink-soft); font-weight: 600; }

/* Objetivos desplegados */
.objective {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-bottom: 1px dashed var(--line-soft);
}
.objective:last-child { border-bottom: none; }
.obj-name { font-size: 13.5px; font-weight: 500; flex: 1; }
.obj-bar { width: 90px; height: 5px; border-radius: 4px; background: var(--cream-2); overflow: hidden; }
.obj-bar > span { display: block; height: 100%; }
.obj-pct { font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint); width: 34px; text-align: right; }

/* Hábitos */
.habit { padding: 13px 0; border-bottom: 1px solid var(--line-soft); }
.habit:last-child { border-bottom: none; }
.habit-top { display: flex; align-items: center; gap: 12px; }
.habit-name { font-size: 14px; font-weight: 500; flex: 1; }
.habit-streak { display: flex; align-items: center; gap: 5px; font-family: var(--mono); font-size: 12.5px; font-weight: 500; color: var(--terracotta); }
.week-dots { display: flex; gap: 6px; margin-top: 10px; }
.wd {
  width: 26px; height: 26px; border-radius: 8px;
  display: grid; place-items: center;
  font-family: var(--mono); font-size: 10px; color: var(--ink-ghost);
  border: 1.5px solid var(--line-soft); background: var(--paper);
  transition: all .16s ease;
}
.wd.on { background: var(--sage); border-color: var(--sage); color: white; }
.wd.today { border-color: var(--terracotta); border-style: dashed; }
.wd.today.on { border-style: solid; }

/* Logros */
.badges { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.badge {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px;
  padding: 16px 8px; border-radius: var(--r-md);
  background: var(--paper-2); border: 1px solid var(--line-soft);
}
.badge.locked { opacity: 0.45; filter: grayscale(0.6); }
.badge-ring {
  width: 50px; height: 50px; border-radius: 50%;
  display: grid; place-items: center;
  background: linear-gradient(150deg, var(--ochre-soft), var(--terracotta-soft));
}
.badge-name { font-size: 12px; font-weight: 600; line-height: 1.3; min-height: 2.6em; display: flex; align-items: center; }
.badge-date { font-size: 10.5px; color: var(--ink-faint); font-family: var(--mono); }

/* Reflexión */
.reflect-prompt { font-size: 17px; font-weight: 500; line-height: 1.4; letter-spacing: -0.01em; text-wrap: balance; }
.reflect-input {
  width: 100%; margin-top: 16px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px 16px;
  font-size: 14px; color: var(--ink);
  resize: none; line-height: 1.55;
  transition: border-color .16s ease;
}
.reflect-input:focus { outline: none; border-color: var(--terracotta); }
.reflect-input::placeholder { color: var(--ink-ghost); }

/* Chart */
.chart-legend { display: flex; gap: 16px; flex-wrap: wrap; }
.legend-item { display: flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--ink-soft); }
.legend-swatch { width: 11px; height: 11px; border-radius: 4px; }

/* Page (views distintas al dashboard) */
.page-head { margin-bottom: 30px; }
.page-head h1 { font-size: 28px; font-weight: 600; letter-spacing: -0.02em; }
.page-head p { color: var(--ink-faint); font-size: 15px; margin-top: 7px; max-width: 560px; line-height: 1.5; }

.seg {
  display: inline-flex; background: var(--cream-2); border: 1px solid var(--line);
  border-radius: 30px; padding: 3px; gap: 2px;
}
.seg button {
  padding: 7px 16px; border-radius: 30px; font-size: 13px; font-weight: 500;
  color: var(--ink-soft); transition: all .16s ease; white-space: nowrap;
}
.seg button.active { background: var(--paper); color: var(--ink); box-shadow: var(--sh-sm); }

/* utilidades */
.fade-in { animation: fade .4s ease; }
@keyframes fade { from { transform: translateY(8px); } to { transform: none; } }
.muted { color: var(--ink-faint); }
.row { display: flex; align-items: center; }
.gap8 { gap: 8px; } .gap12 { gap: 12px; }

/* ---------------- CRUD / inputs ---------------- */
.icon-btn {
  width: 30px; height: 30px; border-radius: 9px;
  display: grid; place-items: center;
  color: var(--ink-faint); transition: all .15s ease; flex-shrink: 0;
}
.icon-btn:hover { background: var(--cream-2); color: var(--ink); }
.icon-btn.danger:hover { background: var(--terracotta-soft); color: var(--terracotta); }

.mini-input {
  background: var(--paper); border: 1px solid var(--line); border-radius: 9px;
  padding: 8px 12px; font-size: 14px; color: var(--ink); width: 100%;
  transition: border-color .15s ease;
}
.mini-input:focus { outline: none; border-color: var(--terracotta); }
.mini-input::placeholder { color: var(--ink-ghost); }

.add-row { display: flex; gap: 8px; align-items: center; margin-top: 14px; }
.btn-soft {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--cream-2); border: 1px solid var(--line); color: var(--ink-soft);
  font-weight: 500; font-size: 13px; padding: 9px 15px; border-radius: 30px;
  transition: all .15s ease; white-space: nowrap;
}
.btn-soft:hover { background: var(--paper); color: var(--ink); }
.btn-soft.accent { color: var(--terracotta); border-color: var(--terracotta-soft); background: var(--terracotta-soft); }
.btn-soft.accent:hover { background: var(--terracotta); color: white; border-color: var(--terracotta); }
.btn-soft.danger-soft { color: oklch(0.52 0.13 28); border-color: oklch(0.90 0.04 28); background: oklch(0.96 0.02 28); }
.btn-soft.danger-soft:hover { background: oklch(0.55 0.15 28); color: white; border-color: oklch(0.55 0.15 28); }

/* fila gestionable (revela acciones al pasar) */
.manage-row .row-actions { display: flex; gap: 2px; opacity: 0; transition: opacity .15s ease; }
.manage-row:hover .row-actions { opacity: 1; }

/* ---------------- Calendario de hábitos por fecha ---------------- */
.week-nav { display: flex; align-items: center; gap: 8px; }
.week-range { font-family: var(--mono); font-size: 13px; color: var(--ink-soft); min-width: 210px; text-align: center; white-space: nowrap; }
.habit-grid { display: grid; grid-template-columns: minmax(150px, 1.6fr) repeat(7, minmax(0, 1fr)) 64px; gap: 4px; }
.cal-head { display: flex; flex-direction: column; align-items: center; gap: 1px; }
.cal-head .wl { font-family: var(--mono); font-size: 11.5px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-faint); }

.cal {
  width: 40px; height: 48px; border-radius: 12px;
  border: 1.5px solid var(--line-soft); background: var(--paper);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
  transition: all .15s ease; cursor: pointer;
}
.cal:hover { border-color: var(--terracotta); }
.cal .d { font-family: var(--mono); font-size: 12px; color: var(--ink-soft); }
.cal .mk { width: 5px; height: 5px; border-radius: 50%; background: transparent; }
.cal.on { background: var(--sage); border-color: var(--sage); }
.cal.on .d { color: white; font-weight: 500; }
.cal.today { border-color: var(--terracotta); border-style: dashed; }
.cal.today.on { border-style: solid; }
.cal.future { opacity: .4; cursor: not-allowed; pointer-events: none; }

/* ---------------- Gratitud ---------------- */
.grat-row { display: flex; align-items: center; gap: 12px; margin-bottom: 11px; }
.grat-num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--ochre-soft); color: var(--terracotta-deep);
  display: grid; place-items: center;
  font-family: var(--mono); font-size: 12px; font-weight: 500; flex-shrink: 0;
}
.grat-input {
  flex: 1; background: var(--paper-2); border: 1px solid var(--line);
  border-radius: 10px; padding: 10px 13px; font-size: 14px; color: var(--ink);
  transition: border-color .15s ease;
}
.grat-input:focus { outline: none; border-color: var(--ochre); }
.grat-input::placeholder { color: var(--ink-ghost); }
.grat-item { display: flex; gap: 10px; align-items: baseline; padding: 5px 0; font-size: 14px; line-height: 1.5; }
.grat-item .dot { color: var(--ochre); font-weight: 700; flex-shrink: 0; }
.grat-item > span:last-child { flex: 1; min-width: 0; }

/* empty state */
.empty {
  text-align: center; color: var(--ink-faint); font-size: 14px;
  padding: 32px 16px; line-height: 1.5;
}

/* ---------------- Metas: dos columnas + drag & drop ---------------- */
.metas-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}
.goal-card { transition: box-shadow .18s ease, border-color .18s ease, opacity .15s ease, outline-color .15s ease; outline: 2px solid transparent; outline-offset: 1px; }
.goal-card:hover { box-shadow: var(--sh-md); }
.goal-card .goal-edit { opacity: 0; transition: opacity .15s ease; }
.goal-card:hover .goal-edit { opacity: 1; }
.goal-card.drop-target { outline-color: var(--terracotta); }
.goal-card.dragging { opacity: .45; }
.grip {
  cursor: grab; padding: 6px 2px; display: grid; place-items: center;
  align-self: center; border-radius: 7px; flex-shrink: 0; color: var(--ink-ghost);
  transition: background .15s ease;
}
.grip:hover { background: var(--cream-2); }
.grip:active { cursor: grabbing; }

/* drag & drop de tareas dentro de un objetivo */
.task-grip {
  cursor: grab; display: grid; place-items: center; flex-shrink: 0;
  width: 20px; height: 20px; border-radius: 6px; color: var(--ink-ghost);
  opacity: 0; transition: opacity .15s ease, background .15s ease;
}
.manage-row:hover .task-grip { opacity: .85; }
.task-grip:hover { background: var(--cream-2); opacity: 1; }
.task-grip:active { cursor: grabbing; }
.task.task-drag-over { box-shadow: inset 0 2px 0 var(--terracotta); }
.task.task-dragging { opacity: .4; }

/* ---------------- Estado físico ---------------- */
.metrics-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.metric-tile { padding: 18px 20px; }
.metric-head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.metric-ico { width: 32px; height: 32px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0; }
.metric-label { font-size: 13px; color: var(--ink-soft); font-weight: 500; }
.metric-value { font-size: 28px; font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
.metric-unit { font-size: 14px; font-weight: 500; color: var(--ink-faint); }
.metric-foot { display: flex; align-items: flex-end; justify-content: space-between; margin-top: 10px; min-height: 30px; gap: 8px; }
.metric-sub { font-size: 12px; color: var(--ink-faint); }
.metric-tile.balance { background: linear-gradient(135deg, oklch(0.985 0.012 60), var(--paper)); }

.nl-card { border: 1px solid var(--line); }
.nl-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.nl-input { margin-top: 0; }
.nl-foot { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-top: 12px; flex-wrap: wrap; }
.nl-toast {
  margin-top: 12px; padding: 11px 14px; border-radius: var(--r-md); font-size: 13.5px; line-height: 1.45;
}
.nl-toast.ok  { background: var(--sage-soft); color: oklch(0.42 0.06 150); }
.nl-toast.err { background: var(--terracotta-soft); color: var(--terracotta-deep); }

.body-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.body-stat { background: var(--paper-2); border: 1px solid var(--line-soft); border-radius: var(--r-md); padding: 16px; }
.bs-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-ghost); }
.bs-val { font-size: 26px; font-weight: 700; letter-spacing: -0.02em; margin: 6px 0 4px; }
.bs-val small { font-size: 14px; font-weight: 500; color: var(--ink-faint); }
.body-legend { display: flex; gap: 24px; margin-top: 14px; font-size: 12.5px; color: var(--ink-soft); flex-wrap: wrap; }
.body-legend b { color: var(--ink); font-weight: 600; }

/* ---------------- Tareas: prioridad + deadline ---------------- */
.task {
  position: relative;
  display: flex; align-items: center; gap: 13px;
  padding: 12px 4px 12px 14px;
  border-bottom: 1px solid var(--line-soft);
  transition: opacity .2s ease;
}
.task .prio-bar {
  position: absolute; left: 0; top: 9px; bottom: 9px; width: 4px; border-radius: 4px;
}
.task.done .prio-bar { opacity: .3; }

.task-meta { flex-wrap: wrap; }
.prio-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600; padding: 2px 9px; border-radius: 20px;
  white-space: nowrap;
}
.prio-pill .pd { width: 6px; height: 6px; border-radius: 50%; }
.deadline {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 11px; font-weight: 500; padding: 2px 8px;
  border-radius: 20px; white-space: nowrap; color: var(--ink-faint);
  background: var(--cream-2);
}
.deadline.overdue { color: oklch(0.52 0.13 28); background: oklch(0.93 0.04 28); }
.deadline.today   { color: var(--terracotta-deep); background: var(--terracotta-soft); }
.deadline.soon    { color: oklch(0.50 0.09 80); background: var(--ochre-soft); }
.repeat-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 500; padding: 2px 9px; border-radius: 20px; white-space: nowrap;
  color: var(--cat-mente); background: var(--cat-mente-tint);
}
.repeat-pill.done-pill { color: var(--ink-faint); background: var(--cream-2); }
.subtask-badge, .note-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 20px; white-space: nowrap;
  color: var(--ink-soft); background: var(--cream-2); border: 1px solid var(--line-soft); cursor: pointer;
}
.note-badge { cursor: default; }
.task-note { font-size: 12.5px; color: var(--ink-faint); margin-top: 4px; line-height: 1.45; white-space: pre-wrap; }
.subtask-list { margin-top: 8px; padding-left: 2px; display: flex; flex-direction: column; gap: 5px; }
.subtask-row { display: flex; align-items: center; gap: 9px; margin-top: 6px; }
.subtask-row.view { margin-top: 0; }
.subtask-editor { margin-top: 12px; padding: 12px; background: var(--paper-2); border-radius: 11px; }
.subtask-editor-head { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-faint); margin-bottom: 8px; }
.check.sm { width: 16px; height: 16px; flex-shrink: 0; }
.subtask-name { flex: 1; font-size: 13.5px; color: var(--ink-soft); }
.subtask-name.done { text-decoration: line-through; color: var(--ink-faint); }

.task-filter { display: inline-flex; gap: 2px; }
.task-filter button {
  font-size: 12.5px; font-weight: 500; color: var(--ink-faint);
  padding: 5px 11px; border-radius: 20px; transition: all .15s ease;
}
.task-filter button.active { background: var(--cream-2); color: var(--ink); }
.task-add-btn { width: 32px; height: 32px; padding: 0; border-radius: 50%; display: inline-grid; place-items: center; flex-shrink: 0; }

/* ===========================================================
   Acceso / login
   =========================================================== */
.login-screen {
  min-height: 100vh; min-height: 100dvh; display: grid; place-items: center;
  padding: 24px; background:
    radial-gradient(120% 80% at 50% 0%, color-mix(in oklab, var(--terracotta), var(--cream) 86%), var(--cream) 70%);
}
.login-card {
  width: 100%; max-width: 408px; background: var(--paper); border: 1px solid var(--line);
  border-radius: 22px; box-shadow: var(--sh-lg); padding: 30px 28px;
}
.login-brand { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.login-title { font-size: 24px; font-weight: 700; letter-spacing: -0.02em; }
.login-sub { font-size: 13px; color: var(--ink-faint); margin-top: 1px; white-space: nowrap; }
.login-brand .brand-text, .login-brand > div:last-child { min-width: 0; }
.login-seg { width: 100%; display: flex; margin-bottom: 20px; }
.login-seg button { flex: 1; }
.login-fields { display: flex; flex-direction: column; gap: 14px; }
.login-field { display: flex; flex-direction: column; gap: 6px; }
.login-field > span { font-size: 12px; font-weight: 600; color: var(--ink-soft); }
.login-field .mini-input { width: 100%; }
.login-remember { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--ink-soft); cursor: pointer; margin-top: 2px; }
.login-remember input { width: 16px; height: 16px; accent-color: var(--terracotta); flex-shrink: 0; }
.login-submit { width: 100%; justify-content: center; margin-top: 6px; padding: 12px; font-size: 15px; }
.login-note {
  display: flex; gap: 9px; align-items: flex-start; margin-top: 20px; padding-top: 18px;
  border-top: 1px solid var(--line-soft); font-size: 12px; line-height: 1.5; color: var(--ink-faint);
}
.login-note svg { flex-shrink: 0; margin-top: 2px; }

/* panel de administración de perfiles */
.profiles-list { display: flex; flex-direction: column; gap: 8px; }
.profile-row { display: flex; align-items: center; gap: 11px; padding: 10px 12px; border: 1px solid var(--line-soft); border-radius: 12px; background: var(--paper-2); }
.profile-row.active { border-color: var(--terracotta); }
.profile-badge { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--terracotta); margin-left: 8px; }

/* composer de tarea */
.composer {
  background: var(--paper-2); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 14px; margin-bottom: 14px;
}
.composer .field-row { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-top: 10px; }
.field {
  display: flex; flex-direction: column; gap: 5px;
}
.field-lbl { font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-ghost); }
.select, .date-input {
  background: var(--paper); border: 1px solid var(--line); border-radius: 9px;
  padding: 8px 11px; font-size: 13.5px; color: var(--ink); font-family: var(--sans);
}
.select:focus, .date-input:focus { outline: none; border-color: var(--terracotta); }
.prio-choose { display: inline-flex; background: var(--paper); border: 1px solid var(--line); border-radius: 9px; padding: 3px; gap: 2px; }
.prio-choose button {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 11px; border-radius: 7px; font-size: 12.5px; font-weight: 500; color: var(--ink-soft);
  transition: all .15s ease;
}
.prio-choose button .pd { width: 7px; height: 7px; border-radius: 50%; }
.prio-choose button.active { background: var(--cream-2); color: var(--ink); }

/* ---------------- Feedback de guardado ---------------- */
.save-bar { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.save-bar .save-btn { margin-left: auto; }
.save-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--terracotta); color: #fff; border: none;
  font-size: 14px; font-weight: 600; padding: 9px 18px; border-radius: 11px;
  cursor: pointer; transition: background .18s ease, transform .12s ease;
  box-shadow: var(--sh-sm);
}
.save-btn:hover { background: var(--terracotta-deep); }
.save-btn:active { transform: translateY(1px); }
.save-btn:disabled { opacity: .5; cursor: default; }
.save-btn.is-saved { background: var(--sage); }
.save-btn .save-btn-ico { display: grid; place-items: center; }

/* entrada del periodo actual ya guardada + botón editar */
.entry-today { border-top: 3px solid var(--sage); }
.entry-edit {
  display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px; font-weight: 600;
  color: var(--ink-soft); background: var(--cream-2); border-radius: 999px; padding: 5px 12px;
  transition: background .15s ease, color .15s ease;
}
.entry-edit:hover { background: var(--terracotta-soft); color: var(--terracotta-deep); }
.intent-hist { border-left: 3px solid var(--terracotta-soft); }

/* selector de fecha para entradas (gratitud/intención/reflexión) */
.entry-datebar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.entry-datebar-lbl { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); }
.entry-datebar-ctrl { display: inline-flex; align-items: center; gap: 2px; background: var(--paper); border: 1px solid var(--line); border-radius: 11px; padding: 3px; box-shadow: var(--sh-sm); }
.date-step { width: 30px; height: 30px; border-radius: 8px; font-size: 18px; line-height: 1; color: var(--ink-soft); display: grid; place-items: center; transition: background .15s ease, color .15s ease; }
.date-step:hover:not(:disabled) { background: var(--cream-2); color: var(--terracotta); }
.date-step:disabled { opacity: .3; cursor: default; }
.entry-datebar-ctrl .date-input { border: none; box-shadow: none; padding: 6px 8px; background: transparent; font-family: var(--mono); }
.entry-datebar-ctrl .date-input:focus { border: none; }
.btn-soft.sm { padding: 6px 12px; font-size: 12.5px; }

/* aviso de entrada ya guardada para la fecha elegida */
.locked-note { display: flex; align-items: center; gap: 14px; }

/* entradas de histórico colapsables */
.hist-entry { padding: 0; overflow: hidden; }
.hist-head {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  padding: 15px 18px; background: transparent; border: none; cursor: pointer;
}
.hist-head:hover { background: var(--cream); }
.hist-head-main { display: flex; align-items: baseline; gap: 12px; min-width: 0; flex: 1; }
.hist-head-main .eyebrow { flex-shrink: 0; }
.hist-preview { font-size: 13.5px; color: var(--ink-faint); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.hist-chev { display: inline-flex; flex-shrink: 0; transition: transform .2s ease; }
.hist-body { padding: 0 18px 18px; }

/* ===========================================================
   Hábitos de reflexión (seguimiento paralelo, solo lectura)
   =========================================================== */
.refl-habits { display: flex; flex-direction: column; gap: 8px; }
.today-habits { display: flex; flex-direction: column; gap: 6px; margin-bottom: 4px; }
.today-habit {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  padding: 11px 12px; border-radius: 12px; background: var(--paper-2); border: 1px solid var(--line-soft);
  cursor: pointer; transition: background .14s ease, border-color .14s ease;
}
.today-habit:hover { border-color: var(--ink-faint); }
.today-habit.done { background: var(--sage-soft); border-color: transparent; }
.th-check {
  width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center;
  border: 2px solid var(--line); transition: background .14s ease, border-color .14s ease;
}
.th-check.on { background: var(--sage); border-color: var(--sage); }
.th-ico { display: grid; place-items: center; width: 28px; height: 28px; border-radius: 8px; background: var(--cream-2); color: var(--terracotta); flex-shrink: 0; }
.today-habit.done .th-ico { background: transparent; }
.th-name { flex: 1; font-size: 14.5px; font-weight: 500; min-width: 0; }
.today-habit.done .th-name { color: var(--ink-soft); }
.th-streak { display: inline-flex; align-items: center; gap: 3px; font-family: var(--mono); font-size: 12px; color: var(--ink-faint); flex-shrink: 0; }

.refl-habits-head {
  display: flex; align-items: center; gap: 7px; margin: 18px 0 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint);
  border-top: 1px solid var(--line-soft); padding-top: 16px;
}
.refl-habit-row {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  padding: 11px 12px; border-radius: 12px; background: var(--paper-2);
  border: 1px solid var(--line-soft); transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.refl-habit-row:hover { background: var(--cream); border-color: var(--line); }
.refl-habit-row:active { transform: translateY(1px); }
.refl-habit-row.done { background: var(--sage-soft); border-color: transparent; }
.rh-check {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
  display: grid; place-items: center; background: var(--cream-2);
  border: 1.5px solid var(--line); transition: background .15s ease, border-color .15s ease;
}
.rh-check.on { background: var(--sage); border-color: var(--sage); }
.rh-body { display: flex; flex-direction: column; gap: 1px; flex: 1; min-width: 0; }
.rh-name { font-size: 14.5px; font-weight: 600; }
.rh-sub { font-size: 12px; color: var(--ink-faint); }
.refl-habit-row.done .rh-sub { color: var(--sage); font-weight: 500; }
.rh-dots { display: flex; gap: 4px; flex-shrink: 0; }
.rh-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--cream-2); border: 1px solid var(--line-soft); }
.rh-dot.on { background: var(--terracotta); border-color: var(--terracotta); }
.rh-dot.today { box-shadow: 0 0 0 2px var(--paper), 0 0 0 3px var(--ink-ghost); }
.rh-flame { display: inline-flex; align-items: center; gap: 4px; flex-shrink: 0; font-family: var(--mono); font-weight: 600; font-size: 14px; color: var(--ink-soft); }
.refl-habits.compact .refl-habit-row { padding: 9px 11px; }
.refl-habits.compact .rh-name { font-size: 13.5px; }
.saved-hint {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12.5px; color: var(--ink-faint); transition: color .2s ease;
}
.saved-hint.flash { color: var(--sage); font-weight: 500; }
.saved-hint .sdot { width: 7px; height: 7px; border-radius: 50%; background: var(--ink-ghost); transition: background .2s ease; }
.saved-hint.flash .sdot { background: var(--sage); }

/* ---------------- Topbar móvil ---------------- */
.topbar-mobile { display: none; }

/* ---------------- Grabador de voz ---------------- */
.nl-input-wrap { position: relative; }
.nl-input-wrap .nl-input { padding-right: 52px; }
.nl-input-wrap .mic-btn { position: absolute; right: 10px; bottom: 10px; }
.mic-btn {
  position: relative; flex-shrink: 0;
  width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--paper); border: 1px solid var(--line); color: var(--ink-soft);
  cursor: pointer; transition: all .16s ease;
}
.mic-btn:hover:not(:disabled) { border-color: var(--terracotta); color: var(--terracotta); }
.mic-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.mic-btn.on { background: var(--terracotta); border-color: var(--terracotta); color: white; }
.mic-pulse {
  position: absolute; inset: -4px; border-radius: 50%;
  border: 2px solid var(--terracotta); opacity: 0.6;
  animation: micPulse 1.3s ease-out infinite;
}
@keyframes micPulse {
  0% { transform: scale(0.85); opacity: 0.7; }
  100% { transform: scale(1.35); opacity: 0; }
}

/* ---------------- Asistente / chatbot ---------------- */
.assistant-card { display: flex; flex-direction: column; max-width: 820px; }
.assistant-head { display: flex; align-items: center; gap: 12px; margin-bottom: 4px; padding-bottom: 16px; border-bottom: 1px solid var(--line-soft); }
.chat-scroll {
  display: flex; flex-direction: column; gap: 16px;
  min-height: 320px; max-height: min(56vh, 560px); overflow-y: auto;
  padding: 20px 4px; scroll-behavior: smooth;
}
.chat-empty { margin: auto; text-align: center; max-width: 520px; padding: 16px; }
.chat-empty-ico {
  width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 14px;
  display: grid; place-items: center; background: var(--cat-mente-tint);
}
.chat-empty-title { font-size: 19px; font-weight: 600; letter-spacing: -0.01em; }
.chat-empty-sub { font-size: 13.5px; color: var(--ink-soft); margin: 6px 0 16px; }
.chat-suggestions { display: flex; flex-direction: column; gap: 10px; }
.chat-chip {
  text-align: left; background: var(--paper-2); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 12px 15px; font-size: 13.5px; color: var(--ink-soft);
  cursor: pointer; transition: all .15s ease; line-height: 1.4;
}
.chat-chip:hover { border-color: var(--terracotta); color: var(--ink); background: var(--paper); }
.chat-weekly {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 16px;
  background: var(--cat-mente-tint); color: var(--cat-mente); border: 1px solid transparent;
  border-radius: 999px; padding: 9px 16px; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all .15s ease;
}
.chat-weekly:hover { border-color: var(--cat-mente); }
.chat-weekly:disabled { opacity: .5; cursor: default; }
.aw-icon:disabled { opacity: .45; cursor: default; }

.chat-msg { display: flex; flex-direction: column; gap: 8px; max-width: 82%; }
.chat-msg.user { align-self: flex-end; align-items: flex-end; }
.chat-msg.assistant { align-self: flex-start; align-items: flex-start; }
.chat-bubble {
  padding: 12px 16px; border-radius: 16px; font-size: 14.5px; line-height: 1.5;
  white-space: pre-wrap; word-break: break-word;
}
.chat-msg.user .chat-bubble { background: var(--terracotta); color: white; border-bottom-right-radius: 5px; }
.chat-msg.assistant .chat-bubble { background: var(--paper-2); border: 1px solid var(--line-soft); color: var(--ink); border-bottom-left-radius: 5px; }
.chat-applied { display: flex; flex-wrap: wrap; gap: 7px; }
.applied-chip {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--sage-soft); color: oklch(0.42 0.06 150);
  border-radius: 40px; padding: 5px 11px; font-size: 12px; font-weight: 500;
}
.undo-chip {
  display: inline-flex; align-items: center; gap: 5px;
  background: transparent; color: var(--ink-soft);
  border: 1px solid var(--line); border-radius: 40px; padding: 4px 11px;
  font-size: 12px; font-weight: 500; cursor: pointer; transition: background .12s ease, border-color .12s ease;
}
.undo-chip:hover { background: var(--cream-2); border-color: var(--ink-faint); color: var(--ink); }

/* avisos proactivos del asistente */
.nudge-block { width: 100%; margin: 4px 0 16px; text-align: left; }
.nudge-head { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--ochre); display: flex; align-items: center; gap: 5px; margin-bottom: 8px; }
.nudge {
  display: flex; align-items: center; justify-content: space-between; gap: 10px; width: 100%;
  text-align: left; padding: 10px 12px; margin-bottom: 6px; border-radius: 11px;
  background: var(--paper-2); border: 1px solid var(--line-soft); cursor: default;
  font-size: 13px; line-height: 1.4; color: var(--ink-soft);
}
.nudge.actionable { cursor: pointer; }
.nudge.actionable:hover { border-color: var(--cat-mente); background: var(--cat-mente-tint); color: var(--ink); }
.nudge-banner { padding: 12px 14px; border-bottom: 1px solid var(--line-soft); background: var(--cream-1, var(--paper-2)); }
.nudge-banner .nudge-head { justify-content: flex-start; position: relative; }
.nudge-x { margin-left: auto; background: transparent; border: none; cursor: pointer; color: var(--ink-faint); padding: 2px; border-radius: 6px; display: inline-flex; }
.nudge-x:hover { background: rgba(0,0,0,.05); }
.fab-count {
  position: absolute; top: -3px; right: -3px; min-width: 19px; height: 19px; padding: 0 5px;
  border-radius: 20px; background: var(--terracotta); color: #fff; font-size: 11px; font-weight: 700;
  display: grid; place-items: center; border: 2px solid var(--paper); font-family: var(--mono);
}

.chat-bubble.typing { display: flex; gap: 5px; align-items: center; }
.chat-bubble.typing span {
  width: 7px; height: 7px; border-radius: 50%; background: var(--ink-ghost);
  animation: typingDot 1s infinite ease-in-out;
}
.chat-bubble.typing span:nth-child(2) { animation-delay: .18s; }
.chat-bubble.typing span:nth-child(3) { animation-delay: .36s; }
@keyframes typingDot { 0%, 60%, 100% { opacity: 0.3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-3px); } }

.chat-input-row {
  display: flex; align-items: flex-end; gap: 10px;
  padding-top: 16px; border-top: 1px solid var(--line-soft);
}
.chat-input { margin-top: 0; flex: 1; resize: none; min-height: 44px; max-height: 140px; }
.chat-send { width: 44px; height: 44px; padding: 0; justify-content: center; flex-shrink: 0; border-radius: 12px; }
.chat-send:disabled { cursor: not-allowed; }

/* polishing spinner del micrófono */
.mic-btn.polishing { border-color: var(--terracotta-soft); }
.mic-spin {
  width: 16px; height: 16px; border-radius: 50%;
  border: 2px solid var(--line); border-top-color: var(--terracotta);
  animation: micSpin .7s linear infinite;
}
@keyframes micSpin { to { transform: rotate(360deg); } }

/* ---------------- Asistente flotante ---------------- */
.assistant-fab-wrap {
  position: fixed; right: 26px; bottom: 26px; z-index: 60;
  display: flex; flex-direction: column; align-items: flex-end; gap: 16px;
}
.assistant-fab {
  position: relative; width: 60px; height: 60px; border-radius: 50%;
  background: var(--terracotta); border: none; cursor: pointer;
  display: grid; place-items: center; box-shadow: var(--sh-lg);
  transition: transform .16s ease, background .16s ease;
}
.assistant-fab:hover { background: var(--terracotta-deep); transform: translateY(-2px); }
.assistant-fab:active { transform: translateY(0); }
.assistant-fab.open { width: 50px; height: 50px; }
.fab-dot {
  position: absolute; top: 12px; right: 12px; width: 10px; height: 10px;
  border-radius: 50%; background: var(--ochre); border: 2px solid var(--terracotta);
}

.assistant-window {
  width: 384px; max-width: calc(100vw - 40px);
  max-height: min(640px, 78vh);
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-xl); box-shadow: var(--sh-lg);
  display: flex; flex-direction: column; overflow: hidden;
}
.aw-head {
  display: flex; align-items: center; gap: 11px;
  padding: 13px 14px; border-bottom: 1px solid var(--line-soft);
  background: linear-gradient(135deg, oklch(0.985 0.012 60), var(--paper));
}
.aw-title { font-size: 15px; font-weight: 600; letter-spacing: -0.01em; }
.aw-sub { font-size: 11.5px; color: var(--ink-soft); margin-top: 1px; }
.aw-icon {
  width: 32px; height: 32px; border-radius: 9px; flex-shrink: 0;
  display: grid; place-items: center; background: transparent; border: none;
  color: var(--ink-faint); cursor: pointer; transition: all .15s ease;
}
.aw-icon:hover { background: var(--cream-2); color: var(--ink); }

.assistant-window .chat-scroll {
  flex: 1; min-height: 0; max-height: none;
  padding: 16px 14px; gap: 14px;
}
.assistant-window .chat-msg { max-width: 90%; }
.assistant-window .chat-bubble { font-size: 14px; }
.assistant-window .chat-input-row { padding: 12px; }
.assistant-window .chat-empty-title { font-size: 17px; }

@media (max-width: 520px) {
  .assistant-fab-wrap { right: 16px; bottom: 16px; }
  .assistant-window { max-height: 72vh; }
}

/* ---------------- Responsive ---------------- */
@media (max-width: 1080px) {
  .main-inner { padding: 32px 30px 70px; }
}

@media (max-width: 900px) {
  /* sidebar pasa a off-canvas; ignorar columna colapsada */
  .app, .app.nav-collapsed { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed; top: 0; left: 0; bottom: 0; width: 264px; z-index: 50;
    transform: translateX(-100%); transition: transform .25s cubic-bezier(.4,0,.2,1);
    box-shadow: var(--sh-lg);
  }
  .app.nav-open .sidebar { transform: translateX(0); }
  /* en móvil mostramos siempre completo dentro del panel */
  .app.nav-collapsed .brand-text,
  .app.nav-collapsed .nav-label,
  .app.nav-collapsed .nav-item span:not(.nav-ico):not(.nav-badge),
  .app.nav-collapsed .area-item span:not(.area-dot),
  .app.nav-collapsed .nav-badge,
  .app.nav-collapsed .user-card > div:not(.avatar) { display: block; }
  .app.nav-collapsed .nav-item, .app.nav-collapsed .area-item { justify-content: flex-start; padding-left: 12px; gap: 12px; }
  .nav-toggle.in-sidebar { display: none; }

  .app.nav-open .nav-scrim {
    display: block; position: fixed; inset: 0; z-index: 40;
    background: oklch(0.3 0.02 55 / 0.32);
  }
  .topbar-mobile {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    padding: 14px 20px; border-bottom: 1px solid var(--line); background: var(--cream-2);
    position: sticky; top: 0; z-index: 20;
  }
  .topbar-mobile .tm-brand { display: flex; align-items: center; gap: 9px; font-weight: 700; font-size: 16px; }
  .topbar-mobile .tm-brand img { width: 28px; height: 28px; }
  .main-inner { padding: 22px 20px 70px; }
  .topbar { flex-direction: column; align-items: stretch; gap: 16px; }
  .greeting h1 { font-size: 25px; white-space: normal; }
  .topbar-actions { justify-content: space-between; }
}

@media (max-width: 760px) {
  /* apilar columnas del dashboard */
  .dash-2col { grid-template-columns: 1fr !important; }
  .metas-grid { grid-template-columns: 1fr; }
  .metrics-grid { grid-template-columns: repeat(2, 1fr); }
  .body-grid { grid-template-columns: repeat(2, 1fr); }
  .badges, .dash-2col .badges { grid-template-columns: repeat(2, 1fr); }
  .chart-legend { gap: 10px; }
}

@media (max-width: 520px) {
  .seg { display: flex; width: 100%; flex-wrap: nowrap; }
  .seg button { flex: 1; padding: 9px 6px; font-size: 12px; text-align: center; }
  .metrics-grid { grid-template-columns: 1fr; }
  .composer .field-row { flex-direction: column; align-items: stretch; }
  .composer .field { width: 100%; }
  .composer .select, .composer .date-input { width: 100%; }
}

/* ===========================================================
   Intención del día + resumen de consumo (Inicio)
   =========================================================== */
.intention-bar {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 14px 18px; box-shadow: var(--sh-sm);
}
.intention-main { display: flex; align-items: center; gap: 12px; flex: 1 1 280px; min-width: 0; }
.intention-field { display: flex; flex-direction: column; gap: 1px; flex: 1; min-width: 0; }
.intention-lbl { font-family: var(--mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); }
.intention-input {
  border: none; background: none; outline: none; color: var(--ink);
  font-size: 16px; font-weight: 500; width: 100%; min-width: 0; padding: 2px 0;
  font-family: inherit; line-height: 1.4; resize: none; overflow: hidden; display: block;
}
.intention-input::placeholder { color: var(--ink-ghost); font-weight: 400; }
.intention-intake { display: flex; gap: 8px; flex-wrap: wrap; flex-shrink: 0; }
.intake-chip {
  display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px; font-weight: 600;
  color: var(--ink-soft); background: var(--cream-2); border-radius: 999px; padding: 6px 11px;
  font-family: var(--mono); transition: background .15s ease;
}
.intention-intake:hover .intake-chip { background: var(--cream); }
.intention-savehint { flex-shrink: 0; white-space: nowrap; }
/* cuando el propio widget es estrecho (no el viewport): apilar y dar todo el ancho al texto */
@container (max-width: 520px) {
  .intention-savehint { display: none; }
  .intention-main { flex: 1 1 100%; }
  .intention-intake { width: 100%; }
  .intention-intake .intake-chip { flex: 1; justify-content: center; }
}

/* ===========================================================
   Navegación inferior (móvil)
   =========================================================== */
.bottom-nav { display: none; }
@media (max-width: 900px) {
  .bottom-nav {
    display: grid; grid-auto-flow: column; grid-auto-columns: 1fr;
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 45;
    background: oklch(0.975 0.010 78 / 0.94); backdrop-filter: blur(12px) saturate(1.4);
    border-top: 1px solid var(--line);
    padding: 6px 4px calc(6px + env(safe-area-inset-bottom));
  }
  .bn-item {
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    padding: 6px 2px; border-radius: 12px; color: var(--ink-faint);
    transition: color .15s ease, background .15s ease;
  }
  .bn-item .bn-ico { display: grid; place-items: center; }
  .bn-label { font-size: 10.5px; font-weight: 600; letter-spacing: .01em; }
  .bn-item.active { color: var(--terracotta); }
  .bn-item.active .bn-ico { transform: translateY(-1px); }
  .bn-item:active { background: var(--cream-2); }

  /* dejar aire para la barra inferior y el FAB del asistente */
  .main-inner { padding-bottom: 96px; }
  .assistant-fab-wrap { bottom: calc(72px + env(safe-area-inset-bottom)); }
}

/* ===========================================================
   Ajustes — preferencias + copia de seguridad
   =========================================================== */
.pref-list { display: flex; flex-direction: column; }
.pref-row {
  display: flex; align-items: center; gap: 16px; padding: 16px 0;
  border-bottom: 1px solid var(--line-soft);
}
.pref-row:last-child { border-bottom: none; }
.pref-text { flex: 1; min-width: 0; }
.pref-label { font-size: 15px; font-weight: 600; }
.pref-sub { font-size: 12.5px; color: var(--ink-faint); margin-top: 2px; }
.stepper { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.step-btn {
  width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center;
  background: var(--cream-2); color: var(--ink-soft); transition: background .15s ease, color .15s ease;
}
.step-btn:hover { background: var(--terracotta-soft); color: var(--terracotta-deep); }
.step-glyph { font-size: 20px; line-height: 1; font-weight: 500; }
.step-value { display: flex; align-items: baseline; gap: 4px; min-width: 96px; justify-content: center; }
.step-input {
  width: 62px; text-align: right; border: none; background: none; outline: none;
  font-family: var(--mono); font-size: 19px; font-weight: 500; color: var(--ink);
  border-bottom: 1.5px solid transparent; transition: border-color .15s ease;
}
.step-input:focus { border-bottom-color: var(--terracotta); }
.step-unit { font-size: 12px; color: var(--ink-faint); font-family: var(--mono); }

.backup-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 6px 0 18px; }
.bk-stat {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  background: var(--paper-2); border: 1px solid var(--line-soft); border-radius: var(--r-sm); padding: 14px 8px;
}
.bk-n { font-family: var(--mono); font-size: 24px; font-weight: 500; color: var(--terracotta-deep); }
.bk-l { font-size: 11.5px; color: var(--ink-faint); text-align: center; }
.backup-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* selector de tema */
.theme-choose { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.theme-opt {
  display: flex; flex-direction: column; align-items: center; gap: 7px; padding: 16px 10px;
  border: 1.5px solid var(--line); border-radius: 13px; background: var(--paper-2);
  color: var(--ink-soft); font-size: 13px; font-weight: 500; cursor: pointer;
  transition: border-color .14s ease, color .14s ease, background .14s ease;
}
.theme-opt:hover { border-color: var(--ink-faint); }
.theme-opt.active { border-color: var(--terracotta); color: var(--terracotta); background: var(--terracotta-soft); }

/* ===========================================================
   Perfil
   =========================================================== */
.profile-view { max-width: 760px; }
.profile-hero { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.profile-photo-wrap { position: relative; flex-shrink: 0; }
.profile-avatar-img { border-radius: 50%; object-fit: cover; box-shadow: var(--sh-sm); }
.profile-avatar-fallback {
  border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 700;
  background: linear-gradient(150deg, var(--cat-alma), var(--terracotta)); box-shadow: var(--sh-sm);
}
.profile-photo-edit {
  position: absolute; right: 2px; bottom: 2px; width: 30px; height: 30px; border-radius: 50%;
  background: var(--terracotta); display: grid; place-items: center; cursor: pointer;
  border: 3px solid var(--paper); box-shadow: var(--sh-sm);
}
.profile-hero-main { flex: 1; min-width: 240px; }
.profile-name-row { display: flex; align-items: center; }
.profile-name-row .profile-avatar-fallback, .profile-name-row .profile-avatar-img { display: none; }
.profile-name-input {
  font-size: 26px; font-weight: 700; letter-spacing: -0.02em; color: var(--ink);
  border: none; background: none; outline: none; width: 100%; padding: 2px 4px; border-radius: 8px;
}
.profile-name-input:focus { background: var(--cream-2); }
.profile-tagline-input {
  font-size: 14px; color: var(--ink-soft); border: none; background: none; outline: none;
  width: 100%; padding: 4px; margin-top: 4px; border-radius: 8px;
}
.profile-tagline-input:focus { background: var(--cream-2); }

.accent-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.accent-swatch {
  display: flex; align-items: center; gap: 10px; padding: 12px 14px; cursor: pointer;
  border: 1.5px solid var(--line); border-radius: 13px; background: var(--paper-2);
  transition: border-color .14s ease, background .14s ease;
}
.accent-swatch:hover { border-color: var(--ink-faint); }
.accent-swatch.active { border-color: var(--terracotta); background: var(--terracotta-soft); }
.accent-dot { width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center; box-shadow: inset 0 0 0 1px rgba(0,0,0,.08); }
.accent-name { font-size: 13.5px; font-weight: 600; color: var(--ink-soft); }
.link-btn { color: var(--terracotta); font-weight: 600; text-decoration: underline; }
@media (max-width: 560px) { .accent-grid { grid-template-columns: repeat(2, 1fr); } }

/* selector de plantillas de metas */
.tpl-box { width: 100%; max-width: 720px; background: var(--paper); border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--sh-lg); overflow: hidden; }
.tpl-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; padding: 18px 20px; border-bottom: 1px solid var(--line-soft); }
.tpl-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; padding: 18px; max-height: 64vh; overflow-y: auto; }
.tpl-card { text-align: left; padding: 16px; border: 1px solid var(--line); border-top: 3px solid var(--ink); border-radius: 14px; background: var(--paper-2); cursor: pointer; transition: transform .12s ease, box-shadow .12s ease; }
.tpl-card:hover { transform: translateY(-2px); box-shadow: var(--sh-md); }
.tpl-name { font-size: 15.5px; font-weight: 600; margin-top: 10px; }
.tpl-meta { font-size: 11.5px; color: var(--ink-faint); font-family: var(--mono); margin-top: 3px; }
.tpl-why { font-size: 13px; color: var(--ink-soft); margin-top: 8px; line-height: 1.45; }
@media (max-width: 620px) { .tpl-grid { grid-template-columns: 1fr; } }

/* ===========================================================
   Aviso de copia de seguridad (Inicio)
   =========================================================== */
.backup-banner {
  display: flex; align-items: center; gap: 14px; margin: 0 0 22px;
  padding: 14px 18px; border-radius: 16px;
  background: var(--cat-cuerpo-tint, #f6efe3); border: 1px solid var(--ochre);
}
.bb-ico { display: inline-grid; place-items: center; width: 34px; height: 34px; border-radius: 10px; background: #fff; flex-shrink: 0; }
.bb-text { flex: 1; min-width: 0; font-size: 13.5px; line-height: 1.45; color: var(--ink-soft); }
.bb-close { width: 30px; height: 30px; display: grid; place-items: center; border: none; background: transparent; border-radius: 8px; cursor: pointer; transform: rotate(45deg); color: var(--ink-faint); flex-shrink: 0; }
.bb-close:hover { background: rgba(0,0,0,.05); }
.auto-snap { display: flex; align-items: center; gap: 8px; margin-top: 12px; font-size: 12.5px; color: var(--ink-soft); flex-wrap: wrap; }

.archived-habits > summary {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer; list-style: none;
  font-size: 13.5px; font-weight: 500; color: var(--ink-soft); padding: 8px 0;
}
.archived-habits > summary::-webkit-details-marker { display: none; }
.archived-habits > summary:hover { color: var(--ink); }
.archived-card { padding: 0 !important; }

/* ===========================================================
   Anillos de nutrición (Inicio)
   =========================================================== */
.nutri-rings { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.nutri-ring {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: transparent; border: none; cursor: pointer; padding: 10px 6px 8px; border-radius: 14px;
  transition: background .14s ease;
}
.nutri-ring:hover { background: var(--cream-2); }
.nutri-val { font-family: var(--mono); font-size: 17px; font-weight: 600; color: var(--ink); margin-top: 8px; }
.nutri-unit { font-size: 11px; font-weight: 500; color: var(--ink-faint); margin-left: 1px; }
.nutri-lbl { font-size: 12.5px; font-weight: 500; color: var(--ink-soft); }
.nutri-goal { font-size: 11px; color: var(--ink-faint); font-family: var(--mono); }

/* ánimo / energía */
.mood-block { margin-bottom: 14px; }
.mood-block:last-child { margin-bottom: 0; }
.mood-label { font-size: 13px; font-weight: 600; color: var(--ink-soft); margin-bottom: 7px; }
.mood-pick { font-weight: 500; color: var(--ink-faint); margin-left: 4px; }
.mood-dots { display: grid; grid-template-columns: repeat(5, 1fr); gap: 7px; }
.mood-dot {
  height: 38px; border-radius: 11px; border: 1.5px solid var(--line); background: var(--paper-2);
  font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--ink-faint); cursor: pointer;
  transition: transform .12s ease, border-color .12s ease;
}
.mood-dot:hover { border-color: var(--ink-faint); transform: translateY(-1px); }

/* ===========================================================
   Tendencias
   =========================================================== */
.trend-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.trend-stat { padding: 16px 18px; }
.trend-stat-label { font-size: 12.5px; color: var(--ink-soft); font-weight: 500; }
.trend-stat-value { font-family: var(--mono); font-size: 30px; font-weight: 700; line-height: 1.1; margin-top: 6px; }
.trend-stat-unit { font-size: 14px; font-weight: 600; margin-left: 2px; }
.trend-delta { font-size: 11.5px; margin-top: 6px; display: inline-flex; align-items: center; gap: 3px; font-family: var(--mono); }
.trend-delta.pos { color: var(--sage); }
.trend-delta.neg { color: var(--prio-alta); }
.trend-delta.flat { color: var(--ink-faint); }
.trend-bars { display: grid; grid-template-columns: repeat(8, 1fr); gap: 10px; align-items: end; height: 180px; }
.trend-bar-col { display: flex; flex-direction: column; align-items: center; height: 100%; justify-content: flex-end; gap: 5px; }
.trend-bar-track { width: 100%; max-width: 34px; flex: 1; background: var(--cream-2); border-radius: 8px; display: flex; align-items: flex-end; overflow: hidden; }
.trend-bar-fill { width: 100%; border-radius: 8px; transition: height .4s cubic-bezier(.34,1.2,.64,1); min-height: 3px; }
.trend-bar-val { font-family: var(--mono); font-size: 11px; color: var(--ink-soft); font-weight: 600; }
.trend-bar-lbl { font-family: var(--mono); font-size: 10px; color: var(--ink-ghost); white-space: nowrap; }
.leg-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 5px; vertical-align: middle; }
.insight-card { background: var(--cat-cuerpo-tint, #f6efe3); }
.insight-list { margin: 0; padding-left: 20px; display: flex; flex-direction: column; gap: 9px; }
.insight-list li { font-size: 14px; line-height: 1.5; color: var(--ink-soft); }
@media (max-width: 820px) {
  .trend-stats { grid-template-columns: repeat(2, 1fr); }
  .trend-bars { gap: 5px; }
  .trend-bar-lbl { font-size: 8.5px; }
}

/* ===========================================================
   Comidas del día
   =========================================================== */
.meals-list { display: flex; flex-direction: column; }
.meal-row {
  display: flex; align-items: center; gap: 12px; padding: 11px 2px;
  border-bottom: 1px solid var(--line-soft);
}
.meal-row:last-child { border-bottom: none; }
.meal-row.editing { flex-wrap: wrap; border-bottom: none; gap: 8px; }
.meal-name { flex: 1; min-width: 0; font-weight: 500; font-size: 14.5px; }
.meal-macros { font-family: var(--mono); font-size: 13px; color: var(--ink-soft); white-space: nowrap; }
.meal-macros b { color: var(--ink); font-weight: 600; }
.meal-num { width: 88px; flex-shrink: 0; }

/* ===========================================================
   Búsqueda global
   =========================================================== */
.sidebar-search {
  display: flex; align-items: center; gap: 10px; width: 100%;
  margin-bottom: 14px; padding: 9px 12px; border-radius: 11px;
  background: var(--cream-2); border: 1px solid var(--line); cursor: pointer;
  color: var(--ink-soft); font-size: 13.5px; transition: border-color .14s ease;
}
.sidebar-search:hover { border-color: var(--ink-faint); }
.ss-label { flex: 1; text-align: left; }
.ss-kbd { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); background: var(--paper); border: 1px solid var(--line); border-radius: 6px; padding: 1px 6px; }
.nav-collapsed .sidebar-search .ss-label, .nav-collapsed .sidebar-search .ss-kbd { display: none; }

.search-scrim {
  position: fixed; inset: 0; z-index: 200; background: rgba(40, 30, 20, .34);
  backdrop-filter: blur(3px); display: flex; align-items: flex-start; justify-content: center;
  padding: 12vh 20px 20px; animation: fadeIn .12s ease;
}
.search-box {
  width: 100%; max-width: 580px; background: var(--paper); border: 1px solid var(--line);
  border-radius: 18px; box-shadow: 0 26px 70px rgba(40, 30, 20, .3); overflow: hidden;
}
.search-input-row { display: flex; align-items: center; gap: 12px; padding: 16px 18px; border-bottom: 1px solid var(--line-soft); }
.search-ico { display: inline-flex; flex-shrink: 0; }
.search-input { flex: 1; border: none; outline: none; background: transparent; font-size: 17px; color: var(--ink); font-family: inherit; }
.search-esc { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); background: var(--cream-2); border: 1px solid var(--line); border-radius: 7px; padding: 3px 8px; cursor: pointer; }
.search-results { max-height: 52vh; overflow-y: auto; padding: 8px; }
.search-empty, .search-hint { padding: 22px 14px; text-align: center; color: var(--ink-faint); font-size: 13.5px; }
.search-result {
  display: flex; align-items: center; gap: 12px; width: 100%; padding: 11px 12px;
  border: none; background: transparent; border-radius: 11px; cursor: pointer; text-align: left;
}
.search-result.active { background: var(--cream-2); }
.sr-ico { display: inline-grid; place-items: center; width: 30px; height: 30px; border-radius: 8px; background: var(--paper-2); flex-shrink: 0; }
.sr-text { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.sr-label { font-weight: 500; font-size: 14.5px; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sr-label.done { text-decoration: line-through; color: var(--ink-faint); }
.sr-sub { font-size: 12px; color: var(--ink-faint); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sr-kind { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; flex-shrink: 0; font-family: var(--mono); }
@media (max-width: 560px) { .sr-kind { display: none; } .search-scrim { padding-top: 8vh; } }

/* ===========================================================
   Agenda
   =========================================================== */
.agenda-layout { display: grid; grid-template-columns: 1fr 320px; gap: 24px; align-items: start; }
.agenda-bucket { margin-bottom: 22px; }
.agenda-bucket-head { display: flex; align-items: center; gap: 9px; margin-bottom: 10px; }
.ab-bar { width: 4px; height: 16px; border-radius: 3px; }
.ab-label { font-size: 13px; font-weight: 600; letter-spacing: .02em; text-transform: uppercase; color: var(--ink-soft); }
.ab-count { font-family: var(--mono); font-size: 12px; color: var(--ink-faint); background: var(--cream-2); border-radius: 20px; padding: 1px 8px; }
.agenda-task { padding: 12px 2px; align-items: flex-start; }
.agenda-side { position: sticky; top: 20px; display: flex; flex-direction: column; gap: 12px; }
.agenda-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.agenda-cal-title { font-size: 15px; font-weight: 600; text-transform: capitalize; }
.agenda-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.agenda-dow { text-align: center; font-size: 11px; font-weight: 600; color: var(--ink-faint); padding-bottom: 4px; font-family: var(--mono); }
.agenda-day { position: relative; aspect-ratio: 1; display: flex; align-items: center; justify-content: center; border-radius: 9px; font-size: 13px; color: var(--ink-soft); }
.agenda-day.today { background: var(--ochre-soft); color: var(--terracotta-deep); font-weight: 700; }
.ad-num { line-height: 1; }
.ad-dot { position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%); min-width: 6px; height: 6px; border-radius: 20px; background: var(--sage); display: grid; place-items: center; font-size: 8px; color: #fff; padding: 0 2px; line-height: 1; }
.ad-dot.overdue { background: var(--prio-alta); }
.ad-dot.mini { position: static; transform: none; display: inline-grid; }
.agenda-legend { display: flex; gap: 16px; justify-content: center; font-size: 11.5px; color: var(--ink-faint); }
.agenda-legend span { display: inline-flex; align-items: center; gap: 5px; }
@media (max-width: 900px) {
  .agenda-layout { grid-template-columns: 1fr; }
  .agenda-side { position: static; order: -1; }
}
@media (max-width: 560px) {
  .meal-num { width: 72px; }
  .meal-row.editing .mini-input { min-width: 0; }
}
@media (max-width: 620px) {
  .backup-banner { flex-wrap: wrap; }
  .backup-banner .btn-soft { width: 100%; justify-content: center; }
}

/* ===========================================================
   Selector de icono
   =========================================================== */
.icon-picker { position: relative; display: inline-block; }
.icon-picker-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 7px 8px; border: 1px solid var(--line); border-radius: 11px;
  background: var(--paper-2); cursor: pointer; transition: border-color .15s ease, background .15s ease;
}
.icon-picker-btn:hover { border-color: var(--ink-faint); }
.icon-picker-caret { display: inline-flex; }
.icon-picker-pop {
  z-index: 1200; width: 268px;
  padding: 10px; background: var(--paper); border: 1px solid var(--line); border-radius: 14px;
  box-shadow: 0 18px 48px rgba(40, 30, 20, .22);
}
.icon-picker-title { font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); margin: 2px 2px 9px; }
.icon-picker-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px;
  max-height: 216px; overflow-y: auto; padding-right: 2px;
}
.icon-opt {
  display: grid; place-items: center; width: 100%; aspect-ratio: 1 / 1; min-height: 36px;
  border: 1px solid transparent; border-radius: 9px; background: transparent;
  color: var(--ink-soft); cursor: pointer; transition: background .12s ease, color .12s ease, border-color .12s ease;
}
.icon-opt:hover { background: var(--cream-2); color: var(--ink); }
.icon-opt.active { background: var(--cat-mente-tint); color: var(--cat-mente); border-color: var(--cat-mente); }

/* arrastrar para reordenar hábitos */
.habit-row-dnd { transition: background .12s ease; }
.hrow-grip {
  position: absolute; left: 3px; top: 50%; transform: translateY(-50%); z-index: 4;
  width: 20px; height: 30px; display: grid; place-items: center; border-radius: 6px;
  color: var(--ink-ghost); background: transparent; cursor: grab; opacity: 0;
  transition: opacity .15s ease, color .15s ease, background .15s ease; touch-action: none;
}
.habit-row-dnd:hover .hrow-grip { opacity: 1; }
.hrow-grip:hover { color: var(--terracotta); background: var(--cream-2); }
.hrow-grip:active { cursor: grabbing; }
.hrow-over { background: var(--cat-mente-tint); box-shadow: inset 0 2px 0 var(--terracotta); }
.hrow-dragging { opacity: .4; }
@media (max-width: 900px) { .hrow-grip { opacity: .6; } }

/* hábitos: en móvil la tabla se desplaza horizontalmente manteniendo alineación */
.habit-scroll { width: 100%; }
@media (max-width: 700px) {
  .habit-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .habit-scroll .habit-grid { min-width: 540px; }
}

.obj-collapse {
  display: inline-grid; place-items: center; width: 24px; height: 24px;
  border: none; background: transparent; border-radius: 7px; cursor: pointer; flex-shrink: 0;
  transition: transform .2s ease, background .12s ease;
}
.obj-collapse:hover { background: var(--cream-2); }

.habit-ico {
  display: inline-grid; place-items: center; width: 34px; height: 34px; flex-shrink: 0;
  border-radius: 10px; background: var(--cream-2); color: var(--terracotta);
}
.habit-weekgoal { color: var(--ink-faint); display: inline-flex; align-items: center; gap: 4px; }
.habit-weekgoal.met { color: var(--sage); font-weight: 600; }
.habit-settings { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 10px; }
.habit-settings label { display: flex; flex-direction: column; gap: 3px; font-size: 11px; color: var(--ink-faint); font-weight: 500; }
.habit-settings .select { font-size: 12.5px; padding: 6px 8px; border-radius: 9px; }

/* celda numérica */
.num-cell-wrap { position: relative; }
.num-cell {
  width: 34px; height: 34px; border-radius: 10px; border: 1.5px solid var(--line);
  background: var(--paper-2); cursor: pointer; display: grid; place-items: center;
  font-family: var(--mono); font-size: 12px; font-weight: 600; color: var(--ink-soft);
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.num-cell:hover { border-color: var(--terracotta); }
.num-cell.partial { background: var(--terracotta-soft); border-color: var(--terracotta-soft); color: var(--terracotta-deep); }
.num-cell.met { background: var(--terracotta); border-color: var(--terracotta); color: #fff; }
.num-cell.today { box-shadow: 0 0 0 2px var(--ochre); }
.num-cell.future { opacity: .4; cursor: not-allowed; }
.num-cell .mk { width: 5px; height: 5px; border-radius: 50%; background: var(--ink-ghost); }
.num-pop {
  position: absolute; z-index: 30; top: calc(100% + 6px); left: 50%; transform: translateX(-50%);
  background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 8px;
  box-shadow: 0 12px 30px rgba(40,30,20,.18); width: max-content;
}
.num-pop-row { display: flex; align-items: center; gap: 6px; }
.np-btn { width: 28px; height: 28px; border-radius: 8px; border: 1px solid var(--line); background: var(--cream-2); font-size: 16px; cursor: pointer; line-height: 1; color: var(--ink); }
.np-btn:hover { border-color: var(--terracotta); }
.np-input { width: 64px; text-align: center; font-family: var(--mono); font-size: 14px; padding: 5px 6px; border: 1px solid var(--line); border-radius: 8px; }
.np-target { font-size: 11px; color: var(--ink-faint); text-align: center; margin-top: 5px; font-family: var(--mono); }

/* ===========================================================
   Notificaciones / recordatorios
   =========================================================== */
.toggle {
  position: relative; width: 44px; height: 25px; border-radius: 999px; flex-shrink: 0;
  background: var(--cream-2); border: 1px solid var(--line); transition: background .18s ease, border-color .18s ease;
}
.toggle.on { background: var(--sage); border-color: var(--sage); }
.toggle:disabled { opacity: .45; cursor: default; }
.toggle-knob {
  position: absolute; top: 2px; left: 2px; width: 19px; height: 19px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.25); transition: transform .18s cubic-bezier(.34,1.4,.64,1);
}
.toggle.on .toggle-knob { transform: translateX(19px); }

.reminder-list { display: flex; flex-direction: column; margin-top: 4px; }
.reminder-row {
  display: flex; align-items: center; gap: 13px; padding: 15px 0;
  border-bottom: 1px solid var(--line-soft); transition: opacity .15s ease;
}
.reminder-row:last-child { border-bottom: none; }
.reminder-row.off { opacity: .55; }
.reminder-text { flex: 1; min-width: 0; }
.reminder-controls { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.time-input {
  font-family: var(--mono); font-size: 13px; color: var(--ink);
  background: var(--paper-2); border: 1px solid var(--line); border-radius: 9px; padding: 6px 9px;
}
.time-input:disabled { opacity: .5; }
.reminder-day {
  font-size: 12.5px; padding: 6px 9px; border-radius: 9px; max-width: 130px;
}
@media (max-width: 620px) {
  .reminder-row { flex-wrap: wrap; }
  .reminder-controls { width: 100%; justify-content: flex-end; }
}

/* ===========================================================
   InBody — composición corporal
   =========================================================== */
.ib-drop {
  width: 100%; display: flex; flex-direction: column; align-items: center; gap: 8px;
  text-align: center; padding: 34px 26px; margin-top: 6px;
  border: 2px dashed var(--line); border-radius: var(--r-md); background: var(--paper-2);
  transition: border-color .15s ease, background .15s ease;
}
.ib-drop:hover { border-color: var(--cat-cuerpo); background: var(--cat-cuerpo-tint); }
.ib-drop-ico { width: 54px; height: 54px; border-radius: 16px; display: grid; place-items: center; background: var(--cat-cuerpo-tint); }
.ib-drop-title { font-size: 16px; font-weight: 600; }
.ib-drop-sub { font-size: 13px; color: var(--ink-faint); max-width: 440px; line-height: 1.5; }

.ib-reading { display: flex; align-items: center; gap: 14px; padding: 22px 6px; }
.ib-progress { height: 6px; border-radius: 4px; background: var(--cream-2); overflow: hidden; margin-top: 10px; max-width: 320px; }
.ib-progress > span { display: block; height: 100%; background: var(--cat-cuerpo); border-radius: 4px; transition: width .3s ease; }

/* gráfico de tendencia + nota + nota historial */
.ib-trend .card-head { align-items: flex-start; }
.ib-note { display: flex; align-items: center; gap: 14px; }
.ib-card { margin-top: 0; }

/* ===========================================================
   WidgetBoard — rejilla reordenable + selector de columnas
   =========================================================== */
.wb-footer { display: flex; align-items: center; gap: 12px; margin-top: 22px; padding-top: 16px; border-top: 1px solid var(--line-soft); flex-wrap: wrap; }
.wb-hint { font-size: 12px; color: var(--ink-faint); display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); }
.wb-cols { margin-left: auto; display: flex; align-items: center; gap: 5px; background: var(--paper); border: 1px solid var(--line); border-radius: 11px; padding: 4px 6px 4px 12px; box-shadow: var(--sh-sm); }
.wb-cols-lbl { font-size: 10.5px; color: var(--ink-faint); font-family: var(--mono); text-transform: uppercase; letter-spacing: .1em; margin-right: 3px; }
.wb-col-btn { width: 28px; height: 26px; border-radius: 7px; font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--ink-soft); transition: background .15s ease, color .15s ease; }
.wb-col-btn:hover { background: var(--cream-2); }
.wb-col-btn.active { background: var(--terracotta); color: #fff; }
.wb-tools { margin-left: auto; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.wb-tools .wb-cols { margin-left: 0; }
.wb-mason-btn {
  display: inline-flex; align-items: center; gap: 6px; height: 36px; padding: 0 13px;
  border: 1px solid var(--line); border-radius: 11px; background: var(--paper); box-shadow: var(--sh-sm);
  font-size: 12.5px; font-weight: 500; color: var(--ink-soft); transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.wb-mason-btn:hover { border-color: var(--ink-faint); color: var(--ink); }
.wb-mason-btn.active { background: var(--terracotta); border-color: var(--terracotta); color: #fff; }

.wb-grid { display: grid; grid-template-columns: repeat(var(--wb-cols, 2), minmax(0, 1fr)); gap: 20px; align-items: start; }
.wb-grid.wb-masonry { align-items: stretch; }
.wb-item { position: relative; min-width: 0; container-type: inline-size; }
.wb-inner { min-width: 0; }
.wb-full { grid-column: 1 / -1; }
.wb-grip {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%); z-index: 6;
  height: 21px; padding: 0 14px; border-radius: 999px; display: grid; place-items: center;
  color: var(--ink-faint); background: var(--paper); border: 1px solid var(--line); box-shadow: var(--sh-sm);
  cursor: grab; opacity: 0; transition: opacity .15s ease, color .15s ease, background .15s ease;
  touch-action: none; -webkit-user-select: none; user-select: none;
}
.wb-item:hover .wb-grip { opacity: 1; }
.wb-grip:hover { color: var(--terracotta); background: var(--cream); }
.wb-grip:active { cursor: grabbing; }
/* asa de redimensionado en el borde derecho */
.wb-resize {
  position: absolute; top: 0; right: -11px; width: 22px; height: 100%; z-index: 6;
  display: flex; align-items: center; justify-content: center; background: transparent; border: none;
  cursor: ew-resize; opacity: 0; transition: opacity .15s ease; touch-action: none;
}
.wb-item:hover .wb-resize { opacity: 1; }
.wb-resize-bar { width: 5px; height: 40px; max-height: 60%; border-radius: 4px; background: var(--line); transition: background .15s ease; }
.wb-resize:hover .wb-resize-bar, .wb-resizing-item .wb-resize-bar { background: var(--terracotta); }
.wb-resizing, .wb-resizing * { cursor: ew-resize !important; user-select: none !important; }
.wb-resizing-item { outline: 2px solid var(--terracotta); outline-offset: 4px; border-radius: var(--r-md); }
.wb-over { outline: 2px dashed var(--terracotta); outline-offset: 5px; border-radius: var(--r-md); }
.wb-dragging { opacity: .38; }

@media (max-width: 900px) {
  .wb-grid { grid-template-columns: 1fr !important; gap: 16px; }
  .wb-grid.wb-masonry { grid-auto-rows: auto !important; }
  .wb-grid.wb-masonry .wb-item { grid-row-end: auto !important; }
  .wb-item { grid-column: span 1 !important; }
  .wb-cols, .wb-tools { display: none; }
  .wb-hint { display: none; }
  .wb-footer { display: none; }
  .wb-grip { opacity: .7; height: 26px; padding: 0 18px; }
  .wb-resize { display: none; }
}

/* tarjeta de revisión / manual */
.ib-review { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r-md); padding: 18px; margin-top: 6px; }
.ib-review-head { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.ib-review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.ib-field { display: flex; flex-direction: column; gap: 5px; }
.ib-field-date { grid-column: 1 / -1; max-width: 260px; }
.ib-flabel { font-family: var(--mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); }
.ib-seg-edit { margin-top: 16px; }
.ib-seg-inputs { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; margin-top: 8px; }
.ib-review-foot { display: flex; align-items: center; gap: 10px; margin-top: 18px; }

/* resultados */
.ib-primary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 6px; }
.ib-stat { background: var(--paper-2); border: 1px solid var(--line-soft); border-radius: var(--r-md); padding: 16px; }
.ib-stat-label { font-size: 12.5px; color: var(--ink-faint); font-weight: 500; }
.ib-stat-val { font-family: var(--mono); font-size: 27px; font-weight: 500; margin: 4px 0 6px; letter-spacing: -0.01em; }
.ib-stat-val small { font-size: 14px; color: var(--ink-faint); }
.ib-delta { font-size: 12px; font-weight: 600; font-family: var(--mono); }
.ib-delta.good { color: var(--sage); }
.ib-delta.bad { color: var(--terracotta); }
.ib-delta.flat { color: var(--ink-ghost); }

.ib-secondary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 14px; }
.ib-mini { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; padding: 10px 14px; background: var(--cream); border-radius: var(--r-sm); }
.ib-mini-label { font-size: 12.5px; color: var(--ink-soft); }
.ib-mini-val { font-family: var(--mono); font-size: 15px; font-weight: 500; }
.ib-mini-val small { font-size: 11px; color: var(--ink-faint); }

.ib-charts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 22px; }
.ib-chart-t { font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint); margin-bottom: 4px; }

.ib-seg { margin-top: 22px; }
.ib-seg-bars { display: flex; flex-direction: column; gap: 8px; }
.ib-seg-row { display: flex; align-items: center; gap: 12px; }
.ib-seg-lbl { font-size: 12.5px; color: var(--ink-soft); width: 92px; flex-shrink: 0; }
.ib-seg-track { flex: 1; height: 9px; border-radius: 5px; background: var(--cream-2); overflow: hidden; }
.ib-seg-track > span { display: block; height: 100%; background: var(--sage); border-radius: 5px; transition: width .5s ease; }
.ib-seg-num { font-family: var(--mono); font-size: 13px; font-weight: 500; width: 42px; text-align: right; }

.ib-history { margin-top: 22px; border-top: 1px solid var(--line-soft); padding-top: 14px; }
.ib-hrow { display: flex; align-items: center; gap: 12px; padding: 8px 0; border-bottom: 1px solid var(--line-soft); }
.ib-hrow:last-child { border-bottom: none; }
.ib-hdate { font-family: var(--mono); font-size: 12.5px; color: var(--ink-soft); width: 64px; flex-shrink: 0; }
.ib-hmetrics { display: flex; gap: 14px; flex-wrap: wrap; flex: 1; }
.ib-hmetrics em { font-style: normal; font-size: 13px; color: var(--ink-soft); }
.ib-hrow .icon-btn { opacity: 0; transition: opacity .15s ease; }
.ib-hrow:hover .icon-btn { opacity: 1; }

/* comparador InBody */
.ib-cmp-selectors { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.ib-cmp-selectors .select { flex: 1; }
.ib-cmp-table { display: flex; flex-direction: column; }
.ib-cmp-row { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 8px; align-items: center; padding: 9px 0; border-bottom: 1px solid var(--line-soft); }
.ib-cmp-row:last-child { border-bottom: none; }
.ib-cmp-head { font-size: 11px; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-faint); font-weight: 700; }
.ib-cmp-head span:not(:first-child), .ib-cmp-num, .ib-cmp-delta { text-align: right; font-family: var(--mono); }
.ib-cmp-metric { font-size: 13.5px; font-weight: 500; }
.ib-cmp-metric small { color: var(--ink-faint); }
.ib-cmp-num { font-size: 14px; color: var(--ink-soft); }
.ib-cmp-delta { font-size: 13px; font-weight: 600; }
.ib-cmp-delta.good { color: var(--sage); }
.ib-cmp-delta.bad { color: var(--prio-alta); }
.ib-cmp-delta.flat { color: var(--ink-faint); }

/* importación CSV en bloque */
.ib-batch-list { display: flex; flex-direction: column; margin: 4px 0 6px; max-height: 280px; overflow-y: auto; }
.ib-batch-row { display: flex; align-items: center; gap: 14px; padding: 9px 0; border-bottom: 1px solid var(--line-soft); }
.ib-batch-row:last-child { border-bottom: none; }
.ib-batch-date { font-family: var(--mono); font-size: 12.5px; color: var(--ink-soft); min-width: 92px; }
.ib-batch-metrics { display: flex; flex-wrap: wrap; gap: 6px 12px; }
.ib-batch-metrics em { font-style: normal; font-size: 12.5px; color: var(--ink-soft); font-family: var(--mono); }

/* ===========================================================
   Hoja imprimible (resumen semanal → PDF)
   =========================================================== */
.print-sheet { display: none; }
@media print {
  /* ocultar toda la app y mostrar solo la hoja */
  body * { visibility: hidden !important; }
  .print-sheet, .print-sheet * { visibility: visible !important; }
  .print-sheet {
    display: block !important; position: absolute; inset: 0; width: 100%;
    padding: 32px 36px; background: #fff; color: #1a1a1a; font-size: 12pt;
  }
  .app-shell, .sidebar, .bottom-nav, .assistant-fab-wrap, .wb-footer { display: none !important; }
  @page { margin: 1.2cm; }
}
.ps-head { display: flex; justify-content: space-between; align-items: flex-end; border-bottom: 2px solid #1a1a1a; padding-bottom: 12px; }
.ps-eyebrow { font-size: 10pt; letter-spacing: .05em; text-transform: uppercase; color: #666; }
.ps-title { font-size: 22pt; font-weight: 700; margin-top: 4px; }
.ps-brand { font-size: 11pt; font-weight: 600; color: #b5562f; }
.ps-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin: 22px 0; }
.ps-stat { border: 1px solid #ddd; border-radius: 8px; padding: 12px; text-align: center; }
.ps-stat span { display: block; font-size: 20pt; font-weight: 700; }
.ps-stat small { font-size: 9pt; color: #666; }
.ps-section { margin: 18px 0; break-inside: avoid; }
.ps-section h3 { font-size: 12pt; border-bottom: 1px solid #ccc; padding-bottom: 4px; margin-bottom: 8px; }
.ps-section ul { margin: 0; padding-left: 18px; }
.ps-section li { margin-bottom: 4px; line-height: 1.4; }
.ps-section p { line-height: 1.5; }
.ps-foot { margin-top: 28px; padding-top: 10px; border-top: 1px solid #ccc; font-size: 9pt; color: #888; text-align: center; }

@media (max-width: 760px) {
  .ib-primary { grid-template-columns: repeat(2, 1fr); }
  .ib-secondary { grid-template-columns: repeat(2, 1fr); }
  .ib-charts { grid-template-columns: 1fr; }
  .ib-review-grid { grid-template-columns: repeat(2, 1fr); }
  .ib-seg-inputs { grid-template-columns: repeat(3, 1fr); }
  .backup-stats { grid-template-columns: repeat(2, 1fr); }
  .intention-intake { width: 100%; }
}
@media (max-width: 520px) {
  .ib-primary { grid-template-columns: 1fr 1fr; }
  .ib-review-grid { grid-template-columns: 1fr 1fr; }
}

/* ===========================================================
   Celebración (confeti al completar una meta) + pop de tareas
   =========================================================== */
.celebrate-layer { position: fixed; inset: 0; pointer-events: none; z-index: 9999; overflow: hidden; }
.confetti-bit {
  position: absolute; will-change: transform, opacity;
  animation: confetti-fly 1.5s cubic-bezier(.15,.6,.4,1) forwards;
}
@keyframes confetti-fly {
  0%   { transform: translate(0,0) rotate(0deg); opacity: 1; }
  12%  { opacity: 1; }
  100% { transform: translate(var(--dx), calc(var(--dy) + 60vh)) rotate(var(--rot)); opacity: 0; }
}
.check.just-done { animation: check-pop .4s cubic-bezier(.34,1.56,.64,1); }
@keyframes check-pop { 0% { transform: scale(1); } 40% { transform: scale(1.35); } 100% { transform: scale(1); } }

/* ===========================================================
   El cielo — volcado de preocupaciones (nubes)
   =========================================================== */
.cielo-wrap { max-width: 920px; }

.sky {
  position: relative; border-radius: 22px; overflow: hidden;
  padding: 26px 24px 34px; min-height: 340px; margin-bottom: 18px;
  /* el cielo se oscurece según --overcast (0 despejado → 1 cargado) */
  background:
    linear-gradient(180deg,
      color-mix(in oklab, #aacbe8, #8b96a4 calc(var(--overcast, 0) * 70%)) 0%,
      color-mix(in oklab, #c7dcef, #aeb7c2 calc(var(--overcast, 0) * 65%)) 48%,
      color-mix(in oklab, #f3e7d6, #cbc8c4 calc(var(--overcast, 0) * 55%)) 100%);
  box-shadow: inset 0 2px 14px rgba(255,255,255,.35), var(--sh-sm);
  transition: background .8s ease;
}
.sky-sun {
  position: absolute; top: 26px; right: 32px; width: 64px; height: 64px;
  opacity: calc(1 - var(--overcast, 0) * .85); transition: opacity .8s ease; pointer-events: none;
}
.sun-core { position: absolute; inset: 16px; border-radius: 50%; background: radial-gradient(circle at 40% 38%, #fff6d8, #ffd86b 60%, #f5b73e); box-shadow: 0 0 22px 6px rgba(255,206,94,.6); }
.sun-glow { position: absolute; inset: 0; border-radius: 50%; background: radial-gradient(circle, rgba(255,214,107,.45), transparent 68%); animation: sunPulse 5s ease-in-out infinite; }
@keyframes sunPulse { 0%,100% { transform: scale(1); opacity: .8; } 50% { transform: scale(1.18); opacity: 1; } }

.sky-status { position: relative; z-index: 2; max-width: 70%; }
.sky-status-title { font-size: 19px; font-weight: 700; color: #2c3a4a; letter-spacing: -.01em; }
.sky-status-sub { font-size: 13.5px; color: #46566a; margin-top: 4px; line-height: 1.45; }
.sky-weight { font-family: var(--mono); font-size: 11.5px; color: #5a6b7e; margin-top: 8px; }
.sky.clear .sky-status-title { color: #2c3a4a; }

.cloud-field { position: relative; z-index: 2; display: flex; flex-wrap: wrap; gap: 22px 26px; align-items: flex-start; margin-top: 26px; padding-bottom: 6px; }

/* nube individual */
.cloud { position: relative; border: none; background: transparent; padding: 10px 6px 6px; cursor: pointer; display: inline-flex; }
@media (prefers-reduced-motion: no-preference) { .cloud { animation: cloudDrift var(--dur, 8s) ease-in-out var(--delay, 0s) infinite; } }
@keyframes cloudDrift { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }
.cloud:hover { filter: drop-shadow(0 8px 16px rgba(40,55,75,.22)); }
.cloud:active { transform: scale(.97); }

.cloud-body {
  position: relative; z-index: 2; max-width: 230px;
  background: linear-gradient(#ffffff, #eef3f8);
  border-radius: 34px; padding: 15px 20px;
  box-shadow: 0 12px 26px rgba(54,68,90,.18), inset 0 2px 0 rgba(255,255,255,.95);
  display: flex; flex-direction: column; gap: 8px; text-align: left;
}
.cloud-puff { position: absolute; z-index: 1; border-radius: 50%; background: #fff; box-shadow: inset 0 2px 0 rgba(255,255,255,.9); }
.cloud-puff.p1 { width: calc(40px * var(--ps, 1)); height: calc(40px * var(--ps, 1)); top: -2px; left: 18px; }
.cloud-puff.p2 { width: calc(58px * var(--ps, 1)); height: calc(58px * var(--ps, 1)); top: calc(-14px * var(--ps, 1)); left: 44%; transform: translateX(-50%); }
.cloud-puff.p3 { width: calc(38px * var(--ps, 1)); height: calc(38px * var(--ps, 1)); top: 0; right: 22px; }
.cloud-text { font-size: 14px; font-weight: 500; color: #33414f; line-height: 1.4; max-height: 4.2em; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }
.cloud-steps { display: flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; color: #6a7a8b; }
.cloud-steps-bar { flex: 1; height: 5px; border-radius: 3px; background: #dde5ee; overflow: hidden; }
.cloud-steps-bar span { display: block; height: 100%; background: var(--sage); border-radius: 3px; }

/* intensidades: tamaño + tono */
.cloud.i1 .cloud-body { max-width: 180px; padding: 12px 17px; background: linear-gradient(#ffffff, #f3f7fb); }
.cloud.i1 .cloud-text { font-size: 13px; }
.cloud.i3 .cloud-body { background: linear-gradient(#e4e9f0, #cdd5e0); max-width: 250px; }
.cloud.i3 .cloud-puff { background: #e0e6ee; }
.cloud.i3 .cloud-text { color: #2a3744; font-weight: 600; }

.release-card { margin-top: 0; }
.release-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 12px; flex-wrap: wrap; }
.weight-pills { display: flex; gap: 8px; flex-wrap: wrap; }
.weight-pill {
  display: inline-flex; align-items: center; gap: 6px; padding: 7px 13px; border-radius: 20px;
  border: 1.5px solid var(--line); background: var(--paper-2); color: var(--ink-soft);
  font-size: 13px; font-weight: 500; cursor: pointer; transition: border-color .14s, color .14s, background .14s;
}
.weight-pill:hover { border-color: var(--ink-faint); }
.weight-pill.active { border-color: var(--cat-mente); color: var(--cat-mente); background: var(--cat-mente-tint); }

/* modal de detalle */
.cielo-modal { width: 100%; max-width: 560px; background: var(--paper); border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--sh-lg); padding: 20px; max-height: 86vh; overflow-y: auto; }
.cielo-modal-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.cloud-mini { display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: 11px; background: #e8f0f8; color: #5a7da6; }
.cielo-modal-foot { display: flex; justify-content: space-between; gap: 12px; margin-top: 20px; }

.weight-choose { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.weight-opt { display: flex; flex-direction: column; align-items: center; gap: 5px; padding: 14px 8px; border: 1.5px solid var(--line); border-radius: 13px; background: var(--paper-2); cursor: pointer; transition: border-color .14s, background .14s; }
.weight-opt:hover { border-color: var(--ink-faint); }
.weight-ico { color: var(--ink-faint); }
.weight-lbl { font-size: 13px; font-weight: 600; color: var(--ink-soft); }
.weight-hint { font-size: 10.5px; color: var(--ink-faint); text-align: center; line-height: 1.3; }
.weight-opt.active { border-color: var(--cat-mente); background: var(--cat-mente-tint); }
.weight-opt.active .weight-ico, .weight-opt.active .weight-lbl { color: var(--cat-mente); }

.step-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 4px; }
.step-row { display: flex; align-items: center; gap: 10px; }
.step-name { flex: 1; font-size: 13.5px; color: var(--ink-soft); }
.step-name.done { text-decoration: line-through; color: var(--ink-faint); }

.danger-soft { color: var(--prio-alta); }
.danger-soft:hover { background: color-mix(in oklab, var(--prio-alta), transparent 88%); }

/* archivo de cielos despejados */
.archive-toggle { display: flex; align-items: center; gap: 12px; width: 100%; background: transparent; border: none; cursor: pointer; padding: 0; }
.archive-list { margin-top: 16px; border-top: 1px solid var(--line-soft); padding-top: 12px; display: flex; flex-direction: column; gap: 4px; }
.archive-row { display: flex; align-items: center; gap: 11px; padding: 9px 0; border-bottom: 1px solid var(--line-soft); }
.archive-row:last-child { border-bottom: none; }
.archive-check { display: inline-grid; place-items: center; width: 22px; height: 22px; flex-shrink: 0; border-radius: 50%; background: var(--sage); }
.archive-text { font-size: 14px; color: var(--ink-soft); }
.archive-date { font-size: 11.5px; color: var(--ink-faint); font-family: var(--mono); margin-top: 2px; }

/* cielo nocturno (modo oscuro) */
[data-theme="dark"] .sky {
  background:
    linear-gradient(180deg,
      color-mix(in oklab, #1d2740, #0e1422 calc(var(--overcast, 0) * 60%)) 0%,
      color-mix(in oklab, #28324a, #161d2c calc(var(--overcast, 0) * 55%)) 55%,
      color-mix(in oklab, #3a3550, #1c1b28 calc(var(--overcast, 0) * 50%)) 100%);
}
[data-theme="dark"] .sky-status-title { color: #e6ecf5; }
[data-theme="dark"] .sky-status-sub { color: #aab6c8; }
[data-theme="dark"] .sky-weight { color: #8ea0b6; }
[data-theme="dark"] .cloud-body { background: linear-gradient(#3a4252, #2c3344); }
[data-theme="dark"] .cloud-puff { background: #3a4252; }
[data-theme="dark"] .cloud-text { color: #dde5f0; }
[data-theme="dark"] .cloud.i3 .cloud-body { background: linear-gradient(#4a5266, #353c4d); }
[data-theme="dark"] .cloud.i3 .cloud-puff { background: #4a5266; }
[data-theme="dark"] .cloud.i3 .cloud-text { color: #eef2f8; }
[data-theme="dark"] .cloud-mini { background: #28344a; color: #8fb0d6; }

@media (max-width: 700px) {
  .cloud-field { gap: 16px 18px; }
  .cloud-body { max-width: 150px; padding: 12px 15px; }
  .cloud-text { font-size: 12.5px; }
  .sky-status { max-width: 100%; }
  .sky-sun { width: 48px; height: 48px; top: 18px; right: 18px; }
  .weight-choose { grid-template-columns: 1fr; }
  .release-row { flex-direction: column; align-items: stretch; }
  .release-row .btn-primary { justify-content: center; }
}

/* ---- Login: botón de Google + separador ---- */
.login-google { display: flex; flex-direction: column; align-items: center; gap: 12px; margin: 4px 0 14px; }
.login-or { display: flex; align-items: center; gap: 12px; width: 100%; color: var(--ink-faint, #9aa); font-size: 12.5px; }
.login-or::before, .login-or::after { content: ""; flex: 1; height: 1px; background: var(--border, #e7e2d6); }
