*{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;--tirz: #6c8cff;--semorelin: #4caf7d;--testc: #e8a449;--radius: 14px;--safe-bottom: env(safe-area-inset-bottom, 0px)}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;max-width:480px;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}.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:50%;transform:translate(-50%);width:100%;max-width:480px;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}.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}.type-badge.tirz{background:#6c8cff26;color:var(--tirz)}.type-badge.semorelin{background:#4caf7d26;color:var(--semorelin)}.type-badge.testc{background:#e8a44926;color:var(--testc)}.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:max(16px,calc(50% - 224px));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:480px;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}.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}.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}
