@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";body{min-height:100vh;margin:0;padding:0}:root{--bg-dark:#0f172a;--glass-bg:#1e293bb3;--glass-border:#ffffff14;--accent:#f59e0b;--accent-glow:#f59e0b4d;--text-main:#f8fafc;--text-dim:#94a3b8;--success:#22c55e;--danger:#ef4444;--info:#3b82f6}body{background:var(--bg-dark);background-image:radial-gradient(ellipse at 30% 20%, #1e293b 0%, var(--bg-dark) 70%);color:var(--text-main);height:100vh;margin:0;font-family:Inter,system-ui,sans-serif;overflow:hidden}*{box-sizing:border-box}.game-layout{grid-template-rows:auto 1fr;grid-template-columns:1fr auto;width:100vw;height:100vh;display:grid;overflow:hidden}.game-top-bar{border-bottom:1px solid var(--glass-border);z-index:200;background:#0f172af2;grid-column:1/-1;justify-content:space-between;align-items:center;min-height:48px;padding:8px 16px;display:flex}.game-board-area{grid-area:2/1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.game-sidebar{border-left:1px solid var(--glass-border);z-index:100;background:#0f172a99;flex-direction:column;grid-area:2/2;gap:10px;width:300px;padding:12px;display:flex;overflow-y:auto}.game-container{flex-direction:column;justify-content:center;align-items:center;height:100vh;padding:2rem;display:flex}.lobby-screen{flex-direction:column;justify-content:center;align-items:center;gap:20px;height:100vh;display:flex}.lobby-card{text-align:center;width:480px;padding:2rem}.lobby-card h1{margin-bottom:.25rem;font-size:1.6rem!important}.player-slots{grid-template-columns:1fr 1fr;gap:10px;margin:1.5rem 0;display:grid}.player-slot{border:2px dashed #ffffff26;border-radius:12px;align-items:center;gap:10px;padding:14px;transition:all .3s;display:flex}.player-slot.occupied{background:#ffffff0d;border-style:solid}.player-slot.you{border-color:var(--accent);background:#f59e0b14}.player-slot .color-dot{border:2px solid #fff6;border-radius:50%;flex-shrink:0;width:24px;height:24px}.player-slot .slot-empty{color:var(--text-dim);font-size:.85rem;font-style:italic}.player-slot .slot-name{font-size:.9rem;font-weight:600}.lobby-waiting{color:var(--text-dim);align-items:center;gap:8px;font-size:.85rem;display:flex}.lobby-waiting .spinner{border:2px solid var(--text-dim);border-top:2px solid var(--accent);border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:16px;padding:1rem 1.25rem;box-shadow:0 8px 32px #0000004d}.btn-action{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;transition:all .2s}.btn-action:hover{box-shadow:0 4px 12px var(--accent-glow);transform:translateY(-1px)}.btn-action:active{transform:translateY(0)}.btn-action.end-turn{background:var(--danger);color:#fff}.btn-action.active-mode{background:var(--success);box-shadow:0 0 16px #22c55e80}.btn-action:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-lg{padding:12px 24px;font-size:1rem}.btn-ghost{color:var(--text-main);background:0 0;border:1px solid #ffffff26}.btn-ghost:hover{box-shadow:none;background:#ffffff0d}.phase-banner{border-radius:12px;justify-content:center;align-items:center;gap:12px;padding:10px 20px;font-size:.9rem;font-weight:600;animation:2s ease-in-out infinite pulse-glow;display:flex}.phase-banner.your-turn{color:#93c5fd;background:linear-gradient(135deg,#3b82f64d,#8b5cf64d);border:1px solid #3b82f666}.phase-banner.waiting{color:var(--text-dim);background:#64748b33;border:1px solid #64748b4d;animation:none}@keyframes pulse-glow{0%,to{box-shadow:0 0 #3b82f633}50%{box-shadow:0 0 20px 4px #3b82f626}}.sidebar-section{background:#0003;border:1px solid #ffffff0a;border-radius:12px;padding:12px}.sidebar-section h3{text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin:0 0 8px;font-size:.75rem}.resource-grid{grid-template-columns:1fr 1fr 1fr;gap:6px;display:grid}.resource-item{background:#0000004d;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:.85rem;display:flex}.resource-item .count{text-align:right;min-width:16px;font-weight:800}.build-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.build-btn{cursor:pointer;color:var(--text-main);background:#0000004d;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:8px;font-family:Inter,sans-serif;font-size:.75rem;transition:all .2s;display:flex}.build-btn:hover{background:#ffffff14;border-color:#fff3}.build-btn.active{border-color:var(--success);background:#22c55e33;box-shadow:0 0 12px #22c55e4d}.build-btn .build-icon{font-size:1.4rem}.build-btn .build-cost{color:var(--text-dim);font-size:.65rem}.dice-display{background:#0000004d;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:8px;display:flex}.die{color:#1e293b;background:#fff;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;font-weight:900;display:flex;box-shadow:0 2px 8px #0000004d}.dice-total{color:var(--accent);font-size:1.1rem;font-weight:800}.board-wrapper{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.board-inner{width:0;height:0;position:relative}.hexagon{clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);filter:drop-shadow(0 8px 8px #00000080);background-color:#1e293b;background-position:50%;background-size:200%;justify-content:center;align-items:center;width:196px;height:226px;font-weight:700;transition:filter .3s;display:flex;position:absolute}.hexagon:after{content:"";pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 0 30px #0009}.hexagon.forest{background-image:url(/assets/forest_hexagon.png)}.hexagon.pasture{background-image:url(/assets/pasture_hexagon.png)}.hexagon.field{background-image:url(/assets/field_hexagon.png)}.hexagon.hill{background-image:url(/assets/hill_hexagon.png)}.hexagon.mountain{background-image:url(/assets/mountain_hexagon.png)}.hexagon.desert{background-image:url(/assets/desert_hexagon.png)}.hexagon.hex-clickable:hover{cursor:pointer;filter:drop-shadow(0 12px 15px #ef444480)brightness(1.3)!important}.token{color:#1e293b;z-index:10;background:#fef3c7;border:3px solid #fffbeb;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-family:Times New Roman,serif;font-size:1.3rem;font-weight:900;display:flex;box-shadow:0 3px 8px #00000080}.token.high-prob{color:#dc2626;font-size:1.5rem}.road-edge{cursor:pointer;z-index:25;background-color:#0000;border-radius:4px;width:50px;height:8px;transition:all .2s;position:absolute}.road-edge.built{height:10px;box-shadow:0 2px 8px #0009}.road-edge.road-hover:not(.built):hover{height:10px;box-shadow:0 0 12px #fff6;background-color:#ffffff80!important}.port-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5;background:#0f172acc;border:1px solid #ffffff26;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:50px;height:50px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 12px #0006}.port-badge:hover{border-color:#ffffff4d;transform:translate(-50%,-50%)scale(1.1);box-shadow:0 6px 16px #0009}.port-icon{font-size:1.2rem;line-height:1}.port-rate{color:var(--text-dim);letter-spacing:.5px;font-size:.65rem;font-weight:800}.port-line{pointer-events:none;z-index:4;background:linear-gradient(90deg,#ffffff4d 0%,#fff0 100%);height:2px}.vertex-point{cursor:pointer;z-index:50;transition:all .2s}.vertex-point.vertex-hover:not(.settled):not(.city):hover{transform:scale(1.5);box-shadow:0 0 16px #fff9;background-color:#ffffffb3!important}.vertex-point.settled{cursor:pointer;z-index:60;border:2px solid #ffffffe6;box-shadow:0 2px 8px #00000080}.vertex-point.city{cursor:pointer;z-index:60;border:2px solid #fff;box-shadow:0 0 12px #fff6,0 2px 8px #00000080}.vertex-point.setup-highlight{animation:1.5s ease-in-out infinite setup-pulse}@keyframes setup-pulse{0%,to{box-shadow:0 0 #3b82f633;background-color:#3b82f64d!important}50%{box-shadow:0 0 20px 6px #3b82f64d;background-color:#3b82f6b3!important}}.road-edge.setup-highlight{animation:1.5s ease-in-out infinite road-pulse}@keyframes road-pulse{0%,to{box-shadow:0 0 #3b82f633;background-color:#3b82f633!important}50%{box-shadow:0 0 12px 3px #3b82f64d;background-color:#3b82f699!important}}.robber-icon{z-index:15;filter:drop-shadow(0 3px 6px #000c);font-size:2.2rem;animation:2.5s ease-in-out infinite robber-bob;position:absolute}@keyframes robber-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.error-toast{color:#fff;z-index:9999;background:#ef4444f2;border-radius:10px;padding:10px 20px;font-size:.85rem;font-weight:600;position:fixed;top:60px;left:50%;transform:translate(-50%);box-shadow:0 6px 24px #ef444466}.victory-overlay{z-index:10000;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.victory-card{text-align:center;padding:3rem!important}.victory-card h1{margin-bottom:.5rem;font-size:2.5rem!important}.game-log{border:1px solid var(--glass-border);z-index:200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f172af2;border-radius:12px;max-width:320px;max-height:180px;padding:10px 14px;font-size:.72rem;position:fixed;bottom:10px;left:10px;overflow-y:auto}.log-entry{color:var(--text-dim);border-bottom:1px solid #ffffff0a;padding:2px 0;line-height:1.4}.log-entry:last-child{color:#e2e8f0;border-bottom:none}.scoreboard{align-items:center;gap:4px;display:flex}.score-card{background:#0000004d;border:2px solid #ffffff26;border-radius:8px;align-items:center;gap:6px;padding:4px 10px;font-size:.8rem;display:flex}.score-card.active-player{box-shadow:0 0 10px var(--accent-glow);border-color:var(--accent)}.badge{color:#fcd34d;background:#f59e0b26;border:1px solid #f59e0b4d;border-radius:6px;padding:2px 8px;font-size:.7rem;font-weight:600}.trade-section{background:#0000004d;border:1px solid #ffffff0f;border-radius:10px;padding:10px}.trade-section h4{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px;font-size:.75rem}.trade-inputs{grid-template-columns:repeat(5,1fr);gap:4px;display:grid}.trade-input-item{flex-direction:column;align-items:center;gap:2px;font-size:.75rem;display:flex}.trade-input-item input{color:#fff;text-align:center;background:#00000080;border:1px solid #ffffff26;border-radius:4px;width:32px;padding:3px;font-size:.8rem}.discard-panel{background:#ef444426;border:1px solid #ef44444d;border-radius:12px;padding:12px}.discard-panel h4{color:#fca5a5;margin:0 0 4px}.dev-card-item{background:#0000004d;border:1px solid #ffffff0d;border-radius:6px;justify-content:space-between;align-items:center;padding:6px 10px;font-size:.8rem;display:flex}.dev-card-item .card-name{text-transform:capitalize}.dev-card-item .card-new{color:var(--accent);font-size:.65rem;font-weight:600}.incoming-trade{background:#3b82f626;border:1px solid #3b82f64d;border-radius:12px;padding:12px}h1{background:linear-gradient(to bottom right,#fde047,#d97706);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.5rem;font-weight:800}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.auth-card{text-align:center;width:400px;padding:2rem!important}.auth-input{width:100%;color:var(--text-main);background:#0006;border:1px solid #ffffff1f;border-radius:10px;outline:none;padding:12px 16px;font-family:Inter,sans-serif;font-size:.9rem;transition:border-color .2s}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.auth-input::placeholder{color:#ffffff4d}.auth-error{color:#fca5a5;text-align:center;background:#ef444426;border:1px solid #ef44444d;border-radius:8px;padding:8px 12px;font-size:.8rem}.dice-face{background:#fff;border-radius:10px;flex-shrink:0;position:relative;box-shadow:0 3px 10px #0000004d,inset 0 1px #fffc}.dice-dot{background:#1e293b;border-radius:50%;width:18%;height:18%;position:absolute;transform:translate(-50%,-50%);box-shadow:inset 0 1px 2px #0000004d}.dice-overlay{z-index:9000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dice-animation-container{align-items:center;gap:24px;display:flex}.dice-total-display{color:var(--accent);text-shadow:0 0 30px var(--accent-glow);margin-top:16px;font-size:3rem;font-weight:900}.pulsing{animation:1.5s ease-in-out infinite pulse-op}@keyframes pulse-op{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}
