*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;min-height:100vh;padding:20px}.container{max-width:500px;margin:0 auto}h1{text-align:center;color:#333;margin-bottom:24px;font-size:1.5rem}.hidden{display:none!important}.toei-toggle-label{display:flex;align-items:center;flex-wrap:wrap;gap:8px;background:#fff;border-radius:12px;padding:12px 16px;margin-bottom:16px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:border-color .2s}.toei-checkbox{width:18px;height:18px;accent-color:#0066cc;cursor:pointer}.toei-toggle-text{font-size:.9375rem;font-weight:700;color:#333}.toei-toggle-sub{font-size:.75rem;color:#999}.departure-section{background:#fff;border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 2px 8px #0000001a}.departure-section label{display:block;font-size:.875rem;color:#666;margin-bottom:12px}.station-label{margin-top:16px}.line-buttons{display:flex;flex-wrap:wrap;gap:8px}.line-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;border:2px solid #eee;border-radius:24px;background:#fff;cursor:pointer;transition:all .2s;font-size:.875rem}.line-btn:hover{border-color:#ccc;background:#f8f8f8}.line-btn.selected{border-color:#06c;background:#e8f4ff}.line-btn-circle{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.line-btn-name{color:#333;white-space:nowrap}.station-buttons{display:flex;flex-wrap:wrap;gap:8px;max-height:200px;overflow-y:auto;padding:4px}.station-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;border:2px solid #eee;border-radius:20px;background:#fff;cursor:pointer;transition:all .2s;font-size:.875rem}.station-btn:hover{border-color:#ccc;background:#f8f8f8}.station-btn.selected{border-color:#06c;background:#e8f4ff}.station-btn-circle{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.625rem;font-weight:700;flex-shrink:0}.station-btn-name{color:#333;white-space:nowrap}.station-select{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:1rem;background:#fff}.current-departure{background:#fff;border-radius:12px;padding:16px;margin-bottom:16px;text-align:center;font-weight:700;color:#333;box-shadow:0 2px 8px #0000001a}.random-button{width:100%;padding:16px;font-size:1.125rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#06c,#0052a3);border:none;border-radius:12px;cursor:pointer;transition:transform .1s,box-shadow .2s,opacity .2s,background .2s;box-shadow:0 4px 12px #0066cc4d}.random-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #06c6}.random-button:active:not(:disabled){transform:translateY(0)}.random-button:disabled{background:#ccc;box-shadow:none;cursor:not-allowed}.end-game-button{width:100%;padding:12px;font-size:1rem;font-weight:700;color:#666;background:#fff;border:2px solid #ddd;border-radius:12px;cursor:pointer;margin-top:12px;transition:border-color .2s,color .2s}.end-game-button:hover{border-color:#999;color:#333}.result-section{background:#fff;border-radius:12px;padding:24px;margin-top:16px;text-align:center;box-shadow:0 2px 8px #0000001a;display:none}.result-section.show{display:block}.line-badge{display:inline-block;padding:4px 12px;border-radius:16px;color:#fff;font-size:.875rem;font-weight:700;margin-bottom:12px}.station-name{font-size:2rem;font-weight:700;color:#333;margin-bottom:16px}.route-display{margin-bottom:16px;text-align:left}.route-label{font-size:.75rem;color:#666;margin-bottom:12px;text-align:center}.transit-link{display:inline-block;padding:12px 24px;background:#f60;color:#fff;text-decoration:none;border-radius:8px;font-weight:700;transition:background .2s}.transit-link:hover{background:#e55c00}.games-section{margin-top:24px}.games-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.games-header h2{font-size:1rem;color:#666}.clear-all-button{padding:6px 12px;font-size:.75rem;color:#999;background:transparent;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:border-color .2s,color .2s}.clear-all-button:hover{border-color:#f44336;color:#f44336}.game-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:12px}.game-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:2px solid #ddd;border-radius:20px;background:#fff;cursor:pointer;font-size:.875rem;color:#666;white-space:nowrap;transition:all .2s}.game-tab:hover{border-color:#999;color:#333}.game-tab.active{border-color:#06c;background:#e8f4ff;color:#06c}.game-tab-name{max-width:120px;overflow:hidden;text-overflow:ellipsis}.game-content{min-height:100px}.game-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000001a}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #eee}.game-name{font-weight:700;color:#333;font-size:1rem}.game-actions{display:flex;gap:8px}.shared-section{margin-bottom:16px}.game-share,.game-recalc,.game-name-edit,.game-delete{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px;opacity:.6;transition:opacity .2s}.game-share:hover,.game-recalc:hover,.game-name-edit:hover,.game-delete:hover{opacity:1}.route-visual{display:flex;flex-direction:column}.route-node{display:flex;align-items:stretch;min-height:44px}.route-line-container{width:44px;display:flex;flex-direction:column;align-items:center;position:relative}.route-line{width:4px;flex:1}.route-line-top{margin-bottom:-1px}.route-line-bottom{margin-top:-1px}.route-circle{width:28px;height:28px;border-radius:50%;border:3px solid;background:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#333;z-index:1;flex-shrink:0}.route-info{display:flex;align-items:center;gap:8px;padding:8px 0;flex:1;flex-wrap:wrap}.route-station{font-size:.9375rem;font-weight:500;color:#333}.route-badge{font-size:.6875rem;padding:2px 8px;color:#fff;border-radius:4px}.route-badge-transfer{background:#ff9500}.route-badge-current{background:#06c}.route-badge-start{background:#00bb85}.route-badge-destination{background:#8f76d6}.route-badge-stay{background:#06c}.stay-time{font-size:1.25rem;font-weight:700;color:#06c;margin-bottom:8px}.trip-fare{font-size:.875rem;color:#666;margin-bottom:16px}.game-fare{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 12px;border-radius:8px;margin-bottom:12px;font-size:.8125rem}.game-fare-profit{background:#e8f5e9}.game-fare-loss{background:#fff8e1}.fare-total{color:#333;font-weight:500}.fare-pass{color:#666}.fare-savings{font-weight:700;margin-left:auto}.game-fare-profit .fare-savings{color:#2e7d32}.game-fare-loss .fare-savings{color:#f57f17}.stay-section{margin-top:16px}.stay-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fff;border:2px solid #ddd;border-radius:12px;cursor:pointer;font-size:.875rem;font-weight:700;color:#666;transition:border-color .2s,color .2s}.stay-toggle:hover{border-color:#999;color:#333}.stay-arrow{margin-left:auto;font-size:.75rem;transition:transform .2s}.stay-toggle.open{border-radius:12px 12px 0 0;border-bottom-color:#eee}.stay-toggle.open .stay-arrow{transform:rotate(90deg)}.stay-content{background:#fff;border-radius:0 0 12px 12px;padding:16px;border:2px solid #ddd;border-top:none}.stay-fields{display:flex;gap:12px}.stay-field{flex:1;display:flex;flex-direction:column;gap:4px}.stay-field-label{font-size:.75rem;color:#666}.stay-input{width:100%;padding:8px;border:1px solid #ddd;border-radius:8px;font-size:1rem;text-align:center}.stay-input:focus{outline:none;border-color:#06c}.exclude-section{margin-top:16px}.exclude-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fff;border:2px solid #ddd;border-radius:12px;cursor:pointer;font-size:.875rem;font-weight:700;color:#666;transition:border-color .2s,color .2s}.exclude-toggle:hover{border-color:#999;color:#333}.exclude-count{color:#06c;font-weight:400;font-size:.8125rem}.exclude-arrow{margin-left:auto;font-size:.75rem;transition:transform .2s}.exclude-toggle.open{border-radius:12px 12px 0 0;border-bottom-color:#eee}.exclude-toggle.open .exclude-arrow{transform:rotate(90deg)}.exclude-content{background:#fff;border-radius:0 0 12px 12px;padding:12px;border:2px solid #ddd;border-top:none;max-height:400px;overflow-y:auto}.exclude-line{margin-bottom:4px}.exclude-line-header{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;cursor:pointer;transition:background .2s}.exclude-line-header:hover{background:#f5f5f5}.exclude-line-name{font-size:.875rem;color:#333;font-weight:500}.exclude-line-count{font-size:.75rem;color:#f44336;font-weight:700}.exclude-line-toggle{margin-left:auto;padding:2px 8px;font-size:.6875rem;border:1px solid #ddd;border-radius:4px;background:#fff;color:#666;cursor:pointer;transition:border-color .2s,color .2s}.exclude-line-toggle:hover{border-color:#06c;color:#06c}.exclude-stations{display:flex;flex-wrap:wrap;gap:4px;padding:8px 8px 8px 40px}.exclude-station-label{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;cursor:pointer;transition:background .2s;font-size:.8125rem}.exclude-station-label:hover{background:#f5f5f5}.exclude-checkbox{accent-color:#f44336}.exclude-station-name{color:#333}.empty-history{padding:24px;text-align:center;color:#999}
