*{margin:0;padding:0;box-sizing:border-box}:root{--bg-void: #0a0a0a;--bg-surface: #121212;--bg-elevated: #1e1e1e;--bg-subtle: #2a2a2a;--text-primary: #f0f0f0;--text-secondary: #b0b0b0;--text-muted: #707070;--text-dim: #505050;--accent-amber: #fbbf24;--accent-green: #22c55e;--accent-red: #ef4444;--border-primary: #333333;--border-subtle: #1f1f1f;--primary-color: #4a90e2;--secondary-color: #667eea;--accent-color: #764ba2;--success-color: #28a745;--danger-color: #dc3545;--warning-color: #ffc107;--info-color: #17a2b8;--light-color: #f8f9fa;--dark-color: #343a40;--text-color: #333;--text-muted: #6c757d;--text-secondary: #6c757d;--border-color: #dee2e6;--sidebar-bg: #f8f9fa;--background-secondary: #f8f9fa;--background-light: #ffffff;--gradient-primary: #667eea;--gradient-secondary: #4CAF50;--gradient-dark: #2c3e50;--shadow-sm: 0 .125rem .25rem rgba(0, 0, 0, .075);--shadow: 0 .5rem 1rem rgba(0, 0, 0, .15);--shadow-lg: 0 1rem 3rem rgba(0, 0, 0, .175);--shadow-terminal: 0 4px 20px rgba(0, 0, 0, .3);--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-section: 4rem;--radius-sm: 0;--radius-md: 0;--radius-lg: 0;--radius-xl: 0;--radius-full: 50%;--radius-circle: 50%;--bp-sm: 576px;--bp-md: 768px;--bp-lg: 992px;--bp-xl: 1200px;--terminal-bg: #121212;--terminal-bg-solid: #121212;--terminal-text: #d4d4d4;--terminal-text-white: #ffffff;--terminal-text-green: #00ff00;--terminal-prompt: #4CAF50;--terminal-border: rgba(255, 255, 255, .1);--terminal-header-bg: #2d2d2d;--terminal-dot-red: #ff6b5d;--terminal-dot-yellow: #ffc843;--terminal-dot-green: #32d74b;--terminal-output: #00D084;--terminal-success: #4ade80;--terminal-error: #ff6b6b;--terminal-info: #60a5fa;--badge-beginner-bg: #d4edda;--badge-beginner-text: #155724;--badge-intermediate-bg: #fff3cd;--badge-intermediate-text: #856404;--badge-application-bg: #f8d7da;--badge-application-text: #721c24;--badge-advanced-bg: #f8d7da;--badge-advanced-text: #721c24;--transition-fast: .15s ease;--transition-normal: .15s ease;--transition-slow: .3s ease}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--bg-void);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:focus-visible{outline:2px solid var(--accent-amber);outline-offset:2px}.terminal-area{display:flex;flex-direction:column;background:var(--terminal-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--terminal-border)}.terminal-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1);min-height:50px}.terminal-controls{display:flex;gap:8px;align-items:center}.terminal-control-btn{width:12px;height:12px;border-radius:50%;border:none;cursor:pointer;transition:all .2s ease}.terminal-control-btn.close{background:linear-gradient(145deg,#ff6b5a,#ff5f4f)}.terminal-control-btn.minimize{background:linear-gradient(145deg,#ffbd2e,#ffb300)}.terminal-control-btn.maximize{background:linear-gradient(145deg,#28ca42,#20a834)}.terminal-control-btn:hover{transform:scale(1.1);box-shadow:0 2px 8px #0000004d}.terminal-title{color:#888;font-size:.9rem;position:absolute;left:50%;transform:translate(-50%);font-weight:500;pointer-events:none}.terminal-actions{display:flex;gap:8px;align-items:center}.terminal-clear{padding:.25rem .75rem;background:linear-gradient(145deg,#3d3d3d,#333);color:#888;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .3s}.terminal-clear:hover{background:linear-gradient(145deg,#4d4d4d,#434343);color:#aaa;transform:translateY(-1px)}.terminal{flex:1;padding:1rem;overflow-y:auto;font-family:Fira Code,Monaco,Consolas,monospace;font-size:.95rem;line-height:1.4;cursor:text;color:var(--terminal-text)}.terminal-output{color:var(--terminal-text);white-space:pre-wrap;word-wrap:break-word;cursor:text;margin-bottom:.5rem}.terminal-input-line{display:flex;align-items:center;margin-top:.5rem}.terminal-prompt{color:var(--terminal-prompt);margin-right:.5rem;font-weight:600;white-space:nowrap}.terminal-input{flex:1;background:transparent;border:none;color:var(--terminal-text);font-family:inherit;font-size:inherit;outline:none;caret-color:var(--terminal-prompt)}.terminal-cursor{display:inline-block;width:.5rem;height:1.2rem;background:var(--terminal-prompt);animation:cursor-blink 1s infinite;margin-left:2px}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.success-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#28a745f2;color:#fff;padding:2rem 3rem;border-radius:15px;font-size:1.4rem;font-weight:600;text-align:center;z-index:1000;box-shadow:var(--shadow-lg);animation:successPulse .8s ease-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}@keyframes successPulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}50%{transform:translate(-50%,-50%) scale(1.1);opacity:1}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.difficulty-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;color:#fff;text-transform:uppercase}.difficulty-badge.beginner{background:linear-gradient(135deg,#28a745,#20c997)}.difficulty-badge.intermediate{background:linear-gradient(135deg,#ffc107,#fd7e14)}.difficulty-badge.application,.difficulty-badge.advanced{background:linear-gradient(135deg,#dc3545,#e83e8c)}.progress-bar{width:100%;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin:.5rem 0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--success-color),var(--primary-color));border-radius:4px;transition:width .3s ease;width:0%}.badge-count{color:var(--warning-color);font-weight:600;font-size:1.1rem}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.d-flex{display:flex}.d-none{display:none}.d-block{display:block}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.hero-section{background:var(--gradient-primary);color:#fff;padding:var(--spacing-3xl) var(--spacing-xl);text-align:center;border-radius:var(--radius-xl);margin-bottom:var(--spacing-2xl)}.hero-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;gap:var(--spacing-2xl)}.hero-text{flex:1;text-align:left}.hero-image{flex:1;max-width:500px}.hero-main-image{width:100%;height:auto;border-radius:var(--radius-xl)}.hero-title{font-size:var(--font-size-5xl);margin-bottom:var(--spacing-xl);font-weight:700}.hero-subtitle{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2xl);opacity:.95}.cta-button,.hero-button{padding:var(--spacing-md) var(--spacing-2xl);font-size:var(--font-size-lg);border-radius:var(--radius-lg);text-decoration:none;transition:var(--transition-normal);display:inline-block;border:none;cursor:pointer;font-weight:500}.cta-button-large,.hero-button-primary{background:#fff;color:var(--secondary-color);font-weight:700}.cta-button-secondary,.hero-button-secondary{background:#fff3;color:#fff;border:2px solid white}.cta-button:hover,.hero-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.hero-button-cta{background:#4caf50;color:#fff;font-size:1.3rem;padding:1.3rem 3rem;box-shadow:0 6px 20px #4caf5080;animation:cta-pulse 2s ease-in-out infinite;position:relative;overflow:hidden;font-weight:700;letter-spacing:.5px}.hero-button-cta:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.hero-button-cta:hover:before{width:300px;height:300px}.hero-button-cta:hover{transform:translateY(-3px);box-shadow:0 6px 20px #4caf5099}@keyframes cta-pulse{0%,to{transform:scale(1);box-shadow:0 6px 20px #4caf5080}50%{transform:scale(1.05);box-shadow:0 8px 30px #4caf50b3}}.hero-buttons{display:flex;gap:var(--spacing-xl);justify-content:center;flex-wrap:wrap}.features-section{padding:var(--spacing-2xl) var(--spacing-xl);background:var(--light-color);border-radius:var(--radius-xl);margin-bottom:var(--spacing-2xl)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-2xl);margin-top:var(--spacing-2xl)}.feature-card{background:#fff;padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center}.feature-icon{font-size:var(--font-size-5xl);margin-bottom:var(--spacing-md)}.feature-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-sm);color:var(--text-color)}.feature-description{color:var(--text-muted);line-height:1.6}.terminal-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.terminal-dot{width:12px;height:12px;border-radius:var(--radius-full);display:inline-block;box-shadow:inset 0 1px 2px #0000004d}.terminal-dot.red{background:var(--terminal-dot-red)}.terminal-dot.yellow{background:var(--terminal-dot-yellow)}.terminal-dot.green{background:var(--terminal-dot-green)}.terminal-header{background:var(--terminal-header-bg);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #404040}.terminal-title{color:var(--terminal-text-white);font-size:var(--font-size-sm);font-weight:500;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.terminal-wrapper{max-width:100%;margin:0 auto;width:100%;box-shadow:var(--shadow-terminal)}.terminal{background:var(--terminal-bg-solid);color:var(--terminal-text-white);font-family:Monaco,Menlo,Ubuntu Mono,Courier New,monospace;font-size:var(--font-size-sm);line-height:1.4;padding:var(--spacing-md);border-radius:0 0 var(--radius-lg) var(--radius-lg);min-height:300px;overflow-y:auto}.terminal-output{white-space:pre-wrap;word-wrap:break-word}.terminal-input-line{display:flex;align-items:center;margin-top:var(--spacing-sm)}.prompt{color:var(--terminal-prompt);margin-right:var(--spacing-sm);font-weight:700}.terminal-input{background:transparent;border:none;color:var(--terminal-text-white);font-family:inherit;font-size:inherit;outline:none;flex:1;caret-color:var(--terminal-prompt)}.page-list{list-style:none;padding:0}.page-list li{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);transition:var(--transition-normal)}.page-list li:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.page-list a{text-decoration:none;color:var(--secondary-color);font-weight:500;display:block}.page-list a:hover{color:var(--accent-color)}.page-description{color:var(--text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-xs);line-height:1.4}.page-meta{display:flex;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--text-muted)}.faq-category{margin-bottom:var(--spacing-xl)}.faq-item{background:var(--light-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);overflow:hidden}.faq-question{background:#e9ecef;padding:var(--spacing-md);margin:0;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;justify-content:space-between;align-items:center;transition:var(--transition-normal)}.faq-question:hover{background:#dee2e6}.faq-question:after{content:"▼";transition:var(--transition-normal)}.faq-question.active:after{transform:rotate(180deg)}.faq-answer{padding:var(--spacing-md);display:none;line-height:1.6;border-top:1px solid var(--border-color)}.faq-answer.active{display:block}.faq-icon{font-size:var(--font-size-2xl)}.cta-section{background:var(--gradient-primary);color:#fff;padding:var(--spacing-2xl);text-align:center;border-radius:var(--radius-lg);margin:var(--spacing-2xl) 0}.cta-section h2{margin-bottom:var(--spacing-md)}.cta-section p{margin-bottom:var(--spacing-xl);opacity:.95}.cta-section .cta-button{background:#fff;color:var(--secondary-color);padding:var(--spacing-md) var(--spacing-2xl);font-weight:700}.error-container,.error-page{text-align:center;padding:var(--spacing-3xl) var(--spacing-xl);min-height:70vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.error-content{max-width:600px;margin:0 auto}.error-image{text-align:center;margin-bottom:var(--spacing-xl)}.error-character,.error-penguin-image{width:200px;height:auto;margin-bottom:var(--spacing-xl);animation:float 3s ease-in-out infinite;border-radius:15px;box-shadow:0 8px 20px #00000026}.error-code{font-size:8rem;font-weight:700;color:var(--secondary-color);margin-bottom:var(--spacing-md);text-shadow:2px 2px 4px rgba(0,0,0,.1)}.error-title{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-md);color:var(--text-color)}.error-description{font-size:var(--font-size-lg);color:var(--text-muted);margin-bottom:var(--spacing-xl);line-height:1.6}.terminal-mockup{background:var(--terminal-bg-solid);border-radius:var(--radius-lg);padding:var(--spacing-md);margin:var(--spacing-xl) auto;font-family:Courier New,monospace;color:var(--terminal-text-green);text-align:left;max-width:500px}.terminal-line{margin:var(--spacing-sm) 0}.terminal-mockup .prompt{color:var(--terminal-text-green)}.terminal-mockup .command{color:var(--terminal-text-white)}.error-output{color:var(--terminal-error)}.suggestions{background:var(--light-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin:var(--spacing-xl) 0}.suggestions h3{margin-bottom:var(--spacing-md);color:var(--text-color)}.suggestion-list{list-style:none;padding:0}.suggestion-list li{margin-bottom:var(--spacing-sm);padding:var(--spacing-sm);background:#fff;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.suggestion-list a{text-decoration:none;color:var(--secondary-color);font-weight:500}.suggestion-list a:hover{color:var(--accent-color)}.quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin:var(--spacing-xl) 0}.quick-link-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;transition:var(--transition-normal)}.quick-link-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.quick-link-card h4{margin-bottom:var(--spacing-sm);color:var(--text-color)}.quick-link-card p{color:var(--text-muted);font-size:var(--font-size-sm)}.quick-link-card a{text-decoration:none;color:inherit;display:block}.link-icon{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-sm)}.action-section{margin-top:var(--spacing-xl)}.action-buttons{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.btn-primary{background:var(--secondary-color);color:#fff;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);text-decoration:none;font-weight:500;transition:var(--transition-normal);border:none;cursor:pointer}.btn-primary:hover{background:#5a6fd8}.btn-secondary{background:#fff;color:var(--secondary-color);padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);text-decoration:none;border:2px solid var(--secondary-color);font-weight:500;transition:var(--transition-normal);cursor:pointer}.btn-secondary:hover{background:var(--secondary-color);color:#fff}.cookie-consent{position:fixed;bottom:0;left:0;right:0;background:#000000e6;color:#fff;padding:var(--spacing-xl);text-align:center;z-index:9999;box-shadow:0 -2px 10px #0000004d;border-top:2px solid var(--secondary-color)}.cookie-consent.hidden{display:none}.cookie-consent p{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-sm);line-height:1.5}.cookie-consent button{background:var(--secondary-color);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:700;cursor:pointer;margin-right:var(--spacing-md);transition:var(--transition-normal)}.cookie-consent button:hover{background:#5a6fd8}.cookie-consent a{color:#fff;text-decoration:underline;font-size:var(--font-size-xs);transition:var(--transition-normal)}.cookie-consent a:hover{color:#ccc}@media(max-width:768px){.hero-content{flex-direction:column;text-align:center;gap:var(--spacing-xl)}.hero-text{text-align:center}.hero-image{max-width:300px;margin:0 auto;text-align:center}.hero-title{font-size:var(--font-size-3xl)}.hero-buttons{gap:var(--spacing-md)}.hero-button-cta{font-size:1.1rem;padding:1rem 2rem;width:100%;text-align:center}.features-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.cookie-consent{padding:var(--spacing-md) var(--spacing-sm)}.cookie-consent p{font-size:var(--font-size-xs);margin-bottom:var(--spacing-sm)}.cookie-consent button{display:block;width:100%;margin:0 0 var(--spacing-sm) 0;padding:var(--spacing-sm)}.cookie-consent a{display:block;margin-top:var(--spacing-xs)}.error-code{font-size:6rem}.error-title{font-size:var(--font-size-2xl)}}@media(max-width:480px){.hero-section{padding:var(--spacing-2xl) var(--spacing-md);margin-bottom:var(--spacing-xl)}.features-section,.error-container{padding:var(--spacing-xl) var(--spacing-md)}.error-character{width:150px}.error-code{font-size:4rem}}.sitemap-section{margin-bottom:var(--spacing-2xl);padding:var(--spacing-xl);background:var(--light-color);border-radius:var(--radius-lg);border-left:4px solid var(--secondary-color)}.sitemap-section h2{color:var(--text-color);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.sitemap-section h3{color:#495057;margin:var(--spacing-lg) 0 var(--spacing-md) 0;font-size:var(--font-size-xl)}.search-section{background:var(--gradient-primary);color:#fff;padding:var(--spacing-xl);border-radius:var(--radius-lg);text-align:center;margin-bottom:var(--spacing-2xl)}.search-box{max-width:500px;margin:0 auto;display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.search-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base)}.search-button{padding:var(--spacing-sm) var(--spacing-lg);background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-base);transition:var(--transition-normal)}.search-button:hover{background:#ffffff4d}.recent-updates{background:#e3f2fd;border:1px solid #90caf9;border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.update-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid #bbdefb}.update-item:last-child{border-bottom:none}.update-date{color:#1976d2;font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;margin-left:var(--spacing-md)}.updates-header{cursor:pointer;display:flex;justify-content:space-between;align-items:center;margin:0 0 var(--spacing-md) 0;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.updates-header:hover{background-color:#90caf91a}.toggle-icon{font-size:var(--font-size-lg);transition:transform .3s ease;color:#1976d2}.toggle-icon.expanded{transform:rotate(180deg)}.updates-content{overflow:hidden;transition:max-height .4s ease-out,opacity .3s ease}.updates-content.collapsed{max-height:0;opacity:0;padding:0}.updates-content.expanded{max-height:800px;opacity:1;padding:var(--spacing-sm) 0 0 0}.update-item:hover{background-color:#90caf90d;border-radius:var(--radius-sm)}.show-more-btn{background:var(--gradient-primary);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;margin:var(--spacing-md) auto 0 auto;display:block;transition:all .2s ease;box-shadow:var(--shadow-sm)}.show-more-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.show-more-btn:active{transform:translateY(0)}@media(max-width:768px){.updates-header{padding:var(--spacing-xs) var(--spacing-sm)}.update-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.update-date{margin-left:0;font-size:var(--font-size-xs)}.show-more-btn{width:100%;margin:var(--spacing-sm) 0 0 0}}.guides-index{max-width:1200px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-md)}.guides-hero{background:var(--gradient-primary);color:#fff;padding:var(--spacing-2xl) var(--spacing-xl);border-radius:var(--radius-xl);text-align:center;margin-bottom:var(--spacing-2xl)}.guides-hero h1{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-md);font-weight:700}.guides-hero p{font-size:var(--font-size-xl);opacity:.9;max-width:600px;margin:0 auto}.guides-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.guide-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:0;overflow:hidden;transition:var(--transition-normal);text-decoration:none;color:inherit;display:block;position:relative;cursor:pointer}.guide-card>.guide-card-content>a[href]:last-child:after{content:"";position:absolute;inset:0;z-index:1}.guide-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.guide-card-image{width:100%;aspect-ratio:3 / 2;overflow:hidden;background:var(--gradient-primary);position:relative}.guide-card-image img{width:100%;height:100%;object-fit:cover;object-position:center center;transition:transform .3s ease}.guide-card:hover .guide-card-image img{transform:scale(1.05)}.guide-card-content{padding:var(--spacing-lg)}.guide-card-header{background:var(--gradient-primary);padding:var(--spacing-lg);color:#fff;display:flex;align-items:center;gap:var(--spacing-md)}.guide-number{background:#fff3;width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-xl)}.guide-card-body{padding:var(--spacing-xl)}.guide-card h3{margin-bottom:var(--spacing-sm);color:var(--text-color);font-size:1.3rem;font-weight:600}.guide-card p{color:var(--text-muted);line-height:1.6;margin-bottom:var(--spacing-md);font-size:.95rem}.guide-card a{color:var(--secondary-color);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:.25rem;transition:color .2s ease}.guide-card a:hover{color:var(--accent-color)}.guide-description{color:var(--text-muted);line-height:1.6}.guide-meta{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-muted)}.guide-meta span{display:flex;align-items:center;gap:var(--spacing-xs)}.learning-path{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow);margin-bottom:var(--spacing-2xl)}.path-step{display:flex;align-items:flex-start;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);position:relative}.path-step:not(:last-child):after{content:"";position:absolute;left:20px;top:50px;width:2px;height:calc(100% + var(--spacing-xl));background:var(--border-color)}.step-number{background:var(--gradient-primary);color:#fff;width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.step-content h4{margin-bottom:var(--spacing-sm)}.step-content p{color:var(--text-muted);line-height:1.6}.test-page-container{max-width:1200px;margin:0 auto;background:#fff;border-radius:var(--border-radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg)}.test-page-body{font-family:var(--font-family-primary);margin:var(--spacing-lg);background:var(--gradient-primary);color:var(--color-text);min-height:100vh}.test-page-title{text-align:center;color:var(--color-primary);margin-bottom:var(--spacing-2xl)}.test-controls{text-align:center;margin-bottom:var(--spacing-2xl)}.test-btn{background:var(--gradient-success);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--border-radius-md);cursor:pointer;font-size:var(--font-size-base);margin:0 var(--spacing-sm);transition:var(--transition-smooth)}.test-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #4caf504d}.test-btn.secondary{background:var(--gradient-info)}.test-btn.secondary:hover{box-shadow:0 5px 15px #2196f34d}.results-container{margin-top:var(--spacing-2xl)}.test-category{background:var(--color-bg-secondary);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg);border-left:4px solid var(--color-success)}.test-category.failed{border-left-color:var(--color-error)}.tutorials-index .category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.tutorials-index .category-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text)}.tutorials-index .category-stats{background:var(--color-success);color:#fff;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--border-radius-full);font-size:var(--font-size-sm);font-weight:600}.test-page .category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.test-page .category-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text)}.test-page .category-stats{background:var(--color-success);color:#fff;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--border-radius-full);font-size:var(--font-size-sm);font-weight:600}.category-stats.failed{background:var(--color-error)}.test-item{display:flex;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border-light)}.test-item:last-child{border-bottom:none}.test-status{width:24px;height:24px;margin-right:var(--spacing-md);font-size:var(--font-size-base)}.test-name{flex:1;color:var(--color-text-secondary)}.test-error{color:var(--color-error);font-size:var(--font-size-sm);margin-left:36px;font-style:italic}.overall-results{background:var(--gradient-success);color:#fff;padding:var(--spacing-lg);border-radius:var(--border-radius-lg);text-align:center;margin-bottom:var(--spacing-lg)}.overall-results.failed{background:var(--gradient-error)}.overall-percentage{font-size:var(--font-size-4xl);font-weight:700;margin-bottom:var(--spacing-sm)}.live-test-section{background:#e3f2fd;border-radius:var(--border-radius-md);padding:var(--spacing-lg);margin-top:var(--spacing-2xl)}.live-test-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-info);margin-bottom:var(--spacing-md)}.platform-test{display:inline-block;width:48%;margin:1%;vertical-align:top}.platform-title{background:var(--color-info);color:#fff;padding:var(--spacing-sm);text-align:center;border-radius:var(--border-radius-md) var(--border-radius-md) 0 0;font-weight:600}.platform-content{background:#fff;border:2px solid var(--color-info);border-top:none;border-radius:0 0 var(--border-radius-md) var(--border-radius-md);padding:var(--spacing-md);min-height:200px}#loading{text-align:center;color:var(--color-text-muted);font-style:italic;margin:var(--spacing-lg) 0}.e2e-container{max-width:1400px;margin:0 auto;background:#fff;border-radius:var(--border-radius-xl);overflow:hidden;box-shadow:0 20px 60px #00000026}.e2e-header{background:var(--gradient-primary);color:#fff;padding:var(--spacing-2xl);text-align:center}.e2e-header h1{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-sm);font-weight:700}.e2e-header p{font-size:var(--font-size-lg);opacity:.9}.e2e-controls{padding:var(--spacing-2xl);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.control-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.control-section{background:#fff;padding:var(--spacing-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border)}.control-title{font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-primary);font-size:var(--font-size-lg)}.btn{background:var(--gradient-primary);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;transition:var(--transition-smooth);margin:var(--spacing-xs);display:inline-block;text-decoration:none}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn.success{background:var(--gradient-success)}.btn.danger{background:var(--gradient-error)}.btn.warning{background:var(--gradient-warning)}.btn.info{background:var(--gradient-info)}.btn.secondary{background:var(--gradient-secondary)}.status-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:#fff;border-bottom:1px solid var(--color-border)}.status-left{display:flex;align-items:center;gap:var(--spacing-md)}.status-indicator{width:12px;height:12px;border-radius:50%;background:var(--color-text-muted)}.status-indicator.running{background:var(--color-warning);animation:pulse 1.5s infinite}.status-indicator.success{background:var(--color-success)}.status-indicator.error{background:var(--color-error)}.status-text{font-weight:500;color:var(--color-text)}.status-time{color:var(--color-text-muted);font-size:var(--font-size-sm)}.results-area{padding:var(--spacing-xl)}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:#fff;padding:var(--spacing-lg);border-radius:var(--border-radius-lg);border:1px solid var(--color-border);text-align:center;transition:var(--transition-smooth)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-value{font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--spacing-xs)}.stat-value.success{color:var(--color-success)}.stat-value.error{color:var(--color-error)}.stat-value.warning{color:var(--color-warning)}.stat-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500}.platform-comparison{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.platform-section{background:#fff;border:2px solid var(--color-border);border-radius:var(--border-radius-lg);overflow:hidden}.platform-header{background:var(--color-primary);color:#fff;padding:var(--spacing-md) var(--spacing-lg);font-weight:600;text-align:center}.platform-content{padding:var(--spacing-lg)}.quick-stat{display:flex;justify-content:space-between;margin:var(--spacing-sm) 0;padding:var(--spacing-sm) 0;border-bottom:1px solid #f0f0f0}.quick-stat:last-child{border-bottom:none}@media(max-width:768px){.e2e-container{margin:var(--spacing-sm);border-radius:var(--border-radius-lg)}.platform-comparison,.control-grid{grid-template-columns:1fr}.summary-stats{gap:var(--spacing-md)}.status-bar{flex-direction:column;align-items:flex-start}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.browser-test-container{max-width:1200px;margin:0 auto;background:#fff;border-radius:var(--border-radius-xl);overflow:hidden;box-shadow:0 20px 60px #00000026}.browser-test-header{background:var(--gradient-primary);color:#fff;padding:var(--spacing-2xl);text-align:center}.browser-test-header h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm)}.browser-test-header p{opacity:.9;font-size:var(--font-size-lg)}.browser-test-content{padding:var(--spacing-2xl)}.test-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.test-section h2{color:var(--color-primary);margin-bottom:var(--spacing-md);font-size:var(--font-size-xl)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg);margin:var(--spacing-lg) 0}.info-item{background:#fff;padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--color-border-light)}.info-label{font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.info-value{font-family:var(--font-family-mono);background:var(--color-bg-secondary);padding:var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);word-break:break-all}.device-status{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);font-weight:600;margin-left:var(--spacing-sm)}.device-status.mobile{background:#e8f5e8;color:var(--color-success)}.device-status.desktop{background:#e3f2fd;color:var(--color-info)}.browser-support{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin:var(--spacing-lg) 0}.browser-item{background:#fff;padding:var(--spacing-md);border-radius:var(--border-radius-md);text-align:center;border:1px solid var(--color-border);transition:var(--transition-smooth)}.browser-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.browser-icon{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm)}.browser-name{font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.browser-status{font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);font-weight:600}.browser-status.supported{background:#e8f5e8;color:var(--color-success)}.browser-status.partial{background:#fff8e6;color:var(--color-warning)}.browser-status.unsupported{background:#ffebee;color:var(--color-error)}.test-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg);flex-wrap:wrap}.browser-test-btn{background:var(--gradient-primary);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;transition:var(--transition-smooth);text-decoration:none;display:inline-block}.browser-test-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.browser-test-btn.success{background:var(--gradient-success)}.browser-test-btn.info{background:var(--gradient-info)}.browser-test-btn.warning{background:var(--gradient-warning)}@media(max-width:768px){.browser-test-container{margin:var(--spacing-sm);border-radius:var(--border-radius-lg)}.browser-test-content{padding:var(--spacing-lg)}.test-actions{flex-direction:column}.browser-test-btn{width:100%;text-align:center}}.hidden{display:none!important}.free-terminal-section{margin:var(--spacing-section) 0;padding:var(--spacing-xl);background:var(--background-light);border-radius:var(--border-radius-lg)}.free-terminal-header{margin-bottom:var(--spacing-xl)}.free-terminal-intro{display:flex;align-items:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.free-terminal-text{flex:1}.free-terminal-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--primary-color);margin:0 0 var(--spacing-sm) 0}.free-terminal-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);margin:0 0 var(--spacing-sm) 0;font-weight:500}.free-terminal-description{color:var(--text-muted);line-height:1.6;margin:0}.free-terminal-character{flex-shrink:0}.free-terminal-character-image{width:120px;height:auto;object-fit:contain;border:3px solid var(--primary-light)}.terminal-wrapper{background:var(--dark-color);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-terminal)}@media(max-width:768px){.free-terminal-intro{flex-direction:column;text-align:center}.free-terminal-character-image{width:100px;height:100px}.free-terminal-section{padding:var(--spacing-lg)}}.lesson-filter{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.filter-btn{background:var(--background-secondary);border:2px solid var(--border-color);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .3s ease;text-align:center;min-width:60px}.filter-btn:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.filter-btn.active{background:var(--gradient-primary);border-color:var(--primary-color);color:#fff;box-shadow:var(--shadow-sm)}.filter-btn:focus{outline:none;box-shadow:0 0 0 3px var(--primary-light)}.achievement-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--gradient-primary);color:#fff;padding:var(--spacing-xl);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-popup);z-index:1000;text-align:center;min-width:300px;max-width:90vw;animation:achievementSlideIn .5s ease-out}.achievement-popup.hidden{display:none}.achievement-image{margin-bottom:var(--spacing-md);display:flex;justify-content:center;align-items:center}.achievement-image img{width:150px;height:150px;border-radius:15px;object-fit:cover;border:3px solid rgba(255,255,255,.3);box-shadow:0 8px 15px #0003}.achievement-content h3{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-xl)}.achievement-content p{margin:0;font-size:var(--font-size-lg)}.achievement-buttons{margin-top:var(--spacing-lg);display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.achievement-btn{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-md);font-size:var(--font-size-md);cursor:pointer;transition:all .3s ease;min-height:44px;min-width:140px}.achievement-btn-primary{background:#ffffffe6;color:var(--primary-color);font-weight:600}.achievement-btn-primary:hover{background:#fff;transform:translateY(-2px)}.achievement-btn-primary:active{transform:translateY(0)}.achievement-btn-secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.5)}.achievement-btn-secondary:hover{background:#ffffff4d}.achievement-btn-secondary:active{background:#fff6}@media(max-width:768px){.achievement-popup{min-width:280px;max-width:95vw;padding:var(--spacing-lg)}.achievement-image img{width:120px;height:120px}.achievement-content h3{font-size:var(--font-size-lg)}.achievement-content p{font-size:var(--font-size-md)}}@media(max-width:480px){.achievement-buttons{flex-direction:column;gap:var(--spacing-sm)}.achievement-btn{width:100%;min-width:unset;font-size:var(--font-size-sm)}}@media(min-width:481px)and (max-width:768px){.achievement-btn{min-width:120px;font-size:var(--font-size-sm)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes achievementSlideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.footer-noscript{background:var(--gradient-primary);color:#fff;padding:2rem 1rem;text-align:center;margin-top:auto}.footer-noscript nav{margin-bottom:1rem}.footer-noscript nav a{color:#ffffffe6;text-decoration:none;margin:0 .5rem}.footer-noscript nav a:hover{color:#fff;text-decoration:underline}.footer-noscript p{color:#ffffffb3;font-size:var(--font-size-sm);margin:0}
