*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#242836;--border:#2e3345;--text:#e4e6ed;--text2:#8b8fa3;--accent:#6c8cff;--accent2:#4a6cf7;--green:#4caf7d;--orange:#e8a449;--red:#e05555;--radius:14px;--safe-bottom:env(safe-area-inset-bottom,0px)}:root[data-theme=light]{--bg:#f5f5f7;--surface:#fff;--surface2:#e8e8ed;--border:#d1d1d6;--text:#1c1c1e;--text2:#6e6e73;--accent:#4a6cf7;--accent2:#3a5ce5;--green:#34a065;--orange:#c98a2e;--red:#d63e3e}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}.app{flex-direction:column;min-height:100dvh;margin:0 auto;display:flex}.app-header{z-index:10;background:var(--bg);align-items:center;gap:12px;padding:20px 20px 12px;display:flex;position:sticky;top:0}.app-header h1{letter-spacing:-.5px;flex:1;font-size:28px;font-weight:800}.theme-toggle{color:var(--text2);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.header-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.hamburger-btn{color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.menu-overlay{z-index:50;background:#00000080;animation:.2s ease-out fadeIn;position:fixed;inset:0}.menu-drawer{background:var(--surface);flex-direction:column;width:280px;max-width:80vw;animation:.25s ease-out slideInLeft;display:flex;position:absolute;top:0;bottom:0;left:0;overflow-y:auto}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.menu-header{justify-content:space-between;align-items:center;padding:20px 16px 16px;display:flex}.menu-header h2{font-size:20px;font-weight:800}.menu-items{flex-direction:column;padding:4px 8px;display:flex}.menu-item{color:var(--text);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:12px;font-size:15px;font-weight:500;transition:background .15s;display:flex}.menu-item:active{background:var(--surface2)}.menu-item.active{background:var(--surface2);color:var(--accent)}.menu-item svg{flex-shrink:0}.menu-item-danger{color:var(--red)}.menu-divider{background:var(--border);height:1px;margin:4px 16px}.menu-spacer{flex:1}.app-main{padding:8px 16px 16px;padding-bottom:calc(88px + var(--safe-bottom));flex:1;overflow-y:auto}.tab-bar{background:var(--surface);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);display:flex;position:fixed;bottom:0;left:0;right:0}.tab-bar button{min-height:52px;color:var(--text2);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px 0 10px;font-size:11px;font-weight:500;transition:color .2s;display:flex}.tab-bar button.active{color:var(--accent)}.tab-bar button svg{width:22px;height:22px}.view-toggle{background:var(--surface);border-radius:8px;gap:2px;padding:2px;display:flex}.view-toggle-btn{width:32px;height:28px;color:var(--text2);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.view-toggle-btn.active{background:var(--surface2);color:var(--text);box-shadow:0 1px 4px #00000040}.filter-row-with-toggle{align-items:center;gap:8px;margin-bottom:12px;display:flex}.filter-row-with-toggle .filter-bar{flex:1;margin-bottom:0}.detail-list .card{max-width:600px}.detail-field{gap:8px;padding:4px 0;display:flex}.detail-field+.detail-field{border-top:1px solid var(--border)}.detail-label{color:var(--text2);flex-shrink:0;min-width:72px;padding-top:1px;font-size:12px}.detail-value{color:var(--text);font-size:13px}.list-view .list-row{background:var(--surface);border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:10px;padding:8px 12px;transition:background .15s;display:flex}.list-view .list-row:first-child{border-radius:var(--radius) var(--radius) 0 0}.list-view .list-row:last-child{border-radius:0 0 var(--radius) var(--radius);border-bottom:none}.list-view .list-row:only-child{border-radius:var(--radius)}.list-view .list-row:active{background:var(--surface2)}.list-primary{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14px;font-weight:500;overflow:hidden}.list-secondary{color:var(--text2);white-space:nowrap;font-size:12px}.list-badge{flex-shrink:0}.data-table-wrap{-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:6px;overflow-x:auto}.data-table{min-width:max-content;display:grid}.dt-header{color:var(--text2);background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;border-bottom:2px solid var(--border);padding:8px 10px;font-size:12px;font-weight:600;position:relative}.dt-header:hover,.dt-header.dt-sorted{color:var(--text)}.dt-sort-arrow{font-size:10px}.dt-resize-handle{cursor:col-resize;z-index:1;background:var(--border);opacity:.5;border-radius:2px;width:5px;transition:opacity .15s,background .15s;position:absolute;top:4px;bottom:4px;right:-2px}.dt-resize-handle:hover,.dt-resize-handle:active{background:var(--accent);opacity:.8}.dt-cell{color:var(--text);border-bottom:1px solid var(--border);white-space:nowrap;text-overflow:ellipsis;-webkit-tap-highlight-color:transparent;padding:7px 10px;font-size:13px;transition:background .15s;overflow:hidden}.dt-clickable:hover{background:var(--surface)}.data-table .dt-cell{background:0 0}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;margin-bottom:6px;padding:12px 14px;transition:background .15s}.card:active{background:var(--surface2)}.card-row{justify-content:space-between;align-items:center;display:flex}.card-row+.card-row{margin-top:8px}.type-badge{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.dose-text{font-variant-numeric:tabular-nums;font-size:17px;font-weight:700}.date-text{color:var(--text2);font-size:13px}.units-text{color:var(--text2);font-variant-numeric:tabular-nums;font-size:13px}.notes-text{color:var(--text2);margin-top:6px;font-size:13px;line-height:1.4}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-header h2{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;font-size:15px;font-weight:600}.btn{border-radius:var(--radius);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:6px;padding:12px 20px;font-size:15px;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-danger{color:var(--red);background:#e0555526}.btn-ghost{color:var(--accent);background:0 0;padding:8px 12px}.fab{bottom:calc(76px + var(--safe-bottom));background:var(--accent);color:#fff;cursor:pointer;z-index:5;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;line-height:1;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;right:16px;box-shadow:0 4px 20px #6c8cff59}.fab:active{transform:scale(.9);box-shadow:0 2px 10px #6c8cff40}.modal-overlay{z-index:20;background:#0009;justify-content:center;align-items:flex-end;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:var(--surface);width:100%;max-width:540px;max-height:90dvh;padding:8px 20px 20px;padding-bottom:calc(20px + var(--safe-bottom));border-radius:20px 20px 0 0;animation:.25s ease-out slideUp;overflow-y:auto}.modal-sheet:before{content:"";background:var(--border);border-radius:2px;width:36px;height:4px;margin:0 auto 16px;display:block}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-overlay.closing{animation:.2s ease-in forwards fadeOut}.modal-overlay.closing .modal-sheet{animation:.2s ease-in forwards slideDown}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h2{font-size:20px;font-weight:700}.modal-close{background:var(--surface2);color:var(--text2);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.about-modal{border:1px solid var(--border)}.about-modal:before{display:none}.about-content{flex-direction:column;align-items:center;padding:8px 0 16px;display:flex}.about-icon{border-radius:18px;width:80px;height:80px;margin-bottom:16px}.about-name{margin:0 0 6px;font-size:20px;font-weight:700}.about-build{color:var(--text2);margin:0;font-size:13px}.field{margin-bottom:16px}.field label{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.field input,.field select,.field textarea{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:10px;outline:none;padding:12px 14px;font-family:inherit;font-size:16px;transition:border-color .2s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}.field textarea{resize:vertical;min-height:60px}.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b8fa3' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.field-row{gap:12px;display:flex}.field-row .field{flex:1}.form-actions{gap:10px;margin-top:24px;display:flex}.form-actions .btn{flex:1}.shot-form-sheet{padding:6px 16px 14px;padding-bottom:calc(14px + var(--safe-bottom))}.shot-form-sheet:before{margin-bottom:10px}.shot-form-sheet .modal-header{margin-bottom:12px}.shot-form-sheet .modal-header h2{font-size:17px}.shot-form-sheet .field{margin-bottom:10px}.shot-form-sheet .field label{margin-bottom:4px;font-size:11px}.shot-form-sheet .field input,.shot-form-sheet .field select,.shot-form-sheet .field textarea{border-radius:8px;padding:9px 12px;font-size:15px}.shot-form-sheet .field textarea{min-height:44px}.shot-form-sheet .form-actions{margin-top:14px}.shot-form-sheet .btn{padding:10px 16px;font-size:14px}.dose-input-row{align-items:center;gap:10px;display:flex}.dose-input-row input{flex:1}.dose-iu-inline{color:var(--accent);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:15px;font-weight:700}.filter-bar{background:var(--surface);-webkit-overflow-scrolling:touch;scrollbar-width:none;border-radius:10px;margin-bottom:12px;padding:3px;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-btn{color:var(--text2);white-space:nowrap;cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:center;background:0 0;border:none;border-radius:8px;flex:1;padding:7px 12px;font-size:13px;font-weight:500;transition:all .2s;position:relative}.filter-btn.active{background:var(--surface2);color:var(--text);box-shadow:0 1px 4px #00000040}.filter-btn:disabled{opacity:.35}.date-filter-btn{padding:6px 10px;font-size:12px}.custom-date-row{gap:12px;margin-bottom:12px;display:flex}.custom-date-row .field{flex:1}.vial-med{font-size:15px;font-weight:600}.vial-id{color:var(--accent);font-size:14px;font-weight:700}.vial-detail{color:var(--text2);font-size:13px}.vial-used-bar{background:var(--surface2);border-radius:2px;height:4px;margin-top:10px;overflow:hidden}.vial-used-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.calc-mode-toggle{background:var(--surface);border-radius:10px;margin-bottom:16px;padding:3px;display:flex}.calc-mode-toggle .filter-btn{flex:1}.calc-result{text-align:center;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;padding:24px}.calc-result .units-big{color:var(--accent);font-variant-numeric:tabular-nums;font-size:56px;font-weight:800;line-height:1}.calc-result .units-label{color:var(--text2);margin-top:4px;font-size:14px}.calc-formula{color:var(--text2);border-top:1px solid var(--border);font-variant-numeric:tabular-nums;margin-top:12px;padding-top:12px;font-size:13px}.empty-state{text-align:center;color:var(--text2);padding:48px 24px}.empty-state p{margin-top:8px;font-size:15px}.confirm-actions{gap:10px;margin-top:16px;display:flex}.confirm-actions .btn{flex:1}.loading-screen{min-height:100dvh;color:var(--text2);justify-content:center;align-items:center;font-size:16px;display:flex}.login-screen{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.login-card{text-align:center;width:100%;max-width:380px}.login-title{letter-spacing:-.5px;margin-bottom:4px;font-size:32px;font-weight:800}.login-subtitle{color:var(--text2);margin-bottom:32px;font-size:15px}.login-form{text-align:left}.login-btn{width:100%;margin-top:8px}.login-error{color:var(--red);margin-bottom:4px;font-size:13px}.login-divider{color:var(--text2);align-items:center;gap:12px;margin:20px 0;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-google-btn{background:var(--surface);width:100%;color:var(--text);border:1px solid var(--border);gap:10px}.login-toggle{color:var(--text2);margin-top:20px;font-size:14px}.login-toggle button{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:600}.import-desc{color:var(--text2);margin-bottom:20px;font-size:14px;line-height:1.5}.import-file-btn{width:100%}.import-summary{background:var(--surface2);border-radius:10px;margin-bottom:20px;padding:4px 0}.import-summary-row{justify-content:space-between;align-items:center;padding:12px 16px;font-size:15px;display:flex}.import-summary-row+.import-summary-row{border-top:1px solid var(--border)}.import-count{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:700}.clear-check{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;padding:12px 4px;font-size:15px;display:flex}.clear-check+.clear-check{border-top:1px solid var(--border)}.clear-check input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.clear-check .clear-count{color:var(--text2);font-variant-numeric:tabular-nums;margin-left:auto;font-size:14px}.clear-warning{color:var(--red);text-align:center;margin-top:12px;font-size:13px;font-weight:500}.schedule-name{font-size:15px;font-weight:600}.schedule-status-badge{color:var(--red);background:#e0555526;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.schedule-status-badge.active{color:var(--green);background:#4caf7d26}.schedule-timeframe-badge{color:var(--accent);font-size:12px;font-weight:500}.schedule-day-pills{gap:4px;margin-top:8px;display:flex}.day-pill-display{background:var(--surface2);width:26px;height:26px;color:var(--text2);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.day-pill-display.active{background:var(--accent);color:#fff}.day-picker{gap:6px;display:flex}.day-pill{border:1px solid var(--border);background:var(--surface2);width:38px;height:38px;color:var(--text2);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;transition:all .15s;display:flex}.day-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.day-pill:active{transform:scale(.9)}.schedule-active-toggle{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:10px;display:flex!important}.schedule-active-toggle input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent);cursor:pointer}.schedule-type-bar{margin-bottom:0}.home-card{cursor:default;flex-direction:column;gap:8px;display:flex}.home-card-add-btn{background:var(--accent);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-left:auto;font-size:20px;font-weight:600;line-height:1;transition:transform .1s,background .15s;display:flex}.home-card-add-btn:active{transform:scale(.9)}.home-card.overdue{border-left:3px solid var(--red)}.home-card-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.home-card-body{align-items:center;gap:12px;display:flex}.home-gauge{flex-shrink:0}.home-card-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.home-card-detail{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.home-card-schedule{justify-content:space-between;align-items:center;gap:8px;display:flex}.home-status{color:var(--green);font-size:13px;font-weight:600}.home-status.overdue{color:var(--red)}@media (width>=640px){.app-header{padding:20px 28px 12px}.app-main{padding:8px 28px 16px;padding-bottom:calc(88px + var(--safe-bottom))}.card-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:6px;display:grid}.card-grid .card{margin-bottom:0}.filter-bar,.calc-mode-toggle,.custom-date-row{max-width:540px}.tab-bar button{max-width:160px;margin:0 auto}.fab{right:28px}.modal-overlay{align-items:center}.modal-sheet{border-radius:20px;max-height:85dvh}.shot-form-sheet,.about-modal{border-radius:20px}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(40px)}}}@media (width>=1024px){.app-header{padding:20px 40px 12px}.app-main{padding:8px 40px 16px;padding-bottom:calc(88px + var(--safe-bottom))}.fab{right:40px}}.week-strip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-evenly;align-items:flex-start;margin-bottom:12px;padding:12px 8px;display:flex}.week-strip-day{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:4px;display:flex;position:relative}.week-strip-label{color:var(--text2);font-size:11px;font-weight:400}.week-strip-label.today{color:var(--accent);font-weight:700}.week-strip-circle{border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.week-strip-circle.today{border:2px solid var(--accent)}.week-strip-circle.on-time{background:#4caf7d26;border-color:#0000}.week-strip-circle.late{background:#e0555526;border-color:#0000}.week-strip-count{color:var(--accent);font-size:10px;font-weight:700;position:absolute;top:-2px;right:-4px}.settings-section-title{color:var(--text2);margin:16px 0 4px;font-size:13px}.settings-description{color:var(--text2);margin-bottom:16px;font-size:13px}.settings-divider{background:var(--border);height:1px;margin:12px 0}.med-row{align-items:center;gap:8px;padding:4px 0;display:flex}.med-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.med-row-lock{color:var(--text2);flex-shrink:0;margin-left:4px}.health-type-badge{color:var(--accent);background:#6c8cff26;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.health-source-badge{background:var(--surface2);color:var(--text2);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500}.health-stats{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;gap:12px;margin-top:12px;padding:12px;display:flex}.health-stat{text-align:center;flex:1;min-width:60px}.health-stat-value{color:var(--accent);font-variant-numeric:tabular-nums;font-size:20px;font-weight:700}.health-stat-label{color:var(--text2);text-transform:uppercase;font-size:11px}
