*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#8b4513;--secondary-color:#d2691e;--accent-color:peru;--background:#f8f9fa;--surface:#fff;--text-primary:#333;--text-secondary:#555;--border-color:#e2e8f0;--success:#4ade80;--error:#ef4444;--border-radius:8px}body{background-color:var(--background);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.navbar{background-color:var(--surface);border-bottom:1px solid var(--border-color);z-index:100;padding:1rem 0;position:sticky;top:0;box-shadow:0 2px 4px #0000000d}.navbar .container{justify-content:space-between;align-items:center;display:flex}.logo{color:var(--primary-color);font-size:1.5rem;font-weight:700;text-decoration:none}.nav-links{gap:1.5rem;display:flex}.nav-links a{color:var(--text-secondary);font-weight:500;text-decoration:none;transition:color .3s}.nav-links a:hover,.nav-links a.active{color:var(--primary-color)}.main-content{min-height:calc(100vh - 80px);padding:2rem 1rem}.hero{text-align:center;padding:4rem 0}.hero h1{color:#2d3748;margin-bottom:1rem;font-size:3rem}.subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:1.25rem}.cta-buttons{justify-content:center;gap:1rem;margin-top:2rem;display:flex}.features{max-width:1200px;margin:4rem auto;padding:0 1rem}.features h2{text-align:center;color:#2d3748;margin-bottom:2rem;font-size:2rem}.features-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;display:grid}.feature-card{background-color:var(--surface);border-radius:var(--border-radius);text-align:center;border:1px solid var(--border-color);padding:2rem;box-shadow:0 2px 4px #0000000d}.feature-card h3{color:var(--primary-color);margin-bottom:1rem}.btn{border-radius:var(--border-radius);cursor:pointer;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-block}.btn-primary:hover{background-color:var(--secondary-color)}.btn-secondary{color:var(--primary-color);border:2px solid var(--primary-color);background-color:#0000}.btn-secondary:hover{background-color:var(--primary-color);color:#fff}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.login-page,.register-page{justify-content:center;align-items:center;min-height:calc(100vh - 80px);display:flex}.login-container,.register-container{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);width:100%;max-width:400px;padding:2rem;box-shadow:0 4px 6px #0000000d}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;display:block}.form-input{background-color:var(--background);border-radius:var(--border-radius);width:100%;color:var(--text-primary);border:1px solid #cbd5e0;padding:.75rem;font-size:1rem}.form-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #8b45131a}.error-message{color:var(--error);border-radius:var(--border-radius);background-color:#fff5f5;border:1px solid #feb2b2;margin-bottom:1rem;padding:.75rem}.text-center{text-align:center;color:var(--text-secondary);margin-top:1rem}.text-center a{color:var(--primary-color);text-decoration:none}.text-center a:hover{text-decoration:underline}.challenges-page{max-width:1200px;margin:0 auto}.challenges-page-white-theme{background-color:var(--background);color:var(--text-primary);min-height:calc(100vh - 80px);padding-top:2rem;padding-bottom:2rem}.header-section{text-align:center;margin-bottom:3rem}.header-section h1{color:#2d3748;margin-bottom:1rem;font-size:2.5rem}.header-section p{color:var(--text-secondary);font-size:1.1rem}.challenge-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;display:grid}.challenge-card-link{color:inherit;text-decoration:none;display:block}.challenge-card{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);flex-direction:column;height:100%;padding:1.5rem;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px #0000000d}.challenge-card:hover{border-color:var(--primary-color);transform:translateY(-5px);box-shadow:0 10px 15px #0000001a}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.category-badge{color:#4a5568;text-transform:uppercase;letter-spacing:.5px;background-color:#f0f4f8;border:1px solid #cbd5e0;border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.difficulty-badge{font-size:.8rem;font-weight:700}.difficulty-easy{color:#38a169}.difficulty-medium{color:#d69e2e}.difficulty-hard{color:#e53e3e}.difficulty-expert{color:#c53030}.difficulty-extreme{color:#805ad5}.challenge-card h3{color:var(--text-primary);margin-bottom:.75rem;font-size:1.25rem;font-weight:700}.challenge-card .description{color:var(--text-secondary);flex-grow:1;margin-bottom:1.5rem;font-size:.9rem;line-height:1.6}.card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.points{color:var(--accent-color);font-size:1.1rem;font-weight:700}.status-completed{color:var(--success);align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;display:flex}.status-open{color:var(--primary-color);font-size:.9rem;font-weight:700;transition:transform .2s}.challenge-card:hover .status-open{transform:translate(4px)}.filters-section{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);flex-wrap:wrap;justify-content:flex-start;gap:2rem;margin-bottom:2rem;padding:1.5rem;display:flex;box-shadow:0 2px 4px #0000000d}.filter-group{align-items:center;gap:1rem;display:flex}.filter-group label{color:var(--text-secondary);min-width:fit-content;margin-bottom:0;font-weight:600}.filter-group select{border:1px solid var(--border-color);border-radius:var(--border-radius);background-color:var(--background);color:var(--text-primary);cursor:pointer;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23333%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-position:right .7rem top 50%;background-repeat:no-repeat;background-size:.65rem;padding:.5rem 2rem .5rem 1rem;font-size:1rem}.filter-group select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #8b45131a}.filter-buttons{flex-wrap:wrap;gap:.5rem;display:flex}.filter-btn{border:1px solid var(--border-color);background-color:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;padding:.5rem 1rem;font-size:.9rem;transition:all .2s}.filter-btn:hover{border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.filter-btn.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 2px 4px #8b451333}.fade-in{animation:.5s ease-out forwards fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;color:var(--text-secondary);background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);grid-column:1/-1;padding:4rem;font-size:1.2rem}.challenge-detail-page{max-width:900px;margin:0 auto;padding:2rem 1rem}.challenge-detail{animation:.3s ease-out fadeIn}.challenge-header{margin-bottom:2rem}.challenge-header .challenge-meta{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.challenge-header .challenge-meta .category{background-color:var(--primary-color);color:#fff;border-radius:20px;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.challenge-header .challenge-meta .difficulty{color:#f59e0b;letter-spacing:2px;font-size:1rem}.challenge-header .challenge-meta .points{background-color:var(--accent-color);color:#fff;border-radius:20px;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.challenge-header .challenge-meta .completed-badge{background-color:var(--success);color:#fff;border-radius:20px;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.challenge-title{color:#2d3748;margin-bottom:.5rem;font-size:2rem}.challenge-title-en{color:var(--text-secondary);margin:0;font-size:1rem}.challenge-detail .tags{flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;display:flex}.challenge-detail .tag{color:#4a5568;border:1px solid var(--border-color);background-color:#f0f4f8;border-radius:20px;padding:.25rem .75rem;font-size:.8rem}.challenge-description{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:2rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.challenge-description h2{color:#2d3748;border-bottom:2px solid var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem}.description-content p{margin-bottom:.75rem;line-height:1.8}.description-content p:last-child{margin-bottom:0}.required-knowledge{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:2rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.required-knowledge h2{color:#2d3748;border-bottom:2px solid var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem}.required-knowledge ul{list-style:none}.required-knowledge li{background-color:var(--background);border-radius:var(--border-radius);margin-bottom:.5rem;padding:.75rem}.required-knowledge li:last-child{margin-bottom:0}.required-knowledge li strong{color:var(--primary-color);margin-bottom:.25rem;display:block}.required-knowledge li p{color:var(--text-secondary);margin:0;font-size:.9rem}.hints-section{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:2rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.hints-section h2{color:#2d3748;border-bottom:2px solid var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem}.hints-list{flex-direction:column;gap:.75rem;display:flex}.hint-item{border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.hint-toggle{background-color:var(--background);text-align:left;cursor:pointer;width:100%;color:var(--text-primary);border:none;padding:.75rem 1rem;font-size:.95rem;transition:background-color .2s}.hint-toggle:hover{background-color:#e2e8f0}.hint-content{color:#92400e;background-color:#fffbeb;max-height:0;padding:0;transition:all .3s;overflow:hidden}.hint-content.visible{max-height:500px;padding:1rem}.terminal-section{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:2rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.terminal-section h2{color:#2d3748;border-bottom:2px solid var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem}.terminal-section p{color:var(--text-secondary);margin-bottom:1rem}.terminal-button{color:#48bb78;border-radius:var(--border-radius);cursor:pointer;background-color:#1a202c;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.terminal-button:hover{background-color:#2d3748;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.flag-submission{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:2rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.flag-submission h2{color:#2d3748;border-bottom:2px solid var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem}.flag-form{gap:1rem;margin-top:1rem;display:flex}.flag-input{border:2px solid var(--border-color);border-radius:var(--border-radius);background-color:var(--background);color:var(--text-primary);flex:1;padding:.75rem 1rem;font-family:Courier New,monospace;font-size:1rem;transition:border-color .2s}.flag-input:focus{border-color:var(--primary-color);outline:none}.flag-input::placeholder{color:#a0aec0}.submit-button{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.submit-button:hover:not(:disabled){background-color:var(--secondary-color);transform:translateY(-2px)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.submit-result{border-radius:var(--border-radius);align-items:center;gap:.5rem;margin-top:1rem;padding:1rem;font-weight:500;display:flex}.submit-result .icon{font-size:1.25rem}.submit-result.success{color:#065f46;background-color:#d1fae5;border:1px solid #6ee7b7}.submit-result.incorrect{color:#991b1b;background-color:#fee2e2;border:1px solid #fca5a5}.submit-result.error{color:#92400e;background-color:#fef3c7;border:1px solid #fcd34d}.submit-result .points-earned{color:#047857;font-weight:700}.back-section{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1rem}.back-link{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color .2s}.back-link:hover{color:var(--secondary-color);text-decoration:underline}.challenge-environment{background-color:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:2rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.challenge-environment h2{color:#2d3748;border-bottom:2px solid var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem}.environment-error{color:#92400e;border-radius:var(--border-radius);background-color:#fef3c7;border:1px solid #fcd34d;align-items:center;gap:.5rem;margin-bottom:1rem;padding:1rem;display:flex}.environment-inactive{text-align:center;padding:1rem}.environment-description{color:var(--text-secondary);margin-bottom:1rem}.start-button{color:#48bb78;border-radius:var(--border-radius);cursor:pointer;background-color:#1a202c;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.start-button:hover:not(:disabled){background-color:#2d3748;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.start-button:disabled{opacity:.6;cursor:not-allowed}.environment-active{padding:1rem}.session-info{margin-bottom:1.5rem}.session-status{color:#065f46;margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.session-id{color:var(--text-secondary);font-size:.9rem}.session-id code{background-color:var(--background);border-radius:4px;padding:.25rem .5rem;font-family:Courier New,monospace;font-size:.85rem}.web-access,.terminal-access{margin-bottom:1rem}.web-access .btn,.terminal-access .btn{border-radius:var(--border-radius);padding:.75rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--secondary-color);transform:translateY(-2px)}.btn-terminal{color:#48bb78;background-color:#1a202c}.btn-terminal:hover{background-color:#2d3748;transform:translateY(-2px)}.url-hint{color:var(--text-secondary);margin-top:.5rem;font-family:Courier New,monospace;font-size:.85rem}@media (width<=768px){.challenge-title{font-size:1.5rem}.flag-form{flex-direction:column}.submit-button,.start-button{width:100%}}.dashboard-page{max-width:1200px;margin:0 auto}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{background-color:var(--surface);border-radius:var(--border-radius);text-align:center;border:1px solid var(--border-color);padding:1.5rem;box-shadow:0 2px 4px #0000000d}.stat-value{color:var(--primary-color);margin-top:.5rem;font-size:2rem;font-weight:700}.terminal-container{border-radius:var(--border-radius);background-color:#1a202c;overflow:hidden;box-shadow:0 4px 6px #0000001a}.terminal-header{color:#e2e8f0;background-color:#2d3748;padding:.5rem 1rem;font-weight:500}.terminal-body{color:#48bb78;min-height:400px;padding:1rem;font-family:Courier New,monospace}.loading{text-align:center;color:var(--text-secondary);padding:2rem}.not-found-page{text-align:center;padding:4rem 1rem}.not-found-page h1{color:var(--primary-color);margin-bottom:1rem;font-size:4rem}.tooltip-term{cursor:help;border-bottom:1px dotted var(--primary-color);color:var(--primary-color);font-weight:500;position:relative}.tooltip-term:after{content:attr(data-tooltip);color:#f0f4f8;border-radius:var(--border-radius);white-space:normal;text-align:left;opacity:0;visibility:hidden;z-index:1000;pointer-events:none;background-color:#1a202c;width:max-content;max-width:300px;margin-bottom:8px;padding:.75rem 1rem;font-size:.85rem;font-weight:400;line-height:1.5;transition:opacity .2s,visibility .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}.tooltip-term:before{content:"";opacity:0;visibility:hidden;z-index:1001;border:6px solid #0000;border-top-color:#1a202c;margin-bottom:-4px;transition:opacity .2s,visibility .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.tooltip-term:hover:after,.tooltip-term:hover:before{opacity:1;visibility:visible}.terminal-page{max-width:1000px;margin:0 auto;padding:2rem}.terminal-page .terminal-header{border-bottom:2px solid var(--primary-color);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.terminal-page .terminal-header h1{color:var(--text-primary);margin:0;font-size:1.5rem}.terminal-page .session-info{align-items:center;gap:1rem;display:flex}.terminal-page .session-id{color:var(--text-secondary);font-family:monospace;font-size:.85rem}.terminal-page .status{border-radius:1rem;padding:.25rem .75rem;font-size:.8rem;font-weight:500}.terminal-page .status.connected{color:#155724;background-color:#d4edda}.terminal-page .status.disconnected{color:#721c24;background-color:#f8d7da}.terminal-page .terminal-error{color:#dc2626;border-radius:var(--border-radius);background-color:#fee2e2;margin-bottom:1rem;padding:1rem}.terminal-page .connect-section{text-align:center;margin-bottom:1rem;padding:2rem}.terminal-page .connect-btn{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:1rem 2rem;font-size:1.1rem;transition:background-color .2s}.terminal-page .connect-btn:hover{background-color:var(--primary-hover)}.terminal-page .terminal-output{color:#0f0;border-radius:var(--border-radius);background-color:#1a1a2e;min-height:400px;max-height:500px;margin-bottom:1rem;padding:1rem;font-family:Courier New,Courier,monospace;overflow-y:auto}.terminal-page .terminal-output pre{white-space:pre-wrap;word-wrap:break-word;margin:0;font-size:.9rem;line-height:1.5}.terminal-page .terminal-input-area{border-radius:var(--border-radius);background-color:#1a1a2e;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.terminal-page .prompt{color:#0f0;font-family:Courier New,Courier,monospace;font-weight:700}.terminal-page .terminal-input{color:#0f0;background-color:#0000;border:none;outline:none;flex:1;font-family:Courier New,Courier,monospace;font-size:.95rem}.terminal-page .terminal-input::placeholder{color:#4a5568}.terminal-page .send-btn{background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;padding:.5rem 1rem;transition:background-color .2s}.terminal-page .send-btn:hover{background-color:var(--primary-hover)}.terminal-page .back-section{text-align:center;margin-top:2rem}.terminal-page .back-link{color:var(--primary-color);text-decoration:none}.terminal-page .back-link:hover{text-decoration:underline}@media (width<=768px){.hero h1{font-size:2rem}.cta-buttons{flex-direction:column}.challenges-grid{grid-template-columns:1fr}.flag-submission form{flex-direction:column}.tooltip-term:after{max-width:250px;font-size:.8rem}.terminal-page{padding:1rem}.terminal-page .terminal-header{flex-direction:column;align-items:flex-start;gap:1rem}.terminal-page .terminal-output{min-height:300px}}.terminal-page-fullscreen{z-index:9999;background:#1a1a2e;flex-direction:column;display:flex;position:fixed;inset:0}.terminal-toolbar{background:#16213e;border-bottom:1px solid #0f3460;align-items:center;gap:1rem;padding:.5rem 1rem;display:flex}.terminal-toolbar .back-button{color:#e0e0e0;background:#0f3460;border-radius:4px;padding:.4rem .8rem;font-size:.9rem;text-decoration:none;transition:background .2s}.terminal-toolbar .back-button:hover{background:#1a4a7a}.terminal-toolbar .session-badge{color:#8be9fd;font-family:Menlo,Monaco,Courier New,monospace;font-size:.85rem}.terminal-container{flex:1;padding:.5rem;overflow:hidden}.terminal-container .xterm{height:100%}.terminal-container .xterm-viewport{overflow-y:auto!important}.terminal-modal-overlay{z-index:10000;background:#000000b3;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.terminal-modal{background:#1a1a2e;border:1px solid #0f3460;border-radius:12px;flex-direction:column;width:90%;max-width:1000px;height:80vh;max-height:600px;display:flex;box-shadow:0 20px 60px #00000080}.terminal-modal-header{background:#16213e;border-bottom:1px solid #0f3460;border-radius:12px 12px 0 0;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.terminal-modal-title{color:#e0e0e0;font-size:1rem;font-weight:700}.terminal-modal-session{color:#8be9fd;flex:1;font-family:Menlo,Monaco,Courier New,monospace;font-size:.85rem}.terminal-modal-close{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;transition:background .2s;display:flex}.terminal-modal-close:hover{background:#c0392b}.terminal-modal-body{flex:1;padding:.5rem;overflow:hidden}.terminal-modal-body .xterm{height:100%}.terminal-modal-body .xterm-viewport{overflow-y:auto!important}@media (width<=768px){.terminal-modal-overlay{padding:1rem}.terminal-modal{border-radius:8px;width:100%;height:70vh}.terminal-modal-header{border-radius:8px 8px 0 0;flex-wrap:wrap}.terminal-modal-session{order:3;width:100%;margin-top:.5rem}}