code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-page{align-items:center;background:linear-gradient(135deg,#1a1a2e,#3f007d);display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.background-grid{animation:gridMove 20s linear infinite;background-image:linear-gradient(#5400cb1a 1px,#0000 0),linear-gradient(90deg,#5400cb1a 1px,#0000 0);background-size:50px 50px;height:100%;left:0;position:absolute;top:0;width:100%}@keyframes gridMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.floating-orbs{height:100%;overflow:hidden;position:absolute;width:100%}.orb{animation:float 8s ease-in-out infinite;background:radial-gradient(circle,#8000ff4d,#5400cb1a);border-radius:50%;filter:blur(1px);position:absolute}.orb:first-child{animation-delay:0s;height:300px;right:-150px;top:-150px;width:300px}.orb:nth-child(2){animation-delay:3s;bottom:-100px;height:200px;left:-100px;width:200px}.orb:nth-child(3){animation-delay:6s;height:150px;left:20%;top:30%;width:150px}@keyframes float{0%,to{opacity:.6;transform:translateY(0) rotate(0deg)}33%{opacity:.8;transform:translateY(-30px) rotate(120deg)}66%{opacity:.4;transform:translateY(30px) rotate(240deg)}}.login-container{animation:slideIn 1s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1a2ee6;border:1px solid #5400cb4d;border-radius:24px;box-shadow:0 25px 50px #1a1a2ecc,0 0 0 1px #8000ff33,inset 0 1px 0 #ffffff1a;max-width:450px;padding:2.5rem;position:relative;width:100%;z-index:10}@keyframes slideIn{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.header-section{margin-bottom:2.5rem;text-align:center}.login-logo{display:block;height:64px;margin:0 auto 1.5rem;width:auto}.welcome-title{color:#eaeaea;font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}.welcome-subtitle{color:#8f8f8f;font-size:1rem;font-weight:400;line-height:1.5}.form-group{margin-bottom:1.8rem;position:relative}.form-label{color:#eaeaea;display:block;font-size:.9rem;font-weight:600;letter-spacing:.01em;margin-bottom:.8rem}.input-wrapper{position:relative}.form-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a2ecc;border:2px solid #5400cb4d;border-radius:16px;box-sizing:border-box;color:#eaeaea;font-size:1rem;outline:none;padding:1.2rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.form-input::placeholder{color:#8f8f8f}.form-input:focus{background:#1a1a2ef2;border-color:#5400cb;box-shadow:0 0 0 3px #5400cb33,0 8px 25px #5400cb26;transform:translateY(-2px)}.input-icon{color:#8f8f8f;position:absolute;right:1.2rem;top:50%;transform:translateY(-50%);transition:color .3s ease}.form-input:focus+.input-icon{color:#5400cb}.form-options{align-items:center;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:2rem}.checkbox-wrapper{align-items:center;color:#eaeaea;cursor:pointer;display:flex;gap:.8rem;-webkit-user-select:none;user-select:none}.custom-checkbox{background:#0000;border:2px solid #5400cb80;border-radius:6px;height:20px;position:relative;transition:all .3s ease;width:20px}.checkbox-wrapper input[type=checkbox]{display:none}.checkbox-wrapper input[type=checkbox]:checked+.custom-checkbox{background:linear-gradient(135deg,#5400cb,#8000ff);border-color:#5400cb}.checkbox-wrapper input[type=checkbox]:checked+.custom-checkbox:after{color:#fff;content:"✓";font-size:.8rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.forgot-link{color:#5400cb;font-weight:600;position:relative;text-decoration:none;transition:all .3s ease}.forgot-link:hover{color:#8000ff}.forgot-link:after{background:linear-gradient(90deg,#5400cb,#8000ff);bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.forgot-link:hover:after{width:100%}.login-button{background:linear-gradient(135deg,#5400cb,#8000ff);border-radius:16px;box-shadow:0 8px 20px #5400cb66;font-size:1.1rem;font-weight:700;overflow:hidden;padding:1.2rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.login-button:hover:not(:disabled){box-shadow:0 12px 30px #5400cb99;transform:translateY(-3px)}.login-button:active:not(:disabled){transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.7}.login-button:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s;width:100%}.login-button:hover:not(:disabled):before{left:100%}.divider{align-items:center;color:#8f8f8f;display:flex;font-size:.9rem;margin:2.5rem 0}.divider:after,.divider:before{background:linear-gradient(90deg,#0000,#5400cb4d,#0000);content:"";flex:1 1;height:1px}.divider span{font-weight:500;padding:0 1.5rem}.social-login{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.social-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a2e99;border:2px solid #5400cb33;border-radius:16px;color:#eaeaea;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.8rem;justify-content:center;padding:1rem;transition:all .3s ease}.social-button:hover:not(:disabled){background:#5400cb1a;border-color:#5400cb;box-shadow:0 6px 20px #5400cb33;transform:translateY(-2px)}.social-button:disabled{cursor:not-allowed;opacity:.7}.social-icon{align-items:center;background:linear-gradient(135deg,#5400cb,#8000ff);border-radius:50%;color:#fff;display:flex;font-size:.8rem;height:24px;justify-content:center;width:24px}.signup-section{color:#8f8f8f;font-size:.95rem;text-align:center}.signup-link{color:#5400cb;font-weight:700;margin-left:.5rem;text-decoration:none;transition:color .3s ease}.signup-link:hover{color:#8000ff}@keyframes slideInNotification{0%{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutNotification{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100px)}}@media (max-width:768px){.login-container{margin:1rem;max-width:380px;padding:2rem}.welcome-title{font-size:1.8rem}.social-login{grid-template-columns:1fr}}@media (max-width:480px){.login-container{padding:1.5rem}.welcome-title{font-size:1.6rem}}.project-card{background:#5400cb1a;border:1px solid #3f007d;border-radius:12px;display:flex;flex-direction:column;gap:10px;height:352px;padding:14px;position:relative;transition:all .3s ease}.project-card:hover{border-color:#5400cb;box-shadow:0 8px 25px #5400cb33;transform:translateY(-3px)}.project-visual-area{border:none;border-radius:8px;height:240px;padding:2px;position:relative}.project-board-thumb,.project-visual-area{align-items:center;background:#0000;display:flex;justify-content:center;overflow:hidden}.project-board-thumb{border-radius:6px;height:100%;width:100%}.project-board-thumb img{height:100%;object-fit:contain;transform-origin:center center;transition:transform .2s ease;width:100%}.project-board-thumb-fallback{color:#eaeaea;font-size:1.8rem;font-weight:700}.project-info{display:flex;flex-direction:column;gap:3px;min-width:0}.project-info h3{-webkit-line-clamp:1;-webkit-box-orient:vertical;color:#eaeaea;display:-webkit-box;font-size:.92rem;line-height:1.25;margin:0;overflow:hidden;word-break:break-word}.project-description-overlay{background:linear-gradient(180deg,#06060a00,#06060aeb 58%);bottom:0;left:0;opacity:0;padding:10px 12px;position:absolute;right:0;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease}.project-description-overlay.visible{opacity:1;transform:translateY(0)}.project-description-label{color:#b4a8c9;display:block;font-size:.68rem;letter-spacing:.06em;margin-bottom:4px;text-transform:uppercase}.project-description-text{-webkit-line-clamp:3;color:#dcd6eb;font-size:.78rem;line-height:1.3;margin:0}.project-board,.project-description-text{-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden;word-break:break-word}.project-board{-webkit-line-clamp:1;color:#8f8f8f;font-family:monospace;font-size:.75rem;line-height:1.25}.project-actions{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-top:auto}.project-last-make{color:#8f8f8f;font-size:.74rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-btn{border:none;border-radius:5px;cursor:pointer;display:inline-block;font-size:.76rem;min-width:96px;padding:8px 12px;text-align:center;text-decoration:none;transition:all .3s ease}.btn-secondary{background:#5400cb33;border:1px solid #5400cb;color:#eaeaea}.btn-tertiary{background:#3f007d33;border:1px solid #3f007d;color:#eaeaea}.action-btn:hover{box-shadow:0 4px 15px #5400cb33;transform:translateY(-2px)}.delete-btn-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#8f8f8f4d;border:1px solid #8f8f8f80;border-radius:50%;color:#8f8f8f;cursor:pointer;display:flex;font-size:14px;font-weight:400;height:24px;justify-content:center;opacity:.7;position:absolute;right:8px;top:8px;transition:all .2s ease;width:24px;z-index:10}.delete-btn-overlay:hover{background:#5400cb33;border-color:#5400cb;color:#eaeaea;opacity:1;transform:scale(1.05)}.delete-btn-overlay:active{background:#5400cb4d;transform:scale(.95)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:fadeIn .3s ease-in-out;background:#1a1a2e;border:1px solid #3f007d;border-radius:12px;box-shadow:0 8px 32px 0 #0000005e;max-width:500px;padding:30px;position:relative;width:90%}.modal-content h2{color:#eaeaea;font-size:1.5rem;margin-bottom:25px;text-align:center}.modal-close-btn{background:#0000;border:none;color:#8f8f8f;cursor:pointer;font-size:1.5rem;position:absolute;right:15px;top:15px;transition:color .3s ease}.modal-close-btn:hover{color:#eaeaea}.form-group{margin-bottom:20px}.form-group label{color:#8f8f8f;display:block;font-size:.9rem;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{background:#ffffff0d;border:1px solid #3f007d;border-radius:6px;box-sizing:border-box;color:#eaeaea;font-size:1rem;padding:12px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.form-group textarea{font-family:inherit;min-height:80px;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#5400cb;box-shadow:0 0 0 2px #5400cb80;outline:none}.form-group select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238F8F8F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:1em}.board-select{position:relative}.board-select-trigger{align-items:center;background:#ffffff0d;border:1px solid #3f007d;border-radius:6px;color:#eaeaea;cursor:pointer;display:flex;font-size:1rem;gap:12px;justify-content:space-between;padding:10px 12px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.board-select-trigger:focus{border-color:#5400cb;box-shadow:0 0 0 2px #5400cb80;outline:none}.board-select-placeholder{color:#8f8f8f}.board-select-thumb{align-items:center;background:#00000059;border-radius:8px;display:flex;flex-shrink:0;height:48px;justify-content:center;overflow:hidden;width:48px}.board-select-thumb img{height:100%;object-fit:contain;width:100%}.board-select-fallback{color:#eaeaea;font-weight:600}.board-select-label{flex:1 1;text-align:left}.board-select-caret{color:#8f8f8f;font-size:.8rem;transition:transform .2s ease}.board-select-caret.open{transform:rotate(180deg)}.board-select-dropdown{background:#141423;border:1px solid #3f007d;border-radius:10px;box-shadow:0 8px 24px #00000073;left:0;max-height:260px;overflow-y:auto;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:10}.board-select-option{align-items:center;background:#0000;border:none;border-radius:8px;color:#eaeaea;cursor:pointer;display:flex;gap:12px;padding:8px;transition:background .2s ease;width:100%}.board-select-option:hover{background:#5400cb26}.board-select-option.selected{background:#5400cb4d}.board-select-empty{color:#8f8f8f;font-size:.9rem;padding:12px;text-align:center}.error-message{background:#ff4d4d1a;border:1px solid #ff4d4d;border-radius:6px;color:#ff4d4d;margin-bottom:20px;padding:10px;text-align:center}.modal-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px}.btn{font-weight:500;padding:12px 24px;transition:all .3s ease}.btn-primary{background:linear-gradient(45deg,#5400cb,#8000ff)}.btn-primary:hover{box-shadow:0 4px 15px #5400cb4d;transform:translateY(-2px)}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.btn-secondary{background:#0000;border:1px solid #3f007d;color:#8f8f8f}.btn-secondary:hover{background:#3f007d;color:#eaeaea}.advanced-toggle{margin-bottom:16px}.advanced-toggle-btn{align-items:center;background:#0000;border:none;color:#8f8f8f;cursor:pointer;display:flex;font-size:.9rem;gap:8px;padding:8px 0;transition:color .2s ease}.advanced-toggle-btn:hover{color:#eaeaea}.advanced-toggle-icon{display:inline-block;font-size:.7rem;transition:transform .2s ease}.advanced-toggle-icon.expanded{transform:rotate(90deg)}.advanced-options{animation:slideDown .2s ease-out;background:#ffffff05;border:1px solid #3f007d80;border-radius:8px;margin-bottom:16px;padding:16px}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.form-row{display:flex;gap:16px}.form-group-half{flex:1 1;margin-bottom:0}.confirm-delete-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.confirm-delete-dialog{background:#1a1a1a;border:1px solid #3f007d;border-radius:12px;box-shadow:0 20px 40px #00000080;max-width:500px;padding:30px;width:90%}.confirm-delete-header h3{color:#eaeaea;font-size:1.4rem;margin:0 0 20px;text-align:center}.confirm-delete-content p{color:#eaeaea;line-height:1.6;margin-bottom:15px;text-align:center}.confirm-delete-content strong{color:#5400cb}.warning-text{color:#ff6b6b!important;font-size:.9rem;font-style:italic}.confirm-delete-actions{display:flex;gap:15px;justify-content:center;margin-top:25px}.cancel-btn,.delete-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:12px 24px;transition:all .3s ease}.cancel-btn{background:#5400cb33;border:1px solid #5400cb;color:#eaeaea}.cancel-btn:hover:not(:disabled){background:#5400cb4d;transform:translateY(-2px)}.delete-btn{background:#ff6b6bcc;border:1px solid #ff6b6b80;color:#fff}.delete-btn:hover:not(:disabled){background:#ff6b6b;border-color:#ff6b6bcc;box-shadow:0 4px 15px #ff6b6b33;transform:translateY(-2px)}.cancel-btn:disabled,.delete-btn:disabled{cursor:not-allowed;opacity:.6}.app-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-primary);color:var(--text-primary);justify-content:space-between;padding:1rem 2rem}.app-header,.header-logo{align-items:center;display:flex}.header-logo-img{display:block;height:36px;width:auto}.header-user-menu{align-items:center;display:flex;gap:1rem}.profile-entry{align-items:center;background:#0000;border:1px solid #0000;border-radius:999px;color:var(--text-primary);display:inline-flex;gap:.55rem;padding:.2rem .35rem .2rem .2rem}.profile-entry:not(:disabled){cursor:pointer}.profile-entry:not(:disabled):hover{background:#5400cb1f;border-color:var(--border-secondary)}.profile-entry:disabled{opacity:1}.user-avatar{border:2px solid var(--primary-light)}.user-name{font-weight:500}.lang-toggle-button{align-items:center;background-color:initial;border:1px solid var(--border-secondary);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:.15rem;letter-spacing:.02em;padding:.35rem .6rem;transition:all .2s ease-in-out}.lang-toggle-button:hover{border-color:var(--primary-color);color:var(--text-primary)}.lang-option{opacity:.5;transition:opacity .2s}.lang-option.lang-active{color:var(--primary-light);font-weight:700;opacity:1}.lang-sep{margin:0 .1rem;opacity:.4}.logout-button{background-color:initial;border:1px solid var(--border-secondary);border-radius:8px;color:var(--text-secondary);cursor:pointer;padding:.5rem 1rem;transition:all .2s ease-in-out}.logout-button:hover{background-color:var(--primary-color);border-color:var(--primary-color);color:var(--text-primary)}.wechat-contact{position:relative}.wechat-contact-btn{align-items:center;background:#0000;border:1px solid var(--border-secondary);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;padding:.35rem .7rem;transition:all .2s}.wechat-contact-btn:hover{border-color:#07c160;color:var(--text-primary)}.wechat-icon{border-radius:3px;height:18px;width:18px}.wechat-qr-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;min-width:200px;padding:16px;position:absolute;right:0;text-align:center;top:calc(100% + 10px);z-index:1000}.wechat-qr-title{color:#333;font-size:13px;font-weight:600;margin-bottom:10px}.wechat-qr-img{border-radius:8px;height:180px;width:180px}.project-list-container{margin:0 auto;max-width:1200px;padding:20px}.project-list-main{padding-top:20px}.project-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.project-list-header h1{color:#eaeaea;font-size:2rem}.header-buttons{display:flex;gap:1rem}.add-device-btn{background-color:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .2s ease-in-out}.add-device-btn:hover{background-color:#218838}.manual-flash-btn{align-items:center;background:#5400cb33;border:1px solid #5400cb;border-radius:8px;color:#eaeaea;display:inline-flex;font-size:1rem;font-weight:600;justify-content:center;padding:.75rem 1.25rem;text-decoration:none;transition:all .2s ease-in-out}.manual-flash-btn:hover{background:#5400cb59;transform:translateY(-1px)}.project-grid{grid-gap:1.6rem;display:grid;gap:1.6rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.error-state,.loading-state{align-items:center;color:#8f8f8f;display:flex;flex-direction:column;justify-content:center;min-height:50vh;text-align:center}.error-state h2{color:#eaeaea;margin-bottom:10px}.loading-container{align-items:center;color:#a0a0c0;display:flex;flex-direction:column;height:60vh;justify-content:center}.spinner{animation:spin 1s ease infinite;border:4px solid #fff3;border-left-color:#6a82fb;border-radius:50%;height:36px;margin-bottom:20px;width:36px}.empty-state-container{align-items:center;color:#8f8f8f;display:flex;flex-direction:column;justify-content:center;min-height:60vh;text-align:center}.empty-state-content{max-width:400px}.empty-state-icon{color:#5400cb;margin-bottom:20px}.empty-state-content h2{color:#eaeaea;font-size:1.5rem;margin-bottom:15px}.empty-state-content p{line-height:1.6;margin-bottom:25px}.programming-layout{color:#f5f5f7;color:var(--text-primary,#f5f5f7);font-family:Inter,Segoe UI,sans-serif}.programming-empty,.programming-layout{background-color:#0f1018;background-color:var(--bg-primary,#0f1018);display:flex;min-height:100vh}.programming-empty{align-items:center;color:#a1a6b3;color:var(--text-secondary,#a1a6b3);flex-direction:column;gap:.5rem;justify-content:center;text-align:center}.programming-empty h2{color:#f5f5f7;color:var(--text-primary,#f5f5f7);margin-bottom:.25rem}.chat-column{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(180deg,#181e2cf2,#10131ef2);border-right:1px solid #ffffff14;border-right:1px solid var(--border-secondary,#ffffff14);display:flex;flex-direction:column;height:100vh;max-width:100%;overflow:hidden;width:calc(420px + 2vw)}.canvas-column{background-color:#151926;background-color:var(--bg-surface,#151926);display:flex;flex:1 1;flex-direction:column}.canvas-body{background-color:#0f1018;background-color:var(--bg-primary,#0f1018);flex:1 1;overflow:hidden;position:relative}.canvas-pane{display:none;inset:0;position:absolute}.canvas-pane.is-active{display:block}.chat-panel{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow:hidden;padding:16px 14px 16px 10px;width:100%}.chat-header-toolbar{align-items:center;background:#14182499;border:1px solid #ffffff0f;border-radius:10px;display:flex;gap:6px;padding:8px}.toolbar-divider{background:#ffffff1a;height:24px;margin:0 4px;width:1px}.toolbar-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#a1a6b3;color:var(--text-secondary,#a1a6b3);cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:500;gap:5px;height:32px;padding:0 10px;transition:all .15s ease;white-space:nowrap}.toolbar-btn svg{flex-shrink:0;height:16px;width:16px}.toolbar-btn:hover{background:#ffffff14;color:#fff;color:var(--text-primary,#fff)}.toolbar-btn:active{transform:scale(.97)}.toolbar-btn:disabled{cursor:not-allowed;filter:grayscale(.35);opacity:.45}.toolbar-btn:disabled:hover{background:#0000;color:#a1a6b3;color:var(--text-secondary,#a1a6b3)}.toolbar-btn--home{background:#6366f11a;border:1px solid #6366f133;color:#a5b4fc}.toolbar-btn--home:hover{background:#6366f133;border-color:#6366f166;color:#c7d2fe}.toolbar-btn--advanced{background:#ec48991a;border:1px solid #ec489940;color:#f9a8d4}.toolbar-btn--advanced:hover{background:#ec489933;border-color:#ec489973;color:#fbcfe8}.toolbar-btn--advanced.is-active{background:#ec48993d;border-color:#ec48998c;color:#fdf2f8}.toolbar-btn--download{background:#22c55e1a;border:1px solid #22c55e33;color:#86efac}.toolbar-btn--download:hover{background:#22c55e33;border-color:#22c55e66;color:#bbf7d0}.toolbar-btn--flash{background:#fbbf241a;border:1px solid #fbbf2433;color:#fcd34d}.toolbar-btn--flash:hover{background:#fbbf2433;border-color:#fbbf2466;color:#fde68a}.flash-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#06080fd1;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.flash-modal{background:linear-gradient(180deg,#141726,#0e111d);border:1px solid #ffffff14;border-radius:18px;box-shadow:0 30px 60px #050814a6;color:#fff;color:var(--text-primary,#fff);width:min(520px,90%)}.flash-modal__header{align-items:center;display:flex;justify-content:space-between;padding:20px 24px 0}.flash-modal__close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.5rem}.flash-modal__body{display:flex;flex-direction:column;gap:16px;padding:0 24px 24px}.flash-modal__section{background:#ffffff05;border:1px solid #ffffff0d;border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px}.flash-modal__actions{display:flex;gap:12px;justify-content:flex-end}.flash-modal__error{color:#ff9fac}.flash-modal__logs{display:flex;flex-direction:column;gap:8px}.flash-modal__log-window{background:#00000059;border:1px solid #ffffff0d;border-radius:10px;font-family:JetBrains Mono,monospace;font-size:.8rem;max-height:160px;overflow-y:auto;padding:10px}.flash-modal__log-line{color:#dde2ff;opacity:.85}.flash-progress{align-items:center;display:flex;gap:10px}.flash-progress__track{background:#ffffff14;border-radius:999px;flex:1 1;height:8px;overflow:hidden}.flash-progress__fill{background:linear-gradient(135deg,#68f0c2,#43c6ac);height:100%;transition:width .2s ease}.chat-action-alert{align-items:center;border:1px solid #0000;border-radius:10px;display:flex;font-size:.8rem;gap:10px;justify-content:space-between;margin-bottom:4px;margin-top:-4px;padding:8px 12px}.chat-action-alert button{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0 4px}.chat-action-alert--success{background:#40d6ab26;border-color:#40d6ab66;color:#d2fff2}.chat-action-alert--error{background:#ff698726;border-color:#ff698759;color:#ffd0db}.switch{display:inline-block;height:24px;position:relative;width:48px}.switch input{height:0;opacity:0;width:0}.switch .slider{background-color:#787e9b4d;border-radius:34px;cursor:pointer;inset:0;position:absolute;transition:.3s ease}.switch .slider:before{background-color:#fff;border-radius:50%;bottom:3px;box-shadow:0 2px 6px #0f121c73;content:"";height:18px;left:4px;position:absolute;transition:.3s ease;width:18px}.switch input:checked+.slider{background:linear-gradient(135deg,#6a5eff,#9250ff)}.switch input:checked+.slider:before{transform:translateX(22px)}.mode-label{color:#9aa1b5;color:var(--text-secondary,#9aa1b5);font-size:.85rem;font-weight:500}.error-banner{align-items:center;background:#ff4d6d1f;border:1px solid #ff4d6d59;border-radius:10px;color:#ffadc2;display:flex;font-size:.9rem;justify-content:space-between;padding:12px 16px}.error-banner button{background:none;border:none;border-radius:6px;color:inherit;cursor:pointer;font-size:.85rem;padding:4px 8px;transition:background .2s ease}.error-banner button:hover{background:#ffffff14}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding-right:6px;scrollbar-color:#ffffff1a #0000;scrollbar-width:thin}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:8px}.history-loader{background:linear-gradient(180deg,#0e111af2,#0e111a00);display:flex;justify-content:center;padding:12px 0 4px;position:-webkit-sticky;position:sticky;top:-12px;z-index:2}.history-loader__button{background:#7483ff26;border:1px solid #7483ff73;border-radius:999px;color:#dee4ff;cursor:pointer;font-size:.78rem;letter-spacing:.03em;padding:6px 18px;text-transform:uppercase;transition:all .2s ease}.history-loader__button:hover{background:#7483ff40;box-shadow:0 4px 16px #5460c440;transform:translateY(-1px)}.history-loader__status{color:#a6adc4;color:var(--text-secondary,#a6adc4);font-size:.78rem;padding:4px 8px}.history-loader__status--muted{font-style:italic;opacity:.75}.chat-line{align-items:flex-start;display:flex;gap:12px}.chat-line.user{flex-direction:row-reverse}.avatar{align-items:center;background:linear-gradient(135deg,#5e6bff,#8d45ff);border-radius:50%;box-shadow:0 6px 16px #505aff40;color:#fff;display:flex;font-weight:600;height:36px;justify-content:center;width:36px}.chat-line.user .avatar{background:linear-gradient(135deg,#1ec7ff,#4f7aff)}.bubble{background:#ffffff0f;border:1px solid #ffffff0f;border-radius:14px;display:flex;flex-direction:column;gap:8px;max-width:80%;padding:12px 14px}.chat-line.user .bubble{background:linear-gradient(135deg,#299eff33,#745cff40);border:1px solid #648aff59}.bubble-content{color:#f5f5f7;color:var(--text-primary,#f5f5f7);font-size:.95rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.bubble-meta{align-self:flex-end;color:#7c8299;color:var(--text-tertiary,#7c8299);font-size:.75rem;letter-spacing:.02em}.bubble.loading{align-items:center;background:#ffffff08}.loading-dots{display:flex;gap:6px}.loading-dots span{animation:chat-dot 1.2s ease-in-out infinite;background:linear-gradient(135deg,#6f7bff,#9c58ff);border-radius:50%;height:8px;width:8px}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}@keyframes chat-dot{0%,80%,to{opacity:.2;transform:translateY(2px)}40%{opacity:1;transform:translateY(-2px)}}.progress-card{background:#202637b3;border:1px solid #6670ff40;border-radius:14px;box-shadow:0 12px 24px #1e284b40;display:flex;flex-direction:column;gap:12px;padding:16px}.progress-header{align-items:center;display:flex;justify-content:space-between}.progress-header h3{color:#fff;color:var(--text-primary,#fff);font-size:1rem;margin:0}.status-tag{background:#6c79ff33;border:1px solid #6c79ff59;border-radius:999px;color:#dfe3ff;font-size:.75rem;letter-spacing:.08em;padding:4px 10px;text-transform:uppercase}.status-tag.status-cancelled,.status-tag.status-failed{background:#ff5e7a26;border-color:#ff5e7a59;color:#ffcbd2}.progress-body{display:flex;flex-direction:column;gap:10px}.progress-row{color:#b0b6cc;color:var(--text-secondary,#b0b6cc);display:flex;font-size:.9rem;justify-content:space-between}.progress-row .label{color:#8c92a8;color:var(--text-tertiary,#8c92a8)}.progress-row .value{color:#fff;color:var(--text-primary,#fff);font-weight:500}.progress-bar-row{align-items:center;display:flex;gap:12px}.progress-bar{background:#818bdf33;border-radius:999px;flex:1 1;height:8px;overflow:hidden;position:relative}.progress-bar-fill{background:linear-gradient(135deg,#5f6bff,#9778ff);border-radius:999px;bottom:0;left:0;position:absolute;top:0;transition:width .3s ease}.progress-logs{border-top:1px solid #ffffff0f;padding-top:12px}.progress-logs h4{color:#bfc4d8;color:var(--text-secondary,#bfc4d8);font-size:.85rem;letter-spacing:.08em;margin:0 0 8px;text-transform:uppercase}.progress-logs ul{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.progress-logs li{color:#b0b6cc;color:var(--text-secondary,#b0b6cc);display:flex;font-size:.8rem;gap:8px}.progress-logs .log-time{color:#8d93aa;color:var(--text-tertiary,#8d93aa);font-family:JetBrains Mono,monospace}.progress-logs .log-message{color:#fff;color:var(--text-primary,#fff)}.chat-input-bar{align-items:flex-end;background:#1b202dd9;border:1px solid #ffffff14;border-radius:14px;display:flex;gap:12px;padding:14px}.chat-input-bar textarea{background:#0f111abf;border:none;border-radius:12px;box-shadow:inset 0 0 0 1px #727ead26;color:#fff;color:var(--text-primary,#fff);flex:1 1;font-size:.95rem;line-height:1.5;max-height:160px;min-height:72px;padding:12px;resize:none}.chat-input-bar textarea:focus{box-shadow:inset 0 0 0 1px #7684f799,0 0 0 3px #586cff40;outline:none}.chat-input-bar textarea::placeholder{color:#8a90a5;color:var(--text-tertiary,#8a90a5)}.chat-input-bar button{background:linear-gradient(135deg,#625bff,#9b54ff);border:none;border-radius:12px;box-shadow:0 12px 22px #5852ff40;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;min-width:96px;padding:12px 16px;transition:transform .15s ease,box-shadow .15s ease,opacity .2s ease}.chat-input-bar button:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.chat-input-bar button:not(:disabled):hover{box-shadow:0 14px 24px #605aff52;transform:translateY(-1px)}.chat-input-bar button:not(:disabled):active{transform:translateY(0)}.btn-secondary{background:#ffffff0a;border:1px solid #ffffff14;color:#a1a6b3;color:var(--text-secondary,#a1a6b3)}.btn-secondary:hover{background:#ffffff14}.btn-primary{background:linear-gradient(135deg,#655bff,#a052ff);box-shadow:0 12px 24px #5a50ff59}.btn-primary:hover{box-shadow:0 14px 26px #5a50ff6b;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}@media (max-width:1080px){.chat-column{max-width:none;width:100%}.programming-layout{flex-direction:column}.canvas-column{min-height:360px}.chat-panel{padding:20px}.chat-header-actions{justify-content:flex-start;width:100%}}.schematic-editor{display:flex;flex-direction:column;height:100%}.diagram-status{margin-top:8px}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:500;gap:4px;padding:4px 12px}.status-badge.loading{background:#ff98001a;border:1px solid #ff98004d;color:#ff9800}.status-badge.saving{background:#2196f31a;border:1px solid #2196f34d;color:#2196f3}.status-badge.saved{background:#4caf501a;border:1px solid #4caf504d;color:#4caf50}.add-module-dropdown-btn{align-items:center;background:#6366f126;border:1px solid #6366f14d;border-radius:6px;color:#a5b4fc;cursor:pointer;display:flex;font-size:1.2rem;font-weight:400;height:30px;justify-content:center;line-height:1;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .1s ease;width:30px}.add-module-dropdown-btn:hover{background:#6366f147;border-color:#6366f180;color:#c7d2fe}.add-module-dropdown-btn:active{background:#6366f166;border-color:#6366f199;color:#e0e7ff;transform:scale(.95)}.module-overlay-menu{background:#1b1b1b;border:1px solid #2b2b2b;border-radius:10px;box-shadow:0 10px 28px #00000073;left:0;max-height:70vh;overflow-y:auto;padding:10px;position:absolute;top:44px;width:320px;z-index:1000}.module-search{background:#111;border:1px solid #2f2f2f;border-radius:8px;color:#f2f2f2;font-size:.9rem;margin-bottom:10px;outline:none;padding:8px 10px;width:100%}.module-search:focus{border-color:#4d90fe}.module-category{margin-bottom:10px}.category-label{color:#9a9a9a;font-size:.75rem;font-weight:600;letter-spacing:.6px;padding:6px 8px 4px;text-transform:uppercase}.module-dropdown-item{align-items:center;background:#0000;border:none;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:8px;text-align:left;transition:all .2s;width:100%}.module-dropdown-item:hover{background:#2a2a2a;transform:translateX(2px)}.module-card{gap:12px;padding:8px 10px}.module-thumb{align-items:center;background:#111;border:1px solid #2b2b2b;border-radius:8px;display:inline-flex;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;width:40px}.module-thumb img{height:64px;object-fit:contain;width:64px}.module-thumb-placeholder{background:linear-gradient(135deg,#ffffff14,#ffffff05);border:1px dashed #ffffff26;border-radius:6px;height:24px;width:24px}.module-item-label{color:#f1f1f1;font-size:.9rem}.module-empty{color:#9a9a9a;font-size:.85rem;padding:10px 8px 4px}.schematic-body{box-sizing:border-box;height:calc(100% - 56px);padding:16px;position:relative}.schematic-canvas{background:repeating-linear-gradient(0deg,#5400cb0d,#5400cb0d 24px,#5400cb14 0,#5400cb14 25px),repeating-linear-gradient(90deg,#5400cb0d,#5400cb0d 24px,#5400cb14 0,#5400cb14 25px);background-color:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:16px;height:100%;overflow:hidden;position:relative;width:100%}.schematic-canvas-toolbar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f1018a6;border:1px solid #ffffff14;border-radius:10px;box-shadow:0 4px 16px #0000004d;display:flex;gap:6px;left:12px;padding:5px;position:absolute;top:12px;z-index:1100}.canvas-toggle-btn{background:#0000;border:1px solid #0000;border-radius:6px;color:#a1a6b3;color:var(--text-secondary,#a1a6b3);cursor:pointer;font-size:.8rem;font-weight:500;height:30px;padding:0 10px;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .1s ease}.canvas-toggle-btn:hover{background:#6366f126;border-color:#6366f159;color:#c7d2fe}.canvas-toggle-btn:active{background:#6366f14d;border-color:#6366f18c;color:#e0e7ff;transform:scale(.95)}.canvas-toggle-btn:disabled{background:#0000;border-color:#0000;color:#666;cursor:not-allowed;opacity:.4;transform:none}.schematic-canvas:focus{outline:2px solid var(--primary-color);outline-offset:2px}.connection-layer{height:100%;left:0;overflow:visible;pointer-events:none;position:absolute;top:0;width:100%;z-index:10}.connection-line{pointer-events:auto}.connection-line path{transition:stroke-width .2s ease}.connection-line path:hover{stroke-width:5px}.connection-segment-h{cursor:ns-resize!important}.connection-segment-v{cursor:ew-resize!important}.connection-endpoint{filter:drop-shadow(0 0 3px rgba(0,0,0,.45));pointer-events:none;transition:transform .15s ease}.connection-endpoint.selected{filter:drop-shadow(0 0 4px rgba(255,255,255,.5));transform:scale(1.15)}.module-instance{cursor:default;position:absolute;-webkit-user-select:none;user-select:none}.module-instance.selected{box-shadow:0 0 12px #5400cb59;outline:2px dashed #ffffffb3;outline-offset:4px}*{--wokwi-pin-cursor:crosshair}wokwi-esp32-devkit-v1::part(pin),wokwi-hc-sr04::part(pin),wokwi-lcd1602::part(pin),wokwi-ntc-temperature-sensor::part(pin){cursor:crosshair!important}.pin-hotspot{align-items:center;border:1px solid #0000;border-radius:50%;cursor:crosshair;display:flex;height:16px;justify-content:center;pointer-events:all;position:absolute;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease;width:16px;z-index:1000}.pin-dot{background:#0000;background:var(--pin-wire-color,#0000);border:none;border-radius:50%;height:6px;opacity:0;pointer-events:none;transition:transform .2s,background .2s,border-color .2s,opacity .2s;width:6px}.pin-hotspot.connected .pin-dot{background:var(--pin-wire-color);box-shadow:none;opacity:0}.pin-hotspot:hover .pin-dot{border:2px solid #ffffffd9;box-shadow:0 0 4px #fff9;height:10px;opacity:1;width:10px}.pin-hotspot.pin-selected .pin-dot{background:#4caf50cc;border-color:#4caf50eb;box-shadow:0 0 6px #4caf50d9;transform:scale(1.25)}.pin-label{background:#000000d9;border-radius:4px;color:#fff;font-size:.7rem;font-weight:500;left:50%;opacity:0;padding:3px 8px;pointer-events:none;position:absolute;top:-22px;transform:translateX(-50%);transition:opacity .2s,color .2s;white-space:nowrap;z-index:2000}.pin-hotspot:hover .pin-label{opacity:1}.json-editor-container{display:flex;flex:1 1;height:100%;width:100%}.wire-toolbar{animation:fadeIn .2s ease-out;background:#2b2b2b;border-radius:4px;box-shadow:0 4px 12px #0000004d;padding:6px;position:absolute}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.wire-toolbar-content{align-items:center;display:flex;gap:4px}.wire-toolbar .color-button{align-items:center;border:2px solid #fff3;border-radius:3px;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:28px;justify-content:center;padding:0;transition:all .2s ease;width:28px}.wire-toolbar .color-button:hover{border-color:#ffffff80;box-shadow:0 2px 8px #0000004d;transform:scale(1.1)}.wire-toolbar .color-button.color-swatch{font-size:0}.wire-toolbar .close-button,.wire-toolbar .delete-button{align-items:center;background:#d32f2f;border:none;border-radius:3px;color:#fff;cursor:pointer;display:flex;font-size:16px;height:28px;justify-content:center;margin-left:4px;padding:0;transition:all .2s ease;width:28px}.wire-toolbar .close-button{background:#666;font-size:18px;font-weight:700}.wire-toolbar .delete-button:hover{background:#f44336;transform:scale(1.1)}.wire-toolbar .close-button:hover{background:#888;transform:scale(1.1)}.connection-line{cursor:pointer;transition:stroke-width .2s ease}.connection-line:hover path{filter:brightness(1.2)}.save-status-indicator{align-items:center;border-radius:6px;box-shadow:0 2px 8px #00000026;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;position:fixed;right:20px;top:20px;transition:all .3s ease;z-index:1000}.status-saved{background-color:#f0f9ff;border:1px solid #bfdbfe;color:#1e40af}.status-saving{animation:pulse 1.5s ease-in-out infinite;background-color:#fef9e7;border:1px solid #fde68a;color:#d97706}.status-unsaved{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.status-text{-webkit-user-select:none;user-select:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width:768px){.save-status-indicator{font-size:12px;padding:6px 12px;right:10px;top:10px}}.serial-console-panel{display:none;flex-direction:column;height:100%}.serial-console-panel.is-active{display:flex}.serial-console-toolbar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f1018a6;border:1px solid #ffffff14;border-radius:10px;box-shadow:0 4px 16px #0000004d;display:flex;gap:6px;left:12px;padding:5px;position:absolute;top:12px;z-index:1100}.serial-btn{background:#00000059;border:1px solid #ffffff2e;border-radius:8px;color:#f2f2f2;cursor:pointer;font-size:.85rem;font-weight:600;height:36px;padding:0 12px;transition:all .2s}.serial-btn:hover{background:#0000008c}.serial-btn.primary{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.serial-console-body{flex:1 1;min-height:0;padding:56px 16px 16px}.serial-log{background:#080a10e6;border:1px solid #ffffff14;border-radius:12px;color:#e5e7eb;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.85rem;height:100%;min-height:0;overflow:auto;padding:12px}.serial-log-line{display:flex;gap:10px;line-height:1.4;white-space:pre-wrap}.serial-log-line.error{color:#ff9fac}.serial-log-time{color:#7c8299;color:var(--text-tertiary,#7c8299);flex-shrink:0;font-size:.8rem}.serial-log-message{color:#e5e7eb;color:var(--text-primary,#e5e7eb)}.serial-log-line.error .serial-log-message{color:#ff9fac}.serial-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#06080fd1;display:flex;inset:0;justify-content:center;position:absolute;z-index:1300}.serial-modal{background:linear-gradient(180deg,#141726,#0e111d);border:1px solid #ffffff14;border-radius:14px;box-shadow:0 30px 60px #050814a6;color:#fff;color:var(--text-primary,#fff);padding:16px;width:min(420px,90%)}.serial-modal-header{font-size:1rem;font-weight:600;margin-bottom:12px}.serial-modal-body{display:flex;flex-direction:column;gap:8px}.serial-modal-label{color:#b4bacb;font-size:.85rem}.serial-modal-select{background:#00000059;border:1px solid #ffffff1f;border-radius:8px;color:#f2f2f2;height:36px;padding:0 10px}.serial-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.serial-buffer-indicator{align-items:center;background:#00000040;border:1px solid #ffffff24;border-radius:7px;color:#bfc6dc;display:inline-flex;font-family:SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.75rem;height:28px;letter-spacing:.01em;margin-left:auto;padding:0 8px}.burn-page{background-color:var(--background-color);color:var(--text-color);display:flex;gap:1.5rem;height:calc(100vh - 60px);padding:1.5rem}.burn-controls{flex:0 0 380px}.burn-logs{flex:1 1 auto}.burn-logs,.card{display:flex;flex-direction:column}.card{background-color:var(--primary-bg);border-radius:8px;box-shadow:0 4px 12px #0000001a;height:100%;overflow:hidden}.card-header{border-bottom:1px solid var(--border-color);padding:1.5rem}.card-header h2{font-size:1.5rem;margin:0}.card-header p{color:var(--text-color-secondary);font-size:.9rem;margin:.25rem 0 0;word-break:break-all}.card-body{display:flex;flex-direction:column;font-family:Menlo,Monaco,Courier New,monospace;gap:1.5rem;padding:1.5rem}.control-group{gap:.75rem}.btn,.control-group label{font-size:1rem;font-weight:600}.btn{border:none;border-radius:6px;cursor:pointer;padding:.75rem 1.5rem;text-align:center;transition:all .2s ease-in-out}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-color-dark)}.btn-secondary{background-color:var(--secondary-bg);border:1px solid var(--border-color);color:var(--text-color)}.btn-secondary:hover:not(:disabled){background-color:var(--hover-bg)}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover:not(:disabled){background-color:#218838}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.firmware-input{display:none}.file-label{display:inline-block;flex-grow:1;overflow:hidden;padding:.75rem 1.5rem;text-overflow:ellipsis;white-space:nowrap}.file-list{display:flex;flex-direction:column;gap:.75rem;width:100%}.file-entry{align-items:center;display:flex;gap:.5rem}.address-input{background-color:var(--secondary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-family:Menlo,Monaco,Courier New,monospace;padding:.75rem;width:80px}.remove-btn{background:#0000;border:none;color:var(--text-color-secondary);cursor:pointer;font-size:1.5rem;font-weight:700;line-height:1;padding:0 .5rem}.remove-btn:hover{color:#dc3545;color:var(--danger-color,#dc3545)}.terminal{background-color:#1e1e1e;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #0000001a;color:#d4d4d4;flex-grow:1;font-family:Menlo,Monaco,Courier New,monospace;font-size:.9rem;overflow-y:auto;padding:1rem}.log-line{display:flex;gap:1rem;line-height:1.5}.log-time{color:#6a9955}.log-message{white-space:pre-wrap}.log-line.error .log-message{color:#f44747}.mode-selector{background-color:var(--secondary-bg);display:flex;padding:.5rem}.mode-btn{background-color:initial;border:1px solid #0000;border-radius:6px;color:var(--text-color-secondary);cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.75rem;transition:all .2s ease-in-out}.mode-btn.active{background-color:var(--primary-bg);border-color:var(--border-color);box-shadow:0 1px 3px #0000000d;color:var(--primary-color)}.baud-rate-select{background-color:var(--secondary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-size:1rem;padding:.75rem;width:100%}.logs-page{background:radial-gradient(circle at top left,#5400cb33,#0000 55%),radial-gradient(circle at bottom right,#1a1a2ee6,#0000 60%);min-height:100vh;padding:32px}.logs-header{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:24px}.logs-header h1{font-size:2rem;letter-spacing:.02em;margin:0}.logs-header p{color:var(--text-secondary);margin:6px 0 0}.logs-controls{grid-gap:16px;background:#00000040;border:1px solid var(--border-secondary);border-radius:12px;box-shadow:var(--shadow-card);display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px;padding:16px}.control-group{display:flex;flex-direction:column;gap:6px}.control-group label{color:var(--text-secondary);font-size:.8rem}.control-group input,.control-group select{background:#0006;border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:.9rem;padding:8px 10px}.control-group.toggles{gap:10px;justify-content:center}.control-group.toggles label{align-items:center;display:flex;font-size:.85rem;gap:8px}.control-group.action{justify-content:flex-end}.control-group button{background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;letter-spacing:.02em;padding:10px 12px}.control-group button:disabled{cursor:not-allowed;opacity:.6}.logs-error{background:#ff444426;border:1px solid #f446;border-radius:8px;color:#ff8b8b;margin-bottom:16px;padding:12px 16px}.logs-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:minmax(320px,420px) 1fr}.logs-timeline{display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 320px);overflow-y:auto;padding-right:8px}.log-item{background:#16213ebf;border:1px solid #5400cb59;border-radius:12px;color:var(--text-primary);cursor:pointer;padding:12px 14px;text-align:left;transition:border .2s ease,transform .2s ease}.log-item:hover{transform:translateY(-2px)}.log-item.active,.log-item:hover{border-color:var(--primary-light)}.log-item.active{box-shadow:0 0 0 1px #8000ff99}.log-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.log-source{background:#5400cb33;border-radius:6px;font-size:.75rem;letter-spacing:.12em;padding:2px 6px;text-transform:uppercase}.log-source.run_logs{background:#ffa80033;color:#fc6}.log-source.chat_messages{background:#00ff882e;color:#8fc}.log-source.llm_interactions{background:#06f3;color:#99c2ff}.log-time{color:var(--text-secondary);font-size:.75rem}.log-summary{font-size:.95rem;font-weight:600;margin-bottom:6px}.log-meta{color:var(--text-secondary);display:flex;font-size:.8rem;gap:10px}.log-run{color:#d7c8ff}.logs-empty{background:#0003;border:1px dashed var(--border-secondary);border-radius:12px;color:var(--text-secondary);padding:18px}.load-more{background:#0000;border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);cursor:pointer;padding:10px 12px}.logs-detail{background:#00000059;border:1px solid var(--border-secondary);border-radius:12px;max-height:calc(100vh - 320px);overflow-y:auto;padding:18px}.detail-header{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.detail-meta{color:var(--text-secondary);display:flex;font-size:.8rem;gap:12px}.detail-summary{font-size:1rem;font-weight:600;margin-bottom:12px}.detail-body pre{background:#0006;border:1px solid #5400cb4d;border-radius:8px;color:#cfc7ff;font-size:.8rem;padding:12px;white-space:pre-wrap;word-break:break-word}.detail-empty{color:var(--text-secondary);padding:12px}@media (max-width:1024px){.logs-content{grid-template-columns:1fr}.logs-detail,.logs-timeline{max-height:none}}.user-detail-container{margin:0 auto;max-width:1200px;padding:20px}.user-detail-main{grid-gap:1rem;display:grid;gap:1rem;padding-top:20px}.user-detail-toolbar{align-items:center;display:flex;justify-content:space-between}.back-btn{background:#0000;border:1px solid var(--border-secondary);border-radius:8px;color:var(--text-primary);cursor:pointer;padding:.5rem 1rem}.back-btn:hover{border-color:var(--primary-color);color:var(--primary-light)}.range-switch{display:flex;gap:8px}.range-switch button{background:#0000;border:1px solid var(--border-secondary);border-radius:999px;color:var(--text-secondary);cursor:pointer;padding:.4rem .8rem}.range-switch button.active{background:#8000ff26;border-color:var(--primary-light);color:var(--text-primary)}.user-detail-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:1rem}.profile-row{align-items:center;display:flex;gap:1rem}.profile-avatar{border:2px solid var(--primary-light);border-radius:50%;height:72px;object-fit:cover;width:72px}.profile-main h2{margin:0}.profile-main p{color:var(--text-secondary);margin:.3rem 0}.role-badge{border:1px solid var(--border-secondary);border-radius:999px;color:var(--text-secondary);font-size:.8rem;padding:.2rem .5rem}.points-box{margin-left:auto;text-align:right}.points-box span{color:var(--text-secondary);display:block;font-size:.9rem}.points-box strong{color:#ffd966;font-size:1.8rem}.curve-head{align-items:center;display:flex;gap:1rem;justify-content:space-between}.curve-head h3{margin:0}.curve-meta{color:var(--text-secondary);display:flex;font-size:.9rem;gap:1rem}.curve-wrap{margin-top:.8rem}.curve-svg{background:#ffffff05;border:1px solid var(--border-secondary);border-radius:10px;height:200px;width:100%}.curve-xlabels{color:var(--text-secondary);display:flex;font-size:.85rem;justify-content:space-between;margin-top:.4rem}.curve-svg rect{cursor:pointer;transition:fill .15s}.bar-tooltip{color:var(--text-secondary);font-size:.85rem;margin-top:.3rem;text-align:center}.bar-tooltip strong{color:var(--text-primary)}.curve-empty{color:var(--text-secondary);margin-top:.8rem}.ledger-table-wrap{margin-top:.8rem;overflow-x:auto}.ledger-table{border-collapse:collapse;min-width:760px;width:100%}.ledger-table td,.ledger-table th{border-bottom:1px solid #ffffff14;font-size:.9rem;padding:.55rem .45rem;text-align:left}.ledger-table th{color:var(--text-secondary);font-weight:600}.ledger-table .minus{color:#ff7b7b}.ledger-table .plus{color:#5be89b}@media (max-width:900px){.user-detail-toolbar{align-items:flex-start;flex-direction:column;gap:.75rem}.profile-row{flex-wrap:wrap}.points-box{margin-left:0;text-align:left}.curve-head{align-items:flex-start;flex-direction:column}}:root{--primary-color:#5400cb;--primary-dark:#3f007d;--primary-light:#8000ff;--bg-primary:#1a1a2e;--bg-secondary:#16213e;--bg-card:#5400cb1a;--text-primary:#eaeaea;--text-secondary:#8f8f8f;--text-accent:#5400cb;--status-online:#0f0;--status-offline:#8f8f8f;--status-error:#f44;--border-primary:#3f007d;--border-secondary:#5400cb4d;--shadow-card:0 8px 25px #5400cb33;--shadow-button:0 4px 15px #5400cb4d}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#1a1a2e;background-color:var(--bg-primary);color:#eaeaea;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.initial-loading{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);background:linear-gradient(135deg,var(--bg-primary),var(--bg-secondary));display:flex;flex-direction:column;height:100vh;justify-content:center}.loading-logo{animation:spin 1s linear infinite;border:4px solid #5400cb4d;border-top-color:#8000ff;border:4px solid var(--border-secondary);border-radius:50%;border-top-color:var(--primary-light);height:60px;margin-bottom:1.5rem;width:60px}.loading-text{color:#8f8f8f;color:var(--text-secondary);font-size:1.2rem}@keyframes spin{to{transform:rotate(1turn)}}.login-page-container{align-items:center;display:flex;justify-content:center;min-height:100vh}.login-box{background:#0003;border:1px solid #3f007d;border:1px solid var(--border-primary);border-radius:12px;padding:2.5rem;text-align:center}.login-title{font-size:2rem;margin-bottom:.5rem}.login-subtitle{color:#8f8f8f;color:var(--text-secondary);margin-bottom:2rem}.login-button{background:#5400cb;background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:.8rem 2.5rem;transition:background .3s}.login-button:hover{background:#6a1bdb}.container{margin:0 auto;max-width:1200px;padding:20px}.header{align-items:center;border-bottom:1px solid #3f007d;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;margin-bottom:40px;padding:20px 0}.logo{color:#5400cb;color:var(--primary-color);font-size:24px;font-weight:700}.user-info{gap:15px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:#5400cb;background:var(--primary-color);border-radius:50%;font-weight:700;height:40px;justify-content:center;width:40px}.logout-btn{background:#0000;border:1px solid #5400cb;border:1px solid var(--primary-color);border-radius:6px;color:#eaeaea;color:var(--text-primary);cursor:pointer;padding:8px 16px;transition:all .3s ease}.logout-btn:hover{background:#5400cb;background:var(--primary-color);color:#fff}.connection-status{align-items:center;background:#8080801a;border:1px solid #8f8f8f;border:1px solid var(--text-secondary);border-radius:20px;color:#8f8f8f;color:var(--text-secondary);display:flex;font-size:.85rem;gap:8px;margin-bottom:1rem;padding:6px 12px}.connection-status.status-online{background:#00ff001a;border:1px solid #0f0;color:#0f0}.status-dot{background:currentColor;border-radius:50%;height:8px;width:8px}.error-container{align-items:center;display:flex;flex-direction:column;height:100vh;justify-content:center;padding:2rem;text-align:center}.error-container h2{color:#f44;color:var(--status-error);margin-bottom:1rem}
/*# sourceMappingURL=main.ada9b0b8.css.map*/