@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-dark:#0a0e1a;--bg-card:#141827;--bg-card-hover:#1a1f35;--text:#e8eaf0;--text-dim:#9ca3af;--accent:#6366f1;--accent-hover:#4f46e5;--border:rgba(255,255,255,.08);--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--phase-1:#7c9cff;--phase-2:#6ee7b7;--phase-3:#4dd0e1}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#0a0e1a 0,#1a1f3a 100%);color:var(--text);line-height:1.6;min-height:100vh;padding-bottom:40px}header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(140%) blur(10px);background:linear-gradient(180deg,rgba(10,14,26,.92),rgba(10,14,26,.75));border-bottom:1px solid var(--border);transition:all .3s ease}.brand,.nav{display:flex;align-items:center}.nav{justify-content:space-between;gap:16px;width:100%;padding:16px 24px;box-sizing:border-box}.brand{gap:14px;font-weight:800;font-size:18px;letter-spacing:.3px;text-decoration:none;color:var(--text);flex-shrink:0;white-space:nowrap}.nav-buttons{flex-shrink:0;margin-left:auto}.logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--phase-3));color:#0a0e1a;font-weight:900;font-size:20px;box-shadow:0 10px 30px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.03)}.nav-buttons{display:flex;gap:12px;align-items:center}.cta{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.12);text-decoration:none;color:var(--text);background:rgba(255,255,255,.04);font-size:14px;font-weight:500;transition:all .2s ease;white-space:nowrap}.cta:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.25);transform:translateY(-1px)}.cta.primary{background:linear-gradient(135deg,rgba(99,102,241,.25),rgba(77,208,225,.2));border-color:rgba(99,102,241,.4);font-weight:600}.cta.primary:hover{background:linear-gradient(135deg,rgba(99,102,241,.35),rgba(77,208,225,.3));border-color:var(--accent)}.hamburger-btn{display:none;flex-direction:column;gap:6px;background:0 0;border:0;cursor:pointer;padding:8px;color:var(--text);font-size:20px}.hamburger-btn span{width:24px;height:2px;background:var(--text);border-radius:1px;transition:all .3s ease}.hamburger-btn.active span:nth-child(1){transform:rotate(45deg) translate(10px,10px)}.hamburger-btn.active span:nth-child(2){opacity:0}.hamburger-btn.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.mobile-menu{display:none;position:absolute;top:70px;right:0;background:linear-gradient(180deg,rgba(10,14,26,.95),rgba(10,14,26,.9));border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;gap:12px;flex-direction:column;z-index:1000;min-width:200px}.mobile-menu.active{display:flex}.mobile-menu .cta{width:100%;justify-content:center}@media (max-width:768px){.hamburger-btn{display:flex}.nav-buttons{display:none}.nav{padding:12px 16px;gap:10px}.brand{font-size:16px;gap:10px}.logo{width:36px;height:36px;font-size:18px}.nav-buttons{gap:8px}.cta{padding:8px 14px;font-size:13px}}.header{padding:24px 20px;background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(168,85,247,.08));border-bottom:1px solid var(--border);text-align:center}.back-link,.protocol-option label{background:rgba(255,255,255,.04);transition:all .2s ease;font-weight:500}.back-link{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid rgba(255,255,255,.1);border-radius:999px;color:var(--text);font-size:14px;margin-bottom:16px;text-decoration:none}.back-link:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2)}h1{font-size:32px;font-weight:700;background:linear-gradient(135deg,#a78bfa,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.subtitle{color:var(--text-dim);font-size:16px}.protocol-title{color:var(--text);font-size:18px;font-weight:600;margin-top:8px;margin-bottom:8px}.container{max-width:900px;margin:0 auto;padding:20px}.instructions-section{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:24px;max-width:1200px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box}.dashboard h2,.instructions-section h2,.protocol-selector h2{font-size:20px;margin-bottom:16px;color:var(--text)}.instructions-content{line-height:1.8}.instructions-content>p{margin-bottom:20px;color:var(--text);font-size:15px}.instruction-step{margin-bottom:16px;padding:12px;background:rgba(255,255,255,.02);border-left:3px solid var(--accent);border-radius:6px}.instruction-step strong{display:block;color:var(--accent);font-size:15px;margin-bottom:4px}.instruction-step p{color:var(--text-dim);font-size:14px;margin:0}.instruction-tip{margin-top:20px;padding:12px 16px;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.3);border-radius:8px;font-size:14px;color:var(--text)}.instruction-tip strong{color:var(--accent)}.protocol-selector{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:24px}.protocol-options{display:flex;gap:12px;flex-wrap:wrap}.modal-overlay .protocol-options{flex-direction:column!important;gap:10px!important}.protocol-option{flex:1;min-width:200px}.protocol-option input[type=radio]{display:none}.protocol-option label{display:block;padding:16px;border:2px solid var(--border);border-radius:12px;cursor:pointer;text-align:center}.modal-overlay .protocol-option label{background:rgba(255,255,255,.04)!important;border:2px solid var(--border)!important;color:var(--text)!important;padding:12px!important;text-align:left!important}.protocol-option input:checked+label{background:rgba(99,102,241,.15);border-color:var(--accent);color:var(--accent)}.modal-overlay .protocol-option input:checked+label{background:rgba(99,102,241,.2)!important;border-color:var(--accent)!important;color:var(--accent)!important}.chart-type-btn:hover,.protocol-option label:hover{background:rgba(255,255,255,.08)}.modal-overlay .protocol-option label:hover{background:rgba(255,255,255,.08)!important}.protocol-selection-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px;margin-top:4px}.protocol-description{font-size:12px;color:var(--text-dim);margin-bottom:12px;line-height:1.5}.protocol-option-description{font-size:11px;color:var(--text-dim);margin-top:4px;line-height:1.4;display:block}.dashboard{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:24px;width:100%;box-sizing:border-box}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}.stat-value{font-size:28px;font-weight:700;color:var(--accent);margin-bottom:4px}.no-data-message,.stat-label{font-size:13px;color:var(--text-dim)}.no-data-message{padding:32px;text-align:center;font-size:15px}.trend-charts{margin-top:20px;display:grid;grid-template-columns:1fr;gap:16px}.chart-container{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:12px;padding:16px;position:relative;overflow:hidden}.chart-canvas-wrapper{position:relative;height:250px;width:100%}.chart-canvas-wrapper canvas,.chart-fullscreen-canvas canvas{cursor:grab}.chart-canvas-wrapper canvas:active,.chart-fullscreen-canvas canvas:active{cursor:grabbing}.chart-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:12px}.chart-controls{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:12px}.chart-controls-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.chart-controls-section{display:flex;flex-direction:column;gap:8px}.chart-controls-section label{font-size:11px;color:var(--text-dim);text-transform:uppercase;font-weight:600}.chart-type-buttons{display:flex;gap:4px}.chart-type-btn,.time-range-select{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;cursor:pointer}.chart-type-btn{padding:6px 12px;transition:all .2s ease}.chart-type-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.time-range-select{padding:6px 10px}.time-range-select option{background:var(--bg-card);color:var(--text)}.metric-toggles{display:flex;gap:12px;flex-wrap:wrap}.metric-toggle{display:flex;align-items:center;gap:6px;padding:4px 8px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:12px}.metric-toggle:hover,.rating-scale label:hover{background:rgba(255,255,255,.08)}.metric-toggle input[type=checkbox]{cursor:pointer}.metric-toggle label{cursor:pointer;margin:0;user-select:none}.metric-color-indicator{width:12px;height:12px;border-radius:3px;display:inline-block}.section-header{cursor:pointer;display:flex;align-items:center;justify-content:space-between;user-select:none}.section-header:hover{opacity:.8}.collapse-icon{font-size:16px;transition:transform .2s ease;color:var(--text-dim)}.progress-ring svg,.section-header.collapsed .collapse-icon{transform:rotate(-90deg)}.chart-fullscreen-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(10,14,26,.95);z-index:9999;overflow-y:auto;backdrop-filter:blur(10px);animation:fadeIn .3s ease}.chart-fullscreen-modal.active{display:block}.chart-fullscreen-content{max-width:1400px;margin:20px auto;padding:20px;background:var(--bg-card);border-radius:16px;border:1px solid var(--border)}.chart-fullscreen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.chart-fullscreen-title{font-size:20px;font-weight:700;color:var(--text)}.close-fullscreen-btn{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:all .2s ease}.close-fullscreen-btn:hover,.expand-chart-btn:hover{background:rgba(255,255,255,.1);border-color:var(--accent)}.chart-fullscreen-canvas{position:relative;min-height:600px;width:100%}.date-input-group input[type=date],.expand-chart-btn{border:1px solid var(--border);border-radius:6px;font-size:12px;cursor:pointer}.expand-chart-btn{background:rgba(255,255,255,.06);color:var(--text-dim);padding:6px 12px;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px}.expand-chart-btn:hover{color:var(--text)}.date-range-inputs{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.date-input-group{display:flex;flex-direction:column;gap:6px}.date-input-group label{font-size:11px;color:var(--text-dim);text-transform:uppercase;font-weight:600}.date-input-group input[type=date]{padding:6px 10px;background:rgba(255,255,255,.04);color:var(--text)}.apply-date-btn,.reset-date-btn{padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s ease}.apply-date-btn{background:var(--accent);border:1px solid var(--accent);color:#fff;font-weight:600}.apply-date-btn:hover{background:var(--accent-hover)}.reset-date-btn{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text-dim)}.reset-date-btn:hover,.reset-zoom-btn:hover{background:rgba(255,255,255,.1);color:var(--text)}.zoom-controls{display:flex;gap:8px;margin-top:12px}.reset-zoom-btn{padding:6px 12px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .2s ease}@media (max-width:768px){.chart-fullscreen-content{margin:0;border-radius:0;min-height:100vh}.chart-fullscreen-canvas{min-height:400px}.date-range-inputs{flex-direction:column;width:100%}.date-input-group{width:100%}}.collapsible-content{overflow:hidden;transition:max-height .3s ease,opacity .3s ease}.collapsible-content.collapsed{max-height:0!important;opacity:0}.journal-form{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:24px}.entries-section h2,.journal-form h2{font-size:20px;margin-bottom:20px;color:var(--text)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text)}.form-group input[type=date],.form-group select,.form-group textarea{width:100%;padding:12px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;font-family:inherit}.form-group textarea{min-height:80px;resize:vertical}.flatpickr-input,input.flatpickr-input{width:100%!important;padding:12px!important;background:rgba(255,255,255,.04)!important;border:1px solid var(--border)!important;border-radius:8px!important;color:var(--text)!important;font-size:14px!important;font-family:inherit!important;cursor:pointer;transition:all .2s ease}.flatpickr-input:focus,input.flatpickr-input:focus{background:rgba(255,255,255,.06)!important;border-color:var(--accent)!important;outline:0;box-shadow:0 0 0 3px rgba(99,102,241,.1)!important}.flatpickr-input:hover,input.flatpickr-input:hover{background:rgba(255,255,255,.05)!important;border-color:rgba(99,102,241,.4)!important}.flatpickr-input::placeholder,.modal-overlay .modal-input::placeholder,input.flatpickr-input::placeholder{color:var(--text-dim)!important}.flatpickr-calendar{background:#141827!important;border:1px solid rgba(255,255,255,.08)!important;box-shadow:0 20px 60px rgba(0,0,0,.4)!important;border-radius:12px!important}.flatpickr-calendar,.flatpickr-innerContainer{width:280px!important}.flatpickr-calendar.hasTime .flatpickr-innerContainer{border-right:0!important}.flatpickr-calendar .flatpickr-innerContainer,.flatpickr-calendar .flatpickrMonthNext,.flatpickr-calendar .flatpickrMonthPrev{background:0 0!important}.flatpickr-calendar .flatpickr-months{border-bottom:1px solid rgba(255,255,255,.08)!important}.flatpickr-calendar .flatpickr-month,.flatpickr-calendar .flatpickr-title{color:var(--text)!important}.flatpickr-calendar .flatpickr-next-month,.flatpickr-calendar .flatpickr-prev-month{color:var(--text-dim)!important;transition:all .2s ease}.flatpickr-calendar .flatpickr-next-month:hover,.flatpickr-calendar .flatpickr-prev-month:hover{color:var(--accent)!important}.flatpickr-monthDropdown-months,.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month{background:#141827!important;color:var(--text)!important}.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month:hover{background:rgba(99,102,241,.2)!important;color:var(--text)!important}.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month.selected{background:var(--accent)!important;color:#0a0e1a!important}.flatpickr-yearDropdown,.flatpickr-yearDropdown-button{color:var(--text)!important;background:0 0!important}.flatpickr-yearDropdown-button:hover,.flatpickr-yearDropdown:hover{color:var(--accent)!important}.flatpickr-weekdays{background:rgba(99,102,241,.1)!important;color:var(--text-dim)!important}.flatpickr-day{color:var(--text)!important;border-color:transparent!important;flex-basis:calc(20% - 4px)!important;padding:4px 0!important;height:auto!important;line-height:1.8!important;font-size:13px!important}.flatpickr-day:hover{background:rgba(99,102,241,.2)!important;border-color:transparent!important}.flatpickr-day.today{border-color:var(--accent)!important;background:rgba(99,102,241,.15)!important}.flatpickr-day.selected{background:var(--accent)!important;border-color:var(--accent)!important;color:#0a0e1a!important}.flatpickr-day.inRange{background:rgba(99,102,241,.2)!important;box-shadow:inset 0 0 0 1px rgba(99,102,241,.4)!important}.flatpickr-day.disabled{color:var(--text-dim)!important;opacity:.5}.flatpickr-time input{border:1px solid rgba(255,255,255,.08)!important}.flatpickr-time .flatpickr-hour,.flatpickr-time .flatpickr-minute,.flatpickr-time .flatpickr-second,.flatpickr-time input{background:rgba(255,255,255,.04)!important;color:var(--text)!important}.flatpickr-time .separator{color:var(--text-dim)!important}.rating-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.rating-item{display:flex;flex-direction:column;gap:8px}.rating-item label{font-size:13px;color:var(--text-dim)}.rating-scale{display:flex;gap:4px}.rating-scale input[type=radio]{display:none}.rating-scale label{flex:1;padding:8px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;text-align:center;cursor:pointer;font-size:12px;transition:all .2s ease}.rating-scale input:checked+label{background:var(--accent);border-color:var(--accent);color:#fff}.supplement-checklist{display:flex;flex-direction:column;gap:8px}.dosage-input-group,.supplement-item{background:rgba(255,255,255,.04);border:1px solid var(--border)}.supplement-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px}.supplement-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.supplement-item label{flex:1;cursor:pointer;font-size:14px;margin:0}.dosage-input-group{padding:12px;border-radius:8px;margin-bottom:8px}.supplement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.supplement-name{font-size:14px;font-weight:600;color:var(--text)}.recommended-dose{font-size:12px;color:var(--text-dim);background:rgba(99,102,241,.1);padding:4px 8px;border-radius:4px}.dosage-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.dose-input{width:100px;padding:8px 12px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:14px;font-family:inherit}.dose-input:focus{outline:0;border-color:var(--accent);background:rgba(255,255,255,.08)}.filter-group label,.unit-label{font-size:13px;color:var(--text-dim)}.unit-label{margin-right:10px}.checkbox-container{display:flex;align-items:center;gap:6px;cursor:pointer;padding:6px 12px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;transition:all .2s ease}.checkbox-container:hover{background:rgba(255,255,255,.08)}.checkbox-container input[type=checkbox]{width:16px;height:16px;cursor:pointer}.checkbox-label{font-size:13px;color:var(--text);margin:0}.dose-status{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.dose-status.compliant{background:rgba(16,185,129,.2);color:var(--success)}.dose-status.low{background:rgba(245,158,11,.2);color:var(--warning)}.dose-status.high{background:rgba(239,68,68,.2);color:var(--danger)}.dose-status.no-data{background:rgba(156,163,175,.2);color:var(--text-dim)}@media (max-width:768px){.dosage-controls{flex-direction:column;align-items:stretch;gap:8px}.dose-input{width:100%}.supplement-header{flex-direction:column;align-items:flex-start;gap:6px}}.form-actions{display:flex;gap:12px;margin-top:24px}.btn{padding:12px 24px;border:0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--accent);color:#fff;flex:1}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:rgba(255,255,255,.04);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:rgba(255,255,255,.08)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.entries-section{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:24px;width:100%;box-sizing:border-box}.filter-controls{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:end}.filter-group{flex:1;min-width:150px}.filter-group label{display:block;margin-bottom:6px}.filter-group .flatpickr-input,.filter-group input[type=date],.filter-group select{width:100%;padding:10px 12px;height:40px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:8px;color:var(--text);font-size:14px;cursor:pointer;transition:all .2s ease;box-sizing:border-box}.filter-group .flatpickr-input:focus,.filter-group input[type=date]:focus{background:rgba(255,255,255,.15);border-color:var(--accent);outline:0;box-shadow:0 0 0 3px rgba(99,102,241,.1)}.filter-group .flatpickr-input:hover,.filter-group input[type=date]:hover{background:rgba(255,255,255,.12);border-color:rgba(99,102,241,.5)}.filter-group select option,.form-group select option{background:var(--bg-card);color:var(--text);padding:10px}.form-group select{cursor:pointer;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2)}.filter-actions,.pagination{display:flex;gap:8px}.filter-actions button{padding:10px 16px;font-size:13px}.pagination{align-items:center;justify-content:center;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.pagination button{padding:8px 12px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;cursor:pointer;transition:all .2s ease}.pagination button:hover:not(:disabled){background:rgba(255,255,255,.08)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.pagination .page-btn{min-width:36px}.pagination .page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pagination-info{font-size:13px;color:var(--text-dim);margin:0 12px}.entries-list{display:flex;flex-direction:column;gap:12px}.entry-actions button,.entry-card{background:rgba(255,255,255,.04);transition:all .2s ease}.entry-card{border:1px solid var(--border);border-radius:12px;padding:16px}.entry-card:hover{background:rgba(255,255,255,.06)}.entry-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.entry-date{font-weight:600;color:var(--text);font-size:15px}.entry-protocol{font-size:12px;color:var(--text-dim)}.entry-actions{display:flex;gap:8px}.entry-actions button{padding:6px 12px;font-size:12px;border:0;color:var(--text);border-radius:6px;cursor:pointer}.entry-actions button:hover{background:rgba(255,255,255,.08)}.entry-actions .delete-btn:hover{background:var(--danger);color:#fff}.entry-ratings{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:12px;margin-bottom:12px}.entry-rating{display:flex;flex-direction:column;gap:4px}.entry-rating-label{font-size:11px;color:var(--text-dim);text-transform:uppercase}.entry-rating-value{font-size:18px;font-weight:600;color:var(--accent)}.entry-notes{font-size:14px;color:var(--text-dim);line-height:1.5;margin-top:8px;padding-top:12px;border-top:1px solid var(--border)}.export-section{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:24px}.export-section h2{margin-bottom:16px}.export-actions{display:flex;gap:12px;flex-wrap:wrap}.export-actions .btn{flex:1;min-width:140px}.import-area{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.file-input-wrapper{position:relative;overflow:hidden;display:inline-block;width:100%}.file-input-wrapper input[type=file]{position:absolute;left:-9999px}.file-input-label{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:600}.file-input-label:hover{background:rgba(255,255,255,.08)}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:1000;padding:20px;overflow-y:auto}.modal.active{display:flex;align-items:center;justify-content:center}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:500px;width:100%}.export-section h2,.modal-header h3{font-size:20px;color:var(--text)}.modal-actions{display:flex;gap:12px;margin-top:24px}@media (min-width:1024px){.container{max-width:1400px;padding:24px 32px}.export-section{display:none!important}.dashboard-wrapper{display:flex;flex-direction:column;gap:24px;max-width:1200px;margin:0 auto}.dashboard-left,.dashboard-right{display:flex;flex-direction:column;gap:20px}.dashboard-right{gap:24px}.protocol-selector{padding:16px}.protocol-selector h2{font-size:16px;margin-bottom:12px}.protocol-options{gap:8px}.protocol-option label{padding:10px 16px;font-size:14px}.dashboard{padding:20px}.dashboard h2{font-size:18px;margin-bottom:14px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:12px}.stat-value{font-size:24px}.filter-group label,.stat-label{font-size:12px}.journal-form{padding:20px}.journal-form h2{font-size:18px;margin-bottom:16px}.quick-actions-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px;width:100%;box-sizing:border-box}.quick-actions-panel h3{font-size:16px;margin-bottom:14px;color:var(--text)}.quick-actions-panel .export-actions{flex-direction:column;gap:8px}.quick-actions-panel .btn{width:100%;min-width:auto;padding:10px 16px;font-size:13px}.filter-controls{flex-wrap:nowrap;gap:8px;margin-bottom:16px}.filter-group{min-width:120px}.filter-group .flatpickr-input,.filter-group input[type=date],.filter-group select{padding:8px 10px;font-size:13px;height:40px;box-sizing:border-box}.filter-actions button{padding:8px 12px;font-size:12px}.entries-section{padding:20px}.entries-section h2{font-size:18px}.entry-card{padding:14px}.full-width-section{grid-column:1/-1;margin-top:24px}}@media (max-width:768px){h1{font-size:24px}.container{padding:12px}.flatpickr-calendar{max-width:320px!important}.flatpickr-calendar,.flatpickr-innerContainer{width:100%!important}.flatpickr-day{flex-basis:calc(14.28% - 2px)!important;padding:3px 0!important;font-size:12px!important}.form-group input.flatpickr-input,.form-group input[type=date]{padding:10px 12px!important;font-size:14px!important;height:44px!important}.dashboard-wrapper{display:block}.dashboard-left,.dashboard-right{display:contents}.export-section{display:block!important}.quick-actions-panel{display:none!important}.dashboard,.entries-section,.export-section,.instructions-section,.journal-form,.protocol-selector{padding:16px;margin-bottom:16px}.instruction-step{padding:10px}.instruction-step strong{font-size:14px}.instruction-step p{font-size:13px}.stats-grid{grid-template-columns:repeat(2,1fr)}.rating-group{grid-template-columns:1fr}.entry-ratings{grid-template-columns:repeat(3,1fr)}.export-actions{flex-direction:column}.export-actions .btn{width:100%}}@media (min-width:769px) and (max-width:1023px){.container{max-width:900px;padding:20px}.dashboard-wrapper{display:block}.dashboard-left,.dashboard-right{display:contents}.export-section{display:block!important}.quick-actions-panel{display:none!important}}.hidden{display:none!important}.journal-selector-view{display:none}.journal-selector-view.active{display:block}.journal-selector-view .container{max-width:1400px;padding:40px 24px}@media (min-width:1024px){.journal-selector-view .container{padding:60px 32px}}.journal-selector-header{text-align:center;margin-bottom:48px;padding:24px 0}.journal-selector-header h2{font-size:clamp(24px,5vw,36px);font-weight:700;background:linear-gradient(135deg,#a78bfa,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:12px;letter-spacing:-.5px}.journal-selector-header p{color:var(--text-dim);font-size:clamp(14px,2vw,18px);line-height:1.6}.journals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;margin-bottom:24px;max-width:1400px;margin-left:auto;margin-right:auto}@media (min-width:1024px){.journals-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:768px) and (max-width:1023px){.journals-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:767px){.journals-grid{grid-template-columns:1fr}}.journal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;cursor:pointer;transition:all .3s ease;position:relative;display:flex;flex-direction:column;min-height:280px;overflow:hidden}.journal-card:hover{background:var(--bg-card-hover);border-color:var(--accent);transform:translateY(-6px);box-shadow:0 12px 32px rgba(99,102,241,.25)}.journal-card>div[onclick]{display:flex;flex-direction:column;height:100%}.journal-card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px;flex:1}.journal-card-name{font-size:20px;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.3}.journal-card-protocol{font-size:12px;color:var(--text-dim);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.journal-card-stats{display:flex;gap:16px;margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.05)}.journal-card-stat{flex:1;text-align:center}.journal-card-stat-value{font-size:24px;font-weight:700;color:var(--accent);margin-bottom:6px;line-height:1}.journal-card-stat-label{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.journal-card-actions{display:flex;gap:8px}.journal-card-action-btn{width:32px;height:32px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px}.journal-card-action-btn:hover{background:rgba(255,255,255,.08)}.journal-card-action-btn.delete:hover{background:rgba(239,68,68,.15);border-color:var(--danger);color:var(--danger)}.create-journal-card,.create-journal-icon,.journal-card-action-btn{display:flex;align-items:center;justify-content:center}.create-journal-card{background:rgba(99,102,241,.08);border:2px dashed var(--accent);flex-direction:column;gap:16px;min-height:280px;border-radius:16px;transition:all .3s ease}.create-journal-card:hover{background:rgba(99,102,241,.15);transform:translateY(-6px);box-shadow:0 12px 32px rgba(99,102,241,.25);border-color:rgba(99,102,241,.8)}.create-journal-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--accent),var(--phase-3));border-radius:50%;font-size:32px;color:#fff;box-shadow:0 8px 20px rgba(99,102,241,.3)}.create-journal-text{font-size:18px;font-weight:600;color:var(--accent);text-align:center}.journal-empty-state{text-align:center;padding:80px 20px}.journal-empty-icon{font-size:64px;margin-bottom:16px;opacity:.3}.journal-empty-state h3{font-size:20px;color:var(--text);margin-bottom:8px}.journal-empty-state p{color:var(--text-dim);margin-bottom:24px}.journal-view{display:none}.journal-view.active{display:block}.back-to-journals-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:999px;color:var(--text);font-size:14px;font-weight:500;transition:all .2s ease;margin-bottom:16px;cursor:pointer}.back-to-journals-btn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2)}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.85);z-index:10000}.modal-overlay.active{display:flex!important;align-items:center!important;justify-content:center!important}.modal-overlay .modal{background:var(--bg-card)!important;border:1px solid rgba(255,255,255,.15)!important;border-radius:16px!important;padding:24px!important;max-width:700px!important;width:90%!important;max-height:90vh!important;height:auto!important;overflow-y:auto!important;box-shadow:0 25px 50px rgba(0,0,0,.8)!important;z-index:10001!important;display:block!important;margin:auto!important;flex-shrink:0!important}.modal-body,.modal-header{margin-bottom:20px}.modal-overlay .modal-header h3{font-size:20px!important;color:var(--text)!important;margin-bottom:6px!important;font-weight:700!important}.modal-overlay .modal-header p{font-size:13px!important;color:var(--text-dim)!important}.modal-overlay .modal.progress-trends-modal{max-width:1200px!important;width:90vw!important;overflow:hidden!important}.progress-trends-modal .modal-header{display:flex!important;align-items:flex-start!important;justify-content:space-between!important}.modal-footer{display:flex;gap:12px;justify-content:flex-end}.modal-overlay .modal-input{width:100%!important;background:rgba(255,255,255,.06)!important;border:2px solid var(--border)!important;border-radius:8px!important;color:var(--text)!important;font-size:14px!important;font-family:inherit!important;margin-bottom:16px!important;appearance:none!important;-webkit-appearance:none!important;-moz-appearance:none!important;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e8eaf0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")!important;background-repeat:no-repeat!important;background-position:right 12px center!important;background-size:20px!important;padding:12px 40px 12px 12px!important}.modal-overlay .modal-input:focus{outline:0!important;border-color:var(--accent)!important;background-color:rgba(255,255,255,.08)!important;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236366f1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")!important;background-repeat:no-repeat!important;background-position:right 12px center!important;background-size:20px!important;box-shadow:0 0 0 3px rgba(99,102,241,.1)!important}.modal-overlay .modal-input option{background:var(--bg-card)!important;color:var(--text)!important;padding:8px 4px!important}.modal-overlay .modal-input option:hover{background:rgba(99,102,241,.2)!important}.modal-overlay .modal-input option:checked{background:linear-gradient(rgba(99,102,241,.3),rgba(99,102,241,.3))!important;background-color:var(--accent)!important}.delete-warning,.modal-error-message{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3)}.modal-error-message{display:none;padding:12px 14px;border-radius:6px;color:#ef4444;font-size:13px;margin-top:12px;animation:slideDown .2s ease}.modal-error-message.show{display:block}.delete-warning{border-radius:8px;padding:12px 16px;margin-bottom:16px}.delete-warning-text{color:var(--danger);font-size:14px;font-weight:600;margin-bottom:4px}.delete-warning-subtext{color:var(--text-dim);font-size:13px}.modal-overlay .entry-modal{max-width:1200px!important;width:95%!important;max-height:95vh!important;padding:0!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}.modal-overlay .entry-modal .modal-header{padding:24px 24px 20px!important;border-bottom:1px solid var(--border);flex-shrink:0}.modal-overlay .entry-modal .entry-modal-body{padding:24px!important;overflow-y:auto!important;flex:1!important}.modal-overlay .entry-modal .entry-modal-body::-webkit-scrollbar,.modal-overlay .phase-progress-modal::-webkit-scrollbar,.progress-info-modal::-webkit-scrollbar{width:12px}.modal-overlay .entry-modal .entry-modal-body::-webkit-scrollbar-track,.modal-overlay .phase-progress-modal::-webkit-scrollbar-track,.progress-info-modal::-webkit-scrollbar-track{background:rgba(0,0,0,.2);border-radius:10px}.modal-overlay .entry-modal .entry-modal-body::-webkit-scrollbar-thumb,.modal-overlay .phase-progress-modal::-webkit-scrollbar-thumb,.progress-info-modal::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:10px;border:2px solid rgba(0,0,0,.2)}.modal-overlay .entry-modal .entry-modal-body::-webkit-scrollbar-thumb:hover,.modal-overlay .phase-progress-modal::-webkit-scrollbar-thumb:hover,.progress-info-modal::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.3)}.entry-modal .modal-footer{padding:20px 24px 24px!important;border-top:1px solid var(--border);flex-shrink:0}.add-entry-button{font-size:16px!important;padding:14px 28px!important}.modal-overlay .phase-progress-modal{max-width:1400px!important;width:95%!important;max-height:90vh!important;height:auto!important;overflow-y:auto!important}.phase-progress-modal .modal-header{display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:24px}.info-btn{background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.info-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);transform:scale(1.05)}.progress-mode-toggle{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.toggle-options{display:inline-flex;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:8px;padding:4px;gap:4px}.toggle-option{background:0 0;border:0;color:var(--text-dim);font-size:13px;font-weight:600;padding:6px 16px;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.toggle-option:hover{background:rgba(255,255,255,.06);color:var(--text)}.toggle-option.active{background:rgba(124,156,255,.2);color:#7c9cff}.progress-info-modal{max-width:900px!important;width:95%!important;max-height:90vh!important;overflow-y:auto!important}.info-section{color:var(--text)}.info-factor{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:20px}.info-factor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.info-factor-badge{padding:6px 14px;border-radius:999px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.info-factor-weight{color:var(--text-dim);font-size:13px;font-weight:600}.info-factor-description{color:var(--text);font-size:14px;line-height:1.6;margin-bottom:16px}.info-example{background:rgba(0,0,0,.2);border-left:3px solid rgba(124,156,255,.5);border-radius:6px;padding:12px 16px}.info-example-label{color:var(--text-dim);font-size:12px;text-transform:uppercase;font-weight:700;letter-spacing:.5px;margin-bottom:8px}.info-example-text{color:var(--text);font-size:14px;line-height:1.8}.info-example-text strong{color:#7c9cff}.info-final-calc{background:linear-gradient(135deg,rgba(124,156,255,.1)0,rgba(110,231,183,.1) 100%);border:2px solid rgba(124,156,255,.3);border-radius:12px;padding:24px;margin-top:24px}.info-final-header{color:var(--text);font-size:16px;font-weight:700;text-align:center;margin-bottom:20px}.info-final-formula{background:rgba(0,0,0,.3);border-radius:8px;padding:20px}.info-formula-line{display:flex;align-items:center;justify-content:center;gap:16px;margin:8px 0}.info-formula-item{color:var(--text);font-size:15px;font-weight:600}.info-formula-operator{color:#7c9cff;font-size:18px;font-weight:700}.info-formula-divider{height:2px;background:rgba(255,255,255,.2);margin:12px 0}.info-formula-equals,.info-formula-result{font-size:20px;font-weight:700;text-align:center}.info-formula-equals{color:#7c9cff;margin:12px 0}.info-formula-result{color:#6ee7b7}.phase-progress-body{overflow:visible}.phase-progress-content{display:flex;flex-direction:column;gap:20px}.phase-card{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:12px;padding:20px;transition:all .3s ease}.phase-card:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12)}.phase-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.phase-title-section{flex:1}.phase-badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.phase-badge.phase-1{background:rgba(124,156,255,.2);color:#7c9cff}.phase-badge.phase-2{background:rgba(110,231,183,.2);color:#6ee7b7}.phase-badge.phase-3{background:rgba(77,208,225,.2);color:#4dd0e1}.phase-badge.phase-4{background:rgba(251,191,36,.2);color:#fbbf24}.phase-badge.phase-5{background:rgba(236,72,153,.2);color:#ec4899}.phase-name{font-size:18px;font-weight:700;color:var(--text);margin-bottom:4px}.phase-description{font-size:13px;color:var(--text-dim)}.progress-ring{width:80px;height:80px;position:relative}.progress-ring-circle{fill:none;stroke:rgba(255,255,255,.1);stroke-width:8}.progress-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.progress-ring.phase-1 .progress-ring-fill{stroke:#7c9cff}.progress-ring.phase-2 .progress-ring-fill{stroke:#6ee7b7}.progress-ring.phase-3 .progress-ring-fill{stroke:#4dd0e1}.progress-ring.phase-4 .progress-ring-fill{stroke:#fbbf24}.progress-ring.phase-5 .progress-ring-fill{stroke:#ec4899}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:18px;font-weight:700;color:var(--text)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.metric{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:12px}.metric-label{font-size:12px;color:var(--text-dim);display:block;margin-bottom:6px}.metric-value{font-size:20px;font-weight:700;color:var(--text);display:block}.missing-days-badge{font-size:12px;font-weight:600;color:#fbbf24;background:rgba(251,191,36,.15);padding:4px 8px;border-radius:6px;margin-left:8px;white-space:nowrap}.view-missing-days-btn{background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:6px;padding:8px 12px;color:var(--text);font-size:13px;cursor:pointer;margin-top:12px;width:100%;transition:all .2s ease}.view-missing-days-btn:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}.missing-days-details{background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.3);border-radius:8px;padding:16px;margin-top:12px}.missing-days-header{font-size:13px;font-weight:700;color:var(--text);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.missing-days-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.missing-day-item{background:rgba(0,0,0,.2);border-left:3px solid rgba(251,191,36,.6);padding:8px 12px;border-radius:4px;font-size:13px;color:var(--text)}.missing-day-item.large-gap{border-left-color:#ef4444;background:rgba(239,68,68,.1)}.missing-days-tip{font-size:12px;color:var(--text-dim);font-style:italic;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}.metric-subtext{font-size:11px;color:var(--text-dim);margin-top:4px}.progress-bar{background:rgba(255,255,255,.08);height:6px;border-radius:3px;margin-top:8px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.progress-bar-fill.phase-1{background:#7c9cff}.progress-bar-fill.phase-2{background:#6ee7b7}.progress-bar-fill.phase-3{background:#4dd0e1}.progress-bar-fill.phase-4{background:#fbbf24}.progress-bar-fill.phase-5{background:#ec4899}.recommendation-box{background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.2);border-radius:8px;padding:16px;margin-top:16px}.recommendation-box.success{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.2)}.recommendation-box.warning{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.2)}.recommendation-box.info{background:rgba(59,130,246,.08);border-color:rgba(59,130,246,.2)}.recommendation-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px}.recommendation-text{font-size:13px;color:var(--text-dim);line-height:1.6}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;margin-top:8px}.status-badge.ready{background:rgba(16,185,129,.15);color:#10b981}.status-badge.in-progress{background:rgba(245,158,11,.15);color:#f59e0b}.status-badge.not-started{background:rgba(107,114,128,.15);color:#9ca3af}.supplement-compliance{margin-top:12px}.supplement-list-compact{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.supplement-tag{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:4px 8px;font-size:11px;color:var(--text-dim)}.no-data-phase,footer{text-align:center;padding:40px 20px;color:var(--text-dim)}footer{max-width:1280px;margin:0 auto;padding:40px 24px;font-size:14px;border-top:1px solid var(--border)}footer a{color:var(--accent);text-decoration:none;transition:color .2s ease}footer a:hover{color:var(--phase-3)}@media (max-width:768px){.journals-grid{grid-template-columns:1fr}.modal{padding:24px;width:95%}.entry-modal{width:100%!important;max-width:100%!important;height:100vh!important;max-height:100vh!important;border-radius:0!important}.add-entry-button{width:100%;max-width:300px}}