.memory-card{aspect-ratio:1;perspective:1000px;cursor:pointer;transition:transform .2s ease;border-radius:12px;position:relative;min-height:80px;max-height:350px}.memory-card:hover:not(.disabled):not(.matched){transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.memory-card:focus{outline:3px solid #007bff;outline-offset:2px}.memory-card.disabled{cursor:not-allowed}.memory-card.matched{opacity:.8;transform:scale(.95)}.card-inner{position:relative;width:100%;height:100%;text-align:center;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d;border-radius:12px}.memory-card.flipped .card-inner{transform:rotateY(180deg)}.card-face{position:absolute;top:0;left:0;width:100%;height:100%;backface-visibility:hidden;border-radius:12px;overflow:hidden}.card-back{background:linear-gradient(135deg,var(--border-light) 0%,var(--border-medium) 100%);display:flex;align-items:center;justify-content:center;transform:rotateY(0)}.card-pattern{width:60%;height:60%;position:relative;opacity:.3}.pattern-dots{width:100%;height:100%;background-image:radial-gradient(circle at 25% 25%,var(--text-muted) 2px,transparent 2px),radial-gradient(circle at 75% 25%,var(--text-muted) 2px,transparent 2px),radial-gradient(circle at 25% 75%,var(--text-muted) 2px,transparent 2px),radial-gradient(circle at 75% 75%,var(--text-muted) 2px,transparent 2px),radial-gradient(circle at 50% 50%,var(--text-muted) 3px,transparent 3px);background-size:20px 20px;background-position:0 0,0 0,0 0,0 0,0 0}.card-front{background:var(--card-bg);transform:rotateY(180deg);padding:0;display:block}.card-image{width:100%;height:100%;object-fit:cover;border-radius:12px;-webkit-user-select:none;user-select:none;pointer-events:none;display:block}.memory-card.matched .card-face{box-shadow:0 0 0 3px #28a745}.memory-card.matched .card-back{background:linear-gradient(135deg,var(--accent-color) 0%,var(--accent-warm) 100%);opacity:.7}.memory-card.disabled{opacity:.6}.memory-card.disabled:not(.flipped):not(.matched) .card-inner{transform:none!important}@media (max-width: 768px){.memory-card,.card-face{border-radius:8px}.card-front{padding:0}.card-image{border-radius:8px}}@media (prefers-reduced-motion: reduce){.memory-card,.card-inner{transition:none}.memory-card:hover:not(.disabled):not(.matched){transform:none;box-shadow:0 4px 12px #0000001a}}.game-board-container{max-width:100%;margin:0 auto;padding:.5rem 1rem;min-height:100vh;display:flex;flex-direction:column;background:var(--primary-bg);position:relative}.game-controls-top{display:flex;gap:1rem;align-items:center;justify-content:center;margin:.75rem auto;padding:.75rem;background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--shadow-light);max-width:fit-content}.timing-control{display:flex;flex-direction:column;gap:.25rem;background:var(--card-bg);padding:.75rem;border-radius:12px;box-shadow:0 4px 12px var(--shadow-light);border:2px solid var(--border-light)}.timing-label{font-size:.75rem;color:var(--text-secondary);font-weight:500;margin:0;white-space:nowrap}.timing-select{background:var(--card-bg);border:1px solid var(--border-medium);border-radius:4px;padding:.25rem .5rem;font-size:.8rem;color:var(--text-primary);cursor:pointer;min-width:120px}.timing-select:focus{outline:2px solid var(--accent-color);outline-offset:1px;border-color:var(--accent-color)}.timing-select option{background:var(--card-bg);color:var(--text-primary)}.manual-flip-btn{background:var(--accent-color);color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px var(--shadow-light);white-space:nowrap;min-width:100px}.manual-flip-btn:hover:not(:disabled){background:#6b8c78;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-medium)}.manual-flip-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px var(--shadow-light)}.manual-flip-btn:disabled{background:var(--text-muted);cursor:not-allowed;opacity:.5}.manual-flip-btn:focus{outline:2px solid var(--accent-color);outline-offset:2px}.game-header{text-align:center;margin-bottom:.5rem;padding:.5rem .5rem 0;background:transparent}.game-header h1{font-size:1.5rem;color:var(--text-primary);margin:0 0 .25rem;font-weight:700;font-family:system-ui,-apple-system,sans-serif}.game-subtitle{font-size:.85rem;color:var(--text-secondary);margin:0 0 .5rem;font-weight:400}.game-stats{display:inline-block;justify-content:center;font-size:.95rem;color:var(--text-primary);font-weight:600;background:var(--secondary-bg);padding:.5rem 1rem;border-radius:20px;box-shadow:0 2px 8px var(--shadow-light)}.game-stats span{padding:0;background:transparent;border:none}.game-board{display:grid;gap:1rem;margin:.5rem auto;padding:1rem;background:var(--card-bg);border-radius:12px;box-shadow:0 8px 24px var(--shadow-medium);max-width:100%;justify-content:center;border:1px solid var(--border-light);flex:1}.game-board[data-columns="3"]{grid-template-columns:repeat(3,minmax(120px,1fr));max-width:min(90vw,800px)}.game-board[data-columns="4"]{grid-template-columns:repeat(4,minmax(100px,1fr));max-width:min(90vw,1000px)}.game-board[data-columns="5"]{grid-template-columns:repeat(5,minmax(90px,1fr));max-width:min(90vw,1100px)}.game-board[data-columns="6"]{grid-template-columns:repeat(6,minmax(80px,1fr));max-width:min(90vw,1200px)}.game-board[data-columns="8"]{grid-template-columns:repeat(8,minmax(70px,1fr));max-width:min(95vw,1400px)}.game-board[data-columns="10"]{grid-template-columns:repeat(10,minmax(60px,1fr));max-width:min(95vw,1500px)}@media (min-width: 768px){.game-board{gap:1.25rem;padding:2.5rem}.game-board[data-columns="3"]{grid-template-columns:repeat(3,minmax(140px,1fr));max-width:min(85vw,900px)}.game-board[data-columns="4"]{grid-template-columns:repeat(4,minmax(120px,1fr));max-width:min(85vw,1100px)}.game-board[data-columns="5"]{grid-template-columns:repeat(5,minmax(110px,1fr));max-width:min(85vw,1200px)}.game-board[data-columns="6"]{grid-template-columns:repeat(6,minmax(100px,1fr));max-width:min(90vw,1300px)}.game-board[data-columns="8"]{grid-template-columns:repeat(8,minmax(90px,1fr));max-width:min(90vw,1500px)}.game-board[data-columns="10"]{grid-template-columns:repeat(10,minmax(80px,1fr));max-width:min(95vw,1600px)}}@media (min-width: 1024px){.game-board{gap:1.5rem;padding:3rem}.game-board[data-columns="3"]{grid-template-columns:repeat(3,minmax(160px,1fr));max-width:min(80vw,1000px)}.game-board[data-columns="4"]{grid-template-columns:repeat(4,minmax(140px,1fr));max-width:min(80vw,1200px)}.game-board[data-columns="5"]{grid-template-columns:repeat(5,minmax(130px,1fr));max-width:min(85vw,1300px)}.game-board[data-columns="6"]{grid-template-columns:repeat(6,minmax(120px,1fr));max-width:min(85vw,1400px)}.game-board[data-columns="8"]{grid-template-columns:repeat(8,minmax(110px,1fr));max-width:min(90vw,1600px)}.game-board[data-columns="10"]{grid-template-columns:repeat(10,minmax(100px,1fr));max-width:min(90vw,1700px)}}.game-complete{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.game-complete h2{color:#fff;font-size:3rem;margin-bottom:1rem;text-align:center}.game-complete p{color:#fff;font-size:1.5rem;margin-bottom:2rem;text-align:center}.game-complete-actions{display:flex;gap:1rem;align-items:center;justify-content:center}.close-modal-btn{background:rgba(255,255,255,.2);color:#fff;border:2px solid white;padding:1rem 2rem;font-size:1.2rem;font-weight:600;border-radius:50px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #ffffff1a}.close-modal-btn:hover{background:rgba(255,255,255,.3);transform:translateY(-2px);box-shadow:0 6px 20px #fff3}.play-again-btn{background:#28a745;color:#fff;border:none;padding:1rem 2rem;font-size:1.2rem;font-weight:600;border-radius:50px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #28a7454d}.play-again-btn:hover{background:#218838;transform:translateY(-2px);box-shadow:0 6px 20px #28a74566}.game-controls{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:auto;padding:.75rem 1rem}.difficulty-navigation{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.difficulty-nav-btn{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-medium);padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .3s ease;min-height:44px;min-width:44px;display:flex;align-items:center;gap:.5rem}.difficulty-nav-btn:hover:not(:disabled){background:var(--border-light);border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-medium)}.difficulty-nav-btn:disabled{background:var(--card-bg);color:var(--text-muted);border-color:var(--border-light);cursor:not-allowed;opacity:.6}.level-up{border-color:var(--accent-warm)}.level-up:hover:not(:disabled){border-color:var(--accent-warm)}.level-down{border-color:var(--accent-color)}.new-game-btn{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-medium);padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:none;min-height:44px;min-width:44px;display:flex;align-items:center;gap:.5rem}.new-game-btn:hover{background:var(--border-light);border-color:var(--accent-color);transform:none;box-shadow:none}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.game-board-container{padding:.25rem .5rem}.game-controls-top{flex-direction:column;gap:.5rem;padding:.5rem}.timing-control{padding:.5rem}.timing-label{font-size:.7rem}.timing-select{font-size:.75rem;min-width:100px}.manual-flip-btn{font-size:.75rem;padding:.4rem .75rem;min-width:90px}.game-header{margin-bottom:.5rem;padding:.5rem .5rem 0}.game-header h1{font-size:1.25rem}.game-subtitle{font-size:.75rem;margin-bottom:.5rem}.game-stats{font-size:.85rem;padding:.4rem .8rem}.game-board{gap:.5rem;padding:.5rem}.game-board[data-columns="3"]{grid-template-columns:repeat(3,100px);max-width:380px}.game-board[data-columns="4"]{grid-template-columns:repeat(4,80px);max-width:400px}.game-board[data-columns="5"],.game-board[data-columns="6"],.game-board[data-columns="8"]{grid-template-columns:repeat(4,75px);max-width:380px}.game-board[data-columns="10"]{grid-template-columns:repeat(5,65px);max-width:400px}.difficulty-navigation{flex-direction:column;gap:.75rem}.difficulty-nav-btn{font-size:.8rem;padding:.6rem 1rem}.new-game-btn{font-size:.85rem}.game-complete h2{font-size:2rem}.game-complete p{font-size:1.2rem;padding:0 1rem}.game-complete-actions{flex-direction:column;gap:.75rem}.close-modal-btn,.play-again-btn{font-size:1rem;padding:.75rem 1.5rem}}@media (max-width: 480px){.game-board[data-columns="4"],.game-board[data-columns="5"]{grid-template-columns:repeat(4,70px);max-width:295px;gap:.25rem}.game-header h1{font-size:1.75rem}.game-subtitle{font-size:.85rem}}@media (prefers-reduced-motion: reduce){.game-complete{animation:none}.play-again-btn:hover,.new-game-btn:hover,.manual-flip-btn:hover{transform:none}}@media (prefers-contrast: high){.game-header,.game-board{border:2px solid #000000}.game-stats span{border-color:#000}}.about-page{min-height:100vh;background:var(--primary-bg);padding:4rem 2rem 2rem}.about-content{max-width:800px;margin:0 auto;background:var(--card-bg);border-radius:16px;padding:3rem;box-shadow:0 4px 12px var(--shadow-light)}.about-section{margin-bottom:3rem}.about-section:last-child{margin-bottom:0}.about-section h1{font-size:2.5rem;color:var(--text-primary);margin-bottom:1.5rem;font-weight:700}.about-section h2{font-size:1.75rem;color:var(--text-secondary);margin-bottom:1rem;font-weight:600}.about-section p{font-size:1.125rem;line-height:1.8;color:var(--text-primary);margin-bottom:1rem}.about-section p:last-child{margin-bottom:0}.who-made-section .profile-container{display:flex;align-items:flex-start;gap:2rem}.profile-photo{width:150px;height:auto;border-radius:12px;flex-shrink:0;box-shadow:0 4px 12px var(--shadow-medium)}.profile-text{flex:1}.profile-text h2{margin-top:0}.about-section .highlight{font-weight:600;color:var(--accent-color);font-size:1.25rem;margin-top:1.5rem}.contact-link{color:var(--accent-color);text-decoration:none;font-weight:500;border-bottom:2px solid transparent;transition:border-color .3s ease}.contact-link:hover{border-bottom-color:var(--accent-color)}@media (max-width: 768px){.about-page{padding:1rem}.about-content{padding:2rem 1.5rem}.about-section h1{font-size:2rem}.about-section h2{font-size:1.5rem}.about-section p{font-size:1rem}.about-section .highlight{font-size:1.125rem}.who-made-section .profile-container{flex-direction:column;align-items:center;text-align:center}.profile-photo{width:120px}.profile-text h2{margin-top:1rem}}.theme-gallery{min-height:100vh;background:var(--primary-bg);padding:2rem;position:relative}.gallery-header{text-align:center;color:var(--text-primary);margin-bottom:3rem;padding-top:4rem}.how-to-play{background:var(--card-bg);border-radius:12px;padding:1.5rem;margin:2rem auto;max-width:500px;box-shadow:0 4px 12px var(--shadow-light);border:2px solid var(--border-light)}.how-to-play h3{color:var(--accent-color);margin:0 0 1rem;font-size:1.3rem}.how-to-play p{margin:.5rem 0;color:var(--text-secondary);font-size:1rem;text-align:left}.gallery-header h1{font-size:3rem;font-weight:700;margin:0 0 .5rem;text-shadow:none}.gallery-header p{font-size:1.2rem;opacity:.9;margin:0}.about-link{display:inline-block;margin-top:1rem;color:var(--accent-color);text-decoration:none;font-size:1rem;border-bottom:2px solid transparent;transition:border-color .3s ease}.about-link:hover{border-bottom-color:var(--accent-color)}.themes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.theme-card{background:var(--card-bg);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px var(--shadow-light);border:3px solid transparent;min-height:44px;min-width:44px}.theme-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow-medium);border-color:var(--accent-color)}.theme-card:active{transform:translateY(-2px)}.theme-preview{width:100%;height:160px;border-radius:12px;overflow:hidden;margin-bottom:1rem;background:var(--border-light);display:flex;align-items:center;justify-content:center}.theme-preview img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.theme-card:hover .theme-preview img{transform:scale(1.05)}.theme-info{text-align:center}.theme-name{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.theme-info h3{color:var(--text-primary)}.theme-description{font-size:.95rem;color:var(--text-secondary);margin:0 0 .75rem;line-height:1.4}.theme-info p{color:var(--text-secondary)}.theme-count{display:inline-block;background:transparent;color:var(--text-muted);padding:.25rem 0;border-radius:0;font-size:.85rem;font-weight:400;border:none}.theme-suggestion-section{max-width:600px;margin:4rem auto 2rem;padding:2rem;background:var(--card-bg);border-radius:16px;box-shadow:0 4px 12px var(--shadow-light);border:2px solid var(--border-light)}.theme-suggestion-section h2{color:var(--text-primary);font-size:1.8rem;margin:0 0 1rem;text-align:center}.suggestion-description{color:var(--text-secondary);text-align:center;margin:0 0 2rem;font-size:1rem;line-height:1.5}.suggestion-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-primary);font-weight:600;font-size:.95rem}.optional-label{color:var(--text-muted);font-weight:400;font-size:.875rem}.form-input{padding:.75rem 1rem;border:2px solid var(--border-medium);border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .3s ease;background:var(--card-bg);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-input:focus{outline:none;border-color:var(--accent-color)}.form-input::placeholder{color:var(--text-muted)}.submit-button{background:var(--accent-color);color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:44px;margin-top:.5rem}.submit-button:hover{background:#6b8c78;transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-medium)}.submit-button:active{transform:translateY(0)}.submit-button:disabled{background:var(--border-medium);cursor:not-allowed;transform:none;box-shadow:none}.form-message{padding:.75rem 1rem;border-radius:8px;font-size:.95rem;font-weight:500;text-align:center;margin-top:.5rem}.form-message.success{background:#e8f5e9;color:#2e7d32;border:2px solid #81c784}.form-message.error{background:#ffebee;color:#c62828;border:2px solid #ef5350}@media (max-width: 768px){.theme-gallery{padding:1rem}.gallery-header h1{font-size:2.5rem}.themes-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.theme-card{padding:1rem}.theme-preview{height:140px}.theme-name{font-size:1.2rem}.theme-suggestion-section{margin:3rem 1rem 1rem;padding:1.5rem}.theme-suggestion-section h2{font-size:1.5rem}}@media (max-width: 480px){.themes-grid{grid-template-columns:1fr}.gallery-header h1{font-size:2rem}.theme-suggestion-section{padding:1.25rem}.submit-button{padding:.875rem 1.5rem}}.difficulty-selection{min-height:100vh;background:var(--primary-bg);padding:2rem;position:relative}.accessibility-controls{position:fixed;top:1rem;right:1rem;z-index:100;display:flex;gap:.5rem}.accessibility-button{background:var(--card-bg);border:2px solid var(--border-medium);border-radius:8px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:all .3s ease;color:var(--text-primary);font-weight:500;min-height:44px;min-width:44px;display:flex;align-items:center;gap:.5rem}.accessibility-button:hover{background:var(--border-light);border-color:var(--accent-color)}.accessibility-button:focus{outline:2px solid var(--accent-color);outline-offset:2px}.difficulty-header{max-width:800px;margin:0 auto 3rem}.difficulty-header .back-button{margin-bottom:2rem}.selected-theme{display:flex;align-items:center;background:var(--card-bg);padding:1.5rem;border-radius:16px;box-shadow:0 4px 12px var(--shadow-light);border:2px solid var(--border-light)}.theme-preview-small{width:80px;height:80px;border-radius:12px;object-fit:cover;margin-right:1.5rem;flex-shrink:0}.theme-details h2{font-size:1.8rem;color:var(--text-primary);margin:0 0 .5rem}.theme-details p{color:var(--text-secondary);margin:0 0 .5rem;font-size:1rem}.theme-details span{background:transparent;color:var(--text-muted);padding:.25rem 0;border-radius:0;font-size:.9rem;font-weight:400;border:none}.difficulty-content{max-width:800px;margin:0 auto;text-align:center}.difficulty-content h3{font-size:2.5rem;color:var(--text-primary);margin:0 0 .5rem;text-shadow:none}.difficulty-content>p{font-size:1.2rem;color:var(--text-secondary);margin:0 0 3rem}.loading{text-align:center;color:var(--text-primary);font-size:1.5rem;margin-top:4rem}.error-state{text-align:center;max-width:500px;margin:4rem auto;padding:2rem;background:var(--card-bg);border-radius:16px;box-shadow:0 4px 12px var(--shadow-light);border:2px solid var(--border-light)}.error-icon{font-size:4rem;margin-bottom:1rem}.error-state h2{color:var(--text-primary);font-size:1.8rem;margin:0 0 1rem}.error-state p{color:var(--text-secondary);font-size:1.1rem;margin:0 0 2rem;line-height:1.5}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.back-to-themes-button{display:inline-flex;align-items:center;text-decoration:none;color:var(--text-primary);background:var(--card-bg);border:2px solid var(--border-medium);padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:44px}.back-to-themes-button:hover{background:var(--border-light);border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-medium)}.retry-button{background:var(--accent-color);color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:44px}.retry-button:hover{background:#6b8c78;transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-medium)}.retry-button:active{transform:translateY(0)}.difficulty-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem}.difficulty-card{background:var(--card-bg);border:none;border-radius:16px;padding:2rem 1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px var(--shadow-light);border:3px solid transparent;text-align:center;min-height:44px;min-width:44px}.difficulty-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow-medium);border-color:var(--accent-color)}.difficulty-card:active{transform:translateY(-2px)}.difficulty-icon{font-size:1.5rem;margin-bottom:1rem;color:var(--accent-color);letter-spacing:.2rem}.difficulty-label{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.difficulty-description{font-size:1rem;color:var(--text-secondary);margin:0 0 .5rem}.difficulty-pairs{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.difficulty-time{display:inline-block;background:transparent;color:var(--text-secondary);padding:.5rem 1rem;border:2px solid var(--border-medium);border-radius:20px;font-size:.9rem;font-weight:500}.difficulty-card:nth-child(1) .difficulty-icon{color:var(--accent-color)}.difficulty-card:nth-child(2) .difficulty-icon{color:var(--accent-warm)}.difficulty-card:nth-child(3) .difficulty-icon{color:var(--text-secondary)}.difficulty-card:nth-child(4) .difficulty-icon{color:var(--text-primary)}@media (max-width: 768px){.difficulty-selection{padding:1rem}.selected-theme{flex-direction:column;text-align:center}.theme-preview-small{margin:0 0 1rem}.difficulty-content h3{font-size:2rem}.difficulty-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.difficulty-card{padding:1.5rem 1rem}}@media (max-width: 480px){.difficulty-grid{grid-template-columns:1fr 1fr}.difficulty-card{padding:1rem}.difficulty-icon{font-size:1.5rem}.difficulty-label{font-size:1.2rem}}.global-nav{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;gap:1rem;align-items:center}.nav-link{display:inline-block;padding:.75rem 1.5rem;background:var(--card-bg);color:var(--text-primary);text-decoration:none;border-radius:8px;border:2px solid var(--border-medium);font-weight:500;font-size:1rem;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow-light)}.nav-link:hover{background:var(--border-light);border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-medium)}.theme-switcher{padding:.75rem 1rem;background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-medium);border-radius:8px;font-weight:500;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow-light);min-height:44px;min-width:44px}.theme-switcher:hover{border-color:var(--accent-color);box-shadow:0 4px 12px var(--shadow-medium)}.theme-switcher:focus{outline:2px solid var(--accent-color);outline-offset:2px}.theme-switcher option{background:var(--card-bg);color:var(--text-primary)}@media (max-width: 768px){.global-nav{top:.5rem;right:.5rem;gap:.5rem}.nav-link{padding:.5rem 1rem;font-size:.9rem}.theme-switcher{padding:.5rem .75rem;font-size:.9rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-bg: #f7f7f5;--secondary-bg: #eef2eb;--accent-color: #7b9f8a;--accent-warm: #c4a569;--text-primary: #2d3339;--text-secondary: #5a6169;--text-muted: #8a9199;--card-bg: #ffffff;--border-light: #e2e6e3;--border-medium: #d1d7d4;--shadow-light: rgba(45, 51, 57, .08);--shadow-medium: rgba(45, 51, 57, .12)}[data-theme=dark]{--primary-bg: #1a1d23;--secondary-bg: #22252b;--accent-color: #6b9f8a;--accent-warm: #b8a679;--text-primary: #e8e9eb;--text-secondary: #b8bcc2;--text-muted: #8a8e94;--card-bg: #2a2d33;--border-light: #3a3d43;--border-medium: #4a4d53;--shadow-light: rgba(0, 0, 0, .3);--shadow-medium: rgba(0, 0, 0, .5)}[data-theme=high-contrast]{--primary-bg: #000000;--secondary-bg: #1a1a1a;--accent-color: #00d4ff;--accent-warm: #ffa500;--text-primary: #ffffff;--text-secondary: #e0e0e0;--text-muted: #b0b0b0;--card-bg: #1a1a1a;--border-light: #666666;--border-medium: #888888;--shadow-light: rgba(255, 255, 255, .15);--shadow-medium: rgba(255, 255, 255, .3)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}[data-reduced-motion=true] *,[data-reduced-motion=true] *:before,[data-reduced-motion=true] *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;transform:none!important}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--primary-bg);color:var(--text-primary);line-height:1.6}.App{min-height:100vh}.page-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background-color:var(--card-bg);border-bottom:2px solid var(--border-light);box-shadow:0 2px 4px var(--shadow-light)}.game-nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--card-bg);box-shadow:0 2px 8px var(--shadow-light)}.game-info{display:flex;align-items:center;gap:1rem}.theme-name{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.difficulty-badge{background:var(--accent-color);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.9rem;font-weight:500}.pairs-count{color:var(--text-secondary);font-size:.95rem}.game-main{padding:2rem}.back-button{display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--text-secondary);border:1px solid var(--border-medium);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .3s ease;min-height:44px;min-width:44px;opacity:.8}.back-button:hover,.back-button:focus{background:var(--card-bg);border-color:var(--accent-color);color:var(--text-primary);opacity:1}.back-button:visited{color:var(--text-secondary)}.nav-button,.control-button,.action-button,.setting-button{display:inline-block;padding:.75rem 1.5rem;margin:.5rem;border:none;border-radius:8px;text-decoration:none;text-align:center;font-weight:600;cursor:pointer;transition:all .2s;font-size:1rem}.primary{background-color:var(--accent-color);color:#fff;min-height:44px;min-width:44px}.primary:hover{background-color:#6b8c78}.secondary{background-color:#6c757d;color:#fff}.secondary:hover{background-color:#545b62}.tertiary{background-color:#28a745;color:#fff}.tertiary:hover{background-color:#1e7e34}.home-page{text-align:center;padding:2rem}.hero-section{margin-bottom:3rem}.hero-section h1{font-size:3rem;color:#343a40;margin-bottom:1rem}.hero-section p{font-size:1.25rem;color:#6c757d}.main-navigation{margin-bottom:4rem}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.feature{background:white;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.feature h3{color:#007bff;margin-bottom:1rem}.game-page{min-height:100vh;background:var(--primary-bg)}.settings-button{color:#6c757d;text-decoration:none;font-weight:500;transition:color .2s}.settings-button:hover{color:#495057}.game-main{padding:0}.create-form{max-width:600px;margin:0 auto;padding:2rem}.theme-section,.difficulty-section{margin-bottom:3rem}.theme-input-group{display:flex;flex-direction:column;gap:.5rem}.theme-input{padding:1rem;border:2px solid #ced4da;border-radius:8px;font-size:1rem}.theme-input:focus{outline:none;border-color:#007bff}.input-help{color:#6c757d;font-size:.875rem}.difficulty-selector{display:flex;flex-direction:column;gap:1rem}.difficulty-slider{width:100%}.difficulty-labels{display:flex;justify-content:space-between;font-size:.875rem;color:#6c757d}.actions{display:flex;gap:1rem;justify-content:center}.generate-button:disabled{background-color:#6c757d;cursor:not-allowed}.settings-content{max-width:600px;margin:0 auto;padding:2rem}.settings-content section{margin-bottom:3rem}.setting-item{margin-bottom:1.5rem}.setting-label{display:flex;align-items:center;gap:.5rem;font-weight:500}.volume-slider{width:100%;margin-top:.5rem}.parent-auth-page .auth-content{max-width:400px;margin:0 auto;padding:2rem}.pin-form{background:white;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;text-align:center}.pin-input-group{margin:2rem 0}.pin-input{padding:1rem;border:2px solid #ced4da;border-radius:8px;font-size:1.5rem;text-align:center;width:150px}.auth-button{background-color:#28a745;color:#fff;padding:1rem 2rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:1rem}.demo-notice{margin-top:1rem;color:#6c757d;font-size:.875rem}.dashboard-content{max-width:1000px;margin:0 auto;padding:2rem}.dashboard-content section{margin-bottom:3rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.stat-number{display:block;font-size:2rem;font-weight:700;color:#007bff;margin-top:.5rem}.activity-list{background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.activity-item{display:flex;justify-content:space-between;padding:1rem;border-bottom:1px solid #e9ecef}.activity-item:last-child{border-bottom:none}.activity-date{color:#6c757d;font-size:.875rem}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap}@media (max-width: 768px){.hero-section h1{font-size:2rem}.page-header{padding:1rem}.features{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.activity-item{flex-direction:column;gap:.5rem}.action-buttons{flex-direction:column}}
