:root{--color-primary: #1E3A5F;--color-primary-dark: #152A45;--color-primary-light: #2D4A6F;--color-primary-bg: #E8F0FE;--color-secondary: #7C6CDB;--color-secondary-light: #9D8FE8;--color-secondary-dark: #5C4CBB;--color-accent: #F5D547;--color-highlight: #5B9BD5;--color-lavender: #C5BDF2;--color-purple-light: #B8B0E8;--color-mint: #B8E6D3;--color-green-light: #A8E6CF;--color-text: #1E3A5F;--color-text-primary: #1E3A5F;--color-text-secondary: #4A5568;--color-text-muted: #6B7C93;--color-text-light: #6B7C93;--color-text-inverse: #FFFFFF;--color-background: #F8FAFC;--color-surface: #FFFFFF;--color-surface-elevated: #FFFFFF;--color-bg-primary: #FFFFFF;--color-bg-secondary: #F8FAFC;--color-bg-tertiary: #E8EDF3;--color-border: #D1D9E6;--color-border-light: #E8EDF3;--color-neutral: #6B7C93;--color-neutral-light: #E8EDF3;--color-neutral-dark: #4A5568;--color-success: #2D8B6F;--color-success-light: #A8E6CF;--color-success-dark: #1D7B5F;--color-success-bg: #E5F5EE;--color-warning: #F5A623;--color-warning-light: #FFD180;--color-warning-dark: #E59613;--color-warning-bg: #FFF8E6;--color-error: #E53935;--color-error-light: #EF9A9A;--color-error-dark: #C62828;--color-error-bg: #FFEBEE;--color-info: #5B9BD5;--color-info-bg: #E8F0FE;--color-state-neutral: #78909C;--color-state-stress: #EF5350;--color-state-attended: #2D8B6F;--color-state-saturated: #8D6E63;--color-bot: #7C6CDB;--color-person-uncared: #F5A623;--color-person-cared: #2D8B6F;--color-obstacle: #6B7C93;--color-resource: #F5D547;--color-target: #5B9BD5;--color-block-action: #5B9BD5;--color-block-loop: #F5A623;--color-block-condition: #7C6CDB;--color-block-container: #2D8B6F;--color-bg-light-blue: #E8F0FE;--color-bg-light-purple: #E8E5F7;--color-bg-light-green: #E5F5EE;--gradient-primary: linear-gradient(135deg, #1E3A5F 0%, #2D4A6F 100%);--gradient-secondary: linear-gradient(135deg, #7C6CDB 0%, #9D8FE8 100%);--gradient-background: linear-gradient(135deg, #E8F0FE 0%, #E8E5F7 50%, #E5F5EE 100%);--gradient-card: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);--gradient-success: linear-gradient(135deg, #2D8B6F 0%, #3DA882 100%);--gradient-gold: linear-gradient(135deg, #F5D547 0%, #E5C537 100%);--font-family: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono: "Fira Code", "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: 2rem;--font-size-4xl: 2.5rem;--font-weight-normal: 400;--font-weight-medium: 600;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extra: 800;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-xxl: 3rem;--border-radius-sm: 4px;--border-radius: 8px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--border-radius-2xl: 24px;--border-radius-full: 9999px;--border-width: 1px;--border-width-thick: 2px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .06);--shadow-glow: 0 0 20px rgba(124, 108, 219, .3);--shadow-glow-success: 0 0 20px rgba(45, 139, 111, .3);--transition-fast: .15s ease;--transition: .25s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-popover: 400;--z-tooltip: 500;--z-notification: 600;--header-height: 64px;--sidebar-width: 380px;--max-content-width: 1400px;--cell-size: 64px;--block-height: 48px}@media(max-width:1200px){:root{--cell-size: 56px;--sidebar-width: 340px}}@media(max-width:900px){:root{--cell-size: 48px;--sidebar-width: 300px;--font-size-base: .9375rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background:var(--gradient-background);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 20% 80%,rgba(124,108,219,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(91,155,213,.05) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(45,139,111,.03) 0%,transparent 70%);pointer-events:none;z-index:-1}#app{min-height:100vh;display:flex;flex-direction:column;position:relative}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background:var(--color-primary-light);color:var(--color-text-inverse)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:var(--border-radius-full)}::-webkit-scrollbar-thumb{background:var(--color-primary-light);border-radius:var(--border-radius-full);transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.text-left{text-align:left}.font-semibold{font-weight:var(--font-weight-semibold)}.flex-row{flex-direction:row}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.justify-start{justify-content:flex-start}.gap-xs{gap:var(--spacing-xs)}.gap-xl{gap:var(--spacing-xl)}.m-0{margin:0}.m-xs{margin:var(--spacing-xs)}.p-0{padding:0}.p-xl{padding:var(--spacing-xl)}.visible{visibility:visible}.cursor-pointer{cursor:pointer}.cursor-grab{cursor:grab}.cursor-grabbing{cursor:grabbing}.pointer-events-none{pointer-events:none}.select-none{-webkit-user-select:none;user-select:none}.transition{transition:all var(--transition)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes glow{0%,to{box-shadow:0 0 5px #7c6cdb4d}50%{box-shadow:0 0 20px #7c6cdb99}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}.animate-fade-in-up{animation:fadeInUp var(--transition-normal) forwards}.animate-fade-in-down{animation:fadeInDown var(--transition-normal) forwards}.animate-scale-in{animation:scaleIn var(--transition-spring) forwards}.animate-pulse{animation:pulse 2s infinite}.animate-bounce{animation:bounce 1s infinite}.animate-float{animation:float 3s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-pop{animation:pop .3s ease-out}.animate-glow{animation:glow 2s ease-in-out infinite}.stagger-item{opacity:0;animation:fadeInUp var(--transition-normal) forwards}.stagger-item:nth-child(1){animation-delay:0ms}.stagger-item:nth-child(2){animation-delay:50ms}.stagger-item:nth-child(3){animation-delay:.1s}.stagger-item:nth-child(4){animation-delay:.15s}.stagger-item:nth-child(5){animation-delay:.2s}.stagger-item:nth-child(6){animation-delay:.25s}.stagger-item:nth-child(7){animation-delay:.3s}.stagger-item:nth-child(8){animation-delay:.35s}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--spacing-md);background:var(--gradient-background)}.loading-screen h1{color:var(--color-primary);font-size:var(--font-size-4xl);animation:pulse 2s ease-in-out infinite}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);line-height:1;text-decoration:none;border:none;border-radius:var(--border-radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn:hover:before{left:100%}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn:disabled:before{display:none}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm);border-radius:var(--border-radius-md)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg);border-radius:var(--border-radius-xl)}.btn-xl{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-xl);border-radius:var(--border-radius-xl)}.btn-primary{background:var(--gradient-primary);color:var(--color-text-inverse);box-shadow:var(--shadow-md),0 4px #152a45}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-lg),0 6px #152a45;transform:translateY(-2px)}.btn-primary:active:not(:disabled){box-shadow:var(--shadow-sm),0 2px #152a45;transform:translateY(2px)}.btn-secondary{background:var(--color-bg-primary);color:var(--color-primary);border:2px solid var(--color-primary);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-bg);box-shadow:var(--shadow-md)}.btn-success{background:var(--gradient-success);color:var(--color-text-inverse);box-shadow:var(--shadow-md),0 4px #1d7b5f}.btn-success:hover:not(:disabled){box-shadow:var(--shadow-lg),0 6px #1d7b5f;transform:translateY(-2px)}.btn-outline{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary);color:var(--color-text-inverse);box-shadow:var(--shadow-md)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-bg-secondary);color:var(--color-text-primary)}.btn-danger{background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error-dark) 100%);color:var(--color-text-inverse);box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-icon{padding:var(--spacing-sm);min-width:40px;min-height:40px;aspect-ratio:1}.btn-play{background:var(--gradient-primary);color:var(--color-text-inverse);padding:var(--spacing-lg) var(--spacing-3xl);font-size:var(--font-size-xl);font-weight:var(--font-weight-extra);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-lg),0 6px #152a45,var(--shadow-glow);text-transform:uppercase;letter-spacing:.05em}.btn-play:hover:not(:disabled){transform:translateY(-4px);box-shadow:var(--shadow-xl),0 10px #152a45,0 0 30px #7c6cdb66}.btn-play:active:not(:disabled){transform:translateY(2px);box-shadow:var(--shadow-md),0 2px #152a45,var(--shadow-glow)}.btn-play .btn-icon{font-size:1.5em;animation:pulse 2s infinite}.btn-loading{pointer-events:none}.btn-loading .btn-text{opacity:0}.btn-loading:after{content:"";position:absolute;width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.card{background:var(--color-bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.card-interactive:hover{transform:translateY(-4px)}.card-elevated{box-shadow:var(--shadow-lg)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border-light);background:var(--color-bg-secondary)}.game-panel{background:var(--color-bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-lg);border:2px solid var(--color-border-light);overflow:hidden}.game-panel-header{background:var(--gradient-primary);color:var(--color-text-inverse);padding:var(--spacing-sm) var(--spacing-md);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:var(--spacing-sm)}.game-panel-body{padding:var(--spacing-md)}.panel-glow{position:relative}.panel-glow:before{content:"";position:absolute;inset:-2px;background:var(--gradient-secondary);border-radius:inherit;z-index:-1;opacity:0;transition:opacity var(--transition-normal)}.panel-glow:hover:before,.panel-glow.active:before{opacity:1}.modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-lg);animation:fadeIn var(--transition-fast)}.modal{background:var(--color-bg-primary);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-xl);max-width:500px;width:100%;max-height:90vh;overflow:auto;animation:scaleIn var(--transition-spring)}.modal-header{padding:var(--spacing-lg);text-align:center;border-bottom:1px solid var(--color-border-light)}.modal-title{font-size:var(--font-size-2xl);margin:0}.modal-body{padding:var(--spacing-lg)}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);display:flex;gap:var(--spacing-md);justify-content:center;border-top:1px solid var(--color-border-light)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--border-radius-full);background-color:var(--color-neutral-light);color:var(--color-text)}.badge-primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.badge-secondary{background-color:var(--color-secondary);color:var(--color-text-inverse)}.badge-success{background-color:var(--color-success);color:var(--color-text-inverse)}.badge-warning{background-color:var(--color-warning);color:var(--color-text)}.badge-error{background-color:var(--color-error);color:var(--color-text-inverse)}.badge-lg{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--border-radius-lg);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f1a}.input::placeholder{color:var(--color-text-muted)}.progress{width:100%;height:8px;background-color:var(--color-neutral-light);border-radius:var(--border-radius-full);overflow:hidden}.progress-bar{height:100%;background:var(--gradient-primary);border-radius:var(--border-radius-full);transition:width var(--transition)}.progress-bar-success{background:var(--gradient-success)}.progress-bar-warning{background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-warning-dark) 100%)}.progress-bar-error{background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error-dark) 100%)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);background-color:var(--color-primary-dark);color:var(--color-text-inverse);border-radius:var(--border-radius-md);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:var(--z-tooltip);margin-bottom:var(--spacing-xs)}[data-tooltip]:hover:after{opacity:1}.spinner{width:24px;height:24px;border:3px solid var(--color-neutral-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:40px;height:40px;border-width:4px}.spinner-secondary{border-top-color:var(--color-secondary)}.stars{display:flex;gap:var(--spacing-xs)}.star{font-size:var(--font-size-2xl);color:var(--color-neutral-light);transition:all var(--transition-fast)}.star-filled{color:var(--color-accent);text-shadow:0 2px 8px rgba(245,213,71,.4)}.star-filled.animate{animation:pop .3s ease-out}.notification{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);border-left:4px solid var(--color-info);animation:slideInRight var(--transition-normal)}.notification-success{border-left-color:var(--color-success);background:var(--color-success-bg)}.notification-warning{border-left-color:var(--color-warning);background:var(--color-warning-bg)}.notification-error{border-left-color:var(--color-error);background:var(--color-error-bg)}.divider{height:1px;background:var(--color-border-light);margin:var(--spacing-lg) 0}.divider-vertical{width:1px;height:auto;margin:0 var(--spacing-lg)}.btn-control{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);line-height:1;border:none;border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.btn-control-play{background:var(--gradient-success);color:var(--color-text-inverse);box-shadow:0 3px #1d7b5f,var(--shadow-sm)}.btn-control-play:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px #1d7b5f,var(--shadow-md)}.btn-control-play:active:not(:disabled){transform:translateY(2px);box-shadow:0 1px #1d7b5f}.btn-control-pause{background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-warning-dark) 100%);color:var(--color-text-inverse);box-shadow:0 3px #d58603,var(--shadow-sm)}.btn-control-stop{background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error-dark) 100%);color:var(--color-text-inverse);box-shadow:0 3px #c62828,var(--shadow-sm)}.btn-control-reset{background:var(--color-bg-secondary);color:var(--color-text-secondary);border:2px solid var(--color-border)}.btn-control-reset:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:var(--color-primary);color:var(--color-primary)}.btn-circle{width:48px;height:48px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl)}.btn-circle-sm{width:36px;height:36px;font-size:var(--font-size-lg)}.btn-circle-lg{width:64px;height:64px;font-size:var(--font-size-2xl)}.btn-fab{position:fixed;bottom:var(--spacing-xl);right:var(--spacing-xl);width:56px;height:56px;border-radius:50%;background:var(--gradient-primary);color:var(--color-text-inverse);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);border:none;cursor:pointer;transition:all var(--transition-fast);z-index:var(--z-sticky)}.btn-fab:hover{transform:scale(1.1);box-shadow:var(--shadow-xl)}.btn-fab:active{transform:scale(.95)}.btn-group{display:inline-flex;border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.btn-group .btn{border-radius:0;margin:0}.btn-group .btn:first-child{border-top-left-radius:var(--border-radius-lg);border-bottom-left-radius:var(--border-radius-lg)}.btn-group .btn:last-child{border-top-right-radius:var(--border-radius-lg);border-bottom-right-radius:var(--border-radius-lg)}.btn-group .btn:not(:last-child){border-right:1px solid rgba(255,255,255,.2)}.btn-animated-icon .btn-icon{transition:transform var(--transition-fast)}.btn-animated-icon:hover .btn-icon{transform:scale(1.2)}.btn-animated-icon:active .btn-icon{transform:scale(.9)}.speed-controls{display:flex;align-items:center;gap:var(--spacing-xs);background:var(--color-bg-secondary);padding:var(--spacing-xs);border-radius:var(--border-radius-lg)}.speed-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);background:transparent;border:none;border-radius:var(--border-radius-md);cursor:pointer;color:var(--color-text-muted);transition:all var(--transition-fast)}.speed-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.speed-btn.active{background:var(--color-primary);color:var(--color-text-inverse)}.btn-nav{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--border-radius-lg);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.btn-nav:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-bg)}.btn-nav:disabled{opacity:.5;cursor:not-allowed}.btn-nav-prev .btn-icon{margin-right:var(--spacing-xs)}.btn-nav-next .btn-icon{margin-left:var(--spacing-xs)}.btn-toggle{position:relative;width:48px;height:24px;background:var(--color-neutral-light);border:none;border-radius:var(--border-radius-full);cursor:pointer;transition:background var(--transition-fast)}.btn-toggle:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--color-bg-primary);border-radius:50%;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.btn-toggle.active{background:var(--color-success)}.btn-toggle.active:after{transform:translate(24px)}.btn-close{width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--font-size-lg);transition:all var(--transition-fast)}.btn-close:hover{background:var(--color-error-bg);color:var(--color-error)}.btn-link{background:none;border:none;padding:0;color:var(--color-primary);font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.btn-link:hover{color:var(--color-primary-dark)}.level-card{background:var(--gradient-card);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-md);border:2px solid var(--color-border-light);padding:var(--spacing-lg);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.level-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-fast)}.level-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary-light)}.level-card:hover:before{opacity:1}.level-card.completed{border-color:var(--color-success)}.level-card.completed:before{background:var(--gradient-success);opacity:1}.level-card.locked{opacity:.6;cursor:not-allowed;filter:grayscale(.5)}.level-card.locked:hover{transform:none;box-shadow:var(--shadow-md)}.level-card-number{width:40px;height:40px;background:var(--gradient-primary);color:var(--color-text-inverse);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-md)}.level-card.completed .level-card-number{background:var(--gradient-success)}.level-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.level-card-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.level-card-stars{display:flex;gap:var(--spacing-xs)}.info-card{background:var(--color-bg-primary);border-radius:var(--border-radius-lg);padding:var(--spacing-md);border-left:4px solid var(--color-info);box-shadow:var(--shadow-sm)}.info-card-success{border-left-color:var(--color-success);background:var(--color-success-bg)}.info-card-warning{border-left-color:var(--color-warning);background:var(--color-warning-bg)}.info-card-error{border-left-color:var(--color-error);background:var(--color-error-bg)}.stat-card{background:var(--color-bg-primary);border-radius:var(--border-radius-lg);padding:var(--spacing-md);text-align:center;box-shadow:var(--shadow-sm)}.stat-card-icon{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm)}.stat-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:var(--spacing-xs)}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.result-panel{background:var(--color-bg-primary);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-xl);padding:var(--spacing-2xl);text-align:center;animation:scaleIn var(--transition-spring)}.result-panel-success{border:3px solid var(--color-success)}.result-panel-success:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,var(--color-success-bg) 0%,transparent 70%);border-radius:inherit;z-index:-1}.result-panel-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:bounce 1s ease infinite}.result-panel-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.result-panel-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.result-panel-stars{display:flex;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.result-panel-stars .star{font-size:3rem}.result-panel-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.instruction-panel{background:var(--color-bg-light-blue);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);border:2px solid var(--color-highlight)}.instruction-panel-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.instruction-panel-icon{width:32px;height:32px;background:var(--color-highlight);color:var(--color-text-inverse);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg)}.instruction-panel-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.instruction-panel-content{color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.objective-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--border-radius-lg);border:2px solid transparent;transition:all var(--transition-fast)}.objective-card.completed{background:var(--color-success-bg);border-color:var(--color-success)}.objective-card.failed{background:var(--color-error-bg);border-color:var(--color-error)}.objective-card-icon{width:40px;height:40px;background:var(--color-neutral-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);flex-shrink:0}.objective-card.completed .objective-card-icon{background:var(--color-success);color:var(--color-text-inverse)}.objective-card.failed .objective-card-icon{background:var(--color-error);color:var(--color-text-inverse)}.objective-card-content{flex:1}.objective-card-title{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.objective-card-description{font-size:var(--font-size-sm);color:var(--color-text-muted)}.floating-panel{position:absolute;background:var(--color-bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-lg);z-index:var(--z-popover);animation:fadeInUp var(--transition-normal)}.floating-panel-arrow{position:absolute;width:12px;height:12px;background:var(--color-bg-primary);transform:rotate(45deg);box-shadow:-2px -2px 4px #0000000d}.floating-panel-arrow.top{top:-6px;left:50%;margin-left:-6px}.floating-panel-arrow.bottom{bottom:-6px;left:50%;margin-left:-6px}.collapsible-panel{background:var(--color-bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.collapsible-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);cursor:pointer;transition:background var(--transition-fast)}.collapsible-panel-header:hover{background:var(--color-bg-secondary)}.collapsible-panel-title{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.collapsible-panel-icon{transition:transform var(--transition-fast)}.collapsible-panel.open .collapsible-panel-icon{transform:rotate(180deg)}.collapsible-panel-content{padding:0 var(--spacing-md) var(--spacing-md);display:none}.collapsible-panel.open .collapsible-panel-content{display:block;animation:fadeIn var(--transition-fast)}.map-container{background:var(--color-bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-lg);padding:var(--spacing-lg);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.map-container:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,var(--color-border-light) 1px,transparent 0);background-size:20px 20px;opacity:.5;pointer-events:none}.map-grid{display:grid;gap:4px;background:var(--color-bg-secondary);padding:8px;border-radius:var(--border-radius-lg);position:relative;z-index:1}.map-cell{width:var(--cell-size);height:var(--cell-size);background:var(--color-bg-primary);border-radius:var(--border-radius-md);position:relative;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.map-cell-resource{background:linear-gradient(135deg,#fff8e1,#ffecb3)}.map-cell-visited{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.entity{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:all var(--transition-normal)}.entity-bot{width:48px;height:48px;background:var(--gradient-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md),0 0 0 4px #7c6cdb33;font-size:24px;z-index:10}.entity-bot:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--color-secondary);animation:pulse 1.5s infinite;opacity:.5}.entity-bot.moving{animation:float .3s ease-in-out}.bot{background:var(--gradient-secondary);box-shadow:var(--shadow-md),0 0 0 4px #7c6cdb33;z-index:10}.entity-person{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all var(--transition-spring)}.entity-person.uncared{background:linear-gradient(135deg,#fff0d4,#f5d547);box-shadow:0 4px 8px #f5a6234d}.entity-person.cared{background:linear-gradient(135deg,#b8e6d3,#a8e6cf);box-shadow:0 4px 8px #2d8b6f4d;animation:bounce .5s ease}.person{background-color:var(--color-surface);border:3px solid currentColor}.entity-resource{width:32px;height:32px;background:var(--gradient-gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:0 4px 8px #f5d5474d;animation:float 2s ease-in-out infinite}.entity-bot[data-direction=north]{transform:translate(-50%,-50%) rotate(0)}.entity-bot[data-direction=east]{transform:translate(-50%,-50%) rotate(90deg)}.entity-bot[data-direction=south]{transform:translate(-50%,-50%) rotate(180deg)}.entity-bot[data-direction=west]{transform:translate(-50%,-50%) rotate(270deg)}.cell-effect{position:absolute;inset:0;pointer-events:none;border-radius:inherit;z-index:20}.cell-effect-care{background:radial-gradient(circle,rgba(45,139,111,.4) 0%,transparent 70%);animation:pulse .5s ease-out}.cell-effect-collect{background:radial-gradient(circle,rgba(245,213,71,.4) 0%,transparent 70%);animation:pulse .5s ease-out}.cell-effect-error{background:radial-gradient(circle,rgba(229,57,53,.3) 0%,transparent 70%);animation:shake .3s ease-out}.cell-effect-move{background:radial-gradient(circle,rgba(124,108,219,.2) 0%,transparent 70%);animation:fadeIn .2s ease-out}.map-container.celebrating .entity-bot,.map-container.celebrating .bot{animation:bounce .5s ease infinite}.map-container.celebrating .entity-person.cared,.map-container.celebrating .person-attended{animation:float 1s ease-in-out infinite}.confetti{position:absolute;width:10px;height:10px;background:var(--color-accent);animation:confetti-fall 3s ease-out forwards;z-index:100}@keyframes confetti-fall{0%{transform:translateY(-100%) rotate(0);opacity:1}to{transform:translateY(500%) rotate(720deg);opacity:0}}.mini-map{position:absolute;bottom:var(--spacing-md);right:var(--spacing-md);background:var(--color-bg-primary);border-radius:var(--border-radius-md);box-shadow:var(--shadow-md);padding:var(--spacing-sm);opacity:.8;transition:opacity var(--transition-fast)}.mini-map:hover{opacity:1}.mini-map-cell{width:8px;height:8px;border-radius:2px}.map-overlay{position:absolute;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:50;animation:fadeIn var(--transition-fast)}.map-overlay-content{text-align:center;color:var(--color-text-inverse)}.map-overlay-icon{font-size:4rem;margin-bottom:var(--spacing-md)}.map-overlay-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}@media(max-width:768px){.map-container{padding:var(--spacing-md)}.entity-bot,.bot{width:36px;height:36px;font-size:18px}.entity-person,.person,.map-entity{width:32px;height:32px;font-size:16px}.entity-resource{width:24px;height:24px;font-size:12px}}.block-palette{background:var(--color-bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-md);padding:var(--spacing-md)}.block-palette-section{margin-bottom:var(--spacing-md)}.block-palette-section:last-child{margin-bottom:0}.block-palette-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--spacing-sm)}.block-palette-items{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.block{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);min-height:var(--block-height);border-radius:var(--border-radius-md);cursor:grab;-webkit-user-select:none;user-select:none;transition:all var(--transition-fast);position:relative;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.block:hover{transform:scale(1.02);box-shadow:var(--shadow-md)}.block:active{cursor:grabbing;transform:scale(1.05)}.block.dragging{opacity:.8;transform:scale(1.1) rotate(2deg);box-shadow:var(--shadow-xl);z-index:100}.block-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff4d;border-radius:var(--border-radius-sm);font-size:14px}.block-label{flex:1}.block-action{background:linear-gradient(135deg,#5b9bd5,#4a8ac4);color:#fff;box-shadow:0 3px #3a7ab4,var(--shadow-sm)}.block-action:active{box-shadow:0 1px #3a7ab4;transform:translateY(2px)}.block-loop{background:linear-gradient(135deg,#f5a623,#e59613);color:#fff;box-shadow:0 3px #d58603,var(--shadow-sm)}.block-loop:active{box-shadow:0 1px #d58603;transform:translateY(2px)}.block-condition{background:linear-gradient(135deg,#7c6cdb,#6c5ccb);color:#fff;box-shadow:0 3px #5c4cbb,var(--shadow-sm)}.block-condition:active{box-shadow:0 1px #5c4cbb;transform:translateY(2px)}.block-container{background:linear-gradient(135deg,#2d8b6f,#1d7b5f);color:#fff;box-shadow:0 3px #0d6b4f,var(--shadow-sm);flex-direction:column;align-items:stretch;padding:var(--spacing-sm)}.block-container:active{box-shadow:0 1px #0d6b4f;transform:translateY(2px)}.program-area{background:var(--color-bg-secondary);border:2px dashed var(--color-border);border-radius:var(--border-radius-lg);min-height:200px;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs);transition:all var(--transition-fast)}.program-area.drag-over{border-color:var(--color-primary);background:var(--color-primary-bg);box-shadow:var(--shadow-glow)}.program-area.empty:before{content:"Arrastra bloques aquí";display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);font-style:italic}.program-block{margin-left:0;transition:margin-left var(--transition-fast)}.program-block.nested-1{margin-left:20px}.program-block.nested-2{margin-left:40px}.program-block.nested-3{margin-left:60px}.block-children{min-height:48px;background:#ffffffe6;border-radius:var(--border-radius-md);margin-top:var(--spacing-xs);padding:var(--spacing-sm);border:2px dashed var(--color-border)}.block-children.drag-over{border-color:var(--color-primary);background:var(--color-primary-bg)}.block:hover .block-remove,.block-element:hover .block-remove{opacity:1}.drop-indicator{height:4px;background:var(--color-primary);border-radius:var(--border-radius-full);margin:var(--spacing-xs) 0;animation:pulse .5s infinite}.block-ghost{position:fixed;pointer-events:none;z-index:1000;opacity:.9;transform:rotate(3deg)}.block-counter{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--border-radius-md);font-size:var(--font-size-sm)}.block-counter-value{font-weight:var(--font-weight-bold);color:var(--color-primary)}.block-counter.warning .block-counter-value{color:var(--color-warning)}.block-counter.error .block-counter-value{color:var(--color-error)}.block.executing,.block-element.executing{box-shadow:0 0 0 3px var(--color-accent),var(--shadow-glow);animation:glow 1s ease-in-out infinite}.block.error,.block-element.error{box-shadow:0 0 0 3px var(--color-error);animation:shake .3s ease-out}.block.completed,.block-element.completed{opacity:.7}.block.completed:after,.block-element.completed:after{content:"✓";position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%);color:var(--color-success);font-weight:var(--font-weight-bold)}.block-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary-dark);color:var(--color-text-inverse);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:var(--z-tooltip);margin-bottom:var(--spacing-sm)}.block:hover .block-tooltip{opacity:1}.block-tooltip:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:var(--color-primary-dark) transparent transparent transparent}@media(max-width:768px){.block{padding:var(--spacing-xs) var(--spacing-sm);min-height:40px;font-size:var(--font-size-xs)}.block-icon{width:20px;height:20px;font-size:12px}.block-palette{padding:var(--spacing-sm)}.block-counter{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:var(--font-weight-bold)}.font-medium{font-weight:var(--font-weight-medium)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.hidden{display:none!important}.invisible{visibility:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media(max-width:768px){.hide-mobile{display:none!important}}@media(min-width:769px){.hide-desktop{display:none!important}}.welcome-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 50%,var(--color-secondary) 100%);padding:var(--spacing-xl)}.welcome-content{text-align:center;max-width:500px;color:var(--color-text-inverse)}.welcome-header{margin-bottom:var(--spacing-xl)}.logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.logo-icon{font-size:4rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.logo-text{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin:0;color:#fff}.tagline{font-size:var(--font-size-xl);opacity:.9;font-style:italic;margin:0}.welcome-description{margin-bottom:var(--spacing-xxl)}.intro-text{font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-md)}.sub-text{font-size:var(--font-size-base);opacity:.8;margin:0}.player-name-section{margin-bottom:var(--spacing-xl)}.name-label{display:block;font-size:var(--font-size-sm);opacity:.9;margin-bottom:var(--spacing-sm)}.player-name-input{width:100%;max-width:300px;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg);text-align:center;border:2px solid rgba(255,255,255,.3);border-radius:var(--radius-lg);background:#ffffff1a;color:var(--color-text-inverse);outline:none;transition:all var(--transition)}.player-name-input::placeholder{color:#ffffff80}.player-name-input:focus{border-color:#fff9;background:#ffffff26;box-shadow:0 0 20px #ffffff1a}.welcome-actions{margin-bottom:var(--spacing-xxl)}.start-btn{padding:var(--spacing-md) var(--spacing-xxl);font-size:var(--font-size-xl);background-color:var(--color-success);border:none;box-shadow:var(--shadow-lg);transition:transform var(--transition),box-shadow var(--transition)}.start-btn:hover{transform:scale(1.05);box-shadow:var(--shadow-xl)}.welcome-footer{opacity:.7}.footer-text{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.brand-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.map-view{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background:var(--color-bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.map-view:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,var(--color-border-light) 1px,transparent 0);background-size:20px 20px;opacity:.5;pointer-events:none}.map-grid{display:grid;grid-template-columns:repeat(var(--grid-cols),var(--cell-size));grid-template-rows:repeat(var(--grid-rows),var(--cell-size));gap:4px;background-color:var(--color-bg-secondary);padding:8px;border-radius:var(--border-radius-lg);position:relative;z-index:1;overflow:visible}.map-cell{width:var(--cell-size);height:var(--cell-size);background:var(--color-bg-primary);border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.map-cell:hover{box-shadow:var(--shadow-md);transform:scale(1.02)}.map-cell-empty{background:linear-gradient(135deg,#fafafa,#f5f5f5)}.map-cell-obstacle{background:linear-gradient(135deg,#cfd8dc,#b0bec5);box-shadow:inset 0 2px 4px #0000001a}.map-cell-wall{background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);box-shadow:inset 0 2px 4px #0003}.map-cell-block{background:linear-gradient(135deg,var(--color-neutral-dark) 0%,var(--color-neutral) 100%)}.map-cell-target{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px dashed var(--color-target);animation:pulse 2s infinite}.map-cell-highlight-active{background:linear-gradient(135deg,var(--color-primary-bg) 0%,var(--color-bg-light-blue) 100%);box-shadow:0 0 0 2px var(--color-primary-light)}.map-cell-highlight-success{background:linear-gradient(135deg,var(--color-success-bg) 0%,var(--color-green-light) 100%);box-shadow:0 0 0 2px var(--color-success)}.map-cell-highlight-error{background:linear-gradient(135deg,var(--color-error-bg) 0%,var(--color-error-light) 100%);box-shadow:0 0 0 2px var(--color-error);animation:shake .3s ease-out}.map-entity{position:absolute;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;transition:all var(--transition-normal);z-index:1}.bot{background:var(--gradient-secondary);box-shadow:var(--shadow-md),0 0 0 4px #7c6cdb33;z-index:2}.bot-overlay{position:absolute;transition:left .4s ease-out,top .4s ease-out;z-index:10}.bot:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--color-secondary);animation:pulse 1.5s infinite;opacity:.5}.bot-icon{filter:grayscale(0)}.bot.moving{animation:float .3s ease-in-out}.person{background-color:var(--color-surface);border:3px solid currentColor;transition:all var(--transition-spring)}.person-neutral{color:var(--color-state-neutral);border-color:var(--color-state-neutral)}.person-stress-high{color:var(--color-state-stress);border-color:var(--color-state-stress);animation:pulse 1s ease-in-out infinite}.person-attended{color:var(--color-state-attended);border-color:var(--color-state-attended);background:linear-gradient(135deg,#b8e6d3,#a8e6cf)}.person-saturated{color:var(--color-state-saturated);border-color:var(--color-state-saturated)}.person-no-response{color:var(--color-neutral);border-color:var(--color-neutral);opacity:.7}.person-unknown{color:var(--color-secondary);border-color:var(--color-secondary);background:linear-gradient(135deg,#e8e3f3,#d4cce8)}.bot-info-bubble{position:absolute;top:-28px;left:50%;transform:translate(-50%);background:var(--color-bg-primary);border-radius:var(--border-radius-md);padding:2px 6px;box-shadow:var(--shadow-md);border:2px solid currentColor;z-index:20;animation:bubble-appear .3s ease-out}.bot-info-bubble:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid currentColor}.bubble-icon{font-size:16px}.bubble-unknown{color:var(--color-secondary);border-color:var(--color-secondary)}.bubble-neutral{color:var(--color-state-neutral);border-color:var(--color-state-neutral)}.bubble-stress-high{color:var(--color-state-stress);border-color:var(--color-state-stress)}.bubble-attended{color:var(--color-state-attended);border-color:var(--color-state-attended)}.bubble-saturated{color:var(--color-state-saturated);border-color:var(--color-state-saturated)}.bubble-no-response{color:var(--color-neutral);border-color:var(--color-neutral)}@keyframes bubble-appear{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.map-view.celebrating .bot{animation:bounce .5s ease infinite}.map-view.celebrating .person-attended{animation:float 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:768px){.map-view{--cell-size: 40px;padding:var(--spacing-sm)}.map-entity{width:32px;height:32px;font-size:20px}}.block-element{background-color:var(--block-color, var(--color-primary));border-radius:var(--border-radius-md);margin-bottom:var(--spacing-xs);-webkit-user-select:none;user-select:none;transition:all var(--transition-fast)}.block-element:hover{transform:scale(1.02);box-shadow:var(--shadow-md)}.block-element.dragging{opacity:.8;transform:scale(1.05) rotate(2deg);box-shadow:var(--shadow-xl);z-index:100}.block-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-inverse);cursor:grab;border-radius:var(--border-radius-md);min-height:var(--block-height)}.block-header:active{cursor:grabbing}.block-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff4d;border-radius:var(--border-radius-sm);font-size:var(--font-size-lg)}.block-label{flex:1;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.block-remove{width:24px;height:24px;border:none;background:#fff3;color:var(--color-text-inverse);border-radius:50%;cursor:pointer;font-size:var(--font-size-lg);line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-fast)}.block-element:hover .block-remove{opacity:1}.block-remove:hover{background:#fff6;transform:scale(1.1)}.block-element[data-type=action]{background:linear-gradient(135deg,#5b9bd5,#4a8ac4);box-shadow:0 3px #3a7ab4,var(--shadow-sm)}.block-element[data-type=loop]{background:linear-gradient(135deg,#f5a623,#e59613);box-shadow:0 3px #d58603,var(--shadow-sm)}.block-element[data-type=condition]{background:linear-gradient(135deg,#7c6cdb,#6c5ccb);box-shadow:0 3px #5c4cbb,var(--shadow-sm)}.block-element[data-type=container]{background:linear-gradient(135deg,#2d8b6f,#1d7b5f);box-shadow:0 3px #0d6b4f,var(--shadow-sm)}.block-control{display:flex;align-items:center;gap:var(--spacing-xs)}.times-control{background:#fff3;padding:2px var(--spacing-xs);border-radius:var(--border-radius-sm);display:flex;align-items:center;gap:var(--spacing-xs)}.times-btn{width:20px;height:20px;border:none;background:#ffffff4d;color:var(--color-text-inverse);border-radius:50%;cursor:pointer;font-size:var(--font-size-sm);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.times-btn:hover{background:#ffffff80}.times-value{min-width:20px;text-align:center;font-weight:var(--font-weight-bold)}.times-label{font-size:var(--font-size-xs);opacity:.8}.block-condition-select{padding:2px var(--spacing-xs);border:none;background:#fff3;color:var(--color-text-inverse);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);cursor:pointer;max-width:150px}.block-condition-select option{color:var(--color-text-primary);background:var(--color-bg-primary)}.block-children-wrapper{padding:var(--spacing-sm);padding-top:0}.block-section{margin-bottom:var(--spacing-xs)}.section-label{font-size:var(--font-size-xs);color:#ffffffb3;margin-bottom:var(--spacing-xs);padding-left:var(--spacing-xs)}.block-children{min-height:48px;background:#ffffffe6;border-radius:var(--border-radius-md);padding:var(--spacing-sm);border:2px dashed var(--color-border);transition:all var(--transition-fast)}.block-children:empty:before{content:"Arrastra bloques aquí";color:var(--color-text-muted);font-size:var(--font-size-xs);display:block;text-align:center;padding:var(--spacing-sm)}.block-children.drag-over{border-color:var(--color-primary);background:var(--color-primary-bg);box-shadow:var(--shadow-glow)}.block-element.executing{box-shadow:0 0 0 3px var(--color-accent),0 0 20px #f5d54766;animation:glow 1s ease-in-out infinite}@keyframes glow{0%,to{box-shadow:0 0 0 3px var(--color-accent),0 0 10px #f5d5474d}50%{box-shadow:0 0 0 3px var(--color-accent),0 0 25px #f5d54799}}.block-element.error{box-shadow:0 0 0 3px var(--color-error);animation:shake .3s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.block-element.completed{opacity:.7}@media(max-width:768px){.block-header{padding:var(--spacing-xs) var(--spacing-sm);min-height:40px}.block-icon{width:20px;height:20px;font-size:var(--font-size-base)}.block-label{font-size:var(--font-size-xs)}}.program-panel{background-color:var(--color-surface);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);display:flex;flex-direction:column;height:100%;overflow:hidden}.program-panel.locked{opacity:.7;pointer-events:none}.program-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-neutral-light);flex-shrink:0}.program-panel-header h3{margin:0;font-size:var(--font-size-lg)}.program-count{font-size:var(--font-size-sm);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.program-palette{padding:var(--spacing-sm);border-bottom:1px solid var(--color-neutral-light);max-height:200px;overflow-y:auto;flex-shrink:0}.palette-category{margin-bottom:var(--spacing-sm)}.palette-category:last-child{margin-bottom:0}.palette-category-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.palette-blocks{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.palette-block{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--block-color, var(--color-primary));color:var(--color-text-inverse);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);cursor:grab;-webkit-user-select:none;user-select:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.palette-block:hover{transform:scale(1.05);box-shadow:var(--shadow-md)}.palette-block:active{cursor:grabbing}.palette-block.dragging{opacity:.5}.palette-block .block-icon{font-size:var(--font-size-base)}.program-workspace{flex:1;padding:var(--spacing-md);overflow-y:auto;min-height:150px;transition:background-color var(--transition-fast)}.program-workspace.drag-over{background-color:#1e3a5f1a}.workspace-placeholder{color:var(--color-text-muted);text-align:center;padding:var(--spacing-xl);border:2px dashed var(--color-neutral-light);border-radius:var(--border-radius);margin:0}body.dragging *{cursor:grabbing!important}.drop-indicator{position:relative;height:2px;margin:1px 0;padding:0;background-color:transparent;transition:all var(--transition-fast)}body.dragging .drop-indicator{height:4px;margin:0;padding:8px 0;background-clip:content-box}.drop-indicator:after{content:"";position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:0;border-radius:2px;background-color:transparent;transition:all var(--transition-fast)}body.dragging .drop-indicator:after{height:4px;background-color:var(--color-neutral-light)}body.dragging .drop-indicator:hover:after,.drop-indicator.active:after{height:6px;background-color:var(--color-primary);box-shadow:0 0 12px var(--color-primary-light)}.add-to-end-zone{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);margin-top:var(--spacing-sm);border:2px dashed var(--color-neutral-light);border-radius:var(--border-radius);color:var(--color-text-muted);font-size:var(--font-size-sm);transition:all var(--transition-fast);cursor:default}.add-to-end-icon{font-size:var(--font-size-lg);font-weight:700;opacity:.6}.add-to-end-zone.drag-over{border-color:var(--color-primary);background-color:#1e3a5f1a;color:var(--color-primary)}.add-to-end-zone.drag-over .add-to-end-icon{opacity:1}body.dragging .add-to-end-zone{border-color:var(--color-primary-light);background-color:#1e3a5f0d}.control-panel{background-color:var(--color-surface);border-radius:var(--border-radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow)}.control-buttons{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.control-buttons .btn{min-width:140px}@media(max-width:768px){.control-buttons .btn{flex:1;min-width:100px}}.level-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-lg);gap:var(--spacing-md)}.level-header-center{flex:0 0 auto}.progress-tracker{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);position:relative;cursor:pointer;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--border-radius);background:var(--color-bg-secondary);transition:background var(--transition-fast)}.progress-tracker:hover{background:var(--color-bg-tertiary)}.level-progress{display:flex;align-items:center;gap:var(--spacing-xs)}.level-dot{display:flex;flex-direction:column;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);transition:all var(--transition-fast);position:relative}.level-dot-number{line-height:1}.level-dot-stars{position:absolute;bottom:-8px;font-size:8px;color:var(--color-warning);text-shadow:0 1px 2px rgba(0,0,0,.3)}.level-dot-pending{background:var(--color-neutral-light);color:var(--color-text-muted);border:2px solid transparent}.level-dot-current{background:var(--color-primary);color:#fff;border:2px solid var(--color-primary-light);box-shadow:0 0 8px var(--color-primary-light);animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 8px var(--color-primary-light)}50%{box-shadow:0 0 16px var(--color-primary-light)}}.level-dot-complete{background:var(--color-success);color:#fff;border:2px solid var(--color-success)}.level-dot-failed{background:var(--color-error-bg);color:var(--color-error);border:2px solid var(--color-error)}.level-dot-progress{background:var(--color-warning-bg);color:var(--color-warning);border:3px solid var(--color-warning);box-shadow:0 0 6px var(--color-warning)}.total-score-display{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm)}.total-score-label{color:var(--color-text-muted)}.total-score-value{font-weight:var(--font-weight-bold);color:var(--color-primary)}.progress-tooltip{display:none;position:absolute;top:100%;left:50%;transform:translate(-50%);padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + var(--spacing-sm));background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);min-width:280px;z-index:100}.progress-tooltip:before{content:"";position:absolute;top:calc(-1 * var(--spacing-sm));left:0;right:0;height:var(--spacing-sm);background:transparent}.progress-tracker:hover .progress-tooltip{display:block}.tooltip-title{font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border)}.tooltip-level{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-md) 0;font-size:var(--font-size-sm)}.tooltip-level-num{font-weight:var(--font-weight-medium);min-width:60px}.tooltip-level-stars{color:var(--color-warning)}.tooltip-level-score,.tooltip-level-status{color:var(--color-text-muted);font-size:var(--font-size-xs)}.tooltip-level.completed .tooltip-level-num{color:var(--color-success)}.tooltip-level.failed .tooltip-level-num{color:var(--color-error)}.tooltip-level.current .tooltip-level-num{color:var(--color-primary)}.tooltip-level.pending .tooltip-level-num{color:var(--color-text-muted)}.tooltip-level.progress{background:var(--color-warning-bg);border-radius:var(--border-radius-sm);padding:var(--spacing-md) var(--spacing-sm);margin:0 calc(-1 * var(--spacing-sm))}.tooltip-level.progress .tooltip-level-num,.tooltip-level.progress .tooltip-level-status{color:var(--color-warning)}.tooltip-total{display:flex;align-items:center;justify-content:space-between;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);font-weight:var(--font-weight-semibold)}.tooltip-total-value{color:var(--color-primary)}.tooltip-share{margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-primary);color:#fff;text-align:center;border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);cursor:pointer;transition:background var(--transition-fast)}.tooltip-share:hover{background:var(--color-primary-dark)}.level-header-left{display:flex;align-items:center;gap:var(--spacing-md);flex-shrink:0}.back-button{font-size:var(--font-size-xl)}.help-button{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.help-button:hover{background:var(--color-primary-dark);transform:scale(1.1)}.level-info{display:flex;flex-direction:column;gap:2px}.level-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0;color:var(--color-primary)}.level-description{font-size:var(--font-size-xs);color:var(--color-text-light);margin:0;max-width:500px}.level-header-stats{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;justify-content:flex-end}.header-stat{display:flex;align-items:center;gap:var(--spacing-xs);background:var(--color-bg-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-full);font-size:var(--font-size-sm);white-space:nowrap}.stat-icon{font-size:var(--font-size-base)}.stat-label{color:var(--color-text);max-width:200px;overflow:hidden;text-overflow:ellipsis}.stat-value{font-weight:var(--font-weight-bold);color:var(--color-text)}.stat-separator,.stat-max{color:var(--color-text-muted)}.objective-stat{position:relative;cursor:help}.objective-tooltip{display:none;position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);font-size:var(--font-size-sm);color:var(--color-text);white-space:normal;max-width:300px;min-width:200px;z-index:100;line-height:1.4}.objective-stat:hover .objective-tooltip{display:block}.header-stat.stat-high{background:var(--color-success-bg)}.header-stat.stat-high .stat-value{color:var(--color-success)}.header-stat.stat-medium{background:var(--color-warning-bg)}.header-stat.stat-medium .stat-value{color:var(--color-warning)}.header-stat.stat-low{background:var(--color-error-bg)}.header-stat.stat-low .stat-value{color:var(--color-error)}@media(max-width:1024px){.objective-text{display:none}.level-description{max-width:200px}.level-dot{width:24px;height:24px;font-size:10px}.level-dot-stars{font-size:7px;bottom:-6px}.total-score-label{display:none}}@media(max-width:768px){.level-header{padding:var(--spacing-xs) var(--spacing-md);flex-wrap:wrap}.level-header-center{order:3;flex:1 0 100%;margin-top:var(--spacing-xs)}.progress-tracker{flex-direction:row;justify-content:center;width:100%}.level-name{font-size:var(--font-size-base)}.level-description{display:none}.header-stat{padding:var(--spacing-xs)}.stat-label{display:none}.objective-tooltip{right:auto;left:0}.progress-tooltip{left:0;transform:none}}.help-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .2s ease-out}.help-modal{background:var(--color-surface);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-xl);max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.help-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border)}.help-modal-title{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text)}.help-modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs);line-height:1;border-radius:var(--border-radius);transition:all var(--transition-fast)}.help-modal-close:hover{background:var(--color-bg-secondary);color:var(--color-text)}.help-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.help-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-sm)}.help-tab{background:none;border:none;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);cursor:pointer;border-radius:var(--border-radius);transition:all var(--transition-fast)}.help-tab:hover{background:var(--color-bg-secondary);color:var(--color-text)}.help-tab.active{background:var(--color-primary);color:#fff}.help-tab-content{animation:fadeIn .2s ease-out}.help-tab-content.hidden{display:none}.help-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0 0 var(--spacing-sm) 0}.help-subsection{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-light);margin:var(--spacing-lg) 0 var(--spacing-sm) 0}.help-subsection:first-of-type{margin-top:var(--spacing-md)}.help-intro{color:var(--color-text-light);font-size:var(--font-size-sm);margin:0 0 var(--spacing-md) 0;line-height:var(--line-height-relaxed)}.help-items{display:flex;flex-direction:column;gap:var(--spacing-sm)}.help-items.compact{gap:var(--spacing-xs)}.help-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-sm);background:var(--color-bg-secondary);border-radius:var(--border-radius)}.help-item-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border-radius:var(--border-radius);flex-shrink:0}.help-item-icon.state-unknown{background:var(--color-neutral-light)}.help-item-icon.state-high{background:var(--color-error-bg)}.help-item-icon.state-neutral{background:var(--color-warning-bg)}.help-item-icon.state-attended{background:var(--color-success-bg)}.help-item-icon.state-saturated{background:var(--color-error-bg)}.help-item-icon.block-movement{background:#4a7c9b20}.help-item-icon.block-action{background:#4caf5020}.help-item-icon.block-control{background:#ff572220}.help-item-icon.block-condition{background:#2196f320}.help-item-info{display:flex;flex-direction:column;gap:2px;min-width:0}.help-item-label{font-weight:var(--font-weight-medium);color:var(--color-text);font-size:var(--font-size-sm)}.help-item-desc{color:var(--color-text-light);font-size:var(--font-size-xs);line-height:var(--line-height-relaxed)}.help-tips{display:flex;flex-direction:column;gap:var(--spacing-md)}.help-tip{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--border-radius);border-left:3px solid var(--color-primary)}.help-tip-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;border-radius:50%;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);flex-shrink:0}.help-tip-content{flex:1}.help-tip-content strong{display:block;color:var(--color-text);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.help-tip-content p{margin:0;color:var(--color-text-light);font-size:var(--font-size-xs);line-height:var(--line-height-relaxed)}@media(max-width:600px){.help-modal{max-height:90vh}.help-modal-content{padding:var(--spacing-md)}.help-tabs{flex-wrap:wrap}.help-tab{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.help-item{gap:var(--spacing-sm)}.help-item-icon{width:32px;height:32px;font-size:1.2rem}}.map-cell{position:relative;overflow:visible}.effect-move{animation:pulse-move .3s ease-out}@keyframes pulse-move{0%{background-color:var(--color-primary-light)}to{background-color:var(--color-surface)}}.effect-success{animation:pulse-success .5s ease-out}@keyframes pulse-success{0%{background-color:var(--color-success-light);transform:scale(1.05)}to{background-color:var(--color-surface);transform:scale(1)}}.effect-error{animation:shake-error .4s ease-out}@keyframes shake-error{0%,to{transform:translate(0);background-color:var(--color-error-light)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.effect-action{animation:pulse-action .4s ease-out}@keyframes pulse-action{0%{box-shadow:0 0 0 0 var(--color-success)}50%{box-shadow:0 0 0 8px #4caf5000}to{box-shadow:0 0 #4caf5000}}.effect-scan{animation:scan-effect .5s ease-out}@keyframes scan-effect{0%{box-shadow:inset 0 0 0 0 var(--color-secondary)}50%{box-shadow:inset 0 0 20px 5px var(--color-secondary)}to{box-shadow:inset 0 0 0 0 var(--color-secondary)}}.effect-condition{animation:condition-effect .25s ease-out}@keyframes condition-effect{0%{box-shadow:0 0 0 0 var(--color-warning)}50%{box-shadow:0 0 8px 4px var(--color-warning)}to{box-shadow:0 0 0 0 var(--color-warning)}}.effect-loop{animation:loop-effect .2s ease-out}@keyframes loop-effect{0%{background-color:var(--color-secondary-light);transform:scale(1)}50%{transform:scale(1.02)}to{background-color:var(--color-surface);transform:scale(1)}}.floating-message{position:absolute;top:-30px;left:50%;transform:translate(-50%) translateY(10px);padding:4px 8px;font-size:12px;font-weight:500;white-space:nowrap;border-radius:4px;opacity:0;transition:all .3s ease;z-index:100;pointer-events:none}.floating-message.visible{opacity:1;transform:translate(-50%) translateY(0)}.floating-message.fade-out{opacity:0;transform:translate(-50%) translateY(-10px)}.floating-message-success{background-color:var(--color-success);color:#fff}.floating-message-error{background-color:var(--color-error);color:#fff}.floating-message-action{background-color:var(--color-primary);color:#fff}.floating-message-scan{background-color:var(--color-secondary);color:#fff}.floating-message-condition{background-color:var(--color-warning);color:var(--color-text)}.floating-message-loop{background-color:var(--color-secondary);color:#fff}.block-highlight{position:relative}.block-highlight:before{content:"";position:absolute;inset:-2px;border:2px solid var(--color-warning);border-radius:var(--border-radius);animation:block-pulse .5s ease-in-out infinite}@keyframes block-pulse{0%,to{opacity:1}50%{opacity:.5}}.bot{transition:transform .25s ease-out}.bot.moving{animation:bot-bounce .25s ease-out}@keyframes bot-bounce{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.person{transition:all .3s ease}.person.state-changing{animation:person-change .4s ease}@keyframes person-change{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.animation-timeline{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--border-radius)}.timeline-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.timeline-progress{flex:1;height:6px;background:var(--color-neutral-light);border-radius:var(--border-radius-full);overflow:hidden}.timeline-bar{height:100%;background:var(--color-primary);transition:width .1s linear}.timeline-step{font-size:var(--font-size-sm);color:var(--color-text-muted);min-width:60px;text-align:right}.timeline-speed{display:flex;align-items:center}.speed-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--border-radius);background:var(--color-background);font-size:var(--font-size-sm);cursor:pointer}.speed-select:focus{outline:none;border-color:var(--color-primary)}.game-screen{display:flex;flex-direction:column;height:100vh;background-color:var(--color-background)}.game-screen-header{flex-shrink:0;background-color:var(--color-surface);border-bottom:1px solid var(--color-neutral-light)}.game-screen-content{flex:1;display:flex;overflow:hidden;padding:var(--spacing-md);gap:var(--spacing-md)}.game-screen-left{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md);min-width:0}.game-screen-right{width:350px;flex-shrink:0;display:flex;flex-direction:column}.map-container{flex:1;background-color:var(--color-surface);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:300px}.control-container{flex-shrink:0}.program-container{flex:1;min-height:0;overflow:hidden}@media(max-width:1024px){.game-screen-content{flex-direction:column}.game-screen-right{width:100%;height:50vh}}@media(max-width:768px){.game-screen-right{height:40vh}.program-container{max-height:none}}.level-result-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#000000b3;z-index:200;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.result-content{background:var(--color-surface);border-radius:var(--border-radius-xl);padding:var(--spacing-xxl);text-align:center;max-width:450px;width:90%;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.result-content.success{border-top:4px solid var(--color-success)}.result-content.fail{border-top:4px solid var(--color-warning)}.result-icon{font-size:4rem;margin-bottom:var(--spacing-md)}.result-title{font-size:var(--font-size-2xl);margin:0 0 var(--spacing-md);color:var(--color-text)}.result-message{font-size:var(--font-size-base);color:var(--color-text-light);margin-bottom:var(--spacing-lg)}.result-stars{display:flex;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.star{font-size:2.5rem;color:var(--color-neutral-light);transition:all .3s ease}.star.filled{color:var(--color-warning);animation:starPop .5s ease}@keyframes starPop{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.score-breakdown{background:var(--color-background);border-radius:var(--border-radius);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.score-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-neutral-light)}.score-label{font-weight:var(--font-weight-medium)}.score-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.score-details{font-size:var(--font-size-sm);color:var(--color-text-light);text-align:left}.score-line{padding:var(--spacing-xs) 0}.result-actions{margin-bottom:var(--spacing-lg)}.result-learning{padding-top:var(--spacing-md);border-top:1px solid var(--color-neutral-light)}.learning-message{font-style:italic;color:var(--color-text-muted);font-size:var(--font-size-sm);margin:0}.score-breakdown.partial{background:var(--color-warning-bg);border:1px solid var(--color-warning)}.score-breakdown.partial .score-value{color:var(--color-warning)}.progress-indicator{margin-bottom:var(--spacing-lg)}.progress-bar{height:8px;background:var(--color-neutral-light);border-radius:var(--border-radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-fill{height:100%;background:var(--color-warning);border-radius:var(--border-radius-full);transition:width .5s ease}.progress-stats{display:flex;justify-content:center;gap:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-light)}.progress-stat{display:flex;align-items:center;gap:var(--spacing-xs)}.progress-stat .stat-icon{color:var(--color-warning)}.progress-message{margin-top:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-muted)}.new-high-score{background:linear-gradient(135deg,var(--color-warning-bg),var(--color-primary-bg));border:2px solid var(--color-warning);border-radius:var(--border-radius);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-lg);font-weight:var(--font-weight-bold);color:var(--color-warning);animation:pulse 1s ease infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.result-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.result-actions .btn{width:100%}.final-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);padding:var(--spacing-xl)}.final-content{width:100%;max-width:400px}.final-header{text-align:center;margin-bottom:var(--spacing-lg)}.final-title{color:var(--color-text-inverse);font-size:var(--font-size-2xl);margin:0}.share-card{background:var(--color-surface);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-xl)}.share-card-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);color:var(--color-text-muted)}.game-logo{font-size:var(--font-size-xl)}.game-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.player-section{text-align:center;margin-bottom:var(--spacing-md)}.player-name-display{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.score-section{text-align:center;margin-bottom:var(--spacing-lg)}.total-score{font-size:3.5rem;font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1}.score-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase}.profile-section{text-align:center;margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--color-background);border-radius:var(--border-radius)}.main-badge{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.badge-icon{font-size:2rem}.badge-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-primary)}.badge-description{font-size:var(--font-size-sm);color:var(--color-text-light);margin:0}.extra-badges{display:flex;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.extra-badge{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-neutral-light);border-radius:var(--border-radius-full);font-size:var(--font-size-sm)}.stats-section{display:flex;justify-content:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.stat{text-align:center}.stat-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase}.message-section{padding:var(--spacing-md);border-top:1px solid var(--color-neutral-light);border-bottom:1px solid var(--color-neutral-light);margin-bottom:var(--spacing-md)}.final-message{font-style:italic;color:var(--color-text-light);font-size:var(--font-size-sm);text-align:center;line-height:var(--line-height-relaxed);margin:0}.brand-footer{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted)}.final-actions{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.screenshot-hint{color:var(--color-text-inverse);border-color:#ffffff80}.screenshot-hint:hover{background:#ffffff1a}.verification-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-neutral-light);border-radius:var(--border-radius);margin-bottom:var(--spacing-md);overflow:hidden}.verification-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.verification-code{font-family:monospace;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-primary);letter-spacing:.05em;-webkit-user-select:all;user-select:all;word-break:break-all;text-align:center;max-width:100%;padding:0 var(--spacing-xs)}.copy-results-btn{background:var(--color-primary);color:var(--color-text-inverse);border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background .2s,transform .1s;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.copy-results-btn:hover{background:var(--color-primary-dark)}.copy-results-btn:active{transform:scale(.98)}.copy-results-btn.copied{background:var(--color-success)}.copy-results-btn.copied:after{content:" ✓"}
