/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

/* ===== VARIABLES ===== */
:root {
  --bg: #F0EDFF;
  --card: #FFFFFF;
  --text: #1A1040;
  --text-muted: #7C6FAB;
  --border: #E2DCF8;
  --shadow: 0 8px 32px rgba(124,58,237,.10);
  --shadow-hover: 0 16px 40px rgba(124,58,237,.20);
  --purple: #7C3AED;
  --purple-light: #EDE9FE;
  --pink: #EC4899;
  --orange: #F97316;
  --green: #10B981;
  --radius: 20px;
}
body.dark {
  --bg: #0D0B1A;
  --card: #1A1535;
  --text: #F0EDFF;
  --text-muted: #9D8FCC;
  --border: #2D2555;
  --shadow: 0 8px 32px rgba(0,0,0,.5);
  --purple-light: #1E1650;
}

/* ===== BASE ===== */
body {
  font-family: 'Nunito', sans-serif;
  background: var(--bg);
  color: var(--text);
  transition: background .3s, color .3s;
  min-height: 100vh;
}

/* ===== CONFETI ===== */
#confetti-canvas {
  position:fixed; top:0; left:0;
  width:100%; height:100%;
  pointer-events:none; z-index:9999;
}

/* ===== TOAST ===== */
#toast {
  position:fixed; bottom:28px; left:50%;
  transform:translateX(-50%) translateY(100px);
  background:linear-gradient(135deg,var(--purple),var(--pink));
  color:white; padding:13px 26px;
  border-radius:99px; font-weight:800; font-size:.92rem;
  box-shadow:0 8px 24px rgba(124,58,237,.4);
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
  z-index:9998; white-space:nowrap; max-width:90vw; text-align:center;
}
#toast.show { transform:translateX(-50%) translateY(0); }

/* ===== LAYOUT ===== */
.app { max-width:960px; margin:auto; padding:16px; }

/* ===== TOPBAR ===== */
.topbar {
  display:flex; justify-content:space-between;
  align-items:center; margin-bottom:20px; gap:12px;
}
.logo-wrap { display:flex; align-items:center; gap:12px; }
.logo-icon {
  font-size:1.8rem;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  width:48px; height:48px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(124,58,237,.35);
}
.topbar h1 {
  font-size:1.5rem; font-weight:900;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.topbar p { color:var(--text-muted); font-size:.8rem; }
.topbar-actions { display:flex; gap:8px; align-items:center; }

select {
  padding:7px 10px;
  border:2px solid var(--border); border-radius:10px;
  font-family:'Nunito',sans-serif; font-size:.82rem; font-weight:700;
  background:var(--card); color:var(--text); cursor:pointer;
}
#themeToggle {
  border:2px solid var(--border); background:var(--card);
  padding:7px 11px; border-radius:10px;
  cursor:pointer; font-size:1rem;
  transition:transform .2s;
}
#themeToggle:hover { transform:scale(1.15); }

/* ===== HERO ===== */
.hero-banner {
  background:linear-gradient(135deg,var(--purple) 0%,var(--pink) 100%);
  border-radius:var(--radius); padding:24px 28px;
  margin-bottom:18px; display:flex;
  align-items:center; justify-content:space-between;
  color:white; box-shadow:0 12px 40px rgba(124,58,237,.35);
  animation:slideDown .5s ease;
}
.hero-text h2 { font-size:1.5rem; font-weight:900; }
.hero-text p { font-size:.88rem; opacity:.9; margin-top:4px; max-width:320px; }
.hero-emoji { font-size:3rem; animation:bounce 2s infinite; }

@keyframes bounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes slideDown { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
@keyframes pop { from{transform:scale(0);opacity:0} to{transform:scale(1);opacity:1} }
@keyframes spin { to{transform:rotate(360deg)} }

/* ===== STATS ===== */
.stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  gap:12px; margin-bottom:18px;
}
.stat-card {
  border-radius:var(--radius); padding:18px;
  color:white; position:relative; overflow:hidden;
  transition:transform .2s,box-shadow .2s;
  animation:fadeUp .5s ease both;
}
.stat-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-hover); }
.stat-card::after {
  content:''; position:absolute;
  width:70px; height:70px; border-radius:50%;
  background:rgba(255,255,255,.12);
  bottom:-18px; right:-18px;
}
.card-purple { background:linear-gradient(135deg,#7C3AED,#9F67F7); box-shadow:0 6px 22px rgba(124,58,237,.35); }
.card-orange  { background:linear-gradient(135deg,#F97316,#FBBF24); box-shadow:0 6px 22px rgba(249,115,22,.35); }
.card-green   { background:linear-gradient(135deg,#10B981,#34D399); box-shadow:0 6px 22px rgba(16,185,129,.35); }
.card-pink    { background:linear-gradient(135deg,#EC4899,#F472B6); box-shadow:0 6px 22px rgba(236,72,153,.35); }
.stat-card:nth-child(1){animation-delay:.05s}
.stat-card:nth-child(2){animation-delay:.1s}
.stat-card:nth-child(3){animation-delay:.15s}
.stat-card:nth-child(4){animation-delay:.2s}
.stat-icon { font-size:1.5rem; margin-bottom:6px; }
.stat-card span { font-size:.75rem; font-weight:700; opacity:.85; text-transform:uppercase; letter-spacing:.06em; }
.stat-card h3 { font-size:1.55rem; font-weight:900; margin:4px 0 2px; }
.stat-card small { font-size:.72rem; opacity:.85; }

/* ===== CARD ===== */
.card {
  background:var(--card); border-radius:var(--radius);
  padding:22px; box-shadow:var(--shadow);
  margin-bottom:18px; transition:background .3s;
}

/* ===== PROGRESS ===== */
.progress-card { padding:18px 22px; }
.progress-header {
  display:flex; justify-content:space-between;
  font-size:.82rem; font-weight:800;
  color:var(--text-muted); margin-bottom:8px;
}
.progress-bar {
  height:13px; background:var(--border);
  border-radius:99px; overflow:hidden; margin-bottom:8px;
}
.progress-fill {
  height:100%; width:0%; border-radius:99px;
  background:linear-gradient(90deg,#10B981,#34D399);
  transition:width .8s cubic-bezier(.34,1.2,.64,1),background .4s;
}
#progressLabel { font-size:.82rem; color:var(--text-muted); font-weight:700; }

/* ===== TABS ===== */
.tabs {
  display:flex; gap:6px; margin-bottom:14px;
  background:var(--card); padding:5px;
  border-radius:16px; box-shadow:var(--shadow);
  overflow-x:auto;
}
.tab {
  flex:1; min-width:fit-content;
  padding:9px 8px; border:none; border-radius:12px;
  font-family:'Nunito',sans-serif;
  font-size:.82rem; font-weight:800;
  cursor:pointer; background:transparent;
  color:var(--text-muted); transition:all .2s; white-space:nowrap;
}
.tab.active {
  background:linear-gradient(135deg,var(--purple),var(--pink));
  color:white; box-shadow:0 4px 14px rgba(124,58,237,.35);
}
.tab-content { display:none; }
.tab-content.active { display:block; }
.section-title { font-size:1rem; font-weight:900; margin-bottom:16px; }

/* ===== INPUTS COMPARTIDOS ===== */
.add-item { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.add-item input, .add-item select {
  flex:1; min-width:120px;
  padding:10px 12px;
  border:2px solid var(--border); border-radius:11px;
  font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:700;
  background:var(--bg); color:var(--text);
  transition:border-color .2s;
}
.add-item input:focus, .add-item select:focus { outline:none; border-color:var(--purple); }

.btn-add {
  padding:10px 18px;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  color:white; border:none; border-radius:11px;
  font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:900;
  cursor:pointer; box-shadow:0 4px 14px rgba(124,58,237,.3);
  transition:transform .15s,box-shadow .15s; white-space:nowrap;
}
.btn-add:hover { transform:translateY(-2px); box-shadow:0 8px 20px rgba(124,58,237,.4); }
.btn-add:active { transform:scale(.97); }

/* ===== SUGERENCIAS ===== */
#suggestions,.sug-wrap { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:10px; }
.sug-badge {
  padding:5px 13px;
  background:var(--purple-light); color:var(--purple);
  border:none; border-radius:99px;
  font-family:'Nunito',sans-serif; font-size:.78rem; font-weight:800;
  cursor:pointer; transition:background .2s,transform .1s;
}
.sug-badge:hover { background:#DDD6FE; transform:scale(1.06); }
.sug-tag {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px;
  background:linear-gradient(135deg,#EDE9FE,#FCE7F3);
  border-radius:99px; font-size:.8rem; font-weight:800;
  color:var(--purple);
}
.sug-tag button {
  background:none; border:none; cursor:pointer;
  font-size:.8rem; color:var(--pink); font-weight:900; padding:0;
}

/* ===== GRAFICO ===== */
.chart-wrap {
  background:var(--bg); border-radius:14px;
  padding:14px; margin-bottom:12px;
}
.chart-title { font-size:.85rem; font-weight:800; margin-bottom:10px; color:var(--text-muted); }
.cat-row { display:flex; align-items:center; gap:8px; margin-bottom:7px; }
.cat-label { font-size:.85rem; min-width:26px; }
.cat-bar-wrap { flex:1; background:var(--border); border-radius:99px; height:10px; overflow:hidden; }
.cat-bar-fill { height:100%; border-radius:99px; transition:width .6s ease; }
.cat-amount { font-size:.78rem; font-weight:800; color:var(--text-muted); min-width:72px; text-align:right; }

/* ===== LISTA ===== */
.item-list { list-style:none; display:flex; flex-direction:column; gap:7px; }
.item-li {
  display:flex; align-items:center; gap:9px;
  background:var(--bg); border-radius:11px;
  padding:11px 14px; font-size:.88rem; font-weight:700;
  animation:fadeUp .3s ease; transition:transform .15s;
}
.item-li:hover { transform:translateX(3px); }
.item-li .cat { font-size:1.05rem; }
.item-li .name { flex:1; }
.item-li .price {
  background:linear-gradient(135deg,var(--purple),var(--pink));
  -background-clip:text;
   -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  font-weight:900;
}
.item-li .del-btn {
  background:none; border:none; cursor:pointer;
  font-size:.88rem; color:var(--text-muted);
  padding:4px 6px; border-radius:8px; transition:background .2s,color .2s;
}
.item-li .del-btn:hover { background:#FEE2E2; color:#EF4444; }

.list-footer {
  display:flex; justify-content:space-between; align-items:center;
  margin-top:12px; padding-top:11px;
  border-top:2px dashed var(--border); font-size:.88rem; font-weight:800;
}
.btn-ghost-danger {
  padding:6px 13px; background:transparent; color:#EF4444;
  border:2px solid #EF4444; border-radius:9px;
  font-family:'Nunito',sans-serif; font-size:.78rem; font-weight:800;
  cursor:pointer; transition:background .2s;
}
.btn-ghost-danger:hover { background:#FEF2F2; }

.btn-big {
  width:100%; margin-top:18px; padding:15px;
  background:linear-gradient(135deg,#7C3AED,#EC4899);
  color:white; border:none; border-radius:14px;
  font-family:'Nunito',sans-serif;
  font-size:.95rem; font-weight:900; cursor:pointer;
  box-shadow:0 8px 24px rgba(124,58,237,.4);
  transition:transform .2s,box-shadow .2s;
}
.btn-big:hover { transform:translateY(-3px); box-shadow:0 14px 32px rgba(124,58,237,.5); }
.btn-big:active { transform:scale(.98); }

/* ===== HOGAR RESUMEN ===== */
.hogar-resumen {
  margin-top:18px; background:var(--bg);
  border-radius:14px; padding:16px;
  display:flex; flex-direction:column; gap:10px;
}
.resumen-row {
  display:flex; justify-content:space-between;
  align-items:center; font-size:.9rem; font-weight:700;
  padding-bottom:8px; border-bottom:1px solid var(--border);
}
.resumen-row:last-child { border:none; }
.resumen-total { font-size:1rem; }
.resumen-total strong { color:var(--green); font-size:1.1rem; }

/* ===== MENÚ SEMANAL ===== */
.week-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
  gap:10px;
}
.day-card {
  background:var(--bg); border-radius:13px;
  padding:12px; display:flex; flex-direction:column; gap:7px;
}
.day-name { font-size:.7rem; font-weight:900; text-transform:uppercase; letter-spacing:.08em; color:var(--purple); }
.day-emoji { font-size:1.3rem; }
.meal-label { font-size:.62rem; font-weight:800; color:var(--text-muted); text-transform:uppercase; margin-bottom:2px; }
.day-card input {
  border:2px solid var(--border); border-radius:8px;
  padding:5px 7px; font-size:.76rem; font-weight:700;
  font-family:'Nunito',sans-serif;
  background:var(--card); color:var(--text); width:100%;
  transition:border-color .2s;
}
.day-card input:focus { outline:none; border-color:var(--purple); }

/* ===== RULETA ===== */
.ruleta-desc { color:var(--text-muted); font-size:.88rem; font-weight:700; margin-bottom:20px; }
.ruleta-wrap {
  display:flex; flex-direction:column;
  align-items:center; margin-bottom:18px; position:relative;
}
.ruleta-pointer {
  font-size:2rem; color:var(--purple);
  text-shadow:0 2px 8px rgba(124,58,237,.4);
  margin-bottom:-8px; z-index:2; position:relative;
}
#ruletaCanvas {
  border-radius:50%;
  box-shadow:0 8px 40px rgba(124,58,237,.35);
  cursor:pointer;
  transition:box-shadow .2s;
}
#ruletaCanvas:hover { box-shadow:0 12px 48px rgba(124,58,237,.5); }

.btn-spin {
  display:block; margin:0 auto 18px;
  padding:14px 40px;
  background:linear-gradient(135deg,#F97316,#FBBF24);
  color:white; border:none; border-radius:99px;
  font-family:'Nunito',sans-serif;
  font-size:1.05rem; font-weight:900; cursor:pointer;
  box-shadow:0 8px 24px rgba(249,115,22,.4);
  transition:transform .2s,box-shadow .2s;
}
.btn-spin:hover { transform:translateY(-3px) scale(1.04); }
.btn-spin:active { transform:scale(.97); }
.btn-spin:disabled { opacity:.6; cursor:not-allowed; transform:none; }

.ruleta-result {
  text-align:center; font-size:1.3rem; font-weight:900;
  padding:14px; border-radius:14px;
  min-height:54px; transition:all .3s;
  margin-bottom:18px;
}
.ruleta-result.show {
  background:linear-gradient(135deg,#EDE9FE,#FCE7F3);
  color:var(--purple); animation:pop .4s cubic-bezier(.34,1.56,.64,1);
}
.ruleta-custom h3 { font-size:.92rem; font-weight:900; margin-bottom:2px; }

/* ===== CALCULADORA ===== */
.tabs-inner {
  display:flex; gap:6px; margin-bottom:16px;
  background:var(--bg); padding:4px; border-radius:12px;
}
.tab-inner {
  flex:1; padding:8px 6px; border:none; border-radius:9px;
  font-family:'Nunito',sans-serif; font-size:.8rem; font-weight:800;
  cursor:pointer; background:transparent; color:var(--text-muted);
  transition:all .2s;
}
.tab-inner.active {
  background:var(--card); color:var(--purple);
  box-shadow:0 2px 8px rgba(124,58,237,.15);
}
.inner-content { display:none; }
.inner-content.active { display:block; }
.calc-desc { color:var(--text-muted); font-size:.85rem; font-weight:700; margin-bottom:14px; }
.calc-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px; margin-bottom:14px;
}
.field { display:flex; flex-direction:column; gap:6px; }
.field label { font-size:.82rem; font-weight:800; color:var(--text-muted); }
.field input {
  padding:10px 13px;
  border:2px solid var(--border); border-radius:11px;
  font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:700;
  background:var(--bg); color:var(--text); transition:border-color .2s;
}
.field input:focus { outline:none; border-color:var(--purple); }
.btn-save {
  padding:9px;
  background:var(--purple-light); color:var(--purple);
  border:2px solid var(--purple); border-radius:11px;
  font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:900;
  cursor:pointer; transition:all .2s;
}
.btn-save:hover { background:var(--purple); color:white; }
.btn-calc {
  padding:12px 28px;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  color:white; border:none; border-radius:12px;
  font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:900;
  cursor:pointer; box-shadow:0 4px 14px rgba(124,58,237,.3);
  transition:transform .15s;
}
.btn-calc:hover { transform:translateY(-2px); }
.calc-result {
  margin-top:14px; padding:14px; border-radius:13px;
  font-weight:800; font-size:.9rem; min-height:48px;
  background:linear-gradient(135deg,#EDE9FE,#FCE7F3);
  color:var(--purple); display:none;
}
.calc-result.show { display:block; animation:fadeUp .3s ease; }

/* ===== CHANCHITO ===== */
.chanchito-wrap {
  background:var(--bg); border-radius:16px;
  padding:18px; margin-top:18px;
}
.chanchito-body { display:flex; align-items:center; gap:16px; margin-top:12px; }
.pig-anim {
  font-size:3rem; animation:bounce 2s infinite;
  transition:font-size .5s;
}
.pig-info { flex:1; }
.pig-bar-wrap {
  height:14px; background:var(--border);
  border-radius:99px; overflow:hidden; margin-bottom:8px;
}
.pig-bar {
  height:100%; width:0%;
  background:linear-gradient(90deg,#EC4899,#FBBF24);
  border-radius:99px; transition:width .8s ease;
}
#pigLabel { font-size:.82rem; font-weight:800; color:var(--text-muted); }

/* ===== LOGROS ===== */
.logros-wrap { display:flex; flex-wrap:wrap; gap:8px; }
.logro-badge {
  padding:7px 16px;
  background:linear-gradient(135deg,#FEF9C3,#FDE68A);
  border-radius:99px; font-size:.82rem; font-weight:800;
  color:#92400E; border:2px solid #FCD34D;
  animation:pop .3s cubic-bezier(.34,1.56,.64,1);
}
.no-logros { color:var(--text-muted); font-size:.88rem; font-weight:700; }

/* ===== HISTORIAL ===== */
.historial-wrap { display:flex; flex-direction:column; gap:9px; }
.hist-row {
  display:flex; align-items:center; gap:11px;
  background:var(--bg); border-radius:11px;
  padding:11px 14px; font-size:.86rem; font-weight:700;
}
.hist-num {
  background:linear-gradient(135deg,var(--purple),var(--pink));
  color:white; border-radius:99px;
  width:26px; height:26px;
  display:flex; align-items:center; justify-content:center;
  font-size:.76rem; font-weight:900; flex-shrink:0;
}
.hist-info { flex:1; line-height:1.5; }
.hist-info span { color:var(--text-muted); font-size:.76rem; }
.hist-saved { color:var(--green); font-weight:900; }

/* ===== RESPONSIVE ===== */
@media (max-width:600px) {
  .topbar { flex-direction:column; align-items:flex-start; }
  .topbar h1 { font-size:1.25rem; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .hero-emoji { display:none; }
  .add-item { flex-direction:column; }
  .week-grid { grid-template-columns:1fr 1fr; }
  #ruletaCanvas { width:260px; height:260px; }
}
/* ==========================
   CORRECCIONES FINALES
========================== */

.card-inner{
  background:var(--card);
}

.config-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;
}

.config-grid .field{
  background:var(--bg);
  padding:14px;
  border-radius:14px;
}

/* Mejoras responsive ruleta */
#ruletaCanvas{
  max-width:100%;
  height:auto;
}

/* Scroll más lindo */
::-webkit-scrollbar{
  width:10px;
  height:10px;
}

::-webkit-scrollbar-track{
  background:var(--bg);
}

::-webkit-scrollbar-thumb{
  background:linear-gradient(
    180deg,
    var(--purple),
    var(--pink)
  );
  border-radius:99px;
}

/* Animación suave tabs */
.tab-content{
  animation:fadeUp .25s ease;
}

/* Inputs numéricos */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button{
  opacity:1;
}

/* Mejor visualización móvil */
@media (max-width:480px){

  .stats-grid{
    grid-template-columns:1fr;
  }

  .week-grid{
    grid-template-columns:1fr;
  }

  .calc-grid{
    grid-template-columns:1fr;
  }

  .hero-banner{
    padding:18px;
  }

  .hero-text h2{
    font-size:1.2rem;
  }

  .hero-text p{
    font-size:.8rem;
  }

  .btn-spin{
    width:100%;
  }
}