*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafafa;color:#4a4a4a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}.loading-container{align-items:center;display:flex;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#f96;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#f96,#f74);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #ff77444d;transform:translateY(-2px)}.btn-secondary{background:#f5f5f5;border:1px solid #e0e0e0;color:#4a4a4a}.btn-secondary:hover{background:#efefef}.btn-danger{background:#fcc;color:#c00}.btn-danger:hover{background:#ffb3b3}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1.5rem;transition:all .3s ease}.card:hover{box-shadow:0 4px 16px #00000014}.card-header{border-bottom:1px solid #f0f0f0;color:#2a2a2a;font-size:1.1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem}.input-group{margin-bottom:1.25rem}.input-label{color:#4a4a4a;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.input-field{border:1px solid #e0e0e0;border-radius:8px;font-size:.95rem;padding:.75rem;transition:all .3s ease;width:100%}.input-field:focus{border-color:#f96;box-shadow:0 0 0 3px #ff99661a;outline:none}.status-badge{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:500;padding:.35rem .75rem}.status-connected{background:#e6f4ea;color:#1e7e34}.status-disconnected{background:#f5f5f5;color:#6c757d}.status-abnormal{background:#ffe6e6;color:#c00}.status-normal{background:#e6f4ea;color:#1e7e34}@media (max-width:768px){.main-content{padding:1rem}}.header{background:#fff;box-shadow:0 2px 8px #0000000d;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:1rem 2rem}.header-logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f96,#f74);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:600}.header-nav{display:flex;gap:2rem}.nav-link{color:#6c757d;font-size:.95rem;font-weight:500;position:relative;text-decoration:none;transition:color .3s ease}.nav-link:hover{color:#f96}.nav-link.active{color:#f74}.nav-link.active:after{background:linear-gradient(135deg,#f96,#f74);border-radius:3px 3px 0 0;bottom:-1.2rem;content:"";height:3px;left:0;position:absolute;right:0}.header-user{align-items:center;display:flex;gap:.75rem}.user-email{background:#f5f5f5;border-radius:20px;color:#6c757d;font-size:.9rem;padding:.5rem 1rem}.logout-btn{background:#fcc;border:none;border-radius:20px;color:#c00;cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.logout-btn:hover{background:#ffb3b3;transform:translateY(-1px)}@media (max-width:768px){.header-container{flex-direction:column;gap:1rem;padding:1rem}.header-nav{flex-wrap:wrap;gap:1rem;justify-content:center}.nav-link.active:after{display:none}}.dashboard{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{margin-bottom:2rem}.dashboard-header h2{color:#2a2a2a;font-size:2rem;font-weight:600;margin-bottom:.5rem}.subtitle{color:#6c757d;font-size:1rem}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.card-link{color:#f74;font-size:.9rem;font-weight:500;text-decoration:none}.card-link:hover{color:#f96}.card-header{align-items:center;display:flex;justify-content:space-between}.integrations-list{display:flex;flex-direction:column;gap:1rem}.integration-item{align-items:center;background:#fafafa;border-radius:8px;display:flex;gap:1rem;padding:.75rem}.integration-icon{align-items:center;background:linear-gradient(135deg,#f96,#f74);border-radius:50%;color:#fff;display:flex;font-size:1.2rem;font-weight:600;height:40px;justify-content:center;width:40px}.integration-info{flex:1 1}.integration-name{color:#2a2a2a;font-weight:600;text-transform:capitalize}.integration-sync{color:#6c757d;font-size:.85rem;margin-top:.25rem}.health-metrics{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.metric-item{background:#fafafa;border-radius:8px;padding:1rem;text-align:center}.metric-label{color:#6c757d;font-size:.85rem;margin-bottom:.5rem;text-transform:capitalize}.metric-value{color:#2a2a2a;font-size:1.5rem;font-weight:600}.metric-unit{color:#6c757d;font-size:.9rem;margin-left:.25rem}.blood-tests-list{display:flex;flex-direction:column;gap:.75rem}.blood-test-item{align-items:center;background:#fafafa;border-radius:8px;display:flex;gap:1rem;padding:.75rem}.blood-test-date{color:#2a2a2a;font-weight:600;min-width:120px}.blood-test-lab{color:#6c757d;flex:1 1}.blood-test-markers{color:#6c757d;font-size:.85rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.stat-box{background:#fafafa;border-radius:8px;padding:1rem;text-align:center}.stat-number{color:#f74;font-size:2rem;font-weight:600}.stat-label{font-size:.85rem;margin-top:.25rem}.empty-state{color:#6c757d;font-style:italic;padding:2rem;text-align:center}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(3,1fr)}}.integrations-page{animation:fadeIn .5s ease-in}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.page-header h2{color:#2a2a2a;font-size:2rem;font-weight:600;margin-bottom:.5rem}.providers-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.provider-card{display:flex;flex-direction:column}.provider-header{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.provider-icon-large{align-items:center;border-radius:12px;color:#fff;display:flex;font-size:1.8rem;font-weight:600;height:60px;justify-content:center;width:60px}.provider-info h3{color:#2a2a2a;font-size:1.3rem;font-weight:600}.provider-sync{color:#6c757d;font-size:.85rem;margin-top:.25rem}.provider-status{margin-bottom:1rem}.provider-description{color:#6c757d;flex:1 1;font-size:.95rem;line-height:1.6;margin-bottom:1.5rem}.provider-actions{display:flex;gap:.75rem}.provider-actions button{flex:1 1}.instructions{color:#4a4a4a;line-height:1.8}.instructions ol{margin-left:1.5rem}.instructions li{margin-bottom:.75rem}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:1rem}.providers-grid{grid-template-columns:1fr}}.blood-tests-page{animation:fadeIn .5s ease-in}.blood-tests-layout{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:350px 1fr}.tests-list{display:flex;flex-direction:column;gap:1rem}.test-card{border:2px solid #0000;cursor:pointer;transition:all .3s ease}.test-card:hover{border-color:#f96}.test-card.selected{border-color:#f74;box-shadow:0 4px 16px #f743}.test-date{color:#2a2a2a;font-weight:600;margin-bottom:.5rem}.test-lab{color:#6c757d;font-size:.95rem;margin-bottom:.5rem}.test-markers-count{color:#f74;font-size:.85rem;font-weight:500}.test-details{min-height:400px}.test-info{margin-bottom:2rem}.info-row{border-bottom:1px solid #f0f0f0;display:flex;padding:.75rem 0}.info-label{color:#4a4a4a;font-weight:600;min-width:100px}.markers-section h3{color:#2a2a2a;font-size:1.2rem;font-weight:600;margin-bottom:1rem}.markers-list{display:flex;flex-direction:column;gap:1rem}.marker-item{background:#fafafa;border-left:4px solid #f74;border-radius:8px;padding:1rem}.marker-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.marker-name{color:#2a2a2a;font-size:1.05rem;font-weight:600}.marker-value{color:#f74;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.marker-range{color:#6c757d;font-size:.9rem;margin-bottom:.5rem}.marker-notes{color:#4a4a4a;font-size:.9rem;font-style:italic}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:500px;overflow-y:auto;padding:2rem;width:90%}.modal-content h3{color:#2a2a2a;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.input-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.modal-actions button{padding:.75rem 1.5rem}@media (max-width:968px){.blood-tests-layout{grid-template-columns:1fr}.test-details{min-height:auto}}.health-data-page{animation:fadeIn .5s ease-in}.filters-section{display:flex;gap:2rem;margin-bottom:2rem}.filter-group{flex:1 1}.filter-label{color:#4a4a4a;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.filter-select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.95rem;padding:.75rem;transition:all .3s ease;width:100%}.filter-select:focus{border-color:#f96;box-shadow:0 0 0 3px #ff99661a;outline:none}.stats-section{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{padding:1.5rem;text-align:center}.stat-label{color:#6c757d;font-size:.9rem;font-weight:500;margin-bottom:.75rem}.stat-value{color:#f74;font-size:2rem;font-weight:600}.stat-unit{color:#6c757d;font-size:1rem;margin-left:.25rem}.chart-container{margin-bottom:2rem}.chart-title{color:#2a2a2a;font-size:1.3rem;font-weight:600;margin-bottom:1.5rem;text-transform:capitalize}.chart-wrapper{height:400px;position:relative}.data-table h3{color:#2a2a2a;font-size:1.2rem;font-weight:600;margin-bottom:1rem}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:#fafafa}th{border-bottom:2px solid #e0e0e0;font-size:.9rem;font-weight:600;text-align:left}td,th{color:#4a4a4a;padding:1rem}td{border-bottom:1px solid #f0f0f0}tbody tr:hover{background:#fafafa}.provider-badge{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:500;padding:.35rem .75rem;text-transform:capitalize}.provider-fitbit{background:#00b0b926;color:#00848c}.provider-oura{background:#6772e526;color:#4952b8}.provider-clue{background:#ff5c8d26;color:#cc4971}.table-footer{color:#6c757d;font-size:.9rem;margin-top:1rem;text-align:center}@media (max-width:768px){.filters-section{flex-direction:column;gap:1rem}.stats-section{grid-template-columns:repeat(2,1fr)}.chart-wrapper{height:300px}table{font-size:.85rem}td,th{padding:.75rem .5rem}}.auth-container{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;justify-content:center;min-height:100vh;padding:2rem;pointer-events:auto}.auth-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;max-width:400px;padding:2.5rem;pointer-events:auto;width:100%}.auth-header{margin-bottom:2rem;text-align:center}.auth-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f96,#f74);-webkit-background-clip:text;background-clip:text;color:#2a2a2a;font-size:2rem;font-weight:700;margin-bottom:.5rem}.auth-subtitle{color:#6c757d;font-size:.95rem;margin:0}.auth-form{margin-bottom:1.5rem}.google-auth-btn{align-items:center;background:#fff;border:1px solid #dadce0;color:#3c4043;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;margin-top:1rem;padding:.875rem;transition:all .3s ease;width:100%}.google-auth-btn:hover{background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.google-icon{flex-shrink:0}.error-message{background:#ffe6e6;border:1px solid #fcc;border-radius:8px;color:#c00;font-size:.9rem;margin-bottom:1rem;padding:.75rem;text-align:center}.auth-toggle{border-top:1px solid #f0f0f0;padding-top:1rem;text-align:center}.auth-toggle p{color:#6c757d;font-size:.9rem;margin:0}.auth-toggle-btn{background:none;border:none;color:#f74;cursor:pointer;font-size:inherit;font-weight:600;margin-left:.5rem;text-decoration:underline}.auth-toggle-btn:hover{color:#f96}@media (max-width:480px){.auth-container{padding:1rem}.auth-card{padding:2rem 1.5rem}.auth-header h2{font-size:1.75rem}}
/*# sourceMappingURL=main.41d0fd69.css.map*/