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