:root{--accent-purple: rgb(89, 37, 220);--accent-purple-soft: #a78bfa}*{margin:0;padding:0;box-sizing:border-box}[hidden]{display:none!important}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0a0a0a;color:#e0e0e0;min-height:100vh}#app{width:100%;min-height:100vh}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-overlay.hidden{display:none}.modal-overlay.drag-over .modal{border-color:var(--accent-purple-soft);background:#5925dc0d}.modal{width:100%;max-width:620px;padding:32px 40px;border:2px dashed #444;border-radius:10px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:#161616}.modal:hover{border-color:var(--accent-purple-soft)}.modal__logo{display:block;width:auto;height:38px;margin:0 auto 18px;opacity:.85}.modal h1{font-size:1.7rem;margin-bottom:6px;color:#fff}.modal p{color:#888;margin-bottom:18px}.modal code{background:#252525;padding:2px 6px;border-radius:4px;color:#fff}.modal--error{cursor:default;border-style:solid;border-color:#3a2222;max-width:680px;text-align:left}.modal--error:hover{border-color:#3a2222}.modal--error h1{text-align:center}.modal__disclosure{margin-top:20px;font-size:11px;color:#555;text-align:center;line-height:1.5}.modal__errors-intro{color:#f08a8a;margin-bottom:16px;text-align:center}.error-list{max-height:360px;overflow-y:auto;margin-bottom:20px;border:1px solid #2a1a1a;border-radius:8px;background:#120d0d;text-align:left}.error-group{padding:12px 16px;border-bottom:1px solid #2a1a1a}.error-group:last-child{border-bottom:none}.error-group__title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#f08a8a;margin-bottom:6px}.error-group__items{list-style:none;padding:0;margin:0}.error-group__items li{font-size:.85rem;color:#d0c0c0;padding:6px 0 6px 14px;position:relative;line-height:1.4}.error-group__items li:before{content:"•";position:absolute;left:2px;color:#f08a8a}.error-group__items code{background:#1a1010;padding:1px 5px;border-radius:3px;color:#ffb3b3;font-size:.8rem}.modal__errors{text-align:center}.btn{padding:10px 24px;border:none;border-radius:8px;background:#5925dc;color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s}.btn:hover{background:#6d39f0}.btn--sm{padding:6px 14px;font-size:.8rem}.btn--outline{background:transparent;border:1px solid #333;color:#e0e0e0}.btn--outline:hover{border-color:#5925dc;color:#fff;background:#5925dc}.preview{width:100%;height:100vh;display:flex;flex-direction:column}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border-radius:999px;background:transparent;border:1px solid #333;color:#aaa;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.icon-btn:hover{color:#fff;border-color:var(--accent-purple-soft);background:#5925dc2e}.icon-btn svg{display:block}.icon-btn .ti{display:block;font-size:14px;line-height:1}.picker{display:flex;gap:4px}.picker--stack{flex-direction:column;gap:6px}.picker--stack .pick-btn{width:100%;text-align:left;padding:8px 12px;display:flex;justify-content:space-between;align-items:center}.pick-btn{padding:5px 10px;border:1px solid #333;border-radius:6px;background:transparent;color:#888;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.pick-btn span{color:#555;margin-left:4px}.pick-btn:hover{border-color:#555;color:#ccc}.pick-btn.active{border-color:var(--accent-purple-soft);color:#fff}.pick-btn.active span{color:#bbb}.page-indicator{display:flex;gap:4px;flex-wrap:wrap}.page-badge{padding:3px 9px;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.02em;color:#fff;background:#5925dc;cursor:default;-webkit-user-select:none;user-select:none}.page-badge--inactive{color:#555;background:#1a1a1a}.page-badge--current{outline:2px solid #fff;outline-offset:1px;background:#fff;color:#000}.preview__body{flex:1;display:flex;min-height:0;position:relative}.panel-toggle{position:absolute;top:50%;transform:translateY(-50%);width:16px;height:56px;padding:0;background:#161616;border:1px solid #2a2a2a;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;transition:left .15s ease-in,right .15s ease-in,background .15s,color .15s,border-color .15s}.panel-toggle:hover{background:var(--accent-purple);color:#fff;border-color:var(--accent-purple)}.panel-toggle--left{left:384px;border-radius:0 6px 6px 0;border-left:none}.panel-toggle--right{right:384px;border-radius:6px 0 0 6px;border-right:none}.panel-toggle__icon{display:inline-block;font-size:.95rem;line-height:1;transition:transform .15s ease-in}.preview__body--data-collapsed .data-panel{width:0;flex:0 0 0;transition:width .15s ease-out,flex-basis .15s ease-out}.preview__body--data-collapsed .panel-toggle--left{left:0;transition:left .15s ease-out,right .15s ease-out,background .15s,color .15s,border-color .15s}.preview__body--data-collapsed .panel-toggle--left .panel-toggle__icon{transform:rotate(180deg);transition:transform .15s ease-out}.preview__body--controls-collapsed .control-panel{width:0;flex:0 0 0;transition:width .15s ease-out,flex-basis .15s ease-out}.preview__body--controls-collapsed .panel-toggle--right{right:0;transition:left .15s ease-out,right .15s ease-out,background .15s,color .15s,border-color .15s}.preview__body--controls-collapsed .panel-toggle--right .panel-toggle__icon{transform:rotate(180deg);transition:transform .15s ease-out}.preview__stage{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#1e1e1e;position:relative}.data-panel__file{flex:0 0 auto;padding:12px 14px;border-bottom:1px solid #1a1a1a;background:#0a0a0a}.riv-file-info__row{display:flex;align-items:center;gap:8px}.riv-file-info__icon{font-size:16px;color:#888;flex:0 0 auto}.riv-file-info__name{flex:1 1 auto;font-size:.78rem;font-weight:500;color:#ddd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.riv-file-info__upload{width:22px;height:22px;flex:0 0 auto}.riv-file-info__upload .ti{font-size:12px}.riv-file-info__meta{margin-top:6px;display:flex;align-items:center;gap:6px;font:500 10.5px/1.4 ui-monospace,SF Mono,Menlo,monospace;color:#666;letter-spacing:.02em}.riv-file-info__divider{color:#444}.riv-file-info__help,.riv-file-info__warn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;cursor:help;outline:none}.riv-file-info__help{margin-left:2px;color:#666}.riv-file-info__help:hover,.riv-file-info__help:focus-visible{color:#ccc}.riv-file-info__warn{color:#f59e0b}.riv-file-info__warn:hover,.riv-file-info__warn:focus-visible{color:#fbbf24}.riv-file-info__help .ti{font-size:13px;line-height:1}.riv-file-info__tooltip{position:fixed;top:0;left:0;z-index:1000;width:280px;padding:10px 12px;border-radius:6px;background:#1a1a1a;border:1px solid #2a2a2a;box-shadow:0 8px 24px #00000080;font:400 11px/1.5 -apple-system,system-ui,sans-serif;letter-spacing:normal;color:#ccc;text-transform:none;opacity:0;visibility:hidden;transform:translateY(-2px);transition:opacity .12s ease,transform .12s ease,visibility .12s;pointer-events:none}.riv-file-info__tooltip[data-visible=true]{opacity:1;visibility:visible;transform:translateY(0)}.riv-file-info__tooltip strong{display:block;margin-bottom:6px;color:#fff;font-weight:600}.riv-file-info__tooltip ol{margin:0 0 6px;padding-left:18px}.riv-file-info__tooltip li{margin:2px 0}.riv-file-info__tooltip code{font:500 10.5px/1.2 ui-monospace,SF Mono,Menlo,monospace;color:#d8c4ff;background:#5925dc26;padding:1px 4px;border-radius:3px}.data-panel{position:relative;z-index:2;width:384px;flex:0 0 384px;display:flex;flex-direction:column;background:#0c0c0c;border-right:1px solid #1a1a1a;overflow:hidden;transition:width .15s ease-in,flex-basis .15s ease-in}.data-panel__header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #1a1a1a}.data-panel__title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#888}.data-panel__count{font-size:.68rem;color:#555}.data-panel__body{flex:1 1 auto;overflow-y:auto;padding:8px 0;font-size:.78rem}.data-panel__body::-webkit-scrollbar{width:8px}.data-panel__body::-webkit-scrollbar-track{background:transparent}.data-panel__body::-webkit-scrollbar-thumb{background:#222;border-radius:4px}.data-panel__body::-webkit-scrollbar-thumb:hover{background:#333}.data-panel__empty{padding:14px;font-size:.78rem;color:#555;line-height:1.5}.control-panel{position:relative;z-index:2;width:384px;flex:0 0 384px;display:flex;flex-direction:column;background:#0c0c0c;border-left:1px solid #1a1a1a;overflow-y:auto;transition:width .15s ease-in,flex-basis .15s ease-in}.control-section{border-bottom:1px solid #1a1a1a;display:flex;flex-direction:column}.control-section__header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #1a1a1a}.control-section__title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#888}.control-section__body{padding:12px 14px}.data-panel__empty code{background:#1a1a1a;color:#aaa;padding:1px 5px;border-radius:3px;font-size:.72rem}.dt-node{display:flex;flex-direction:column}.dt-row{display:flex;align-items:center;gap:6px;padding:3px 12px 3px 0;cursor:default;-webkit-user-select:none;user-select:none;color:#ccc;line-height:1.5;min-width:0}.dt-row--clickable{cursor:pointer}.dt-row--clickable:hover{background:#141414}.dt-chev{display:inline-flex;width:12px;justify-content:center;align-items:center;color:#666;font-size:12px;line-height:1;flex:0 0 12px;transition:transform .12s ease}.dt-chev--open{transform:rotate(90deg)}.dt-chev--blank{visibility:hidden}.dt-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex:0 0 18px;border-radius:3px;font-size:12px;line-height:1;color:#888;background:#1a1a1a;border:1px solid #232323}.dt-icon--vm{color:var(--accent-purple-soft);background:#a78bfa14;border-color:#a78bfa40}.dt-name{color:#e0e0e0;font-weight:500}.dt-name--vm{color:#fff;font-weight:600}.dt-type{color:#666;font-weight:400}.dt-type--vm{color:var(--accent-purple-soft)}.dt-value{margin-left:auto;padding-left:8px;color:#888;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.7rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.dt-children{display:none}.dt-children--open{display:block}.dt-empty{padding:4px 12px 4px 36px;font-size:.72rem;color:#444;font-style:italic}#rive-canvas{background:#000;border:1px solid #444}.toast-container{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column-reverse;gap:8px;align-items:center;z-index:200;pointer-events:none}.toast{color:#fff;padding:10px 18px;border-radius:8px;border:1px solid #666;background:#1e1e1e;font-size:.85rem;box-shadow:0 6px 20px #00000080;opacity:0;transform:translateY(12px);transition:opacity .2s ease,transform .2s ease;pointer-events:auto;max-width:480px}.toast--visible{opacity:1;transform:translateY(0)}.toast--success{border-color:#2fb56a;background:#2fb56a2e}.toast--error{border-color:#e25555;background:#e255552e}.toast--info{border-color:var(--accent-purple-soft);background:#5925dc2e}.custom-panel{width:384px;flex:0 0 384px;display:flex;flex-direction:column;background:#0c0c0c;border-left:1px solid #1a1a1a;overflow:hidden}.custom-panel--hidden{display:none}.custom-panel__header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #1a1a1a}.custom-panel__title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#888}.custom-panel__body{flex:1 1 auto;min-height:0;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.custom-panel__body::-webkit-scrollbar{width:8px}.custom-panel__body::-webkit-scrollbar-track{background:transparent}.custom-panel__body::-webkit-scrollbar-thumb{background:#222;border-radius:4px}.custom-panel__body::-webkit-scrollbar-thumb:hover{background:#333}.custom-panel__footer{flex:0 0 auto;display:flex;border-top:1px solid #1a1a1a}.custom-panel__action{flex:1 1 0;padding:14px 0;background:transparent;border:none;color:#ccc;font-size:.85rem;font-weight:500;cursor:pointer;font-family:inherit}.custom-panel__action:hover{color:#fff;background:#141414}.custom-panel__action+.custom-panel__action{border-left:1px solid #1a1a1a}.custom-panel__action--primary{color:#fff;background:var(--accent-purple)}.custom-panel__action--primary:hover{background:#6d39f0}.cf-section{flex:0 0 auto;border:1px solid #222;border-radius:8px;background:#111;overflow:hidden}.cf-section__header{padding:10px 14px;background:#181818;border-bottom:1px solid #222;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#aaa;display:flex;align-items:center;gap:10px}.cf-section__title{flex:0 0 auto}.cf-pill{display:inline-flex;align-items:center;padding:2px 8px;border:1px solid var(--accent-purple-soft);border-radius:999px;background:transparent;color:var(--accent-purple-soft);font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:none}.cf-section__body{padding:14px;display:flex;flex-direction:column;gap:12px}.cf-row{display:grid;grid-template-columns:160px 1fr;align-items:center;gap:12px}.cf-row--stack{display:flex;flex-direction:column;align-items:stretch;gap:8px}.cf-label{font-size:.78rem;color:#ccc;font-weight:500}.cf-input,.cf-select{width:100%;padding:6px 10px;background:#0c0c0c;border:1px solid #2a2a2a;border-radius:5px;color:#fff;font-size:.8rem;font-family:inherit}.cf-input:focus,.cf-select:focus{outline:none;border-color:var(--accent-purple-soft)}.cf-slider-row{display:grid;grid-template-columns:1fr 70px;gap:10px;align-items:center}.cf-slider{width:100%;accent-color:rgb(89,37,220)}.cf-checkbox-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid #222;border-left:1px solid #222;background:#0c0c0c}.cf-checkbox{position:relative;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;font-size:.78rem;color:#888;cursor:pointer;border-right:1px solid #222;border-bottom:1px solid #222;transition:background .12s ease,color .12s ease}.cf-checkbox input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.cf-checkbox:hover{background:#141414;color:#bbb}.cf-checkbox:has(input:checked){background:#181818;color:#fff}.cf-checkbox:after{content:"✓";font-size:.78rem;color:var(--accent-purple-soft);opacity:0;transition:opacity .12s ease}.cf-checkbox:has(input:checked):after{opacity:1}.cf-checkbox:focus-within{outline:1px solid var(--accent-purple-soft);outline-offset:-1px}.cf-courses{display:flex;flex-direction:column;gap:8px}.cf-course-row{display:grid;grid-template-columns:1fr 100px auto;gap:8px;align-items:center}.cf-course-add{align-self:flex-start;font-size:.75rem;color:var(--accent-purple-soft);background:transparent;border:1px dashed #333;padding:6px 12px;border-radius:6px;cursor:pointer}.cf-course-add:hover{border-color:var(--accent-purple-soft)}.cf-course-add:disabled{opacity:.4;cursor:not-allowed}.cf-icon-btn{background:transparent;border:1px solid #333;color:#888;border-radius:5px;padding:4px 8px;font-size:.75rem;cursor:pointer}.cf-icon-btn:hover{color:#fff;border-color:#555}.cf-hint{font-size:.7rem;color:#555}
