.quest-lab-ordering{padding:var(--space-xl) 0}.quest-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);padding:var(--space-xl);background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.quest-logo{display:flex;gap:var(--space-lg);align-items:center}.quest-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:var(--radius-xl);box-shadow:0 4px 12px #3b82f64d;filter:brightness(1.2) contrast(1.1)}.quest-info h2{margin:0;font-size:var(--font-size-2xl);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.quest-info p{margin:var(--space-xs) 0 0 0;color:var(--text-secondary);font-size:var(--font-size-sm)}.order-form-section{display:grid;grid-template-columns:1fr 400px;gap:var(--space-xl)}.tests-selection h3{font-size:var(--font-size-2xl);margin-bottom:var(--space-sm)}.section-description{color:var(--text-secondary);margin-bottom:var(--space-xl)}.recommended-section{background:linear-gradient(135deg,#6366f10d,#4f46e50d);border:2px solid var(--color-primary);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-2xl);position:relative;overflow:hidden}.recommended-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-light) 100%)}.recommended-header{margin-bottom:var(--space-lg)}.recommended-header h3{font-size:var(--font-size-2xl);margin-bottom:var(--space-sm);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.recommended-tests{display:grid;gap:var(--space-md);margin-bottom:var(--space-lg)}.recommended-card{position:relative;border-color:var(--color-primary-light)!important;box-shadow:0 4px 12px #6366f126!important}.recommended-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.recommended-badge{position:absolute;top:var(--space-md);left:var(--space-md);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 8px #6366f14d;z-index:1}.recommended-card:hover{border-color:var(--color-primary)!important;box-shadow:0 6px 16px #6366f140!important}.btn-add-all{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);font-size:var(--font-size-base)}.test-category{margin-bottom:var(--space-2xl)}.category-name{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-primary)}.tests-grid{display:grid;gap:var(--space-md)}.test-card{background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all .2s ease}.test-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.test-card.selected{border-color:var(--color-primary);background:linear-gradient(135deg,#6366f10d,#4f46e50d);box-shadow:var(--shadow-md)}.test-header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.recommended-card .test-header{padding-top:calc(var(--space-md) + var(--space-xs))}.test-checkbox{width:24px;height:24px;border:2px solid var(--color-gray-300);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);color:#fff;flex-shrink:0;transition:all .2s ease}.test-card.selected .test-checkbox{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-color:var(--color-primary)}.test-info{flex:1;min-width:0}.test-info h5{margin:0 0 var(--space-xs) 0;font-size:var(--font-size-base);font-weight:600;color:var(--text-primary)}.test-code{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:500}.test-price{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);flex-shrink:0}.test-description{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-md);line-height:1.5}.test-details{display:flex;flex-wrap:wrap;gap:var(--space-md);font-size:var(--font-size-xs);color:var(--text-secondary)}.test-turnaround,.test-requirements{display:flex;align-items:center;gap:var(--space-xs)}.order-summary{position:sticky;top:var(--space-xl);background:var(--bg-primary);border:2px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--space-xl);height:fit-content;box-shadow:var(--shadow-lg)}.order-summary h3{margin:0 0 var(--space-lg) 0;font-size:var(--font-size-xl)}.selected-tests-list{border-bottom:2px solid var(--color-gray-200);padding-bottom:var(--space-md);margin-bottom:var(--space-md)}.summary-test{display:flex;justify-content:space-between;padding:var(--space-sm) 0;font-size:var(--font-size-sm)}.summary-total{display:flex;justify-content:space-between;padding:var(--space-md) 0;font-size:var(--font-size-lg);border-bottom:2px solid var(--color-gray-200);margin-bottom:var(--space-lg)}.scheduling-options,.form-group{margin-bottom:var(--space-lg)}.form-group label{display:block;font-weight:600;margin-bottom:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-primary)}.form-group input,.form-group select{width:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.btn-large{width:100%;padding:var(--space-lg);font-size:var(--font-size-base)}.orders-list h3{font-size:var(--font-size-2xl);margin-bottom:var(--space-xl)}.orders-grid{display:grid;gap:var(--space-lg)}.order-card{background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-xl);transition:all .3s ease}.order-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.order-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:2px solid var(--color-gray-200)}.order-header h4{margin:0 0 var(--space-xs) 0;font-size:var(--font-size-xl)}.order-date{font-size:var(--font-size-sm);color:var(--text-secondary)}.status-badge{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase}.status-scheduled{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.status-completed{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-cancelled{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.order-tests{margin-bottom:var(--space-lg)}.order-test{padding:var(--space-sm) 0;color:var(--text-secondary);font-size:var(--font-size-sm)}.order-details{display:flex;flex-direction:column;gap:var(--space-sm)}.order-detail{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.order-total{margin-top:var(--space-md);padding-top:var(--space-md);border-top:2px solid var(--color-gray-200);color:var(--text-primary);font-size:var(--font-size-lg)}.order-actions{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:2px solid var(--color-gray-200);display:flex;gap:var(--space-sm)}.order-actions .btn{flex:1}.empty-state{text-align:center;padding:var(--space-2xl);background:var(--bg-secondary);border-radius:var(--radius-lg)}.empty-state p{margin-bottom:var(--space-lg);color:var(--text-secondary);font-size:var(--font-size-lg)}@media (max-width: 1024px){.order-form-section{grid-template-columns:1fr}.order-summary{position:relative;top:0}}@media (max-width: 768px){.quest-header{flex-direction:column;gap:var(--space-lg);text-align:center}.quest-logo{flex-direction:column;text-align:center}}.health-product-explorer{margin:var(--space-2xl) 0;padding:var(--space-3xl);background:linear-gradient(135deg,#f0f9ff,#e0f2fe,#f8fafc);border-radius:24px;border:1px solid rgba(99,102,241,.1);box-shadow:0 10px 40px #0000000a,0 2px 8px #00000005;position:relative;overflow:hidden}.health-product-explorer:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(99,102,241,.05) 0%,transparent 70%);border-radius:50%;pointer-events:none}.health-product-explorer:after{content:"";position:absolute;bottom:-30%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(59,130,246,.04) 0%,transparent 70%);border-radius:50%;pointer-events:none}.explorer-header{text-align:center;margin-bottom:var(--space-3xl);position:relative;z-index:1}.explorer-header h2{font-size:2.5rem;font-weight:800;margin-bottom:var(--space-md);background:linear-gradient(135deg,#6366f1,#8b5cf6,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.explorer-header p{color:var(--text-secondary);font-size:1.125rem;max-width:700px;margin:0 auto;line-height:1.7;font-weight:400}.explorer-controls{margin-bottom:var(--space-3xl);position:relative;z-index:1}.search-box{margin-bottom:var(--space-xl);max-width:600px;margin-left:auto;margin-right:auto}.search-input{width:100%;padding:1rem 1.5rem;font-size:1rem;border:2px solid rgba(226,232,240,.8);border-radius:16px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}.search-input:hover{border-color:#6366f14d;background:#fff}.search-input:focus{outline:none;border-color:#6366f180;background:#fff;box-shadow:0 4px 20px #6366f11f,0 0 0 4px #6366f114;transform:translateY(-1px)}.search-input::placeholder{color:#64748b99}.category-filters{display:flex;gap:.375rem;flex-wrap:wrap;justify-content:center;margin-top:.75rem;margin-bottom:2rem}.category-chip{padding:.375rem .75rem;font-size:.75rem;font-weight:500;border:1px solid rgba(203,213,225,.5);border-radius:6px;background:#f8fafc99;color:#64748b;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:none}.category-chip:hover{border-color:#6366f14d;background:#ffffffe6;color:#6366f1}.category-chip.active{background:#6366f1;color:#fff;border-color:#6366f1}.category-chip.active:hover{background:#5558e3}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.5rem;margin-bottom:var(--space-xl);position:relative;z-index:1}.product-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.6);border-radius:20px;padding:1.75rem;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;display:flex;flex-direction:column;box-shadow:0 4px 12px #00000008,0 1px 3px #00000005;overflow:hidden;animation:fadeInUp .6s ease-out backwards}.product-card:nth-child(1){animation-delay:.05s}.product-card:nth-child(2){animation-delay:.1s}.product-card:nth-child(3){animation-delay:.15s}.product-card:nth-child(4){animation-delay:.2s}.product-card:nth-child(5){animation-delay:.25s}.product-card:nth-child(6){animation-delay:.3s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.product-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#cbd5e180,#94a3b880);transition:all .4s cubic-bezier(.4,0,.2,1)}.product-card:after{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(99,102,241,.03) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;pointer-events:none}.product-card:hover{border-color:#6366f14d;box-shadow:0 20px 40px #6366f11f,0 8px 16px #0000000f;transform:translateY(-6px)}.product-card:hover:before{background:linear-gradient(90deg,#6366f1,#8b5cf6);height:4px}.product-card:hover:after{opacity:1}.product-card.popular{border-color:#fbbf244d;background:linear-gradient(135deg,#fffffffa,#fefce8f2)}.product-card.popular:before{background:linear-gradient(90deg,#fbbf24,#f59e0b);height:4px}.popular-badge{position:absolute;top:1rem;right:1rem;padding:.375rem .875rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:999px;box-shadow:0 4px 12px #fbbf2466;animation:pulse-badge 3s ease-in-out infinite;z-index:10}@keyframes pulse-badge{0%,to{transform:scale(1);box-shadow:0 4px 12px #fbbf2466}50%{transform:scale(1.05);box-shadow:0 6px 16px #fbbf2480}}.product-image-container{width:100%;height:180px;margin-bottom:1.25rem;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#f8fafc,#f1f5f9);position:relative;z-index:1}.product-image{width:100%;height:100%;object-fit:cover;transition:transform .4s cubic-bezier(.4,0,.2,1)}.product-card:hover .product-image{transform:scale(1.05)}.product-header{margin-bottom:1rem}.product-header h3{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin-bottom:.625rem;letter-spacing:-.01em}.product-category{display:inline-block;padding:.375rem .75rem;font-size:.75rem;font-weight:600;background:linear-gradient(135deg,#6366f114,#8b5cf614);color:#6366f1;border-radius:8px;border:1px solid rgba(99,102,241,.15)}.product-description{color:var(--text-secondary);font-size:.9375rem;line-height:1.65;margin-bottom:1.25rem;flex-grow:1}.product-services{margin-bottom:1.25rem;padding:1rem;background:linear-gradient(135deg,#f8fafccc,#f1f5f9cc);border-radius:12px;border:1px solid rgba(226,232,240,.5)}.product-services strong{display:block;margin-bottom:.625rem;font-size:.8125rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.service-tags{display:flex;flex-wrap:wrap;gap:.5rem}.service-tag{display:inline-block;padding:.375rem .75rem;font-size:.8125rem;background:#fff;color:#64748b;border:1px solid rgba(226,232,240,.8);border-radius:6px;white-space:nowrap;transition:all .2s ease}.service-tag:hover{border-color:#6366f14d;color:#6366f1;background:#6366f10a}.product-actions{display:flex;gap:.75rem;margin-top:auto}.product-actions .btn{flex:1;text-align:center;text-decoration:none;display:inline-block;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid transparent}.product-actions .btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f14d}.product-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.no-results{text-align:center;padding:3rem 2rem;background:#fffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;border:2px dashed rgba(203,213,225,.6);position:relative;z-index:1}.no-results p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.125rem;font-weight:500}.no-results .btn-secondary{padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;border-radius:12px;background:#ffffffe6;color:#6366f1;border:2px solid rgba(99,102,241,.3);transition:all .3s ease}.no-results .btn-secondary:hover{background:#6366f114;border-color:#6366f180;transform:translateY(-2px)}.explorer-footer{margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(226,232,240,.6);position:relative;z-index:1}.disclaimer{font-size:.875rem;color:var(--text-secondary);line-height:1.7;padding:1.25rem 1.5rem;background:#ffffffb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;border-left:4px solid #6366f1;box-shadow:0 2px 8px #00000008}.disclaimer strong{color:#6366f1;display:block;margin-bottom:.5rem;font-weight:700;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}@media (max-width: 768px){.health-product-explorer{padding:1.5rem;border-radius:16px}.health-product-explorer:before,.health-product-explorer:after{display:none}.explorer-header h2{font-size:2rem}.explorer-header p{font-size:1rem}.products-grid{grid-template-columns:1fr;gap:1.25rem}.product-card{padding:1.5rem}.product-image-container{height:160px;margin-bottom:1rem}.category-filters{justify-content:flex-start;gap:.375rem}.category-chip{font-size:.6875rem;padding:.3125rem .625rem}.search-input{padding:.875rem 1.25rem;font-size:.9375rem}.product-actions .btn{padding:.75rem 1.25rem;font-size:.875rem}.no-results{padding:2rem 1.5rem}}.connections-page{padding:var(--space-xl) 0}.connections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg);margin-bottom:var(--space-2xl)}.connection-card{background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-xl);transition:all .3s ease;position:relative;overflow:hidden}.connection-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-light) 100%)}.connection-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.connection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.connection-header h3{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.status-badge{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.status-active{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.status-error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.org-name{color:var(--text-secondary);margin-bottom:var(--space-lg);font-weight:500;font-size:var(--font-size-sm)}.connection-details{margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.detail{display:flex;gap:var(--space-sm);margin-bottom:var(--space-sm);font-size:var(--font-size-sm)}.detail:last-child{margin-bottom:0}.detail .label{font-weight:700;color:var(--text-primary);min-width:80px}.connection-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg)}.add-connection-section{background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-sm)}.add-connection-section h2{margin-bottom:var(--space-lg);font-size:var(--font-size-2xl);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.vendor-buttons{display:flex;gap:var(--space-md);flex-wrap:wrap}.btn{padding:var(--space-md) var(--space-xl);border:2px solid transparent;border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--color-gray-200)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-200);border-color:var(--color-gray-300)}.btn-danger{background:linear-gradient(135deg,var(--color-danger) 0%,var(--color-danger-dark) 100%);color:#fff}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.clinical-timeline-container{position:relative;width:100%;background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;overflow:hidden;margin-bottom:20px}.timeline-controls{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom:1px solid rgba(255,255,255,.2)}.zoom-indicator{font-size:12px;font-weight:600;background:#fff3;padding:4px 10px;border-radius:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.timeline-instructions{font-size:11px;opacity:.9;font-weight:500}.timeline-scroll-wrapper{overflow-x:auto;overflow-y:hidden;background:#fff;cursor:grab}.timeline-scroll-wrapper:active{cursor:grabbing}.clinical-timeline-svg{display:block;min-height:400px}.timeline-tooltip{position:absolute;pointer-events:none;z-index:1000;background:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026,0 0 0 1px #0000000d;padding:12px;min-width:200px;max-width:300px;animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,calc(-100% - 5px))}to{opacity:1;transform:translate(-50%,-100%)}}.tooltip-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.tooltip-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;color:#fff;letter-spacing:.5px}.tooltip-date{font-size:12px;color:#64748b;font-weight:500}.tooltip-title{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:6px;line-height:1.4}.tooltip-value{font-size:13px;color:#475569;margin-bottom:4px;line-height:1.5}.tooltip-source{font-size:12px;color:#94a3b8;margin-top:6px;padding-top:6px;border-top:1px solid #f1f5f9;font-style:italic}.clinical-timeline-svg .x-axis path,.clinical-timeline-svg .x-axis line{stroke:#cbd5e1}.clinical-timeline-svg .x-axis text{fill:#64748b;font-size:12px}.clinical-timeline-svg .event-circle{transition:r .15s ease}.clinical-timeline-svg .event-circle:hover{filter:brightness(1.1)}@media (max-width: 768px){.clinical-timeline-container{margin-bottom:16px}.timeline-controls{flex-direction:column;gap:8px;align-items:flex-start;padding:8px 12px}.zoom-indicator{font-size:11px;padding:3px 8px}.timeline-instructions{font-size:10px}.clinical-timeline-svg{min-height:250px}.timeline-tooltip{max-width:200px;font-size:11px;padding:10px}.tooltip-title{font-size:13px}.tooltip-value{font-size:12px}}@media print{.timeline-controls{background:#667eea;-webkit-print-color-adjust:exact;print-color-adjust:exact}.clinical-timeline-container{box-shadow:none;border:1px solid #e2e8f0}.timeline-tooltip{display:none}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.timeline-settings-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;z-index:9999;width:90%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.modal-close-btn{width:32px;height:32px;border:none;background:transparent;color:#64748b;font-size:1.25rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.modal-close-btn:hover{background:#f1f5f9;color:#334155}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-section{margin-bottom:24px}.modal-section:last-child{margin-bottom:0}.modal-label{display:block;font-size:.875rem;font-weight:600;color:#475569;margin-bottom:10px}.modal-section .search-bar{position:relative;display:flex;align-items:center}.modal-section .search-icon{position:absolute;left:12px;font-size:1rem;opacity:.5;pointer-events:none}.modal-section .search-input{width:100%;padding:10px 14px 10px 38px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:all .15s ease}.modal-section .search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-section .view-mode-toggle{display:flex;gap:8px}.modal-section .view-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:500;color:#475569;cursor:pointer;transition:all .15s ease}.modal-section .view-mode-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.modal-section .view-mode-btn.active{background:#667eea;border-color:#667eea;color:#fff}.modal-section .view-mode-btn span:first-child{font-size:1.1rem}.modal-section .type-filters{display:flex;flex-wrap:wrap;gap:8px}.modal-section .filter-chip{padding:8px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.813rem;font-weight:500;color:#475569;cursor:pointer;transition:all .15s ease;text-transform:capitalize}.modal-section .filter-chip:hover{background:#f1f5f9;border-color:#cbd5e1}.modal-section .filter-chip.active{background:#667eea;border-color:#667eea;color:#fff}.modal-section .date-filter{display:flex;align-items:center;gap:12px}.modal-section .date-input{flex:1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#334155;transition:all .15s ease}.modal-section .date-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-section .date-separator{color:#94a3b8;font-weight:500}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e2e8f0}.clear-all-btn{padding:10px 18px;background:transparent;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:500;color:#ef4444;cursor:pointer;transition:all .15s ease}.clear-all-btn:hover{background:#fef2f2;border-color:#fecaca}.apply-btn{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;font-size:.875rem;font-weight:600;color:#fff;cursor:pointer;transition:all .15s ease}.apply-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}@media (max-width: 768px){.timeline-settings-modal{width:95%;max-height:90vh;border-radius:12px}.modal-header{padding:16px 20px}.modal-header h2{font-size:1.125rem}.modal-body{padding:20px}.modal-section{margin-bottom:20px}.modal-section .view-mode-toggle{flex-direction:column}.modal-section .view-mode-btn{width:100%}.modal-section .date-filter{flex-direction:column;gap:8px}.modal-section .date-input{width:100%}.modal-footer{padding:12px 20px;flex-direction:column}.clear-all-btn,.apply-btn{width:100%}}.timeline-page{padding:16px 0;max-width:1400px;margin:0 auto}.page-header .header-content{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:0 12px;margin-bottom:16px}.page-header .header-content h1{font-size:1.5rem;margin:0 0 4px}.page-header .header-content p{font-size:.875rem;margin:0;color:#64748b}.new-encounter-btn{display:flex;align-items:center;gap:.4rem;padding:10px 18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #667eea40;white-space:nowrap}.new-encounter-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.new-encounter-btn:active{transform:translateY(0)}.new-encounter-btn .btn-icon{font-size:1.25rem;line-height:1}.header-actions{display:flex;align-items:center;gap:10px;margin-left:auto}.settings-btn{position:relative;display:flex;align-items:center;gap:.4rem;padding:10px 18px;background:#fff;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #00000014;white-space:nowrap}.settings-btn:hover{background:#f8fafc;border-color:#cbd5e1;box-shadow:0 2px 6px #0000001f}.settings-btn:active{transform:scale(.98)}.settings-btn span:first-child{font-size:1.1rem;line-height:1}.filter-badge{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 6px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:10px;font-size:.688rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #00000026;border:2px solid white}.appointment-reminder-banner{margin:12px 0;padding:0 12px}.reminder-content{display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid rgba(102,126,234,.2);border-left:3px solid #667eea;border-radius:8px;box-shadow:0 1px 3px #0000000d;transition:all .2s ease}.reminder-content:hover{box-shadow:0 4px 12px #00000014;border-color:#667eea4d}.reminder-icon{font-size:1.75rem;flex-shrink:0}.reminder-details{flex:1}.reminder-title{font-size:.875rem;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.reminder-info{font-size:1rem;color:var(--text-primary);font-weight:500}.reminder-action-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.reminder-action-btn:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.reminder-action-btn:active{transform:translateY(0)}.visualization-container{margin-bottom:var(--space-3xl)}.visualization-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);padding:0 var(--space-md)}.visualization-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.visualization-toggle{display:flex;gap:.5rem;background:#f1f5f9cc;padding:.25rem;border-radius:12px;border:1px solid rgba(226,232,240,.8)}.toggle-btn{padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;border:none;background:transparent;color:#64748b;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.toggle-btn:hover{background:#fff9;color:#3b82f6}.toggle-btn.active{background:#fff;color:#3b82f6;box-shadow:0 2px 4px #0000000f}@media (max-width: 768px){.visualization-container{display:none}.visualization-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.visualization-header h2{font-size:1.25rem}.toggle-btn{padding:.5rem 1rem;font-size:.8125rem}}.timeline-controls{margin-bottom:16px;padding:0 12px;display:flex;flex-direction:column;gap:12px}.controls-toolbar{display:flex;gap:12px;align-items:center}.search-bar{flex:1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;font-size:1rem;opacity:.5;pointer-events:none}.search-input{width:100%;padding:10px 14px 10px 38px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.search-input::placeholder{color:var(--text-tertiary)}.view-mode-toggle{display:flex;gap:4px;background:#f8fafc;padding:4px;border-radius:8px;border:1px solid #e2e8f0}.view-mode-btn{display:flex;align-items:center;justify-content:center;padding:6px 12px;background:transparent;border:none;border-radius:6px;font-size:1.1rem;color:#64748b;cursor:pointer;transition:all .2s ease;min-width:40px}.view-mode-btn:hover{background:#e2e8f0}.view-mode-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a}.filter-bar{background:var(--bg-primary);border:1px solid #e2e8f0;border-radius:8px;padding:12px 14px}.filter-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.type-filters{display:flex;flex-wrap:wrap;gap:6px;flex:1}.filter-chip{padding:6px 12px;border:1px solid #e2e8f0;border-radius:6px;background:var(--bg-primary);cursor:pointer;transition:all .2s ease;font-size:.75rem;font-weight:600;color:var(--text-primary);text-transform:capitalize}.filter-chip:hover{border-color:#cbd5e1;background:#f8fafc}.filter-chip.active{border-color:var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary);font-weight:700}.date-filter{display:flex;align-items:center;gap:8px}.date-input{padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.8125rem;font-weight:500;transition:all .2s ease;background:var(--bg-primary);color:var(--text-primary);min-width:130px}.date-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.date-separator{color:#94a3b8;font-size:.875rem;font-weight:500}.clear-filters-btn{display:flex;align-items:center;justify-content:center;padding:6px;border:1px solid #e2e8f0;border-radius:6px;background:var(--bg-primary);color:#94a3b8;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:32px;height:32px}.clear-filters-btn:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.timeline-table-container{background:var(--bg-primary);border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014}.timeline-summary{padding:12px 16px;border-bottom:1px solid #e2e8f0;background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.result-count{font-weight:700;color:var(--text-secondary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em}.timeline-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.timeline-table thead{background:var(--bg-secondary);border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.timeline-table th{padding:10px 14px;text-align:left;font-weight:700;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.timeline-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease}.timeline-table th.sortable:hover{background:var(--color-gray-100);color:var(--color-primary)}.timeline-table th.sorted{color:var(--color-primary);font-weight:800}.sort-indicator{display:inline-block;font-size:var(--font-size-base);opacity:.6}.timeline-table th.col-type{width:120px}.timeline-table th.col-event{width:auto;min-width:250px}.timeline-table th.col-date{width:180px}.timeline-table th.col-value{width:150px}.timeline-table th.col-source{width:200px}.timeline-row{cursor:pointer;transition:all .2s ease;border-bottom:1px solid var(--color-gray-200);position:relative}.timeline-row:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-light) 100%);opacity:0;transition:opacity .3s ease}.timeline-row:hover{background:linear-gradient(135deg,#6366f108,#4f46e508);box-shadow:inset 0 0 0 1px var(--color-primary-light)}.timeline-row:hover:before{opacity:1}.timeline-row:last-child{border-bottom:none}.timeline-table td{padding:12px 14px;vertical-align:middle;font-size:.875rem}.cell-type .type-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--color-gray-100);color:var(--text-primary);transition:all .2s ease}.cell-event{font-weight:600;color:var(--text-primary)}.event-name{display:block;line-height:1.4}.cell-date .date-container{display:flex;flex-direction:column;gap:var(--space-xs)}.date-primary{font-weight:600;color:var(--text-primary);font-size:var(--font-size-sm)}.date-time{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:500}.cell-value .event-value{display:inline-block;font-weight:700;font-size:var(--font-size-base);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cell-source .source-name{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.timeline-row.lab .type-badge{background:linear-gradient(135deg,#3b82f626,#2563eb26);color:#2563eb}.timeline-row.med .type-badge{background:linear-gradient(135deg,#10b98126,#05966926);color:#059669}.timeline-row.allergy .type-badge{background:linear-gradient(135deg,#f59e0b26,#d9770626);color:#d97706}.timeline-row.condition .type-badge{background:linear-gradient(135deg,#8b5cf626,#7c3aed26);color:#7c3aed}.timeline-row.encounter .type-badge{background:linear-gradient(135deg,#06b6d426,#0891b226);color:#0891b2}.timeline-row.doc .type-badge{background:linear-gradient(135deg,#64748b26,#47556926);color:#475569}.timeline-row.vital .type-badge{background:linear-gradient(135deg,#ef444426,#dc262626);color:#dc2626}.timeline-row.activity .type-badge{background:linear-gradient(135deg,#ec489926,#db277726);color:#db2777}.timeline-row.sleep .type-badge{background:linear-gradient(135deg,#a855f726,#9333ea26);color:#9333ea}.timeline-row.nutrition .type-badge{background:linear-gradient(135deg,#f9731626,#ea580c26);color:#ea580c}.timeline-row.procedure .type-badge{background:linear-gradient(135deg,#06b6d426,#0891b226);color:#0891b2}@media (max-width: 1200px){.timeline-table th.col-source,.timeline-table td.cell-source{display:none}}@media (max-width: 900px){.timeline-table th.col-value,.timeline-table td.cell-value{display:none}.timeline-table th.col-event,.timeline-table td.cell-event{min-width:200px}}@media (max-width: 768px){.timeline-page{padding:12px 0}.page-header .header-content{flex-direction:column;align-items:flex-start;gap:12px}.page-header .header-content h1{font-size:1.25rem}.page-header .header-content p{font-size:.8125rem}.new-encounter-btn{width:100%;justify-content:center}.controls-toolbar{flex-direction:column;gap:8px}.view-mode-toggle{width:100%;justify-content:stretch}.view-mode-btn{flex:1}.filter-row{flex-direction:column;align-items:stretch;gap:10px}.type-filters{width:100%}.filter-chip{font-size:.6875rem;padding:5px 10px}.date-filter{width:100%}.date-input{flex:1;min-width:0}.clear-filters-btn{width:100%;height:auto;padding:8px}.timeline-table-container{border-radius:8px}.timeline-table{font-size:.8125rem}.timeline-table th,.timeline-table td{padding:10px 12px}.timeline-table th.col-value,.timeline-table td.cell-value{display:none}}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-secondary);background:var(--bg-primary);border-radius:var(--radius-lg);border:2px dashed var(--color-gray-300)}.empty-state p{font-size:var(--font-size-lg);font-weight:500}.timeline-row.lab:before{background:linear-gradient(180deg,#3b82f6,#2563eb)}.timeline-row.med:before{background:linear-gradient(180deg,#10b981,#059669)}.timeline-row.allergy:before{background:linear-gradient(180deg,#f59e0b,#d97706)}.timeline-row.condition:before{background:linear-gradient(180deg,#8b5cf6,#7c3aed)}.timeline-row.encounter:before,.timeline-row.procedure:before{background:linear-gradient(180deg,#06b6d4,#0891b2)}.timeline-row.doc:before{background:linear-gradient(180deg,#64748b,#475569)}.timeline-row.vital:before{background:linear-gradient(180deg,#ef4444,#dc2626)}.timeline-row.activity:before{background:linear-gradient(180deg,#ec4899,#db2777)}.timeline-row.sleep:before{background:linear-gradient(180deg,#a855f7,#9333ea)}.timeline-row.nutrition:before{background:linear-gradient(180deg,#f97316,#ea580c)}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-xl);border-top:2px solid var(--color-gray-200);background:var(--bg-secondary)}.pagination-btn{padding:var(--space-sm) var(--space-lg);border:2px solid var(--color-gray-300);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;border-color:var(--color-gray-200);color:var(--text-tertiary)}.pagination-info{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600;padding:0 var(--space-md);white-space:nowrap}@media (max-width: 768px){.pagination-controls{flex-direction:column;gap:var(--space-md);padding:var(--space-lg)}.pagination-btn{width:100%}}.new-encounter-page{max-width:1400px;margin:0 auto;padding:2rem}.page-header p{color:#6b7280;font-size:1rem;margin:0}.encounter-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}@media (max-width: 1024px){.encounter-grid{grid-template-columns:1fr}}.encounter-card{background:#fff;border:2px solid #e5e7eb;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px #0000000d;transition:all .2s;overflow:hidden}.encounter-card.full-width{grid-column:1 / -1}.encounter-card:hover{box-shadow:0 8px 12px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb;gap:1rem;flex-wrap:wrap;max-width:100%}.card-header h2{font-size:1.25rem;font-weight:600;margin:0;color:#111827;flex-shrink:0}.detecting-badge,.detected-badge,.verified-badge,.status-badge{font-size:.75rem;font-weight:600;padding:.375rem .75rem;border-radius:.375rem;text-transform:uppercase;letter-spacing:.05em}.detecting-badge{background:#fef3c7;color:#92400e;animation:pulse 2s infinite}.detected-badge,.verified-badge{background:#d1fae5;color:#065f46}.status-badge{background:#dbeafe;color:#1e40af}.status-checked-in{background:#d1fae5;color:#065f46}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-state p{color:#6b7280;margin:0}.facility-name{font-size:1.125rem;font-weight:600;color:#111827;margin-bottom:1rem}.facility-map{margin-bottom:1.25rem;position:relative}.facility-map iframe{width:100%;height:200px;border:2px solid #e5e7eb;border-radius:.5rem;display:block}.map-attribution{margin-top:.5rem;text-align:right}.view-larger-map{color:#667eea;font-size:.8125rem;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;transition:all .2s}.view-larger-map:hover{color:#764ba2;transform:translate(4px)}.facility-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;align-items:center;gap:.75rem;color:#4b5563;font-size:.9375rem}.detail-row .icon{font-size:1.25rem;flex-shrink:0}.appointment-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.appointment-item{display:flex;flex-direction:column;gap:.5rem}.appointment-item.full-width{grid-column:1 / -1}.item-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.item-value{color:#111827;font-weight:500}.primary-complaint{background:#f0f9ff;padding:.75rem;border-radius:.5rem;border-left:4px solid #0284c7;color:#0c4a6e;font-weight:500}.visit-timeline-compact{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e5e7eb}.timeline-header-compact{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.timeline-header-compact h4{font-size:.875rem;font-weight:600;color:#111827;margin:0}.timeline-subtitle{font-size:.75rem;color:#6b7280;font-style:italic}.timeline-mini-chart{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem}.chart-container{margin-bottom:.75rem}.chart-svg{width:100%;height:60px;display:block}.visit-markers{display:flex;justify-content:space-between;gap:.5rem}.visit-marker{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;min-width:0}.visit-marker.current{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:.375rem;padding:.375rem .25rem;border:1px solid #bae6fd}.marker-date{font-size:.6875rem;color:#6b7280;font-weight:500;white-space:nowrap}.marker-value{font-size:.875rem;font-weight:700;padding:.125rem .375rem;border-radius:.25rem}.marker-value.high{color:#dc2626;background:#fee}.marker-value.low{color:#ea580c;background:#ffedd5}.marker-value.normal{color:#10b981;background:#d1fae5}.marker-value.pending{color:#9ca3af;background:#f3f4f6}.marker-dose{font-size:.625rem;color:#6b7280;white-space:nowrap}.physician-card.full-width{padding:1.25rem}.physician-card.full-width .card-header{margin-bottom:1rem;padding-bottom:.875rem;border-bottom:1px solid #e5e7eb}.physician-card.full-width .card-header h2{font-size:1rem;font-weight:600;margin:0}.physician-card.full-width .card-content{display:grid;grid-template-columns:1fr 1.5fr;gap:1.5rem}@media (max-width: 1024px){.physician-card.full-width .card-content{grid-template-columns:1fr;gap:1.25rem}}.physician-info{display:flex;gap:1rem}.physician-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border:3px solid white;box-shadow:0 2px 4px #00000014}.avatar-photo{width:100%;height:100%;object-fit:cover}.avatar-initials{color:#fff;font-size:1.5rem;font-weight:700}.physician-details{flex:1;display:flex;flex-direction:column;gap:.5rem;min-width:0}.physician-name{font-size:1.125rem;font-weight:700;color:#111827;line-height:1.3;margin-bottom:.125rem}.physician-title{font-size:.875rem;font-weight:600;color:#667eea;line-height:1.4}.physician-specialty{font-size:.8125rem;color:#6b7280;line-height:1.4;margin-bottom:.5rem}.physician-stats{display:flex;gap:1rem;margin:.5rem 0;padding:.5rem 0;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.stat-item{display:flex;align-items:center;gap:.375rem}.stat-icon{font-size:1rem;opacity:.8}.stat-value{font-size:.8125rem;font-weight:600;color:#374151}.physician-credentials{display:grid;grid-template-columns:1fr;gap:.375rem;padding-top:.5rem}.credential-item,.contact-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#4b5563;line-height:1.4}.credential-icon,.contact-item .icon{font-size:.875rem;opacity:.7;flex-shrink:0}.physician-contact{display:flex;flex-direction:column;gap:.375rem;padding-top:.5rem}.physician-availability{padding:0;margin:0;border:none}.physician-card.full-width .physician-availability{padding-top:0;margin-top:0;border-top:none}.physician-availability h4{font-size:.875rem;font-weight:600;color:#111827;margin:0 0 .75rem;letter-spacing:.01em}.availability-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media (min-width: 1024px){.physician-card.full-width .availability-grid{grid-template-columns:1fr}}.availability-item{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem;transition:all .15s ease}.availability-item:hover{border-color:#667eea;box-shadow:0 1px 3px #667eea14;background:#fafbff}.availability-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.availability-icon{font-size:1rem;opacity:.8;flex-shrink:0}.availability-title{font-size:.8125rem;font-weight:600;color:#111827;flex:1;line-height:1.4}.availability-status{font-size:.6875rem;font-weight:600;padding:.1875rem .5rem;border-radius:.25rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.availability-status.online,.availability-status.available{background:#d1fae5;color:#065f46}.availability-status.offline,.availability-status.unavailable{background:#fee;color:#991b1b}.availability-info{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.5rem}.availability-detail{font-size:.75rem;color:#6b7280;flex:1;line-height:1.4}.contact-action-btn{padding:.4375rem .875rem;border:none;border-radius:.375rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap;letter-spacing:.01em}.contact-action-btn.messaging{background:#667eea;color:#fff}.contact-action-btn.messaging:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 2px 4px #667eea33}.contact-action-btn.call{background:#10b981;color:#fff}.contact-action-btn.call:hover{background:#059669;transform:translateY(-1px);box-shadow:0 2px 4px #10b98133}.contact-action-btn.video{background:#667eea;color:#fff}.contact-action-btn.video:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 2px 4px #667eea33}.scribe-card{background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #667eea}.scribe-top{margin-bottom:2rem}.recording-indicator{display:flex;align-items:center;gap:.5rem;background:#fee;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:600;color:#991b1b;flex-shrink:1;white-space:nowrap;min-width:0;max-width:100%;overflow:hidden}.recording-dot{width:10px;height:10px;background:#dc2626;border-radius:50%;animation:pulse-dot 1.5s infinite;flex-shrink:0}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.recording-duration{font-family:Courier New,monospace;flex-shrink:0}.recording-indicator>span:not(.recording-dot):not(.recording-duration){flex-shrink:1;overflow:hidden;text-overflow:ellipsis}.scribe-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem}.scribe-empty-state h3{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.scribe-empty-state p{color:#6b7280;margin:0 0 1.5rem;max-width:500px}.scribe-features{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:.5rem}.scribe-features li{color:#4b5563;font-size:.9375rem}.start-recording-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px #dc26264d}.start-recording-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #dc262666}.start-recording-btn:disabled{opacity:.5;cursor:not-allowed}.start-recording-btn .btn-icon{font-size:1.5rem}.btn-hint{margin-top:.75rem;font-size:.8125rem;color:#9ca3af;font-style:italic}.scribe-active-state{display:flex;flex-direction:column;gap:1.5rem}.transcript-container{background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;padding:1.5rem}.transcript-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.transcript-header h4{font-size:1rem;font-weight:600;color:#111827;margin:0}.transcript-info{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280}.transcript-lines{display:flex;flex-direction:column;gap:1.25rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.transcript-line{display:flex;flex-direction:column;gap:.5rem}.speaker-label{font-size:.875rem;font-weight:600;color:#667eea}.speaker-text{color:#374151;line-height:1.6;padding-left:1rem}.transcript-line.listening{flex-direction:row;align-items:center;gap:1rem;opacity:.7}.listening-indicator{display:flex;gap:.25rem;align-items:center}.listening-indicator .dot{width:6px;height:6px;background:#667eea;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.listening-indicator .dot:nth-child(1){animation-delay:-.32s}.listening-indicator .dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.listening-text{color:#6b7280;font-style:italic;font-size:.875rem}.recording-controls{display:flex;justify-content:center;padding-top:1rem}.stop-recording-btn,.save-encounter-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px #667eea4d}.stop-recording-btn:hover,.save-encounter-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.stop-recording-btn .btn-icon,.save-encounter-btn .btn-icon{font-size:1.5rem}.recording-stopped{display:flex;flex-direction:column;align-items:center;gap:1rem}.stopped-message{font-size:.875rem;color:#6b7280;font-style:italic}.lab-detail-page{padding:2rem 0}.lab-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.detail-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem}.detail-card h2{font-size:.875rem;text-transform:uppercase;color:#666;margin-bottom:1rem;font-weight:600}.value-display{display:flex;align-items:baseline;gap:.5rem}.value-number{font-size:2rem;font-weight:700;color:#2563eb}.value-unit{font-size:1rem;color:#666}.value-text{font-size:1.5rem;color:#374151}.subtext{font-size:.875rem;color:#666;margin-top:.25rem}.error{text-align:center;padding:3rem;color:#ef4444}.medication-detail-page{max-width:1200px;margin:0 auto;padding:2rem}.medication-header-info{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.med-code{font-size:.875rem;color:#6b7280;font-family:Monaco,Courier New,monospace}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-active{background:#d1fae5;color:#065f46}.status-completed{background:#dbeafe;color:#1e40af}.status-stopped{background:#fee2e2;color:#991b1b}.status-error{background:#fef3c7;color:#92400e}.status-unknown{background:#f3f4f6;color:#6b7280}.medication-details{display:grid;gap:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item .label{font-size:.875rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.info-item .value{font-size:1rem;color:#111827;font-weight:500}.dosage-instruction{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:1.5rem;margin-bottom:1rem}.dosage-instruction:last-child{margin-bottom:0}.dosage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.dosage-header h3{font-size:1.125rem;font-weight:600;margin:0;color:#111827}.timing-badge{background:#2563eb;color:#fff;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.dosage-content{display:flex;flex-direction:column;gap:1rem}.dosage-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.dosage-row:last-child{border-bottom:none}.dosage-row .label{font-weight:500;color:#6b7280}.dosage-row .value{color:#111827;font-weight:500}.dosage-details{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.dosage-details h4{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.timing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.timing-item{display:flex;flex-direction:column;gap:.25rem}.timing-item .label{font-size:.75rem;color:#6b7280}.timing-item .value{font-size:.875rem;color:#111827;font-weight:500}.dose-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.dose-info:last-child{margin-bottom:0}.dose-row{display:flex;justify-content:space-between;padding:.5rem 0}.dose-row .label{font-weight:500;color:#6b7280;font-size:.875rem}.dose-row .value{color:#111827;font-weight:500;font-size:.875rem}.patient-instruction{margin-top:1rem;padding:1rem;background:#fff;border:1px solid #d1d5db;border-radius:.375rem}.patient-instruction h4{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .5rem}.patient-instruction p{margin:0;color:#4b5563;line-height:1.6}.note-text{color:#4b5563;line-height:1.8;margin:0}.history-list{display:flex;flex-direction:column;gap:1rem}.history-item{display:flex;gap:1rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem}.history-date{font-weight:600;color:#111827;min-width:120px}.history-details{flex:1;display:flex;flex-direction:column;gap:.5rem}.history-note{margin:0;color:#4b5563;font-size:.875rem}.fhir-details{margin-top:.5rem}.fhir-summary{cursor:pointer;font-weight:500;color:#6b7280;padding:.5rem 0;-webkit-user-select:none;user-select:none}.fhir-summary:hover{color:#111827}.fhir-data{margin-top:1rem;padding:1rem;background:#1f2937;color:#e5e7eb;border-radius:.375rem;overflow-x:auto;font-family:Monaco,Courier New,monospace;font-size:.75rem;line-height:1.6}.encounter-detail-page{max-width:1200px;margin:0 auto;padding:2rem}.encounter-details{display:grid;gap:1.5rem}.event-list{display:flex;flex-direction:column;gap:.75rem}.event-item{display:flex;gap:1rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;transition:all .2s}.event-item.clickable{cursor:pointer}.event-item.clickable:hover{background:#f3f4f6;border-color:#d1d5db;transform:translate(4px)}.event-icon{font-size:1.5rem;flex-shrink:0}.event-content{flex:1}.event-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.5rem}.event-header h3{font-size:1rem;font-weight:600;margin:0;color:#111827}.event-date{font-size:.875rem;color:#6b7280}.event-value{font-size:.875rem;color:#4b5563;font-weight:500}.notes-list{display:flex;flex-direction:column;gap:1rem}.note-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem}.note-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.note-author{font-weight:600;color:#111827}.note-type{font-size:.875rem;color:#6b7280;background:#e5e7eb;padding:.25rem .5rem;border-radius:.25rem}.note-time{font-size:.875rem;color:#6b7280}.note-text{color:#374151;line-height:1.6;white-space:pre-wrap}.documents-list{display:flex;flex-direction:column;gap:.75rem}.document-item{display:flex;gap:1rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;transition:all .2s}.document-item.clickable{cursor:pointer}.document-item.clickable:hover{background:#f3f4f6;border-color:#d1d5db;transform:translate(4px);box-shadow:0 2px 4px #0000001a}.document-icon{font-size:2rem;flex-shrink:0}.document-content{flex:1}.document-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.5rem}.document-header h3{font-size:1rem;font-weight:600;margin:0;color:#111827}.document-date{font-size:.875rem;color:#6b7280}.document-description{font-size:.875rem;color:#6b7280;margin:.5rem 0}.document-meta{display:flex;gap:1rem;font-size:.75rem;color:#9ca3af;margin-top:.5rem}.empty-state{color:#6b7280;text-align:center;padding:2rem;font-style:italic}.procedure-list{list-style:none;padding:0;margin:0}.procedure-list li{padding:.75rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;margin-bottom:.5rem}.procedure-list li:last-child{margin-bottom:0}.procedure-info,.treatment-section,.findings-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.procedure-info h3,.treatment-section h3,.findings-section h3{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:#374151}.procedure-info p,.treatment-section p,.findings-section p{margin:0;color:#4b5563;line-height:1.6}.prescription-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.prescription-section h3{font-size:1rem;font-weight:600;margin:0 0 1rem;color:#374151}.rx-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.rx-column{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem}.rx-column h4{font-size:.875rem;font-weight:600;margin:0 0 .75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.rx-values{display:flex;flex-direction:column;gap:.5rem}.rx-values div{font-size:.875rem;color:#111827}.rx-values strong{color:#6b7280;margin-right:.5rem}.next-appointment{margin-top:1.5rem;padding:1rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:.375rem;color:#1e40af;font-size:.875rem}.ambient-scribe-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.ambient-scribe-badge{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.transcript-section{margin-bottom:2rem}.transcript-section h3{font-size:1rem;font-weight:600;color:#374151;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.conversation-summary{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-left:4px solid #0284c7;border-radius:.5rem;padding:1.25rem;margin-bottom:1.5rem}.conversation-summary h4{font-size:.875rem;font-weight:600;color:#0c4a6e;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.conversation-summary p{color:#0c4a6e;line-height:1.6;margin:0;font-size:.9375rem}.dialogue-container{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;max-height:500px;overflow-y:auto}.dialogue-entry{margin-bottom:1.5rem;display:flex;gap:1rem}.dialogue-entry:last-child{margin-bottom:0}.speaker-indicator{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600}.speaker-indicator.physician{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.speaker-indicator.patient{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.dialogue-content{flex:1}.speaker-name{font-weight:600;font-size:.875rem;color:#111827;margin-bottom:.25rem}.speaker-role{font-size:.75rem;color:#6b7280;margin-left:.5rem}.dialogue-text{color:#374151;line-height:1.6;font-size:.9375rem}.highlight-symptom{background:linear-gradient(120deg,#fef3c7,#fde68a);padding:.125rem .25rem;border-radius:.25rem;font-weight:500;border-bottom:2px solid #f59e0b}.highlight-medication{background:linear-gradient(120deg,#ddd6fe,#c4b5fd);padding:.125rem .25rem;border-radius:.25rem;font-weight:500;border-bottom:2px solid #8b5cf6}.highlight-vitals{background:linear-gradient(120deg,#fecaca,#fca5a5);padding:.125rem .25rem;border-radius:.25rem;font-weight:500;border-bottom:2px solid #ef4444}.highlight-test-order{background:linear-gradient(120deg,#bfdbfe,#93c5fd);padding:.125rem .25rem;border-radius:.25rem;font-weight:500;border-bottom:2px solid #3b82f6}.highlight-plan{background:linear-gradient(120deg,#bbf7d0,#86efac);padding:.125rem .25rem;border-radius:.25rem;font-weight:500;border-bottom:2px solid #10b981}.highlight-lifestyle{background:linear-gradient(120deg,#fed7aa,#fdba74);padding:.125rem .25rem;border-radius:.25rem;font-weight:500;border-bottom:2px solid #f97316}.highlight-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280}.legend-color{width:12px;height:12px;border-radius:.125rem}.highlights-section{margin-top:2rem;padding-top:2rem;border-top:2px solid #e5e7eb}.highlights-section h3{font-size:1rem;font-weight:600;color:#374151;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.highlights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.highlight-card{background:#fff;border:2px solid #e5e7eb;border-left:4px solid #667eea;border-radius:.5rem;padding:1rem;transition:all .2s}.highlight-card:hover{border-left-color:#764ba2;box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.highlight-label{font-size:.75rem;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.highlight-value{color:#111827;font-weight:500;line-height:1.5}.highlight-note{font-size:.8125rem;color:#6b7280;margin-top:.5rem;font-style:italic}.document-detail-page{max-width:1200px;margin:0 auto;padding:2rem}.back-button{background:#f3f4f6;border:1px solid #e5e7eb;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;margin-bottom:1rem;transition:background .2s}.back-button:hover{background:#e5e7eb}.document-details{display:grid;gap:1.5rem}.detail-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f3f4f6}.info-row .label{font-weight:500;color:#6b7280}.info-row span:last-child{color:#111827}.pdf-preview{margin-top:1rem}.pdf-placeholder{background:#f9fafb;border:2px dashed #d1d5db;border-radius:.5rem;padding:3rem;text-align:center;margin-bottom:2rem}.pdf-icon{font-size:4rem;margin-bottom:1rem}.pdf-text{font-size:1.25rem;font-weight:600;color:#111827;margin:.5rem 0}.pdf-subtext{color:#6b7280;font-size:.875rem;margin:.5rem 0}.pdf-size{color:#9ca3af;font-size:.75rem;margin:.5rem 0}.download-button{background:#2563eb;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;margin-top:1rem;transition:background .2s}.download-button:hover{background:#1d4ed8}.mock-document-content{background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:2rem;font-family:Georgia,Times New Roman,serif;line-height:1.8;color:#111827}.document-header-section{border-bottom:2px solid #e5e7eb;padding-bottom:1rem;margin-bottom:1.5rem}.document-header-section h3{font-size:1.5rem;margin:0 0 .5rem;color:#111827}.document-date-header{color:#6b7280;font-size:.875rem;margin:0}.document-source-header{color:#6b7280;font-size:.875rem;margin:.25rem 0 0}.lab-results-table{margin-top:1rem;border:1px solid #e5e7eb;border-radius:.375rem;overflow:hidden}.table-row{display:grid;grid-template-columns:2fr 1.5fr 1.5fr;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #f3f4f6}.table-row.header{background:#f9fafb;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.table-row span{color:#111827;font-size:.875rem}.plan-list{margin:.5rem 0;padding-left:1.5rem;color:#4b5563}.plan-list li{margin:.5rem 0;line-height:1.6}.document-section{margin-bottom:2rem}.document-section h4{font-size:1.125rem;font-weight:600;margin:0 0 .75rem;color:#374151;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.document-section p{margin:0;color:#4b5563;text-align:justify}.text-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem;max-height:600px;overflow-y:auto}.text-content{font-family:Monaco,Courier New,monospace;font-size:.875rem;line-height:1.6;color:#111827;margin:0;white-space:pre-wrap;word-wrap:break-word}.document-preview{margin-top:1rem}.preview-placeholder{background:#f9fafb;border:2px dashed #d1d5db;border-radius:.5rem;padding:3rem;text-align:center}.preview-icon{font-size:4rem;margin-bottom:1rem}.preview-placeholder p{font-size:1.125rem;font-weight:600;color:#111827;margin:.5rem 0}.preview-subtext{color:#6b7280;font-size:.875rem;margin:1rem 0}.fhir-metadata{margin-top:1rem}.nutrition-detail-page{max-width:1000px;margin:0 auto;padding:2rem}.back-button{background:transparent;border:1px solid #e5e7eb;color:#374151;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;margin-bottom:1rem;transition:all .2s}.back-button:hover{background:#f9fafb;border-color:#d1d5db}.detail-card h2{font-size:1.25rem;font-weight:600;margin:0 0 1rem;color:#111827;border-bottom:2px solid #e5e7eb;padding-bottom:.5rem}.calorie-summary{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.calorie-display{text-align:center}.calorie-main{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:.5rem}.calorie-value{font-size:3rem;font-weight:700;color:#059669}.calorie-unit{font-size:1.5rem;color:#6b7280}.calorie-goal{font-size:1rem;color:#6b7280;margin-bottom:.5rem}.calorie-remaining{font-size:1.125rem;font-weight:600;margin-bottom:1rem}.remaining-positive{color:#059669}.remaining-negative{color:#dc2626}.progress-bar{width:100%;height:12px;background-color:#e5e7eb;border-radius:6px;margin:.5rem 0;overflow:hidden}.progress-fill{height:100%;background-color:#059669;transition:width .3s ease;border-radius:6px}.progress-text{font-size:.875rem;color:#6b7280;margin-top:.5rem}.macros-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1rem}.macro-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem}.macro-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.macro-header h3{font-size:1rem;font-weight:600;margin:0;color:#374151}.macro-percent{font-size:.875rem;font-weight:600;color:#6b7280}.macro-value{font-size:1.5rem;font-weight:700;color:#111827;margin-bottom:.5rem}.macro-goal{font-size:.875rem;font-weight:400;color:#6b7280}.progress-fill.carbs{background-color:#f59e0b}.progress-fill.protein{background-color:#3b82f6}.progress-fill.fat{background-color:#8b5cf6}.progress-fill.water{background-color:#06b6d4}.macro-extras{display:flex;gap:2rem;padding-top:1rem;border-top:1px solid #e5e7eb;margin-top:1rem}.macro-extra-item{display:flex;gap:.5rem}.macro-extra-item .label{font-weight:500;color:#6b7280}.macro-extra-item .value{color:#111827}.meals-list{display:flex;flex-direction:column;gap:1rem}.meal-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem}.meal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.meal-header h3{font-size:1.125rem;font-weight:600;margin:0;color:#111827}.meal-calories{font-size:1rem;font-weight:600;color:#059669}.meal-macros{display:flex;gap:1rem;font-size:.875rem;color:#6b7280;margin-bottom:.75rem}.foods-list{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.food-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.food-item:last-child{border-bottom:none}.food-name{font-size:.875rem;color:#111827;font-weight:500}.food-quantity{font-weight:400;color:#6b7280;margin-left:.25rem}.food-macros{display:flex;gap:.75rem;font-size:.75rem;color:#6b7280}.food-calories{font-weight:600;color:#059669}.water-intake{background:linear-gradient(135deg,#ecfeff,#cffafe);border-color:#67e8f9}.water-display{text-align:center}.water-value{font-size:2.5rem;font-weight:700;color:#0891b2;margin-bottom:.5rem}.water-goal{font-size:1rem;color:#6b7280;margin-bottom:1rem}.allergy-detail-page{padding:var(--space-xl) 0}.page-header .header-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2xl)}.allergy-title{display:flex;gap:var(--space-lg);align-items:center}.category-icon{font-size:3rem;line-height:1}.allergy-title h1{font-size:var(--font-size-3xl);margin:0 0 var(--space-xs) 0}.allergy-date{color:var(--text-secondary);font-size:var(--font-size-sm);margin:0}.criticality-badge{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);color:#fff;font-weight:700;font-size:var(--font-size-sm);letter-spacing:.05em;white-space:nowrap}.allergy-details{display:grid;gap:var(--space-xl)}.detail-card{background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.detail-card h2{font-size:var(--font-size-xl);margin-bottom:var(--space-lg);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.identification-card{border-left:4px solid var(--color-primary)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg)}.detail-item{display:flex;flex-direction:column;gap:var(--space-xs)}.detail-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:var(--font-size-base);color:var(--text-primary);font-weight:500}.code-display{font-family:Courier New,monospace;background:var(--bg-secondary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);display:inline-block}.category-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-full)}.status-badge{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600}.status-active{background:#dcfce7;color:#166534}.status-inactive{background:#fee2e2;color:#991b1b}.reactions-card{border-left:4px solid #dc2626}.reaction-section{margin-bottom:var(--space-lg)}.reaction-section:last-child{margin-bottom:0}.severity-badge{display:inline-block;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:700;margin-bottom:var(--space-md)}.severity-severe{background:#fee2e2;color:#991b1b}.severity-moderate{background:#fed7aa;color:#9a3412}.severity-mild{background:#fef3c7;color:#92400e}.manifestations-list{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.manifestation-tag{display:inline-block;padding:var(--space-xs) var(--space-md);background:linear-gradient(135deg,#fef3c7,#fde68a);color:#78350f;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600}.reaction-description,.reaction-text{color:var(--text-secondary);line-height:1.6;margin:0}.no-data{color:var(--text-secondary);font-style:italic}.treatment-card{border-left:4px solid #16a34a}.treatment-notes{display:flex;flex-direction:column;gap:var(--space-md)}.note-section{padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.note-section p{margin:0;line-height:1.6;color:var(--text-primary)}.note-author{margin-top:var(--space-sm)!important;font-style:italic;color:var(--text-secondary);font-size:var(--font-size-sm)}.treatment-recommendations{display:flex;flex-direction:column;gap:var(--space-lg)}.recommendation-item{display:flex;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);transition:all .2s ease}.recommendation-item:hover{background:var(--color-gray-200);transform:translate(4px)}.recommendation-icon{font-size:1.5rem;flex-shrink:0}.recommendation-item strong{display:block;margin-bottom:var(--space-xs);color:var(--text-primary)}.recommendation-item p{margin:0;color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5}.source-card{border-left:4px solid #6366f1}.source-info{display:grid;gap:var(--space-md)}.source-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.source-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.source-value{font-size:var(--font-size-base);color:var(--text-primary);font-weight:500}.warning-banner{display:flex;gap:var(--space-lg);padding:var(--space-xl);background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:var(--radius-lg);margin-top:var(--space-2xl)}.warning-icon{font-size:2rem;flex-shrink:0}.warning-text strong{display:block;margin-bottom:var(--space-sm);color:#78350f;font-size:var(--font-size-lg)}.warning-text p{margin:0;color:#92400e;line-height:1.6}@media (max-width: 768px){.page-header .header-content{flex-direction:column;gap:var(--space-lg)}.criticality-badge{align-self:flex-start}.detail-grid{grid-template-columns:1fr}.allergy-title{flex-direction:column;text-align:center}.category-icon{font-size:2rem}}.personalized-supplements-section{background:#fff;border-radius:12px;padding:32px;margin-bottom:32px;box-shadow:0 2px 8px #00000014}.supplements-header{margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #f0f0f0}.header-content h2{margin:0 0 8px;font-size:1.75rem;color:#1a1a1a}.subtitle{margin:0;font-size:1rem;color:#666}.conditions-considered{margin-top:16px;padding:12px 16px;background:#f8f9fa;border-radius:8px;font-size:.875rem;color:#555}.conditions-considered strong{color:#1a1a1a;margin-right:8px}.priority-supplements,.additional-supplements{margin-bottom:32px}.section-title{display:flex;align-items:center;gap:12px;margin-bottom:20px;font-size:1.25rem;font-weight:600;color:#1a1a1a}.priority-badge,.additional-badge{display:inline-block;padding:4px 12px;border-radius:6px;font-size:.75rem;font-weight:700;letter-spacing:.5px}.priority-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.additional-badge{background:#e3f2fd;color:#1976d2}.supplements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,400px),1fr));gap:20px}.supplement-card{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:all .2s ease}.supplement-card:hover{border-color:#bbb;box-shadow:0 2px 12px #00000014}.supplement-main{padding:20px;flex:1}.supplement-name{margin:0 0 8px;font-size:1.125rem;font-weight:600;color:#1a1a1a}.supplement-dosage{font-size:.875rem;color:#666;margin:4px 0}.supplement-timing{font-size:.8125rem;color:#888;margin:2px 0 12px}.supplement-why{font-size:.9375rem;color:#444;line-height:1.5;margin:12px 0}.condition-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.condition-tag{display:inline-block;padding:4px 10px;background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:.75rem;font-weight:500}.marketplace-section{padding:16px 20px 20px;background:#f8f9fa;border-top:1px solid #e0e0e0}.marketplace-label{font-size:.875rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.marketplace-vendors{display:flex;flex-direction:column;gap:8px;margin-top:12px}.vendor-link{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;text-decoration:none;color:inherit;transition:all .15s ease}.vendor-link:hover{border-color:#bbb;background:#fafafa}.vendor-link.popular{border-color:#667eea;background:#f8f9ff}.vendor-name{font-size:.9375rem;font-weight:500;color:#1a1a1a;margin:0;flex:1}.vendor-price{font-size:.875rem;color:#666;margin:0;font-weight:500;white-space:nowrap}.popular-badge{padding:3px 8px;background:#667eea;color:#fff;border-radius:4px;font-size:.625rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.supplements-footer{margin-top:32px;padding-top:24px;border-top:2px solid #f0f0f0}.disclaimer{padding:16px;background:#fff3e0;border-left:4px solid #f57c00;border-radius:8px;margin-bottom:24px;font-size:.875rem;color:#444;line-height:1.6}.disclaimer strong{color:#e65100}.next-steps{padding:16px;background:#f8f9fa;border-radius:8px;font-size:.9375rem}.next-steps strong{display:block;margin-bottom:12px;color:#1a1a1a;font-weight:600}.next-steps ol{margin:0;padding-left:20px}.next-steps li{margin-bottom:8px;color:#444;line-height:1.6}@media (max-width: 768px){.personalized-supplements-section{padding:20px}.supplements-grid{grid-template-columns:1fr}.supplement-main{padding:16px}.marketplace-section{padding:12px 16px 16px}.vendor-link{padding:10px 12px;flex-wrap:wrap}.vendor-name{font-size:.875rem}.vendor-price{font-size:.8125rem}.popular-badge{font-size:.5625rem;padding:2px 6px}}.insights-page{max-width:1200px;margin:0 auto;padding:2rem}.insights-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.insight-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;box-shadow:0 1px 3px #0000001a;transition:all .2s}.insight-card:hover{box-shadow:0 2px 8px #00000026}.insight-card.insight-important{border-left:4px solid #dc2626}.insight-card.insight-opportunity{border-left:4px solid #059669}.insight-card.insight-pattern{border-left:4px solid #2563eb}.insight-card.insight-recommendation{border-left:4px solid #7c3aed}.insight-card.insight-warning{border-left:4px solid #f59e0b}.insight-header{display:flex;align-items:start;gap:.75rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #f3f4f6}.insight-icon{font-size:1.5rem;flex-shrink:0}.insight-title-section{flex:1}.insight-category{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:.25rem}.insight-title-section h2{font-size:1.125rem;font-weight:600;margin:0;color:#111827;line-height:1.3}.insight-impact{padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.impact-high{background:#fee2e2;color:#991b1b}.impact-medium{background:#fef3c7;color:#92400e}.impact-low{background:#e0f2fe;color:#0369a1}.insight-description{margin-bottom:.75rem}.insight-description p{color:#4b5563;line-height:1.5;margin:0;font-size:.875rem}.insight-content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem;margin-bottom:.75rem}.insight-summary-compact{background:#f0f9ff;border:1px solid #bfdbfe;border-radius:.375rem;padding:.75rem;grid-column:1 / -1}.insight-summary-compact h4{font-size:.875rem;font-weight:600;margin:0 0 .5rem;color:#1e40af}.insight-summary-compact p{color:#1e3a8a;line-height:1.5;margin:0;font-size:.8125rem}.insight-visits-compact{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:.75rem}.visits-header-compact{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.visits-header-compact h4{font-size:.875rem;font-weight:600;margin:0;color:#374151}.timeline-badge{font-size:.75rem;padding:.25rem .5rem;background:#e5e7eb;border-radius:.25rem;color:#6b7280}.visits-timeline-compact{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.visit-item-compact{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#fff;border-radius:.25rem;font-size:.8125rem}.visit-date-compact{font-weight:600;color:#111827;min-width:60px}.visit-info-compact{flex:1;display:flex;justify-content:space-between;align-items:center}.visit-provider-compact{color:#6b7280}.status-badge-compact{padding:.125rem .375rem;border-radius:.25rem;font-size:.6875rem;font-weight:500;text-transform:capitalize}.status-badge-compact.status-ongoing{background:#fef3c7;color:#92400e}.visit-pattern-compact{font-size:.75rem;color:#6b7280;font-style:italic;padding-top:.5rem;border-top:1px solid #e5e7eb}.insight-chart-compact{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:.75rem}.insight-chart-compact h4{font-size:.875rem;font-weight:600;margin:0 0 .5rem;color:#374151}.chart-container-compact{height:80px;margin-bottom:.5rem}.chart-meta{display:flex;justify-content:space-between;font-size:.75rem;color:#6b7280}.macro-bars{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.macro-bar-item{display:flex;flex-direction:column;gap:.25rem}.macro-label{font-size:.75rem;color:#6b7280}.macro-bar{position:relative;height:20px;background:#f3f4f6;border-radius:.25rem;overflow:hidden}.macro-fill{height:100%;border-radius:.25rem;transition:width .3s}.macro-value{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:600;color:#111827}.bmi-indicator{margin-bottom:.5rem}.bmi-value{font-size:1.5rem;font-weight:700;color:#111827;text-align:center;margin-bottom:.5rem}.bmi-scale{width:100%}.bmi-range{display:flex;justify-content:space-between;font-size:.6875rem;color:#6b7280;margin-bottom:.25rem}.bmi-bar{position:relative;height:20px;display:flex;border-radius:.25rem;overflow:hidden}.bmi-normal{background:#10b981}.bmi-overweight{background:#f59e0b}.bmi-obese{background:#ef4444}.bmi-marker{position:absolute;top:-4px;width:3px;height:28px;background:#111827;transform:translate(-50%)}.bp-display{text-align:center;margin-bottom:.5rem}.bp-value-large{font-size:1.75rem;font-weight:700;color:#dc2626;margin-bottom:.25rem}.bp-target{font-size:.75rem;color:#6b7280}.bp-status-warning{font-size:.75rem;color:#dc2626;text-align:center;padding:.5rem;background:#fee2e2;border-radius:.25rem}.insight-bottom-section{display:grid;grid-template-columns:2fr 1fr;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.insight-next-steps-compact{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.375rem;padding:.75rem}.insight-next-steps-compact h4{font-size:.875rem;font-weight:600;margin:0 0 .5rem;color:#166534}.steps-grid-compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}.step-item-compact{background:#fff;border:1px solid #bbf7d0;border-radius:.25rem;padding:.5rem;display:flex;align-items:start;gap:.5rem;position:relative}.step-item-compact.priority-high{border-left:3px solid #dc2626}.step-item-compact.priority-medium{border-left:3px solid #f59e0b}.step-item-compact.priority-low{border-left:3px solid #6b7280}.step-number-compact{background:#059669;color:#fff;width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.6875rem;flex-shrink:0}.step-content-compact{flex:1}.step-text{color:#374151;line-height:1.4;font-size:.8125rem;margin-bottom:.25rem}.step-timeframe-compact{font-size:.6875rem;color:#6b7280;font-style:italic}.step-priority-badge{width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.6875rem;flex-shrink:0}.step-priority-badge.priority-high{background:#fee2e2;color:#991b1b}.step-priority-badge.priority-medium{background:#fef3c7;color:#92400e}.step-priority-badge.priority-low{background:#e5e7eb;color:#6b7280}.insight-data-compact{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:.75rem}.data-grid-compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.data-point-compact{display:flex;flex-direction:column;gap:.125rem}.data-label-compact{font-size:.6875rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.data-value-compact{font-size:.875rem;font-weight:600;color:#111827}.data-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.data-value{font-size:.875rem;color:#111827;font-weight:500}.insight-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.insight-action-btn{background:#2563eb;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s;text-decoration:none;display:inline-block}.insight-action-btn:hover{background:#1d4ed8}.insight-share-btn{background:#059669;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s;margin-left:.5rem}.insight-share-btn:hover{background:#047857}.share-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.share-modal{background:#fff;border-radius:.75rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.share-modal-header h3{font-size:1.25rem;font-weight:600;margin:0;color:#111827}.share-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .2s}.share-modal-close:hover{background:#f3f4f6}.share-modal-description{color:#6b7280;font-size:.875rem;margin-bottom:1.5rem;line-height:1.6}.share-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.share-option{display:flex;align-items:start;gap:1rem;padding:1rem;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;transition:all .2s}.share-option:hover,.share-option.active{border-color:#2563eb;background:#eff6ff}.share-option-icon{font-size:1.5rem;flex-shrink:0}.share-option-content{flex:1}.share-option-content h4{font-size:1rem;font-weight:600;margin:0 0 .25rem;color:#111827}.share-option-content p{font-size:.875rem;color:#6b7280;margin:0}.share-summary-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem}.share-summary-preview h4{font-size:.875rem;font-weight:600;margin:0 0 .75rem;color:#374151}.summary-preview-content{background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:.75rem;max-height:150px;overflow-y:auto}.summary-preview-content pre{font-family:Courier New,monospace;font-size:.75rem;line-height:1.5;margin:0;color:#374151;white-space:pre-wrap;word-wrap:break-word}.share-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb}.share-cancel-btn{background:#fff;color:#374151;border:1px solid #d1d5db;padding:.625rem 1.25rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.share-cancel-btn:hover{background:#f9fafb}.share-confirm-btn{background:#2563eb;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.share-confirm-btn:hover{background:#1d4ed8}.empty-state{text-align:center;padding:4rem 2rem;color:#6b7280}.empty-state p{font-size:1.125rem;margin:.5rem 0}.insights-footer{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;margin-top:3rem}.insights-footer h3{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:#374151}.insights-footer p{font-size:.875rem;color:#6b7280;line-height:1.6;margin:0}.loading{text-align:center;padding:3rem;font-size:1.125rem;color:#6b7280}.supplements-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.75rem;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a}.supplements-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.supplements-title h2{color:#fff;font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.supplements-title p{color:#ffffffe6;font-size:.95rem;margin:0}.btn-get-recommendations{background:#fff;color:#667eea;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000001a}.btn-get-recommendations:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.btn-get-recommendations:disabled{opacity:.6;cursor:not-allowed}.supplements-content{background:#fff;border-radius:.5rem;padding:1.5rem;margin-top:1rem}.supplements-loading{text-align:center;padding:3rem 1rem}.loading-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.supplements-loading p{color:#6b7280;font-size:1rem}.supplements-recommendations{animation:fadeIn .5s ease-in}.personalization-info{background:linear-gradient(to right,#f0f9ff,#e0f2fe);border-left:4px solid #667eea;padding:1rem 1.25rem;border-radius:.375rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.personalization-info strong{display:block;color:#4338ca;font-size:1.05rem;margin-bottom:.75rem}.personalization-details{display:flex;flex-direction:column;gap:.5rem}.personalization-details p{margin:0;color:#374151;line-height:1.5;font-size:.9rem}.personalization-details .label{font-weight:600;color:#1e40af}.recommendations-text{line-height:1.8;color:#374151}.supplement-heading{font-size:1.25rem;font-weight:700;color:#111827;margin:1.5rem 0 .75rem;padding-top:1rem;border-top:2px solid #e5e7eb}.supplement-heading:first-child{margin-top:0;padding-top:0;border-top:none}.supplement-subheading{font-size:1.1rem;font-weight:600;color:#1f2937;margin:1rem 0 .5rem}.supplement-item{margin:.75rem 0;padding:1rem;background:#f9fafb;border-left:3px solid #667eea;border-radius:.25rem;font-weight:500;color:#1f2937}.supplement-bullet{margin:.5rem 0 .5rem 1.5rem;color:#4b5563;line-height:1.6}.supplement-paragraph{margin:.75rem 0;color:#4b5563;line-height:1.7}.supplements-disclaimer{background:#fef3c7;border:1px solid #fbbf24;border-radius:.5rem;padding:1rem;margin-top:1.5rem;font-size:.9rem;color:#92400e;line-height:1.6}.supplements-disclaimer strong{display:block;margin-bottom:.25rem;font-size:1rem}.btn-refresh-recommendations{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.95rem;font-weight:600;cursor:pointer;margin-top:1rem;transition:background .2s}.btn-refresh-recommendations:hover{background:#5568d3}.supplements-error{text-align:center;padding:2rem;color:#dc2626}.supplements-error p{margin-bottom:1rem}.btn-retry{background:#dc2626;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-retry:hover{background:#b91c1c}.clinical-trials-section-insights{background:linear-gradient(135deg,#06b6d4,#3b82f6);border-radius:.75rem;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a}.section-header-insights{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-title-insights h2{color:#fff;font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.section-title-insights p{color:#ffffffe6;font-size:.95rem;margin:0}.section-content-insights{background:#fff;border-radius:.5rem;padding:1.5rem;margin-top:1rem}.section-loading{text-align:center;padding:3rem 1rem}.section-loading p{color:#6b7280;font-size:1rem}.section-error{text-align:center;padding:2rem;color:#dc2626}.section-error p{margin-bottom:1rem}.trials-recommendations{animation:fadeIn .5s ease-in}.trials-status-message{background:#dbeafe;border:1px solid #3b82f6;padding:.875rem;border-radius:.375rem;margin-bottom:1rem;color:#1e40af;font-weight:500;text-align:center}.trials-match-info{background:linear-gradient(to right,#e0f2fe,#dbeafe);border-left:4px solid #0284c7;padding:1rem 1.25rem;border-radius:.375rem;margin-bottom:1.5rem;color:#0c4a6e;box-shadow:0 1px 3px #0000001a}.trials-match-info strong{display:block;margin-bottom:.5rem;font-size:1.05rem;color:#075985}.trials-match-info p{margin:.25rem 0;line-height:1.6}.trials-search-note{font-size:.875rem;color:#0369a1;margin-top:.5rem!important;font-style:italic}.trials-grid-compact{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:1rem}.trial-card-compact{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;cursor:pointer;transition:all .2s}.trial-card-compact:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a;border-color:#3b82f6}.trial-card-header{margin-bottom:.75rem}.trial-card-header h4{font-size:1rem;font-weight:600;color:#111827;margin:0 0 .5rem;line-height:1.4}.trial-badges-compact{display:flex;flex-wrap:wrap;gap:.25rem}.badge-compact{padding:.125rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.status-recruiting{background-color:#d4edda;color:#155724}.status-not-yet-recruiting{background-color:#fff3cd;color:#856404}.phase-badge-compact{background-color:#e7e7ff;color:#4a4ae6}.trial-match-compact{background:#e0f2fe;color:#0369a1;padding:.5rem;border-radius:.25rem;font-size:.85rem;font-weight:500;margin-bottom:.5rem;border-left:2px solid #0284c7}.match-reason-item{padding:.125rem 0;line-height:1.4}.trial-conditions-compact{color:#6b7280;font-size:.85rem;margin-bottom:.5rem;font-weight:500}.trial-summary-compact{color:#4b5563;font-size:.875rem;line-height:1.5;margin:.5rem 0}.trial-footer-compact{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;margin-top:.75rem;border-top:1px solid #e5e7eb}.trial-id-compact{font-size:.75rem;color:#9ca3af;font-family:monospace}.btn-view-trial{background:#3b82f6;color:#fff;border:none;padding:.375rem .75rem;border-radius:.25rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-view-trial:hover{background:#2563eb}.trials-footer-compact{text-align:center;padding:1rem;color:#6b7280;font-size:.9rem}.modal-overlay-insights{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content-insights{background:#fff;border-radius:.5rem;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0003}.modal-header-insights{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:1}.modal-header-insights h2{margin:0;font-size:1.25rem;flex:1;padding-right:1rem;color:#111827}.modal-close-insights{font-size:1.75rem;background:none;border:none;cursor:pointer;color:#6b7280;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close-insights:hover{color:#111827}.modal-body-insights{padding:1.5rem}.modal-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.modal-section{margin-bottom:1.5rem}.modal-section h3{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:#374151}.modal-section p{margin:0;line-height:1.6;color:#4b5563}.modal-section ul{margin:0;padding-left:1.5rem;line-height:1.8;color:#4b5563}.conditions-tags{display:flex;flex-wrap:wrap;gap:.5rem}.condition-tag-small{padding:.375rem .75rem;background-color:#f3f4f6;border-radius:.25rem;font-size:.85rem;color:#374151}.btn-primary-modal{display:inline-block;background:#3b82f6;color:#fff;padding:.75rem 1.5rem;border-radius:.375rem;text-decoration:none;font-weight:500;transition:background .2s}.btn-primary-modal:hover{background:#2563eb}@media (max-width: 768px){.supplements-section{padding:1.5rem}.supplements-header{flex-direction:column;align-items:flex-start;gap:1rem}.btn-get-recommendations{width:100%}.supplements-content{padding:1rem}.clinical-trials-section-insights{padding:1.5rem}.section-header-insights{flex-direction:column;align-items:flex-start;gap:1rem}.section-content-insights{padding:1rem}.trials-grid-compact{grid-template-columns:1fr}.modal-overlay-insights{padding:0}.modal-content-insights{border-radius:0;max-height:100vh}}.marketplace-accordion{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:2rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}.marketplace-accordion-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transition:background .3s ease}.marketplace-accordion-header:hover{background:linear-gradient(135deg,#5568d3,#6b3f8f)}.marketplace-accordion-header h2{margin:0;font-size:1.25rem;font-weight:600}.accordion-icon{font-size:1rem;transition:transform .3s ease}.marketplace-accordion-content{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:5000px}}.insurance-page{max-width:1200px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:700;margin:.5rem 0;color:#111827}.page-header p{color:#6b7280;font-size:1rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem;text-align:center;box-shadow:0 2px 8px #0000000f,0 1px 2px #0000000a;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f,0 2px 4px #00000014;border-color:#d1d5db}.summary-card:hover:before{transform:scaleX(1)}.summary-card h3{font-size:.6875rem;font-weight:600;color:#6b7280;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.08em}.summary-value{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:.5rem 0;line-height:1.2}.summary-label{font-size:.75rem;color:#9ca3af;margin:0;font-weight:500}.detail-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.detail-card h2{font-size:1.25rem;font-weight:600;margin:0 0 1.5rem;color:#111827;border-bottom:2px solid #e5e7eb;padding-bottom:.5rem}.insurance-type-section{margin-bottom:2rem}.insurance-type-section:last-child{margin-bottom:0}.insurance-type-header{font-size:1.125rem;font-weight:600;color:#374151;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.insurance-type-icon{font-size:1.25rem}.coverage-list{display:flex;flex-direction:column;gap:1rem}.coverage-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem}.coverage-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.coverage-header h3{font-size:1.125rem;font-weight:600;margin:0 0 .25rem;color:#111827}.coverage-type{font-size:.875rem;color:#6b7280;margin:0}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.status-badge.pending{background:#fef3c7;color:#92400e}.coverage-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.detail-row:last-child{border-bottom:none}.detail-row .label{font-weight:500;color:#6b7280}.detail-row span:last-child{color:#111827}.benefits-section{margin-top:1rem;padding-top:1rem;border-top:2px solid #e5e7eb}.benefits-section h4{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.benefit-item{display:flex;flex-direction:column;gap:.25rem}.benefit-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.benefit-value{font-size:1rem;font-weight:600;color:#111827}.claims-type-section{margin-bottom:2rem}.claims-type-section:last-child{margin-bottom:0}.claims-table{display:flex;flex-direction:column;gap:0;border:1px solid #e5e7eb;border-radius:.375rem;overflow:hidden;margin-top:1rem}.table-header{display:grid;grid-template-columns:100px 150px 200px 100px 100px 140px 100px;gap:1rem;padding:.75rem 1rem;background:#f9fafb;font-weight:600;font-size:.875rem;color:#374151;border-bottom:2px solid #e5e7eb}.table-row{display:grid;grid-template-columns:100px 150px 200px 100px 100px 140px 100px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #f3f4f6;font-size:.875rem;transition:background .2s}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f9fafb}.provider-name{font-weight:500;color:#111827}.service-name{color:#4b5563}.status-paid{background:#d1fae5;color:#065f46}.status-pending{background:#fef3c7;color:#92400e}.status-denied{background:#fee2e2;color:#991b1b}.empty-state{text-align:center;padding:3rem;color:#6b7280}.loading,.error{text-align:center;padding:3rem;font-size:1.125rem}.error{color:#dc2626}.privacy-page{padding:2rem 0}.privacy-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.privacy-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2rem}.privacy-card.danger{border-color:#ef4444}.privacy-card h2{font-size:1.5rem;margin-bottom:.5rem}.card-description{color:#666;margin-bottom:1.5rem}.access-log{max-height:400px;overflow-y:auto}.access-log table{width:100%;border-collapse:collapse}.access-log th{text-align:left;padding:.75rem;border-bottom:2px solid #e0e0e0;font-weight:600;font-size:.875rem;color:#666}.access-log td{padding:.75rem;border-bottom:1px solid #f0f0f0;font-size:.875rem}.action-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.action-consent_completed,.action-sync_complete{background:#d1fae5;color:#065f46}.action-api_read{background:#dbeafe;color:#1e40af}.action-export{background:#fef3c7;color:#92400e}.action-delete,.action-revoke{background:#fee2e2;color:#991b1b}.empty{text-align:center;color:#666;padding:2rem}.profile-page{max-width:1200px;margin:0 auto;padding:2rem}.profile-header-with-photo{display:flex;align-items:center;gap:2rem;margin-bottom:2.5rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;box-shadow:0 4px 12px #0000000d}.profile-photo-container{flex-shrink:0}.profile-photo{width:160px;height:160px;border-radius:50%;object-fit:cover;border:4px solid white;box-shadow:0 8px 24px #0000001f;transition:transform .3s ease}.profile-photo:hover{transform:scale(1.05)}.profile-header-content{flex:1}.profile-header-content h1{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.profile-name-display{font-size:1.5rem;font-weight:600;color:#6366f1;margin-bottom:.5rem}@media (max-width: 768px){.profile-header-with-photo{flex-direction:column;text-align:center;gap:1.5rem}.profile-photo{width:120px;height:120px}.profile-header-content h1{font-size:2rem}.profile-name-display{font-size:1.25rem}}.profile-section{margin-bottom:2rem}.profile-section h2{color:#333;margin-bottom:1rem;font-size:1.5rem;border-bottom:2px solid #e0e0e0;padding-bottom:.5rem}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.profile-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.profile-card h3{color:#555;margin-bottom:1rem;font-size:1.1rem;font-weight:600}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-row .label{color:#666;font-weight:500}.info-row .value{color:#333;font-weight:400}.info-row .sub-text{font-size:.875rem;color:#888;margin-top:.25rem}.vital-value{display:flex;align-items:baseline;gap:.5rem;margin:1rem 0}.value-large{font-size:2rem;font-weight:600;color:#2c3e50}.unit{font-size:1rem;color:#666}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-active{background-color:#4caf50;color:#fff}.badge-severe{background-color:#f44336;color:#fff}.badge-achieved{background-color:#4caf50;color:#fff}.badge-in-progress{background-color:#ff9800;color:#fff}.progress-bar{width:100%;height:8px;background-color:#e0e0e0;border-radius:4px;margin:.5rem 0;overflow:hidden}.progress-fill{height:100%;background-color:#4caf50;transition:width .3s ease}.loading,.error{text-align:center;padding:2rem;color:#666}.section-subtitle{color:#666;font-size:.875rem;margin:-.5rem 0 1rem;font-style:italic}.vital-card{position:relative}.vital-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-normal{background-color:#d1fae5;color:#065f46}.status-elevated{background-color:#fef3c7;color:#92400e}.status-abnormal{background-color:#fee2e2;color:#991b1b}.vital-meta{display:flex;flex-direction:column;gap:.25rem;margin-top:.75rem;font-size:.75rem;color:#666}.recency{color:#2563eb;font-weight:500}.source{color:#6b7280;font-style:italic}.device{color:#9ca3af;font-size:.7rem}.trend-indicator{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #f0f0f0}.trend{font-size:.75rem;font-weight:500}.trend-stable{color:#6b7280}.trend-improving{color:#059669}.trend-declining{color:#dc2626}.trend-decreasing{color:#059669}.live-indicator{color:#059669;font-size:.75rem;font-weight:600;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.priority-alert{margin:2rem 0;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px #00000026;animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.alert-critical{background:linear-gradient(135deg,#fee2e2,#fecaca);border:3px solid #dc2626}.alert-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff}.alert-icon{font-size:3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.alert-title-section{flex:1;display:flex;align-items:center;justify-content:space-between;gap:1rem}.alert-title{margin:0;font-size:1.75rem;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.alert-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.badge-critical{background:#fff;color:#991b1b}.alert-content{padding:2rem;background:#fff;display:flex;flex-direction:column;gap:2rem}.alert-column-full{width:100%}.alert-two-columns{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.alert-column-full h3{font-size:1.75rem;font-weight:700;color:#991b1b;margin:0 0 1.5rem}.clinical-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:2rem}.detail-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fef2f2;border-radius:8px;border-left:4px solid #dc2626}.detail-label{font-weight:700;color:#7f1d1d;min-width:140px;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.detail-value{color:#1f2937;font-weight:600;font-size:1rem}.staging-badge{display:inline-block;padding:.5rem 1rem;background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;border-radius:20px;font-weight:700;box-shadow:0 2px 8px #dc26264d}.alert-note{padding:1rem;background:#fffbeb;border-left:4px solid #f59e0b;border-radius:4px;font-size:.875rem;line-height:1.6;color:#78350f}.alert-note strong{display:block;margin-bottom:.5rem;color:#92400e;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.prognostic-section{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.prognostic-section h4{font-size:1.25rem;font-weight:700;color:#065f46;margin:0 0 1rem}.prognostic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.prognostic-item{background:#fff;padding:1rem;border-radius:8px;text-align:center;box-shadow:0 2px 4px #0000000d}.prognostic-label{display:block;font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-weight:600}.prognostic-value{display:block;font-size:1.5rem;font-weight:700;color:#1f2937}.prognostic-value.positive{color:#059669}.melanoma-subsection{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem}.melanoma-subsection h4{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 1rem;border-bottom:2px solid #dc2626;padding-bottom:.5rem}.care-team-member{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-bottom:1rem}.care-team-member:last-child{margin-bottom:0}.member-name{font-weight:700;color:#1f2937;font-size:1rem;margin-bottom:.25rem}.member-role{color:#dc2626;font-weight:600;font-size:.875rem;margin-bottom:.5rem}.member-org{color:#6b7280;font-size:.875rem;margin-bottom:.25rem}.member-phone{color:#2563eb;font-size:.875rem;font-weight:500}.surgery-item{background:#fff;border-left:4px solid #10b981;border-radius:4px;padding:1rem;margin-bottom:.75rem}.surgery-date{font-weight:700;color:#1f2937;font-size:.875rem;margin-bottom:.5rem}.surgery-procedure{color:#374151;font-size:.875rem;margin-bottom:.25rem;font-weight:600}.surgery-result{color:#059669;font-size:.875rem;font-weight:500}.cost-summary{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e5e7eb}.cost-summary h5{font-size:1rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.cost-row{display:flex;justify-content:space-between;padding:.75rem;margin-bottom:.5rem;background:#fff;border-radius:6px;font-size:.875rem}.cost-row.highlight{background:#fef3c7;border:1px solid #f59e0b;font-weight:600}.cost-row.success{background:#d1fae5;border:1px solid #10b981;font-weight:600}.amount-due{color:#d97706;font-weight:700}.followup-section{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem}.followup-section h4{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.followup-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.followup-item{background:#fff;border:2px solid #dbeafe;border-radius:8px;padding:1.25rem;transition:all .3s ease}.followup-item:hover{border-color:#2563eb;box-shadow:0 4px 12px #2563eb26;transform:translateY(-2px)}.followup-type{font-weight:700;color:#1f2937;font-size:1rem;margin-bottom:.5rem}.followup-frequency{color:#2563eb;font-weight:600;font-size:.875rem;margin-bottom:.75rem}.followup-next{background:#dbeafe;padding:.5rem .75rem;border-radius:6px;color:#1e40af;font-weight:600;font-size:.875rem;margin-bottom:.5rem}.followup-provider{color:#6b7280;font-size:.875rem;font-style:italic;margin-bottom:.5rem}.followup-instructions{color:#374151;font-size:.875rem;line-height:1.5;padding-top:.75rem;border-top:1px solid #e5e7eb}.alert-actions h4{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.care-plan-list{list-style:none;padding:0;margin:0 0 1.5rem}.care-plan-list li{padding:.75rem;margin-bottom:.5rem;background:#f9fafb;border-radius:6px;border-left:3px solid #6b7280;font-size:.875rem;line-height:1.5;transition:all .2s ease}.care-plan-list li:hover{background:#f3f4f6;transform:translate(4px)}.alert-button-group{display:flex;gap:1rem;flex-wrap:wrap}.alert-btn{display:inline-block;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;text-decoration:none;text-align:center;transition:all .3s ease;font-size:.875rem;box-shadow:0 2px 8px #0000001a}.alert-btn.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.alert-btn.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.alert-btn.btn-secondary{background:#fff;color:#2563eb;border:2px solid #2563eb}.alert-btn.btn-secondary:hover{background:#dbeafe;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb33}.status-borderline{background-color:#fef3c7;color:#92400e}@media (max-width: 1024px){.alert-two-columns{grid-template-columns:1fr}.clinical-details-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width: 768px){.alert-title{font-size:1.25rem}.alert-header{flex-direction:column;text-align:center;gap:.75rem}.alert-title-section{flex-direction:column;text-align:center}.clinical-details-grid{grid-template-columns:1fr}.prognostic-grid{grid-template-columns:1fr 1fr}.followup-grid{grid-template-columns:1fr}.alert-button-group{flex-direction:column}.alert-btn{width:100%}}.rag-settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rag-settings-modal{background:#fff;border-radius:12px;width:90%;max-width:800px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.rag-settings-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.rag-settings-header h2{margin:0;font-size:24px;font-weight:600}.close-btn{background:none;border:none;font-size:32px;cursor:pointer;color:#fff;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s}.close-btn:hover{background:#fff3}.rag-settings-tabs{display:flex;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:0 32px}.tab{background:none;border:none;padding:16px 24px;font-size:15px;font-weight:500;cursor:pointer;color:#6b7280;border-bottom:2px solid transparent;transition:all .2s}.tab:hover{color:#374151;background:#667eea0d}.tab.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.rag-message{margin:16px 32px;padding:12px 16px;border-radius:8px;background:#f0fdf4;border:1px solid #86efac;color:#166534;font-size:14px}.rag-loading{display:flex;align-items:center;justify-content:center;padding:64px;color:#6b7280;font-size:16px}.rag-settings-content{flex:1;overflow-y:auto;padding:32px}.config-panel{display:flex;flex-direction:column;gap:32px}.config-section{display:flex;flex-direction:column;gap:16px}.config-section h3{margin:0;font-size:18px;font-weight:600;color:#111827}.section-description{margin:0;font-size:14px;color:#6b7280}.config-item{display:flex;flex-direction:column;gap:8px}.config-item label{display:flex;flex-direction:column;gap:4px;font-size:14px;font-weight:500;color:#374151}.label-hint{font-size:13px;font-weight:400;color:#6b7280}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:flex-start;gap:12px!important;cursor:pointer}.checkbox-label input[type=checkbox]{margin-top:2px;cursor:pointer}.checkbox-label span{flex:1}.config-item input[type=range]{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;-webkit-appearance:none;cursor:pointer}.config-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;box-shadow:0 2px 4px #0003;transition:transform .2s}.config-item input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.config-item input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.filter-checkbox{display:flex;align-items:center;gap:8px;padding:10px;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:#374151}.filter-checkbox:hover{border-color:#667eea;background:#667eea0d}.filter-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.system-prompt-input{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;color:#111827;resize:vertical;min-height:100px}.system-prompt-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.config-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid #e5e7eb}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.data-panel{display:flex;flex-direction:column;gap:32px}.data-section{display:flex;flex-direction:column;gap:16px}.data-section h3{margin:0;font-size:18px;font-weight:600;color:#111827}.data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.data-item{display:flex;flex-direction:column;gap:4px}.data-label{font-size:13px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.data-value{font-size:16px;font-weight:600;color:#111827}.events-breakdown{display:flex;flex-direction:column;gap:12px}.event-type-item{display:grid;grid-template-columns:120px 1fr 60px;gap:12px;align-items:center}.event-type{font-size:14px;font-weight:500;color:#374151;text-transform:capitalize}.event-bar{height:24px;background:#f3f4f6;border-radius:12px;overflow:hidden}.event-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.event-count{font-size:14px;font-weight:600;color:#667eea;text-align:right}@media (max-width: 768px){.rag-settings-modal{width:95%;max-height:90vh}.rag-settings-header,.rag-settings-tabs,.rag-settings-content{padding-left:16px;padding-right:16px}.filter-grid{grid-template-columns:1fr}.event-type-item{grid-template-columns:100px 1fr 50px;gap:8px}.config-actions{flex-direction:column}.btn{width:100%}}.performance-monitor{padding:0;background:linear-gradient(135deg,#f8fafc,#f1f5f9);height:100%;overflow-y:auto;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:2rem}.loading-spinner{position:relative;width:80px;height:80px}.spinner-ring{position:absolute;width:100%;height:100%;border:4px solid transparent;border-top-color:#3b82f6;border-radius:50%;animation:spin 1.5s cubic-bezier(.68,-.55,.265,1.55) infinite}.spinner-ring:nth-child(2){border-top-color:#8b5cf6;animation-delay:.2s;width:90%;height:90%;top:5%;left:5%}.spinner-ring:nth-child(3){border-top-color:#10b981;animation-delay:.4s;width:80%;height:80%;top:10%;left:10%}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:#64748b;font-size:12px;font-weight:500}.monitor-header-modern{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}.header-left .monitor-title{display:flex;align-items:center;gap:1rem}.title-icon{display:none}.monitor-title h2{margin:0;font-size:14px;font-weight:700;color:#1e293b}.subtitle{margin:0;font-size:11px;color:#64748b;font-weight:500}.header-right{display:flex;align-items:center;gap:.75rem}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:100px;font-size:11px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1)}.status-badge.connected{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;box-shadow:0 2px 8px #10b98133}.status-badge.disconnected{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;box-shadow:0 2px 8px #ef444433}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse-dot 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.control-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);color:#64748b}.control-btn:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.control-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f64d}.empty-state-modern{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;margin:2rem;background:#fff;border-radius:20px;box-shadow:0 1px 3px #0000000d}.empty-icon{display:none}.empty-state-modern h3{margin:0 0 .75rem;font-size:14px;font-weight:700;color:#1e293b}.empty-state-modern p{margin:0 0 2rem;font-size:12px;color:#64748b;max-width:400px;line-height:1.6}.empty-tip{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:100px;font-size:11px;color:#1e40af;font-weight:500}.tip-icon{display:none}.kpi-grid{display:grid;grid-template-columns:1fr;gap:1rem;padding:1rem 1.5rem;max-width:100%;box-sizing:border-box}.kpi-card{background:#fff;padding:1rem;border-radius:12px;box-shadow:0 1px 2px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;gap:1rem;align-items:flex-start;position:relative;overflow:hidden;border:1px solid #f1f5f9}.kpi-card:before{display:none}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:#e5e7eb}.load-card{flex-direction:column;gap:1.25rem}.kpi-header{display:flex;justify-content:space-between;align-items:center;width:100%}.kpi-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.kpi-badge{padding:.375rem .875rem;border-radius:100px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.kpi-value-large{font-size:14px;font-weight:700;line-height:1.4;letter-spacing:-.02em}.kpi-icon{display:none}.kpi-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.kpi-value{font-size:14px;font-weight:700;color:#1e293b;line-height:1.4;letter-spacing:-.02em}.kpi-unit{font-size:11px;font-weight:600;color:#64748b;margin-left:.25rem}.kpi-secondary{font-size:11px;color:#94a3b8;font-weight:500}.kpi-trend{margin-top:.25rem}.trend-good,.trend-ok,.trend-bad{font-size:11px;font-weight:600;padding:.25rem .625rem;border-radius:6px;display:inline-block}.trend-good{background:#d1fae5;color:#065f46}.trend-ok{background:#fed7aa;color:#92400e}.trend-bad{background:#fee2e2;color:#991b1b}.progress-bar-modern{width:100%;height:12px;background:#f1f5f9;border-radius:100px;overflow:hidden;position:relative}.progress-fill-modern{height:100%;border-radius:100px;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-glow{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.charts-grid{display:grid;grid-template-columns:1fr;gap:1rem;padding:0 1.5rem 1rem;max-width:100%;box-sizing:border-box}.chart-card{background:#fff;padding:1rem;border-radius:12px;box-shadow:0 1px 2px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid #f1f5f9}.chart-card:hover{box-shadow:0 4px 12px #00000014;border-color:#e5e7eb}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.chart-title{margin:0 0 .25rem;font-size:13px;font-weight:700;color:#1e293b}.chart-subtitle{margin:0;font-size:11px;color:#94a3b8;font-weight:500}.chart-legend{display:flex;gap:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:11px;color:#64748b;font-weight:500}.legend-dot{width:10px;height:10px;border-radius:50%}.activity-card{background:#fff;margin:0 1.5rem 1.5rem;padding:1rem;border-radius:12px;box-shadow:0 1px 2px #0000000d;border:1px solid #f1f5f9}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.activity-count{font-size:11px;color:#64748b;background:#f1f5f9;padding:.375rem .875rem;border-radius:100px;font-weight:600}.activity-list{display:flex;flex-direction:column;gap:.5rem}.activity-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;background:#f8fafc;transition:all .2s cubic-bezier(.4,0,.2,1)}.activity-item:hover{background:#f1f5f9;transform:translate(2px)}.activity-status{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-weight:700;font-size:11px;flex-shrink:0}.status-icon-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-icon-error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.status-icon-pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.activity-details{flex:1;display:flex;flex-direction:column;gap:.375rem}.activity-main{display:flex;align-items:center;gap:1rem}.activity-time{font-size:12px;font-weight:600;color:#1e293b}.activity-model{font-size:10px;font-weight:600;padding:.25rem .625rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border-radius:6px}.activity-metrics{display:flex;gap:1rem}.activity-metric{font-size:11px;color:#64748b;font-weight:500}.activity-pending{font-size:11px;color:#92400e;font-weight:600}.performance-monitor::-webkit-scrollbar{width:10px}.performance-monitor::-webkit-scrollbar-track{background:#f1f5f9}.performance-monitor::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#cbd5e1,#94a3b8);border-radius:100px;border:2px solid #f1f5f9}.performance-monitor::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#94a3b8,#64748b)}@media (max-width: 768px){.monitor-header-modern{padding:1rem;flex-direction:column;gap:1rem;align-items:stretch}.header-right{justify-content:space-between}.kpi-grid{padding:1rem;gap:.75rem}.charts-grid{padding:0 1rem 1rem}.activity-card{margin:0 1rem 1rem}}@media (max-width: 480px){.kpi-grid{padding:.75rem;gap:.75rem}.kpi-card{padding:.875rem}.charts-grid{padding:0 .75rem .75rem}.activity-card{margin:0 .75rem .75rem}}.chat-history-sidebar{position:fixed;top:0;left:-320px;bottom:0;width:300px;background:#171717;border-right:1px solid #2d2d2d;z-index:100;display:flex;flex-direction:column;transition:left .3s ease}.chat-history-sidebar.open{left:0}.chat-history-header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-bottom:1px solid #2d2d2d}.chat-history-header h2{margin:0;font-size:1rem;color:#fff;font-weight:600}.close-button{background:none;border:none;color:#999;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s}.close-button:hover{background:#2d2d2d;color:#fff}.new-chat-button{margin:.75rem 1rem;padding:.65rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.new-chat-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.conversations-list{flex:1;overflow-y:auto;padding:0 .5rem}.loading-state,.empty-state{padding:2rem 1rem;text-align:center;color:#999}.empty-state p{margin:.5rem 0}.empty-subtitle{font-size:.85rem;color:#666}.conversation-item{position:relative;display:flex;align-items:center;padding:.75rem;margin:.25rem 0;border-radius:8px;cursor:pointer;transition:background .2s;border:1px solid transparent}.conversation-item:hover{background:#2d2d2d}.conversation-item.active{background:#2d2d2d;border-color:#667eea}.conversation-content{flex:1;min-width:0}.conversation-title{color:#fff;font-size:.9rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.conversation-meta{display:flex;gap:.5rem;font-size:.75rem;color:#999}.conversation-count{color:#666}.delete-button{opacity:0;background:none;border:none;font-size:1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.conversation-item:hover .delete-button{opacity:1}.delete-button:hover{background:#ef44441a}.delete-confirm{position:absolute;top:0;left:0;right:0;bottom:0;background:#171717;border-radius:8px;padding:.75rem;display:flex;flex-direction:column;justify-content:center;gap:.5rem;border:1px solid #ef4444}.delete-confirm p{margin:0;color:#fff;font-size:.85rem;text-align:center}.delete-actions{display:flex;gap:.5rem}.confirm-delete,.cancel-delete{flex:1;padding:.5rem;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;font-weight:500;transition:all .2s}.confirm-delete{background:#ef4444;color:#fff}.confirm-delete:hover{background:#dc2626}.cancel-delete{background:#2d2d2d;color:#999}.cancel-delete:hover{background:#3d3d3d;color:#fff}.conversations-list::-webkit-scrollbar{width:6px}.conversations-list::-webkit-scrollbar-track{background:#171717}.conversations-list::-webkit-scrollbar-thumb{background:#2d2d2d;border-radius:3px}.conversations-list::-webkit-scrollbar-thumb:hover{background:#3d3d3d}.history-tabs{display:flex;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #2d2d2d;background:#1a1a1a}.history-tab{flex:1;padding:.5rem .75rem;background:transparent;border:1px solid #2d2d2d;color:#999;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.history-tab:hover{background:#2d2d2d;color:#fff}.history-tab.active{background:#667eea;border-color:#667eea;color:#fff}.debug-panel{flex:1;overflow-y:auto;padding:1rem}.debug-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #2d2d2d}.debug-section:last-child{border-bottom:none}.debug-section h3{margin:0 0 .75rem;font-size:.9rem;color:#fff;font-weight:600}.debug-toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.5rem;background:#2d2d2d;border-radius:8px;transition:background .2s}.debug-toggle:hover{background:#3d3d3d}.debug-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.debug-toggle span{color:#fff;font-size:.9rem;font-weight:500}.debug-hint{margin:.75rem 0 0;font-size:.8rem;line-height:1.5;color:#999}.debug-features,.debug-troubleshooting{margin:.5rem 0 0;padding-left:1.25rem;color:#ccc;font-size:.85rem;line-height:1.7}.debug-features li,.debug-troubleshooting li{margin-bottom:.5rem}.debug-links{display:flex;flex-direction:column;gap:.5rem}.debug-link{padding:.75rem;background:#2d2d2d;border:1px solid #3d3d3d;border-radius:6px;color:#667eea;text-decoration:none;font-size:.85rem;text-align:center;transition:all .2s}.debug-link:hover{background:#3d3d3d;border-color:#667eea;color:#8a9eea}.debug-panel::-webkit-scrollbar{width:6px}.debug-panel::-webkit-scrollbar-track{background:#171717}.debug-panel::-webkit-scrollbar-thumb{background:#2d2d2d;border-radius:3px}.debug-panel::-webkit-scrollbar-thumb:hover{background:#3d3d3d}.performance-panel{flex:1;overflow-y:auto;background:#f9f9f9}.performance-panel::-webkit-scrollbar{width:8px}.performance-panel::-webkit-scrollbar-track{background:#f1f1f1}.performance-panel::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.performance-panel::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.chat-history-sidebar{left:-100%;width:85%;max-width:320px}.chat-history-sidebar.open{left:0;box-shadow:2px 0 8px #0000004d}.chat-history-header{padding:.75rem}.chat-history-header h2{font-size:.95rem}.new-chat-button{margin:.5rem;padding:.55rem;font-size:.85rem}.history-tabs{padding:0 .5rem}.history-tab{padding:.5rem .75rem;font-size:.8rem}.conversations-list{padding:0 .25rem}.conversation-item{padding:.65rem;font-size:.9rem}.conversation-title{font-size:.9rem}.conversation-meta{font-size:.75rem}.delete-button{padding:.35rem .5rem;font-size:.75rem;min-height:32px}.debug-panel{padding:.75rem}.debug-section h3{font-size:.95rem}.debug-hint,.debug-features li{font-size:.8rem}.debug-link{padding:.5rem .75rem;font-size:.8rem}@media (max-width: 480px){.chat-history-sidebar{width:100%;max-width:100%}}}@media (pointer: coarse){.close-button,.new-chat-button,.conversation-item,.delete-button,.history-tab,.debug-link{min-height:44px}.close-button{min-width:44px}}@supports (-webkit-touch-callout: none){.chat-history-sidebar{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.conversations-list{-webkit-overflow-scrolling:touch;overscroll-behavior-y:none}.close-button,.new-chat-button,.conversation-item,.delete-button,.history-tab{-webkit-tap-highlight-color:transparent}}.voice-input-container{display:flex;align-items:center;gap:.5rem}.voice-button{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s;box-shadow:0 2px 4px #0000001a}.voice-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.voice-button:disabled{opacity:.5;cursor:not-allowed}.voice-button.recording{background:linear-gradient(135deg,#f093fb,#f5576c);animation:pulse-glow 2s ease-in-out infinite}.voice-button.playing{background:linear-gradient(135deg,#4facfe,#00f2fe)}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #f5576c80}50%{box-shadow:0 0 20px #f5576ccc}}.recording-indicator{position:relative;width:12px;height:12px}.recording-indicator .pulse{position:absolute;width:12px;height:12px;background:#fff;border-radius:50%;animation:pulse-scale 1.5s ease-out infinite}@keyframes pulse-scale{0%{transform:scale(.8);opacity:1}to{transform:scale(2);opacity:0}}.voice-processing{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#f3f4f6;border-radius:8px;font-size:.875rem;color:#6b7280}.spinner{width:16px;height:16px;border:2px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.voice-button svg{flex-shrink:0}@media (max-width: 768px){.voice-input-container{gap:.375rem;flex-wrap:wrap}.voice-button{padding:.5rem .75rem;font-size:.8rem;min-height:44px;min-width:44px;-webkit-tap-highlight-color:transparent}.voice-button svg{width:18px;height:18px}.voice-processing{padding:.5rem .75rem;font-size:.8rem}.spinner{width:14px;height:14px}}@media (max-width: 375px){.voice-button{padding:.45rem .65rem;font-size:.75rem}.voice-button svg{width:16px;height:16px}}@media (pointer: coarse){.voice-button{min-height:44px;min-width:44px}}.smart-home-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:20px;margin:16px 0;box-shadow:0 10px 30px #00000026;color:#fff;animation:slideIn .3s ease-out}.smart-home-card.applied{background:linear-gradient(135deg,#56ab2f,#a8e063)}.home-icon{font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.automation-actions{background:#ffffff26;border-radius:12px;padding:12px;margin-bottom:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.action-item{display:flex;align-items:center;gap:12px;padding:12px;background:#ffffff1a;border-radius:10px;margin-bottom:8px;transition:background .2s}.action-item:last-child{margin-bottom:0}.action-item:hover{background:#ffffff26}.action-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:8px;flex-shrink:0}.action-details{flex:1}.action-device{font-size:15px;font-weight:500;margin-bottom:4px}.action-change{display:flex;align-items:center;gap:8px;font-size:13px;color:#ffffffe6}.apply-button{background:#fff;color:#667eea;border:none;padding:12px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #00000026}.sleep-history-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;margin-top:16px;color:#fff;box-shadow:0 10px 30px #667eea4d}.sleep-history-card .card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.sleep-history-card .sleep-icon{font-size:32px;background:#fff3;width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sleep-history-card .card-title h3{margin:0;font-size:20px;font-weight:600}.sleep-history-card .card-subtitle{margin:4px 0 0;font-size:14px;opacity:.9}.sleep-history-card .sleep-stats{display:flex;gap:16px;margin-bottom:24px;background:#ffffff26;padding:16px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sleep-history-card .stat-item{flex:1;text-align:center}.sleep-history-card .stat-label{font-size:12px;opacity:.8;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.sleep-history-card .stat-value{font-size:24px;font-weight:700}.sleep-history-card .sleep-chart{display:flex;align-items:flex-end;gap:8px;height:200px;margin-bottom:20px;padding:20px;background:#ffffff1a;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sleep-history-card .chart-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.sleep-history-card .chart-bar{width:100%;min-height:20px;border-radius:6px 6px 0 0;transition:all .3s ease;cursor:pointer;position:relative;display:flex;align-items:flex-start;justify-content:center;padding-top:4px}.sleep-history-card .chart-bar:hover{transform:translateY(-4px);opacity:.8}.sleep-history-card .bar-label{font-size:10px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.sleep-history-card .chart-date{font-size:10px;margin-top:8px;opacity:.8;white-space:nowrap;transform:rotate(-45deg);transform-origin:center}.sleep-history-card .sleep-legend{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.2)}.sleep-history-card .legend-item{display:flex;align-items:center;gap:6px;font-size:12px}.sleep-history-card .legend-color{width:16px;height:16px;border-radius:4px;border:2px solid rgba(255,255,255,.3)}.sleep-history-card .loading-state,.sleep-history-card .error-state,.sleep-history-card .empty-state{text-align:center;padding:40px 20px;opacity:.9}.sleep-history-card .error-state{color:#fecaca}.product-recommendation-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;margin-top:16px;color:#fff;box-shadow:0 10px 30px #667eea4d}.product-recommendation-card .card-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.product-recommendation-card .product-icon{font-size:32px;background:#fff3;width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.product-recommendation-card .card-title h3{margin:0;font-size:20px;font-weight:600}.product-recommendation-card .card-subtitle{margin:4px 0 0;font-size:14px;opacity:.9}.product-recommendation-card .products-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.product-recommendation-card .product-item{background:#ffffff26;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.product-recommendation-card .product-item:hover{transform:translateY(-4px);background:#fff3}.product-recommendation-card .product-image{position:relative;height:180px;background:#fff;overflow:hidden}.product-recommendation-card .product-image img{width:100%;height:100%;object-fit:cover}.product-recommendation-card .product-type-badge{position:absolute;top:8px;right:8px;background:#667eeaf2;color:#fff;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.product-recommendation-card .product-details{padding:16px}.product-recommendation-card .product-details h4{margin:0 0 8px;font-size:16px;font-weight:600}.product-recommendation-card .product-description{margin:0 0 12px;font-size:13px;opacity:.9;line-height:1.4}.product-recommendation-card .product-benefits{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.product-recommendation-card .benefit-tag{font-size:11px;opacity:.8;display:block}.product-recommendation-card .product-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid rgba(255,255,255,.2)}.product-recommendation-card .product-price{font-size:18px;font-weight:700}.product-recommendation-card .product-view-btn{background:#fff3;color:#fff;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.product-recommendation-card .product-view-btn:hover{background:#ffffff4d;transform:translate(2px)}.product-recommendation-card .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.product-recommendation-card .modal-content{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080}.product-recommendation-card .modal-close{position:absolute;top:16px;right:16px;background:#fff3;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s;z-index:1}.product-recommendation-card .modal-close:hover{background:#ffffff4d}.product-recommendation-card .modal-image{height:300px;background:#fff;overflow:hidden}.product-recommendation-card .modal-image img{width:100%;height:100%;object-fit:cover}.product-recommendation-card .modal-body{padding:32px;color:#fff}.product-recommendation-card .modal-type-badge{background:#fff3;display:inline-block;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.product-recommendation-card .modal-body h2{margin:0 0 16px;font-size:28px;font-weight:700}.product-recommendation-card .modal-description{margin:0 0 24px;font-size:16px;opacity:.95;line-height:1.6}.product-recommendation-card .modal-benefits{margin-bottom:24px}.product-recommendation-card .modal-benefits h3{margin:0 0 12px;font-size:18px;font-weight:600}.product-recommendation-card .modal-benefits ul{margin:0;padding-left:20px}.product-recommendation-card .modal-benefits li{margin-bottom:8px;opacity:.9;line-height:1.5}.product-recommendation-card .modal-footer{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.2)}.product-recommendation-card .modal-price{font-size:32px;font-weight:700}.product-recommendation-card .modal-view-btn{background:#fff;color:#667eea;padding:14px 28px;border-radius:10px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s;box-shadow:0 4px 12px #00000026}.product-recommendation-card .modal-view-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.social-groups-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;margin-top:16px;color:#fff;box-shadow:0 10px 30px #667eea4d}.social-groups-card .card-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.social-groups-card .groups-icon{font-size:32px;background:#fff3;width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-groups-card .card-title h3{margin:0;font-size:20px;font-weight:600}.social-groups-card .card-subtitle{margin:4px 0 0;font-size:14px;opacity:.9}.social-groups-card .groups-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.social-groups-card .group-item{background:#ffffff26;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-groups-card .group-item:hover{transform:translateY(-4px);background:#fff3}.social-groups-card .group-image{position:relative;height:180px;background:#fff;overflow:hidden}.social-groups-card .group-image img{width:100%;height:100%;object-fit:cover}.social-groups-card .subscribed-badge{position:absolute;top:8px;right:8px;background:#2ed573f2;color:#fff;padding:6px 12px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #00000026}.social-groups-card .group-details{padding:16px}.social-groups-card .group-category{display:inline-block;background:#fff3;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-groups-card .group-details h4{margin:0 0 8px;font-size:16px;font-weight:600;line-height:1.3}.social-groups-card .group-members{margin:0 0 8px;font-size:13px;opacity:.9;font-weight:500}.social-groups-card .group-description{margin:0 0 12px;font-size:13px;opacity:.9;line-height:1.4}.social-groups-card .group-footer{padding-top:12px;border-top:1px solid rgba(255,255,255,.2)}.social-groups-card .group-view-btn,.social-groups-card .group-join-btn{background:#fff3;color:#fff;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-block}.social-groups-card .group-view-btn:hover,.social-groups-card .group-join-btn:hover{background:#ffffff4d;transform:translate(2px)}.social-groups-card .group-join-btn{background:#ffffff40;font-weight:600}.social-groups-card .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.social-groups-card .modal-content{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;max-width:650px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080}.social-groups-card .modal-close{position:absolute;top:16px;right:16px;background:#fff3;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s;z-index:1}.social-groups-card .modal-close:hover{background:#ffffff4d}.social-groups-card .modal-image{height:300px;background:#fff;overflow:hidden}.social-groups-card .modal-image img{width:100%;height:100%;object-fit:cover}.social-groups-card .modal-body{padding:32px;color:#fff}.social-groups-card .modal-category-badge{background:#fff3;display:inline-block;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-groups-card .modal-subscribed-badge{background:#2ed57333;display:inline-block;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;margin-bottom:16px;margin-left:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(46,213,115,.4)}.social-groups-card .modal-body h2{margin:0 0 8px;font-size:28px;font-weight:700;line-height:1.2}.social-groups-card .modal-members{margin:0 0 16px;font-size:15px;opacity:.95;font-weight:500}.social-groups-card .modal-description{margin:0 0 24px;font-size:16px;opacity:.95;line-height:1.6}.social-groups-card .modal-recent-topics{margin-bottom:24px}.social-groups-card .modal-recent-topics h3{margin:0 0 12px;font-size:18px;font-weight:600}.social-groups-card .topics-list{display:flex;flex-direction:column;gap:12px}.social-groups-card .topic-item{background:#ffffff1a;padding:12px 16px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-groups-card .topic-title{font-size:14px;font-weight:500;margin-bottom:4px;line-height:1.4}.social-groups-card .topic-engagement{font-size:12px;opacity:.8}.social-groups-card .modal-footer{padding-top:24px;border-top:1px solid rgba(255,255,255,.2)}.social-groups-card .modal-view-btn,.social-groups-card .modal-join-btn{background:#fff;color:#667eea;padding:14px 28px;border-radius:10px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s;box-shadow:0 4px 12px #00000026;display:inline-block}.social-groups-card .modal-view-btn:hover,.social-groups-card .modal-join-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.social-groups-card .modal-join-btn{background:linear-gradient(135deg,#2ed573,#26d07c);color:#fff}.elimination-plan-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;margin-top:16px;color:#fff;box-shadow:0 10px 30px #667eea4d}.elimination-plan-card .plan-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.elimination-plan-card .plan-icon{font-size:32px;background:#fff3;width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.elimination-plan-card .plan-title-section h3{margin:0;font-size:20px;font-weight:600}.elimination-plan-card .plan-subtitle{margin:4px 0 0;font-size:14px;opacity:.9}.elimination-plan-card .plan-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px;background:#ffffff1a;padding:16px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.elimination-plan-card .overview-item{display:flex;flex-direction:column;gap:4px}.elimination-plan-card .overview-label{font-size:12px;opacity:.8;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.elimination-plan-card .overview-value{font-size:16px;font-weight:600}.elimination-plan-card .phases-timeline{margin-bottom:24px}.elimination-plan-card .phase-item{background:#ffffff26;border-radius:12px;margin-bottom:12px;overflow:hidden;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.elimination-plan-card .phase-item.expanded{background:#fff3}.elimination-plan-card .phase-header{display:flex;align-items:center;gap:16px;padding:16px;cursor:pointer;transition:all .2s}.elimination-plan-card .phase-header:hover{background:#ffffff1a}.elimination-plan-card .phase-number{background:#ffffff4d;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.elimination-plan-card .phase-info{flex:1;display:flex;flex-direction:column;gap:2px}.elimination-plan-card .phase-week{font-size:12px;opacity:.8;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.elimination-plan-card .phase-action{font-size:16px;font-weight:600}.elimination-plan-card .phase-duration{font-size:13px;opacity:.8}.elimination-plan-card .phase-toggle{font-size:14px;opacity:.7;transition:transform .2s}.elimination-plan-card .phase-item.expanded .phase-toggle{transform:rotate(0)}.elimination-plan-card .phase-details{padding:0 16px 16px 72px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.elimination-plan-card .phase-section{margin-bottom:16px}.elimination-plan-card .phase-section:last-child{margin-bottom:0}.elimination-plan-card .phase-section h4{margin:0 0 8px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px}.elimination-plan-card .phase-list{margin:0;padding:0;list-style:none}.elimination-plan-card .phase-list li{margin-bottom:6px}.elimination-plan-card .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;transition:all .2s}.elimination-plan-card .checkbox-label:hover{opacity:.8}.elimination-plan-card .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:rgba(255,255,255,.8)}.elimination-plan-card .checkbox-label span.checked{text-decoration:line-through;opacity:.6}.elimination-plan-card .plan-instructions{background:#ffffff1a;padding:16px;border-radius:12px;margin-bottom:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.elimination-plan-card .plan-instructions h4{margin:0 0 12px;font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}.elimination-plan-card .plan-instructions ul{margin:0;padding-left:20px}.elimination-plan-card .plan-instructions li{margin-bottom:8px;font-size:13px;opacity:.95;line-height:1.5}.elimination-plan-card .plan-instructions li:last-child{margin-bottom:0}.elimination-plan-card .plan-actions{display:flex;gap:12px;flex-wrap:wrap}.elimination-plan-card .export-plan-btn,.elimination-plan-card .track-btn{flex:1;min-width:140px;background:#fff3;color:#fff;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;gap:8px}.elimination-plan-card .export-plan-btn:hover,.elimination-plan-card .track-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.elimination-plan-card .track-btn{background:#ffffff40}.meal-suggestions-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;margin-top:16px;color:#fff;box-shadow:0 10px 30px #667eea4d}.meal-suggestions-card .card-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.meal-suggestions-card .meal-icon{font-size:32px;background:#fff3;width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.meal-suggestions-card .card-title h3{margin:0;font-size:20px;font-weight:600}.meal-suggestions-card .card-subtitle{margin:4px 0 0;font-size:14px;opacity:.9}.meal-suggestions-card .meals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.meal-suggestions-card .meal-item{background:#ffffff26;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.meal-suggestions-card .meal-item:hover{transform:translateY(-4px);background:#fff3}.meal-suggestions-card .meal-image{position:relative;height:180px;background:#fff;overflow:hidden}.meal-suggestions-card .meal-image img{width:100%;height:100%;object-fit:cover}.meal-suggestions-card .meal-category-badge{position:absolute;top:8px;right:8px;background:#667eeaf2;color:#fff;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.meal-suggestions-card .meal-details{padding:16px}.meal-suggestions-card .meal-details h4{margin:0 0 8px;font-size:16px;font-weight:600}.meal-suggestions-card .meal-description{margin:0 0 12px;font-size:13px;opacity:.9;line-height:1.4}.meal-suggestions-card .meal-macros{display:flex;gap:12px;margin-bottom:12px;font-size:12px;opacity:.9;font-weight:500}.meal-suggestions-card .macro{display:flex;align-items:center;gap:4px}.meal-suggestions-card .meal-benefits-preview{display:flex;flex-direction:column;gap:4px}.meal-suggestions-card .benefit-tag{font-size:11px;opacity:.8;display:block}.meal-suggestions-card .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.meal-suggestions-card .modal-content{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080}.meal-suggestions-card .modal-close{position:absolute;top:16px;right:16px;background:#fff3;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s;z-index:1}.meal-suggestions-card .modal-close:hover{background:#ffffff4d}.meal-suggestions-card .modal-image{height:300px;background:#fff;overflow:hidden}.meal-suggestions-card .modal-image img{width:100%;height:100%;object-fit:cover}.meal-suggestions-card .modal-body{padding:32px;color:#fff}.meal-suggestions-card .modal-category-badge{background:#fff3;display:inline-block;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.meal-suggestions-card .modal-body h2{margin:0 0 16px;font-size:28px;font-weight:700}.meal-suggestions-card .modal-description{margin:0 0 24px;font-size:16px;opacity:.95;line-height:1.6}.meal-suggestions-card .modal-macros{margin-bottom:24px}.meal-suggestions-card .modal-macros h3{margin:0 0 12px;font-size:18px;font-weight:600}.meal-suggestions-card .macros-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.meal-suggestions-card .macro-item{background:#ffffff1a;padding:12px;border-radius:8px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.meal-suggestions-card .macro-icon{font-size:24px;margin-bottom:4px}.meal-suggestions-card .macro-label{font-size:11px;opacity:.8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.meal-suggestions-card .macro-value{font-size:18px;font-weight:700}.meal-suggestions-card .modal-benefits{margin-bottom:24px}.meal-suggestions-card .modal-benefits h3{margin:0 0 12px;font-size:18px;font-weight:600}.meal-suggestions-card .modal-benefits ul{margin:0;padding-left:20px}.meal-suggestions-card .modal-benefits li{margin-bottom:8px;opacity:.9;line-height:1.5}.fitness-goals-card{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border-radius:16px;padding:20px;margin:16px 0;box-shadow:0 10px 30px #00000026;color:#fff;animation:slideIn .3s ease-out}.fitness-goals-card.applied{background:linear-gradient(135deg,#56ab2f,#a8e063)}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.fitness-icon{font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.card-subtitle{margin:4px 0 0;font-size:14px;color:#ffffffd9;font-weight:400}.goals-list{background:#ffffff26;border-radius:12px;padding:12px;margin-bottom:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.goal-item{display:flex;align-items:center;gap:12px;padding:12px;background:#ffffff1a;border-radius:10px;margin-bottom:8px;transition:background .2s}.goal-item:last-child{margin-bottom:0}.goal-item:hover{background:#ffffff26}.goal-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:8px;flex-shrink:0}.goal-details{flex:1}.goal-name{font-size:15px;font-weight:500;margin-bottom:4px}.goal-change{display:flex;align-items:center;gap:8px;font-size:13px;color:#ffffffe6}.current-value{padding:2px 8px;background:#fff3;border-radius:4px;font-weight:500}.arrow{font-size:12px;opacity:.7}.suggested-value{padding:2px 8px;background:#ffffff4d;border-radius:4px;font-weight:600}.card-actions{display:flex;justify-content:flex-end}.apply-button{background:#fff;color:#ff6b6b;border:none;padding:12px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #00000026}.apply-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #0003}.apply-button:active:not(:disabled){transform:translateY(0)}.apply-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fff3;color:#fff;padding:12px;border-radius:8px;margin-bottom:12px;font-size:14px;border-left:3px solid #ff4444}.exam-note-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:20px;margin:16px 0;color:#fff;box-shadow:0 4px 6px #0000001a}.exam-note-card.saved{background:linear-gradient(135deg,#10b981,#059669)}.card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.note-icon{font-size:24px;flex-shrink:0}.card-title h3{margin:0;font-size:18px;font-weight:600;color:#fff}.card-subtitle{margin:4px 0 0;font-size:14px;opacity:.9;color:#fff}.note-content{margin-top:16px}.note-input{width:100%;padding:12px;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;font-size:14px;font-family:inherit;resize:vertical;min-height:80px;margin-bottom:12px}.note-input::placeholder{color:#fff9}.note-input:focus{outline:none;border-color:#fff9;background:#ffffff26}.save-button{width:100%;padding:12px 24px;background:#fff;color:#667eea;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.save-button:hover:not(:disabled){background:#ffffffe6;transform:translateY(-1px);box-shadow:0 4px 8px #0003}.save-button:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#fef2f2;background:#ef44444d;padding:8px 12px;border-radius:6px;font-size:14px;margin-bottom:12px}.health-assistant-page{height:100vh;display:flex;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;transition:margin-left .3s ease;max-width:100%}.main-content.sidebar-open{margin-left:300px}.sidebar-toggle{padding:.5rem .75rem;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s;color:#333;font-weight:700}.sidebar-toggle:hover{background:#e0e0e0;border-color:#2196f3;color:#2196f3}.header-content{display:flex;justify-content:space-between;align-items:center;gap:1rem}.header-actions{display:flex;align-items:center;gap:.75rem}.mode-toggle{padding:.5rem 1rem;border:2px solid;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.375rem;white-space:nowrap}.mode-toggle.mock{background:#fff3cd;border-color:#ffc107;color:#856404}.mode-toggle.mock:hover{background:#ffe69c;box-shadow:0 4px 12px #ffc1074d;transform:translateY(-1px)}.mode-toggle.live{background:#d4edda;border-color:#28a745;color:#155724}.mode-toggle.live:hover{background:#c3e6cb;box-shadow:0 4px 12px #28a7454d;transform:translateY(-1px)}.settings-button{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.375rem;white-space:nowrap}.settings-button:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.page-header{padding:.875rem 1.5rem;border-bottom:1px solid #e0e0e0;background:#fff;flex-shrink:0}.chat-container{display:flex;flex-direction:column;flex:1;background:#fff;overflow:hidden}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:#f9f9f9}.message{display:flex;gap:.75rem;align-items:flex-start;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{flex-direction:row-reverse}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;background:#e3f2fd}.message.user .message-avatar{background:#fff3e0}.message-content{max-width:70%;display:flex;flex-direction:column;gap:.25rem}.message.user .message-content{align-items:flex-end}.message-text{padding:.75rem 1rem;border-radius:12px;background:#fff;box-shadow:0 1px 3px #0000001a;line-height:1.5}.message.user .message-text{background:#2196f3;color:#fff}.message-text p{margin:.25rem 0}.message-text p:first-child{margin-top:0}.message-text p:last-child{margin-bottom:0}.message-time{font-size:.75rem;color:#666;padding:0 .5rem}.message.user .message-time{text-align:right}.typing-indicator{display:flex;gap:.25rem;padding:.75rem 1rem}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#999;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.quick-questions{padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background:#fff}.quick-questions-label{font-size:.875rem;color:#666;margin-bottom:.5rem;font-weight:500}.quick-questions-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.quick-question-btn{padding:.5rem 1rem;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:20px;font-size:.875rem;cursor:pointer;transition:all .2s;color:#333}.quick-question-btn:hover{background:#e3f2fd;border-color:#2196f3;color:#2196f3}.input-container{display:flex;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background:#fff}.message-input{flex:1;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:24px;font-size:1rem;outline:none;transition:border-color .2s}.message-input:focus{border-color:#2196f3}.message-input:disabled{background:#f5f5f5;cursor:not-allowed}.send-button{padding:.75rem 1.5rem;background:#2196f3;color:#fff;border:none;border-radius:24px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.send-button:hover:not(:disabled){background:#1976d2}.send-button:disabled{background:#ccc;cursor:not-allowed}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#f1f1f1}.messages-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:#555}.settings-button.active{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 12px #f093fb66}.message-metadata{margin-top:.75rem;padding:.75rem;background:#f8f9fa;border-left:3px solid #2196f3;border-radius:6px;font-size:.85rem}.metadata-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #dee2e6}.view-prompt-btn{padding:.25rem .75rem;background:#2196f3;color:#fff;border:none;border-radius:4px;font-size:.75rem;cursor:pointer;transition:background .2s}.view-prompt-btn:hover{background:#1976d2}.metadata-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem;margin-bottom:.75rem}.stat{display:flex;flex-direction:column;gap:.125rem}.stat-label{font-weight:500;color:#666;font-size:.75rem}.stat-value{color:#2196f3;font-weight:600;font-size:.9rem}.metadata-context{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #dee2e6}.metadata-context strong{display:block;margin-bottom:.5rem;color:#333}.context-stats{display:flex;flex-wrap:wrap;gap:.75rem}.context-stats span{padding:.25rem .75rem;background:#fff;border:1px solid #dee2e6;border-radius:12px;font-size:.8rem;color:#495057}.prompt-viewer{margin-top:1rem;padding-top:1rem;border-top:1px solid #dee2e6}.prompt-viewer strong{display:block;margin-bottom:.5rem;color:#333}.prompt-content{background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:1rem;font-family:Monaco,Courier New,monospace;font-size:.75rem;line-height:1.5;overflow-x:auto;max-height:400px;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}.prompt-content::-webkit-scrollbar{width:6px;height:6px}.prompt-content::-webkit-scrollbar-track{background:#f1f1f1}.prompt-content::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.prompt-content::-webkit-scrollbar-thumb:hover{background:#555}.processing-status{margin-top:.5rem;padding:.5rem 0;font-size:.85rem;color:#666}.status-label{display:block;font-weight:500;color:#2196f3;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.processing-details{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem;font-size:.75rem;color:#888}.processing-details span{animation:fadeInUp .5s ease-out forwards;opacity:0}.processing-details span:nth-child(1){animation-delay:.2s}.processing-details span:nth-child(2){animation-delay:.4s}.processing-details span:nth-child(3){animation-delay:.6s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.health-assistant-page{height:100dvh}.main-content.sidebar-open{margin-left:0}.page-header{padding:.75rem 1rem}.header-content{flex-wrap:wrap;gap:.5rem}.header-content h1{font-size:1.25rem}.header-content p{font-size:.8rem}.mode-toggle,.settings-button{padding:.4rem .75rem;font-size:.8rem;white-space:nowrap}.messages-container{padding:1rem;gap:.75rem}.message-content{max-width:85%}.message-text{padding:.65rem .85rem;font-size:.95rem}.message-avatar{width:32px;height:32px;font-size:1rem}.quick-questions{padding:.75rem 1rem}.quick-questions-label{font-size:.8rem;margin-bottom:.5rem}.quick-questions-buttons{display:flex;gap:.5rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:.25rem}.quick-questions-buttons::-webkit-scrollbar{display:none}.quick-question-btn{padding:.45rem .75rem;font-size:.8rem;-webkit-tap-highlight-color:rgba(0,0,0,0);flex-shrink:0;white-space:nowrap;min-height:36px}.input-container{padding:.75rem 1rem;gap:.5rem;flex-wrap:wrap}.message-input{padding:.65rem .85rem;font-size:16px;border-radius:20px;min-height:44px;flex:1;min-width:0}.send-button{padding:.65rem 1.25rem;border-radius:20px;font-size:.9rem;min-height:44px;min-width:60px;flex-shrink:0}.input-container .voice-input-container{order:-1;width:100%;justify-content:flex-start;margin-bottom:.5rem}.message-metadata{font-size:.75rem;padding:.5rem}.metadata-stats{grid-template-columns:1fr 1fr;gap:.375rem}.stat-label{font-size:.7rem}.stat-value{font-size:.8rem}.context-stats{gap:.5rem}.context-stats span{padding:.2rem .5rem;font-size:.75rem}.prompt-content{font-size:.7rem;padding:.75rem;max-height:300px}.view-prompt-btn{font-size:.7rem;padding:.2rem .5rem}}@media (max-width: 375px){.page-header{padding:.5rem .75rem}.header-content h1{font-size:1.1rem}.messages-container{padding:.75rem}.message-content{max-width:90%}.message-text{font-size:.9rem;padding:.55rem .75rem}.message-avatar{width:28px;height:28px;font-size:.9rem}.quick-questions-buttons{gap:.375rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:.25rem}.quick-questions-buttons::-webkit-scrollbar{display:none}.quick-question-btn{padding:.4rem .65rem;font-size:.75rem;flex-shrink:0;white-space:nowrap}.input-container{padding:.5rem .75rem;gap:.375rem}.message-input{padding:.55rem .75rem;font-size:16px}.send-button{padding:.55rem 1rem;font-size:.85rem;min-width:55px}}@supports (-webkit-touch-callout: none){.health-assistant-page{height:-webkit-fill-available}.messages-container{overscroll-behavior-y:none;-webkit-overflow-scrolling:touch}.message-input{font-size:16px}.quick-question-btn,.send-button,.settings-button,.mode-toggle{-webkit-tap-highlight-color:transparent}}@media (pointer: coarse){.quick-question-btn,.send-button,.settings-button,.sidebar-toggle,.view-prompt-btn{min-height:44px;min-width:44px}.message-input{min-height:44px}}@media (max-width: 896px) and (orientation: landscape){.messages-container{padding:.75rem 1rem}.input-container,.quick-questions{padding:.5rem 1rem}.quick-questions-buttons{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.quick-questions-buttons::-webkit-scrollbar{display:none}}.share-with-provider-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #3b82f633}.share-with-provider-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.share-with-provider-button:active{transform:translateY(0)}.share-icon{width:20px;height:20px}.share-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.share-modal{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.share-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.share-modal-header h2{margin:0;font-size:1.5rem;color:#1f2937}.close-button{background:none;border:none;padding:.5rem;cursor:pointer;color:#6b7280;transition:color .2s;border-radius:4px}.close-button:hover{color:#1f2937;background:#f3f4f6}.close-button svg{width:24px;height:24px}.share-modal-content{padding:1.5rem}.share-data-info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.share-data-info p{margin:0;color:#1e40af;font-size:.9375rem}.provider-selection{margin-bottom:1.5rem}.provider-selection label{display:block;font-weight:600;color:#1f2937;margin-bottom:1rem;font-size:.9375rem}.provider-list{display:grid;gap:.75rem;max-height:300px;overflow-y:auto;padding-right:.25rem}.provider-list::-webkit-scrollbar{width:6px}.provider-list::-webkit-scrollbar-track{background:#f3f4f6;border-radius:3px}.provider-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.provider-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.provider-card{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;position:relative}.provider-card:hover{border-color:#3b82f6;background:#f9fafb}.provider-card.selected{border-color:#3b82f6;background:#eff6ff}.provider-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.125rem;flex-shrink:0}.provider-info{flex:1}.provider-name{font-weight:600;color:#1f2937;margin-bottom:.25rem;font-size:1rem}.provider-specialty{font-size:.875rem;color:#6b7280;margin-bottom:.125rem}.provider-organization{font-size:.75rem;color:#9ca3af}.selected-check{position:absolute;top:.75rem;right:.75rem;width:24px;height:24px;color:#3b82f6}.share-note-section{margin-bottom:1.5rem}.share-note-section label{display:block;font-weight:600;color:#1f2937;margin-bottom:.5rem;font-size:.9375rem}.share-note-section textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9375rem;font-family:inherit;resize:vertical;transition:border-color .2s}.share-note-section textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.share-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb;border-radius:0 0 16px 16px}.cancel-button,.share-button{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s;border:none}.cancel-button{background:#fff;color:#6b7280;border:1px solid #d1d5db}.cancel-button:hover{background:#f9fafb;color:#1f2937}.share-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 4px #3b82f633}.share-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.share-button:disabled{opacity:.5;cursor:not-allowed}.share-success{padding:3rem 1.5rem;text-align:center}.success-icon{width:64px;height:64px;color:#10b981;margin:0 auto 1rem}.share-success h3{margin:0 0 .5rem;color:#1f2937;font-size:1.5rem}.share-success p{margin:0;color:#6b7280;font-size:1rem}@media (max-width: 768px){.share-modal{max-height:95vh}.share-modal-header{padding:1rem}.share-modal-header h2{font-size:1.25rem}.share-modal-content,.share-modal-footer{padding:1rem}.provider-card{padding:.75rem}.provider-avatar{width:40px;height:40px;font-size:1rem}.provider-name{font-size:.9375rem}.share-with-provider-button{padding:.625rem 1.25rem;font-size:.875rem}}.sleep-history-page{padding:2rem;max-width:1400px;margin:0 auto}.sleep-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:linear-gradient(135deg,#1e293b,#0f172a);padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f;color:#fff}.stat-label{font-size:.875rem;font-weight:600;margin-bottom:.5rem;color:#e2e8f0;letter-spacing:.025em}.stat-value{font-size:2.75rem;font-weight:700;line-height:1;color:#fff}.stat-unit{font-size:1.125rem;font-weight:500;color:#cbd5e1}.chart-section h2{margin:0 0 1.5rem;font-size:1.25rem;color:#1f2937}.sleep-records-section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.sleep-records-section h2{margin:0 0 1.5rem;font-size:1.25rem;color:#1f2937}.sleep-records-list{display:grid;gap:1rem}.sleep-record-card{border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem;transition:all .2s}.sleep-record-card:hover{box-shadow:0 4px 6px #0000001a;border-color:#8b5cf6}.record-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.record-date-info{display:flex;flex-direction:column;gap:.5rem}.record-date-info h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.sleep-quality-badge{display:inline-block;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.sleep-quality-badge.excellent{background:#d1fae5;color:#065f46}.sleep-quality-badge.good{background:#dbeafe;color:#1e40af}.sleep-quality-badge.fair{background:#fef3c7;color:#92400e}.sleep-quality-badge.poor{background:#fee2e2;color:#991b1b}.record-total-info{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.total-sleep{font-size:1.875rem;font-weight:700;color:#8b5cf6;line-height:1}.efficiency{font-size:.75rem;color:#6b7280}.sleep-stages-visual{margin-bottom:1rem}.stage-bar-container{display:flex;width:100%;height:8px;border-radius:4px;overflow:hidden;background:#f3f4f6}.stage-bar{height:100%;transition:width .3s ease}.stage-bar.deep{background:#10b981}.stage-bar.light{background:#3b82f6}.stage-bar.rem{background:#8b5cf6}.stage-bar.awake{background:#ef4444}.record-breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.breakdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f9fafb;border-radius:8px;transition:background .2s}.breakdown-item:hover{background:#f3f4f6}.breakdown-icon{width:12px;height:12px;border-radius:50%;flex-shrink:0}.breakdown-icon.deep{background:#10b981}.breakdown-icon.light{background:#3b82f6}.breakdown-icon.rem{background:#8b5cf6}.breakdown-icon.awake{background:#ef4444}.breakdown-content{display:flex;flex-direction:column;gap:.125rem;flex:1}.breakdown-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.breakdown-value{font-size:.875rem;font-weight:600;color:#1f2937}@media (max-width: 768px){.sleep-history-page{padding:1rem}.page-header h1{font-size:1.5rem}.sleep-stats-grid{grid-template-columns:1fr;gap:1rem}.chart-section,.sleep-records-section{padding:1rem}.record-breakdown{grid-template-columns:1fr}.stat-value{font-size:2rem}.record-header{flex-direction:column;gap:.75rem;align-items:flex-start}.record-total-info{align-items:flex-start}.total-sleep{font-size:1.5rem}.breakdown-item{padding:.5rem .75rem}.sleep-quality-badge{font-size:.625rem;padding:.25rem .5rem}.record-date-info h3{font-size:1rem}}.history-page{padding:2rem;max-width:1400px;margin:0 auto}.events-grid{display:grid;gap:1rem}.event-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .2s}.event-card.clickable{cursor:pointer}.event-card:hover{box-shadow:0 4px 6px #0000001a;border-color:#8b5cf6}.event-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.event-header h3{margin:0;font-size:1.125rem;color:#1f2937;flex:1}.event-date{font-size:.875rem;color:#6b7280;white-space:nowrap;margin-left:1rem}.event-content{display:flex;flex-direction:column;gap:.75rem}.event-value,.value-number{font-size:1.5rem;font-weight:700;color:#8b5cf6}.value-unit{font-size:1rem;font-weight:400;color:#6b7280}.event-text{font-size:.9375rem;color:#4b5563}.event-source{font-size:.875rem;color:#9ca3af}@media (max-width: 768px){.history-page{padding:1rem}.page-header h1{font-size:1.5rem}.event-card{padding:1rem}.event-header{flex-direction:column;gap:.5rem}.event-date{margin-left:0}.value-number{font-size:1.25rem}}.nutrition-history-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.page-header h1{margin:0 0 .5rem;font-size:2rem;color:#1f2937}.page-header p{margin:0;color:#6b7280;font-size:1rem}.loading,.empty-state{text-align:center;padding:4rem 2rem;color:#6b7280;font-size:1.125rem}.nutrition-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:linear-gradient(135deg,#10b981,#059669);padding:1.5rem;border-radius:12px;color:#fff;text-align:center}.stat-label{font-size:.875rem;opacity:.9;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-unit{font-size:.875rem;opacity:.8}.chart-section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.chart-section h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1f2937}.daily-entries-section{margin-top:3rem}.daily-entries-section h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1f2937}.entries-grid{display:grid;gap:1rem}.nutrition-day-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .2s}.nutrition-day-card:hover{box-shadow:0 4px 6px #0000001a;border-color:#10b981}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.day-header h3{margin:0;font-size:1.125rem;color:#1f2937}.calorie-status{font-size:.875rem;font-weight:600;padding:.25rem .75rem;border-radius:999px}.calorie-status.under{background:#d1fae5;color:#065f46}.calorie-status.over{background:#fee2e2;color:#991b1b}.day-calories{margin-bottom:1rem}.calorie-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.9375rem}.calorie-row .label{color:#6b7280}.calorie-row .value{color:#1f2937;font-weight:600}.calorie-row.deficit{margin-top:.5rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.calorie-row.deficit .label{color:#1f2937;font-weight:600}.calorie-row.deficit .value{color:#10b981;font-weight:700}.day-macros{display:flex;justify-content:space-around;align-items:center;background:#f9fafb;padding:1rem;border-radius:8px}.macro-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.macro-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.macro-value{font-size:1.125rem;font-weight:700;color:#1f2937}.macro-divider{width:1px;height:2rem;background:#d1d5db}@media (max-width: 768px){.nutrition-history-page{padding:1rem}.page-header h1{font-size:1.5rem}.nutrition-stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.chart-section{padding:1rem}.chart-section h2{font-size:1.25rem}.nutrition-day-card{padding:1rem}.day-header{flex-direction:column;align-items:flex-start;gap:.5rem}.day-macros{padding:.75rem}.macro-value{font-size:1rem}}.layout{min-height:100vh;display:flex;flex-direction:column}.nav{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-gray-200);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.nav-brand{font-size:var(--font-size-2xl);font-weight:800;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;z-index:11;letter-spacing:-.025em}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:11;border-radius:var(--radius-sm);transition:background .2s}.hamburger:hover{background:var(--color-gray-100)}.hamburger-line{width:25px;height:3px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);transition:all .3s ease;border-radius:2px}.hamburger-line.open:nth-child(1){transform:rotate(45deg) translate(8px,8px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.nav-links{display:flex;gap:.5rem;align-items:center}.nav-links a{text-decoration:none;color:var(--text-secondary);font-weight:600;font-size:var(--font-size-sm);padding:.625rem 1rem;border-radius:var(--radius-md);transition:all .2s ease;position:relative}.nav-links a:hover{background:var(--color-primary-bg);color:var(--color-primary-dark);transform:translateY(-1px)}.nav-links a.active{color:var(--color-primary);background:var(--color-primary-bg);box-shadow:var(--shadow-sm)}.nav-links a.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40%;height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-primary) 50%,transparent 100%);border-radius:var(--radius-full)}.main{flex:1;padding:var(--space-xl);max-width:1200px;width:100%;margin:0 auto}@media (max-width: 768px){.nav{padding:var(--space-md) var(--space-lg)}.hamburger{display:flex}.nav-links{position:fixed;top:0;right:-100%;height:100vh;width:75%;max-width:320px;background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;justify-content:flex-start;padding:80px var(--space-lg) var(--space-lg);gap:var(--space-xs);box-shadow:var(--shadow-xl);transition:right .3s cubic-bezier(.4,0,.2,1);z-index:10}.nav-links.mobile-open{right:0}.nav-links a{width:100%;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border-bottom:none;text-align:left}.nav-links a.active:after{display:none}.nav-links a.active{background:linear-gradient(135deg,var(--color-primary-bg) 0%,rgba(129,140,248,.1) 100%)}.main{padding:var(--space-md)}}@media (max-width: 1024px) and (min-width: 769px){.nav-links{gap:var(--space-xs)}.nav-links a{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm)}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #6366f1;--color-primary-dark: #4f46e5;--color-primary-light: #818cf8;--color-primary-bg: #eef2ff;--color-secondary: #10b981;--color-secondary-dark: #059669;--color-accent: #f59e0b;--color-danger: #ef4444;--color-danger-dark: #dc2626;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--text-primary: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(to bottom,#f9fafb,#fff);background-attachment:fixed;color:var(--text-primary);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;background:var(--color-gray-100);padding:.125rem .375rem;border-radius:var(--radius-sm);font-size:.875em}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}.page-header{margin-bottom:var(--space-xl)}.page-header h1{font-size:var(--font-size-3xl);margin-bottom:var(--space-sm);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header p{color:var(--text-secondary);font-size:var(--font-size-lg)}.loading{text-align:center;padding:var(--space-2xl);color:var(--text-secondary);font-size:var(--font-size-lg)}.card{background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .2s ease}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}
