.setup-screen{max-width:600px;margin:0 auto;padding:40px 20px}.game-title{text-align:center;font-size:2.5rem;font-weight:800;color:#1a1a2e;margin-bottom:40px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.setup-section{margin-bottom:32px;background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 20px #00000014}.setup-section h2{font-size:1.25rem;font-weight:600;color:#212529;margin-bottom:4px}.section-hint{font-size:.875rem;color:#6c757d;margin-bottom:16px}.deck-options{display:flex;gap:12px;flex-wrap:wrap}.deck-button{flex:1;min-width:120px;padding:16px;border:2px solid #e9ecef;border-radius:12px;background:#f8f9fa;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.deck-button:hover{border-color:#667eea;background:#f0f0ff}.deck-button.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea20,#764ba220)}.deck-name{font-weight:600;font-size:1.1rem;color:#212529}.deck-count{font-size:.8rem;color:#6c757d}.pair-slider{display:flex;flex-direction:column;gap:12px}.pair-slider input[type=range]{width:100%;height:8px;border-radius:4px;background:#e9ecef;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.pair-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;box-shadow:0 2px 8px #667eea66}.pair-count{text-align:center;font-weight:600;font-size:1.1rem;color:#667eea}.player-count-options{display:flex;gap:12px;margin-bottom:20px}.player-count-button{flex:1;padding:16px;font-size:1.25rem;font-weight:600;border:2px solid #e9ecef;border-radius:12px;background:#f8f9fa;cursor:pointer;transition:all .2s ease}.player-count-button:hover{border-color:#667eea}.player-count-button.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.player-names{display:flex;flex-direction:column;gap:12px}.player-name-input{display:flex;align-items:center;gap:12px}.player-color-dot{width:20px;height:20px;border-radius:50%;flex-shrink:0}.player-name-input input{flex:1;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;transition:border-color .2s ease}.player-name-input input:focus{outline:none;border-color:#667eea}.start-button{width:100%;padding:20px;font-size:1.25rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:16px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #667eea66}.start-button:hover{transform:translateY(-2px);box-shadow:0 6px 30px #667eea80}.start-button:active{transform:translateY(0)}@media(max-width:480px){.game-title{font-size:2rem}.setup-section{padding:16px}.deck-button{min-width:100px;padding:12px}}.card{width:100%;height:0;padding-bottom:149%;position:relative;perspective:1000px;cursor:pointer;transition:transform .2s ease}.card:hover:not(.flipped):not(.matched){transform:scale(1.05)}.card.matched{cursor:default}.card.matched .card-inner{opacity:.7;transform:rotateY(180deg) scale(.95)}.card-inner{position:absolute;top:0;left:0;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d;border-radius:12px;box-shadow:0 4px 15px #0003}.card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:12px;overflow:hidden}.card-front{background:linear-gradient(145deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center}.card-back-design{width:85%;height:90%;border:3px solid rgba(255,255,255,.3);border-radius:8px;display:flex;align-items:center;justify-content:center}.card-pattern{width:60%;height:60%;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.05) 10px,rgba(255,255,255,.05) 20px);border:2px solid rgba(255,255,255,.2);border-radius:4px}.card-back{background:#fff;transform:rotateY(180deg);display:flex;flex-direction:column}.card-back img{width:100%;height:88%;object-fit:cover;object-position:top}.card-back.placeholder{background:linear-gradient(135deg,#667eea,#764ba2);justify-content:center;align-items:center}.card-back.placeholder:before{content:"?";font-size:4rem;color:#fff;opacity:.5}.card-label{height:12%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2px 4px;background:linear-gradient(to bottom,#f8f9fa,#e9ecef);border-top:1px solid #dee2e6}.child-name{font-size:.7rem;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.profession-name{font-size:.85rem;font-weight:700;color:#212529;text-align:center}@media(max-width:600px){.card-label{padding:2px}.child-name{font-size:.55rem}.profession-name{font-size:.65rem}}.game-board{display:grid;grid-template-columns:repeat(var(--columns, 4),minmax(160px,1fr));gap:16px;padding:20px;max-width:1400px;margin:0 auto}@media(max-width:900px){.game-board{gap:8px;padding:12px}}@media(max-width:600px){.game-board{gap:6px;padding:8px}}.player-panel{display:flex;justify-content:center;gap:16px;padding:16px;flex-wrap:wrap}.player-card{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border:3px solid transparent}.player-card.active{border-color:var(--player-color);box-shadow:0 4px 20px #00000026;transform:scale(1.05)}.player-indicator{width:16px;height:16px;border-radius:50%;background:var(--player-color);transition:transform .3s ease}.player-card.active .player-indicator{transform:scale(1.3);box-shadow:0 0 10px var(--player-color)}.player-info{display:flex;flex-direction:column}.player-name{font-weight:600;font-size:1rem;color:#212529}.player-score{font-size:.85rem;color:#6c757d}@media(max-width:600px){.player-panel{gap:8px;padding:8px}.player-card{padding:8px 12px;gap:8px}.player-name{font-size:.85rem}.player-score{font-size:.75rem}}.game-over-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-over-content{background:#fff;padding:40px;border-radius:24px;max-width:400px;width:100%;text-align:center;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.game-over-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.result-message{font-size:1.25rem;color:#6c757d;margin-bottom:32px}.final-scores h2{font-size:1rem;font-weight:600;color:#212529;margin-bottom:16px;text-transform:uppercase;letter-spacing:1px}.score-list{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}.score-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8f9fa;border-radius:12px;transition:all .3s ease}.score-item.winner{background:linear-gradient(135deg,#ffd70020,#ffb30020);border:2px solid #ffd700}.rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#e9ecef;border-radius:50%;font-weight:700;font-size:.9rem;color:#495057}.score-item.winner .rank{background:gold;color:#212529}.player-dot{width:12px;height:12px;border-radius:50%;background:var(--player-color)}.score-item .player-name{flex:1;text-align:left;font-weight:600;color:#212529}.score-item .player-score{font-weight:500;color:#6c757d}.play-again-button{width:100%;padding:16px;font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #667eea66}.play-again-button:hover{transform:translateY(-2px);box-shadow:0 6px 30px #667eea80}.app{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8eb)}.game-container{min-height:100vh;display:flex;flex-direction:column}.game-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fff;box-shadow:0 2px 10px #0000001a}.game-header h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.back-button{padding:8px 16px;font-size:.9rem;font-weight:600;color:#667eea;background:transparent;border:2px solid #667eea;border-radius:8px;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#667eea;color:#fff}@media(max-width:600px){.game-header{padding:12px 16px}.game-header h1{font-size:1.2rem}.back-button{padding:6px 12px;font-size:.8rem}}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;color:#212529}img{display:block;max-width:100%}button,input{font-family:inherit}
