.game-board{width:100%;height:100%;position:absolute;top:0;left:0;touch-action:none;background:radial-gradient(circle at center,#2c3e50,#1a252f)}.game-board canvas{width:100%!important;height:100%!important;outline:none}.lobby{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.lobby-bg{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#4ecdc4,#556270);z-index:0}.hex-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='49' viewBox='0 0 28 49'%3E%3Cg fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.08'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15l12.99-7.5zM3 17.9v12.7l10.99 6.34 11-6.35V17.9l-11-6.34L3 17.9zM0 15l12.98-7.5V0h-2v6.35L0 12.69v2.3zm0 18.5L12.98 41v8h-2v-6.85L0 35.81v-2.3zM15 0v7.5L27.99 15H28v-2.31h-.01L17 6.35V0h-2zm0 49v-8l12.99-7.5H28v2.31h-.01L17 42.15V49h-2z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");animation:patternMove 30s linear infinite}@keyframes patternMove{0%{background-position:0 0}to{background-position:56px 98px}}.lobby-content{position:relative;z-index:1;width:100%;max-width:420px;padding:20px}.lobby-logo{text-align:center;margin-bottom:24px}.logo-hex{width:80px;height:92px;margin:0 auto 16px;background:linear-gradient(135deg,#ff6b6b,#ffe66d);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);animation:bounce 2s ease-in-out infinite}.logo-hex span{font-size:40px;font-weight:900;color:var(--color-text);font-family:var(--font-display)}.lobby-logo h1{font-family:var(--font-display);font-size:28px;font-weight:800;color:var(--color-white);text-shadow:0 2px 10px rgba(0,0,0,.2);margin-bottom:4px}.lobby-subtitle{font-size:16px;color:#fffc}.lobby-error{background:var(--color-secondary);color:#fff;padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;text-align:center;cursor:pointer;font-weight:600}.lobby-card{background:var(--color-white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-lg)}.input-group{margin-bottom:16px}.input-group label{display:block;font-size:14px;font-weight:700;color:var(--color-text-light);margin-bottom:8px}.input-hint{display:block;margin-top:6px;font-size:11px;color:var(--color-text-light)}.mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.mode-btn{display:flex;align-items:center;gap:10px;padding:14px;background:#f5f7fa;border:3px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.mode-btn.active{border-color:var(--color-primary);background:#4ecdc41a}.mode-btn:hover{background:#4ecdc40d}.mode-icon{font-size:28px}.mode-text{display:flex;flex-direction:column}.mode-text strong{font-size:14px;color:var(--color-text)}.mode-text small{font-size:12px;color:var(--color-text-light)}.lobby-btn{width:100%;padding:16px;font-size:16px}.lobby-divider{display:flex;align-items:center;margin:20px 0;color:var(--color-text-light);font-size:14px}.lobby-divider:before,.lobby-divider:after{content:"";flex:1;height:1px;background:#e8e8e8}.lobby-divider span{padding:0 16px}.lobby-footer{text-align:center;margin-top:20px;color:#ffffffb3;font-size:14px}.loading-spinner-sm{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.animate-shake{animation:shake .5s ease}@media (max-width: 480px){.lobby-content{padding:16px}.lobby-card{padding:20px}.logo-hex{width:70px;height:81px}.logo-hex span{font-size:34px}.lobby-logo h1{font-size:24px}}.game-list-section{margin-bottom:16px}.game-list-section label{display:block;font-size:14px;font-weight:700;color:var(--color-text-light);margin-bottom:10px}.game-list{max-height:200px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:var(--radius-md);background:#fafafa}.game-list-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid #e0e0e0;transition:background var(--transition-fast)}.game-list-item:last-child{border-bottom:none}.game-list-item:hover{background:#f0f0f0}.game-info{display:flex;align-items:center;gap:10px;font-size:14px}.game-mode{font-size:18px}.game-players{font-weight:600;color:var(--color-primary)}.game-id-short{color:#888;font-family:monospace;font-size:12px}.btn-sm{padding:6px 14px;font-size:12px}.btn-join{background:var(--color-secondary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;transition:background var(--transition-fast)}.btn-join:hover{background:#e07b00}.btn-join:disabled{opacity:.5;cursor:not-allowed}.btn-refresh{display:block;width:100%;margin-top:8px;padding:8px;background:transparent;border:1px solid #ddd;border-radius:var(--radius-sm);color:#666;font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.btn-refresh:hover{background:#f5f5f5;border-color:#ccc}.btn-refresh:disabled{opacity:.5;cursor:not-allowed}.player-panel{display:flex;flex-direction:column;gap:8px}.player-card{display:flex;align-items:center;gap:10px;background:#fffffff2;padding:10px 12px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border-left:4px solid var(--player-color);transition:all var(--transition-fast)}.player-card.active{box-shadow:var(--shadow-md);transform:translate(4px);background:#fff}.player-card.self{border-left-width:6px}.player-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:16px;text-shadow:0 1px 2px rgba(0,0,0,.2);flex-shrink:0}.player-info{flex:1;min-width:0}.player-name{font-weight:700;font-size:13px;color:var(--color-text);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-badge{background:var(--color-primary);color:#fff;font-size:9px;padding:2px 6px;border-radius:var(--radius-full);font-weight:700}.player-stats{display:flex;gap:10px;margin-top:4px}.stat{font-size:12px;color:var(--color-text-light)}.turn-indicator{color:var(--color-primary);font-size:12px;animation:pulse 1s ease-in-out infinite}.special-cards{margin-top:8px;display:flex;flex-direction:column;gap:4px}.special-card{background:#ffe66df2;padding:6px 10px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;color:var(--color-text)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.player-card{padding:8px 10px}.player-avatar{width:30px;height:30px;font-size:14px}.player-name{font-size:12px}.stat{font-size:11px}}.action-bar{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.waiting-info{background:#ffffffe6;padding:10px 20px;border-radius:var(--radius-full);font-weight:600;color:var(--color-text)}.action-btn{min-width:160px;padding:14px 28px;font-size:16px}.roll-btn{animation:bounce 1s ease-in-out infinite}.action-buttons{display:flex;gap:8px}.action-btn-sm{padding:10px 16px;font-size:14px;min-width:auto}.setup-hint{display:flex;align-items:center;gap:10px;background:#fffffff2;padding:12px 20px;border-radius:var(--radius-full);font-weight:600;color:var(--color-text);box-shadow:var(--shadow-md)}.hint-icon{font-size:20px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@media (max-width: 768px){.action-bar{gap:8px}.action-btn{min-width:140px;padding:12px 20px;font-size:14px}.action-btn-sm{padding:8px 12px;font-size:12px}.setup-hint{padding:10px 16px;font-size:13px}.hint-icon{font-size:16px}}@media (max-width: 480px){.action-buttons{flex-wrap:wrap;justify-content:center}}.dice-display{background:#fffffff2;padding:12px 16px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;gap:8px}.dice-container{display:flex;gap:8px}.dice{font-size:36px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);transition:transform .1s ease}.dice.rolling{animation:diceRoll .1s ease infinite}@keyframes diceRoll{0%{transform:rotate(-10deg) scale(1.1)}50%{transform:rotate(10deg) scale(.95)}to{transform:rotate(-10deg) scale(1.1)}}.dice-total{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--color-text);background:var(--color-accent);padding:4px 16px;border-radius:var(--radius-full)}.dice-total.critical{background:var(--color-secondary);color:#fff;animation:pulse .5s ease infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width: 768px){.dice-display{padding:10px 12px}.dice{font-size:28px;width:38px;height:38px}.dice-total{font-size:18px;padding:3px 12px}}.resource-bar{display:flex;justify-content:center;gap:8px;padding:8px;background:#fffffff2;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.resource-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:linear-gradient(135deg,var(--resource-color) 0%,color-mix(in srgb,var(--resource-color) 70%,white) 100%);border-radius:var(--radius-md);min-width:50px;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.resource-item:active{transform:scale(.95)}.resource-icon{font-size:20px}.resource-count{font-family:var(--font-display);font-size:18px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.dev-cards{--resource-color: #9B59B6}@media (max-width: 768px){.resource-bar{gap:6px;padding:6px}.resource-item{padding:6px 8px;min-width:42px}.resource-icon{font-size:16px}.resource-count{font-size:14px}}@media (max-width: 375px){.resource-item{padding:4px 6px;min-width:36px}.resource-icon{font-size:14px}.resource-count{font-size:12px}}.phase-indicator{display:flex;align-items:center;gap:10px;background:#fffffff2;padding:10px 16px;border-radius:var(--radius-full);box-shadow:var(--shadow-md)}.phase-icon{font-size:20px}.phase-info{display:flex;flex-direction:column;gap:2px}.phase-label{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--color-text)}.current-turn{font-size:11px;color:var(--color-text-light)}.turn-number{font-family:var(--font-display);font-size:12px;font-weight:700;background:var(--color-primary);color:#fff;padding:4px 8px;border-radius:var(--radius-full)}@media (max-width: 768px){.phase-indicator{padding:8px 12px;gap:8px}.phase-icon{font-size:16px}.phase-label{font-size:12px}.current-turn{font-size:10px}.turn-number{font-size:10px;padding:3px 6px}}.game-over-modal{padding:32px;text-align:center;min-width:300px}.trophy-icon{font-size:64px;margin-bottom:16px;animation:bounce 1s ease infinite}.winner-title{font-family:var(--font-display);font-size:28px;font-weight:800;color:var(--color-text);margin-bottom:8px}.winner-points{font-size:16px;color:var(--color-text-light);margin-bottom:24px}.final-standings{background:#f5f7fa;border-radius:var(--radius-md);padding:16px;margin-bottom:24px}.final-standings h3{font-size:14px;font-weight:700;color:var(--color-text-light);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.standing-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #E8E8E8}.standing-row:last-child{border-bottom:none}.standing-rank{font-size:18px;width:32px}.standing-name{flex:1;font-weight:600;text-align:left}.standing-points{font-family:var(--font-display);font-weight:700;color:var(--color-primary)}@media (max-width: 480px){.game-over-modal{padding:24px;min-width:auto;width:100%}.trophy-icon{font-size:48px}.winner-title{font-size:22px}}.game-ui{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:100;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.game-ui>*{pointer-events:auto}.glass-panel{background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.4);box-shadow:0 4px 16px #0000001a;border-radius:16px}.ui-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;padding:20px;gap:16px}.game-code{background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 16px;border-radius:20px;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;align-items:center;gap:2px;max-width:220px;transition:transform .2s ease}.game-code:hover{transform:translateY(-2px);background:#fffffff2}.game-code-label{font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.game-code-value{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;font-weight:600;color:#333;text-align:center;word-break:break-all}.game-code-copy{margin-top:6px;padding:4px 12px;border:none;border-radius:12px;background:#4ecdc4;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.game-code-copy:hover{background:#3ebcb3;transform:scale(1.05)}.game-code-copy:active{transform:scale(.95)}.ui-left{position:absolute;top:80px;left:20px;max-width:200px}.ui-right{position:absolute;top:80px;right:20px}.ui-bottom{position:absolute;bottom:0;left:0;right:0;padding:24px;display:flex;flex-direction:column;gap:16px;background:linear-gradient(to top,rgba(0,0,0,.4) 0%,transparent 100%);pointer-events:none}.ui-bottom>*{pointer-events:auto}@media (max-width: 768px){.ui-top{padding:12px}.ui-left{top:70px;left:10px;max-width:150px}.ui-right{top:70px;right:10px}.ui-bottom{padding:12px}.game-code{padding:6px 12px}.game-code-label{font-size:9px}.game-code-value{font-size:11px}.game-code-copy{font-size:10px;padding:3px 10px}}@media (max-width: 375px){.ui-left{display:none}}.app{width:100%;height:100%;position:relative;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2)}.loading-screen{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#4ecdc4,#556270);color:#fff;z-index:9999}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{--color-primary: #4ECDC4;--color-secondary: #FF6B6B;--color-accent: #FFE66D;--color-success: #95E1A3;--color-warning: #FFA07A;--color-brick: #E17055;--color-wood: #81B29A;--color-wheat: #F9C74F;--color-sheep: #A8E6CF;--color-ore: #6C7A89;--color-desert: #DDD6C8;--color-player-red: #FF6B6B;--color-player-blue: #4ECDC4;--color-player-orange: #FFA07A;--color-player-white: #F8F9FA;--color-bg: #F0F5F9;--color-bg-dark: #1A1A2E;--color-text: #2D3436;--color-text-light: #636E72;--color-white: #FFFFFF;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16);--shadow-glow: 0 0 20px rgba(78, 205, 196, .3);--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--font-main: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Quicksand", var(--font-main);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-main);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:16px;font-weight:700;cursor:pointer;transition:all var(--transition-fast);touch-action:manipulation;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.95)}.btn-primary{background:linear-gradient(135deg,var(--color-primary),#3DB9B1);color:var(--color-white);box-shadow:var(--shadow-md),0 4px #2a9d8f}.btn-primary:hover{box-shadow:var(--shadow-lg),0 4px #2a9d8f;transform:translateY(-2px)}.btn-primary:active{transform:translateY(2px);box-shadow:var(--shadow-sm),0 2px #2a9d8f}.btn-secondary{background:linear-gradient(135deg,var(--color-secondary),#E55A5A);color:var(--color-white);box-shadow:var(--shadow-md),0 4px #c74848}.btn-accent{background:linear-gradient(135deg,var(--color-accent),#F0D644);color:var(--color-text);box-shadow:var(--shadow-md),0 4px #d4bc3d}.btn-outline{background:var(--color-white);color:var(--color-text);border:3px solid var(--color-primary);box-shadow:var(--shadow-sm)}.btn-outline:hover{background:var(--color-primary);color:var(--color-white)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:20px}.card-glass{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5)}.input{width:100%;padding:14px 20px;border:3px solid #E8E8E8;border-radius:var(--radius-full);font-family:var(--font-main);font-size:16px;outline:none;transition:all var(--transition-fast)}.input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:90vw;max-height:85vh;overflow:auto;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-bounce{animation:bounce 1s infinite}.animate-pulse{animation:pulse 2s infinite}.animate-fadeIn{animation:fadeIn .3s ease}.animate-slideUp{animation:slideUp .4s ease}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:var(--radius-full)}@media (hover: none){.btn:hover{transform:none}.btn:active{transform:scale(.95)}}@media (max-width: 768px){:root{--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px}.btn{padding:10px 20px;font-size:14px}}
