@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box}html{width:100%;height:100%;margin:0;padding:0;overflow:hidden}body{margin:0;padding:0;display:flex;width:100%;height:100vh;overflow:hidden;background-color:#f2f2f2;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;max-width:100%;margin:0;padding:0;text-align:left;display:flex}:root{font-family:Inter,system-ui,sans-serif;line-height:1.5;font-weight:400;letter-spacing:-.03em;color-scheme:light;color:#000;background-color:#f2f2f2;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--institution-primary-color: #07F77F;--institution-secondary-color: #1aff8c;--institution-primary-hover: #00e670;--institution-secondary-hover: #00ff95;--institution-accent-color: #f59e0b;--institution-success-color: #10b981;--institution-warning-color: #f59e0b;--institution-error-color: #ef4444;--institution-bg-primary: #ffffff;--institution-bg-secondary: #f8fafc;--institution-bg-tertiary: #f1f5f9;--institution-text-primary: #1e293b;--institution-text-secondary: #64748b;--institution-text-muted: #94a3b8;--institution-text-on-primary: #ffffff;--institution-border-light: #e2e8f0;--institution-border-medium: #cbd5e1;--institution-border-dark: #94a3b8;--institution-gradient: linear-gradient(135deg, var(--institution-primary-color), var(--institution-secondary-color));--institution-gradient-hover: linear-gradient(135deg, var(--institution-primary-hover), var(--institution-secondary-hover));--institution-shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--institution-shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--institution-shadow-lg: 0 8px 24px rgba(0, 0, 0, .15)}@media all{body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}*{font-family:Inter,system-ui,sans-serif;letter-spacing:-.03em}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f5f5f5;color:#000;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#000;background-color:#f2f2f2}a:hover{color:#747bff}button{background-color:#f5f5f5;color:#000}}.app-nav{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;width:100%;background-color:transparent}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@font-face{font-family:Sk-Modernist-Mono;src:url(./Sk-Modernist-Mono.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}*{margin:0;padding:0;box-sizing:border-box}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.App{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:20px;background-color:transparent;border-radius:12px;box-sizing:border-box;display:flex;flex-direction:column}.App h1{text-align:center;margin-bottom:20px;font-weight:400;font-size:2em}h2{color:#000;margin:1.5rem 0 1rem}.form-group{margin-bottom:.5rem;width:100%}.form-group label{display:inline-block;margin-bottom:.2rem;font-weight:500;font-size:16px;color:#000}.file-input-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;margin-top:20px}.file-drop-area{width:100%;height:200px;border:1px dashed #cccccc;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f2f2f2;cursor:pointer;transition:all .2s ease;position:relative;text-align:center;padding:30px 10px;margin-bottom:0}.file-drop-area:hover{background-color:#ececec}.file-drop-area.drag-over{background-color:#07f77f1a;border-color:#07f77f;border-style:solid}.file-input-hidden{position:absolute;width:100%;height:100%;top:0;left:0;opacity:0;cursor:pointer}.file-icon{width:40px;height:40px;margin-bottom:30px;color:#07f77f;background-color:#00ff801a;display:flex;align-items:center;justify-content:center;border-radius:8px}.drag-text{font-weight:400;color:#000;margin-bottom:5px}.size-limit-text{font-size:11px;color:#888;margin-top:2px;padding:0;border-radius:0;background-color:transparent;border:none}.uploaded-files{margin-top:10px;width:100%;display:flex;flex-direction:column}.uploaded-files-title{color:#000;font-size:16px;font-weight:400;margin-bottom:0}.files-container{max-height:120px;overflow-y:auto;margin-bottom:12px}.files-container ul{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:4px}.file-action-buttons{display:flex;justify-content:flex-end;position:sticky;bottom:0;padding-top:8px}.file-action-buttons button.cancel-btn{display:flex;align-items:center;justify-content:center;height:40px;background-color:transparent!important;color:#000;border:1px solid #f2f2f2;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;cursor:pointer;margin-right:10px;font-family:var(--custom-button-font)!important;text-transform:uppercase;letter-spacing:-.05em}.file-action-buttons button.cancel-btn:hover{background-color:transparent!important;transform:translateY(-2px);border-color:#888}.inline-error-message{color:#ff4d4f;font-size:13px;margin-top:12px;margin-bottom:12px;text-align:left;width:100%;padding:10px 12px;background-color:#ff4d4f26;border-radius:6px;border-left:3px solid #ff4d4f;font-weight:500;display:flex;align-items:flex-start;line-height:1.4}.uploaded-file-item{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;margin:0;background-color:#f2f2f2;border-radius:8px;border:none;transition:all .2s ease;min-height:50px;box-sizing:border-box}.uploaded-file-item:hover{background-color:#ececec}.file-info{flex:1;display:flex;flex-direction:column;overflow:hidden;text-align:left;min-width:0;font-size:13px;justify-content:center;height:100%;padding:4px 0}.file-info .file-name{width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#000;font-weight:500;font-size:14px;line-height:1}.file-info .file-size{font-size:11px;color:#888;margin-left:0;font-weight:400}.remove-file-btn{background-color:transparent;color:#888;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;margin-left:6px;font-size:12px;cursor:pointer;border:none;flex-shrink:0}.remove-file-btn:hover{color:#000;background-color:#dc35451a}.upload-progress-bar{height:5px;background-color:#3498db;border-radius:2px;transition:width .3s ease}button.attach-files-btn{display:flex;align-items:center;justify-content:center;height:40px;background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;text-decoration:none;border:none;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;overflow:hidden;cursor:pointer;font-family:var(--custom-button-font)!important;text-transform:uppercase;letter-spacing:-.05em}button.attach-files-btn:hover{background-color:#1aff8c;transform:translateY(-2px);color:#000}button.attach-files-btn:focus{outline:none;box-shadow:none}.attach-files-btn:disabled{background-color:#00ff8080;transform:none;cursor:not-allowed}button.cancel-btn{display:flex;align-items:center;justify-content:center;height:40px;background-color:transparent;color:#000;border:1px solid #f2f2f2;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;cursor:pointer;margin-right:10px;font-family:var(--custom-button-font)!important;text-transform:uppercase;letter-spacing:-.05em}.cancel-btn:hover{background-color:transparent;transform:translateY(-2px);border-color:#888}ul{list-style:none;padding:0}li{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin:.5rem 0;background:#f8f9fa;border-radius:4px;border:1px solid #dee2e6}.error{color:#e74c3c;padding:1rem;margin:1rem 0;background:#fdf0ed;border-radius:4px;border:1px solid #fadbd8}.error-message{margin:16px auto;padding:16px;max-width:600px;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24}.error-message p{margin:0 0 8px;font-weight:500}.storage-error{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.error-suggestions{margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.1)}.error-suggestions p{margin:0 0 8px;font-size:14px}.error-suggestions ul{margin:0;padding-left:20px;font-size:14px}.error-suggestions li{margin-bottom:4px}.error-message.note{background-color:#cce5ff;color:#004085;border:1px solid #b8daff}.error-message.success{background-color:#07f77f33;color:#000;border:1px solid rgba(7,247,127,.3)}.success-message{padding:.75rem;margin-bottom:1rem;background-color:#d4edda;color:#155724;border-radius:4px}.app-nav{display:flex!important;justify-content:flex-start!important;align-items:center!important;padding:.75rem 19px .75rem 20px!important;background-color:transparent!important;border-radius:12px!important;box-shadow:none!important;margin-bottom:20px!important;height:60px!important;width:100%!important;box-sizing:border-box!important;gap:0!important;position:fixed!important;top:15px!important;left:0!important;right:0!important;z-index:1000!important}.main-content.with-sidebar .app-nav{left:280px!important;width:calc(100% - 280px)!important}.app-nav-actions{display:flex;align-items:center;margin-left:auto;gap:15px}.app-nav>:last-child{margin-left:auto}.credits-dropdown{margin-right:auto}.page-title{margin:0;font-size:24px;font-weight:400;color:#000;flex:0;text-align:left;white-space:nowrap;padding-left:15px}.app-nav a,.app-nav button{margin-left:20px}.app-nav a{text-decoration:none;color:#000;font-weight:500;transition:color .2s}.app-nav a.home-link{margin-left:20px}.app-nav a:hover{color:#007bff}.login-nav-button{background-color:#007bff;color:#fff!important;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.login-nav-button:hover{background-color:#0069d9}.auth-outer-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0;min-height:calc(100vh - 120px)}.auth-logo-outer{display:flex;justify-content:center;margin-bottom:60px}.auth-mode-toggle{display:flex;justify-content:center;margin-bottom:24px}.auth-mode-text{font-size:21px;color:#000;text-align:center;position:relative;font-weight:400;letter-spacing:-.5px}.auth-container{width:440px;max-width:90%;padding:2.5rem;background-color:#fff;border-radius:12px;border:1px solid #e0e0e0}.auth-logo{display:flex;justify-content:center;margin-bottom:20px}.auth-container h2{margin-top:0;text-align:center;margin-bottom:1.5rem;font-size:1.8rem;font-weight:500;color:#000}.auth-container .form-group{margin-bottom:1.2rem}.auth-container label{display:block;margin-bottom:.5rem;font-size:14px;color:#ccc}.auth-container input{width:100%;padding:.9rem 1rem;background-color:#fff;border:1px solid #eaeaea!important;border-radius:25px;color:#000;font-size:14px;transition:all .2s ease;box-sizing:border-box;caret-color:#111}.auth-container input:focus{outline:none!important;border-color:#eaeaea!important}.auth-container input::selection{background-color:#00ff804d}.auth-container button{width:100%;padding:.9rem;margin-top:.5rem;background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;border:none;border-radius:25px;font-size:1rem;font-weight:400;cursor:pointer;transition:all .3s ease;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;letter-spacing:-.05em}.auth-container button:hover{transform:translateY(-2px)}.auth-container button:disabled{background-color:#00ff8080;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;margin:1.5rem 0;color:#aaa;font-size:14px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:#eaeaea}.auth-divider span{padding:0 1rem}.google-sign-in-button{width:auto;min-width:220px;height:48px;padding:0 16px;background-color:transparent!important;color:#000!important;border:1px solid #eaeaea!important;border-radius:24px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;margin:0 auto;gap:10px;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;letter-spacing:-.05em}.google-sign-in-button svg{flex-shrink:0;width:20px;height:20px}.google-sign-in-button:hover{background-color:#ffffff0d!important;transform:translateY(-2px)}.google-sign-in-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-toggle{margin-top:1.5rem;text-align:center}.auth-toggle button{background:transparent!important;color:#07f77f!important;border:none;padding:0;font-size:14px;width:auto;font-weight:400}.auth-toggle button:hover{text-decoration:underline;background:none!important;box-shadow:none;transform:none}input{outline:none!important;box-shadow:none!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;border-color:transparent!important}input:focus{outline:none!important;border-color:transparent!important}.project-name-input{width:100%;padding:.75rem 1rem;border:none!important;border-radius:10px;font-size:14px;transition:all .2s ease;background-color:transparent;color:#000;outline:0!important;box-shadow:none!important;caret-color:#07f77f}.project-name-input::selection{background-color:#00ff804d}.project-input-container{width:100%;border-radius:25px;display:flex;align-items:center;background-color:transparent;position:relative;transition:none;border:1px solid #eaeaea}.project-input-container:hover{background-color:transparent;border-color:#eaeaea;transform:none}.project-input-container:focus-within{outline:none!important;box-shadow:none!important;border-color:#eaeaea}.project-name-input:-webkit-autofill,.project-name-input:-webkit-autofill:hover,.project-name-input:-webkit-autofill:focus,.project-name-input:-webkit-autofill:active{-webkit-text-fill-color:#000000!important;-webkit-box-shadow:0 0 0px 1000px transparent inset!important;transition:background-color 5000s ease-in-out 0s;outline:none!important;border:none!important}.upload-form{margin:0 auto;padding:1.5rem 2rem;background-color:#fff;border-radius:12px;border:none;width:60%;max-width:800px;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center}.upload-form h1{margin-top:.8rem;margin-bottom:.4rem;text-align:center;font-size:1.8rem}.upload-form p{font-size:14px;color:#888;text-align:center;margin-top:.3rem;margin-bottom:1.5rem}.selected-files{margin-left:1.5rem;padding:1.5rem;background-color:transparent;border-radius:12px;border:none;box-shadow:none;width:35%;min-width:380px;box-sizing:border-box}.selected-files h3{margin-top:0;margin-bottom:1rem;color:#000;font-size:1rem;font-weight:500}.selected-files ul{margin-bottom:1.5rem;padding:0}.selected-files button{margin-top:.5rem;background-color:#28a745;padding:.75rem 1.5rem;font-weight:500}.selected-files button:hover{background-color:#218838}.selected-files button:disabled{background-color:#8bbf9f;cursor:not-allowed}.selected-file-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin:.5rem 0;background:transparent;border-radius:10px;border:1px solid #333}.process-btn{background-color:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:500;cursor:pointer;transition:all .2s}.process-btn:hover{background-color:#218838;transform:translateY(-2px)}.view-project-btn{background-color:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:500;cursor:pointer;transition:all .2s}.view-project-btn:hover{background-color:#0069d9;transform:translateY(-2px)}.preview-mode{width:100%}.project-header-container{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:1.5rem;background-color:#e7e7e7;border-radius:12px;padding:.8rem 1rem}.project-title{margin:0;font-size:18px;font-weight:400;color:#000;text-align:center;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.back-button{background-color:transparent;color:#000;border:1px solid #d4d4d4;border-radius:25px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:400;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s ease;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;outline:none;-webkit-tap-highlight-color:transparent}.back-button:hover{background-color:transparent;color:#000;border:1px solid #d4d4d4;outline:none;box-shadow:none;transform:translateY(-2px)}.back-button:focus{background-color:transparent;color:#000;border:1px solid #d4d4d4;outline:none;box-shadow:none}.preview-header{display:flex;align-items:center;margin-bottom:1.5rem}.project-item{background-color:#fff;border-radius:16px;padding:.8rem;transition:all .2s;cursor:pointer}.project-item:hover{background-color:#fcfcfc}.project-content{display:flex;align-items:center;width:100%}.project-icon{margin-right:16px;display:flex;align-items:center;justify-content:center}.project-icon img{width:40px;height:auto}.project-details{flex:1;display:flex;flex-direction:column;gap:2px}.project-details h3{margin:0;font-size:16px;font-weight:400;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-count{font-size:10px;color:#999;white-space:nowrap;text-transform:uppercase}.project-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.favorite-btn-container{background-color:transparent;border:1px solid #eaeaea;border-radius:50%;padding:4px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.project-item.favorited .favorite-btn-container{background-color:#fff;border:none}.project-item.favorited .three-dots-container{background-color:transparent;border:1px solid #b8b8b8;opacity:.5}.project-item.favorited .three-dots-btn svg path{fill:#a8a8a8;opacity:1}.three-dots-container{background-color:transparent;border:1px solid #eaeaea;border-radius:50%;padding:4px;position:relative}.favorite-btn{background:transparent;border:none;cursor:pointer;padding:4px;margin:0;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;outline:none;-webkit-tap-highlight-color:transparent}.favorite-btn:focus{outline:none;box-shadow:none}.favorite-btn:hover{background-color:#ffffff1a}.project-item.favorited{background:#e7e7e7}.three-dots-menu{position:relative}.three-dots-btn{background:transparent;border:none;cursor:pointer;padding:4px;margin:0;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s;outline:none;-webkit-tap-highlight-color:transparent}.three-dots-btn:focus{outline:none;box-shadow:none}.three-dots-btn:hover{background-color:#ffffff1a}.project-dropdown-menu{position:absolute;top:100%;right:0;width:120px;background-color:#fff;border-radius:6px;overflow:hidden;z-index:10;margin-top:4px}.project-dropdown-menu .dropdown-item{padding:10px 12px;color:#000;font-size:14px;cursor:pointer;transition:background-color .2s}.project-dropdown-menu .dropdown-item:hover{background-color:#252540}.project-dropdown-menu .dropdown-item.delete-item{color:#ff4d4f}.project-dropdown-menu .dropdown-item.delete-item:hover{background-color:#ff4d4f1a}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;background:#fff;border-radius:12px;padding:40px;max-width:600px;margin:0 auto;position:relative;overflow:hidden;box-sizing:border-box;border:1px solid #e0e0e0}@keyframes container-glow{0%,to{border-color:#00ff8026}50%{border-color:#00ff804d}}.loading-container .content-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;position:relative;z-index:5}.loading-container p{margin:0;color:#000;font-size:16px;font-weight:500;text-align:center;letter-spacing:.5px;z-index:5;position:relative}.loading-container p:first-of-type{margin-top:24px;font-weight:600;background:linear-gradient(to right,#fff,#07f77f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent}.loading-container p:last-of-type{margin-top:5px;font-size:13px;color:#aaa}.loading-spinner{width:80px;height:80px;margin:0 auto 24px;perspective:800px;transform-style:preserve-3d;position:relative}.loading-spinner .cube{position:absolute;width:100%;height:100%;transform-style:preserve-3d;animation:platform-cube-spin 4s infinite linear}.loading-spinner .cube-face{position:absolute;width:80px;height:80px;background:#00ff800d;border:1px solid rgba(0,255,128,.6);backface-visibility:visible;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-spinner .cube-face:nth-child(1){transform:rotateY(0) translateZ(40px)}.loading-spinner .cube-face:nth-child(2){transform:rotateY(90deg) translateZ(40px)}.loading-spinner .cube-face:nth-child(3){transform:rotateY(180deg) translateZ(40px)}.loading-spinner .cube-face:nth-child(4){transform:rotateY(-90deg) translateZ(40px)}.loading-spinner .cube-face:nth-child(5){transform:rotateX(90deg) translateZ(40px)}.loading-spinner .cube-face:nth-child(6){transform:rotateX(-90deg) translateZ(40px)}@keyframes platform-cube-spin{0%{transform:rotateX(0) rotateY(0)}to{transform:rotateX(360deg) rotateY(360deg)}}.loading-indicator{padding:2rem;text-align:center;color:#000;position:relative;z-index:5;display:flex;flex-direction:column;align-items:center}.loading-indicator p{margin:0 0 24px;color:#ccc;font-size:15px;line-height:1.5;max-width:500px}.loading-indicator p:last-child{margin:20px 0 0;font-size:13px;color:#aaa}.spinner{width:80px;height:80px;margin:0 auto 24px;perspective:800px;transform-style:preserve-3d;position:relative}.spinner .cube{position:absolute;width:100%;height:100%;transform-style:preserve-3d;animation:platform-cube-spin 4s infinite linear}.spinner .cube-face{position:absolute;width:80px;height:80px;background:#00ff800d;border:1px solid rgba(0,255,128,.6);backface-visibility:visible;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spinner .cube-face:nth-child(1){transform:rotateY(0) translateZ(40px)}.spinner .cube-face:nth-child(2){transform:rotateY(90deg) translateZ(40px)}.spinner .cube-face:nth-child(3){transform:rotateY(180deg) translateZ(40px)}.spinner .cube-face:nth-child(4){transform:rotateY(-90deg) translateZ(40px)}.spinner .cube-face:nth-child(5){transform:rotateX(90deg) translateZ(40px)}.spinner .cube-face:nth-child(6){transform:rotateX(-90deg) translateZ(40px)}.particle-field{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:1;pointer-events:none}.particle{position:absolute;width:3px;height:3px;background:#07f77f;border-radius:50%;opacity:0;z-index:1;animation:float-up var(--duration, 3s) ease-in infinite;animation-delay:var(--delay, 0s);left:var(--x, 50%)}@keyframes float-up{0%{bottom:-10px;opacity:0;transform:translate(0) scale(.2)}20%{opacity:.7;transform:translate(var(--drift, 10px)) scale(1)}80%{opacity:.4;transform:translate(calc(var(--drift, 10px) * -1)) scale(.8)}to{bottom:110%;opacity:0;transform:translate(0) scale(.2)}}.gcode-loading{display:flex;align-items:center;justify-content:center;padding:20px;margin:20px 0}.gcode-loading p{font-size:16px;color:#000;margin-right:15px}.login-prompt{margin:3rem auto;padding:2rem;max-width:500px;text-align:center;background-color:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.login-prompt h2{margin-top:0;color:#343a40}.login-button{display:inline-block;margin-top:1.5rem;padding:.75rem 2rem;background-color:#007bff;color:#fff;text-decoration:none;border-radius:4px;font-weight:500;transition:background-color .2s}.login-button:hover{background-color:#0069d9}.logout-button{background-color:transparent;color:#333;border:none;font-weight:500;cursor:pointer;padding:0;margin-left:1rem}.logout-button:hover{color:#dc3545}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.project-header h3{margin:0;color:#000;font-size:1.2rem;font-weight:600}.delete-project-btn{background-color:transparent;color:#dc3545;border:none;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .2s;font-size:18px}.delete-project-btn:hover{background-color:#dc35451a}.app-container{display:flex;height:100vh;width:100%;overflow:hidden;background-color:#f2f2f2;background-image:radial-gradient(circle,rgba(0,0,0,.1) 1px,transparent 1px);background-size:32px 32px}.main-content{flex:1;height:100vh;overflow-y:auto;transition:margin-left .3s;margin-left:0;padding:80px 15px 15px;width:100%;box-sizing:border-box;display:flex;flex-direction:column}.main-content.with-sidebar{margin-left:280px;width:calc(100% - 280px);box-sizing:border-box;padding-left:0;padding-top:95px!important}.coming-soon{max-width:600px;margin:4rem auto;padding:3rem;text-align:center;background-color:transparent;border-radius:16px;box-shadow:none}.coming-soon h1{margin-bottom:1.5rem;color:#000;font-size:2rem}.coming-soon p{margin-bottom:2.5rem;color:#ccc;font-size:1.2rem}.coming-soon button{background-color:#007bff;color:#fff;border:none;padding:.75rem 1.75rem;border-radius:12px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:all .3s}.coming-soon button:hover{background-color:#0069d9;transform:translateY(-3px)}.empty-state-wrapper{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 200px);width:100%;margin:0;padding:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:800px;margin:0;padding:4rem;text-align:center;background-color:#fff;border-radius:12px;border:none}.empty-state p{margin-bottom:24px;color:#000;font-size:29px;font-weight:400}.empty-state-icon{width:60px;height:auto;margin-bottom:2rem;opacity:.8}.button{display:inline-flex;align-items:center;justify-content:center;width:auto;height:42px;background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;text-decoration:none;border-radius:50px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 28px;overflow:hidden;text-transform:uppercase;font-family:var(--custom-button-font, "Courier New", monospace)!important;letter-spacing:-.05em;border:none;cursor:pointer}.button:hover{background-color:#1aff8c;transform:translateY(-2px);color:#000;text-decoration:none}@keyframes blink{0%{opacity:.3}50%{opacity:.8}to{opacity:.3}}.status-indicator{display:none;position:fixed;bottom:30px;left:50%;transform:translate(-50%);text-align:center;color:#888;font-size:9px;align-items:center;justify-content:center;z-index:10;text-transform:uppercase}.status-indicator-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background-color:#28a745;margin-right:3px;opacity:.8;animation:blink 1.5s infinite}.loading-bar-container{width:100%;margin:20px auto;position:relative;display:flex;flex-direction:column;gap:8px}.loading-segments{display:flex;gap:4px;height:6px}.loading-bar-segment{flex:1;height:100%;background-color:#e7e7e7;border-radius:2px;transition:background-color .3s ease;position:relative;overflow:hidden}.loading-bar-segment.active{background-color:#07f77f}.loading-bar-segment.loading{background-color:#07f77f;background-size:200% 100%;animation:segment-loading 1.5s ease-in-out infinite}.loading-step-labels{display:flex;gap:4px;margin-top:8px}.loading-step-label{flex:1;display:flex;flex-direction:column;align-items:flex-start;font-size:11px;line-height:1.2}.step-title{font-weight:400;color:#888;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;font-size:14px}.step-status{font-size:12px;color:#ccc;font-weight:400}.loading-step-label.completed .step-title{color:#000}.loading-step-label.completed .step-status{color:#888;font-weight:500}.loading-step-label.active .step-title{color:#000;font-weight:400}.loading-step-label.active .step-status{color:#888;font-weight:500;animation:pulse 1.5s infinite}.loading-step-label.waiting .step-title{color:#888}.loading-step-label.waiting .step-status{color:#ccc}@keyframes segment-loading{0%{background-position:-200% 0}to{background-position:200% 0}}.loading-bar{height:100%;width:0;background:#07f77f;border-radius:10px;transition:width .3s ease-out}.loading-bar.indeterminate{width:50%;background:#07f77f;background-size:200% 100%;animation:loading-animation 1.5s ease-in-out infinite;position:absolute;top:0;left:-50%}@keyframes loading-animation{0%{left:-50%;background-position:0% 50%}to{left:100%;background-position:100% 50%}}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px;padding-bottom:0;position:relative;border:none!important;border-bottom:none!important;border-top:none!important;border-left:none!important;border-right:none!important}.section-header *,.section-header h2,.section-header .section-title,.section-header .section-count{border:none!important;border-bottom:none!important;border-top:none!important;border-left:none!important;border-right:none!important;outline:none!important;box-shadow:none!important}.section-header h1{margin:0;font-size:29px}.new-project-btn{display:flex;align-items:center;justify-content:center;height:40px;background-color:#07f77f;color:#000;text-decoration:none;border:none;border-radius:10px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;cursor:pointer}.new-project-btn:hover{background-color:#1aff8c;transform:translateY(-2px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-container{width:450px;background-color:#fff;border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h3{margin:0;color:#000;font-size:18px;font-weight:600}.modal-body{padding:20px}.modal-footer{padding:15px 20px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px}.rename-btn{display:flex;align-items:center;justify-content:center;height:40px;background-color:#07f77f;color:#000;text-decoration:none;border:none;border-radius:10px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;cursor:pointer}.rename-btn:hover{background-color:#1aff8c;transform:translateY(-2px)}.upload-progress-text{text-align:center;color:#07f77f;font-size:14px;margin-top:8px;margin-bottom:5px;font-weight:500}.current-step-text{text-align:center;color:#ccc;font-size:13px;margin-bottom:10px;animation:pulse 1.5s infinite}.processing-status{display:flex;flex-direction:column;align-items:center;margin-bottom:15px}.processing-steps{display:flex;flex-direction:column;gap:6px;width:100%;max-width:300px;margin-top:5px;font-size:13px}.processing-step{color:#888;border-radius:4px;position:relative;padding:4px 8px 4px 24px}.processing-step:before{content:"";position:absolute;left:8px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background-color:#444}.processing-step.active{color:#000;background-color:#00ff801a}.processing-step.active:before{background-color:#07f77f;animation:pulse 1.5s infinite}.processing-step.completed{color:#aaa}.processing-step.completed:before{background-color:#07f77f;opacity:.5}@keyframes pulse{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.file-drop-area.disabled{opacity:.3;cursor:not-allowed;pointer-events:none;border-color:#1e1e3c33;background-color:#0a0a1480;position:relative}.file-drop-area.disabled:after{content:"Processing in progress...";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffffff80;font-size:14px;font-weight:500;text-align:center;width:100%;z-index:5}.file-drop-area.disabled .file-icon,.file-drop-area.disabled .drag-text,.file-drop-area.disabled .size-limit-text{visibility:hidden}.file-drop-area.disabled:hover{background-color:#0a0a1480;border-color:#1e1e3c33;transform:none}.auth-container .error-message{padding:.75rem;margin-bottom:1.5rem;background-color:#ff4d4f1a;color:#ff4d4f;border-radius:8px;font-size:14px;text-align:center;border:1px solid rgba(255,77,79,.2)}.auth-loading{display:inline-block;width:16px;height:16px;border:2px solid rgba(0,0,0,.3);border-radius:50%;border-top-color:#000;animation:auth-spin 1s linear infinite;margin-left:10px}@keyframes auth-spin{to{transform:rotate(360deg)}}.toggle-link{color:#888;text-decoration:none;font-size:14px;opacity:.8;transition:opacity .2s ease}.toggle-link:hover{opacity:1;text-decoration:underline;color:#111}.password-field{position:relative;width:100%}.password-field input{width:100%;box-sizing:border-box;padding-right:40px}.eye-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.eye-icon:hover{opacity:.8}.project-header-container .new-project-btn{height:36px;padding:0 16px;font-size:13px;white-space:nowrap}@keyframes loading-progress{0%{transform:translate(-100%)}to{transform:translate(100%)}}.loading-dot{display:inline-block;width:8px;height:8px;background:#07f77f;border-radius:50%;margin-left:8px;position:relative;animation:pulse-dot 1.5s cubic-bezier(.455,.03,.515,.955) infinite}@keyframes pulse-dot{0%{transform:scale(.8);opacity:.6}50%{transform:scale(1.2);opacity:1}to{transform:scale(.8);opacity:.6}}.project-preview.loading{text-align:center;padding:3rem 1.5rem;background:#fff;border-radius:12px;max-width:700px;margin:0 auto;position:relative;overflow:hidden;animation:container-glow 3s ease-in-out infinite;box-sizing:border-box;min-height:400px;display:flex;flex-direction:column;border:1px solid #e0e0e0}.project-preview.loading .content-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;z-index:5;position:relative}.project-preview.loading h2{font-size:22px;font-weight:600;margin-bottom:20px;margin-top:0;background:linear-gradient(to right,#fff,#07f77f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;position:relative;z-index:5}.spinner-small{width:40px;height:40px;perspective:400px;transform-style:preserve-3d;position:relative;display:inline-block;vertical-align:middle;margin-left:15px}.spinner-small .cube{width:100%;height:100%;transform-style:preserve-3d;animation:platform-cube-spin 3s infinite linear}.spinner-small .cube-face{position:absolute;width:40px;height:40px;background:#00ff800d;border:1px solid rgba(0,255,128,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spinner-small .cube-face:nth-child(1){transform:rotateY(0) translateZ(20px)}.spinner-small .cube-face:nth-child(2){transform:rotateY(90deg) translateZ(20px)}.spinner-small .cube-face:nth-child(3){transform:rotateY(180deg) translateZ(20px)}.spinner-small .cube-face:nth-child(4){transform:rotateY(-90deg) translateZ(20px)}.spinner-small .cube-face:nth-child(5){transform:rotateX(90deg) translateZ(20px)}.spinner-small .cube-face:nth-child(6){transform:rotateX(-90deg) translateZ(20px)}.classic-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.2);border-radius:50%;border-top-color:#07f77f;animation:classic-spin 1s ease-in-out infinite;position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:1000}@keyframes classic-spin{to{transform:translate(-50%) rotate(360deg)}}.classic-spinner-small{width:24px;height:24px;border:2px solid rgba(255,255,255,.2);border-radius:50%;border-top-color:#07f77f;animation:classic-spin-small 1s ease-in-out infinite;display:inline-block;vertical-align:middle;margin-left:15px}@keyframes classic-spin-small{to{transform:rotate(360deg)}}.loading-overlay p{margin-top:15px;font-size:14px;color:#fff}.loading-overlay .classic-spinner-small{position:static;margin:0;transform:none}.spinner-container{position:relative;width:100%;height:300px;margin:60px auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.spinner-title{font-size:22px;font-weight:600;color:#000;margin-top:80px;margin-bottom:12px;text-align:center}.spinner-subtitle{font-size:16px;color:#aaa;margin-bottom:6px;text-align:center}.spinner-text{margin-top:14px;font-size:14px;color:#000;font-weight:500;text-align:center}.navigation-buttons{display:flex;gap:6px}.nav-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:transparent;color:#000;border:1px solid #d4d4d4;border-radius:50%;cursor:pointer;transition:none;padding:0;outline:none;-webkit-tap-highlight-color:transparent}.nav-button:hover{background-color:transparent;color:#000;border:1px solid #d4d4d4;outline:none;box-shadow:none}.nav-button:focus{background-color:transparent;color:#000;border:1px solid #d4d4d4;outline:none;box-shadow:none}.nav-button svg{width:24px;height:24px}.nav-button svg path{stroke:#000;stroke-width:1}.nav-button:hover svg path{stroke:#000;stroke-width:1}.nav-button:focus svg path{stroke:#000;stroke-width:1}.nav-button:active:not(:disabled){transform:scale(.95)}.nav-button:disabled{opacity:.4;cursor:not-allowed}.upload-form .form-group label{display:inline-block;margin-bottom:.4rem;font-weight:400;font-size:14px!important;color:#000!important}.projects-section{margin-bottom:32px}.projects-section:last-child{margin-bottom:0}.section-title{margin:0;font-size:18px;font-weight:400;color:#000}.section-count{font-size:14px;color:#888;font-weight:400}.project-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-top:2px}.projects-section .section-title{margin:0;font-size:18px!important;font-weight:400;color:#000}.storage-usage-info{margin:12px 0;padding:8px 12px;background-color:#f2f2f2;border-radius:12px}.storage-estimate{font-size:14px;color:#495057;font-weight:500}.inline-error-message{color:#dc3545;font-size:14px;margin-top:8px;padding:8px 12px;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px}.storage-breakdown{display:flex;flex-direction:column;gap:4px}.storage-line{display:flex;align-items:center;gap:8px;font-size:14px;color:#888}.storage-line.total{margin-top:4px;padding-top:8px;border-top:1px solid #dee2e6;font-weight:500;color:#212529}.storage-icon{font-size:16px;width:20px;display:flex;justify-content:center}.storage-label{flex:1;text-align:left}.storage-value{font-weight:500;color:#888;min-width:60px;text-align:right}.storage-line.total .storage-value{color:#212529;font-weight:500}@font-face{font-family:Sk-Modernist-Mono;src:url(/Sk-Modernist-Mono.otf) format("opentype"),url(/Sk-Modernist-Mono.otf) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--custom-button-font: "Sk-Modernist-Mono", "Courier New", Consolas, Monaco, monospace}.sidebar{position:fixed;left:15px;top:15px;width:250px;height:calc(100vh - 30px);background-color:#e7e7e7;border:none;border-radius:12px;z-index:100;transition:transform .3s ease;transform:translate(0);overflow:visible;display:flex;flex-direction:column;padding:0}.sidebar-header{padding:0 15px;display:flex;align-items:center;justify-content:space-between;border-bottom:none;height:65px;position:relative;width:100%;box-sizing:border-box}.sidebar-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background-image:linear-gradient(to right,#CFD0CF 4px,transparent 4px);background-size:10px 1px;background-repeat:repeat-x}.logo{display:flex;align-items:center;justify-content:flex-start;padding-left:0;pointer-events:none;height:45px;width:auto}.logo *{pointer-events:auto}.logo-image{height:auto;max-width:105px;width:auto;transition:none!important;filter:none!important;opacity:1!important;transform:none!important;-webkit-filter:none!important;-webkit-transform:none!important}.logo-image:hover,.logo:hover .logo-image,.sidebar-header:hover .logo-image{filter:none!important;opacity:1!important;transform:none!important;-webkit-filter:none!important;-webkit-transform:none!important}.logo-icon{display:inline-block;width:30px;height:30px;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M12 2L2 7l10 5 10-5-10-5zM2 17l10 5 10-5M2 12l10 5 10-5'%3e%3c/path%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat}.logo-text{font-size:24px;font-weight:700;color:#000}.sidebar-nav{flex:1;padding:20px 0;overflow:visible}.sidebar-nav-item{display:flex;align-items:center;padding:12px 8px;color:#666;text-decoration:none;position:relative;transition:all .2s;margin:4px 10px;border-radius:10px;background-color:transparent!important;border:none!important;box-shadow:none!important}.sidebar-nav-item:hover{background-color:#00000014!important;color:#000;border:none!important;box-shadow:none!important}.sidebar-nav-item.active{color:#000;background-color:#fff!important;border:none!important;box-shadow:none!important}.sidebar-icon{display:inline-flex;align-items:center;justify-content:center;margin-right:10px}.icon{display:inline-block;width:20px;height:20px;margin-right:12px;opacity:.7;flex-shrink:0;background-position:center;filter:invert(36%) sepia(0%) saturate(0%) hue-rotate(245deg) brightness(92%) contrast(87%)}.sidebar-nav-item:hover .icon,.sidebar-nav-item.active .icon{opacity:1}.document-icon{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 16H8v-2h8v2zm0-4H8v-2h8v2zm-3-5V3.5L18.5 9H13z'%3e%3c/path%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat}.ai-icon{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M21.6 10.2l-9-6.8c-.3-.3-.9-.3-1.2 0l-9 6.8c-.3.2-.4.5-.4.8v11c0 .6.4 1 1 1h18c.6 0 1-.4 1-1V11c0-.3-.1-.6-.4-.8z'%3e%3c/path%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat}.info-icon{display:inline-block;width:16px;height:16px;margin-left:auto;background-size:contain;background-repeat:no-repeat}.sidebar-nav-item:hover .info-icon{opacity:.7}.text{font-size:14px;font-weight:400}.sidebar-footer{padding:10px;border-top:none;display:flex;flex-direction:column;justify-content:center;margin:0;position:relative}.sidebar .login-button-sidebar,.sidebar .buy-credits-button{display:flex;align-items:center;justify-content:center;width:100%;height:40px;background-color:var(--institution-primary-color, #07F77F);background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;text-decoration:none;border-radius:20px;font-weight:400;transition:all .3s ease;text-align:center;margin:0 auto;font-size:14px;box-sizing:border-box;padding:0;overflow:hidden;text-transform:uppercase;font-family:var(--custom-button-font)!important;letter-spacing:-.05em}.sidebar .login-button-sidebar:hover,.sidebar .buy-credits-button:hover{background-color:var(--institution-primary-hover, #1aff8c);transform:translateY(-2px)}.sidebar .buy-credits-button{gap:10px;font-family:var(--custom-button-font)!important}.sidebar .buy-credits-text,.sidebar .login-button-text{font-family:var(--custom-button-font)!important;font-weight:400!important;text-transform:uppercase;letter-spacing:-.05em}.folder-icon{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M10 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2h-8l-2-2z'%3e%3c/path%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat}.settings-icon{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M19.14 12.94c.04-.3.06-.61.06-.94 0-.32-.02-.64-.07-.94l2.03-1.58c.18-.14.23-.41.12-.61l-1.92-3.32c-.12-.22-.37-.29-.59-.22l-2.39.96c-.5-.38-1.03-.7-1.62-.94l-.36-2.54c-.04-.24-.24-.41-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54c-.59.24-1.13.57-1.62.94l-2.39-.96c-.22-.08-.47 0-.59.22L2.74 8.87c-.12.21-.08.47.12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58c-.18.14-.23.41-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54c.59-.24 1.13-.56 1.62-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32c.12-.22.07-.47-.12-.61l-2.01-1.58zM12 15.6c-1.98 0-3.6-1.62-3.6-3.6s1.62-3.6 3.6-3.6 3.6 1.62 3.6 3.6-1.62 3.6-3.6 3.6z'%3e%3c/path%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;width:20px;height:20px;opacity:.5;transition:opacity .2s;margin-right:5px}.header-settings-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background-color:transparent;border:none;cursor:pointer;padding:0;transition:background-color .2s ease}.header-settings-link:hover{background-color:#0000000d}.bolt-icon{display:inline-block;width:16px;height:16px;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3e%3cpath d='M11 21h-1l1-7H7.5c-.58 0-.57-.32-.38-.66.19-.34.05-.08.07-.12C8.48 10.94 10.42 7.54 13 3h1l-1 7h3.5c.49 0 .56.33.47.51l-.07.15C12.96 17.55 11 21 11 21z'%3e%3c/path%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat}.credit-display{display:flex;align-items:center;justify-content:center;background-color:#ffffff1a;border-radius:4px;padding:6px 10px;margin-bottom:10px;color:#f0f0f0;font-size:14px;font-weight:500}.credit-display .bolt-icon{margin-right:8px;opacity:.9}.sidebar-toggle:hover{background-color:var(--institution-primary-hover, #1aff8c);transform:translateY(-2px)}.sidebar-nav-item.coming-soon{cursor:pointer;opacity:.6;pointer-events:auto;position:relative;display:flex;align-items:center;padding:12px 8px;margin:4px 10px;border-radius:10px;background-color:transparent!important;border:none!important;box-shadow:none!important}.sidebar-nav-item.coming-soon:hover{background-color:#0000000a!important;color:#000;border:none!important;box-shadow:none!important;display:flex;align-items:center;padding:12px 8px;margin:4px 10px;border-radius:10px}.sidebar-nav-item.coming-soon .text{color:#999;font-size:14px;font-weight:400}.sidebar-nav-item.coming-soon .sidebar-icon{display:inline-flex;align-items:center;justify-content:center;margin-right:10px}.sidebar-nav-item.coming-soon .sidebar-icon img{opacity:.6;width:20px;height:20px}.sidebar-nav-item.coming-soon[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background-color:#000;color:#fff;padding:6px 8px;border-radius:8px;font-size:11px;white-space:nowrap;z-index:999999;box-shadow:0 2px 8px #0000004d;pointer-events:none;font-weight:400;opacity:1!important}.sidebar-nav-item.coming-soon[data-tooltip]:hover:before{content:"";position:absolute;left:calc(100% + 5px);top:50%;transform:translateY(-50%);width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:6px solid #000000;z-index:999999;pointer-events:none;opacity:1!important}.logo-container{display:flex;align-items:center;gap:8px}.institution-logo-sidebar{height:40px;width:auto;max-width:140px;object-fit:contain;transition:none!important;filter:none!important;opacity:1!important;transform:none!important}.institution-logo-sidebar:hover{filter:none!important;opacity:1!important;transform:none!important}.beta-icon{height:16px;width:auto;opacity:.8}@media (max-width: 768px){.institution-logo-sidebar{height:36px;max-width:120px}}.pricing-popup-overlay *,.pricing-popup-overlay *:before,.pricing-popup-overlay *:after{border:none!important;outline:none!important}.pricing-popup-overlay .plan-card{border:1px solid #eaeaea!important}.pricing-popup-overlay .plan-button.current,.pricing-popup-overlay .plan-button.downgrade{border:1px solid #888!important}.pricing-popup-overlay .pricing-popup{box-shadow:0 20px 60px #000c!important}.pricing-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.pricing-popup{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:1000px;width:100%;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out;position:relative}.pricing-header{display:flex;justify-content:space-between;align-items:flex-start;padding:32px;position:relative}.pricing-header-content{display:flex;justify-content:space-between;align-items:flex-start;width:100%;gap:32px}.pricing-header h2{margin:0;font-size:29px;font-weight:400;color:#1a1a1a;letter-spacing:-.03em;text-align:left;flex:1}.pricing-header .current-usage{background:transparent;border:none;border-radius:0;padding:0;margin:8px 0 0;flex-shrink:0}.pricing-header .current-usage h4{font-size:16px;color:#111;margin:0 0 2px;font-weight:500;text-align:right}.pricing-header .usage-stats{display:flex;flex-direction:column;gap:2px;align-items:flex-end}.pricing-header .usage-stat{display:flex;align-items:center;gap:12px;padding:0;background:transparent;border-radius:0;border:none;justify-content:flex-end}.pricing-header .stat-label{color:#888;font-size:14px;font-weight:400}.pricing-header .stat-value{color:#111;font-size:14px;font-weight:600}.close-button{position:absolute;top:16px;right:16px;background:transparent;border:none;color:#666;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.close-button:hover{background-color:#f5f5f5;color:#333}.pricing-loading,.pricing-error{padding:60px;text-align:center;color:#888;font-size:16px}.pricing-error{color:#e74c3c}.pricing-content{padding:0 32px 32px}.plans-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;max-width:1000px;margin:0 auto}.plan-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:32px 24px 16px;position:relative;transition:all .2s ease;display:flex;flex-direction:column}.plan-card:hover{border-color:#eaeaea;background-color:#f7f7f7;transform:translateY(-2px)}.plan-card.pro{border-color:#07f77f;background:#111;color:#fff;pointer-events:auto}.plan-card.pro:hover{background:#111!important;background-color:#111!important;transform:translateY(-2px);transition:all .2s ease}.plan-card.pro .plan-name{color:#07f77f}.plan-card.pro .amount{color:#fff}.plan-card.pro .plan-description{color:#888}.plan-card.pro:not(.active) .feature-text{color:#ccc}.plan-card.pro:not(.active) .feature-text strong{color:#fff}.plan-card.pro.active .feature-text{color:#888}.plan-card.pro.active .feature-text strong{color:#111}.plan-card.pro .currency{color:#fff}.pricing-popup-overlay .plan-card.studio,.pricing-popup-overlay .plan-card.studio:hover{border-color:#eaeaea!important}.pricing-popup-overlay .plan-card.free{border-color:#eaeaea!important;background:#fff!important}.pricing-popup-overlay .plan-card.free:hover{border-color:#eaeaea!important;background:#f7f7f7!important}.plan-card.active{background:#f8f9fa;border-color:#07f77f}.popular-badge{position:absolute;top:32px;right:24px;background:#07f77f;color:#000;padding:6px 16px;border-radius:16px;font-size:12px;font-weight:500;letter-spacing:-.05em;font-family:Inter,system-ui,-apple-system,sans-serif}.plan-name{font-size:24px;color:#111;margin:0 0 8px;text-align:left;font-weight:500}.plan-price{text-align:left;margin-bottom:12px}.plan-description{font-size:14px;color:#888;text-align:left;margin-bottom:24px;line-height:1.4}.currency{font-size:50px;color:#111;vertical-align:baseline;margin-right:2px;font-weight:500}.amount{font-size:50px;color:#111;font-weight:500;line-height:1}.period{font-size:14px;color:#888;margin-left:8px;display:inline-block;vertical-align:center;line-height:1.4}.plan-action{display:block!important;margin-top:0!important;margin-bottom:48px!important;order:1;text-align:center!important;width:100%!important;position:relative!important}.plan-action:after{content:"";position:absolute;bottom:-24px;left:-24px;right:-24px;height:1px;background-color:#eaeaea}.plan-card.pro .plan-action:after{background-color:#424242}.plan-card.pro.active .plan-action:after{background-color:#eaeaea}.plan-button{display:inline-block!important;width:100%!important;height:40px!important;border-radius:25px!important;font-size:14px!important;font-weight:400!important;border:none!important;cursor:pointer!important;transition:all .3s ease!important;font-family:var(--custom-button-font)!important;text-transform:uppercase!important;letter-spacing:-.05em!important;box-sizing:border-box!important;padding:0 20px!important;text-align:center!important;line-height:40px!important;margin:0 auto!important}.plan-button.upgrade{background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000}.plan-button.upgrade:hover{background-color:#1aff8c;transform:translateY(-2px);color:#000}.plan-button.current{background-color:transparent;color:#000;border:1px solid #f2f2f2;cursor:default}.plan-card.pro .plan-button.current,.plan-card.studio .plan-button.current{background-color:transparent!important;color:#000!important;border:1px solid #eaeaea!important}.plan-card.pro.active .plan-name,.plan-card.studio.active .plan-name,.plan-card.pro.active .amount,.plan-card.pro.active .currency,.plan-card.studio.active .amount,.plan-card.studio.active .currency{color:#000!important}.plan-button.downgrade{background-color:transparent;color:#888;border:1px solid #888;cursor:not-allowed}.plan-button:disabled{opacity:.6;cursor:not-allowed}.pricing-popup-overlay .plan-card.free .plan-button.downgrade{border:1px solid #888!important}.current-usage{background:#fff;border:1px solid #eaeaea;border-radius:20px;padding:32px 24px;margin-top:32px}.current-usage h4{font-size:18px;color:#111;margin:0 0 20px;font-weight:500;text-align:left}.usage-stats{display:flex;flex-direction:column;gap:16px}.usage-stat:nth-child(1){order:1}.usage-stat:nth-child(2){order:2}.usage-stat{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f8f9fa;border-radius:12px;border:none}.stat-label{color:#888;font-size:14px;font-weight:400}.stat-value{color:#07f77f;font-size:14px;font-weight:600}.features-header{margin-bottom:16px;order:3}.features-header h4{font-size:13px;font-weight:600;color:#111;margin:0 0 4px;text-transform:uppercase;letter-spacing:.5px;text-align:left}.plan-card.pro .features-header h4{color:#fff}.plan-card.pro.active .features-header h4{color:#000}.features-header p{font-size:14px;color:#888;margin:0;text-align:left;line-height:1.3}.plan-card.pro .features-header p{color:#ccc}.plan-card.pro.active .features-header p{color:#888}.plan-features{list-style:none;padding:0;margin:0;flex:1;order:4;text-align:left}.plan-features li{display:flex;align-items:flex-start;gap:6px;padding:2px 0;color:#888;font-size:14px;line-height:1.4;text-align:left;justify-content:flex-start;background:none!important;border:none!important;border-radius:0!important}.plan-card.pro .plan-features li{background:none!important;border:none!important}.feature-icon{width:16px;height:16px;flex-shrink:0;margin-top:1px}.feature-text{color:#888}.feature-text strong{color:#111;font-weight:500}@media (max-width: 1024px){.plans-grid{max-width:700px;gap:20px}.plan-card{padding:28px 20px}}@media (max-width: 768px){.pricing-popup-overlay{padding:10px}.pricing-popup{margin:0;max-width:100%;width:calc(100vw - 20px);max-height:calc(100vh - 20px)}.pricing-header,.pricing-content{padding:20px}.plans-grid{grid-template-columns:1fr;gap:20px;max-width:400px}.amount{font-size:32px}.popular-badge{right:20px}}@media (max-width: 480px){.pricing-popup-overlay{padding:5px}.pricing-popup{width:calc(100vw - 10px);max-height:calc(100vh - 10px);border-radius:12px}.pricing-header,.pricing-content{padding:16px}.plan-card{padding:24px 16px}.amount{font-size:28px}}.plan-card.pro.active:hover{background:inherit!important;border-color:#eaeaea!important;transform:none!important;background-color:inherit!important}.storage-usage-card{background:#111;border-radius:14px;padding:12px;margin:0 3px 3px;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;box-shadow:0 2px 8px #00000026;border:1px solid #3a3a3a;display:flex;flex-direction:column;gap:12px}.storage-content{display:flex;align-items:center;gap:16px}.storage-circle-container{position:relative;width:55px;height:55px;flex-shrink:0}.storage-circle{width:100%;height:100%;transform:rotate(-90deg)}.storage-circle-bg{fill:none;stroke:#404040;stroke-width:2}.storage-circle-progress{fill:none;stroke:#07f77f;stroke-width:2;stroke-linecap:round;transition:stroke-dasharray .3s ease}.storage-percentage-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:500;color:#fff;display:flex;align-items:baseline}.percentage-number{font-size:18px;line-height:1}.percentage-symbol{font-size:11px;line-height:1}.storage-info{flex:1;display:flex;flex-direction:column;gap:4px}.storage-title{font-size:14px;font-weight:500;color:#fff;margin:0}.storage-details{font-size:12px;color:#ccc;font-weight:400;margin:0}.cloud-storage-value{color:#07f77f;font-weight:500}.storage-value{color:#888;font-weight:400}.storage-header,.storage-percentage,.storage-progress-bar,.storage-progress-fill,.storage-used{display:none}.storage-usage-card.loading{opacity:.7}.storage-loading{font-size:12px;color:#ccc;text-align:center;padding:8px 0}.storage-usage-card.error{border-color:#f44}.storage-error{font-size:12px;color:#f66;text-align:center;padding:8px 0}@media (max-width: 768px){.storage-usage-card{padding:12px;margin-bottom:12px}.storage-title,.storage-percentage{font-size:13px}.storage-used{font-size:11px}.storage-updated{font-size:10px}}.storage-progress-fill[style*="width: 9"],.storage-progress-fill[style*="width: 10"]{background:linear-gradient(90deg,#ff5722,#f44336)!important}.storage-progress-fill[style*="width: 8"]{background:linear-gradient(90deg,#ff9800,#ff5722)!important}.storage-progress-fill[style*="width: 7"]{background:linear-gradient(90deg,#ffc107,#ff9800)!important}.storage-buy-credits-button{display:flex;align-items:center;justify-content:center;width:100%;height:35px;background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;text-decoration:none;border-radius:50px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0;overflow:hidden;text-transform:uppercase;font-family:var(--custom-button-font, "Courier New", monospace)!important;letter-spacing:-.05em}.storage-buy-credits-button:hover{background-color:#1aff8c;transform:translateY(-2px);color:#000}.storage-buy-credits-button:hover .storage-buy-credits-text{color:#000}.storage-buy-credits-text{font-family:var(--custom-button-font, "Courier New", monospace)!important;font-weight:400!important;text-transform:uppercase;letter-spacing:-.05em}.user-profile-dropdown{position:relative;display:inline-flex;background-color:#e7e7e7;border-radius:8px;width:auto;max-width:220px;margin-right:0;margin-left:auto;border:none}.profile-header{display:flex;align-items:center;padding:12px 16px 12px 12px;cursor:pointer;position:relative;transition:background-color .2s;width:100%;height:100%;border-radius:8px}.avatar-container{margin-right:12px;flex-shrink:0;display:flex;align-items:center}.avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.user-info{flex:1;overflow:hidden;margin-right:12px;display:flex;flex-direction:column;justify-content:center}.user-name{font-size:14px;font-weight:400;color:#000;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:150px;line-height:1.2}.user-email{font-size:12px;color:#888;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:150px;line-height:1.2}.dropdown-icon{flex-shrink:0;margin-left:0;transform:rotate(0);transition:transform .3s ease;display:flex;align-items:center;justify-content:center;width:auto;padding-right:0;height:100%}.user-profile-dropdown.open .dropdown-icon{transform:rotate(180deg)}.user-profile-dropdown.open .profile-header{border-radius:8px 8px 0 0!important;background-color:#e7e7e7;margin-bottom:0}.dropdown-menu{position:absolute;top:calc(100% - 1px);left:0;width:100%;background-color:#e7e7e7;border-radius:0 0 8px 8px;z-index:100;overflow:visible;border:none}.dropdown-item{padding:12px 16px;color:#333;cursor:pointer;transition:background-color .2s;font-size:14px}.dropdown-item:hover{background-color:#ececec}.dropdown-item:not(:last-child){margin-bottom:0;padding-bottom:12px;position:relative}.dropdown-item:not(:last-child):after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background-color:#ccc}.language-dropdown-item{position:relative}.language-item-content{display:flex;justify-content:space-between;align-items:center;width:100%}.language-dropdown-icon{transform:rotate(0);transition:transform .2s ease;flex-shrink:0;width:10px!important;height:7px!important;min-width:10px;min-height:7px;max-width:10px;max-height:7px}.language-dropdown-icon.open{transform:rotate(180deg)}.language-submenu{position:static;margin-top:8px}.language-option{display:flex;align-items:center;padding:8px 10px;cursor:pointer;transition:background-color .2s;font-size:14px;color:#333;width:100%}.language-option:hover{background-color:#e0e0e0;border-radius:6px}.language-option.active{background-color:#f2f2f2;color:#000;border-radius:6px}.language-option.active:hover{background-color:#f2f2f2;border-radius:6px}.flag-icon{margin-right:8px;display:inline-block;width:24px;height:18px;border-radius:2px;flex-shrink:0}.profile-popup-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}.profile-popup-content.settings-panel{background-color:#fff;padding:0;border-radius:16px;width:450px;max-width:90%;max-height:90vh;overflow-y:auto}.settings-header{display:flex;justify-content:space-between;align-items:center;background-color:#e7e7e7;border-radius:14px;margin:10px;padding:20px 24px}.settings-header h2{font-size:18px;margin:0;color:#000;font-weight:400;line-height:1}.close-button{background:transparent;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:24px;color:#ccc;line-height:1}.settings-content{padding:24px;border-top:none!important}.settings-content>*:first-child{border-top:none!important;margin-top:0!important;padding-top:0!important}.settings-section{margin-bottom:40px}.settings-section:last-child{margin-bottom:0}.settings-section-title{display:block;margin-bottom:8px;color:#111;font-size:14px;font-weight:400}.profile-photo-section{display:flex;align-items:center;margin-bottom:18px;border-radius:8px}.profile-avatar-container{flex-shrink:0;margin-right:20px;height:96px;display:flex;align-items:center}.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:none}.photo-info{padding:0}.photo-action{color:#000;font-size:14px;font-weight:400;text-decoration:none;cursor:pointer;transition:opacity .2s;padding:0;margin:0;text-indent:0;border:none;outline:none;display:inline-block;font-family:inherit}.photo-action:hover{opacity:1;text-decoration:underline;color:#000!important}.photo-action-separator{margin:0 12px;color:#eaeaea;font-weight:400;padding:0}.photo-description{font-size:12px;color:#999;line-height:1.5;padding:0;margin:0}.settings-field{margin-bottom:18px}.settings-section .settings-field:last-child{margin-bottom:0}.settings-label{display:block;margin-bottom:8px;color:#111;font-size:14px;font-weight:400}.required-indicator{color:#ff4757;margin-left:4px}.settings-input{width:100%;padding:14px 12px;border-radius:25px;border:1px solid #eaeaea!important;background-color:transparent;color:#888;font-size:14px;box-sizing:border-box}.settings-input:focus{outline:none!important;border-color:#eaeaea!important}.settings-input:hover{border-color:#eaeaea!important}.settings-input[readonly]{background-color:#f8f9fa;cursor:not-allowed;opacity:.8;color:#888}.settings-message{font-size:16px;color:#a0a0a0;text-align:center;padding:40px 0}.settings-actions{margin-top:24px;display:flex;justify-content:flex-end}.save-button{display:flex;align-items:center;justify-content:center;height:40px;background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;text-decoration:none;border:none;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;overflow:hidden;cursor:pointer;font-family:sk-modernist-mono,monospace;text-transform:uppercase;letter-spacing:-.05em}.save-button:hover:not(:disabled){background-color:#1aff8c;transform:translateY(-2px);color:#000}.save-button:focus{outline:none;box-shadow:none}.save-button:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.settings-error{background-color:#dc26261a;color:#ff6b6b;padding:16px;border-radius:8px;margin-top:8px;font-size:14px;border:1px solid rgba(220,38,38,.2)}.settings-success{background-color:#22c55e1a;color:#22c55e;padding:16px;border-radius:8px;margin-top:8px;font-size:14px;border:1px solid rgba(34,197,94,.2)}.app-nav{display:flex;justify-content:space-between;align-items:center;padding:.75rem .25rem .75rem 1rem;background-color:transparent;border-radius:12px;margin-bottom:20px;height:60px;width:100%;box-sizing:border-box;gap:20px}.credits-display{display:flex;align-items:center;gap:10px;background:#e7e7e7;border:none;border-radius:8px;padding:15px 16px;transition:all .3s ease;position:relative;overflow:hidden}.credits-display.loading{min-width:120px}.credits-skeleton{width:100%;height:32px;background:linear-gradient(90deg,#333 25%,#444,#333 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.credits-icon{color:#07f77f;display:flex;align-items:center;justify-content:center}.credits-info{display:flex;flex-direction:column;align-items:flex-start}.credits-value{font-size:16px;font-weight:600;color:#111;line-height:1}.credits-label{font-size:9px;color:#111;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.credits-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#333;display:none}.credits-progress-bar{height:100%;background:#07f77f;transition:width .3s ease}.credits-display.low .credits-value,.credits-display.low .credits-icon{color:#ff9800}.credits-display.low .credits-progress-bar{background:#ff9800}.credits-display:hover{background:#ddd;cursor:pointer}@media (max-width: 768px){.credits-display{padding:6px 12px;margin-right:8px}.credits-value{font-size:16px}.credits-label{font-size:10px}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-dialog{background-color:#fff;border-radius:12px;padding:24px;width:90%;max-width:400px;text-align:center}@keyframes dialog-fade-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.confirm-dialog-title{margin-top:0;font-size:1.25rem;color:#343a40;margin-bottom:1rem}.confirm-dialog-message{margin-bottom:1.5rem;color:#6c757d;line-height:1.5}.confirm-dialog-buttons{display:flex;justify-content:flex-end;gap:12px}.confirm-dialog-button{padding:.6rem 1.2rem;border:none;border-radius:10px;font-weight:500;cursor:pointer;transition:all .2s}.confirm-dialog-cancel{background-color:#e9ecef;color:#495057}.confirm-dialog-cancel:hover{background-color:#dee2e6}.confirm-dialog-confirm{background-color:#dc3545;color:#fff}.confirm-dialog-confirm:hover{background-color:#c82333;transform:translateY(-2px)}.confirm-button:hover{background-color:#c53030}.project-preview{margin:2rem 0;padding:1.5rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.project-preview h2{margin-top:0;margin-bottom:1.5rem;color:#343a40;font-size:1.5rem}.project-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.project-header h2{margin:0;color:#000;font-size:24px;font-weight:500}.project-info{display:flex;align-items:center;opacity:.6;font-size:12px}.webgl-status{margin-left:1rem;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;background-color:#e9ecef;color:#6c757d}.model-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.model-card{border:none;border-radius:16px;overflow:hidden;background-color:#fff;margin-bottom:25px;position:relative;transition:all .2s ease;min-height:500px;display:flex;flex-direction:column}.model-card.selected{border:2px solid #07F77F;transform:translateY(-2px)}.model-card:hover{transform:translateY(-2px)}.model-viewer{height:340px;background-color:#fff;position:relative;overflow:visible;flex-shrink:0}.model-viewer canvas{width:100%!important;height:100%!important;outline:none}.loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#000000b3;color:#fff;z-index:10}.spinner{width:40px;height:40px;border-radius:50%;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;animation:spin 1s linear infinite;margin-bottom:10px}.preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:420px;background-color:#fff;color:#6c757d;font-size:1.2rem;text-align:center;padding:20px}.preview-placeholder p{margin:5px 0}.preview-placeholder p:first-child{font-weight:700;color:#adb5bd}.preview-placeholder.error{background-color:#331a1a;color:#f66}.preview-placeholder.waiting{background-color:#f5f5f5;color:#adb5bd}.model-info{display:none}.model-info h3{margin-top:0;margin-bottom:.5rem;font-size:1rem;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.model-metadata{margin:.2rem 0;font-size:.85rem;color:#adb5bd}.model-status{margin:.2rem 0;font-size:.85rem;color:#07f77f}.model-version{margin:.2rem 0;font-size:.85rem;color:#07f77f;background-color:#07f77f1a;padding:4px 8px;border-radius:4px;display:inline-block}.loading-indicator{padding:2rem;text-align:center;color:#6c757d}.project-preview.empty{text-align:center;padding:3rem 1.5rem;color:#6c757d}.project-preview.loading{text-align:center;padding:3rem 1.5rem}.view-model-link{margin-top:1rem;padding:.5rem 1rem;background-color:#e7e7e7;color:#fff;text-decoration:none;border-radius:4px;font-size:.9rem;transition:background-color .2s}.view-model-link:hover{background-color:#e7e7e7;text-decoration:none;color:#fff}.reset-view-button{position:absolute;top:10px;right:10px;background-color:#f2f2f2;color:#626262;border:none;border-radius:50px;padding:6px 10px;cursor:pointer;font-size:10px;z-index:100;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;outline:none;-webkit-tap-highlight-color:transparent}.reset-view-button:hover{background-color:#e7e7e7}.reset-view-button:focus{background-color:#f2f2f2;outline:none;box-shadow:none}.active-version-indicator{position:absolute;top:40px;right:10px;background-color:#07f77f33;color:#07f77f;border:1px solid rgba(7,247,127,.5);border-radius:4px;padding:3px 8px;font-size:11px;z-index:100;font-weight:500}.project-actions{display:flex;gap:.5rem;align-items:center;margin-left:auto}.model-select{position:absolute;top:10px;left:10px;z-index:10;background-color:#0f0f1eb3;padding:3px;border-radius:6px;display:flex;align-items:center;border:1px solid rgba(255,255,255,.1)}.select-checkbox-container{display:flex;align-items:center;position:absolute;top:10px;left:10px;z-index:10;padding:3px;height:24px;cursor:pointer;font-size:14px;-webkit-user-select:none;user-select:none;background-color:transparent;border-radius:6px;border:none}.select-checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;left:5px;height:20px;width:20px;background-color:transparent;border:1px solid #eaeaea;border-radius:50%}.select-checkbox-container:hover .checkmark{background-color:transparent;border-color:#eaeaea}.select-checkbox-container input:checked~.checkmark{background-color:#07f77f;border-color:#07f77f}.checkmark:after{content:"";position:absolute;display:none}.select-checkbox-container input:checked~.checkmark:after{display:block;left:6px;top:3px;width:5px;height:10px;border:solid black;border-width:0 2px 2px 0;transform:rotate(45deg)}.select-label{margin-left:5px;color:#ccc;font-weight:500}.download-buttons{display:flex;gap:10px;margin-top:10px}.download-button{border:none;border-radius:6px;padding:8px 12px;font-size:14px;cursor:pointer;background-color:#1e1e3c80;color:#ccc;transition:all .2s ease;flex:1;border:1px solid rgba(255,255,255,.1)}.download-button:hover{background-color:#28285080;transform:translateY(-2px)}.download-button.primary{background-color:#07f77f;color:#000;border:none}.download-button.primary:hover{background-color:#1aff8c;box-shadow:0 4px 8px #00000026}.auto-orient-btn{padding:12px 14px;background-color:#07f77f;color:#000;border:none;border-radius:25px;font-size:14px;font-weight:400;cursor:pointer;transition:all .2s ease;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase}.auto-orient-btn:hover:not(:disabled){background-color:#1aff8c;transform:translateY(-2px)}.auto-orient-btn:disabled{background-color:#ccc;cursor:not-allowed;opacity:.7}.insufficient-credits-badge{display:inline-block;margin-left:8px;background-color:#f44;color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px;animation:credits-pulse 2s ease-in-out infinite}@keyframes credits-pulse{0%,to{opacity:1}50%{opacity:.7}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.orientation-popup{background-color:#fff;border-radius:8px;padding:2rem;width:100%;max-width:500px;box-shadow:0 4px 12px #00000026}.orientation-popup h2{margin-top:0;margin-bottom:1.5rem;color:#343a40;font-size:1.5rem;text-align:center}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057}.form-group select{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;background-color:#f8f9fa;cursor:pointer}.popup-buttons{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.cancel-button{padding:.6rem 1.2rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background-color:#5a6268}.apply-button{padding:.6rem 1.2rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.apply-button:hover{background-color:#0069d9}.form-group .help-text{font-size:.8rem;color:#6c757d;margin-top:.25rem;font-style:italic}.gcode-viewer-section{margin-top:20px;border-top:1px solid #e0e0e0;padding-top:20px;height:80vh;width:100%;background-color:#f8f9fa;border-radius:8px;box-shadow:0 2px 5px #0000001a;overflow:hidden;display:flex;flex-direction:column}.tool-buttons{display:flex;gap:10px;margin-top:10px}.tool-button{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;display:inline-flex;align-items:center;justify-content:center;transition:background-color .2s}.tool-button:hover{background-color:#1976d2}.tool-button:disabled{background-color:#b0bec5;cursor:not-allowed}.gcode-btn{background-color:#4caf50}.gcode-btn:hover{background-color:#388e3c}.view-gcode-btn{padding:10px 20px;background-color:#4caf50;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;box-shadow:0 2px 4px #0003}.view-gcode-btn:hover{background-color:#388e3c;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.view-gcode-btn.active{background-color:#2196f3}.view-gcode-btn.active:hover{background-color:var(--btn-primary-hover)}.gcode-viewer-wrapper{height:80vh;width:100%;margin-top:20px;border-radius:8px;overflow:hidden;box-shadow:0 2px 10px #0000001a}.download-gcode-btn{padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;text-align:center;text-decoration:none;display:inline-block;transition:background-color .3s}.download-gcode-btn:hover{background-color:#388e3c}.section-title{font-size:1.25rem;margin:20px 0 15px;padding-bottom:5px;border-bottom:1px solid #e0e0e0}.gcode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:20px}.gcode-loading{display:flex;align-items:center;gap:10px;margin:15px 0}.spinner-small{width:20px;height:20px;border-radius:50%;border:2px solid #f3f3f3;border-top:2px solid #3498db;animation:spin 1s linear infinite}.project-tabs-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.project-tabs{display:flex;border-bottom:none}.tab-button{background:transparent;border:none;color:#adb5bd;padding:.75rem 1.5rem;font-size:14px;font-weight:400;cursor:pointer;position:relative;transition:all .2s;margin-right:.5rem;outline:none;-webkit-tap-highlight-color:transparent;box-shadow:none}.tab-button:focus{outline:none;box-shadow:none}.tab-button:hover:not(:disabled){background-color:#ffffff08}.tab-button.active{color:#111;font-weight:400}.tab-button.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:1px;background-color:#111}.tab-button:disabled{cursor:not-allowed;opacity:.5}.tab-button:disabled:hover{background-color:transparent}.loading-dot{display:inline-block;width:8px;height:8px;background-color:#07f77f;border-radius:50%;margin-left:5px;animation:pulse 1.5s infinite}.tab-content{min-height:200px}.empty-gcode-message{text-align:center;padding:3rem 1.5rem;color:#adb5bd;background-color:#0f0f1e4d;border-radius:8px;border:1px dashed rgba(255,255,255,.1)}.gcode-tab-content{animation:fadeIn .3s ease-in-out}.select-all-btn{padding:12px 14px;background-color:transparent;color:#111;border:1px solid #d4d4d4;border-radius:25px;font-size:14px;font-weight:400;cursor:pointer;transition:all .2s ease;margin-right:2px;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;outline:none;-webkit-tap-highlight-color:transparent}.select-all-btn:hover{background-color:transparent;color:#111;border:1px solid #d4d4d4;outline:none;box-shadow:none;transform:translateY(-2px)}.select-all-btn:focus{background-color:transparent;color:#111;border:1px solid #d4d4d4;outline:none;box-shadow:none}.delete-selected-btn{padding:11px;background-color:transparent;color:#ccc;border:1px solid #d4d4d4;border-radius:50%;font-size:14px;cursor:pointer;transition:all .2s ease;margin-right:2px;display:flex;align-items:center;justify-content:center;width:43px;height:43px}.delete-selected-btn:hover{background-color:#ff4d4f26;border-color:#ff4d4f4d;color:#ff4d4f}.delete-selected-btn:disabled{opacity:.8;cursor:not-allowed}.delete-selected-btn svg{stroke:currentColor}.add-models-btn{padding:11px;background-color:transparent;color:#ccc;border:1px solid #d4d4d4;border-radius:50%;font-size:14px;cursor:pointer;transition:all .2s ease;margin-right:2px;margin-left:2px;display:flex;align-items:center;justify-content:center;width:43px;height:43px}.add-models-btn:hover{background-color:#07f77f26;border-color:#07f77f4d;color:#07f77f}.add-models-btn:disabled{opacity:.8;cursor:not-allowed}.add-models-btn svg{stroke:currentColor}.dimensions-button{position:absolute;bottom:10px;left:10px;top:auto;background-color:#0f0f1e66;color:#ffffffb3;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:5px 10px;font-size:16px;cursor:pointer;z-index:10;transition:all .2s;opacity:.5}.dimensions-button:hover{background-color:#0f0f1eb3;color:#ffffffe6;opacity:.8}.dimensions-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:100}.dimensions-content{background-color:#1a1a2e;border-radius:8px;padding:20px;min-width:300px;border:1px solid #07F77F;box-shadow:0 0 15px #07f77f4d}.dimensions-content h4{color:#07f77f;margin-top:0;margin-bottom:15px;text-align:center;font-size:18px}.version-selector{margin-bottom:15px}.version-selector label{display:block;color:#ccc;margin-bottom:8px;font-size:14px;font-weight:500}.version-tabs{display:flex;flex-wrap:wrap;gap:5px;border-bottom:1px solid #444;padding-bottom:8px}.version-tab{background:none;border:1px solid #333;padding:8px 12px;color:#ccc;cursor:pointer;border-radius:4px;transition:all .2s ease;position:relative}.version-tab:hover{background-color:#07f77f1a;color:#fff;border-color:#07f77f4d}.version-tab.active{background-color:#07f77f33;color:#07f77f;border-color:#07f77f}.version-tab.active:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #07F77F}.dimension-fields{margin-bottom:15px}.dimension-field{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding:5px 0;border-bottom:1px solid #333}.dimension-field label{color:#ccc;font-weight:500}.dimension-value{color:#fff;cursor:pointer;padding:5px 8px;border-radius:4px;position:relative}.dimension-value:hover{background-color:#07f77f1a}.edit-icon{color:#07f77f;margin-left:8px;font-size:12px;opacity:.6}.dimension-value:hover .edit-icon{opacity:1}.dimension-edit{display:flex;align-items:center}.dimension-unit{font-size:12px;opacity:.7;margin-left:0;color:#666}.edit-actions{display:flex;margin-left:10px}.edit-actions button{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#fff;cursor:pointer;border-radius:3px;margin-left:2px;padding:0}.save-btn{background-color:#07f77f4d}.save-btn:hover{background-color:#07f77f80}.cancel-btn{background-color:#ff3b304d}.cancel-btn:hover{background-color:#ff3b3080}.scaling-info{background-color:#07f77f1a;border-radius:4px;padding:8px 12px;margin-bottom:15px;text-align:center}.scaling-info p{color:#07f77f;margin:0;font-weight:500}.dimensions-actions{display:flex;justify-content:space-between;margin-top:15px}.dimensions-actions button{padding:8px 12px;background-color:#07f77f26;border:1px solid rgba(7,247,127,.3);color:#07f77f;border-radius:4px;cursor:pointer;transition:all .2s}.dimensions-actions button:hover{background-color:#07f77f4d}.wireframe-mode-button{position:absolute;top:10px;right:10px;background-color:#0009;color:#fff;border:none;border-radius:4px;padding:5px 10px;cursor:pointer;z-index:20;font-size:14px;transition:background-color .2s}.wireframe-mode-button:hover{background-color:#2feb6ccc}.duplicate-control{position:relative;background-color:#fff;display:flex;justify-content:space-between;align-items:center;color:#333;cursor:default;z-index:10;transition:all .2s;border-top:none;padding:8px 15px;box-shadow:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);height:auto;min-height:40px;border:1px solid #eaeaea;border-radius:8px;margin-bottom:20px;margin-left:15px;margin-right:15px}.duplicate-control:hover{background-color:#f8f9fa;border-color:#ccc;transform:none;box-shadow:none}.copies-label{font-size:13px;white-space:nowrap;color:#333;font-weight:500}.duplicate-input{width:60px;height:26px;padding:0 8px;background:#fff;border:1px solid #cccccc;border-radius:3px;color:#333;font-size:14px;text-align:center;outline:none}.duplicate-input:hover{background:#fff;border-color:#ccc}.duplicate-input::-webkit-outer-spin-button,.duplicate-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.duplicate-input[type=number]{-moz-appearance:textfield}.duplicate-arrow-btn{width:16px;height:12px;background-color:transparent;border:none;border-radius:2px;color:#333;cursor:pointer;display:block;font-size:8px;font-weight:400;transition:all .2s ease;-webkit-user-select:none;user-select:none;line-height:1;text-align:center;padding:0;position:absolute;right:15px}.duplicate-arrow-btn:first-of-type{top:8px}.duplicate-arrow-btn:last-of-type{top:22px}.duplicate-arrow-btn svg{width:8px;height:6px;color:inherit;display:block;margin:0 auto}.duplicate-arrow-btn:hover{background-color:#f0f0f0;border:none}.duplicate-arrow-btn:active{background-color:#e0e0e0;transform:scale(.95)}.duplicate-arrow-btn:disabled{background-color:transparent;color:#ccc;cursor:not-allowed;opacity:.6}.duplicate-arrow-btn:disabled:hover{background-color:transparent;border:none;transform:none}.duplicate-icon{position:absolute;top:3px;right:3px;font-size:10px;color:#07f77f;pointer-events:none}.gcode-folders-list{display:flex;flex-direction:column;gap:20px;padding:20px}.dimensions-display{position:relative;background-color:transparent;display:flex;justify-content:center;align-items:center;gap:8px;padding:8px 12px;color:#333;font-size:12px;z-index:10;border-top:1px solid #e0e0e0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.filename-display{background-color:transparent;padding:8px 12px 2px;text-align:center}.filename-text{font-size:12px;color:#888;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block;max-width:100%;cursor:default;background-color:#f2f2f2;padding:6px 12px;border-radius:20px}.dimension-item{display:flex;align-items:center;gap:3px;background-color:#fff;padding:8px;border-radius:8px;border:1px solid #eaeaea;transition:all .2s ease}.dimension-item:has(.dimension-input-direct.value-changed){background-color:#ccffe6;border-color:#ccffe6}.dimension-input-direct{width:40px;text-align:center;font-weight:500;padding:2px;border:none;border-radius:3px;background-color:transparent;color:#333;font-size:12px;cursor:text;-webkit-user-select:text;user-select:text}.dimension-input-direct.value-changed{color:#333;border:none;background-color:transparent}.dimension-input-direct:focus{outline:none;background-color:#fff;border:1px solid #07F77F;box-shadow:0 0 3px #07f77f4d;cursor:text}.dimension-input-direct:focus::selection{background-color:#07f77f;color:#fff}.dimension-input-direct::-moz-selection{background-color:#07f77f;color:#fff}.unit-toggle-btn{background-color:transparent;border:1px solid #eaeaea;color:#333;font-size:12px;padding:11px 8px;border-radius:10px;cursor:pointer;transition:all .2s}.unit-toggle-btn:hover{background-color:transparent;border-color:#999}.model-controls-wrapper{margin-top:auto;display:flex;flex-direction:column;padding-bottom:20px}.model-preview-container{position:relative;width:100%;height:400px;background-color:#fff;border-radius:12px;border:1px solid #e0e0e0;overflow:hidden}.model-preview-container:hover{border-color:#ccc}.model-preview-container.loading{border-color:#07f77f}.model-preview-container.error{border-color:#ff5c5c}.model-controls{position:absolute;bottom:16px;left:16px;right:16px;display:flex;gap:12px;background-color:#fffffff2;border-radius:8px;border:1px solid #e0e0e0;padding:12px}.model-control-button{background-color:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s ease}.model-control-button:hover{background-color:#e0e0e0}.model-info-panel{position:absolute;top:16px;right:16px;background-color:#fffffff2;border-radius:8px;border:1px solid #e0e0e0;padding:12px;min-width:200px}.progress-container{background-color:#f5f5f5;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden;height:8px}.layer-slider-container{background-color:#fffffff2;border-radius:8px;border:1px solid #e0e0e0;padding:12px}.glow-effect{border-color:#07f77f}.model-stats{background-color:#fffffff2;border-radius:8px;border:1px solid #e0e0e0;padding:12px}.duplicate-input:focus{border-color:#07f77f;box-shadow:0 0 5px #07f77f4d}.upload-progress-container{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;margin-bottom:20px}.upload-progress-container h3{margin:0 0 15px;color:#000;font-size:16px;font-weight:500}.upload-files-list{display:flex;flex-direction:column;gap:12px;margin-bottom:15px}.upload-file-item{display:flex;align-items:center;padding:12px;background-color:#fff;border:1px solid #e9ecef;border-radius:6px;gap:15px}.upload-file-item .file-info{flex:1;min-width:0}.upload-file-item .file-name{font-weight:500;color:#000;font-size:14px;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-file-item .file-size{color:#6c757d;font-size:12px}.upload-progress{position:relative;width:120px;height:20px;background-color:#e9ecef;border-radius:10px;overflow:hidden}.upload-progress-bar{height:100%;background-color:#07f77f;border-radius:10px;transition:width .3s ease}.upload-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:500;color:#000;z-index:1}.upload-note{color:#6c757d;font-size:13px;margin:0;font-style:italic}.pagination-controls{display:flex;justify-content:center;align-items:center;margin:20px 0;padding:10px;gap:15px}.pagination-button{padding:8px 16px;background-color:#fff;color:#000;border:1px solid #cccccc;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.pagination-button:hover:not(:disabled){background-color:#f5f5f5}.pagination-button:disabled{background-color:#f8f9fa;color:#888;cursor:not-allowed}.page-indicator{color:#666;font-size:14px}.project-info{color:#666;font-size:14px;margin:10px 0}.cache-info{font-size:12px;color:#666;margin-top:4px;padding:2px 6px;background-color:#f5f5f5;border-radius:4px;display:inline-block}.model-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin:20px 0}.model-card{max-height:320px;overflow:hidden}.model-viewer{position:relative;min-height:240px}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;z-index:10}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite;margin-bottom:10px}.gcode-preview-card{background-color:#fff;border-radius:12px;border:1px solid #eaeaea;overflow:hidden;transition:transform .2s ease;cursor:pointer;display:flex;flex-direction:column;height:100%}.gcode-preview-card:hover{border-color:#ccc}.gcode-preview-container{background-color:#fff;border-radius:0;overflow:hidden;position:relative;height:300px;border-bottom:1px solid #e0e0e0}.gcode-content-preview{width:100%;height:100%;overflow-y:auto;font-family:Courier New,monospace;font-size:12px;background-color:#fff;color:#333}.gcode-content-preview pre{margin:0;padding:0}.gcode-line{display:flex;padding:0;border-bottom:1px solid #e0e0e0;line-height:1.4;white-space:pre}.gcode-line-number{background-color:#f5f5f5;color:#888;text-align:right;padding:0 5px;min-width:40px;-webkit-user-select:none;user-select:none;border-right:1px solid #e0e0e0}.gcode-line-content{padding:0 5px;overflow-x:auto;width:100%}.gcode-preview-placeholder{display:flex;justify-content:center;align-items:center;height:100%;flex-direction:column;color:#adb5bd;font-style:italic}.gcode-preview-placeholder.error{color:#ff5c5c}.gcode-info{padding:15px 15px 12px;flex-grow:1;display:flex;flex-direction:column;gap:8px;color:#adb5bd}.gcode-info h3{margin:0 0 8px;font-size:16px;font-weight:500;word-break:break-word;color:#000}.gcode-metadata{margin:5px 0;font-size:14px;color:#adb5bd}.plate-info{margin:5px 0;font-size:14px;color:#07f77f;font-weight:500}.gcode-actions{display:flex;justify-content:center;margin-top:10px;width:100%}.gcode-view-toggle-button,.gcode-download-button{background-color:#f5f5f5;border:1px solid #1e1e35;border-radius:6px;padding:8px 16px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;color:#ccc}.gcode-view-toggle-button:hover,.gcode-download-button:hover{background-color:#2d2d45;color:#000}.gcode-view-toggle-button{background-color:#1a2a1f;border-color:#1e3526;color:#07f77f}.gcode-view-toggle-button:hover{background-color:#1e3526;color:#07f77f}.gcode-download-button{background-color:#07f77f!important;border:1px solid #07F77F!important;border-radius:24px!important;padding:12px 16px!important;cursor:pointer;font-size:14px!important;font-weight:400!important;font-family:SK-Modernist-Mono,monospace!important;text-transform:uppercase!important;transition:all .2s ease;color:#111!important;width:100%;text-align:center;outline:none!important;box-shadow:none!important}.gcode-download-button:hover{background-color:#07f77f!important;color:#111!important;outline:none!important;box-shadow:none!important;transform:translateY(-2px)}.gcode-download-button:focus{outline:none!important;box-shadow:none!important}.gcode-download-button:active{outline:none!important;box-shadow:none!important}.gcode-metadata-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 0}.gcode-metadata-row{display:none}.gcode-metadata-container{display:flex;flex-wrap:nowrap;align-items:center;gap:2px;justify-content:flex-start}.gcode-metadata-item{display:flex;align-items:center;gap:4px}.metadata-separator{margin:0 6px;color:#3d3d59;font-weight:400}.time-icon,.filament-icon{display:flex;align-items:center;justify-content:center;margin-right:2px;color:#3f3f4b}.time-icon,.filament-icon{color:#3f3f4b}.time-icon svg,.filament-icon svg{display:block}.metadata-label{font-weight:500;color:#adb5bd;font-size:13px}.metadata-value{font-size:13px;color:#e0e0e0}body .simple-modal-overlay,html body .simple-modal-overlay,html body div.simple-modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background-color:#0009!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:1000!important;pointer-events:auto!important;opacity:1!important;transition:none!important;animation:none!important;transform:none!important;will-change:auto!important;cursor:default!important}body .simple-modal-overlay:hover,body .simple-modal-overlay:focus,body .simple-modal-overlay:active,body .simple-modal-overlay:focus-within,html body .simple-modal-overlay:hover,html body .simple-modal-overlay:focus,html body .simple-modal-overlay:active,html body .simple-modal-overlay:focus-within{background-color:#0009!important;opacity:1!important;transform:none!important;transition:none!important;animation:none!important;will-change:auto!important}body .simple-modal,html body .simple-modal,html body div.simple-modal{background-color:#fff!important;padding:10px!important;border-radius:16px!important;width:450px!important;max-width:90%!important;max-height:90vh!important;overflow-y:auto!important;pointer-events:auto!important;position:relative!important;transform:none!important;transition:none!important;animation:none!important;will-change:auto!important;margin:0!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important;cursor:default!important}body .simple-modal:hover,body .simple-modal:focus,body .simple-modal:active,body .simple-modal:focus-within,html body .simple-modal:hover,html body .simple-modal:focus,html body .simple-modal:active,html body .simple-modal:focus-within,body div.simple-modal:hover,body div.simple-modal:focus,body div.simple-modal:active,body div.simple-modal:focus-within{transform:none!important;position:relative!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important;transition:none!important;animation:none!important;will-change:auto!important;margin:0!important}body .simple-modal *,body .simple-modal *:hover,body .simple-modal *:focus,body .simple-modal *:active,html body .simple-modal *,html body .simple-modal *:hover,html body .simple-modal *:focus,html body .simple-modal *:active{transform:none!important;position:relative!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important;margin:inherit!important}.simple-modal-header{display:flex!important;justify-content:space-between!important;align-items:center!important;background-color:#e7e7e7!important;border-radius:14px!important;margin:10px!important;padding:24px!important;transform:none!important;position:relative!important}.simple-modal-header h2{font-size:18px!important;color:#000!important;font-weight:400!important;margin:0!important;transform:none!important;position:relative!important}.simple-close-btn{background:transparent!important;border:none!important;cursor:pointer!important;padding:8px!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:6px!important;font-size:24px!important;color:#999!important;width:32px!important;height:32px!important;transform:none!important;transition:background-color .2s ease!important;position:relative!important}.simple-close-btn:hover{background-color:#ffffff1a!important;color:#333!important;transform:none!important;position:relative!important}.simple-modal-content{padding:0 24px 24px!important;transform:none!important;position:relative!important}.simple-modal-content h3{font-size:18px!important;margin-bottom:16px!important;color:#000!important;font-weight:400!important;margin-top:0!important;transform:none!important;position:relative!important}.simple-modal-content p{margin:0 0 18px!important;padding-top:30px!important;font-size:14px!important;color:#888!important;line-height:1.5!important;font-weight:400!important;transform:none!important;position:relative!important}.simple-file-info{background:#f8f9fa!important;border:1px solid #eaeaea!important;border-radius:8px!important;padding:12px!important;margin-bottom:18px!important;transform:none!important;position:relative!important}.simple-file-name{font-family:monospace!important;font-size:14px!important;color:#495057!important;transform:none!important;position:relative!important}.simple-benefits{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important;margin-bottom:18px!important;transform:none!important;position:relative!important;text-align:left!important}.simple-benefits h4{margin:0 0 16px!important;padding-top:20px!important;padding-bottom:10px!important;font-size:16px!important;font-weight:400!important;color:#000!important;transform:none!important;position:relative!important;text-align:left!important}.simple-benefits ul{list-style:none!important;padding:0!important;margin:0!important;transform:none!important;position:relative!important;text-align:left!important}.simple-benefits li{padding:6px 0!important;font-size:14px!important;color:#888!important;font-weight:400!important;transform:none!important;position:relative!important;display:flex!important;align-items:center!important;text-align:left!important;justify-content:flex-start!important;background:transparent!important;border:none!important;margin:0!important}.simple-benefits li .checkmark-icon,.simple-modal .checkmark-icon{width:16px!important;height:16px!important;margin-right:6px!important;flex-shrink:0!important;display:inline-block!important}.simple-benefits li span,.simple-benefits li text{text-align:left!important;flex:1!important;padding-left:0!important}.simple-modal-actions{display:flex!important;justify-content:flex-start!important;gap:8px!important;margin-top:24px!important;padding:0 24px 24px!important;transform:none!important;position:relative!important}.simple-primary-btn,.simple-secondary-btn{display:flex!important;align-items:center!important;justify-content:center!important;height:40px!important;border-radius:25px!important;font-weight:400!important;text-align:center!important;font-size:14px!important;box-sizing:border-box!important;padding:0 20px!important;cursor:pointer!important;font-family:sk-modernist-mono,monospace!important;text-transform:uppercase!important;letter-spacing:-.05em!important;transform:none!important;transition:all .3s ease!important;position:relative!important;border:none!important;min-width:120px!important}.simple-primary-btn{background-color:#07f77f!important;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%)!important;color:#000!important;overflow:hidden!important;transform:none!important;position:relative!important}.simple-primary-btn:hover{background-color:#1aff8c!important;color:#000!important;transform:translateY(-2px)!important;position:relative!important}.simple-primary-btn:focus{outline:none!important;box-shadow:none!important}.simple-secondary-btn{background-color:transparent!important;color:#000!important;border:1px solid #eaeaea!important;transform:none!important;position:relative!important}.simple-secondary-btn:hover{background-color:transparent!important;border-color:#888!important;color:#000!important;transform:translateY(-2px)!important;position:relative!important}.simple-secondary-btn:focus{outline:none!important;box-shadow:none!important}@media (max-width: 600px){.simple-modal{width:95%!important;margin:20px!important;transform:none!important;position:relative!important}.simple-modal-header,.simple-modal-content,.simple-modal-actions{padding:16px!important;transform:none!important;position:relative!important}.simple-modal-actions{flex-direction:column!important;transform:none!important;position:relative!important}.simple-primary-btn,.simple-secondary-btn{width:100%!important;justify-content:center!important}}.gcode-settings-popup{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000}.gcode-settings-content{background-color:#fff;border-radius:12px;padding:24px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;position:relative}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-overlay.with-intent-popup{justify-content:center;align-items:center}.orientation-popup{background-color:#fff;padding:0;border-radius:16px;width:450px;max-width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;background-color:#e7e7e7;border-radius:14px;margin:10px;padding:24px}.close-button{background:transparent;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:6px}.close-button:hover{background-color:#ffffff1a}.modal-content{padding:24px}.orientation-popup h2{font-size:18px;margin-bottom:0;color:#000;font-weight:400}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:8px;color:#111;font-size:14px;font-weight:400}.form-group select{width:100%;padding:14px 30px 14px 12px;border-radius:25px;border:1px solid #eaeaea;background-color:transparent;color:#888;font-size:14px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23cccccc' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.form-group select:focus{outline:none;border-color:#eaeaea}.form-group select:hover{border-color:#eaeaea}.popup-buttons{display:flex;align-items:center;margin-top:24px}.popup-buttons .back-button{flex:none}.popup-buttons .apply-button{flex:none;width:auto;min-width:120px;margin-left:4px}.back-button{display:flex;align-items:center;justify-content:center;height:40px;background-color:transparent;color:#666;border:1px solid #e0e0e0;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;cursor:pointer;font-family:sk-modernist,monospace;letter-spacing:-.05em}.back-button:hover{background-color:#f5f5f5;color:#333;border-color:#ccc;transform:translateY(-1px)}.back-button:focus{outline:none;box-shadow:none}.cancel-button{display:flex;align-items:center;justify-content:center;height:40px;background-color:transparent;color:#000;border:1px solid #eaeaea;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;cursor:pointer;font-family:sk-modernist,monospace;text-transform:uppercase;letter-spacing:-.05em}.cancel-button:hover{background-color:transparent;transform:translateY(-2px);border-color:#888}.cancel-button:focus{outline:none;box-shadow:none}.apply-button{display:flex;align-items:center;justify-content:center;height:40px;background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;text-decoration:none;border:none;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;overflow:hidden;cursor:pointer;font-family:sk-modernist,monospace;text-transform:uppercase;letter-spacing:-.05em}.apply-button:hover{background-color:#07f77f;transform:translateY(-2px);color:#000}.apply-button:focus{outline:none;box-shadow:none}.loading-message{display:flex;justify-content:center;align-items:center;padding:30px;color:#000;font-size:14px;position:relative;min-height:100px}.loading-message:before{content:"";width:24px;height:24px;border-radius:50%;border:2px solid #ffffff;border-top-color:transparent;margin-right:10px;animation:spinner .8s linear infinite}@keyframes spinner{to{transform:rotate(360deg)}}.error-message{background-color:#dc26261a;color:#ff6b6b;padding:16px;border-radius:8px;margin:24px;font-size:14px;border:1px solid rgba(220,38,38,.2)}.user-intent-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.user-intent-popup{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:1100px;width:100%;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out;position:relative}.user-intent-header{display:flex;justify-content:space-between;align-items:center;background-color:#e7e7e7;border-radius:14px;margin:10px;padding:32px 24px;position:relative;min-height:20px}.user-intent-header-content{flex:1;display:flex;align-items:center}.user-intent-header h2{margin:0;font-size:18px;font-weight:400;color:#000;letter-spacing:-.03em;line-height:1}.close-button:hover{background-color:#ffffff1a;color:#333}.user-intent-content{padding:0 32px 32px}.preset-section{margin-bottom:24px}.preset-section h3{font-size:18px;font-weight:400;color:#1a1a1a;margin:50px 0 16px;letter-spacing:-.02em}.preset-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.preset-card{border:1px solid #eaeaea;border-radius:12px;padding:20px 16px;cursor:pointer;transition:all .2s ease;background:#fff;min-height:180px;display:flex;flex-direction:column}.preset-card:hover{border-color:#eaeaea;background-color:#f9fafb;transform:translateY(-2px)}.preset-card.selected{border-color:#d1d5db;background:#f8f9fa;transform:translateY(-2px)}.preset-card h4{font-size:16px;font-weight:400;color:#1a1a1a;margin:0 0 6px}.preset-card p{font-size:14px;color:#888;margin:0 0 16px;line-height:1.4}.preset-benefits{margin-bottom:8px;padding-top:16px;border-top:1px solid #eaeaea;margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px}.preset-tradeoffs{margin-bottom:8px}.benefit-item,.tradeoff-item{display:flex;align-items:center;font-size:14px;line-height:1.3;margin-bottom:8px}.benefit-item .check{width:14px;height:14px;margin-right:6px;background-image:url(/checkmark_icon.svg);background-size:contain;background-repeat:no-repeat;background-position:center;display:inline-block;flex-shrink:0}.tradeoff-item .warning{color:#f59e0b;margin-right:6px;font-size:14px}.benefit-item,.tradeoff-item{color:#888}.ai-chat-section{padding-top:24px}.ai-chat-section h3{font-size:18px;font-weight:400;color:#1a1a1a;margin:0 0 6px;letter-spacing:-.02em}.ai-chat-description{font-size:14px;color:#888;margin:0 0 16px;line-height:1.5}.ai-suggestion{background:#f0f9ff;border:1px solid #eaeaea;border-radius:12px;padding:16px;margin-bottom:16px}.suggestion-header{display:flex;align-items:center;margin-bottom:8px}.ai-icon{margin-right:8px;font-size:16px}.suggestion-header strong{color:#1d4ed8;font-size:14px}.ai-suggestion p{margin:0 0 12px;font-size:14px;color:#888;line-height:1.5}.ai-bullet-summary{margin-top:12px}.ai-bullet-point{display:flex;align-items:flex-start;margin-bottom:8px;font-size:14px;line-height:1.4;color:#1a1a1a}.ai-bullet-point .bullet{margin-right:8px;margin-top:2px;flex-shrink:0;font-weight:700}.ai-bullet-point.benefit .bullet.green{color:#10b981}.ai-bullet-point.tradeoff .bullet.orange{color:#f59e0b}.ai-bullet-point span:last-child{flex:1}.prompt-error{background:#fef2f2;border:1px solid #eaeaea;border-radius:12px;padding:16px;margin-bottom:20px;display:flex;align-items:center;color:#dc2626;font-size:14px}.error-icon{margin-right:8px}.ai-input-container{margin-bottom:20px}.ai-input-wrapper{position:relative;display:flex;align-items:flex-end;border:1px solid #eaeaea;border-radius:12px;background:#fff;transition:border-color .2s}.ai-input-wrapper:focus-within{border-color:#eaeaea;box-shadow:0 0 0 1px #eaeaea}.ai-prompt-textarea{flex:1;border:none;outline:none;padding:16px;font-size:14px;line-height:1.5;resize:none;font-family:inherit;background:transparent;border-radius:12px}.ai-prompt-textarea::placeholder{color:#888;opacity:.5}.ai-submit-button{border:none;background:#07f77f;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s;width:36px;height:36px;margin:6px}.ai-submit-button:hover.enabled{background-color:#06e070}.arrow-icon{color:#000;font-size:16px;font-weight:700;width:20px;height:20px;flex-shrink:0}.ai-submit-button:disabled{cursor:not-allowed;opacity:.5}.spinner-small{width:16px;height:16px;border:2px solid #eaeaea;border-radius:50%;border-top-color:#eaeaea;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-examples{font-size:12px;color:#888}.ai-examples p{display:inline;margin:0 8px 0 0;font-weight:400;font-size:12px;color:#888}.ai-examples ul{margin:0;padding:0;list-style-type:none;display:inline}.ai-examples li{display:inline;line-height:1.4;font-style:italic;font-size:12px;color:#888;margin:0;padding:0;background:none;border:none;white-space:nowrap}.ai-examples li:not(:last-child):after{content:" • ";margin:0 4px;color:#9ca3af}.popup-buttons{display:flex;gap:4px;margin-top:24px;padding-top:20px;border-top:1px solid #eaeaea;justify-content:flex-end}.cancel-button,.apply-button{flex:none;width:auto;min-width:100px;padding:14px 24px;border-radius:25px;font-size:14px;font-weight:400;cursor:pointer;transition:all .2s ease;border:1px solid;font-family:sk-modernist,monospace}.cancel-button{background:#fff;color:#888;border-color:#eaeaea}.cancel-button:hover{background:#f9fafb;border-color:#eaeaea;transform:translateY(-1px)}.apply-button{background:#07f77f;color:#000;border-color:#07f77f}.apply-button:hover{background:#07f77f;border-color:#07f77f;transform:translateY(-1px)}@media (max-width: 1024px){.preset-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media (max-width: 768px){.user-intent-popup{margin:20px;max-width:calc(100vw - 40px)}.user-intent-header,.user-intent-content{padding:20px}.preset-grid{grid-template-columns:1fr}.preset-card{min-height:auto}}.build-plate-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.build-plate-warning-popup{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:600px;width:100%;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out;position:relative;margin:20px}.build-plate-warning-header{display:flex;justify-content:space-between;align-items:center;background-color:#e7e7e7;border-radius:14px;margin:10px;padding:32px 24px;position:relative;border:none}.build-plate-warning-header-content{flex:1;display:flex;align-items:center;gap:12px}.warning-icon{font-size:24px;line-height:1}.build-plate-warning-header h2{margin:0;font-size:18px;font-weight:400;color:#000;letter-spacing:-.03em;line-height:1}.close-button{background:transparent;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;height:32px;width:32px;flex-shrink:0}.close-button:hover{background-color:#0000001a;color:#333}.build-plate-warning-content{padding:0 32px 32px}.warning-message{border:none;border-bottom:none}.warning-message p{font-size:16px;line-height:1.5;color:#000;margin:20px 0}.incompatible-models{background-color:transparent;border-radius:8px;padding:0;margin:20px 0;border:none}.incompatible-model{display:flex;align-items:center;margin-bottom:8px;font-size:14px;color:#333}.incompatible-model:last-child{margin-bottom:0}.incompatible-model .bullet{display:none}.model-name{font-family:monospace;background-color:#f2f2f2;padding:6px 12px;border-radius:25px;font-size:13px}.warning-message h4{font-size:16px;font-weight:500;color:#333;margin:24px 0 12px}.warning-message ol{margin:0;padding-left:0;text-align:left}.warning-message li{font-size:14px;line-height:1.6;color:#888;margin-bottom:8px;background:none;border:none;padding:0;display:flex;align-items:center;list-style:none;text-align:left}.warning-message li:last-child{margin-bottom:0}.solution-icon{width:14px;height:14px;margin-right:8px;flex-shrink:0}.warning-message li span{text-align:left;flex:1}.error-notice{background-color:#f8d7da;border:none;border-radius:8px;padding:16px;margin:20px 0;color:#721c24;font-size:14px;font-weight:500!important;text-align:center}.popup-buttons{display:flex;gap:12px;margin-top:20px;padding-top:0;justify-content:flex-end;border-top:none!important;border:none!important}.cancel-button,.continue-button{flex:none;width:auto;min-width:100px;padding:14px 24px;border-radius:25px;font-size:14px;font-weight:400;cursor:pointer;transition:all .2s ease;border:1px solid;font-family:sk-modernist,monospace}.cancel-button{background:#fff;color:#333;border-color:#e0e0e0}.cancel-button:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.continue-button{background:#07f77f;color:#000;border-color:#07f77f}.continue-button:hover{background:#06e070;border-color:#06e070;transform:translateY(-1px)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.build-plate-warning-popup{margin:20px;max-width:calc(100vw - 40px)}.build-plate-warning-header,.build-plate-warning-content{padding:20px}.popup-buttons{flex-direction:column}.cancel-button,.continue-button{width:100%}}.gcode-folder-card{background-color:#fff;border-radius:16px;padding:0;cursor:pointer;transition:transform .2s ease;width:100%}.gcode-folder-card:hover{transform:translateY(-2px)}.gcode-folder-header{display:flex;align-items:center;padding:16px 20px;cursor:pointer;transition:background-color .2s ease}.folder-icon{box-shadow:none!important;margin-right:21px;display:flex;align-items:center;justify-content:center;width:45px;height:auto;background-image:url(/folder-close-icon.png);background-size:contain;background-repeat:no-repeat;background-position:center;transition:background-image .2s ease;min-width:45px;aspect-ratio:1}.folder-icon img{display:none}.gcode-folder-card:hover .folder-icon{background-image:url(/folder-hover-icon.png)}.folder-info{flex:1}.folder-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.folder-info h3{margin:0;font-size:16px;font-weight:400;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-date{margin:0 0 2px;font-size:14px;color:#adb5bd}.folder-stats{display:none}.folder-controls{display:flex;gap:10px}.download-all-button,.expand-button,.delete-button{border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;border:1px solid}.download-all-button{background-color:#07f77f;border-color:#07f77f;color:#111}.download-all-button:hover{background-color:#07f77f;border-color:#07f77f;color:#111;transform:translateY(-2px)}.download-all-button.loading{background-color:#07f77f;color:#111;cursor:not-allowed;position:relative;border-color:#07f77f}.button-spinner{width:24px;height:24px;border-radius:50%;border:2px solid rgba(255,255,255,.2);border-top:2px solid #ffffff;animation:download-spinner 1s linear infinite;display:inline-block;box-sizing:border-box;flex-shrink:0;transform-origin:center}@keyframes download-spinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.expand-button{background-color:transparent;color:#d4d4d4;border-color:#d4d4d4}.expand-button:hover{background-color:transparent;color:#d4d4d4;border-color:#d4d4d4;transform:translateY(-2px)}.delete-button{background-color:transparent;color:#d4d4d4;border-color:#d4d4d4}.delete-button:hover{background-color:#ff5c5c1a;border-color:#ff5c5c;color:#ff5c5c;transform:translateY(-2px)}.delete-button.loading{background-color:transparent;color:#d4d4d4;cursor:not-allowed}.delete-button .button-spinner{border:2px solid rgba(255,92,92,.2);border-top-color:#ff5c5c}.folder-content{padding:0 20px 2px;background-color:#fff;border-top:1px solid #e0e0e0;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.folder-content .gcode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.folder-metadata{margin-top:0;margin-bottom:8px;display:flex;align-items:center;flex-wrap:wrap;gap:1px;color:#888;font-size:13px}.folder-total-time,.folder-total-filament,.folder-loading{margin:2px 0;font-size:13px;color:#adb5bd;display:flex;align-items:center}.folder-metadata-row{display:none}.folder-metadata-item{display:flex;align-items:center;gap:6px;margin-right:0}.folder-stats-info{display:flex;align-items:center;color:#888;font-size:13px;gap:2px;margin-right:0}.files-icon,.time-icon,.filament-icon,.printer-icon,.nozzle-icon,.material-icon{display:flex;align-items:center;justify-content:center;color:#848484;width:16px;height:16px;background-size:contain;background-repeat:no-repeat;background-position:center}.files-icon{background-image:url(/file-icon2.svg)}.printer-icon{background-image:url(/3-d-view-icon.svg)}.time-icon{background-image:url(/time-quarter-icon.svg);color:#848484}.filament-icon{background-image:url(/layers-icon.svg);color:#848484}.nozzle-icon{background-image:url(/nozzle_icon.svg)}.material-icon{background-image:url(/material_icon.svg)}.files-icon svg,.time-icon svg,.filament-icon svg,.printer-icon svg,.nozzle-icon svg,.material-icon svg{display:none}.folder-loading{font-style:italic;color:#888}.metadata-label{font-weight:400;margin-right:2px;color:#888}.metadata-value{color:#888;font-weight:400}.metadata-separator{margin:0 12px;color:#eaeaea;font-weight:300;display:inline}.folder-printer-info{display:none}.printer-name{color:#888;font-size:13px}.gcode-folder-card.loading{pointer-events:none;opacity:.7}.gcode-folder-card.loading .folder-content{opacity:.5}button.download-all-button svg,button.expand-button svg,button.delete-button svg{width:64px!important;height:64px!important;display:block!important;visibility:visible!important;opacity:1!important;min-width:64px!important;min-height:64px!important;max-width:none!important;max-height:none!important}.gcode-folder-card .gcode-folder-header .folder-controls .download-all-button svg,.gcode-folder-card .gcode-folder-header .folder-controls .expand-button svg,.gcode-folder-card .gcode-folder-header .folder-controls .delete-button svg,.gcode-folder-card .folder-controls .download-all-button svg,.gcode-folder-card .folder-controls .expand-button svg,.gcode-folder-card .folder-controls .delete-button svg{width:64px!important;height:64px!important;display:block!important;transition:transform .2s ease!important;visibility:visible!important;opacity:1!important;transform:none!important;max-width:none!important;max-height:none!important;min-width:14px!important;min-height:14px!important}.storage-quota-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.storage-quota-popup{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:480px;width:90%;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out;position:relative}.storage-quota-header{padding:32px 32px 16px;text-align:center;position:relative}.storage-quota-icon{margin-bottom:12px}.storage-quota-icon img{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.storage-quota-header h2{margin:0;font-size:21px;font-weight:500;color:#1a1a1a;letter-spacing:-.02em}.storage-quota-close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:#eaeaea;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.storage-quota-close:hover{background-color:#f5f5f5;color:#333}.storage-quota-content{padding:0 32px 12px}.storage-quota-content h2{margin:0 0 8px;font-size:21px;font-weight:500;color:#1a1a1a;letter-spacing:-.02em;text-align:center}.storage-quota-message{font-size:14px;line-height:1.5;color:#888;margin:0 0 16px;text-align:center}.storage-quota-options{display:flex;flex-direction:column;gap:16px}.storage-option{padding:20px;border:1px solid #eaeaea;border-radius:12px;transition:all .2s ease}.storage-option:hover{border-color:#eaeaea;background-color:#f7f7f7}.storage-option h3{margin:0 0 8px;font-size:16px;font-weight:500;color:#111}.storage-option p{margin:0;font-size:14px;color:#888;line-height:1.4}.storage-option-divider{text-align:center;font-size:12px;font-weight:500;color:#888;text-transform:uppercase;letter-spacing:.05em;margin:8px 0;position:relative}.storage-option-divider:before,.storage-option-divider:after{content:"";position:absolute;top:50%;width:35%;height:1px;background-color:#eaeaea}.storage-option-divider:before{left:0}.storage-option-divider:after{right:0}.storage-quota-actions{padding:0 32px 32px;display:flex;gap:8px;justify-content:flex-end}.storage-quota-manage{display:flex;align-items:center;justify-content:center;height:40px;background-color:transparent;color:#000;border:1px solid #f2f2f2;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;cursor:pointer;font-family:var(--custom-button-font)!important;text-transform:uppercase;letter-spacing:-.05em}.storage-quota-manage:hover{background-color:transparent;transform:translateY(-2px);border-color:#888}.storage-quota-upgrade{display:flex;align-items:center;justify-content:center;height:40px;background-color:#07f77f;background-image:radial-gradient(circle at center,#ffffff4d,#fff0 80%);color:#000;text-decoration:none;border:none;border-radius:25px;font-weight:400;transition:all .3s ease;text-align:center;font-size:14px;box-sizing:border-box;padding:0 20px;overflow:hidden;cursor:pointer;font-family:var(--custom-button-font)!important;text-transform:uppercase;letter-spacing:-.05em}.storage-quota-upgrade:hover{background-color:#1aff8c;transform:translateY(-2px);color:#000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.storage-quota-popup{max-width:95%;margin:16px}.storage-quota-header,.storage-quota-content,.storage-quota-actions{padding-left:24px;padding-right:24px}.storage-quota-actions{flex-direction:column}.storage-quota-manage,.storage-quota-upgrade{width:100%;justify-content:center}}@font-face{font-family:Sk-Modernist-Mono;src:url(/Sk-Modernist-Mono.otf) format("opentype"),url(/Sk-Modernist-Mono.otf) format("truetype");font-weight:400;font-style:normal;font-display:swap}.persistent-video-player{position:fixed;bottom:20px;right:20px;width:400px;background:#1a1a1a;border-radius:12px;box-shadow:0 10px 25px #0000004d;z-index:9999;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;animation:slideIn .4s cubic-bezier(.4,0,.2,1)}.persistent-video-player.dragging{cursor:grabbing;-webkit-user-select:none;user-select:none;transition:none}.video-header{background:#000;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;cursor:grab;border-bottom:1px solid #333;height:34px;box-sizing:border-box}.video-header:active{cursor:grabbing}.video-title{color:#fff;font-size:13px;font-weight:400;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;margin-right:12px}.video-controls{display:flex;gap:4px;align-items:center}.minimize-btn,.close-btn{background:none;border:none;color:#999;cursor:pointer;padding:4px 6px;border-radius:4px;font-size:14px;font-weight:700;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.minimize-btn:hover{background:#3a3a3a;color:#fff}.close-btn:hover{background:#212121;color:#fff}.video-content{background:#000;position:relative}.video-element{width:100%;height:225px;object-fit:cover;display:block;background:#000;outline:none!important;border:none!important}.video-element::-webkit-media-controls-panel{background-color:#0003!important;background-image:none!important}.video-element::-webkit-media-controls-enclosure{background-color:transparent!important}.video-element::-webkit-media-controls-overlay-enclosure{background-color:transparent!important}.video-element::-webkit-media-controls-play-button,.video-element::-webkit-media-controls-volume-slider,.video-element::-webkit-media-controls-timeline,.video-element::-webkit-media-controls-current-time-display,.video-element::-webkit-media-controls-time-remaining-display,.video-element::-webkit-media-controls-mute-button,.video-element::-webkit-media-controls-fullscreen-button{filter:drop-shadow(0 0 2px rgba(0,0,0,.8));color:#fff!important}.video-element::-webkit-media-controls-timeline{background-color:#ffffff4d!important}.video-element{transition:all .3s ease}.video-element:hover::-webkit-media-controls-panel{background-color:#0000001a!important}.persistent-video-player:hover{box-shadow:0 15px 35px #0006}@keyframes slideIn{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.persistent-video-player{width:350px;bottom:10px;right:10px}.video-element{height:200px}}@media (max-width: 480px){.persistent-video-player{width:calc(100vw - 20px);right:10px;left:10px;max-width:350px}.video-element{height:180px}}.close-btn:focus{outline:2px solid #4a90e2;outline-offset:1px}.video-element[data-loading=true]{background:linear-gradient(45deg,#1a1a1a,#2a2a2a);background-size:400% 400%;animation:loadingGradient 2s ease infinite}@keyframes loadingGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.video-player-toggle,.video-player-toggle:hover,.video-player-toggle:focus,.video-player-toggle:active,.video-player-toggle:focus-visible{outline:0!important;outline:none!important;outline-width:0!important;outline-style:none!important;outline-color:transparent!important;-webkit-tap-highlight-color:rgba(0,0,0,0)!important;-webkit-tap-highlight-color:transparent!important;-webkit-focus-ring-color:transparent!important;-moz-outline:0!important;-moz-outline:none!important;box-shadow:none!important;border:1px solid rgba(255,255,255,.2)!important}.video-player-toggle{position:fixed;bottom:20px;right:20px;background:#07f77f;color:#000;border:none;padding:12px 16px;border-radius:25px;cursor:pointer;font-size:14px;font-weight:400;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:9998;display:flex;align-items:center;gap:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.video-player-toggle:hover{transform:translateY(-2px)}.video-player-toggle:active{transform:translateY(0)}@media (max-width: 768px){.video-player-toggle{bottom:15px;right:15px;padding:10px 14px;font-size:13px}}@media (max-width: 480px){.video-player-toggle{bottom:10px;right:10px;padding:8px 12px;font-size:12px}}.video-element:focus,.video-element:hover,.video-element:active{outline:none!important;outline-width:0!important;outline-style:none!important;outline-color:transparent!important;border:none!important;box-shadow:none!important}.persistent-video-player:focus,.persistent-video-player:hover,.persistent-video-player:active{outline:none!important;border:none!important}.stl-finder-card-no-bg{background:transparent;border:none;box-shadow:none;margin:0;padding:0;border-radius:0;width:100%;display:flex;flex-direction:column;min-height:calc(100vh - 200px)}.stl-results-container{flex-shrink:0;margin-bottom:2rem;margin-top:3rem;max-height:calc(100vh - 250px);overflow-y:auto;padding-right:8px}.stl-results-container::-webkit-scrollbar{display:none}.stl-results-container{-ms-overflow-style:none;scrollbar-width:none}.stl-finder-content.with-results{padding-bottom:200px}.searching-indicator,.search-error,.no-results{text-align:center;padding:2rem;margin-bottom:1rem}.stl-results-grid{padding:1.5rem;margin-bottom:1rem}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.results-header h3{margin:0;font-size:1.2rem;font-weight:500;color:#1f2937}.new-search-btn,.retry-search-btn{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.new-search-btn:hover,.retry-search-btn:hover{background:#2563eb}.model-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;align-items:start;justify-content:center}.stl-model-card{background:#f9fafb;border-radius:16px;overflow:hidden;transition:transform .2s;display:flex;flex-direction:column;height:100%;align-self:stretch}.stl-model-card:hover{transform:translateY(-2px)}.model-thumbnail{position:relative;height:0;padding-bottom:100%;overflow:hidden}.model-thumbnail img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.model-source-badge{display:inline-block;background:#f2f2f2;color:#626262;padding:2px 6px;border-radius:12px;font-size:10px;font-weight:500;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;text-transform:uppercase;margin-bottom:.5rem;text-align:left;width:fit-content}.model-info{padding:1rem;flex:1;display:flex;flex-direction:column}.model-title{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#1f2937;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.model-description{margin:0 0 1rem;font-size:.875rem;color:#6b7280;line-height:1.4;text-align:left;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.model-meta{display:flex;justify-content:space-between;margin-bottom:1rem;font-size:.75rem;color:#9ca3af;text-align:left}.download-model-btn{width:100%;background:transparent;color:#000;border:1px solid #d4d4d4;padding:.75rem;border-radius:25px;cursor:pointer;font-size:.9rem;font-weight:400;text-transform:uppercase;font-family:Sk-Modernist-Mono,Courier New,Consolas,Monaco,monospace;margin-top:auto;outline:none;transform:translateY(-1px)!important}.download-model-btn:hover,.download-model-btn:focus,.download-model-btn:active,.download-model-btn:focus-visible{outline:none!important;box-shadow:none!important;border:1px solid #d4d4d4!important;-webkit-tap-highlight-color:transparent!important}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stl-finder-content{background:transparent;padding:0;display:flex;flex-direction:column;width:100%;flex:1}.stl-search-interface{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:none;padding:1rem;flex:1;flex-shrink:0}.stl-search-interface.with-results{position:fixed;bottom:0;left:0;right:0;z-index:100;margin-top:0;flex:none;justify-content:center}.main-content.with-sidebar .stl-search-interface.with-results{left:280px!important;width:calc(100% - 280px)!important}.search-prompt h3{margin:0 0 .5rem;font-size:29px;color:#1f2937;font-weight:400;text-align:center}.search-prompt p{margin:0 0 2rem;color:#888;font-size:1rem;text-align:center}.stl-search-input-container{width:100%!important;max-width:700px!important;margin:0 auto!important;display:block!important}.stl-search-input-wrapper{position:relative!important;width:100%!important;display:flex!important;align-items:flex-start!important}.stl-search-textarea{width:100%!important;padding:.8rem .8rem 45px!important;border:none!important;border-radius:12px!important;font-size:1rem!important;resize:none!important;font-family:inherit!important;margin-bottom:0!important;outline:none!important;box-shadow:none!important;background-color:#f9fafb!important}.stl-search-button{position:absolute!important;right:12px!important;bottom:12px!important;background:linear-gradient(135deg,#9ca3af,#6b7280)!important;color:#fff!important;border:none!important;border-radius:50%!important;cursor:not-allowed!important;transition:all .2s ease!important;z-index:2!important;width:36px!important;height:36px!important;min-width:36px!important;min-height:36px!important;max-width:36px!important;max-height:36px!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;padding:0!important;margin:0!important;box-sizing:border-box!important;opacity:.6!important}.stl-search-button.enabled{background:#07f77f!important;cursor:pointer!important;opacity:1!important}.stl-search-button:hover.enabled{background:#1aff8c!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px #07f77f4d!important}.stl-search-examples{margin:10px 0 0!important;padding:0!important}.stl-search-examples p{text-align:center!important;color:#888!important;font-size:12px!important;margin:0!important;padding:0!important;margin-bottom:1rem!important}@media (max-width: 768px){.stl-search-input-container{max-width:90vw!important}.stl-search-textarea{padding:.8rem .8rem 40px!important;font-size:.9rem!important}.stl-search-button{width:32px!important;height:32px!important;right:8px!important;bottom:8px!important}}@media (max-width: 480px){.stl-search-input-container{max-width:95vw!important}.stl-search-textarea{padding:.7rem .7rem 35px!important;font-size:.85rem!important}.stl-search-button{width:30px!important;height:30px!important;right:6px!important;bottom:6px!important}}.ai-support-container{padding:1.5rem;max-width:100%;height:calc(100vh - 120px);display:flex;flex-direction:column;overflow:hidden}.ai-support-header{margin-bottom:2rem}.ai-support-title h1{margin:0 0 .5rem;font-size:2rem;font-weight:600;color:#1f2937}.ai-support-title p{margin:0;color:#6b7280;font-size:1.1rem}.ai-support-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem;flex:1;overflow:hidden}.ai-card-wrapper{display:flex;height:100%;overflow:hidden;box-shadow:none!important}.ai-card-wrapper .ai-card{margin:0;width:100%;height:100%;max-height:none;min-height:auto;border-radius:16px;display:flex;flex-direction:column;box-shadow:none!important}.ai-card-wrapper .ai-card-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.ai-card-wrapper .maxel-assistant-card,.ai-card-wrapper .maxel-assistant-card:hover{box-shadow:none!important}.ai-card-wrapper .maxel-assistant-card .chat-messages{max-height:none;flex:1;overflow-y:auto}.ai-card-wrapper .file-assistant-card .file-analysis-grid{height:auto;flex:1;grid-template-columns:1fr;gap:1rem}.ai-card-wrapper .file-assistant-card .file-list,.ai-card-wrapper .file-assistant-card .analysis-details{max-height:none;height:auto;min-height:200px}.ai-card-wrapper .stl-finder-card .search-results{flex:1;min-height:200px}.ai-support-grid{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1400px){.ai-support-grid{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.ai-card-wrapper:nth-child(3){grid-column:1 / -1}}@media (max-width: 1024px){.ai-support-grid{grid-template-columns:1fr;gap:1rem}.ai-card-wrapper:nth-child(3){grid-column:auto}.ai-card-wrapper .file-assistant-card .file-analysis-grid{grid-template-columns:1fr}}@media (max-width: 768px){.ai-support-container{padding:1rem;height:calc(100vh - 100px)}.ai-support-header{margin-bottom:1.5rem}.ai-support-title h1{font-size:1.5rem}.ai-support-title p{font-size:1rem}.ai-support-grid{gap:.75rem}}.ai-support-centered{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:2rem;text-align:center}.ai-support-centered .ai-support-header{margin-bottom:3rem}.ai-support-centered .ai-support-title h1{margin:0 0 1rem;font-size:2.5rem;font-weight:600;color:#1f2937}.ai-support-centered .ai-support-title p{margin:0;color:#6b7280;font-size:1.2rem;max-width:600px}.centered-card{max-width:1200px;width:100%}.centered-card .ai-card{margin:0;width:100%;height:auto;min-height:500px}.centered-card .stl-finder-card-no-bg .search-input-container{width:100%!important;max-width:700px!important;margin:0 auto!important;display:block!important;gap:0!important}.centered-card .stl-finder-card-no-bg .search-input-wrapper{position:relative!important;width:100%!important;display:flex!important;align-items:flex-start!important}.centered-card .stl-finder-card-no-bg .stl-search-input{width:100%!important;max-width:none!important;padding:1rem 120px 1rem 1rem!important;border:2px solid #e5e7eb!important;border-radius:12px!important;font-size:1rem!important;resize:none!important;font-family:inherit!important;transition:border-color .2s ease!important;margin-bottom:0!important}.centered-card .stl-finder-card-no-bg .search-execute-btn{position:absolute!important;right:8px!important;top:8px!important;background:linear-gradient(135deg,#3b82f6,#1e40af)!important;color:#fff!important;border:none!important;padding:.6rem 1.5rem!important;border-radius:8px!important;font-weight:600!important;cursor:pointer!important;transition:all .2s ease!important;font-size:.9rem!important;z-index:2!important;height:auto!important}.centered-card .stl-finder-card-no-bg .search-execute-btn:hover:not(:disabled){transform:translateY(-1px)!important;box-shadow:0 4px 12px #3b82f64d!important}.centered-card .stl-finder-card-no-bg .search-execute-btn:disabled{background:#9ca3af!important;cursor:not-allowed!important;transform:none!important;box-shadow:none!important}.centered-card .stl-finder-card-no-bg .search-input-footer{width:100%!important;max-width:none!important;margin-top:.5rem!important;margin-bottom:2rem!important;text-align:left!important}.centered-card .stl-finder-card-no-bg .character-count{font-size:.8rem!important;color:#9ca3af!important}@media (max-width: 768px){.centered-card .stl-finder-card-no-bg .search-input-container{max-width:90vw!important}.centered-card .stl-finder-card-no-bg .stl-search-input{padding:.8rem 100px .8rem .8rem!important;font-size:.9rem!important}.centered-card .stl-finder-card-no-bg .search-execute-btn{padding:.5rem 1rem!important;font-size:.8rem!important;right:6px!important;top:6px!important}}@media (max-width: 480px){.centered-card .stl-finder-card-no-bg .search-input-container{max-width:95vw!important}.centered-card .stl-finder-card-no-bg .stl-search-input{padding:.7rem 90px .7rem .7rem!important;font-size:.85rem!important}.centered-card .stl-finder-card-no-bg .search-execute-btn{padding:.4rem .8rem!important;font-size:.75rem!important;right:5px!important;top:5px!important}}.floating-chat-button{position:fixed;top:50%;right:24px;transform:translateY(-50%);width:60px;height:60px;background-color:transparent;border-radius:50%;display:none;align-items:center;justify-content:center;cursor:pointer;box-shadow:none;transition:all .3s ease;z-index:1000;border:none;animation:pulse-glow 3s ease-in-out infinite}.floating-chat-button:hover{transform:translateY(-50%) translateY(-2px) scale(1.05);box-shadow:none;animation:none}.floating-chat-button img{width:60px;height:60px;border-radius:50%}@keyframes pulse-glow{0%,to{box-shadow:none;transform:translateY(-50%) scale(1)}50%{box-shadow:none;transform:translateY(-50%) scale(1.02)}}.floating-chat-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:transparent;z-index:1001;pointer-events:auto}.floating-chat-modal{position:fixed;top:50%;right:24px;transform:translateY(-50%);width:400px;height:600px;background-color:#fff;border-radius:16px;border:1px solid #e5e7eb;display:flex;flex-direction:column;box-shadow:none;animation:slideInFromRight .3s ease-out;overflow:hidden;z-index:1002}@keyframes slideInFromRight{0%{opacity:0;transform:translateY(-50%) translate(100%)}to{opacity:1;transform:translateY(-50%) translate(0)}}@keyframes slideOutToRight{0%{opacity:1;transform:translateY(-50%) translate(0)}to{opacity:0;transform:translateY(-50%) translate(100%)}}.floating-chat-modal.closing{animation:slideOutToRight .3s ease-out forwards}.floating-chat-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e5e7eb;background-color:#e7e7e7}.chat-header-info{display:flex;align-items:center;gap:12px}.chat-header-info img{border-radius:50%;background-color:transparent;padding:0;width:40px;height:40px}.chat-header-info h3{margin:0;font-size:21px;font-weight:400;color:#1f2937}.chat-status{display:flex;align-items:center;gap:6px;font-size:14px;color:#10b981;font-weight:500}.status-dot{width:8px;height:8px;border-radius:50%;background-color:#10b981}.status-dot.online{animation:pulse 2s infinite}.close-chat-button{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.close-chat-button:hover{background-color:#f3f4f6;color:#374151}.floating-chat-content{flex:1;display:flex;flex-direction:column;height:0}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.message{display:flex;align-items:flex-start;gap:12px}.message.user{flex-direction:row-reverse}.message-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center}.message-avatar img{border-radius:50%}.user-avatar{background-color:#07f77f;color:#000;font-weight:600;font-size:14px}.message-content{max-width:70%;display:flex;flex-direction:column}.message.user .message-content{align-items:flex-end}.message-text{background-color:#f3f4f6;padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.4;color:#374151}.message.user .message-text{background-color:#07f77f;color:#000}.message-timestamp{font-size:12px;color:#9ca3af;margin-top:4px;padding:0 4px}.typing-indicator{display:flex;gap:4px;padding:12px 16px;background-color:#f3f4f6;border-radius:18px}.typing-indicator span{width:8px;height:8px;border-radius:50%;background-color:#9ca3af;animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}.floating-chat-input{border-top:1px solid #e5e7eb;padding:16px 20px;background-color:#fff}.suggested-questions{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.suggestion-chip{background-color:#f3f4f6;border:none;padding:6px 12px;border-radius:20px;font-size:12px;cursor:pointer;transition:background-color .2s ease;color:#374151}.suggestion-chip:hover{background-color:#e5e7eb}.chat-input-wrapper{display:flex;gap:8px;align-items:flex-end}.chat-input{flex:1;padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;resize:none;min-height:44px;max-height:120px;font-family:inherit;font-size:14px;line-height:1.4;transition:border-color .2s ease}.chat-input:focus{outline:none;border-color:#07f77f;box-shadow:0 0 0 3px #07f77f1a}.send-button{padding:12px;background-color:#07f77f;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#000;min-width:44px;height:44px}.send-button:hover:not(:disabled){background-color:#06e070;transform:translateY(-1px)}.send-button:disabled{background-color:#d1d5db;cursor:not-allowed;transform:none;color:#9ca3af}@media (max-width: 768px){.floating-chat-button{bottom:20px;right:20px;width:56px;height:56px}.floating-chat-overlay{background-color:#00000080}.floating-chat-modal{position:fixed;bottom:90px;left:16px;right:16px;width:auto;height:70vh;max-height:600px;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 10px 40px #0003;animation:slideInFromRight .3s ease-out}.floating-chat-header,.chat-messages{padding:16px 20px}.floating-chat-input{padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom))}.suggested-questions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.suggestion-chip{text-align:center;padding:8px 12px}}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.teacher-platform{min-height:100vh;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.teacher-header{background:var(--institution-primary-color, #1e40af);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.teacher-brand{display:flex;align-items:center;gap:1rem}.teacher-brand .institution-logo{height:40px;width:auto;filter:brightness(0) invert(1)}.teacher-nav h1{margin:0;font-size:1.5rem;font-weight:600}.teacher-navigation{display:flex;gap:2rem;margin-top:.5rem}.teacher-navigation .nav-link{color:#ffffffe6;text-decoration:none;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;font-weight:500}.teacher-navigation .nav-link:hover{background:#ffffff1a;color:#fff}.teacher-user-info{display:flex;align-items:center;gap:1rem}.logout-btn:hover{background:#ffffff4d}.teacher-main{max-width:1200px;margin:0 auto;padding:2rem}.teacher-dashboard h2{margin-bottom:2rem;color:#1e293b;font-size:2rem;font-weight:600}.dashboard-card h3{margin:0 0 .5rem;color:var(--institution-primary-color, #1e40af);font-size:1.25rem;font-weight:600}.dashboard-card p{margin:0 0 1rem;color:#64748b;line-height:1.5}.coming-soon{background:#fef3c7;color:#92400e;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;text-align:center;border:1px solid #fbbf24}.coming-soon-large h3{margin:0 0 1rem;color:#1e40af;font-size:1.25rem;font-weight:600}.coming-soon-large ul{margin:0;padding-left:1.5rem;color:#64748b}.students-view h2,.analytics-view h2,.projects-view h2,.reports-view h2{margin-bottom:1rem;color:#1e293b;font-size:2rem;font-weight:600}.students-view p,.analytics-view p,.projects-view p,.reports-view p{color:#64748b;font-size:1.1rem;margin-bottom:2rem}@media (max-width: 768px){.teacher-header{flex-direction:column;gap:1rem}.teacher-navigation{gap:1rem}.teacher-navigation .nav-link{padding:.5rem;font-size:.875rem}.teacher-main{padding:1rem}.dashboard-grid{grid-template-columns:1fr}.teacher-dashboard h2{font-size:1.5rem}}.admin-platform{min-height:100vh;width:100%;max-width:none!important;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0!important;padding:0!important}.admin-header{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px #0000001a}.admin-nav h1{margin:0;font-size:1.5rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.admin-navigation{display:flex;gap:1.5rem;margin-top:.5rem;flex-wrap:wrap}.admin-navigation .nav-link{color:#ffffffe6;text-decoration:none;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;font-weight:500;font-size:.9rem}.admin-navigation .nav-link:hover{background:#ffffff26;color:#fff;transform:translateY(-1px)}.admin-user-info{display:flex;align-items:center;gap:1rem}.super-admin-badge{background:#fff3;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;letter-spacing:.05em;border:1px solid rgba(255,255,255,.3)}.admin-main{max-width:1600px;margin:0 auto;padding:2rem;width:100%}.admin-dashboard h2{margin-bottom:2rem;color:#1e293b;font-size:2rem;font-weight:600}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000000d;border:1px solid #e2e8f0;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-card h3{margin:0 0 1rem;color:#64748b;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:2.5rem;font-weight:700;color:#dc2626;line-height:1;margin-bottom:.5rem}.stat-label{color:#64748b;font-size:.875rem}.dashboard-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;transition:all .2s ease}.dashboard-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.dashboard-card h3{margin:0 0 .5rem;color:#dc2626;font-size:1.25rem;font-weight:600}.dashboard-card p{margin:0 0 1.5rem;color:#64748b;line-height:1.5}.card-action{display:inline-block;background:#dc2626;color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;transition:all .2s ease}.card-action:hover{background:#b91c1c;transform:translateY(-1px)}.view-header h2{margin:0;color:#1e293b;font-size:2rem;font-weight:600}.primary-btn{background:#dc2626;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.primary-btn:hover{background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.coming-soon-large{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;margin-top:2rem}.coming-soon-large h3{margin:0 0 1rem;color:#dc2626;font-size:1.25rem;font-weight:600}.coming-soon-large ul{margin:0 0 1.5rem;padding-left:1.5rem;color:#64748b}.coming-soon-large p{margin:0;color:#059669;font-weight:600}.institutions-view h2,.licenses-view h2,.users-view h2,.analytics-view h2,.billing-view h2,.settings-view h2{margin-bottom:1rem;color:#1e293b;font-size:2rem;font-weight:600}.users-table-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow:auto;max-height:70vh;min-height:400px}.users-table{width:100%;border-collapse:collapse;margin-bottom:1rem}.users-table th,.users-table td{text-align:left;padding:.75rem;border-bottom:1px solid #e2e8f0}.users-table th{background:#f8fafc;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.users-table tbody tr:hover{background:#f8fafc}.user-email{font-weight:500;color:#1e293b}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.role-super-admin{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.licenses-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-top:2rem}.license-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000000d;border:1px solid #e2e8f0;transition:all .2s ease;position:relative}.license-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.license-card.popular{border-color:#dc2626;background:linear-gradient(135deg,#dc26260d,#b91c1c0d)}.popular-badge{position:absolute;top:-8px;left:1rem;background:#dc2626;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.license-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.license-name{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.license-type{color:#fff;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.license-description{color:#64748b;margin:0 0 .5rem;line-height:1.5}.license-audience{color:#374151;font-weight:500;font-size:.875rem;margin:0 0 1rem}.license-features{border-top:1px solid #e2e8f0;padding-top:1rem;margin-bottom:1rem}.feature-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem}.feature-row span{color:#64748b}.feature-row strong{color:#1e293b;font-weight:600}.license-actions{padding-top:1rem;border-top:1px solid #e2e8f0}.edit-license-btn{background:#64748b;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%}.edit-license-btn:hover{background:#dc2626;transform:translateY(-1px)}.license-stats{display:flex;gap:1rem;margin-top:.5rem;font-size:.875rem;color:#64748b}.license-stats span{padding:.25rem .75rem;background:#f1f5f9;border-radius:6px;font-weight:500}.view-actions{display:flex;gap:1rem;align-items:center}.secondary-btn{background:#f8fafc;color:#374151;border:1px solid #d1d5db;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.secondary-btn:hover{background:#f1f5f9;border-color:#9ca3af}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.success-message{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.empty-state{text-align:center;padding:3rem 2rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.empty-state h3{margin:0 0 .5rem;color:#374151;font-size:1.5rem;font-weight:600}.empty-state p{margin:0 0 2rem;color:#64748b;line-height:1.5}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.license-modal{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0;border-bottom:1px solid #e2e8f0;margin-bottom:1.5rem}.close-btn{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-btn:hover{background:#f1f5f9;color:#374151}.license-edit-form{padding:0 1.5rem 1.5rem}.form-group{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500;font-size:.875rem}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:all .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.checkbox-label input{width:auto;margin:0}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.role-institution-admin{background:#f0fdf4;color:#059669;border:1px solid #bbf7d0}.role-teacher{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.role-student{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.action-btn{background:#dc2626;color:#fff;border:none;padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#b91c1c;transform:translateY(-1px)}.super-admin-label{display:inline-block;padding:.375rem .75rem;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.batch-assign-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:14px;margin-left:8px}.batch-assign-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.batch-assign-btn:disabled{background:#d1d5db;cursor:not-allowed;transform:none}.filter-section{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.filter-group{display:flex;align-items:center;gap:.75rem}.filter-group label{font-weight:500;color:#374151;min-width:140px}.institution-filter-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.875rem;color:#374151;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;min-width:200px}.institution-filter-select:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.institution-filter-select:hover{border-color:#9ca3af}.institution-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.875rem;color:#374151;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;width:100%;box-sizing:border-box}.institution-select:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.institution-select:hover{border-color:#9ca3af}.loading-message,.no-users-message{text-align:center;padding:2rem;color:#64748b;font-size:1.1rem}.error-message{background:#fef2f2;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #fecaca}.success-message{background:#f0fdf4;color:#059669;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #bbf7d0}.users-stats{margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:8px;text-align:center;color:#64748b}.users-stats p{margin:.25rem 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;border-radius:12px;width:90%;max-width:500px;box-shadow:0 20px 25px #00000040}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;color:#1e293b;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f1f5f9;color:#374151}.modal-body{padding:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-group input:disabled{background:#f9fafb;color:#6b7280}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e2e8f0}.institutions-stats{display:flex;gap:1rem;margin-top:.5rem;font-size:.875rem;color:#64748b}.institutions-stats span{background:#f1f5f9;padding:.25rem .75rem;border-radius:12px;font-weight:500}.institutions-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow:hidden}.institutions-table{width:100%;border-collapse:collapse}.institutions-table th,.institutions-table td{padding:1rem;text-align:left;border-bottom:1px solid #e2e8f0}.institutions-table th{background:#f8fafc;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.institutions-table tbody tr:hover{background:#f8fafc}.institution-info strong{display:block;color:#1e293b;margin-bottom:.25rem}.institution-url{font-size:.875rem;color:#64748b}.subdomain-code{background:#f1f5f9;padding:.25rem .5rem;border-radius:4px;font-family:Monaco,Menlo,monospace;font-size:.875rem;color:#dc2626}.theme-preview{display:flex;gap:.5rem}.color-box{width:24px;height:24px;border-radius:4px;border:1px solid #e2e8f0;cursor:pointer}.email-domains{display:flex;flex-wrap:wrap;gap:.25rem}.domain-tag{background:#dbeafe;color:#1e40af;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.no-domains{color:#9ca3af;font-style:italic;font-size:.875rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:.5rem}.edit-btn{background:#3b82f6;color:#fff}.edit-btn:hover{background:#2563eb}.delete-btn{background:#ef4444;color:#fff}.delete-btn:hover{background:#dc2626}.empty-state{text-align:center;padding:3rem 2rem;color:#64748b}.empty-state h3{margin:0 0 .5rem;color:#374151}.empty-state p{margin:0 0 1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group small{display:block;margin-top:.25rem;color:#64748b;font-size:.875rem}.color-input-group{display:flex;gap:.75rem;align-items:center}.color-picker{width:60px;height:40px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;background:none;padding:0}.color-picker::-webkit-color-swatch-wrapper{padding:0;border:none;border-radius:4px}.color-picker::-webkit-color-swatch{border:none;border-radius:4px}.hex-input{flex:1;max-width:120px;font-family:Monaco,Menlo,monospace;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.hex-input:invalid{border-color:#ef4444;box-shadow:0 0 0 1px #ef4444}.hex-input:focus:invalid{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-group input[type=checkbox]{margin-right:.5rem;width:auto;opacity:1!important;appearance:auto!important;-webkit-appearance:checkbox!important;-moz-appearance:checkbox!important;transform:scale(1.2);cursor:pointer}.form-group label input[type=checkbox]{margin-right:.75rem;opacity:1!important;position:relative;display:inline-block;width:16px!important;height:16px!important}.logo-upload-section{display:flex;flex-direction:column;gap:1rem}.logo-preview{position:relative;display:inline-block;max-width:200px}.logo-preview-image{max-width:100%;max-height:100px;object-fit:contain;border:2px solid #e2e8f0;border-radius:8px;background:#f8fafc;padding:.5rem}.remove-logo-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:#ef4444;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;transition:all .2s ease}.remove-logo-btn:hover{background:#dc2626;transform:scale(1.1)}.logo-upload-input{display:flex;flex-direction:column;gap:.5rem}.file-input-hidden{display:none}.file-upload-btn{display:inline-block;background:#3b82f6;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:500;text-align:center;border:none;font-size:.875rem;max-width:200px}.file-upload-btn:hover{background:#2563eb;transform:translateY(-1px)}.file-upload-btn:active{transform:translateY(0)}.logo-upload-input small{color:#64748b;font-size:.75rem;margin-top:.25rem}.institution-details{background:#f8fafc;padding:1rem;border-radius:6px;margin:1rem 0;font-size:.875rem}.institution-details div{margin:.5rem 0}.delete-confirm{background:#ef4444!important}.delete-confirm:hover{background:#dc2626!important}.admin-platform *{box-sizing:border-box}.admin-platform{position:relative;z-index:1}.admin-platform .App{max-width:none!important;width:100%!important;margin:0!important;padding:0!important}@media (max-width: 768px){.admin-header{flex-direction:column;gap:1rem;padding:1rem}.admin-navigation{gap:.5rem;justify-content:center;flex-wrap:wrap}.admin-navigation .nav-link{padding:.5rem .75rem;font-size:.8rem}.admin-main{padding:1rem;max-width:none!important}.dashboard-stats,.dashboard-grid{grid-template-columns:1fr;gap:1rem}.admin-dashboard h2{font-size:1.5rem}.stat-value{font-size:2rem}.view-header{flex-direction:column;gap:1rem;align-items:flex-start}.institutions-table-container,.users-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.form-row{grid-template-columns:1fr}}.institution-platform{min-height:100vh;background:var(--institution-bg-secondary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.institution-header{background:var(--institution-gradient);color:var(--institution-text-on-primary);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--institution-shadow-md)}.institution-brand{display:flex;align-items:center;gap:1rem}.institution-brand .institution-logo{height:40px;width:auto;filter:brightness(0) invert(1)}.institution-nav h1{margin:0;font-size:1.5rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.institution-navigation{display:flex;gap:1.5rem;margin-top:.5rem;flex-wrap:wrap}.institution-navigation .nav-link{color:#ffffffe6;text-decoration:none;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;font-weight:500;font-size:.9rem}.institution-navigation .nav-link:hover{background:#ffffff26;color:#fff;transform:translateY(-1px)}.institution-user-info{display:flex;align-items:center;gap:1rem}.institution-badge{background:#fff3;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;letter-spacing:.05em;border:1px solid rgba(255,255,255,.3)}.logout-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:500}.logout-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.institution-main{max-width:1400px;margin:0 auto;padding:2rem}.institution-dashboard h2{margin-bottom:2rem;color:var(--institution-text-primary);font-size:2rem;font-weight:600}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:var(--institution-bg-primary);border-radius:12px;padding:1.5rem;box-shadow:var(--institution-shadow-sm);border:1px solid var(--institution-border-light);transition:all .2s ease}.stat-card:hover{box-shadow:var(--institution-shadow-md);transform:translateY(-2px)}.stat-card h3{margin:0 0 1rem;color:var(--institution-text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:2.5rem;font-weight:700;color:var(--institution-primary-color);line-height:1;margin-bottom:.5rem}.stat-label{color:var(--institution-text-secondary);font-size:.875rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.dashboard-card{background:var(--institution-bg-primary);border-radius:12px;padding:1.5rem;box-shadow:var(--institution-shadow-sm);border:1px solid var(--institution-border-light);transition:all .2s ease}.dashboard-card:hover{box-shadow:var(--institution-shadow-md);transform:translateY(-2px)}.dashboard-card h3{margin:0 0 .5rem;color:var(--institution-primary-color);font-size:1.25rem;font-weight:600}.dashboard-card p{margin:0 0 1.5rem;color:var(--institution-text-secondary);line-height:1.5}.card-action{display:inline-block;background:var(--institution-primary-color);color:var(--institution-text-on-primary);text-decoration:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;transition:all .2s ease}.card-action:hover{background:var(--institution-primary-hover);transform:translateY(-1px)}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.view-header h2{margin:0;color:var(--institution-text-primary);font-size:2rem;font-weight:600}.view-actions{display:flex;gap:1rem}.primary-btn{background:var(--institution-primary-color);color:var(--institution-text-on-primary);border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.primary-btn:hover{background:var(--institution-primary-hover);transform:translateY(-1px);box-shadow:var(--institution-shadow-md)}.secondary-btn{background:var(--institution-bg-primary);color:var(--institution-primary-color);border:1px solid var(--institution-primary-color);padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.secondary-btn:hover{background:var(--institution-bg-tertiary);transform:translateY(-1px)}.coming-soon-large{background:var(--institution-bg-primary);border-radius:12px;padding:2rem;box-shadow:var(--institution-shadow-sm);border:1px solid var(--institution-border-light);margin-top:2rem}.coming-soon-large h3{margin:0 0 1rem;color:var(--institution-primary-color);font-size:1.25rem;font-weight:600}.coming-soon-large ul{margin:0 0 1.5rem;padding-left:1.5rem;color:var(--institution-text-secondary)}.coming-soon-large li{margin-bottom:.5rem;line-height:1.5}.coming-soon-large p{margin:0;color:var(--institution-primary-color);font-weight:600}.print-orders-view h2,.gcode-library-view h2,.billing-view h2,.users-view h2,.settings-view h2{margin-bottom:1rem;color:var(--institution-text-primary);font-size:2rem;font-weight:600}@media (max-width: 768px){.institution-header{flex-direction:column;gap:1rem}.institution-navigation{gap:.5rem}.institution-navigation .nav-link{padding:.5rem;font-size:.8rem}.institution-main{padding:1rem}.dashboard-stats,.dashboard-grid{grid-template-columns:1fr}.institution-dashboard h2{font-size:1.5rem}.stat-value{font-size:2rem}.view-header{flex-direction:column;gap:1rem;align-items:flex-start}.view-actions{width:100%;justify-content:flex-end}}
