.player-avatar[data-v-554c89a3]{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:50%;overflow:hidden;line-height:0}.player-avatar[data-v-554c89a3] svg{width:100%;height:100%}.player-avatar--interactive[data-v-554c89a3]{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;box-shadow:0 2px 6px #0000001f}.player-avatar--interactive[data-v-554c89a3]:hover{transform:scale(1.12);box-shadow:0 4px 12px #0000002e}.player-avatar--interactive[data-v-554c89a3]:active{transform:scale(.95)}.overlay-enter-active[data-v-2bca9e16],.overlay-leave-active[data-v-2bca9e16]{transition:opacity .2s ease}.overlay-enter-from[data-v-2bca9e16],.overlay-leave-to[data-v-2bca9e16]{opacity:0}.banner-enter-active[data-v-2bca9e16],.banner-leave-active[data-v-2bca9e16]{transition:transform .22s ease}.banner-enter-from[data-v-2bca9e16],.banner-leave-to[data-v-2bca9e16]{transform:translate(-50%) translateY(100%)}.notice-banner[data-v-2bca9e16]{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:600;cursor:pointer;animation:slideInNotice-2bca9e16 .24s ease}.notice-banner--success[data-v-2bca9e16]{background:#d1fae5;color:#065f46;border-left:4px solid #10B981}.notice-banner--error[data-v-2bca9e16]{background:#fee2e2;color:#991b1b;border-left:4px solid #EF4444}.notice-banner--info[data-v-2bca9e16]{background:#dbeafe;color:#1e40af;border-left:4px solid #3B82F6}.notice-icon[data-v-2bca9e16]{font-size:1rem;font-weight:800;flex-shrink:0}.notice-close[data-v-2bca9e16]{margin-left:auto;background:none;border:none;color:inherit;cursor:pointer;font-size:.875rem;opacity:.6;padding:0 4px}.notice-close[data-v-2bca9e16]:hover{opacity:1}.notice-enter-active[data-v-2bca9e16]{transition:all .2s ease}.notice-leave-active[data-v-2bca9e16]{transition:all .16s ease}.notice-enter-from[data-v-2bca9e16],.notice-leave-to[data-v-2bca9e16]{opacity:0;transform:translateY(-8px)}.user-badge[data-v-2bca9e16]{font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:var(--radius-sm, 6px);background:#e0f2fe;color:#0369a1;border:2px solid #0EA5E9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;box-shadow:1px 1px 0 var(--color-fg, #0F172A)}.user-badge--guest[data-v-2bca9e16]{background:#fef3c7;color:#92400e;border-color:#f59e0b}@keyframes slideInNotice-2bca9e16{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}.top-actions a[data-v-2bca9e16],.tab-bar a[data-v-2bca9e16]{text-decoration:none;color:inherit}:root{--color-bg: #FFFBEB;--color-fg: #0F172A;--color-primary: #78716C;--color-accent: #D97706;--color-hit: #DC2626;--color-valid: #16A34A;--color-drag: #D97706;--color-miss: #A8A29E;--color-blue-pen: #2D5DA1;--color-postit: #FFF9C4;--color-card-bg: #FFFFFF;--color-line-blue: #BFDBFE;--color-win-bg: #DCFCE7;--color-lose-bg: #FEF2F2;--color-neutral-bg: #F3F4F6;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 16px;--radius-pill: 24px;--radius-full: 9999px;--shadow-sm: 2px 2px 0 var(--color-fg);--shadow-md: 3px 3px 0 var(--color-fg);--shadow-lg: 4px 4px 0 var(--color-fg);--shadow-xl: 5px 5px 0 var(--color-fg);--board-cell-bg: #FFFFFF;--board-hit-bg: #FEE2E2;--board-destroy-bg: #FEF2F2;--board-miss-bg: #F3F4F6}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100dvh;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5;color:var(--color-fg);background-color:var(--color-bg);background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,rgba(45,93,161,.12) 31px,rgba(45,93,161,.12) 32px),linear-gradient(90deg,transparent 0px,transparent 52px,rgba(220,38,38,.18) 52px,rgba(220,38,38,.18) 54px,transparent 55px);background-attachment:local;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}button,select,input,textarea{font:inherit}h1,h2,h3,h4,h5,h6,p,ol,ul{margin:0}h1{font-size:clamp(1.6rem,6vw,1.75rem);font-weight:700;line-height:1.15;color:var(--color-fg)}h2{font-size:1.125rem;font-weight:600;color:var(--color-fg)}h3{font-size:.9375rem;font-weight:600;color:var(--color-fg)}.eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-hit);margin-bottom:var(--space-1)}button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:48px;padding:var(--space-3) var(--space-5);font-size:.875rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;border:2px solid var(--color-fg);transition:transform 0ms,box-shadow 0ms;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:var(--color-postit);color:var(--color-fg);box-shadow:var(--shadow-md)}button:active{transform:translate(3px,3px);box-shadow:none}button:disabled{cursor:not-allowed;opacity:.4;pointer-events:none}button:focus-visible{outline:2px solid var(--color-blue-pen);outline-offset:2px}.btn-secondary{background:var(--color-bg);font-weight:500;box-shadow:var(--shadow-md)}.btn-danger{background:var(--color-lose-bg);color:var(--color-hit);box-shadow:var(--shadow-md)}.btn-sm{min-height:36px;padding:var(--space-2) var(--space-3);font-size:.8125rem;box-shadow:var(--shadow-sm)}.btn-sm:active{transform:translate(2px,2px);box-shadow:none}.btn-ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--color-primary);min-height:44px}.btn-ghost:active{transform:none;background:#0f172a0f}input[type=text],input[type=email],input[type=password],input[type=number],select,textarea{display:block;width:100%;min-height:44px;padding:var(--space-2) var(--space-3);background:var(--color-card-bg);color:var(--color-fg);border:2px solid var(--color-fg);border-radius:var(--radius-md);font-size:.875rem;transition:box-shadow .12s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}input:focus,select:focus,textarea:focus{outline:none;box-shadow:var(--shadow-sm)}input::placeholder{color:var(--color-miss)}label span{display:block;font-size:.8125rem;font-weight:600;color:var(--color-fg);margin-bottom:var(--space-1)}.card{background:var(--color-card-bg);border:2px solid var(--color-fg);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-3)}.card-notebook{background:var(--color-bg);border:2px solid var(--color-fg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-4)}.app-shell{display:flex;flex-direction:column;min-height:100dvh;max-width:520px;margin:0 auto;position:relative;padding-bottom:80px}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);min-height:52px;background:#fffbebeb;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-bottom:1px solid rgba(45,93,161,.15)}.topbar-title{font-size:1.0625rem;font-weight:700;color:var(--color-fg);letter-spacing:-.01em}.topbar-sub{font-size:.6875rem;color:var(--color-primary);margin-top:1px}.connection-dot{display:inline-block;width:7px;height:7px;border-radius:var(--radius-full);background:var(--color-miss);vertical-align:middle;margin-right:var(--space-1);flex-shrink:0}.connection-dot--online{background:var(--color-valid)}.tab-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;height:72px;padding:var(--space-2) var(--space-5) calc(var(--space-4) + env(safe-area-inset-bottom,0px));background:var(--color-bg);border-top:1px solid rgba(45,93,161,.15);display:flex;justify-content:space-around;align-items:flex-start;z-index:60}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);width:60px;height:48px;font-size:.6875rem;font-weight:500;color:var(--color-primary);border-radius:var(--radius-pill);border:none;background:transparent;box-shadow:none;min-height:unset;padding:6px var(--space-3);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .12s ease,background .12s ease}.tab-item:active{transform:none;box-shadow:none}.tab-item--active{background:var(--color-fg);color:var(--color-bg);font-weight:600;width:72px}.tab-item__icon{font-size:1.25rem;line-height:1}.content-area{flex:1;padding:var(--space-4) var(--space-4) var(--space-3);overflow-y:auto;-webkit-overflow-scrolling:touch}.notice-banner{background:var(--color-postit);border:2px solid var(--color-fg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-3) var(--space-4);font-size:.875rem;font-weight:600;color:var(--color-fg);margin-bottom:var(--space-3)}.error-text{color:var(--color-hit);font-size:.875rem;font-weight:600}.lobby-panel{display:flex;flex-direction:column;gap:var(--space-4)}.lobby-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.lobby-stats{display:flex;gap:var(--space-4);font-size:.8125rem;color:var(--color-primary);flex-wrap:wrap}.lobby-stats strong{color:var(--color-fg);font-weight:700}.create-room-form{background:var(--color-card-bg);border:2px solid var(--color-fg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.create-room-form label{display:grid;gap:var(--space-1)}.room-list{display:flex;flex-direction:column;gap:var(--space-3)}.room-row{background:var(--color-card-bg);border:2px solid var(--color-fg);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-3) var(--space-4);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.room-row-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.room-name{font-size:.9375rem;font-weight:700;color:var(--color-fg);display:flex;align-items:center;gap:var(--space-2)}.room-lock-icon{font-size:.75rem;opacity:.65}.room-meta{font-size:.75rem;color:var(--color-primary)}.room-players{font-size:.6875rem;color:var(--color-miss)}.compact-input{display:grid;gap:var(--space-1)}.status-strip{background:var(--color-card-bg);border:2px solid var(--color-fg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-3) var(--space-4);display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-3)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px 10px;border-radius:var(--radius-pill);border:2px solid var(--color-fg);background:var(--color-neutral-bg);font-size:.75rem;font-weight:700}.status-badge--waiting{background:var(--color-line-blue)}.status-badge--ready{background:var(--color-win-bg)}.status-badge--playing{background:var(--color-postit)}.status-badge--finished{background:var(--color-neutral-bg)}.match-meta{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap;font-size:.8125rem;color:var(--color-primary);padding:var(--space-2) 0 var(--space-3)}.match-meta strong{color:var(--color-fg);font-weight:700}.timer{display:inline-flex;align-items:center;gap:var(--space-1);font-size:1.125rem;font-weight:700;color:var(--color-fg)}.timer--urgent{color:var(--color-hit);animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.55}}.room-code-card{background:var(--color-postit);border:3px solid var(--color-fg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-5);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.room-code-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary)}.room-code-value{font-size:2rem;font-weight:700;letter-spacing:.2em;color:var(--color-fg);font-family:JetBrains Mono,Courier New,monospace}.boards{display:grid;grid-template-columns:1fr;gap:var(--space-5);margin-bottom:var(--space-4)}@media(min-width:640px){.boards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.boards{grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-6)}}.board-panel{min-width:0}.board-panel h2{font-size:.875rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.board-svg{display:block;width:100%;aspect-ratio:1;background:var(--color-card-bg);border:2px solid var(--color-fg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);touch-action:manipulation}.board-cell{fill:#fff;stroke:var(--color-line-blue);stroke-width:.8;outline:none;transition:fill 80ms ease}.board-cell-clickable{cursor:pointer}.board-cell-clickable:hover,.board-cell-clickable:focus{fill:#fef3c7;stroke:var(--color-accent);stroke-width:1.2;outline:none}.board-cell-clickable:active{fill:#fde68a}.board-cell-hit{fill:#fee2e2}.board-cell-miss{fill:#f3f4f6}.board-cell-destroy{fill:#fef2f2}.labels{fill:var(--color-primary);font-size:9px;font-family:Inter,system-ui,sans-serif;font-weight:500}.attack-mark{font-size:13px;font-weight:800;pointer-events:none;dominant-baseline:middle;text-anchor:middle}.attack-miss{fill:var(--color-miss)}.attack-hit,.attack-destroy,.attack-win{fill:var(--color-hit)}.plane-layer{pointer-events:none}.plane-cell{stroke-width:1.5}.plane-head{stroke-width:2.5}.plane-destroyed{opacity:.3;stroke-dasharray:3 2}.plane-variant-0{fill:#dcfce7;stroke:#16a34a}.plane-variant-1{fill:#fef3c7;stroke:#d97706}.plane-variant-2{fill:#dbeafe;stroke:#2d5da1}.plane-variant-3{fill:#fce7f3;stroke:#db2777}.controls{display:flex;flex-wrap:wrap;gap:var(--space-3);margin:var(--space-3) 0}.message-grid{display:grid;gap:var(--space-4)}.messages-panel{background:var(--color-card-bg);border:2px solid var(--color-fg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.messages-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid rgba(45,93,161,.15);display:flex;flex-direction:column;gap:var(--space-2)}.messages-heading-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.message-filter{display:flex;gap:var(--space-2);background:var(--color-neutral-bg);border-radius:var(--radius-pill);padding:3px}.message-filter button{min-height:30px;padding:2px var(--space-3);font-size:.75rem;font-weight:600;border:none;border-radius:var(--radius-pill);background:transparent;color:var(--color-primary);box-shadow:none}.message-filter button.active{background:var(--color-fg);color:var(--color-bg)}.message-filter button:active{transform:none}.emoji-row{display:flex;gap:var(--space-2);flex-wrap:wrap}.emoji-row button{min-height:36px;min-width:44px;padding:0 var(--space-2);font-size:.875rem;box-shadow:var(--shadow-sm);font-family:system-ui}.messages-list{display:flex;flex-direction:column;gap:var(--space-2);list-style:none;margin:0;padding:var(--space-3) var(--space-4);max-height:220px;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(15,23,42,.1) transparent}.messages-list::-webkit-scrollbar{width:4px}.messages-list::-webkit-scrollbar-thumb{background:#0f172a1f;border-radius:2px}.message-row{display:flex;width:100%}.message-own{justify-content:flex-end}.message-other{justify-content:flex-start}.message-system-row{justify-content:center}.message-bubble{display:grid;gap:3px;max-width:min(76%,320px);border:2px solid var(--color-fg);border-radius:var(--radius-md);background:var(--color-bg);padding:var(--space-2) var(--space-3);box-shadow:var(--shadow-sm);overflow-wrap:anywhere;font-size:.875rem}.message-attack{background:var(--color-postit)}.message-emoji{font-weight:700;font-size:1rem}.message-system{max-width:min(90%,360px);border-color:var(--color-blue-pen);background:#eff6ff;color:var(--color-blue-pen);font-size:.8125rem}.message-meta{color:var(--color-miss);font-size:.6875rem;justify-self:end}.settings-panel{display:flex;flex-direction:column;gap:var(--space-5)}.settings-card{background:var(--color-card-bg);border:2px solid var(--color-fg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.settings-grid{display:flex;flex-direction:column;gap:var(--space-3)}.settings-grid label,.auth-panel label{display:grid;gap:var(--space-1)}.auth-panel{display:flex;flex-direction:column;gap:var(--space-3)}.checkbox-line{grid-template-columns:auto 1fr;align-items:center;gap:var(--space-2)!important}.checkbox-line input[type=checkbox]{width:18px;height:18px;min-height:unset;accent-color:var(--color-fg);cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding-bottom:80px;background:#0f172a8c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-card{width:calc(100% - 32px);max-width:420px;border:3px solid var(--color-fg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-6) var(--space-5);display:flex;flex-direction:column;align-items:center;gap:var(--space-4);animation:modal-slide-up .24s cubic-bezier(.34,1.56,.64,1);text-align:center}@keyframes modal-slide-up{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-card--win{background:var(--color-win-bg)}.modal-card--lose{background:var(--color-lose-bg)}.modal-emoji{font-size:3rem;line-height:1}.modal-title{font-size:1.5rem;font-weight:700;color:var(--color-fg)}.modal-subtitle{font-size:.9375rem;color:var(--color-primary)}.modal-actions{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center;width:100%}.reconnect-banner{position:fixed;bottom:72px;left:50%;transform:translate(-50%);width:100%;max-width:520px;height:64px;background:var(--color-fg);padding:0 var(--space-4);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);z-index:90;animation:banner-slide-up .22s ease}@keyframes banner-slide-up{0%{transform:translate(-50%) translateY(100%)}to{transform:translate(-50%) translateY(0)}}.reconnect-left{display:flex;align-items:center;gap:var(--space-3)}.reconnect-spinner{font-size:1.25rem;animation:spin 1.5s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reconnect-title{font-size:.875rem;font-weight:700;color:var(--color-bg)}.reconnect-sub{font-size:.75rem;color:#fffbeba6}.reconnect-btn{background:var(--color-accent);color:var(--color-card-bg);border:none;border-radius:var(--radius-md);box-shadow:none;min-height:36px;padding:var(--space-2) var(--space-3);font-size:.8125rem;font-weight:700}.reconnect-btn:active{transform:scale(.96)}footer{padding:var(--space-5) var(--space-4);text-align:center;font-size:.6875rem;color:var(--color-miss);border-top:1px solid rgba(45,93,161,.1)}:focus-visible{outline:2px solid var(--color-blue-pen);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.timer--urgent{animation:none;color:var(--color-hit)}}@media(min-width:640px){.app-shell{max-width:720px;padding-bottom:0}.app-shell--room{max-width:1100px}.tab-bar{display:none}.top-actions{display:flex;gap:var(--space-2)}.content-area{padding:var(--space-5) var(--space-5) var(--space-4)}.topbar{padding:var(--space-4) var(--space-5)}}@media(min-width:1024px){.app-shell{max-width:960px}.app-shell--room{max-width:1300px}.content-area{padding:var(--space-6) var(--space-8) var(--space-5)}}@media(min-width:1440px){.app-shell--room{max-width:1500px}}@media(max-width:1023px)and (orientation:landscape){.app-shell{max-width:100%;padding-bottom:0}.topbar{min-height:40px;padding:var(--space-1) var(--space-4)}.tab-bar{display:none}.content-area{padding:var(--space-2) var(--space-4)}.boards{grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4);margin-bottom:var(--space-2)}.status-strip{padding:var(--space-1) var(--space-3);margin-bottom:var(--space-2);font-size:.8125rem}.match-meta{padding:var(--space-1) 0 var(--space-2);font-size:.75rem;gap:var(--space-2)}.controls{margin:var(--space-1) 0}.controls button{min-height:36px;padding:var(--space-1) var(--space-3);font-size:.8125rem}.messages-panel{border-radius:var(--radius-sm)}.messages-header{padding:var(--space-2) var(--space-3)}.messages-list{max-height:120px;padding:var(--space-2) var(--space-3)}.board-panel h2{font-size:.8125rem;margin-bottom:var(--space-1)}.opponent-status-banner{padding:var(--space-1) var(--space-3);font-size:.8125rem}}@media(max-width:639px){.app-shell--room.battle-focus .topbar,.app-shell--room.battle-focus .tab-bar,.app-shell--room.battle-focus footer{display:none!important}.app-shell--room.battle-focus{max-width:100%;padding-bottom:0}.app-shell--room.battle-focus .content-area{padding:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.app-shell--room.battle-focus .boards{grid-template-columns:1fr;gap:var(--space-2);margin-bottom:0}.app-shell--room.battle-focus .board-panel h2{font-size:.75rem;margin-bottom:var(--space-1);padding-left:var(--space-2)}.app-shell--room.battle-focus .board-svg{max-width:100%;border-radius:0;border-left:none;border-right:none}}.top-actions{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}
