*{box-sizing:border-box;margin:0;padding:0}:root{--blue:#7bdff2;--mint:#b2f7ef;--white:#eff7f6;--blush:#f7d6e0;--pink:#f2b5d4;--text:#2d2d3a;--muted:#8a8a9a;--blue-dark:#3ab8d4;--pink-dark:#d47aaa}body{background:var(--white);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px}.layout{background:#fff;flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex}.app-header{border-bottom:2px solid var(--blush);z-index:10;background:#fff;justify-content:space-between;align-items:center;padding:14px 16px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:8px;display:flex}.app-logo{color:var(--text);letter-spacing:-.5px;font-size:17px;font-weight:900}.app-logo span{color:var(--blue-dark)}.header-sub{color:var(--muted);font-size:12px}.signout-btn{color:var(--muted);border:1px solid var(--blush);cursor:pointer;background:0 0;border-radius:8px;padding:4px 10px;font-size:12px}.signout-btn:hover{color:var(--blue-dark);border-color:var(--blue)}.main-content{flex:1;padding:0 0 84px}.bottom-nav{border-top:2px solid var(--blush);z-index:10;width:100%;max-width:480px;padding-bottom:env(safe-area-inset-bottom);background:#fff;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-btn{cursor:pointer;color:#c9c9d8;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;padding:10px 4px 8px;font-size:11px;font-weight:700;transition:color .15s;display:flex}.nav-btn.active,.nav-btn:hover{color:var(--blue-dark)}.nav-icon{margin-bottom:2px;font-size:22px}.emoji-watermark{pointer-events:none;z-index:0;max-width:480px;margin:0 auto;position:fixed;inset:0;overflow:hidden}.emoji-watermark span{opacity:.18;-webkit-user-select:none;user-select:none;font-size:52px;line-height:1;position:absolute}.page{z-index:1;flex-direction:column;gap:14px;padding:16px;display:flex;position:relative}.card{border:2px solid var(--blush);background:#fff;border-radius:18px;padding:16px}.section-title{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;font-size:11px;font-weight:800}.hero-card{background:linear-gradient(135deg, var(--mint) 0%, var(--blush) 100%);border:2px solid var(--blue);border-radius:20px;padding:22px;position:relative;overflow:hidden}.hero-card:before{content:"";background:#f2b5d459;border-radius:50%;width:110px;height:110px;position:absolute;top:-24px;right:-24px}.hero-card:after{content:"";background:#7bdff240;border-radius:50%;width:85px;height:85px;position:absolute;bottom:-30px;left:30px}.hero-label{color:var(--blue-dark);text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:800}.hero-coins{color:var(--text);margin:6px 0 4px;font-size:48px;font-weight:900;line-height:1}.hero-sub{color:var(--pink-dark);font-size:13px;font-weight:600}.hero-progress{background:#ffffff8c;border-radius:99px;height:8px;margin-top:16px}.hero-progress-fill{background:linear-gradient(90deg, var(--blue-dark), var(--pink-dark));border-radius:99px;height:8px;transition:width .5s}.metric-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.metric{border:2px solid var(--blush);background:#fff;border-radius:14px;padding:14px}.metric-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:11px;font-weight:700}.metric-value{color:var(--text);font-size:26px;font-weight:900}.coin{color:var(--pink-dark)}.badge{border-radius:8px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-block}.badge-green{color:#065f46;background:#d1fae5}.badge-amber{color:#92400e;background:#fef3c7}.badge-blue{color:#1e40af;background:#dbeafe}.badge-red{color:#991b1b;background:#fee2e2}.badge-purple{background:var(--blush);color:var(--pink-dark)}.badge-orange{background:var(--mint);color:var(--blue-dark)}.activity-preview{align-items:center;gap:12px;display:flex}.activity-emoji{font-size:34px}.activity-name{color:var(--text);font-size:14px;font-weight:700}.activity-meta{color:var(--muted);margin-top:2px;font-size:12px}.leaderboard-row{border-bottom:1px solid var(--blush);align-items:center;gap:10px;padding:10px 0;display:flex}.leaderboard-row:last-child{border-bottom:none}.highlighted-row{background:var(--white);border-left:4px solid var(--blue-dark);border-radius:10px;margin:0 -16px;padding:10px 16px}.rank{color:#c9c9d8;flex-shrink:0;width:28px;font-size:14px;font-weight:900}.rank-1{color:#fbbf24}.rank-2{color:#94a3b8}.rank-3{color:#f97316}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:12px;font-weight:800;display:flex}.av-purple{background:var(--blush);color:var(--pink-dark)}.av-teal{background:var(--mint);color:var(--blue-dark)}.av-coral{color:#991b1b;background:#fee2e2}.av-blue{color:#1e40af;background:#dbeafe}.av-pink{background:var(--pink);color:#9d174d}.emp-info{flex:1}.emp-name{color:var(--text);font-size:14px;font-weight:700}.emp-role{color:var(--muted);font-size:12px}.coin-count{color:var(--pink-dark);font-size:15px;font-weight:800}.history-row{border-bottom:1px solid var(--blush);color:var(--text);justify-content:space-between;align-items:center;padding:9px 0;font-size:13px;display:flex}.history-row:last-child{border-bottom:none}.coin-breakdown{background:var(--white);border:1px solid var(--blush);border-radius:12px;padding:12px}.coin-rule{color:var(--text);justify-content:space-between;padding:4px 0;font-size:13px;display:flex}.activity-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.q-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.q-number{color:var(--muted);font-size:13px;font-weight:700}.progress-wrap{background:var(--blush);border-radius:99px;height:8px;margin:10px 0}.progress-bar{background:linear-gradient(90deg, var(--blue-dark), var(--pink-dark));border-radius:99px;height:8px;transition:width .3s}.streak-bar{gap:4px;margin:8px 0;display:flex}.streak-dot{background:var(--blush);border:2px solid var(--pink);border-radius:50%;width:20px;height:20px}.dot-correct{background:#4ade80;border-color:#16a34a}.dot-wrong{background:#f87171;border-color:#dc2626}.dot-current{background:var(--blue);border-color:var(--blue-dark)}.emoji-display{text-align:center;letter-spacing:8px;background:var(--white);border:2px solid var(--blush);border-radius:14px;margin:10px 0;padding:20px 0;font-size:38px}.q-text{color:var(--text);margin-bottom:4px;font-size:16px;font-weight:700}.options{grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;display:grid}.option-btn{border:2px solid var(--blush);cursor:pointer;text-align:left;color:var(--text);background:#fff;border-radius:14px;padding:14px 10px;font-size:13px;font-weight:600;line-height:1.4;transition:border-color .15s,background .15s}.option-btn:hover:not(.disabled){border-color:var(--blue-dark);background:var(--white)}.option-btn.correct{color:#065f46;background:#d1fae5;border-color:#16a34a}.option-btn.wrong{color:#991b1b;background:#fee2e2;border-color:#dc2626}.option-btn.disabled{cursor:not-allowed;opacity:.45}.feedback-box{border-radius:12px;margin-top:12px;padding:12px 14px;font-size:14px;font-weight:700}.fb-correct{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7}.fb-wrong{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.nav-btns{gap:8px;margin-top:16px;display:flex}.btn-primary{background:linear-gradient(135deg, var(--blue-dark), var(--pink-dark));color:#fff;cursor:pointer;border:none;border-radius:14px;padding:13px 22px;font-size:14px;font-weight:800;transition:opacity .15s;box-shadow:0 4px 16px #7bdff259}.btn-primary:hover{opacity:.9}.btn-primary:disabled{color:#9ca3af;box-shadow:none;cursor:not-allowed;background:#e5e7eb}.btn-secondary{border:2px solid var(--blush);cursor:pointer;color:var(--muted);background:#fff;border-radius:14px;padding:13px 18px;font-size:14px;font-weight:700}.btn-secondary:hover{border-color:var(--blue-dark);color:var(--blue-dark)}.result-score{color:var(--blue-dark);margin:8px 0;font-size:56px;font-weight:900}.coins-earned{color:var(--pink-dark);margin:10px 0 4px;font-size:28px;font-weight:900}.review-row{border-bottom:1px solid var(--blush);align-items:flex-start;gap:10px;padding:10px 0;display:flex}.review-row:last-child{border-bottom:none}.review-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:11px;font-weight:800;display:flex}.ri-correct{color:#065f46;background:#d1fae5}.ri-wrong{color:#991b1b;background:#fee2e2}.wallet-total{color:var(--blue-dark);margin:8px 0 4px;font-size:48px;font-weight:900}.redeem-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px;display:grid}.redeem-card{border:2px solid var(--blush);text-align:center;background:var(--white);border-radius:14px;padding:12px}.redeem-card.redeem-unlocked{border-color:var(--blue-dark);background:var(--mint);box-shadow:0 4px 14px #7bdff24d}.redeem-coins{color:var(--pink-dark);font-size:18px;font-weight:900}.redeem-label{color:var(--muted);margin-top:4px;font-size:11px}.login-wrap{background:var(--white);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-card{border:2px solid var(--blush);background:#fff;border-radius:24px;width:100%;max-width:380px;padding:36px 28px;box-shadow:0 8px 40px #f2b5d440}.login-logo{text-align:center;margin-bottom:8px;font-size:52px}.login-card h1{text-align:center;color:var(--text);letter-spacing:-.5px;margin-bottom:4px;font-size:28px;font-weight:900}.login-sub{color:var(--muted);text-align:center;margin-bottom:28px;font-size:13px}.login-card form{flex-direction:column;gap:14px;display:flex}.login-card label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:800}.login-card input{border:2px solid var(--blush);background:var(--white);width:100%;color:var(--text);border-radius:12px;margin-top:4px;padding:12px 14px;font-size:14px}.login-card input:focus{border-color:var(--blue-dark);outline:none}.login-card button{background:linear-gradient(135deg, var(--blue-dark), var(--pink-dark));color:#fff;cursor:pointer;border:none;border-radius:14px;margin-top:4px;padding:14px;font-size:16px;font-weight:900;box-shadow:0 4px 20px #7bdff259}.login-card button:hover{opacity:.9}label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:12px;font-weight:800;display:block}input,select{border:2px solid var(--blush);background:var(--white);width:100%;color:var(--text);border-radius:10px;padding:10px 12px;font-size:14px}input:focus,select:focus{border-color:var(--blue-dark);outline:none}.celebration-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#7bdff240;justify-content:center;align-items:center;padding:20px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.celebration-modal{text-align:center;border:3px solid var(--pink);background:#fff;border-radius:28px;width:100%;max-width:380px;padding:36px 28px;animation:.4s cubic-bezier(.34,1.56,.64,1) popUp;position:relative;box-shadow:0 20px 60px #f2b5d466}.celebration-trophy{margin-bottom:8px;font-size:72px}.celebration-title{color:var(--text);margin-bottom:6px;font-size:26px;font-weight:900}.celebration-subtitle{color:var(--muted);margin-bottom:20px;font-size:14px}.celebration-coins{color:var(--blue-dark);font-size:52px;font-weight:900;line-height:1}.celebration-coins-label{color:var(--muted);margin-top:4px;margin-bottom:20px;font-size:14px}.celebration-score-pill{background:var(--blush);border:2px solid var(--pink);color:var(--pink-dark);border-radius:99px;margin-bottom:24px;padding:6px 18px;font-size:13px;font-weight:800;display:inline-block}.celebration-confetti{justify-content:center;gap:6px;margin-bottom:20px;font-size:22px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popUp{0%{opacity:0;transform:scale(.7)translateY(40px)}to{opacity:1;transform:scale(1)translateY(0)}}.bday-card{text-align:center;background:linear-gradient(135deg,#f7d6e0,#f2b5d4);border:2px solid #e89ec8;border-radius:14px;padding:18px 16px;position:relative;overflow:hidden}.bday-confetti{opacity:.85;border-radius:2px;animation:linear infinite bdayFall;position:absolute}@keyframes bdayFall{0%{opacity:1;transform:translateY(-10px)rotate(0)}to{opacity:0;transform:translateY(200px)rotate(360deg)}}.bday-cake{font-size:38px;animation:1.2s ease-in-out infinite bdayBounce;display:block}@keyframes bdayBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.bday-title{color:#7a1a5e;margin:8px 0 4px;font-size:18px;font-weight:700;animation:2s ease-in-out infinite bdayPulse}@keyframes bdayPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.bday-name{color:#a0337a;margin-bottom:6px;font-size:16px;font-weight:700}.bday-msg{color:#9c3070;background:#fff6;border-radius:8px;margin-top:6px;padding:8px 10px;font-size:13px;line-height:1.5;transition:opacity .35s}.bday-balloons{justify-content:center;gap:6px;margin-top:10px;display:flex}.bday-balloon{font-size:22px;animation:2s ease-in-out infinite bdaySway;display:inline-block}@keyframes bdaySway{0%,to{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}.loading{height:100vh;color:var(--muted);background:var(--white);justify-content:center;align-items:center;font-size:16px;display:flex}.empty-state{color:var(--muted);padding:12px 0;font-size:13px}.error-msg{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5;border-radius:10px;padding:10px 14px;font-size:13px}.success-msg{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7;border-radius:10px;margin-bottom:8px;padding:10px 14px;font-size:13px}
