:root{--bg: #0f0e17;--panel: #1b1a2b;--panel-2: #25243a;--accent: #8b5cf6;--accent-2: #6d28d9;--text: #e8e6f0;--muted: #9b98b3;--good: #34d399;--gem: #38bdf8;--danger: #f87171}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-tap-highlight-color:transparent}.app{max-width:560px;margin:0 auto;padding:env(safe-area-inset-top) 16px calc(env(safe-area-inset-bottom) + 24px)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 4px 8px;position:sticky;top:0;background:var(--bg);z-index:5}.topbar h1{font-size:20px;margin:0}.topbar .who{color:var(--muted);font-size:13px}.gembar{display:flex;gap:12px;margin:8px 0 16px}.gemcard{flex:1;background:linear-gradient(160deg,var(--panel-2),var(--panel));border:1px solid #322f4d;border-radius:16px;padding:14px 16px}.gemcard .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.gemcard .value{font-size:28px;font-weight:700;margin-top:2px}.gemcard .value .em{font-size:20px}.category{margin-bottom:20px}.category h2{font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 8px 4px}.habit{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:var(--panel);border:1px solid #2a2840;color:var(--text);border-radius:14px;padding:14px 16px;margin-bottom:8px;font-size:16px;cursor:pointer;transition:background .12s,transform .08s}.habit:active{transform:scale(.99)}.habit.done{background:#16261f;border-color:#1f4d3a}.habit.done .text{color:var(--muted);text-decoration:line-through}.habit .check{width:24px;height:24px;border-radius:50%;border:2px solid #4b4870;display:grid;place-items:center;flex:0 0 auto;font-size:14px}.habit.done .check{background:var(--good);border-color:var(--good);color:#06241a}.habit .text{flex:1}.habit .gems{color:var(--gem);font-weight:600;font-size:14px;white-space:nowrap}.readonly-note{color:var(--muted);font-size:13px;margin:4px 0 14px}.tabs{display:flex;gap:6px;margin:4px 0 16px}.tabs button{flex:1;background:var(--panel);border:1px solid #2a2840;color:var(--muted);border-radius:12px;padding:10px;font-size:14px;cursor:pointer}.tabs button.active{background:var(--accent-2);border-color:var(--accent);color:#fff}.btn{background:var(--accent-2);border:none;color:#fff;border-radius:12px;padding:12px 16px;font-size:15px;cursor:pointer}.btn.secondary{background:var(--panel-2);border:1px solid #322f4d}.btn.danger{background:transparent;color:var(--danger);border:1px solid #4a2a2a}.btn.small{padding:6px 10px;font-size:13px}.btn:disabled{opacity:.5;cursor:default}.row{display:flex;gap:8px;align-items:center}input,select{background:var(--panel);border:1px solid #322f4d;color:var(--text);border-radius:10px;padding:10px 12px;font-size:15px;width:100%}input.gems{width:84px;text-align:center}.pin{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.pin .title{font-size:22px;font-weight:600}.pin .dots{display:flex;gap:14px}.pin .dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--accent)}.pin .dot.filled{background:var(--accent)}.pin .error{color:var(--danger);min-height:18px;font-size:14px}.keypad{display:grid;grid-template-columns:repeat(3,78px);gap:16px}.key{height:78px;border-radius:50%;background:var(--panel);border:1px solid #2a2840;color:var(--text);font-size:28px;cursor:pointer}.key:active{background:var(--panel-2)}.key.blank{background:transparent;border:none;cursor:default}.history-day{display:flex;justify-content:space-between;background:var(--panel);border:1px solid #2a2840;border-radius:12px;padding:12px 16px;margin-bottom:8px}.history-day .date{font-weight:600}.history-day .meta{color:var(--muted);font-size:14px}.setup-cat{background:var(--panel);border:1px solid #2a2840;border-radius:14px;padding:14px;margin-bottom:14px}.setup-cat .cat-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px}.setup-habit{display:flex;gap:8px;align-items:center;margin-bottom:8px}.setup-habit .text{flex:1}.empty{color:var(--muted);text-align:center;padding:40px 0}.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%);background:var(--panel-2);border:1px solid #322f4d;padding:10px 16px;border-radius:12px;font-size:14px}.install-banner{background:var(--panel-2);border:1px solid #322f4d;border-radius:12px;padding:12px 14px;margin-bottom:14px;font-size:14px;display:flex;justify-content:space-between;align-items:center;gap:10px}
