@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-hover: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #18cb96;--accent-hover: #15b887;--accent-light: #20e0a8;--accent-bg: rgba(24, 203, 150, .1);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--border: #e2e8f0;--border-strong: #cbd5e1;--shadow: rgba(0, 0, 0, .08);--shadow-strong: rgba(0, 0, 0, .15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--transition: all .2s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-secondary);color:var(--text-primary);line-height:1.5;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100vh}.app-header{background:linear-gradient(135deg,#18cb96,#15b887);padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px var(--shadow);position:relative;z-index:100}.header-left{display:flex;align-items:center;gap:1.5rem}.logo{display:flex;align-items:center;gap:.75rem;color:#fff}.logo h1{font-size:1.5rem;font-weight:700;letter-spacing:-.5px}.subtitle{color:#fffffff2;font-size:.875rem;font-weight:500}.header-actions{display:flex;gap:.5rem}.btn{padding:.625rem 1rem;border:none;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap}.btn-primary{background:#fff;color:var(--accent);box-shadow:0 2px 8px #ffffff4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #fff6}.btn-secondary{background:#ffffff26;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:#ffffff40}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-pro{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-pro:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f180}.main-layout{display:flex;flex:1;overflow:hidden;position:relative}.canvas-container{flex:1;position:relative;transition:margin-right .3s ease}.canvas-container.panel-open{margin-right:500px}.canvas-container.lesson-mode{margin-left:0}.sidebar{width:320px;background:#fff;border-right:2px solid var(--border);display:flex;flex-direction:column;position:relative;z-index:20}.sidebar-left{border-right:2px solid var(--border)}.tabs{display:flex;background:var(--bg-secondary);border-bottom:2px solid var(--border)}.tab{flex:1;padding:.875rem 1rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab:hover{color:var(--text-primary);background:var(--bg-hover)}.tab.active{color:var(--accent);background:var(--bg-primary);border-bottom-color:var(--accent)}.tab-content{flex:1;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-primary)}.canvas-container{position:relative;background:radial-gradient(circle at 20px 20px,var(--border) 1px,transparent 1px),var(--bg-secondary);background-size:20px 20px;overflow:hidden;flex:1}.canvas{position:relative;width:100%;height:100%;cursor:default}.canvas-empty-state{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--text-muted);pointer-events:none;z-index:1}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.canvas-empty-state h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--text-secondary);font-weight:600}.canvas-empty-state p{font-size:.875rem;color:var(--text-muted)}.connections-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:auto;z-index:1}.connection-line{stroke:var(--accent);stroke-width:3;fill:none;transition:var(--transition);filter:drop-shadow(0 2px 4px rgba(24,203,150,.3));pointer-events:stroke;stroke-linecap:round}.connection-line:hover{stroke:var(--accent-light);stroke-width:4}.connection-line-clickable{stroke:transparent;stroke-width:20;fill:none;cursor:pointer;pointer-events:stroke}.packet{fill:var(--warning)}.device-palette{padding:1.5rem}.device-palette-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.25rem}.device-palette-subtitle{font-size:.75rem;color:var(--text-muted);margin-bottom:1rem}.device-list{display:flex;flex-direction:column;gap:.75rem}.device-item{display:flex;align-items:center;gap:.875rem;padding:1rem;background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);position:relative;width:100%;text-align:left}.device-item:hover{border-color:var(--accent);background:#fff;transform:translate(4px);box-shadow:0 4px 12px var(--shadow)}.device-item:active{transform:scale(.98)}.device-item-icon{font-size:1.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent);flex-shrink:0}.device-item-info{flex:1}.device-item-info h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.device-item-info p{font-size:.75rem;color:var(--text-muted)}.device-item-add{width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:50%;font-size:1rem;flex-shrink:0;opacity:0;transition:var(--transition)}.device-item:hover .device-item-add{opacity:1}.network-device-wrapper{position:absolute;padding-bottom:15px;z-index:10}.network-device{position:absolute;background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:1rem;min-width:200px;transition:box-shadow .2s,border-color .2s;box-shadow:0 2px 8px var(--shadow);z-index:10;-webkit-user-select:none;user-select:none;cursor:pointer}.network-device:hover{border-color:var(--accent);box-shadow:0 8px 24px var(--shadow-strong)}.network-device.selected{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-bg),0 8px 24px var(--shadow-strong)}.network-device.powered-on{border-color:var(--accent)}.network-device.dragging{cursor:grabbing;box-shadow:0 12px 32px var(--shadow-strong);transform:scale(1.02)}.device-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.device-icon{color:var(--accent);flex-shrink:0}.device-power{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);color:var(--text-muted);transition:var(--transition);display:flex;align-items:center}.device-power:hover{background:var(--bg-secondary)}.device-power.powered{color:var(--success)}.device-name{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.device-ip{font-size:.75rem;color:var(--text-muted);font-family:JetBrains Mono,monospace}.device-controls{position:absolute;top:-38px;left:0;display:flex;gap:.375rem;opacity:0;transition:var(--transition);pointer-events:none;z-index:100}.device-controls.visible{opacity:1;pointer-events:all}.device-control-button{background:#fff;border:2px solid var(--border);padding:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);color:var(--text-secondary);box-shadow:0 2px 8px var(--shadow)}.device-control-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.device-control-button.drag-handle{border-color:var(--success);color:var(--success);cursor:grab}.device-control-button.drag-handle:active{cursor:grabbing}.device-control-button.terminal-button{border-color:#8b5cf6;color:#8b5cf6}.device-control-button.config-button{border-color:#3b82f6;color:#3b82f6}.device-control-button.delete-button{border-color:var(--error);color:var(--error)}.device-ports-simple{display:flex;gap:.25rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}.port-simple{background:var(--bg-secondary);border:1.5px solid var(--border);padding:.25rem;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.port-simple:hover{background:var(--accent-bg);border-color:var(--accent);transform:scale(1.1)}.port-simple.connecting{background:#f59e0b1a;border-color:var(--warning);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.network-tag-badge{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);padding:.25rem .625rem;border-radius:10px;font-size:.6875rem;font-weight:600;white-space:nowrap;box-shadow:0 2px 6px #00000026;z-index:5;max-width:140px;overflow:hidden;text-overflow:ellipsis}.sliding-panel{position:absolute;right:-500px;top:0;width:500px;height:100%;background:#fff;border-left:2px solid var(--border);transition:right .3s ease;z-index:50;display:flex;flex-direction:column;box-shadow:-4px 0 16px var(--shadow)}.sliding-panel.open{right:0}.sliding-panel.builder-panel{width:700px;right:-700px}.sliding-panel.builder-panel.open{right:0}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:2px solid var(--border);background:#fff}.panel-header h3{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.panel-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:var(--transition);display:flex;align-items:center;justify-content:center}.panel-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.panel-content{flex:1;overflow-y:auto;background:var(--bg-secondary)}.terminal-container{height:100%;display:flex;flex-direction:column;background:#0a0e1a;color:#0f0;font-family:JetBrains Mono,monospace}.terminal-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#0d1117;border-bottom:1px solid #30363d}.terminal-title{display:flex;align-items:center;gap:.5rem;color:var(--accent);font-size:.875rem;font-weight:600}.terminal-actions{display:flex;gap:.5rem}.terminal-clear-btn{background:none;border:none;color:#fff9;cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:var(--transition);display:flex;align-items:center;justify-content:center}.terminal-clear-btn:hover{background:#ffffff1a;color:var(--accent)}.terminal-content{flex:1;overflow-y:auto;padding:1rem}.terminal-output{font-size:.8125rem;line-height:1.6}.terminal-line{margin-bottom:.25rem;white-space:pre-wrap;word-break:break-word}.terminal-line.prompt{color:var(--accent);font-weight:600}.terminal-line.info{color:#fff}.terminal-line.success{color:#10b981}.terminal-line.warning{color:#f59e0b}.terminal-line.error{color:#ef4444}.terminal-empty{padding:2rem;text-align:center;color:var(--text-muted)}.terminal-input-container{display:flex;align-items:center;padding:.75rem 1rem;background:#0d1117;border-top:1px solid #30363d}.terminal-prompt{color:var(--accent);font-weight:600;margin-right:.5rem;flex-shrink:0}.terminal-input{flex:1;background:transparent;border:none;color:#fff;font-family:JetBrains Mono,monospace;font-size:.8125rem;outline:none}.config-empty{padding:3rem 2rem;text-align:center}.config-empty-icon{color:var(--text-muted);margin-bottom:1rem}.config-empty p{color:var(--text-muted)}.config-container{padding:1.5rem}.config-group{margin-bottom:1.5rem}.config-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.config-input{width:100%;padding:.75rem 1rem;background:#fff;border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:.9375rem;transition:var(--transition)}.config-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.config-input:disabled{background:var(--bg-tertiary);cursor:not-allowed}.toggle-container{display:flex;align-items:center;gap:.75rem}.toggle{width:48px;height:24px;background:var(--border);border-radius:12px;position:relative;cursor:pointer;transition:var(--transition)}.toggle.active{background:var(--success)}.toggle-slider{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:var(--transition);box-shadow:0 2px 4px #0003}.toggle.active .toggle-slider{left:26px}.toggle-label{font-size:.875rem;color:var(--text-secondary)}.router-interfaces{display:flex;flex-direction:column;gap:1rem}.interface-config{background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-md);padding:1rem}.interface-header{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.interface-fields{display:flex;flex-direction:column;gap:.75rem}.config-group-inline{display:flex;flex-direction:column;gap:.375rem}.config-label-small{font-size:.75rem;font-weight:600;color:var(--text-secondary)}.config-input-small{width:100%;padding:.5rem .625rem;background:#fff;border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:.8125rem;transition:var(--transition)}.config-input-small:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:var(--radius-lg);padding:2rem;max-width:600px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.connection-modal{max-width:500px}.connection-details{display:flex;gap:1.5rem;padding:1.5rem 0}.connection-endpoint{flex:1;text-align:center}.endpoint-label{font-size:.75rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem}.endpoint-device{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.endpoint-info{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem}.endpoint-port{display:inline-block;padding:.25rem .625rem;background:var(--accent-bg);color:var(--accent);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.connection-cable{display:flex;flex-direction:column;align-items:center;justify-content:center}.cable-icon{color:var(--accent);margin-bottom:.5rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1.5rem;border-top:2px solid var(--border)}.btn-delete-connection{padding:.75rem 1.5rem;background:var(--error);color:#fff;border:none;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-delete-connection:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.lesson-panel{height:100%;overflow-y:auto;background:var(--bg-secondary)}.lesson-list-header{padding:2rem 1.5rem 1rem;background:#fff;border-bottom:2px solid var(--border)}.lesson-list-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.lesson-list-header p{color:var(--text-muted);font-size:.875rem}.import-lesson-section{margin:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:var(--radius-lg);text-align:center;box-shadow:0 4px 16px #6366f14d}.import-lesson-section h4{color:#fff;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.import-lesson-section p{color:#ffffffe6;font-size:.875rem;margin-bottom:1.25rem}.file-input-wrapper{position:relative;display:inline-block}.file-input-wrapper input[type=file]{position:absolute;opacity:0;width:100%;height:100%;top:0;left:0;cursor:pointer;z-index:1}.btn-import{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:#fff;color:#6366f1;border:none;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:0 2px 8px #0000001a;position:relative;z-index:0}.btn-import:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0003}.btn-import:disabled{opacity:.6;cursor:not-allowed}.lessons-grid{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.lessons-section-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem .75rem;margin-top:.5rem}.lessons-section-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.lesson-count-badge{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .625rem;background:var(--accent-bg);color:var(--accent);border-radius:12px;font-size:.75rem;font-weight:600}.lesson-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;cursor:pointer;transition:var(--transition)}.lesson-card:hover{border-color:var(--accent);box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.custom-lesson-card{border-color:#8b5cf6;background:linear-gradient(to bottom right,#fff,#faf5ff)}.custom-lesson-card:hover{border-color:#7c3aed;box-shadow:0 4px 12px #8b5cf64d}.lesson-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.lesson-card-header h3{font-size:1rem;font-weight:600;color:var(--text-primary)}.custom-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.lesson-card-meta{display:flex;gap:.5rem;margin-bottom:.75rem}.badge-difficulty{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;color:#fff}.badge-duration{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-secondary)}.lesson-card-curriculum{font-size:.8125rem;color:var(--accent);font-weight:500;margin-bottom:.5rem}.lesson-card-description{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1rem}.lesson-card-footer{display:flex;gap:1rem;padding-top:.75rem;border-top:1px solid var(--border);font-size:.8125rem;color:var(--text-muted)}.lesson-detail{padding:1.5rem;background:#fff}.lesson-detail-header{padding:1rem 1.5rem;background:#fff;border-bottom:2px solid var(--border)}.btn-back{background:none;border:none;color:var(--accent);font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem 0;transition:var(--transition);display:inline-flex;align-items:center;gap:.375rem}.btn-back:hover{color:var(--accent-hover)}.lesson-detail-top{margin-bottom:1rem}.lesson-detail-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.lesson-badges{display:flex;gap:.5rem}.lesson-curriculum{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--accent);font-weight:500;margin-bottom:1rem}.lesson-description{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.lesson-scenario{background:#fff7ed;border-left:4px solid #f59e0b;border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1.5rem}.lesson-scenario h4{font-size:.9375rem;font-weight:600;color:#f59e0b;margin-bottom:.75rem}.lesson-scenario p{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin:0}.lesson-scenario-active{background:#fff7ed;border-left:4px solid #f59e0b;border-radius:var(--radius-md);padding:1.25rem}.lesson-scenario-active h4{color:#f59e0b;margin-bottom:.75rem}.lesson-scenario-active p{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin:0}.lesson-objectives-preview{margin-bottom:1.5rem}.lesson-objectives-preview h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.lesson-objectives-preview ul{list-style:none;padding:0}.lesson-objectives-preview li{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem;font-size:.875rem;color:var(--text-secondary)}.lesson-objectives-preview li svg{color:var(--success);flex-shrink:0;margin-top:.125rem}.lesson-challenges-preview{margin-bottom:1.5rem}.lesson-challenges-preview h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.challenges-preview-list{display:flex;flex-direction:column;gap:.5rem}.challenge-preview{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-secondary)}.challenge-preview-number{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;background:var(--accent);color:#fff;border-radius:50%;font-weight:600;font-size:.8125rem;flex-shrink:0}.btn-start-lesson{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-start-lesson:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #18cb964d}.lesson-header-active{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;border-bottom:2px solid var(--border)}.lesson-header-info{display:flex;align-items:center;gap:.75rem}.lesson-icon{color:var(--accent)}.lesson-active-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.lesson-active-meta{font-size:.75rem;color:var(--text-muted)}.btn-exit-lesson{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--error);color:#fff;border:none;border-radius:var(--radius-md);font-size:.8125rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-exit-lesson:hover{background:#dc2626}.lesson-content-active{padding:1.5rem}.lesson-section{margin-bottom:2rem}.lesson-section h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.lesson-objectives{list-style:none;padding:0}.lesson-objectives li{padding:.625rem .625rem .625rem 1.5rem;position:relative;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.lesson-objectives li:before{content:"✓";position:absolute;left:.5rem;color:var(--success);font-weight:600}.challenges-list{display:flex;flex-direction:column;gap:1rem}.challenge-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius-md);padding:1rem}.challenge-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.challenge-number{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--accent);color:#fff;border-radius:50%;font-weight:600;font-size:.875rem;flex-shrink:0}.challenge-header h5{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.challenge-description{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin-bottom:.75rem}.challenge-hint{margin-top:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:.8125rem}.challenge-hint summary{cursor:pointer;font-weight:500;color:var(--text-primary);-webkit-user-select:none;user-select:none}.challenge-hint summary:hover{color:var(--accent)}.challenge-hint p{margin-top:.75rem;color:var(--text-secondary);line-height:1.5}.challenge-solution{display:block;margin-top:.75rem;padding:.5rem .75rem;background:#0a0e1a;color:var(--accent);border-radius:var(--radius-sm);font-family:JetBrains Mono,monospace;font-size:.8125rem}.lesson-instructions{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem}.lesson-instructions h4{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.lesson-instructions ol{padding-left:1.5rem;font-size:.875rem;color:var(--text-secondary);line-height:1.6}.lesson-instructions li{margin-bottom:.5rem}.lesson-instructions code{padding:.125rem .375rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:JetBrains Mono,monospace;font-size:.8125rem;color:var(--accent)}.lesson-builder{height:100%;display:flex;flex-direction:column;background:var(--bg-secondary)}.pro-notice{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:.875rem;font-weight:600;border-bottom:2px solid rgba(255,255,255,.2)}.builder-progress{display:flex;padding:1.5rem;background:#fff;border-bottom:2px solid var(--border);overflow-x:auto;gap:.5rem}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 1rem;min-width:100px;cursor:pointer;transition:var(--transition);border-radius:var(--radius-md);position:relative}.progress-step:hover{background:var(--bg-secondary)}.progress-step.active{background:var(--accent-bg)}.progress-step.completed{background:var(--bg-tertiary)}.step-circle{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-secondary);border:2px solid var(--border);font-weight:600;font-size:.875rem;color:var(--text-secondary);transition:var(--transition)}.progress-step.active .step-circle{background:var(--accent);border-color:var(--accent);color:#fff}.progress-step.completed .step-circle{background:var(--success);border-color:var(--success);color:#fff}.step-label{font-size:.75rem;font-weight:500;color:var(--text-secondary);text-align:center}.progress-step.active .step-label{color:var(--accent);font-weight:600}.builder-content{flex:1;padding:2rem;overflow-y:auto}.builder-step{max-width:800px;margin:0 auto}.step-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.step-description{font-size:.9375rem;color:var(--text-muted);margin-bottom:2rem}.network-preview{background:var(--bg-tertiary);border:2px solid var(--accent);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.preview-header{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--accent);margin-bottom:1rem;font-size:.9375rem}.preview-stats{display:flex;gap:2rem;margin-bottom:1rem}.preview-stats .stat{display:flex;flex-direction:column;align-items:center}.preview-stats .stat strong{font-size:2rem;font-weight:700;color:var(--accent)}.preview-stats .stat span{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.preview-note{font-size:.8125rem;color:var(--text-secondary);font-style:italic}.empty-network-warning{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;min-height:500px}.empty-network-warning svg{color:var(--warning);margin-bottom:1.5rem}.empty-network-warning h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.empty-network-warning>p{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem;max-width:400px}.instructions-list{background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;max-width:500px;text-align:left}.instructions-list h4{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.instructions-list ol{padding-left:1.5rem;font-size:.875rem;color:var(--text-secondary);line-height:1.8}.instructions-list li{margin-bottom:.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem 1rem;background:#fff;border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9375rem;transition:var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.form-textarea{resize:vertical;font-family:Inter,sans-serif}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.topics-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1.5rem}.topic-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;cursor:pointer;transition:var(--transition)}.topic-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.topic-card.selected{border-color:var(--accent);background:var(--accent-bg);box-shadow:0 0 0 3px #18cb9626}.topic-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.topic-checkbox{width:24px;height:24px;border:2px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}.topic-card.selected .topic-checkbox{background:var(--accent);border-color:var(--accent);color:#fff}.topic-info{flex:1}.topic-code-badge{display:inline-block;padding:.125rem .5rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;color:var(--text-muted);margin-bottom:.375rem}.topic-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0}.topic-category{font-size:.75rem;color:var(--accent);font-weight:500;margin-bottom:.75rem}.topic-subtopics{display:flex;flex-wrap:wrap;gap:.375rem}.subtopic-tag{display:inline-block;padding:.25rem .5rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.6875rem;color:var(--text-secondary)}.selected-topics-summary{margin-top:1.5rem;padding:1rem;background:var(--accent-bg);border:2px solid var(--accent);border-radius:var(--radius-md);text-align:center;color:var(--accent);font-weight:600}.objectives-list{display:flex;flex-direction:column;gap:1rem}.objective-item{display:flex;gap:.75rem;align-items:center}.objective-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:50%;font-weight:600;font-size:.875rem;flex-shrink:0}.objective-item .form-input{flex:1}.btn-add{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:0 2px 8px #18cb964d}.btn-add:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #18cb9666}.btn-icon-danger{background:var(--error);color:#fff;border:none;padding:.5rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.btn-icon-danger:hover{background:#dc2626}.btn-icon-danger:disabled{opacity:.5;cursor:not-allowed}.btn-icon-small-danger{background:var(--error);color:#fff;border:none;padding:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.btn-icon-small-danger:hover{background:#dc2626}.challenge-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--border)}.review-summary{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.summary-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.summary-card h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.summary-item{display:flex;justify-content:space-between;margin-bottom:.75rem}.summary-item .label{font-weight:600;color:var(--text-secondary)}.summary-item .value{color:var(--text-primary)}.topic-badges{display:flex;flex-wrap:wrap;gap:.5rem}.topic-badge{display:inline-block;padding:.375rem .75rem;background:var(--accent-bg);color:var(--accent);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.no-data{color:var(--text-muted);font-style:italic}.network-devices-list{margin-top:1rem;max-height:200px;overflow-y:auto}.device-preview{padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.8125rem;color:var(--text-secondary);margin-bottom:.5rem;font-family:JetBrains Mono,monospace}.export-section{background:#fff;border:2px solid var(--border);border-radius:var(--radius-lg);padding:2rem}.export-section h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.export-section p{color:var(--text-secondary);margin-bottom:1.5rem}.code-preview-container{margin-bottom:1.5rem}.code-preview-header{background:#0d1117;color:var(--accent);padding:.75rem 1rem;border-radius:var(--radius-md) var(--radius-md) 0 0;font-weight:600;font-size:.875rem}.code-preview{background:#0a0e1a;color:#10b981;padding:1.5rem;border-radius:0 0 var(--radius-md) var(--radius-md);font-family:JetBrains Mono,monospace;font-size:.75rem;line-height:1.6;overflow-x:auto;max-height:400px;overflow-y:auto;margin:0}.btn-download{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition);margin-bottom:1.5rem;box-shadow:0 2px 8px #18cb964d}.btn-download:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #18cb9666}.instructions{background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-md);padding:1.5rem}.instructions h5{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.instructions ol{padding-left:1.5rem;font-size:.875rem;color:var(--text-secondary);line-height:1.8}.instructions code{padding:.125rem .375rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:JetBrains Mono,monospace;font-size:.8125rem;color:var(--accent)}.builder-nav{display:flex;gap:1rem;padding:1.5rem;background:#fff;border-top:2px solid var(--border)}.btn-nav{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border:2px solid var(--border);border-radius:var(--radius-md);background:#fff;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-nav:hover:not(:disabled){border-color:var(--accent);background:var(--accent-bg);transform:translateY(-1px)}.btn-nav:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-nav.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px #18cb964d}.btn-nav.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 12px #18cb9666}.btn-nav.btn-success{background:var(--success);border-color:var(--success);color:#fff;box-shadow:0 2px 8px #10b9814d}.btn-nav.btn-success:hover{background:#10b981;box-shadow:0 4px 12px #10b98166}.nav-spacer{flex:1}.empty-state{padding:3rem 2rem;text-align:center;background:var(--bg-secondary);border:2px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted)}.empty-state p{margin:0;font-size:.9375rem}@media (max-width: 1400px){.sliding-panel{width:450px;right:-450px}.sliding-panel.builder-panel{width:600px;right:-600px}.canvas-container.panel-open{margin-right:450px}}@media (max-width: 1200px){.sliding-panel{width:400px;right:-400px}.sliding-panel.builder-panel{width:100%;right:-100%}.canvas-container.panel-open{margin-right:400px}}@media (max-width: 768px){.sidebar{width:280px}.form-row,.topics-container{grid-template-columns:1fr}.builder-progress{padding:1rem}}
