:root{--color-guess-who:var(--accent-primary);--color-guess-who-soft:var(--accent-secondary);--color-guess-who-dark:var(--accent-primary);--bg-guess-who:var(--bg-primary);--gw-primary:#a855f7;--gw-primary-glow:rgba(168,85,247,0.35);--gw-secondary:#ec4899;--gw-cyan:#22d3ee;--gw-surface:rgba(20,20,25,0.92);--gw-surface-elevated:rgba(30,30,40,0.96);--gw-glass:rgba(255,255,255,0.06);--gw-border:rgba(255,255,255,0.12);--gw-text:var(--text-primary);--gw-text-muted:rgba(255,255,255,0.68);--gw-gradient:linear-gradient(135deg,#a855f7 0%,#ec4899 100%);--gw-bg:linear-gradient(135deg,#0b041f 0%,#1a0f38 50%,#0b0a22 100%);--gw-radius:16px;--gw-radius-sm:10px;--gw-timing:cubic-bezier(0.4,0,0.2,1);}[data-theme="light"]{--gw-surface:rgba(255,255,255,0.92);--gw-surface-elevated:rgba(245,245,250,0.98);--gw-glass:rgba(0,0,0,0.03);--gw-border:rgba(0,0,0,0.12);--gw-text-muted:rgba(0,0,0,0.62);--gw-bg:linear-gradient(135deg,#f5f3ff 0%,#fdf2f8 50%,#eff6ff 100%);}.nav-links{position:fixed !important;bottom:24px !important;left:50% !important;top:auto !important;transform:translateX(-50%) !important;flex-direction:row !important;padding:12px 24px !important;border-radius:100px !important;background:linear-gradient(135deg,rgba(168,85,247,0.22) 0%,rgba(20,20,25,0.88) 45%,rgba(236,72,153,0.18) 100%) !important;border:1px solid rgba(168,85,247,0.28) !important;-webkit-backdrop-filter:blur(14px) !important;backdrop-filter:blur(14px) !important;box-shadow:0 18px 60px rgba(168,85,247,0.14),0 14px 40px rgba(0,0,0,0.42),inset 0 1px 0 rgba(255,255,255,0.10) !important;overflow:hidden !important;isolation:isolate !important;}.nav-links::before{content:'';position:absolute;inset:-2px;background:radial-gradient(circle at 30% 120%,rgba(168,85,247,0.40),transparent 55%),radial-gradient(circle at 80% -30%,rgba(236,72,153,0.35),transparent 55%);opacity:0.55;pointer-events:none;z-index:0;}.nav-links>*{position:relative;z-index:1;}.nav-link{color:rgba(255,255,255,0.82);}.nav-link:hover{color:#ffffff;background:rgba(168,85,247,0.18);}.nav-link:focus-visible{outline:2px solid rgba(34,211,238,0.85);outline-offset:3px;}[data-theme="light"] .nav-links{background:linear-gradient(135deg,rgba(168,85,247,0.16) 0%,rgba(255,255,255,0.90) 50%,rgba(236,72,153,0.14) 100%) !important;border:1px solid rgba(107,33,168,0.22) !important;box-shadow:0 18px 60px rgba(107,33,168,0.12),0 14px 40px rgba(0,0,0,0.14),inset 0 1px 0 rgba(255,255,255,0.60) !important;}[data-theme="light"] .nav-link{color:rgba(0,0,0,0.68);}[data-theme="light"] .nav-link:hover{color:rgba(0,0,0,0.92);background:rgba(168,85,247,0.14);}.game-info-bar{display:none !important;}html,body{background:var(--gw-bg);background-color:#0b041f;min-height:100vh;min-height:100dvh;height:100%;margin:0;padding:0;padding-bottom:calc(60px+env(safe-area-inset-bottom,0px));overflow-x:hidden;overscroll-behavior-y:none;}body.guess-who-mode{background:var(--gw-bg);color:var(--text-primary);overflow-x:hidden;}body.guess-who-mode::before{content:'';position:fixed;inset:0;background:radial-gradient(circle at 18% 80%,rgba(168,85,247,0.18) 0%,transparent 55%),radial-gradient(circle at 82% 18%,rgba(236,72,153,0.16) 0%,transparent 55%),radial-gradient(circle at 55% 45%,rgba(34,211,238,0.08) 0%,transparent 60%);pointer-events:none;z-index:0;}.container{position:relative;z-index:1;}@media (min-width:769px){.container{padding-top:90px;padding-bottom:130px;}body.in-game .container{padding-top:50px;padding-bottom:110px;}#preGameScreen,#gameOverScreen{min-height:calc(100dvh - 240px);display:flex;align-items:center;justify-content:center;}#preGameScreen>.pre-game-content,#gameOverScreen>.game-over-content{width:100%;}}body.in-game .clue-and-actions-wrapper{margin-top:10px;}body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}.game-container{display:none;}header{text-align:center;margin-bottom:40px;animation:fadeInDown 0.8s ease;}@keyframes fadeInDown{from{opacity:0;transform:translateY(-30px);}to{opacity:1;transform:translateY(0);}}header h1{font-size:3.5rem;margin-bottom:15px;font-weight:800;background:linear-gradient(135deg,#fff 0%,#ffd700 50%,#ff8c00 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 4px 20px rgba(255,215,0,0.4);letter-spacing:2px;}header .subtitle{font-size:1.2rem;opacity:0.95;font-weight:300;color:var(--text-secondary);letter-spacing:0.5px;}.screen{animation:fadeIn 0.4s ease;}@keyframes fadeIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}.pre-game-hero{display:grid;gap:18px;align-items:center;justify-items:center;margin-bottom:26px;}.guess-who-header{text-align:center;margin-bottom:6px;}.mode-badge.guess-who-badge{display:inline-flex;align-items:center;gap:10px;background:var(--gw-gradient);color:#fff;font-weight:800;font-size:0.85rem;padding:8px 18px;border-radius:999px;letter-spacing:2px;text-transform:uppercase;box-shadow:0 6px 22px var(--gw-primary-glow);border:1px solid rgba(255,255,255,0.18);animation:gwPulse 2.2s infinite;}.mode-badge.guess-who-badge svg{width:18px;height:18px;}@keyframes gwPulse{0%,100%{box-shadow:0 6px 22px var(--gw-primary-glow);}50%{box-shadow:0 10px 34px rgba(236,72,153,0.28);}}.pre-game-content{max-width:900px;margin:0 auto;text-align:center;}.guess-who-header h1{font-size:clamp(2.05rem,5vw,3.3rem);margin-top:14px;margin-bottom:10px;font-weight:800;background:linear-gradient(135deg,rgba(255,255,255,0.98) 0%,rgba(233,213,255,0.95) 55%,rgba(244,114,182,0.9) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-0.02em;}[data-theme="light"] .guess-who-header h1{background:linear-gradient(135deg,#1a1a1a 0%,#2b2b2b 55%,#6b21a8 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}.guess-who-header .subtitle{font-size:1.08rem;line-height:1.65;color:var(--gw-text-muted);margin:0 auto;max-width:680px;}.mode-icon-large{width:90px;height:90px;display:flex;align-items:center;justify-content:center;border-radius:24px;background:var(--gw-glass);border:1px solid var(--gw-border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:rgba(255,255,255,0.9);box-shadow:0 18px 50px rgba(0,0,0,0.35);animation:pulse 2.2s ease-in-out infinite;}.mode-icon-large svg{width:44px;height:44px;}@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.1);}}.pre-game-content h2{font-size:2rem;margin-bottom:30px;color:var(--text-primary);}.instructions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px;}@media (min-width:770px) and (max-width:900px){.instructions{grid-template-columns:repeat(2,minmax(0,1fr));}}.instruction-card{background:var(--gw-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--gw-border);border-radius:var(--gw-radius);padding:24px 20px;transition:transform 0.25s var(--gw-timing),box-shadow 0.25s var(--gw-timing),border-color 0.25s var(--gw-timing);position:relative;overflow:hidden;}.instruction-card:hover{transform:translateY(-3px);border-color:rgba(168,85,247,0.6);box-shadow:0 18px 60px rgba(168,85,247,0.12);}.instruction-icon{width:58px;height:58px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;border-radius:14px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);color:#fff;}[data-theme="light"] .instruction-icon{background:rgba(0,0,0,0.03);border:1px solid rgba(0,0,0,0.08);color:#1a1a1a;}.instruction-icon svg{width:26px;height:26px;stroke:currentColor;}.instruction-card h3{font-size:1.2rem;margin:10px 0;color:var(--text-primary);}.instruction-card p{font-size:0.9rem;color:var(--gw-text-muted);line-height:1.5;}.start-button{background:var(--gw-gradient);color:#fff;border:1px solid rgba(255,255,255,0.16);padding:16px 38px;border-radius:14px;font-size:1.1rem;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:12px;transition:transform 0.2s var(--gw-timing),box-shadow 0.2s var(--gw-timing),filter 0.2s var(--gw-timing);margin-bottom:30px;box-shadow:0 14px 40px rgba(168,85,247,0.18);}.start-button:hover{transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 18px 60px rgba(236,72,153,0.22);}.start-button:focus-visible{outline:2px solid rgba(34,211,238,0.8);outline-offset:3px;}.button-icon{font-size:1.3rem;}.stats-preview{display:flex;justify-content:center;gap:40px;padding:30px;background:var(--bg-secondary);border-radius:16px;border:1px solid var(--border-color);}.stat-item{display:flex;flex-direction:column;align-items:center;gap:8px;}.stat-label{font-size:0.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;}.stat-value{font-size:1.8rem;font-weight:700;color:var(--color-guess-who);}.game-info-bar{display:flex;justify-content:space-around;gap:20px;padding:20px;background:var(--bg-secondary);border-radius:16px;border:1px solid var(--border-color);margin-bottom:30px;box-shadow:var(--shadow-sm);}.info-item{display:flex;flex-direction:column;align-items:center;gap:8px;}.info-label{font-size:0.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;}.info-value{font-size:2rem;font-weight:700;color:var(--color-guess-who);}.clue-and-actions-wrapper{display:flex;gap:20px;margin-bottom:30px;margin-top:20px;align-items:center;}.clue-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:20px;flex:1;min-width:0;box-shadow:var(--shadow-sm);}.clue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}.clue-header h3{font-size:1.3rem;margin:0;color:var(--text-primary);}.next-clue-btn{background:linear-gradient(135deg,var(--color-guess-who) 0%,var(--color-guess-who-soft) 100%);color:white;border:none;padding:12px 24px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all 0.2s ease;}.next-clue-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);}.next-clue-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.current-clue{background:var(--bg-tertiary);border:2px solid var(--color-guess-who);border-radius:12px;padding:20px;margin-bottom:15px;}.clue-text{font-size:1.3rem;font-weight:600;color:var(--text-primary);display:block;text-align:center;}.clue-history{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px;}.clue-badge{background:var(--bg-tertiary);border:1px solid var(--border-color);padding:8px 16px;border-radius:8px;font-size:0.9rem;color:var(--text-secondary);}body.guess-who-mode .clue-container{background:linear-gradient(135deg,rgba(168,85,247,0.16) 0%,rgba(30,30,40,0.92) 45%,rgba(236,72,153,0.10) 100%);border:1px solid rgba(168,85,247,0.32);box-shadow:0 18px 60px rgba(168,85,247,0.10),0 10px 28px rgba(0,0,0,0.28);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);}[data-theme="light"] body.guess-who-mode .clue-container{background:linear-gradient(135deg,rgba(168,85,247,0.14) 0%,rgba(255,255,255,0.92) 55%,rgba(236,72,153,0.12) 100%);border:1px solid rgba(107,33,168,0.22);box-shadow:0 18px 60px rgba(107,33,168,0.10),0 10px 28px rgba(0,0,0,0.10);}body.guess-who-mode .current-clue{background:rgba(255,255,255,0.06);border:2px solid rgba(168,85,247,0.85);box-shadow:inset 0 1px 0 rgba(255,255,255,0.08);}[data-theme="light"] body.guess-who-mode .current-clue{background:rgba(0,0,0,0.03);border:2px solid rgba(107,33,168,0.65);}body.guess-who-mode .clue-badge{background:rgba(255,255,255,0.05);border:1px solid rgba(168,85,247,0.22);color:rgba(255,255,255,0.78);}[data-theme="light"] body.guess-who-mode .clue-badge{background:rgba(0,0,0,0.03);border:1px solid rgba(107,33,168,0.18);color:rgba(0,0,0,0.62);}body.guess-who-mode .next-clue-btn{background:var(--gw-gradient);border:1px solid rgba(255,255,255,0.16);box-shadow:0 14px 40px rgba(168,85,247,0.16);}body.guess-who-mode .next-clue-btn:hover{box-shadow:0 18px 60px rgba(236,72,153,0.22);}.cards-section h3{font-size:1.2rem;margin-bottom:20px;color:var(--text-primary);text-align:center;}.cards-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:15px;margin-bottom:30px;max-width:900px;margin-left:auto;margin-right:auto;}.card-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:12px;cursor:pointer;transition:all 0.3s ease;position:relative;overflow:hidden;}.card-item:hover:not(.eliminated){transform:translateY(-4px);border-color:var(--color-guess-who);box-shadow:var(--shadow-md);}.card-item.selectable{border-color:var(--color-guess-who);animation:pulse-select 1.5s ease-in-out infinite;}@keyframes pulse-select{0%,100%{box-shadow:var(--shadow-sm);}50%{box-shadow:var(--shadow-glow);}}.card-item.eliminated{opacity:0.3;cursor:not-allowed;filter:grayscale(100%);}.card-item.eliminated::after{content:'❌';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;}.card-image{width:100%;height:120px;object-fit:contain;margin-bottom:10px;border-radius:8px;}.card-name{font-size:0.9rem;font-weight:600;color:var(--text-primary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.action-buttons{display:flex;flex-direction:column;gap:15px;min-width:180px;}.action-btn{padding:15px 25px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all 0.3s ease;border:1px solid transparent;white-space:nowrap;font-family:inherit;}.solve-btn{background:var(--accent-green);color:white;}.solve-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md);}.solve-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}.surrender-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);}.surrender-btn:hover{background:var(--accent-red);border-color:var(--accent-red);color:white;}.game-over-content{max-width:600px;margin:0 auto;text-align:center;}.result-icon{font-size:5rem;margin-bottom:20px;animation:bounce 0.6s ease;}@keyframes bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-20px);}}.game-over-content h2{font-size:2.5rem;margin-bottom:15px;color:var(--text-primary);}.game-over-content p{font-size:1.2rem;color:var(--text-secondary);margin-bottom:30px;}.result-card{background:var(--bg-secondary);border:2px solid var(--color-guess-who);border-radius:16px;padding:30px;margin-bottom:30px;}.result-card img{width:200px;height:200px;object-fit:contain;margin-bottom:15px;border-radius:12px;}.result-card h3{font-size:1.8rem;color:var(--text-primary);margin:0;}.result-stats{display:flex;justify-content:space-around;gap:20px;padding:30px;background:var(--bg-secondary);border-radius:16px;border:1px solid var(--border-color);margin-bottom:30px;}.result-stat{display:flex;flex-direction:column;align-items:center;gap:8px;}.result-stat-label{font-size:0.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;}.result-stat-value{font-size:2rem;font-weight:700;color:var(--color-guess-who);}.result-actions{display:flex;justify-content:center;gap:20px;}.primary-btn{background:linear-gradient(135deg,var(--color-guess-who) 0%,var(--color-guess-who-soft) 100%);color:white;}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(157,78,221,0.4);}.secondary-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);}.secondary-btn:hover{background:var(--bg-hover);}@media (max-width:768px){.home-button{display:none !important;}.container{padding:15px;padding-bottom:100px;}header h1{font-size:2.5rem;}.game-info-bar{flex-wrap:wrap;padding:15px;gap:15px;}.info-item{flex:1 1 30%;min-width:80px;}.info-value{font-size:1.5rem;}.clue-and-actions-wrapper{flex-direction:column;gap:15px;}.clue-container{padding:15px;}.clue-header{flex-direction:column;gap:10px;align-items:stretch;}.clue-header h3{text-align:center;}.next-clue-btn{width:100%;}.current-clue{padding:15px;}.clue-text{font-size:1.1rem;}.action-buttons{flex-direction:row;width:100%;gap:10px;}.action-btn{flex:1;padding:12px 15px;font-size:0.9rem;}.cards-section{margin-bottom:20px;}.cards-section h3{font-size:1rem;padding:0 10px;}.cards-grid{grid-template-columns:repeat(5,1fr);gap:8px;padding:0 5px;margin-bottom:20px;}.card-item{padding:8px;border-radius:10px;}.card-image{height:70px;margin-bottom:6px;}.card-name{font-size:0.75rem;}.instructions{grid-template-columns:1fr 1fr;gap:12px;}.instruction-card{padding:20px 15px;}.instruction-icon{font-size:2rem;}.instruction-card h3{font-size:1rem;}.instruction-card p{font-size:0.8rem;}.stats-preview,.result-stats{flex-direction:column;gap:15px;padding:20px;}.result-actions{flex-direction:column;gap:10px;}.result-card{padding:20px;}.result-card img{width:150px;height:150px;}.result-card h3{font-size:1.4rem;}.game-over-content h2{font-size:2rem;}.result-icon{font-size:4rem;}body{padding-bottom:100px;}}@media (max-width:600px){.cards-grid{grid-template-columns:repeat(3,1fr) !important;}}@media (max-width:480px){.container{padding:10px;padding-bottom:100px;}.game-info-bar{flex-direction:row;justify-content:space-between;padding:12px;}.info-item{flex:1;}.info-label{font-size:0.7rem;}.info-value{font-size:1.3rem;}.clue-container{padding:12px;}.clue-text{font-size:1rem;}.clue-badge{font-size:0.8rem;padding:6px 12px;}.cards-grid{grid-template-columns:repeat(3,1fr);gap:5px;}.card-item{padding:6px;}.card-image{height:55px;margin-bottom:4px;}.card-name{font-size:0.65rem;}.card-item.eliminated::after{font-size:2rem;}.instructions{grid-template-columns:1fr;gap:10px;}.start-button{padding:14px 30px;font-size:1rem;}.mode-icon-large{width:74px;height:74px;border-radius:20px;}.mode-icon-large svg{width:36px;height:36px;}.guess-who-header h1{font-size:1.9rem;}.guess-who-header .subtitle{font-size:0.95rem;}body{padding-bottom:calc(100px+env(safe-area-inset-bottom,0px));}}@media (max-width:360px){.cards-grid{grid-template-columns:repeat(3,1fr);gap:4px;}.card-image{height:50px;}.card-name{font-size:0.6rem;}}.achievement-popup{position:fixed;top:20px;right:-400px;background:linear-gradient(135deg,rgba(30,30,30,0.98) 0%,rgba(20,20,20,0.98) 100%);border:2px solid #FFD700;border-radius:16px;padding:16px 24px;z-index:3000;box-shadow:0 10px 40px rgba(255,215,0,0.4),0 0 60px rgba(255,215,0,0.2);transition:right 0.5s cubic-bezier(0.68,-0.55,0.265,1.55);max-width:350px;}.achievement-popup.show{right:20px;}.achievement-popup-content{display:flex;align-items:center;gap:16px;}.achievement-popup-icon{font-size:3rem;color:#FFD700;animation:achievementBounce 0.6s ease infinite;}@keyframes achievementBounce{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-8px) scale(1.1);}}.achievement-popup-text strong{display:block;color:#FFD700;font-size:0.9rem;margin-bottom:4px;}.achievement-popup-text p{color:#fff;font-size:1.1rem;font-weight:600;margin:0 0 4px 0;}.achievement-popup-text small{color:#FFA500;font-size:0.85rem;font-weight:500;}