:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1e293b;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;background:#f8fafc}h1,h2,h3,h4,h5,h6{margin:0;padding:0}button{font-family:inherit;cursor:pointer;border:none;outline:none}button:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.welcome-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#fff,#f5f7fa);color:#2c3e50}.welcome-header{text-align:center;padding:1.5rem 1rem 1rem;animation:fadeInDown .8s ease-out}.welcome-title{font-size:2.8rem;font-weight:700;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.1);letter-spacing:.05em}.welcome-main{flex:1;max-width:800px;margin:0 auto;padding:1rem;width:100%}.welcome-section{margin-bottom:2rem;animation:fadeIn 1s ease-out .2s both}.welcome-intro{text-align:center}.section-title{font-size:1.2rem;font-weight:700;color:#2c3e50;margin:0 0 .8rem;padding-bottom:.4rem;border-bottom:2px solid #e0e8f0}.section-text{font-size:.95rem;color:#4a6080;line-height:1.8;margin:0}.welcome-tagline{text-align:center;font-size:.95rem;color:#4a6080;margin:0 0 .8rem;line-height:1.6}.welcome-description{font-size:.95rem;color:#4a6080;line-height:1.8;margin:0}.rules-list{padding-left:1.4rem;margin:0;color:#4a6080;font-size:.95rem;line-height:1.8}.rules-list li{margin-bottom:.4rem}.rules-list code{font-family:monospace;background:#eef4fb;padding:.1em .4em;border-radius:4px;font-size:.9em;color:#357abd}.rules-hint{list-style:none;margin-top:.6rem;padding:.6rem .8rem;background:#f0f6ff;border-left:3px solid #4a90e2;border-radius:0 6px 6px 0;font-size:.9rem;line-height:1.7}.hint-q{font-weight:700;color:#357abd;margin-right:.3em}.hint-a{font-weight:700;color:#4a7a5a;margin-right:.3em}.role-label{display:inline-block;font-size:.75rem;font-weight:700;padding:.1em .5em;border-radius:4px;margin-right:.4em;vertical-align:middle}.role-major{background:#ffeaa0;color:#7a5c00}.role-minor{background:#d8f0e0;color:#1a6b3a}.welcome-actions{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.2rem;animation:fadeIn 1s ease-out .4s both}.btn-large{padding:1rem 2rem;font-size:1.1rem}.btn-secondary{background:linear-gradient(135deg,#5a9fd4,#2e78c2);color:#fff;border:none;box-shadow:0 4px 15px #2e78c259}.btn-secondary:hover{opacity:1;transform:translateY(-2px);box-shadow:0 6px 20px #4a90e259}.btn-sub{display:block;font-size:.7rem;opacity:.85;margin-top:.2rem}.actions-note{margin:0;font-size:.75rem;color:#888;text-align:center}.welcome-highlight-img{display:block;width:100%;max-width:760px;margin:1rem auto 0;border-radius:10px;box-shadow:0 4px 15px #0000001f}.room-meta-info{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem 1rem}.room-count-info{text-align:center;font-size:.85rem;color:#6b7c93;margin:0}.room-count-number{font-weight:700;color:#4a90e2}.room-expiry-info{text-align:center;font-size:.8rem;color:#8a9ab0;margin:0}.welcome-links{text-align:center;margin-bottom:1.2rem;animation:fadeIn 1s ease-out .6s both}.link-manual{display:inline-block;color:#4a90e2;text-decoration:none;font-size:.95rem;padding:.6rem 1.2rem;border-radius:8px;background:#ffffffb3;transition:all .3s ease}.link-manual:hover{background:#ffffffe6;transform:translateY(-1px)}.welcome-footer{text-align:center;padding:1rem;background:#0000000d;font-size:.85rem}.welcome-footer p{margin:.3rem 0;opacity:.8}.footer-nav{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:.3rem;margin:.4rem 0}.footer-link{color:#4a90e2;text-decoration:none;font-size:.8rem;transition:opacity .2s}.footer-link:hover{opacity:.7;text-decoration:underline}.footer-sep{color:#aaa;font-size:.8rem}.contact-link{color:#4a90e2;text-decoration:none;transition:opacity .3s ease}.contact-link:hover{opacity:.7;text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.welcome-title{font-size:2.2rem}.btn-large{padding:.9rem 1.5rem;font-size:1rem}}.card-component{display:inline-block;border-radius:8px;transition:all .2s ease;-webkit-user-select:none;user-select:none;position:relative}.card-image{width:100%;height:100%;display:block;border-radius:8px}.card-size-small{width:60px;height:60px}.card-size-medium{width:80px;height:80px}.card-size-large{width:90px;height:90px}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-4px);box-shadow:0 6px 12px #00000026}.card-selected{transform:translateY(-8px) rotate(-3deg);box-shadow:0 8px 16px #3b82f666,0 0 30px #3b82f6cc,0 0 50px #3b82f680;outline:4px solid #3b82f6;animation:selectedFloat 2s ease-in-out infinite}.card-in-combo{transform:translateY(-8px) rotate(-3deg);box-shadow:0 8px 16px #22c55e66,0 0 30px #22c55ecc,0 0 50px #22c55e80;outline:4px solid #22c55e;animation:comboFloat 2s ease-in-out infinite}.card-highlighted{box-shadow:0 0 0 3px #fbbf2499;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #fbbf2499}50%{box-shadow:0 0 0 6px #fbbf244d}}@keyframes selectedFloat{0%,to{transform:translateY(-8px) rotate(-3deg)}50%{transform:translateY(-12px) rotate(-3deg)}}@keyframes comboFloat{0%,to{transform:translateY(-8px) rotate(-3deg)}50%{transform:translateY(-12px) rotate(-3deg)}}.card-delete-icon{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;background:#ef4444;border:2px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;box-shadow:0 2px 6px #0000004d;transition:all .2s ease;z-index:10;padding:0}.card-delete-icon:hover{background:#dc2626;transform:scale(1.15);box-shadow:0 4px 10px #ef444480}.card-delete-icon:active{transform:scale(1.05)}.card-with-delete{margin:8px}.card-cancel-icon{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;background:#3b82f6;border:2px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;box-shadow:0 2px 6px #0000004d;transition:all .2s ease;z-index:10;padding:0}.card-cancel-icon:hover{background:#2563eb;transform:scale(1.15);box-shadow:0 4px 10px #3b82f680}.card-cancel-icon:active{transform:scale(1.05)}.card-with-cancel{margin:8px}.card-selected-indicator{position:absolute;top:-10px;left:-10px;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);border:3px solid white;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;box-shadow:0 2px 8px #3b82f680,0 0 20px #3b82f666;z-index:10;animation:checkmarkPop .3s ease-out}.card-combo-indicator{position:absolute;top:-10px;left:-10px;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);border:3px solid white;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;box-shadow:0 2px 8px #22c55e80,0 0 20px #22c55e66;z-index:10;animation:checkmarkPop .3s ease-out}@keyframes checkmarkPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.cell{width:90px;height:90px;background:#f8fafc;border:2px solid #cbd5e1;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.cell-clickable{cursor:pointer}.cell-clickable:hover{background:#e0f2fe;border-color:#3b82f6}.cell-highlighted{background:#fef3c7;border-color:#f59e0b;box-shadow:0 0 8px #f59e0b4d}.cell-selected{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;border-width:4px;box-shadow:0 0 20px #3b82f6cc,0 0 40px #3b82f666;transform:scale(1.05);animation:cellSelectedPulse 1.5s ease-in-out infinite}@keyframes cellSelectedPulse{0%,to{box-shadow:0 0 20px #3b82f6cc,0 0 40px #3b82f666}50%{box-shadow:0 0 30px #3b82f6,0 0 60px #3b82f699}}.cell-in-combo{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#22c55e;border-width:4px;box-shadow:0 0 20px #22c55ecc,0 0 40px #22c55e66;transform:scale(1.05);animation:cellComboPulse 1.5s ease-in-out infinite}@keyframes cellComboPulse{0%,to{box-shadow:0 0 20px #22c55ecc,0 0 40px #22c55e66}50%{box-shadow:0 0 30px #22c55e,0 0 60px #22c55e99}}.cell-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.cell-empty-indicator{width:24px;height:24px;border:2px dashed #94a3b8;border-radius:50%;opacity:.5}.cell-clickable:hover .cell-empty-indicator{opacity:1;border-color:#3b82f6;border-style:solid}.board-grid{display:inline-block;padding:12px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.board-row{display:flex;gap:8px}.board-row:not(:last-child){margin-bottom:8px}.board-grid-disabled{opacity:.5;pointer-events:none;filter:grayscale(.3)}.hand-area{padding:8px 12px;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;min-height:80px}.hand-area-label{font-size:13px;font-weight:600;color:#475569;margin-bottom:6px}.hand-cards{display:flex;flex-wrap:wrap;gap:8px;min-height:60px;align-items:center}.hand-card-wrapper{transition:all .2s ease}.hand-empty{color:#94a3b8;font-size:14px;font-style:italic;padding:20px}.hand-count{margin-top:12px;font-size:12px;color:#64748b;font-weight:500;text-align:right}.hand-area-opponent .hand-cards{opacity:.7}.hand-area-opponent .hand-card-wrapper{pointer-events:none}.hand-area-disabled{opacity:.5;pointer-events:none}.hand-area-disabled .hand-cards{filter:grayscale(.3)}.hand-card-hidden{width:60px;height:60px;border-radius:8px;background:linear-gradient(135deg,#64748b,#475569);border:2px solid #334155;box-shadow:0 2px 4px #0003;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.hand-card-hidden:before{content:"?";font-size:28px;font-weight:700;color:#e2e8f0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.hand-card-hidden:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.05) 10px,rgba(255,255,255,.05) 20px);pointer-events:none}.hand-ready-button{margin-top:12px;display:flex;justify-content:center;pointer-events:auto;opacity:1!important}.ready-button{padding:0;font-size:14px;font-weight:600;color:#1e40af;background:none;border:none;cursor:pointer;text-decoration:underline;pointer-events:auto!important;opacity:1!important}.ready-button:hover{color:#1e3a8a}.ready-button:active{color:#1e293b}.waiting-message{padding:12px 16px;font-size:14px;color:#475569;background:#f1f5f9;border-radius:8px;text-align:center;font-weight:500;pointer-events:auto;opacity:1!important}.hand-guest-url-field{margin-top:12px;padding:12px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;pointer-events:auto!important;opacity:1!important}.guest-url-container{display:flex;flex-direction:column;gap:8px}.guest-url-label{font-size:13px;font-weight:600;color:#475569;margin-bottom:4px}.guest-url-input-wrapper{display:flex;gap:8px}.guest-url-input{flex:1;padding:8px 12px;font-size:13px;color:#1e293b;background:#fff;border:1px solid #cbd5e1;border-radius:6px;font-family:monospace;-webkit-user-select:all;user-select:all}.guest-url-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.guest-url-copy-button{padding:0;font-size:13px;font-weight:600;color:#1e40af;background:none;border:none;cursor:pointer;text-decoration:underline;white-space:nowrap;pointer-events:auto!important;opacity:1!important}.guest-url-copy-button:hover{color:#1e3a8a}.guest-url-copy-button:active{color:#1e293b}.guest-url-copy-button.copied{color:#059669;font-weight:600}.game-status{padding:16px;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:12px;min-width:200px}.status-section{display:flex;flex-direction:column;gap:12px}.status-item{display:flex;align-items:center;gap:8px}.status-label{font-size:12px;color:#64748b;font-weight:500}.status-value{font-size:14px;font-weight:600;color:#1e293b}.status-value.current-turn{color:#3b82f6;padding:4px 12px;background:#dbeafe;border-radius:6px}.status-value.stars{color:#f59e0b}.status-value.deck{color:#10b981}.player-scores{padding-top:12px;border-top:1px solid #e2e8f0;justify-content:space-around}.player-score{display:flex;flex-direction:column;align-items:center;gap:4px}.player-name{font-size:11px;color:#64748b;font-weight:500}.player-stars{font-size:15px;font-weight:700;color:#f59e0b}.game-over{padding:16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;text-align:center;border:2px solid #f59e0b}.game-over-title{font-size:18px;font-weight:700;color:#92400e;margin-bottom:8px}.game-over-result{font-size:16px;font-weight:600;color:#b45309}.commentary-area{width:100%;background:#1e293b;border-radius:6px;padding:8px 12px;display:flex;flex-direction:column;gap:4px;font-family:Courier New,monospace;box-shadow:0 2px 4px #0000001a}.commentary-messages{display:flex;flex-direction:column;gap:4px}.commentary-message{display:flex;align-items:center;gap:8px;padding:4px 8px;background:transparent;border-radius:3px;font-size:13px;line-height:1.4;color:#cbd5e1;transition:background .15s ease}.commentary-message:hover{background:#ffffff0d}.commentary-message-latest{color:#f1f5f9;font-weight:500;animation:fadeIn .3s ease}.commentary-icon{font-size:14px;flex-shrink:0}.commentary-text{color:inherit;flex:1}.commentary-type-combo .commentary-text{color:#fbbf24;font-weight:600}.commentary-type-star .commentary-text{color:#c084fc;font-weight:600}.commentary-type-turn .commentary-text{color:#34d399;font-weight:500}.commentary-type-action .commentary-text{color:#60a5fa}.commentary-empty{text-align:left;color:#64748b;font-size:12px;padding:4px 8px;font-style:italic}@media(max-width:768px){.commentary-area,.commentary-message{font-size:12px}}.control-panel{background:#fff;border-radius:8px;padding:12px;box-shadow:0 2px 8px #0000001a;width:100%;max-width:200px}.control-panel-title{font-size:14px;font-weight:700;color:#1e293b;margin:0 0 8px;text-align:center}.control-buttons{display:flex;flex-direction:column;gap:0}.control-button{padding:6px 12px;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%}.control-button:hover:not(:disabled){transform:translateY(-1px)}.control-button:active:not(:disabled){transform:translateY(0)}.control-button:disabled{background:#94a3b8;cursor:not-allowed;opacity:.6}.control-button.claim-combo{background:#f59e0b}.control-button.claim-combo:hover:not(:disabled){background:#d97706;box-shadow:0 4px 8px #f59e0b4d}.control-button.end-turn{background:#10b981}.control-button.end-turn:hover:not(:disabled){background:#059669;box-shadow:0 4px 8px #10b9814d}.button-divider{height:1px;background:linear-gradient(to right,transparent,#cbd5e1,transparent);margin:12px 0;position:relative}.button-divider:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:30px;height:13px;background:#fff}.game-container{max-width:1400px;margin:0 auto;padding:16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);min-height:100vh}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding:8px 16px;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a}.game-title{font-size:24px;font-weight:700;color:#1e293b;margin:0}.reset-button{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.reset-button:active{transform:translateY(0)}.leave-button{background:#ef4444}.leave-button:hover{background:#dc2626;box-shadow:0 4px 8px #ef44444d}.leave-confirm-modal{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}.leave-confirm-content{background:#fff;padding:40px;border-radius:16px;box-shadow:0 20px 60px #0000004d;text-align:center;max-width:420px;width:90%;animation:slideUp .3s ease}.leave-confirm-content h2{font-size:22px;font-weight:700;color:#1e293b;margin:0 0 16px}.leave-confirm-message{font-size:15px;color:#475569;line-height:1.7;margin:0 0 28px}.leave-confirm-message strong{color:#dc2626}.leave-confirm-actions{display:flex;gap:12px;justify-content:center}.leave-cancel-button{padding:10px 28px;background:#e2e8f0;color:#475569;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.leave-cancel-button:hover{background:#cbd5e1;transform:translateY(-1px)}.leave-confirm-button{padding:10px 28px;background:#ef4444;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.leave-confirm-button:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.game-content{display:flex;flex-direction:column;gap:12px}.opponent-area,.player-area{width:100%;display:flex;flex-direction:column;gap:16px}.game-middle{display:flex;justify-content:center;padding:8px 0}.status-board-commentary-container{display:flex;gap:16px;align-items:flex-start}.board-and-info-container{display:flex;flex-direction:column;gap:8px;align-items:center}.info-display-area{display:flex;flex-direction:column;gap:8px;width:100%;max-width:320px}.selected-card-info{padding:8px 16px;background:#dbeafe;color:#1e40af;border-radius:6px;font-size:14px;font-weight:600}.selected-board-cards-info{padding:8px 16px;background:#fef3c7;color:#92400e;border-radius:6px;font-size:14px;font-weight:600}.error-message{padding:8px 16px;background:#fee2e2;color:#991b1b;border-radius:6px;font-size:14px;font-weight:600;animation:fadeIn .3s ease}.board-full-notice{padding:8px 16px;background:#fef3c7;color:#92400e;border-radius:6px;font-size:14px;font-weight:600;border:2px solid #f59e0b}.no-hand-notice{padding:8px 16px;background:#dbeafe;color:#1e40af;border-radius:6px;font-size:14px;font-weight:600;border:2px solid #3b82f6}.game-over-modal{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.game-over-content{background:#fff;padding:48px;border-radius:20px;box-shadow:0 20px 60px #0000004d;text-align:center;max-width:500px;animation:slideUp .4s ease;position:relative}.game-over-content h2{font-size:36px;font-weight:700;color:#1e293b;margin:0 0 24px}.winner-text{font-size:28px;font-weight:600;color:#f59e0b;margin:0 0 32px}.final-scores{display:flex;flex-direction:column;gap:16px;margin-bottom:32px;padding:24px;background:#f8fafc;border-radius:12px}.score-item{display:flex;justify-content:space-between;align-items:center;font-size:20px;font-weight:600;color:#475569}.score-value{font-size:24px;color:#f59e0b}.new-game-button{padding:16px 48px;background:#3b82f6;color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s ease}.new-game-button:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 8px 16px #3b82f666}.new-game-button:active{transform:translateY(0)}.game-over-leave-button{margin-top:12px;padding:12px 36px;background:#ef4444;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.game-over-leave-button:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 8px 16px #ef444466}.game-over-leave-button:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.difficulty-modal{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.difficulty-modal-content{background:#fff;padding:40px;border-radius:20px;box-shadow:0 20px 60px #0000004d;text-align:center;max-width:500px;animation:slideUp .4s ease;position:relative}.difficulty-modal-content h2{font-size:22px;font-weight:700;color:#1e293b;margin:0 0 24px}.setting-section{margin-bottom:24px}.setting-section h3{font-size:16px;font-weight:600;color:#475569;margin:0 0 12px;text-align:left}.difficulty-buttons{display:flex;flex-direction:column;gap:12px}.turn-order-buttons{display:flex;gap:12px}.difficulty-button{padding:12px 20px;background:#3b82f6;color:#fff;border:3px solid transparent;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative}.difficulty-button:hover:not(.disabled){background:#2563eb;transform:translateY(-2px);box-shadow:0 8px 16px #3b82f666}.difficulty-button.selected{border-color:#f59e0b;background:#2563eb}.difficulty-button.disabled{background:#cbd5e1;color:#64748b;cursor:not-allowed;opacity:.6}.difficulty-button.disabled:hover{transform:none;box-shadow:none}.difficulty-button .coming-soon{display:block;font-size:12px;font-weight:400;margin-top:4px}.turn-order-button{flex:1;padding:12px 20px;background:#3b82f6;color:#fff;border:3px solid transparent;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.turn-order-button:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 8px 16px #3b82f666}.turn-order-button.selected{border-color:#f59e0b;background:#2563eb}.difficulty-modal-actions{display:flex;gap:16px;justify-content:center;margin-top:24px}.difficulty-cancel-button{padding:10px 28px;background:#e2e8f0;color:#475569;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.difficulty-cancel-button:hover{background:#cbd5e1;transform:translateY(-1px)}.difficulty-start-button{padding:10px 28px;background:#10b981;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.difficulty-start-button:hover{background:#059669;transform:translateY(-1px);box-shadow:0 8px 16px #10b98166}@media(max-width:1200px){.status-board-commentary-container{flex-direction:column;align-items:center}}@media(max-width:768px){.game-container{padding:12px}.game-title{font-size:22px}}.modal-close-button{position:absolute;top:12px;right:12px;width:32px;height:32px;padding:0;background:transparent;border:none;color:#94a3b8;font-size:28px;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-close-button:hover{color:#475569;background:#f1f5f9;transform:scale(1.1)}.show-rules-button{padding:12px 20px;background:#fffef7;color:#d4a017;border:2px solid #e0d5b7;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:280px;max-width:320px;box-shadow:0 1px 3px #0000001a}.show-rules-button:hover{background:#fff9e6;border-color:#d4a017;transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.combo-rules-panel{background-color:#fffef7;border:2px solid #e0d5b7;border-radius:8px;padding:12px 16px;font-size:13px;line-height:1.6;color:#333;box-shadow:0 1px 3px #0000001a;min-width:280px;max-width:320px;position:relative}.combo-rules-title{text-align:center;font-weight:700;font-size:14px;margin-bottom:10px;color:#d4a017}.combo-rules-subtitle{font-weight:700;margin-top:8px;margin-bottom:4px;color:#333}.combo-rule-section{margin-bottom:10px}.combo-rule-section:last-of-type{margin-bottom:8px}.combo-rule-header{font-weight:700;color:#555;margin-bottom:3px}.combo-rule-combinations{padding-left:8px;color:#666}.combo-rule-note{padding-left:8px;font-size:12px;color:#888;font-style:italic}.combo-rule-important{margin-top:8px;padding-top:8px;border-top:1px solid #e0d5b7;text-align:center;font-weight:700;font-size:12px;color:#d4a017}.combo-rules-close-button{position:absolute;top:8px;right:8px;width:20px;height:20px;padding:0;background:transparent;border:none;color:#999;font-size:18px;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.combo-rules-close-button:hover{color:#666;transform:scale(1.1)}.dialog-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dialog-content{background:#fff;border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.dialog-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;line-height:1;color:#666;cursor:pointer;padding:.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.dialog-close:hover{background-color:#f0f0f0;color:#333}.dialog-title{margin:0 0 .4rem;font-size:1.5rem;font-weight:600;color:#333}.dialog-note{margin:0 0 1.2rem;font-size:.8rem;color:#8a9ab0}.dialog-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:500;color:#555;font-size:.95rem}.form-input{padding:.75rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#4a90e2}.form-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:6px;border-left:4px solid #c33;font-size:.9rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.room-info{display:flex;flex-direction:column;gap:1.5rem}.room-success-message{background-color:#e8f5e9;color:#2e7d32;padding:1rem;border-radius:8px;border-left:4px solid #4caf50;margin:0}.url-section{display:flex;flex-direction:column;gap:.5rem}.url-title{font-size:1rem;font-weight:600;color:#555;margin:0}.url-container{display:flex;gap:.5rem;align-items:stretch}.url-input{flex:1;padding:.75rem;border:2px solid #ddd;border-radius:8px;font-size:.9rem;font-family:Courier New,monospace;background-color:#f9f9f9}.btn-copy{background-color:#4caf50;color:#fff;padding:.75rem 1rem;white-space:nowrap;min-width:100px}.btn-copy:hover{background-color:#45a049;transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.room-info-details{background-color:#f5f5f5;padding:1rem;border-radius:8px;font-size:.9rem;color:#666}.room-info-details p{margin:.25rem 0}@media(max-width:600px){.dialog-content{padding:1.5rem;width:95%}.dialog-title{font-size:1.25rem}.url-container{flex-direction:column}.btn-copy{width:100%}}.dialog-description{color:#666;font-size:.95rem;margin-bottom:1.5rem;line-height:1.5;text-align:center}.manual-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#fff,#f5f7fa);color:#2c3e50}.manual-header{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;padding:1.2rem 1rem;text-align:center}.manual-header-inner{max-width:800px;margin:0 auto;position:relative}.manual-back{position:absolute;left:0;top:50%;transform:translateY(-50%);color:#ffffffd9;text-decoration:none;font-size:.9rem;transition:color .2s;white-space:nowrap}.manual-back:hover{color:#fff}.manual-header h1{font-size:1.8rem;margin:0;font-weight:700}.manual-subtitle{margin:.3rem 0 0;opacity:.9;font-size:1rem}.manual-main{flex:1;max-width:800px;margin:0 auto;padding:1.5rem 1rem 2rem;width:100%}.manual-section{background:#fff;border-radius:12px;padding:1.4rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #00000014}.manual-section h2{font-size:1.25rem;color:#2c3e50;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:2px solid #e8f0fe;padding-bottom:.5rem}.section-num{display:inline-flex;align-items:center;justify-content:center;width:1.8rem;height:1.8rem;background:#4a90e2;color:#fff;border-radius:50%;font-size:.9rem;font-weight:700;flex-shrink:0}.manual-section h3{font-size:1.05rem;color:#357abd;margin:1.2rem 0 .6rem}.manual-section p{line-height:1.7;margin:.6rem 0}.manual-note{font-size:.85rem;color:#8a9ab0;margin-top:.8rem}.manual-screenshot{width:100%;border-radius:8px;margin:1rem 0;display:block}.manual-screenshot--small{width:60%;margin-left:auto;margin-right:auto}.screenshot-placeholder{background:#f0f7ff;border:2px dashed #4a90e2;border-radius:8px;padding:1.2rem;text-align:center;color:#4a90e2;font-size:.88rem;margin:1rem 0;line-height:1.5}.card-table-wrapper{overflow-x:auto;margin:.8rem 0}.card-table{width:100%;border-collapse:collapse;font-size:.95rem}.card-table th,.card-table td{padding:.5rem .8rem;text-align:center;border:1px solid #e0e8f0}.card-table th{background:#4a90e2;color:#fff;font-weight:700}.card-table tr:nth-child(2n){background:#f8faff}.card-table .highlight-row{background:#fff8e1}.card-table .total-row{background:#e8f0fe;font-weight:700}.info-box{background:#fff8e1;border-left:4px solid #ffc107;border-radius:0 8px 8px 0;padding:.8rem 1rem;font-size:.9rem;margin-top:1rem;line-height:1.6}.step-list{padding-left:1.5rem;margin:.5rem 0}.step-list li{margin:.5rem 0;line-height:1.7}.turn-flow{display:flex;flex-direction:column;gap:.8rem;margin:1rem 0}.turn-step{display:flex;gap:1rem;align-items:flex-start}.step-badge{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:#4a90e2;color:#fff;border-radius:50%;font-weight:700;font-size:1rem;flex-shrink:0;margin-top:.1rem}.step-content{flex:1}.step-content strong{display:block;font-size:1rem;margin-bottom:.3rem;color:#2c3e50}.step-content p{margin:.3rem 0!important;font-size:.95rem;color:#4a6080}.step-content .note{font-size:.85rem;color:#888}.adjacency-diagram{background:#f8faff;border-radius:8px;padding:1rem;margin:1rem 0}.diagram-label{font-size:.88rem;color:#666;margin-bottom:.8rem}.diagrams{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.diagram{text-align:center}.diagram-title{font-size:.85rem;color:#4a6080;margin-bottom:.4rem;font-weight:700}.grid-3x3{display:grid;grid-template-columns:repeat(3,1.8rem);gap:2px;justify-content:center}.grid-3x3 .cell{width:1.8rem;height:1.8rem;display:flex;align-items:center;justify-content:center;font-size:.85rem;border-radius:3px}.grid-3x3 .cell.combo{background:#4a90e2;color:#fff;font-weight:700}.grid-3x3 .cell.empty{background:#e0e0e0;color:#aaa}.combo-card{border-radius:8px;padding:1rem;margin:.8rem 0}.combo-big{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-left:4px solid #ff9800}.combo-small{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-left:4px solid #4caf50}.combo-condition{font-weight:700;margin-bottom:.5rem;font-size:.95rem}.combo-reward{margin-bottom:.4rem;font-size:.95rem;line-height:1.6}.combo-example{font-size:.85rem;color:#555;font-style:italic}.winner-box{background:#e8f0fe;border-radius:8px;padding:1rem;margin-top:.8rem;line-height:1.8}.manual-section ul,.manual-section ol{padding-left:1.5rem;margin:.5rem 0}.manual-section ul li,.manual-section ol li{margin:.4rem 0;line-height:1.7}.manual-footer{text-align:center;padding:1.5rem 1rem;background:#0000000d;font-size:.85rem;display:flex;flex-direction:column;align-items:center;gap:.8rem}.manual-footer p{margin:0;opacity:.7}.btn{display:inline-block;padding:.8rem 1.5rem;font-size:1rem;font-weight:700;text-decoration:none;text-align:center;border-radius:10px;transition:all .3s ease;cursor:pointer;border:none;font-family:inherit}.btn-primary{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;box-shadow:0 4px 15px #4a90e24d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}@media(max-width:768px){.manual-header h1{font-size:1.5rem;padding:0 2rem}.manual-back{font-size:.8rem}.manual-section{padding:1rem}.diagrams{gap:.8rem}.card-table th,.card-table td{padding:.4rem .5rem;font-size:.9rem}}.static-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#fff,#f5f7fa);color:#2c3e50}.static-header{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;padding:1.2rem 1rem;text-align:center}.static-header-inner{max-width:800px;margin:0 auto;position:relative}.static-back{position:absolute;left:0;top:50%;transform:translateY(-50%);color:#ffffffd9;text-decoration:none;font-size:.9rem;transition:color .2s;white-space:nowrap}.static-back:hover{color:#fff}.static-header h1{font-size:1.8rem;margin:0;font-weight:700}.static-main{flex:1;max-width:800px;margin:0 auto;padding:1.5rem 1rem 2rem;width:100%}.static-section{margin-bottom:2rem}.static-section h2{font-size:1.2rem;font-weight:700;color:#2c3e50;margin:0 0 .8rem;padding-bottom:.4rem;border-bottom:2px solid #e0e8f0}.static-section p{font-size:.95rem;color:#4a6080;line-height:1.8;margin:0 0 .6rem}.static-section p:last-child{margin-bottom:0}.static-section ul,.static-section ol{padding-left:1.4rem;margin:0;color:#4a6080;font-size:.95rem;line-height:1.8}.static-section li{margin-bottom:.3rem}.static-contact{display:inline-block;color:#4a90e2;text-decoration:none;transition:opacity .2s}.static-contact:hover{opacity:.7;text-decoration:underline}.static-info-table{width:100%;border-collapse:collapse;font-size:.95rem;color:#4a6080}.static-info-table th,.static-info-table td{padding:.6rem .8rem;border-bottom:1px solid #e0e8f0;text-align:left;vertical-align:top}.static-info-table th{width:9rem;color:#2c3e50;font-weight:700;white-space:nowrap}.static-sitemap-group{margin-bottom:1.2rem}.static-sitemap-group h3{font-size:1rem;font-weight:700;color:#2c3e50;margin:0 0 .5rem}.static-sitemap-list{list-style:none;padding:0 0 0 1rem;margin:0}.static-sitemap-list li{margin-bottom:.4rem}.static-sitemap-list a{color:#4a90e2;text-decoration:none;font-size:.95rem;transition:opacity .2s}.static-sitemap-list a:hover{opacity:.7;text-decoration:underline}.static-footer{text-align:center;padding:1rem;background:#0000000d;font-size:.85rem}.static-footer p{margin:.3rem 0;opacity:.8}@media(max-width:768px){.static-header h1{font-size:1.4rem}.static-info-table th{width:6rem}}#root{width:100%;min-height:100vh;margin:0;padding:0}
