@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap";.theme-toggle{border-radius:var(--radius-full);width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--bg-card-hover);color:var(--duo-primary)}.btn{justify-content:center;align-items:center;gap:var(--space-2);min-height:44px;font-family:var(--font-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);border-radius:var(--radius-2xl);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;border:none;padding:.625rem 1.25rem;line-height:1.2;text-decoration:none;display:inline-flex;position:relative}.btn:active{transform:translateY(2px)}.btn-primary{background:var(--duo-primary);color:#fff;box-shadow:0 4px 0 var(--duo-primary-dark)}.btn-primary:hover{background:#1aa0e0}.btn-primary:active{box-shadow:0 1px 0 var(--duo-primary-dark);transform:translateY(3px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:2px solid var(--border-color);box-shadow:0 4px 0 var(--border-color)}.btn-secondary:hover{filter:brightness(.95)}.btn-secondary:active{box-shadow:0 1px 0 var(--border-color);transform:translateY(3px)}.btn-outline{border:2px solid var(--duo-primary);color:var(--duo-primary);box-shadow:none;background:0 0}.btn-outline:hover{background:#80808026}.btn-outline:active{transform:translateY(2px)}.btn-ghost{color:var(--text-secondary);min-height:unset;box-shadow:none;background:0 0;padding:.5rem .875rem}.btn-ghost:hover{background:#80808026}.btn-ghost:active{transform:translateY(1px)}.btn-google{background:var(--bg-card);color:var(--text-primary);border:2px solid var(--border-color);box-shadow:0 3px 0 var(--border-color)}.btn-google:hover{border-color:var(--border-color-hover)}.btn-google:active{box-shadow:0 1px 0 var(--border-color);transform:translateY(2px)}.btn-google svg{width:20px;height:20px}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 4px #d93636}.btn-danger:hover{background:#e63e3e}.btn-danger:active{transform:translateY(3px);box-shadow:0 1px #d93636}.btn-success{background:var(--success);color:#fff;box-shadow:0 4px 0 var(--green-600)}.btn-success:hover{background:#4db802}.btn-success:active{box-shadow:0 1px 0 var(--green-600);transform:translateY(3px)}.btn-sm{font-size:var(--font-size-xs);min-height:36px;padding:.375rem .875rem}.btn-lg{font-size:var(--font-size-base);min-height:48px;padding:.75rem 1.75rem}.btn-icon{min-height:unset;border-radius:var(--radius-lg);padding:.5rem}.btn:disabled,.btn-loading{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-loading .btn-spinner{animation:.8s linear infinite spin}.btn-full{width:100%}@media (width<=768px){.btn{font-size:var(--font-size-sm);min-height:44px;padding:.5rem 1rem}.btn-sm{font-size:var(--font-size-xs);min-height:36px;padding:.375rem .75rem}.btn-lg{font-size:var(--font-size-sm);min-height:44px;padding:.625rem 1.5rem}}@media (width<=480px){.btn{min-height:44px;padding:.5rem .875rem}.btn-lg{font-size:var(--font-size-sm);min-height:44px;padding:.5rem 1.25rem}}.navbar{z-index:var(--z-sticky);background:var(--bg-nav);border-bottom:2px solid var(--border-color);transition:all var(--transition-normal);position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;gap:var(--space-4);height:64px;display:flex}.navbar-logo{align-items:center;gap:var(--space-2);flex-shrink:0;text-decoration:none;display:flex}.navbar-logo img{width:auto;height:36px}.navbar-logo-image{-o-object-fit:contain;object-fit:contain;width:auto;height:32px}.navbar-logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-extrabold);letter-spacing:.2px;line-height:1}.navbar-logo-text .brand-hay{color:var(--duo-primary)}.navbar-logo-text .brand-rest{color:var(--text-primary)}[data-theme=dark] .navbar-logo-text .brand-rest{color:#fff}.navbar-nav{align-items:center;gap:var(--space-1);display:flex}.navbar-link{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-secondary);border-radius:var(--radius-xl);transition:all var(--transition-fast);white-space:nowrap;text-transform:uppercase;letter-spacing:.02em;text-decoration:none}.navbar-link:hover,.navbar-link.active{color:var(--duo-primary);background:var(--duo-primary-light)}[data-theme=dark] .navbar-link:hover,[data-theme=dark] .navbar-link.active{background:#1cb0f61f}.navbar-actions{align-items:center;gap:var(--space-2);display:flex}.navbar-streak{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:#ff9600;background:#ff96001f;border:1.5px solid #ff960040;display:flex}.navbar-streak-icon{color:#ff9600}.navbar-user{position:relative}.navbar-user-btn{align-items:center;gap:var(--space-2);padding:var(--space-1);border-radius:var(--radius-full);transition:all var(--transition-fast);cursor:pointer;min-height:44px;display:flex}.navbar-user-btn:hover{background:var(--bg-card-hover)}.navbar-user-avatar{border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:2px solid var(--duo-primary);width:36px;height:36px}.navbar-user-avatar-placeholder{border-radius:var(--radius-full);background:var(--duo-primary);color:#fff;width:36px;height:36px;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);justify-content:center;align-items:center;display:flex}.navbar-dropdown{top:calc(100% + var(--space-2));background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-2xl);min-width:220px;box-shadow:var(--shadow-xl);padding:var(--space-2);z-index:var(--z-dropdown);animation:.2s ease-out fadeInDown;position:absolute;right:0}.navbar-dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);border-radius:var(--radius-xl);transition:all var(--transition-fast);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;min-height:44px;text-decoration:none;display:flex}.navbar-dropdown-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.navbar-dropdown-divider{background:var(--border-color);height:1px;margin:var(--space-2) 0}.navbar-dropdown-item.danger{color:var(--danger)}.navbar-dropdown-item.danger:hover{background:var(--danger-light)}.navbar-hamburger{border-radius:var(--radius-xl);width:44px;height:44px;color:var(--text-primary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:none}.navbar-hamburger:hover{background:var(--bg-card-hover)}.navbar-mobile-overlay{z-index:var(--z-modal);background:var(--bg-primary);flex-direction:column;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.navbar-mobile-overlay-header{padding:var(--space-4) var(--space-6);border-bottom:2px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;height:64px;display:flex}.navbar-mobile-close{border-radius:var(--radius-xl);width:44px;height:44px;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.navbar-mobile-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.navbar-mobile-links{padding:var(--space-6) var(--space-8);justify-content:center;gap:var(--space-2);flex-direction:column;flex:1;display:flex}.navbar-mobile-link{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-secondary);border-radius:var(--radius-2xl);transition:all var(--transition-fast);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;min-height:52px;text-decoration:none;display:flex}.navbar-mobile-link:hover,.navbar-mobile-link.active{background:var(--duo-primary-light);color:var(--duo-primary)}[data-theme=dark] .navbar-mobile-link:hover,[data-theme=dark] .navbar-mobile-link.active{background:#1cb0f61f}.navbar-mobile-signout{color:var(--danger)}.navbar-mobile-signout:hover{background:var(--danger-light)!important;color:var(--danger)!important}.navbar-mobile-divider{background:var(--border-color);height:1px;margin:var(--space-2) 0}.navbar-mobile-auth-actions{gap:var(--space-3);margin-top:var(--space-2);flex-direction:column;display:flex}.navbar-mobile-auth-actions a{display:block}@media (width<=900px){.navbar-nav{display:none}.navbar-hamburger{display:flex}}@media (width<=768px){.navbar-actions .btn{display:none}.navbar-streak{font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2)}}@media (width<=480px){.navbar-inner{height:56px}.navbar-mobile-overlay-header{height:56px;padding:var(--space-3) var(--space-4)}.navbar-logo img{height:28px}.navbar-logo-image{height:24px}.navbar-logo-text{font-size:var(--font-size-lg)}.navbar-user-avatar,.navbar-user-avatar-placeholder{width:32px;height:32px}.navbar-mobile-links{padding:var(--space-4) var(--space-6);gap:var(--space-1)}.navbar-mobile-link{font-size:var(--font-size-lg);padding:var(--space-3) var(--space-4);min-height:48px}}.footer{background:var(--bg-secondary);border-top:2px solid var(--border-color);padding:var(--space-12) 0 var(--space-8);margin-top:auto}.footer-inner{gap:var(--space-10);grid-template-columns:2fr 1fr 1fr;display:grid}.footer-brand{gap:var(--space-4);flex-direction:column;display:flex}.footer-logo{align-items:center;gap:var(--space-2);text-decoration:none;display:flex}.footer-logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-extrabold)}.footer-logo-text .brand-hay{color:var(--duo-primary)}.footer-logo-text .brand-rest{color:var(--text-primary)}[data-theme=dark] .footer-logo-text .brand-rest{color:#fff}.footer-description{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);max-width:350px}.footer-column-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-extrabold);color:var(--text-primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-4)}.footer-links{gap:var(--space-3);flex-direction:column;display:flex}.footer-link{color:var(--text-secondary);font-size:var(--font-size-sm);transition:color var(--transition-fast);text-decoration:none}.footer-link:hover{color:var(--duo-primary)}.footer-bottom{margin-top:var(--space-10);padding-top:var(--space-6);border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.footer-copyright,.footer-made-with{color:var(--text-tertiary);font-size:var(--font-size-sm)}@media (width<=768px){.footer-inner{gap:var(--space-8);grid-template-columns:1fr}.footer-bottom{gap:var(--space-3);text-align:center;flex-direction:column}}.spinner-container{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-12);flex-direction:column;display:flex}.spinner{border:4px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.spinner-sm{border-width:3px;width:24px;height:24px}.spinner-lg{border-width:5px;width:64px;height:64px}.spinner-text{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.spinner-fullpage{background:var(--bg-primary);z-index:var(--z-modal);position:fixed;inset:0}.home{overflow-x:hidden}.hero{background:linear-gradient(135deg,#0a84c8 0%,#1cb0f6 50%,#4abef8 100%);justify-content:center;align-items:center;min-height:85vh;display:flex;position:relative;overflow:hidden}[data-theme=dark] .hero{background:linear-gradient(135deg,#0a2e42 0%,#0d4060 50%,#105580 100%)}.hero-content{z-index:1;text-align:center;max-width:800px;padding:var(--space-8) var(--space-6);position:relative}.hero-logo{height:80px;margin:0 auto var(--space-6);filter:drop-shadow(0 4px 12px #00000026);animation:.8s ease-out bounceIn}.hero-title{font-size:var(--font-size-5xl);font-weight:var(--font-weight-extrabold);color:#fff;margin-bottom:var(--space-4);animation:.6s ease-out .2s both fadeInUp}.hero-title-accent{color:#ffffffd9;font-weight:var(--font-weight-bold)}.hero-subtitle{font-size:var(--font-size-xl);color:#ffffffd9;margin-bottom:var(--space-8);font-weight:var(--font-weight-medium);line-height:var(--line-height-relaxed);animation:.6s ease-out .4s both fadeInUp}.hero-actions{justify-content:center;align-items:center;gap:var(--space-4);flex-wrap:wrap;animation:.6s ease-out .6s both fadeInUp;display:flex}.hero-actions .btn{font-size:var(--font-size-base);min-height:48px;padding:.75rem 2rem}.stats-section{z-index:2;padding:0 var(--space-6);margin-top:-60px;position:relative}.stats-grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);max-width:900px;margin:0 auto;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-8) var(--space-6);text-align:center;box-shadow:var(--shadow-lg);border:2px solid var(--border-color);transition:all var(--transition-normal)}.stat-card:hover{box-shadow:var(--shadow-xl);border-color:var(--duo-primary);transform:translateY(-4px)}.stat-icon-wrap{border-radius:var(--radius-2xl);width:56px;height:56px;margin:0 auto var(--space-3);color:#fff;justify-content:center;align-items:center;display:flex}.stat-icon-blue{background:var(--duo-primary)}.stat-icon-green{background:var(--success)}.stat-icon-orange{background:#ff9600}.stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);color:var(--duo-primary);margin-bottom:var(--space-1)}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-semibold)}.features-section{padding:var(--space-24) 0}.section-header{text-align:center;margin-bottom:var(--space-16)}.section-badge{padding:var(--space-2) var(--space-5);background:var(--duo-primary-light);border:1.5px solid var(--duo-primary-200);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--duo-primary);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.03em;display:inline-block}[data-theme=dark] .section-badge{background:#1cb0f61a;border-color:#1cb0f640}.section-title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-4)}.section-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:600px;margin:0 auto}.features-grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.feature-card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-8);border:2px solid var(--border-color);text-align:center;transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.feature-card:hover{box-shadow:var(--shadow-lg);border-color:var(--duo-primary);transform:translateY(-4px)}.feature-icon{border-radius:var(--radius-2xl);width:64px;height:64px;margin:0 auto var(--space-5);background:var(--duo-primary-light);color:var(--duo-primary);transition:transform var(--transition-normal);justify-content:center;align-items:center;display:flex}[data-theme=dark] .feature-icon{background:#1cb0f61f}.feature-card:hover .feature-icon{transform:scale(1.1)}.feature-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-3)}.feature-text{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.cta-section{padding:var(--space-20) 0;background:linear-gradient(135deg,#0a84c8,#1cb0f6);position:relative;overflow:hidden}[data-theme=dark] .cta-section{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,#0d3b55,#105580)}.cta-content{z-index:1;text-align:center;position:relative}.cta-title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);color:#fff;margin-bottom:var(--space-4)}.cta-text{font-size:var(--font-size-lg);color:#ffffffd9;margin-bottom:var(--space-8);max-width:550px;margin-left:auto;margin-right:auto}.cta-actions{justify-content:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.cta-actions .btn{min-height:48px;padding:.75rem 2rem}@media (width<=1024px){.features-grid{grid-template-columns:repeat(2,1fr)}.hero-title{font-size:var(--font-size-4xl)}.features-section{padding:var(--space-16) 0}}@media (width<=768px){.hero{min-height:70vh}.hero-content{padding:var(--space-6) var(--space-4)}.hero-title{font-size:var(--font-size-3xl)}.hero-subtitle{font-size:var(--font-size-base);margin-bottom:var(--space-6)}.hero-logo{height:60px}.hero-actions{gap:var(--space-3);flex-direction:column;width:100%;max-width:320px;margin:0 auto}.hero-actions .btn{width:100%;font-size:var(--font-size-sm);min-height:44px;padding:.625rem 1.5rem}.cta-section{padding:var(--space-12) 0}.cta-actions{align-items:center;gap:var(--space-3);flex-direction:column}.cta-actions .btn{width:100%;max-width:320px;min-height:44px;padding:.625rem 1.5rem}.stats-section{margin-top:-40px}.stats-grid{gap:var(--space-4);grid-template-columns:1fr}.stat-card{padding:var(--space-5) var(--space-4)}.features-section{padding:var(--space-12) 0}.features-grid{gap:var(--space-4);grid-template-columns:1fr}.feature-card{padding:var(--space-6)}.section-header{margin-bottom:var(--space-8)}.section-title{font-size:var(--font-size-2xl)}.section-subtitle{font-size:var(--font-size-base)}.cta-title{font-size:var(--font-size-2xl)}.cta-text{font-size:var(--font-size-base)}}@media (width<=480px){.hero{min-height:65vh}.hero-title{font-size:var(--font-size-2xl)}.hero-subtitle{font-size:var(--font-size-sm)}.hero-logo{height:48px}.hero-actions{max-width:280px}.stats-section{padding:0 var(--space-3)}.stat-value{font-size:var(--font-size-2xl)}.cta-title{font-size:var(--font-size-xl)}}.about-page{padding-bottom:var(--space-20)}.about-hero{padding:var(--space-20) 0;text-align:center;background:var(--bg-secondary)}.about-hero-title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-4)}.about-hero-text{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:700px;line-height:var(--line-height-relaxed);margin:0 auto}.about-mission{padding:var(--space-16) 0}.about-mission-grid{gap:var(--space-12);grid-template-columns:1fr 1fr;align-items:center;display:grid}.about-mission-content{gap:var(--space-4);flex-direction:column;display:flex}.about-mission-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold)}.about-mission-text{color:var(--text-secondary);line-height:var(--line-height-relaxed)}.about-mission-visual{background:var(--duo-primary-light);border-radius:var(--radius-2xl);padding:var(--space-12);justify-content:center;align-items:center;gap:var(--space-4);text-align:center;border:2px solid var(--duo-primary-200);flex-direction:column;min-height:300px;display:flex}[data-theme=dark] .about-mission-visual{background:#1cb0f614;border-color:#1cb0f633}.about-mission-visual-emoji{font-size:4rem}.about-mission-visual-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--duo-primary);max-width:250px}.about-how{padding:var(--space-16) 0}.about-steps{gap:var(--space-6);margin-top:var(--space-12);grid-template-columns:repeat(4,1fr);display:grid}.about-step{text-align:center;position:relative}.about-step-number{border-radius:var(--radius-full);width:60px;height:60px;font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);margin:0 auto var(--space-4);color:#fff;background:var(--duo-primary);box-shadow:0 4px 0 var(--duo-primary-dark);justify-content:center;align-items:center;display:flex}.about-step:nth-child(2) .about-step-number{background:var(--duo-primary-dark);box-shadow:0 4px 0 var(--duo-primary-darker)}.about-step:nth-child(3) .about-step-number{box-shadow:0 4px 0 var(--duo-primary);background:#4abef8}.about-step:nth-child(4) .about-step-number{background:var(--duo-primary-darker);box-shadow:0 4px #044a70}.about-step-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.about-step-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.about-team{padding:var(--space-16) 0}.about-team-grid{gap:var(--space-8);margin-top:var(--space-12);grid-template-columns:repeat(3,1fr);display:grid}.about-team-card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-8);text-align:center;border:2px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.about-team-card:hover{box-shadow:var(--shadow-lg);border-color:var(--duo-primary);transform:translateY(-4px)}.about-team-avatar{border-radius:var(--radius-full);width:72px;height:72px;margin:0 auto var(--space-4);background:var(--duo-primary-light);color:var(--duo-primary);justify-content:center;align-items:center;display:flex}[data-theme=dark] .about-team-avatar{background:#1cb0f61f}.about-team-name{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);margin-bottom:var(--space-1)}.about-team-role{color:var(--duo-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}@media (width<=768px){.about-mission-grid{grid-template-columns:1fr}.about-steps{grid-template-columns:repeat(2,1fr)}.about-team-grid{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}.about-hero-title{font-size:var(--font-size-3xl)}}@media (width<=480px){.about-steps{grid-template-columns:1fr}}.auth-page{min-height:calc(100vh - 140px);padding:var(--space-8) var(--space-6);background:linear-gradient(180deg, var(--bg-tertiary) 0%, var(--bg-primary) 100%);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--bg-card);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);border:2px solid var(--border-color);width:100%;max-width:460px;padding:var(--space-10);animation:.5s ease-out fadeInUp}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{height:48px;margin:0 auto var(--space-4)}.auth-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-2)}.auth-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-form{gap:var(--space-5);flex-direction:column;display:flex}.auth-field{gap:var(--space-2);flex-direction:column;display:flex}.auth-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.auth-input{padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-input);color:var(--text-primary);font-size:var(--font-size-base);transition:all var(--transition-normal)}.auth-input:focus{border-color:var(--duo-primary);outline:none;box-shadow:0 0 0 3px #1cb0f626}.auth-input::placeholder{color:var(--text-tertiary)}.auth-input.error{border-color:var(--danger)}.auth-input-wrapper{position:relative}.auth-input-wrapper .auth-input{width:100%;padding-right:var(--space-12)}.auth-toggle-password{right:var(--space-3);color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:color var(--transition-fast);position:absolute;top:50%;transform:translateY(-50%)}.auth-toggle-password:hover{color:var(--text-primary)}.auth-error{background:var(--danger-light);color:var(--danger);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:1px solid #ef444433}[data-theme=dark] .auth-error{background:#ef44441a}.auth-divider{align-items:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--font-size-sm);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-color);flex:1;height:1px}.auth-footer{text-align:center;margin-top:var(--space-6);color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-footer a{color:var(--accent-primary);font-weight:var(--font-weight-semibold)}.auth-footer a:hover{text-decoration:underline}.password-strength{gap:var(--space-1);margin-top:var(--space-1);display:flex}.password-strength-bar{border-radius:var(--radius-full);background:var(--border-color);height:4px;transition:background var(--transition-fast);flex:1}.password-strength-bar.active-weak{background:var(--danger)}.password-strength-bar.active-medium{background:var(--warning)}.password-strength-bar.active-strong{background:var(--success)}.password-strength-text{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.google-icon{width:20px;height:20px}@media (width<=480px){.auth-card{padding:var(--space-6);border-radius:var(--radius-2xl)}.auth-title{font-size:var(--font-size-xl)}.auth-form .btn{min-height:40px;font-size:var(--font-size-sm);padding:.5rem 1rem}}.badge{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em;padding:.25rem .625rem;line-height:1;display:inline-flex}.badge-easy{color:#58cc02;background:#58cc0226}.badge-medium{color:#e0a800;background:#ffc80026}.badge-hard{color:#ff4b4b;background:#ff4b4b26}.level-badge{align-items:center;gap:var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);background:var(--duo-primary-light);color:var(--duo-primary);border:1.5px solid var(--duo-primary-200);padding:.375rem .75rem;display:inline-flex}.level-badge-lg{font-size:var(--font-size-sm);padding:.5rem 1rem}[data-theme=dark] .level-badge{background:#1cb0f61f;border-color:#1cb0f640}.packs-page{padding:var(--space-10) 0 var(--space-20)}.packs-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.packs-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold)}.packs-filters{align-items:center;gap:var(--space-2);display:flex}.packs-filter-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-secondary);background:var(--bg-card);border:2px solid var(--border-color);transition:all var(--transition-fast);cursor:pointer;text-transform:uppercase;letter-spacing:.02em}.packs-filter-btn:hover{border-color:var(--duo-primary);color:var(--duo-primary)}.packs-filter-btn.active{background:var(--duo-primary);color:#fff;border-color:var(--duo-primary)}.packs-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.pack-card{background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);cursor:pointer;color:inherit;text-decoration:none;display:block;overflow:hidden}.pack-card:hover{box-shadow:var(--shadow-lg);border-color:var(--duo-primary);transform:translateY(-4px)}.pack-card-image{aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover;background:var(--duo-primary-light);width:100%;transition:transform var(--transition-slow)}[data-theme=dark] .pack-card-image{background:var(--bg-tertiary)}.pack-card:hover .pack-card-image{transform:scale(1.03)}.pack-card-image-wrapper{position:relative;overflow:hidden}.pack-card-badge{top:var(--space-3);right:var(--space-3);position:absolute}.pack-card-body{padding:var(--space-5) var(--space-6)}.pack-card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.pack-card-meta{color:var(--text-secondary);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;display:flex}.pack-card-count{align-items:center;gap:var(--space-1);display:flex}.pack-card-placeholder{aspect-ratio:16/10;background:var(--duo-primary-light);color:var(--duo-primary);justify-content:center;align-items:center;display:flex}[data-theme=dark] .pack-card-placeholder{background:var(--bg-tertiary)}.packs-empty{text-align:center;padding:var(--space-20);color:var(--text-secondary)}.packs-empty-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}@media (width<=768px){.packs-grid{grid-template-columns:1fr}.packs-header{flex-direction:column;align-items:flex-start}.packs-title{font-size:var(--font-size-2xl)}.packs-filters{flex-wrap:wrap}.packs-filter-btn{min-height:40px;padding:var(--space-2) var(--space-5)}.packs-page{padding:var(--space-6) 0 var(--space-12)}}@media (width<=480px){.packs-grid{gap:var(--space-4)}.pack-card-body{padding:var(--space-4)}.pack-card-title{font-size:var(--font-size-lg)}}.viewer-page{flex-direction:column;min-height:calc(100vh - 140px);display:flex}.viewer-topbar{padding:var(--space-4) 0;border-bottom:2px solid var(--border-color);background:var(--bg-secondary)}.viewer-topbar-inner{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.viewer-back{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);transition:color var(--transition-fast);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);min-height:44px;text-decoration:none;display:flex}.viewer-back:hover{color:var(--duo-primary);background:var(--bg-card-hover)}.viewer-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.viewer-counter{font-size:var(--font-size-sm);color:var(--duo-primary);font-weight:var(--font-weight-bold);white-space:nowrap;background:var(--duo-primary-light);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}[data-theme=dark] .viewer-counter{background:#1cb0f61f}.viewer-progress{background:var(--border-color);height:4px}.viewer-progress-fill{background:var(--duo-primary);border-radius:0 var(--radius-full) var(--radius-full) 0;height:100%;transition:width .4s}.viewer-content{padding:var(--space-8) var(--space-6);flex:1;justify-content:center;align-items:center;display:flex;position:relative}.viewer-image-container{cursor:pointer;-webkit-user-select:none;user-select:none;width:100%;max-width:700px;position:relative}.viewer-image-wrapper{border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);transition:all var(--transition-normal);background:var(--bg-card);border:2px solid var(--border-color);position:relative;overflow:hidden}.viewer-image-wrapper:hover{box-shadow:var(--shadow-xl);border-color:var(--duo-primary)}.viewer-image{width:100%;height:auto;transition:filter var(--transition-normal);display:block}.viewer-image-wrapper.revealed .viewer-image{filter:brightness(.35)}.viewer-tap-hint{justify-content:center;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-5);background:var(--duo-primary);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);pointer-events:none;transition:opacity var(--transition-normal);white-space:nowrap;width:fit-content;box-shadow:0 3px 0 var(--duo-primary-dark);text-transform:uppercase;letter-spacing:.03em;margin-left:auto;margin-right:auto;display:flex}.viewer-overlay{padding:var(--space-8);opacity:0;pointer-events:none;border-radius:var(--radius-2xl);flex-direction:column;justify-content:center;transition:opacity .4s;display:flex;position:absolute;inset:0}.viewer-image-wrapper.revealed .viewer-overlay{opacity:1;pointer-events:auto}.viewer-overlay-top{gap:var(--space-6);margin-bottom:var(--space-6);flex:1;align-items:center;display:flex}.viewer-overlay-section{text-align:center;flex:1}.viewer-overlay-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--duo-primary-200);margin-bottom:var(--space-2)}.viewer-overlay-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:#fff;line-height:var(--line-height-relaxed);text-shadow:0 2px 8px #00000080}.viewer-overlay-divider{border-radius:var(--radius-full);width:2px;margin:var(--space-2) 0;background:#fff3;align-self:stretch}.viewer-overlay-bottom{padding-top:var(--space-4);text-align:center;border-top:1px solid #ffffff26}.viewer-overlay-bottom .viewer-overlay-label{color:#fff9}.viewer-overlay-bottom .viewer-overlay-text{font-size:var(--font-size-base)}.viewer-nav{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-6) var(--space-4);display:flex}.viewer-nav-btn{border-radius:var(--radius-full);background:var(--bg-card);border:2px solid var(--border-color);width:52px;height:52px;color:var(--text-primary);box-shadow:0 3px 0 var(--border-color);transition:all var(--transition-fast);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;display:flex}.viewer-nav-btn:hover:not(:disabled){border-color:var(--duo-primary);color:var(--duo-primary)}.viewer-nav-btn:active:not(:disabled){box-shadow:0 1px 0 var(--border-color);transform:translateY(2px)}.viewer-nav-btn:disabled{opacity:.3;cursor:not-allowed}.viewer-nav-dots{gap:var(--space-2);flex-wrap:wrap;justify-content:center;align-items:center;max-width:60%;display:flex}.viewer-nav-dot{border-radius:var(--radius-full);background:var(--border-color);width:10px;height:10px;transition:all var(--transition-normal);cursor:pointer;border:none}.viewer-nav-dot.active{background:var(--duo-primary);border-radius:var(--radius-full);width:28px}.viewer-nav-dot.viewed{background:var(--success)}.viewer-xp-popup{z-index:var(--z-toast);pointer-events:none;animation:1.5s ease-out forwards xpPopIn;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.viewer-xp-popup-inner{background:var(--duo-primary);color:#fff;padding:var(--space-4) var(--space-8);border-radius:var(--radius-2xl);font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);box-shadow:0 4px 0 var(--duo-primary-dark), var(--shadow-xl)}.viewer-image-placeholder{aspect-ratio:4/3;justify-content:center;align-items:center;gap:var(--space-3);background:var(--duo-primary-light);width:100%;color:var(--duo-primary);flex-direction:column;display:flex}[data-theme=dark] .viewer-image-placeholder{background:var(--bg-tertiary)}@media (width<=1024px){.viewer-content{padding:var(--space-6) var(--space-4)}.viewer-image-container{max-width:580px}}@media (width<=768px){.viewer-page{min-height:calc(100vh - 120px)}.viewer-topbar-inner{gap:var(--space-2)}.viewer-content{padding:var(--space-4) var(--space-3)}.viewer-overlay{padding:var(--space-4)}.viewer-overlay-top{gap:var(--space-4);flex-direction:column}.viewer-overlay-divider{width:100%;height:1px;margin:0}.viewer-overlay-text{font-size:var(--font-size-base)}.viewer-nav{gap:var(--space-3);padding:var(--space-4) var(--space-3)}.viewer-nav-btn{width:48px;height:48px}.viewer-title{font-size:var(--font-size-base)}.viewer-tap-hint{margin-top:var(--space-3);font-size:var(--font-size-xs);padding:var(--space-2) var(--space-4)}}@media (width<=480px){.viewer-content{padding:var(--space-3) var(--space-2)}.viewer-overlay-text{font-size:var(--font-size-sm)}.viewer-overlay-label{font-size:.65rem}.viewer-nav-btn{width:44px;height:44px}.viewer-nav-dots{max-width:50%}.viewer-xp-popup-inner{font-size:var(--font-size-lg);padding:var(--space-3) var(--space-6)}}.leaderboard-page{padding:var(--space-10) 0 var(--space-20)}.leaderboard-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-8);text-align:center}.podium{justify-content:center;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-10);padding:0 var(--space-4);display:flex}.podium-place{align-items:center;gap:var(--space-3);transition:transform var(--transition-normal);flex-direction:column;display:flex}.podium-place:hover{transform:translateY(-6px)}.podium-avatar{border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:3px solid;width:64px;height:64px}.podium-avatar-placeholder{border-radius:var(--radius-full);width:64px;height:64px;font-weight:var(--font-weight-extrabold);font-size:var(--font-size-xl);color:#fff;border:3px solid;justify-content:center;align-items:center;display:flex}.podium-place-1 .podium-avatar,.podium-place-1 .podium-avatar-placeholder{width:80px;height:80px;font-size:var(--font-size-2xl);border-color:#ffc800}.podium-place-1 .podium-avatar-placeholder{background:#ffc800}.podium-place-2 .podium-avatar,.podium-place-2 .podium-avatar-placeholder{border-color:#a0b4bc}.podium-place-2 .podium-avatar-placeholder{background:#a0b4bc}.podium-place-3 .podium-avatar,.podium-place-3 .podium-avatar-placeholder{border-color:#cd7f32}.podium-place-3 .podium-avatar-placeholder{background:#cd7f32}.podium-medal{font-size:1.75rem}.podium-place-1 .podium-medal{font-size:2.25rem}.podium-name{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100px;overflow:hidden}.podium-xp{font-size:var(--font-size-sm);font-weight:var(--font-weight-extrabold);color:var(--duo-primary)}.podium-stand{border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding-top:var(--space-4);font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);color:#fff;justify-content:center;align-items:flex-start;min-width:100px;display:flex}.podium-place-1 .podium-stand{background:var(--duo-primary);height:120px}.podium-place-2 .podium-stand{background:var(--duo-primary-dark);height:90px}.podium-place-3 .podium-stand{background:var(--duo-primary-darker);height:70px}.leaderboard-table-wrapper{background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);box-shadow:var(--shadow-md);overflow:hidden}.leaderboard-table{border-collapse:collapse;width:100%}.leaderboard-table th{padding:var(--space-4) var(--space-6);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color);background:var(--bg-secondary)}.leaderboard-table td{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-color);font-size:var(--font-size-sm)}.leaderboard-table tr:last-child td{border-bottom:none}.leaderboard-table tr{transition:background var(--transition-fast)}.leaderboard-table tr:hover{background:var(--bg-card-hover)}.leaderboard-row-self{border-left:3px solid var(--duo-primary);background:var(--duo-primary-light)!important}[data-theme=dark] .leaderboard-row-self{background:#1cb0f614!important}.leaderboard-rank{font-weight:var(--font-weight-extrabold);font-size:var(--font-size-lg);min-width:40px}.leaderboard-user{align-items:center;gap:var(--space-3);display:flex}.leaderboard-user-avatar{border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-color);width:36px;height:36px}.leaderboard-user-avatar-placeholder{border-radius:var(--radius-full);background:var(--duo-primary);color:#fff;width:36px;height:36px;font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);justify-content:center;align-items:center;display:flex}.leaderboard-user-name{font-weight:var(--font-weight-bold)}.leaderboard-xp{font-weight:var(--font-weight-extrabold);color:var(--duo-primary);font-size:var(--font-size-base)}@media (width<=768px){.leaderboard-title{font-size:var(--font-size-2xl);margin-bottom:var(--space-6)}.podium{gap:var(--space-3);padding:0 var(--space-2)}.podium-stand{min-width:70px}.podium-place-1 .podium-avatar,.podium-place-1 .podium-avatar-placeholder{width:64px;height:64px}.podium-avatar,.podium-avatar-placeholder{width:52px;height:52px}.podium-name{font-size:var(--font-size-xs);max-width:80px}.leaderboard-table th,.leaderboard-table td{padding:var(--space-3) var(--space-4)}.leaderboard-table .hide-mobile{display:none}.leaderboard-page{padding:var(--space-6) 0 var(--space-12)}}@media (width<=480px){.podium-stand{min-width:56px;font-size:var(--font-size-lg)}.podium-place-1 .podium-stand{height:90px}.podium-place-2 .podium-stand{height:65px}.podium-place-3 .podium-stand{height:50px}.podium-medal{font-size:1.25rem}.podium-place-1 .podium-medal{font-size:1.75rem}.podium-xp{font-size:var(--font-size-xs)}.leaderboard-table th,.leaderboard-table td{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.leaderboard-rank{font-size:var(--font-size-base);min-width:28px}.leaderboard-user-avatar,.leaderboard-user-avatar-placeholder{width:28px;height:28px}}.image-upload{width:100%;position:relative}.image-upload-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-xl);padding:var(--space-8);text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--bg-input)}.image-upload-dropzone:hover,.image-upload-dropzone.dragging{border-color:var(--accent-primary);background:var(--bg-card-hover)}.image-upload-dropzone.dragging{box-shadow:var(--shadow-glow-blue);transform:scale(1.01)}.image-upload-icon{color:var(--text-tertiary);margin-bottom:var(--space-3)}.image-upload-text{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-1)}.image-upload-hint{color:var(--text-tertiary);font-size:var(--font-size-xs)}.image-upload-preview{border-radius:var(--radius-xl);border:2px solid var(--border-color);position:relative;overflow:hidden}.image-upload-preview img{-o-object-fit:cover;object-fit:cover;width:100%;max-height:300px}.image-upload-preview-actions{top:var(--space-3);right:var(--space-3);gap:var(--space-2);display:flex;position:absolute}.image-upload-remove{border-radius:var(--radius-full);color:#fff;cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);background:#ef4444e6;border:none;justify-content:center;align-items:center;display:flex}.image-upload-remove:hover{background:var(--danger);transform:scale(1.1)}.image-upload-avatar{align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.image-upload-avatar-circle{border-radius:var(--radius-full);border:4px solid var(--accent-primary);cursor:pointer;width:120px;height:120px;transition:all var(--transition-normal);position:relative;overflow:hidden}.image-upload-avatar-circle:hover{border-color:var(--accent-secondary);transform:scale(1.05)}.image-upload-avatar-circle img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.image-upload-avatar-placeholder{background:linear-gradient(135deg, var(--blue-500), var(--blue-700));color:#fff;width:100%;height:100%;font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);justify-content:center;align-items:center;display:flex}.image-upload-avatar-overlay{color:#fff;opacity:0;transition:opacity var(--transition-fast);background:#0006;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.image-upload-avatar-circle:hover .image-upload-avatar-overlay{opacity:1}input[type=file].image-upload-input{display:none}.profile-page{padding:var(--space-10) 0 var(--space-20)}.profile-header{align-items:center;gap:var(--space-8);margin-bottom:var(--space-10);padding:var(--space-8);background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);box-shadow:var(--shadow-md);display:flex}.profile-avatar-section{flex-shrink:0}.profile-avatar{border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:4px solid var(--duo-primary);width:110px;height:110px}.profile-avatar-placeholder{border-radius:var(--radius-full);width:110px;height:110px;font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);color:#fff;background:var(--duo-primary);justify-content:center;align-items:center;display:flex}.profile-info{flex:1}.profile-name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-1)}.profile-username{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.profile-stats-row{gap:var(--space-6);flex-wrap:wrap;display:flex}.profile-stat{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.profile-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-extrabold);color:var(--duo-primary);align-items:center;gap:var(--space-1);display:flex}.profile-stat-label{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:var(--font-weight-semibold)}.profile-streak-stat .profile-stat-value,.profile-streak-icon{color:#ff9600}.profile-xp-bar{margin-top:var(--space-4);max-width:350px}.profile-xp-info{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-2);justify-content:space-between;display:flex}.profile-xp-track{background:var(--border-color);border-radius:var(--radius-full);height:10px;overflow:hidden}.profile-xp-fill{border-radius:var(--radius-full);background:var(--duo-primary);height:100%;transition:width 1s ease-out;animation:1s ease-out progressFill}.profile-tabs{gap:var(--space-1);margin-bottom:var(--space-8);border-bottom:2px solid var(--border-color);display:flex}.profile-tab{padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;text-transform:uppercase;letter-spacing:.02em;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px}.profile-tab:hover{color:var(--text-primary)}.profile-tab.active{color:var(--duo-primary);border-bottom-color:var(--duo-primary)}.profile-history{background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);overflow:hidden}.profile-history-title{padding:var(--space-5) var(--space-6);font-weight:var(--font-weight-bold);border-bottom:1px solid var(--border-color)}.profile-history-item{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.profile-history-item:last-child{border-bottom:none}.profile-history-item:hover{background:var(--bg-card-hover)}.profile-history-pack{font-weight:var(--font-weight-semibold)}.profile-history-date{font-size:var(--font-size-xs);color:var(--text-tertiary)}.profile-history-empty{padding:var(--space-10);text-align:center;color:var(--text-secondary)}.profile-settings{background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);padding:var(--space-8)}.profile-settings-section{margin-bottom:var(--space-8)}.profile-settings-section:last-child{margin-bottom:0}.profile-settings-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.profile-form-group{margin-bottom:var(--space-5)}.profile-form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2);color:var(--text-primary);text-transform:uppercase;letter-spacing:.02em;display:block}.profile-form-input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-input);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-fast)}.profile-form-input:focus{border-color:var(--duo-primary);outline:none;box-shadow:0 0 0 3px #1cb0f626}.profile-form-textarea{resize:vertical;min-height:80px}.profile-success{padding:var(--space-3) var(--space-4);background:var(--success-light);color:var(--success);border-radius:var(--radius-xl);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);margin-bottom:var(--space-4);border:1.5px solid #58cc0240}.profile-form-actions{gap:var(--space-3);margin-top:var(--space-4);display:flex}@media (width<=768px){.profile-header{text-align:center;padding:var(--space-6);flex-direction:column}.profile-stats-row{justify-content:center}.profile-xp-bar{margin:var(--space-4) auto 0}.profile-tabs{overflow-x:auto}.profile-settings{padding:var(--space-5)}.profile-form-actions{flex-direction:column}.profile-form-actions .btn{width:100%;min-height:48px}}@media (width<=480px){.profile-header{padding:var(--space-4);gap:var(--space-4)}.profile-avatar,.profile-avatar-placeholder{width:80px;height:80px}.profile-avatar-placeholder{font-size:var(--font-size-3xl)}.profile-name{font-size:var(--font-size-xl)}.profile-stat-value{font-size:var(--font-size-lg)}.profile-tab{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.profile-settings{padding:var(--space-4)}.profile-form-input{padding:var(--space-2) var(--space-3)}.profile-history-item{padding:var(--space-3) var(--space-4);align-items:flex-start;gap:var(--space-1);flex-direction:column}}.games-page{padding:var(--space-10) 0 var(--space-20)}.games-header{align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.games-header-icon{border-radius:var(--radius-2xl);background:var(--duo-primary);color:#fff;width:56px;height:56px;box-shadow:0 4px 0 var(--duo-primary-dark);flex-shrink:0;justify-content:center;align-items:center;display:flex}.games-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold)}.games-subtitle{color:var(--text-secondary);font-size:var(--font-size-base);margin-top:var(--space-1)}.games-leaderboard-link{margin-bottom:var(--space-8)}.games-lb-btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--duo-primary-light);color:var(--duo-primary);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);transition:all var(--transition-fast);border:1.5px solid var(--duo-primary-200);display:inline-flex}[data-theme=dark] .games-lb-btn{background:#1cb0f61a;border-color:#1cb0f640}.games-lb-btn:hover{background:var(--duo-primary);color:#fff;border-color:var(--duo-primary)}.games-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.games-pack-card{background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);cursor:pointer;color:inherit;text-decoration:none;display:block;overflow:hidden}.games-pack-card:hover{box-shadow:var(--shadow-lg);border-color:var(--duo-primary);transform:translateY(-4px)}.games-pack-image-wrapper{overflow:hidden}.games-pack-image{aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover;width:100%;transition:transform var(--transition-slow)}.games-pack-card:hover .games-pack-image{transform:scale(1.03)}.games-pack-placeholder{aspect-ratio:16/9;background:var(--duo-primary-light);width:100%;color:var(--duo-primary);justify-content:center;align-items:center;display:flex}[data-theme=dark] .games-pack-placeholder{background:var(--bg-tertiary)}.games-pack-body{padding:var(--space-5) var(--space-6)}.games-pack-top{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.games-pack-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.games-pack-meta{align-items:center;gap:var(--space-1);color:var(--text-secondary);font-size:var(--font-size-sm);display:flex}.games-empty{text-align:center;padding:var(--space-20);color:var(--text-secondary)}.games-empty-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}@media (width<=768px){.games-grid{grid-template-columns:1fr}.games-title{font-size:var(--font-size-2xl)}.games-page{padding:var(--space-6) 0 var(--space-12)}}.game-select-page{padding:var(--space-8) 0 var(--space-20)}.game-select-back{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);margin-bottom:var(--space-6);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);transition:all var(--transition-fast);display:inline-flex}.game-select-back:hover{color:var(--duo-primary);background:var(--bg-card-hover)}.game-select-header{margin-bottom:var(--space-8)}.game-select-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-2)}.game-select-subtitle{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--font-size-base);display:flex}.game-select-grid{gap:var(--space-4);max-width:700px;display:grid}.game-card{align-items:center;gap:var(--space-5);padding:var(--space-6);background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);transition:all var(--transition-normal);color:inherit;text-decoration:none;display:flex}.game-card-active{cursor:pointer;box-shadow:0 4px 0 var(--border-color)}.game-card-active:hover{border-color:var(--duo-primary);box-shadow:0 4px 0 var(--duo-primary-dark);transform:translateY(-2px)}.game-card-active:active{box-shadow:0 1px 0 var(--border-color);transform:translateY(2px)}.game-card-locked{opacity:.55;cursor:not-allowed}.game-card-icon{background:var(--duo-primary-light);border-radius:var(--radius-2xl);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:2.25rem;display:flex}[data-theme=dark] .game-card-icon{background:#1cb0f61a}.game-card-icon-locked{filter:grayscale()}.game-card-content{flex:1}.game-card-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--space-1);align-items:center;gap:var(--space-2);display:flex}.game-card-lock{color:var(--text-tertiary)}.game-card-desc{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.game-card-arrow{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--duo-primary);flex-shrink:0}.game-card-coming-soon{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-secondary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);flex-shrink:0}@media (width<=768px){.game-select-title{font-size:var(--font-size-2xl)}.game-card{padding:var(--space-4);gap:var(--space-4)}.game-card-icon{width:48px;height:48px;font-size:1.75rem}.game-select-page{padding:var(--space-6) 0 var(--space-12)}}.game-results-page{min-height:calc(100vh - 140px);padding:var(--space-8) var(--space-6);justify-content:center;align-items:center;display:flex}.game-results-card{background:var(--bg-card);border-radius:var(--radius-3xl);border:2px solid var(--border-color);box-shadow:var(--shadow-2xl);padding:var(--space-10);text-align:center;width:100%;max-width:480px;position:relative;overflow:hidden}.game-results-card:before{content:"";background:radial-gradient(circle, var(--duo-primary-light) 0%, transparent 70%);z-index:0;opacity:.6;width:200px;height:200px;position:absolute;top:-50px;left:50%;transform:translate(-50%)}.dark .game-results-card:before{background:radial-gradient(circle,#1cb0f61a 0%,#0000 70%)}.game-results-card>*{z-index:1;position:relative}.game-results-icon{border-radius:var(--radius-full);background:var(--duo-primary);color:#fff;width:88px;height:88px;margin:0 auto var(--space-6);box-shadow:0 4px 0 var(--duo-primary-dark), 0 10px 20px #1cb0f64d;justify-content:center;align-items:center;display:flex}.game-results-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-black);margin-bottom:var(--space-2);color:var(--text-primary);letter-spacing:-.02em}.game-results-pack{color:var(--text-secondary);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin-bottom:var(--space-8)}.game-results-stats{justify-content:center;gap:var(--space-6);margin-bottom:var(--space-10);background:var(--bg-secondary);padding:var(--space-5) var(--space-6);border-radius:var(--radius-2xl);border:1px solid var(--border-color);flex-wrap:wrap;display:flex}.game-results-stat{align-items:center;gap:var(--space-1);flex-direction:column;min-width:80px;display:flex}.game-results-stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);color:var(--duo-primary);line-height:1}.game-results-stat-label{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em}.game-results-actions{gap:var(--space-3);flex-direction:column;align-items:center;display:flex}@media (width<=768px){.game-results-card{padding:var(--space-8) var(--space-6)}.game-results-title,.game-results-stat-value{font-size:var(--font-size-2xl)}}.fc-page{flex-direction:column;min-height:calc(100vh - 140px);display:flex}.fc-topbar{padding:var(--space-4) 0;border-bottom:2px solid var(--border-color);background:var(--bg-secondary)}.fc-topbar-inner{justify-content:space-between;align-items:center;display:flex}.fc-back{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);transition:all var(--transition-fast);min-height:44px;display:flex}.fc-back:hover{color:var(--duo-primary);background:var(--bg-card-hover)}.fc-counter{font-weight:var(--font-weight-bold);color:var(--duo-primary);background:var(--duo-primary-light);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm)}[data-theme=dark] .fc-counter{background:#1cb0f61f}.fc-progress{background:var(--border-color);height:4px}.fc-progress-fill{background:var(--duo-primary);border-radius:0 var(--radius-full) var(--radius-full) 0;height:100%;transition:width .3s}.fc-content{padding:var(--space-8) var(--space-6);perspective:1000px;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.fc-swipe-instruction{width:100%;max-width:500px;margin-bottom:var(--space-6);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.1em;justify-content:space-between;display:flex}.fc-swipe-left{color:var(--danger)}.fc-swipe-right{color:var(--success)}.fc-card-container{width:100%;max-width:500px;min-height:320px;position:relative}.fc-card{cursor:grab;-webkit-user-select:none;user-select:none;width:100%;height:100%;min-height:320px;transform-style:preserve-3d;border-radius:var(--radius-2xl);box-shadow:0 6px 0 var(--border-color);background:0 0;position:relative}.fc-card:active{cursor:grabbing}.fc-card-overlay{z-index:10;border-radius:var(--radius-2xl);font-size:var(--font-size-3xl);font-weight:var(--font-weight-black);text-transform:uppercase;color:#fff;pointer-events:none;opacity:0;text-shadow:0 2px 10px #0003;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.fc-card-overlay-left{border:4px solid var(--danger);background:#ff4b4bd9}.fc-card-overlay-right{border:4px solid var(--success);background:#58cc02d9}.fc-card-inner{width:100%;height:100%;min-height:320px;transform-style:preserve-3d;border-radius:var(--radius-2xl);transition:transform .5s cubic-bezier(.4,0,.2,1);position:relative}.fc-card-flipped .fc-card-inner{transform:rotateY(180deg)}.fc-card-front,.fc-card-back{backface-visibility:hidden;border-radius:var(--radius-2xl);border:2px solid var(--border-color);background:var(--bg-card);padding:var(--space-8);text-align:center;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.fc-card-back{gap:var(--space-4);transform:rotateY(180deg)}.fc-card-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--duo-primary);margin-bottom:var(--space-3)}.fc-card-text{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);color:var(--text-primary);line-height:var(--line-height-relaxed)}.fc-card-text-sm{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);line-height:var(--line-height-relaxed)}.fc-card-hint{margin-top:var(--space-6);font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.fc-card-section{width:100%}.fc-card-divider{background:var(--border-color);width:60%;height:1px}@media (width<=768px){.fc-content{padding:var(--space-4) var(--space-3)}.fc-card-container,.fc-card,.fc-card-inner{min-height:280px}.fc-card-text{font-size:var(--font-size-xl)}.fc-card-front,.fc-card-back{padding:var(--space-6)}}.mc-page{flex-direction:column;min-height:calc(100vh - 140px);display:flex}.mc-topbar{padding:var(--space-4) 0;border-bottom:2px solid var(--border-color);background:var(--bg-secondary)}.mc-topbar-inner{justify-content:space-between;align-items:center;display:flex}.mc-back{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);transition:all var(--transition-fast);min-height:44px;display:flex}.mc-back:hover{color:var(--duo-primary);background:var(--bg-card-hover)}.mc-score{align-items:center;gap:var(--space-1);font-weight:var(--font-weight-bold);color:var(--success);background:var(--success-light);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);display:flex}.mc-timer{align-items:center;gap:var(--space-2);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--bg-card);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);border:1.5px solid var(--border-color);display:flex}.mc-progress{background:var(--border-color);height:4px}.mc-progress-fill{background:var(--duo-primary);border-radius:0 var(--radius-full) var(--radius-full) 0;height:100%;transition:width .3s}.mc-content{padding:var(--space-8) var(--space-6);flex-direction:column;flex:1;align-items:center;width:100%;max-width:600px;margin:0 auto;display:flex}.mc-question-card{text-align:center;margin-bottom:var(--space-8);width:100%}.mc-question-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.05em}.mc-question-text{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);color:var(--text-primary);line-height:var(--line-height-relaxed)}.mc-options{gap:var(--space-3);flex-direction:column;width:100%;display:flex}.mc-option{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-2xl);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;box-shadow:0 3px 0 var(--border-color);min-height:56px;color:inherit;display:flex}.mc-option:hover:not(:disabled){border-color:var(--duo-primary);box-shadow:0 3px 0 var(--duo-primary-dark);background:var(--bg-card-hover)}.mc-option:active:not(:disabled){box-shadow:0 1px 0 var(--border-color);transform:translateY(2px)}.mc-option-letter{border-radius:var(--radius-lg);background:var(--bg-secondary);width:32px;height:32px;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--text-secondary);border:1.5px solid var(--border-color);flex-shrink:0;justify-content:center;align-items:center;display:flex}.mc-option-text{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);line-height:var(--line-height-normal);flex:1}.mc-option-correct{background:#58cc0214;border-color:var(--success)!important;box-shadow:0 3px 0 var(--green-600)!important}.mc-option-correct .mc-option-letter{background:var(--success);color:#fff;border-color:var(--success)}.mc-option-wrong{background:#ff4b4b14;border-color:var(--danger)!important;box-shadow:0 3px #d93636!important}.mc-option-wrong .mc-option-letter{background:var(--danger);color:#fff;border-color:var(--danger)}.mc-option-dimmed{opacity:.5}.mc-option-icon-correct{color:var(--success);flex-shrink:0}.mc-option-icon-wrong{color:var(--danger);flex-shrink:0}.mc-feedback{width:100%;margin-top:var(--space-6);padding:var(--space-5);border-radius:var(--radius-2xl);text-align:center}.mc-feedback-correct{background:#58cc021a;border:2px solid #58cc024d}.mc-feedback-wrong{background:#ff4b4b1a;border:2px solid #ff4b4b4d}.mc-feedback-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-extrabold)}.mc-feedback-correct .mc-feedback-text{color:var(--success)}.mc-feedback-wrong .mc-feedback-text{color:var(--danger)}.mc-feedback-answer{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-2)}@media (width<=768px){.mc-content{padding:var(--space-6) var(--space-4)}.mc-question-text{font-size:var(--font-size-xl)}.mc-option{padding:var(--space-3) var(--space-4);gap:var(--space-3)}}.glb-page{padding:var(--space-8) 0 var(--space-20)}.glb-back{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);margin-bottom:var(--space-6);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);transition:all var(--transition-fast);display:inline-flex}.glb-back:hover{color:var(--duo-primary);background:var(--bg-card-hover)}.glb-header{text-align:center;margin-bottom:var(--space-8)}.glb-icon{border-radius:var(--radius-full);color:#fff;width:64px;height:64px;margin:0 auto var(--space-4);background:#ffc800;justify-content:center;align-items:center;display:flex;box-shadow:0 4px #d4a600}.glb-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-2)}.glb-subtitle{color:var(--text-secondary);font-size:var(--font-size-base)}.glb-filters{justify-content:center;gap:var(--space-2);margin-bottom:var(--space-8);flex-wrap:wrap;display:flex}.glb-filter-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);background:var(--bg-card);border:2px solid var(--border-color);color:var(--text-secondary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);transition:all var(--transition-fast);cursor:pointer}.glb-filter-btn:hover{border-color:var(--duo-primary-200);background:var(--duo-primary-light)}.glb-filter-btn.active{background:var(--duo-primary);color:#fff;border-color:var(--duo-primary);box-shadow:0 3px 0 var(--duo-primary-dark)}.glb-table-wrapper{background:var(--bg-card);border-radius:var(--radius-2xl);border:2px solid var(--border-color);box-shadow:var(--shadow-md);max-width:900px;margin:0 auto;overflow:hidden}.glb-table{border-collapse:collapse;width:100%}.glb-table th{padding:var(--space-4) var(--space-6);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color);background:var(--bg-secondary)}.glb-table td{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-color);font-size:var(--font-size-sm)}.glb-table tr:last-child td{border-bottom:none}.glb-table tr{transition:background var(--transition-fast)}.glb-table tr:hover{background:var(--bg-card-hover)}.glb-row-self{border-left:3px solid var(--duo-primary);background:var(--duo-primary-light)!important}[data-theme=dark] .glb-row-self{background:#1cb0f614!important}.glb-rank{font-weight:var(--font-weight-extrabold);font-size:var(--font-size-lg)}.glb-user{align-items:center;gap:var(--space-3);display:flex}.glb-avatar{border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-color);width:32px;height:32px}.glb-avatar-placeholder{border-radius:var(--radius-full);background:var(--duo-primary);color:#fff;width:32px;height:32px;font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);justify-content:center;align-items:center;display:flex}.glb-name{font-weight:var(--font-weight-bold)}.glb-pack-info{flex-direction:column;gap:2px;display:flex}.glb-pack-type{font-size:var(--font-size-xs);color:var(--duo-primary);font-weight:var(--font-weight-bold);text-transform:uppercase}.glb-pack-title{font-weight:var(--font-weight-semibold);color:var(--text-secondary)}.glb-score{font-weight:var(--font-weight-extrabold);color:var(--success);background:var(--success-light);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm)}.glb-time{font-family:monospace;font-weight:var(--font-weight-semibold);color:var(--text-secondary)}.glb-empty{text-align:center;padding:var(--space-10);color:var(--text-secondary)}@media (width<=768px){.glb-title{font-size:var(--font-size-2xl)}.glb-table th,.glb-table td{padding:var(--space-3) var(--space-4)}.glb-table .hide-mobile{display:none}}@media (width<=480px){.glb-table th,.glb-table td{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.glb-rank{font-size:var(--font-size-base)}.glb-score{padding:var(--space-1) var(--space-2)}.glb-user{gap:var(--space-2)}.glb-avatar,.glb-avatar-placeholder{width:24px;height:24px;font-size:10px}}.modal-backdrop{-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);padding:var(--space-6);background:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:var(--radius-2xl);border:1px solid var(--border-color);box-shadow:var(--shadow-2xl);width:100%;max-width:560px;max-height:90vh;z-index:var(--z-modal);animation:.3s ease-out scaleIn;overflow-y:auto}.modal-header{padding:var(--space-6) var(--space-6) var(--space-4);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.modal-close{border-radius:var(--radius-lg);width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.modal-body{padding:0 var(--space-6) var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);gap:var(--space-3);justify-content:flex-end;display:flex}.admin-page{padding:var(--space-10) 0 var(--space-20)}.admin-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-2)}.admin-subtitle{color:var(--text-secondary);margin-bottom:var(--space-8)}.admin-stats{gap:var(--space-4);margin-bottom:var(--space-10);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.admin-stat-card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-6);border:1px solid var(--border-color);box-shadow:var(--shadow-md);text-align:center}.admin-stat-icon{margin-bottom:var(--space-2);font-size:2rem}.admin-stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);color:var(--accent-primary)}.admin-stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-semibold)}.admin-section{background:var(--bg-card);border-radius:var(--radius-2xl);border:1px solid var(--border-color);box-shadow:var(--shadow-md);margin-bottom:var(--space-8);overflow:hidden}.admin-section-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.admin-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.admin-section-body{padding:var(--space-6)}.admin-list-item{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast);display:flex}.admin-list-item:last-child{border-bottom:none}.admin-list-item:hover{background:var(--bg-card-hover)}.admin-list-thumb{border-radius:var(--radius-lg);-o-object-fit:cover;object-fit:cover;background:var(--bg-tertiary);flex-shrink:0;width:60px;height:60px}.admin-list-thumb-placeholder{border-radius:var(--radius-lg);background:var(--bg-tertiary);flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;font-size:1.5rem;display:flex}.admin-list-info{flex:1;min-width:0}.admin-list-title{font-weight:var(--font-weight-bold);margin-bottom:var(--space-1);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.admin-list-meta{font-size:var(--font-size-xs);color:var(--text-secondary)}.admin-list-actions{gap:var(--space-2);flex-shrink:0;display:flex}.admin-form{gap:var(--space-5);flex-direction:column;display:flex}.admin-form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.admin-form-group{gap:var(--space-2);flex-direction:column;display:flex}.admin-form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.admin-form-input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-input);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-fast)}.admin-form-input:focus{border-color:var(--border-color-focus)}.admin-form-select{padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-input);color:var(--text-primary);font-size:var(--font-size-base);cursor:pointer}.admin-form-textarea{resize:vertical;min-height:80px}.admin-form-actions{gap:var(--space-3);display:flex}.admin-idiom-editor{background:var(--bg-tertiary);border-radius:var(--radius-xl);padding:var(--space-6);margin-top:var(--space-4)}.admin-empty{padding:var(--space-10);text-align:center;color:var(--text-secondary)}.admin-users-table{border-collapse:collapse;width:100%}.admin-users-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-secondary);border-bottom:2px solid var(--border-color)}.admin-users-table td{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);border-bottom:1px solid var(--border-color)}.admin-users-table tr:hover{background:var(--bg-card-hover)}.admin-search{padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-input);color:var(--text-primary);font-size:var(--font-size-sm);min-width:250px;transition:border-color var(--transition-fast)}.admin-search:focus{border-color:var(--border-color-focus)}@media (width<=768px){.admin-form-row{grid-template-columns:1fr}.admin-list-item{flex-wrap:wrap}.admin-search{min-width:100%}.admin-users-table .hide-mobile{display:none}}:root{--font-primary:"Inter", system-ui, -apple-system, sans-serif;--font-display:"Space Grotesk", sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--font-weight-black:900;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--radius-full:9999px;--duo-primary:#1cb0f6;--duo-primary-dark:#0a84c8;--duo-primary-darker:#0870a8;--duo-primary-light:#eaf6ff;--duo-primary-100:#d4efff;--duo-primary-200:#a8dffe;--duo-primary-btn-shadow:#0a84c8;--blue-100:#d4efff;--blue-200:#a8dffe;--blue-300:#7dcefd;--blue-400:#4abef8;--blue-500:#1cb0f6;--blue-600:#0a84c8;--blue-700:#0870a8;--blue-800:#065c8c;--blue-900:#044a70;--green-500:#58cc02;--green-600:#46a302;--orange-400:#ff9600;--orange-500:#ff9600;--bg-primary:#fff;--bg-secondary:#f7f7f7;--bg-tertiary:#efefef;--bg-card:#fff;--bg-card-hover:#f0f7ff;--bg-nav:#fff;--bg-light-blue:#eaf6ff;--bg-input:#fff;--text-primary:#3c3c3c;--text-secondary:#777;--text-tertiary:#afafaf;--border-color:#e5e5e5;--border-color-focus:#1cb0f6;--border-color-hover:#d0d0d0;--accent-primary:#1cb0f6;--accent-secondary:#0a84c8;--danger:#ff4b4b;--danger-light:#ff4b4b1a;--success:#58cc02;--success-light:#58cc021a;--warning:#ffc800;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 2px 8px #00000014;--shadow-lg:0 4px 16px #00000014;--shadow-xl:0 8px 24px #0000001a;--shadow-2xl:0 12px 32px #0000001f;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--transition-bounce:.3s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown:50;--z-sticky:100;--z-modal-backdrop:900;--z-modal:1000;--z-toast:1100}[data-theme=dark]{--bg-primary:#131f24;--bg-secondary:#1a2b33;--bg-tertiary:#213740;--bg-card:#1a2b33;--bg-card-hover:#213740;--bg-nav:#131f24;--bg-light-blue:#1a2b33;--bg-input:#213740;--text-primary:#f0f0f0;--text-secondary:#a0b4bc;--text-tertiary:#6b8590;--border-color:#2a3e48;--border-color-focus:#1cb0f6;--border-color-hover:#3a5060;--shadow-sm:0 1px 3px #0003;--shadow-md:0 2px 8px #00000040;--shadow-lg:0 4px 16px #0000004d;--shadow-xl:0 8px 24px #00000059;--shadow-2xl:0 12px 32px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;transition:background-color var(--transition-normal), color var(--transition-normal);-webkit-tap-highlight-color:transparent}@media (width<=768px){:root{--font-size-base:.9375rem}}@media (width<=480px){:root{--font-size-base:.875rem}}#root{flex-direction:column;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}img{max-width:100%;display:block}input,textarea,select{font-family:inherit;font-size:inherit}.container{width:100%;max-width:1200px;padding:0 var(--space-6);margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.95)}to{transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes fireFlicker{0%,to{transform:scale(1)}25%{transform:scale(1.15)rotate(-3deg)}50%{transform:scale(1.05)rotate(3deg)}75%{transform:scale(1.1)rotate(-2deg)}}@keyframes page-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes progressFill{0%{width:0}}@keyframes cardFlip{0%{transform:rotateY(0)}to{transform:rotateY(180deg)}}@keyframes popIn{0%{opacity:0;transform:translate(-50%,-50%)scale(.5)}70%{opacity:1;transform:translate(-50%,-50%)scale(1.1)}to{transform:translate(-50%,-50%)scale(1)}}@keyframes xpPopIn{0%{opacity:0;transform:translate(-50%,-50%)scale(.5)}20%{opacity:1;transform:translate(-50%,-50%)scale(1.1)}40%{transform:translate(-50%,-50%)scale(1)}80%{opacity:1;transform:translate(-50%,-60%)}to{opacity:0;transform:translate(-50%,-80%)}}.page-enter{animation:.4s ease-out page-enter}.animate-fade-in-up{opacity:0;animation:.6s ease-out forwards fadeInUp}.animate-fade-in{opacity:0;animation:.4s ease-out forwards fadeIn}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.stagger-6{animation-delay:.6s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background:var(--accent-primary);color:#fff}
