:root{--bg-primary: #000000;--bg-secondary: #111111;--bg-panel: #1a1a1a;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #666666;--accent-primary: #3b82f6;--accent-danger: #ef4444;--accent-success: #22c55e;--accent-warning: #eab308;--border-color: #333333;--border-light: #444444;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-family: "Inter", system-ui, -apple-system, sans-serif;--font-size-sm: 12px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--header-height: 60px;--panel-height: 200px;--hour-width: 60px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}.recharts-wrapper,.recharts-surface,.recharts-layer,.recharts-sector,.recharts-rectangle,.recharts-curve,.recharts-dot,path,g,rect{outline:none!important}.recharts-wrapper *:focus{outline:none!important}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);-webkit-font-smoothing:antialiased;overflow:hidden}#root{height:100dvh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.timeline-scroll-wrapper{width:100%;height:100%;overflow:auto;position:relative;scrollbar-width:thin;scrollbar-color:var(--border-light) var(--bg-secondary);overscroll-behavior:none}.timeline-content{position:relative;min-height:100%;height:max-content;display:flex;flex-direction:column;row-gap:12px;padding-bottom:40px}.now-line{position:absolute;top:0;bottom:0;width:2px;background-color:#8b0000;z-index:50;pointer-events:none}.time-axis{position:relative;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow:hidden}.time-tick{position:absolute;top:0;bottom:0;border-left:1px solid var(--border-light);display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:4px;padding-left:4px;font-size:10px;color:var(--text-muted)}.time-tick.midnight{border-left:1px solid var(--text-secondary)}.hour-label{margin-bottom:2px}.day-label{position:absolute;top:2px;left:4px;font-weight:700;color:var(--text-primary);font-size:12px;white-space:nowrap}.weather-panel{position:relative;width:100%;border-bottom:1px solid var(--border-color);background-color:var(--bg-panel);display:flex;flex-direction:column}.panel-header{width:fit-content;padding:4px 12px 4px 38px;z-index:70;pointer-events:none;position:sticky;left:0;white-space:nowrap}.panel-body{display:grid;grid-template-areas:"axis content";grid-template-columns:32px 1fr;align-items:stretch;width:100%;position:relative}.panel-title{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px}.panel-axis{grid-area:axis;position:sticky;left:0;z-index:15;background-color:#1a1a1af2;border-right:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;min-width:32px}.panel-content{grid-area:content;width:100%;height:100%;position:relative;z-index:1;overflow:hidden}.panel-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.02) 10px,rgba(255,255,255,.02) 20px)}.app-container{display:flex;flex-direction:column;height:100dvh;width:100vw;background-color:var(--bg-primary)}.app-header{height:var(--header-height);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);background-color:var(--bg-secondary)}.logo{font-weight:700;font-size:var(--font-size-lg)}.header-controls{display:flex;align-items:center;gap:var(--spacing-md)}.status-indicator{width:12px;height:12px;border-radius:50%;background-color:var(--accent-success);box-shadow:0 0 8px var(--accent-success)}.settings-btn{background:none;border:1px solid var(--border-light);color:var(--text-secondary);padding:4px 8px;border-radius:4px;cursor:pointer;font-size:var(--font-size-sm)}.settings-btn:hover{background-color:var(--bg-panel);color:var(--text-primary)}.app-main{flex:1;overflow:hidden;position:relative}
