@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;700&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#app{text-align:center;box-sizing:border-box;border-inline:none;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.nonogram-canvas-container[data-v-dc1b957a]{background-color:#0000;border-radius:12px;width:100%;min-width:0;height:100%;min-height:0;padding:0;display:block;position:relative}.canvas-frame[data-v-dc1b957a]{background-color:#0f172a;border:1px solid #ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}canvas[data-v-dc1b957a]{cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:none;display:block;position:absolute}.draw-mode-hud[data-v-dc1b957a]{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;background:#0f172ad9;border:1px solid #ffffff14;border-radius:9999px;align-items:center;width:80px;height:36px;padding:4px;display:flex;position:absolute;bottom:20px;left:20px;box-shadow:0 4px 12px #0006}.draw-mode-slider[data-v-dc1b957a]{z-index:1;box-sizing:border-box;background:#ffffff14;border:1px solid #ffffff1f;border-radius:9999px;width:36px;height:28px;transition:transform .25s cubic-bezier(.25,.8,.25,1);position:absolute;top:4px;left:4px}.draw-mode-slider.x[data-v-dc1b957a]{transform:translate(36px)}.draw-mode-btn[data-v-dc1b957a]{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;z-index:2;box-sizing:border-box;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;width:36px;height:28px;margin:0;padding:0;transition:all .2s;display:flex}.mode-icon[data-v-dc1b957a]{justify-content:center;align-items:center;transition:transform .2s;display:flex}.draw-mode-btn:hover .mode-icon[data-v-dc1b957a]{transform:scale(1.15)}.fill-icon[data-v-dc1b957a]{background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);border-radius:3px;width:14px;height:14px;display:block;box-shadow:0 1px 3px #38bdf84d}.x-icon[data-v-dc1b957a]{stroke:#f43f5e;width:14px;height:14px;display:block}.zoom-hud[data-v-dc1b957a]{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#0f172ad9;border:1px solid #ffffff14;border-radius:9999px;align-items:center;gap:.5rem;padding:.35rem .6rem;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0006}.zoom-btn[data-v-dc1b957a]{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.1rem;font-weight:700;transition:all .15s;display:flex}.zoom-btn[data-v-dc1b957a]:hover{color:#f8fafc;background-color:#ffffff14}.zoom-level[data-v-dc1b957a]{color:#38bdf8;text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;min-width:42px;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:700;transition:color .15s}.zoom-level[data-v-dc1b957a]:hover{color:#818cf8}@media (width<=768px){.draw-mode-hud[data-v-dc1b957a]{bottom:12px;left:12px}.zoom-hud[data-v-dc1b957a]{gap:.35rem;padding:.25rem .5rem;bottom:12px;left:50%;transform:translate(-50%)}.zoom-btn[data-v-dc1b957a]{width:20px;height:20px;font-size:.95rem}.zoom-level[data-v-dc1b957a]{min-width:36px;font-size:.72rem}}body{color:#f8fafc;touch-action:pan-x pan-y;background-color:#0f172a;justify-content:center;align-items:center;height:100dvh;margin:0;padding:0;font-family:Outfit,sans-serif;display:flex;overflow:hidden}.app-container{box-sizing:border-box;touch-action:pan-x pan-y;flex-direction:column;width:100%;max-width:1200px;height:100dvh;padding:1rem 1.5rem;display:flex;overflow:hidden}.app-header{border-bottom:1px solid #1e293b;flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.logo-wrapper{align-items:center;gap:.75rem;display:flex}.logo-icon{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);gap:2px;width:2.2rem;height:2.2rem;animation:4s linear infinite spin;display:grid;box-shadow:0 0 15px #38bdf840}.logo-cell{box-sizing:border-box;background-color:#1e293b;border:1px solid #ffffff26;border-radius:2px}.logo-cell.filled{background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);border-color:#6366f180;box-shadow:0 0 5px #38bdf866}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.logo-title-wrapper{flex-direction:column;justify-content:center;gap:2px;margin-top:-3px;display:flex}.app-title{background:linear-gradient(135deg,#38bdf8 0%,#818cf8 50%,#c084fc 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;margin:0 0 -4px;padding-bottom:4px;font-size:2.1rem;font-weight:800;line-height:1.2}.app-subtitle{text-transform:uppercase;letter-spacing:.12em;color:#94a3b8;text-align:justify;text-align-last:justify;margin:0;font-size:.52rem;font-weight:700;line-height:1.1}.app-nav button{color:#94a3b8;cursor:pointer;background-color:#0000;border:1px solid #0000;border-radius:8px;align-items:center;gap:.35rem;padding:.5rem 1rem;font-family:Outfit,sans-serif;font-weight:600;transition:all .2s;display:inline-flex}.header-icon{stroke:currentColor;flex-shrink:0;width:1.1rem;height:1.1rem;transition:transform .25s cubic-bezier(.2,.8,.2,1)}.app-nav button:hover .header-icon,.leaderboard-toggle-btn:hover .header-icon{transform:scale(1.1)}.app-nav button.active{color:#38bdf8;background-color:#38bdf81a;border-color:#38bdf833}.app-nav button:hover:not(.active){color:#f8fafc;background-color:#ffffff0d}.leaderboard-toggle-btn,.help-toggle-btn{color:#f8fafc;cursor:pointer;background-color:#334155;border:1px solid #475569;border-radius:8px;align-items:center;gap:.25rem;padding:.5rem .75rem;font-family:Outfit,sans-serif;font-weight:600;transition:all .2s;display:flex}.leaderboard-toggle-btn:hover,.help-toggle-btn:hover{color:#fff;background-color:#475569;border-color:#64748b}.leaderboard-toggle-btn.active{color:#fbbf24;background:linear-gradient(135deg,#fbbf2426,#f59e0b26);border-color:#fbbf24;box-shadow:0 0 10px #fbbf2433}.help-toggle-btn.active{color:#38bdf8;background:#38bdf826;border-color:#38bdf8;box-shadow:0 0 10px #38bdf833}.toggle-list-btn{cursor:pointer;border:none;border-radius:10px;width:100%;padding:.6rem;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:700;transition:all .2s}.toggle-list-btn.expand-btn{color:#38bdf8;background-color:#38bdf81a;border:1px solid #38bdf84d}.toggle-list-btn.expand-btn:hover{background-color:#38bdf833;border-color:#38bdf8;box-shadow:0 0 12px #38bdf826}.toggle-list-btn.collapse-btn{color:#f8fafc;background-color:#334155;border:1px solid #475569}.toggle-list-btn.collapse-btn:hover{background-color:#475569;border-color:#64748b}.app-layout{flex-grow:1;grid-template-columns:1fr;align-items:stretch;gap:1.25rem;width:100%;min-height:0;transition:grid-template-columns .3s cubic-bezier(.4,0,.2,1);display:grid}.app-layout.mypage-layout{grid-template-columns:280px 1fr}@media (width<=1024px){.app-layout.mypage-layout{grid-template-columns:240px 1fr}}@media (width<=768px){.app-header{gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem}.app-title{font-size:1.4rem}.app-subtitle{display:none}.logo-icon{border-width:3px;width:1.6rem;height:1.6rem}.app-container{padding:.5rem}.app-nav button,.leaderboard-toggle-btn,.help-toggle-btn{padding:.35rem .6rem;font-size:.78rem}.app-layout{gap:.75rem;grid-template-columns:1fr!important}.app-layout.mypage-layout{height:100%;overflow-y:auto}.app-sidebar-left{flex-shrink:0;height:auto}.mypage-dashboard{width:100%;max-width:540px;padding:0}.modal-content{width:88%;padding:1.25rem 1rem}.mypage-user-profile{gap:1rem;margin-bottom:1rem;padding-bottom:1rem}.profile-avatar{width:3.5rem;height:3.5rem;font-size:2.2rem}.profile-username{margin-bottom:.25rem;font-size:1.25rem}.mypage-dashboard .stage-card-list{max-height:calc(100dvh - 250px)!important}.active-stage-badge{width:85vw;max-width:340px;padding:.5rem 2.5rem}.puzzle-selector-dropdown{width:85vw;max-width:340px}}@media (width<=600px){.app-nav button .btn-text,.leaderboard-toggle-btn .btn-text,.help-toggle-btn .btn-text{display:none}.app-nav button,.leaderboard-toggle-btn,.help-toggle-btn{justify-content:center;align-items:center;width:36px;height:36px;padding:.5rem;display:inline-flex}}.puzzle-selector-floating-container{z-index:100;justify-content:center;display:flex;position:absolute;top:25px;left:50%;transform:translate(-50%)}.active-stage-badge{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;white-space:nowrap;box-sizing:border-box;background:#1e293bb3;border:1px solid #ffffff14;border-radius:9999px;justify-content:center;align-items:center;gap:.6rem;min-width:240px;max-width:90vw;padding:.5rem 2.5rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;box-shadow:0 4px 20px -5px #0000004d}.active-stage-badge:hover{background:#1e293be6;border-color:#38bdf866;box-shadow:0 6px 24px -5px #38bdf833}.active-stage-badge-name{color:#f8fafc;white-space:nowrap;text-overflow:ellipsis;text-align:center;width:100%;font-size:.95rem;font-weight:700;overflow:hidden}.active-stage-badge-size{color:#64748b;background-color:#ffffff0d;border-radius:6px;padding:.1rem .4rem;font-size:.8rem}.active-stage-badge-tag{text-transform:uppercase;border-radius:4px;padding:.1rem .35rem;font-size:.7rem;font-weight:800}.active-stage-arrow{color:#94a3b8;font-size:.75rem;transition:transform .2s;position:absolute;right:1.25rem}.active-stage-arrow.open{transform:rotate(180deg)}.puzzle-selector-dropdown{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0f172af2;border:1px solid #ffffff1a;border-radius:16px;flex-direction:column;gap:.75rem;width:340px;max-height:350px;padding:1rem;display:flex;position:absolute;top:100%;left:50%;transform:translate(-50%)translateY(8px);box-shadow:0 20px 40px -15px #00000080}.play-size-filter-bar-floating{z-index:100;flex-direction:column;align-items:flex-end;width:90px;display:flex;position:absolute;bottom:20px;right:20px}.active-size-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;-webkit-user-select:none;user-select:none;color:#38bdf8;box-sizing:border-box;background:#0f172ad9;border:1px solid #ffffff14;border-radius:9999px;justify-content:center;align-items:center;gap:.4rem;width:100%;padding:.5rem .75rem;font-family:Outfit,sans-serif;font-size:.8rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 12px #0006}.active-size-badge:hover{color:#fff;background:#1e293be6;border-color:#38bdf84d}.active-size-arrow{color:#94a3b8;font-size:.65rem;line-height:1;transition:transform .25s;display:inline-block}.active-size-arrow.open{color:#38bdf8;transform:rotate(180deg)}.play-size-filter-dropdown{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:101;box-sizing:border-box;background:#0f172af2;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;gap:.25rem;width:100%;padding:.35rem;display:flex;position:absolute;bottom:calc(100% + 8px);right:0;box-shadow:0 10px 25px -5px #00000080}.play-size-filter-dropdown-item{color:#94a3b8;cursor:pointer;text-align:center;box-sizing:border-box;border-radius:8px;width:100%;padding:.4rem .5rem;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:600;transition:all .15s}.play-size-filter-dropdown-item:hover{color:#f8fafc;background-color:#ffffff0d}.play-size-filter-dropdown-item.active{color:#38bdf8;background-color:#38bdf826;border-color:#38bdf84d}.slide-up-enter-active,.slide-up-leave-active{transition:all .25s cubic-bezier(.25,1,.5,1)}.slide-up-enter-from,.slide-up-leave-to{opacity:0;transform:translateY(10px)}@media (width<=768px){.play-size-filter-bar-floating{width:80px;bottom:12px;right:12px}.active-size-badge{padding:.4rem .6rem;font-size:.72rem}}.leaderboard-popup-overlay{z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a99;justify-content:center;align-items:center;animation:.25s ease-out fade-in;display:flex;position:fixed;inset:0}.leaderboard-popup-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1e293bd9;border:1px solid #ffffff1a;border-radius:20px;flex-direction:column;width:340px;max-height:80vh;padding:1.5rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) slide-up-anim;display:flex;box-shadow:0 25px 50px -12px #0000008c}.leaderboard-popup-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.leaderboard-popup-title{color:#fbbf24;margin:0;font-size:1.2rem;font-weight:700}.leaderboard-popup-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:1.5rem;transition:color .15s}.leaderboard-popup-close:hover{color:#f8fafc}.slide-down-enter-active,.slide-down-leave-active{transition:all .25s cubic-bezier(.4,0,.2,1)}.slide-down-enter-from,.slide-down-leave-to{opacity:0;transform:translate(-50%)translateY(0)scale(.95)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up-anim{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-sidebar-left{flex-direction:column;min-height:0;display:flex}.sidebar-card{box-sizing:border-box;background-color:#1e293b;border:1px solid #334155;border-radius:16px;flex-direction:column;height:100%;min-height:0;padding:1.25rem;display:flex;box-shadow:0 10px 25px -5px #0000004d}.sidebar-card-title{color:#38bdf8;border-bottom:1px solid #334155;flex-shrink:0;margin-top:0;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.15rem;font-weight:700}.category-tabs{flex-shrink:0;gap:.5rem;margin-bottom:.75rem;display:flex}.category-tab-btn{color:#94a3b8;cursor:pointer;background-color:#0f172a;border:1px solid #334155;border-radius:6px;flex-grow:1;padding:.4rem;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:600;transition:all .2s}.category-tab-btn.active{color:#0f172a;background-color:#38bdf8;border-color:#38bdf8}.stage-card-list,.leaderboard-scrollable{flex-direction:column;flex-grow:1;gap:.5rem;min-height:0;padding-right:4px;display:flex;overflow-y:auto}.stage-card-list::-webkit-scrollbar{width:6px}.leaderboard-scrollable::-webkit-scrollbar{width:6px}.stage-card-list::-webkit-scrollbar-track{background:0 0}.leaderboard-scrollable::-webkit-scrollbar-track{background:0 0}.stage-card-list::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.leaderboard-scrollable::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.stage-card-list::-webkit-scrollbar-thumb:hover{background:#475569}.leaderboard-scrollable::-webkit-scrollbar-thumb:hover{background:#475569}.stage-item-card{cursor:pointer;background-color:#0f172a;border:1px solid #1e293b;border-radius:10px;justify-content:space-between;align-items:center;padding:.75rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.stage-item-card:hover{border-color:#38bdf8;transform:translateY(-1px);box-shadow:0 4px 12px #38bdf826}.stage-item-card.active{background:linear-gradient(135deg,#38bdf826,#818cf826);border-color:#38bdf8;box-shadow:0 0 10px #38bdf840}.stage-card-info{flex-direction:column;gap:.15rem;display:flex}.stage-card-name{color:#f8fafc;font-size:.9rem;font-weight:700}.stage-card-size{color:#64748b;font-size:.75rem}.stage-card-tag{border-radius:4px;padding:.15rem .4rem;font-size:.7rem;font-weight:700}.normal-tag{color:#818cf8;background-color:#6366f126}.ai-tag{color:#f472b6;background-color:#ec489926}.app-main{flex-direction:column;flex-grow:1;justify-content:center;align-items:center;min-height:0;display:flex}.canvas-wrapper-container{flex-grow:1;justify-content:center;align-items:center;width:100%;min-width:0;min-height:0;display:flex;position:relative}.canvas-wrapper{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;width:100%;min-width:0;height:100%;min-height:0;padding:0;display:flex}.loading-state{color:#94a3b8;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;width:100%;height:100%;min-height:200px;font-size:1.1rem;display:flex}.spinner-logo{filter:drop-shadow(0 0 8px #38bdf866);grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);gap:3px;width:3.5rem;height:3.5rem;animation:1.2s cubic-bezier(.4,0,.2,1) infinite spin;display:grid}.spinner-cell{box-sizing:border-box;background-color:#1e293b;border:1.5px solid #fff3;border-radius:4px}.spinner-cell.filled{background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);border-color:#6366f199;box-shadow:inset 0 0 4px #fff3}.loading-text{letter-spacing:.05em;color:#e2e8f0;font-weight:500;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.error-state{color:#f43f5e;text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f43f5e0d;border:1px solid #f43f5e26;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;max-width:400px;margin:auto;padding:2rem;display:flex}.error-icon{font-size:3rem;animation:2s infinite bounce}.error-text{color:#fda4af;margin:0;font-size:1rem;line-height:1.5}.retry-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f43f5e 0%,#e11d48 100%);border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.6rem 1.5rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 12px #f43f5e4d}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f43f5e66}.retry-btn:active{transform:translateY(0)}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.confetti-canvas{pointer-events:none;z-index:9999;width:100vw;height:100vh;position:fixed;top:0;left:0}.celebration-overlay-container{z-index:10000;justify-content:center;align-items:center;margin-top:.75rem;display:flex}.top-progress-bar-container{z-index:11000;background:#ffffff08;width:100vw;height:5px;position:fixed;top:0;left:0}.top-progress-bar{background:linear-gradient(90deg,#38bdf8 0%,#818cf8 50%,#c084fc 100%);width:0%;height:100%;animation:3s linear forwards progress-grow}.all-cleared-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);text-align:center;background:#1e293bd9;border:1px solid #fbbf244d;border-radius:24px;padding:1.25rem 2.5rem;animation:.35s cubic-bezier(.175,.885,.32,1.275) pop-in;box-shadow:0 20px 40px -10px #fbbf2433}.trophy-icon{font-size:3rem;animation:1.5s ease-in-out infinite alternate trophy-bounce}.star-burst{opacity:.9;letter-spacing:.25rem;margin-top:.25rem;font-size:1.1rem;animation:2s ease-in-out infinite alternate pulse-glow}@keyframes countdown-shrink{0%{width:100%}to{width:0%}}@keyframes progress-grow{0%{width:0%}to{width:100%}}@keyframes spin-pulse{0%{transform:scale(1)rotate(0)}50%{transform:scale(1.2)rotate(180deg)}to{transform:scale(1)rotate(360deg)}}@keyframes arrow-bounce{0%{transform:translate(0)}to{transform:translate(4px)}}@keyframes trophy-bounce{0%{transform:translateY(0)scale(1)}to{transform:translateY(-8px)scale(1.05)}}@keyframes pulse-glow{0%{opacity:.6;text-shadow:0 0 4px #fbbf2433}to{opacity:1;text-shadow:0 0 12px #fbbf2499}}.leaderboard-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.leaderboard-item{background-color:#0f172a;border:1px solid #1e293b;border-radius:8px;align-items:center;gap:.5rem;padding:.4rem .6rem;font-size:.85rem;font-weight:600;display:flex}.leaderboard-item .rank{color:#64748b;text-align:center;width:16px}.leaderboard-item:first-child .rank{color:#fbbf24}.leaderboard-item:nth-child(2) .rank{color:#94a3b8}.leaderboard-item:nth-child(3) .rank{color:#b45309}.leaderboard-item .username{color:#f8fafc;text-overflow:ellipsis;white-space:nowrap;flex-grow:1;overflow:hidden}.leaderboard-item .level{color:#38bdf8;background-color:#38bdf81a;border-radius:4px;padding:.05rem .3rem;font-size:.75rem}.leaderboard-item .xp{color:#818cf8;font-size:.75rem}.mypage-dashboard{box-sizing:border-box;flex-direction:column;gap:1.25rem;width:100%;max-width:600px;display:flex}.mypage-user-profile{box-sizing:border-box;background-color:#1e293b;border:1px solid #334155;border-radius:16px;align-items:center;gap:1.5rem;width:100%;padding:1.5rem;display:flex;box-shadow:0 10px 25px -5px #0000004d}.profile-avatar{background-color:#0f172a;border:2px solid #38bdf8;border-radius:50%;justify-content:center;align-items:center;width:4.5rem;height:4.5rem;font-size:3rem;display:flex}.profile-username{color:#f8fafc;margin:0 0 .5rem;font-size:1.5rem}.profile-stats{gap:.75rem;display:flex}.profile-lv{color:#38bdf8;background-color:#38bdf826;border-radius:4px;padding:.15rem .5rem;font-size:.85rem;font-weight:700}.profile-xp{color:#818cf8;align-items:center;font-size:.85rem;font-weight:600;display:flex}.history-item{background-color:#1e293b;border:1px solid #334155;border-radius:10px;padding:.8rem 1rem;transition:all .2s}.history-item:hover{border-color:#38bdf8;transform:translateY(-1px)}.key-indicator{border-radius:4px;margin-right:.5rem;padding:.25rem .5rem;font-size:.85rem;font-weight:600}.left-click{color:#0f172a;background-color:#38bdf8}.right-click{color:#fff;background-color:#f43f5e}.modal-content{text-align:center;box-sizing:border-box;background-color:#1e293b;border:1px solid #334155;border-radius:16px;width:90%;padding:2rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) pop-in;box-shadow:0 25px 50px -12px #0000008c}@keyframes pop-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.home-dashboard{box-sizing:border-box;flex-direction:column;gap:1.5rem;width:100%;max-width:800px;max-height:calc(100dvh - 120px);padding-right:.5rem;display:flex;overflow-y:auto}.home-dashboard::-webkit-scrollbar{width:6px}.home-dashboard::-webkit-scrollbar-track{background:0 0}.home-dashboard::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}.glass-card{-webkit-backdrop-filter:blur(12px);background:#1e293b73;border:1px solid #ffffff0f;border-radius:16px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 30px -10px #00000080}.hero-section{text-align:center;padding:2rem;position:relative;overflow:hidden}.hero-section:before{content:"";pointer-events:none;background:radial-gradient(circle,#38bdf80d 0%,#0000 70%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.hero-logo-container{justify-content:center;margin-bottom:1rem;display:flex}.hero-logo-icon{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);gap:4px;width:3.5rem;height:3.5rem;animation:6s linear infinite spin;display:grid;box-shadow:0 0 25px #38bdf84d}.hero-title{background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .75rem;font-size:1.8rem;font-weight:800}.hero-subtitle{color:#94a3b8;max-width:600px;margin:0 auto 1.5rem;font-size:.95rem;line-height:1.6}.cta-play-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);border:none;border-radius:9999px;align-items:center;gap:.5rem;padding:.75rem 2rem;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 20px #6366f166}.cta-play-btn:hover{transform:translateY(-2px)scale(1.03);box-shadow:0 6px 24px #6366f199}.cta-play-btn:active{transform:translateY(0)scale(1)}.section-title{color:#f1f5f9;letter-spacing:.05em;margin:0 0 .75rem;font-size:1.1rem;font-weight:700}.telemetry-section{flex-direction:column;display:flex}.telemetry-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.telemetry-card{align-items:center;gap:.75rem;padding:1rem;display:flex}.telemetry-card:hover{background:#1e293b99;border-color:#38bdf84d;transform:translateY(-2px)}.telemetry-icon{background:#ffffff0a;border-radius:12px;justify-content:center;align-items:center;padding:.5rem;font-size:1.5rem;display:flex}.telemetry-info{flex-direction:column;gap:.2rem;display:flex}.telemetry-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.telemetry-value{color:#f8fafc;font-size:1.1rem;font-weight:700}.timeline-section{flex-direction:column;display:flex}.timeline-container{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex;position:relative}.timeline-container:before{content:"";background:#ffffff0f;width:2px;position:absolute;top:2rem;bottom:2rem;left:2.25rem}.timeline-item{z-index:1;gap:1.5rem;display:flex;position:relative}.timeline-badge{color:#38bdf8;background:#38bdf826;border:1px solid #38bdf84d;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:4rem;height:1.75rem;font-size:.78rem;font-weight:700;display:flex;box-shadow:0 0 10px #38bdf826}.timeline-content{flex-direction:column;gap:.25rem;display:flex}.timeline-date{color:#64748b;font-size:.75rem;font-weight:600}.timeline-title{color:#e2e8f0;margin:0;font-size:.95rem;font-weight:700}.timeline-desc{color:#94a3b8;margin:0;font-size:.85rem;line-height:1.5}@media (width<=768px){.telemetry-grid{grid-template-columns:repeat(2,1fr)}.timeline-container:before{left:2rem}}@media (width<=480px){.telemetry-grid{grid-template-columns:1fr}.hero-section{padding:1.5rem}.hero-title{font-size:1.5rem}}.app-container.home-mode{background-color:#0a0f1d;max-width:100%;height:auto;min-height:100dvh;padding:0;display:block;overflow:visible}.home-mode .app-layout{gap:0;height:auto;min-height:100dvh;display:block}.home-mode .app-main{width:100%;height:auto;min-height:100dvh;display:block}.home-mode .home-dashboard{gap:0;max-width:100%;max-height:none;padding:0;overflow:visible}.landing-nav{z-index:1000;-webkit-backdrop-filter:blur(12px);box-sizing:border-box;background:#000000b3;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:sticky;top:0}.landing-logo{cursor:pointer;align-items:center;gap:.75rem;display:flex}.landing-logo-icon{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);gap:2px;width:1.5rem;height:1.5rem;display:grid}.landing-logo-text{color:#fff;letter-spacing:-.03em;font-size:1.25rem;font-weight:700}.landing-nav-links{align-items:center;gap:1.5rem;display:flex}.landing-nav-link{color:#a1a1aa;cursor:pointer;background:0 0;border:none;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:500;transition:color .2s}.landing-nav-link:hover{color:#fff}.landing-play-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);border:none;border-radius:6px;padding:.4rem 1rem;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:600;transition:all .2s;box-shadow:0 2px 10px #38bdf840}.landing-play-btn:hover{background:linear-gradient(135deg,#818cf8 0%,#c084fc 100%);box-shadow:0 4px 15px #818cf866}.home-mode .hero-section{text-align:center;background:radial-gradient(circle,#38bdf814 0%,#0000 60%);border-bottom:1px solid #ffffff14;flex-direction:column;align-items:center;padding:8rem 2rem 6rem;display:flex}.hero-logo-icon-large{filter:drop-shadow(0 0 25px #38bdf84d);grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr);gap:6px;width:4.5rem;height:4.5rem;margin-bottom:2rem;animation:8s linear infinite spin;display:grid}.home-mode .hero-title{letter-spacing:-.5px;background:linear-gradient(135deg,#38bdf8 0%,#818cf8 50%,#c084fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;padding:4px 10px;font-size:4rem;font-weight:800;line-height:1.25;display:inline-block}.home-mode .hero-subtitle{color:#a1a1aa;max-width:640px;margin:0 auto 2.5rem;font-size:1.2rem;line-height:1.6}.hero-actions{justify-content:center;gap:1rem;display:flex}.cta-play-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);border:none;border-radius:9999px;padding:.8rem 2.2rem;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;transition:all .25s;box-shadow:0 4px 20px #38bdf859}.cta-play-btn:hover{color:#fff;background:linear-gradient(135deg,#818cf8 0%,#c084fc 100%);transform:translateY(-2px);box-shadow:0 6px 24px #818cf880}.cta-status-btn{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:9999px;padding:.8rem 2.2rem;font-family:Outfit,sans-serif;font-size:1rem;font-weight:600;transition:all .25s}.cta-status-btn:hover{color:#38bdf8;background:#38bdf80d;border-color:#38bdf8;transform:translateY(-2px)}.home-mode .telemetry-section{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:6rem 2rem}.home-mode .section-title{letter-spacing:-.04em;color:#fff;text-align:left;margin-bottom:2rem;font-size:1.8rem;font-weight:800}.home-mode .telemetry-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}.home-mode .telemetry-card{-webkit-backdrop-filter:blur(12px);background:#1e293b73;border:1px solid #ffffff0f;border-radius:12px;padding:1.75rem;transition:all .3s;box-shadow:0 10px 30px -10px #00000080}.home-mode .telemetry-card:hover{background:#1e293b99;border-color:#38bdf84d;transform:translateY(-4px);box-shadow:0 12px 30px -10px #38bdf826}.telemetry-svg{flex-shrink:0;width:24px;height:24px}.home-mode .telemetry-info{gap:.35rem}.home-mode .telemetry-label{color:#71717a;letter-spacing:.05em;font-size:.75rem;font-weight:600}.home-mode .telemetry-value{color:#fff;letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.home-mode .timeline-section{box-sizing:border-box;width:100%;max-width:800px;margin:0 auto;padding:0 2rem 8rem}.home-mode .timeline-container{-webkit-backdrop-filter:blur(12px);background:#1e293b73;border:1px solid #ffffff0f;border-radius:16px;padding:2.5rem;box-shadow:0 10px 30px -10px #00000080}.home-mode .timeline-badge{color:#fff;background:#ffffff0f;border:1px solid #ffffff1f;font-weight:600}.home-mode .timeline-title{color:#fff;font-size:1.1rem;font-weight:600}.home-mode .timeline-desc{color:#a1a1aa}@media (width<=968px){.home-mode .hero-title{font-size:3rem}.home-mode .telemetry-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.home-mode .hero-title{font-size:2.25rem}.home-mode .telemetry-grid{grid-template-columns:1fr}.hero-actions{flex-direction:column;width:100%;max-width:280px}.cta-play-btn,.cta-status-btn{box-sizing:border-box;text-align:center;width:100%}.landing-nav{padding:0 1rem}.landing-nav-links{gap:1rem}}
