*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#1a1a2e;--color-bg-light:#16213e;--color-primary:#4361ee;--color-secondary:#3f37c9;--color-accent:#f72585;--color-success:#4cc9f0;--color-warning:#f9c74f;--color-danger:#ef476f;--color-crop:#78b450;--color-meat:#e63946;--color-gold:gold;--color-player-1:#ff6b6b;--color-player-2:#4dabf7;--color-player-3:#69db7c;--color-player-4:#ffd43b;--color-text:#fff;--color-text-muted:#b8c1ec;--font-main:"Poppins",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--shadow-soft:0 4px 6px -1px rgba(0,0,0,.3);--shadow-medium:0 10px 15px -3px rgba(0,0,0,.4);--shadow-hard:0 20px 25px -5px rgba(0,0,0,.5);--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:30px}html{background-color:var(--color-bg-light);font-size:16px}body{background:linear-gradient(135deg,var(--color-bg) 0,var(--color-bg-light) 100%);color:var(--color-text);font-family:var(--font-main);min-height:100vh;overflow-x:hidden;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);touch-action:manipulation}#game-container{align-items:center;display:flex;justify-content:center;min-height:100vh;min-height:100dvh;padding:1rem}.screen{animation:fadeIn .3s ease-out;display:none;max-width:800px;padding:2rem;position:relative;width:100%}.screen.active{display:block}h1{font-size:clamp(2rem,8vw,4rem);font-weight:700;margin-bottom:1rem}h1,h2{text-align:center}h2{font-size:clamp(1.5rem,5vw,2.5rem);margin-bottom:1.5rem}h2,h3{font-weight:600}h3{font-size:clamp(1rem,3vw,1.25rem);margin-bottom:1rem}p{line-height:1.6}.btn{align-items:center;border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);color:#fff;cursor:pointer;display:inline-flex;font-family:var(--font-main);font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;letter-spacing:.05em;padding:1rem 2rem;text-transform:uppercase;transition:all .2s ease}.btn:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn:disabled:hover{box-shadow:var(--shadow-soft);transform:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff}.btn-secondary{background:hsla(0,0%,100%,.1);border:2px solid hsla(0,0%,100%,.2);color:var(--color-text)}.btn-secondary:hover{background:hsla(0,0%,100%,.2)}.btn-large{border-radius:var(--radius-lg);font-size:1.25rem;padding:1.25rem 3rem}.btn-player{color:#fff;font-size:1.5rem;min-width:150px;padding:2rem 3rem}.btn-player.player-1{background:linear-gradient(135deg,var(--color-player-1),#ff5252)}.btn-player.player-2{background:linear-gradient(135deg,var(--color-player-2),#339af0)}.btn-player.player-3{background:linear-gradient(135deg,var(--color-player-3),#51cf66)}.btn-action{align-items:center;background:hsla(0,0%,100%,.1);border:2px solid hsla(0,0%,100%,.2);color:#fff;display:flex;flex-direction:column;gap:.75rem;min-width:140px;padding:1.5rem 2rem}.btn-action:hover{background:hsla(0,0%,100%,.2);border-color:var(--color-primary)}.btn-action.btn-end{border-color:var(--color-warning)}.btn-action .action-icon{font-size:2rem}.btn-accept{background:linear-gradient(135deg,#40c057,#2f9e44);color:#fff;padding:1.25rem 2.5rem}.btn-accept:disabled{background:linear-gradient(135deg,#555,#444);color:#888;cursor:not-allowed;opacity:.6}.btn-decline{background:linear-gradient(135deg,#fa5252,#e03131);color:#fff;padding:1.25rem 2.5rem}.menu-content{text-align:center}.game-banner{filter:drop-shadow(0 0 20px rgba(255,215,0,.3));height:auto;margin-bottom:.5rem;max-width:100%;width:clamp(280px,80vw,500px)}.game-title{color:var(--color-gold);margin-bottom:.5rem;text-shadow:0 0 30px rgba(255,215,0,.5)}.subtitle{color:var(--color-text-muted);font-size:clamp(1rem,3vw,1.5rem);margin-bottom:2rem}.rules-box{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);margin:2rem auto;max-width:600px;padding:1.5rem 2rem;text-align:left}.rules-box h3{color:var(--color-success);margin-bottom:1rem;text-align:center}.rules-box ul{list-style:none}.rules-box li{color:var(--color-text-muted);font-size:clamp(.875rem,2.5vw,1rem);padding:.5rem 0}.rules-box strong{color:var(--color-text)}.player-count-buttons{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin:2rem 0}#back-to-menu{display:block;margin:2rem auto 0}.turn-announcement{text-align:center}.turn-number{color:var(--color-text-muted);font-size:clamp(1.5rem,4vw,2rem);margin-bottom:1rem}.turn-number span{color:var(--color-gold);font-weight:700}.instruction{color:var(--color-text-muted);font-size:clamp(1rem,3vw,1.25rem);margin:1.5rem 0}.warning{color:var(--color-warning);font-weight:600;margin-bottom:2rem}.deck-header{color:var(--color-text-muted);font-size:clamp(1rem,3vw,1.25rem);margin-bottom:1.5rem;text-align:center}.role-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-medium);margin-bottom:2rem;padding:2rem;text-align:center}.role-card,.role-card.farmer{background:linear-gradient(135deg,var(--color-crop),#5a8a3a)}.role-card.merchant{background:linear-gradient(135deg,var(--color-gold),#daa520)}.role-card.fisherman{background:linear-gradient(135deg,var(--color-meat),#b52d38)}.role-card h2{margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.role-card p{font-size:clamp(.875rem,2.5vw,1.1rem);opacity:.9}.current-resources,.resources-section{margin:2rem 0}.current-resources h3,.resources-section h3{color:var(--color-text-muted);text-align:center}.resource-cards{flex-wrap:wrap;gap:1rem;margin-top:1rem}.resource-card,.resource-cards{display:flex;justify-content:center}.resource-card{align-items:center;border-radius:var(--radius-md);box-shadow:var(--shadow-soft);flex-direction:column;min-width:100px;padding:1rem 1.5rem}.resource-cards.small .resource-card{min-width:80px;padding:.75rem 1rem}.resource-card.crop{background:linear-gradient(135deg,var(--color-crop),#5a8a3a)}.resource-card.meat{background:linear-gradient(135deg,var(--color-meat),#b52d38)}.resource-card.gold{background:linear-gradient(135deg,var(--color-gold),#daa520)}.resource-icon{font-size:1.5rem;margin-bottom:.25rem}.resource-name{font-size:.75rem;font-weight:600;letter-spacing:.1em;opacity:.9}.resource-amount{font-size:1.75rem;font-weight:700}.goal-progress{margin:2rem 0}.goal-progress h3{color:var(--color-text-muted);text-align:center}.progress-item{margin:.75rem 0}.progress-label{display:flex;font-size:.875rem;justify-content:space-between;margin-bottom:.25rem}.progress-bar{background:hsla(0,0%,100%,.1);border-radius:6px;height:12px;overflow:hidden}.progress-fill{border-radius:6px;height:100%;transition:width .3s ease}.progress-fill.crop{background:linear-gradient(90deg,var(--color-crop),#9acd32)}.progress-fill.meat{background:linear-gradient(90deg,var(--color-meat),#ff6b6b)}.progress-fill.gold{background:linear-gradient(90deg,var(--color-gold),#ffe066)}#continue-btn{display:block;margin:2rem auto 0}.cards-this-turn{background:rgba(255,220,50,.1);border:2px solid var(--color-warning);border-radius:var(--radius-md);margin:1.5rem 0;padding:1rem;text-align:center}.cards-this-turn h3{color:var(--color-warning);margin-bottom:.75rem}.action-buttons,.trade-players{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin:2rem 0}.trade-player-btn{border:3px solid transparent;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:var(--font-main);font-size:1.1rem;font-weight:600;min-width:150px;padding:1.5rem 2rem;transition:all .2s ease}.trade-player-btn:hover{box-shadow:var(--shadow-medium);transform:translateY(-3px)}.trade-player-btn.player-0{background:var(--color-player-1)}.trade-player-btn.player-1{background:var(--color-player-2)}.trade-player-btn.player-2{background:var(--color-player-3)}.trade-player-btn.player-3{background:var(--color-player-4)}#cancel-trade{display:block;margin:0 auto}.trade-subtitle{color:var(--color-text-muted);margin-bottom:2rem;text-align:center}.trade-section{background:hsla(0,0%,100%,.05);border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1.5rem}.trade-section h3{margin-bottom:1rem;text-align:center}.trade-resources{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.trade-resource{gap:.5rem}.trade-resource,.trade-resource-info{align-items:center;display:flex;flex-direction:column}.trade-resource-info{border-radius:var(--radius-sm);min-width:80px;padding:.5rem 1rem}.trade-resource-info.crop{background:var(--color-crop)}.trade-resource-info.meat{background:var(--color-meat)}.trade-resource-info.gold{background:var(--color-gold);color:#333}.trade-controls{align-items:center;display:flex;gap:.5rem}.trade-controls button{background:hsla(0,0%,100%,.2);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.25rem;height:40px;transition:all .2s ease;width:40px}.trade-controls button:hover{background:hsla(0,0%,100%,.3)}.trade-controls button:disabled{cursor:not-allowed;opacity:.3}.trade-amount{font-size:1.5rem;font-weight:700;min-width:40px;text-align:center}.trade-visibility{margin:1.5rem 0;text-align:center}.toggle-label{align-items:center;cursor:pointer;display:inline-flex;gap:.75rem}.toggle-label input[type=checkbox]{cursor:pointer;height:20px;width:20px}.toggle-text{color:var(--color-text-muted)}.trade-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.trade-wait-content{text-align:center}.trade-wait-content h2{color:var(--color-success)}.offer-hidden{background:hsla(0,0%,100%,.05);border:2px dashed hsla(0,0%,100%,.2);border-radius:var(--radius-md);color:var(--color-text-muted);padding:2rem;text-align:center}.respond-buttons{display:flex;gap:1.5rem;justify-content:center;margin-top:2rem}.trade-result-content{text-align:center}.result-message.success h2{color:var(--color-success)}.result-message.failed h2{color:var(--color-danger)}#trade-summary{background:hsla(0,0%,100%,.05);border-radius:var(--radius-md);margin:1.5rem 0;padding:1rem}.game-over-content{text-align:center}.game-over-content h1{animation:celebrate .5s ease infinite alternate;color:var(--color-gold);text-shadow:0 0 30px rgba(255,215,0,.5)}@keyframes celebrate{0%{transform:scale(1)}to{transform:scale(1.05)}}.game-over-content h2{margin:1rem 0}#winner-role{color:var(--color-text-muted);font-size:1.25rem;margin-bottom:2rem}#final-resources{display:flex;gap:1rem;justify-content:center;margin:2rem 0}.rage-quit-content h1{color:var(--color-danger);text-shadow:0 0 30px rgba(239,71,111,.5)}.rage-quit-content h2{color:var(--color-warning)}.rage-quit-content p{font-size:1.5rem;margin-bottom:2rem}@media (max-width:768px){.screen{padding:1rem}.btn-large{max-width:300px;width:100%}.player-count-buttons{align-items:center;flex-direction:column}.btn-player{max-width:250px;width:100%}.action-buttons{align-items:center;flex-direction:column}.btn-action{max-width:250px;width:100%}.resource-card{min-width:85px;padding:.75rem 1rem}.trade-player-btn{max-width:200px;width:100%}.respond-buttons{align-items:center;flex-direction:column}.btn-accept,.btn-decline{max-width:250px;width:100%}.trade-buttons{align-items:center;flex-direction:column}.trade-buttons .btn{max-width:250px;width:100%}}@media (max-width:480px){html{font-size:14px}.rules-box{padding:1rem}.role-card{padding:1.25rem}.resource-cards{gap:.5rem}.resource-card{min-width:75px;padding:.5rem .75rem}.trade-resource-info{min-width:65px;padding:.25rem .5rem}.trade-controls button{height:35px;width:35px}}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.menu-buttons{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.connect-form,.create-game-form,.join-game-form{margin:0 auto;max-width:400px}.form-group{margin-bottom:1.5rem;text-align:left}.form-group label{color:var(--color-text-muted);display:block;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select{background:hsla(0,0%,100%,.1);border:2px solid hsla(0,0%,100%,.2);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-main);font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus{background:hsla(0,0%,100%,.15);border-color:var(--color-primary);outline:none}.form-group input::placeholder{color:hsla(0,0%,100%,.4)}.form-hint{color:var(--color-text-muted);font-size:.75rem;margin-top:.5rem}.form-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.error-message{color:var(--color-danger);margin-top:1rem;min-height:1.5rem;text-align:center}.lobby-welcome{color:var(--color-success);margin-bottom:2rem;text-align:center}.lobby-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.games-list{background:hsla(0,0%,100%,.05);border-radius:var(--radius-lg);margin-bottom:2rem;max-height:400px;overflow-y:auto;padding:1.5rem}.games-list h3{margin-bottom:1rem;text-align:center}.no-games{color:var(--color-text-muted);padding:2rem;text-align:center}.game-item{align-items:center;background:hsla(0,0%,100%,.05);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:.75rem;padding:1rem;transition:all .2s ease}.game-item:hover{background:hsla(0,0%,100%,.1)}.game-info{flex:1}.game-name{align-items:center;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem}.game-name .lock-icon,.game-players{font-size:.875rem}.game-players{color:var(--color-text-muted);display:block;margin-top:.25rem}.game-locked{font-size:.875rem;margin-left:.5rem}.game-details{color:var(--color-text-muted);font-size:.875rem;margin-top:.25rem}.game-item .btn{padding:.5rem 1.5rem}#disconnect-btn{display:block;margin:0 auto}.game-code{color:var(--color-text-muted);margin-bottom:2rem;text-align:center}.players-list{background:hsla(0,0%,100%,.05);border-radius:var(--radius-lg);margin-bottom:2rem;padding:1.5rem}.players-list h3{margin-bottom:1rem;text-align:center}.player-item{align-items:center;background:hsla(0,0%,100%,.05);border-radius:var(--radius-md);display:flex;gap:1rem;margin-bottom:.5rem;padding:.75rem 1rem}.player-item.player-0{border-left:4px solid var(--color-player-1)}.player-item.player-1{border-left:4px solid var(--color-player-2)}.player-item.player-2{border-left:4px solid var(--color-player-3)}.player-item.player-3{border-left:4px solid var(--color-player-4)}.player-color{border-radius:50%;flex-shrink:0;height:12px;width:12px}.player-name{flex:1;font-weight:600}.you-badge{color:#fff}.player-badge,.you-badge{background:var(--color-primary);border-radius:var(--radius-sm);font-size:.75rem;padding:.25rem .5rem}.player-badge.host{background:var(--color-warning);color:#333}.player-badge.you{background:var(--color-success)}.waiting-room-actions{margin-bottom:2rem;text-align:center}.waiting-hint{color:var(--color-text-muted);font-size:.875rem;margin-top:.5rem}#leave-game-btn{display:block;margin:0 auto}.waiting-turn-content{text-align:center}.current-turn-info{font-size:1.25rem;margin-bottom:2rem}.current-turn-info span{color:var(--color-warning);font-weight:700}.waiting-animation{animation:pulse-wait 1.5s infinite;font-size:3rem;margin:2rem 0}@keyframes pulse-wait{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.your-info-preview{background:hsla(0,0%,100%,.05);border-radius:var(--radius-lg);margin-top:2rem;padding:1.5rem}.your-info-preview h3{margin-bottom:1rem;text-align:center}.your-info-preview h3 span{color:var(--color-success)}@media (max-width:768px){.lobby-actions{align-items:center;flex-direction:column}.game-item{align-items:flex-start;flex-direction:column;gap:1rem}.game-item .btn{width:100%}.form-buttons{flex-direction:column}.form-buttons .btn{width:100%}}.leave-game-x{align-items:center;background:hsla(0,0%,100%,.1);border:none;border-radius:50%;color:var(--color-text-muted);cursor:pointer;display:flex;font-size:1.25rem;height:2.5rem;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s ease;width:2.5rem;z-index:10}.leave-game-x:hover{background:var(--color-danger);color:#fff;transform:scale(1.1)}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:rgba(0,0,0,.8);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .2s ease;background:var(--color-bg-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-strong);max-width:90%;padding:2rem;text-align:center;width:320px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h2{color:var(--color-text);margin-bottom:.5rem}.modal-content p{color:var(--color-text-muted);font-size:1.25rem;margin-bottom:1.5rem}.modal-buttons{display:flex;gap:1rem;justify-content:center}.modal-buttons .btn{flex:1;min-width:100px}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#d63a5b}