:root{--primary: #9ca3af;--primary-dark: #757c8f;--success: #16a34a;--danger: #dc2626;--warning: #ca8a04;--secondary: #6b7280;--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #141414;--text-primary: #f9fafb;--text-secondary: #9ca3af;--border: #1f1f1f;--shadow: rgba(0, 0, 0, .7)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;overflow:hidden}.app-desktop{width:100vw;height:100vh;aspect-ratio:16 / 9;max-width:100vw;max-height:100vh;margin:0 auto;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;overflow:hidden}.desktop-header{background:var(--bg-secondary);border-bottom:2px solid var(--border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;height:80px;flex-shrink:0}.header-left{display:flex;align-items:center;gap:1rem}.logo{width:50px;height:50px;border-radius:12px;object-fit:cover;box-shadow:0 4px 12px #6366f166}.desktop-header h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),#ffff00);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0}.subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.header-right{display:flex;align-items:center;gap:1rem}.status-indicator{padding:.5rem 1.25rem;border-radius:20px;font-size:.875rem;font-weight:600;background:#64748b33;color:var(--secondary);border:2px solid var(--secondary);transition:all .3s ease}.status-indicator.connected{background:#10b98133;color:var(--success);border-color:var(--success);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.desktop-layout{display:flex;flex:1;overflow:hidden}.desktop-sidebar{width:240px;background:var(--bg-secondary);border-right:2px solid var(--border);flex-shrink:0;overflow-y:auto}.desktop-nav{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:1rem;background:transparent;border:none;border-radius:12px;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:left}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translate(5px)}.nav-item.active{background:linear-gradient(135deg,var(--text-primary),#ffff00);color:#000;box-shadow:0 4px 12px #6366f166}.nav-icon{font-size:1.25rem}.desktop-main{flex:1;padding:2rem;overflow-y:auto;background:var(--bg-primary)}.desktop-footer{background:var(--bg-secondary);border-top:2px solid var(--border);padding:1rem 2rem;text-align:center;flex-shrink:0;height:60px;display:flex;align-items:center;justify-content:center}.desktop-footer p{margin:0;color:var(--text-secondary);font-size:.875rem}.desktop-footer a{color:#ff0;text-decoration:none;transition:color .3s ease;font-weight:450}.desktop-footer a:hover{color:#0f0;text-decoration:underline}.app-mobile{width:100vw;height:100vh;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;overflow:hidden}.mobile-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:1rem;display:flex;align-items:center;gap:.75rem;height:60px;flex-shrink:0}.logo-mobile{width:40px;height:40px;border-radius:10px;object-fit:cover}.mobile-header h1{font-size:1.25rem;font-weight:700;flex:1;background:linear-gradient(135deg,var(--text-primary),#ffff00);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.status-dot{width:12px;height:12px;border-radius:50%;background:var(--secondary);border:2px solid var(--bg-primary)}.status-dot.connected{background:var(--success);box-shadow:0 0 10px var(--success);animation:pulse 2s infinite}.mobile-main{flex:1;overflow-y:auto;padding:1rem;padding-bottom:80px}.mobile-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:.5rem;height:70px;z-index:1000;box-shadow:0 -4px 12px var(--shadow)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;flex:1;background:none;border:none;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .3s ease;padding:.5rem;border-radius:8px}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-item.active{color:var(--primary);background:#6366f11a}.mobile-nav-item.active .mobile-nav-icon{transform:scale(1.2)}.mobile-nav-icon{font-size:1.5rem;transition:transform .3s ease}.section-content{height:100%;display:flex;flex-direction:column;gap:1.5rem;margin-bottom:10rem}.section-content h2{font-size:1.5rem;font-weight:600;margin:0}.section-content h3{font-size:1.125rem;font-weight:600;margin:0 0 1rem}.status-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600}.status-badge.connected{background:#10b98133;color:var(--success);border:1px solid var(--success)}.status-badge.disconnected{background:#64748b33;color:var(--secondary);border:1px solid var(--secondary)}.chip-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:1rem;font-weight:600;color:var(--text-primary);font-family:Courier New,monospace}.connection-panel{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.baud-selector{display:flex;align-items:center;gap:1rem}.baud-selector label{font-size:.875rem;font-weight:500;color:var(--text-secondary);min-width:80px}.baud-selector select{flex:1;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .3s ease}.baud-selector select:hover:not(:disabled){border-color:var(--primary)}.action-buttons{display:flex;gap:1rem}.drop-zone{border:2px dashed var(--border);border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-secondary)}.drop-zone:hover:not(.dragging){border-color:var(--primary);background:#6366f10d}.drop-zone.dragging{border-color:var(--success);background:#10b9811a;transform:scale(1.02)}.drop-zone-content{pointer-events:none}.upload-icon{font-size:3rem;margin-bottom:1rem}.drop-text{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.drop-subtext{font-size:.875rem;color:var(--text-secondary)}.files-list{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto}.file-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;transition:all .3s ease}.file-item:hover{border-color:var(--primary);box-shadow:0 2px 8px var(--shadow)}.file-info{display:flex;align-items:center;gap:.75rem;flex:1}.file-icon{font-size:1.5rem}.file-details{display:flex;flex-direction:column;gap:.25rem}.file-name{font-weight:500;color:var(--text-primary)}.file-size{font-size:.75rem;color:var(--text-secondary)}.file-actions{display:flex;align-items:center;gap:.5rem}.address-input{padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-family:Courier New,monospace;font-size:.875rem;width:100px;transition:all .3s ease}.address-input:focus{outline:none;border-color:var(--primary)}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.filter-select{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer}.firmware-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;max-height:calc(100vh - 100px);overflow-y:auto}.firmware-card{padding:1.5rem;background:var(--bg-secondary);border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .3s ease}.firmware-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 16px var(--shadow)}.firmware-card.selected{border-color:var(--primary);background:#6366f11a}.firmware-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.75rem}.firmware-header h3{font-size:1rem;font-weight:600;margin:0}.chip-badge{padding:.25rem .75rem;background:var(--primary);color:#fff;border-radius:12px;font-size:.75rem;font-weight:600}.firmware-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.5}.firmware-footer{display:flex;justify-content:space-between;align-items:center}.firmware-size{font-size:.75rem;color:var(--text-secondary)}.serial-monitor-section{height:100%;display:flex;flex-direction:column;gap:1rem}.serial-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.serial-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-primary);border-radius:20px}.connection-dot{width:10px;height:10px;border-radius:50%;background:var(--secondary);transition:all .3s ease}.connection-dot.active{background:var(--success);box-shadow:0 0 10px var(--success);animation:pulse 2s infinite}.connection-text{font-size:.875rem;font-weight:600;color:var(--text-primary)}.serial-controls-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border);align-items:end}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.serial-select{padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .3s ease;font-family:Courier New,monospace}.serial-select:hover:not(:disabled){border-color:var(--primary)}.serial-select:disabled{opacity:.5;cursor:not-allowed}.checkbox-label-inline{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.75rem;background:var(--bg-primary);border-radius:8px;transition:all .3s ease}.checkbox-label-inline:hover{background:var(--bg-tertiary)}.checkbox-label-inline input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.checkbox-label-inline span{font-size:.875rem;font-weight:500;color:var(--text-primary)}.control-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.serial-output-container{flex:1;min-height:400px;max-height:calc(100vh - 500px);display:flex;flex-direction:column}.serial-output{flex:1;background:#0a0a0a;border:2px solid var(--border);border-radius:12px;padding:1rem;overflow-y:auto;font-family:Courier New,Consolas,Monaco,monospace;font-size:.9rem;line-height:1.5;color:#0f0;box-shadow:inset 0 2px 8px #00000080}.serial-output::-webkit-scrollbar{width:10px}.serial-output::-webkit-scrollbar-track{background:#1a1a1a;border-radius:5px}.serial-output::-webkit-scrollbar-thumb{background:#333;border-radius:5px}.serial-output::-webkit-scrollbar-thumb:hover{background:var(--primary)}.serial-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#555;text-align:center;gap:1rem}.empty-icon{font-size:3rem;opacity:.5}.serial-empty p{margin:0;font-size:1rem}.empty-subtext{font-size:.875rem!important;color:#777}.serial-line{margin-bottom:.25rem;display:flex;gap:.75rem;font-family:Courier New,Consolas,monospace;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.serial-line.serial-data{color:#0f0}.serial-line.serial-sent{color:#00d4ff}.serial-line.serial-system{color:#fa0}.serial-line.serial-error{color:#f44}.serial-time{color:#666;font-size:.75rem;flex-shrink:0;-webkit-user-select:none;user-select:none;min-width:100px;font-weight:600}.serial-text{white-space:pre-wrap;word-break:break-word;flex:1}.serial-input-panel{display:flex;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.serial-input{flex:1;padding:.75rem 1rem;background:var(--bg-primary);border:2px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;font-family:Courier New,monospace;transition:all .3s ease}.serial-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #6366f126}.serial-input:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary)}.serial-input::placeholder{color:var(--text-secondary);opacity:.6}.serial-stats{display:flex;gap:1rem;padding:1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border);flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-primary);border-radius:8px;flex:1;min-width:120px}.stat-label{font-size:.75rem;color:var(--text-secondary);font-weight:600}.stat-value{font-size:.875rem;color:var(--text-primary);font-family:Courier New,monospace;font-weight:700}@media(max-width:768px){.serial-controls-panel{grid-template-columns:1fr;padding:1rem}.control-buttons{grid-column:1 / -1}.serial-output-container{max-height:calc(100vh - 600px);min-height:300px}.serial-stats{flex-direction:column}.stat-item{justify-content:space-between}.serial-time{min-width:80px;font-size:.65rem}}@media(max-width:480px){.serial-output{font-size:.8rem}.serial-input-panel{flex-direction:column}.serial-line{flex-direction:column;gap:.25rem}}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-large{padding:1rem 2rem;font-size:1rem;width:100%}.btn-small{padding:.5rem 1rem;font-size:.75rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover:not(:disabled){background:#475569;transform:translateY(-2px)}.btn-text{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;padding:.5rem 1rem;transition:all .3s ease}.btn-text:hover{background:#6366f11a;border-radius:6px}.btn-icon-small{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;padding:.5rem;cursor:pointer;font-size:1rem;transition:all .3s ease}.btn-icon-small:hover:not(:disabled){background:var(--primary);border-color:var(--primary);transform:scale(1.1)}.btn-icon{font-size:1.125rem}.button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.progress-section{margin-top:1rem}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem;font-weight:600}.progress-percent{color:var(--primary);font-size:1rem}.progress-container{width:100%;height:32px;background:var(--bg-secondary);border-radius:16px;overflow:hidden;box-shadow:inset 0 2px 4px var(--shadow);border:1px solid var(--border)}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),#8b5cf6);border-radius:16px;transition:width .3s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;position:relative;overflow:hidden}.progress-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shine 2s infinite}@keyframes shine{to{left:100%}}.advanced-section{padding-top:1rem;border-top:1px solid var(--border)}.advanced-options{margin-top:1rem;padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border)}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.checkbox-label-small{display:flex;align-items:center;gap:.375rem;font-size:.875rem;cursor:pointer}.checkbox-label-small input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary)}.help-section{padding:1.5rem;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:1px solid rgba(99,102,241,.3);border-radius:12px}.help-steps{display:flex;flex-direction:column;gap:1rem}.help-step{display:flex;gap:1rem;align-items:start}.step-number{width:32px;height:32px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.step-content strong{display:block;margin-bottom:.25rem;color:var(--text-primary)}.step-content p{font-size:.875rem;color:var(--text-secondary);margin:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}@media(max-width:1024px){.firmware-grid{grid-template-columns:1fr}.chip-info-grid{grid-template-columns:1fr 1fr}}@media(max-width:768px){.mobile-main{padding:.75rem}.chip-info-grid,.button-grid{grid-template-columns:1fr}.file-item{flex-direction:column;align-items:flex-start;gap:.75rem}.file-actions{width:100%}.address-input{flex:1}}.console-card{min-height:400px}.console-actions{display:flex;align-items:center;gap:.5rem}.logs-container{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:1rem;max-height:400px;overflow-y:auto;font-family:Courier New,monospace;font-size:.875rem;line-height:1.8}.logs-container::-webkit-scrollbar{width:8px}.logs-container::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.logs-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.logs-container::-webkit-scrollbar-thumb:hover{background:var(--primary)}.logs-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.log-line{margin-bottom:.5rem;padding:.5rem;border-radius:4px;transition:background .2s ease}.log-line:hover{background:var(--bg-secondary)}.log-time{color:var(--text-secondary);margin-right:.5rem;font-size:.75rem}.log-text{color:var(--text-primary)}.log-success .log-text{color:var(--success)}.log-error .log-text{color:var(--danger)}.log-warning .log-text{color:var(--warning)}
