.site-header-logo-container[data-astro-cid-3ef6ksr2]{display:flex;align-items:center}:root{--bg-color-a: #f8fafc;--bg-color-b: #f0fdf4;--card-bg: rgba(255, 255, 255, .7);--accent-color: #4f46e5;--secondary-accent: #059669;--text-color: #0f172a;--text-secondary: #475569;--danger-color: #e11d48;--success-color: #10b981;--border-color: rgba(0, 0, 0, .08);--shadow-soft: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06), 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-elevated: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--safe-area-inset-top: env(safe-area-inset-top, 0px);--shadow-color: rgba(79, 70, 229, .15);--radius-lg: 24px;--radius-md: 16px;--radius-sm: 8px;--control-height: 48px;--control-radius: var(--radius-sm);--control-padding-x: 16px;--secondary-action-height: 38px;--header-height: 40px;--header-padding-top: 12px;--footer-height: 80px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}button,a,.btn-action,.btn-warp,.line-badge,.warp-prefecture-btn,.autocomplete-item,.btn-mode-detailed,.btn-back-topleft{touch-action:manipulation}[x-cloak]{display:none!important}body{background-color:var(--bg-color-a);background-image:radial-gradient(circle at 2px 2px,rgba(79,70,229,.05) 1px,transparent 0),url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");background-size:32px 32px,150px 150px;background-blend-mode:normal,overlay;color:var(--text-color);font-family:Noto Sans JP,sans-serif;display:flex;justify-content:center;align-items:stretch;min-height:100dvh;transition:background-color .8s cubic-bezier(.4,0,.2,1);overflow-x:hidden;overflow-y:auto;position:relative}body.player-b-active{background-color:var(--bg-color-b)}#app{width:100%;max-width:500px;padding:15px;display:flex;flex-direction:column;gap:15px;min-height:calc(100dvh - 120px);justify-content:flex-start;padding-top:calc(var(--safe-area-inset-top) + 60px);padding-bottom:80px;overflow:visible}@media(min-width:851px){#app{max-width:900px;display:grid;grid-template-columns:1.2fr 300px;height:auto;overflow:visible}}@media(max-width:850px){body{align-items:flex-start;overflow-y:auto}#app{height:auto;min-height:100dvh;overflow:visible;padding-top:calc(var(--safe-area-inset-top) + 54px)}.main-panel{padding:16px 16px 24px}.history-box{max-height:300px}.main-panel .logo{font-size:1.2rem;margin-top:5px;margin-bottom:10px}.timer-wrapper{position:sticky;top:calc(var(--header-height) + var(--header-padding-top)*2);z-index:50;background:var(--card-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);margin:0 -25px;padding:8px 25px;border-bottom:1px solid var(--border-color)}}.main-panel{background:#ffffffb3;border-radius:var(--radius-lg);padding:22px 30px 30px;box-shadow:0 8px 32px 0 var(--shadow-color);border:1px solid rgba(255,255,255,.4);position:relative;z-index:10;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);transition:all .3s ease}.side-panel{display:flex;flex-direction:column;gap:20px}.logo{font-family:Noto Sans JP,sans-serif;font-size:2.8rem;font-weight:900;margin-bottom:2rem;text-align:center;background:linear-gradient(135deg,#5c67f2,#818cf8 40%,#10b981);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:10px;filter:drop-shadow(0 4px 12px rgba(92,103,242,.25))}.player-turn-chip{display:inline-flex;align-items:center;justify-content:center;padding:6px 20px;border-radius:50px;font-weight:700;font-size:.72rem;color:#fff;background:linear-gradient(135deg,#5c67f2,#818cf8);box-shadow:0 4px 14px #5c67f273;letter-spacing:1.5px;white-space:nowrap}.info-section{position:relative;text-align:center;margin:.5rem 0;background:#f8fafc80;padding:16px 18px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.label{font-size:.8rem;color:var(--text-secondary);font-weight:700;letter-spacing:1.5px;margin-bottom:.8rem;display:block}.current-station-label{text-align:left;padding-right:160px}.current-station{font-size:2.2rem;font-weight:700;margin-bottom:.2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.station-name-tag{background:#fff;color:#0f172a;padding:8px 16px 28px;border:3px solid #0f172a;border-radius:4px;position:relative;font-size:2.8rem;font-weight:900;letter-spacing:.1em;box-shadow:0 12px 24px #0000001a,0 4px 8px #0000000d;transition:all .3s cubic-bezier(.175,.885,.32,1.275);width:min(320px,100%);height:110px;display:flex;align-items:center;justify-content:center;overflow:hidden;white-space:normal;text-align:center;line-height:1.1;text-wrap:balance;word-break:keep-all;overflow-wrap:anywhere}.btn-return-title{line-height:1.15}.station-name-tag.text-md{font-size:2.2rem}.station-name-tag.text-sm{font-size:1.8rem}.station-name-tag.text-xs{font-size:1.4rem}.station-name-tag:before,.station-name-tag:after{content:"";position:absolute;left:-3.5px;right:-3.5px;height:9px;background:#00a651}.station-name-tag:before{top:0}.station-name-tag:after{bottom:0}.station-prefecture{font-size:.8rem;color:#0f172a;font-weight:700;margin:0;text-align:center;position:absolute;left:50%;bottom:18px;transform:translate(-50%);line-height:1;pointer-events:none;z-index:2}.line-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:4px}.line-badge{padding:5px 12px;border-radius:50px;font-size:.8rem;font-weight:500;background:#fff;color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;transition:all .15s ease;outline:none}@media(max-width:850px){.line-badges{gap:6px;margin-top:6px}.line-badge{padding:4px 10px;font-size:.76rem}.current-station-label{padding-right:144px}}.line-badge:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #5c67f233}.line-badge.selected{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 2px 8px #5c67f259}.line-badge.disabled{opacity:.35;cursor:not-allowed}.controls{display:flex;flex-direction:column;gap:10px}.input-wrapper{position:relative;width:100%}.input-wrapper input{width:100%;padding-right:44px}#clear-input-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#f1f5f9;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;z-index:5}#clear-input-btn:hover{background:#e2e8f0;color:var(--danger-color)}#clear-input-btn .material-icons{font-size:18px}.clear-input-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#f1f5f9;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;z-index:5}.clear-input-btn:hover{background:#e2e8f0;color:var(--danger-color)}.clear-input-btn .material-icons{font-size:18px}.input-group{display:flex;flex-direction:column;gap:10px;position:relative}.autocomplete-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:2px solid var(--border-color);border-radius:var(--radius-sm);max-height:300px;overflow-y:auto;z-index:1000;display:none;box-shadow:0 8px 24px #00000014}.autocomplete-dropdown.open{display:block}.autocomplete-item{padding:12px 16px;font-size:.95rem;cursor:pointer;border-bottom:1px solid var(--border-color)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item.highlighted{background:#f0f2ff;border-left:3px solid var(--accent-color);padding-left:13px}.candidate-list{display:flex;flex-direction:column;gap:0;margin-top:10px;padding:0;background:#fff;border-radius:12px;border:1px solid var(--border-color);max-height:200px;overflow-y:auto;box-shadow:0 4px 12px #0000000d}.candidate-item{padding:12px 16px;background:#fff;border-bottom:1px solid #f1f5f9;border-radius:0;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;color:var(--text-color)}.candidate-item:last-child{border-bottom:none}.candidate-item:hover{background:#f8fafc;color:var(--accent-color);transform:none}.candidate-item:before{content:"location_on";font-family:Material Icons;margin-right:10px;font-size:18px;color:var(--text-secondary)}.candidate-item:hover:before{color:var(--accent-color)}select,input{background:#fff;border:2px solid var(--border-color);color:var(--text-color);padding:0 var(--control-padding-x);border-radius:var(--control-radius);font-size:.95rem;font-weight:500;outline:none;transition:all .3s ease;width:100%;min-height:var(--control-height);line-height:1.2}select:focus,input:focus{border-color:var(--accent-color);box-shadow:0 0 0 4px #5c67f21a}.btn-action{background:linear-gradient(135deg,var(--accent-color),#6366f1);color:#fff;border:none;min-height:var(--control-height);padding:0 var(--control-padding-x);border-radius:var(--control-radius);font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px var(--shadow-color);display:flex;align-items:center;justify-content:center;gap:8px}.btn-secondary{min-height:var(--control-height);padding:0 var(--control-padding-x);border:1px solid #cbd5e1;border-radius:var(--control-radius);background:#f8fafc;color:#334155;font-size:1rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1;cursor:pointer}.btn-action:active{transform:scale(.96);filter:brightness(.9)}.btn-action:hover{transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 8px 24px var(--shadow-color)}.move-error{color:var(--danger-color);font-size:.85rem;font-weight:500;min-height:1.2em;padding:0 4px}.timer-wrapper{display:flex;align-items:center;gap:15px;margin-bottom:20px}.game-timers-row{display:flex;position:sticky;top:var(--header-height);align-items:flex-end;gap:12px;margin-top:-10px;margin-bottom:14px;padding:10px 0;width:100%;z-index:100;background:#fffffff2}.timer-column{display:flex;flex-direction:column;gap:4px}.timer-column.global{flex:2}.timer-column.turn{flex:1}.timer-label-tiny{font-size:.65rem;color:var(--text-secondary);font-weight:700;margin-left:2px;letter-spacing:.02em}.global-timer-bar-container{display:flex;align-items:center;gap:4px;background:transparent;padding:0}.global-timer-icon{display:flex;align-items:center;justify-content:center;width:28px}.global-timer-icon .material-icons{font-size:24px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.2))}.global-timer-icon.left{color:#fbbf24}.global-timer-icon.right{color:#f59e0b}.global-timer-gauge-wrapper{flex-grow:1;height:30px;background:#e2e8f0;border-radius:6px;position:relative;overflow:hidden;border:2px solid #64748b;box-shadow:inset 0 2px 4px #0000001a}.global-timer-gauge-fill{height:100%;background:linear-gradient(90deg,#86efac,#22c55e);width:100%;transition:width 1s linear}.global-timer-text-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:Orbitron,sans-serif;font-weight:700;font-size:1.1rem;color:#1e293b;text-shadow:0 1px 0 rgba(255,255,255,.4);letter-spacing:.05em;z-index:2}.digital-board-style{display:flex;align-items:center}.digital-timer-display{background:#1e293b;width:100%;height:30px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:2px solid #334155;box-shadow:0 4px 6px #0000001a;text-align:center}.digital-timer-display span{font-family:Orbitron,monospace;font-size:1.4rem;font-weight:700;color:#4ade80;text-shadow:0 0 8px rgba(74,222,128,.5);display:block;line-height:1}.digital-timer-display.danger{border-color:#ef4444;animation:borderFlash .5s infinite alternate}.digital-timer-display.danger span{color:#ef4444;text-shadow:0 0 12px rgba(239,68,68,.8);animation:textFlash .2s infinite alternate}@keyframes borderFlash{0%{box-shadow:0 0 2px #ef444433}to{box-shadow:0 0 8px #ef444499}}@keyframes textFlash{0%{opacity:1}to{opacity:.7}}.timer-danger{background:linear-gradient(90deg,#ef4444,#b91c1c)!important;animation:timerPulse .5s ease-in-out infinite!important;box-shadow:0 0 15px #ef444499!important}.result-history{margin:10px 0 0}.result-history-title{font-size:.78rem;font-weight:700;color:var(--text-secondary);margin-bottom:6px;padding:0 2px;text-align:left}.result-history-list{max-height:120px;overflow-y:auto;list-style:none;border:1px solid var(--border-color);border-radius:10px;padding:6px 10px;font-size:.8rem;color:var(--text-color);margin:0}.result-history-list li{padding:4px 0;border-bottom:1px solid var(--border-color);display:flex;gap:6px}.result-history-list li:last-child{border-bottom:none}.result-history-num{color:var(--text-secondary);min-width:22px;font-size:.74rem}.timer-container{flex-grow:1;height:14px;background:#0000000f;border-radius:7px;overflow:hidden;box-shadow:inset 0 1px 3px #00000014}#timer-bar{height:100%;width:100%;background:var(--success-color);transition:width 1s linear,background-color .3s ease;box-shadow:0 0 10px #48bb784d}.timer-success{background:var(--success-color)!important;box-shadow:0 0 10px #48bb784d!important}.timer-warning{background:#fbbf24!important;box-shadow:0 0 10px #fbbf244d!important}.timer-danger{background:var(--danger-color)!important;box-shadow:0 0 10px #ef444480!important;animation:timerPulse .5s ease-in-out infinite!important}@keyframes timerPulse{0%,to{box-shadow:0 0 8px #ef444466}50%{box-shadow:0 0 22px #ef4444cc}}.timer-text-box{font-family:Orbitron,sans-serif;font-size:1.4rem;font-weight:700;color:var(--text-color);min-width:44px;text-align:right;letter-spacing:-.02em}.history-box{background:var(--card-bg);border-radius:6px;border-radius:var(--radius-sm);padding:24px;box-shadow:var(--shadow-soft);border:1px solid var(--border-color);flex-grow:1;display:flex;flex-direction:column;max-height:400px}.history-list{list-style:none;overflow-y:auto;margin-top:10px;position:relative;padding-left:20px}.history-list:before{content:"";position:absolute;left:7px;top:10px;bottom:10px;width:2px;background:#e0e7ff}.history-item{position:relative;padding-bottom:12px;padding-left:10px;display:flex;flex-direction:column;gap:2px}.history-item:last-child{padding-bottom:0}.history-item:before{content:"";position:absolute;top:0;left:-20px;width:16px;height:16px;background:#fff;border:4px solid var(--accent-color);border-radius:50%;z-index:2}.history-item.player-b-item:before{border-color:var(--secondary-accent)}.history-item.warp-item:before{border-color:#f59e0b;box-shadow:0 0 8px #f59e0b66}.history-item.player-b-item{border-left-color:var(--secondary-accent)}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.history-header span:first-child{font-size:.625rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.history-header span:last-child{font-size:.75rem;color:#64748b;font-weight:500}.history-item>div:last-child{font-size:.875rem;font-weight:700;color:#0f172a;line-height:1.4}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffe6;backdrop-filter:blur(12px);display:flex;justify-content:center;align-items:flex-start;z-index:12000;visibility:hidden;opacity:0;transition:all .3s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:calc(var(--safe-area-inset-top) + var(--header-height) + var(--header-padding-top) + 20px) 0 20px}.modal.active{visibility:visible;opacity:1}#result-screen.modal{padding-top:calc(var(--safe-area-inset-top) + 48px)}@media(min-width:851px){#result-screen.modal{padding-top:calc(var(--safe-area-inset-top) + 52px)}}.modal-content{position:relative;background:#fff;padding:50px 30px;border-radius:var(--radius-lg);text-align:center;max-width:500px;width:92%;box-shadow:0 25px 50px -12px #0000001a;border:2px solid var(--border-color);margin:auto}.btn-back-topleft{position:absolute;top:20px;left:20px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:var(--radius-sm);padding:8px 16px;font-size:.875rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s ease;line-height:1}.btn-back-topleft:hover{background:#f1f5f9;color:#334155;border-color:#cbd5e1;transform:translate(-2px)}.modal-title{color:#000;font-size:2rem;margin-bottom:1rem;font-weight:700;text-align:center}.game-over-desc{font-size:.94rem;color:var(--text-secondary);margin-bottom:.95rem;line-height:1.5}.animate-pop{animation:pop .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes pop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.btn-give-up{background:none;color:var(--text-secondary);border:1px solid var(--border-color);height:var(--secondary-action-height);padding:0 10px;border-radius:var(--radius-sm);font-weight:500;font-size:.85rem;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;line-height:1}.btn-give-up:hover{background:#fff0f0;color:var(--danger-color);border-color:var(--danger-color)}.btn-warp{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;border:none;height:var(--secondary-action-height);padding:0 10px;border-radius:var(--radius-sm);font-weight:700;font-size:.84rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 10px #f59e0b4d;display:inline-flex;align-items:center;justify-content:center;gap:6px;line-height:1}.btn-warp .material-icons{font-size:16px;line-height:1}.btn-warp:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 8px 20px #f59e0b66}.btn-warp:disabled{background:var(--border-color);color:var(--text-secondary);cursor:not-allowed;box-shadow:none}#warp-overlay{position:fixed;inset:0;background:#ffffffeb;z-index:2000;display:none;justify-content:center;align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);opacity:0;transition:opacity .3s ease}#warp-overlay.active{display:flex;opacity:1}.warp-content{position:relative;text-align:center;padding:40px 32px;background:#fff;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #0000001f;border:2px solid var(--border-color);max-width:380px;width:90%}.warp-title{font-size:1.4rem;font-weight:700;margin-top:24px;margin-bottom:.4rem;color:var(--text-color)}.warp-subtitle{font-size:.85rem;color:var(--text-secondary);margin-bottom:1.8rem}.warp-prefectures{display:grid;grid-template-columns:1fr 1fr;gap:12px}.warp-prefecture-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:20px 12px;border-radius:var(--radius-md);font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d}.warp-prefecture-btn:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 8px 20px #667eea73;filter:brightness(1.1)}.history-item.warp-item{border-left-color:#f59e0b;background:#fffbeb}.mode-select{display:flex;flex-direction:column;gap:10px;width:100%;max-width:340px}.mode-section{width:100%;margin-bottom:10px;display:flex;flex-direction:column;gap:12px}.mode-section-title{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-align:left;margin-bottom:8px;padding-left:4px;letter-spacing:.5px}.mode-divider{height:1px;background:var(--border-color);margin:10px 0;width:100%}.btn-rules-link{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px 16px;border:1.5px solid var(--accent-color);border-radius:var(--radius-sm);color:var(--accent-color);font-weight:700;font-size:.95rem;text-decoration:none;transition:all .2s;margin-bottom:4px}.btn-rules-link:hover{background:var(--accent-color);color:#fff}.mode-row{display:flex;align-items:stretch;gap:8px;margin-bottom:10px}.btn-mode{flex-grow:1;display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 20px;font-size:1.05rem;text-align:center}.btn-info-circle{width:48px;background:#fff;color:var(--text-secondary);border:2px solid var(--border-color);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.btn-info-circle:hover{background:#f8fafc;color:var(--accent-color);border-color:var(--accent-color)}.btn-local{background:linear-gradient(135deg,#1e3a8a,#1e40af)}.btn-online-mode{background:linear-gradient(135deg,#10b981,#059669)}.btn-cpu{background:linear-gradient(135deg,#718096,#4a5568)}.mode-desc{font-size:.72rem;font-weight:400;opacity:.85}.btn-mode-detailed{display:flex;align-items:flex-start;padding:20px;background:#fff;border-radius:var(--radius-lg);border:1px solid #f1f5f9;box-shadow:0 2px 10px -3px #00000005;transition:all .3s ease;text-align:left;width:100%;cursor:pointer;overflow:hidden;position:relative;text-decoration:none}.btn-mode-detailed:hover{box-shadow:0 8px 30px #0000000f;border-color:#e0e7ff;transform:translateY(-2px)}.btn-mode-icon-box{width:48px;height:48px;background:#eef2ff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-right:16px;flex-shrink:0;transition:all .3s}.btn-mode-detailed:hover .btn-mode-icon-box{background:var(--accent-color)}.btn-mode-detailed:hover .btn-mode-icon-box .material-icons{color:#fff}.btn-mode-icon-box .material-icons{font-size:24px;color:var(--accent-color);transition:color .3s}#cpu-btn .btn-mode-icon-box{background:#f1f5f9}#cpu-btn .btn-mode-icon-box .material-icons{color:#64748b}#cpu-btn:hover .btn-mode-icon-box{background:#64748b}#cpu-btn:hover .btn-mode-icon-box .material-icons{color:#fff}#local-btn .btn-mode-icon-box{background:#dbeafe}#local-btn .btn-mode-icon-box .material-icons{color:#1e40af}#local-btn:hover .btn-mode-icon-box{background:#1e40af}#local-btn:hover .btn-mode-icon-box .material-icons{color:#fff}#online-btn .btn-mode-icon-box{background:#d1fae5}#online-btn .btn-mode-icon-box .material-icons{color:#059669}#online-btn:hover .btn-mode-icon-box{background:#059669}#online-btn:hover .btn-mode-icon-box .material-icons{color:#fff}#create-room-btn .btn-mode-icon-box{background:#d1fae5}#create-room-btn .btn-mode-icon-box .material-icons{color:#059669}#create-room-btn:hover .btn-mode-icon-box{background:#059669}#create-room-btn:hover .btn-mode-icon-box .material-icons{color:#fff}.btn-mode-content{flex:1}.btn-mode-title{font-size:1.05rem;font-weight:700;color:#0f172a;margin-bottom:2px;display:block}.btn-mode-subtitle{font-size:.8rem;color:#64748b;font-weight:500;line-height:1.4;display:block}.btn-mode-info-icon{color:#cbd5e1;transition:color .3s;margin-left:8px;flex-shrink:0}.btn-mode-info-icon .material-icons{font-size:20px}.btn-mode-detailed:hover .btn-mode-info-icon{color:var(--accent-color)}.modal-panel,.lobby-content{max-width:380px;width:92%;padding:36px}.tokoton-setup-content{text-align:left;max-height:calc(100dvh - var(--safe-area-inset-top) - var(--header-height) - var(--header-padding-top) - 40px);overflow-y:auto}.tokoton-setup-content .modal-selection-title,.tokoton-setup-content .cpu-difficulty-title{text-align:center}.tokoton-setup-content .input-button-row{align-items:stretch}.tokoton-setup-content .btn-action{min-height:var(--control-height);padding:0 var(--control-padding-x);border-radius:var(--control-radius);font-size:.95rem;line-height:1.2}.tokoton-setup-content .autocomplete-dropdown{text-align:left}#tokoton-autocomplete{position:static;top:auto;left:auto;right:auto;width:100%;margin-top:4px;max-height:min(32dvh,240px);z-index:20}.tokoton-input-hint{display:block;font-size:.85rem;color:var(--text-secondary);margin-top:-14px}.modal-panel-body,.lobby-body{display:flex;flex-direction:column;gap:12px;margin-top:18px}.divider-text{text-align:center;color:var(--text-secondary);font-size:.85rem}.join-row{display:flex;gap:10px}.room-code-input{flex:1;padding:14px 16px;border:2px solid #e2e8f0;border-radius:var(--radius-sm);font-size:1.2rem;text-transform:uppercase;text-align:center;letter-spacing:6px;font-weight:700;outline:none;transition:all .2s ease;background:#f8fafc}.room-code-input:focus{border-color:var(--accent-color);background:#fff;box-shadow:0 0 0 3px #6366f11a}.waiting-content{max-width:380px;width:92%;padding:36px;text-align:center}.waiting-label{font-size:.82rem;color:var(--text-secondary);font-weight:700}.room-code-wrapper{position:relative;display:block;width:100%}.room-code-display{font-size:2.8rem;font-weight:900;letter-spacing:12px;color:var(--accent-color);background:#f0f4ff;border-radius:var(--radius-sm);padding:14px 48px 14px 20px;margin:10px 0;width:100%;box-sizing:border-box}#copy-room-code-btn{position:absolute;top:50%;right:12px;transform:translateY(-50%);background:none;border:none;padding:6px;border-radius:8px;cursor:pointer;color:var(--accent-color);opacity:.55;transition:opacity .15s,background .15s;display:flex;align-items:center;justify-content:center;margin-top:5px}#copy-room-code-btn:hover{opacity:1;color:var(--accent-color)}#copy-room-code-btn.copied{opacity:1;color:#10b981}.btn-line-invite{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;padding:13px 0;background:#06c755;color:#fff;border:none;border-radius:4px;font-size:.95rem;font-weight:700;cursor:pointer;margin-bottom:16px;transition:opacity .15s;letter-spacing:.02em}.btn-line-invite:hover{opacity:.88}.waiting-status{color:var(--text-secondary);font-size:.9rem;margin-top:8px}.spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite;margin:16px auto 0}@keyframes spin{to{transform:rotate(360deg)}}.online-indicator{display:flex;justify-content:space-between;font-size:.75rem;font-weight:700;padding:6px 12px;border-radius:4px;background:#f0f4ff;margin-bottom:8px;color:var(--accent-color)}#opponent-turn-overlay{display:flex;position:absolute;inset:0;background:#0006;border-radius:8px;z-index:2000;cursor:wait;justify-content:center;align-items:flex-start;padding-top:22vh;pointer-events:auto}#opponent-status-text{background:#334155e6;color:#fff;font-size:.85rem;font-weight:700;padding:6px 16px;border-radius:50px;pointer-events:none;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:6px}#start-screen{width:100%;min-height:calc(100dvh - 120px);background:var(--bg-color-a);z-index:3000;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;overflow-y:visible;padding-top:60px;padding-bottom:80px}.start-content{width:100%;max-width:600px;display:flex;flex-direction:column;justify-content:center;align-items:center}.site-header{position:fixed;top:0;left:0;width:100%;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:var(--header-padding-top) 24px;border-bottom:1px solid var(--border-color);background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:13000}.site-header-logo{margin:0;font-family:Noto Sans JP,sans-serif;font-weight:900;font-size:1.15rem;background:linear-gradient(135deg,var(--accent-color),var(--secondary-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:4px}#app-logo{cursor:pointer;user-select:none}.site-header-desc{font-size:.72rem;color:var(--text-secondary);font-weight:500}.site-footer{position:relative;width:100%;min-height:50px;height:auto;padding:10px 16px;border-top:1px solid var(--border-color);background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);margin-top:auto;z-index:13000}.site-footer-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:6px}.site-footer-links a{font-size:.75rem;color:var(--accent-color);text-decoration:none;font-weight:500;transition:opacity .2s;white-space:nowrap}.site-footer-links a:hover{opacity:.8;text-decoration:underline}.site-footer-copy{font-size:.68rem;color:var(--text-secondary);text-align:center}.start-logo{font-size:4rem;font-weight:900;margin-bottom:1rem;background:linear-gradient(135deg,var(--accent-color),var(--secondary-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:12px;filter:drop-shadow(0 10px 15px rgba(0,0,0,.05))}#turn-overlay{position:fixed;inset:0;background:#ffffffe6;z-index:2500;display:none;justify-content:center;align-items:center;backdrop-filter:blur(10px);opacity:0;transition:opacity .3s ease}#turn-overlay.active{display:flex;opacity:1}.turn-message{font-size:2.5rem;font-weight:900;color:var(--text-color)}@keyframes slideFade{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-slide-up{animation:slideFade .6s cubic-bezier(.23,1,.32,1) forwards}#loading-overlay{position:fixed;inset:0;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:4000}.footer{grid-column:1 / -1;text-align:center;padding:20px;margin-top:20px;font-size:.8rem;color:var(--text-secondary);border-top:1px solid var(--border-color)}.game-stats-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:.78rem;font-weight:700;color:var(--text-secondary);margin-top:-2px;margin-bottom:6px;padding:0 4px}.game-meta-left{display:flex;align-items:center;gap:6px;min-width:0}.game-meta-right{display:flex;align-items:center;gap:8px;margin-left:auto}#turn-count-display{white-space:nowrap}.fault-label{color:var(--text-secondary)}.fault-player{padding:1px 6px;border-radius:4px;font-size:.74rem}.fault-a{background:#5c67f21f;color:var(--accent-color)}.fault-b{background:#10b9811f;color:var(--secondary-accent)}.fault-player.danger{background:#f5656526;color:var(--danger-color)}.score-bar{display:flex;justify-content:center;gap:24px;font-size:.82rem;font-weight:700;margin-bottom:12px;padding:0 4px}.score-bar .score-player{display:flex;align-items:center;gap:6px}.score-bar .score-label{color:var(--text-secondary)}.score-bar .score-value{font-size:1rem;font-weight:900}.score-bar .score-value.player-a{color:var(--accent-color)}.score-bar .score-value.player-b{color:var(--secondary-accent)}.mission-station-tag{position:absolute;top:6px;right:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:clamp(96px,22vw,122px);padding:6px 10px;border-radius:4px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;text-align:center;line-height:1;box-shadow:0 4px 12px #10b9814d;transform:rotate(4deg);z-index:5;animation:missionPop .5s cubic-bezier(.34,1.56,.64,1)}.mission-station-tag.cleared{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.mission-station-target{font-size:1.08rem;font-weight:900;display:inline-flex;flex-direction:column;align-items:center;line-height:1;max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mission-target-main{line-height:1}.mission-target-sub{margin-top:.14em;font-size:.64em;font-weight:700;line-height:1.05;opacity:.95}.mission-station-label-row{display:inline-flex;align-items:center;justify-content:center;gap:4px;line-height:1}.mission-station-label-row .material-icons{font-size:12px;line-height:1;opacity:.95}.mission-station-label{font-size:.56rem;font-weight:700;letter-spacing:.08em;opacity:.92;white-space:nowrap}@keyframes missionPop{0%{transform:scale(.8) rotate(-5deg);opacity:0}to{transform:scale(1) rotate(4deg);opacity:1}}@media(max-width:850px){.mission-station-tag{top:5px;right:8px;width:clamp(90px,28vw,112px);padding:5px 8px}.mission-station-target{max-width:152px;font-size:.94rem}}.point-popup{position:fixed;font-size:1.1rem;font-weight:900;color:var(--accent-color);pointer-events:none;z-index:9999;animation:pointFloat 1.2s ease forwards}@keyframes pointFloat{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-60px) scale(1.2)}}.result-score-section{display:flex;gap:10px;margin:10px 0;justify-content:center}.result-score-item{flex:1;max-width:140px;background:#f8fafc;border-radius:4px;padding:10px 12px;text-align:center;border:2px solid var(--border-color)}.result-score-item.winner{background:#fffbeb;border-color:#f59e0b}.result-score-player{display:block;font-size:.7rem;font-weight:700;color:var(--text-secondary);margin-bottom:2px;letter-spacing:1px}.result-score-value{font-size:1.35rem;font-weight:900}.result-score-value.player-a{color:var(--accent-color)}.result-score-value.player-b{color:var(--secondary-accent)}.result-buttons,.share-buttons{display:flex;gap:10px;margin:10px 0 6px}.share-divider{display:flex;align-items:center;text-align:center;margin:10px 0 6px}.share-divider:before,.share-divider:after{content:"";flex:1;height:1px;background:#000}.share-divider span{padding:0 12px;color:var(--text-secondary);font-weight:700;font-size:.75rem}.btn-share{flex:1;height:40px;padding:10px 8px;border:none;border-radius:var(--radius-sm);font-size:.88rem;font-weight:700;cursor:pointer;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:6px;line-height:1;white-space:nowrap}.btn-share:hover{opacity:.85}.support-buttons{display:flex;gap:10px;margin:10px 0 6px}.btn-share-ofuse{background:linear-gradient(135deg,#125f8c,#1a78aa);color:#fff;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:40px;padding:10px 8px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:700;transition:opacity .15s}.btn-share-ofuse:hover{opacity:.85}.ofuse-icon{width:20px;height:20px;object-fit:contain;background:#fffffff2;border-radius:999px;padding:2px}.btn-share-url{background:var(--accent-color, #5c67f2);color:#fff}.btn-share-url.copied{background:#10b981}.btn-share-x{background:#000;color:#fff}.btn-share-line{background:#06c755;color:#fff}.btn-share .material-icons{font-size:1.1rem}.share-icon-x,.share-icon-line{font-weight:700;font-size:1rem}.result-map-wrapper{position:relative}.result-map-canvas{height:240px;border-radius:16px;overflow:hidden;margin:12px 0}.result-ticket-wrap{margin:8px 0;text-align:left}.result-ticket-label{font-size:.8rem;font-weight:700;color:var(--text-secondary);margin-bottom:6px}.result-ticket{position:relative;background:#ccecf7;border:1px solid #94b8c9;border-radius:4px;padding:9px;overflow:hidden;box-shadow:2px 4px 10px #00000026}.result-ticket:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.1) 0,rgba(255,255,255,.1) 1px,transparent 1px,transparent 10px),repeating-linear-gradient(-45deg,rgba(255,255,255,.1) 0,rgba(255,255,255,.1) 1px,transparent 1px,transparent 10px);pointer-events:none}.result-ticket:after{content:"EKITORE EKITORE EKITORE EKITORE EKITORE EKITORE EKITORE EKITORE EKITORE EKITORE EKITORE EKITORE";position:absolute;top:-8px;left:-8px;width:220%;height:220%;font-size:13px;font-weight:700;color:#90cbe66b;transform:rotate(-15deg);transform-origin:top left;letter-spacing:2px;line-height:2.4;pointer-events:none}.result-ticket-content{position:relative;z-index:1}.result-ticket-punch-hole{position:absolute;left:-7px;bottom:30px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:inset -2px 0 3px #0000001f;z-index:3}.result-ticket-header{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:2px solid #1f2937;padding-bottom:4px;margin-bottom:8px}.result-ticket-header-left{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.result-ticket-company{font-size:1rem;font-weight:900;letter-spacing:.08em;color:#1f2937}.result-ticket-type{font-size:.7rem;font-weight:700;color:#334155;background:#fffc;border:1px solid #334155;border-radius:2px;padding:2px 5px}.result-ticket-date{font-size:.68rem;font-weight:700;color:#475569}.result-ticket-route{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;margin-bottom:8px;min-height:64px}.ticket-station-block{display:flex;flex-direction:column;min-width:0;align-items:center}.ticket-station-title{font-size:.66rem;font-weight:700;color:#475569;margin-bottom:2px}.ticket-station-name{font-size:clamp(1rem,4vw,2.15rem);font-weight:900;color:#0f172a;letter-spacing:.03em;line-height:1.05;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.ticket-station-pref{font-size:.68rem;font-weight:700;color:#475569;line-height:1.2;margin-top:2px;text-align:center}.ticket-route-arrow{font-size:clamp(1rem,3.6vw,1.6rem);font-weight:900;color:#1f2937;margin-top:14px}.result-ticket-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;background:#ffffff9e;border:1px solid #7ea6bb;border-radius:4px;padding:6px 8px}.result-ticket-stat{display:flex;flex-direction:column;gap:2px}.result-ticket-stat-label{font-size:.66rem;font-weight:700;color:#475569}.result-ticket-stat-value{font-size:1rem;font-weight:900;color:#0f172a}.result-ticket-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:8px;gap:8px;font-size:.65rem;color:#475569}.result-ticket-barcode{font-family:Courier New,monospace;letter-spacing:-.5px}.result-ticket-meta{font-size:.62rem;font-weight:700;text-align:right}.result-ticket-stamp{position:absolute;right:10px;bottom:8px;width:56px;height:56px;border:3px solid #dc2626;border-radius:999px;color:#dc2626;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.1;font-size:9px;font-weight:800;transform:rotate(-13deg);opacity:.86;box-shadow:inset 0 0 2px #dc262659}.result-ticket-stamp:after{content:"";position:absolute;inset:4px;border:1px solid #dc2626;border-radius:999px}@media(max-width:480px){.result-ticket{padding:10px}.result-ticket-stamp{width:54px;height:54px;font-size:9px;right:8px;bottom:8px}.result-ticket-footer{margin-top:6px}}.btn-expand-map{position:absolute;bottom:28px;right:10px;z-index:400;width:36px;height:36px;background:#1e1e32bf;border:none;border-radius:2px;font-size:1.2rem;line-height:1;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);box-shadow:0 2px 6px #0006;padding:0}.btn-expand-map:hover{background:#5c67f2e6}.map-fullscreen-overlay{display:none;position:fixed;inset:0;background:#000000eb;z-index:20000;flex-direction:column}.map-fullscreen-overlay.active{display:flex}.btn-close-map{position:absolute;top:16px;right:16px;z-index:20001;padding:8px 18px;background:#fff;border:none;border-radius:4px;font-size:.9rem;font-weight:700;cursor:pointer}#map-fullscreen-inner{flex:1;width:100%}.result-content{max-width:520px;margin-top:0;width:92%;padding:14px 18px 16px;background:#fff;border-radius:16px;text-align:center;box-shadow:0 25px 50px -12px #0000001a;border:2px solid var(--border-color);margin-bottom:36px}.result-content .modal-title{font-size:1.35rem;margin-bottom:.4rem;line-height:1.2}.score-breakdown{margin:12px 0 4px}.score-breakdown-table{width:100%;border-collapse:collapse;font-size:.82rem;color:var(--text-secondary)}.score-breakdown-table thead th{font-size:.72rem;font-weight:700;padding:4px 12px;text-align:center;border-bottom:1px solid var(--border-color)}.score-breakdown-table thead th:first-child{text-align:left}.score-breakdown-table th.breakdown-col-a{color:var(--accent-color)}.score-breakdown-table th.breakdown-col-b{color:var(--secondary-accent)}.score-breakdown-table tbody td{padding:4px 12px;text-align:center;border-bottom:1px solid #f0f0f0}.score-breakdown-table tbody td:first-child{text-align:left;color:var(--text-secondary);font-size:.75rem}.score-breakdown-table .breakdown-bonus{color:#10b981;font-weight:600}.result-stats{display:flex;flex-direction:row;gap:10px;margin:8px 0;justify-content:center;flex-wrap:nowrap}.stat-item{background:#f8fafc;border-radius:4px;padding:8px 12px;text-align:center;border:1px solid var(--border-color)}.stat-label{display:block;font-size:.7rem;color:var(--text-secondary);font-weight:700;margin-bottom:2px}.stat-value{font-size:1.05rem;font-weight:700;color:var(--text-color)}.toast-notification{position:fixed;top:-80px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:14px 28px;border-radius:4px;font-size:.9rem;font-weight:700;z-index:30000;box-shadow:0 8px 24px #ef444466;transition:top .4s cubic-bezier(.34,1.56,.64,1);max-width:90%;text-align:center;pointer-events:none}.toast-notification.show{top:24px}.btn-rematch{background:linear-gradient(135deg,#10b981,#059669)!important;margin-bottom:8px}.btn-rematch:hover{filter:brightness(1.1);box-shadow:0 8px 20px #10b9814d!important}.btn-rematch:disabled{background:var(--border-color)!important;color:var(--text-secondary)!important;cursor:not-allowed;box-shadow:none!important}.result-buttons .result-action{height:40px;font-size:.88rem;padding:10px 8px;border-radius:var(--radius-sm);gap:6px;line-height:1;white-space:nowrap}.result-buttons .result-action .material-icons{font-size:1rem}@media(max-width:480px){.result-content{width:94%;padding:12px 14px 14px}.result-map-canvas{height:210px;margin:10px 0}.result-ticket-company{font-size:.9rem}.ticket-station-name{font-size:clamp(1.25rem,5.2vw,2.4rem)}.result-ticket-stat-value{font-size:.9rem}.result-ticket-footer{font-size:.58rem}.result-ticket-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.result-ticket-stat{min-width:0}.result-ticket-stat-label{font-size:.62rem}}.modal-selection-title,.cpu-difficulty-title{font-size:1.1rem;font-weight:700;text-align:center;margin-top:24px;margin-bottom:20px;color:var(--text-color)}.modal-selection-buttons,.cpu-difficulty-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.btn-easy .btn-mode-icon-box{background:#d1fae5}.btn-easy .btn-mode-icon-box .material-icons{color:#059669}.btn-easy:hover .btn-mode-icon-box{background:#6ee7b7}.btn-easy:hover .btn-mode-icon-box .material-icons{color:#fff}.btn-normal .btn-mode-icon-box{background:#fef3c7}.btn-normal .btn-mode-icon-box .material-icons{color:#d97706}.btn-normal:hover .btn-mode-icon-box{background:#fcd34d}.btn-normal:hover .btn-mode-icon-box .material-icons{color:#fff}.btn-hard .btn-mode-icon-box{background:#fecdd3}.btn-hard .btn-mode-icon-box .material-icons{color:#e11d48}.btn-hard:hover .btn-mode-icon-box{background:#fda4af}.btn-hard:hover .btn-mode-icon-box .material-icons{color:#fff}.btn-oni .btn-mode-icon-box{background:#991b1b}.btn-oni .btn-mode-icon-box .material-icons{color:#fff}.btn-oni:hover .btn-mode-icon-box{background:#7f1d1d}.btn-oni:hover .btn-mode-icon-box .material-icons{color:#fff}.player-a-text{color:var(--accent-color)}.player-b-text{color:var(--secondary-accent)}.cpu-difficulty-badge{display:inline-flex;align-items:center;gap:4px;background:#334155;color:#fff;padding:2px 10px;border-radius:6px;font-size:.7rem;font-weight:700;margin:0 8px;text-transform:uppercase;letter-spacing:.5px}.cpu-difficulty-badge .material-icons{font-size:14px}.controls .label{display:block;margin-bottom:2px}.input-button-row{display:flex;gap:10px;align-items:stretch;width:100%}.input-button-row .input-wrapper{flex:1}.input-button-row #submit-move{height:var(--control-height);padding:0 var(--control-padding-x);border-radius:var(--control-radius)}.input-button-row #station-input,.input-button-row #tokoton-destination-input,.input-button-row #tokoton-start-btn{height:var(--control-height)}@media(max-width:850px){#tokoton-setup-modal{align-items:center;padding-top:calc(var(--safe-area-inset-top) + 8px);padding-bottom:calc(env(safe-area-inset-bottom,0px) + 8px)}#tokoton-setup-modal .modal-content{margin:0 auto;width:94%;max-height:calc(100dvh - var(--safe-area-inset-top) - 16px);overflow-y:auto;padding:20px 16px 16px}#tokoton-setup-modal .modal-panel-body{margin-top:14px}#tokoton-setup-modal .input-button-row{position:sticky;bottom:0;z-index:6;margin-top:8px;padding-top:10px;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 8px);background:linear-gradient(to bottom,#fff0,#fffffffa 22px)}#tokoton-destination-input,#station-input{font-size:16px}}.move-error{min-height:20px;margin-top:4px}#give-up-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px}#give-up-btn .material-icons{font-size:16px}.secondary-actions{display:flex;flex-direction:column;gap:4px;margin-top:2px}.mission-flash-overlay{position:fixed;inset:0;background:#0f172ae6;z-index:15000;display:none;flex-direction:column;justify-content:center;align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff}.mission-text-effect{font-size:1.2rem;font-weight:700;color:#94a3b8;letter-spacing:.5rem;margin-bottom:2rem;animation:slideInDown .8s cubic-bezier(.34,1.56,.64,1)}.mission-pref-effect{font-size:5rem;font-weight:900;color:#fff;text-shadow:0 0 30px rgba(79,70,229,.6);text-align:center;width:100%;word-break:keep-all;overflow-wrap:break-word;animation:zoomInBounce 1s .2s cubic-bezier(.34,1.56,.64,1) both}.mission-pref-effect.has-sub,.mission-flash-pref.has-sub{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}.mission-overlay-main{line-height:1}.mission-overlay-sub{margin-top:.16em;font-size:.42em;font-weight:700;opacity:.95;line-height:1.05}@keyframes zoomIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes zoomInBounce{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}@keyframes fadeInOut{0%{opacity:0}15%{opacity:1}85%{opacity:1}to{opacity:0}}@keyframes slideInDown{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}.siren-overlay{position:fixed;inset:0;pointer-events:none;z-index:9000;box-shadow:inset 0 0 #e11d4800;transition:box-shadow .5s ease;background:#ffffff0d}.siren-overlay.active{animation:siren-pulse .8s infinite alternate cubic-bezier(.4,0,.6,1)}@keyframes siren-pulse{0%{box-shadow:inset 0 0 60px #e11d481a,inset 40px 40px 80px #e11d481a,inset -40px -40px 80px #e11d481a,inset 40px -40px 80px #e11d481a,inset -40px 40px 80px #e11d481a}to{box-shadow:inset 0 0 120px #e11d4866,inset 60px 60px 120px #e11d484d,inset -60px -60px 120px #e11d484d,inset 60px -60px 120px #e11d484d,inset -60px 60px 120px #e11d484d}}.transfer-overlay{position:fixed;inset:0;background:#fffffff2;z-index:10000;display:none;flex-direction:column;justify-content:center;align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#0f172a;text-align:center}.transfer-overlay[data-player=A]{border:8px solid var(--accent-color)}.transfer-overlay[data-player=B]{border:8px solid var(--secondary-accent)}.transfer-details{text-align:center;padding:30px;background:#fffc;border:2px solid #e2e8f0;border-radius:4px;box-shadow:0 10px 30px #0000000d}.transfer-overlay.active{display:flex;animation:transferFadeInOut var(--transfer-duration, 1.5s) forwards}.transfer-title{font-size:1.5rem;font-weight:800;letter-spacing:.3rem;margin-bottom:.5rem}.transfer-overlay.active[data-player=A] .transfer-title{color:var(--accent-color);animation:transferSlideRight .5s cubic-bezier(.23,1,.32,1) forwards}.transfer-overlay.active[data-player=B] .transfer-title{color:var(--secondary-accent);animation:transferSlideLeft .5s cubic-bezier(.23,1,.32,1) forwards}.transfer-overlay.active .transfer-title.warp-mode{animation:warpParabolic .8s cubic-bezier(.34,1.56,.64,1) forwards;color:#f59e0b!important}@keyframes transferSlideRight{0%{transform:translate(-100px);opacity:0}30%{transform:translate(20px);opacity:1}to{transform:translate(0);opacity:1}}@keyframes transferSlideLeft{0%{transform:translate(100px);opacity:0}30%{transform:translate(-20px);opacity:1}to{transform:translate(0);opacity:1}}@keyframes warpParabolic{0%{transform:translate(-100px,50px) scale(.5);opacity:0}50%{transform:translateY(-30px) scale(1.2);opacity:1}to{transform:translate(0) scale(1);opacity:1}}.transfer-line-name{font-size:1.2rem;font-weight:700;margin-bottom:1rem;color:var(--text-secondary)}.transfer-overlay.active .transfer-line-name{animation:transferZoomIn .5s .1s both}.transfer-path{display:flex;align-items:center;gap:20px;margin-bottom:2rem}.transfer-overlay.active .transfer-path{animation:transferFadeInUp .5s .2s both}.transfer-station{font-size:2.2rem;font-weight:900;display:inline-flex;flex-direction:column;align-items:center;text-align:center;line-height:1.1;min-width:0}.transfer-station-name{display:block;word-break:keep-all;overflow-wrap:anywhere;text-wrap:balance}.transfer-station-prefecture{display:block;margin-top:4px;font-size:.8rem;font-weight:700;color:var(--text-secondary)}.transfer-arrow{font-size:2rem;color:var(--text-secondary)}.transfer-next-player{font-size:1.2rem;font-weight:700;padding:8px 24px;border-radius:4px;background:#ffffff1a;margin-top:1rem}.transfer-overlay.active .transfer-next-player{animation:transferFadeInUp .5s .3s both}.transfer-points{margin-top:1.5rem;display:flex;align-items:baseline;justify-content:center;gap:8px}.transfer-overlay.active .transfer-points{animation:slideInUp .4s .3s both}.transfer-points-label{font-size:1rem;font-weight:800;color:var(--text-secondary)}.transfer-points-value{font-size:2.5rem;font-weight:900;color:var(--accent-color);text-shadow:0 4px 12px rgba(0,0,0,.1)}.transfer-points-unit{font-size:1rem;font-weight:700;color:var(--text-secondary)}.transfer-overlay[data-player=B] .transfer-points-value{color:var(--secondary-accent)}@keyframes transferFadeInOut{0%{opacity:0}15%{opacity:1}85%{opacity:1}to{opacity:0}}@keyframes transferSlideDown{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes transferZoomIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes transferFadeInUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.mission-flash-overlay.active{display:flex;animation:fadeInOut var(--mission-duration, 2s) forwards}#mission-clear-flash .mission-flash-title{font-size:3rem;color:gold;text-shadow:0 0 30px rgba(255,215,0,.6);text-align:center;margin-bottom:.5rem}.mission-flash-pref{font-size:6rem;font-weight:900;color:#fff;text-shadow:0 0 30px rgba(255,255,255,.5);text-align:center;animation:zoomIn .8s cubic-bezier(.34,1.56,.64,1)}#game-over-flash .mission-pref-effect{color:#ff3e3e;text-shadow:0 0 30px rgba(255,62,62,.6)}#game-start-flash .mission-pref-effect{color:#fff;text-shadow:0 0 30px rgba(255,255,255,.6)}.fault-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#f006;z-index:10000;pointer-events:none;opacity:0;transition:none}.fault-overlay.active{animation:faultFlash 1s ease-out forwards}body.fault-shake .main-panel{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}@keyframes faultFlash{0%{opacity:0}10%{opacity:1}to{opacity:0}}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}.route-tooltip{background:#0f172ae6!important;border:1px solid var(--accent-color)!important;color:#fff!important;font-family:Orbitron,sans-serif;font-size:.8rem;font-weight:700;padding:6px 10px;border-radius:2px;box-shadow:0 4px 12px #0000004d}.route-tooltip:before{border-top-color:#0f172ae6!important}.site-footer-version{font-size:.75rem;color:var(--text-secondary);opacity:.8;margin-left:8px;font-weight:500}.site-layout-wrapper{display:flex;flex-direction:column;min-height:100dvh;width:100%}.site-layout-wrapper>#app{flex:1;margin:0 auto;width:100%}
