@import "https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap";html,body,#root{width:100%;min-height:100%}body{color:#0b1f52;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background:#f3f5f9;margin:0}a{color:inherit}:root{--color-bg:#f3f5f9;--color-bg-soft:#e9edf5;--color-surface:#fff;--color-surface-soft:#f7f9fc;--color-text:#0b1f52;--color-text-muted:#7f91ad;--color-primary:#3f7fe8;--color-primary-strong:#2e67c6;--color-mint:#1db987;--color-orange:#f2a100;--color-coral:#ef4747;--color-violet:#7f57e8;--color-border:#dbe4f1;--color-border-strong:#b8c8e3;--color-focus:#1947a6;--radius-sm:14px;--radius-md:22px;--radius-lg:30px;--container-radius:var(--radius-md);--container-padding:clamp(1rem, 1.2vw, 1.35rem);--container-border:1px solid var(--color-border);--container-shadow:var(--shadow-low);--shadow-low:0 6px 16px #2446821f;--shadow-mid:0 10px 26px #24468229;--shadow-high:0 16px 34px #24468233;--space-1:.4rem;--space-2:.7rem;--space-3:1rem;--space-4:1.3rem;--space-5:1.8rem;--space-6:2.4rem;--page-shell-padding:clamp(.9rem, 1.5vw, 1.45rem);--section-stack-spacing:var(--space-4);--label-font-preset-lg:clamp(1rem, 1.4vw, 1.12rem);--panel-card-stack-gap:var(--space-3);--list-view-empty-padding:var(--space-3);--list-view-border:1px solid #d8e2f2;--list-view-empty-border:2px dashed #d5e1f2;--page-max-width:1320px;--color-success:var(--color-mint);--color-warning:var(--color-orange);--z-base:1;--z-select:80;--z-select-menu:90;--z-flash:800;--z-welcome:900;--z-modal:1000;--z-celebration:1050;--z-xp:1100;--z-select-portal:1600;--z-toast:2000;--duration-fast:.12s;--duration-normal:.14s;--duration-medium:.18s;--duration-slow:.28s;--ease-default:ease;--ease-spring:cubic-bezier(.22, 1, .36, 1);--ease-spring-bounce:cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#9cb3d7 #eef3fb}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#eef3fb;border-radius:999px}::-webkit-scrollbar-thumb{background:linear-gradient(#b9cae6 0%,#95aed5 100%);border:2px solid #eef3fb;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(#a9c0e1 0%,#849fc9 100%)}html,body,#root{width:100%;min-height:100%;margin:0}body{color:var(--color-text);background:var(--color-bg);font-family:Be Vietnam Pro,Segoe UI,Tahoma,sans-serif;line-height:1.45}h1,h2,h3,h4,h5,h6{color:var(--color-text);margin:0;font-family:Plus Jakarta Sans,Be Vietnam Pro,sans-serif;line-height:1.18}h1{font-size:clamp(2rem,4.6vw,3.2rem)}h2{font-size:clamp(1.35rem,3.1vw,2rem)}p{color:var(--color-text-muted);margin:0}.btn{cursor:pointer;letter-spacing:.03em;border:2px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:.45rem;min-height:44px;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-weight:800;transition:transform .14s,box-shadow .14s,background-color .14s,border-color .14s;display:inline-flex}.btn-label{font-weight:800}.btn:focus-visible{outline:3px solid var(--color-focus);outline-offset:2px}.btn:active{transform:translateY(1px)}.btn-small{min-height:36px;padding:.45rem .8rem;font-size:.86rem}.btn-medium{min-height:44px;padding:.68rem 1rem;font-size:.95rem}.btn-large{min-height:52px;padding:.86rem 1.24rem;font-size:1rem}.btn-full-width{width:100%}.btn-primary,.btn-secondary,.btn-success,.btn-danger{font-family:Plus Jakarta Sans,Be Vietnam Pro,sans-serif;font-weight:800;box-shadow:0 6px}.btn-primary .btn-label,.btn-secondary .btn-label,.btn-success .btn-label,.btn-danger .btn-label{letter-spacing:.005em;text-shadow:.015em 0;font-weight:800}.btn-primary:hover,.btn-secondary:hover,.btn-success:hover,.btn-danger:hover{transform:translateY(-1px)scale(1.01)}.btn-primary{background:var(--color-orange);color:#10254f;border-color:#d89100;box-shadow:0 6px #c88400}.btn-primary:hover{background:#f3ae1f}.btn-secondary{color:var(--color-text);background:#eef3fb;border-color:#ccdaee;box-shadow:0 6px #d6e1f0}.btn-secondary:hover{background:#e7eef9}.btn-success{color:#fff;background:#1db987;border-color:#129068;box-shadow:0 6px #16795a}.btn-success:hover{background:#21c28f}.btn-danger{color:#fff;background:#ef4747;border-color:#d03a3a;box-shadow:0 6px #b53030}.btn-danger:hover{background:#f05959}.btn-disabled{opacity:.66;cursor:not-allowed;box-shadow:none}.btn-spinner{border:2px solid #ffffff61;border-top-color:#fff;border-radius:50%;width:.9rem;height:.9rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.card{border-radius:var(--container-radius);border:var(--container-border);background:var(--color-surface);padding:var(--container-padding)}.base-container{border-radius:var(--container-radius);border:var(--container-border);background:var(--color-surface);box-shadow:var(--container-shadow);padding:var(--container-padding)}.card-elevation-none{box-shadow:none}.card-elevation-low{box-shadow:var(--shadow-low)}.card-elevation-medium{box-shadow:var(--shadow-mid)}.card-elevation-high{box-shadow:var(--shadow-high)}.card-interactive{cursor:pointer;transition:transform .14s,border-color .14s,box-shadow .14s}.card-interactive:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-mid);transform:translateY(-3px)scale(1.01)}.input-group{gap:var(--space-1);flex-direction:column;display:flex}.input-group-full{width:100%}.textarea-group{flex-direction:column;gap:.35rem;display:flex}.textarea-group-full{width:100%}.input-label{color:#7b8faa;text-transform:uppercase;letter-spacing:.04em;font-size:.86rem;font-weight:800}.input-shell{background:#fff;border:2px solid #d8e2f0;border-radius:999px;align-items:center;gap:.55rem;min-height:54px;padding:.15rem .3rem .15rem .7rem;transition:border-color .14s,box-shadow .14s,transform .14s;display:flex;box-shadow:0 2px #e5ebf5}.input-shell:hover{border-color:#bfd0e8;transform:translateY(-1px)}.input-shell:focus-within{border-color:var(--color-focus);box-shadow:0 0 0 3px #1947a629}.input-shell-error{border-color:#ef4747}.input-leading-icon{color:#6680a8;background:#eef3fb;border:1px solid #d6e1f1;border-radius:999px;flex:none;place-items:center;width:2rem;height:2rem;font-size:.92rem;line-height:1;display:grid}.input{color:var(--color-text);background:0 0;border:0;border-radius:999px;width:100%;min-height:44px;padding:.72rem .2rem;font-size:1rem;font-weight:600;transition:border-color .14s,box-shadow .14s,transform .14s}textarea.input{border-radius:var(--radius-sm)}.textarea-shell{border-radius:var(--radius-md);background:#fff;border:2px solid #d8e2f0;min-height:118px;padding:.35rem .45rem;transition:border-color .14s,box-shadow .14s,transform .14s;box-shadow:0 2px #e5ebf5}.textarea-shell:hover{border-color:#bfd0e8;transform:translateY(-1px)}.textarea-shell:focus-within{border-color:var(--color-focus);box-shadow:0 0 0 3px #1947a629}.textarea-shell-error{border-color:#ef4747}.textarea{width:100%;min-height:96px;color:var(--color-text);resize:vertical;background:0 0;border:0;border-radius:12px;padding:.35rem .4rem;font-family:inherit;font-size:.98rem;font-weight:600;line-height:1.45}.textarea:focus{outline:none}.input::placeholder{color:#a1afc4}.input:hover{border-color:#0000}.input:focus{box-shadow:none;outline:none}.input-file{border-radius:12px;min-height:34px;padding:.45rem .2rem}.input-file::file-selector-button{color:var(--color-text);cursor:pointer;background:#eef3fb;border:1px solid #c9d8ed;border-radius:10px;margin-right:.65rem;padding:.35rem .7rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-weight:700}.input-file-name{color:var(--color-text);font-size:.9rem;font-weight:700}.select-shell{z-index:var(--z-base);position:relative}.select-shell-open{z-index:var(--z-select)}.select-trigger{width:100%;color:var(--color-text);cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:space-between;align-items:center;gap:.7rem;min-height:44px;padding:.72rem .2rem;font-size:1rem;font-weight:600;line-height:1.1;display:flex}.select-trigger:focus{outline:none}.select-trigger:disabled{opacity:.55;cursor:not-allowed}.select-trigger-label{white-space:nowrap;text-overflow:ellipsis;text-align:left;overflow:hidden}.select-chevron{color:#7f91ad;font-size:.82rem;transition:transform .14s}.select-chevron-open{transform:rotate(180deg)}.select-menu{z-index:var(--z-select-menu);background:#fff;border:2px solid #bfd0e8;border-radius:16px;gap:.2rem;max-height:230px;padding:.35rem;display:grid;position:absolute;top:calc(100% + .4rem);left:0;right:0;overflow-y:auto;box-shadow:0 18px 36px #12234233}.select-menu-portal{z-index:var(--z-select-portal);position:fixed;top:0;left:0;right:auto}.select-option{color:var(--color-text);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:12px;min-height:40px;padding:.45rem .7rem;font-size:.95rem;font-weight:600;transition:background-color .12s,transform .12s}.select-option-focused,.select-option:hover{background:#edf3ff;transform:translateY(-1px)}.select-option-selected{color:#1e4f9c;background:#dfeaff}.select-option:disabled{opacity:.5;cursor:not-allowed}.select-native{clip:rect(0 0 0 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.input-trailing-action{color:#3566c2;cursor:pointer;background:#eef3fb;border:0;border-radius:999px;min-height:38px;padding:0 .85rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-weight:800;transition:transform .12s,background-color .12s}.input-trailing-action:hover{background:#e4ecfa;transform:translateY(-1px)}.input-trailing-action:focus-visible{outline:3px solid var(--color-focus);outline-offset:2px}.input-error{border-color:#ef4747}.input-error-text{color:#c53939;font-size:.82rem}.input-helper-text{color:var(--color-text-muted);font-size:.82rem}.toggle-group{display:inline-flex}.toggle-label{cursor:pointer;align-items:center;gap:.6rem;display:inline-flex}.toggle-input{opacity:0;pointer-events:none;position:absolute}.toggle-slider{background:#c5d3e8;border-radius:999px;width:48px;height:26px;transition:all .18s;position:relative}.toggle-slider:after{content:"";background:#fff;border:1px solid #b7c8e3;border-radius:50%;width:20px;height:20px;transition:transform .18s;position:absolute;top:3px;left:4px}.toggle-input:checked+.toggle-slider{background:#5f95eb}.toggle-input:checked+.toggle-slider:after{transform:translate(20px)}.toggle-text{color:var(--color-text);font-weight:700}.badge{border:1px solid #0000;border-radius:999px;align-items:center;gap:.3rem;padding:.22rem .65rem;font-size:.76rem;font-weight:700;display:inline-flex}.badge-default{color:#4f658c;background:#eef3fb;border-color:#d5e0ef}.badge-primary{color:#1f56b4;background:#e7effd;border-color:#bfd3f8}.badge-success{color:#1b8b66;background:#e6f8f2;border-color:#b6e7d7}.badge-warning{color:#9a6a00;background:#fff7e5;border-color:#f4dfae}.badge-danger{color:#b23333;background:#fdecec;border-color:#f5c2c2}.progress-container{gap:.4rem;display:grid}.progress-label{color:var(--color-text);font-weight:700}.progress-bar{background:#e1e9f5;border-radius:999px;width:100%;height:14px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-violet));height:100%;transition:width .18s;position:relative}.progress-animated:after{content:"";background:#ffffff8c;width:24px;animation:1.4s linear infinite progress-slide;position:absolute;top:0;bottom:0;right:-24px}@keyframes progress-slide{0%{transform:translate(-220px)}to{transform:translate(220px)}}.progress-percent{color:var(--color-text-muted);font-size:.82rem}.modal-overlay{z-index:var(--z-modal);background:#4e5f7f66;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal{border:1px solid var(--color-border);border-radius:var(--radius-lg);width:min(92vw,760px);max-height:85vh;box-shadow:var(--shadow-high);background:#fff;overflow:auto}.modal-small{max-width:430px}.modal-medium{max-width:650px}.modal-large{max-width:960px}.modal-header,.modal-footer{padding:var(--container-padding);border-bottom:1px solid var(--color-border)}.modal-header{align-items:center;gap:var(--space-2);display:flex}.modal-footer{border-bottom:0;border-top:1px solid var(--color-border)}.modal-content{padding:var(--container-padding)}.modal-close{color:var(--color-text);cursor:pointer;opacity:.8;background:0 0;border:0;margin-left:auto;font-size:1.25rem;font-weight:600;transition:opacity .14s}.modal-close:hover{opacity:1}.auth-page{background-color:#141b28;background-image:url(/space-dark.svg);background-position:50%;background-repeat:no-repeat;background-size:100%;place-items:center;min-height:100vh;padding:1.5rem;display:grid}.auth-container{grid-template-columns:1fr;gap:1rem;width:min(640px,100%);display:grid}.auth-card{text-align:center;justify-items:center;gap:1rem;padding:1.4rem;display:grid}.auth-header h1{color:var(--color-text);letter-spacing:-.04em;font-size:clamp(2.1rem,5vw,3rem);font-weight:900}.auth-header p{margin-top:.35rem;font-size:1.35rem;font-weight:700}.auth-form{gap:.95rem;width:100%;display:grid}.auth-form .input-group{text-align:left}.auth-form .btn-medium{font-size:1rem}.auth-form .btn-primary .btn-label{letter-spacing:0;text-shadow:none;font-family:Be Vietnam Pro,Segoe UI,Tahoma,sans-serif;font-size:1rem;font-weight:900}.dashboard-page .btn .btn-label,.admin-page .btn .btn-label{color:inherit;font-family:Be Vietnam Pro,Segoe UI,Tahoma,sans-serif;font-size:1rem;font-weight:900}.auth-error{border-radius:var(--radius-sm);color:#b33a3a;background:#fdeeee;border:2px solid #f2bcbc;padding:.7rem}.auth-success{border-radius:var(--radius-sm);color:#065f46;background:#ecfdf5;border:2px solid #a7f3d0;padding:.7rem}.auth-footer{color:var(--color-text-muted);text-align:center;width:100%;font-family:Be Vietnam Pro,Segoe UI,Tahoma,sans-serif;font-size:1rem;font-weight:900}.auth-switch{color:var(--color-primary);cursor:pointer;background:0 0;border:0;font-family:Be Vietnam Pro,Segoe UI,Tahoma,sans-serif;font-size:1rem;font-weight:900}.dashboard-page,.mission-builder-page,.mission-player-page,.admin-page,.layout-page{min-height:100vh;width:min(100%, var(--page-max-width));padding:var(--page-shell-padding);margin-inline:auto}.welcome-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:var(--z-welcome);padding:var(--space-4);background:#0b1f52b3;place-items:center;display:grid;position:fixed;inset:0}.welcome-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-high);gap:var(--space-3);flex-direction:column;display:flex}.welcome-emoji{font-size:3.5rem;line-height:1}.welcome-card h2{color:var(--color-text);margin:0;font-size:1.5rem}.welcome-card p{color:var(--color-text-muted);margin:0;font-size:1rem;line-height:1.6}.xp-float{pointer-events:none;z-index:var(--z-xp);color:#f5c542;text-shadow:0 2px 8px #0000002e;font-size:1.6rem;font-weight:900;animation:.9s ease-out forwards xp-rise;position:fixed;top:40%;left:50%;transform:translate(-50%)}@keyframes xp-rise{0%{opacity:0;transform:translate(-50%)translateY(0)scale(.7)}20%{opacity:1;transform:translate(-50%)translateY(-8px)scale(1.15)}80%{opacity:1;transform:translate(-50%)translateY(-48px)scale(1)}to{opacity:0;transform:translate(-50%)translateY(-72px)scale(.9)}}.cb-overlay{pointer-events:none;z-index:var(--z-celebration);position:fixed;inset:0;overflow:hidden}.cb-step{justify-content:center;align-items:center;display:flex}.cb-particle{background:var(--cb-color,#f5c542);width:14px;height:14px;animation:.8s cubic-bezier(.22,1,.36,1) forwards cb-particle-burst;animation-delay:calc(var(--i,0) * 10ms);border-radius:50%;position:absolute}.cb-particle-inner{width:9px;height:9px;animation-duration:.65s;animation-delay:calc((var(--i,0) - 16) * 10ms + 60ms)}@keyframes cb-particle-burst{0%{transform:rotate(var(--angle,0deg)) translateY(0) scale(.5);opacity:1}50%{opacity:1}to{transform:rotate(var(--angle,0deg)) translateY(-145px) scale(0);opacity:0}}.cb-confetti-piece{top:-6%;left:calc(var(--i,0) * 2.68% + 0.4%);background:hsl(calc(var(--i,0) * 25deg + 15deg), 90%, 62%);width:8px;height:15px;animation:cb-confetti-fall calc(2s + calc(var(--i,0) * 50ms)) ease-in forwards;animation-delay:calc(var(--i,0) * 35ms);transform:rotate(calc(var(--i,0) * 21deg));border-radius:3px 3px 1px 1px;position:absolute}@keyframes cb-confetti-fall{0%{opacity:0;transform:translateY(0)rotate(0)scale(.85)}6%{opacity:1}88%{opacity:1}to{opacity:0;transform:translateY(108vh) rotate(calc(var(--i,0) * 55deg + 130deg)) scale(1.1)}}.cb-balloon{bottom:-90px;left:calc(var(--i,0) * 13% + 1.5%);background:hsl(calc(var(--i,0) * 48deg + 20deg), 80%, 64%);width:52px;height:64px;animation:cb-balloon-rise calc(2.7s + calc(var(--i,0) * .2s)) ease-in-out forwards;animation-delay:calc(var(--i,0) * 80ms);border-radius:50%/54% 54% 46% 46%;position:absolute;box-shadow:inset -8px -6px #00000017,inset 4px 5px #ffffff4d}.cb-balloon:before{content:"";border-left:5px solid #0000;border-right:5px solid #0000;border-top:9px solid hsl(calc(var(--i,0) * 48deg + 20deg), 74%, 52%);width:0;height:0;position:absolute;bottom:-9px;left:50%;transform:translate(-50%)}.cb-balloon:after{content:"";transform-origin:top;width:1.5px;height:36px;transform:translateX(-50%) rotate(calc(var(--i,0) * 6deg - 18deg));background:linear-gradient(#00000038,#00000014);position:absolute;bottom:-44px;left:50%}@keyframes cb-balloon-rise{0%{opacity:0;transform:translateY(0)rotate(-4deg)}5%{opacity:1}28%{opacity:1;transform:translateY(-28vh)rotate(6deg)}58%{opacity:1;transform:translateY(-65vh)rotate(-5deg)}88%{opacity:.4}to{opacity:0;transform:translateY(-120vh)rotate(9deg)}}.cb-star{top:calc(var(--i,0) * 7.5% + 6%);left:calc(var(--i,0) * 8% + 4%);animation:cb-star-pop calc(.48s + calc(var(--i,0) * 65ms)) ease-out forwards;animation-delay:calc(var(--i,0) * .12s + .2s);opacity:0;font-size:1.4rem;line-height:1;position:absolute}@keyframes cb-star-pop{0%{opacity:0;transform:scale(0)rotate(-25deg)}38%{opacity:1;transform:scale(1.6)rotate(12deg)}65%{opacity:1;transform:scale(1)rotate(4deg)}to{opacity:0;transform:scale(0)rotate(-8deg)}}.dashboard-stat-clickable{cursor:pointer;transition:background-color .12s;position:relative}.dashboard-stat-clickable:hover{background:var(--color-bg-soft)}.dashboard-stat-chevron{color:var(--color-text-muted);margin-top:2px;font-size:.65rem}.trophy-gallery{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin:0 auto var(--space-4);max-width:var(--page-max-width);animation:.2s fadeSlideIn}.trophy-gallery-title{margin:0 0 var(--space-2);color:var(--color-text);font-size:1rem;font-weight:700}.trophy-gallery-hint{color:var(--color-text-muted);margin:0;font-size:.78rem}@keyframes stepFlashIn{0%{opacity:0;transform:scale(.5)}40%{opacity:1;transform:scale(1.15)}70%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1)}}.step-success-flash{pointer-events:none;z-index:var(--z-flash);place-items:center;display:grid;position:fixed;inset:0}.step-success-check{background:var(--color-mint);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:2.2rem;font-weight:800;animation:.7s forwards stepFlashIn;display:flex;box-shadow:0 0 0 12px #1db98733}.toast-viewport{z-index:var(--z-toast);pointer-events:none;flex-direction:column;gap:.55rem;width:100%;max-width:min(420px,100vw - 2rem);display:flex;position:fixed;top:clamp(1rem,2.5vw,1.6rem);right:clamp(1rem,2.5vw,1.6rem)}.toast-card{pointer-events:all;border-radius:var(--container-radius);border:var(--container-border);box-shadow:var(--container-shadow);color:var(--color-text);will-change:transform, opacity;grid-template-columns:1.5rem 1fr auto auto;align-items:center;gap:.7rem;padding:.82rem 1rem;font-family:Be Vietnam Pro,sans-serif;font-size:.95rem;font-weight:700;line-height:1.4;display:grid;position:relative;overflow:hidden}.toast-card-success{color:#0d5c3a;background:linear-gradient(#f5fdf9 0%,#edfbf5 100%);border-color:#8ee8c4}.toast-card-error{color:#891f1f;background:linear-gradient(#fff8f8 0%,#fff2f2 100%);border-color:#f5a5a5}.toast-card-warning{color:#6b4500;background:linear-gradient(#fffdf4 0%,#fffaed 100%);border-color:#f5d87a}.toast-card-info{color:#1a3a8c;background:linear-gradient(#f5f8ff 0%,#edf3ff 100%);border-color:#9dbaff}.toast-icon{flex-shrink:0;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;display:flex}.toast-icon svg{width:100%;height:100%}.toast-card-success .toast-icon{color:var(--color-mint)}.toast-card-error .toast-icon{color:var(--color-coral)}.toast-card-warning .toast-icon{color:var(--color-orange)}.toast-card-info .toast-icon{color:var(--color-primary)}.toast-message{word-break:break-word;letter-spacing:.005em;min-width:0}.toast-persistent-badge{text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;opacity:.82;background:#0b1f521a;border-radius:999px;padding:.16rem .48rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-size:.68rem;font-weight:800}.toast-dismiss{cursor:pointer;width:1.72rem;height:1.72rem;color:inherit;opacity:.62;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:opacity .15s,background .15s;display:flex}.toast-dismiss:hover{opacity:1;background:#0b1f521a}.toast-progress{border-radius:0 0 var(--radius-sm) var(--radius-sm);transform-origin:0;width:100%;height:3px;animation:linear forwards toast-progress-shrink;position:absolute;bottom:0;left:0}.toast-card-success .toast-progress{background:var(--color-mint)}.toast-card-error .toast-progress{background:var(--color-coral)}.toast-card-warning .toast-progress{background:var(--color-orange)}.toast-card-info .toast-progress{background:var(--color-primary)}@keyframes toast-progress-shrink{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.toast-card-enter{animation:.28s cubic-bezier(.22,1,.36,1) forwards toast-enter}@keyframes toast-enter{0%{opacity:0;transform:translate(110%)scale(.92)}to{opacity:1;transform:translate(0)scale(1)}}.toast-card-exit{animation:.28s ease-in forwards toast-exit}@keyframes toast-exit{0%{opacity:1;max-height:120px;margin-bottom:0;transform:translate(0)scale(1)}to{opacity:0;max-height:0;margin-bottom:-.55rem;transform:translate(110%)scale(.88)}}@media (width<=500px){.toast-viewport{gap:.4rem;max-width:100%;padding:.6rem;top:0;left:0;right:0}}.admin-chart-subtitle{color:var(--color-text-muted);margin:-.25rem 0 var(--space-3);font-size:.85rem}.admin-chart{gap:var(--space-2);flex-direction:column;display:flex}.admin-chart-row{align-items:center;gap:var(--space-2);grid-template-columns:160px 1fr 44px 56px;display:grid}.admin-chart-label{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:600;overflow:hidden}.admin-chart-bar-wrap{background:var(--color-bg-soft);border-radius:99px;height:12px;overflow:hidden}.admin-chart-bar{background:var(--color-mint);border-radius:99px;min-width:2px;height:100%;transition:width .6s}.admin-chart-pct{color:var(--color-mint);text-align:right;font-size:.78rem;font-weight:700}.admin-chart-count{color:var(--color-text-muted);text-align:right;font-size:.75rem}.mission-footer{gap:var(--space-1);flex-wrap:wrap;align-items:center;display:flex}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dashboard-header,.builder-header,.admin-header,.mission-player-header,.layout-header{color:var(--color-text)}.builder-header,.admin-header,.mission-player-header,.layout-header{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.mission-player-header{justify-content:flex-start;align-items:flex-start;gap:var(--space-4)}.mission-player-header-info{text-align:left;flex:1;gap:.35rem;min-width:0;display:grid}.mission-player-kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary);font-size:.76rem;font-weight:900}.mission-player-header-info h1{letter-spacing:-.05em;text-wrap:balance;max-width:18ch;margin:0;font-size:clamp(1.9rem,4vw,3rem);line-height:.98}.mission-player-meta{flex-wrap:wrap;align-items:center;gap:.45rem;margin-top:.15rem;display:flex}.mission-player-pill{color:#45618f;letter-spacing:-.01em;background:#eef4ff;border:1px solid #d4e0f6;border-radius:999px;align-items:center;min-height:1.7rem;padding:.2rem .62rem;font-size:.75rem;font-weight:800;display:inline-flex}.mission-player-pill-soft{background:var(--color-surface-soft);border-color:var(--color-border);color:var(--color-text-muted)}.builder-header-nav,.builder-header-actions,.layout-actions,.header-actions,.admin-header-actions,.module-header-back{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.dashboard-greeting{letter-spacing:-.02em;color:var(--color-text);white-space:nowrap;flex-shrink:0;margin:0;font-size:clamp(1.1rem,2vw,1.5rem);font-weight:900}.dashboard-header p,.builder-header p,.admin-header p,.layout-header p{color:#6f86aa;font-weight:700}.dashboard-content,.admin-section,.layout-content,.builder-container,.mission-player-body{margin-top:var(--section-stack-spacing);gap:var(--section-stack-spacing);justify-items:center;display:grid}.dashboard-content,.admin-section,.builder-container{justify-items:stretch}.modules-view,.module-view,.missions-view{gap:var(--space-3);margin-top:var(--container-padding);z-index:2;display:grid;position:relative}.module-view-header-row{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.mission-filter-tabs{gap:var(--space-2);flex-wrap:wrap;margin-left:auto;display:flex}.mission-filter-tab{border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:background var(--duration-normal) var(--ease-default), color var(--duration-normal) var(--ease-default), border-color var(--duration-normal) var(--ease-default);border-radius:999px;padding:.45rem 1rem;font-family:inherit;font-size:.85rem;font-weight:700}.mission-filter-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.mission-filter-tab.active,.mission-filter-tab[aria-selected=true]{background:var(--color-primary);border-color:var(--color-primary);color:#fff}@media (width<=900px){.module-view-header-row{align-items:flex-start}.mission-filter-tabs{width:100%;margin-left:0}}.modules-view h2,.module-header-back h2{letter-spacing:-.02em;color:#0b1f52;margin:0;font-size:clamp(1.6rem,2.8vw,2.15rem);font-weight:900}.modules-view-header{align-items:center;gap:var(--space-1);margin-bottom:var(--space-3);flex-direction:column;display:flex}.modules-start-cta{color:var(--color-primary);margin:0;font-size:1rem;font-weight:600;animation:2.5s ease-in-out infinite cta-pulse}@keyframes cta-pulse{0%,to{opacity:1}50%{opacity:.55}}.modules-grid{gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;display:grid}.missions-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));align-items:stretch;display:grid}.builder-container{grid-template-columns:repeat(12,minmax(0,1fr))}.builder-settings-panel{grid-column:1/-1}.builder-main-workspace{gap:var(--space-3);grid-column:1/-1;grid-template-columns:minmax(220px,1fr) minmax(0,3fr);align-items:start;display:grid}.builder-settings-surface{gap:var(--space-3);display:grid}.builder-settings-surface h2{letter-spacing:-.02em;color:var(--color-text);margin:0;font-size:clamp(1.35rem,2.4vw,1.9rem);font-weight:900}.builder-settings-grid{gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.builder-setting-field-title,.builder-setting-field-description,.builder-setting-field-cover,.builder-setting-field:nth-child(2){grid-column:span 2}.builder-setting-field-description{grid-row:auto;align-self:start}.builder-setting-field-cover{grid-row:span 2;align-self:stretch}.builder-description-field{flex-direction:column;gap:.4rem;height:100%;display:flex}.builder-mission-description{resize:vertical;flex:1;min-height:116px;overflow:auto}.nav-back-icon,.btn-icon{vertical-align:-.125em;width:1em;height:1em;margin-right:.35em;display:inline-block}.btn-icon-right{margin-left:.35em;margin-right:0}.builder-steps-panel{grid-column:auto}.builder-editor-panel{flex-direction:column;grid-column:auto;align-self:stretch;display:flex}.builder-editor-card{flex-direction:column;flex:1;min-height:0;display:flex}.builder-editor-empty{place-items:center;min-height:240px;display:grid}.builder-editor-empty p{color:var(--color-text-muted);text-align:center;font-weight:700}.builder-constellation-hint{color:#4d6590;background:#f7fbff;border:1px solid #d8e2f2;border-radius:12px;margin:0;padding:.65rem .8rem;font-weight:700}.builder-media-field{gap:.5rem;display:grid}.builder-media-upload-row{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.builder-media-upload-button,.builder-media-clear-button{color:var(--color-text);cursor:pointer;background:#edf3fc;border:2px solid #c7d8ef;border-radius:999px;padding:.4rem .8rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-size:.85rem;font-weight:800;transition:transform .12s,border-color .12s,background-color .12s}.builder-media-upload-button:hover,.builder-media-clear-button:hover{background:#e5eefb;border-color:#b0c7e8;transform:translateY(-1px)}.builder-media-input{display:none}.builder-media-preview{background:#f8fbff;border:1px solid #d7e2f2;border-radius:14px;padding:.6rem}.builder-media-preview-image,.builder-media-preview-video{object-fit:contain;background:#eaf1fc;border-radius:10px;width:100%;max-height:280px}.steps-header{margin-bottom:var(--container-padding);justify-content:space-between;align-items:center;gap:1rem;display:flex}.steps-list{gap:var(--space-3);display:grid}.step-item{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-3);cursor:pointer;background:var(--color-surface-soft);transition:transform var(--duration-normal) var(--ease-default), border-color var(--duration-normal) var(--ease-default), box-shadow var(--duration-normal) var(--ease-default)}.step-item:hover,.step-active{box-shadow:var(--shadow-low);border-color:#b6c8e5;transform:translateY(-1px)}.step-item-header{grid-template-rows:auto auto;grid-template-columns:auto 1fr;align-items:center;gap:0;display:grid}.step-number{color:#1f56b4;background:#e7effd;border:1px solid #bfd3f8;border-radius:999px;grid-area:1/1;place-items:center;width:20px;height:20px;font-size:.65rem;font-weight:700;display:grid}.step-type-badge{color:#7288aa;grid-area:1/2;place-self:center start;margin-left:4px;font-size:.72rem;font-weight:700;line-height:1}.step-title{color:var(--color-text);grid-area:2/1/auto/-1;margin-top:3px;font-weight:700}.step-item-actions{gap:.4rem;margin-top:.6rem;display:flex}.empty-state p{font-weight:600}.se-container{gap:var(--space-3);background:var(--color-surface);border:var(--container-border);border-radius:var(--container-radius);width:100%;max-width:860px;box-shadow:var(--shadow-high);flex-direction:column;min-height:560px;margin-inline:auto;display:flex;overflow:hidden}.se-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding:var(--container-padding) var(--container-padding) 0;display:flex}.se-header-left{flex-direction:column;gap:.2rem;min-width:0;display:flex}.se-step-label{text-transform:uppercase;letter-spacing:.07em;color:var(--color-primary);font-size:.72rem;font-weight:900}.se-title{letter-spacing:-.02em;color:var(--color-text);word-break:break-word;margin:0;font-size:clamp(1.15rem,2vw,1.55rem);font-weight:900}.se-header-right{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.se-dots{align-items:center;gap:6px;display:flex}.se-dot{background:var(--color-border);border-radius:50%;width:10px;height:10px;transition:background .25s,transform .25s}.se-dot.se-dot-active{background:var(--color-primary);transform:scale(1.25);box-shadow:0 0 0 3px #3f7fe833}.se-dot.se-dot-done{background:var(--color-success);animation:.35s dot-pop}@keyframes dot-pop{0%{transform:scale(1)}40%{transform:scale(1.5)}70%{transform:scale(.9)}to{transform:scale(1)}}.se-guidance-panel{justify-content:space-between;align-items:center;gap:var(--space-2);margin-inline:var(--container-padding);padding:var(--space-2) var(--container-padding);background:var(--color-surface-soft);border:1px solid var(--color-border);border-radius:var(--radius-sm);flex-wrap:wrap;display:flex}.se-guidance-info{flex-direction:column;gap:.15rem;min-width:0;display:flex}.se-guidance-count{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary);font-size:.7rem;font-weight:900}.se-guidance-prompt{color:var(--color-text-muted);margin:0;font-size:.88rem;font-weight:700}.se-guidance-actions{gap:var(--space-1);flex-wrap:wrap;display:flex}.se-content{padding-inline:var(--container-padding)}.se-content-canvas{padding-inline:0}.se-text-content{gap:var(--space-2);display:grid}.se-text-body{color:var(--color-text);margin:0;font-size:1rem;font-weight:600;line-height:1.6}.se-image-content{gap:var(--space-2);display:grid}.se-image-button{cursor:zoom-in;border-radius:var(--radius-sm);background:0 0;border:0;padding:0;display:block}.se-image{border-radius:var(--radius-sm);object-fit:contain;background:var(--color-bg-soft);width:100%;max-height:480px;transition:transform .16s}.se-image-caption{color:var(--color-text-muted);text-align:center;margin:0;font-size:.88rem;font-weight:600}.se-image-lightbox{z-index:1700;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#121c348f;place-items:center;padding:clamp(1rem,2vw,1.5rem);display:grid;position:fixed;inset:0}.se-image-lightbox-panel{gap:.8rem;width:min(95vw,1500px);display:grid}.se-image-lightbox-toolbar{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.se-image-lightbox-chip{color:#24385f;min-height:1.9rem;text-shadow:none;background:#fff9;border:1px solid #ffffff61;border-radius:999px;align-items:center;padding:.2rem .7rem;font-size:.78rem;font-weight:800;display:inline-flex}.se-image-lightbox-stage{cursor:zoom-in;touch-action:none;background:0 0;border-radius:24px;place-items:center;min-height:min(78vh,860px);display:grid;position:relative;overflow:hidden}.se-image-lightbox-stage.is-zoomable{cursor:grab}.se-image-lightbox-stage.is-dragging{cursor:grabbing}.se-image-lightbox-inner{place-items:center;width:100%;height:100%;display:grid;position:relative}.se-image-lightbox-image{transform-origin:50%;-webkit-user-select:none;user-select:none;pointer-events:none;will-change:transform;background:#0d1627;border-radius:20px;max-width:min(92vw,1320px);max-height:min(78vh,860px);transition:none;box-shadow:0 22px 60px #00000052}.se-image-lightbox-close{z-index:1;color:#fff;cursor:pointer;background:#ffffff24;border:1px solid #ffffff2e;border-radius:999px;padding:.5rem .9rem;font-size:.82rem;font-weight:800;position:absolute;top:clamp(.9rem,2vw,1.3rem);right:clamp(.9rem,2vw,1.3rem)}.se-image-lightbox-close:hover{background:#fff3}.se-video-content{gap:var(--space-2);display:grid}.se-video{border-radius:var(--radius-sm);background:#000;width:100%;max-height:520px}.se-video-embed{aspect-ratio:16/9;border:none;max-height:520px}.se-video-caption{color:var(--color-text-muted);margin:0;font-size:.88rem;font-weight:600}.se-canvas-content{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.se-canvas-area{background:var(--color-bg-soft);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);justify-content:center;align-items:stretch;width:100%;min-height:440px;display:flex}.se-canvas-area .constellation-stage{border:none;border-radius:0;flex:1;min-height:440px}.se-canvas-caption{padding-inline:var(--container-padding);color:var(--color-text-muted);margin:0;font-size:.95rem;font-weight:600;line-height:1.55}.se-canvas-placeholder{align-items:center;gap:var(--space-2);color:var(--color-text-muted);text-align:center;padding:var(--space-4);flex-direction:column;font-weight:700;display:flex}.se-canvas-icon{font-size:2.5rem}.se-instruction{padding-inline:var(--container-padding);color:var(--color-text-muted);margin:0;font-size:.95rem;font-weight:600;line-height:1.55}.se-interaction{gap:var(--space-2);padding-inline:var(--container-padding);display:grid}.se-question-text{color:var(--color-text);margin:0;font-weight:800}.se-options{gap:.4rem;display:grid}.se-option{gap:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;color:var(--color-text);align-items:center;padding:.5rem .7rem;font-weight:600;transition:border-color .12s,background-color .12s;display:flex}.se-option-native{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.se-option-check{border:1px solid var(--color-border-strong);color:#fff;background:#fff;border-radius:9px;flex-shrink:0;place-items:center;width:26px;height:26px;display:grid}.se-option-check-icon{opacity:1;line-height:1;transform:translateY(-1px)}.se-option-label{font-weight:600}.se-option:hover{border-color:var(--color-border-strong);background:var(--color-surface-soft)}.se-option.selected{background:#f4fcf8;border-color:#35b171}.se-option.selected .se-option-check{background:#2fb86f;border-color:#2aa666}.se-multi-hint{border-radius:var(--radius-sm);color:#2553a0;background:#eef4ff;border:1.5px solid #c3d7f8;align-items:center;gap:.4rem;padding:.45rem .8rem;font-size:.85rem;font-weight:700;transition:background .18s,border-color .18s,color .18s;display:flex}.se-multi-hint--complete{color:#1a7a4e;background:#f0faf5;border-color:#6dd6a4}.se-option--wrong{animation:.35s wrong-shake;background:#fff4f4!important;border-color:#f08080!important}.se-option--wrong .se-option-check{background:#e86060;border-color:#e05050}.se-option-wrong-tag{color:#c03030;white-space:nowrap;background:#fde8e8;border:1px solid #f5aaaa;border-radius:20px;flex-shrink:0;margin-left:auto;padding:.1rem .5rem;font-size:.75rem;font-weight:800}@keyframes wrong-shake{0%{transform:translate(0)}25%{transform:translate(-5px)}50%{transform:translate(5px)}75%{transform:translate(-3px)}to{transform:translate(0)}}.se-footer{gap:var(--space-2);padding:0 var(--container-padding) var(--container-padding);border-top:1px solid var(--color-border);padding-top:var(--space-3);flex-direction:column;display:flex}.se-footer-nav{gap:var(--space-2);display:flex}.se-next-preview{color:var(--color-text-muted);text-align:center;margin:0;font-size:.8rem;font-style:italic}.se-next-preview-label{color:var(--color-violet);font-style:normal;font-weight:700}.se-step-error{margin:0 var(--container-padding) var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:#7a5000;text-align:center;justify-content:center;align-items:center;gap:var(--space-2);background:#fff8ec;border:2px solid #f5c542;font-size:.9rem;font-weight:700;animation:.4s error-shake;display:flex}.se-step-error-icon{flex-shrink:0;font-size:1.2rem}@keyframes error-shake{0%{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}to{transform:translate(0)}}.btn-ready-pulse{animation:2s ease-in-out infinite btn-pulse}@keyframes btn-pulse{0%,to{box-shadow:0 0 #3f7fe866}50%{box-shadow:0 0 0 8px #3f7fe800}}.dashboard-top{background:var(--color-surface);border:var(--container-border);border-radius:var(--container-radius);box-shadow:var(--container-shadow);overflow:hidden}.dashboard-top>.dashboard-header{padding:var(--container-padding)}.dashboard-header-content{align-items:center;gap:var(--space-3);flex-wrap:nowrap;min-height:60px;display:flex}.dashboard-greeting{letter-spacing:-.02em;color:var(--color-text);white-space:nowrap;flex:auto;font-size:clamp(1.1rem,2vw,1.5rem);font-weight:900}.achievements-divider{background:var(--color-border);flex-shrink:0;width:1px;height:32px}.achievements-bar{align-items:center;gap:var(--space-5);flex-shrink:0;display:flex}.ach-stars-block{align-items:center;gap:var(--space-2);flex-direction:row;flex-shrink:0;display:flex}.ach-stars-inner{flex-direction:column;gap:3px;min-width:100px;display:flex}.ach-stars-top{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.ach-star-icon{flex-shrink:0;font-size:1.5rem;line-height:1}.ach-stars-value{color:var(--color-text);font-size:.85rem;font-weight:700;line-height:1}.ach-progress-pct{color:var(--color-primary);font-size:.75rem;font-weight:400;line-height:1}.ach-progress-bar{background:var(--color-border);border-radius:999px;align-self:stretch;width:100%;height:5px;overflow:hidden}.ach-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-accent,#6c63ff));border-radius:999px;min-width:2px;height:100%;transition:width .6s}.ach-total-block{text-align:center;border-radius:var(--radius-sm);flex-direction:column;flex-shrink:0;align-items:center;gap:2px;padding:2px 6px;transition:background-color .12s;display:flex}.ach-total-clickable{cursor:pointer}.ach-total-clickable:hover,.ach-total-clickable:focus-visible{background:var(--color-surface-hover,#0000000d);outline:none}.ach-total-count{color:var(--color-text);font-size:1rem;font-weight:400;line-height:1.1}.ach-total-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.55rem;font-weight:600}.ach-tiers{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.ach-tier-item{justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:relative}.ach-tier-icon{object-fit:contain;width:32px;height:32px;display:block}.ach-tier-count{color:var(--color-text);background:var(--color-surface,#fff);border-radius:4px;padding:0 2px;font-size:.8rem;font-weight:400;line-height:1;position:absolute;bottom:6px;right:-6px}.ach-tier-platinum .ach-tier-count{color:#7dd3fc}.ach-tier-gold .ach-tier-count{color:#fbbf24}.ach-tier-silver .ach-tier-count{color:#94a3b8}.ach-tier-bronze .ach-tier-count{color:#c2844f}@media (width<=900px){.dashboard-header-content{gap:var(--space-2);flex-wrap:wrap}.dashboard-greeting{flex:100%}.achievements-divider{display:none}.achievements-bar{gap:var(--space-2);border-top:1px solid var(--color-border);padding-top:var(--space-2);flex-wrap:wrap;width:100%}.ach-tier-icon{width:20px;height:20px}}.explorer-level-badge{color:var(--color-primary);border:1.5px solid var(--color-border);letter-spacing:.01em;background:#eef3fb;border-radius:999px;margin-top:.2rem;padding:.18rem .7rem;font-size:.82rem;font-weight:700;display:inline-block}.dashboard-stat-xp{flex:2 200px;align-items:flex-start;gap:.4rem}.dashboard-stat-xp-row{align-items:baseline;gap:.35rem;display:flex}.xp-bar-wrap{flex-direction:column;gap:.25rem;width:100%;display:flex}.xp-bar-label{color:var(--color-text-muted);font-size:.7rem;font-weight:600}.continue-adventure-banner{border:2px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);gap:var(--space-2);margin-top:var(--section-stack-spacing);background:linear-gradient(135deg,#edf4ff 0%,#f5f0ff 100%);flex-direction:column;animation:.35s slide-in-top;display:flex}.continue-adventure-inner{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.continue-adventure-text{flex-direction:column;gap:.2rem;display:flex}.continue-adventure-label{color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.continue-adventure-mission{color:var(--color-text);font-size:1.05rem;font-weight:800}@keyframes slide-in-top{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mission-card-header-top{justify-content:space-between;align-items:center;gap:.4rem;margin-bottom:.3rem;display:flex}.mission-difficulty{letter-spacing:-.02em;flex-shrink:0;font-size:.75rem}.mission-player-description{max-width:72ch;color:var(--color-text-muted);text-wrap:pretty;margin:.5rem 0 0;font-size:.98rem;line-height:1.5}@media (width<=760px){.mission-player-header{flex-direction:column;align-items:stretch}.mission-player-header>.btn{align-self:flex-start}.mission-player-header-info h1{font-size:clamp(1.7rem,7vw,2.3rem)}}.mission-notice{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);border:1.5px solid var(--color-coral);color:var(--color-coral);background:#fff2f2;font-size:.9rem;font-weight:600}.mission-notice.mission-notice-info{border-color:var(--color-primary);color:var(--color-primary);background:#f0f6ff}.step-viewer{gap:.9rem;max-width:860px;margin:0 auto;display:grid}.step-content{gap:.9rem;display:grid}.step-header,.step-meta,.module-card-header,.mission-card-header,.mission-footer,.module-footer,.user-card-header{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.step-media,.step-question,.video-with-questions{border-radius:var(--radius-sm);background:var(--color-surface-soft);border:1px solid var(--color-border);padding:.75rem}.step-annotations{pointer-events:none;background:0 0;border:0;padding:0;position:absolute;inset:0}.step-image,.step-video{border-radius:var(--radius-sm);width:100%}.question-text{color:var(--color-text);margin-bottom:.6rem;font-weight:700}.question-options{gap:.45rem;display:grid}.question-option{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:12px;align-items:center;gap:.5rem;padding:.45rem .55rem;font-weight:600;transition:border-color .12s;display:flex}.question-option:hover{border-color:var(--color-border-strong)}.step-actions{justify-content:space-between;gap:.8rem;display:flex}.guidance-panel{border:1px solid var(--color-border);background:var(--color-surface-soft);border-radius:var(--radius-sm);padding:var(--space-2) var(--container-padding);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.guidance-panel-count{color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.15rem;font-size:.76rem;font-weight:900;display:inline-block}.guidance-panel p{color:var(--color-text-muted);font-weight:700}.guidance-panel-actions{flex-wrap:wrap;gap:.55rem;display:flex}.completion-card,.module-card,.mission-card,.user-card{position:relative;overflow:hidden}.completion-content{text-align:center;gap:.75rem;display:grid}.completion-trophy{font-size:3.5rem;line-height:1;animation:.6s trophy-bounce}@keyframes trophy-bounce{0%{opacity:0;transform:scale(.4)rotate(-10deg)}60%{opacity:1;transform:scale(1.2)rotate(4deg)}80%{transform:scale(.95)rotate(-2deg)}to{opacity:1;transform:scale(1)rotate(0)}}.completion-headline{letter-spacing:.04em;color:#0b1f52;margin:0;font-size:1.45rem;font-weight:900}.completion-subline{color:var(--color-text-muted);margin:-.45rem 0 .5rem;font-size:1rem;font-weight:600}.celebration-confetti{pointer-events:none;position:absolute;inset:0;overflow:hidden}.confetti-piece{--confetti-color:hsl(calc(var(--piece) * 31deg), 85%, 62%);top:-12%;left:calc((var(--piece) * 5.4%) + 2%);background:var(--confetti-color);width:10px;height:18px;animation:1.5s ease-in forwards confetti-fall;animation-delay:calc(var(--piece) * 35ms);transform:rotate(calc(var(--piece) * 16deg));border-radius:4px;position:absolute}@keyframes confetti-fall{0%{opacity:0;transform:translateY(0)rotate(0)scale(.7)}20%{opacity:1}to{opacity:0;transform:translateY(240px)rotate(220deg)scale(1.05)}}.completion-rewards{grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;display:grid}.reward-item{text-align:center;color:#3c5278;background:#f8fbff;border:1px solid #d8e2f2;border-radius:12px;gap:.25rem;padding:.6rem;font-weight:700;display:grid}.reward-item-points{background:#fffbec;border-color:#f5c542}.reward-icon{font-size:1.4rem}.reward-value{color:#0b1f52;font-size:1.8rem;font-weight:900;line-height:1}.reward-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.completion-trophies-list{gap:var(--space-2);flex-direction:column;align-items:center;display:flex}.completion-trophies-section{margin-top:var(--space-4);text-align:center}.trophy-unlock-header{letter-spacing:.12em;color:var(--color-primary);text-transform:uppercase;margin-bottom:var(--space-3);font-size:.8rem;font-weight:900;animation:2s ease-in-out infinite trophy-header-pulse}@keyframes trophy-header-pulse{0%,to{opacity:1}50%{opacity:.65}}.completion-trophy-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:2px solid var(--color-border);background:var(--color-surface);width:100%;max-width:360px;animation:.5s cubic-bezier(.34,1.56,.64,1) both trophy-card-pop;animation-delay:calc(var(--trophy-idx,0) * .14s + .25s);display:flex;position:relative;overflow:hidden}.completion-trophy-card--bronze{background:#fff8f3;border-color:#c2844f}.completion-trophy-card--silver{background:#f8f9fb;border-color:#94a3b8}.completion-trophy-card--gold{background:#fffbeb;border-color:#fbbf24}.completion-trophy-card--platinum{background:#f0f9ff;border-color:#7dd3fc}@keyframes trophy-card-pop{0%{opacity:0;transform:scale(.3)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.trophy-card-glow{border-radius:inherit;pointer-events:none;opacity:0;animation:2.4s ease-in-out infinite trophy-glow-pulse;position:absolute;inset:0}.completion-trophy-card--bronze .trophy-card-glow{opacity:1;background:radial-gradient(at 50% 0,#c2844f44,#0000 65%)}.completion-trophy-card--silver .trophy-card-glow{opacity:1;background:radial-gradient(at 50% 0,#94a3b844,#0000 65%)}.completion-trophy-card--gold .trophy-card-glow{opacity:1;background:radial-gradient(at 50% 0,#fbbf2444,#0000 65%)}.completion-trophy-card--platinum .trophy-card-glow{opacity:1;background:radial-gradient(at 50% 0,#7dd3fc44,#0000 65%)}@keyframes trophy-glow-pulse{0%,to{opacity:.4}50%{opacity:.8}}.trophy-card-icon{object-fit:contain;width:40px;height:40px;animation:trophy-icon-bounce .7s ease calc(var(--trophy-idx,0) * .14s + .55s) 1 both;flex-shrink:0}@keyframes trophy-icon-bounce{0%{transform:scale(.5)rotate(-10deg)}60%{transform:scale(1.2)rotate(4deg)}to{transform:scale(1)rotate(0)}}.trophy-card-text{text-align:left;flex-direction:column;gap:2px;display:flex}.trophy-card-title{color:var(--color-text);font-size:.95rem;font-weight:800;line-height:1.2}.trophy-card-desc{color:var(--color-text-muted);font-size:.78rem;line-height:1.3}.trophy-card-tier{letter-spacing:.1em;text-transform:uppercase;margin-top:2px;font-size:.65rem;font-weight:900}.trophy-card-tier--bronze{color:#c2844f}.trophy-card-tier--silver{color:#64748b}.trophy-card-tier--gold{color:#d97706}.trophy-card-tier--platinum{color:#0284c7}.mission-unavailable{opacity:.45;filter:saturate(.3)}.mission-card{border-width:2px;flex-direction:column;gap:.55rem;min-height:240px;display:flex;overflow:hidden}.mission-body{flex:1}.mission-card-cover{--cover-frame-size:.36rem;width:calc(100% + (var(--container-padding) * 2));background:var(--color-surface);height:clamp(100px,18vw,150px);margin-top:calc(-1 * var(--container-padding));margin-right:calc(-1 * var(--container-padding));margin-bottom:.55rem;margin-left:calc(-1 * var(--container-padding));border-radius:var(--container-radius) var(--container-radius) 0 0;padding:var(--cover-frame-size);position:relative;overflow:hidden}.mission-card-cover:before{content:"";border-radius:inherit;pointer-events:none;z-index:2;position:absolute;inset:0;box-shadow:inset 0 0 0 4px #fffffffa}.mission-card-cover:after{content:"";left:var(--cover-frame-size);right:var(--cover-frame-size);pointer-events:none;z-index:3;background:linear-gradient(#fff0 0%,#ffffff1f 100%);height:14%;position:absolute;bottom:0}.mission-card-cover-image{top:var(--cover-frame-size);left:var(--cover-frame-size);width:calc(100% - (var(--cover-frame-size) * 2));height:calc(100% - (var(--cover-frame-size) * 2));object-fit:cover;object-position:center top;border-radius:calc(var(--container-radius) - 6px) calc(var(--container-radius) - 6px) 0 0;z-index:1;display:block;position:absolute;-webkit-mask-image:linear-gradient(#000 0% 89%,#000000d1 96%,#0000008c 100%);mask-image:linear-gradient(#000 0% 89%,#000000d1 96%,#0000008c 100%)}.module-card-cover{--cover-frame-size:.36rem;width:calc(100% + (var(--container-padding) * 2));background:var(--module-card-surface,var(--color-surface));height:clamp(100px,18vw,150px);margin-top:calc(-1 * var(--container-padding));margin-right:calc(-1 * var(--container-padding));margin-bottom:.6rem;margin-left:calc(-1 * var(--container-padding));border-radius:var(--container-radius) var(--container-radius) 0 0;padding:var(--cover-frame-size);position:relative;overflow:hidden}.module-card-cover:before{content:"";border-radius:inherit;box-shadow:inset 0 0 0 4px var(--module-card-surface,var(--color-surface));pointer-events:none;z-index:2;position:absolute;inset:0}.module-card-cover:after{content:"";left:var(--cover-frame-size);right:var(--cover-frame-size);background:linear-gradient(180deg, #fff0 0%, var(--module-card-surface,var(--color-surface)) 100%);pointer-events:none;z-index:3;height:14%;position:absolute;bottom:0}.module-card-cover-image{top:var(--cover-frame-size);left:var(--cover-frame-size);width:calc(100% - (var(--cover-frame-size) * 2));height:calc(100% - (var(--cover-frame-size) * 2));object-fit:cover;object-position:center;border-radius:calc(var(--container-radius) - 6px) calc(var(--container-radius) - 6px) 0 0;z-index:1;display:block;position:absolute;-webkit-mask-image:linear-gradient(#000 0% 89%,#000000d1 96%,#0000008c 100%);mask-image:linear-gradient(#000 0% 89%,#000000d1 96%,#0000008c 100%)}.module-card{--module-card-surface:var(--color-surface);padding:var(--container-padding);flex-direction:column;height:100%;display:flex}.module-card-highlighted{box-shadow:0 0 0 2px var(--color-primary), var(--shadow-low)}.module-card:hover,.mission-card:hover{transform:translateY(-3px)scale(1.015)}.module-card-header{align-items:flex-start;gap:.85rem;margin-bottom:.35rem;display:flex}.module-icon{background:#eef3fb;border:1px solid #d5e0ef;border-radius:999px;flex-shrink:0;place-items:center;width:2.65rem;height:2.65rem;font-size:1.35rem;display:grid}.module-card-header-content{flex:1;gap:.35rem;min-width:0;display:grid}.module-card-tags,.mission-card-tags{flex-wrap:wrap;align-items:center;gap:.3rem;display:flex}.card-tag-compact{padding:.16rem .5rem;font-size:.67rem;line-height:1.1}.mission-card-header{align-items:flex-start}.module-name,.mission-title{color:var(--color-text);word-break:break-word;flex:1;margin:0;font-size:1.1rem;font-weight:800}.module-card-divider{background:var(--color-border);height:2px;margin:.15rem 0 .4rem}.module-description,.mission-description,.step-instruction{color:var(--color-text-muted);margin:0;font-size:.88rem;font-weight:600;line-height:1.4}.module-description,.mission-description{min-height:2.8em}.module-card-spacer{flex:1}.module-footer{align-items:center;gap:.6rem;margin-top:.75rem;margin-bottom:.5rem;display:flex}.mission-card-tags{flex-shrink:0;margin-top:-.05rem;margin-bottom:.1rem}.module-card-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem;display:grid}.module-card-actions button{width:100%;min-width:0}.module-card-actions .module-card-button{min-width:0}.module-card-button{padding-inline:.55rem}.module-card-button .btn-label{white-space:nowrap;font-size:.88rem}.module-card-button-manage{grid-column:1/-1;padding-inline:.7rem}.module-card-button-manage .btn-label{letter-spacing:.01em;font-size:.78rem}.mission-completed-icon{color:#1db987;font-weight:900}.mission-completed{background:linear-gradient(160deg,#f4fdf9 0%,#edfbf4 100%)!important;border-color:#a8e6cc!important}.mission-completed .mission-completed-icon{font-size:1rem}.admin-tabs{margin-top:var(--space-4);flex-wrap:wrap;gap:.5rem;display:flex}.admin-tab{color:#3e567f;text-transform:uppercase;letter-spacing:.03em;cursor:pointer;background:#f7f9fc;border:2px solid #d4e0f1;border-radius:999px;padding:.45rem .8rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-weight:800;transition:transform .12s,border-color .12s,background-color .12s}.admin-tab:hover{background:#eef3fb;border-color:#b8cbe8;transform:translateY(-1px)}.admin-tab-active{color:#1d53ad;background:#e8f0fd;border-color:#3f7fe8}.admin-error{color:#9f3131;border-radius:var(--container-radius);padding:var(--container-padding);margin-top:var(--space-3);box-shadow:var(--shadow-low);background:linear-gradient(#fff7f7 0%,#fdeeee 100%);border:1px solid #f0c4c4;font-weight:700}.admin-success{margin-top:var(--space-3);color:#1b8b66;border-radius:var(--container-radius);padding:var(--container-padding);box-shadow:var(--shadow-low);background:linear-gradient(#f2fcf8 0%,#e6f8f2 100%);border:1px solid #b6e7d7;font-weight:700}.admin-loading{margin-top:var(--space-3);color:#5f759a;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--container-radius);padding:var(--container-padding);font-weight:700}.admin-grid-4,.stats-panel-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.8rem;display:grid}.admin-stat h3{color:#6f86aa;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.45rem;font-size:.9rem}.admin-stat p{color:var(--color-text);font-size:1.45rem;font-weight:800}.admin-section-header{max-width:420px}.admin-section-header .input-label{font-size:var(--label-font-preset-lg);color:#fff;letter-spacing:.05em}.admin-table-wrap{overflow:auto}.admin-table{border-collapse:collapse;width:100%;min-width:760px}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid #e4ebf7;padding:.65rem}.admin-table th{text-transform:uppercase;letter-spacing:.03em;color:#7188ab;font-size:.78rem}.admin-role-actions{align-items:center;gap:.5rem;display:flex}.admin-rank-badge{text-align:center;min-width:2rem;font-size:1.25rem;display:inline-block}.admin-section-title{color:var(--color-text);margin:0 0 .25rem;font-size:1rem;font-weight:700}.admin-section-desc{color:var(--color-text-muted);margin:0 0 1rem;font-size:.85rem}.admin-completion-cell{align-items:center;gap:.6rem;display:flex}.admin-completion-bar-wrap{background:#e4ebf7;border-radius:4px;flex:1;min-width:60px;height:6px;overflow:hidden}.admin-completion-bar{background:var(--color-success);border-radius:4px;height:100%;transition:width .3s}.admin-completion-pct{color:var(--color-text-muted);white-space:nowrap;text-align:right;min-width:2.5rem;font-size:.8rem;font-weight:600}.admin-section--2col{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-form-grid{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.admin-analytics-filter-row{gap:var(--space-3);margin:var(--space-3) 0;grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.admin-content-summary{flex-wrap:wrap;gap:.55rem;display:flex}.admin-panel-card{gap:var(--panel-card-stack-gap);width:100%;display:grid}.admin-panel-card>.btn{justify-self:start}.admin-section-actions{gap:var(--space-2);flex-wrap:wrap;justify-self:start;display:flex}.list-view{gap:var(--space-3);width:100%;display:grid}.list-view-header,.list-view-header-actions{justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap;display:flex}.list-view-header-copy{gap:.2rem;display:grid}.list-view-title{letter-spacing:-.02em;color:var(--color-text);font-size:clamp(1.35rem,2.4vw,1.9rem);font-weight:900}.list-view-description{color:#5c759b;font-weight:600}.list-view-add-trigger{align-self:center}.list-view-search{width:min(100%,460px)}.list-view-search-filters{gap:var(--space-3);flex-direction:column;display:flex}.list-view-search-filters--split{gap:var(--space-4);grid-template-columns:minmax(0,1fr) auto;align-items:end;display:grid}.list-view-search-filters--split .list-view-search{width:100%}.list-view-filters{gap:var(--space-3);flex-wrap:wrap;align-items:flex-end;display:flex}.list-view-filters>.btn{align-self:flex-end;margin-bottom:1px}.list-view-body{border-radius:var(--radius-md);background:#fff}.list-view-body-framed{border:var(--list-view-border);overflow:auto}.list-view-body-framed.list-view-body-no-border{border:none}.list-view-body-content{background:0 0;border:0;overflow:visible}.list-view-empty{padding:var(--space-5) var(--space-4);text-align:center;color:var(--color-text-muted);border:2px dashed var(--color-border);background:#f5f8ff;border-radius:16px;font-size:.95rem;font-weight:700;line-height:1.5}.list-add-modal-description{color:#5c759b;margin-bottom:var(--space-3);font-weight:600}.admin-backup .card{gap:.8rem;display:grid}textarea.input{resize:vertical;min-height:180px}.layout-content,.video-questions-list{gap:.8rem;display:grid}.guidance-overlay-container{pointer-events:none;position:absolute;inset:0}.guidance-backdrop{-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#08173857;position:absolute;inset:0}.guidance-arrow,.guidance-highlight,.guidance-pulse,.guidance-text-bubble,.guidance-typing-hint,.guidance-drawing{z-index:3;pointer-events:auto;position:absolute}.guidance-arrow{align-items:flex-start;gap:.6rem;display:inline-flex}.guidance-arrow-glyph{color:#fff;text-shadow:0 6px 20px #071d4f59;font-size:2rem}.guidance-highlight{border:3px dashed var(--color-primary);background:#ffffff14;border-radius:16px;box-shadow:0 0 0 999px #08173814}.guidance-pulse{background:var(--color-orange);border-radius:999px;width:18px;height:18px;box-shadow:0 0 0 12px #ff9f432e}.guidance-pulse-animate{animation:.9s ease-in-out infinite pulse-ring}@keyframes pulse-ring{0%{transform:scale(.95)}50%{transform:scale(1.1)}to{transform:scale(.95)}}.guidance-text-bubble{max-width:260px}.guidance-inline-card,.guidance-floating-card{box-shadow:var(--shadow-low);background:#fffffff5;border:1px solid #d2def1;border-radius:14px;max-width:240px;padding:.55rem .7rem}.guidance-floating-card{position:absolute;top:calc(100% + 10px);left:0}.guidance-floating-card-offset{left:auto;right:0}.guidance-inline-card p,.guidance-floating-card p{color:#3e567d;font-weight:700}.guidance-bubble-content{box-shadow:var(--shadow-low);background:#fff;border:1px solid #c9d9ef;border-radius:14px;padding:.55rem .7rem}.guidance-bubble-content p{color:#3e567d;font-weight:600}.guidance-interaction-chip{color:#2854a1;text-transform:uppercase;letter-spacing:.05em;background:#e8effc;border-radius:999px;justify-content:center;align-items:center;margin-top:.45rem;padding:.18rem .55rem;font-size:.72rem;font-weight:900;display:inline-flex}.guidance-bubble-pointer{border-top:8px solid #c9d9ef;border-left:7px solid #0000;border-right:7px solid #0000;width:0;height:0;margin-left:12px}.guidance-typing-hint{box-shadow:var(--shadow-low);background:#fff;border:1px solid #d6e1f1;border-radius:12px;align-items:center;gap:.4rem;padding:.45rem .6rem;display:inline-flex}.hint-text{color:#3e567d;font-weight:700}.guidance-drawing{border:2px dashed #fff;border-radius:18px}.guidance-drawing-svg{width:100%;height:100%}.guidance-drawing-svg path{fill:none;stroke:#fff;stroke-width:4px;stroke-linecap:round;stroke-linejoin:round}.guidance-glow{box-shadow:0 10px 28px #1d4d9e47}.badge-manager-panel{gap:.9rem;display:grid}.badge-manager-card-top,.badge-manager-title-row,.badge-manager-actions,.badge-manager-form-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.badge-manager-form-row{gap:var(--space-3);grid-template-columns:1fr;align-items:stretch;display:grid}.badge-manager-copy p,.badge-manager-trigger{color:#5c759b;font-weight:600}.badge-manager-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.badge-manager-card{padding:var(--container-padding);flex-direction:column;gap:.8rem;display:flex}.badge-manager-card-top{align-items:flex-start;gap:.85rem;display:flex}.badge-manager-icon{border:2px solid;border-radius:18px;flex-shrink:0;place-items:center;width:3rem;height:3rem;font-size:1.45rem;display:grid}.badge-manager-copy{flex-direction:column;flex:1;gap:.35rem;min-width:0;display:flex}.badge-manager-copy h4{color:var(--color-text);margin:0;font-size:.95rem;font-weight:900}.badge-manager-copy p{margin:0;font-size:.82rem}.badge-manager-form{gap:.8rem;display:grid}.badge-manager-color-field{gap:.35rem;min-width:110px;display:grid}.badge-manager-color-input{background:#fff;border:2px solid #d8e2f0;border-radius:14px;width:100%;min-height:54px;padding:.35rem}.mission-player-loading,.mission-player-error,.loading-screen{text-align:center;min-height:44vh;color:var(--color-text);letter-spacing:.02em;place-items:center;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;display:grid}.loading-state{align-items:center;gap:var(--space-3);padding:var(--space-5) 0;flex-direction:column;display:flex}.loading-spinner{border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.loading-text{color:var(--color-text-muted);font-family:Be Vietnam Pro,sans-serif;font-size:1rem}.mission-player-error-card{align-items:center;gap:var(--space-3);padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);max-width:400px;box-shadow:var(--shadow-low);flex-direction:column;display:flex}.mission-player-error-icon{font-size:3rem;line-height:1}.mission-player-error-card h2{color:var(--color-text);margin:0;font-size:1.25rem}.mission-player-error-card p{color:var(--color-text-muted);text-align:center;margin:0;font-size:.95rem}.error-boundary{min-height:100vh;padding:var(--space-4);background:var(--color-bg);place-items:center;display:grid}.error-boundary-card{align-items:center;gap:var(--space-3);padding:var(--space-6);background:var(--color-surface);border-radius:var(--radius-lg);border:var(--container-border);box-shadow:var(--shadow-high);text-align:center;flex-direction:column;max-width:460px;display:flex}.error-boundary-icon{font-size:3rem;line-height:1}.error-boundary-card h2{color:var(--color-text);font-size:1.4rem}.error-boundary-card p{color:var(--color-text-muted);font-size:.95rem;line-height:1.6}.error-boundary-details{width:100%;color:var(--color-text-muted);text-align:left;font-size:.8rem}.error-boundary-details summary{cursor:pointer;padding:.3rem 0;font-weight:700}.error-boundary-details pre{background:var(--color-bg-soft);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-all;max-height:200px;margin:.5rem 0 0;padding:.75rem;font-size:.78rem;overflow:auto}.admin-pagination{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-3) 0 var(--space-2);display:flex}.admin-pagination-info{color:var(--color-text-muted);font-family:Be Vietnam Pro,sans-serif;font-size:.9rem}@media (width<=1100px){.builder-main-workspace{grid-template-columns:minmax(0,1fr)}.builder-settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.builder-setting-field-title,.builder-setting-field-description,.builder-setting-field-cover{grid-column:span 1}.builder-setting-field-cover{grid-row:auto}.admin-grid-4,.stats-panel-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.modules-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=900px){.admin-header,.builder-header,.admin-form-grid,.admin-analytics-filter-row,.guidance-panel,.badge-manager-card-top,.badge-manager-title-row,.badge-manager-actions,.badge-manager-form-row,.mission-player-header{flex-direction:column;align-items:flex-start}.modules-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (orientation:portrait){.auth-page{background-size:auto 100%}}@media (width<=720px){.completion-rewards,.admin-grid-4,.stats-panel-grid,.admin-form-grid,.admin-section--2col,.builder-settings-grid,.modules-grid,.missions-grid{grid-template-columns:1fr}}.creator-page{min-height:100vh;width:min(100%, var(--page-max-width));padding:var(--page-shell-padding);margin-inline:auto}.creator-page .btn .btn-label{color:inherit;font-family:Be Vietnam Pro,Segoe UI,Tahoma,sans-serif;font-size:1rem;font-weight:900}.creator-header{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.creator-header h1{letter-spacing:-.02em;color:var(--color-text);margin:0;font-size:clamp(1.4rem,2.2vw,1.8rem);font-weight:900}.creator-welcome{color:var(--color-text-muted);font-size:.95rem;font-weight:700}.creator-header-left{flex-direction:column;gap:.2rem;display:flex}.creator-header-actions{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.creator-body{margin-top:var(--space-4)}.creator-inline-error{margin-top:0;margin-bottom:var(--space-3)}.creator-section{gap:var(--space-4);display:grid}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.creator-section-header{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.creator-section-header h2{letter-spacing:-.02em;color:var(--color-text);font-size:clamp(1.35rem,2.4vw,1.9rem);font-weight:900}.creator-back-row{align-items:center;gap:var(--space-3);display:flex}.creator-loading{color:var(--color-text-muted);padding:var(--space-4);font-weight:600}.creator-missions-list{gap:var(--space-2);display:grid}.creator-page .modules-view .module-card{min-height:unset}.creator-page .modules-view .module-description{min-height:2.8em}.creator-page .module-card-actions .module-card-button{padding-block:.42rem}.creator-page .module-card-actions .module-card-button-manage{padding-block:.48rem}.creator-page .module-card-actions{margin-top:.75rem}.creator-mission-card{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.creator-mission-card-archived{opacity:.6;background:var(--color-bg-soft)}.creator-mission-info{align-items:center;gap:var(--space-3);flex-wrap:wrap;flex:1;min-width:0;display:flex}.creator-mission-title{color:var(--color-text);flex:1;min-width:0;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:800}.creator-mission-points{color:var(--color-text-muted);white-space:nowrap;font-size:.88rem;font-weight:700}.creator-mission-actions{gap:var(--space-2);flex-shrink:0;display:flex}.creator-archived-section{gap:var(--space-2);display:grid}.creator-archived-toggle{color:var(--color-text-muted);cursor:pointer;text-align:left;background:0 0;border:0;padding:0;font-size:.9rem;font-weight:700}.creator-archived-badge{color:#8a5c00;text-transform:uppercase;letter-spacing:.04em;background:#f5e6c8;border:1px solid #e8d4a0;border-radius:999px;padding:.15rem .55rem;font-size:.72rem;font-weight:800}.creator-missions-archived .creator-mission-card{background:var(--color-bg-soft);border-style:dashed}.creator-modules-archived{margin-top:var(--space-1)}.creator-modules-archived .module-card{--module-card-surface:var(--color-bg-soft);opacity:.6;background:var(--color-bg-soft);box-shadow:none;border-style:dashed}.emoji-preset-picker{gap:var(--space-2);display:grid}.emoji-preset-grid,.creator-icon-picker{gap:var(--space-2);flex-wrap:wrap;display:flex}.emoji-preset-option,.creator-icon-option{border-radius:var(--radius-sm);border:2px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:center;place-items:center;width:40px;height:40px;padding:0;font-family:Apple Color Emoji,Segoe UI Emoji,Noto Color Emoji,Be Vietnam Pro,sans-serif;font-size:1.3rem;line-height:1;transition:border-color .12s,transform .12s;display:grid}.emoji-preset-option:hover,.creator-icon-option:hover{border-color:var(--color-primary);transform:scale(1.08)}.emoji-preset-glyph{line-height:1}.emoji-preset-option-custom{letter-spacing:.04em;text-transform:uppercase;width:auto;min-width:92px;color:var(--color-text-muted);padding-inline:.8rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-size:.78rem;font-weight:900}.emoji-preset-selected,.creator-icon-selected{border-color:var(--color-primary);background:#e8f0fd}.creator-modal-form{gap:var(--space-3);display:grid}.modal-actions-row{justify-content:flex-end;gap:var(--space-2);display:flex}.modal-actions-right{gap:var(--space-2);display:flex}.modal-actions-row-split{justify-content:space-between;align-items:center;width:100%}.builder-textarea{background:var(--color-surface);border:2px solid var(--color-border);width:100%;color:var(--color-text);resize:vertical;transition:border-color var(--duration-normal) var(--ease-default);border-radius:14px;padding:.6rem .8rem;font-family:inherit;font-size:.92rem;font-weight:600;line-height:1.5}.builder-textarea:focus{border-color:var(--color-focus);outline:none}.form-group{gap:var(--space-1);margin-top:var(--space-2);flex-direction:column;display:flex}.builder-editor-tabs{border-bottom:2px solid var(--color-border);gap:.3rem;margin-bottom:1rem;padding-bottom:0;display:flex}.builder-editor-tab{color:var(--color-text-muted);cursor:pointer;letter-spacing:.02em;text-transform:uppercase;background:0 0;border:0;border-bottom:3px solid #0000;border-radius:0;align-items:center;gap:.4rem;margin-bottom:-2px;padding:.5rem .9rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-size:.88rem;font-weight:800;transition:color .12s,border-color .12s;display:flex}.builder-editor-tab:hover{color:var(--color-text)}.builder-editor-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.builder-editor-content{gap:var(--space-3);display:grid}.builder-editor-content h2{margin-bottom:.8rem}.builder-overlays-content{flex-direction:column;flex:1;min-height:0;display:flex}.constellation-studio-card{gap:var(--space-3);flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:visible}.constellation-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap;display:flex}.constellation-header h2{color:var(--color-text);font-size:1.06rem;font-weight:900}.constellation-header p{color:var(--color-text-muted);max-width:520px;margin-top:.3rem;font-size:.88rem;font-weight:600}.constellation-count{color:#1f56b4;background:#eaf1ff;border:1px solid #bdd2f6;border-radius:999px;justify-content:center;align-items:center;padding:.2rem .7rem;font-size:.78rem;font-weight:800;display:inline-flex}.constellation-toolbar{justify-content:space-between;align-items:center;gap:var(--space-2);background:#f4f8ff;border:1px solid #d8e5fa;border-radius:16px;flex-wrap:nowrap;padding:.45rem;display:flex;overflow:auto hidden}.constellation-workspace{gap:var(--space-3);flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.constellation-toolset{flex-wrap:nowrap;flex:1 0 auto;align-items:center;gap:.35rem;min-width:0;display:flex;overflow-x:visible}.constellation-tool-icon{justify-content:center;align-items:center;width:1.1rem;min-width:1.1rem;height:1.1rem;display:inline-flex}.constellation-tool-icon img{object-fit:contain;pointer-events:none;width:100%;height:100%;display:block}.constellation-layout{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.constellation-stage{overscroll-behavior:contain;touch-action:none;background-color:#f8fbff;background-image:radial-gradient(circle,#1f56b43d 1px,#0000 1px),radial-gradient(circle,#1f56b429 1px,#0000 1px);background-size:var(--constellation-grid-size,24px) var(--constellation-grid-size,24px), var(--constellation-grid-size,24px) var(--constellation-grid-size,24px);background-position:var(--constellation-grid-offset-x,0px) var(--constellation-grid-offset-y,0px), calc(var(--constellation-grid-offset-x,0px) + var(--constellation-grid-half-size,12px)) calc(var(--constellation-grid-offset-y,0px) + var(--constellation-grid-half-size,12px));cursor:default;border:2px solid #c8daf8;border-radius:18px;flex:1;min-height:420px;position:relative;overflow:clip}.constellation-stage-tool-pan{cursor:grab}.constellation-stage-tool-select{cursor:default}.constellation-stage-tool-rect,.constellation-stage-tool-ellipse,.constellation-stage-tool-line,.constellation-stage-tool-arrow,.constellation-stage-tool-pen,.constellation-stage-tool-text,.constellation-stage-tool-image{cursor:crosshair}.constellation-svg{width:100%;height:100%;position:absolute;inset:0}.constellation-image-hint{border-radius:10px;padding:.35rem .6rem;position:absolute;bottom:.8rem;left:.8rem}.constellation-text-editor-overlay{z-index:1;pointer-events:auto;position:absolute}.constellation-text-editor-overlay textarea{width:100%;height:100%;font:inherit;color:inherit;background:0 0}.constellation-zoom-overlay,.constellation-history-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:3;background:#f7fbfff0;border:1px solid #d6e3f8;border-radius:12px;align-items:center;gap:.4rem;padding:.3rem;display:inline-flex;position:absolute}.constellation-zoom-overlay{bottom:.8rem;right:.8rem}.constellation-history-overlay{bottom:.8rem;left:.8rem}.constellation-zoom-label{color:var(--color-text-muted);text-align:center;min-width:3rem;font-size:.82rem;font-weight:800}.constellation-inspector-shell{top:-150px;right:calc(-1 * (232px + var(--space-4)));z-index:3;width:232px;display:block;position:absolute}.constellation-inspector-shell.open,.constellation-inspector-shell.collapsed{pointer-events:auto}.constellation-inspector{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f8fbfff5;border:1px solid #d8e5fa;border-radius:16px;gap:1rem;padding:.95rem;display:grid;overflow:visible;box-shadow:0 16px 40px #1027541f}.constellation-inspector-empty{place-items:center;min-height:180px}.constellation-inspector-empty p{color:var(--color-text-muted);text-align:center;font-size:.9rem;font-weight:700}.constellation-inspector-header{justify-content:space-between;align-items:flex-start;gap:var(--space-2);display:flex}.constellation-inspector-header h3{color:var(--color-text);text-transform:uppercase;letter-spacing:.03em;font-size:.95rem;font-weight:900}.constellation-inspector-header p{color:#7188ad;margin-top:.18rem;font-size:.78rem;font-weight:700}.constellation-style-section{gap:.55rem;display:grid}.constellation-style-section-header{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.constellation-style-value{color:#5f77a4;font-size:.74rem;font-weight:800}.constellation-inspector-toggle-toolbar{flex:none;margin-left:.45rem}.constellation-tool-icon-image{object-fit:contain;pointer-events:none;width:14px;height:14px;display:block}.constellation-style-section-header span:first-child{color:var(--color-text);font-size:.78rem;font-weight:800}.constellation-style-mixed{color:#4c67a3;letter-spacing:.03em;text-transform:uppercase;background:#e8efff;border-radius:999px;padding:.12rem .45rem;font-size:.68rem;font-weight:900}.constellation-swatch-row,.constellation-chip-row{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.constellation-swatch,.constellation-style-chip{cursor:pointer;background:#f5f7fc;border:1px solid #d8e2f2;border-radius:10px;transition:transform .12s,border-color .12s,background-color .12s,box-shadow .12s}.constellation-swatch:hover,.constellation-style-chip:hover{transform:translateY(-1px)}.constellation-swatch.active,.constellation-style-chip.active{background:#e8e5ff;border-color:#7a73ff;box-shadow:0 0 0 1px #7a73ff2e}.constellation-swatch{background:var(--swatch-color);width:24px;height:24px;position:relative}.constellation-swatch.transparent{background-color:#fff;background-image:linear-gradient(45deg,#eef1f7 25%,#0000 25% 75%,#eef1f7 75%),linear-gradient(45deg,#eef1f7 25%,#0000 25% 75%,#eef1f7 75%);background-position:0 0,7px 7px;background-repeat:repeat,repeat;background-size:14px 14px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box}.constellation-style-chip{color:#2f3d60;justify-content:center;align-items:center;min-width:38px;height:34px;padding:0 .45rem;font-size:1rem;font-weight:900;display:inline-flex}.constellation-style-line,.constellation-style-preview,.constellation-slop-preview,.constellation-edge-preview{display:inline-block}.constellation-style-icon{object-fit:contain;pointer-events:none;width:16px;height:16px;display:block}.constellation-style-icon-small{width:16px;height:16px}.constellation-style-line{width:16px;height:var(--line-width,2px);background:#2d3139;border-radius:999px}.constellation-style-preview{border-top:2px solid #2d3139;width:18px;height:0}.constellation-style-preview-dashed{border-top-style:dashed}.constellation-style-preview-dotted{border-top-style:dotted}.constellation-slop-preview{background-position:50%;background-repeat:no-repeat;width:18px;height:10px}.constellation-slop-preview-none{background-image:linear-gradient(135deg,#0000 45%,#2d3139 45% 55%,#0000 55%)}.constellation-slop-preview-low{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 12'%3E%3Cpath d='M1 9 C5 6,7 8,11 5 S17 7,23 3' fill='none' stroke='%232d3139' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E")}.constellation-slop-preview-high{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 12'%3E%3Cpath d='M1 9 C4 4,7 10,10 5 S15 8,18 4 S21 6,23 3' fill='none' stroke='%232d3139' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E")}.constellation-text-align-icon{object-fit:contain;pointer-events:none;width:16px;height:16px;display:block}.constellation-text-vertical-align-icon{width:14px;height:18px;display:inline-block;position:relative}.constellation-text-vertical-align-icon:before,.constellation-text-vertical-align-icon:after{content:"";background:#2d3139;position:absolute;left:50%;transform:translate(-50%)}.image-upload-field{gap:var(--space-2);flex-direction:column;display:flex}.image-upload-shell{border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.6rem .75rem}.image-upload-shell-content{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.image-upload-inline-preview{border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background:var(--color-bg-soft);box-shadow:var(--shadow-low);flex:none;position:relative;overflow:hidden}.image-upload-inline-preview img{object-fit:cover;width:100%;height:100%;display:block}.image-upload-inline-clear{width:1.4rem;height:1.4rem;color:var(--color-coral);cursor:pointer;background:#ffffffeb;border:1.5px solid #ef474759;border-radius:999px;justify-content:center;align-items:center;font-size:.7rem;font-weight:900;line-height:1;transition:background .12s,border-color .12s;display:flex;position:absolute;top:.25rem;right:.25rem}.image-upload-inline-clear:hover{border-color:var(--color-coral);background:#fff0f0}.image-upload-inline-clear:disabled{opacity:.5;cursor:not-allowed}.image-upload-file-input-hidden{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.image-upload-file-stack{flex-direction:column;flex:1;align-items:center;gap:.25rem;min-width:0;display:flex}.image-upload-choose-label{border:1.5px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text);letter-spacing:.03em;text-transform:uppercase;cursor:pointer;white-space:nowrap;box-shadow:0 2px 0 var(--color-bg-soft);border-radius:999px;align-items:center;padding:.4rem 1rem;font-family:Space Grotesk,Be Vietnam Pro,sans-serif;font-size:.8rem;font-weight:800;transition:background .12s,border-color .12s,box-shadow .12s;display:inline-flex}.image-upload-choose-label:hover{background:var(--color-bg-soft);border-color:var(--color-primary);box-shadow:0 2px #dce8f8}.image-upload-choose-label[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.image-upload-filename{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:100%;padding-left:.1rem;font-size:.78rem;font-weight:600;overflow:hidden}@media (width<=720px){.image-upload-shell{flex-wrap:wrap}.image-upload-shell-content{order:1;width:100%}}.constellation-text-vertical-align-icon:before{width:2px;height:100%;top:0}.constellation-text-vertical-align-icon:after{width:10px;height:2px}.constellation-text-vertical-align-top:after{top:2px}.constellation-text-vertical-align-middle:after{top:50%;transform:translate(-50%,-50%)}.constellation-text-vertical-align-bottom:after{bottom:2px}.constellation-font-size-chip{min-width:34px}.constellation-edge-preview{border:2px dashed #2d3139;width:18px;height:14px}.constellation-edge-preview-sharp{border-radius:0}.constellation-edge-preview-rounded{border-radius:7px}.constellation-opacity-track{padding-bottom:.4rem;position:relative}.constellation-opacity-slider{accent-color:#827cff;width:100%;display:block}.constellation-opacity-thumb-label{color:#7085a9;pointer-events:none;white-space:nowrap;font-size:.72rem;font-weight:700;position:absolute;bottom:0;transform:translate(-50%)}.constellation-opacity-scale{color:#7085a9;justify-content:space-between;gap:.5rem;font-size:.72rem;font-weight:700;display:flex}.builder-question-section{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-soft);padding:var(--space-3);gap:var(--space-3);display:grid}.builder-question-options-editor{gap:var(--space-2);display:grid}.builder-question-options-header{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.builder-question-options-list{gap:var(--space-2);display:grid}.builder-question-option-row{align-items:center;gap:var(--space-2);grid-template-columns:auto minmax(0,1fr) auto;display:grid}.builder-question-option-row .input-group{margin:0}.builder-question-correct-check{border:1px solid var(--color-border-strong);width:40px;height:40px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-normal) var(--ease-default);background:#fff;border-radius:12px;place-items:center;font-size:1rem;font-weight:800;display:grid}.builder-question-correct-check-icon{opacity:1;line-height:1;transform:translateY(-1px)}.builder-question-correct-check:hover:not(:disabled){background:#f3fdf8;border-color:#39b876}.builder-question-correct-check.selected{color:#fff;background:#2fb86f;border-color:#2aa666}.builder-question-correct-check.selected .builder-question-correct-check-icon{opacity:1}.builder-question-correct-check:disabled{cursor:not-allowed;opacity:.4}@media (width<=860px){.builder-question-option-row{grid-template-columns:auto minmax(0,1fr)}.builder-question-option-row .btn{grid-column:1/-1;justify-self:end}}.builder-overlays-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap;display:flex}.builder-overlays-header h2{color:var(--color-text);font-size:1.1rem;font-weight:900}.builder-overlays-header p{color:var(--color-text-muted);max-width:360px;margin-top:.3rem;font-size:.86rem;font-weight:600}.builder-overlays-empty{background:var(--color-bg-soft);border-style:dashed}.builder-overlays-empty p{color:var(--color-text-muted);text-align:center;padding:var(--space-3) 0;font-size:.92rem;font-weight:600}.builder-overlays-list{gap:var(--space-2);display:grid}.builder-overlay-card{gap:var(--space-2);background:#f8fbff;display:grid}.builder-overlay-row{align-items:flex-end;gap:var(--space-2);flex-wrap:wrap;display:flex}.builder-overlay-num{color:#1f56b4;background:#e7effd;border:1px solid #bfd3f8;border-radius:999px;flex-shrink:0;place-items:center;width:26px;height:26px;font-size:.78rem;font-weight:800;display:grid}.builder-overlay-badge{background:var(--color-primary);color:#fff;text-align:center;border-radius:999px;min-width:1.2rem;padding:.1rem .4rem;font-size:.7rem;font-weight:800}.builder-overlay-coords{gap:var(--space-2);flex-wrap:wrap;align-items:flex-end;display:flex}.builder-input-sm{width:80px;color:var(--color-text);background:#fff;border:2px solid #d8e2f0;border-radius:10px;padding:.4rem .5rem;font-family:inherit;font-size:.88rem;font-weight:700}.builder-input-sm:focus{border-color:var(--color-focus);outline:none}.builder-input-full{width:100%;color:var(--color-text);background:#fff;border:2px solid #d8e2f0;border-radius:12px;padding:.5rem .7rem;font-family:inherit;font-size:.92rem;font-weight:600}.builder-input-full:focus{border-color:var(--color-focus);outline:none}.builder-overlay-toggles{gap:var(--space-4);flex-wrap:wrap;display:flex}.builder-toggle-label{cursor:pointer;color:var(--color-text-muted);align-items:center;gap:.4rem;font-size:.86rem;font-weight:700;display:flex}.builder-toggle-label input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--color-primary)}.builder-preview-fullscreen{margin-top:var(--space-4);gap:var(--space-3);display:grid}.builder-blocker-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0b1f5299;place-items:center;display:grid;position:fixed;inset:0}.builder-blocker-dialog{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-5);width:90%;max-width:380px;box-shadow:var(--shadow-high);gap:var(--space-3);flex-direction:column;display:flex}.builder-blocker-dialog h3{color:var(--color-text);margin:0;font-size:1.15rem}.builder-blocker-dialog p{color:var(--color-text-muted);margin:0;font-size:.95rem}.builder-blocker-actions{gap:var(--space-2);justify-content:flex-end;display:flex}.builder-preview-nav{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.builder-preview-dot{background:var(--color-border);border:2px solid var(--color-border-strong);cursor:pointer;border-radius:999px;width:12px;height:12px;transition:transform .12s,background-color .12s}.builder-preview-dot.active{background:var(--color-primary);border-color:var(--color-primary);transform:scale(1.3)}@media (prefers-contrast:more){:root{--color-text:#000;--color-text-muted:#294372;--color-border:#7e93b6}.card,.input,.admin-table-wrap,.step-item,.question-option,.btn{border-color:#4c6796}}@media (width<=1080px){.constellation-inspector-shell{grid-template-rows:auto;justify-self:end;width:min(300px,100%);position:static;top:auto;bottom:auto;right:auto}.constellation-inspector{min-height:auto}}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}.reward-tier-groups{gap:var(--space-4);flex-direction:column;display:flex}.reward-tier-label{letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-2);padding:0 var(--space-2);align-items:center;gap:var(--space-2);font-size:.72rem;font-weight:800;display:flex}.reward-tier-label:after{content:"";opacity:.2;background:currentColor;flex:1;height:1px}.reward-trophy-list{border:var(--list-view-border);border-radius:var(--radius-md);flex-direction:column;gap:0;display:flex;overflow:hidden}.reward-trophy-card{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border-bottom:var(--list-view-border);transition:background .12s;display:flex;position:relative}.reward-trophy-card:last-child{border-bottom:none}.reward-trophy-card:before{content:"";background:var(--reward-tier-color,var(--color-primary));border-radius:0;width:3px;position:absolute;top:0;bottom:0;left:0}.reward-trophy-card:hover{background:var(--color-bg-soft)}.reward-trophy-card-locked{opacity:.55}.reward-tier-count-badge{margin-left:var(--space-2);color:var(--color-text-muted);font-size:.78rem;font-weight:500}.reward-trophy-card-left{align-items:center;gap:var(--space-3);flex:1;min-width:0;display:flex}.reward-trophy-icon{text-align:center;flex-shrink:0;width:2.4rem;font-size:1.8rem;line-height:1}.reward-trophy-info{flex-direction:column;gap:2px;min-width:0;display:flex}.reward-trophy-name{color:var(--color-text);align-items:center;gap:var(--space-2);font-size:.95rem;font-weight:700;display:flex}.reward-inactive-badge{background:var(--color-orange);color:#fff;letter-spacing:.04em;text-transform:uppercase;border-radius:99px;padding:2px 7px;font-size:.65rem;font-weight:700}.reward-trophy-desc{color:var(--color-text-muted);font-size:.82rem;font-weight:500}.reward-trophy-conditions{margin-top:var(--space-1);flex-wrap:wrap;align-items:center;gap:4px;display:flex}.reward-trophy-conditions span{color:#3a5fa0;background:#eef3fb;border:1px solid #d0dff5;border-radius:99px;padding:2px 8px;font-size:.72rem;font-weight:600}.reward-logic-sep{background:var(--color-primary);color:#fff;border:none;border-radius:99px;padding:2px 6px;font-size:.65rem;font-weight:800}.reward-form-row{gap:var(--spacing-md);align-items:flex-end;display:flex}.reward-toggle-row{margin:var(--spacing-sm) 0}.reward-toggle-label{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.reward-conditions-section{border-top:1px solid var(--color-border,#ffffff1a);padding-top:var(--spacing-md);margin-top:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;display:flex}.reward-conditions-header{justify-content:space-between;align-items:center;display:flex}.reward-conditions-title{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:600}.reward-conditions-empty{font-size:var(--font-size-sm);color:var(--color-text-muted,var(--color-text-secondary));padding:var(--spacing-sm) 0;font-style:italic}.reward-condition-row{align-items:flex-end;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface-raised,#ffffff0a);border-radius:var(--radius-md);border:1px solid var(--color-border,#ffffff14);flex-wrap:wrap;display:flex}.trophy-filter-bar{gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);max-width:var(--content-max-width,1200px);margin:0 auto;display:flex}.trophy-filter-btn{border:1px solid var(--color-border,#ffffff26);border-radius:var(--radius-lg,20px);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;padding:6px 16px;transition:all .15s}.trophy-filter-btn:hover{border-color:var(--color-primary);color:var(--color-text-primary)}.trophy-filter-btn-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.trophies-view{gap:var(--spacing-xl);flex-direction:column;display:flex}.trophies-empty{text-align:center;padding:var(--spacing-2xl) 0;color:var(--color-text-secondary)}.trophies-empty-icon{margin-bottom:var(--spacing-md);font-size:3rem}.trophies-empty-hint{font-size:var(--font-size-sm);opacity:.7}.trophies-tier-groups{gap:var(--spacing-2xl);flex-direction:column;display:flex}.trophies-tier-header{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border,#ffffff1a);display:flex}.trophies-tier-icon{object-fit:contain;width:28px;height:28px}.trophies-tier-name{font-size:var(--font-size-base);color:var(--color-text-primary);letter-spacing:.05em;font-weight:700}.trophies-tier-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-left:auto}.trophies-tier-platinum .trophies-tier-name{color:#e5e4e2}.trophies-tier-gold .trophies-tier-name{color:gold}.trophies-tier-silver .trophies-tier-name{color:#a8a9ad}.trophies-tier-bronze .trophies-tier-name{color:#cd7f32}.trophies-list{flex-direction:column;gap:2px;display:flex}.trophy-row{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);transition:background .15s;display:flex}.trophy-row-earned{background:var(--color-surface-raised,#ffffff0a)}.trophy-row-locked{opacity:.45;background:0 0}.trophy-row:hover{background:var(--color-surface-hover,#ffffff12);opacity:1}.trophy-emoji{text-align:center;flex-shrink:0;width:2.5rem;font-size:2rem;line-height:1}.trophy-emoji-locked{filter:grayscale()}.trophy-row-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.trophy-row-name{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:600}.trophy-row-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.trophy-row-condition{font-size:var(--font-size-xs);color:var(--color-text-muted,var(--color-text-secondary));opacity:.8;font-style:italic}.trophy-row-status{text-align:right;flex-shrink:0}.trophy-row-earned-date{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.trophy-check{color:var(--color-success,#22c55e);font-size:1.1rem;font-weight:700}.trophy-date{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.trophy-locked-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);opacity:.6}.app{color:#0b1f52;background:#141b28;min-height:100vh;position:relative;overflow:clip auto}.app:before{content:"";pointer-events:none;opacity:1;z-index:0;background-image:url(/happy-planets-bg.svg);background-position:0 0;background-repeat:repeat;background-size:560px;position:fixed;inset:0}.app[data-page=content]:before{opacity:1}.app:after{content:none}.app>*{z-index:1;position:relative}.loading-screen{color:#0b1f52;place-items:center;min-height:100vh;font-size:1.1rem;font-weight:700;display:grid}.form-group{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.form-group label{color:#5f7397;font-weight:700}.input,textarea.input{width:100%}.loading{color:#5f7397;padding:1rem}
