@import "https://fonts.googleapis.com/css2?family=Gothic+A1:wght@400;500;600;700;800&family=Nanum+Myeongjo:wght@700;800&family=Spline+Sans+Mono:wght@400;500;600&display=swap";.lobby-shell,.difficulty-shell,.rules-shell,.play-shell{min-height:100vh;color:var(--text-primary);background:linear-gradient(#ffffff2e, #fff0), var(--surface-paper)}.lobby-shell,.difficulty-shell,.rules-shell{place-items:center;padding:32px;display:grid}.lobby-copy,.difficulty-copy,.rules-copy{border:1px solid var(--line-soft);background:#fbf6eabd;border-radius:6px;width:min(680px,100%);padding:48px;box-shadow:0 18px 42px #2e262014}.lobby-copy h1,.difficulty-copy h1,.rules-copy h1{font-family:var(--font-display);margin:0;font-size:clamp(48px,8vw,66px);line-height:1}.lobby-copy p,.difficulty-copy p,.rules-copy p{max-width:560px;color:var(--text-secondary);margin:22px 0 0;font-size:16px;line-height:1.75}.lobby-shell{align-content:start;place-items:start center;min-height:100dvh;padding:clamp(56px,12dvh,92px) 24px 24px}.lobby-copy{text-align:center;width:min(360px,100%);box-shadow:none;background:0 0;border:0;justify-items:center;padding:0;display:grid}.lobby-meta,.lobby-build{color:var(--text-faint);font-family:var(--font-mono);letter-spacing:.22em;margin:0;font-size:10px;line-height:1.4}.lobby-meta{margin-bottom:38px}.lobby-build{margin-top:22px;font-size:9.5px}.lobby-emblem{place-items:center;width:96px;height:82px;margin-bottom:12px;display:grid;position:relative}.lobby-emblem:after{content:"";pointer-events:none;border:1px solid #0ea5e92e;border-radius:50%;position:absolute;inset:13px 20px}.lobby-stone{z-index:1;aspect-ratio:1;background:var(--stone-white);border:1px solid #d8cbacf2;border-radius:50%;width:42px;display:block;position:relative;box-shadow:inset 5px 7px 14px #ffffff3d,inset -8px -10px 16px #22180e1f,0 10px 18px #4634182e}.lobby-echo-ripple{aspect-ratio:1;opacity:0;border:1px solid #0ea5e970;border-radius:50%;width:48px;animation:3.4s ease-out infinite echoRipple;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.55)}.lobby-echo-ripple-2{animation-delay:1.1s}.lobby-echo-ripple-3{animation-delay:2.2s}.lobby-copy h1{letter-spacing:.02em;font-size:clamp(54px,14vw,64px)}.lobby-copy .lobby-tagline{max-width:220px;color:var(--text-secondary);margin-top:13px;font-size:13px;font-weight:500;line-height:1.75}.lobby-actions{gap:10px;width:100%;margin-top:30px;display:grid}.lobby-actions>.primary-button{border-radius:9px;width:100%;min-height:48px;box-shadow:0 10px 24px #0e85bd33}.lobby-secondary-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.lobby-secondary-actions .secondary-button{background:#fffdf794;border-color:#ccbb9ad1;min-height:42px}.rules-lead{color:var(--text-secondary);margin-top:22px;font-size:15px;font-weight:600;line-height:1.65}.rules-blocks{gap:18px;margin-top:30px;display:grid}.rules-block{border-top:1px solid var(--line-soft);gap:10px;padding-top:18px;display:grid}.rules-block h2{color:var(--text-primary);margin:0;font-size:17px;line-height:1.35}.rules-block p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.7}.rules-steps,.rules-notes{color:var(--text-secondary);gap:10px;margin:0;padding-left:22px;line-height:1.65;display:grid}.rules-notes{margin-top:22px}.rules-comparison{gap:10px;margin:0;display:grid}.rules-comparison div{grid-template-columns:minmax(72px,max-content) 1fr;align-items:start;gap:12px;display:grid}.rules-comparison dt{color:var(--echo-strong);white-space:nowrap;font-weight:800}.rules-comparison dd{min-width:0;color:var(--text-secondary);margin:0;line-height:1.65}.rules-actions{flex-wrap:wrap;gap:12px;margin-top:30px;display:flex}.side-selector{margin-top:26px}.side-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.side-option{--side-echo:var(--echo-white);--side-echo-strong:var(--echo-white-strong);border:1px solid var(--line-strong);background:var(--surface-raised);min-width:0;min-height:44px;color:var(--text-primary);cursor:pointer;border-radius:9px;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-size:13px;font-weight:800;display:flex}.side-option-black{--side-echo:var(--echo-black);--side-echo-strong:var(--echo-black-strong)}.side-option:hover,.side-option:focus-visible{border-color:var(--side-echo-strong)}.side-option:focus-visible{outline-offset:3px;outline:3px solid #0ea5e938}.side-option.is-selected{border-color:var(--side-echo-strong);color:var(--side-echo-strong);background:#fffdf7bd;box-shadow:inset 0 0 0 1px #ffffff70}.side-option-stone{border-radius:50%;flex:none;width:16px;height:16px;display:inline-block}.side-option-stone-white{background:radial-gradient(circle at 36% 30%,#fffdf7,#e2d6bb);border:1px solid #d8cbac}.side-option-stone-black{background:radial-gradient(circle at 36% 30%,#564e46,#100c09);border:1px solid #100c0973}.difficulty-options{grid-template-columns:repeat(auto-fit,minmax(172px,1fr));gap:12px;margin-top:24px;display:grid}.difficulty-option{border:1px solid var(--line-strong);background:var(--surface-raised);min-height:142px;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:6px;gap:10px;padding:18px;display:grid}.difficulty-option:hover,.difficulty-option:focus-visible{border-color:var(--echo-strong)}.difficulty-option span{font-family:var(--font-display);justify-content:space-between;align-items:center;gap:8px;font-size:25px;display:flex}.difficulty-option strong{color:var(--echo-strong);font-family:var(--font-mono);border:1px solid #0ea5e961;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700}.difficulty-option small{color:var(--text-secondary);font-size:13px;line-height:1.55}.difficulty-copy>.secondary-button{margin-top:24px}.play-shell{--board-size:clamp(480px, min(calc(100dvh - 150px), calc(100vw - 430px)), 720px);--info-width:clamp(304px, 30vw, 340px);--play-gap:clamp(24px, 3vw, 36px);background:0 0;align-content:start;width:min(100%,1220px);margin:0 auto;padding:26px 28px 32px;display:grid}.play-topbar{justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:20px;display:flex}.play-brand{align-items:baseline;gap:12px;min-width:0;display:flex}.play-brand h1{font-family:var(--font-display);letter-spacing:.04em;margin:0;font-size:26px;font-weight:800;line-height:1}.play-brand>span,.mode-pill,.turn-meta,.screen-kicker,.panel-label,.notation-counts,.file-labels,.rank-labels,.event-list,.echo-item{font-family:var(--font-mono)}.play-brand>span{color:var(--text-muted);letter-spacing:.12em;white-space:nowrap;font-size:11px}.play-topbar-actions{flex:none;align-items:center;gap:10px;display:flex}.mode-pill{border:1px solid var(--line-soft);color:var(--text-muted);letter-spacing:.04em;white-space:nowrap;border-radius:20px;flex:none;padding:4px 11px;font-size:11px}.play-lobby-button{border-radius:9px;min-height:34px;padding:0 13px;font-size:12px}.screen-kicker{color:var(--echo-strong);margin:0 0 8px;font-size:12px;font-weight:600}.play-content{align-items:flex-start;gap:var(--play-gap);display:flex}.board-area,.info-column,.side-panel,.event-section{min-width:0}.board-area{justify-items:center;display:grid}.primary-button,.secondary-button{cursor:pointer;border:1px solid #0000;border-radius:10px;min-height:44px;padding:0 18px;font-weight:700}.primary-button{border-color:var(--echo-strong);background:var(--echo);color:#fff}.secondary-button{border-color:var(--line-strong);background:var(--surface-raised);color:var(--text-primary)}.primary-button:focus-visible,.secondary-button:focus-visible{outline-offset:3px;outline:3px solid #0ea5e957}.board-cell:focus-visible{outline:0;box-shadow:inset 0 0 0 2px #0ea5e929}.board-cell.is-selected:focus-visible{box-shadow:inset 0 0 0 2px #0ea5e91a}.board-cell.is-capture:focus-visible,.board-cell.is-direct-win:focus-visible,.board-cell.is-echo-win:focus-visible{box-shadow:inset 0 0 0 2px #b84a3a2e}.board-frame{width:var(--board-size)}.board-with-ranks{grid-template-columns:var(--board-size);grid-template-rows:var(--board-size) 22px;row-gap:4px;display:grid;position:relative}.board-with-ranks>[aria-hidden=true]:not(.rank-labels):not(.file-labels){display:none}.file-labels{width:var(--board-size);color:#46341c8c;text-align:center;grid-template-columns:repeat(6,1fr);font-size:12px;line-height:22px;display:grid}.rank-labels{width:22px;height:var(--board-size);color:#46341c8c;text-align:right;grid-template-rows:repeat(6,1fr);font-size:12px;display:grid;position:absolute;top:0;right:calc(100% + 8px)}.rank-labels span{line-height:calc(var(--board-size) / 6)}.board-grid{isolation:isolate;width:var(--board-size);aspect-ratio:1;background:radial-gradient(circle at 32% 22%, var(--surface-board-light) 0%, var(--surface-board-mid) 70%, var(--surface-board-deep) 100%);border:1px solid #46341c66;border-radius:4px;grid-template-rows:repeat(6,1fr);grid-template-columns:repeat(6,1fr);display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 40px #785f372e,0 18px 40px #3c2d1429}.board-grid.is-finished:before{content:"";z-index:4;pointer-events:none;background:#2e26206b;position:absolute;inset:0}.board-cell{z-index:1;cursor:pointer;background:0 0;border:1px solid #46341c33;border-top:0;border-left:0;place-items:center;min-width:0;display:grid;position:relative}.board-cell:nth-child(6n){border-right:0}.board-cell:nth-last-child(-n+6){border-bottom:0}.board-cell:disabled,.board-cell[aria-disabled=true]{cursor:default}.stone-white,.echo-owner-white,.board-cell.is-echo-target-white,.board-cell.is-finish-owner-white,.result-stone-white{--owner-echo:var(--echo-white);--owner-echo-strong:var(--echo-white-strong);--owner-echo-rgb:var(--echo-white-rgb)}.stone-black,.echo-owner-black,.board-cell.is-echo-target-black,.board-cell.is-finish-owner-black,.result-stone-black{--owner-echo:var(--echo-black);--owner-echo-strong:var(--echo-black-strong);--owner-echo-rgb:var(--echo-black-rgb)}.board-cell.is-selected:after,.board-cell.is-capture:after,.board-cell.is-echo-target:after{content:"";pointer-events:none;border-radius:50%;position:absolute;inset:12%}.board-cell.is-selected:after{border:2px solid var(--echo);box-shadow:0 0 0 3px #0ea5e91f}.board-cell.is-capture:after{border:2px dashed var(--danger)}.board-cell.is-echo-target:after{border:var(--echo-ring-border) dashed rgba(var(--owner-echo-rgb), .92);box-shadow:0 0 0 4px rgba(var(--owner-echo-rgb), .08)}.board-cell.is-echo-conversion:after{border-color:var(--owner-echo)}.board-cell.is-direct-win:after,.board-cell.is-echo-win:after{border-color:var(--danger);box-shadow:0 0 0 4px #b84a3a14}.board-cell.is-finish-origin,.board-cell.is-finish-target{z-index:6;background:#fbf6ead1}.board-cell.is-finish-origin:before,.board-cell.is-finish-target:before{content:"";z-index:3;pointer-events:none;border-radius:50%;position:absolute;inset:12%}.board-cell.is-finish-origin:before{border:2px solid rgba(var(--owner-echo-rgb), .95);box-shadow:0 0 0 5px rgba(var(--owner-echo-rgb), .12), inset 0 0 22px rgba(var(--owner-echo-rgb), .16)}.board-cell.is-finish-target:before{border:2px solid var(--danger);box-shadow:0 0 0 6px #b84a3a29,inset 0 0 24px #b84a3a2e}.board-cell.is-finish-direct.is-finish-origin:before{border-color:var(--danger);box-shadow:0 0 0 5px #b84a3a24,inset 0 0 22px #b84a3a24}.move-dot{pointer-events:none;background:#0ea5e94d;border:1px solid #0e85bdb8;border-radius:50%;width:16px;height:16px;position:absolute}.echo-target-ring{width:var(--echo-ring-size);aspect-ratio:1;border:var(--echo-ring-border) dashed rgba(var(--owner-echo-rgb), .72);pointer-events:none;border-radius:50%;max-width:74%;position:absolute}.board-cell.is-echo-win .echo-target-ring{border-color:#b84a3ad1}.finish-target-ring{z-index:7;aspect-ratio:1;border:2px solid var(--danger);pointer-events:none;border-radius:50%;width:68%;max-width:62px;position:absolute;box-shadow:0 0 0 6px #b84a3a24,0 0 18px #b84a3a42}.finish-arrow{z-index:8;border:1px solid rgba(var(--owner-echo-rgb), .9);background:var(--owner-echo);color:#fff;width:30px;height:30px;font-family:var(--font-mono);pointer-events:none;border-radius:50%;place-items:center;font-size:18px;font-weight:700;line-height:1;display:grid;position:absolute;top:8px;right:8px;box-shadow:0 4px 10px #2e262047}.board-cell.is-finish-direct .finish-arrow{background:var(--danger);border-color:#b84a3ae6}.finish-badge{z-index:8;background:var(--danger);color:#fff;white-space:nowrap;pointer-events:none;border:1px solid #fffdf7ad;border-radius:20px;max-width:calc(100% - 12px);padding:3px 7px;font-size:10px;font-weight:800;line-height:1.1;position:absolute;bottom:6px;right:6px}.cell-alert{z-index:3;background:var(--owner-echo);color:#fff;width:20px;height:20px;font-family:var(--font-mono);pointer-events:none;border-radius:50%;place-items:center;font-size:12px;font-weight:700;display:grid;position:absolute;bottom:9px;right:9px;box-shadow:0 2px 6px #2e26204d}.cell-alert-danger{background:var(--danger)}.stone{z-index:2;width:min(70%, var(--stone-size));aspect-ratio:1;border-radius:50%;display:block;position:relative;box-shadow:inset 5px 7px 14px #fff3,inset -8px -10px 16px #22180e2e,0 9px 15px #2f24143d}.stone-white{background:var(--stone-white);border:1px solid #d8cbacf2}.stone-black{background:var(--stone-black);border:1px solid #100c09b8}.nucleus-mark{width:var(--nucleus-mark-size);aspect-ratio:1;border:2px solid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(45deg)}.stone-white .nucleus-mark{color:#4f463b;background:#fffdf7b8}.stone-black .nucleus-mark{color:#f4edda;background:#100c0957}.echo-arrow{z-index:2;border:1px solid rgba(var(--owner-echo-rgb), .85);width:24px;height:24px;color:var(--owner-echo-strong);font-family:var(--font-mono);background:#fbf6eaeb;border-radius:50%;place-items:center;font-size:16px;font-weight:700;line-height:1;display:grid;position:absolute;top:-10px;right:-8px;box-shadow:0 2px 6px #2e262024}.echo-ripple{z-index:-1;width:var(--echo-ring-size);aspect-ratio:1;border:var(--echo-ring-border) solid rgba(var(--owner-echo-rgb), .42);opacity:0;pointer-events:none;animation:echoRipple var(--echo-ring-duration) ease-out infinite;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.55)}.echo-ripple-2{animation-delay:.9s}.echo-ripple-3{animation-delay:1.8s}.info-column{flex:0 0 var(--info-width);width:var(--info-width);flex-direction:column;align-self:stretch;gap:16px;display:flex}.side-panel{flex-direction:column;gap:16px;width:100%;display:flex}.status-card{border:1px solid var(--line-soft);background:#2e26200d;border-radius:11px;align-items:center;gap:11px;min-height:56px;padding:11px 14px;display:flex}.status-stone,.mini-stone{border-radius:50%;flex:none;display:inline-block}.status-stone{width:24px;height:24px;box-shadow:0 2px 4px #4634184d}.status-stone-white,.mini-stone-white{background:radial-gradient(circle at 36% 30%,#fffdf7,#e2d6bb);border:1px solid #d8cbac}.status-stone-black,.mini-stone-black{background:radial-gradient(circle at 36% 30%,#564e46,#100c09);border:1px solid #100c0973}.mini-stone-neutral{border:1px solid var(--line-strong);background:var(--draw)}.turn-meta{color:var(--text-muted);letter-spacing:.12em;margin:0 0 2px;font-size:10.5px}.status-card h2{margin:0;font-size:16px;font-weight:800;line-height:1.2}.status-card p:not(.turn-meta){color:var(--text-secondary);margin:5px 0 0;font-size:11.5px;line-height:1.4}.panel-section{min-width:0}.panel-label{color:var(--text-faint);letter-spacing:.14em;margin:0 0 11px;font-size:10px;font-weight:600}.phase-list,.echo-list,.event-list{margin:0;padding:0;list-style:none}.phase-list{display:flex;position:relative}.phase-list:before{content:"";background:var(--line-soft);height:2px;position:absolute;top:10px;left:12.5%;right:12.5%}.phase-list li{z-index:1;color:var(--text-faint);text-align:center;flex-direction:column;flex:1;align-items:center;gap:7px;font-size:11px;line-height:1.2;display:flex;position:relative}.phase-marker{border:1.5px solid var(--line-strong);background:var(--surface-paper);width:22px;height:22px;color:var(--text-faint);font-family:var(--font-mono);border-radius:50%;place-items:center;font-size:11px;font-weight:700;display:grid}.phase-list .is-active{color:var(--echo-strong);font-weight:700}.phase-list .is-active .phase-marker{border-color:var(--echo);background:var(--echo);color:#fff;box-shadow:0 0 0 4px #0ea5e929}.phase-hint{color:var(--text-secondary);text-align:center;margin:10px 0 0;font-size:11.5px;line-height:1.5}.echo-card{background:#0ea5e912;border:1px solid #0ea5e959;border-radius:12px;padding:14px}.echo-title{color:var(--echo-strong);align-items:center;gap:7px;margin:0 0 11px;font-size:12px;font-weight:800;display:flex}.echo-title span{background:var(--echo);border-radius:50%;width:7px;height:7px;animation:1.6s infinite softPulse}.echo-card>p:not(.echo-title){color:var(--text-secondary);margin:0;font-size:12px}.echo-list{gap:8px;display:grid}.echo-item{align-items:center;gap:9px;min-width:0;font-size:14px;font-weight:500;display:flex}.echo-square{color:var(--text-primary);background:#ffffffb8;border:1px solid #d8cbac;border-radius:6px;padding:4px 9px}.echo-target-square{border-style:dashed;border-color:var(--owner-echo);color:var(--owner-echo-strong)}.echo-symbol{color:var(--owner-echo);font-size:18px}.echo-badge{background:var(--owner-echo);color:#fff;font-family:var(--font-body);white-space:nowrap;border-radius:20px;margin-left:auto;padding:3px 8px;font-size:10.5px;font-weight:800}.echo-win .echo-badge{background:var(--danger)}.event-section{border-top:1px solid var(--line-soft);flex:1;width:100%;min-height:0;padding-top:13px}.notation-heading{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:9px;display:flex}.notation-heading .panel-label{color:var(--text-primary);font-family:var(--font-body);letter-spacing:0;margin-bottom:0;font-size:12px;font-weight:800}.notation-counts{color:var(--text-muted);flex-wrap:wrap;flex:168px;justify-content:flex-end;gap:12px;margin-left:auto;font-size:11px;display:flex}.notation-counts span{white-space:nowrap;align-items:center;gap:5px;display:flex}.mini-stone{width:11px;height:11px}.event-list{flex-direction:column;gap:1px;font-size:12px;display:flex}.event-list li{min-width:0;color:var(--text-secondary);border-radius:6px;grid-template-columns:18px 11px 1fr;align-items:center;gap:9px;padding:6px 8px;line-height:1.35;display:grid}.event-list li>span:last-child{overflow-wrap:anywhere;min-width:0}.event-list .is-latest{color:var(--echo-strong);background:#0ea5e91a}.event-number{color:inherit}.event-section>p{color:var(--text-secondary);margin:0;font-size:12px;line-height:1.5}.result-panel{border-top:1px solid var(--line-soft);gap:12px;padding-top:13px;display:grid}.result-panel h2{font-family:var(--font-display);margin:0;font-size:28px}.result-panel p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.result-actions{flex-wrap:wrap;gap:10px;display:flex}.result-card{--result-echo:var(--echo-white);--result-echo-strong:var(--echo-white-strong);--result-echo-rgb:var(--echo-white-rgb);border:1px solid var(--line-soft);text-align:center;background:#fbf6ead1;border-radius:10px;justify-items:center;width:100%;padding:24px 18px 18px;display:grid;box-shadow:0 12px 28px #2e262014}.result-card-black{--result-echo:var(--echo-black);--result-echo-strong:var(--echo-black-strong);--result-echo-rgb:var(--echo-black-rgb)}.result-card-won{border-color:rgba(var(--result-echo-rgb), .32)}.result-kicker{color:var(--text-faint);font-family:var(--font-mono);letter-spacing:.14em;margin:0;font-size:10px;line-height:1.5}.result-emblem{justify-content:center;align-items:center;height:92px;margin-top:10px;margin-bottom:2px;display:flex;position:relative}.result-stone{z-index:1;border-radius:50%;place-items:center;width:58px;height:58px;display:grid;position:relative;box-shadow:0 6px 13px #140c0452}.result-stone-white,.result-draw-stone.result-stone-white{background:radial-gradient(circle at 36% 30%,#fffdf7,#e2d6bb);border:1px solid #d8cbac}.result-stone-black,.result-draw-stone.result-stone-black{background:radial-gradient(circle at 36% 30%,#564e46,#2a241f 55%,#100c09)}.result-stone .echo-ripple{z-index:-1;border-color:rgba(var(--owner-echo-rgb), .9);width:60px}.result-nucleus-mark{z-index:2;color:#f4edda;border:2px solid;border-radius:3px;width:22px;height:22px;position:relative;transform:rotate(45deg)}.result-stone-white .result-nucleus-mark{color:#4f463b}.result-draw-stone{border-radius:50%;width:48px;height:48px;box-shadow:0 6px 13px #4634183d}.result-equals{color:var(--draw);font-family:var(--font-mono);margin:0 14px;font-size:22px}.result-card h2{font-family:var(--font-display);margin:0;font-size:42px;font-weight:800;line-height:1}.result-reason{border:1px solid rgba(var(--result-echo-rgb), .35);background:rgba(var(--result-echo-rgb), .1);color:var(--result-echo-strong);border-radius:20px;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin:15px 0 0;padding:7px 12px;font-size:12.5px;font-weight:700;line-height:1.45;display:inline-flex}.result-reason span{color:inherit;font-weight:600}.result-reason-draw{border-color:var(--line-soft);color:var(--text-secondary);background:#2e26200d}.result-card .result-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:100%;margin-top:22px;display:grid}.result-card .result-actions>button{min-width:0;padding-inline:10px}.result-card-won .primary-button{border-color:var(--result-echo-strong);background:var(--result-echo);box-shadow:0 10px 24px rgba(var(--result-echo-rgb), .2)}.result-card-won .primary-button:focus-visible{outline-color:rgba(var(--result-echo-rgb), .34)}@media (width>=1101px){.play-topbar{grid-template-columns:var(--board-size) var(--info-width);column-gap:var(--play-gap);justify-content:start;display:grid}.play-topbar-actions{justify-content:space-between;width:100%}}.dialog-backdrop{z-index:20;background:#2e26205c;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.confirm-dialog{border:1px solid var(--line-strong);background:var(--surface-raised);width:min(360px,100%);color:var(--text-primary);border-radius:8px;padding:24px;box-shadow:0 18px 44px #2e26203d}.dialog-kicker{color:var(--text-faint);font-family:var(--font-body);letter-spacing:0;margin:0 0 8px;font-size:11px;font-weight:600}.confirm-dialog h2{margin:0;font-size:20px;line-height:1.35}.confirm-dialog p:not(.dialog-kicker){color:var(--text-secondary);margin:10px 0 0;font-size:13px;line-height:1.65}.dialog-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:22px;display:grid}.dialog-actions button{width:100%}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}@keyframes echoRipple{0%{opacity:.68;transform:translate(-50%,-50%)scale(.55)}to{opacity:0;transform:translate(-50%,-50%)scale(2.6)}}@keyframes softPulse{0%,to{opacity:.45}50%{opacity:1}}@media (prefers-reduced-motion:reduce){.echo-ripple,.echo-title span,.lobby-echo-ripple{animation:none}.echo-ripple{opacity:.42;transform:translate(-50%,-50%)scale(1.4)}.lobby-echo-ripple{opacity:.22;transform:translate(-50%,-50%)scale(1.9)}}@media (width<=1100px){.play-shell{--board-size:clamp(320px, min(calc(100vw - 56px), calc(100dvh - 300px)), 520px);width:min(100%,620px);padding:22px 20px 32px}.play-content{flex-direction:column;align-items:center;gap:16px;display:flex}.info-column{flex-basis:auto;width:100%;display:contents}.side-panel{order:1;width:100%}.board-area{order:2;width:100%;margin-top:4px}.event-section{order:3;width:100%}.side-panel-result{order:3}.side-panel-result+.event-section{order:4}}@media (width<=560px){.lobby-shell,.difficulty-shell,.rules-shell,.play-shell{min-height:100dvh;padding:14px 16px 20px}.lobby-copy,.difficulty-copy,.rules-copy{padding:32px 24px}.lobby-copy{padding:0}.lobby-shell{align-content:center;place-items:center;padding-top:24px;padding-bottom:28px}.lobby-meta{margin-bottom:34px}.rules-comparison div{grid-template-columns:1fr;gap:4px}.play-topbar{align-items:center;gap:12px;margin-bottom:12px}.play-brand{flex-wrap:wrap;gap:8px 10px}.play-brand h1{font-size:24px}.play-brand>span{letter-spacing:.1em;font-size:10px}.mode-pill{padding:4px 9px;font-size:10px}.play-topbar-actions{flex-wrap:wrap;justify-content:flex-end}.play-lobby-button{min-height:32px;padding:0 11px;font-size:11px}.play-shell{--board-size:clamp(260px, min(calc(100vw - 56px), calc(100dvh - 360px)), 430px)}.info-column{display:contents}.side-panel{order:1;gap:10px;width:100%}.board-area{order:2;width:100%;margin-top:4px}.event-section{order:3;width:100%}.side-panel-result{order:3}.side-panel-result+.event-section{order:4}.status-card{min-height:50px;padding:9px 12px}.status-card h2{font-size:15px}.panel-label{margin-bottom:8px}.phase-list li{gap:5px;font-size:10px}.phase-marker{width:20px;height:20px;font-size:10px}.phase-list:before{top:9px}.phase-hint{margin-top:8px;font-size:11px}.echo-card{padding:12px}.echo-title{margin-bottom:8px}.echo-item{flex-wrap:wrap}.echo-badge{margin-left:0}.event-section{padding-top:10px}}:root{font-family:var(--font-body);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text-primary);background:var(--surface-paper);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--font-display:"Nanum Myeongjo", Georgia, "Times New Roman", serif;--font-body:"Gothic A1", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"Spline Sans Mono", ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;--surface-paper:#f1e9d6;--surface-raised:#fbf6ea;--surface-board-light:#f4edda;--surface-board-mid:#e8dec4;--surface-board-deep:#ddd0b2;--line-soft:#ddd0b2;--line-strong:#ccbb9a;--text-primary:#2e2620;--text-secondary:#6b5d4a;--text-muted:#8a7c66;--text-faint:#a3947f;--echo-white:#0ea5e9;--echo-white-strong:#0a85bd;--echo-white-rgb:14, 165, 233;--echo-black:#f97316;--echo-black-strong:#c2410c;--echo-black-rgb:249, 115, 22;--echo:var(--echo-white);--echo-strong:var(--echo-white-strong);--owner-echo:var(--echo-white);--owner-echo-strong:var(--echo-white-strong);--owner-echo-rgb:var(--echo-white-rgb);--draw:#a39684;--danger:#b84a3a;--success:#2f8f5b;--stone-size:56px;--stone-white:radial-gradient(circle at 36% 30%, #fffdf7 0%, #f4ecda 55%, #e2d6bb 100%);--stone-black:radial-gradient(circle at 36% 30%, #564e46 0%, #2a241f 55%, #100c09 100%);--nucleus-mark-size:19px;--echo-ring-size:56px;--echo-ring-border:1.6px;--echo-ring-duration:2.8s}*{box-sizing:border-box}body{background:linear-gradient(#ffffff2e, #fff0), var(--surface-paper);margin:0}button,input,textarea,select{font:inherit}
