:root{--bg-color:#0b0f19;--bg-gradient:radial-gradient(circle at 10% 20%, #3b82f640 0%, transparent 50%), radial-gradient(circle at 90% 80%, #8b5cf640 0%, transparent 50%);--text-color:#f8fafc;--text-muted:#94a3b8;--card-bg:#1e293b80;--card-bg-hover:#1e293bcc;--card-border:#ffffff1a;--card-border-hover:#fff3;--header-bg:#0b0f19bf;--primary:#3b82f6;--primary-glow:#3b82f680;--secondary:#8b5cf6;--code-bg:#0f172a;--code-text:#38bdf8;--btn-back-bg:#ffffff1a;--btn-back-hover:#fff3}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);background-image:var(--bg-gradient);color:var(--text-color);background-attachment:fixed;flex-direction:column;min-height:100vh;font-family:Inter,Noto Sans KR,sans-serif;display:flex;overflow-x:clip}header{z-index:50;background-color:var(--header-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:.8rem 2rem;transition:all .3s;display:flex;position:fixed;top:0;left:0;right:0}header h1{letter-spacing:-1px;flex-direction:column;align-items:center;font-size:1.5rem;font-weight:800;line-height:1;display:flex}nav a,nav span{color:var(--text-muted);margin-left:.1rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s}nav a:hover,nav span:hover{color:var(--text-color)}main{flex:1;width:100%;margin-top:70px}.container{max-width:1600px;margin:0 auto;padding:0 2rem}.site-footer{background:var(--card-bg);border-top:1px solid var(--card-border);color:var(--text-muted);word-break:keep-all;margin-top:auto;padding:3rem 0 2rem;font-size:.9rem}.footer-top{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;margin-bottom:2rem;display:flex}@media (min-width:768px){.footer-top{text-align:left;flex-direction:row;justify-content:space-between;align-items:center}}.footer-brand{color:var(--text-color);margin-bottom:.5rem;font-size:1rem;font-weight:700}.footer-links{justify-content:center;align-items:center;gap:1rem;display:flex}@media (min-width:768px){.footer-links{justify-content:flex-end}}.footer-bottom{border-top:1px solid var(--card-border);text-align:center;padding-top:1.5rem;font-size:.85rem}@media (min-width:768px){.footer-bottom{text-align:left}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) forwards fadeIn}.delay-1{animation-delay:.2s}.delay-2{animation-delay:.4s}.delay-3{animation-delay:.6s}.floating-home-btn{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;width:55px;height:55px;box-shadow:0 4px 15px var(--primary-glow);z-index:99;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:fixed;bottom:30px;right:30px}.floating-home-btn:hover{box-shadow:0 8px 25px var(--primary-glow);color:#fff;transform:translateY(-5px)scale(1.05)}.lang-selector{margin-right:1.5rem;display:inline-block;position:relative}.lang-btn{background:var(--card-bg);border:1px solid var(--card-border);cursor:pointer;color:var(--text-color);border-radius:2rem;align-items:center;gap:.5rem;padding:.4rem .8rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.lang-btn:hover{background:var(--card-bg-hover)}.lang-dropdown{background:var(--header-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--card-border);z-index:100;opacity:0;visibility:hidden;border-radius:12px;min-width:150px;margin-top:.5rem;padding:.5rem 0;transition:all .2s cubic-bezier(.16,1,.3,1);position:absolute;top:100%;right:0;transform:translateY(-10px);box-shadow:0 4px 20px #0003}.lang-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}.lang-option{text-align:left;cursor:pointer;width:100%;color:var(--text-color);background:0 0;border:none;justify-content:space-between;align-items:center;padding:.6rem 1rem;font-size:.875rem;transition:background .2s;display:flex}.lang-option:hover{background:var(--card-bg)}.lang-option .check-icon{visibility:hidden;color:var(--primary)}.lang-option.active{background:var(--card-bg);font-weight:600}.lang-option.active .check-icon{visibility:visible}body{top:0!important}.skiptranslate,#google_translate_element{display:none!important}.learning-container{z-index:1;min-height:100vh;padding-top:3rem;padding-bottom:5rem;position:relative}.course-cards-view{flex-direction:column;align-items:center;animation:.4s ease-out forwards fadeIn;display:flex}.page-title{text-align:center;background:linear-gradient(135deg, var(--text-color), var(--primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:3rem;font-size:2.5rem;font-weight:800}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.2rem;width:100%;max-width:1200px;display:grid}@media (max-width:1024px){.cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.cards-grid{grid-template-columns:1fr}}.course-card{background:var(--card-bg);border:1px solid var(--card-border);text-align:center;cursor:pointer;-webkit-backdrop-filter:blur(12px);border-radius:12px;flex-direction:column;align-items:center;padding:1.5rem 1.2rem;text-decoration:none;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),border-color .3s,background .3s;display:flex;position:relative;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.course-card:hover{border-color:var(--card-border-hover);background:var(--card-bg-hover);z-index:50;box-shadow:0 12px 20px -3px #00000014,0 4px 6px -2px #0000000a}.course-icon{margin-bottom:.8rem;font-size:2.5rem;transition:transform .3s}.course-card:hover .course-icon{transform:scale(1.05)}.course-card h3{color:var(--text-color);letter-spacing:-.03em;white-space:nowrap;text-overflow:ellipsis;text-align:center;width:100%;margin-bottom:0;font-size:1rem;font-weight:700;overflow:hidden}.course-card p{color:#f1f5f9;-webkit-backdrop-filter:blur(16px);z-index:100;opacity:0;visibility:hidden;letter-spacing:-.01em;pointer-events:none;background:#0f172ad9;border:1px solid #ffffff1a;border-top-color:#fff3;border-radius:12px;width:max-content;max-width:280px;margin:0;padding:1rem 1.2rem;font-size:.85rem;font-weight:400;line-height:1.6;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:absolute;bottom:110%;left:50%;transform:translate(-50%)translateY(15px)scale(.95);box-shadow:0 20px 40px -10px #00000080,0 0 20px #3b82f626}.course-card p:after{content:"";border:6px solid #0000;border-top-color:#0f172ad9;position:absolute;top:100%;left:50%;transform:translate(-50%)}.course-card:hover p{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)scale(1)}.section-container{width:100%;margin-bottom:4rem}.section-header{text-align:left;border-left:4px solid var(--primary);max-width:1200px;margin-bottom:2rem;margin-left:auto;margin-right:auto;padding:0 1rem 0 1.2rem}.section-title{color:var(--text-color);align-items:center;gap:.6rem;margin-bottom:.5rem;font-size:1.6rem;font-weight:700;display:flex}.section-desc{color:var(--text-muted);margin:0;font-size:.95rem}.floating-home-btn{display:none!important}.course-container{max-width:1600px;min-height:100vh;margin:0 auto;padding-top:3rem;padding-bottom:5rem;animation:.4s ease-out forwards fadeIn}pre[class*=language-],code[class*=language-]{text-shadow:none!important;background:0 0!important;margin:0!important;padding:0!important}.detail-header{border-bottom:1px solid var(--card-border);align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.detail-title{align-items:center;gap:.75rem;margin:0;font-size:2rem;font-weight:700;display:flex}.topic-list{flex-direction:column;gap:5rem;display:flex}.topic-card{background:var(--card-bg);border:1px solid var(--card-border);-webkit-backdrop-filter:blur(24px);border-radius:16px;transition:transform .3s,box-shadow .3s;overflow:hidden;box-shadow:0 10px 40px -10px #0000001a,0 1px 3px #0000000d}.topic-card:hover{transform:translateY(-4px);box-shadow:0 12px 20px -3px #00000026,0 4px 6px -4px #0000001a}.topic-header{color:#ffffffd9;background:var(--code-bg);letter-spacing:-.2px;border-bottom:1px solid #ffffff1a;align-items:center;padding:1rem 1.5rem;font-size:1.05rem;font-weight:500;display:flex}.topic-body{flex-direction:column;display:flex}.topic-code{background:var(--code-bg);border-bottom:1px solid var(--card-border);padding:1.5rem 2rem;overflow-x:auto}.topic-code pre{margin:0!important;padding:1.25rem 1.5rem!important}.topic-code code{color:var(--code-text);font-family:Fira Code,Consolas,Monaco,monospace;font-size:.95rem;line-height:1.6}.topic-desc{color:var(--text-muted);letter-spacing:.02em;padding:2rem;line-height:2}.topic-desc p{margin-bottom:2.5rem}.topic-desc p:last-child{margin-bottom:0}.topic-desc ul{margin-bottom:1rem;padding-left:1.5rem}.topic-desc li{margin-bottom:.5rem}.topic-desc strong{color:var(--text-color)}.topic-desc [style*=background] strong{color:inherit}.topic-desc table{border-collapse:separate;border-spacing:0;border:1px solid var(--card-border-hover);background:0 0;border-radius:8px;width:100%;margin-top:1.5rem;font-size:.95rem;overflow:hidden}.topic-desc th,.topic-desc td{border-bottom:1px solid var(--card-border-hover);border-right:1px solid var(--card-border-hover);text-align:left;padding:1rem 1.25rem;line-height:1.6}.topic-desc tr:last-child th,.topic-desc tr:last-child td{border-bottom:none}.topic-desc th:last-child,.topic-desc td:last-child{border-right:none}.topic-desc th{color:var(--text-color);white-space:nowrap;border-bottom:2px solid var(--text-muted);background:#00000026;font-weight:600}.topic-desc td{color:var(--text-muted)}.topic-desc tbody td{transition:background-color .2s}.topic-desc tbody tr:hover td{background-color:#80808014}details.topic-preview[open] summary~*{animation:.35s cubic-bezier(.2,.8,.2,1) forwards slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-15px)scaleY(.98)}to{opacity:1;transform:translateY(0)scaleY(1)}}.scrollspy-nav{z-index:100;flex-direction:column;align-items:flex-end;gap:16px;height:max-content;margin:auto;display:flex;position:fixed;top:0;bottom:0;right:2rem}.scrollspy-item{justify-content:flex-end;align-items:center;gap:12px;text-decoration:none;display:flex}.scrollspy-line{background-color:var(--text-muted);opacity:.3;border-radius:4px;width:16px;height:3px;transition:all .3s cubic-bezier(.25,.8,.25,1)}.scrollspy-item:hover .scrollspy-line{opacity:1;background-color:var(--primary);width:24px}.scrollspy-item.active .scrollspy-line{opacity:1;background-color:var(--primary);width:32px;box-shadow:0 0 8px var(--primary-glow)}.scrollspy-label{color:var(--text-color);white-space:nowrap;opacity:0;visibility:hidden;background:var(--card-bg-hover);border:1px solid var(--card-border-hover);border-radius:6px;padding:.35rem .8rem;font-size:.8rem;font-weight:500;transition:all .3s cubic-bezier(.25,.8,.25,1);transform:translate(10px);box-shadow:0 4px 12px #00000014}.scrollspy-nav:hover .scrollspy-label{opacity:1;visibility:visible;transform:translate(0)}.scrollspy-item:hover .scrollspy-label,.scrollspy-item.active .scrollspy-label{color:var(--primary);border-color:var(--primary-glow);font-weight:600}.mobile-toc-btn{background:linear-gradient(135deg, var(--secondary), var(--primary));color:#fff;width:55px;height:55px;box-shadow:0 4px 15px var(--primary-glow);z-index:98;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;transition:transform .2s,box-shadow .2s;display:none;position:fixed;bottom:100px;right:30px}.mobile-toc-btn:active{transform:scale(.95)}.mobile-toc-btn:hover{box-shadow:0 8px 25px var(--primary-glow);transform:translateY(-5px)scale(1.05)}.mobile-toc-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;background:#00000080;transition:opacity .3s;display:none;position:fixed;inset:0}.mobile-toc-overlay.active{opacity:1;display:block}.mobile-toc-menu{background:var(--bg-color);z-index:1001;border-top:1px solid var(--card-border);border-top-left-radius:24px;border-top-right-radius:24px;max-height:80vh;padding:2rem 1.5rem;transition:bottom .3s cubic-bezier(.2,.8,.2,1);position:fixed;bottom:-100%;left:0;right:0;overflow-y:auto;box-shadow:0 -10px 40px #0000004d}.mobile-toc-menu.active{bottom:0}.mobile-toc-header{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.mobile-toc-title{color:var(--text-color);align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:700;display:flex}.mobile-toc-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:1.5rem;display:flex}.mobile-toc-list{flex-direction:column;gap:.5rem;display:flex}.mobile-toc-item{color:var(--text-color);background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;align-items:center;gap:.75rem;padding:1rem;font-weight:500;text-decoration:none;transition:background .2s;display:flex}.mobile-toc-item:active{background:var(--card-bg-hover)}@media (max-width:1300px){.scrollspy-nav{display:none}.mobile-toc-btn{display:flex}}html{scroll-padding-top:100px}.game-wrapper{max-width:1200px;min-height:100vh;margin:0 auto;padding-top:8rem;padding-bottom:5rem;animation:.4s ease-out forwards fadeIn}.game-header{text-align:center;margin-bottom:2rem}.game-header h2{color:var(--primary);text-shadow:0 0 15px var(--primary-glow);justify-content:center;align-items:center;gap:.8rem;font-size:2.5rem;font-weight:800;display:flex}.game-board{border:2px solid var(--card-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172acc;border-radius:16px;width:100%;height:600px;position:relative;overflow:hidden;box-shadow:0 0 30px #00000080,inset 0 0 20px #00000080}.word{color:#fff;white-space:nowrap;background:#0006;border:1px solid #38bdf84d;border-radius:6px;padding:.2rem .5rem;font-size:1.25rem;font-weight:700;transition:opacity .1s;position:absolute}.game-ui{border-bottom:1px solid var(--card-border);color:#fff;z-index:5;background:#00000080;justify-content:space-between;padding:1rem 2rem;font-size:1.2rem;font-weight:600;display:flex;position:relative}.game-input-container{text-align:center;margin-top:2rem}.game-input{border:2px solid var(--primary);background:var(--card-bg);width:400px;max-width:90%;color:var(--text-color);text-align:center;box-shadow:0 0 15px var(--primary-glow);border-radius:30px;outline:none;padding:1rem 1.5rem;font-size:1.5rem;transition:all .3s}.game-input:focus{background:var(--card-bg-hover);box-shadow:0 0 25px var(--primary-glow)}.start-btn{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;cursor:pointer;box-shadow:0 10px 25px var(--primary-glow);border:none;border-radius:30px;padding:1rem 3rem;font-size:1.5rem;font-weight:700;transition:transform .2s}.start-btn:hover{transform:scale(1.05)}.category-btn,.diff-btn{border:2px solid var(--primary);color:#fff;cursor:pointer;background:0 0;border-radius:20px;padding:.5rem 1.5rem;font-size:1.1rem;font-weight:600;transition:all .2s}.category-btn:hover,.diff-btn:hover{background:#3b82f633}.category-btn.active,.diff-btn.active{background:var(--primary);color:#fff;box-shadow:0 0 15px var(--primary-glow)}.diff-btn[data-diff=hell]{border-color:#ef4444}.diff-btn[data-diff=hell]:hover{background:#ef444433}.diff-btn[data-diff=hell].active{background:#ef4444;box-shadow:0 0 15px #ef444480}.game-over-screen{z-index:10;background:#000c;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.game-over-screen h3{color:#ef4444;text-shadow:0 0 20px #ef4444cc;margin-bottom:1rem;font-size:4rem}.virtual-keyboard{flex-direction:column;align-items:center;gap:.5rem;margin-top:2rem;display:flex}.keyboard-row{gap:.5rem;display:flex}.v-key{color:#a1a1aa;-webkit-user-select:none;user-select:none;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;min-width:45px;height:45px;padding:0 10px;font-family:Inter,sans-serif;font-size:1.1rem;font-weight:600;transition:all .1s;display:flex;box-shadow:0 4px 6px #0000004d}.v-key.pressed{background:var(--primary);color:#fff;box-shadow:0 0 15px var(--primary-glow);border-color:#0000;transform:translateY(4px)}.v-key-space{min-width:300px}.v-key-enter,.v-key-backspace{min-width:80px}.footer-link{color:var(--text-muted);text-decoration:none;transition:color .2s}.footer-link:hover{color:var(--text-color)}.footer-divider{color:var(--card-border)}.escape-container{flex-direction:column;gap:2rem;max-width:1400px;min-height:100vh;margin:0 auto;padding-top:5rem;padding-bottom:5rem;animation:.4s ease-out forwards fadeIn;display:flex}.escape-header{text-align:center}.level-badge{background:var(--primary-glow);color:#fff;border-radius:20px;margin-bottom:1rem;padding:.5rem 1rem;font-weight:700;display:inline-block;box-shadow:0 0 15px #e91e6366}.escape-header h2{text-shadow:0 0 20px #ffffff1a;margin-bottom:1rem;font-size:2.5rem}.escape-header p{color:var(--text-muted);max-width:800px;margin:0 auto;font-size:1.1rem}.escape-workspace{flex:1;gap:2rem;min-height:600px;display:flex}.editor-panel{border:1px solid var(--card-border);background:#0f172a;border-radius:12px;flex-direction:column;flex:1;display:flex;overflow:hidden;box-shadow:0 10px 30px #00000080}.panel-header{background:#1e293b;border-bottom:1px solid #334155;align-items:center;padding:10px 15px;display:flex}.dot{border-radius:50%;width:12px;height:12px;margin-right:6px;display:inline-block}.code-editor{color:#38bdf8;resize:none;background:0 0;border:none;outline:none;flex:1;padding:20px;font-family:Courier New,Courier,monospace;font-size:1.2rem;font-weight:700;line-height:1.6}.editor-actions{background:#1e293b;border-top:1px solid #334155;padding:15px}.hint-btn{color:#fff;cursor:pointer;background:#334155;border:none;border-radius:6px;padding:8px 16px;font-weight:700;transition:background .2s}.hint-btn:hover{background:#475569}.hint-box{color:#eab308;background:#eab3081a;border-left:4px solid #eab308;border-radius:0 4px 4px 0;margin-top:10px;padding:10px;font-size:.95rem}.room-panel{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 50px #00000080}.room-scene{justify-content:center;align-items:center;width:100%;height:100%;transition:all .5s;display:flex;position:relative}.room-scene.level-1{background:#000}.room-scene.level-1.success{background:radial-gradient(circle,#fef08a 0%,#ca8a04 50%,#713f12 100%)}.room-darkness{text-align:center}.dark-text{color:#333;text-shadow:0 0 5px #ffffff1a;font-size:1.2rem}.light-bulb-on{color:#854d0e;font-size:2rem;font-weight:700;animation:1.5s infinite alternate pulse}.room-scene.level-2{background:url(https://images.unsplash.com/photo-1518152006812-edab29b069ac?q=80&w=1000) 50%/cover no-repeat}.room-scene.level-2:before{content:"";background:#000000b3;width:100%;height:100%;position:absolute;top:0;left:0}.room-door{z-index:1;background:#78350f;border:10px solid #451a03;border-bottom:none;border-radius:10px 10px 0 0;justify-content:center;align-items:center;width:200px;height:300px;display:flex;position:relative}.door-lock{color:#fff;background:#1e293b;border:2px solid #cbd5e1;border-radius:8px;padding:10px 20px;font-weight:700;transition:all .3s}.door-lock.locked{color:#ef4444;border-color:#ef4444}.door-lock.unlocked{color:#22c55e;border-color:#22c55e;transform:scale(1.1);box-shadow:0 0 20px #22c55e66}.room-scene.level-3{background:#0f172a}.portal{color:#475569;text-align:center;border:4px dashed #334155;border-radius:100px 100px 0 0;justify-content:center;align-items:center;width:200px;height:300px;padding:20px;font-weight:700;display:flex}.portal.active{color:#fff;background:radial-gradient(circle,#60a5fa,#1d4ed8);border-color:#3b82f6;animation:2s infinite alternate portalPulse;box-shadow:0 0 50px #3b82f6}@keyframes portalPulse{0%{transform:scale(1);box-shadow:0 0 30px #3b82f6}to{transform:scale(1.05);box-shadow:0 0 80px #60a5fa}}.success-overlay{z-index:10;background:#0006;justify-content:center;align-items:center;width:100%;height:100%;animation:.3s fadeIn;display:flex;position:absolute;top:0;left:0}.success-message{background:var(--card-bg);text-align:center;border:2px solid #22c55e;border-radius:12px;padding:2rem;box-shadow:0 10px 40px #22c55e4d}.success-message h3{color:#22c55e;margin-bottom:1.5rem;font-size:1.5rem}.victory-screen{text-align:center;background:url(https://images.unsplash.com/photo-1533158326339-7f3cf2404354?q=80&w=1000) 50%/cover no-repeat;border-radius:20px;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:4rem;display:flex;position:relative}.victory-screen:before{content:"";background:#0f172ad9;border-radius:20px;width:100%;height:100%;position:absolute;top:0;left:0}.victory-screen>*{z-index:1;position:relative}.victory-title{color:#fbbf24;text-shadow:0 0 30px #fbbf2499;margin-bottom:1rem;font-size:4rem;animation:3s ease-in-out infinite float}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-20px)}to{transform:translateY(0)}}@media (max-width:900px){.escape-workspace{flex-direction:column}.editor-panel,.room-panel{min-height:400px}}.next-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:50px;margin-top:1rem;padding:12px 28px;font-size:1.2rem;font-weight:700;transition:all .2s ease-in-out;box-shadow:0 4px 15px #10b98166}.next-btn:hover{background:linear-gradient(135deg,#34d399,#10b981);transform:translateY(-2px);box-shadow:0 6px 20px #10b98199}.next-btn:active{transform:translateY(1px);box-shadow:0 2px 10px #10b98166}.utility-container{flex-direction:column;gap:2rem;max-width:1400px;min-height:100vh;margin:0 auto;padding:2rem;display:flex}@media (min-width:1024px){.utility-container{flex-direction:row;align-items:stretch}.utility-controls{flex:0 0 400px}.utility-preview-area{flex:1}}.utility-controls{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;flex-direction:column;gap:1.5rem;padding:2rem;display:flex;box-shadow:0 8px 32px #0000004d}.utility-preview-area{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;flex-direction:column;gap:1.5rem;padding:2rem;display:flex}.utility-preview-box{background-color:#0f172a;background-image:linear-gradient(45deg,#1e293b 25%,#0000 25%),linear-gradient(-45deg,#1e293b 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#1e293b 75%),linear-gradient(-45deg,#0000 75%,#1e293b 75%);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px;border-radius:12px;flex:1;justify-content:center;align-items:center;min-height:300px;display:flex;position:relative;overflow:hidden}.utility-output{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:1rem;position:relative}.utility-output pre{white-space:pre-wrap;word-break:break-all;color:#38bdf8;margin:0;font-family:JetBrains Mono,D2Coding,monospace;font-size:.9rem}.utility-copy-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.utility-copy-btn:hover{background:#2563eb;transform:translateY(-1px)}.utility-copy-btn:active{transform:translateY(1px)}.utility-control-group{flex-direction:column;gap:.5rem;display:flex}.utility-control-header{justify-content:space-between;align-items:center;display:flex}.utility-control-label{color:var(--text-color);font-size:.95rem;font-weight:600}.utility-control-value{color:#94a3b8;background:#0003;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:.85rem}.utility-slider{-webkit-appearance:none;background:#334155;border-radius:3px;outline:none;width:100%;height:6px}.utility-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#3b82f6;border-radius:50%;width:18px;height:18px;transition:transform .1s;box-shadow:0 0 10px #3b82f680}.utility-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.utility-slider::-moz-range-thumb{cursor:pointer;background:#3b82f6;border:none;border-radius:50%;width:18px;height:18px;box-shadow:0 0 10px #3b82f680}.utility-color-picker{cursor:pointer;border:none;border-radius:6px;width:100%;height:40px;padding:0;overflow:hidden}.utility-color-picker::-webkit-color-swatch-wrapper{padding:0}.utility-color-picker::-webkit-color-swatch{border:none}.utility-select{color:#fff;cursor:pointer;background:#0f172a;border:1px solid #334155;border-radius:6px;outline:none;width:100%;padding:.75rem;font-size:.95rem}.utility-select:focus{border-color:#3b82f6}.utility-input{color:#fff;background:#0f172a;border:1px solid #334155;border-radius:6px;outline:none;width:100%;padding:.75rem;font-size:.95rem}.utility-input:focus{border-color:#3b82f6}.utility-checkbox-label{cursor:pointer;color:var(--text-color);align-items:center;gap:.5rem;font-size:.95rem;display:flex}.utility-checkbox{accent-color:#3b82f6;cursor:pointer;width:18px;height:18px}.pro-slider-container{-webkit-user-select:none;user-select:none;cursor:crosshair;width:100%;height:48px;margin:1.5rem 0;position:relative}.pro-slider-track{background-color:#0f172a;background-image:linear-gradient(45deg,#1e293b 25%,#0000 25%),linear-gradient(-45deg,#1e293b 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#1e293b 75%),linear-gradient(-45deg,#0000 75%,#1e293b 75%);background-position:0 0,0 5px,5px -5px,-5px 0;background-size:10px 10px;border:2px solid #fff3;border-radius:14px;height:28px;position:absolute;top:10px;left:10px;right:10px;box-shadow:0 4px 15px #0000004d,inset 0 2px 5px #0003}.pro-slider-gradient{border-radius:12px;position:absolute;inset:0}.pro-slider-thumb{cursor:grab;z-index:2;background:#fff;border:2px solid #334155;border-radius:6px;width:24px;height:36px;transition:box-shadow .2s,border-color .2s;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 4px 10px #0006}.pro-slider-thumb:active{cursor:grabbing}.pro-slider-thumb.active{z-index:3;border-color:#ec4899;box-shadow:0 0 15px #ec489999}.pro-slider-thumb-inner{border:2px solid #fff;border-radius:4px;width:100%;height:100%}.pro-panel-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (min-width:768px){.pro-panel-grid{grid-template-columns:1fr 1fr}}.pro-glass-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f172a99;border:1px solid #ffffff0d;border-radius:12px;padding:1.5rem;box-shadow:0 8px 32px #0003}.pro-color-preview{border:1px solid #334155;border-radius:8px;width:100%;height:120px;margin-bottom:1rem;position:relative;overflow:hidden;box-shadow:inset 0 2px 10px #0000004d}.pro-color-preview-inner{width:100%;height:100%}.pro-input-grid{grid-template-columns:repeat(5,1fr);gap:.5rem;margin-bottom:1rem;display:grid}.pro-input-group{flex-direction:column;gap:.25rem;display:flex}.pro-input-label{color:#94a3b8;text-align:center;font-size:.75rem;font-weight:700}.pro-input{color:#fff;text-align:center;background:#1e293b;border:1px solid #334155;border-radius:6px;outline:none;width:100%;padding:.5rem;font-family:monospace;font-size:.85rem;transition:border-color .2s}.pro-input:focus{border-color:#ec4899}.pro-stop-list{flex-direction:column;gap:.5rem;max-height:250px;padding-right:.5rem;display:flex;overflow-y:auto}.pro-stop-item{cursor:pointer;background:#1e293b;border:1px solid #0000;border-radius:8px;align-items:center;gap:.75rem;padding:.75rem;transition:all .2s;display:flex}.pro-stop-item:hover{background:#27354f}.pro-stop-item.active{background:#ec48991a;border-color:#ec4899}.pro-stop-swatch{border:2px solid #fff;border-radius:6px;width:32px;height:32px;position:relative;overflow:hidden;box-shadow:0 2px 5px #0003}.pro-stop-hex{color:#e2e8f0;flex:1;font-family:monospace;font-size:.9rem}.pro-stop-pos-input{color:#fff;text-align:center;background:#0f172a;border:1px solid #334155;border-radius:4px;width:50px;padding:.4rem;font-family:monospace;font-size:.85rem}.pro-stop-delete{color:#ef4444;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.4rem;transition:background .2s;display:flex}.pro-stop-delete:hover:not(:disabled){background:#ef444433}.pro-stop-delete:disabled{color:#475569;cursor:not-allowed}.pro-presets{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.pro-preset-btn{cursor:pointer;border:2px solid #ffffff1a;border-radius:8px;width:36px;height:36px;transition:transform .2s,box-shadow .2s}.pro-preset-btn:hover{border-color:#fff;transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.pro-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.pro-toggle-group{background:#0f172a;border:1px solid #334155;border-radius:8px;display:flex;overflow:hidden}.pro-toggle-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:.9rem;font-weight:700;transition:all .2s}.pro-toggle-btn.active{color:#fff;background:#3b82f6}@media (max-width:768px){.course-card p{color:var(--text-muted);width:100%;max-width:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;opacity:1;visibility:visible;pointer-events:auto;background:0 0;border:none;margin-top:.8rem;padding:0;font-size:.85rem;position:static;transform:none}.course-card p:after{display:none}.course-card:hover p{transform:none}}.mermaid{white-space:pre;font-family:monospace}.premium-info-box{-webkit-backdrop-filter:blur(12px);border:1px solid #ffffff1a;border-left:4px solid var(--primary,#3b82f6);background:#1e293b66;border-radius:12px;margin-top:1.5rem;margin-bottom:1.5rem;padding:1.5rem;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden;box-shadow:0 8px 32px #0003}.premium-info-box:hover{border-color:#fff3;border-left-color:var(--secondary,#8b5cf6);transform:translateY(-2px);box-shadow:0 12px 40px #0000004d}.premium-info-box:before{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff0d 0%,#0000 100%);width:100%;height:100%;position:absolute;top:0;left:0}.premium-info-title{color:var(--text-color,#fff);text-shadow:0 2px 4px #00000080;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:1.1rem;font-weight:700;display:flex}.premium-info-desc{color:var(--text-muted,#94a3b8);margin:0;font-size:.95rem;line-height:1.6}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--bg-color);border-left:1px solid var(--card-border)}::-webkit-scrollbar-thumb{background:var(--card-border-hover);border:3px solid var(--bg-color);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}html{scrollbar-width:thin;scrollbar-color:var(--card-border-hover) var(--bg-color)}
