.split-view{width:100%;height:100%;display:flex;overflow:hidden}.split-view-left,.split-view-right{height:100%;transition:width .1s ease-out;position:relative;overflow:auto}.split-view-left{background-color:#fff;border-right:none}.split-view-right{background-color:#f8f9fa}.split-view-divider{cursor:col-resize;z-index:10;background-color:#e9ecef;justify-content:center;align-items:center;width:5px;transition:background-color .15s;display:flex}.split-view-divider:hover{background-color:#339af0}.split-view-divider-grip{display:none}.editor{background:#fff;flex-direction:column;height:100%;display:flex}.editor-header{background-color:#fff;border-bottom:1px solid #e9ecef;flex-shrink:0;align-items:center;height:44px;padding:0 1rem;display:flex}.editor-header h2{color:#adb5bd;text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.75rem;font-weight:600}.editor-content{flex:1;overflow:hidden}.monaco-editor .margin{background-color:#fff!important}.timeline-container{background:#fff;flex-direction:column;height:100%;display:flex;overflow:hidden}.timeline-header{background-color:#fff;border-bottom:1px solid #e9ecef;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;height:44px;padding:0 1rem;display:flex}.timeline-header h2{color:#adb5bd;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;margin:0;font-size:.75rem;font-weight:600}.timeline-controls{align-items:center;gap:.75rem;display:flex}.timeline-toggles{gap:4px;display:flex}.timeline-pill-btn{color:#868e96;cursor:pointer;background:0 0;border:1px solid #dee2e6;border-radius:999px;padding:3px 10px;font-size:.75rem;font-weight:500;transition:all .15s}.timeline-pill-btn:hover{color:#495057;border-color:#adb5bd}.timeline-pill-btn.active{color:#1971c2;background:#e7f5ff;border-color:#74c0fc}.timeline-ratio-group{border:1px solid #dee2e6;border-radius:6px;display:flex;overflow:hidden}.timeline-ratio-btn{color:#868e96;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-right:1px solid #dee2e6;padding:3px 10px;font-size:.75rem;font-weight:500;transition:all .15s}.timeline-ratio-btn:last-child{border-right:none}.timeline-ratio-btn:hover{color:#495057;background:#f8f9fa}.timeline-ratio-btn.active{color:#fff;background:#1a1b1e}.timeline-export-buttons{gap:6px;display:flex}.timeline-download-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:5px;padding:4px 12px;font-size:.75rem;font-weight:600;transition:all .15s}.timeline-download-btn.secondary{color:#495057;background:#f1f3f5}.timeline-download-btn.secondary:hover{color:#212529;background:#e9ecef}.timeline-download-btn.primary{color:#fff;background:#339af0}.timeline-download-btn.primary:hover{background:#228be6}.timeline-download-btn.success{color:#fff;background:#40c057}.timeline-content{background:#f8f9fa;flex:1;padding:1rem;position:relative;overflow:auto}.timeline-svg{background:#fff;border-radius:6px;min-width:100%;display:block;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.empty-timeline{color:#adb5bd;justify-content:center;align-items:center;font-size:.875rem;display:flex}.timeline-track-bg{fill:#f8f9fa;stroke:#f1f3f5;stroke-width:1px}.timeline-track-bg:nth-child(2n){fill:#fff}.timeline-track-label{fill:#343a40;dominant-baseline:middle;text-transform:uppercase;letter-spacing:.8px;font-weight:700;line-height:1.2}.timeline-track-label tspan{dominant-baseline:text-before-edge}.timeline-row-label{fill:#868e96;dominant-baseline:middle;font-size:.7rem;font-weight:500}.timeline-track text,.timeline-row text{text-anchor:end}.timeline-grid-line{stroke:#f1f3f5;stroke-width:1px}.timeline-week-label{fill:#868e96;font-size:.65rem;font-weight:500}.timeline-month-label{fill:#495057;font-size:.7rem;font-weight:600}.timeline-day-label{fill:#adb5bd;font-size:.65rem}.timeline-bar-rect{stroke-width:0;opacity:1}.timeline-bar-label{fill:#fff;pointer-events:none;font-size:.7rem;font-weight:600}.timeline-point-label{fill:#343a40;pointer-events:none;font-size:.7rem;font-weight:500}.timeline-point-shape{stroke-width:0}.timeline-milestone-line{stroke-width:1.5px;stroke-dasharray:4 3;opacity:.55}.timeline-milestone-marker{stroke-width:0;opacity:1}.timeline-milestone-label{fill:#212529;font-size:.75rem;font-weight:600}.timeline-milestone-bg{fill:#fff;stroke:none}.timeline-today-line{stroke:#fa5252;stroke-width:1.5px;stroke-dasharray:4 4;opacity:.8}.timeline-today-stipple{stroke:#fa5252;stroke-width:1px;stroke-dasharray:1 3;opacity:.2}.timeline-today-bg{fill:#fa5252}.timeline-today-label{fill:#fff;font-size:.7rem;font-weight:700}.color-blue{fill:#339af0;stroke:#339af0}.color-lightblue{fill:#74c0fc;stroke:#74c0fc}.color-green{fill:#40c057;stroke:#40c057}.color-lightgreen{fill:#8ce99a;stroke:#8ce99a}.color-yellow{fill:#fcc419;stroke:#fcc419}.color-orange{fill:#fd7e14;stroke:#fd7e14}.color-red{fill:#fa5252;stroke:#fa5252}.color-purple{fill:#cc5de8;stroke:#cc5de8}.color-pink{fill:#f06595;stroke:#f06595}.color-cyan{fill:#15aabf;stroke:#15aabf}.color-teal{fill:#12b886;stroke:#12b886}.color-gray{fill:#868e96;stroke:#868e96}.color-indigo{fill:#5c7cfa;stroke:#5c7cfa}.color-violet{fill:#845ef7;stroke:#845ef7}.color-lime{fill:#82c91e;stroke:#82c91e}.timeline-bar-rect:hover{filter:brightness(1.08);cursor:default}.timeline-point-shape:hover{filter:brightness(1.1);cursor:default}.help-modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.help-modal{background:#fff;border-radius:8px;flex-direction:column;width:90%;max-width:800px;max-height:90vh;display:flex;box-shadow:0 4px 6px #0000001a}.help-modal-header{border-bottom:1px solid #e9ecef;justify-content:space-between;align-items:center;padding:1rem;display:flex}.help-modal-header h2{color:#495057;margin:0;font-size:1.25rem}.help-modal-close{color:#6c757d;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1}.help-modal-close:hover{color:#495057}.help-modal-content{padding:1.5rem;overflow-y:auto}.help-modal-content section{margin-bottom:2rem}.help-modal-content h3{color:#495057;margin-top:0;margin-bottom:1rem;font-size:1.1rem}.help-modal-content h4{color:#495057;margin-top:1.5rem;margin-bottom:.5rem;font-size:1rem}.help-modal-content p{color:#495057;margin-bottom:1rem;line-height:1.5}.help-modal-content pre{background:#f8f9fa;border-radius:4px;margin:.5rem 0 1rem;padding:1rem;font-size:.875rem;line-height:1.5;overflow-x:auto}.help-modal-content code{color:#495057;background:#f1f3f5;border-radius:3px;padding:.2rem .4rem;font-size:.875rem}.help-modal-content ul{margin:.5rem 0 1rem;padding-left:1.5rem}.help-modal-content li{color:#495057;margin-bottom:.5rem;line-height:1.5}:root{--surface:#fff;--surface-subtle:#f8f9fa;--border:#e9ecef;--text-primary:#212529;--text-secondary:#6c757d;--text-muted:#adb5bd;--accent:#339af0;--accent-dark:#1c7ed6;--header-bg:#1a1b1e;--header-text:#c9d1d9}.app{background-color:var(--surface-subtle);height:100vh;color:var(--text-primary);flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;display:flex;overflow:hidden}.app-header{background-color:var(--header-bg);border-bottom:1px solid #2d2e31;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 1.25rem;display:flex}.app-header h1{color:var(--header-text);letter-spacing:.02em;margin:0;font-size:.875rem;font-weight:600}.help-button{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #444;border-radius:50%;justify-content:center;align-items:center;font-size:.875rem;font-weight:600;transition:all .15s;display:flex}.help-button:hover{color:var(--header-text);border-color:#888}.app-content{flex:1;overflow:hidden}*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]{display:none}.visible{visibility:visible}.fixed{position:fixed}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.uppercase{text-transform:uppercase}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}
