@import "https://fonts.googleapis.com/css2?family=Inter:wght@500;700;800&family=Jua&family=Noto+Sans+KR:wght@400;500;700&display=swap";:root{--bg-main:#f6f7fb;--bg-gradient:radial-gradient(circle at 20% 10%, #ff6b4a1f, transparent 28%), radial-gradient(circle at 82% 0%, #2aa7a724, transparent 30%), linear-gradient(180deg, #fbfcff 0%, #eef2f7 100%);--surface:#fff;--surface-muted:#f8f5ef;--panel-bg:#ffffffe6;--panel-border:#e1e7ef;--panel-border-hover:#cbd6e4;--line-soft:#e7edf5;--line-strong:#ccd7e6;--text-primary:#172033;--text-secondary:#647086;--text-muted:#9aa6b7;--accent-coral:#ff6b4a;--accent-teal:#2aa7a7;--accent-violet:#6d5dfc;--accent-amber:#f4b740;--accent-blue:#2f7df6;--pastel-pink:var(--accent-coral);--pastel-pink-glow:#ff6b4a47;--pastel-mint:var(--accent-teal);--pastel-mint-glow:#2aa7a742;--pastel-yellow:#f9df91;--pastel-yellow-glow:#f4b74047;--pastel-lavender:var(--accent-violet);--pastel-lavender-glow:#6d5dfc3d;--pastel-blue:var(--accent-blue);--pastel-blue-glow:#2f7df63d;--pastel-peach:#ff9b73;--pastel-peach-glow:#ff9b7342;--pastel-lemon:var(--accent-amber);--pastel-lemon-glow:#f4b7404d;--pastel-danger:#e54b4b;--pastel-danger-glow:#e54b4b42;--font-sans:"Inter", "Noto Sans KR", sans-serif;--transition-smooth:all .24s ease;--transition-fast:all .2s ease-in-out}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:var(--accent-teal) #fff;margin:0;padding:0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-main);border-radius:10px}::-webkit-scrollbar-thumb{background:var(--accent-teal);border:2px solid var(--bg-main);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--accent-violet)}body{font-family:var(--font-sans);background:var(--bg-main);background-image:var(--bg-gradient);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5;overflow-x:hidden}button{line-height:1}#root{flex-direction:column;min-height:100vh;display:flex}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--panel-border);transition:var(--transition-smooth);border-radius:16px;box-shadow:0 18px 48px #17203314}.glass-panel:hover{border-color:var(--panel-border-hover);box-shadow:0 22px 56px #1720331c}.glass-panel-neon{background:var(--panel-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line-strong);transition:var(--transition-smooth);border-radius:16px;position:relative;overflow:hidden;box-shadow:0 18px 48px #17203314}.btn{cursor:pointer;transition:var(--transition-smooth);font-size:.98rem;font-weight:700;font-family:var(--font-sans);border:1px solid #0000;border-radius:12px;outline:none;justify-content:center;align-items:center;gap:8px;padding:14px 28px;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-coral) 0%, var(--accent-violet) 100%);color:#fff;border:1px solid #0000;box-shadow:0 12px 24px #6d5dfc38}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px #6d5dfc47}.btn-secondary{border:1px solid var(--panel-border);color:var(--text-primary);background:#fff;box-shadow:0 8px 18px #1720330a}.btn-secondary:hover{border-color:var(--accent-teal);background:#f8fbff;transform:translateY(-2px)}.btn-neon-violet{color:var(--accent-violet);background:#f4f2ff;border:1px solid #ddd8ff;box-shadow:0 8px 18px #6d5dfc1f}.btn-neon-violet:hover{background:var(--accent-violet);color:#fff;transform:translateY(-2px);box-shadow:0 14px 28px #6d5dfc3d}.btn:active{transform:translateY(0)scale(1)}.text-gradient{background:linear-gradient(135deg, #172033 0%, var(--accent-violet) 55%, var(--accent-teal) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}@keyframes spring-float{0%{transform:translateY(0)rotate(0)}25%{transform:translateY(-4px)rotate(-1deg)}50%{transform:translateY(0)rotate(0)}75%{transform:translateY(-2px)rotate(1deg)}to{transform:translateY(0)rotate(0)}}.animate-float{animation:3.5s ease-in-out infinite spring-float}.grid-container{gap:24px;display:grid}.flex-center{justify-content:center;align-items:center;display:flex}.app-container{flex-direction:column;width:100%;max-width:1320px;min-height:100vh;margin:0 auto;padding:0 20px 40px;display:flex}.app-header{border-bottom:1px solid var(--line-soft);z-index:20;-webkit-backdrop-filter:blur(16px);background:#f6f7fbdb;justify-content:space-between;align-items:center;margin-bottom:24px;padding:18px 0;display:flex;position:sticky;top:0}@media (width<=640px){.app-header{flex-direction:column;gap:12px;margin-bottom:16px;padding:16px 0}}.logo-section{cursor:pointer;transition:var(--transition-smooth);align-items:center;gap:12px;display:flex}.logo-section:hover{transform:translateY(-1px)}.brand-mark{color:#fff;letter-spacing:0;background:#172033;border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;font-size:.86rem;font-weight:800;display:inline-flex;box-shadow:8px 8px #2aa7a72e}.logo-section h1{letter-spacing:0;margin:0;font-family:Jua,sans-serif;font-size:2rem}.header-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;display:flex}.total-score-badge{background:var(--surface);border:1px solid var(--line-soft);color:var(--text-primary);border-radius:999px;align-items:center;gap:8px;padding:8px 18px;font-family:Jua,sans-serif;font-size:.9rem;font-weight:700;display:flex;box-shadow:0 8px 18px #1720330a}.lobby-hero{text-align:left;margin-bottom:24px;padding:6px 2px 0;position:relative}.lobby-eyebrow{color:var(--accent-coral);font-family:var(--font-sans);letter-spacing:.08em;align-items:center;margin-bottom:6px;font-size:.78rem;font-weight:800;display:inline-flex}.lobby-quick-stats{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.lobby-quick-stats span{border:1px solid var(--line-soft);color:var(--text-primary);background:#ffffffc7;border-radius:999px;padding:6px 12px;font-family:Jua,sans-serif;font-size:.8rem}.lobby-layout{grid-template-columns:1fr;gap:28px;display:grid}@media (width>=1024px){.lobby-layout{grid-template-columns:minmax(0,2.8fr) minmax(280px,1fr);align-items:start}}.games-grid{grid-template-columns:1fr;gap:20px;display:grid}@media (width>=640px){.games-grid{grid-template-columns:repeat(2,1fr)}}.game-card{cursor:pointer;border:1px solid var(--panel-border);background:var(--surface);isolation:isolate;border-radius:16px;outline:none;flex-direction:column;justify-content:space-between;min-height:292px;padding:24px;display:flex;position:relative;box-shadow:0 18px 44px #17203312}.game-card:after{content:"";background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,50%), var(--card-glow,#2aa7a724) 0%, transparent 70%) no-repeat;opacity:0;pointer-events:none;z-index:1;border:1px solid #0000;border-radius:24px;transition:opacity .4s;position:absolute;inset:0}.game-card:hover:after{opacity:1}.game-card:hover{transform:translateY(-6px)scale(1.01);box-shadow:0 24px 56px #1720331f}.game-card:focus-visible{border-color:var(--accent-teal);box-shadow:0 0 0 5px #2aa7a729,0 24px 56px #1720331f}.game-card-top{z-index:2;justify-content:space-between;align-items:flex-start;display:flex}.game-icon-wrapper{border:1px solid var(--line-soft);width:56px;height:56px;transition:var(--transition-smooth);background:#f4f6fb;border-radius:14px;justify-content:center;align-items:center;font-size:1.25rem;font-weight:800;display:flex}.game-card:hover .game-icon-wrapper{transform:translateY(-2px)}.game-card.tetris-card .game-icon-wrapper{color:var(--accent-coral);background:#fff3ef;border-color:#ffd8cc}.game-card.puzzle2048-card .game-icon-wrapper{color:#9a6400;background:#fff8e7;border-color:#f5dfaa;font-size:.9rem}.game-card.minesweeper-card .game-icon-wrapper{color:var(--accent-teal);background:#effafa;border-color:#cceaea}.game-card.snake-card .game-icon-wrapper{color:var(--accent-violet);background:#f4f2ff;border-color:#ddd8ff}.game-card.syntaxBlocks-card .game-icon-wrapper{color:var(--accent-blue);background:#edf4ff;border-color:#cfe0ff;font-size:.95rem}.game-card.photoJigsaw-card .game-icon-wrapper{color:var(--accent-teal);background:#effafa;border-color:#cceaea;font-size:.86rem}.game-card.photoSlider-card .game-icon-wrapper{color:#9a6400;background:#fff8e7;border-color:#f5dfaa;font-size:.86rem}.high-score-tag{color:var(--text-secondary);border:1px solid var(--line-soft);background:#fff;border-radius:999px;padding:5px 12px;font-family:Jua,sans-serif;font-size:.8rem;font-weight:700}.game-card-body{z-index:2;margin-top:auto}.game-card-body h3{color:var(--text-primary);margin-bottom:6px;font-family:Jua,sans-serif;font-size:1.45rem;font-weight:800}.game-card-body p{color:var(--text-secondary);font-size:.88rem;line-height:1.4}.game-card-footer{z-index:2;border-top:1px solid var(--line-soft);color:var(--text-secondary);justify-content:space-between;align-items:center;gap:10px;margin-top:18px;padding-top:14px;font-family:Jua,sans-serif;font-size:.82rem;display:flex}.game-card-footer strong{color:var(--accent-coral);font-size:.88rem}.sidebar-panel{flex-direction:column;gap:24px;display:flex}@media (width>=1024px){.sidebar-panel{position:sticky;top:96px}}.panel-title{color:var(--text-primary);border-bottom:1px solid var(--line-soft);align-items:center;gap:8px;margin-bottom:14px;padding-bottom:8px;font-family:Jua,sans-serif;font-size:1.15rem;font-weight:800;display:flex}.stats-list{flex-direction:column;gap:14px;display:flex}.stat-item{border:1px solid var(--line-soft);background:#fff;border-radius:12px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.stat-label{color:var(--text-secondary);font-size:.9rem}.stat-value{color:var(--text-primary);font-weight:800}.achievements-list{flex-direction:column;gap:10px;max-height:350px;padding-right:4px;display:flex;overflow-y:auto}.achievement-item{border:1px solid var(--line-soft);transition:var(--transition-fast);background:#fff;border-radius:12px;align-items:center;gap:12px;padding:12px;display:flex}.achievement-item.unlocked{background:#fff8e7;border-color:#f5dfaa}.achievement-icon-wrapper{width:40px;height:40px;color:var(--text-muted);background:#fcfbfe;border-radius:10px;justify-content:center;align-items:center;font-size:1.4rem;display:flex}.achievement-item.unlocked .achievement-icon-wrapper{background:#fff;box-shadow:0 4px 8px #f4b74024}.achievement-info{flex:1}.achievement-title{color:var(--text-secondary);font-family:Jua,sans-serif;font-size:.9rem;font-weight:800}.achievement-item.unlocked .achievement-title{color:var(--text-primary)}.achievement-desc{color:var(--text-muted);font-size:.75rem}.achievement-item.unlocked .achievement-desc{color:var(--text-secondary)}.game-play-container{grid-template-columns:1fr;gap:24px;width:100%;display:grid}@media (width>=1024px){.game-play-container{grid-template-columns:3fr 1fr}}.game-main-area{flex-direction:column;justify-content:flex-start;align-items:center;width:100%;min-height:520px;padding:24px;display:flex}@media (width<=640px){.game-main-area{min-height:auto;padding:16px 8px}}.game-control-panel{flex-direction:column;gap:16px;display:flex}.game-header{justify-content:space-between;align-items:center;gap:10px;width:100%;margin-bottom:20px;display:flex}@media (width<=640px){.game-header{flex-wrap:wrap;justify-content:center;gap:8px}}.game-title-badge{align-items:center;gap:8px;display:flex}.game-title-badge h2{font-family:Jua,sans-serif;font-size:1.5rem;font-weight:800}.game-canvas-wrapper{border:1px solid var(--line-strong);touch-action:none;background:#f8fbff;border-radius:16px;max-width:100%;position:relative;overflow:hidden;box-shadow:0 18px 44px #17203314}.game-canvas-wrapper canvas{width:100%;height:100%;display:block}.mobile-keypad{flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;max-width:320px;margin-top:20px;display:flex}.mobile-keypad-row{justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.btn-control{border:1px solid var(--line-strong);width:54px;height:54px;color:var(--accent-violet);cursor:pointer;-webkit-user-select:none;user-select:none;transition:var(--transition-fast);-webkit-tap-highlight-color:transparent;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.3rem;display:flex;box-shadow:0 8px 18px #17203314}.btn:focus-visible,.btn-control:focus-visible,.btn-control-rect:focus-visible,.mode-toggle-btn:focus-visible{outline-offset:3px;outline:4px solid #2aa7a733}.btn:disabled{cursor:not-allowed}.btn-control:active{border-color:var(--accent-violet);background:#f4f2ff;transform:scale(.85);box-shadow:0 2px 4px #17203314}.btn-control-rect{border:1px solid var(--line-strong);height:48px;color:var(--accent-violet);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#fff;border-radius:12px;justify-content:center;align-items:center;padding:0 16px;font-family:Jua,sans-serif;font-size:.9rem;font-weight:700;transition:all .1s;display:flex;box-shadow:0 8px 18px #17203314}.btn-control-rect:active{background:#f4f2ff;transform:scale(.9)}.mode-toggle-container{border:1px solid var(--line-strong);background:#fff;border-radius:999px;gap:8px;margin-bottom:16px;padding:4px;display:flex;box-shadow:0 8px 18px #1720330f}.mode-toggle-btn{cursor:pointer;color:var(--text-secondary);transition:var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:99px;align-items:center;gap:6px;padding:8px 16px;font-family:Jua,sans-serif;font-size:.9rem;font-weight:700;display:flex}.mode-toggle-btn.active{background:linear-gradient(135deg, var(--accent-teal) 0%, var(--accent-violet) 100%);color:#fff;box-shadow:0 8px 18px #6d5dfc2e}.game-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#f6f7fbf0;flex-direction:column;justify-content:center;align-items:center;gap:22px;animation:.4s fadeIn;display:flex;position:absolute;inset:0}.game-overlay-title{font-family:Jua,sans-serif;font-size:2.2rem;font-weight:800}.game-overlay-score{color:var(--text-secondary);font-family:Jua,sans-serif;font-size:1.15rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.achievement-toast{border:1px solid var(--line-strong);z-index:1000;opacity:0;background:#fff;border-radius:16px;align-items:center;gap:12px;padding:14px 20px;animation:4s cubic-bezier(.175,.885,.32,1.275) forwards slideUpToast;display:flex;position:fixed;bottom:24px;right:24px;transform:translateY(120px);box-shadow:0 18px 48px #17203329}@keyframes slideUpToast{0%{opacity:0;transform:translateY(120px)}10%{opacity:1;transform:translateY(0)}90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(120px)}}.toast-icon{font-size:1.8rem}.toast-info{flex-direction:column;gap:2px;display:flex}.toast-subtitle{color:var(--text-secondary);font-family:Jua,sans-serif;font-size:.78rem}.toast-title{color:var(--accent-coral);font-family:Jua,sans-serif;font-size:1rem}.mobile-hide{display:block}@media (width<=760px){.mobile-hide{display:none!important}.game-card{min-height:260px}.lobby-hero h2{font-size:1.8rem!important}}@media (width<=420px){.app-container{padding-inline:12px}.header-actions{width:100%}.total-score-badge{justify-content:center;width:100%}.btn{padding:12px 18px}.mode-toggle-container{border-radius:18px;width:100%}.mode-toggle-btn{flex:1;justify-content:center;padding-inline:10px}}.toast-info{text-align:left;flex-direction:column;display:flex}.toast-title{color:var(--text-primary);font-family:Jua,sans-serif;font-size:.95rem;font-weight:800}.toast-subtitle{color:var(--accent-coral);font-size:.8rem;font-weight:700}.syntax-layout{align-items:start}.syntax-main{background:var(--surface);gap:18px}.syntax-brief{border:1px solid var(--line-soft);background:linear-gradient(135deg,#fff 0%,#f8fbff 100%);border-radius:16px;justify-content:space-between;align-items:flex-end;gap:16px;width:100%;max-width:920px;padding:18px;display:flex}.syntax-brief h3{color:var(--text-primary);margin:4px 0 0;font-family:Jua,sans-serif;font-size:1.35rem;font-weight:800}.syntax-score{color:#fff;text-align:center;background:#172033;border-radius:14px;min-width:112px;padding:10px 14px}.syntax-score span{color:#ffffffad;font-size:.72rem;font-weight:800;display:block}.syntax-score strong{font-size:1.55rem;line-height:1.1;display:block}.syntax-board{perspective:900px;border:1px solid var(--line-soft);background:linear-gradient(#f8fbfff5,#fffffff5),repeating-linear-gradient(0deg,#1720330a 0 1px,#0000 1px 22px);border-radius:20px;grid-template-columns:repeat(4,minmax(140px,1fr));gap:10px;width:100%;max-width:920px;padding:18px;display:grid;box-shadow:inset 0 0 0 6px #2f7df608}.syntax-slot{border:2px dashed var(--line-strong);min-height:150px;color:var(--text-secondary);cursor:pointer;text-align:left;transition:var(--transition-fast);background:linear-gradient(135deg,#ffffffa8,#f8fbffbd),repeating-linear-gradient(90deg,#2f7df60f 0 1px,#0000 1px 18px);border-radius:18px;flex-direction:column;justify-content:space-between;padding:14px 14px 16px;display:flex;position:relative;overflow:visible;transform:rotateX(5deg);box-shadow:inset 0 0 0 4px #ffffffb8,8px 10px #1720330a}.syntax-slot:before,.syntax-slot:after{content:"";border:2px dashed var(--line-strong);z-index:0;background:#f8fbff;width:22px;height:44px;position:absolute;top:50%;transform:translateY(-50%)}.syntax-slot:before{border-left:0;border-radius:0 24px 24px 0;left:-12px}.syntax-slot:after{border-right:0;border-radius:24px 0 0 24px;right:-12px}.syntax-slot:first-child:before,.syntax-slot:last-child:after{display:none}.slot-order{z-index:2;color:#fff;background:#172033;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:.78rem;font-weight:800;display:inline-flex;position:absolute;top:-12px;left:12px}.syntax-slot strong{color:var(--text-primary);font-family:Jua,sans-serif;font-size:1.25rem}.syntax-slot .slot-label{z-index:1;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-left:30px;font-size:.74rem;font-weight:800;position:relative}.syntax-slot.wedge{border-color:#f4b740b3}.syntax-slot.block{border-color:#2f7df694}.syntax-slot.socket{border-color:#6d5dfc94}.syntax-slot.cap{border-color:#2aa7a79e}.syntax-slot.filled{background:#fff;border-style:solid;transform:rotateX(0)rotateY(0)}.syntax-slot.attract{border-color:var(--accent-teal);background:linear-gradient(135deg,#effafaf5,#fffffff5);box-shadow:0 0 0 6px #2aa7a724,8px 10px #2aa7a71f}.syntax-slot.repel{opacity:.58}.syntax-empty-socket,.syntax-piece-in-slot{z-index:1;border-radius:16px;gap:4px;min-height:74px;padding:14px;display:grid;position:relative}.syntax-empty-socket{text-align:center;color:var(--text-muted);background:radial-gradient(circle at 16px,#0000 0 10px,#9aa6b71f 11px),radial-gradient(circle at calc(100% - 16px),#9aa6b71f 0 10px,#0000 11px);border:2px dashed;place-content:center}.syntax-empty-socket small,.syntax-piece-in-slot small{color:var(--text-secondary);font-size:.74rem;font-weight:700}.syntax-piece-in-slot{border:1px solid var(--line-soft);background:#fff;box-shadow:0 14px 26px #17203314}.syntax-piece-in-slot:before,.syntax-piece-in-slot:after{content:"";border:1px solid var(--line-soft);background:#fff;width:18px;height:34px;position:absolute;top:50%;transform:translateY(-50%)}.syntax-piece-in-slot:before{border-left:0;border-radius:0 18px 18px 0;left:-9px}.syntax-piece-in-slot:after{border-right:0;border-radius:18px 0 0 18px;right:-9px}.syntax-sentence,.syntax-feedback,.syntax-mission,.syntax-complete,.syntax-chunks{width:100%;max-width:920px}.syntax-sentence{border:1px solid var(--line-soft);color:#fff;background:#172033;border-radius:14px;padding:14px 16px}.syntax-sentence span{color:#ffffff9e;margin-bottom:4px;font-size:.74rem;font-weight:800;display:block}.syntax-sentence strong{font-family:Jua,sans-serif;font-size:1.2rem}.syntax-mission{background:#fff8e7;border:1px solid #f5dfaa;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;padding:16px;display:flex}.syntax-mission strong{color:var(--text-primary);font-family:Jua,sans-serif;font-size:1.1rem;display:block}.syntax-chip-row{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.syntax-chip{background:var(--accent-coral);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:58px;height:40px;padding:0 14px;font-weight:800;display:inline-flex}.syntax-complete{color:var(--text-primary);background:#effafa;border:1px solid #cceaea;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;font-family:Jua,sans-serif;display:flex}.syntax-feedback{min-height:46px;color:var(--text-secondary);background:#f6f7fb;border-radius:14px;padding:12px 14px;font-weight:700}.syntax-chunks{border:1px solid var(--line-soft);background:#f8fbff;border-radius:18px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;padding:16px;display:grid}.syntax-chunk{border:1px solid var(--line-soft);background:var(--surface);min-height:78px;color:var(--text-primary);cursor:pointer;text-align:left;transition:var(--transition-fast);isolation:isolate;border-radius:16px;padding:14px 16px;position:relative;box-shadow:0 10px 24px #1720330d}.syntax-chunk:hover,.syntax-chunk.active{border-color:var(--accent-blue);transform:translateY(-2px);box-shadow:0 14px 30px #2f7df61f}.syntax-chunk.active{outline:5px solid #2f7df61f}.syntax-chunk.compatible{border-color:var(--accent-teal);box-shadow:0 14px 30px #2aa7a729}.syntax-chunk.decoy{color:#8a4f4f;background:#fbf7f7}.syntax-chunk.wedge{border-top:5px solid var(--accent-amber)}.syntax-chunk.block{border-top:5px solid var(--accent-blue)}.syntax-chunk.socket{border-top:5px solid var(--accent-violet)}.syntax-chunk.cap{border-top:5px solid var(--accent-teal)}.piece-tab,.piece-hole{background:inherit;border:1px solid inherit;z-index:-1;width:18px;height:34px;position:absolute;top:50%;transform:translateY(-50%)}.piece-tab{border-right:0;border-radius:18px 0 0 18px;right:-10px}.piece-hole{border-left:0;border-radius:0 18px 18px 0;left:-10px}.syntax-chunk strong{margin-bottom:4px;font-family:Jua,sans-serif;font-size:1.06rem;display:block}.syntax-chunk span{color:var(--text-secondary);font-size:.78rem}.syntax-chunk small{width:fit-content;color:var(--text-muted);background:#f1f5fb;border-radius:999px;margin-top:10px;padding:4px 8px;font-size:.72rem;font-weight:800;display:inline-flex}.syntax-side-card{background:var(--surface);padding:22px}.syntax-loop{gap:10px;display:grid}.syntax-loop span{border:1px solid var(--line-soft);color:var(--text-primary);border-radius:12px;align-items:center;gap:8px;padding:10px 12px;font-weight:700;display:flex}.review-alert{background:#fff8e7;border:1px solid #f5dfaa;border-radius:14px;gap:10px;margin-bottom:14px;padding:14px;display:grid}.review-alert strong{color:var(--accent-coral);font-family:Jua,sans-serif}.syntax-wall{gap:10px;display:grid}.wall-brick,.empty-wall{border:1px solid var(--line-soft);background:#f8fbff;border-radius:12px;padding:12px;display:block}.wall-brick strong{color:var(--accent-violet);margin-bottom:4px;font-family:Jua,sans-serif;display:block}.wall-brick span,.empty-wall{color:var(--text-secondary);font-size:.84rem}@media (width<=900px){.syntax-board{grid-template-columns:repeat(2,minmax(130px,1fr))}.syntax-brief,.syntax-mission,.syntax-complete{flex-direction:column;align-items:stretch}.syntax-chip-row{justify-content:flex-start}}.photo-puzzle-layout{align-items:start}.photo-puzzle-main{background:var(--surface);gap:18px;position:relative}.photo-upload-panel{border:1px solid var(--line-soft);width:100%;max-width:860px;transition:var(--transition-fast);background:linear-gradient(135deg,#ffffffeb,#f8fbfff5),repeating-linear-gradient(90deg,#2f7df60d 0 1px,#0000 1px 18px);border-radius:16px;justify-content:space-between;align-items:center;gap:14px;padding:14px;display:flex}.photo-upload-panel.dragging{border-color:var(--accent-blue);box-shadow:inset 0 0 0 2px #2f7df624,0 18px 32px #2f7df61f}.photo-upload-button{color:#fff;cursor:pointer;min-width:170px;font-weight:800;font-family:var(--font-sans);background:#172033;border:0;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 18px;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 10px 22px #17203324}.sr-only-input{opacity:0;pointer-events:none;width:1px;height:1px;position:fixed}.photo-difficulty{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.photo-options-row{flex-wrap:wrap;align-items:center;gap:10px;width:100%;max-width:860px;display:flex}.segmented-control{border:1px solid var(--line-soft);background:#fff;border-radius:14px;align-items:center;gap:4px;padding:4px;display:inline-flex;box-shadow:0 8px 18px #1720330a}.segmented-control button{min-height:34px;color:var(--text-secondary);cursor:pointer;font-family:var(--font-sans);white-space:nowrap;background:0 0;border:0;border-radius:10px;padding:0 12px;font-size:.84rem;font-weight:800}.segmented-control button.active{color:#fff;background:#172033;box-shadow:0 8px 16px #17203324}.photo-board-wrap{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:16px;width:100%;display:flex;position:relative}.photo-preview-panel{flex-direction:column;flex:0 0 164px;gap:10px;width:164px;display:flex}.photo-preview-panel img{aspect-ratio:1;border:1px solid var(--line-strong);object-fit:cover;border-radius:16px;width:100%;box-shadow:0 14px 28px #1720331a}.photo-preview-panel .btn,.photo-preview-restore{padding:10px 12px;font-size:.86rem}.photo-preview-restore{flex:none;align-self:flex-start}.photo-jigsaw-board,.photo-slider-board{grid-template-columns:repeat(var(--grid-size), 1fr);grid-template-rows:repeat(var(--grid-size), 1fr);aspect-ratio:1;border:1px solid var(--line-strong);background:linear-gradient(#f8fbfff5,#fffffff5),repeating-linear-gradient(45deg,#1720330a 0 1px,#0000 1px 20px);border-radius:20px;gap:6px;width:min(680px,100%);padding:14px;display:grid;position:relative;overflow:hidden;box-shadow:0 22px 56px #1720331a}.photo-jigsaw-board{background:linear-gradient(#fffffff7,#f4f8fdf7),repeating-linear-gradient(0deg,#17203309 0 1px,#0000 1px 34px),repeating-linear-gradient(90deg,#17203309 0 1px,#0000 1px 34px);gap:0;padding:28px;overflow:visible}.photo-slider-board{overflow:hidden}.photo-guide-overlay{z-index:0;opacity:.22;pointer-events:none;filter:saturate(.9);background-position:50%;background-size:cover;border-radius:14px;position:absolute;inset:14px}.photo-jigsaw-board.empty,.photo-slider-board.empty{justify-content:center;align-items:center;display:flex}.photo-empty-state{text-align:center;max-width:360px;color:var(--text-secondary);justify-items:center;gap:10px;display:grid}.photo-empty-state strong{color:var(--text-primary);font-family:Jua,sans-serif;font-size:1.25rem}.jigsaw-slot{z-index:1;cursor:pointer;min-width:0;min-height:0;transition:var(--transition-fast);background:0 0;border:0;border-radius:0;place-items:center;padding:0;display:grid;position:relative;overflow:visible}.jigsaw-slot:hover,.jigsaw-slot.hint-slot{box-shadow:inset 0 0 0 2px #2f7df61f}.jigsaw-slot.filled{background:0 0;border-color:#0000}.jigsaw-slot-number{z-index:2;color:#6470868a;font-family:Jua,sans-serif;font-size:.8rem;position:relative}.jigsaw-slot-guide{pointer-events:none;width:152%;height:152%;position:absolute;inset:-26%;overflow:visible}.jigsaw-slot-guide path{fill:#fff6;stroke:#64708680;stroke-width:1.8px;stroke-dasharray:4 4;vector-effect:non-scaling-stroke}.jigsaw-piece,.slider-tile{z-index:1;cursor:pointer;transition:var(--transition-fast);background-repeat:no-repeat;border:0;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #1720331f,0 8px 16px #1720331a}.jigsaw-piece{width:100%;height:100%;transform:rotate(var(--piece-rotation,0deg));filter:drop-shadow(0 8px 8px #1720332e);box-shadow:none;background:0 0;border-radius:10px;overflow:visible}.jigsaw-piece.in-tray{aspect-ratio:1;min-height:76px;transform:translate(var(--scatter-x), var(--scatter-y)) rotate(calc(var(--piece-rotation,0deg) + var(--scatter-turn,0deg)))}.jigsaw-piece.on-board{min-width:0;min-height:0}.jigsaw-piece:before,.jigsaw-piece:after{content:"";pointer-events:none;display:none;position:absolute;inset:0}.jigsaw-piece:before{z-index:1;mix-blend-mode:soft-light;background:radial-gradient(circle at 50% 7%,#ffffff80 0 7%,#0000 8%),radial-gradient(circle at 93%,#0003 0 7%,#0000 8%),linear-gradient(135deg,#ffffff7a,#0000 34%,#0000002e 100%)}.jigsaw-piece:after{z-index:1;opacity:.58;background:repeating-linear-gradient(18deg,#ffffff14 0 1px,#0000 1px 8px),repeating-linear-gradient(108deg,#1720330f 0 1px,#0000 1px 11px)}.jigsaw-connector{z-index:2;width:var(--connector-width,30%);height:var(--connector-height,30%);pointer-events:none;border-radius:50%;display:block;position:absolute}.jigsaw-connector.connector-shape-0{--connector-width:30%;--connector-height:30%;border-radius:50%}.jigsaw-connector.connector-shape-1{--connector-width:36%;--connector-height:26%;border-radius:48% 55% 48% 58%}.jigsaw-connector.connector-shape-2{--connector-width:26%;--connector-height:36%;border-radius:60% 44% 56% 46%}.jigsaw-connector.connector-shape-3{--connector-width:34%;--connector-height:32%;border-radius:42% 62% 50% 58%}.jigsaw-connector.tab{background-image:inherit;background-size:inherit;background-position:inherit;box-shadow:inset 1px 1px #ffffffb3,inset -2px -2px #17203338,0 7px 10px #17203329}.jigsaw-connector.slot{background:radial-gradient(#17203338,#17203317 42%,#0000 64%),linear-gradient(145deg,#edf3fa,#fff);box-shadow:inset 3px 3px 7px #17203338,inset -2px -2px 4px #ffffffe0}.jigsaw-connector.top{top:-15%;left:50%;transform:translate(-50%)}.jigsaw-connector.right{top:50%;right:-15%;transform:translateY(-50%)}.jigsaw-connector.bottom{bottom:-15%;left:50%;transform:translate(-50%)}.jigsaw-connector.left{top:50%;left:-15%;transform:translateY(-50%)}.jigsaw-connector.slot.top{top:-14%}.jigsaw-connector.slot.right{right:-14%}.jigsaw-connector.slot.bottom{bottom:-14%}.jigsaw-connector.slot.left{left:-14%}.jigsaw-piece-svg{pointer-events:none;width:152%;height:152%;position:absolute;inset:-26%;overflow:visible}.jigsaw-piece-shade{fill:#ffffff29;mix-blend-mode:soft-light}.jigsaw-piece-cutline{fill:#0000;stroke:#17203370;stroke-width:1.35px;vector-effect:non-scaling-stroke;filter:drop-shadow(0 1px #ffffff80)}.jigsaw-piece:hover,.jigsaw-piece.selected,.slider-tile:hover,.slider-tile.movable{box-shadow:0 14px 28px #2f7df62e}.jigsaw-piece:hover,.jigsaw-piece.selected{transform:translateY(-2px) rotate(var(--piece-rotation,0deg))}.jigsaw-piece.in-tray:hover,.jigsaw-piece.in-tray.selected{transform:translate(var(--scatter-x), calc(var(--scatter-y) - 4px)) rotate(calc(var(--piece-rotation,0deg) + var(--scatter-turn,0deg)))}.slider-tile:hover,.slider-tile.movable{transform:translateY(-2px)}.jigsaw-piece.selected{z-index:3;outline:5px solid #2f7df62e}.jigsaw-piece.placed{filter:drop-shadow(0 5px 5px #2aa7a724)}.jigsaw-piece.placed .jigsaw-piece-cutline{stroke:#2a78788c}.jigsaw-piece.edge-piece span{background:#2aa7a7db}.jigsaw-piece.corner-piece span{background:#ff6b4ae6}.jigsaw-piece.hint,.slider-tile.hint{box-shadow:inset 0 0 0 3px var(--accent-amber), 0 0 0 6px #f4b7402e, 0 16px 30px #f4b74033;animation:1s ease-in-out infinite hint-pulse}.jigsaw-piece span,.slider-tile span{z-index:2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;background:#1720338f;border-radius:999px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:.68rem;font-weight:800;display:inline-flex;position:absolute;top:8px;left:8px}.slider-tile{border-radius:12px}.slider-tile.movable{cursor:pointer;box-shadow:inset 0 0 0 2px #2aa7a7b3,0 12px 24px #2aa7a729}.slider-blank{z-index:1;border:2px dashed var(--line-strong);background:radial-gradient(circle,#2f7df614,#0000 55%),#f1f5fb;border-radius:12px;box-shadow:inset 0 0 0 5px #fff9}.jigsaw-piece-tray{border:1px solid var(--line-soft);background:linear-gradient(135deg,#ffffffeb,#f8fbfff0),repeating-linear-gradient(-8deg,#1720330a 0 1px,#0000 1px 18px);border-radius:18px;width:min(860px,100%);padding:16px;box-shadow:0 18px 38px #17203314}.jigsaw-tray-head{color:var(--text-primary);justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;font-family:Jua,sans-serif;display:flex}.jigsaw-tray-head span{color:var(--text-secondary);font-family:var(--font-sans);font-size:.84rem;font-weight:800}.jigsaw-tray-grid{grid-template-columns:repeat(auto-fill, minmax(clamp(74px, calc(210px / var(--grid-size)), 104px), 1fr));gap:14px;padding:8px;display:grid;overflow:visible}.photo-side-card{background:var(--surface);padding:22px}.photo-stat-list{gap:10px;display:grid}.photo-stat-list div{border:1px solid var(--line-soft);background:#f8fbff;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:11px 12px;display:flex}.photo-stat-list span,.photo-help{color:var(--text-secondary);font-size:.88rem}.photo-stat-list strong{color:var(--text-primary);font-family:Jua,sans-serif}.photo-complete-overlay{color:var(--text-primary)}.photo-complete-overlay svg{color:var(--accent-teal);animation:.72s cubic-bezier(.2,1.4,.38,1) complete-pop}.photo-confirm-backdrop{z-index:30;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#17203338;border-radius:16px;place-items:center;padding:20px;display:grid;position:absolute;inset:0}.photo-confirm-card{border:1px solid var(--line-strong);background:#fff;border-radius:16px;width:min(360px,100%);padding:22px;box-shadow:0 24px 58px #17203338}.photo-confirm-card strong{color:var(--text-primary);margin-bottom:8px;font-family:Jua,sans-serif;font-size:1.3rem;display:block}.photo-confirm-card p{color:var(--text-secondary);margin-bottom:18px;font-size:.92rem}.photo-confirm-actions{justify-content:flex-end;gap:10px;display:flex}.photo-confirm-actions .btn{padding:11px 16px}@keyframes hint-pulse{0%,to{transform:translateY(0) rotate(var(--piece-rotation,0deg))}50%{transform:translateY(-4px) rotate(var(--piece-rotation,0deg))}}@keyframes complete-pop{0%{opacity:0;transform:scale(.7)rotate(-8deg)}70%{opacity:1;transform:scale(1.12)rotate(4deg)}to{transform:scale(1)rotate(0)}}@media (width<=720px){.photo-upload-panel{flex-direction:column;align-items:stretch}.photo-difficulty{justify-content:flex-start}.photo-board-wrap{flex-direction:column;align-items:center}.photo-preview-panel{flex-basis:auto;width:100%;max-width:320px}.photo-options-row{flex-direction:column;align-items:stretch}.segmented-control{overflow-x:auto}.photo-jigsaw-board,.photo-slider-board{gap:4px;padding:8px}.photo-jigsaw-board{gap:0;padding:18px}.photo-guide-overlay{inset:8px}.jigsaw-tray-grid{grid-template-columns:repeat(auto-fill,minmax(68px,1fr))}}
