/*
! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.mb-4{margin-bottom:1rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.text-2xl{font-size:1.5rem;line-height:2rem}.text-lg{font-size:1.125rem}.text-lg,.text-xl{line-height:1.75rem}.text-xl{font-size:1.25rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}:root{--bg-primary:#f8f9fa;--bg-secondary:#ffffff;--bg-tertiary:#f8f9fa;--text-primary:#333333;--text-secondary:#666666;--text-tertiary:#999999;--border-color:#dddddd;--shadow-color:rgba(0,0,0,0.1);--header-bg:#007bff;--header-text:#ffffff;--button-bg:#007bff;--button-hover:#0056b3;--code-bg:#272822;--code-text:#f8f8f2;--input-bg:#ffffff;--input-border:#dddddd}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--bg-tertiary:#252525;--text-primary:#e0e0e0;--text-secondary:#b0b0b0;--text-tertiary:#808080;--border-color:#404040;--shadow-color:rgba(0,0,0,0.3);--header-bg:#1e3a8a;--header-text:#ffffff;--button-bg:#1e40af;--button-hover:#1e3a8a;--code-bg:#1e1e1e;--code-text:#d4d4d4;--input-bg:#2d2d2d;--input-border:#404040}body{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity));background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.container{display:flex;height:100vh;overflow:hidden}.sidebar{background:var(--bg-secondary);box-shadow:0 4px 6px var(--shadow-color);border-color:var(--border-color);display:flex;width:16rem;flex-direction:column;border-right-width:1px;padding:1.25rem;--tw-shadow:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.sidebar button{color:var(--text-secondary);border-radius:.375rem;padding:.75rem 1rem;text-align:left;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.sidebar button:hover{background-color:rgb(59 130 246/var(--tw-bg-opacity))}.sidebar .active,.sidebar button:hover{--tw-bg-opacity:1;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.sidebar .active{background-color:rgb(37 99 235/var(--tw-bg-opacity))}.content{background:var(--bg-secondary);box-shadow:0 4px 6px var(--shadow-color);margin-left:1.5rem;margin-right:1.5rem;margin-top:1.5rem;flex:1 1 0%;border-radius:.5rem;padding:1.5rem;--tw-shadow:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.content,.header{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.header{width:100%;font-size:1.25rem;line-height:1.75rem;font-weight:700;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity));--tw-shadow:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);background:var(--header-bg);display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;position:sticky;top:0;z-index:100;transition:background-color .3s ease}.header h1{margin:0}.header-title{position:absolute;left:50%;transform:translateX(-50%);font-size:1.5rem;font-weight:700;margin:0;color:white}.logo-container{display:flex;align-items:center;justify-content:center}.header-logo{width:50px;height:50px;border-radius:50%;-o-object-fit:cover;object-fit:cover;background:white;border:2px solid white;box-shadow:0 2px 8px rgba(0,0,0,.2)}.header-actions{display:flex;align-items:center;gap:12px}.theme-toggle-button{background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.5);color:white;padding:10px 16px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.theme-toggle-button:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.8);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.theme-icon{font-size:20px}.compiler-button{background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.5);color:white;padding:10px 20px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.compiler-button:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.8);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.compiler-icon{font-size:20px}.mobile-menu-container{position:relative}.hamburger-button{display:block;background:transparent;border:none;cursor:pointer;padding:8px;z-index:101}.hamburger-icon{display:flex;flex-direction:column;justify-content:space-between;width:28px;height:22px}.hamburger-icon span{display:block;height:3px;width:100%;background:white;border-radius:2px;transition:all .3s ease}.hamburger-icon.open span:first-child{transform:rotate(45deg) translate(8px,8px)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}.mobile-menu{position:absolute;top:100%;right:0;background:var(--header-bg);border-radius:0 0 0 12px;box-shadow:0 4px 12px rgba(0,0,0,.3);overflow:hidden;z-index:99;min-width:200px}.mobile-menu-item{width:100%;background:transparent;color:white;padding:16px 20px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:12px;transition:background .3s ease;border:none;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-menu-item:last-child{border-bottom:none}.mobile-menu-item:hover{background:rgba(255,255,255,.15)}.mobile-menu-item .compiler-icon,.mobile-menu-item .theme-icon{font-size:20px}.desktop-only{display:flex}.mobile-only{display:none}@media (max-width:768px){.header{padding:1rem}.header-title{font-size:1.25rem;left:50%;transform:translateX(-50%)}.desktop-only{display:none}.mobile-only{display:block}.header-logo{width:40px;height:40px}}.learning-container{max-width:800px;margin:auto;padding:20px}.page-title{font-size:2rem;font-weight:700;color:var(--text-primary);text-align:center}.learning-section{background:var(--bg-tertiary);padding:15px;margin-bottom:15px;border-radius:8px}h2{color:var(--button-bg)}.code-block{background:var(--code-bg);color:var(--code-text);padding:15px;border-radius:8px;overflow-x:auto}.complexity-table,.dry-run-table{width:100%;border-collapse:collapse}td,th{border:1px solid var(--border-color);padding:8px}th{background:var(--button-bg);color:white}.full-page-sidebar{width:100%;min-height:calc(100vh - 72px);background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;flex:1}.sidebar-title{font-size:2rem;font-weight:700;margin-bottom:20px;color:var(--text-primary)}.sidebar-topics{display:flex;flex-direction:column;gap:15px;width:250px}.sidebar-button{background:var(--button-bg);color:white;padding:12px;border:none;border-radius:6px;font-size:16px;cursor:pointer;transition:.3s}.sidebar-button:hover{background:var(--button-hover)}.sidebar-button.disabled,.sidebar-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.sidebar-button.disabled:hover,.sidebar-button:disabled:hover{background:#6c757d}body,html{height:100%;margin:0;padding:0}.app-container,body,html{display:flex;flex-direction:column}.app-container{min-height:100vh}.app-container>:nth-child(2){flex:1}footer{text-align:center;padding:15px;font-size:18px;background:var(--bg-tertiary);color:var(--text-primary);width:100%;margin-top:auto}.track-slider-container{width:100%;max-width:600px;margin:0 auto 30px;padding:0 20px}.track-slider{display:flex;background:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 6px var(--shadow-color);overflow:hidden;position:relative}.track-button{flex:1;padding:16px 20px;border:none;background:transparent;cursor:pointer;transition:all .3s ease;position:relative;z-index:1;text-align:center}.track-button .track-name{display:block;font-size:18px;font-weight:700;color:var(--text-secondary);transition:color .3s ease}.track-button .track-fullname{display:block;font-size:12px;color:var(--text-tertiary);margin-top:4px;transition:color .3s ease}.track-button.active .track-name{color:#fff}.track-button.active .track-fullname{color:rgba(255,255,255,.9)}.track-button:hover:not(.active) .track-name{color:var(--button-bg)}.track-button:hover:not(.active) .track-fullname{color:var(--text-primary)}.track-indicator{position:relative;height:4px;background:var(--border-color);margin-top:-4px}.track-indicator-bar{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);border-radius:2px}.track-indicator-bar,.track-slider:before{position:absolute;top:0;left:0;width:33.333%;transition:transform .3s ease}.track-slider:before{content:"";height:calc(100% - 4px);background:linear-gradient(135deg,#007bff,#0056b3);z-index:0;border-radius:12px}.track-slider[data-track=psp]:before{transform:translateX(0)}.track-slider[data-track=dsa]:before{transform:translateX(100%)}.track-slider[data-track=ada]:before{transform:translateX(200%)}.empty-track-message{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:18px;font-weight:500}.compiler-container{max-width:1400px;margin:0 auto;padding:20px;background:var(--bg-primary);min-height:calc(100vh - 200px)}.compiler-header{text-align:center;margin-bottom:30px}.compiler-title{font-size:2.5rem;color:var(--text-primary);margin-bottom:10px;font-weight:700}.compiler-subtitle{color:var(--text-secondary);font-size:1.1rem}.language-selector{display:flex;justify-content:center;gap:15px;margin-bottom:30px;flex-wrap:wrap}.lang-button{padding:12px 24px;border:2px solid var(--border-color);background:var(--bg-secondary);border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;color:var(--text-primary)}.lang-button:hover{border-color:#007bff;background:#f0f7ff;transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,123,255,.2)}.lang-button.active{background:#007bff;color:white;border-color:#007bff;box-shadow:0 4px 12px rgba(0,123,255,.3)}.compiler-workspace{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}@media (max-width:968px){.compiler-workspace{grid-template-columns:1fr}}.code-section{background:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 12px var(--shadow-color);overflow:hidden}.io-section{display:flex;flex-direction:column;gap:20px}.input-section,.output-section{background:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 12px var(--shadow-color);overflow:hidden;flex:1}.section-header{background:linear-gradient(135deg,var(--button-bg),var(--button-hover));padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.section-title{color:white;font-weight:600;font-size:16px}.language-badge{background:rgba(255,255,255,.2);color:white;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.code-editor,.input-area{width:100%;min-height:400px;padding:20px;border:none;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.6;resize:vertical;background:var(--code-bg);color:var(--code-text)}.code-editor:focus,.input-area:focus{outline:none;box-shadow:inset 0 0 0 2px var(--button-bg)}.input-area,.output-area{min-height:180px}.output-area{padding:20px;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.6;background:var(--bg-tertiary);color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word;overflow-y:auto}.action-buttons{display:flex;justify-content:center;gap:20px;margin-bottom:30px;flex-wrap:wrap}.clear-button,.run-button{padding:14px 32px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.run-button{background:linear-gradient(135deg,#28a745,#218838);color:white;box-shadow:0 4px 12px rgba(40,167,69,.3)}.run-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px rgba(40,167,69,.4)}.run-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.clear-button{background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color)}.clear-button:hover{background:var(--bg-secondary);border-color:var(--text-secondary);transform:translateY(-2px)}.compiler-info{background:var(--bg-secondary);border-radius:12px;padding:20px;box-shadow:0 4px 12px var(--shadow-color);margin-bottom:20px}.compiler-info h3{color:var(--button-bg);margin-bottom:15px}.compiler-info ul{list-style:none;padding:0}.compiler-info li{padding:8px 0;color:var(--text-secondary);line-height:1.6}.compiler-info li:before{content:"✓ ";color:#28a745;font-weight:700;margin-right:8px}