@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}:root{--bg-card:#ffffff;--bg-card-hover:#f8f9fa;--text:#2c3e50;--text-dim:#5a6c7d;--accent:#2a9d8f;--accent-hover:#248a7e;--border:#e2e8f0;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--phase-1:#3b6fa0;--phase-2:#2a9d8f;--phase-3:#1a8a9e;--phase-4:#b8860b;--phase-5:#6c5ba7}body.protocol-page{background:#f8f9fa}.page-hero{text-align:center}.page-hero .container{max-width:1200px;margin:0 auto}.page-hero-nav{margin-bottom:1.5rem}.page-hero h1{color:var(--white, #ffffff);-webkit-text-fill-color:var(--white, #ffffff);background:0 0;font-size:2.5rem;margin-bottom:.5rem}.page-hero .back-to-journals-btn{display:inline-block;color:rgba(255,255,255,.6);text-decoration:none;font-size:.9rem;background:0 0;border:0;cursor:pointer;transition:color .2s;padding:0;font-family:inherit}.page-hero .back-to-journals-btn:hover{color:#fff}.page-hero .protocol-title{color:rgba(255,255,255,.85);font-size:1.15rem;font-weight:600;margin-top:.25rem;margin-bottom:0}.page-hero .page-hero-subtitle{max-width:900px;margin:.75rem auto 0;font-size:1rem;color:rgba(255,255,255,.7);line-height:1.7}main .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(0,0,0,.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(42,157,143,.1);border:1px solid rgba(42,157,143,.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;background:rgba(0,0,0,.02);border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center;font-weight:500}.modal-overlay .protocol-option label{background:rgba(0,0,0,.02)!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(42,157,143,.15);border-color:var(--accent);color:var(--accent)}.modal-overlay .protocol-option input:checked+label{background:rgba(42,157,143,.2)!important;border-color:var(--accent)!important;color:var(--accent)!important}.chart-type-btn:hover,.protocol-option label:hover{background:rgba(0,0,0,.04)}.modal-overlay .protocol-option label:hover{background:rgba(0,0,0,.04)!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(0,0,0,.02);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(0,0,0,.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(0,0,0,.02);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(0,0,0,.02);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(0,0,0,.02);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:12px}.age-group-selector label:hover,.dose-toggle-group label:hover,.metric-toggle:hover,.rating-scale label:hover{background:rgba(0,0,0,.04)}.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(248,249,250,.98);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:#fff;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(0,0,0,.04);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(0,0,0,.05);border-color:var(--accent)}.chart-fullscreen-canvas{position:relative;min-height:600px;width:100%}.expand-chart-btn{background:rgba(0,0,0,.04);border:1px solid var(--border);color:var(--text-dim);padding:6px 12px;border-radius:6px;cursor:pointer;font-size: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;border-radius:6px;color:var(--text);font-size:12px;cursor:pointer}.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(0,0,0,.04);border:1px solid var(--border);color:var(--text-dim)}.reset-date-btn:hover,.reset-zoom-btn:hover{background:rgba(0,0,0,.05);color:var(--text)}.zoom-controls{display:flex;gap:8px;margin-top:12px}.reset-zoom-btn{padding:6px 12px;background:rgba(0,0,0,.04);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)}.date-input-group input[type=date],.form-group input[type=date],.form-group textarea{background:rgba(0,0,0,.02);border:1px solid var(--border)}.form-group input[type=date],.form-group select,.form-group textarea{width:100%;padding:12px;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(0,0,0,.02)!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(0,0,0,.04)!important;border-color:var(--accent)!important;outline:0;box-shadow:0 0 0 3px rgba(42,157,143,.1)!important}.flatpickr-input:hover,input.flatpickr-input:hover{background:rgba(0,0,0,.04)!important;border-color:rgba(42,157,143,.4)!important}.flatpickr-input::placeholder,.modal-overlay .modal-input::placeholder,input.flatpickr-input::placeholder{color:var(--text-dim)!important}.flatpickr-calendar{background:#fff!important;border:1px solid var(--border)!important;box-shadow:0 20px 60px rgba(0,0,0,.12)!important;border-radius:12px!important}.flatpickr-innerContainer{width:320px!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 var(--border)!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:#fff!important;color:var(--text)!important}.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month:hover{background:rgba(42,157,143,.1)!important;color:var(--text)!important}.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month.selected{background:var(--accent)!important;color:#fff!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(42,157,143,.08)!important;color:var(--text-dim)!important}.flatpickr-day{color:var(--text)!important;border-color:transparent!important;flex-basis:calc(14.28% - 2px)!important;padding:4px 0!important;height:auto!important;line-height:1.8!important;font-size:13px!important}.flatpickr-day:hover{background:rgba(42,157,143,.1)!important;border-color:transparent!important}.flatpickr-day.today{border-color:var(--accent)!important;background:rgba(42,157,143,.08)!important}.flatpickr-day.selected{background:var(--accent)!important;border-color:var(--accent)!important;color:#fff!important}.flatpickr-day.inRange{background:rgba(42,157,143,.1)!important;box-shadow:inset 0 0 0 1px rgba(42,157,143,.3)!important}.flatpickr-day.disabled{color:var(--text-dim)!important;opacity:.5}.flatpickr-time input{border:1px solid var(--border)!important}.flatpickr-time .flatpickr-hour,.flatpickr-time .flatpickr-minute,.flatpickr-time .flatpickr-second,.flatpickr-time input{background:rgba(0,0,0,.02)!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}.age-group-selector input[type=radio],.rating-scale input[type=radio]{display:none}.rating-scale label{flex:1;padding:8px;background:rgba(0,0,0,.02);border:1px solid var(--border);border-radius:6px;text-align:center;cursor:pointer;font-size:12px;transition:all .2s ease}.age-group-selector input:checked+label,.dose-toggle-group input:checked+label,.rating-scale input:checked+label{background:var(--accent);border-color:var(--accent);color:#fff}.copy-last-entry-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:rgba(42,157,143,.08);border:1px solid rgba(42,157,143,.25);border-radius:6px;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0;font-family:inherit}.copy-last-entry-btn:hover{background:rgba(42,157,143,.15);border-color:rgba(42,157,143,.4);transform:translateY(-1px)}.age-group-selector{display:flex;gap:4px}.age-group-selector label,.dose-toggle-group label{text-align:center;cursor:pointer;transition:all .2s ease}.age-group-selector label{flex:1;padding:10px 8px;font-size:13px;font-weight:500;color:var(--text)}.supplement-checklist{display:flex;flex-direction:column;gap:4px}.age-group-selector label,.supplement-dose-item{background:rgba(0,0,0,.02);border:1px solid var(--border);border-radius:6px}.supplement-dose-item{padding:10px 12px;margin-bottom:4px}.supplement-dose-check,.supplement-dose-header{display:flex;align-items:center}.supplement-dose-check{gap:8px;cursor:pointer;font-size:14px;margin:0;flex:1}.supplement-dose-check input[type=checkbox]{width:18px;height:18px;cursor:pointer}.supplement-dose-controls{margin-top:8px;display:flex;flex-direction:column;gap:6px}.dose-amount-row,.dose-custom-row{display:flex;align-items:center;gap:8px}.dose-row-label{font-size:11px;color:var(--text-dim);min-width:52px;flex-shrink:0}.dose-unit-label{font-weight:600;color:var(--text-dim)}.dose-toggle-group{display:flex;gap:3px;flex-wrap:wrap;flex:1}.dose-toggle-group input[type=radio]{display:none}.dose-toggle-group label{font-size:12px;white-space:nowrap}.dose-reference-text{font-size:12px;color:var(--text-dim);background:rgba(42,157,143,.08);padding:5px 10px;border-radius:5px;font-style:italic}.dose-toggle-group label,.supplement-custom-input{padding:5px 10px;background:rgba(0,0,0,.02);border:1px solid var(--border);border-radius:5px;color:var(--text)}.supplement-custom-input{flex:1;min-width:0;font-size:13px;font-family:inherit}.dose-input:focus,.supplement-custom-input:focus{outline:0;border-color:var(--accent);background:rgba(0,0,0,.04)}.dosage-input-group,.supplement-item{background:rgba(0,0,0,.02);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(42,157,143,.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(0,0,0,.04);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:14px;font-family:inherit}.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(0,0,0,.02);border:1px solid var(--border);border-radius:6px;transition:all .2s ease}.checkbox-container:hover{background:rgba(0,0,0,.04)}.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(0,0,0,.02);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:rgba(0,0,0,.04)}.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(0,0,0,.02);border:1px solid var(--border);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(0,0,0,.04);border-color:var(--accent);outline:0;box-shadow:0 0 0 3px rgba(42,157,143,.1)}.filter-group .flatpickr-input:hover,.filter-group input[type=date]:hover{background:rgba(0,0,0,.04);border-color:rgba(42,157,143,.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(0,0,0,.02);border:1px solid var(--border)}.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(0,0,0,.02);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(0,0,0,.04)}.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(0,0,0,.02);transition:all .2s ease}.entry-card{border:1px solid var(--border);border-radius:12px;padding:16px}.entry-actions button:hover,.entry-card:hover{background:rgba(0,0,0,.04)}.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 .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(0,0,0,.02);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(0,0,0,.04)}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:1000;padding:20px;overflow-y:auto}.modal.active{display:flex;align-items:center;justify-content:center}.modal-content{background:#fff;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){main .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){.journal-selector-view h1,.journal-view h1{font-size:24px}main .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){main .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,#1a3a5c,#2a9d8f);-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(42,157,143,.15)}.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 var(--border)}.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(0,0,0,.02);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px}.journal-card-action-btn:hover{background:rgba(0,0,0,.04)}.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(42,157,143,.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(42,157,143,.15);transform:translateY(-6px);box-shadow:0 12px 32px rgba(42,157,143,.15);border-color:rgba(42,157,143,.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(42,157,143,.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}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);z-index:10000}.modal-overlay.active{display:flex!important;align-items:center!important;justify-content:center!important}.modal-overlay .modal{background:#fff!important;border:1px solid var(--border)!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,.15)!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-y:auto!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(0,0,0,.04)!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='%232c3e50' 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(0,0,0,.04)!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='%232a9d8f' 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(42,157,143,.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(42,157,143,.1)!important}.modal-overlay .modal-input option:checked{background:linear-gradient(rgba(42,157,143,.2),rgba(42,157,143,.2))!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,.05);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(0,0,0,.15);border-radius:10px;border:2px solid rgba(0,0,0,.05)}.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(0,0,0,.25)}.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(0,0,0,.04);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(0,0,0,.06);border-color:rgba(0,0,0,.1);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,.04);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(0,0,0,.04);color:var(--text)}.toggle-option.active{background:rgba(42,157,143,.15);color:#2a9d8f}.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(0,0,0,.02);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,.04);border-left:3px solid rgba(42,157,143,.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:#2a9d8f}.info-final-calc{background:linear-gradient(135deg,rgba(42,157,143,.1)0,rgba(64,180,166,.1) 100%);border:2px solid rgba(42,157,143,.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,.06);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:#2a9d8f;font-size:18px;font-weight:700}.info-formula-divider{height:2px;background:rgba(0,0,0,.1);margin:12px 0}.info-formula-equals,.info-formula-result{font-size:20px;font-weight:700;text-align:center}.info-formula-equals{color:#2a9d8f;margin:12px 0}.info-formula-result{color:#40b4a6}.phase-progress-body{overflow:visible}.phase-progress-content{display:flex;flex-direction:column;gap:20px}.phase-card{background:rgba(0,0,0,.02);border:1px solid var(--border);border-radius:12px;padding:20px;transition:all .3s ease}.phase-card:hover{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}.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(59,111,160,.15);color:#3b6fa0}.phase-badge.phase-2{background:rgba(42,157,143,.15);color:#2a9d8f}.phase-badge.phase-3{background:rgba(26,138,158,.15);color:#1a8a9e}.phase-badge.phase-4{background:rgba(184,134,11,.15);color:#b8860b}.phase-badge.phase-5{background:rgba(108,91,167,.15);color:#6c5ba7}.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(0,0,0,.08);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:#3b6fa0}.progress-ring.phase-2 .progress-ring-fill{stroke:#2a9d8f}.progress-ring.phase-3 .progress-ring-fill{stroke:#1a8a9e}.progress-ring.phase-4 .progress-ring-fill{stroke:#b8860b}.progress-ring.phase-5 .progress-ring-fill{stroke:#6c5ba7}.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(0,0,0,.02);border:1px solid rgba(0,0,0,.04);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(0,0,0,.04);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(0,0,0,.05);border-color:rgba(0,0,0,.1)}.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,.04);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(0,0,0,.05)}.metric-subtext{font-size:11px;color:var(--text-dim);margin-top:4px}.progress-bar{background:rgba(0,0,0,.06);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:#3b6fa0}.progress-bar-fill.phase-2{background:#2a9d8f}.progress-bar-fill.phase-3{background:#1a8a9e}.progress-bar-fill.phase-4{background:#b8860b}.progress-bar-fill.phase-5{background:#6c5ba7}.recommendation-box{background:rgba(42,157,143,.08);border:1px solid rgba(42,157,143,.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(0,0,0,.04);border:1px solid rgba(0,0,0,.06);border-radius:6px;padding:4px 8px;font-size:11px;color:var(--text-dim)}.no-data-phase{text-align:center;padding:40px 20px;color:var(--text-dim)}@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}}