@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg-base);background-image:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(59,158,255,.07) 0%,transparent 70%)}.auth-box{width:100%;max-width:380px;display:flex;flex-direction:column;gap:1.75rem}.auth-brand{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.35rem}.auth-icon{font-size:2.5rem}.auth-title{font-size:1.75rem;font-weight:700;letter-spacing:-.03em}.auth-sub{font-size:.875rem;color:var(--text-secondary)}.auth-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.auth-error{background:var(--red-dim);color:var(--red);padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.85rem;border:1px solid #5a1010}.auth-submit{width:100%;margin-top:.25rem}.auth-footer{text-align:center;font-size:.875rem;color:var(--text-secondary)}.med-card{position:relative;overflow:hidden;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.1rem;display:flex;flex-direction:column;gap:.7rem;transition:border-color var(--transition);animation:fadeUp .2s ease both}.med-card:hover{border-color:var(--border-lit)}.med-card--urgent{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 0 20px #ff505014}.urgent-ring{position:absolute;top:0;left:0;right:0;height:2px;background:var(--red);box-shadow:0 0 8px var(--red)}.med-card-header{display:flex;align-items:flex-start;gap:.75rem}.med-info{flex:1;min-width:0}.med-name{font-size:1rem;font-weight:600;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.med-dosage{font-size:.8rem;color:var(--text-secondary);font-family:var(--font-mono)}.med-actions{display:flex;gap:.25rem;flex-shrink:0}.icon-btn{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background var(--transition),color var(--transition)}.icon-btn:hover{background:var(--bg-raised);color:var(--text-primary)}.icon-btn--danger:hover{background:var(--red-dim);color:var(--red)}.med-schedule{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.med-freq{font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono)}.med-instructions{font-size:.8rem;color:var(--text-secondary);background:var(--bg-raised);border-radius:var(--radius-sm);padding:.4rem .6rem;border-left:2px solid var(--border-lit)}.med-last-taken{font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono)}.log-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.6rem;border-radius:var(--radius-sm);background:var(--bg-raised);border:1px solid var(--border-lit);color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition)}.log-btn:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.log-btn--urgent{background:var(--red-dim);border-color:var(--red);color:var(--red)}.log-btn--urgent:hover{background:#5a1010}.scan-modal{display:flex;flex-direction:column;gap:1rem}.scan-capture{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 0}.scan-prompt{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-secondary);text-align:center;padding:2rem}.scan-prompt svg{color:var(--accent);opacity:.7}.scan-prompt p{font-size:1rem;font-weight:500;color:var(--text-primary)}.scan-hint{font-size:.8rem}.scan-cta{width:100%;max-width:240px}.scan-divider{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:.75rem;width:100%}.scan-divider:before,.scan-divider:after{content:"";flex:1;height:1px;background:var(--border)}.scan-live{display:flex;flex-direction:column;gap:1rem}.scan-video{width:100%;max-height:340px;object-fit:cover;border-radius:var(--radius-md);background:#000}.scan-live-actions{display:flex;gap:.75rem;justify-content:center;align-items:center}.scan-loading{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.scan-preview{width:100%;max-height:220px;object-fit:cover;border-radius:var(--radius-md);opacity:.7}.scan-loading-info{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.9rem}.scan-review{display:flex;flex-direction:column;gap:.85rem}.scan-preview-row{display:flex;align-items:center;gap:.75rem}.scan-preview-thumb{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.confidence{font-size:.72rem;font-weight:500;padding:2px 8px;border-radius:99px}.confidence--high{background:var(--green-dim);color:var(--green)}.confidence--medium{background:var(--yellow-dim);color:var(--yellow)}.confidence--low{background:var(--red-dim);color:var(--red)}.rescan-btn{margin-left:auto;font-size:.8rem;color:var(--accent);background:none;border:none;cursor:pointer}.rescan-btn:hover{text-decoration:underline}.scan-error{background:var(--red-dim);color:var(--red);padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.85rem;border:1px solid #5a1010}.scan-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.mt-2{margin-top:.5rem}.scan-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.25rem}.log-dose{display:flex;flex-direction:column;gap:1rem}.log-med-name{font-size:1.15rem;font-weight:600}.log-med-dosage{font-size:.85rem;color:var(--text-secondary);font-family:var(--font-mono);margin-top:-.5rem}.log-pill-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.pill-options{display:flex;gap:.5rem;flex-wrap:wrap}.pill-option{width:52px;height:52px;border-radius:var(--radius-md);background:var(--bg-raised);border:2px solid var(--border);font-size:1.25rem;font-weight:600;font-family:var(--font-mono);color:var(--text-secondary);transition:all var(--transition)}.pill-option:hover{border-color:var(--accent);color:var(--accent)}.pill-option--active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.log-pill-fixed{display:flex;align-items:center;gap:.6rem;background:var(--bg-raised);border-radius:var(--radius-sm);padding:.75rem 1rem;color:var(--green)}.log-pill-dose{margin-left:auto;font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.log-instructions{font-size:.82rem;color:var(--text-secondary);background:var(--bg-raised);padding:.5rem .75rem;border-radius:var(--radius-sm);border-left:2px solid var(--accent)}.log-time-section{display:flex;flex-direction:column;gap:.75rem;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);padding:.85rem 1rem}.log-time-toggle{display:flex;gap:4px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;width:100%}.time-tab{flex:1;padding:.4rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500;color:var(--text-muted);background:transparent;border:none;cursor:pointer;transition:background .15s ease,color .15s ease;text-align:center}.time-tab:hover{color:var(--text-secondary)}.time-tab--active{background:var(--bg-hover);color:var(--text-primary)}.log-time-picker{display:flex;flex-direction:column;gap:.4rem;border-top:1px solid var(--border);padding-top:.75rem}.datetime-input{font-family:var(--font-mono);font-size:.9rem;color-scheme:dark;background:var(--bg-surface);border:1px solid var(--border-lit);border-radius:var(--radius-sm);color:var(--text-primary);padding:.5rem .75rem;width:100%}.datetime-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.log-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.25rem}.history-section{display:flex;flex-direction:column;gap:.75rem}.history-count{margin-left:auto;font-size:.72rem;font-weight:500;background:var(--bg-raised);color:var(--text-secondary);padding:2px 8px;border-radius:99px;text-transform:none;letter-spacing:0}.history-empty{font-size:.85rem;color:var(--text-muted);padding:1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.history-list{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:.25rem 1rem}.history-row{display:flex;align-items:flex-start;gap:.85rem;padding:.85rem 0;border-bottom:1px solid var(--border)}.history-row--last{border-bottom:none}.history-dot-col{display:flex;flex-direction:column;align-items:center;padding-top:4px;flex-shrink:0;width:14px}.history-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);flex-shrink:0;box-shadow:0 0 0 3px var(--accent-dim)}.history-line{width:2px;flex:1;min-height:20px;background:var(--border);margin-top:4px}.history-content{flex:1;min-width:0}.history-name{font-size:.9rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-meta{display:flex;gap:.5rem;margin-top:2px;flex-wrap:wrap}.history-dosage,.history-pills{font-size:.75rem;font-family:var(--font-mono);color:var(--text-muted)}.history-pills{color:var(--green)}.history-time{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.history-clock{font-size:.85rem;font-family:var(--font-mono);font-weight:500;color:var(--text-primary)}.history-ago{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.history-right{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}.history-delete-btn{width:26px;height:26px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:transparent;border:none;cursor:pointer;opacity:0;transition:opacity var(--transition),background var(--transition),color var(--transition)}.history-row:hover .history-delete-btn{opacity:1}.history-delete-btn:hover{background:var(--red-dim);color:var(--red)}.history-row--confirming{background:#ff50500a}.history-confirm-row{display:flex;align-items:center;gap:.35rem}.history-confirm-label{font-size:.75rem;color:var(--red);white-space:nowrap}.history-confirm-btn{padding:2px 10px;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all var(--transition)}.history-confirm-btn--yes{background:var(--red-dim);color:var(--red);border-color:#6a1a1a}.history-confirm-btn--yes:hover{background:#5a1010}.history-confirm-btn--no{background:var(--bg-raised);color:var(--text-secondary);border-color:var(--border-lit)}.history-confirm-btn--no:hover{background:var(--bg-hover);color:var(--text-primary)}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.dashboard-title{font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.dashboard-subtitle{font-size:.85rem;color:var(--text-secondary);margin-top:.2rem}.add-btn{display:flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:.875rem;font-weight:500;transition:background var(--transition),transform var(--transition);flex-shrink:0}.add-btn:hover{background:#5aaeff}.add-btn:active{transform:scale(.97)}.dashboard-loading{display:flex;justify-content:center;padding:3rem}.med-section{display:flex;flex-direction:column;gap:.75rem}.section-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.section-label--urgent{color:var(--red)}.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--red);position:relative;flex-shrink:0}.pulse-dot:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:var(--red);animation:pulse-ring 1.5s ease-out infinite}.med-grid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr))}.empty-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 1rem;text-align:center}.empty-icon{font-size:3rem;opacity:.3}.empty-state h2{font-size:1.1rem;font-weight:600}.empty-state p{font-size:.875rem;color:var(--text-secondary);max-width:280px}.settings{display:flex;flex-direction:column;gap:1rem;max-width:560px}.settings-title{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.settings-card{display:flex;flex-direction:column;gap:1rem}.settings-section{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.settings-section--danger{color:var(--red)}.settings-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.55}.settings-desc strong{color:var(--text-primary)}.settings-fields{display:flex;flex-direction:column;gap:.85rem}.settings-row-info{display:flex;align-items:center;justify-content:space-between}.settings-label-sm{font-size:.82rem;color:var(--text-secondary)}.settings-value{font-family:var(--font-mono);font-size:.85rem;color:var(--text-primary);background:var(--bg-raised);padding:2px 8px;border-radius:4px}.push-status{display:flex;flex-direction:column;gap:.6rem}.push-status-row{display:flex;align-items:center;justify-content:space-between}.status-pill{font-size:.72rem;font-weight:500;padding:2px 10px;border-radius:99px}.status-pill--on{background:var(--green-dim);color:var(--green)}.status-pill--off{background:var(--red-dim);color:var(--red)}.status-pill--neutral{background:var(--bg-raised);color:var(--text-secondary)}.toggle-row{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-row input[type=checkbox]{display:none}.toggle-track{width:40px;height:22px;border-radius:11px;background:var(--bg-raised);border:1px solid var(--border-lit);position:relative;flex-shrink:0;transition:background var(--transition)}.toggle-row input:checked~.toggle-track{background:var(--accent-dim);border-color:var(--accent)}.toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-muted);transition:transform var(--transition),background var(--transition)}.toggle-row input:checked~.toggle-track .toggle-thumb{transform:translate(18px);background:var(--accent)}.toggle-label{font-size:.875rem;color:var(--text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500;border-radius:var(--radius-sm);transition:background var(--transition),opacity var(--transition),transform var(--transition);white-space:nowrap;flex-shrink:0}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-md{padding:.55rem 1.1rem;font-size:.9rem}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-icon{padding:.5rem;border-radius:var(--radius-sm)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#5aaeff}.btn-secondary{background:var(--bg-raised);color:var(--text-primary);border:1px solid var(--border-lit)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid #6a1a1a}.btn-danger:hover:not(:disabled){background:#5a1515}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-raised);color:var(--text-primary)}.btn-success{background:var(--green-dim);color:var(--green);border:1px solid #0d5a30}.btn-success:hover:not(:disabled){background:#0f5530}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#040814cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:fadeUp .15s ease}@media (min-width: 600px){.modal-overlay{align-items:center}}.modal{background:var(--bg-surface);border:1px solid var(--border-lit);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;max-height:90dvh;overflow-y:auto}@media (min-width: 600px){.modal{border-radius:var(--radius-lg)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 0}.modal-title{font-size:1.1rem;font-weight:600}.modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg-raised);color:var(--text-secondary);font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:1.25rem}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:.72rem;font-weight:500}.badge-default{background:var(--bg-raised);color:var(--text-secondary)}.badge-green{background:var(--green-dim);color:var(--green)}.badge-yellow{background:var(--yellow-dim);color:var(--yellow)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-blue{background:var(--accent-dim);color:var(--accent)}.icon-spin{animation:spin .8s linear infinite;color:var(--accent)}.spinner-sm{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.field{display:flex;flex-direction:column;gap:.4rem}.field-label{font-size:.82rem;font-weight:500;color:var(--text-secondary)}.field-error{font-size:.8rem;color:var(--red)}.loading-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-base)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.topbar-inner{max-width:960px;margin:0 auto;padding:0 1rem;height:56px;display:flex;align-items:center;gap:1.5rem}.topbar-brand{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.brand-icon{font-size:1.3rem}.brand-name{font-size:1rem;font-weight:600;letter-spacing:-.02em}.topbar-nav{display:flex;gap:.25rem;flex:1}@media (max-width: 599px){.topbar-nav{display:none}}.nav-link{padding:.35rem .75rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:color var(--transition),background var(--transition)}.nav-link:hover{color:var(--text-primary);background:var(--bg-raised);text-decoration:none}.nav-link.active{color:var(--accent);background:var(--accent-dim)}.topbar-user{display:flex;align-items:center;gap:.75rem;margin-left:auto}.user-name{font-size:.85rem;color:var(--text-secondary)}@media (max-width: 599px){.user-name{display:none}}.main-content{flex:1;max-width:960px;width:100%;margin:0 auto;padding:1.5rem 1rem 5rem}@media (min-width: 600px){.main-content{padding-bottom:2rem}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--bg-surface);border-top:1px solid var(--border);padding:.5rem 0 env(safe-area-inset-bottom,.5rem)}@media (max-width: 599px){.bottom-nav{display:flex}}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:.4rem;color:var(--text-muted);font-size:.7rem;font-weight:500;transition:color var(--transition);text-decoration:none}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item:hover{color:var(--text-secondary)}:root{--bg-base: #080e1a;--bg-surface: #0d1526;--bg-raised: #131f35;--bg-hover: #1a2a46;--border: #1e2e4a;--border-lit: #2a3f66;--text-primary: #e8eef8;--text-secondary: #7a90b8;--text-muted: #3d5278;--accent: #3b9eff;--accent-dim: #1a4a80;--accent-glow: rgba(59, 158, 255, .15);--green: #22d07a;--green-dim: #0d4a2a;--yellow: #f5c542;--yellow-dim: #4a3a0a;--red: #ff5050;--red-dim: #4a1010;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100dvh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}input,select,textarea{font-family:var(--font-body);font-size:1rem;background:var(--bg-raised);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:.6rem .85rem;width:100%;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input::placeholder{color:var(--text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-lit);border-radius:3px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-ring{0%{transform:scale(1);opacity:.6}to{transform:scale(1.8);opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}
