*{margin:0;padding:0;-webkit-box-sizing:border-box;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f8fafc;color:#334155;line-height:1.6}.container{max-width:1400px;margin:0 auto;padding:20px}.header{margin-bottom:30px;text-align:center}.header h1{font-size:2.5rem;color:#1e293b;margin-bottom:15px;font-weight:700}.status{display:flex;justify-content:center;align-items:center;grid-gap:20px;gap:20px;margin-top:15px;flex-wrap:wrap}.status-indicator{padding:12px 24px;border-radius:25px;font-weight:600;font-size:1.1rem;-webkit-box-shadow:0 2px 8px rgba(0,0,0,.1);box-shadow:0 2px 8px rgba(0,0,0,.1);-webkit-transition:all .3s ease;transition:all .3s ease}.status-indicator.enter{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.status-indicator.exit{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.status-indicator.unknown{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.last-action{color:#64748b;font-size:.9rem;background:#fff;padding:8px 16px;border-radius:15px;-webkit-box-shadow:0 2px 4px rgba(0,0,0,.1);box-shadow:0 2px 4px rgba(0,0,0,.1)}.main{background:#fff;border-radius:16px;padding:30px;-webkit-box-shadow:0 4px 20px rgba(0,0,0,.08);box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid #e2e8f0}.chart-container{display:flex;grid-gap:20px;gap:20px;margin-bottom:30px;overflow-y:auto;max-height:800px}.date-axis-vertical{display:flex;flex-direction:column;width:120px;min-width:120px;padding-top:45px;flex-shrink:0}.date-label-vertical{height:30px;display:flex;align-items:center;justify-content:flex-end;font-size:.75rem;color:#475569;font-weight:500;padding-right:15px;border-right:2px solid #f1f5f9;margin-bottom:2px;width:100%}.date-text{text-align:right;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:60px}.total-time{font-size:.6rem;color:#64748b;margin-left:5px;white-space:nowrap}.chart-main{flex:1 1;min-height:600px}.time-axis-horizontal{display:flex;height:40px;margin-bottom:5px;border-bottom:2px solid #f1f5f9}.time-label-horizontal{flex:1 1;text-align:center;font-size:.7rem;color:#64748b;font-weight:500;display:flex;align-items:flex-end;justify-content:center;padding-bottom:5px;border-left:1px solid #f8fafc}.time-label-horizontal:first-child{border-left:none}.data-grid-horizontal{display:flex;flex-direction:column}.day-row{height:30px;position:relative;margin-bottom:2px;border:1px solid #f1f5f9;border-radius:4px;background:#fafbfc}.time-bar-horizontal{position:relative;width:100%;height:100%}.session-bar{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:4px;margin:2px 0;-webkit-box-shadow:0 2px 4px rgba(59,130,246,.3);box-shadow:0 2px 4px rgba(59,130,246,.3);cursor:pointer;-webkit-transition:all .3s ease;transition:all .3s ease;border-top:2px solid #1e40af;border-bottom:2px solid #1e40af}.session-bar:hover{background:linear-gradient(135deg,#2563eb,#1e40af);-webkit-transform:scaleY(1.1);transform:scaleY(1.1);-webkit-box-shadow:0 4px 12px rgba(37,99,235,.4);box-shadow:0 4px 12px rgba(37,99,235,.4);z-index:10}.session-bar.ongoing{background:linear-gradient(135deg,#10b981,#059669);border-top:2px solid #047857;border-bottom:2px solid #047857;-webkit-animation:pulse 2s infinite;animation:pulse 2s infinite}.session-bar.ongoing:hover{background:linear-gradient(135deg,#059669,#047857)}@-webkit-keyframes pulse{0%{opacity:1}50%{opacity:.8}to{opacity:1}}@keyframes pulse{0%{opacity:1}50%{opacity:.8}to{opacity:1}}.stats{text-align:center;padding-top:25px;border-top:2px solid #f1f5f9;display:flex;flex-direction:column;grid-gap:15px;gap:15px}.stats p{color:#64748b;font-size:1rem;font-weight:500}.auto-update-info{color:#94a3b8!important;font-size:.85rem!important;font-weight:400!important;font-style:italic}.refresh-button,.retry-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:12px 24px;border-radius:12px;cursor:pointer;font-size:.95rem;font-weight:600;-webkit-transition:all .3s ease;transition:all .3s ease;-webkit-box-shadow:0 4px 12px rgba(59,130,246,.3);box-shadow:0 4px 12px rgba(59,130,246,.3);align-self:center;min-width:160px}.refresh-button:hover,.retry-button:hover{background:linear-gradient(135deg,#2563eb,#1e40af);-webkit-transform:translateY(-2px);transform:translateY(-2px);-webkit-box-shadow:0 6px 20px rgba(37,99,235,.4);box-shadow:0 6px 20px rgba(37,99,235,.4)}.refresh-button:active,.retry-button:active{-webkit-transform:translateY(0);transform:translateY(0);-webkit-box-shadow:0 2px 8px rgba(37,99,235,.3);box-shadow:0 2px 8px rgba(37,99,235,.3)}.error,.loading{text-align:center;padding:60px;font-size:1.2rem;font-weight:500}.error{color:#dc2626;background:#fef2f2;border:2px solid #fecaca;border-radius:12px;margin:20px 0}.loading{color:#64748b;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px}.session-bar[title]:hover:after{content:attr(title);-webkit-transform:translateX(-50%);transform:translateX(-50%);background:#1e293b;color:#fff;padding:10px 14px;border-radius:8px;white-space:pre-line;font-size:.75rem;-webkit-box-shadow:0 4px 12px rgba(0,0,0,.3);box-shadow:0 4px 12px rgba(0,0,0,.3);-webkit-animation:tooltipFadeIn .2s ease-out;animation:tooltipFadeIn .2s ease-out;min-width:140px;text-align:center}.session-bar[title]:hover:after,.session-bar[title]:hover:before{position:absolute;bottom:100%;left:50%;z-index:9999;pointer-events:none}.session-bar[title]:hover:before{content:"";-webkit-transform:translateX(-50%) translateY(2px);transform:translateX(-50%) translateY(2px);border:6px solid transparent;border-top-color:#1e293b}@-webkit-keyframes tooltipFadeIn{0%{opacity:0;-webkit-transform:translateX(-50%) translateY(-4px);transform:translateX(-50%) translateY(-4px)}to{opacity:1;-webkit-transform:translateX(-50%) translateY(0);transform:translateX(-50%) translateY(0)}}@keyframes tooltipFadeIn{0%{opacity:0;-webkit-transform:translateX(-50%) translateY(-4px);transform:translateX(-50%) translateY(-4px)}to{opacity:1;-webkit-transform:translateX(-50%) translateY(0);transform:translateX(-50%) translateY(0)}}@media (max-width:1200px){.chart-main{min-width:600px}.date-label{font-size:.7rem}.total-time{font-size:.6rem}}@media (max-width:768px){.container{padding:15px}.header h1{font-size:2rem}.status{flex-direction:column;grid-gap:15px;gap:15px}.main{padding:20px}.chart-container{grid-gap:15px;gap:15px}.date-axis-vertical{width:100px;min-width:100px;padding-top:35px;flex-shrink:0}.date-label-vertical{height:25px;font-size:.65rem;padding-right:10px;width:100%}.date-text{min-width:50px;white-space:nowrap}.time-axis-horizontal{height:30px}.time-label-horizontal{font-size:.6rem}.day-row{height:25px}.total-time{font-size:.55rem}.stats{grid-gap:12px;gap:12px}.stats p{font-size:.9rem}}.chart-container::-webkit-scrollbar{height:8px}.chart-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.chart-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.chart-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}