:root{
  --cream:#fdf6ee;--rose:#e8a598;--rose-light:#f5d5cf;--rose-dark:#c97a6e;
  --warm-brown:#8b5e52;--sage:#a8b89a;--sage-light:#dce8d5;
  --text:#3d2b24;--text-soft:#7a5c52;--white:#fffaf6;
  --nav-h:74px;
  --sat:env(safe-area-inset-top,0px);
  --sab:env(safe-area-inset-bottom,0px);
  --font-serif:-apple-system,BlinkMacSystemFont,'SF Pro Display','Helvetica Neue',sans-serif;
  --font-sans:-apple-system,BlinkMacSystemFont,'SF Pro Text','Helvetica Neue',sans-serif;
  --lavender:#c9b8e8;--lavender-light:#ede7f6;--lavender-dark:#8b6aaa;
  /* Premium */
  --gold:#c8960a;--gold-light:#fef8e0;--gold-dark:#8a6500;
}

/* ══ DARK MODE ══ */
[data-theme="dark"]{
  --cream:#0a0e1a;
  --white:#0f1525;
  --text:#dde8ff;
  --text-soft:#7080a8;
  --rose:#b87878;
  --rose-light:#2a1820;
  --rose-dark:#cc8888;
  --warm-brown:#b8a0b0;
  --sage:#609060;
  --sage-light:#1a2a18;
  --lavender:#7880c8;
  --lavender-light:#181e38;
  --lavender-dark:#9898e8;
  --gold:#d4a020;
  --gold-light:#201808;
  --gold-dark:#e8c840;
}

/* Adaptaciones de componentes al dark mode */
[data-theme="dark"] .auth-card,
[data-theme="dark"] .modal{background:rgba(15,21,37,.97);}
[data-theme="dark"] .header{background:rgba(10,14,26,.88);}
[data-theme="dark"] .bottom-nav{background:rgba(10,14,26,.93);}
[data-theme="dark"] .stat-card,
[data-theme="dark"] .ext-card,
[data-theme="dark"] .post-card,
[data-theme="dark"] .alarm-card,
[data-theme="dark"] .week-chart,
[data-theme="dark"] .s-card,
[data-theme="dark"] .alarm-active{background:rgba(15,21,37,.9);}
[data-theme="dark"] .fi,
[data-theme="dark"] .ftxt,
[data-theme="dark"] .chat-input{background:rgba(20,28,50,.85);color:var(--text);}
[data-theme="dark"] .loading-overlay{background:rgba(10,14,26,.85);}
[data-theme="dark"] .wc1{background:radial-gradient(ellipse,rgba(80,100,200,.18),transparent 68%);}
[data-theme="dark"] .wc2{background:radial-gradient(ellipse,rgba(60,100,80,.14),transparent 68%);}
[data-theme="dark"] .wc3{background:radial-gradient(ellipse,rgba(80,100,200,.12),transparent 68%);}
[data-theme="dark"] .wc4{background:radial-gradient(ellipse,rgba(60,100,80,.1),transparent 68%);}
[data-theme="dark"] .wc5{background:radial-gradient(ellipse,rgba(100,80,160,.08),transparent 68%);}
[data-theme="dark"] .setup-banner{background:rgba(20,24,8,.9);}
[data-theme="dark"] .auth-err{background:rgba(50,20,20,.9);}
[data-theme="dark"] .pchip,
[data-theme="dark"] .gchip,
[data-theme="dark"] .stor-btn,
[data-theme="dark"] .gselbtn{background:rgba(20,28,50,.8);}
[data-theme="dark"] .unit-tog{background:rgba(20,28,50,.6);}

*{box-sizing:border-box;margin:0;padding:0;}
html{background:var(--cream);height:100%;}
body{font-family:var(--font-sans);background:var(--cream);color:var(--text);min-height:100vh;min-height:100dvh;overflow-x:hidden;transition:background .3s,color .3s;-webkit-text-size-adjust:100%;}

/* ══ ANIMACIONES GLOBALES DE BOTONES ══ */
button,
.nav-btn,
.pchip,
.gchip,
.gselbtn,
.stor-btn,
.sex-btn,
.ctog,
.unit-btn,
.sub-period-btn,
.gchip,
.alarm-home-card,
.home-col,
.hbtn,
.cpb-btn {
  transition: transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .18s ease, opacity .15s ease, background .2s ease;
}
button:active,
.pchip:active,
.gchip:active,
.gselbtn:active,
.stor-btn:active,
.sex-btn:active,
.ctog:active,
.unit-btn:active,
.hbtn:active,
.cpb-btn:active { transform: scale(.93); }
.btn-primary:active,.btn-save:active,.btn-lm:active { transform: scale(.96); box-shadow: none; }
.btn-primary:hover,.btn-save:hover { opacity:.9; transform:translateY(-1px); box-shadow:0 6px 22px rgba(201,122,110,.42); }
.hbtn:hover { background:rgba(245,213,207,.85) !important; transform:scale(1.08); }
.nav-btn:active .nav-pip,.nav-btn:active .nav-center-drop { transform:scale(.9); }
.alarm-home-card:active { transform:scale(.98); }
.home-col:active { transform:scale(.97); }

/* ── WATERCOLOR BG ── */
.wc-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.wc-bg span{position:absolute;border-radius:50%;}
.wc1{width:340px;height:280px;background:radial-gradient(ellipse,#f5d5cf,transparent 68%);top:-90px;right:-90px;opacity:.5;}
.wc2{width:280px;height:240px;background:radial-gradient(ellipse,#dce8d5,transparent 68%);bottom:-70px;left:-70px;opacity:.42;}
.wc3{width:200px;height:170px;background:radial-gradient(ellipse,#f5d5cf,transparent 68%);top:42%;right:-50px;opacity:.28;}
.wc4{width:220px;height:180px;background:radial-gradient(ellipse,#dce8d5,transparent 68%);top:28%;left:-55px;opacity:.24;}
.wc5{width:160px;height:130px;background:radial-gradient(ellipse,#e8a598,transparent 68%);bottom:22%;right:18%;opacity:.14;}

/* ══ LANDING ══ */
.landing{position:fixed;inset:0;z-index:200;background:var(--cream);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 28px;}
.land-bot{position:absolute;pointer-events:none;}
.land-bot.l{left:0;bottom:80px;} .land-bot.r{right:0;bottom:80px;}
.land-drop{width:230px;height:230px;margin-bottom:28px;animation:dropIn .9s cubic-bezier(.34,1.56,.64,1) both;}
@keyframes dropIn{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.land-drop svg{animation:breathe 3.5s ease-in-out infinite;}
@keyframes floatUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.land-title{font-family:var(--font-serif);font-size:3.4rem;font-weight:600;color:var(--warm-brown);letter-spacing:-.02em;text-align:center;line-height:1;margin-bottom:10px;animation:floatUp .7s .36s ease both;}
.land-tag{font-family:var(--font-serif);font-size:1.08rem;font-weight:300;font-style:italic;color:var(--rose-dark);text-align:center;margin-bottom:6px;animation:floatUp .7s .48s ease both;}
.land-sub{font-family:var(--font-sans);font-size:.74rem;color:var(--text-soft);text-align:center;font-weight:300;margin-bottom:40px;animation:floatUp .7s .58s ease both;}
.land-actions{width:100%;max-width:310px;display:flex;flex-direction:column;gap:12px;animation:floatUp .7s .66s ease both;}
.btn-lm{background:linear-gradient(135deg,var(--rose-dark),var(--warm-brown));color:#fff;border:none;border-radius:50px;padding:16px 32px;font-family:var(--font-sans);font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:0 6px 22px rgba(201,122,110,.35);transition:transform .15s,box-shadow .15s;}
.btn-lm:hover{transform:translateY(-2px);}
.btn-ls{background:transparent;color:var(--warm-brown);border:1.5px solid rgba(201,122,110,.32);border-radius:50px;padding:15px 32px;font-family:var(--font-sans);font-size:.93rem;font-weight:500;cursor:pointer;transition:background .2s;}
.btn-ls:hover{background:var(--rose-light);}
.land-dots{display:flex;gap:6px;justify-content:center;margin-top:20px;animation:floatUp .7s .75s ease both;}
.ld{width:6px;height:6px;border-radius:50%;background:var(--rose-light);}
.ld.a{background:var(--rose-dark);width:18px;border-radius:3px;}

/* Landing — features y social proof */
.land-features{width:100%;max-width:310px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:20px;animation:floatUp .7s .82s ease both;}
.land-feat{background:rgba(255,250,246,.7);backdrop-filter:blur(8px);border-radius:20px;padding:11px 8px;text-align:center;border:1px solid rgba(232,165,152,.18);}
.land-feat-icon{font-size:1.3rem;margin-bottom:4px;}
.land-feat-txt{font-family:var(--font-sans);font-size:.62rem;font-weight:500;color:var(--text-soft);line-height:1.3;}
.land-proof{font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);text-align:center;margin-top:14px;animation:floatUp .7s .9s ease both;}
.land-proof strong{color:var(--rose-dark);}
[data-theme="dark"] .land-feat{background:rgba(36,27,22,.7);border-color:rgba(201,122,110,.2);}

/* ══ AUTH ══ */
.auth-screen{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:calc(24px + var(--sat)) 24px calc(24px + var(--sab));position:relative;overflow:hidden;}
#landing-screen{padding-top:var(--sat);}
.auth-back{position:absolute;top:18px;left:18px;background:rgba(255,255,255,.55);border:none;border-radius:50%;width:38px;height:38px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.88rem;color:var(--warm-brown);backdrop-filter:blur(6px);font-family:var(--font-sans);font-weight:600;}
.auth-logo{text-align:center;margin-bottom:22px;}
.auth-logo h1{font-family:var(--font-serif);font-size:2rem;color:var(--warm-brown);font-weight:600;margin-top:6px;}
.auth-logo p{font-family:var(--font-sans);font-size:.76rem;color:var(--text-soft);margin-top:2px;}
.auth-card{background:rgba(255,250,246,.9);backdrop-filter:blur(12px);border-radius:36px;padding:26px 22px 30px;width:100%;max-width:400px;box-shadow:0 8px 40px rgba(139,94,82,.14);}
.auth-tabs{display:flex;background:rgba(245,213,207,.45);border-radius:50px;padding:4px;margin-bottom:20px;}
.auth-tab{flex:1;padding:10px;text-align:center;border-radius:50px;font-family:var(--font-sans);font-size:.83rem;font-weight:500;cursor:pointer;color:var(--text-soft);transition:all .22s;}
.auth-tab.active{background:var(--white);color:var(--warm-brown);box-shadow:0 2px 12px rgba(139,94,82,.14);}
.auth-form{display:none;}
.auth-form.active{display:block;}
.fg{margin-bottom:13px;}
.flbl{font-family:var(--font-sans);font-size:.72rem;font-weight:600;color:var(--text-soft);margin-bottom:5px;display:block;letter-spacing:.04em;text-transform:uppercase;}
.fi{width:100%;background:rgba(253,246,238,.85);border:1.5px solid rgba(232,165,152,.38);border-radius:50px;padding:12px 18px;font-family:var(--font-sans);font-size:.93rem;color:var(--text);outline:none;transition:border-color .2s;}
.fi:focus{border-color:var(--rose-dark);}
.pw-wrap{position:relative;}
.pw-wrap .fi{padding-right:60px;}
.pw-eye{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;font-family:var(--font-sans);font-size:.7rem;font-weight:600;color:var(--rose-dark);opacity:.7;transition:opacity .15s;}
.pw-eye:hover{opacity:1;}
.btn-primary{width:100%;background:linear-gradient(135deg,var(--rose-dark),var(--warm-brown));border:none;border-radius:50px;padding:14px;font-family:var(--font-sans);font-size:.93rem;font-weight:600;color:#fff;cursor:pointer;box-shadow:0 4px 18px rgba(201,122,110,.32);transition:opacity .15s;margin-top:4px;}
.btn-primary:hover{opacity:.9;}
.auth-err{background:rgba(253,234,234,.9);color:#b85c5c;border-radius:20px;padding:10px 16px;font-family:var(--font-sans);font-size:.78rem;margin-bottom:12px;display:none;}

/* loading */
.loading-overlay{position:fixed;inset:0;background:rgba(253,246,238,.8);backdrop-filter:blur(8px);z-index:999;display:none;align-items:center;justify-content:center;flex-direction:column;gap:16px;}
.loading-overlay.show{display:flex;}
.loading-drop{width:60px;height:60px;animation:breathe 1.2s ease-in-out infinite;}
.loading-txt{font-family:var(--font-serif);font-size:1rem;color:var(--warm-brown);font-style:italic;}

/* ══ APP SHELL ══ */
.app-shell{display:none;position:relative;z-index:1;}

/* HEADER — cubre zona de status bar en iPhone */
.header{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:8px;position:sticky;top:0;z-index:50;background:rgba(253,246,238,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:calc(12px + var(--sat)) 16px 10px;margin-top:calc(-1 * var(--sat));}
.header-center{text-align:center;}
.header-logo{display:flex;align-items:center;justify-content:center;gap:8px;}
.hlogo-drop{width:44px;height:44px;}
.header-logo h1{font-family:var(--font-serif);font-size:1.5rem;color:var(--warm-brown);font-weight:600;letter-spacing:-.02em;line-height:1;}
.header-user{font-family:var(--font-sans);font-size:.66rem;color:var(--text-soft);margin-top:1px;}
.header-user strong{color:var(--warm-brown);}
.header-right{display:flex;align-items:center;gap:6px;}
.hbtn{width:38px;height:38px;border-radius:50%;background:rgba(245,213,207,.4);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.hbtn:hover{background:rgba(245,213,207,.8);}
.hbtn svg{width:19px;height:19px;}
.hbtn-comm{border-radius:50px;padding:7px 12px;width:auto;gap:5px;font-family:var(--font-sans);font-size:.7rem;font-weight:600;color:var(--warm-brown);white-space:nowrap;}
.hbtn-comm.active{background:rgba(168,184,154,.5);color:#4a6340;}

/* BOTTOM NAV — 3 tabs */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--sab));background:rgba(253,246,238,.92);backdrop-filter:blur(20px);display:flex;align-items:flex-end;justify-content:space-around;z-index:50;padding:0 2px calc(14px + var(--sab));border-radius:28px 28px 0 0;box-shadow:0 -4px 24px rgba(139,94,82,.1);}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:0 1px;border:none;background:transparent;color:var(--text-soft);transition:color .2s;}
.nav-pip{display:flex;align-items:center;justify-content:center;width:46px;height:38px;border-radius:20px;transition:background .25s,transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;}
.nav-btn.active .nav-pip{background:linear-gradient(135deg,rgba(245,213,207,.9),rgba(220,232,213,.7));transform:translateY(-14px) scale(1.15);box-shadow:0 10px 24px rgba(201,122,110,.22);}
.nav-btn.active{color:var(--warm-brown);}
/* Perfil tab active — tono dorado */
.nav-btn.active#nav-perfil .nav-pip{background:linear-gradient(135deg,rgba(255,240,190,.9),rgba(245,213,207,.7));box-shadow:0 10px 24px rgba(200,150,10,.18);}
.nav-btn.active#nav-perfil{color:var(--gold-dark);}
.nav-svg{width:21px;height:21px;transition:transform .3s;}
.nav-btn.active .nav-svg{transform:scale(1.1);}
.nav-lbl{font-family:var(--font-sans);font-size:.54rem;font-weight:500;margin-top:2px;transition:opacity .2s,transform .2s;}
.nav-btn.active .nav-lbl{opacity:0;transform:translateY(4px);}

/* FAB */
.fab{position:fixed;bottom:calc(var(--nav-h) + var(--sab) + 12px);right:50%;transform:translateX(50%);background:linear-gradient(135deg,var(--rose-dark),var(--warm-brown));color:#fff;border:none;border-radius:50px;padding:13px 26px;font-family:var(--font-sans);font-size:.87rem;font-weight:600;cursor:pointer;box-shadow:0 6px 24px rgba(201,122,110,.42);display:flex;align-items:center;gap:8px;transition:transform .15s,box-shadow .15s;z-index:15;}
.fab:hover{transform:translateX(50%) translateY(-2px);}
.fab-comm{background:linear-gradient(135deg,#b89dc8,#8b6a9a);box-shadow:0 6px 24px rgba(139,106,154,.38);}

/* CONTENT */
.content{padding:18px 16px calc(var(--nav-h) + var(--sab) + 40px);max-width:480px;margin:0 auto;position:relative;z-index:1;width:100%;}

/* STAT CARDS */
.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px;}
.stat-card{background:rgba(255,250,246,.88);border-radius:28px;padding:16px;box-shadow:0 4px 20px rgba(139,94,82,.08);text-align:center;}
.stat-card .val{font-family:var(--font-serif);font-size:1.65rem;font-weight:600;color:var(--warm-brown);}
.stat-card .lbl{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);margin-top:2px;}

/* EXTRACTION CARD */
.ext-card{background:rgba(255,250,246,.9);border-radius:26px;padding:16px 18px;margin-bottom:11px;box-shadow:0 4px 18px rgba(139,94,82,.08);border-left:4px solid var(--rose);animation:slideIn .3s ease;}
.ext-card.frozen{border-left-color:#7ec8e3;}
.ext-card.ref{border-left-color:var(--sage);}
@keyframes slideIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;}
.card-time{font-family:var(--font-serif);font-size:1.2rem;font-weight:600;color:var(--warm-brown);}
.card-amt{font-family:var(--font-serif);font-size:1.5rem;font-weight:600;color:var(--rose-dark);text-align:right;}
.card-amt span{font-family:var(--font-sans);font-size:.76rem;font-weight:400;color:var(--text-soft);}
.card-meta{display:flex;gap:7px;flex-wrap:wrap;margin-top:8px;}
.badge{font-family:var(--font-sans);font-size:.67rem;font-weight:500;padding:4px 11px;border-radius:50px;}
.bd{background:rgba(245,240,234,.9);color:var(--text-soft);}
.bf{background:rgba(224,243,250,.9);color:#3b8fb5;}
.br{background:rgba(220,232,213,.9);color:#4a6340;}
.card-notes{margin-top:8px;font-family:var(--font-sans);font-size:.75rem;color:var(--text-soft);font-style:italic;padding-top:8px;}
.card-actions{display:flex;gap:7px;margin-top:10px;}
.btn-edit,.btn-del{border:none;border-radius:50px;padding:7px 16px;font-family:var(--font-sans);font-size:.74rem;font-weight:500;cursor:pointer;}
.btn-edit{background:rgba(245,213,207,.7);color:var(--warm-brown);}
.btn-del{background:rgba(253,234,234,.8);color:#b85c5c;}
.empty{text-align:center;padding:44px 24px;color:var(--text-soft);}
.empty-icon{font-size:2.8rem;margin-bottom:11px;}
.empty h3{font-family:var(--font-serif);font-size:1.3rem;color:var(--warm-brown);}
.empty p{font-family:var(--font-sans);font-size:.78rem;margin-top:6px;font-weight:300;}
.day-hdr{display:flex;justify-content:space-between;align-items:center;margin:14px 0 7px;padding:0 4px;}
.day-hdr span:first-child{font-family:var(--font-sans);font-size:.7rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;}
.day-hdr span:last-child{font-family:var(--font-sans);font-size:.7rem;color:var(--rose-dark);font-weight:600;}

/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(61,43,36,.38);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--white);border-radius:38px 38px 0 0;padding:24px 22px 36px;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;animation:slideUp .32s cubic-bezier(.34,1.56,.64,1);}
@keyframes slideUp{from{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal h2{font-family:var(--font-serif);font-size:1.4rem;color:var(--warm-brown);margin-bottom:18px;text-align:center;}
.mdrag{width:40px;height:4px;background:var(--rose-light);border-radius:50px;margin:0 auto 18px;}
.ftxt{width:100%;background:rgba(253,246,238,.8);border:1.5px solid rgba(232,165,152,.35);border-radius:24px;min-height:88px;resize:vertical;padding:13px 18px;font-family:var(--font-sans);font-size:.91rem;color:var(--text);outline:none;transition:border-color .2s;}
.ftxt:focus{border-color:var(--rose-dark);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.stor-tog{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.stor-btn{border:1.5px solid rgba(232,165,152,.35);background:rgba(253,246,238,.7);border-radius:24px;padding:13px 10px;text-align:center;cursor:pointer;font-family:var(--font-sans);font-size:.79rem;color:var(--text-soft);font-weight:500;transition:all .15s;}
.stor-btn .si{font-size:1.25rem;display:block;margin-bottom:3px;}
.stor-btn.sf{border-color:#7ec8e3;background:rgba(224,243,250,.7);color:#2e7fa8;}
.stor-btn.sr{border-color:var(--sage);background:rgba(220,232,213,.7);color:#4a6340;}
.m-actions{display:grid;grid-template-columns:1fr 2fr;gap:10px;margin-top:18px;}
.btn-cancel{border:1.5px solid rgba(232,165,152,.35);background:transparent;border-radius:50px;padding:12px;font-family:var(--font-sans);font-size:.87rem;color:var(--text-soft);cursor:pointer;font-weight:500;}
.btn-save{background:linear-gradient(135deg,var(--rose-dark),var(--warm-brown));border:none;border-radius:50px;padding:12px;font-family:var(--font-sans);font-size:.87rem;font-weight:600;color:#fff;cursor:pointer;box-shadow:0 4px 14px rgba(201,122,110,.3);}

/* ALARM */
.alarm-hero{background:linear-gradient(135deg,rgba(245,213,207,.6),rgba(220,232,213,.6));border-radius:32px;padding:22px 20px;text-align:center;margin-bottom:15px;}
.alarm-hero-icon{font-size:1.8rem;margin-bottom:5px;}
.alarm-hero-title{font-family:var(--font-serif);font-size:1.18rem;color:var(--warm-brown);font-weight:600;}
.alarm-hero-sub{font-family:var(--font-sans);font-size:.71rem;color:var(--text-soft);margin-top:3px;}
.alarm-card{background:rgba(255,250,246,.88);border-radius:28px;padding:20px;box-shadow:0 4px 18px rgba(139,94,82,.07);margin-bottom:14px;}
.alarm-card h3{font-family:var(--font-serif);font-size:1.06rem;color:var(--warm-brown);margin-bottom:13px;}
.presets-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:13px;}
.pchip{border:1.5px solid rgba(232,165,152,.4);background:rgba(253,246,238,.7);border-radius:50px;padding:6px 14px;font-family:var(--font-sans);font-size:.74rem;font-weight:500;color:var(--text-soft);cursor:pointer;transition:all .15s;}
.pchip.active{border-color:var(--rose-dark);background:rgba(245,213,207,.7);color:var(--warm-brown);}
.sg{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:13px;}
.slbl{font-family:var(--font-sans);font-size:.67rem;color:var(--text-soft);font-weight:600;text-align:center;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em;}
.stepper{display:flex;align-items:center;border:1.5px solid rgba(232,165,152,.35);border-radius:50px;overflow:hidden;background:rgba(253,246,238,.7);}
.stbtn{width:44px;height:48px;border:none;background:transparent;color:var(--warm-brown);font-family:var(--font-sans);font-size:1.2rem;cursor:pointer;transition:background .15s;flex-shrink:0;}
.stbtn:hover{background:rgba(245,213,207,.5);}
.stval{flex:1;text-align:center;}
.sv-n{font-family:var(--font-serif);font-size:1.65rem;font-weight:600;color:var(--warm-brown);line-height:1;}
.sv-u{font-family:var(--font-sans);font-size:.63rem;color:var(--text-soft);}
.alarm-active{background:rgba(255,250,246,.92);border-radius:28px;padding:18px;box-shadow:0 4px 18px rgba(139,94,82,.08);border:1.5px solid rgba(245,213,207,.8);margin-bottom:14px;}
.aa-top{display:flex;align-items:center;gap:9px;margin-bottom:9px;}
.aa-dot{width:8px;height:8px;border-radius:50%;background:var(--rose-dark);animation:pulse 1.5s ease-in-out infinite;}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}
.aa-lbl{font-family:var(--font-sans);font-size:.74rem;font-weight:600;color:var(--warm-brown);text-transform:uppercase;letter-spacing:.05em;}
.aa-time{font-family:var(--font-serif);font-size:2.2rem;font-weight:600;color:var(--warm-brown);text-align:center;}
.aa-cd{font-family:var(--font-sans);font-size:.76rem;color:var(--text-soft);text-align:center;margin-top:3px;}
.aa-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;}
.aa-int{font-family:var(--font-sans);font-size:.74rem;color:var(--text-soft);}
.btn-stop{background:rgba(253,234,234,.8);color:#b85c5c;border:none;border-radius:50px;padding:8px 18px;font-family:var(--font-sans);font-size:.77rem;font-weight:600;cursor:pointer;}

/* STATS */
.week-chart{background:rgba(255,250,246,.88);border-radius:28px;padding:18px;box-shadow:0 4px 18px rgba(139,94,82,.07);margin-bottom:14px;}
.week-chart h3{font-family:var(--font-serif);color:var(--warm-brown);font-size:1.03rem;margin-bottom:13px;}
.bar-row{display:flex;align-items:flex-end;gap:5px;height:72px;margin-bottom:7px;}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;height:100%;justify-content:flex-end;}
.bar{width:100%;border-radius:8px 8px 0 0;background:linear-gradient(to top,var(--rose-dark),rgba(245,213,207,.9));transition:height .4s cubic-bezier(.34,1.56,.64,1);}
.bar-lbl{font-family:var(--font-sans);font-size:.6rem;color:var(--text-soft);}
.bar-val{font-family:var(--font-sans);font-size:.6rem;font-weight:600;color:var(--warm-brown);}

/* COMMUNITY */
.comm-banner{background:linear-gradient(135deg,rgba(240,230,246,.7),rgba(220,232,213,.6));border-radius:28px;padding:14px 18px;margin-bottom:14px;border-left:4px solid rgba(155,125,192,.5);}
.comm-banner-title{font-family:var(--font-sans);font-size:.74rem;font-weight:600;color:#6b4a8a;margin-bottom:3px;}
.comm-banner p{font-family:var(--font-sans);font-size:.7rem;color:#7a5a90;line-height:1.5;}
.gscroll{display:flex;gap:8px;overflow-x:auto;padding:2px 0 8px;margin-bottom:14px;scrollbar-width:none;}
.gscroll::-webkit-scrollbar{display:none;}
.gchip{flex-shrink:0;border:1.5px solid rgba(232,165,152,.35);background:rgba(255,250,246,.85);border-radius:50px;padding:6px 14px;font-family:var(--font-sans);font-size:.73rem;font-weight:500;color:var(--text-soft);cursor:pointer;transition:all .18s;white-space:nowrap;}
.gchip.active{border-color:var(--rose-dark);background:rgba(245,213,207,.7);color:var(--warm-brown);}
.post-card{background:rgba(255,250,246,.9);border-radius:26px;padding:16px 18px;margin-bottom:11px;box-shadow:0 4px 18px rgba(139,94,82,.07);animation:slideIn .3s ease;}
.post-hdr{display:flex;align-items:center;gap:9px;margin-bottom:9px;}
.post-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,rgba(245,213,207,.9),rgba(220,232,213,.9));display:flex;align-items:center;justify-content:center;font-family:var(--font-sans);font-size:.82rem;font-weight:600;color:var(--warm-brown);flex-shrink:0;}
.post-av.anon{background:linear-gradient(135deg,rgba(232,224,240,.9),rgba(220,232,213,.9));}
.post-auth{font-family:var(--font-sans);font-size:.8rem;font-weight:600;color:var(--text);}
.post-auth.anon{color:var(--text-soft);font-style:italic;}
.post-time{font-family:var(--font-sans);font-size:.67rem;color:var(--text-soft);}
.post-gbadge{display:inline-block;font-family:var(--font-sans);font-size:.64rem;padding:3px 10px;border-radius:50px;background:rgba(245,213,207,.7);color:var(--warm-brown);font-weight:500;margin-bottom:5px;}
.post-title{font-family:var(--font-serif);font-size:1.05rem;font-weight:600;color:var(--warm-brown);margin-bottom:5px;line-height:1.3;}
.post-body{font-family:var(--font-sans);font-size:.84rem;color:var(--text);line-height:1.6;}
.post-foot{display:flex;align-items:center;gap:10px;margin-top:10px;padding-top:9px;}
.btn-like{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:4px;font-family:var(--font-sans);font-size:.73rem;color:var(--text-soft);padding:0;transition:color .15s;}
.btn-like.liked{color:var(--rose-dark);}
.anon-row{display:flex;align-items:center;justify-content:space-between;background:rgba(245,213,207,.35);border-radius:24px;padding:12px 16px;margin-bottom:13px;cursor:pointer;}
.anon-row-l{display:flex;align-items:center;gap:9px;}
.anon-lbl{font-family:var(--font-sans);font-size:.84rem;font-weight:500;color:var(--text);}
.anon-sub{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);}
.tgl{position:relative;width:44px;height:24px;}
.tgl input{opacity:0;width:0;height:0;position:absolute;}
.tgl-t{position:absolute;inset:0;background:rgba(208,198,194,.8);border-radius:50px;cursor:pointer;transition:background .25s;}
.tgl input:checked+.tgl-t{background:var(--rose-dark);}
.tgl-t::after{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 4px rgba(0,0,0,.18);}
.tgl input:checked+.tgl-t::after{transform:translateX(20px);}
.gselbtn-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:13px;}
.gselbtn{border:1.5px solid rgba(232,165,152,.35);background:rgba(253,246,238,.7);border-radius:24px;padding:9px 10px;font-family:var(--font-sans);font-size:.73rem;font-weight:500;color:var(--text-soft);cursor:pointer;text-align:center;transition:all .15s;}
.gselbtn.active{border-color:var(--rose-dark);background:rgba(245,213,207,.7);color:var(--warm-brown);}

/* ════════════════════════════════
   CHAT PAGE
════════════════════════════════ */
.chat-page{display:flex;flex-direction:column;height:calc(100vh - var(--nav-h) - 56px);position:relative;padding:0;max-width:480px;margin:0 auto;}

/* Chat header area */
.chat-header-card{background:linear-gradient(135deg,rgba(237,231,246,.7),rgba(220,232,213,.5));border-radius:28px;padding:16px 18px;margin:14px 16px 0;display:flex;align-items:center;gap:14px;}
.chat-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--lavender-light),rgba(220,232,213,.9));display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.chat-avatar svg{width:26px;height:26px;}
.chat-info-name{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;color:var(--lavender-dark);}
.chat-info-sub{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);margin-top:2px;line-height:1.4;}

/* Chat disclaimer */
.chat-disclaimer{margin:10px 16px 0;background:rgba(255,243,224,.8);border-radius:20px;padding:9px 14px;font-family:var(--font-sans);font-size:.68rem;color:#8b6a40;line-height:1.5;text-align:center;}

/* Messages area */
.chat-messages{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:rgba(232,165,152,.3) transparent;}
.chat-messages::-webkit-scrollbar{width:3px;}
.chat-messages::-webkit-scrollbar-thumb{background:rgba(232,165,152,.3);border-radius:50px;}

/* Individual messages */
.chat-msg{display:flex;gap:9px;animation:slideIn .25s ease;}
.chat-msg.user{flex-direction:row-reverse;}
.msg-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-sans);font-size:.75rem;font-weight:600;align-self:flex-end;}
.msg-avatar.ai{background:linear-gradient(135deg,var(--lavender-light),rgba(220,232,213,.9));}
.msg-avatar.user{background:linear-gradient(135deg,var(--rose-light),rgba(220,232,213,.8));color:var(--warm-brown);}
.msg-bubble{max-width:78%;padding:11px 15px;border-radius:22px;font-family:var(--font-sans);font-size:.86rem;line-height:1.6;color:var(--text);}
.msg-bubble.ai{background:rgba(255,250,246,.95);border-bottom-left-radius:6px;box-shadow:0 2px 10px rgba(139,94,82,.08);}
.msg-bubble.user{background:linear-gradient(135deg,rgba(201,122,110,.15),rgba(139,94,82,.1));border-bottom-right-radius:6px;}
.msg-bubble p{margin-bottom:6px;}
.msg-bubble p:last-child{margin-bottom:0;}
.msg-bubble strong{font-weight:600;color:var(--warm-brown);}

/* Typing indicator */
.typing-dots{display:flex;gap:4px;padding:4px 2px;align-items:center;}
.typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--lavender);animation:typingBounce 1.2s ease-in-out infinite;}
.typing-dots span:nth-child(2){animation-delay:.15s;}
.typing-dots span:nth-child(3){animation-delay:.3s;}
@keyframes typingBounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-6px)}}

/* Suggested questions */
.chat-suggestions{padding:0 16px 8px;display:flex;gap:7px;overflow-x:auto;scrollbar-width:none;flex-wrap:wrap;}
.chat-suggestions::-webkit-scrollbar{display:none;}
.sug-chip{flex-shrink:0;border:1.5px solid rgba(201,186,232,.5);background:rgba(237,231,246,.5);border-radius:50px;padding:7px 14px;font-family:var(--font-sans);font-size:.72rem;font-weight:500;color:var(--lavender-dark);cursor:pointer;transition:all .15s;white-space:nowrap;}
.sug-chip:hover{background:rgba(237,231,246,.9);border-color:var(--lavender-dark);}

/* Chat input */
.chat-input-wrap{padding:10px 16px calc(10px + env(safe-area-inset-bottom,0));display:flex;gap:9px;align-items:flex-end;background:rgba(253,246,238,.7);backdrop-filter:blur(8px);}
.chat-input{flex:1;background:rgba(255,250,246,.95);border:1.5px solid rgba(232,165,152,.35);border-radius:24px;padding:11px 16px;font-family:var(--font-sans);font-size:.9rem;color:var(--text);outline:none;resize:none;min-height:44px;max-height:120px;transition:border-color .2s;line-height:1.4;}
.chat-input:focus{border-color:rgba(201,186,232,.8);}
.chat-send{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--lavender-dark),#6b4a8a);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,opacity .15s;flex-shrink:0;}
.chat-send:hover{transform:scale(1.05);}
.chat-send:disabled{opacity:.4;cursor:not-allowed;transform:none;}
.chat-send svg{width:18px;height:18px;}

/* Clear chat btn */
.chat-clear{background:none;border:none;cursor:pointer;font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);padding:4px 8px;border-radius:50px;transition:background .15s;margin-top:4px;}
.chat-clear:hover{background:rgba(245,213,207,.4);}

/* SETTINGS */
.ss{margin-bottom:16px;}
.ss-t{font-family:var(--font-sans);font-size:.67rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;padding:0 4px;}
.s-card{background:rgba(255,250,246,.9);border-radius:28px;box-shadow:0 4px 18px rgba(139,94,82,.07);overflow:hidden;padding:4px 0;}
.s-row{display:flex;justify-content:space-between;align-items:center;padding:13px 18px;}
.sr-lbl{font-family:var(--font-sans);font-size:.86rem;font-weight:500;color:var(--text);}
.sr-sub{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);margin-top:2px;font-weight:300;}
.unit-tog{display:flex;background:rgba(245,213,207,.45);border-radius:50px;padding:3px;}
.unit-btn{padding:6px 14px;border-radius:50px;font-family:var(--font-sans);font-size:.79rem;font-weight:500;cursor:pointer;border:none;background:transparent;color:var(--text-soft);transition:all .2s;}
.unit-btn.active{background:linear-gradient(135deg,var(--rose-dark),var(--warm-brown));color:#fff;box-shadow:0 2px 8px rgba(201,122,110,.3);}
.btn-danger{background:rgba(253,234,234,.8);color:#b85c5c;border:none;border-radius:50px;padding:7px 14px;font-family:var(--font-sans);font-size:.77rem;font-weight:600;cursor:pointer;}
.btn-logout{background:rgba(245,213,207,.6);color:var(--warm-brown);border:none;border-radius:50px;padding:7px 14px;font-family:var(--font-sans);font-size:.77rem;font-weight:600;cursor:pointer;}

/* ══ MODAL SUSCRIPCIÓN ══ */
.sub-modal{max-height:96vh;}
.sub-hero{text-align:center;margin-bottom:20px;}
.sub-hero-badge{display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,rgba(200,150,10,.15),rgba(255,200,60,.15));border:1px solid rgba(200,150,10,.3);border-radius:50px;padding:5px 14px;font-family:var(--font-sans);font-size:.72rem;font-weight:600;color:var(--gold-dark);margin-bottom:10px;}
.sub-hero-title{font-family:var(--font-serif);font-size:1.6rem;font-weight:600;color:var(--warm-brown);line-height:1.15;}
.sub-hero-sub{font-family:var(--font-sans);font-size:.74rem;color:var(--text-soft);margin-top:5px;}

/* Toggle mensual/anual */
.sub-period-tog{display:flex;background:rgba(245,213,207,.35);border-radius:50px;padding:3px;margin:0 auto 20px;width:fit-content;gap:2px;}
.sub-period-btn{padding:7px 18px;border-radius:50px;font-family:var(--font-sans);font-size:.78rem;font-weight:500;cursor:pointer;border:none;background:transparent;color:var(--text-soft);transition:all .2s;}
.sub-period-btn.active{background:var(--white);color:var(--warm-brown);box-shadow:0 2px 10px rgba(139,94,82,.14);}
.sub-save-badge{background:rgba(100,180,100,.2);color:#2e7a2e;border-radius:50px;padding:2px 8px;font-size:.62rem;font-weight:700;margin-left:4px;}

/* Plan cards */
.sub-plans{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px;}
.sub-plan{border-radius:26px;padding:18px 14px;position:relative;overflow:hidden;}
.sub-plan.free{background:rgba(255,250,246,.9);border:1.5px solid rgba(232,165,152,.25);}
.sub-plan.premium{background:linear-gradient(145deg,rgba(255,248,224,.95),rgba(255,235,160,.6));border:1.5px solid rgba(200,150,10,.3);}
.sub-plan-label{font-family:var(--font-sans);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px;}
.sub-plan.free .sub-plan-label{color:var(--text-soft);}
.sub-plan.premium .sub-plan-label{color:var(--gold-dark);}
.sub-plan-price{font-family:var(--font-serif);font-size:1.7rem;font-weight:600;line-height:1;color:var(--warm-brown);}
.sub-plan.premium .sub-plan-price{color:var(--gold-dark);}
.sub-plan-period{font-family:var(--font-sans);font-size:.65rem;color:var(--text-soft);margin-top:2px;margin-bottom:12px;}
.sub-plan-features{list-style:none;display:flex;flex-direction:column;gap:6px;}
.sub-plan-features li{font-family:var(--font-sans);font-size:.7rem;color:var(--text);display:flex;align-items:flex-start;gap:5px;line-height:1.35;}
.sub-plan-features li.no{color:var(--text-soft);}
.feat-check{flex-shrink:0;font-size:.75rem;}
.sub-plan-tag{position:absolute;top:10px;right:-18px;background:linear-gradient(135deg,var(--gold),#e8b020);color:#fff;font-family:var(--font-sans);font-size:.58rem;font-weight:700;padding:3px 24px 3px 10px;transform:rotate(0deg);border-radius:4px 0 0 4px;}

/* CTA botones */
.sub-cta-free{width:100%;background:rgba(245,213,207,.5);color:var(--warm-brown);border:1.5px solid rgba(201,122,110,.25);border-radius:50px;padding:11px;font-family:var(--font-sans);font-size:.82rem;font-weight:600;cursor:pointer;margin-top:10px;}
.sub-cta-premium{width:100%;background:linear-gradient(135deg,var(--gold),#e8b020);color:#fff;border:none;border-radius:50px;padding:11px;font-family:var(--font-sans);font-size:.82rem;font-weight:600;cursor:pointer;margin-top:10px;box-shadow:0 4px 16px rgba(200,150,10,.3);}
.sub-disclaimer{font-family:var(--font-sans);font-size:.65rem;color:var(--text-soft);text-align:center;line-height:1.5;}

[data-theme="dark"] .sub-plan.free{background:rgba(36,27,22,.9);}
[data-theme="dark"] .sub-plan.premium{background:linear-gradient(145deg,rgba(50,38,8,.85),rgba(60,44,8,.6));}

/* TOAST */
.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:rgba(139,94,82,.92);backdrop-filter:blur(8px);color:#fff;padding:11px 22px;border-radius:50px;font-family:var(--font-sans);font-size:.8rem;font-weight:500;box-shadow:0 6px 24px rgba(139,94,82,.28);z-index:600;white-space:nowrap;}
@keyframes toastIn{from{opacity:0;top:0}to{opacity:1;top:20px}}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-thumb{background:rgba(232,165,152,.4);border-radius:50px;}

/* Setup banner */
.setup-banner{background:rgba(255,243,224,.9);border-radius:24px;padding:12px 16px;margin-bottom:14px;border-left:4px solid #d4a843;display:none;}
.setup-banner.show{display:block;}
.setup-banner-title{font-family:var(--font-sans);font-size:.75rem;font-weight:600;color:#8b6a20;margin-bottom:2px;}
.setup-banner p{font-family:var(--font-sans);font-size:.7rem;color:#a07830;line-height:1.5;}

/* ══ INICIO / HOME ══ */
.greeting-card{background:linear-gradient(135deg,rgba(245,213,207,.65),rgba(220,232,213,.5));border-radius:32px;padding:20px 22px;margin-bottom:14px;position:relative;overflow:hidden;}
.greeting-card::before{content:'';position:absolute;right:-20px;top:-20px;width:100px;height:100px;background:radial-gradient(circle,rgba(201,122,110,.2),transparent 70%);border-radius:50%;}
.greeting-time{font-family:var(--font-sans);font-size:.68rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px;}
.greeting-name{font-family:var(--font-serif);font-size:1.7rem;font-weight:600;color:var(--warm-brown);line-height:1.1;}
.greeting-sub{font-family:var(--font-sans);font-size:.74rem;color:var(--text-soft);margin-top:4px;font-weight:300;}

/* Streak */
.streak-card{background:linear-gradient(135deg,rgba(255,224,130,.4),rgba(255,180,100,.3));border-radius:28px;padding:16px 20px;margin-bottom:14px;display:flex;align-items:center;gap:14px;border:1px solid rgba(200,150,10,.2);}
.streak-fire{font-size:2rem;line-height:1;flex-shrink:0;}
.streak-info{}
.streak-num{font-family:var(--font-serif);font-size:1.8rem;font-weight:600;color:var(--gold-dark);line-height:1;}
.streak-lbl{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);margin-top:2px;}
.streak-zero .streak-fire{filter:grayscale(1);opacity:.4;}
.streak-zero .streak-num{color:var(--text-soft);}

/* Home stats row */
.home-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.home-stat{background:rgba(255,250,246,.9);border-radius:26px;padding:16px;box-shadow:0 4px 18px rgba(139,94,82,.08);text-align:center;}
.home-stat .hval{font-family:var(--font-serif);font-size:1.65rem;font-weight:600;color:var(--warm-brown);}
.home-stat .hlbl{font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);margin-top:3px;}

/* Alarm active card on home */
.home-alarm{background:rgba(255,250,246,.9);border-radius:26px;padding:16px 18px;margin-bottom:14px;box-shadow:0 4px 18px rgba(139,94,82,.08);display:flex;align-items:center;gap:12px;}
.home-alarm-dot{width:9px;height:9px;border-radius:50%;background:var(--rose-dark);animation:pulse 1.5s ease-in-out infinite;flex-shrink:0;}
.home-alarm-info{flex:1;}
.home-alarm-lbl{font-family:var(--font-sans);font-size:.68rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;}
.home-alarm-time{font-family:var(--font-serif);font-size:1.2rem;font-weight:600;color:var(--warm-brown);}
.home-alarm-cd{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);}

/* Quick add button on home */
.home-add{width:100%;background:linear-gradient(135deg,var(--rose-dark),var(--warm-brown));border:none;border-radius:26px;padding:18px;font-family:var(--font-sans);font-size:.95rem;font-weight:600;color:#fff;cursor:pointer;box-shadow:0 6px 22px rgba(201,122,110,.35);display:flex;align-items:center;justify-content:center;gap:9px;margin-bottom:14px;transition:transform .15s,box-shadow .15s;}
.home-add:active{transform:scale(.98);}

/* Recent extractions on home */
.home-section-title{font-family:var(--font-sans);font-size:.68rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.07em;margin-bottom:9px;padding:0 2px;}
.home-recent{}
.home-ext-item{background:rgba(255,250,246,.9);border-radius:22px;padding:13px 16px;margin-bottom:9px;box-shadow:0 3px 14px rgba(139,94,82,.07);display:flex;justify-content:space-between;align-items:center;animation:slideIn .3s ease;}
.home-ext-left{}
.home-ext-time{font-family:var(--font-serif);font-size:1.05rem;font-weight:600;color:var(--warm-brown);}
.home-ext-meta{font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);margin-top:2px;}
.home-ext-amt{font-family:var(--font-serif);font-size:1.3rem;font-weight:600;color:var(--rose-dark);}
.home-ext-unit{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);}
.home-empty{text-align:center;padding:28px 16px;color:var(--text-soft);}
.home-empty p{font-family:var(--font-sans);font-size:.78rem;font-weight:300;margin-top:6px;}

[data-theme="dark"] .home-stat,[data-theme="dark"] .home-alarm,[data-theme="dark"] .home-ext-item{background:rgba(15,21,37,.9);}
[data-theme="dark"] .greeting-card{background:linear-gradient(135deg,rgba(40,20,40,.6),rgba(20,30,50,.5));}
[data-theme="dark"] .streak-card{background:linear-gradient(135deg,rgba(40,30,8,.6),rgba(50,34,8,.4));}

/* ══ PERFIL ══ */
.perf-hero{background:linear-gradient(145deg,rgba(245,213,207,.6),rgba(220,232,213,.5));border-radius:32px;padding:26px 22px 22px;text-align:center;margin-bottom:16px;position:relative;overflow:hidden;}
.perf-hero::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;background:radial-gradient(circle,rgba(201,122,110,.22),transparent 70%);border-radius:50%;}
.perf-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--rose-dark),var(--warm-brown));display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:2rem;font-weight:600;color:#fff;margin:0 auto 12px;box-shadow:0 6px 20px rgba(201,122,110,.32);}
.perf-name{font-family:var(--font-serif);font-size:1.4rem;font-weight:600;color:var(--warm-brown);}
.perf-email{font-family:var(--font-sans);font-size:.74rem;color:var(--text-soft);margin-top:3px;}
.perf-since{font-family:var(--font-sans);font-size:.66rem;color:var(--text-soft);margin-top:2px;font-weight:300;}

/* ══ PLANES MODAL ══ */
.plan-card{background:var(--white);border:1.5px solid var(--rose-light);border-radius:16px;padding:16px;cursor:pointer;transition:transform .18s,box-shadow .18s;position:relative;}
.plan-card:active{transform:scale(.98);}
.plan-card-featured{border-color:var(--warm-brown);box-shadow:0 4px 20px rgba(140,90,70,.15);}
.plan-card-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;}
.plan-name{font-weight:700;font-size:1rem;color:var(--text);}
.plan-price{font-weight:800;font-size:1.1rem;color:var(--warm-brown);}
.plan-price small{font-size:.72rem;font-weight:500;color:var(--text-soft);}
.plan-desc{font-size:.78rem;color:var(--text-soft);line-height:1.5;}
.plan-badge-top{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--warm-brown);color:#fff;font-size:.68rem;font-weight:700;padding:3px 14px;border-radius:50px;white-space:nowrap;}
[data-theme="dark"] .plan-card{border-color:rgba(255,255,255,.08);}
[data-theme="dark"] .plan-card-featured{border-color:var(--warm-brown);}

/* Plan badge */
.plan-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:50px;font-family:var(--font-sans);font-size:.72rem;font-weight:600;margin-top:10px;}
.plan-badge.free{background:rgba(245,213,207,.6);color:var(--warm-brown);}
.plan-badge.premium{background:linear-gradient(135deg,rgba(200,150,10,.2),rgba(255,200,60,.2));color:var(--gold-dark);border:1px solid rgba(200,150,10,.3);}
.plan-badge.owner{background:linear-gradient(135deg,rgba(100,60,180,.18),rgba(60,100,200,.18));color:#6040c0;border:1px solid rgba(100,60,180,.25);}
[data-theme="dark"] .plan-badge.owner{color:#b090ff;border-color:rgba(160,120,255,.3);background:linear-gradient(135deg,rgba(100,60,180,.3),rgba(60,100,200,.25));}

/* Upgrade card */
.upgrade-card{background:linear-gradient(135deg,rgba(255,243,210,.8),rgba(255,224,130,.5));border-radius:28px;padding:18px 20px;margin-bottom:16px;border:1px solid rgba(200,150,10,.25);display:flex;align-items:center;gap:14px;}
.upgrade-card-icon{font-size:1.8rem;flex-shrink:0;}
.upgrade-card-info{flex:1;}
.upgrade-card-title{font-family:var(--font-sans);font-size:.86rem;font-weight:600;color:var(--gold-dark);}
.upgrade-card-sub{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);margin-top:2px;line-height:1.4;}
.btn-upgrade{background:linear-gradient(135deg,var(--gold),#e8b020);color:#fff;border:none;border-radius:50px;padding:9px 18px;font-family:var(--font-sans);font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap;box-shadow:0 4px 14px rgba(200,150,10,.3);flex-shrink:0;}

/* Theme toggle row */
.theme-row{display:flex;justify-content:space-between;align-items:center;padding:13px 18px;}
.theme-icon{font-size:1rem;margin-right:4px;}

[data-theme="dark"] .perf-hero{background:linear-gradient(145deg,rgba(30,20,50,.5),rgba(15,25,50,.4));}
[data-theme="dark"] .upgrade-card{background:linear-gradient(135deg,rgba(40,28,8,.7),rgba(50,34,8,.5));border-color:rgba(200,150,10,.2);}

/* ══ STARS (dark mode) ══ */
.stars-layer{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity 1.4s ease;}
[data-theme="dark"] .stars-layer{opacity:1;}
.star{position:absolute;background:#c8d8ff;border-radius:50%;animation:twinkle var(--tw-dur,3s) ease-in-out infinite var(--tw-del,0s);opacity:0;}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.4)}50%{opacity:var(--tw-op,.8);transform:scale(1)}}

/* ══ HOME HERO ══ */
.home-hero{text-align:center;padding:4px 0 14px;margin-bottom:14px;}
.home-hero-drop{width:68px;height:68px;margin:0 auto 10px;animation:breathe 3.5s ease-in-out infinite;}
.home-hero-drop svg{width:100%;height:100%;}
.home-hero-title{font-family:var(--font-serif);font-size:2.6rem;font-weight:700;color:var(--warm-brown);letter-spacing:-.04em;line-height:1;margin-bottom:5px;}
.home-hero-greeting{font-family:var(--font-sans);font-size:.78rem;color:var(--text-soft);}
.home-hero-greeting strong{color:var(--warm-brown);}
.home-hero-sub{font-family:var(--font-sans);font-size:.72rem;color:var(--text-soft);font-weight:300;margin-top:2px;}

/* ══ HOME COLUMNS ══ */
.home-columns{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:14px;}
.home-col{background:rgba(255,250,246,.9);border-radius:26px;padding:15px 13px;box-shadow:0 4px 18px rgba(139,94,82,.08);min-height:170px;}
.hcol-label{font-family:var(--font-sans);font-size:.6rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;}
.hcol-big-val{font-family:var(--font-serif);font-size:1.75rem;font-weight:600;color:var(--warm-brown);line-height:1;margin-bottom:2px;}
.hcol-small{font-family:var(--font-sans);font-size:.66rem;color:var(--text-soft);margin-bottom:10px;}
.streak-mini{display:inline-flex;align-items:center;gap:4px;background:rgba(255,224,130,.35);border-radius:50px;padding:4px 10px 4px 8px;border:1px solid rgba(200,150,10,.15);margin-bottom:10px;}
.streak-mini-fire{font-size:.85rem;}
.streak-mini-num{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--gold-dark);}
.streak-mini-lbl{font-family:var(--font-sans);font-size:.6rem;color:var(--text-soft);}
.streak-mini.zero .streak-mini-fire{filter:grayscale(1);opacity:.4;}
.streak-mini.zero .streak-mini-num{color:var(--text-soft);}
.mini-chart{margin-top:4px;}
.mini-bars{display:flex;align-items:flex-end;gap:2px;height:32px;margin-bottom:2px;}
.mini-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;}
.mini-bar{width:100%;border-radius:2px 2px 0 0;background:linear-gradient(to top,var(--rose-dark),rgba(245,213,207,.65));min-height:2px;transition:height .4s ease;}
.mini-days{display:flex;gap:2px;}
.mini-day{flex:1;text-align:center;font-family:var(--font-sans);font-size:.44rem;color:var(--text-soft);}

/* Alarm column */
.home-col-right{cursor:pointer;transition:transform .15s,box-shadow .15s;}
.home-col-right:active{transform:scale(.97);}
.alarm-col-off{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:10px;}
.alarm-col-off-lbl{font-family:var(--font-sans);font-size:.72rem;font-weight:600;color:var(--warm-brown);margin-top:5px;}
.alarm-col-off-sub{font-family:var(--font-sans);font-size:.6rem;color:var(--text-soft);margin-top:2px;}
.alarm-col-active{display:flex;flex-direction:column;align-items:center;text-align:center;}
.alarm-col-dot{width:7px;height:7px;border-radius:50%;background:var(--rose-dark);animation:pulse 1.5s ease-in-out infinite;margin-bottom:5px;}
.alarm-col-time{font-family:var(--font-serif);font-size:1.55rem;font-weight:600;color:var(--warm-brown);line-height:1;}
.alarm-col-int{font-family:var(--font-sans);font-size:.6rem;color:var(--text-soft);margin-top:3px;}
.alarm-col-cd{font-family:var(--font-sans);font-size:.6rem;color:var(--text-soft);margin-top:2px;}
.alarm-col-stop{margin-top:8px;background:rgba(253,234,234,.8);color:#b85c5c;border:none;border-radius:50px;padding:5px 11px;font-family:var(--font-sans);font-size:.65rem;font-weight:600;cursor:pointer;}
.alarm-config-panel{background:rgba(255,250,246,.9);border-radius:26px;padding:18px;box-shadow:0 4px 18px rgba(139,94,82,.07);margin-bottom:14px;animation:slideIn .3s ease;}
.alarm-config-panel h3{font-family:var(--font-sans);font-size:.9rem;font-weight:600;color:var(--warm-brown);margin-bottom:12px;}

/* Dark mode home columns */
[data-theme="dark"] .home-col{background:rgba(15,21,37,.9);}
[data-theme="dark"] .alarm-config-panel{background:rgba(15,21,37,.9);}
[data-theme="dark"] .streak-mini{background:rgba(40,30,8,.5);border-color:rgba(200,150,10,.12);}

/* Theme toggle — sun/moon animation */
.theme-icon{display:inline-block;font-size:1rem;margin-right:4px;transition:transform .5s cubic-bezier(.34,1.56,.64,1);}
[data-theme="dark"] .theme-icon{transform:rotate(360deg) scale(1.15);}

/* ══════════════════════════════════════════
   BEBÉ — CRECIMIENTO OMS
══════════════════════════════════════════ */

/* Setup card */
.bebe-setup-card{background:rgba(255,250,246,.92);border-radius:36px;padding:28px 22px 30px;box-shadow:0 8px 32px rgba(139,94,82,.1);text-align:center;}
.bebe-setup-icon{font-size:3rem;margin-bottom:10px;}
.bebe-setup-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:600;color:var(--warm-brown);margin-bottom:6px;}
.bebe-setup-sub{font-family:var(--font-sans);font-size:.76rem;color:var(--text-soft);font-weight:300;margin-bottom:22px;line-height:1.5;}
.sex-tog{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.sex-btn{border:1.5px solid rgba(232,165,152,.4);background:rgba(253,246,238,.7);border-radius:24px;padding:12px;font-family:var(--font-sans);font-size:.86rem;font-weight:500;color:var(--text-soft);cursor:pointer;transition:all .18s;}
.sex-btn.active{border-color:var(--rose-dark);background:rgba(245,213,207,.7);color:var(--warm-brown);font-weight:600;}

/* Baby profile card */
.baby-profile-card{background:linear-gradient(135deg,rgba(245,213,207,.6),rgba(220,232,213,.5));border-radius:26px;padding:16px 18px;margin-bottom:14px;display:flex;align-items:center;gap:13px;}
.baby-avatar{font-size:2rem;flex-shrink:0;}
.baby-profile-info{flex:1;}
.baby-profile-name{font-family:var(--font-serif);font-size:1.2rem;font-weight:600;color:var(--warm-brown);}
.baby-profile-age{font-family:var(--font-sans);font-size:.72rem;color:var(--text-soft);margin-top:2px;}
.baby-edit-btn{background:rgba(255,250,246,.7);border:1.5px solid rgba(232,165,152,.3);border-radius:50px;padding:6px 13px;font-family:var(--font-sans);font-size:.72rem;font-weight:500;color:var(--warm-brown);cursor:pointer;flex-shrink:0;}

/* Chart type toggle */
.chart-type-tog{display:flex;background:rgba(245,213,207,.35);border-radius:50px;padding:3px;margin-bottom:12px;gap:2px;}
.ctog{flex:1;padding:8px 14px;border-radius:50px;font-family:var(--font-sans);font-size:.8rem;font-weight:500;cursor:pointer;border:none;background:transparent;color:var(--text-soft);transition:all .2s;}
.ctog.active{background:var(--white);color:var(--warm-brown);font-weight:600;box-shadow:0 2px 10px rgba(139,94,82,.14);}

/* Growth chart */
.growth-chart-wrap{background:rgba(255,250,246,.9);border-radius:24px;padding:14px 12px 8px;box-shadow:0 4px 18px rgba(139,94,82,.08);margin-bottom:10px;overflow:hidden;}
.growth-chart{width:100%;display:block;}

/* Legend */
.chart-legend{display:flex;align-items:center;gap:14px;justify-content:center;margin-bottom:10px;flex-wrap:wrap;}
.legend-item,.legend-dot-item{display:flex;align-items:center;gap:5px;font-family:var(--font-sans);font-size:.65rem;color:var(--text-soft);}
.legend-line{display:inline-block;width:18px;height:2px;background:var(--rose-dark);border-radius:2px;}
.legend-area{display:inline-block;width:14px;height:10px;background:rgba(232,165,152,.35);border-radius:3px;}
.legend-dot-baby{display:inline-block;width:8px;height:8px;border-radius:50%;background:#3a7bd5;border:1.5px solid #fff;box-shadow:0 0 0 1px #3a7bd5;}

/* WHO info banner */
.who-info{background:rgba(240,246,255,.8);border-radius:16px;padding:9px 14px;font-family:var(--font-sans);font-size:.66rem;color:#5a6a8a;text-align:center;margin-bottom:14px;line-height:1.5;border:1px solid rgba(90,106,138,.12);}

/* Latest measure card */
.latest-card-inner{background:rgba(255,250,246,.9);border-radius:26px;padding:18px;box-shadow:0 4px 18px rgba(139,94,82,.08);margin-bottom:14px;}
.latest-card-title{font-family:var(--font-sans);font-size:.68rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;}
.latest-metrics{display:flex;gap:12px;flex-wrap:wrap;}
.latest-metric{flex:1;min-width:70px;text-align:center;}
.lm-val{font-family:var(--font-serif);font-size:1.6rem;font-weight:600;color:var(--warm-brown);line-height:1;}
.lm-val span{font-family:var(--font-sans);font-size:.7rem;font-weight:400;color:var(--text-soft);margin-left:2px;}
.lm-lbl{font-family:var(--font-sans);font-size:.66rem;color:var(--text-soft);margin-top:3px;}
.pband{display:inline-block;font-family:var(--font-sans);font-size:.6rem;font-weight:600;padding:2px 8px;border-radius:50px;margin-top:4px;}
.pband-ok{background:rgba(180,230,180,.5);color:#3a7a3a;}
.pband-low{background:rgba(255,220,100,.5);color:#8a6800;}
.pband-high{background:rgba(255,200,160,.5);color:#8a5000;}
.latest-notes{font-family:var(--font-sans);font-size:.72rem;color:var(--text-soft);font-style:italic;margin-top:10px;padding-top:10px;border-top:1px solid rgba(232,165,152,.2);}
.latest-empty{text-align:center;padding:20px;color:var(--text-soft);}
.latest-empty p{font-family:var(--font-sans);font-size:.76rem;font-weight:300;margin-top:6px;}

/* Measure history cards */
.measure-card{background:rgba(255,250,246,.9);border-radius:22px;padding:14px 16px;margin-bottom:9px;box-shadow:0 3px 14px rgba(139,94,82,.07);animation:slideIn .3s ease;}
.measure-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.measure-date{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--warm-brown);}
.measure-age{font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);font-weight:400;}
.measure-metrics{display:flex;gap:8px;flex-wrap:wrap;}
.mm{font-family:var(--font-sans);font-size:.74rem;color:var(--text-soft);background:rgba(245,213,207,.5);border-radius:50px;padding:3px 10px;}

/* Dark mode */
[data-theme="dark"] .bebe-setup-card{background:rgba(15,21,37,.95);}
[data-theme="dark"] .baby-profile-card{background:linear-gradient(135deg,rgba(30,20,50,.5),rgba(15,30,25,.4));}
[data-theme="dark"] .growth-chart-wrap,[data-theme="dark"] .latest-card-inner,[data-theme="dark"] .measure-card{background:rgba(15,21,37,.9);}
[data-theme="dark"] .sex-btn,[data-theme="dark"] .ctog.active{background:rgba(20,28,50,.85);}
[data-theme="dark"] .who-info{background:rgba(20,28,50,.7);color:#8090b8;border-color:rgba(90,106,138,.2);}
[data-theme="dark"] .mm{background:rgba(20,28,50,.8);}
[data-theme="dark"] .chart-type-tog{background:rgba(20,28,50,.5);}

/* ══ WELCOME OVERLAY ══ */
.welcome-overlay{position:fixed;inset:0;background:rgba(61,43,36,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:999;display:flex;align-items:center;justify-content:center;padding:20px;}
.welcome-card{background:var(--white);border-radius:32px;padding:32px 24px 24px;max-width:360px;width:100%;text-align:center;box-shadow:0 24px 64px rgba(139,94,82,.25);animation:slideIn .4s cubic-bezier(.34,1.56,.64,1);}
.welcome-logo{font-size:3rem;margin-bottom:10px;filter:drop-shadow(0 4px 12px rgba(232,165,152,.4));}
.welcome-title{font-family:var(--font-serif);font-size:1.6rem;font-weight:700;color:var(--warm-brown);margin-bottom:14px;}
.welcome-text{font-family:var(--font-sans);font-size:.82rem;color:var(--text-soft);line-height:1.65;margin-bottom:22px;}
.welcome-contact{font-family:var(--font-sans);font-size:.72rem;color:var(--text-soft);margin-top:14px;cursor:pointer;}
.welcome-contact span{color:var(--rose-dark);font-weight:600;text-decoration:underline;}
[data-theme="dark"] .welcome-card{background:rgba(15,21,37,.98);}

/* ══ ROLE BADGES ══ */
.role-badge{display:inline-block;font-family:var(--font-sans);font-size:.6rem;font-weight:600;padding:1px 7px;border-radius:50px;margin-left:5px;vertical-align:middle;}
.role-owner{background:rgba(200,150,10,.15);color:#8a6500;border:1px solid rgba(200,150,10,.3);}
.role-admin{background:rgba(90,130,200,.15);color:#3a5a90;border:1px solid rgba(90,130,200,.3);}
.role-emb{background:rgba(200,160,50,.15);color:#8a6010;border:1px solid rgba(200,160,50,.3);}
.role-nutri{background:rgba(100,170,100,.15);color:#3a7a3a;border:1px solid rgba(100,170,100,.3);}
.role-ped{background:rgba(80,160,220,.15);color:#2060a0;border:1px solid rgba(80,160,220,.3);}
.role-asesora{background:rgba(220,130,180,.15);color:#903060;border:1px solid rgba(220,130,180,.3);}
[data-theme="dark"] .role-owner{background:rgba(200,150,10,.2);color:#d4a020;border-color:rgba(200,150,10,.2);}
[data-theme="dark"] .role-admin{background:rgba(90,130,200,.2);color:#7898d8;border-color:rgba(90,130,200,.2);}
[data-theme="dark"] .role-emb{background:rgba(200,160,50,.2);color:#c8a020;border-color:rgba(200,160,50,.2);}
[data-theme="dark"] .role-nutri{background:rgba(100,170,100,.2);color:#60b860;border-color:rgba(100,170,100,.2);}
[data-theme="dark"] .role-ped{background:rgba(80,160,220,.2);color:#50a8e8;border-color:rgba(80,160,220,.2);}
[data-theme="dark"] .role-asesora{background:rgba(220,130,180,.2);color:#e878b8;border-color:rgba(220,130,180,.2);}

/* ══ COMMUNITY PREMIUM BANNER ══ */
.comm-premium-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,rgba(201,184,232,.25),rgba(232,165,152,.2));border:1px solid rgba(201,184,232,.5);border-radius:20px;padding:12px 14px;margin-bottom:14px;}
.cpb-icon{font-size:1.5rem;flex-shrink:0;}
.cpb-info{flex:1;}
.cpb-title{font-family:var(--font-serif);font-size:.9rem;font-weight:600;color:var(--lavender-dark);}
.cpb-sub{font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);margin-top:2px;line-height:1.4;}
.cpb-btn{flex-shrink:0;background:var(--lavender-dark);color:#fff;border:none;border-radius:50px;padding:7px 14px;font-family:var(--font-sans);font-size:.72rem;font-weight:600;cursor:pointer;}
[data-theme="dark"] .comm-premium-banner{background:linear-gradient(135deg,rgba(120,100,200,.15),rgba(200,100,100,.1));border-color:rgba(120,100,200,.3);}

/* ══ ALARM HOME CARD ══ */
.alarm-home-card{background:rgba(255,250,246,.9);border-radius:20px;padding:12px 16px;margin-bottom:12px;box-shadow:0 3px 14px rgba(139,94,82,.07);cursor:pointer;display:flex;align-items:center;gap:12px;}
.alarm-home-lbl{font-family:var(--font-sans);font-size:.7rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;}
.alarm-home-card .alarm-col-off{display:flex;align-items:center;gap:8px;flex:1;}
.alarm-home-card .alarm-col-off-lbl{font-family:var(--font-serif);font-size:.9rem;color:var(--text-soft);}
.alarm-home-card .alarm-col-off-sub{font-family:var(--font-sans);font-size:.66rem;color:var(--text-soft);opacity:.7;}
.alarm-home-card .alarm-col-active{display:flex;align-items:center;gap:10px;flex:1;flex-wrap:wrap;}
[data-theme="dark"] .alarm-home-card{background:rgba(15,21,37,.9);}

/* ══ HOME BEBÉ MINI ══ */
.home-bebe-mini{cursor:pointer;text-align:center;}
.home-bebe-avatar{font-size:1.8rem;margin-bottom:2px;}
.home-bebe-name{font-family:var(--font-serif);font-size:.9rem;font-weight:600;color:var(--warm-brown);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.home-bebe-age{font-family:var(--font-sans);font-size:.65rem;color:var(--text-soft);margin-bottom:4px;}
.home-bebe-weight{font-family:var(--font-serif);font-size:1.3rem;font-weight:700;color:var(--rose-dark);}
.home-bebe-weight span{font-size:.65rem;margin-left:2px;font-weight:400;color:var(--text-soft);}
.home-bebe-empty{text-align:center;}
.home-bebe-empty-lbl{font-family:var(--font-serif);font-size:.85rem;color:var(--text-soft);}
.home-bebe-empty-sub{font-family:var(--font-sans);font-size:.62rem;color:var(--text-soft);opacity:.7;}
.home-bebe-no-data{font-family:var(--font-sans);font-size:.65rem;color:var(--text-soft);}

/* ══ BABY UNIT TOGGLE ══ */
.baby-unit-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.baby-unit-lbl{font-family:var(--font-sans);font-size:.7rem;color:var(--text-soft);font-weight:600;flex-shrink:0;}
.baby-unit-tog{flex:1;}

/* ══ NAV CENTRO CON LOGO ══ */
.nav-center-btn{position:relative;}
.nav-center-btn .nav-center-drop{
  width:46px;height:46px;
  background:var(--rose-light);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 2px;
  box-shadow:0 4px 16px rgba(232,165,152,.35);
  transition:transform .2s ease,box-shadow .2s ease;
}
.nav-center-btn .nav-center-drop svg{width:26px;height:26px;color:var(--rose-dark);}
.nav-center-btn.active .nav-center-drop{
  background:var(--rose-dark);
  box-shadow:0 6px 20px rgba(201,122,110,.45);
  transform:translateY(-2px);
}
.nav-center-btn .nav-lbl{color:var(--text-soft);font-size:.58rem;}
.nav-center-btn.active .nav-lbl{color:var(--rose-dark);}
[data-theme="dark"] .nav-center-btn .nav-center-drop{background:rgba(204,136,136,.18);border:1.5px solid rgba(204,136,136,.25);}
[data-theme="dark"] .nav-center-btn.active .nav-center-drop{background:var(--rose-dark);border-color:transparent;}
[data-theme="dark"] .nav-center-btn .nav-center-drop svg{color:#cc8888;}
[data-theme="dark"] .nav-center-btn.active .nav-center-drop svg{color:#fff;}

/* ══ DARK MODE FIXES — Contrastes ══ */
[data-theme="dark"] .home-col{border:1px solid rgba(204,136,136,.12);}
[data-theme="dark"] .home-col-left .hcol-big-val{color:#e8b0a8;}
[data-theme="dark"] .mini-bar{background:rgba(204,136,136,.7);}
[data-theme="dark"] .streak-mini{background:rgba(255,180,80,.12);border:1px solid rgba(255,180,80,.2);}
[data-theme="dark"] .streak-mini-num{color:#ffb840;}
[data-theme="dark"] .alarm-home-card{background:rgba(15,21,37,.9);border:1px solid rgba(204,136,136,.15);}
[data-theme="dark"] .alarm-col-dot{background:#cc8888;box-shadow:0 0 8px rgba(204,136,136,.6);}
[data-theme="dark"] .growth-chart-wrap{background:rgba(10,14,26,.8);}
[data-theme="dark"] #growth-svg rect{fill:rgba(20,28,50,.6);}
[data-theme="dark"] .nav-btn:not(.nav-center-btn).active .nav-pip{background:linear-gradient(135deg,rgba(204,136,136,.22),rgba(100,120,180,.18));}
[data-theme="dark"] .nav-btn.active{color:#e8c0b8;}
[data-theme="dark"] .hbtn{background:rgba(204,136,136,.12);color:#cc8888;}
[data-theme="dark"] .hbtn-comm{color:#9898c8;}
[data-theme="dark"] .perf-avatar{background:linear-gradient(135deg,rgba(180,90,80,.35),rgba(100,80,160,.25));color:#e8c0b8;}

/* ══ ALARMA EN ESTADÍSTICAS ══ */
.stats-alarm-section{margin-bottom:16px;}
.stats-alarm-card{background:rgba(255,250,246,.9);border-radius:20px;padding:14px 16px;box-shadow:0 3px 14px rgba(139,94,82,.07);}
.stats-alarm-off,.stats-alarm-active{display:flex;align-items:center;gap:12px;}
.sa-icon{font-size:1.8rem;flex-shrink:0;}
.sa-info{flex:1;}
.sa-title{font-family:var(--font-serif);font-size:.95rem;font-weight:600;color:var(--warm-brown);}
.sa-sub{font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);margin-top:2px;}
.sa-time{font-family:var(--font-serif);font-size:1.4rem;font-weight:700;color:var(--rose-dark);line-height:1.1;}
.sa-int{font-family:var(--font-sans);font-size:.68rem;color:var(--text-soft);margin-top:2px;}
.sa-dot-wrap{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;}
.sa-cfg-btn{flex-shrink:0;background:var(--rose-light);color:var(--warm-brown);border:none;border-radius:50px;padding:7px 14px;font-family:var(--font-sans);font-size:.72rem;font-weight:600;cursor:pointer;}
.sa-stop-btn{flex-shrink:0;background:rgba(220,100,80,.12);color:#c05040;border:1px solid rgba(220,100,80,.25);border-radius:50px;padding:7px 12px;font-family:var(--font-sans);font-size:.68rem;font-weight:600;cursor:pointer;}
[data-theme="dark"] .stats-alarm-card{background:rgba(15,21,37,.9);border:1px solid rgba(204,136,136,.12);}
[data-theme="dark"] .sa-cfg-btn{background:rgba(204,136,136,.15);color:#cc8888;}

/* ══ PANEL DE ADMINISTRACIÓN ══ */
.admin-section{margin-top:4px;}
.admin-tabs{display:flex;gap:8px;margin-bottom:12px;}
.admin-tab{flex:1;padding:9px 8px;border:1.5px solid var(--rose-light);border-radius:12px;background:transparent;color:var(--text-soft);font-family:var(--font-sans);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;}
.admin-tab.active{background:var(--rose);color:#fff;border-color:var(--rose);}
.admin-loading,.admin-empty{text-align:center;padding:20px 16px;color:var(--text-soft);font-size:.82rem;}

/* Mensajes de feedback */
.fb-card{background:var(--white);border-radius:14px;padding:12px 14px;margin-bottom:8px;border-left:3px solid var(--rose-light);transition:border-color .2s;}
.fb-card.fb-unread{border-left-color:var(--rose-dark);}
.fb-card.fb-read{opacity:.7;}
.fb-hdr{display:flex;align-items:center;gap:6px;margin-bottom:6px;flex-wrap:wrap;}
.fb-email{font-size:.78rem;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.fb-date{font-size:.68rem;color:var(--text-soft);flex-shrink:0;}
.btn-fb-read{font-size:.68rem;padding:3px 9px;border-radius:8px;border:1px solid var(--rose);color:var(--rose);background:transparent;cursor:pointer;flex-shrink:0;}
.fb-badge-read{font-size:.68rem;color:var(--text-soft);flex-shrink:0;}
.fb-msg{font-size:.82rem;color:var(--text);line-height:1.55;white-space:pre-wrap;}

/* Usuarios */
.user-card{display:flex;align-items:center;gap:10px;background:var(--white);border-radius:14px;padding:10px 12px;margin-bottom:8px;}
.user-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--rose),var(--lavender));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.92rem;flex-shrink:0;}
.user-info{flex:1;min-width:0;}
.user-name{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-sub{font-size:.68rem;color:var(--text-soft);}
.role-sel{font-size:.72rem;padding:5px 8px;border:1.5px solid var(--rose-light);border-radius:10px;background:var(--white);color:var(--text);cursor:pointer;max-width:130px;outline:none;}
.role-sel:disabled{opacity:.5;cursor:not-allowed;}

/* Dark mode admin */
[data-theme="dark"] .admin-tab{border-color:rgba(204,136,136,.2);color:var(--text-soft);}
[data-theme="dark"] .admin-tab.active{background:var(--rose);color:#fff;border-color:var(--rose);}
[data-theme="dark"] .fb-card,[data-theme="dark"] .user-card,[data-theme="dark"] .ref-card{background:rgba(15,21,37,.8);border-color:rgba(204,136,136,.1);}
[data-theme="dark"] .fb-card.fb-unread{border-left-color:var(--rose);}
[data-theme="dark"] .role-sel{background:rgba(15,21,37,.9);border-color:rgba(204,136,136,.2);}

/* ══ REFERIDOS ADMIN ══ */
.ref-stats-summary{display:flex;gap:10px;margin-bottom:14px;}
.ref-stat-box{flex:1;background:var(--white);border:1.5px solid var(--rose-light);border-radius:14px;padding:14px;text-align:center;}
.ref-stat-num{font-size:1.6rem;font-weight:800;color:var(--warm-brown);}
.ref-stat-lbl{font-size:.72rem;color:var(--text-soft);margin-top:2px;}
.ref-card{display:flex;justify-content:space-between;align-items:center;background:var(--white);border:1.5px solid var(--rose-light);border-radius:14px;padding:12px 16px;margin-bottom:10px;}
.ref-code{font-weight:700;font-size:.95rem;color:var(--text);letter-spacing:.5px;}
.ref-owner{font-size:.72rem;color:var(--text-soft);margin-top:2px;}
.ref-card-right{text-align:center;}
.ref-uses{font-size:1.4rem;font-weight:800;color:var(--warm-brown);}
.ref-uses-lbl{font-size:.65rem;color:var(--text-soft);}
[data-theme="dark"] .ref-stat-box{background:rgba(15,21,37,.8);border-color:rgba(204,136,136,.1);}
[data-theme="dark"] .ref-card{background:rgba(15,21,37,.8);border-color:rgba(204,136,136,.1);}

/* ══ RESPONSIVE — iPhone SE y pantallas pequeñas ══ */
/* ══ RESPONSIVE IPHONE ══ */

/* iPhone SE y pantallas pequeñas (≤375px) */
@media (max-width: 375px){
  .header-logo h1{font-size:1.2rem;}
  .content{padding-left:12px;padding-right:12px;}
  .stat-card,.ext-card,.s-card{padding:14px 12px;}
  .home-col{padding:14px 12px;}
  .hbtn{width:34px;height:34px;}
  .nav-lbl{font-size:.5rem;}
  .btn-primary,.btn-cancel,.btn-save{font-size:.84rem;padding:14px 18px;}
  .modal{padding:20px 16px;}
}

/* iPhone estándar (376px–430px) */
@media (min-width:376px) and (max-width:430px){
  .content{padding-left:16px;padding-right:16px;}
}

/* Evitar zoom en inputs en iOS */
input,select,textarea{font-size:16px !important;}
.flbl{font-size:.8rem !important;}

/* Área segura inferior — versión siempre visible */
.page-footer{padding-bottom:calc(8px + var(--sab));}

/* ══ DARK MODE bottom-nav ══ */
[data-theme="dark"] .bottom-nav{background:rgba(10,14,26,.93);}

/* ══ GOOGLE BUTTON ══ */
.btn-google{width:100%;padding:13px;border:1.5px solid rgba(139,94,82,.2);border-radius:16px;background:#fff;color:#3d2b24;font-family:var(--font-sans);font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .2s,box-shadow .2s;}
.btn-google:hover{background:#fafafa;box-shadow:0 2px 12px rgba(0,0,0,.08);}
[data-theme="dark"] .btn-google{background:rgba(20,28,50,.8);border-color:rgba(204,136,136,.2);color:var(--text);}
.auth-divider{display:flex;align-items:center;gap:10px;margin:12px 0;color:var(--text-soft);font-size:.75rem;}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:rgba(139,94,82,.15);}

/* ══ TRIAL ══ */
.plan-badge.trial{background:linear-gradient(135deg,#f5a623,#e8833a);color:#fff;}
.trial-banner{background:linear-gradient(135deg,#fff8e8,#fff3d4);border:1.5px solid #f5a623;border-radius:18px;padding:14px 16px;display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.trial-banner-txt{flex:1;display:flex;flex-direction:column;gap:2px;}
.trial-banner-txt strong{font-size:.85rem;color:#8a6500;}
.trial-banner-txt span{font-size:.72rem;color:#b38a30;}
[data-theme="dark"] .trial-banner{background:rgba(32,24,8,.9);border-color:#c8960a;}
[data-theme="dark"] .trial-banner-txt strong{color:#e8c840;}
[data-theme="dark"] .trial-banner-txt span{color:#b09020;}

/* ══ REFERRAL ══ */
.referral-card{background:linear-gradient(135deg,var(--rose-light),var(--sage-light));border-radius:18px;padding:16px;border:1.5px solid rgba(232,165,152,.3);}
.referral-code-wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;}
.referral-code-txt{font-family:var(--font-serif);font-size:1.4rem;font-weight:700;color:var(--warm-brown);letter-spacing:.08em;}
.referral-copy-btn{background:var(--rose-dark);color:#fff;border:none;border-radius:12px;padding:8px 16px;font-size:.8rem;font-weight:600;cursor:pointer;}
.referral-uses{font-size:.75rem;color:var(--text-soft);margin-bottom:4px;}
.referral-hint{font-size:.72rem;color:var(--text-soft);font-style:italic;}
[data-theme="dark"] .referral-card{background:rgba(15,21,37,.8);border-color:rgba(204,136,136,.2);}
