.module-selector{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem;background-color:var(--bg-primary)}.module-selector-content{max-width:800px;width:100%}.module-selector-content h2{font-size:2rem;margin-bottom:2rem;text-align:center;color:var(--text-primary)}.module-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.module-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;text-align:left;transition:all .2s;cursor:pointer}.module-card:hover{background-color:var(--hover-bg);border-color:#007acc;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.module-number{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.module-name{font-size:1.25rem;font-weight:500;color:var(--text-primary)}.no-modules{grid-column:1 / -1;text-align:center;padding:3rem;color:var(--text-secondary)}.no-modules p{margin-bottom:.5rem}.hint{font-size:.875rem}.file-tree{width:300px;background-color:var(--sidebar-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.file-tree-header{padding:.5rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.file-tree-content{flex:1;overflow-y:auto;padding:.5rem 0}.tree-node{-webkit-user-select:none;user-select:none}.tree-node-label{display:flex;align-items:center;padding:.25rem .5rem;cursor:pointer;color:var(--text-primary);transition:background-color .1s}.tree-node-label:hover{background-color:var(--hover-bg)}.tree-node-label.selected{background-color:var(--active-bg)}.tree-node-icon{display:flex;align-items:center;margin-right:.25rem;color:var(--text-secondary)}.tree-node-icon-spacer{width:16px;margin-right:.25rem}.tree-node-file-icon{margin-right:.5rem;color:var(--text-secondary)}.tree-node-name{font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}code[class*=language-],pre[class*=language-]{color:#ccc;background:none;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#2d2d2d}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.comment,.token.block-comment,.token.prolog,.token.doctype,.token.cdata{color:#999}.token.punctuation{color:#ccc}.token.tag,.token.attr-name,.token.namespace,.token.deleted{color:#e2777a}.token.function-name{color:#6196cc}.token.boolean,.token.number,.token.function{color:#f08d49}.token.property,.token.class-name,.token.constant,.token.symbol{color:#f8c555}.token.selector,.token.important,.token.atrule,.token.keyword,.token.builtin{color:#cc99cd}.token.string,.token.char,.token.attr-value,.token.regex,.token.variable{color:#7ec699}.token.operator,.token.entity,.token.url{color:#67cdcc}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.inserted{color:green}.code-viewer{flex:1;display:flex;flex-direction:column;background-color:var(--bg-primary);overflow:hidden}.code-viewer-header{padding:.5rem 1rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:.875rem}.file-name{color:var(--text-primary)}.code-viewer-content{flex:1;overflow-y:auto;padding:1rem}.code-viewer-empty{display:flex;justify-content:center;align-items:center;height:100%;color:var(--text-secondary)}.code-block{background-color:var(--code-bg);border:1px solid var(--border-color);border-radius:4px;padding:0;overflow-x:auto;font-family:Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;margin:0}.code-block code{display:block;padding:1rem;white-space:pre;background:transparent!important}.code-block code[class*=language-]{text-shadow:none}:root[data-theme=dark] pre[class*=language-]{background:var(--code-bg)!important;color:var(--text-primary)}:root[data-theme=light] pre[class*=language-]{background:var(--code-bg)!important;color:var(--text-primary)}.notebook{max-width:1200px;margin:0 auto}.notebook-cell{margin-bottom:1rem}.markdown-cell{padding:.75rem 1rem;background-color:var(--bg-secondary);border-left:3px solid #007acc;border-radius:4px}.cell-content{color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.code-cell{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;overflow:hidden}.cell-input{display:flex}.cell-code-wrapper{position:relative;flex:1}.copy-button{position:absolute;top:.5rem;right:.5rem;padding:.5rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;opacity:0;transition:opacity .2s,background-color .2s;z-index:10;display:flex;align-items:center;justify-content:center}.cell-code-wrapper:hover .copy-button{opacity:1}.copy-button:hover{background-color:var(--hover-bg);border-color:#007acc}.copy-button:active{background-color:var(--active-bg)}.cell-label{padding:.75rem .5rem;min-width:60px;text-align:right;font-family:Consolas,Courier New,monospace;font-size:.875rem;color:var(--text-secondary);background-color:var(--bg-tertiary);border-right:1px solid var(--border-color)}.cell-code{flex:1;padding:0;margin:0;font-family:Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;color:var(--text-primary);background-color:var(--code-bg);overflow-x:auto}.cell-code code{display:block;padding:.75rem 1rem;white-space:pre;background:transparent!important;text-shadow:none!important}.output-section{border-top:1px solid var(--border-color)}.output-hidden{padding:.75rem 1rem;background-color:var(--bg-primary);display:flex;align-items:center;gap:1rem}.output-encouragement{margin:0;color:var(--text-secondary);font-size:.813rem}.show-output-button{padding:.375rem .875rem;background-color:#007acc;border:none;border-radius:3px;color:#fff;font-size:.813rem;cursor:pointer;transition:background-color .2s;white-space:nowrap}.show-output-button:hover{background-color:#005a9e}.show-output-button:active{background-color:#004578}.cell-output{background-color:var(--bg-primary)}.output-item{padding:.75rem 1rem}.output-text{margin:0;font-family:Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;color:var(--text-primary);white-space:pre-wrap}.output-image{max-width:100%;height:auto;border-radius:4px}.header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);height:48px}.header-left{display:flex;align-items:center;gap:.75rem}.header-title{font-size:1.1rem;font-weight:500;color:var(--text-primary)}.header-right{display:flex;align-items:center;gap:.5rem}.icon-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:4px;color:var(--text-primary);background:transparent;transition:background-color .2s}.icon-button:hover{background-color:var(--hover-bg)}.icon-button:active{background-color:var(--active-bg)}.workshop{display:flex;flex-direction:column;height:100vh;background-color:var(--bg-primary)}.workshop-content{display:flex;flex:1;overflow:hidden;position:relative}.explorer-container{min-width:200px;max-width:600px;overflow:hidden;flex-shrink:0}.resize-handle{width:4px;background-color:var(--border-color);cursor:col-resize;flex-shrink:0;transition:background-color .2s}.resize-handle:hover{background-color:#007acc}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:var(--bg-primary)}.login-box{background-color:var(--bg-secondary);padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;min-width:300px}.login-box h1{margin-bottom:1.5rem;text-align:center;color:var(--text-primary)}.login-input{width:100%;padding:.75rem;margin-bottom:1rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem}.login-input:focus{outline:none;border-color:#007acc}.login-button{width:100%;padding:.75rem;background-color:#007acc;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}.login-button:hover{background-color:#005a9e}.error{color:#f48771;margin-bottom:1rem;text-align:center}.login-hint{margin-top:1rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.admin-panel{display:flex;flex-direction:column;height:100vh;background-color:var(--bg-primary)}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);height:48px}.admin-header-left{display:flex;align-items:center;gap:.75rem}.admin-header-left h1{font-size:1.1rem;font-weight:500;color:var(--text-primary)}.admin-header-right{display:flex;align-items:center;gap:.5rem}.admin-header-right .icon-button span{margin-left:.5rem}.admin-content{display:flex;flex:1;overflow:hidden}.admin-sidebar{width:300px;background-color:var(--sidebar-bg);border-right:1px solid var(--border-color);overflow-y:auto;padding:1rem}.admin-section{margin-bottom:2rem}.admin-section h3{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:.75rem}.module-list-admin,.notebook-list{display:flex;flex-direction:column;gap:.5rem}.module-item,.notebook-item{padding:.75rem;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;text-align:left;color:var(--text-primary);cursor:pointer;transition:all .2s}.module-item:hover,.notebook-item:hover{background-color:var(--hover-bg);border-color:#007acc}.module-item.active,.notebook-item.active{background-color:#007acc;color:#fff;border-color:#007acc}.admin-main{flex:1;overflow-y:auto;padding:2rem}.admin-empty{display:flex;justify-content:center;align-items:center;height:100%;color:var(--text-secondary)}.notebook-control h2{font-size:1.5rem;margin-bottom:2rem;color:var(--text-primary)}.visibility-control{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.visibility-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:1.125rem;font-weight:500;color:var(--text-primary)}.visibility-slider{width:100%;height:8px;border-radius:4px;background:var(--bg-tertiary);outline:none;margin-bottom:1.5rem;cursor:pointer}.visibility-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#007acc;cursor:pointer;transition:background-color .2s}.visibility-slider::-webkit-slider-thumb:hover{background:#005a9e}.visibility-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#007acc;cursor:pointer;border:none}.quick-actions{display:flex;gap:.75rem}.action-button{padding:.5rem 1rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;transition:all .2s}.action-button:hover:not(:disabled){background-color:var(--hover-bg);border-color:#007acc}.action-button.primary{background-color:#007acc;color:#fff;border-color:#007acc}.action-button.primary:hover:not(:disabled){background-color:#005a9e}.action-button:disabled{opacity:.5;cursor:not-allowed}.cell-preview{margin-top:2rem}.cell-preview h3{font-size:1.25rem;margin-bottom:1rem;color:var(--text-primary)}.cell-list{display:flex;flex-direction:column;gap:.75rem}.cell-item{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:1rem;transition:all .2s}.cell-item.visible{border-left:4px solid #4ec9b0}.cell-item.hidden{border-left:4px solid var(--text-secondary);opacity:.6}.cell-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.cell-index{font-weight:600;color:var(--text-primary)}.cell-type{padding:.125rem .5rem;border-radius:3px;font-size:.75rem;font-weight:500;text-transform:uppercase}.cell-type.code{background-color:#4ec9b0;color:#1e1e1e}.cell-type.markdown{background-color:#c586c0;color:#1e1e1e}.cell-status{margin-left:auto;padding:.125rem .5rem;border-radius:3px;font-size:.75rem;font-weight:500}.cell-status.visible{background-color:#4ec9b0;color:#1e1e1e}.cell-status.hidden{background-color:var(--text-secondary);color:var(--bg-primary)}.cell-preview-content{font-family:Consolas,Courier New,monospace;font-size:.875rem;color:var(--text-secondary);white-space:pre-wrap;overflow:hidden}.module-row{display:flex;align-items:center;gap:.5rem}.module-row .module-item{flex:1}.icon-button-small{padding:.375rem;background-color:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-button-small:hover{background-color:var(--hover-bg);border-color:#007acc}.icon-button-small.delete-btn:hover{background-color:#f14c4c;border-color:#f14c4c;color:#fff}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-header h3{margin-bottom:0}.no-files{color:var(--text-secondary);font-size:.875rem;padding:1rem;text-align:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 12px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.25rem;color:var(--text-primary);margin:0}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-group input[type=text],.form-group input[type=number]{width:100%;padding:.75rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group input[type=text]:focus,.form-group input[type=number]:focus{outline:none;border-color:#007acc}.file-input{width:100%;padding:.75rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;cursor:pointer}.file-list{margin-top:1rem;padding:1rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px}.file-list p{font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.file-list ul{list-style:none;padding:0;margin:0}.file-list li{font-size:.875rem;color:var(--text-secondary);padding:.375rem 0;border-bottom:1px solid var(--border-color)}.file-list li:last-child{border-bottom:none}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;cursor:pointer;transition:all .2s}.btn-primary{background-color:#007acc;color:#fff;border-color:#007acc}.btn-primary:hover{background-color:#005a9e;border-color:#005a9e}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--hover-bg);border-color:#007acc}.upload-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin-bottom:.5rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;font-size:.875rem;transition:all .2s}.upload-btn:hover{background-color:var(--hover-bg);border-color:#007acc}:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;min-width:320px;min-height:100vh}#root{width:100%;height:100vh;overflow:hidden}body[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f3f3f3;--bg-tertiary: #e8e8e8;--text-primary: #1e1e1e;--text-secondary: #616161;--border-color: #e5e5e5;--hover-bg: #e8e8e8;--active-bg: #d6d6d6;--code-bg: #f5f5f5;--sidebar-bg: #f3f3f3;--scrollbar-thumb: #c1c1c1;--scrollbar-track: #f3f3f3}body[data-theme=dark]{--bg-primary: #1e1e1e;--bg-secondary: #252526;--bg-tertiary: #2d2d30;--text-primary: #cccccc;--text-secondary: #858585;--border-color: #3e3e42;--hover-bg: #2a2d2e;--active-bg: #37373d;--code-bg: #1e1e1e;--sidebar-bg: #252526;--scrollbar-thumb: #424242;--scrollbar-track: #1e1e1e}body{background-color:var(--bg-primary);color:var(--text-primary)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#555}pre,code{font-family:Consolas,Courier New,monospace}button{font-family:inherit;cursor:pointer;border:none;background:none;padding:0}input{font-family:inherit}
