*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  /* Paleta natural/orgánica */
  --cream:#FFF8F0;       /* fondo principal */
  --cream2:#FEF1E6;      /* fondo cards */
  --sand:#F5E6D3;      /* bordes, dividers */
  --gray-light:#C4BDB5;      /* bordes más marcados */
  --deep:#2D6A4F;        /* verde oscuro — acción principal */
  --deep2:#1E4D38;       /* verde hover */
  --mid:#52B788;        /* verde medio */
  --sage:#95D5B2;       /* verde claro */
  --sage-light:#D8F3DC;        /* verde muy suave */
  --sage-light:#D8F3DC;       /* verde casi blanco */
  --dark:#2A2520;        /* texto principal — marrón cálido */
  --dark2:#3D3229;       /* texto secundario */
  --gray:#8B8178;       /* texto terciario/placeholder */
  --gold:#8a6914;        /* dorado cálido */
  --gold2:#b8900f;
  --goldl:#fef3cd;
  --terra:#E07A5F;   /* error/alerta */
  --terra-light:#F4B8A8;
  --sky:#2a5f8a;
  --skyl:#deeef9;
  --white:#ffffff;
  --r:14px; --rs:9px; --rl:22px;
  --nav-height:0px;
  --nav-gap:14px;
  --app-height:100dvh;
  --screen-end-space:50px;
  --sh:0 2px 12px rgba(61,47,30,0.06);
  --sh2:0 4px 24px rgba(61,47,30,0.10);
  font-family:'Plus Jakarta Sans',sans-serif;
}
html,body{height:100%;overflow:hidden;background:var(--white)}
body{color:var(--dark);max-width:430px;margin:0 auto;position:relative}

/* VERSIÓN WEB - pantallas grandes */
@media (min-width: 768px) {
  body{max-width:600px}
  .content{padding:24px 20px calc(100px + env(safe-area-inset-bottom, 0px))}
  .card{padding:20px 24px}
  .nav{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom,0px));left:50%;transform:translateX(-50%);border-radius:50px;box-shadow:var(--sh2);padding:10px 24px;background:var(--white)}
  .hdr{padding:16px 20px}
  .msheet{max-width:500px}
  #screen-login{max-width:380px;margin:0 auto}
}
@media (min-width: 1024px) {
  body{max-width:700px}
  .card{padding:22px 28px}
}

/* Botón usuario en header */
.user-btn{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;background:var(--cream2);border:1px solid var(--sand);border-radius:24px;cursor:pointer;transition:all .15s}
.user-btn:hover{background:var(--sand)}
.user-avatar-sm{width:26px;height:26px;border-radius:50%;background:var(--sage-light);display:grid;place-items:center;font-size:11px;font-weight:700;color:var(--deep);overflow:hidden}
.user-avatar-sm img{width:100%;height:100%;object-fit:cover}
.user-btn-name{font-size:12px;font-weight:600;color:var(--dark);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--white);border:1px solid var(--sand);border-radius:var(--r);box-shadow:var(--sh2);min-width:200px;z-index:300;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s}
.user-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}
.user-dropdown-header{padding:14px 16px;border-bottom:1px solid var(--sand)}
.user-dropdown-name{font-weight:700;color:var(--dark);font-size:14px}
.user-dropdown-email{font-size:12px;color:var(--gray);margin-top:2px}
.user-dropdown-item{display:flex;align-items:center;gap:10px;padding:12px 16px;font-size:13px;color:var(--dark);cursor:pointer;transition:background .15s}
.user-dropdown-item:hover{background:var(--cream)}
.user-dropdown-item svg{width:16px;height:16px;stroke:var(--gray);stroke-width:2;fill:none}
.user-dropdown-item.danger{color:var(--terra)}
.user-dropdown-item.danger svg{stroke:var(--terra)}

.app{display:grid;grid-template-rows:auto minmax(0,1fr) auto;height:100vh;height:var(--app-height)}

/* HEADER — limpio, cálido, natural */
.hdr{background:var(--white);border-bottom:1px solid var(--sand);padding:14px 18px 12px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:9px}
.lleaf{width:32px;height:32px;background:var(--sage-light);border-radius:50%;display:grid;place-items:center}
.lleaf svg{width:17px;height:17px;fill:none;stroke:var(--deep);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.lname{font-family:'Fredoka',sans-serif;font-size:20px;font-weight:600;color:var(--dark);letter-spacing:-.2px}
.lsub{font-size:10px;color:var(--gray);font-weight:500;margin-top:1px;letter-spacing:.2px}
.hdr-right{display:flex;align-items:center;gap:8px}
.pbadge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:.3px}
.pb-trial{background:var(--goldl);color:var(--gold)}
.pb-basic{background:var(--skyl);color:var(--sky)}
.pb-pro{background:var(--sage-light);color:var(--deep)}
.trial-ct{font-size:11px;color:var(--gray);font-weight:600}

/* CONTENT */
.content{min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:18px 16px calc(16px + env(safe-area-inset-bottom, 0px))}

/* NAV — barra inferior fija, 4 botones bien espaciados */
.nav{position:relative;max-width:430px;margin:0 auto;background:var(--white);border-top:1px solid var(--sand);padding:10px max(20px,env(safe-area-inset-right,0px)) calc(24px + env(safe-area-inset-bottom,0px)) max(20px,env(safe-area-inset-left,0px));display:flex;justify-content:space-around;align-items:center;z-index:100;box-shadow:0 -2px 10px rgba(61,47,30,0.05)}
.nb{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 16px;cursor:pointer;border:none;background:none;border-radius:12px;transition:background .15s;min-width:60px}
.nb:hover{background:var(--sage-light)}
.nb svg{width:22px;height:22px;fill:none;stroke:var(--gray-light);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:stroke .15s}
.nb span{font-size:10px;color:var(--gray-light);font-weight:600;font-family:'Plus Jakarta Sans',sans-serif;transition:color .15s}
.nb.active svg{stroke:var(--deep)}
.nb.active span{color:var(--deep)}

/* Botón instalar pequeño flotante - esquina superior derecha del content */
.fab-install{position:fixed;top:70px;right:12px;display:none;align-items:center;gap:5px;padding:7px 12px;background:var(--deep);color:#fff;border:none;border-radius:20px;font-size:11px;font-weight:600;font-family:'Plus Jakarta Sans',sans-serif;cursor:pointer;box-shadow:0 2px 8px rgba(88,129,87,0.3);z-index:90;transition:transform .2s,opacity .2s}
.fab-install:hover{transform:scale(1.05)}
.fab-install:active{transform:scale(0.98)}
.fab-install svg{width:14px;height:14px;fill:none;stroke:#fff;stroke-width:2.5}
.fab-install.visible{display:flex}

@media (min-width: 768px) {
  body{max-width:600px}
  .nav{max-width:360px;bottom:calc(16px + env(safe-area-inset-bottom,0px));left:50%;right:auto;transform:translateX(-50%);border-radius:50px;border:none;padding:10px 28px;box-shadow:var(--sh2)}
  .nb{padding:8px 14px;min-width:55px}
  .content{padding:20px 20px calc(var(--nav-height) + var(--nav-gap) + env(safe-area-inset-bottom, 0px))}
  .fab-install{display:none !important}
}

@media (min-width: 768px) {
  .app{display:flex;flex-direction:column;height:100vh;height:var(--app-height)}
  .content{flex:1;min-height:auto}
  .nav{position:fixed}
}

/* SCREENS */
.screen{display:none;animation:fi .2s ease}
.screen.active{display:block;padding-bottom:calc(var(--screen-end-space) + env(safe-area-inset-bottom, 0px))}

#screen-login{
  overflow-y:auto;
  min-height:100%;
  padding-bottom:calc(40px + env(safe-area-inset-bottom, 0px)) !important;
}
@keyframes fi{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* TYPOGRAPHY */
.ptitle{font-family:'Fredoka',sans-serif;font-size:24px;font-weight:600;color:var(--dark);margin-bottom:4px;letter-spacing:-.3px}
.ptitle em{color:var(--deep);font-style:italic}
.psub{font-size:13px;color:var(--gray);margin-bottom:18px;line-height:1.6;font-weight:400}

/* CARDS */
.card{background:var(--white);border:1px solid var(--sand);border-radius:var(--r);padding:16px;margin-bottom:12px;box-shadow:var(--sh)}
.card-deep{background:var(--deep);border:none;border-radius:var(--r);padding:16px;margin-bottom:12px}
.card-mint{background:var(--sage-light);border:1px solid var(--sage);border-radius:var(--r);padding:16px;margin-bottom:12px}
.card-cream{background:var(--cream2);border:1px solid var(--sand);border-radius:var(--r);padding:16px;margin-bottom:12px}
.clbl{font-size:10px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-family:'Plus Jakarta Sans',sans-serif}

/* FORMS */
.field{margin-bottom:13px}
.field label{display:block;font-size:11px;font-weight:700;color:var(--gray);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1.5px solid var(--sand);border-radius:var(--rs);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--dark);background:var(--cream);transition:border-color .2s,background .2s;outline:none;-webkit-appearance:none}
.field input:focus,.field textarea:focus{border-color:var(--sage);background:var(--white)}
.field textarea{min-height:70px;resize:vertical}
input::placeholder,textarea::placeholder{color:var(--gray);font-weight:400}

/* CHIPS */
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:5px}
.chip{padding:6px 13px;border:1.5px solid var(--sand);border-radius:30px;font-size:12px;cursor:pointer;background:var(--white);color:var(--dark2);transition:all .15s;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;user-select:none}
.chip:active{transform:scale(.96)}
.chip.on{background:var(--deep);border-color:var(--deep);color:var(--white)}

/* BUTTONS */
.btn{width:100%;padding:13px 16px;border:none;border-radius:var(--r);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:7px;letter-spacing:.1px}
.btn:active{transform:scale(.985)}
.btn-deep{background:var(--deep);color:var(--white)}
.btn-deep:hover{background:var(--deep2)}
.btn-sage{background:var(--sage);color:var(--deep)}
.btn-sage:hover{background:var(--sage)}
.btn-out{background:transparent;color:var(--dark);border:1.5px solid var(--sand)}
.btn-out:hover{background:var(--cream2)}
.btn-gold{background:var(--gold2);color:var(--white)}
.btn-gold:hover{background:var(--gold)}
.btn-sky{background:var(--sky);color:var(--white)}
.btn-sm{padding:9px 14px;font-size:12px;width:auto;border-radius:var(--rs)}
.btn-terr{background:var(--terra-light);color:var(--terra);border:none}
.btn-terra{background:var(--terra);color:var(--white)}
.btn-terra:hover{background:#c9694e}
.menu-cta-sticky{
  position:sticky;
  bottom:8px;
  z-index:20;
  box-shadow:0 -8px 20px var(--cream);
}

/* HERO CARD */
.hero-card{background:var(--deep);border-radius:var(--r);padding:22px 18px;position:relative;overflow:hidden;margin-bottom:16px}
.hero-card::after{content:'';position:absolute;top:-20px;right:-20px;width:100px;height:100px;background:radial-gradient(circle,rgba(149,213,178,0.2) 0%,transparent 70%);border-radius:50%}
.hero-title{font-family:'Fredoka',sans-serif;font-size:20px;font-weight:600;color:var(--cream);line-height:1.3;position:relative}
.hero-title span{color:var(--terra-light)}
.hero-sub{font-size:12px;color:rgba(255,248,240,0.6);margin-top:8px;line-height:1.5;position:relative}
.hero-btn{display:inline-block;margin-top:14px;padding:12px 24px;border-radius:30px;background:var(--terra);color:var(--cream);font-family:'Fredoka',sans-serif;font-size:14px;font-weight:600;cursor:pointer;position:relative;border:none;transition:background .15s}
.hero-btn:hover{background:#c9694e}

/* TRIAL BANNER */
.trial-banner{background:linear-gradient(135deg,var(--terra-light) 0%,var(--cream2) 100%);border:1px solid var(--terra);border-radius:var(--r);padding:14px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px}
.trial-icon{font-size:24px}
.trial-text{flex:1}
.trial-text strong{font-family:'Fredoka',sans-serif;font-size:14px;color:var(--dark);display:block}
.trial-text span{font-size:11px;color:var(--gray)}
.trial-btn{padding:8px 14px;background:var(--terra);color:var(--cream);border:none;border-radius:20px;font-family:'Fredoka',sans-serif;font-size:12px;font-weight:600;cursor:pointer}

/* TIP CARD */
.tip-card{background:linear-gradient(135deg,var(--sage-light) 0%,var(--cream) 100%);border:1px solid var(--sage);border-radius:var(--r);padding:16px;margin-bottom:16px}
.tip-title{font-family:'Quicksand',sans-serif;font-size:9px;font-weight:700;color:var(--deep);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.tip-text{font-size:13px;color:var(--dark);line-height:1.6}

/* PROGRESS */
.progwrap{background:var(--sand);border-radius:10px;height:5px;margin-bottom:14px;overflow:hidden}
.progbar{height:5px;background:var(--sage);border-radius:10px;transition:width .4s cubic-bezier(.4,0,.2,1)}
.steprow{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.steplbl{font-size:11px;font-weight:700;color:var(--gray);letter-spacing:.3px}

/* DAY CARD */
.dcard{background:var(--white);border:1px solid var(--sand);border-radius:var(--r);margin-bottom:10px;overflow:hidden;box-shadow:var(--sh)}
.dhdr{padding:13px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;background:var(--white)}
.dhdr:hover{background:var(--cream)}
.dname{font-family:'Fredoka',sans-serif;font-weight:600;font-size:14px;color:var(--dark)}
.dbadge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;font-family:'Plus Jakarta Sans',sans-serif}
.day-refresh-btn{font-size:10px;font-weight:700;padding:5px 9px;border:1px solid var(--sand);border-radius:20px;background:var(--white);color:var(--gray);cursor:pointer}
.day-refresh-btn:hover{background:var(--cream)}
.dmeals{padding:6px 16px 14px;border-top:1px solid var(--sand);display:none}
.dmeals.open{display:block}
.mrow{display:flex;gap:10px;padding:7px 0;border-bottom:1px solid var(--cream2)}
.mrow:last-child{border-bottom:none}
.mtime{font-size:10px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.3px;min-width:58px;padding-top:2px}
.minfo{flex:1}
.mname{font-size:13px;font-weight:600;color:var(--dark);line-height:1.4}
.mnote{font-size:11px;color:var(--sage);margin-top:2px;font-weight:600;font-style:italic}
.mings{font-size:11px;color:var(--gray);margin-top:2px;line-height:1.4;font-weight:400}

/* SHOPPING */
.ssect{margin-bottom:14px}
.ssect-title{font-size:10px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;padding:0 2px}
.sitem{display:flex;align-items:center;gap:10px;padding:11px 13px;background:var(--white);border:1px solid var(--sand);border-radius:var(--rs);margin-bottom:6px;cursor:pointer;transition:opacity .2s,background .15s}
.sitem:hover{background:var(--cream)}
.sitem.done{opacity:.45}
.schk{width:20px;height:20px;border:1.5px solid var(--gray-light);border-radius:6px;flex-shrink:0;display:grid;place-items:center;transition:all .15s}
.sitem.done .schk{background:var(--deep);border-color:var(--deep)}
.schk svg{width:11px;height:11px;fill:none;stroke:var(--white);stroke-width:2.5;stroke-linecap:round;display:none}
.sitem.done .schk svg{display:block}
.sname{font-size:13px;flex:1;color:var(--dark);font-weight:500}
.sqty{font-size:12px;color:var(--gray);font-weight:600}

/* METRICS */
.mgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:13px}
.mcard{background:var(--white);border:1px solid var(--sand);border-radius:var(--r);padding:14px;text-align:center;box-shadow:var(--sh)}
.mval{font-family:'Fredoka',sans-serif;font-size:26px;font-weight:600;color:var(--dark);line-height:1}
.munit{font-size:11px;color:var(--gray);font-weight:500;margin-top:3px}
.mdelta{font-size:11px;font-weight:700;margin-top:4px}
.dg{color:var(--deep)}.db{color:var(--terra)}.dn{color:var(--gray)}
.chwrap{background:var(--white);border:1px solid var(--sand);border-radius:var(--r);padding:15px;margin-bottom:12px;box-shadow:var(--sh)}
.chtitle{font-size:10px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
.mchart{height:72px;display:flex;align-items:flex-end;gap:5px}
.bar{flex:1;border-radius:4px 4px 0 0;background:var(--sand);transition:height .5s cubic-bezier(.4,0,.2,1);min-height:3px}
.bar.ab{background:var(--sage)}
.blabs{display:flex;gap:5px;margin-top:5px}
.blab{flex:1;font-size:9px;color:var(--gray);text-align:center;font-weight:600}

/* LOADING */
.aiload{text-align:center;padding:48px 20px}
.spinner{width:36px;height:36px;border:2.5px solid var(--sand);border-top-color:var(--sage);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 14px}
@keyframes spin{to{transform:rotate(360deg)}}
.spinmsg{font-size:13px;color:var(--gray);line-height:1.7;font-style:italic}

/* EMPTY */
.empty{text-align:center;padding:44px 16px}
.eico{width:52px;height:52px;background:var(--sage-light);border-radius:50%;display:grid;place-items:center;margin:0 auto 12px}
.eico svg{width:24px;height:24px;fill:none;stroke:var(--sage);stroke-width:1.6;stroke-linecap:round}
.empty h3{font-family:'Fredoka',sans-serif;font-size:17px;font-weight:600;color:var(--dark);margin-bottom:6px}
.empty p{font-size:13px;color:var(--gray);line-height:1.6}

/* TOAST */
.toast{position:fixed;top:66px;left:50%;transform:translateX(-50%) translateY(-8px);background:var(--dark);color:var(--white);padding:10px 18px;border-radius:30px;font-size:12px;font-weight:700;font-family:'Plus Jakarta Sans',sans-serif;z-index:999;opacity:0;transition:all .22s;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* HERO INICIO */
.hero{background:var(--deep);border-radius:var(--rl);padding:26px 22px;margin-bottom:14px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-30px;right:-20px;width:110px;height:110px;background:var(--sage);border-radius:50%;opacity:.2}
.hero::after{content:'';position:absolute;bottom:-20px;left:10px;width:70px;height:70px;background:var(--sage);border-radius:50%;opacity:.15}
.hero h1{font-family:'Fredoka',sans-serif;font-size:26px;font-weight:600;color:var(--white);line-height:1.2;margin-bottom:8px;position:relative}
.hero h1 em{color:var(--sage);font-style:italic}
.hero p{font-size:13px;color:rgba(255,255,255,.65);line-height:1.6;position:relative;font-weight:400}

/* TRIAL PILL */
.trial-pill{background:var(--sage-light);border:1px solid var(--sage);border-radius:var(--r);padding:13px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}
.trial-pill-left h4{font-family:'Fredoka',sans-serif;font-size:14px;font-weight:600;color:var(--deep);margin-bottom:2px}
.trial-pill-left p{font-size:12px;color:var(--sage);font-weight:500}
.trial-num{font-family:'Fredoka',sans-serif;font-size:32px;font-weight:600;color:var(--deep);line-height:1}
.trial-num-sub{font-size:10px;color:var(--sage);font-weight:600;text-align:right;letter-spacing:.3px}

/* STAT ROW */
.srow2{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.sbox{background:var(--white);border:1px solid var(--sand);border-radius:var(--rs);padding:11px 6px;text-align:center;box-shadow:var(--sh)}
.snum{font-family:'Fredoka',sans-serif;font-size:18px;font-weight:600;color:var(--dark)}
.slb{font-size:9px;color:var(--gray);font-weight:700;margin-top:2px;text-transform:uppercase;letter-spacing:.3px}

/* WEEK BANNER */
.wbanner{background:var(--cream2);border:1px solid var(--sand);border-radius:var(--r);padding:14px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}
.winfo h3{font-family:'Fredoka',sans-serif;font-size:14px;font-weight:600;color:var(--dark);margin-bottom:2px}
.winfo p{font-size:11px;color:var(--gray);font-weight:500}
.wnum{font-family:'Fredoka',sans-serif;font-size:30px;font-weight:600;color:var(--sage)}

/* NOTA NUTRICIONAL */
.nota-card{background:var(--sage-light);border:1px solid var(--sage);border-radius:var(--r);padding:14px;margin-bottom:12px;display:flex;gap:10px;align-items:flex-start}
.nota-leaf{width:32px;height:32px;background:var(--sage);border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.nota-leaf svg{width:16px;height:16px;fill:none;stroke:var(--deep);stroke-width:2;stroke-linecap:round}
.nota-body h4{font-size:11px;font-weight:700;color:var(--deep);text-transform:uppercase;letter-spacing:.6px;margin-bottom:3px}
.nota-body p{font-size:13px;color:var(--dark);line-height:1.6;font-style:italic;font-family:'Fredoka',sans-serif}

/* PRICING */
.pricing-hero{background:var(--deep);border-radius:var(--rl);padding:22px 20px;margin-bottom:16px;text-align:center}
.pricing-hero h2{font-family:'Fredoka',sans-serif;font-size:22px;font-weight:600;color:var(--white);margin-bottom:6px}
.pricing-hero p{font-size:12px;color:rgba(255,255,255,.6);line-height:1.6}
.pcard{background:var(--white);border:1.5px solid var(--sand);border-radius:var(--r);overflow:hidden;margin-bottom:10px;position:relative;box-shadow:var(--sh)}
.pcard.featured{border-color:var(--sage);border-width:2px}
.pcard.current{border-color:var(--gold2);border-width:2px}
.pcard-top{padding:16px 16px 12px;display:flex;align-items:flex-start;justify-content:space-between}
.pcard-name{font-family:'Fredoka',sans-serif;font-size:17px;font-weight:600;color:var(--dark)}
.pcard-tag{font-size:10px;font-weight:700;padding:2px 9px;border-radius:20px;margin-top:3px;display:inline-block}
.pcard-price{text-align:right}
.pcard-num{font-family:'Fredoka',sans-serif;font-size:24px;font-weight:600;color:var(--dark)}
.pcard-per{font-size:10px;color:var(--gray);font-weight:500}
.pcard-vat{font-size:9px;color:var(--gray);margin-top:1px}
.pcard-feats{padding:0 16px 14px;border-top:1px solid var(--sand);margin-top:2px}
.feat{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:12px;color:var(--gray);font-weight:500}
.feat.yes{color:var(--dark)}
.feat svg{width:14px;height:14px;fill:none;flex-shrink:0}
.feat.yes svg{stroke:var(--sage);stroke-width:2.5;stroke-linecap:round}
.feat.no svg{stroke:var(--gray-light);stroke-width:2;stroke-linecap:round}
.popular-tag{position:absolute;top:14px;right:14px;background:var(--sage);color:var(--white);font-size:9px;font-weight:700;padding:2px 9px;border-radius:20px;letter-spacing:.3px}
.current-tag{position:absolute;top:14px;right:14px;background:var(--gold2);color:var(--white);font-size:9px;font-weight:700;padding:2px 9px;border-radius:20px}
.compare-note{font-size:11px;color:var(--gray);text-align:center;line-height:1.6;padding:0 10px 6px}

/* PAYWALL INLINE */
.pw-inline{background:var(--cream2);border:1px solid var(--sand);border-radius:var(--rl);padding:24px 18px;text-align:center;margin-bottom:12px}
.pw-inline .pw-icon{font-size:32px;margin-bottom:10px}
.pw-inline h2{font-family:'Fredoka',sans-serif;font-size:19px;font-weight:600;color:var(--dark);margin-bottom:7px}
.pw-inline p{font-size:13px;color:var(--gray);line-height:1.6;margin-bottom:18px}
.pw-plans{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px}
.pwp{border-radius:var(--r);padding:14px 10px;border:1.5px solid var(--sand);cursor:pointer;transition:all .15s;text-align:center;background:var(--white)}
.pwp:hover{border-color:var(--sage)}
.pwp.sel{border-color:var(--sage);background:var(--sage-light)}
.pwp-name{font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.pwp.sel .pwp-name{color:var(--deep)}
.pwp-price{font-family:'Fredoka',sans-serif;font-size:22px;font-weight:600;color:var(--dark)}
.pwp.sel .pwp-price{color:var(--deep)}
.pwp-period{font-size:10px;color:var(--gray)}
.pwp-vat{font-size:9px;color:var(--gray);margin-top:2px}
.pwp-feats{font-size:11px;color:var(--gray);margin-top:7px;line-height:1.6}
.pwp.sel .pwp-feats{color:var(--dark2)}

/* MODAL */
.modal-ov{position:fixed;inset:0;background:rgba(61,47,30,.45);z-index:500;display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(2px)}
.modal-ov.open{display:flex}
.msheet{background:var(--white);border-radius:20px 20px 0 0;padding:20px;width:100%;max-width:430px;animation:slu .22s cubic-bezier(.4,0,.2,1)}
@keyframes slu{from{transform:translateY(100%)}to{transform:translateY(0)}}
.mhandle{width:36px;height:4px;background:var(--sand);border-radius:2px;margin:0 auto 16px}
.mtitle{font-family:'Fredoka',sans-serif;font-size:17px;font-weight:600;color:var(--dark);margin-bottom:3px}
.msub{font-size:12px;color:var(--gray);margin-bottom:16px}
.egrid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:14px}
.ebtn{padding:14px 8px;background:var(--cream);border:1.5px solid var(--sand);border-radius:var(--r);display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;transition:all .15s}
.ebtn:hover{background:var(--cream2);border-color:var(--gray-light)}
.ebtn:active{transform:scale(.97)}
.eico{width:36px;height:36px;border-radius:10px;display:grid;place-items:center}
.eico svg{width:18px;height:18px;fill:none;stroke:var(--white);stroke-width:2;stroke-linecap:round}
.elbl{font-size:12px;font-weight:700;color:var(--dark)}

/* TOGGLE */
.srow{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--sand)}
.srow:last-child{border-bottom:none}
.slbl{font-size:13px;font-weight:600;color:var(--dark)}
.ssub{font-size:11px;color:var(--gray);margin-top:2px;font-weight:400}
.tog{width:44px;height:24px;background:var(--sand);border-radius:12px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.tog.on{background:var(--sage)}
.tok{width:18px;height:18px;background:var(--white);border-radius:50%;position:absolute;top:3px;left:3px;transition:left .18s;box-shadow:0 1px 4px rgba(61,47,30,.2)}
.tog.on .tok{left:23px}

/* MOOD */
.mood-row{display:flex;justify-content:space-between;gap:6px;margin-top:5px}
.mbtn{flex:1;padding:10px 3px;border:1.5px solid var(--sand);border-radius:var(--rs);font-size:18px;cursor:pointer;background:var(--white);transition:all .15s;text-align:center}
.mbtn:active{transform:scale(.92)}
.mbtn.sel{border-color:var(--sage);background:var(--sage-light)}

/* SLIDER */
.slwrap{margin:5px 0 3px}
.slwrap input[type=range]{width:100%;accent-color:var(--deep)}
.slval{font-family:'Fredoka',sans-serif;font-size:24px;font-weight:600;color:var(--dark);text-align:center;margin-bottom:4px}
.slrange-lbls{display:flex;justify-content:space-between;font-size:10px;color:var(--gray);font-weight:700;margin-top:2px}

/* ALERT BANNER */
.alert-banner{background:var(--goldl);border:1px solid #f0d060;border-radius:var(--r);padding:13px 15px;margin-bottom:12px;display:flex;gap:10px;align-items:flex-start}
.alert-icon{width:32px;height:32px;background:var(--gold2);border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.alert-icon svg{width:16px;height:16px;fill:none;stroke:var(--white);stroke-width:2;stroke-linecap:round}
.alert-body h4{font-size:12px;font-weight:700;color:var(--gold);margin-bottom:2px}
.alert-body p{font-size:12px;color:var(--dark2);line-height:1.5}

/* SUMMARY CARD */
.summary-card{background:var(--deep);border-radius:var(--r);padding:14px 16px;margin-bottom:12px}
.summary-card h4{font-family:'Fredoka',sans-serif;font-size:13px;font-weight:600;color:rgba(255,255,255,.7);margin-bottom:6px}
.summary-card p{font-size:14px;font-weight:600;color:var(--white)}
.summary-card .sub{font-size:11px;color:rgba(255,255,255,.55);margin-top:2px;font-weight:400}

/* DIVIDER */
.divider{height:1px;background:var(--sand);margin:8px 0}

/* PWA INSTALL BANNER - oculto por defecto */
/* UPDATE BANNER */
.update-banner{position:fixed;top:66px;left:50%;transform:translateX(-50%) translateY(-80px);width:calc(100% - 32px);max-width:398px;background:var(--deep);color:#fff;border-radius:var(--r);padding:11px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;z-index:200;box-shadow:0 4px 20px rgba(45,90,39,.3);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.update-banner.visible{transform:translateX(-50%) translateY(0)}
.update-banner-text{font-size:12px;font-weight:600;color:#fff}
.update-btn{padding:6px 12px;background:var(--sage);color:var(--dark);border:none;border-radius:8px;font-size:11px;font-weight:700;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;white-space:nowrap}
