:root{--bg-dark:#0f0f1a;--bg-card:#1a1a2e;--bg-sidebar:#141425;--accent:#0f3460;--highlight:#e94560;--highlight-light:#ff6b81;--text-primary:#e0e0e0;--text-secondary:#a0a0b0;--text-heading:#fff;--border-color:#2a2a4a;--code-bg:#0d1117;--sidebar-width:280px;--success:#4caf50;--warning-bg:#3e2723;--warning-border:#ff9800;--tip-bg:#1b3a2a;--tip-border:#4caf50;--concept-bg:#1a2744;--concept-border:#5c6bc0;--example-bg:#1a2e1a;--example-border:#66bb6a;--game-bg:#1a1a3e;--game-border:#7c4dff;--game-success:#00e676;--game-error:#ff5252}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg-dark);color:var(--text-primary);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.7}h1,h2,h3,h4,h5,h6{color:var(--text-heading);margin-bottom:.8em;line-height:1.3}h1{font-size:2.2rem;font-weight:700}h2{border-bottom:2px solid var(--highlight);margin-top:2em;padding-bottom:.4em;font-size:1.7rem;font-weight:600}h3{color:#c0c0e0;margin-top:1.5em;font-size:1.3rem;font-weight:600}h4{margin-top:1.2em;font-size:1.1rem;font-weight:600}p{margin-bottom:1em}a{color:var(--highlight);text-decoration:none;transition:color .2s}a:hover{color:var(--highlight-light);text-decoration:underline}ul,ol{margin-bottom:1em;padding-left:1.5em}li{margin-bottom:.4em}strong{color:var(--text-heading)}.page-wrapper{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);z-index:100;height:100vh;padding:1.5rem 0;transition:transform .3s;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-header{border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding:0 1.2rem 1.2rem}.sidebar-header h2{color:var(--highlight);border:none;align-items:center;gap:.5rem;margin:0;padding:0;font-size:1.1rem;display:flex}.sidebar-header a{color:var(--highlight);align-items:center;gap:.5rem;display:flex}.sidebar-header a:hover{color:var(--highlight-light);text-decoration:none}.sidebar nav ul{margin:0;padding:0;list-style:none}.sidebar nav ul li a{color:var(--text-secondary);border-left:3px solid #0000;padding:.6rem 1.2rem;font-size:.9rem;transition:all .2s;display:block}.sidebar nav ul li a:hover,.sidebar nav ul li a.active{color:var(--text-heading);border-left-color:var(--highlight);background-color:#0f346080;text-decoration:none}.sidebar nav ul li a.active{background-color:#e9456026}.main-content{margin-left:var(--sidebar-width);flex:1;max-width:950px;padding:2rem 3rem}.hamburger{z-index:200;background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;color:var(--text-heading);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:.5rem .7rem;font-size:1.4rem;line-height:1;display:none;position:fixed;top:1rem;left:1rem}.sidebar-overlay{z-index:90;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;display:none;position:fixed;inset:0}.sidebar-overlay.active{display:block}.hero{text-align:center;padding:3rem 1rem}.hero h1{background:linear-gradient(135deg, var(--highlight), var(--highlight-light), #ff9a9e);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.3em;font-size:2.8rem}.hero .subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:1.2rem}.progress-container{max-width:600px;margin:0 auto 3rem}.progress-label{color:var(--text-secondary);justify-content:space-between;margin-bottom:.5rem;font-size:.85rem;display:flex}.progress-bar{background:var(--border-color);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--highlight), var(--highlight-light));border-radius:4px;width:0%;height:100%;transition:width .5s}.chapters-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1rem 0;display:grid}.chapter-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;border-radius:12px;flex-direction:column;padding:1.5rem;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex}.chapter-card:hover{border-color:var(--highlight);transform:translateY(-4px);box-shadow:0 8px 25px #e9456026}.chapter-card .card-icon{margin-bottom:.8rem;font-size:2.2rem}.chapter-card h3{color:var(--text-heading);margin-top:0;font-size:1.1rem}.chapter-card p{color:var(--text-secondary);flex:1;font-size:.9rem}.chapter-card .card-link{background:var(--accent);color:var(--text-heading);text-align:center;border-radius:8px;margin-top:1rem;padding:.5rem 1.2rem;font-size:.85rem;font-weight:500;transition:background .2s,transform .1s;display:inline-block}.chapter-card .card-link:hover{background:var(--highlight);text-decoration:none;transform:scale(1.02)}.concept-box,.example-box,.warning-box,.tip-box{border-left:4px solid;border-radius:10px;margin:1.2em 0;padding:1.2rem 1.5rem}.concept-box{background:var(--concept-bg);border-color:var(--concept-border)}.example-box{background:var(--example-bg);border-color:var(--example-border)}.warning-box{background:var(--warning-bg);border-color:var(--warning-border)}.tip-box{background:var(--tip-bg);border-color:var(--tip-border)}.concept-box .box-title,.example-box .box-title,.warning-box .box-title,.tip-box .box-title{margin-bottom:.5em;font-size:.95rem;font-weight:600}.concept-box .box-title{color:var(--concept-border)}.example-box .box-title{color:var(--example-border)}.warning-box .box-title{color:var(--warning-border)}.tip-box .box-title{color:var(--tip-border)}.code-block{background:var(--code-bg);border:1px solid var(--border-color);border-radius:10px;margin:1em 0;padding:1.2rem 1.5rem;font-family:Cascadia Code,Fira Code,Consolas,Monaco,monospace;font-size:.88rem;line-height:1.6;position:relative;overflow-x:auto}.code-block:before{content:"Python";background:var(--accent);color:var(--text-secondary);border-radius:0 10px 0 8px;padding:.15rem .7rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.7rem;position:absolute;top:0;right:0}.code-block code{color:var(--text-primary);white-space:pre}code{color:#dcdcaa;background:#0f346066;border-radius:4px;padding:.15em .4em;font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.88em}.kw{color:#569cd6}.fn{color:#dcdcaa}.str{color:#6aab73}.cm{color:#6a737d;font-style:italic}.num{color:#ce9178}.op{color:#d4d4d4}.dec{color:#c586c0}table{border-collapse:collapse;width:100%;margin:1.2em 0;font-size:.92rem}th,td{text-align:left;border:1px solid var(--border-color);padding:.75rem 1rem}th{background:var(--accent);color:var(--text-heading);font-weight:600}td{background:var(--bg-card)}tr:hover td{background:#0f34604d}.chapter-header{border-bottom:2px solid var(--border-color);margin-bottom:2rem;padding-bottom:1rem}.chapter-header .chapter-number{color:var(--highlight);text-transform:uppercase;letter-spacing:.1em;font-size:.9rem;font-weight:600}.chapter-header h1{margin-top:.3em}.objectives{background:var(--bg-card);border:1px solid var(--accent);border-radius:12px;margin-bottom:2rem;padding:1.5rem}.objectives h3{color:var(--highlight);margin-top:0;font-size:1.1rem}.objectives ul{margin-bottom:0}.objectives li{color:var(--text-secondary)}.chapter-nav{border-top:1px solid var(--border-color);justify-content:space-between;gap:1rem;margin-top:3rem;padding-top:1.5rem;display:flex}.chapter-nav a{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);border-radius:10px;align-items:center;gap:.5rem;padding:.7rem 1.2rem;font-size:.9rem;transition:border-color .2s,background .2s,transform .1s;display:inline-flex}.chapter-nav a:hover{border-color:var(--highlight);background:#e945601a;text-decoration:none;transform:translateY(-1px)}.exercises-section{background:var(--bg-card);border:1px solid var(--highlight);border-radius:12px;margin-top:2rem;padding:1.5rem}.exercises-section h3{color:var(--highlight);margin-top:0}.exercises-section ul{margin-bottom:0}.takeaways{border:1px solid var(--accent);background:linear-gradient(135deg,#0f34604d,#e945601a);border-radius:12px;margin-top:2rem;padding:1.5rem}.takeaways h3{color:var(--text-heading);margin-top:0}.game-section{background:linear-gradient(135deg, var(--game-bg), #7c4dff14);border:2px solid var(--game-border);border-radius:16px;margin:2rem 0;padding:2rem;position:relative;overflow:hidden}.game-section:before{content:"";pointer-events:none;background:radial-gradient(circle,#7c4dff0d,#0000);width:100%;height:100%;position:absolute;top:-50%;right:-50%}.game-section h3{color:var(--game-border);align-items:center;gap:.5rem;margin-top:0;font-size:1.3rem;display:flex}.game-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:.2rem .6rem;font-size:.7rem;font-weight:700;display:inline-block}.badge-fill{color:#b388ff;background:#7c4dff33}.badge-fix{color:#ff8a80;background:#ff525233}.badge-order{color:#ffcc80;background:#ff980033}.badge-qcm{color:#69f0ae;background:#00e67633}.fill-blank-code{background:var(--code-bg);border:1px solid var(--border-color);white-space:pre-wrap;border-radius:10px;margin:1rem 0;padding:1.5rem;font-family:Cascadia Code,Fira Code,monospace;font-size:.9rem;line-height:1.8}.blank-input{border:2px dashed var(--game-border);color:var(--text-heading);background:#7c4dff26;border-radius:6px;outline:none;min-width:100px;padding:.2rem .5rem;font-family:Cascadia Code,Fira Code,monospace;font-size:.85rem;transition:all .2s}.blank-input:focus{border-color:var(--highlight);background:#e9456026;box-shadow:0 0 8px #e945604d}.blank-input.correct{border-color:var(--game-success);background:#00e67626;border-style:solid}.blank-input.incorrect{border-color:var(--game-error);background:#ff525226;animation:.3s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.drag-container{flex-direction:column;gap:.5rem;margin:1rem 0;display:flex}.drag-item{background:var(--code-bg);border:1px solid var(--border-color);cursor:grab;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:.8rem;padding:.8rem 1rem;font-family:Cascadia Code,Fira Code,monospace;font-size:.85rem;transition:all .2s;display:flex}.drag-item:active{cursor:grabbing}.drag-item:hover{border-color:var(--game-border);background:#7c4dff1a}.drag-handle{color:var(--text-secondary);flex-shrink:0;font-size:1.2rem}.drag-item.dragging{opacity:.5;transform:scale(.98)}.drag-item.correct-position{border-color:var(--game-success);background:#00e67614}.drag-item.wrong-position{border-color:var(--game-error);background:#ff525214}.qcm-options{flex-direction:column;gap:.6rem;margin:1rem 0;display:flex}.qcm-option{background:var(--bg-card);border:2px solid var(--border-color);cursor:pointer;color:var(--text-primary);border-radius:10px;align-items:center;gap:.8rem;padding:.8rem 1.2rem;font-size:.92rem;transition:all .2s;display:flex}.qcm-option:hover{border-color:var(--game-border);background:#7c4dff14}.qcm-option.selected{border-color:var(--game-border);background:#7c4dff26}.qcm-option.correct{border-color:var(--game-success);background:#00e6761f}.qcm-option.wrong{border-color:var(--game-error);background:#ff52521f}.qcm-letter{background:var(--accent);width:28px;height:28px;color:var(--text-heading);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.bug-editor{background:var(--code-bg);border:1px solid var(--border-color);border-radius:10px;margin:1rem 0;overflow:hidden}.bug-editor-header{border-bottom:1px solid var(--border-color);color:var(--game-error);background:#ff525226;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.8rem;font-weight:600;display:flex}.bug-editor textarea{width:100%;color:var(--text-primary);resize:vertical;background:0 0;border:none;outline:none;min-height:150px;padding:1rem 1.5rem;font-family:Cascadia Code,Fira Code,monospace;font-size:.88rem;line-height:1.6}.game-btn{background:linear-gradient(135deg, var(--game-border), #651fff);color:#fff;cursor:pointer;border:none;border-radius:10px;margin-top:.5rem;padding:.7rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s}.game-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #7c4dff66}.game-btn:active{transform:translateY(0)}.game-btn.success{background:linear-gradient(135deg, var(--game-success), #00c853)}.game-btn.reset{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary)}.game-btn.reset:hover{border-color:var(--text-secondary);box-shadow:none}.game-feedback{border-radius:10px;align-items:center;gap:.5rem;margin-top:1rem;padding:.8rem 1.2rem;font-weight:500;animation:.3s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.game-feedback.success{border:1px solid var(--game-success);color:var(--game-success);background:#00e6761f}.game-feedback.error{border:1px solid var(--game-error);color:var(--game-error);background:#ff52521f}.game-feedback.hint{border:1px solid var(--warning-border);color:var(--warning-border);background:#ff98001f}.score-display{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:.8rem 1.2rem;display:flex}.score-bar{background:var(--border-color);border-radius:4px;flex:1;height:8px;overflow:hidden}.score-fill{background:linear-gradient(90deg, var(--game-border), var(--game-success));border-radius:4px;height:100%;transition:width .5s}.score-text{color:var(--game-border);white-space:nowrap;font-size:.9rem;font-weight:700}.exercise-play-btn{background:linear-gradient(135deg, var(--game-border), #651fff);color:#fff;border-radius:10px;align-items:center;gap:.5rem;margin-top:.5rem;padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:inline-flex}.exercise-play-btn:hover{color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 4px 15px #7c4dff66}@media (width<=900px){.main-content{margin-left:0;padding:4rem 1.5rem 2rem}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.hamburger{display:block}.hero h1{font-size:1.8rem}.chapters-grid{grid-template-columns:1fr}.chapter-nav{flex-direction:column}h1{font-size:1.6rem}h2{font-size:1.3rem}.game-section{padding:1.2rem}}@media (width<=480px){.main-content{padding:4rem 1rem 1.5rem}.code-block,.fill-blank-code{padding:.8rem 1rem;font-size:.8rem}table{font-size:.8rem}th,td{padding:.5rem}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--highlight)}::selection{color:var(--text-heading);background:#e945604d}
