:root{--bg: #0f1115;--surface: #1a1d24;--surface-2: #242833;--text: #eef0f4;--muted: #8b919e;--green: #2ecc71;--orange: #ff9f43;--red: #e74c3c;--gray: #3a3f4b;--accent: #ff9f43}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}#root{min-height:100dvh}.app{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;position:sticky;top:0;background:#0f1115eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.header-title{font-weight:700;font-size:16px;letter-spacing:.3px}.streak{font-size:20px;font-weight:800;color:var(--orange)}.content{flex:1;padding:8px 16px 96px}.card{background:var(--surface);border-radius:16px;padding:16px;margin:12px 0}.center{text-align:center}.muted{color:var(--muted)}.error-banner{background:#3d1f1f;color:#ff8a80;border-radius:12px;padding:10px 14px;margin:8px 0}.error-text{color:#ff8a80}.pin-gate{min-height:100dvh;display:flex;align-items:center;justify-content:center}.pin-box{text-align:center;padding:24px;width:100%;max-width:320px}.pin-emoji{font-size:56px}.pin-box input{width:100%;font-size:28px;text-align:center;letter-spacing:8px;padding:14px;border-radius:14px;border:1px solid var(--gray);background:var(--surface);color:var(--text);margin-bottom:16px}button{font-family:inherit;cursor:pointer;border:none}.btn-primary,.btn-done{width:100%;background:var(--green);color:#06270f;font-size:22px;font-weight:800;padding:20px;border-radius:18px}.btn-done:active{transform:scale(.98)}.btn-minimum{width:100%;background:var(--surface-2);color:var(--orange);border:1px solid var(--orange);font-size:15px;font-weight:600;padding:12px;border-radius:14px;margin-top:12px}.btn-secondary{background:var(--surface-2);color:var(--text);font-size:16px;font-weight:600;padding:12px 18px;border-radius:12px}.btn-link{background:none;color:var(--muted);text-decoration:underline;font-size:14px;padding:10px}button:disabled{opacity:.5}.day-header{text-align:center;margin-top:8px}.day-number{font-size:40px;margin:0}.day-total{color:var(--muted);font-size:24px}.day-date{color:var(--muted);margin:4px 0 8px;text-transform:capitalize}.badge{display:inline-block;padding:6px 14px;border-radius:999px;font-weight:700;font-size:14px}.badge-light{background:#1d3324;color:#7bed9f}.badge-finale{background:#33291d;color:gold}.reminder-banner{background:#2d2436;color:#d6a8ff;border-radius:12px;padding:12px 14px;margin:12px 0;text-align:center;font-weight:600}.weight-card label{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.weight-row{display:flex;gap:10px;margin-top:8px}.weight-row input{flex:1;min-width:0;font-size:24px;font-weight:700;padding:10px 14px;border-radius:12px;border:1px solid var(--gray);background:var(--surface-2);color:var(--text)}.doses{display:flex;justify-content:center;gap:12px;margin:20px 0}.dose{flex:1;background:var(--surface);border-radius:16px;padding:18px 8px;text-align:center;display:flex;flex-direction:column}.dose-number{font-size:48px;font-weight:800;line-height:1.1}.dose-label{color:var(--muted);font-size:14px;margin-top:4px}.actions{margin-top:8px;text-align:center}.done-state{font-size:24px;font-weight:800;padding:20px;border-radius:18px}.done-full{background:#14351f;color:var(--green)}.done-minimum{background:#33291d;color:var(--orange)}.calendar h2,.weight-view h2{margin:8px 0 12px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.cal-cell{aspect-ratio:1;border-radius:12px;font-size:16px;font-weight:700;color:var(--text);background:var(--surface)}.cal-full{background:var(--green);color:#06270f}.cal-minimum{background:var(--orange);color:#2d1a00}.cal-missed{background:var(--red);color:#2d0600}.cal-future{background:var(--gray);color:var(--muted)}.cal-today{background:var(--surface-2)}.cal-today-ring{outline:3px solid var(--accent);outline-offset:1px}.legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px;color:var(--muted);font-size:13px}.legend span{display:flex;align-items:center;gap:6px}.dot{width:10px;height:10px;border-radius:50%;display:inline-block}.dot-full{background:var(--green)}.dot-minimum{background:var(--orange)}.dot-missed{background:var(--red)}.dot-future{background:var(--gray)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:50;display:flex;align-items:flex-end}.sheet{background:var(--surface);border-radius:20px 20px 0 0;padding:20px 20px calc(20px + env(safe-area-inset-bottom));width:100%;max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.sheet h3{margin:0}.weight-chart{width:100%;height:auto;background:var(--surface);border-radius:16px;padding:8px}.chart-text{fill:var(--muted);font-size:11px}.weight-add{display:flex;gap:8px}.weight-add input{flex:1;min-width:0;padding:10px;border-radius:10px;border:1px solid var(--gray);background:var(--surface-2);color:var(--text);font-size:15px;color-scheme:dark}.weight-table{width:100%;border-collapse:collapse;margin-top:8px}.weight-table td{padding:10px 8px;border-bottom:1px solid var(--surface-2);font-size:16px}.weight-kg{font-weight:700;text-align:right}.weight-table td:last-child{text-align:right}.graduation{text-align:center}.grad-emoji{font-size:64px;margin-top:16px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:20px 0}.stat-card{background:var(--surface);border-radius:16px;padding:16px 8px;display:flex;flex-direction:column}.stat-number{font-size:28px;font-weight:800}.stat-label{color:var(--muted);font-size:13px;margin-top:4px}.reminders{margin-top:24px;text-align:center}.reminders-msg{font-size:13px;margin-top:8px}.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;display:flex;background:#1a1d24f7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--surface-2);padding-bottom:env(safe-area-inset-bottom);z-index:20}.tab{flex:1;background:none;color:var(--muted);padding:10px 0 12px;display:flex;flex-direction:column;align-items:center;gap:2px}.tab.active{color:var(--accent)}.tab-icon{font-size:22px}.tab-label{font-size:11px;font-weight:600}
