@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap');
:root{--bg:#fff7e8;--card:#fffdf8;--teal:#12afa2;--teal2:#08786f;--orange:#ff8a00;--ink:#14212b;--muted:#65717d;--line:#eadfce;--green:#e2f7e7;--pink:#ffe6e7;--yellow:#fff1c9;--blue:#e7f3ff;--purple:#f2e9ff;--shadow:0 18px 44px rgba(110,79,34,.16)}
*{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:Nunito,system-ui,-apple-system,Segoe UI,sans-serif;background:linear-gradient(150deg,#fff5df 0%,#fffdf7 45%,#e6f8f3 100%);color:var(--ink)}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}button:active{transform:scale(.98)}
.phone{max-width:430px;min-height:100dvh;margin:auto;background:radial-gradient(circle at 15% 0%,#fff3c6 0 22%,transparent 38%),var(--bg);position:relative;overflow:hidden;box-shadow:0 0 0 1px #00000010}.screen{padding:16px 16px 92px;min-height:100dvh}.center{display:grid;place-items:center;text-align:center}.logo{width:128px;height:128px;object-fit:contain}.big-logo{width:210px;filter:drop-shadow(0 16px 18px rgba(28,110,101,.18))}.h1{font-size:39px;font-weight:900;line-height:.94;margin:0;color:var(--orange)}.h1 span{display:block;color:var(--teal)}h1,h2,h3,p{margin-top:0}.muted{color:var(--muted)}.small{font-size:12px}.tiny{font-size:11px}.card{background:rgba(255,253,248,.92);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:16px}.input{width:100%;min-height:48px;border:1px solid #ded2bf;border-radius:15px;background:#fff;padding:0 14px;margin:8px 0;outline:0}.input:focus{border-color:var(--teal);box-shadow:0 0 0 4px #12afa222}textarea.input{padding:12px;min-height:82px}.btn{min-height:50px;border-radius:16px;background:linear-gradient(135deg,var(--teal),#18c7b8);color:#fff;font-weight:900;width:100%;box-shadow:0 12px 22px #12afa240}.btn.light{background:#e5f8f5;color:var(--teal2);box-shadow:none}.btn.danger{background:#ffe2e2;color:#b42323}.btn.warn{background:#fff0c8;color:#a76000}.link{background:transparent;color:var(--teal2);font-weight:900}.top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.iconbtn{width:42px;height:42px;border-radius:15px;background:#fff8;box-shadow:0 8px 18px #00000010;font-weight:900}.hero{position:relative;overflow:hidden;border-radius:30px;padding:18px;background:linear-gradient(135deg,#fff9eb,#e3fbf6 58%,#fff0d3);border:1px solid #f0dfc4;box-shadow:var(--shadow)}.hero:after{content:'';position:absolute;right:-30px;top:-35px;width:140px;height:140px;border-radius:50%;background:#ffcf6b55}.hero-row{display:flex;align-items:center;gap:12px;position:relative}.avatar{width:70px;height:70px;object-fit:contain}.welcome{font-size:26px;line-height:1;font-weight:900}.pill{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:8px 13px;background:#dcf8f2;color:#0d766e;font-weight:900}.level-card{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#fff;border:1px solid #f0dfc4;border-radius:22px;padding:13px;margin-top:14px}.level-copy{min-width:0}.level-badge{margin-left:auto;text-align:right;min-width:92px;background:linear-gradient(135deg,#ffd166,#ff8a00);color:#fff;border-radius:18px;padding:10px 12px;box-shadow:0 10px 20px #ff8a0030}.level-badge b{font-size:24px;display:block;line-height:1}.bar{height:10px;background:#eee3d1;border-radius:99px;overflow:hidden}.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),#ffd166);border-radius:99px}.tabs{display:flex;gap:9px;overflow-x:auto;padding:6px 0 10px;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tabs button{white-space:nowrap;border-radius:999px;padding:10px 16px;background:#ffffff99;font-weight:900;color:#56616b}.tabs .active{background:#dff7f2;color:var(--teal2)}.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.tile,.quick button{background:#fff;border:1px solid var(--line);border-radius:20px;padding:14px 8px;text-align:center;box-shadow:0 9px 18px #0000000a;font-weight:900;color:var(--ink)}.emoji{font-size:30px;display:block}.row{display:flex;align-items:center;justify-content:space-between;gap:12px}.activity{background:#fff;border:1px solid var(--line);border-radius:20px;margin:10px 0;padding:13px;box-shadow:0 8px 18px #0000000a}.activity-main{display:flex;align-items:center;gap:12px}.ico{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;font-size:24px;background:#eaf6ff}.circle{width:28px;height:28px;border-radius:50%;border:2px solid #c8d0d4;display:grid;place-items:center;flex:none}.done .circle{background:#20b486;border-color:#20b486;color:#fff}.done{opacity:.78}.nav{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:min(430px,100%);height:76px;background:#fffdf8ec;backdrop-filter:blur(18px);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);padding-bottom:env(safe-area-inset-bottom);z-index:5}.nav button{background:0;font-size:11px;font-weight:900;color:#58636c}.nav .active{color:var(--teal2)}.plus{margin-top:-20px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--teal),#1ac8bb)!important;color:white!important;font-size:29px!important;box-shadow:0 13px 24px #12afa250}.sheet{position:fixed;inset:0;background:#0007;display:none;align-items:flex-end;z-index:20}.sheet.show{display:flex}.panel{width:min(430px,100%);max-height:88dvh;overflow:auto;margin:auto;background:#fffdf8;border-radius:26px 26px 0 0;padding:18px;box-shadow:0 -10px 40px #0004}.blue{background:var(--blue)}.pink{background:var(--pink)}.purple{background:var(--purple)}.green{background:var(--green)}.yellow{background:var(--yellow)}.orange{background:#ffe9cc}.first{border:4px solid #cfeeda}.then{border:4px solid #ffdf9d}.quote{font-weight:900;font-size:18px;line-height:1.15}.reward{display:flex;align-items:center;gap:10px;background:#fff;border:1px dashed #efbd58;border-radius:18px;padding:12px}.report-card{background:#fff;border-radius:20px;padding:14px;border:1px solid var(--line)}#toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);background:#13202b;color:white;padding:10px 14px;border-radius:999px;display:none;z-index:30;max-width:88%;text-align:center}.hide{display:none!important}@media(max-width:360px){.quick{grid-template-columns:repeat(2,1fr)}.welcome{font-size:23px}.screen{padding-left:12px;padding-right:12px}}

/* Login UI fix - clean parent-focused auth screen */
.auth-screen{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;gap:18px;padding:22px 16px 28px;position:relative;overflow:hidden;background:linear-gradient(150deg,#fff7df 0%,#fffdf8 42%,#e1fbf4 100%)}
.auth-blob{position:absolute;border-radius:999px;filter:blur(.2px);opacity:.75;pointer-events:none}.auth-blob.one{width:170px;height:170px;background:#ffd16666;top:-55px;right:-55px}.auth-blob.two{width:190px;height:190px;background:#12afa233;bottom:-80px;left:-70px}.auth-head{display:flex;align-items:center;gap:14px;position:relative;z-index:1}.auth-logo{width:94px;height:94px;object-fit:contain;filter:drop-shadow(0 12px 18px rgba(18,175,162,.18))}.auth-title{font-size:36px;line-height:.95;margin:0;color:var(--orange);font-weight:900}.auth-head p{margin:6px 0 0;color:#52606b;font-size:14px;line-height:1.25}.auth-card{position:relative;z-index:1;background:rgba(255,253,248,.96);border:1px solid #ecdcc4;border-radius:30px;padding:16px;box-shadow:0 24px 60px rgba(94,67,24,.18)}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:5px;background:#f4eadb;border-radius:18px;margin-bottom:12px}.auth-tabs button{min-height:44px;border-radius:14px;background:transparent;color:#695d4e;font-weight:900}.auth-tabs button.active{background:#fff;color:var(--teal2);box-shadow:0 8px 18px rgba(0,0,0,.08)}.auth-helper{margin:2px 4px 12px;color:#65717d;font-size:13px;line-height:1.35}.field-label{display:block;margin:10px 4px 4px;font-size:12px;font-weight:900;color:#42515c}.auth-input{margin:0;min-height:50px;border-radius:16px}.pass-wrap{position:relative}.pass-wrap .input{padding-right:54px}.pass-wrap button{position:absolute;right:6px;top:6px;width:42px;height:38px;border-radius:13px;background:#eef8f6}.auth-main{margin-top:14px}.google-btn{margin-top:10px;background:#fff;color:#26323b;border:1px solid #ddd2bf;box-shadow:0 8px 16px rgba(0,0,0,.06)}.google-btn span{display:inline-grid;place-items:center;width:25px;height:25px;border-radius:50%;background:#fff3d4;color:#dd7a00;margin-right:6px;font-weight:900}.auth-link{display:block;width:100%;text-align:center;margin-top:12px;padding:10px}.auth-note{position:relative;z-index:1;text-align:center;color:#64727d;font-size:12px}.signup-fields{animation:fadeIn .18s ease-out}@keyframes fadeIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}@media(max-width:360px){.auth-screen{padding:14px 12px}.auth-logo{width:78px;height:78px}.auth-title{font-size:31px}.auth-card{padding:13px;border-radius:24px}.auth-tabs button{min-height:40px}.auth-input{min-height:46px}}


/* Care-focused navigation upgrade only: keeps existing theme/colors and screen UI */
.care-nav{height:82px;grid-template-columns:repeat(6,1fr);border-radius:24px 24px 0 0;box-shadow:0 -10px 30px rgba(34,45,54,.10)}
.care-nav button{font-size:10px;line-height:1.15;padding-top:8px;min-width:0}
.care-nav .active{position:relative;color:var(--teal2)}
.care-nav .active:before{content:'';position:absolute;top:4px;left:50%;transform:translateX(-50%);width:28px;height:3px;border-radius:999px;background:var(--teal)}
@media(max-width:360px){.care-nav button{font-size:9px}.care-nav{height:80px}}


/* Landing page refresh: parent-care focused, same Happy Steps colors/theme */
.landing-care{justify-content:flex-start;padding-top:18px;gap:14px;background:radial-gradient(circle at 80% 0%,#ffd16666 0 15%,transparent 34%),linear-gradient(150deg,#fff7df 0%,#fffdf8 46%,#e1fbf4 100%)}
.landing-orb{position:absolute;width:210px;height:210px;border-radius:50%;background:#12afa21f;right:-80px;top:150px;pointer-events:none}
.landing-hero-card{position:relative;z-index:1;background:linear-gradient(145deg,#fffdf8,#e9fbf6);border:1px solid #ecdcc4;border-radius:34px;padding:17px;box-shadow:0 24px 60px rgba(94,67,24,.16);overflow:hidden}
.landing-hero-card:after{content:'';position:absolute;right:-38px;top:-40px;width:135px;height:135px;border-radius:50%;background:#ffd16650}
.landing-logo-wrap{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;position:relative;z-index:1}.landing-logo{width:112px;height:112px}.safe-badge{display:inline-flex;align-items:center;gap:6px;background:#dcf8f2;color:#0d766e;border-radius:999px;padding:8px 11px;font-size:12px;font-weight:900}.safe-badge:before{content:'🫶'}
.eyebrow{margin:2px 0 4px;color:#0d766e;font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.landing-title{font-size:42px}.landing-title span{display:block;color:var(--teal);line-height:.85}.landing-sub{color:#52606b;line-height:1.36;margin-bottom:13px}.landing-care-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;position:relative;z-index:1}.landing-care-grid div{background:#fff;border:1px solid #f0dfc4;border-radius:18px;padding:10px 6px;text-align:center;box-shadow:0 7px 14px rgba(0,0,0,.05)}.landing-care-grid span{display:block;font-size:25px}.landing-care-grid b{display:block;font-size:12px}.landing-care-grid small{display:block;color:#65717d;font-size:10px;line-height:1.1}.landing-auth-card{border-radius:28px}.landing-google{margin-top:4px;background:#fff;color:#26323b;border:1px solid #ddd2bf;box-shadow:0 9px 17px rgba(0,0,0,.06)}.divider{display:flex;align-items:center;gap:10px;margin:12px 0 6px;color:#8a7b69;font-size:12px;font-weight:800}.divider:before,.divider:after{content:'';height:1px;background:#eadfce;flex:1}.parent-nav{background:rgba(255,253,248,.95)}.parent-nav .nav-ico{font-size:19px;line-height:1;display:inline-block;margin-bottom:1px}.parent-nav button{color:#5e6871}.parent-nav .active{background:linear-gradient(180deg,#e8fbf7,#fffdf8);border-radius:18px 18px 0 0}
@media(max-width:360px){.landing-logo{width:92px;height:92px}.landing-title{font-size:36px}.landing-care-grid small{display:none}.landing-hero-card{padding:14px;border-radius:28px}}


/* Post-login parent landing upgrade only; login UI stays reverted */
.parent-home-hero{padding-bottom:18px}
.care-status-card{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:rgba(255,255,255,.58);border:1px solid rgba(255,255,255,.65);border-radius:24px;padding:14px;margin-top:12px;box-shadow:0 10px 28px rgba(18,175,162,.10)}
.care-status-card h1{margin:2px 0;font-size:42px;line-height:1;color:var(--teal2)}
.buddy-mini{min-width:88px;text-align:center;background:#fff7df;border:1px solid #f1dfbc;border-radius:22px;padding:10px;box-shadow:0 8px 18px rgba(105,76,23,.08)}
.buddy-mini img{width:52px;height:52px;object-fit:contain;display:block;margin:0 auto 4px}.buddy-mini small{display:block;color:#6b7280}.support-card{border-left:5px solid var(--teal2)}
.care-actions button{min-height:74px}.care-actions .emoji{display:block;font-size:23px;margin-bottom:4px}
@media(max-width:380px){.care-status-card h1{font-size:34px}.buddy-mini{min-width:78px}.care-actions button{font-size:12px}}

/* Parent-first emotional flow update: keeps original colors/theme */
.simple-parent-nav{grid-template-columns:repeat(5,1fr);height:84px;padding-left:6px;padding-right:6px;border-radius:26px 26px 0 0}
.simple-parent-nav button{border-radius:18px 18px 0 0;min-width:0}
.calm-top{position:sticky;top:0;background:linear-gradient(180deg,#fffdf8 72%,rgba(255,253,248,0));z-index:4;padding-bottom:8px}
.care-companion-hero{background:linear-gradient(145deg,#fff7df,#e6fbf6);border:1px solid #ecdcc4}
.calm-message{margin-top:14px;background:rgba(255,255,255,.68);border:1px solid rgba(255,255,255,.85);border-radius:22px;padding:13px;box-shadow:0 10px 24px rgba(18,175,162,.08)}
.calm-message b{display:block;font-size:16px;line-height:1.25;color:#25323b}
.next-step-card{border-left:5px solid var(--teal)}
.next-care-card{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:12px;margin-top:10px;box-shadow:0 8px 18px rgba(0,0,0,.05)}
.next-care-card p{margin:2px 0 0}.soft-empty{background:#fffaf0}.parent-safe-actions{grid-template-columns:repeat(4,1fr)}
.parent-safe-actions button{font-size:12px;line-height:1.1;border:1px solid #ecdcc4;background:#fffdf8}
.calm-buddy{background:#fffdf8}.level-card{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:22px;padding:12px;margin-top:10px}.level-copy p{margin:5px 0}.level-badge{min-width:70px;text-align:center;border-radius:18px;background:linear-gradient(145deg,#dff7f2,#fff7df);padding:10px 8px;border:1px solid #d9eee9}.level-badge span{display:block;font-size:10px;color:#64727d;font-weight:900}.level-badge b{font-size:28px;color:var(--teal2)}
.care-purpose{border-left:5px solid #ffb84d}.care-purpose b{font-size:18px}.support-card p{line-height:1.35}
@media(max-width:380px){.parent-safe-actions{grid-template-columns:repeat(2,1fr)}.simple-parent-nav{height:82px}.simple-parent-nav .nav-ico{font-size:17px}.care-status-card{grid-template-columns:1fr}.buddy-mini{justify-self:start}.level-card{grid-template-columns:1fr}.level-badge{justify-self:start}}


/* Daily care calendar + digestion tracking */
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:7px;margin-top:12px}
.day-cell{min-height:58px;border:0;border-radius:18px;background:rgba(255,255,255,.72);box-shadow:0 8px 22px rgba(31,79,82,.08);padding:7px 4px;text-align:center;color:var(--text,#173b3f)}
.day-cell b{display:block;font-size:14px}
.day-cell small{display:block;font-size:10px;opacity:.72;margin-top:3px;line-height:1.1}
.day-cell.today{outline:2px solid #12afa2;background:linear-gradient(180deg,#e9fffb,#fff)}
.day-cell.empty{opacity:.25;box-shadow:none;background:transparent}
.mini{border:0;border-radius:999px;padding:8px 11px;background:#e9fffb;color:#0b7f76;font-weight:800}
.care-actions.quick button{min-height:68px}
.card.pink{background:linear-gradient(180deg,#fff1f4,#fff)}
.card.yellow{background:linear-gradient(180deg,#fff8dc,#fff)}
.card.green{background:linear-gradient(180deg,#ecfff8,#fff)}
@media(max-width:380px){.calendar-grid{gap:5px}.day-cell{min-height:52px;border-radius:15px}.day-cell small{font-size:9px}}


/* Simplified parent-first flow */
.simplified-hero{padding-bottom:18px}
.quick-record-card{border:1px solid rgba(18,175,162,.16)}
.record-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px}
.record-grid button{border:0;border-radius:22px;background:rgba(255,255,255,.76);box-shadow:0 10px 28px rgba(31,79,82,.08);padding:14px 10px;text-align:left;color:var(--text,#173b3f);min-height:86px}
.record-grid button span{font-size:24px;display:block;margin-bottom:4px}
.record-grid button b{display:block;font-size:14px}
.record-grid button small{display:block;opacity:.68;margin-top:3px;line-height:1.2}
.today-record-summary .mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}
.today-record-summary .mini-stats div{background:rgba(255,255,255,.7);border-radius:18px;text-align:center;padding:10px 5px}
.today-record-summary .mini-stats span{display:block;font-size:20px}
.today-record-summary .mini-stats b{display:block;font-size:20px}
.today-record-summary .mini-stats small{font-size:10px;opacity:.7}
.simplified-nav button{font-size:11px}
@media(max-width:390px){.record-grid button{min-height:78px;padding:12px 9px}.today-record-summary .mini-stats{gap:5px}.today-record-summary .mini-stats div{padding:8px 3px}}


/* Refinement pass: faster logging + calmer hierarchy */
.calm-home{box-shadow:0 18px 45px rgba(18,175,162,.10)}
.calm-focus-card{box-shadow:0 12px 34px rgba(31,79,82,.07);border:1px solid rgba(18,175,162,.12)}
.fast-record-grid button{min-height:78px}
.choice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:14px 0}
.choice-grid button{border:0;border-radius:22px;background:rgba(255,255,255,.82);box-shadow:0 10px 24px rgba(31,79,82,.08);padding:16px 10px;text-align:center;color:var(--text,#173b3f);min-height:88px}
.choice-grid button:first-letter{font-size:22px}
.choice-grid button b{display:block;margin-top:6px;font-size:14px}
.calm-sheet-head h2{margin-bottom:4px}
.calm-sheet-head p{margin-top:0}
.buddy-soft-note{background:linear-gradient(180deg,#fff,#f5fffd)}
.quick-record-card .row{align-items:flex-start}
.quick-record-card{margin-top:2px}
.today-record-summary{background:linear-gradient(180deg,#ffffff,#f7fffd)}
#toast{z-index:9999}
@media(max-width:390px){.choice-grid button{min-height:78px;border-radius:18px}.fast-record-grid button{min-height:72px}.record-grid button small{font-size:10px}}

/* Offline mode */
.offline-banner{
position:fixed;
top:10px;
left:50%;
transform:translateX(-50%);
background:#173b3f;
color:#fff;
padding:10px 16px;
border-radius:999px;
font-size:12px;
z-index:99999;
box-shadow:0 10px 24px rgba(0,0,0,.15)
}

/* v1. Offline emotion selector polish: use logo images instead of emoji-style action icons */
.logo-icon{width:42px;height:42px;object-fit:contain;display:inline-block;filter:drop-shadow(0 8px 12px rgba(18,175,162,.14))}.logo-icon.soft{width:48px;height:48px;border-radius:16px;background:#fff7;padding:4px}.action-logo{width:44px;height:44px;object-fit:contain;display:block;margin:0 auto 7px;filter:drop-shadow(0 7px 11px rgba(18,175,162,.18))}.nav-logo-icon{width:22px;height:22px;object-fit:contain;display:inline-block;margin-bottom:1px;filter:drop-shadow(0 4px 8px rgba(18,175,162,.15))}.logo-nav .active .nav-logo-icon{transform:translateY(-2px) scale(1.08)}.mood-pick-logo{width:50px;height:50px;object-fit:contain;display:block;margin:0 auto 6px;filter:drop-shadow(0 8px 13px rgba(18,175,162,.16))}.mood-choice-grid button small{display:block;color:#6a7781;font-size:11px;margin-top:2px}.selected-mood-logo{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#fff8e8,#e5fbf6);border:1px solid #eedfc8;border-radius:22px;padding:12px;margin:12px 0}.selected-logo{width:62px;height:62px;object-fit:contain;filter:drop-shadow(0 10px 16px rgba(18,175,162,.18))}.selected-mood-logo b{font-size:22px;color:var(--teal2)}.stat-logo{width:28px;height:28px;object-fit:contain;display:block;margin:0 auto 3px}.logo-mini-stats span{display:none}.logo-record-grid button span{display:none!important}

/* v1.1 category picture icons: each button now uses a matching visual icon instead of repeated logo/emoji */
.cat-logo,.tile-logo{object-fit:contain;display:block;filter:drop-shadow(0 8px 13px rgba(18,175,162,.16))}
.tile-logo{width:48px;height:48px;margin:0 auto 8px}.tile-logo.big{width:68px;height:68px}.choice-grid button .mood-pick-logo{margin-bottom:8px}.mood-choice-grid button{min-height:116px}.record-grid button{min-height:104px}.selected-logo{transition:transform .18s ease}.selected-mood-logo:hover .selected-logo{transform:scale(1.04)}
.quick .emoji,.tile .emoji{display:none!important}
