/* ================================================================
   STYLES — Despensa Alerta v2
   ================================================================ */

:root {
  --verde:        #1a7a50;
  --verde-claro:  #e8f5ee;
  --verde-dark:   #0f4c35;
  --verde-mid:    #2ea06a;
  --amarillo:     #f59e0b;
  --amarillo-bg:  #fffbeb;
  --rojo:         #e53e3e;
  --rojo-bg:      #fff5f5;
  --gris-bg:      #f4f6f4;
  --gris-card:    #ffffff;
  --gris-borde:   #e2e8e4;
  --texto:        #1a2e24;
  --texto-soft:   #4a6358;
  --texto-muted:  #8aab99;
  --sombra:       0 2px 16px rgba(26,122,80,0.10);
  --font-display: 'Sora', sans-serif;
  --font-body:    'DM Sans', sans-serif;
}

* { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }

body {
  font-family: var(--font-body);
  background: var(--gris-bg);
  color: var(--texto);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── SCREENS ── */
.screen { display:none; min-height:100vh; }
.screen.active { display:block; }

/* ================================================================
   ONBOARDING
   ================================================================ */
#screen-onb {
  background: linear-gradient(160deg,#0f4c35 0%,#1a7a50 55%,#0d3d2a 100%);
  min-height: 100vh;
  display: none;
  flex-direction: column;
  align-items: center;
  padding: 52px 24px 32px;
  position: relative;
  overflow: hidden;
}
#screen-onb.active { display:flex; }
#screen-onb::before { content:''; position:absolute; top:-80px; right:-80px; width:260px; height:260px; border-radius:50%; background:rgba(255,255,255,0.04); }
#screen-onb::after  { content:''; position:absolute; bottom:100px; left:-60px; width:190px; height:190px; border-radius:50%; background:rgba(255,255,255,0.03); }

.onb-logo { text-align:center; margin-bottom:36px; }
.onb-logo-icon { font-size:54px; display:block; margin-bottom:10px; animation:floatIcon 3s ease-in-out infinite; }
@keyframes floatIcon { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
.onb-logo h1 { font-family:var(--font-display); font-size:26px; font-weight:800; color:#fff; letter-spacing:-.5px; }
.onb-logo p  { font-size:13px; color:rgba(255,255,255,.6); margin-top:5px; }

.onb-prog-wrap { width:100%; max-width:340px; height:3px; background:rgba(255,255,255,.15); border-radius:99px; margin-bottom:34px; overflow:hidden; }
.onb-prog-fill { height:100%; background:#4ade80; border-radius:99px; transition:width .4s ease; }

.onb-step { width:100%; max-width:340px; display:none; animation:fadeUp .4s ease; }
.onb-step.active { display:block; }
.onb-step h2 { font-family:var(--font-display); font-size:22px; font-weight:700; color:#fff; margin-bottom:8px; }
.onb-step p  { font-size:14px; color:rgba(255,255,255,.65); margin-bottom:22px; line-height:1.5; }

.onb-input {
  width:100%; padding:16px 18px; border-radius:14px;
  border:2px solid rgba(255,255,255,.15); background:rgba(255,255,255,.10);
  color:#fff; font-family:var(--font-body); font-size:18px; font-weight:500;
  outline:none; transition:border-color .2s; -webkit-appearance:none;
}
.onb-input::placeholder { color:rgba(255,255,255,.35); }
.onb-input:focus { border-color:#4ade80; }

.onb-chips { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:6px; }
.onb-chip  { padding:10px 18px; border-radius:99px; border:2px solid rgba(255,255,255,.2); background:rgba(255,255,255,.08); color:rgba(255,255,255,.8); font-size:14px; font-weight:500; cursor:pointer; transition:all .2s; user-select:none; }
.onb-chip.sel { background:#4ade80; border-color:#4ade80; color:#0f4c35; font-weight:700; }

.onb-err { color:#fca5a5; font-size:13px; margin-top:8px; min-height:20px; display:none; }
.onb-err.show { display:block; }

.btn-onb { width:100%; max-width:340px; padding:16px; border-radius:14px; border:none; background:#4ade80; color:#0f4c35; font-family:var(--font-display); font-size:16px; font-weight:700; cursor:pointer; margin-top:28px; transition:transform .15s; -webkit-appearance:none; }
.btn-onb:active { transform:scale(.97); }

/* ================================================================
   APP LAYOUT
   ================================================================ */
#screen-app { padding-bottom: 80px; }

/* ── HEADER ── */
.header { position:sticky; top:0; z-index:100; background:var(--verde-dark); padding:14px 18px; display:flex; align-items:center; justify-content:space-between; box-shadow:0 2px 12px rgba(15,76,53,.3); }
.header-logo { display:flex; align-items:center; gap:8px; }
.header-logo span { font-size:22px; }
.header-logo h1 { font-family:var(--font-display); font-size:17px; font-weight:800; color:#fff; letter-spacing:-.3px; }
.header-right { display:flex; align-items:center; gap:10px; }

.chip-ia { display:flex; align-items:center; gap:5px; padding:5px 10px; border-radius:99px; font-size:11px; font-weight:600; cursor:pointer; transition:all .3s; border:none; }
.chip-ia.off { background:rgba(255,255,255,.12); color:rgba(255,255,255,.5); }
.chip-ia.on  { background:linear-gradient(135deg,#4ade80,#22c55e); color:#0f4c35; animation:pulseIA 2s ease-in-out infinite; }
@keyframes pulseIA { 0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,.4)} 50%{box-shadow:0 0 0 6px rgba(74,222,128,0)} }

.avatar { width:34px; height:34px; border-radius:50%; background:var(--verde-mid); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:14px; font-weight:700; color:#fff; cursor:pointer; border:2px solid rgba(255,255,255,.2); }

/* ── BANNERS ── */
.banner-trial   { background:linear-gradient(90deg,#f59e0b,#f97316); padding:10px 18px; display:none; align-items:center; justify-content:space-between; gap:8px; }
.banner-vencido { background:var(--rojo); padding:10px 18px; display:none; align-items:center; justify-content:space-between; gap:8px; }
.banner-trial span, .banner-vencido span { font-size:13px; color:#fff; font-weight:600; }
.banner-trial button, .banner-vencido button { padding:5px 12px; border-radius:99px; border:2px solid rgba(255,255,255,.6); background:transparent; color:#fff; font-size:12px; font-weight:700; cursor:pointer; }
.demo-banner { background:linear-gradient(90deg,#f59e0b,#fb923c); padding:8px 18px; display:none; align-items:center; justify-content:space-between; }
.demo-banner.show { display:flex; }
.demo-banner span { font-size:12px; color:#fff; font-weight:700; }
.demo-banner button { padding:4px 12px; border-radius:99px; border:2px solid rgba(255,255,255,.6); background:transparent; color:#fff; font-size:11px; font-weight:700; cursor:pointer; }

/* ── TABS ── */
.tab-pane { display:none; padding-bottom:16px; }
.tab-pane.active { display:block; }

/* ── NAV ── */
.nav-bottom { position:fixed; bottom:0; left:0; right:0; background:var(--verde-dark); display:flex; z-index:100; padding-bottom:max(10px,env(safe-area-inset-bottom)); box-shadow:0 -2px 20px rgba(15,76,53,.3); }
.nav-tab { flex:1; display:flex; flex-direction:column; align-items:center; gap:3px; padding:10px 4px 6px; cursor:pointer; border:none; background:none; }
.nav-tab .nav-ico { font-size:20px; transition:transform .2s; }
.nav-tab .nav-lbl { font-size:10px; font-weight:600; color:rgba(255,255,255,.45); transition:color .2s; }
.nav-tab.active .nav-ico { transform:scale(1.2); }
.nav-tab.active .nav-lbl { color:#4ade80; }

/* ── FAB ── */
.fab { position:fixed; bottom:max(76px,calc(env(safe-area-inset-bottom) + 76px)); right:18px; width:54px; height:54px; border-radius:50%; background:linear-gradient(135deg,var(--verde-mid),#4ade80); border:none; color:#fff; font-size:26px; cursor:pointer; box-shadow:0 4px 20px rgba(26,122,80,.4); display:flex; align-items:center; justify-content:center; z-index:99; transition:transform .2s; }
.fab:active { transform:scale(.93); }

/* ================================================================
   STORIES BAR
   ================================================================ */
.stories-bar { padding:16px 18px 8px; display:flex; gap:14px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.stories-bar::-webkit-scrollbar { display:none; }
.story-item { display:flex; flex-direction:column; align-items:center; gap:5px; cursor:pointer; flex-shrink:0; }
.story-circle { width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; transition:transform .2s; }
.story-circle.new   { background:linear-gradient(135deg,var(--verde-mid),#4ade80); box-shadow:0 0 0 2px var(--gris-bg),0 0 0 4px var(--verde-mid); }
.story-circle.visto { background:#d1e8d9; box-shadow:0 0 0 2px var(--gris-bg),0 0 0 4px #d1e8d9; }
.story-item:active .story-circle { transform:scale(.93); }
.story-label { font-size:10px; color:var(--texto-soft); font-weight:600; text-align:center; max-width:56px; }

/* ================================================================
   FEED CARDS
   ================================================================ */
.feed { padding:8px 18px; display:flex; flex-direction:column; gap:14px; }
.feed-card { background:var(--gris-card); border-radius:18px; box-shadow:var(--sombra); overflow:hidden; animation:fadeUp .4s ease both; border:1px solid var(--gris-borde); }
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }

.fc-header { display:flex; align-items:center; gap:10px; padding:14px 16px 0; }
.fc-avatar { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.fc-avatar.verde    { background:var(--verde-claro); }
.fc-avatar.rojo     { background:var(--rojo-bg); }
.fc-avatar.amarillo { background:var(--amarillo-bg); }
.fc-meta  { flex:1; }
.fc-autor { font-size:12px; font-weight:600; color:var(--verde); }
.fc-tiempo{ font-size:11px; color:var(--texto-muted); }
.fc-badge { padding:3px 10px; border-radius:99px; font-size:11px; font-weight:700; }
.badge-rojo     { background:var(--rojo-bg);     color:var(--rojo); }
.badge-amarillo { background:var(--amarillo-bg); color:#b45309; }
.badge-verde    { background:var(--verde-claro); color:var(--verde); }
.badge-gris     { background:#f1f5f2; color:var(--texto-soft); }

.fc-body     { padding:12px 16px 10px; }
.fc-headline { font-family:var(--font-display); font-size:17px; font-weight:700; color:var(--texto); line-height:1.3; margin-bottom:6px; }
.fc-sub      { font-size:13px; color:var(--texto-soft); line-height:1.5; }
.fc-big-num  { font-family:var(--font-display); font-size:42px; font-weight:800; line-height:1; margin:12px 0 4px; }
.fc-big-num.rojo    { color:var(--rojo); }
.fc-big-num.amarillo{ color:var(--amarillo); }
.fc-big-num.verde   { color:var(--verde); }

.fc-footer    { padding:10px 16px 14px; display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--gris-borde); }
.fc-cta       { padding:8px 16px; border-radius:99px; border:none; background:var(--verde); color:#fff; font-family:var(--font-body); font-size:13px; font-weight:600; cursor:pointer; transition:transform .15s; }
.fc-cta:active{ transform:scale(.96); }
.fc-cta.outline { background:transparent; border:2px solid var(--gris-borde); color:var(--texto-soft); }
.fc-reacciones{ display:flex; gap:6px; }
.reac-btn     { background:none; border:none; font-size:18px; cursor:pointer; padding:4px; border-radius:8px; transition:transform .2s; }
.reac-btn:active { transform:scale(1.4); }

/* ── Semaforo ── */
.semaforo-bar  { display:flex; border-radius:12px; overflow:hidden; margin:12px 0 4px; height:10px; }
.sem-seg       { transition:width .6s ease; }
.sem-rojo      { background:var(--rojo); }
.sem-amarillo  { background:var(--amarillo); }
.sem-verde     { background:var(--verde-mid); }
.sem-legend    { display:flex; gap:14px; margin-top:6px; flex-wrap:wrap; }
.sem-dot       { display:flex; align-items:center; gap:5px; font-size:12px; color:var(--texto-soft); font-weight:500; }
.sem-dot::before { content:''; display:block; width:8px; height:8px; border-radius:50%; }
.sem-dot.r::before { background:var(--rojo); }
.sem-dot.a::before { background:var(--amarillo); }
.sem-dot.v::before { background:var(--verde-mid); }

/* ── Ahorro ── */
.ahorro-highlight { background:linear-gradient(135deg,var(--verde-dark),var(--verde)); border-radius:16px; padding:18px 20px; color:#fff; margin:10px 0 4px; }
.ahorro-highlight .aho-label { font-size:12px; opacity:.75; font-weight:600; }
.ahorro-highlight .aho-num   { font-family:var(--font-display); font-size:38px; font-weight:800; line-height:1.1; margin:4px 0; }
.ahorro-highlight .aho-sub   { font-size:13px; opacity:.75; }

/* ── Micro tip ── */
.micro-tip { background:linear-gradient(135deg,#dcfce7,#bbf7d0); border-radius:12px; padding:12px 14px; margin:0 18px 14px; display:flex; align-items:flex-start; gap:10px; border-left:3px solid var(--verde-mid); }
.micro-tip-ico { font-size:18px; flex-shrink:0; margin-top:1px; }
.micro-tip p   { font-size:13px; color:var(--verde-dark); line-height:1.5; }
.micro-tip strong { color:var(--verde); }

/* ================================================================
   INVENTARIO
   ================================================================ */
.inv-riesgo-banner { background:linear-gradient(135deg,var(--rojo-bg),#ffe4e4); border:1.5px solid var(--rojo); border-radius:16px; margin:16px 18px 8px; padding:14px 16px; display:flex; align-items:center; gap:12px; }
.inv-riesgo-ico    { font-size:24px; }
.inv-riesgo-monto  { font-family:var(--font-display); font-size:22px; font-weight:800; color:var(--rojo); }
.inv-riesgo-label  { font-size:12px; color:var(--rojo); opacity:.8; }
.inv-riesgo-btn    { margin-left:auto; padding:8px 14px; border-radius:99px; border:none; background:var(--rojo); color:#fff; font-size:13px; font-weight:700; cursor:pointer; flex-shrink:0; }

.inv-section       { padding:12px 18px 4px; }
.inv-section-title { font-family:var(--font-display); font-size:12px; font-weight:700; color:var(--texto-muted); letter-spacing:.5px; text-transform:uppercase; margin-bottom:10px; }

.prod-item    { background:var(--gris-card); border-radius:14px; padding:12px 14px; margin-bottom:10px; display:flex; align-items:center; gap:10px; box-shadow:0 1px 6px rgba(26,122,80,.07); border:1px solid var(--gris-borde); animation:fadeUp .3s ease both; }
.prod-sem     { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.prod-sem.r   { background:var(--rojo);     box-shadow:0 0 0 3px var(--rojo-bg); }
.prod-sem.a   { background:var(--amarillo); box-shadow:0 0 0 3px var(--amarillo-bg); }
.prod-sem.v   { background:var(--verde-mid);box-shadow:0 0 0 3px var(--verde-claro); }
.prod-ico     { font-size:22px; flex-shrink:0; }
.prod-info    { flex:1; min-width:0; }
.prod-nombre  { font-weight:700; font-size:15px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.prod-meta    { font-size:12px; color:var(--texto-muted); margin-top:2px; }
.prod-precio  { font-size:12px; color:var(--verde); font-weight:600; margin-top:2px; }
.prod-dias    { font-family:var(--font-display); font-size:13px; font-weight:700; text-align:right; flex-shrink:0; }
.prod-dias.r  { color:var(--rojo); }
.prod-dias.a  { color:var(--amarillo); }
.prod-dias.v  { color:var(--verde); }
.prod-actions { display:flex; gap:6px; flex-shrink:0; }
.prod-btn     { width:32px; height:32px; border-radius:8px; border:none; background:var(--gris-bg); font-size:14px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:transform .15s; }
.prod-btn:active { transform:scale(.9); }

/* ================================================================
   SHEETS / OVERLAY
   ================================================================ */
.overlay { position:fixed; inset:0; background:rgba(10,30,20,.55); z-index:200; display:none; backdrop-filter:blur(3px); }
.overlay.show { display:block; }

.sheet { position:fixed; bottom:0; left:0; right:0; background:#fff; border-radius:24px 24px 0 0; z-index:201; max-height:92vh; overflow-y:auto; transform:translateY(100%); transition:transform .35s cubic-bezier(.32,.72,0,1); padding-bottom:max(24px,env(safe-area-inset-bottom)); }
.sheet.open { transform:translateY(0); }
.sheet-handle { width:36px; height:4px; background:var(--gris-borde); border-radius:99px; margin:14px auto 16px; }
.sheet-title  { font-family:var(--font-display); font-size:20px; font-weight:700; color:var(--texto); padding:0 20px 14px; }

/* ── Forms ── */
.form-group  { padding:0 20px; margin-bottom:14px; }
.form-label  { font-size:12px; font-weight:700; color:var(--texto-soft); text-transform:uppercase; letter-spacing:.4px; margin-bottom:6px; display:block; }
.form-input  { width:100%; padding:13px 16px; border-radius:12px; border:1.5px solid var(--gris-borde); background:var(--gris-bg); font-family:var(--font-body); font-size:15px; color:var(--texto); outline:none; transition:border-color .2s; -webkit-appearance:none; }
.form-input:focus { border-color:var(--verde); }
select.form-input { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238aab99' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }

.cat-pills { display:flex; flex-wrap:wrap; gap:8px; }
.cat-pill  { padding:8px 14px; border-radius:99px; border:2px solid var(--gris-borde); background:var(--gris-bg); font-size:13px; font-weight:600; color:var(--texto-soft); cursor:pointer; transition:all .2s; user-select:none; }
.cat-pill.sel { border-color:var(--verde); background:var(--verde-claro); color:var(--verde); }

.sheet-actions { padding:8px 20px 4px; display:flex; flex-direction:column; gap:10px; }
.btn-sheet-primary   { width:100%; padding:15px; border-radius:14px; border:none; background:var(--verde); color:#fff; font-family:var(--font-display); font-size:16px; font-weight:700; cursor:pointer; transition:transform .15s; -webkit-appearance:none; }
.btn-sheet-primary:active { transform:scale(.98); }
.btn-sheet-secondary { width:100%; padding:13px; border-radius:14px; border:2px solid var(--gris-borde); background:transparent; color:var(--texto-soft); font-family:var(--font-body); font-size:15px; font-weight:600; cursor:pointer; -webkit-appearance:none; }
.btn-sheet-danger    { width:100%; padding:13px; border-radius:14px; border:2px solid var(--rojo-bg); background:var(--rojo-bg); color:var(--rojo); font-family:var(--font-body); font-size:15px; font-weight:700; cursor:pointer; -webkit-appearance:none; }

/* ================================================================
   CAPTURA — formulario unificado
   ================================================================ */
.captura-header { background:linear-gradient(135deg,var(--verde-dark),var(--verde)); padding:16px 20px 14px; display:flex; align-items:center; justify-content:space-between; }
.captura-titulo { font-family:var(--font-display); font-size:17px; font-weight:800; color:#fff; }
.captura-badge  { background:rgba(255,255,255,.2); color:#fff; font-size:11px; font-weight:700; padding:4px 10px; border-radius:99px; }

.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:0 20px; margin-bottom:14px; }
.form-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; padding:0 20px; margin-bottom:14px; }

.fecha-calculada { background:var(--verde-claro); border-radius:10px; padding:10px 14px; margin:0 20px 14px; font-size:13px; color:var(--verde); font-weight:600; }

/* ── Carrito preview ── */
.carrito-header { padding:12px 20px 8px; display:flex; align-items:center; justify-content:space-between; border-top:2px dashed var(--gris-borde); margin-top:8px; }
.carrito-titulo { font-family:var(--font-display); font-size:15px; font-weight:700; color:var(--texto); }
.carrito-badge  { background:var(--verde); color:#fff; font-size:12px; font-weight:700; padding:4px 12px; border-radius:99px; }
.carrito-lista  { padding:0 20px; max-height:35vh; overflow-y:auto; }
.carrito-empty  { text-align:center; padding:16px 0; font-size:13px; color:var(--texto-muted); }

.carrito-item   { background:var(--gris-bg); border-radius:12px; padding:11px 13px; margin-bottom:8px; display:flex; align-items:flex-start; gap:10px; border:1px solid var(--gris-borde); animation:fadeUp .25s ease both; }
.carrito-ico    { font-size:22px; flex-shrink:0; }
.carrito-info   { flex:1; min-width:0; }
.carrito-nombre { font-weight:700; font-size:14px; color:var(--texto); }
.carrito-meta   { font-size:12px; color:var(--texto-muted); margin-top:2px; }
.carrito-fecha-precio { display:flex; align-items:center; gap:10px; margin-top:3px; }
.con-fecha      { font-size:11px; color:var(--verde); font-weight:600; }
.sin-fecha      { font-size:11px; color:var(--texto-muted); }
.carrito-precio { font-size:11px; color:var(--verde); font-weight:700; background:var(--verde-claro); padding:2px 8px; border-radius:99px; }
.carrito-del    { width:28px; height:28px; border-radius:8px; border:none; background:var(--rojo-bg); color:var(--rojo); font-size:14px; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; }

/* ── Modo selector ── */
.modo-card { border-radius:18px; padding:18px 16px; cursor:pointer; display:flex; align-items:center; gap:14px; transition:transform .15s; }
.modo-card:active { transform:scale(.98); }
.modo-card-ico    { font-size:36px; flex-shrink:0; }
.modo-card-titulo { font-family:var(--font-display); font-size:16px; font-weight:700; }
.modo-card-sub    { font-size:13px; color:var(--texto-soft); margin-top:3px; }

/* ================================================================
   DETALLE PRODUCTO
   ================================================================ */
.det-hero   { background:linear-gradient(135deg,var(--verde-dark),var(--verde)); padding:24px 20px 20px; color:#fff; }
.det-icon   { font-size:40px; margin-bottom:8px; }
.det-nombre { font-family:var(--font-display); font-size:22px; font-weight:800; }
.det-badge  { display:inline-block; margin-top:6px; padding:4px 12px; border-radius:99px; font-size:12px; font-weight:700; }
.det-badge.r { background:var(--rojo);   color:#fff; }
.det-badge.a { background:var(--amarillo); color:#7c2d12; }
.det-badge.v { background:#4ade80; color:#0f4c35; }

.det-rows   { padding:16px 20px; }
.det-row    { display:flex; justify-content:space-between; align-items:center; padding:11px 0; border-bottom:1px solid var(--gris-borde); }
.det-row:last-child { border-bottom:none; }
.det-row-label { font-size:13px; color:var(--texto-muted); }
.det-row-val   { font-size:15px; font-weight:600; color:var(--texto); text-align:right; max-width:60%; }

.confirm-del      { background:var(--rojo-bg); border-radius:12px; padding:16px; margin:0 20px; display:none; }
.confirm-del.show { display:block; }
.confirm-del p    { font-size:14px; color:var(--rojo); font-weight:500; margin-bottom:12px; }
.confirm-del-btns { display:flex; gap:10px; }
.confirm-del-btns button { flex:1; padding:10px; border-radius:10px; font-family:var(--font-body); font-size:14px; font-weight:700; cursor:pointer; border:none; }
.btn-cancel-del { background:var(--gris-borde); color:var(--texto); }
.btn-ok-del     { background:var(--rojo); color:#fff; }

/* ================================================================
   LOGROS
   ================================================================ */
.logros-top   { padding:20px 18px 8px; }
.logros-titulo{ font-family:var(--font-display); font-size:20px; font-weight:800; color:var(--texto); margin-bottom:4px; }
.logros-sub   { font-size:13px; color:var(--texto-muted); }

.logros-stats { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; padding:0 18px 16px; }
.logros-stat  { border-radius:14px; padding:16px 10px; text-align:center; }
.logros-stat.verde  { background:var(--verde-claro); }
.logros-stat.rojo   { background:var(--rojo-bg); }
.logros-stat.oscuro { background:linear-gradient(135deg,var(--verde-dark),var(--verde)); }
.lstat-num { font-family:var(--font-display); font-size:22px; font-weight:800; }
.logros-stat.verde  .lstat-num { color:var(--verde); }
.logros-stat.rojo   .lstat-num { color:var(--rojo); }
.logros-stat.oscuro .lstat-num { color:#fff; font-size:16px; }
.lstat-lbl { font-size:10px; font-weight:600; margin-top:3px; }
.logros-stat.verde  .lstat-lbl { color:var(--verde); }
.logros-stat.rojo   .lstat-lbl { color:var(--rojo); }
.logros-stat.oscuro .lstat-lbl { color:rgba(255,255,255,.7); }

.logros-perdido { margin:0 18px 16px; background:var(--rojo-bg); border-radius:12px; padding:12px 16px; display:flex; justify-content:space-between; align-items:center; font-size:13px; color:var(--rojo); }
.logros-perdido strong { font-weight:800; }

.retos-titulo { font-family:var(--font-display); font-size:16px; font-weight:700; margin-bottom:14px; color:var(--texto); }
.reto-card    { background:var(--gris-card); border-radius:16px; padding:16px; margin-bottom:12px; box-shadow:var(--sombra); border:1px solid var(--gris-borde); }
.reto-header  { display:flex; align-items:center; gap:12px; margin-bottom:10px; }
.reto-ico     { font-size:28px; }
.reto-info    { flex:1; }
.reto-nombre  { font-weight:700; font-size:15px; color:var(--texto); }
.reto-desc    { font-size:12px; color:var(--texto-muted); margin-top:2px; }
.reto-contador{ font-family:var(--font-display); font-size:13px; font-weight:700; }
.reto-barra   { height:8px; background:var(--gris-borde); border-radius:99px; overflow:hidden; }
.reto-progreso{ height:100%; border-radius:99px; transition:width .6s ease; }

/* ================================================================
   PERFIL
   ================================================================ */
.perfil-hero    { background:linear-gradient(160deg,var(--verde-dark),var(--verde)); padding:40px 24px 28px; text-align:center; }
.perfil-avatar  { width:72px; height:72px; border-radius:50%; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:28px; font-weight:800; color:#fff; margin:0 auto 12px; border:3px solid rgba(255,255,255,.3); }
.perfil-nombre  { font-family:var(--font-display); font-size:22px; font-weight:800; color:#fff; }
.perfil-sub     { font-size:13px; color:rgba(255,255,255,.65); margin-top:4px; }
.perfil-stats   { display:grid; grid-template-columns:1fr 1fr 1fr; background:rgba(255,255,255,.1); border-radius:16px; margin:20px 0 0; overflow:hidden; }
.perfil-stat    { padding:14px 8px; text-align:center; border-right:1px solid rgba(255,255,255,.15); }
.perfil-stat:last-child { border-right:none; }
.perfil-stat-num{ font-family:var(--font-display); font-size:18px; font-weight:800; color:#fff; }
.perfil-stat-lbl{ font-size:10px; color:rgba(255,255,255,.6); margin-top:2px; }

.perfil-rows    { padding:12px 0; }
.perfil-row     { display:flex; align-items:center; gap:14px; padding:14px 20px; cursor:pointer; transition:background .15s; border-bottom:1px solid var(--gris-borde); }
.perfil-row:active { background:var(--gris-bg); }
.perfil-row-ico { width:38px; height:38px; border-radius:10px; background:var(--verde-claro); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.perfil-row-info  { flex:1; }
.perfil-row-title { font-size:15px; font-weight:600; color:var(--texto); }
.perfil-row-sub   { font-size:12px; color:var(--texto-muted); margin-top:2px; }
.perfil-row-right { font-size:14px; color:var(--texto-muted); }
.perfil-footer    { padding:16px 18px 32px; text-align:center; font-size:11px; color:var(--texto-muted); line-height:1.7; }

.badge-lic       { display:inline-flex; align-items:center; gap:4px; padding:4px 10px; border-radius:99px; font-size:11px; font-weight:700; }
.badge-lic.trial { background:var(--amarillo-bg); color:#b45309; }
.badge-lic.activa{ background:var(--verde-claro);  color:var(--verde); }
.badge-lic.vencida{background:var(--rojo-bg);      color:var(--rojo); }

/* ================================================================
   PLANES / LICENCIAS
   ================================================================ */
.plan-cards { display:flex; flex-direction:column; gap:12px; padding:0 20px; }
.plan-card  { border:2px solid var(--gris-borde); border-radius:16px; padding:16px; position:relative; }
.plan-popular { position:absolute; top:-10px; right:14px; background:var(--amarillo); color:#7c2d12; font-size:10px; font-weight:800; padding:3px 10px; border-radius:99px; }
.plan-name    { font-family:var(--font-display); font-size:16px; font-weight:700; }
.plan-price   { font-family:var(--font-display); font-size:26px; font-weight:800; color:var(--verde); margin:4px 0; }
.plan-price span { font-size:14px; font-weight:500; color:var(--texto-soft); }
.plan-features    { list-style:none; margin:10px 0 14px; }
.plan-features li { font-size:13px; color:var(--texto-soft); padding:3px 0 3px 18px; position:relative; }
.plan-features li::before { content:'✓'; position:absolute; left:0; color:var(--verde); font-weight:700; }
.btn-plan     { width:100%; padding:11px; border-radius:12px; border:none; background:var(--verde); color:#fff; font-family:var(--font-display); font-size:14px; font-weight:700; cursor:pointer; transition:transform .15s; }
.btn-plan:active { transform:scale(.98); }

/* ================================================================
   IA CONFIG
   ================================================================ */
.ia-toggle-row { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--gris-borde); }
.toggle-switch   { position:relative; width:48px; height:26px; }
.toggle-switch input { display:none; }
.toggle-slider   { position:absolute; inset:0; background:#d1e8d9; border-radius:99px; cursor:pointer; transition:background .3s; }
.toggle-slider::before { content:''; position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:#fff; transition:transform .3s; box-shadow:0 1px 4px rgba(0,0,0,.2); }
.toggle-switch input:checked + .toggle-slider { background:var(--verde); }
.toggle-switch input:checked + .toggle-slider::before { transform:translateX(22px); }
.prov-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; padding:0 20px 16px; }
.prov-card { border:2px solid var(--gris-borde); border-radius:14px; padding:14px 10px; text-align:center; cursor:pointer; transition:all .2s; }
.prov-card.sel { border-color:var(--verde); background:var(--verde-claro); }
.prov-ico     { font-size:24px; margin-bottom:6px; }
.prov-name    { font-size:12px; font-weight:700; color:var(--texto); }
.prov-empresa { font-size:10px; color:var(--texto-muted); margin-top:1px; }

/* ================================================================
   COCINA INVERSA
   ================================================================ */
.receta-container { background:linear-gradient(135deg,#f0fdf4,#dcfce7); border-radius:12px; padding:14px; margin:12px 20px 4px; border:1.5px solid #86efac; }
.receta-loading   { display:flex; align-items:center; gap:10px; color:var(--verde); font-size:14px; font-weight:500; }
.spinner          { width:20px; height:20px; border:2.5px solid #bbf7d0; border-top-color:var(--verde); border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }
.receta-text      { font-size:13px; line-height:1.7; color:var(--texto); white-space:pre-wrap; }

/* ================================================================
   WA PREVIEW
   ================================================================ */
.wa-textarea { width:calc(100% - 40px); margin:0 20px; min-height:200px; max-height:40vh; padding:14px; border-radius:12px; border:1.5px solid #25D366; background:#F0FDF4; font-family:var(--font-body); font-size:14px; line-height:1.6; color:var(--texto); resize:none; overflow-y:auto; outline:none; display:block; }
.wa-char-count { font-size:12px; color:var(--texto-muted); text-align:right; padding:4px 20px 10px; }

/* ================================================================
   CELEBRACION
   ================================================================ */
.celebracion-overlay { position:fixed; inset:0; background:rgba(10,30,20,.75); z-index:500; display:none; align-items:center; justify-content:center; overflow:hidden; }
.celebracion-overlay.show { display:flex; }
.celebracion-card  { background:#fff; border-radius:24px; padding:36px 28px; text-align:center; max-width:300px; width:90%; animation:bounceIn .5s cubic-bezier(.175,.885,.32,1.275); position:relative; z-index:2; }
@keyframes bounceIn { 0%{transform:scale(.3);opacity:0} 60%{transform:scale(1.05);opacity:1} 80%{transform:scale(.97)} 100%{transform:scale(1)} }
.cel-ico    { font-size:56px; margin-bottom:12px; }
.cel-titulo { font-family:var(--font-display); font-size:22px; font-weight:800; color:var(--texto); margin-bottom:8px; }
.cel-desc   { font-size:14px; color:var(--texto-soft); line-height:1.5; margin-bottom:20px; }
.cel-btn    { width:100%; padding:13px; border-radius:14px; border:none; background:var(--verde); color:#fff; font-family:var(--font-display); font-size:15px; font-weight:700; cursor:pointer; }
.confetti-piece { position:fixed; width:10px; height:10px; border-radius:2px; z-index:1; pointer-events:none; }
@keyframes confettiFall { 0%{transform:translateY(0) rotate(0deg);opacity:1} 100%{transform:translateY(100vh) rotate(720deg);opacity:0} }

/* ================================================================
   TOAST
   ================================================================ */
.toast { position:fixed; bottom:96px; left:50%; transform:translateX(-50%) translateY(20px); background:rgba(15,76,53,.95); color:#fff; padding:10px 22px; border-radius:99px; font-family:var(--font-body); font-size:14px; font-weight:600; z-index:400; opacity:0; transition:all .3s; white-space:nowrap; backdrop-filter:blur(8px); pointer-events:none; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ================================================================
   EMPTY STATE
   ================================================================ */
.empty-state    { text-align:center; padding:48px 24px; }
.empty-state .ico { font-size:52px; margin-bottom:14px; }
.empty-state h3 { font-family:var(--font-display); font-size:18px; font-weight:700; margin-bottom:8px; }
.empty-state p  { font-size:14px; color:var(--texto-soft); line-height:1.5; margin-bottom:20px; }
.btn-primary    { padding:13px 24px; border-radius:14px; border:none; background:var(--verde); color:#fff; font-family:var(--font-display); font-size:15px; font-weight:700; cursor:pointer; -webkit-appearance:none; }
