*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #0073ea;--color-primary-light: #1f76c2;--color-primary-dark: #0060c0;--color-primary-bg: #e6f2ff;--color-accent: #00c875;--color-warning: #f59e0b;--color-danger: #ef4444;--color-success: #00c875;--color-bg: #f6f7fb;--color-surface: #ffffff;--color-surface-2: #f1f4f9;--color-border: #e2e8f0;--color-border-light:#edf0f5;--color-text: #0f172a;--color-text-2: #475569;--color-text-3: #94a3b8;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.05);--shadow-card: 0 2px 8px rgba(0,115,234,.08);--font: "Figtree", system-ui, -apple-system, sans-serif;--bottom-nav-h: 68px}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--color-bg);color:var(--color-text);line-height:1.5;min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh;display:flex;flex-direction:column}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}h1{font-size:1.75rem;font-weight:700;line-height:1.2}h2{font-size:1.375rem;font-weight:700;line-height:1.25}h3{font-size:1.125rem;font-weight:600;line-height:1.3}h4{font-size:1rem;font-weight:600}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--radius-lg);font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all .15s ease;text-decoration:none;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-primary-bg);color:var(--color-primary)}.btn-secondary:hover{background:#d1fae5}.btn-ghost{background:transparent;color:var(--color-text-2)}.btn-ghost:hover{background:var(--color-surface-2)}.btn-danger{background:#fef2f2;color:var(--color-danger)}.btn-danger:hover{background:#fee2e2}.btn-sm{padding:7px 14px;font-size:.8125rem;border-radius:var(--radius-md)}.btn-lg{padding:14px 24px;font-size:1rem}.btn-icon{padding:8px;border-radius:var(--radius-md)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.card{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-card);border:1px solid var(--color-border-light);padding:20px}.card-sm{padding:14px;border-radius:var(--radius-xl)}.card-compact{padding:16px;border-radius:var(--radius-xl)}.input{width:100%;padding:11px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font);font-size:.9375rem;color:var(--color-text);background:var(--color-surface);transition:border-color .15s;outline:none}.input:focus{border-color:var(--color-primary)}.input::placeholder{color:var(--color-text-3)}select.input{cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:38px}.label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text-2);margin-bottom:6px}.form-group{display:flex;flex-direction:column;gap:6px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.75rem;font-weight:600}.badge-green{background:#d1fae5;color:#065f46}.badge-blue{background:#dbeafe;color:#1e40af}.badge-amber{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-purple{background:#ede9fe;color:#5b21b6}.badge-gray{background:#f1f5f9;color:#475569}.page{flex:1;padding:16px 16px calc(var(--bottom-nav-h) + 20px);max-width:480px;margin:0 auto;width:100%}.page-wide{max-width:600px}.section-title{font-size:.8125rem;font-weight:700;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-h);background:var(--color-surface);border-top:1px solid var(--color-border-light);display:flex;align-items:center;padding:0 4px;padding-bottom:env(safe-area-inset-bottom);z-index:100;box-shadow:0 -4px 16px #0000000f}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border-radius:var(--radius-lg);cursor:pointer;border:none;background:transparent;font-family:var(--font);color:var(--color-text-3);font-size:.6875rem;font-weight:500;transition:all .15s;min-height:52px}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item.active .nav-icon-wrap{background:var(--color-primary-bg)}.nav-icon-wrap{width:34px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:99px;transition:background .15s}.app-header{position:sticky;top:0;z-index:50;background:#f0fdf4eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-light);padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:0;animation:fadeIn .15s ease}.modal-overlay.center{align-items:center;padding:20px}.modal-sheet{background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-height:92dvh;overflow-y:auto;padding:20px;animation:slideUp .2s ease}.modal-center{background:var(--color-surface);border-radius:var(--radius-2xl);width:100%;max-width:440px;max-height:90dvh;overflow-y:auto;padding:24px;animation:scaleIn .15s ease}.modal-handle{width:36px;height:4px;background:var(--color-border);border-radius:99px;margin:0 auto 16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.ring-svg{transform:rotate(-90deg)}.ring-track{fill:none;stroke:var(--color-border)}.ring-fill{fill:none;stroke:var(--color-primary);stroke-linecap:round;transition:stroke-dashoffset .5s ease}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-muted{color:var(--color-text-2)}.text-faint{color:var(--color-text-3)}.text-primary{color:var(--color-primary)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-success{color:var(--color-success)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.divider{height:1px;background:var(--color-border-light);margin:12px 0}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-full{min-height:100dvh;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;background:var(--color-bg)}.stat-box{display:flex;flex-direction:column;gap:4px;padding:14px;border-radius:var(--radius-xl);background:var(--color-surface);border:1px solid var(--color-border-light)}.stat-label{font-size:.6875rem;font-weight:600;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.04em;min-height:2em}.stat-value{font-size:1.375rem;font-weight:700;line-height:1.1}.stat-unit{font-size:.75rem;color:var(--color-text-3);font-weight:500}.tab-bar{display:flex;gap:4px;padding:4px;background:var(--color-surface-2);border-radius:var(--radius-xl);border:1px solid var(--color-border-light)}.tab-item{flex:1;padding:8px 12px;border:none;cursor:pointer;border-radius:var(--radius-lg);font-family:var(--font);font-size:.8125rem;font-weight:600;color:var(--color-text-3);background:transparent;transition:all .15s;white-space:nowrap}.tab-item.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm)}.empty-state{text-align:center;padding:40px 24px;color:var(--color-text-3)}.empty-state-icon{width:56px;height:56px;border-radius:50%;background:var(--color-primary-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--color-primary)}.exercise-card{display:flex;align-items:center;gap:14px;padding:14px;border-radius:var(--radius-xl);background:var(--color-surface);border:1.5px solid var(--color-border-light);cursor:pointer;transition:border-color .15s,box-shadow .15s}.exercise-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md)}.exercise-icon{width:44px;height:44px;border-radius:var(--radius-lg);background:var(--color-primary-bg);color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.habit-row{display:flex;align-items:center;gap:12px;padding:14px;border-radius:var(--radius-xl);background:var(--color-surface);border:1.5px solid var(--color-border-light);margin-bottom:8px;transition:border-color .15s}.habit-row.done{border-color:var(--color-primary-light);background:var(--color-primary-bg)}.habit-check{width:26px;height:26px;border-radius:50%;border:2.5px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;background:transparent}.habit-check.done{border-color:var(--color-primary);background:var(--color-primary)}.measure-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.measure-item{padding:12px;border-radius:var(--radius-lg);background:var(--color-surface-2);border:1px solid var(--color-border-light)}.timer-display{font-size:3rem;font-weight:800;letter-spacing:-.02em;color:var(--color-text);text-align:center;font-variant-numeric:tabular-nums}.fasting-ring-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-md);cursor:pointer;position:relative;font-size:.875rem;font-weight:500;transition:background .12s}.cal-day:hover{background:var(--color-primary-bg)}.cal-day.today{background:var(--color-primary);color:#fff;font-weight:700}.cal-day.other-month{color:var(--color-text-3)}.cal-dots{display:flex;gap:2px;position:absolute;bottom:3px}.cal-dot{width:4px;height:4px;border-radius:50%}.set-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius-lg);background:var(--color-surface-2);border:1.5px solid var(--color-border-light);margin-bottom:6px}.set-num{width:24px;height:24px;border-radius:50%;background:var(--color-primary-bg);color:var(--color-primary);font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.set-input{width:72px;padding:6px 10px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);font-family:var(--font);font-size:.9375rem;text-align:center;background:var(--color-surface);outline:none}.set-input:focus{border-color:var(--color-primary)}
