:root{--color-background-primary: #0d1117;--color-background-secondary: #1a1f29;--color-text-primary: #f1f1f0;--color-text-secondary: #9ca3af;--color-accent: #60a5fa;--color-success: #22c55e;--color-warning: #eab308;--color-error: #ef4444;--color-gold: #fbbf24;--color-accent-light: #93c5fd;--color-accent-dark: #3b82f6;--color-success-light: #4ade80;--color-success-dark: #16a34a;--color-warning-light: #facc15;--color-warning-dark: #ca8a04;--color-error-light: #f87171;--color-error-dark: #dc2626;--color-border-primary: var(--color-accent);--color-border-secondary: var(--color-text-secondary);--color-shadow-primary: rgba(96, 165, 250, .3);--color-shadow-secondary: rgba(0, 0, 0, .5);--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-family-heading: var(--font-family-base);--font-family-mono: "Fira Code", "Monaco", "Consolas", monospace;--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-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-lg: 1rem;--spacing-xl: 1.25rem;--spacing-2xl: 1.5rem;--spacing-3xl: 2rem;--spacing-4xl: 2.5rem;--spacing-5xl: 3rem;--spacing-6xl: 4rem;--radius-none: 0;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-glow-accent: 0 0 20px var(--color-shadow-primary);--shadow-glow-success: 0 0 20px rgba(34, 197, 94, .3);--shadow-glow-warning: 0 0 20px rgba(234, 179, 8, .3);--shadow-glow-error: 0 0 20px rgba(239, 68, 68, .3);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out;--transition-slow: .3s ease-in-out;--transition-slower: .5s ease-in-out;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--z-toast: 1080;--xp-bar-height: 20px;--card-hover-lift: -4px;--animation-duration-bounce: 2s;--animation-duration-float: 3s;--animation-duration-pulse: 1s}[data-theme=dark]{--color-background-primary: #0d1117;--color-background-secondary: #1a1f29;--color-text-primary: #f1f1f0;--color-text-secondary: #9ca3af}[data-theme=light]{--color-background-primary: #ffffff;--color-background-secondary: #f8fafc;--color-text-primary: #1f2937;--color-text-secondary: #6b7280;--color-accent: #3b82f6;--color-success: #059669;--color-warning: #d97706;--color-error: #dc2626;--color-gold: #f59e0b}[data-theme=high-contrast]{--color-background-primary: #000000;--color-background-secondary: #1a1a1a;--color-text-primary: #ffffff;--color-text-secondary: #cccccc;--color-accent: #66b3ff;--color-success: #00ff00;--color-warning: #ffff00;--color-error: #ff0000;--color-gold: #ffcc00}*{box-sizing:border-box;margin:0;padding:0}*:before,*:after{box-sizing:border-box}html{font-size:16px;line-height:var(--line-height-normal);-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-family-base);font-weight:var(--font-weight-normal);color:var(--color-text-primary);background-color:var(--color-background-primary);min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary);margin-bottom:var(--spacing-lg)}h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold)}h2{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold)}h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}h4{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}h5{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium)}h6{font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}p{margin-bottom:var(--spacing-lg);line-height:var(--line-height-normal)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--color-accent-light);text-decoration:underline}a:focus{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}button{font-family:inherit;font-size:inherit;line-height:inherit;margin:0;overflow:visible;text-transform:none}button:focus{outline:2px solid var(--color-accent);outline-offset:2px}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit;margin:0}img,svg{display:block;max-width:100%;height:auto}ul,ol{padding-left:var(--spacing-xl);margin-bottom:var(--spacing-lg)}li{margin-bottom:var(--spacing-sm)}code,pre{font-family:var(--font-family-mono);font-size:var(--font-size-sm)}code{background-color:var(--color-background-secondary);color:var(--color-accent);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm)}pre{background-color:var(--color-background-secondary);color:var(--color-text-primary);padding:var(--spacing-lg);border-radius:var(--radius-lg);overflow-x:auto;margin-bottom:var(--spacing-lg)}.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:var(--font-weight-bold)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-normal{font-weight:var(--font-weight-normal)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-gold{color:var(--color-gold)}.bg-primary{background-color:var(--color-background-primary)}.bg-secondary{background-color:var(--color-background-secondary)}.border-accent{border-color:var(--color-accent)}.border-success{border-color:var(--color-success)}.border-warning{border-color:var(--color-warning)}.border-error{border-color:var(--color-error)}.animate-fadeIn{animation:fadeIn .6s ease-out}.animate-slideUp{animation:slideUp .6s ease-out}.animate-bounce{animation:bounce var(--animation-duration-bounce) ease-in-out infinite}.animate-float{animation:float var(--animation-duration-float) ease-in-out infinite}.animate-pulse{animation:pulse var(--animation-duration-pulse) ease-in-out infinite}.animate-glow{animation:glow 2s ease-in-out infinite alternate}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes glow{0%{box-shadow:var(--shadow-glow-accent)}to{box-shadow:var(--shadow-glow-accent),0 0 40px var(--color-shadow-primary)}}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}@media (min-width: 640px){.container{padding:0 var(--spacing-2xl)}}@media (min-width: 1024px){.container{padding:0 var(--spacing-3xl)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background-primary)}::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-success)}::selection{background:var(--color-accent);color:var(--color-background-primary)}::-moz-selection{background:var(--color-accent);color:var(--color-background-primary)}.focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.animate-bounce,.animate-float,.animate-pulse,.animate-glow{animation:none}}.hud{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:#1a1f29;border-bottom:2px solid #60a5fa;box-shadow:0 2px 10px #0000004d;z-index:var(--z-sticky)}.hud-left,.hud-right{display:flex;align-items:center;gap:1rem;min-width:200px}.hud-right{justify-content:flex-end}.hud-center{flex:1;text-align:center}.game-title{font-size:1.5rem;font-weight:700;margin:0;color:#60a5fa;text-shadow:0 0 10px rgba(96,165,250,.3)}.xp-container{display:flex;align-items:center;gap:.5rem}.xp-label{font-weight:700;color:#60a5fa;font-size:.875rem}.xp-bar{position:relative;width:120px;height:20px;background:#0d1117;border:2px solid #60a5fa;border-radius:10px;overflow:hidden}.xp-fill{height:100%;background:linear-gradient(90deg,#60a5fa,#22c55e);transition:width .5s ease-in-out;box-shadow:0 0 10px #60a5fa80}.xp-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:700;color:#f1f1f0;text-shadow:1px 1px 2px rgba(0,0,0,.8);z-index:1}.currency{display:flex;gap:1rem;align-items:center}.coins,.keys{display:flex;align-items:center;gap:.25rem;font-weight:700;font-size:1rem}.coins{color:#fbbf24}.keys{color:#9ca3af}.reset-button{background:#ef4444;border:none;border-radius:6px;padding:.5rem;font-size:1.2rem;cursor:pointer;transition:all .2s}.reset-button:hover{background:#dc2626;transform:scale(1.1)}.reset-button:active{transform:scale(.95)}.sidebar{width:280px;background:#1a1f29;border-right:2px solid #60a5fa;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:2rem}.section-title{font-size:1.1rem;font-weight:700;color:#60a5fa;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em}.levels-list{display:flex;flex-direction:column;gap:.75rem}.level-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#0d1117;border:2px solid transparent;border-radius:8px;transition:all .3s ease;cursor:pointer}.level-item:hover:not(.locked){border-color:#60a5fa;transform:translateY(-2px);box-shadow:0 4px 12px #60a5fa33}.level-item.active{border-color:#22c55e;background:#22c55e1a}.level-item.locked{opacity:.5;cursor:not-allowed}.level-icon{font-size:2rem;min-width:40px;text-align:center}.level-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.level-name{font-weight:700;font-size:1.1rem;color:#f1f1f0}.level-subtitle{font-size:.875rem;color:#9ca3af}.level-progress{font-size:.8rem;color:#60a5fa}.level-percentage{font-weight:700;color:#22c55e;font-size:1rem}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.badge-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background:#0d1117;border:2px solid #22c55e;border-radius:8px;text-align:center;transition:all .3s ease;cursor:pointer}.badge-item:hover{transform:scale(1.05);box-shadow:0 4px 12px #22c55e4d}.badge-icon{font-size:1.5rem}.badge-name{font-size:.75rem;font-weight:700;color:#22c55e;line-height:1.2}.no-badges{grid-column:1 / -1;text-align:center;padding:2rem 1rem;color:#9ca3af;font-style:italic;border:2px dashed #9ca3af;border-radius:8px}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#0d1117}.sidebar::-webkit-scrollbar-thumb{background:#60a5fa;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#22c55e}.main-layout{width:100vw;height:100vh;display:flex;flex-direction:column;background:#0d1117;color:#f1f1f0;overflow:hidden}.main-content{display:flex;flex:1;overflow:hidden}.game-area{flex:1;padding:1rem;overflow-y:auto;background:linear-gradient(135deg,#0d1117,#1a1f29)}.card{background:#1a1f29;border:2px solid transparent;border-radius:8px;padding:1rem;transition:all .3s ease-in-out;position:relative;overflow:hidden}.card--hover{cursor:pointer}.card--hover:hover{border-color:#60a5fa;transform:translateY(-4px);box-shadow:0 8px 25px #60a5fa33}.card--clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.card--clickable:hover{border-color:#60a5fa;transform:translateY(-2px);box-shadow:0 4px 12px #60a5fa26}.card--clickable:active{transform:translateY(0);box-shadow:0 2px 6px #60a5fa1a}.card--disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.card--disabled:hover{transform:none;box-shadow:none;border-color:transparent}.card--success{border-color:#22c55e;background:#22c55e1a}.card--warning{border-color:#eab308;background:#eab3081a}.card--danger{border-color:#ef4444;background:#ef44441a}.card--locked{background:#0d1117;border-color:#9ca3af;opacity:.7}.card--locked:before{content:"🔒";position:absolute;top:.5rem;right:.5rem;font-size:1.2rem;opacity:.7}.card--clickable:focus{outline:2px solid #60a5fa;outline-offset:2px}.card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s;pointer-events:none}.card--hover:hover:before,.card--clickable:hover:before{left:100%}.level-selector{width:100%;max-width:1000px;margin:0 auto;padding:2rem;text-align:center;animation:fadeIn .8s ease-out}.selector-title{font-size:3rem;color:#60a5fa;margin-bottom:3rem;text-shadow:0 0 30px rgba(96,165,250,.6);background:linear-gradient(135deg,#60a5fa,#22c55e);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.level-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem}.level-card{height:300px;display:flex;flex-direction:column;justify-content:space-between;position:relative;transition:all .4s ease;cursor:pointer;overflow:hidden}.level-card--selected{border-color:#22c55e;background:#22c55e1a;transform:scale(1.05);box-shadow:0 12px 40px #22c55e4d}.level-card--locked{background:#0d1117;border-color:#9ca3af;cursor:not-allowed;opacity:.6}.level-card:not(.level-card--locked):hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 50px #60a5fa66;border-color:#60a5fa}.level-card--selected:hover{transform:scale(1.06) translateY(-4px);box-shadow:0 20px 60px #22c55e66}.level-card__icon{font-size:4rem;margin:2rem 0 1rem;animation:float 3s ease-in-out infinite}.level-card--selected .level-card__icon{animation:selectedFloat 2s ease-in-out infinite}.level-card__content{flex:1;display:flex;flex-direction:column;justify-content:center;padding:0 1.5rem}.level-card__title{font-size:2rem;font-weight:800;color:#f1f1f0;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.level-card--locked .level-card__title{color:#9ca3af}.level-card--selected .level-card__title{color:#22c55e}.level-card__name{font-size:1.2rem;font-weight:600;color:#60a5fa;margin-bottom:1rem}.level-card--locked .level-card__name{color:#9ca3af}.level-card__description{font-size:1rem;color:#9ca3af;line-height:1.5;margin:0;padding:0 1rem}.level-card--locked .level-card__description{font-style:italic;color:#6b7280}.level-card__progress{padding:1.5rem;background:#0003;margin-top:auto}.progress-bar{width:100%;height:8px;background:#0d1117;border-radius:4px;overflow:hidden;margin-bottom:.75rem;border:1px solid #60a5fa}.progress-fill{height:100%;background:linear-gradient(90deg,#60a5fa,#22c55e);transition:width .8s ease-in-out;border-radius:4px;position:relative}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s ease-in-out infinite}.progress-text{font-size:.875rem;font-weight:600;color:#22c55e}.locked-text{font-size:.875rem;font-weight:600;color:#9ca3af;font-style:italic}.level-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(96,165,250,.1),transparent);transition:left .6s;pointer-events:none}.level-card:hover:before{left:100%}.level-card--selected:after{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,#22c55e,#60a5fa,#22c55e);background-size:300% 300%;border-radius:10px;z-index:-1;animation:gradientRotate 4s ease infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes selectedFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.1)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes gradientRotate{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@media (max-width: 768px){.level-selector{padding:1rem}.selector-title{font-size:2rem;margin-bottom:2rem}.level-grid{grid-template-columns:1fr;gap:1.5rem}.level-card{height:280px}.level-card__icon{font-size:3rem;margin:1.5rem 0 1rem}.level-card__title{font-size:1.5rem}.level-card__name{font-size:1rem}.level-card__description{font-size:.9rem;padding:0 .5rem}}.unit-card{width:280px;height:200px;display:flex;flex-direction:column;justify-content:space-between;position:relative;transition:all .3s ease;cursor:pointer}.unit-card--locked{background:#0d1117;border-color:#9ca3af;cursor:not-allowed}.unit-card--open{background:#1a1f29;border-color:#60a5fa;box-shadow:0 0 20px #60a5fa4d}.unit-card--open:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 40px #60a5fa66;border-color:#22c55e}.unit-card--done{background:#22c55e1a;border-color:#22c55e;box-shadow:0 0 20px #22c55e4d}.unit-card--done:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 8px 25px #22c55e66}.unit-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.unit-card__status{font-size:1.5rem;line-height:1}.unit-card__rewards{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;font-size:.75rem;font-weight:600}.xp-reward{color:#60a5fa;background:#60a5fa1a;padding:.25rem .5rem;border-radius:4px;border:1px solid #60a5fa}.coin-reward{color:#fbbf24;background:#fbbf241a;padding:.25rem .5rem;border-radius:4px;border:1px solid #fbbf24}.unit-card__content{flex:1;display:flex;flex-direction:column;justify-content:center}.unit-card__title{font-size:1.1rem;font-weight:700;color:#f1f1f0;margin-bottom:.75rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.unit-card--locked .unit-card__title{color:#9ca3af}.unit-card__summary{font-size:.875rem;color:#9ca3af;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin:0}.unit-card--locked .unit-card__summary{font-style:italic;color:#6b7280}.unit-card__footer{margin-top:1rem;text-align:center;font-size:.875rem;font-weight:600}.unit-card__locked-text{color:#9ca3af;opacity:.8}.unit-card__action-text{color:#60a5fa;background:#60a5fa1a;padding:.5rem 1rem;border-radius:6px;border:1px solid #60a5fa;transition:all .2s}.unit-card--open:hover .unit-card__action-text{background:#60a5fa;color:#fff;transform:scale(1.05)}.unit-card__completed-text{color:#22c55e;background:#22c55e1a;padding:.5rem 1rem;border-radius:6px;border:1px solid #22c55e}.unit-card--open:before{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,#60a5fa,#22c55e,#60a5fa);background-size:300% 300%;border-radius:10px;z-index:-1;animation:gradientShift 3s ease infinite;opacity:0;transition:opacity .3s}.unit-card--open:hover:before{opacity:1}.unit-card--done:after{content:"⭐";position:absolute;top:-10px;right:-10px;font-size:1.5rem;animation:bounce 2s ease-in-out infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes bounce{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(10deg)}}@media (max-width: 768px){.unit-card{width:250px;height:180px}.unit-card__title{font-size:1rem}.unit-card__summary{font-size:.8rem;-webkit-line-clamp:2}}.dungeon-map{width:100%;max-width:1200px;margin:0 auto;padding:2rem;animation:fadeIn .6s ease-out}.map-header{text-align:center;margin-bottom:3rem}.level-title{font-size:2.5rem;color:#60a5fa;margin-bottom:1rem;text-shadow:0 0 20px rgba(96,165,250,.5)}.level-description{font-size:1.2rem;color:#9ca3af;max-width:600px;margin:0 auto}.map-grid{display:flex;flex-direction:column;gap:2rem;margin-bottom:3rem}.map-row{display:flex;align-items:center;justify-content:center;gap:2rem;position:relative}.map-cell{position:relative;animation:slideInUp .6s ease-out;animation-delay:var(--delay, 0s);animation-fill-mode:both}.map-cell.empty{width:280px;height:200px}.corridor{position:absolute;background:linear-gradient(45deg,#60a5fa,#22c55e);border-radius:4px;opacity:.6;animation:pulse 2s ease-in-out infinite}.corridor.horizontal{width:60px;height:4px;right:-80px;top:50%;transform:translateY(-50%)}.corridor.vertical{width:4px;height:60px;bottom:-80px;left:50%;transform:translate(-50%)}.map-legend{display:flex;justify-content:center;gap:2rem;margin-top:2rem;padding:1rem;background:#1a1f2980;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#9ca3af}.legend-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1rem}.legend-icon.locked{background:#9ca3af33;border:1px solid #9ca3af}.legend-icon.open{background:#60a5fa33;border:1px solid #60a5fa}.legend-icon.done{background:#22c55e33;border:1px solid #22c55e}.map-empty{text-align:center;padding:4rem 2rem;color:#9ca3af}.map-empty h2{color:#ef4444;margin-bottom:1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@media (max-width: 1024px){.map-row{gap:1.5rem}.corridor.horizontal{width:40px;right:-60px}.corridor.vertical{height:40px;bottom:-60px}}@media (max-width: 768px){.dungeon-map{padding:1rem}.level-title{font-size:2rem}.level-description{font-size:1rem}.map-row,.map-legend{flex-wrap:wrap;gap:1rem}}.breadcrumb{background:#1a1f2980;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--color-border-secondary)}.breadcrumb-list{display:flex;align-items:center;gap:var(--spacing-sm);list-style:none;margin:0;padding:0;font-size:var(--font-size-sm)}.breadcrumb-item{display:flex;align-items:center}.breadcrumb-link{background:none;border:none;color:var(--color-accent);cursor:pointer;font-size:inherit;font-weight:var(--font-weight-medium);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-base);text-decoration:none;display:flex;align-items:center;gap:var(--spacing-xs)}.breadcrumb-link:hover{color:var(--color-accent-light);background:#60a5fa1a;transform:translateY(-1px)}.breadcrumb-link:focus{outline:2px solid var(--color-accent);outline-offset:2px}.breadcrumb-current{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);padding:var(--spacing-xs) var(--spacing-sm);background:#60a5fa1a;border-radius:var(--radius-sm);border:1px solid var(--color-accent)}.breadcrumb-separator{color:var(--color-text-secondary);font-weight:var(--font-weight-normal);-webkit-user-select:none;user-select:none;margin:0 var(--spacing-xs)}.breadcrumb-item--current{pointer-events:none}.breadcrumb-link{position:relative;overflow:hidden}.breadcrumb-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(96,165,250,.2),transparent);transition:left var(--transition-slower);pointer-events:none}.breadcrumb-link:hover:before{left:100%}@media (max-width: 640px){.breadcrumb{padding:var(--spacing-xs) var(--spacing-md)}.breadcrumb-list{font-size:var(--font-size-xs);gap:var(--spacing-xs)}.breadcrumb-link,.breadcrumb-current{padding:var(--spacing-xs)}.breadcrumb-separator{margin:0}.breadcrumb-item:nth-child(3) .breadcrumb-link{display:none}.breadcrumb-item:nth-child(3)+.breadcrumb-separator{display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease-in-out;text-decoration:none;position:relative;overflow:hidden}.btn:disabled{cursor:not-allowed;opacity:.6}.btn--small{padding:.375rem .75rem;font-size:.875rem}.btn--medium{padding:.5rem 1rem;font-size:1rem}.btn--large{padding:.75rem 1.5rem;font-size:1.125rem}.btn--primary{background:#60a5fa;color:#fff;border:2px solid #60a5fa}.btn--primary:hover:not(:disabled){background:#3b82f6;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #60a5fa66}.btn--secondary{background:transparent;color:#60a5fa;border:2px solid #60a5fa}.btn--secondary:hover:not(:disabled){background:#60a5fa;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #60a5fa66}.btn--success{background:#22c55e;color:#fff;border:2px solid #22c55e}.btn--success:hover:not(:disabled){background:#16a34a;border-color:#16a34a;transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.btn--warning{background:#eab308;color:#0d1117;border:2px solid #eab308}.btn--warning:hover:not(:disabled){background:#ca8a04;border-color:#ca8a04;transform:translateY(-2px);box-shadow:0 4px 12px #eab30866}.btn--danger{background:#ef4444;color:#fff;border:2px solid #ef4444}.btn--danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.btn--loading{pointer-events:none}.btn__spinner{animation:spin 1s linear infinite}.btn__text--hidden{opacity:0}.btn__text{opacity:1;transition:opacity .2s ease-in-out}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn:active:not(:disabled){transform:translateY(0)}.btn:focus:not(:disabled){outline:2px solid #60a5fa;outline-offset:2px}.game-navigation{display:flex;flex-direction:column;height:100%;width:100%}.nav-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);background:#1a1f29cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-primary);position:sticky;top:0;z-index:var(--z-fixed)}.nav-controls,.nav-actions{display:flex;align-items:center;gap:var(--spacing-md);min-width:120px}.nav-actions{justify-content:flex-end}.back-button,.levels-button{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:var(--font-weight-semibold)}.nav-content{flex:1;overflow-y:auto;padding:var(--spacing-lg);background:var(--color-background-primary)}.error-view{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-6xl);text-align:center;min-height:400px}.error-view h2{color:var(--color-error);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-md)}.error-view p{color:var(--color-text-secondary);font-size:var(--font-size-lg);max-width:400px;margin-bottom:var(--spacing-xl)}.nav-header{animation:slideDown .6s ease-out}.nav-content{animation:fadeIn .8s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.nav-header{padding:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.nav-controls,.nav-actions{min-width:auto}.nav-content{padding:var(--spacing-md)}.error-view{padding:var(--spacing-4xl);min-height:300px}.error-view h2{font-size:var(--font-size-xl)}.error-view p{font-size:var(--font-size-base)}}@media (max-width: 480px){.nav-header{flex-direction:column;align-items:stretch}.nav-controls,.nav-actions{justify-content:center}.nav-header>*{width:100%;display:flex;justify-content:center}.nav-content{padding:var(--spacing-sm)}}.game-navigation:focus-within .nav-header{border-color:var(--color-accent)}.nav-content--loading{display:flex;align-items:center;justify-content:center;min-height:400px}.nav-content--loading:after{content:"Loading...";color:var(--color-text-secondary);font-size:var(--font-size-lg);animation:pulse var(--animation-duration-pulse) ease-in-out infinite}@media (prefers-reduced-motion: reduce){.nav-header,.nav-content{animation:none}.back-button,.levels-button{transition:none}}@media (prefers-high-contrast: high){.nav-header{border-bottom-width:2px;background:var(--color-background-secondary)}.back-button,.levels-button{border:2px solid currentColor}}.modal-overlay{position:fixed;inset:0;z-index:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.modal-backdrop{position:absolute;inset:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-content{background:#1a1f29;border:2px solid #60a5fa;border-radius:12px;box-shadow:0 25px 50px #00000080;max-height:90vh;overflow-y:auto;cursor:default;animation:slideIn .3s ease-out;z-index:var(--z-modal);margin:20px}.modal-content--small{width:90%;max-width:400px}.modal-content--medium{width:90%;max-width:600px}.modal-content--large{width:90%;max-width:800px}.modal-content--fullscreen{width:95%;height:90%;max-width:none;max-height:none}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid #60a5fa;background:#60a5fa1a}.modal-title{font-size:1.5rem;font-weight:700;color:#f1f1f0;margin:0}.modal-close-button{background:none;border:none;font-size:1.5rem;color:#9ca3af;cursor:pointer;padding:.5rem;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-button:hover{background:#ef4444;color:#fff;transform:scale(1.1)}.modal-body{padding:2rem}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#0d1117}.modal-content::-webkit-scrollbar-thumb{background:#60a5fa;border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:#22c55e}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.modal-content--small,.modal-content--medium,.modal-content--large{width:95%;max-width:none}.modal-content--fullscreen{width:98%;height:95%}.modal-header{padding:1rem 1.5rem}.modal-body{padding:1.5rem}.modal-title{font-size:1.25rem}.modal-close-button{width:36px;height:36px;font-size:1.25rem}}.progress-bar{width:100%}.progress-bar__label{font-size:.875rem;font-weight:600;color:#f1f1f0;margin-bottom:.5rem}.progress-bar__track{position:relative;background:#0d1117;border-radius:10px;overflow:hidden;border:2px solid}.progress-bar__fill{height:100%;transition:width .5s ease-in-out;border-radius:inherit;position:relative;overflow:hidden}.progress-bar__text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.8);z-index:1;color:#f1f1f0;font-size:.75rem}.progress-bar--small .progress-bar__track{height:16px}.progress-bar--small .progress-bar__text{font-size:.625rem}.progress-bar--medium .progress-bar__track{height:20px}.progress-bar--medium .progress-bar__text{font-size:.75rem}.progress-bar--large .progress-bar__track{height:24px}.progress-bar--large .progress-bar__text{font-size:.875rem}.progress-bar--default .progress-bar__track{border-color:#60a5fa}.progress-bar--default .progress-bar__fill{background:linear-gradient(90deg,#60a5fa,#3b82f6);box-shadow:0 0 10px #60a5fa80}.progress-bar--xp .progress-bar__track{border-color:#60a5fa}.progress-bar--xp .progress-bar__fill{background:linear-gradient(90deg,#60a5fa,#22c55e);box-shadow:0 0 10px #60a5fa80}.progress-bar--health .progress-bar__track{border-color:#ef4444}.progress-bar--health .progress-bar__fill{background:linear-gradient(90deg,#ef4444,#dc2626);box-shadow:0 0 10px #ef444480}.progress-bar--energy .progress-bar__track{border-color:#eab308}.progress-bar--energy .progress-bar__fill{background:linear-gradient(90deg,#eab308,#ca8a04);box-shadow:0 0 10px #eab30880}.progress-bar--animated .progress-bar__fill:after{content:"";position:absolute;inset:0;background-image:linear-gradient(-45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%,transparent);background-size:50px 50px;animation:move 2s linear infinite}@keyframes move{0%{background-position:0 0}to{background-position:50px 50px}}.quiz-container{width:100%;max-width:none}.quiz-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #60a5fa}.quiz-progress{flex:1;margin-right:2rem}.quiz-timer{background:#60a5fa1a;color:#60a5fa;padding:.75rem 1rem;border-radius:8px;border:2px solid #60a5fa;font-weight:700;font-size:1.1rem;min-width:80px;text-align:center;animation:pulse 1s ease-in-out infinite}.timer-warning{background:#ef44441a;color:#ef4444;border-color:#ef4444;animation:timerFlash .5s ease-in-out infinite}.quiz-question{margin-bottom:2rem}.question-text{font-size:1.5rem;font-weight:600;color:#f1f1f0;line-height:1.4;margin:0;text-align:center;padding:1.5rem;background:#60a5fa0d;border-radius:8px;border-left:4px solid #60a5fa}.quiz-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.quiz-option{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#0d1117;border:2px solid #9ca3af;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:1rem;text-align:left;width:100%}.quiz-option:hover:not(:disabled){border-color:#60a5fa;background:#60a5fa0d;transform:translateY(-2px);box-shadow:0 4px 12px #60a5fa33}.quiz-option.selected{border-color:#60a5fa;background:#60a5fa1a}.quiz-option.correct{border-color:#22c55e;background:#22c55e1a}.quiz-option.incorrect{border-color:#ef4444;background:#ef44441a}.quiz-option:disabled{cursor:not-allowed;opacity:.8}.option-letter{background:#60a5fa;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.quiz-option.correct .option-letter{background:#22c55e}.quiz-option.incorrect .option-letter{background:#ef4444}.option-text{flex:1;line-height:1.5;color:#f1f1f0}.correct-icon,.incorrect-icon{font-size:1.25rem;margin-left:auto}.quiz-explanation{margin-bottom:2rem;padding:1.5rem;background:#eab3081a;border:2px solid #eab308;border-radius:8px}.quiz-explanation h4{color:#eab308;margin:0 0 1rem;font-size:1.1rem}.quiz-explanation p{color:#f1f1f0;line-height:1.6;margin:0;font-size:1rem}.quiz-actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:2rem;border-top:1px solid #9ca3af}.no-answer-hint{color:#9ca3af;font-style:italic;text-align:center;flex:1;padding:1rem;font-size:.875rem}.quiz-results{text-align:center;padding:2rem 0}.results-header{margin-bottom:2rem}.results-title{font-size:2.5rem;margin-bottom:1rem;color:#f1f1f0}.score-display{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:12px;border:3px solid;font-size:1.5rem;font-weight:800}.score-display.success{background:#22c55e1a;color:#22c55e;border-color:#22c55e}.score-display.warning{background:#eab3081a;color:#eab308;border-color:#eab308}.score-display.danger{background:#ef44441a;color:#ef4444;border-color:#ef4444}.results-message{font-size:1.2rem;color:#9ca3af;margin-bottom:3rem}.results-breakdown{text-align:left;background:#1a1f2980;border-radius:8px;padding:2rem;margin-top:2rem}.results-breakdown h3{color:#60a5fa;margin-bottom:1.5rem;text-align:center}.result-item{display:flex;gap:1rem;padding:1rem;margin-bottom:1rem;border-radius:8px;border:2px solid}.result-item.correct{background:#22c55e0d;border-color:#22c55e}.result-item.incorrect{background:#ef44440d;border-color:#ef4444}.result-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex-shrink:0}.result-number{background:#60a5fa;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.result-icon{font-size:1.5rem}.result-details{flex:1}.result-question{font-weight:600;color:#f1f1f0;margin-bottom:.5rem}.result-answer,.result-correct{font-size:.875rem;margin:.25rem 0;line-height:1.4}.result-answer{color:#9ca3af}.result-correct{color:#22c55e}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes timerFlash{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@media (max-width: 768px){.quiz-header{flex-direction:column;align-items:stretch;gap:1rem}.quiz-progress{margin-right:0}.quiz-timer{align-self:center;font-size:1rem;padding:.5rem .75rem}.question-text{font-size:1.25rem;padding:1rem}.quiz-option{padding:.75rem 1rem;font-size:.9rem}.option-letter{width:28px;height:28px;font-size:.75rem}.quiz-actions{flex-direction:column;align-items:stretch}.results-title{font-size:2rem}.score-display{font-size:1.25rem;padding:.75rem 1.5rem}.results-breakdown{padding:1rem}.result-item{flex-direction:column;gap:.75rem}.result-header{flex-direction:row;justify-content:center}}.unit-modal__content{max-width:none}.unit-modal__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #60a5fa}.unit-modal__title{font-size:2rem;font-weight:800;color:#f1f1f0;margin:0;flex:1;line-height:1.2}.unit-modal__rewards{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end;margin-left:2rem}.reward-badge{padding:.5rem 1rem;border-radius:6px;font-weight:700;font-size:.875rem;border:2px solid;text-align:center;min-width:80px}.reward-badge.xp{background:#60a5fa1a;color:#60a5fa;border-color:#60a5fa}.reward-badge.coins{background:#fbbf241a;color:#fbbf24;border-color:#fbbf24}.unit-modal__section{margin-bottom:2rem}.section-title{font-size:1.25rem;font-weight:700;color:#60a5fa;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.unit-summary{font-size:1.1rem;line-height:1.6;color:#f1f1f0;margin:0;padding:1.5rem;background:#60a5fa0d;border-left:4px solid #60a5fa;border-radius:0 8px 8px 0}.examples-list{display:flex;flex-direction:column;gap:1rem}.example-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#0d1117;border:1px solid #9ca3af;border-radius:8px;transition:all .2s ease}.example-item:hover{border-color:#60a5fa;transform:translateY(-2px);box-shadow:0 4px 12px #60a5fa33}.example-number{background:#60a5fa;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.example-text{font-size:1rem;line-height:1.5;color:#f1f1f0;flex:1}.quiz-results{padding:1.5rem;background:#22c55e1a;border:2px solid #22c55e;border-radius:8px}.success-message{font-size:1.1rem;font-weight:600;color:#22c55e;margin:.5rem 0 0}.unit-modal__actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2rem;padding-top:2rem;border-top:1px solid #9ca3af}.start-quiz-button{min-width:200px;font-size:1.1rem;padding:.75rem 2rem}.completed-actions{display:flex;gap:1rem}.close-button{margin-left:auto}@media (max-width: 768px){.unit-modal__header{flex-direction:column;align-items:flex-start;gap:1rem}.unit-modal__rewards{margin-left:0;align-items:flex-start;flex-direction:row;gap:.75rem}.unit-modal__title{font-size:1.5rem}.reward-badge{font-size:.75rem;padding:.375rem .75rem;min-width:70px}.unit-summary{font-size:1rem;padding:1rem}.example-item{flex-direction:column;gap:.5rem}.example-number{align-self:flex-start}.unit-modal__actions{flex-direction:column;align-items:stretch}.completed-actions{flex-direction:column}.close-button{margin-left:0}}
