*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{color-scheme:dark;--bg: #0c1220;--surface: #151e2e;--surface-2: #1a2540;--border: #243048;--border-light: #1a2540;--primary: #6366f1;--primary-hover: #818cf8;--primary-light: #1e1b4b;--overdue: #f87171;--overdue-bg: #2d0a0a;--overdue-border: #7f1d1d;--overdue-light: #3b0f0f;--due-soon: #fbbf24;--due-soon-bg: #2a1800;--due-soon-border: #78350f;--due-soon-light: #361f00;--upcoming: #60a5fa;--upcoming-bg: #0f1f3d;--upcoming-border: #1d4ed8;--as-needed: #64748b;--as-needed-bg: #151e2e;--as-needed-border: #243048;--success: #34d399;--success-bg: #062012;--success-light: #064e3b;--danger: #f87171;--danger-hover: #fca5a5;--text: #f1f5f9;--text-2: #cbd5e1;--text-3: #94a3b8;--text-4: #475569;--radius: 14px;--radius-sm: 8px;--radius-lg: 20px;--shadow: 0 1px 3px rgba(0,0,0,.4), 0 4px 16px rgba(0,0,0,.3);--shadow-lg: 0 8px 32px rgba(0,0,0,.5), 0 2px 8px rgba(0,0,0,.3);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;font-family:var(--font);font-size:16px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}[data-theme=light]{color-scheme:light;--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--border-light: #f1f5f9;--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #eef2ff;--overdue: #dc2626;--overdue-bg: #fef2f2;--overdue-border: #fecaca;--overdue-light: #fee2e2;--due-soon: #d97706;--due-soon-bg: #fffbeb;--due-soon-border: #fde68a;--due-soon-light: #fef3c7;--upcoming: #2563eb;--upcoming-bg: #eff6ff;--upcoming-border: #bfdbfe;--as-needed: #64748b;--as-needed-bg: #f8fafc;--as-needed-border: #cbd5e1;--success: #059669;--success-bg: #ecfdf5;--success-light: #d1fae5;--danger: #dc2626;--danger-hover: #b91c1c;--text: #0f172a;--text-2: #334155;--text-3: #64748b;--text-4: #94a3b8;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.05);--shadow-lg: 0 8px 32px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.08)}.app{min-height:100dvh;display:flex;flex-direction:column}.header{background:var(--primary);color:#fff;padding:0 16px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px #4f46e54d}.header-brand{display:flex;align-items:center;gap:10px;font-size:1.15rem;font-weight:700;letter-spacing:-.01em}.header-brand svg{width:26px;height:26px}.header-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#ffffff26;color:#fff;transition:background .15s}.icon-btn:hover{background:#ffffff40}.icon-btn svg{width:18px;height:18px}.add-btn{height:36px;padding:0 14px;border-radius:18px;border:none;cursor:pointer;background:#fff3;color:#fff;font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:6px;transition:background .15s}.add-btn:hover{background:#ffffff4d}.add-btn svg{width:16px;height:16px}.main{flex:1;max-width:700px;width:100%;margin:0 auto;padding:20px 16px 100px}.section-label{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);padding:0 4px;margin:24px 0 8px}.section-label:first-child{margin-top:0}.med-card{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);padding:16px;margin-bottom:10px;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;position:relative;overflow:hidden}.med-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.med-card:active{transform:translateY(0)}.med-card.overdue{border-color:var(--overdue-border);background:var(--overdue-bg)}.med-card.due-soon{border-color:var(--due-soon-border);background:var(--due-soon-bg)}.med-card.upcoming{border-color:var(--upcoming-border)}.med-card.as-needed{border-color:var(--as-needed-border)}.med-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:var(--radius) 0 0 var(--radius)}.med-card.overdue:before{background:var(--overdue)}.med-card.due-soon:before{background:var(--due-soon)}.med-card.upcoming:before{background:var(--upcoming)}.med-card.as-needed:before{background:var(--as-needed)}.med-card-inner{padding-left:8px}.med-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.med-name-block{flex:1;min-width:0}.med-name{font-size:1.05rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.med-generic{font-size:.8rem;color:var(--text-3);margin-top:2px}.med-strength{font-size:.78rem;color:var(--text-4);margin-top:1px}.status-badge{flex-shrink:0;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:20px}.badge-overdue{background:var(--overdue-light);color:var(--overdue)}.badge-due-soon{background:var(--due-soon-light);color:var(--due-soon)}.badge-upcoming{background:var(--primary-light);color:var(--primary)}.badge-as-needed{background:var(--as-needed-bg);color:var(--as-needed)}.med-card-times{display:flex;gap:20px;margin-top:14px;flex-wrap:wrap}.time-block{flex:1;min-width:120px}.time-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-4);margin-bottom:3px}.time-value{font-size:.85rem;font-weight:600;color:var(--text-2)}.time-relative{font-size:.8rem;margin-top:2px}.overdue .time-relative{color:var(--overdue);font-weight:600}.due-soon .time-relative{color:var(--due-soon);font-weight:600}.upcoming .time-relative{color:var(--upcoming)}.as-needed .time-relative{color:var(--as-needed)}.med-dose-row{margin-top:10px;font-size:.8rem;color:var(--text-3);display:flex;align-items:center;gap:6px}.med-dose-row svg{width:13px;height:13px;flex-shrink:0}.footer-actions{position:fixed;bottom:0;left:0;right:0;padding:12px 20px 20px;background:linear-gradient(transparent,var(--bg) 40%);display:flex;justify-content:center;gap:10px;pointer-events:none}.footer-btn{pointer-events:all;height:44px;padding:0 20px;border-radius:22px;border:none;cursor:pointer;font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:7px;box-shadow:0 4px 16px #00000026;transition:transform .15s,box-shadow .15s}.footer-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0003}.footer-btn:active{transform:none}.footer-btn-clear{background:var(--surface);color:var(--text-3);border:1.5px solid var(--border)}.footer-btn-clear:hover{color:var(--danger);border-color:var(--danger)}.footer-btn-clear svg{width:16px;height:16px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-3)}.empty-state svg{width:56px;height:56px;opacity:.3;margin-bottom:16px}.empty-state h3{font-size:1.1rem;color:var(--text-2);margin-bottom:6px}.empty-state p{font-size:.9rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:fadeIn .15s ease}@media (min-width: 500px){.modal-overlay{align-items:center;padding:20px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-height:92dvh;display:flex;flex-direction:column;animation:slideUp .2s ease;overflow:hidden}@media (min-width: 500px){.modal{border-radius:var(--radius-lg);max-width:500px;max-height:88vh}}.modal-header{padding:20px 20px 16px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:1.1rem;font-weight:700;color:var(--text);line-height:1.3}.modal-subtitle{font-size:.82rem;color:var(--text-3);margin-top:3px}.modal-close{width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;background:var(--surface-2);color:var(--text-3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.modal-close:hover{background:var(--border);color:var(--text)}.modal-close svg{width:16px;height:16px}.modal-body{flex:1;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}.modal-footer{padding:16px 20px 24px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;flex-shrink:0}@media (min-width: 400px){.modal-footer{flex-direction:row;flex-wrap:wrap}}.field{margin-bottom:16px}.field-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-2);margin-bottom:6px;letter-spacing:.02em}.field input,.field select,.field textarea{width:100%;height:42px;padding:0 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface-2);color:var(--text);font-size:.9rem;font-family:var(--font);transition:border-color .15s,box-shadow .15s;outline:none}.field textarea{height:auto;padding:10px 12px;resize:vertical;min-height:64px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f;background:var(--surface)}.field-hint{font-size:.75rem;color:var(--text-4);margin-top:4px}.field-row{display:flex;gap:12px}.field-row .field{flex:1}.checkbox-row{display:flex;align-items:center;gap:10px;cursor:pointer;padding:10px 0}.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.checkbox-row span{font-size:.9rem;color:var(--text-2);-webkit-user-select:none;user-select:none}.time-slots{display:flex;gap:8px;flex-wrap:wrap}.slot-btn{padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface-2);color:var(--text-3);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.slot-btn.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.btn{height:44px;padding:0 20px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:600;font-size:.9rem;font-family:var(--font);display:inline-flex;align-items:center;gap:7px;justify-content:center;transition:background .15s,transform .1s,box-shadow .15s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn svg{width:16px;height:16px}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4f46e54d}.btn-primary:hover{background:var(--primary-hover)}.btn-success{background:var(--success);color:#fff;box-shadow:0 2px 8px #05966940}.btn-success:hover{background:#047857}.btn-secondary{background:var(--surface-2);color:var(--text-2);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:transparent;color:var(--danger);border:1.5px solid var(--danger)}.btn-danger:hover{background:#fef2f2}.btn-ghost{background:transparent;color:var(--text-3)}.btn-ghost:hover{background:var(--surface-2);color:var(--text-2)}.btn-sm{height:34px;padding:0 12px;font-size:.82rem}.btn-full{width:100%}.info-section{background:var(--surface-2);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:16px}.info-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:4px 0}.info-row:not(:last-child){border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:8px}.info-key{color:var(--text-3);font-weight:500}.info-val{color:var(--text);font-weight:600;text-align:right;max-width:60%}.divider{height:1px;background:var(--border);margin:20px 0}.alert{border-radius:var(--radius-sm);padding:12px 14px;font-size:.84rem;margin-bottom:16px;display:flex;gap:10px;align-items:flex-start}.alert svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}.alert-warning{background:var(--due-soon-light);color:#92400e;border:1px solid var(--due-soon-border)}.alert-info{background:var(--primary-light);color:#3730a3;border:1px solid #c7d2fe}.alert-danger{background:var(--overdue-light);color:#991b1b;border:1px solid var(--overdue-border)}.alert-success{background:var(--success-light);color:#065f46;border:1px solid #a7f3d0}.settings-section-title{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-4);margin:20px 0 10px}.settings-section-title:first-child{margin-top:0}.notif-dot{width:8px;height:8px;border-radius:50%;background:#f59e0b;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}@media (max-width: 360px){.med-card-times{flex-direction:column;gap:10px}}.history-list{display:flex;flex-direction:column;gap:8px}.history-entry{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;display:flex;justify-content:space-between;align-items:center;gap:10px}.history-left{display:flex;align-items:center;gap:10px;min-width:0}.history-index{font-size:.7rem;font-weight:700;color:var(--text-4);flex-shrink:0;width:22px;text-align:right}.history-time{display:flex;flex-direction:column;gap:2px;min-width:0}.history-date{font-size:.85rem;font-weight:600;color:var(--text-2);white-space:nowrap}.history-ago{font-size:.75rem;color:var(--text-4)}.history-dose{font-size:.8rem;color:var(--text-3);text-align:right;flex-shrink:0;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-remove{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:none;background:transparent;color:var(--text-4);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.history-remove:hover{background:var(--overdue-light);color:var(--overdue)}.history-remove svg{width:13px;height:13px}.history-add-form{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px}.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg)}.auth-card{width:100%;max-width:400px;background:var(--surface);border-radius:var(--radius-lg);border:1.5px solid var(--border);padding:32px 28px 28px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-icon{width:56px;height:56px;background:var(--primary);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:#fff}.auth-logo-icon svg{width:28px;height:28px}.auth-app-name{font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.auth-tagline{font-size:.85rem;color:var(--text-3);margin-top:4px}.auth-tabs{display:flex;background:var(--surface-2);border-radius:var(--radius-sm);padding:4px;margin-bottom:24px;border:1.5px solid var(--border)}.auth-tab{flex:1;height:36px;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:600;font-family:var(--font);background:transparent;color:var(--text-3);transition:all .15s}.auth-tab.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 4px #00000026}.auth-form{display:flex;flex-direction:column;gap:4px}.auth-error{display:flex;align-items:flex-start;gap:8px;background:var(--overdue-bg);color:var(--overdue);border:1px solid var(--overdue-border);border-radius:var(--radius-sm);padding:10px 12px;font-size:.84rem;margin-bottom:8px}.auth-error svg{width:15px;height:15px;flex-shrink:0;margin-top:1px}.auth-submit{margin-top:8px;height:46px;font-size:.95rem;border-radius:var(--radius-sm)}.auth-switch{text-align:center;margin-top:20px;font-size:.84rem;color:var(--text-3)}.auth-link{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;font-size:.84rem;font-family:var(--font);padding:0;text-decoration:underline;text-underline-offset:2px}.auth-link:hover{color:var(--primary-hover)}.auth-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.hamburger-btn{margin-right:2px}.nav-menu{position:absolute;top:calc(100% + 6px);left:12px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:300;min-width:160px;overflow:hidden;animation:fadeIn .12s ease}.nav-menu-item{width:100%;height:46px;padding:0 16px;border:none;background:transparent;color:var(--text-2);font-size:.9rem;font-weight:500;font-family:var(--font);cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .12s;text-align:left}.nav-menu-item:hover{background:var(--surface-2)}.nav-menu-item.active{color:var(--primary);font-weight:700;background:var(--primary-light)}.nav-menu-item svg{width:16px;height:16px;flex-shrink:0}.nav-menu-item+.nav-menu-item{border-top:1px solid var(--border-light)}.sort-bar{display:flex;align-items:center;gap:6px;margin-bottom:16px;flex-wrap:wrap}.sort-bar-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-4);margin-right:2px}.sort-btn{padding:5px 12px;border-radius:16px;border:1.5px solid var(--border);background:var(--surface-2);color:var(--text-3);font-size:.78rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .12s;white-space:nowrap}.sort-btn:hover{border-color:var(--primary);color:var(--primary)}.sort-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.calendar-view{width:100%}.cal-nav{display:flex;align-items:center;gap:8px;margin-bottom:20px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:10px 12px}.cal-nav-arrow{width:36px;height:36px;border-radius:50%;border:none;background:var(--surface-2);color:var(--text-2);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s}.cal-nav-arrow:hover{background:var(--border)}.cal-nav-center{flex:1;min-width:0;text-align:center}.cal-nav-label{font-size:.9rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.cal-nav-controls{display:flex;align-items:center;justify-content:center;gap:4px}.cal-date-input{height:30px;padding:0 8px;border-radius:6px;border:1.5px solid var(--border);background:var(--surface-2);color:var(--text-2);font-size:.78rem;font-family:var(--font);outline:none;cursor:pointer}.cal-date-input:focus{border-color:var(--primary)}.cal-list{display:flex;flex-direction:column}.cal-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;cursor:pointer;transition:transform .12s,box-shadow .12s;position:relative;overflow:hidden}.cal-card:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.cal-card:active{transform:none}.cal-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:var(--radius) 0 0 var(--radius)}.cal-taken{border-color:var(--success-light);background:var(--success-bg)}.cal-taken:before{background:var(--success)}.cal-due-soon{border-color:var(--due-soon-border);background:var(--due-soon-bg)}.cal-due-soon:before{background:var(--due-soon)}.cal-upcoming{border-color:var(--upcoming-border)}.cal-upcoming:before{background:var(--upcoming)}.cal-missed{border-color:var(--overdue-border);background:var(--overdue-bg);opacity:.85}.cal-missed:before{background:var(--overdue)}.cal-card-header{padding-left:8px;margin-bottom:4px}.cal-card-name{font-size:.95rem;font-weight:700;color:var(--text)}.cal-card-generic{font-size:.78rem;color:var(--text-3);margin-top:1px}.cal-card-dose{font-size:.8rem;color:var(--text-3);padding-left:8px;margin-bottom:8px}.cal-card-due-time{font-size:.8rem;font-weight:600;color:var(--upcoming);padding-left:8px}.cal-due-soon .cal-card-due-time{color:var(--due-soon)}.cal-dose-times{display:flex;flex-wrap:wrap;gap:6px;padding-left:8px}.cal-time-chip{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:12px;font-size:.75rem;font-weight:600;background:var(--primary-light);color:var(--primary);border:1px solid transparent}.cal-time-chip-taken{background:var(--success-light);color:var(--success)}
