:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-card: #ffffff;--bg-card-hover: #f8f9fa;--text-primary: #1a1a2e;--text-secondary: #64748b;--accent: #6366f1;--accent-light: #818cf8;--accent-glow: rgba(99, 102, 241, .2);--border: #e2e8f0;--border-light: #f1f5f9;--shadow: rgba(0, 0, 0, .08);--shadow-strong: rgba(0, 0, 0, .12)}body{font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#fff;color:var(--text-primary);min-height:100vh;overflow-x:hidden}#root{min-height:100vh;width:100vw}.app{display:flex;flex-direction:column;min-height:100vh;width:100vw;background:#fff}.welcome-screen{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#fff}.welcome-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.bg-grid,.bg-glow{display:none}.bg-glow-1{width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.2) 0%,transparent 70%);top:-200px;right:-100px;animation:float 12s ease-in-out infinite}.bg-glow-2{width:500px;height:500px;background:radial-gradient(circle,rgba(236,72,153,.15) 0%,transparent 70%);bottom:-150px;left:-100px;animation:float 15s ease-in-out infinite reverse}.bg-glow-3{width:400px;height:400px;background:radial-gradient(circle,rgba(6,182,212,.15) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse-soft 8s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(40px,40px) scale(1.1)}}@keyframes pulse-soft{0%,to{opacity:.4;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.2)}}.bg-lines{display:none}.bg-line{position:absolute;height:2px;width:300px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.3),transparent);animation:moveLine 10s linear infinite}.bg-line:nth-child(1){top:10%;left:-300px}.bg-line:nth-child(2){top:25%;left:-300px;animation-delay:1s}.bg-line:nth-child(3){top:40%;left:-300px;animation-delay:2s}.bg-line:nth-child(4){top:55%;left:-300px;animation-delay:3s}.bg-line:nth-child(5){top:70%;left:-300px;animation-delay:4s}.bg-line:nth-child(6){top:85%;left:-300px;animation-delay:5s}.bg-line:nth-child(7){top:92%;left:-300px;animation-delay:6s}.bg-line:nth-child(8){top:5%;left:-300px;animation-delay:7s}@keyframes moveLine{0%{transform:translate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translate(calc(100vw + 600px));opacity:0}}.bg-particles{display:none}.particle{position:absolute;width:4px;height:4px;background:#6366f166;border-radius:50%;bottom:-10px;animation:rise linear infinite}@keyframes rise{0%{transform:translateY(0) scale(1);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh) scale(0);opacity:0}}.welcome-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem}.logo-container{margin-bottom:2rem}.logo-image,.logo-svg{max-width:450px;width:85vw;height:auto;margin-bottom:1.5rem}.logo-subtitle{font-size:1.8rem;color:#6366f1;font-weight:600;letter-spacing:10px;text-transform:uppercase;margin-top:.5rem}.welcome-tagline{font-size:1.1rem;color:#64748b;margin-bottom:3rem;max-width:500px;line-height:1.6}.play-button{display:flex;align-items:center;gap:1rem;padding:1.25rem 3.5rem;font-size:1.2rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:100px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 40px #6366f14d;text-transform:uppercase;letter-spacing:3px}.play-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 15px 50px #6366f166}.play-button:active{transform:translateY(-1px) scale(.98)}.play-button-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.play-button-icon svg{width:18px;height:18px}.welcome-footer{position:absolute;bottom:2rem;color:var(--text-secondary);font-size:.85rem;letter-spacing:2px;text-transform:uppercase}.header{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 2rem;background:#fff;border-bottom:1px solid var(--border)}.header-logo{height:80px;width:auto}.title{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:2px}.subtitle{color:var(--text-secondary);font-size:.9rem;letter-spacing:2px;font-weight:500;margin-top:.5rem;text-transform:uppercase}.main-content{display:grid;grid-template-columns:300px 1fr;grid-template-rows:1fr auto;grid-template-areas:"characters viewer" "characters stats";flex:1;gap:1rem;padding:1rem;width:100%;max-width:1000px;margin:0 auto;height:100vh;max-height:100vh;overflow:hidden}.sidebar-logo{display:flex;justify-content:center;padding:.5rem 0 1rem;margin-bottom:1rem;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity .2s ease}.sidebar-logo:hover{opacity:.7}.sidebar-logo-img{max-width:180px;height:auto}.character-list{grid-area:characters;background:var(--bg-card);border-radius:16px;padding:1rem;overflow-y:auto;border:1px solid var(--border);box-shadow:0 4px 20px var(--shadow)}.character-list h2{font-size:.75rem;margin-bottom:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:2px;font-weight:600}.cards-container{display:flex;flex-direction:column;gap:.6rem}.character-card{display:flex;flex-direction:row;align-items:center;gap:.75rem;padding:.6rem;background:var(--bg-secondary);border-radius:12px;cursor:pointer;transition:all .2s ease;border:2px solid transparent;position:relative}.character-card:hover{background:var(--bg-card-hover);border-color:var(--border);box-shadow:0 4px 12px var(--shadow);transform:translate(4px)}.character-card.selected{border-color:var(--character-color);background:#fff;box-shadow:0 4px 20px var(--shadow-strong)}.card-avatar{width:65px;height:65px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-avatar .avatar-initial{font-size:1.5rem}.card-avatar-img{width:65px;height:65px;border-radius:12px;overflow:hidden;flex-shrink:0;background:var(--bg-secondary)}.card-avatar-img img{width:100%;height:100%;object-fit:cover;object-position:center top}.card-avatar-3d{width:50px;height:50px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--bg-secondary)}.card-avatar-3d canvas{width:100%!important;height:100%!important}.avatar-initial{font-size:1.25rem;font-weight:700;color:#fff}.card-info{text-align:left;flex:1;min-width:0}.card-name{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-role{font-size:.7rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-indicator{width:10px;height:10px;border-radius:50%;background:var(--character-color);box-shadow:0 0 10px var(--character-color);flex-shrink:0}.viewer-section{grid-area:viewer;position:relative;background:var(--bg-card);border-radius:16px;overflow:hidden;border:1px solid var(--border);box-shadow:0 4px 20px var(--shadow)}.character-viewer{width:100%;height:100%;min-height:280px;background:linear-gradient(180deg,#f8f9fa,#e9ecef)}.game-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 80px #00000080,0 0 40px #6366f133;border:1px solid rgba(99,102,241,.3);animation:slideIn .4s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;font-size:1.5rem;width:36px;height:36px;border-radius:50%;cursor:pointer;transition:background .2s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#fff3}.modal-header{text-align:center;margin-bottom:1.5rem}.modal-header h2{color:#fff;font-size:1.8rem;margin-bottom:.5rem;background:linear-gradient(135deg,#6366f1,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-subtitle{color:#94a3b8;font-size:1rem}.modal-content{display:flex;flex-direction:column;gap:1.5rem}.game-preview{width:100%}.game-preview-img{width:100%;border-radius:12px;display:block}.game-preview-placeholder{background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:12px;padding:3rem;display:flex;align-items:center;justify-content:center;border:2px dashed rgba(99,102,241,.3)}.game-icon{width:80px;height:80px;color:#6366f1;opacity:.6}.game-info h3{color:#fff;font-size:1.2rem;margin-bottom:.75rem}.game-info p{color:#94a3b8;line-height:1.6;font-size:.9rem;margin-bottom:1rem}.game-features{list-style:none;padding:0;margin:1rem 0;display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.game-features li{color:#e2e8f0;font-size:.85rem;padding:.5rem;background:#6366f11a;border-radius:8px;border:1px solid rgba(99,102,241,.2)}.coming-soon{display:inline-block;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600}.press-reviews{margin-top:1rem}.press-reviews h4{color:#94a3b8;font-size:.75rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1rem;text-align:center}.reviews-grid{display:flex;flex-direction:column;gap:.75rem}.review-card{background:#ffffff0d;border-radius:12px;padding:1rem;display:flex;align-items:center;gap:1rem;border:1px solid rgba(255,255,255,.08)}.review-logo{height:24px;width:auto;min-width:60px;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}.review-logo.kotaku{height:18px}.review-logo.polygon{height:20px}.review-logo-text{font-weight:900;font-size:1rem;letter-spacing:1px;min-width:70px;text-align:center;padding:.25rem .5rem;border-radius:4px;flex-shrink:0}.review-logo-text.ign{color:#bf1313;background:#fff;font-family:Arial Black,sans-serif;font-size:1.1rem}.review-logo-text.kotaku{color:#fff;background:#ff5722;font-family:Georgia,serif;font-size:.75rem;letter-spacing:2px}.review-logo-text.polygon{color:#fff;background:#c91c5d;font-family:Helvetica,sans-serif;font-size:.7rem;letter-spacing:3px}.review-logo-text.gamespot{color:#fc0;background:#1a1a1a;font-family:Impact,sans-serif;font-size:.65rem;letter-spacing:1px}.review-quote{flex:1;color:#cbd5e1;font-size:.8rem;font-style:italic;line-height:1.4;margin:0}.review-score{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:.35rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;white-space:nowrap}.modal-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);text-align:center}.developed-by{color:#64748b;font-size:.75rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:.75rem}.ubisoft-brand{display:flex;align-items:center;justify-content:center;gap:.75rem}.ubisoft-logo{height:40px;width:auto;filter:brightness(0) invert(1)}.studio-name{color:#fff;font-size:.9rem;font-weight:500}.stats-section{grid-area:stats;background:var(--bg-card);border-radius:12px;padding:.75rem;border:1px solid var(--border);box-shadow:0 4px 20px var(--shadow)}.character-stats{display:flex;flex-direction:column;gap:.75rem}.stats-top{display:flex;flex-direction:row;align-items:flex-start;gap:1rem}.stats-header{text-align:left;min-width:100px;flex-shrink:0}.stats-name{font-size:1rem;font-weight:700;color:var(--text-primary)}.stats-role{font-size:.7rem;font-weight:600;margin-top:.15rem}.stats-description{display:none}.stats-bars{flex:1}.stats-bars h4{display:none}.stat-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.stat-label{width:100px;font-size:.65rem;color:var(--text-secondary);font-weight:500;display:flex;align-items:center;gap:.35rem}.stat-icon{font-size:.7rem}.stat-bar-container{flex:1;height:6px;background:#e9ecef;border-radius:100px;overflow:hidden}.stat-bar{height:100%;border-radius:100px;transition:width .5s ease}.stat-value{width:24px;font-size:.65rem;font-weight:600;text-align:right;color:var(--text-primary)}.special-skill-section{margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--border);display:flex;align-items:center;gap:.5rem}.special-skill-label{font-size:.65rem;color:var(--text-secondary);font-weight:600;display:flex;align-items:center;gap:.35rem}.special-skill-name{font-size:.7rem;font-weight:600;color:#8a2be2}.select-button{width:100%;padding:.6rem 1rem;border:none;border-radius:8px;font-size:.75rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:1px;white-space:nowrap;text-align:center}.select-button:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.select-button:disabled{opacity:.7;cursor:not-allowed}.select-button.is-animating{display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-loader{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stats-buttons-row{display:flex;gap:.5rem;margin-top:.5rem}.info-button,.play-button-inline{flex:1;padding:.6rem .5rem;border:none;border-radius:8px;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;text-align:center}.info-button{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border)}.info-button:hover{background:var(--border)}.info-button.highlighted{border-width:2px;background:#fff;animation:pulseHighlight 1.5s ease-in-out infinite}@keyframes pulseHighlight{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 6px #6366f100}}.play-button-inline{background:#ccc;color:#fff}.play-button-inline:not(:disabled){cursor:pointer}.play-button-inline:not(:disabled):hover{filter:brightness(1.1);transform:translateY(-1px)}.play-button-inline:disabled{opacity:.6;cursor:not-allowed}.music-toggle{position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;width:60px;height:60px;border-radius:50%;border:none;background:#fffffff2;box-shadow:0 4px 16px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.music-toggle:hover{transform:scale(1.1);box-shadow:0 6px 24px #0003}.music-toggle:active{transform:scale(.95)}.music-toggle svg{width:32px;height:32px;color:var(--text-primary)}@media (max-width: 480px){.music-toggle{width:50px;height:50px;bottom:1rem;right:1rem}.music-toggle svg{width:26px;height:26px}}.footer{text-align:center;padding:.75rem;background:#fff;border-top:1px solid var(--border);color:var(--text-secondary);font-size:.75rem;letter-spacing:1px}@media (max-width: 800px){.main-content{grid-template-columns:1fr;grid-template-rows:auto 1fr auto;grid-template-areas:"characters" "viewer" "stats";max-height:100vh;height:100vh;padding:.5rem;gap:.5rem}.character-list{padding:.5rem;border-radius:12px}.character-list h2,.sidebar-logo{display:none}.cards-container{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:.5rem;padding-bottom:.25rem;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cards-container::-webkit-scrollbar{display:none}.character-card{flex:0 0 auto;flex-direction:column;width:70px;padding:.5rem;gap:.25rem}.card-avatar,.card-avatar-img{width:50px;height:50px;border-radius:10px}.card-info{text-align:center}.card-name{font-size:.65rem}.card-role{display:none}.selected-indicator{position:absolute;top:4px;right:4px;width:8px;height:8px}.viewer-section{border-radius:12px}.character-viewer{min-height:200px}.stats-section{padding:.75rem;border-radius:12px;overflow-y:auto;max-height:40vh}.stats-top{flex-direction:row;gap:.75rem}.stats-header{min-width:80px}.stats-name{font-size:.9rem}.stat-label{width:100px;font-size:.65rem}.stat-bar-container{flex:1}.select-button{padding:.5rem;font-size:.7rem}.stats-buttons-row{gap:.4rem}.info-button,.play-button-inline{padding:.5rem .4rem;font-size:.65rem}}@media (max-width: 480px){.main-content{padding:.35rem;gap:.35rem}.character-card{width:60px;padding:.35rem}.card-avatar,.card-avatar-img{width:42px;height:42px;border-radius:8px}.card-name{font-size:.6rem}.character-viewer{min-height:180px}.stats-top{flex-direction:column;gap:.5rem}.stats-header{text-align:center;min-width:auto;padding-bottom:.35rem;border-bottom:1px solid var(--border)}.stats-section{max-height:45vh;padding:.6rem}.stat-row{flex-wrap:wrap}.stat-label{width:100%;font-size:.6rem;margin-bottom:.15rem}.stat-bar-container{flex:1}.stat-value{font-size:.6rem;width:22px}.special-skill-section{flex-wrap:wrap;justify-content:center}.stats-buttons-row{flex-direction:row;gap:.35rem}.info-button,.play-button-inline{padding:.45rem .3rem;font-size:.6rem;letter-spacing:0}}@media (max-width: 600px){.logo-image{max-width:250px}.logo-subtitle{font-size:1.2rem;letter-spacing:5px}.welcome-tagline{font-size:.9rem;padding:0 1rem}.play-button{padding:.9rem 1.8rem;font-size:.95rem}}
