.chart-container{width:100%;height:100%;min-height:400px;background:#fafafa;border-radius:12px;padding:15px;box-sizing:border-box}.custom-tooltip{background:#fff;border:2px solid #667eea;border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000026;z-index:10}.tooltip-time{margin:0 0 8px;font-weight:600;color:#667eea;font-size:.9rem}.tooltip-value{margin:0 0 6px;color:#333;font-size:.9rem}.tooltip-value strong{color:#0288d1;font-weight:700}.tooltip-context{margin:0;color:#666;font-size:.85rem;font-style:italic}@media (max-width: 768px){.chart-container{min-height:300px;padding:10px}}@media (max-width: 480px){.chart-container{min-height:250px;padding:8px}.custom-tooltip{font-size:.85rem;padding:10px}}.statistics-panel{background:#fff;border-radius:12px;padding:25px;height:100%;display:flex;flex-direction:column}.stats-title{margin:0 0 20px;color:#333;font-size:1.2rem;font-weight:600}.stats-grid{display:grid;grid-template-columns:1fr;gap:15px;margin-bottom:25px;flex:1}.stat-card{display:flex;align-items:center;gap:15px;padding:15px;background:linear-gradient(135deg,#f5f7ff,#f0e6ff);border-radius:10px;border-left:4px solid #667eea;cursor:help;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #667eea1a;transform:translate(4px)}.stat-icon{font-size:1.8rem;min-width:40px;text-align:center}.stat-content{flex:1;min-width:0}.stat-label{margin:0;color:#666;font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{margin:4px 0 0;color:#333;font-size:1.3rem;font-weight:700}.stat-unit{font-size:.9rem;margin-left:4px;color:#999}.sleep-recommendation{margin-top:auto;padding-top:20px;border-top:2px solid #f0f0f0}.sleep-recommendation h3{margin:0 0 15px;color:#333;font-size:1.1rem}.recommendation-box{padding:15px;border-radius:10px;border-left:4px solid #FFC107}.recommendation-box.excellent{background:#f1f8e9;border-left-color:#4caf50}.recommendation-box.excellent .assessment-status{color:#2e7d32}.recommendation-box.excellent .assessment-detail{color:#558b2f}.recommendation-box.good{background:#fff3e0;border-left-color:#8bc34a}.recommendation-box.good .assessment-status{color:#e65100}.recommendation-box.good .assessment-detail{color:#bf360c}.recommendation-box.needs-improvement{background:#ffebee;border-left-color:#f44336}.recommendation-box.needs-improvement .assessment-status{color:#c62828}.recommendation-box.needs-improvement .assessment-detail{color:#b71c1c}.assessment-status{margin:0 0 8px;font-weight:600;font-size:1rem}.assessment-detail{margin:0;font-size:.9rem;line-height:1.5}@media (max-width: 1024px){.statistics-panel{min-height:auto}}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr 1fr}.stat-card{flex-direction:column;text-align:center;gap:10px}.stat-icon{min-width:auto}.stat-label{font-size:.75rem}.stat-value{font-size:1.2rem}}@media (max-width: 480px){.statistics-panel{padding:15px}.stats-title{font-size:1rem}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:12px;gap:12px}.stat-icon{font-size:1.5rem}.stat-value{font-size:1.1rem}}.status-indicator-container{display:flex;justify-content:center;align-items:stretch;min-height:100px}.status-card{flex:1;background:#fff;border-radius:15px;padding:25px;border-left:5px solid;display:flex;flex-direction:column;justify-content:center;box-shadow:0 4px 15px #00000014;transition:transform .2s ease,box-shadow .2s ease}.status-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001f}.status-header{display:flex;align-items:center;gap:15px;margin-bottom:15px}.status-icon{font-size:2.5rem;line-height:1}.status-label{margin:0;font-size:1.5rem;font-weight:700;color:#333}.current-reading{margin-bottom:20px}.light-level-display{display:flex;align-items:baseline;gap:8px;margin-bottom:10px}.light-value{font-size:3rem;font-weight:800;line-height:1}.light-unit{font-size:1.2rem;color:#999;font-weight:600}.status-message{margin:0;font-size:1rem;color:#666;font-weight:500}.threshold-guide{margin:20px 0;padding:15px;background:#f9f9f9;border-radius:10px;border:1px solid #e8e8e8}.threshold-guide h4{margin:0 0 12px;color:#333;font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.thresholds-list{display:flex;flex-direction:column;gap:10px}.threshold-item{display:flex;align-items:center;gap:10px;font-size:.9rem;color:#555}.threshold-color{width:16px;height:16px;border-radius:4px;flex-shrink:0;border:1px solid rgba(0,0,0,.1)}.info-box{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-radius:10px;padding:15px;border-left:4px solid #667eea}.info-title{margin:0 0 8px;color:#333;font-weight:600;font-size:.95rem}.info-text{margin:0;color:#555;font-size:.85rem;line-height:1.6}@media (max-width: 768px){.status-card{padding:20px;border-left-width:4px}.status-header{gap:12px;margin-bottom:12px}.status-icon{font-size:2rem}.status-label{font-size:1.3rem}.light-value{font-size:2.5rem}.light-unit{font-size:1rem}.status-message{font-size:.95rem}.threshold-guide{padding:12px;margin:15px 0}.threshold-guide h4{font-size:.85rem;margin-bottom:10px}.threshold-item{font-size:.85rem;gap:8px}.threshold-color{width:14px;height:14px}}@media (max-width: 480px){.status-card{padding:15px;border-left-width:4px}.status-header{gap:10px;margin-bottom:10px;flex-wrap:wrap}.status-icon{font-size:1.8rem}.status-label{font-size:1.2rem}.light-value{font-size:2rem}.light-unit,.status-message{font-size:.9rem}.current-reading{margin-bottom:15px}.threshold-guide{padding:10px;margin:12px 0}.threshold-guide h4{font-size:.8rem;margin-bottom:8px}.threshold-item{font-size:.8rem}.threshold-color{width:12px;height:12px}.info-box{padding:12px}.info-title{font-size:.9rem;margin-bottom:6px}.info-text{font-size:.8rem}}.timeline-container{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000000d}.timeline-legend{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.legend-item{display:flex;align-items:center;gap:10px;font-size:.95rem;color:#555}.legend-color{width:20px;height:20px;border-radius:4px;flex-shrink:0;border:1px solid rgba(0,0,0,.1);box-shadow:0 2px 4px #0000001a}.timeline-bars{margin-bottom:25px;max-height:500px;overflow-y:auto}.timeline-bar-group{display:grid;grid-template-columns:50px 1fr;gap:15px;align-items:center;margin-bottom:12px;padding:10px 0;border-bottom:1px solid #f5f5f5;transition:background .2s ease}.timeline-bar-group:last-child{border-bottom:none}.timeline-bar-group:hover{background:#f9f9f9;border-radius:8px;padding:10px 8px}.timeline-hour{font-weight:600;color:#333;font-size:.9rem;text-align:right}.timeline-bar-wrapper{position:relative;height:28px;background:#f0f0f0;border-radius:14px;overflow:hidden;display:flex;align-items:center}.timeline-bar{height:100%;border-radius:14px;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;font-size:.75rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2);transition:all .3s ease;cursor:help;min-width:35px}.timeline-bar:hover{filter:brightness(1.1);box-shadow:0 4px 12px #00000026}.timeline-bar-value{font-weight:700;letter-spacing:.5px}.timeline-summary{margin-top:25px;padding:20px;background:linear-gradient(135deg,#f5f7ff,#f0e6ff);border-radius:10px;border:1px solid #e8e8ff}.timeline-summary h3{margin:0 0 15px;color:#333;font-size:1.1rem;font-weight:600}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.summary-stat{display:flex;flex-direction:column;gap:5px;padding:12px;background:#fff;border-radius:8px;border-left:4px solid #667eea}.summary-label{font-size:.85rem;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:1.5rem;color:#333;font-weight:700}@media (max-width: 768px){.timeline-container{padding:20px}.timeline-legend{gap:12px;margin-bottom:20px}.legend-item{font-size:.85rem}.timeline-bar-group{grid-template-columns:45px 1fr;gap:12px;margin-bottom:10px}.timeline-hour{font-size:.8rem}.timeline-bar{min-width:30px}.timeline-bar-value{font-size:.7rem}.timeline-summary{margin-top:20px;padding:15px}.timeline-summary h3{font-size:1rem;margin-bottom:12px}.summary-stats{gap:12px}.summary-stat{padding:10px}.summary-label{font-size:.75rem}.summary-value{font-size:1.3rem}}@media (max-width: 480px){.timeline-container{padding:15px}.timeline-legend{flex-direction:column;gap:10px;margin-bottom:15px}.legend-item{font-size:.8rem}.legend-color{width:16px;height:16px}.timeline-bars{max-height:400px}.timeline-bar-group{grid-template-columns:40px 1fr;gap:10px;margin-bottom:8px;padding:8px 0}.timeline-hour{font-size:.75rem}.timeline-bar-wrapper{height:24px}.timeline-bar{padding-right:8px;min-width:28px}.timeline-bar-value{font-size:.65rem}.timeline-summary{padding:12px}.timeline-summary h3{font-size:.95rem;margin-bottom:10px}.summary-stats{grid-template-columns:1fr;gap:10px}.summary-stat{padding:10px;flex-direction:row;justify-content:space-between;align-items:center}.summary-label{font-size:.7rem}.summary-value{font-size:1.2rem}}.labeling-panel{background:#fff;border-radius:12px;padding:25px;margin:30px 0;box-shadow:0 2px 8px #0000000d}.labeling-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:15px}.labeling-header h2{margin:0;color:#333;font-size:1.3rem}.btn-add-label{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:25px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-add-label:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-add-label:disabled{opacity:.5;cursor:not-allowed}.label-form{background:linear-gradient(135deg,#f5f7ff,#f0e6ff);border:2px solid #e8e8ff;border-radius:12px;padding:20px;margin-bottom:20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:.95rem}.form-input,.form-textarea{width:100%;padding:10px 12px;border:2px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.form-input:focus,.form-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical}.activity-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.activity-option{padding:12px 15px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s;text-align:center}.activity-option:hover{border-color:#667eea;background:#f9f9ff}.activity-option.selected{background:linear-gradient(135deg,#667eea20,#764ba220);font-weight:700}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.form-error{background:#ffebee;border:2px solid #f44336;color:#c62828;padding:12px 15px;border-radius:8px;margin-bottom:15px;font-size:.9rem}.sync-error{background:#fff3e0;border:2px solid #ff9800;color:#e65100;padding:12px 15px;border-radius:8px;margin-bottom:15px;font-size:.9rem}.btn-submit{width:100%;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;padding:12px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.labels-list{display:flex;flex-direction:column;gap:12px}.label-item{background:#fff;border-left:4px solid #667eea;border-radius:8px;padding:15px;border:1px solid #e8e8e8;border-left-width:4px}.label-content{display:flex;flex-direction:column;gap:8px}.label-activity{font-weight:700;color:#333;font-size:1rem}.label-room{color:#666;font-size:.9rem;font-weight:500}.label-time{color:#999;font-size:.85rem;font-family:monospace}.label-notes{color:#555;font-size:.9rem;font-style:italic;padding-top:8px;border-top:1px solid #f0f0f0;margin-top:8px}.empty-state{text-align:center;padding:40px 20px;background:linear-gradient(135deg,#f5f7ff,#f0e6ff);border-radius:8px;color:#999}.empty-state p{margin:0 0 10px;font-size:.95rem}.empty-state .hint{margin:0;font-size:.85rem;color:#bbb}@media (max-width: 768px){.labeling-header{flex-direction:column;align-items:stretch}.btn-add-label{width:100%;text-align:center}.form-row{grid-template-columns:1fr}.activity-options{grid-template-columns:1fr 1fr}.label-form{padding:15px}}@media (max-width: 480px){.labeling-panel{padding:15px;margin:20px 0}.labeling-header h2{font-size:1.1rem}.label-form{padding:12px}.activity-options{grid-template-columns:1fr}.label-item{padding:12px}.empty-state{padding:30px 15px}}.insights-panel{background:#fff;border-radius:12px;padding:25px;margin:30px 0;box-shadow:0 2px 8px #0000000d}.insights-panel h2{margin:0 0 25px;color:#333;font-size:1.3rem}.insights-panel.empty{text-align:center;color:#999;padding:50px 25px}.insights-panel.empty p{margin:0;font-size:1rem}.insights-section{margin-bottom:30px}.insights-section h3{margin:0 0 15px;color:#555;font-size:1.1rem;font-weight:600;border-bottom:2px solid #f0f0f0;padding-bottom:10px}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px}.insight-card{background:linear-gradient(135deg,#f9f9ff,#f5f5ff);border:2px solid #e8e8ff;border-radius:10px;padding:15px;display:flex;gap:12px;align-items:flex-start}.insight-card.status-excellent{border-color:#4caf50;background:linear-gradient(135deg,#f1f8e9,#e8f5e9)}.insight-card.status-good{border-color:#8bc34a;background:linear-gradient(135deg,#f9fde7,#f1f8e9)}.insight-card.status-needs-improvement{border-color:#f44336;background:linear-gradient(135deg,#ffebee,#ffcdd2)}.insight-card.status-neutral{border-color:#2196f3;background:linear-gradient(135deg,#e3f2fd,#e1f5fe)}.insight-icon{font-size:2rem;min-width:50px;text-align:center;line-height:1}.insight-content{flex:1}.insight-content h4{margin:0 0 8px;color:#333;font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.insight-value{font-size:1.6rem;font-weight:700;color:#0288d1;margin:0 0 6px}.insight-value .unit{font-size:.8rem;margin-left:4px;color:#999;font-weight:500}.insight-description{margin:0;font-size:.8rem;color:#666;line-height:1.4}.room-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}.room-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background:#fff;border-radius:6px;font-size:.9rem}.room-name{font-weight:600;color:#333}.room-avg{color:#0288d1;font-weight:700}.comparison-content{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.comparison-item{display:flex;flex-direction:column;gap:4px;padding:8px;background:#fff;border-radius:6px;text-align:center}.comparison-item .label{font-size:.75rem;color:#999;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.comparison-item .value{font-size:1.3rem;font-weight:700;color:#0288d1}.comparison-delta{grid-column:1 / -1;padding:8px;background:#e8f5e9;border-radius:6px;color:#2e7d32;font-weight:700;text-align:center;font-size:.95rem}.comparison-delta.negative{background:#ffebee;color:#c62828}.room-comparison{display:flex;flex-direction:column;gap:12px;margin-top:10px}.room-comparison-item{display:grid;grid-template-columns:80px 1fr 50px;gap:10px;align-items:center}.room-label{font-size:.85rem;font-weight:600;color:#333}.room-bar{height:20px;background:#f0f0f0;border-radius:10px;overflow:hidden}.room-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .3s ease}.room-value{font-size:.85rem;font-weight:700;color:#0288d1;text-align:right}.insight-recommendation{background:linear-gradient(135deg,#e0f2f1,#e0f2f1);border:2px solid #4DB6AC;border-radius:10px;padding:15px;margin-top:20px}.insight-recommendation h4{margin:0 0 10px;color:#00695c;font-size:1rem}.insight-recommendation p{margin:8px 0;color:#00897b;font-size:.9rem;line-height:1.5}.insight-recommendation p:first-child{margin-top:0}.insight-recommendation p:last-child{margin-bottom:0}@media (max-width: 768px){.insights-grid{grid-template-columns:repeat(2,1fr)}.insight-card{flex-direction:column;align-items:center;text-align:center}.insight-icon{font-size:1.8rem;min-width:auto}.comparison-content{grid-template-columns:1fr}.room-comparison-item{grid-template-columns:70px 1fr 40px;gap:8px}}@media (max-width: 480px){.insights-panel{padding:15px}.insights-panel h2{font-size:1.1rem}.insights-grid{grid-template-columns:1fr}.insight-card{padding:12px;gap:10px}.insight-icon{font-size:1.5rem}.insight-content h4{font-size:.85rem}.insight-value{font-size:1.4rem}.insight-recommendation{padding:12px}.room-comparison-item{grid-template-columns:60px 1fr 35px}.room-label{font-size:.8rem}}.dashboard{max-width:1400px;margin:0 auto;background:#fff;border-radius:20px;box-shadow:0 10px 40px #6464961a;overflow:hidden}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.header-content h1{font-size:2.5rem;margin:0 0 10px;font-weight:700;letter-spacing:-.5px}.header-content .subtitle{margin:0;font-size:1.1rem;opacity:.95;font-weight:300}.refresh-btn{background:#ffffff40;border:2px solid rgba(255,255,255,.5);color:#fff;padding:10px 20px;border-radius:25px;font-size:1rem;cursor:pointer;font-weight:600;transition:all .3s ease;white-space:nowrap}.refresh-btn:hover:not(:disabled){background:#fff6;transform:scale(1.05)}.refresh-btn:disabled{opacity:.7;cursor:not-allowed}.last-updated{text-align:right;padding:10px 30px;font-size:.85rem;color:#666;border-bottom:1px solid #f0f0f0;background:#fafafa}.status-section{padding:30px;background:linear-gradient(135deg,#f5f7ff,#f0e6ff);border-bottom:1px solid #e8e8ff}.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:30px;padding:30px;background:#fff}.chart-section,.stats-section{min-height:400px}.section-title{display:flex;align-items:center;gap:10px;margin-bottom:20px}.section-title h2{margin:0;color:#333;font-size:1.4rem}.tooltip-icon{font-size:1.2rem;cursor:help;opacity:.6;transition:opacity .2s}.tooltip-icon:hover{opacity:1}.timeline-section{padding:30px;border-top:1px solid #f0f0f0;background:#fff}.timeline-section .section-title{margin-bottom:25px}.labeling-section,.insights-section{padding:0;background:#fff}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 30px;text-align:center}.spinner{border:4px solid #f0f0f0;border-top:4px solid #667eea;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state p{color:#666;font-size:1.1rem;margin:0}.error-state{display:flex;align-items:center;justify-content:center;min-height:400px}.error-message{text-align:center;padding:40px;background:#ffebee;border-radius:15px;border:2px solid #f44336;color:#c62828}.error-message h2{margin:0 0 15px;font-size:1.5rem}.error-message p{margin:0 0 20px;font-size:1rem}@media (max-width: 1024px){.content-grid{grid-template-columns:1fr;gap:20px;padding:20px}.dashboard-header{padding:30px 20px;flex-direction:column;align-items:flex-start}.header-content h1{font-size:2rem}.refresh-btn{align-self:stretch;text-align:center}}@media (max-width: 768px){.dashboard-header{padding:25px 15px;gap:15px}.header-content h1{font-size:1.6rem;margin-bottom:8px}.header-content .subtitle{font-size:1rem}.status-section,.content-grid,.timeline-section{padding:20px 15px}.section-title h2{font-size:1.2rem}.last-updated{padding:8px 15px;font-size:.8rem}}@media (max-width: 480px){.dashboard{border-radius:10px}.dashboard-header{padding:20px 12px}.header-content h1{font-size:1.3rem}.header-content .subtitle{font-size:.9rem}.status-section,.content-grid,.timeline-section{padding:15px 12px}.section-title h2{font-size:1.1rem}.refresh-btn{padding:8px 16px;font-size:.9rem}}.app{min-height:100vh;background:linear-gradient(135deg,#e0f4ff,#f0e6ff);padding:20px}@media (max-width: 768px){.app{padding:15px}}@media (max-width: 480px){.app{padding:10px}}
