@import"https://fonts.googleapis.com/css2?family=Instrument+Sans:ital,wght@0,400..700;1,400..700&family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Space+Mono:ital,wght@0,400;0,700;1,400;1,700&display=swap";.theme-toggle{background:transparent;border:1px solid transparent;cursor:pointer;padding:.5rem;border-radius:8px;color:var(--text-secondary);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;width:auto;height:auto}.theme-toggle:hover{color:var(--text-primary);background-color:var(--bg-hover, rgba(0, 0, 0, .05));border-color:var(--border-color)}.theme-icon{width:20px;height:20px;transition:transform var(--transition-fast)}.theme-toggle:hover .theme-icon{transform:scale(1.1)}.theme-icon.sun{color:var(--accent-gold)}.theme-icon.moon{color:var(--text-light)}.theme-toggle:hover .theme-icon.moon{color:var(--accent-primary)}.auth-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .2s ease}.auth-modal{position:relative;background:#ffffff08;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.08);border-radius:2rem;padding:3.5rem 2.5rem;max-width:400px;width:100%;text-align:center;animation:slideUp .4s cubic-bezier(.16,1,.3,1);box-shadow:0 40px 100px -20px #00000080,inset 0 0 0 1px #ffffff0d}@keyframes slideUp{0%{opacity:0;transform:translateY(40px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-modal-close{position:absolute;top:1.5rem;right:1.5rem;background:transparent;border:none;color:var(--text-light);font-size:1rem;cursor:pointer;padding:.5rem;opacity:.5;transition:opacity .2s ease}.auth-modal-close:hover{opacity:1}.auth-brand-mark{width:32px;height:32px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center}.mark-line{width:2px;height:100%;background:var(--accent-primary);box-shadow:0 0 15px var(--accent-primary)}.auth-modal-title{font-size:1.5rem;font-weight:500;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:.02em;font-family:var(--font-display)}.auth-modal-subtitle{color:var(--text-light);font-size:.85rem;margin:0 0 2.5rem;opacity:.6;font-weight:400}.auth-social-area{margin-bottom:2rem}.google-auth-btn{width:100%;padding:.875rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.75rem;color:var(--text);font-size:.9rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.75rem;cursor:pointer;transition:all .2s ease}.google-auth-btn:hover{background:#ffffff14;border-color:#fff3;transform:translateY(-1px)}.auth-divider{margin:1.5rem 0;position:relative;display:flex;align-items:center;justify-content:center}.auth-divider:before{content:"";position:absolute;width:100%;height:1px;background:#ffffff0d;z-index:1}.auth-divider span{background:var(--bg-card);padding:0 1rem;font-size:.75rem;color:var(--text-light);opacity:.4;position:relative;z-index:2;text-transform:uppercase;letter-spacing:.1em}.auth-modal-form{display:flex;flex-direction:column;gap:1.25rem}.auth-input-wrapper{position:relative}.auth-modal-input{width:100%;padding:1rem 1.25rem;font-size:.95rem;border:1px solid var(--border-prominent);border-radius:.75rem;background:var(--bg-secondary);color:var(--text-primary);transition:all .2s ease;box-sizing:border-box}.auth-modal-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-primary);box-shadow:0 0 0 4px #6b4c9a1a}.auth-modal-input::placeholder{color:var(--text-light);opacity:.8}.auth-error{display:block;color:#ef4444;font-size:.85rem;margin-top:.5rem;text-align:left}.auth-submit-btn{width:100%;padding:1rem;font-size:.9rem;font-weight:600;border-radius:.75rem;letter-spacing:.02em}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-loading{display:flex;gap:.35rem;justify-content:center;align-items:center}.auth-loading .dot{width:8px;height:8px;background:currentColor;border-radius:50%;animation:bounce .6s infinite alternate}.auth-loading .dot:nth-child(2){animation-delay:.2s}.auth-loading .dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-6px)}}.auth-modal-note{margin:2.5rem 0 0;font-size:.7rem;color:var(--text-light);opacity:.4;line-height:1.6}.auth-success-state{padding:1rem 0}.success-icon-large{width:64px;height:64px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-gold));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;animation:scaleIn .4s cubic-bezier(.16,1,.3,1)}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.auth-success-state h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.auth-success-state p{font-size:.9rem;color:var(--text-light);opacity:.7;margin:0}@media(max-width:480px){.auth-modal{padding:3rem 1.5rem 2rem}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--navbar-height);display:flex;align-items:center;transition:all var(--transition-base)}.navbar-container{max-width:var(--container);width:100%;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between}.navbar-brand{display:flex;align-items:center;gap:1rem;text-decoration:none;z-index:1001}.brand-logo-wrapper{position:relative;padding:2px;border-radius:10px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-gold));display:flex}.navbar-logo{width:32px;height:32px;border-radius:8px;object-fit:cover}.navbar-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.navbar-menu{display:flex;align-items:center;gap:3rem;transition:all var(--transition-base)}.navbar-links{display:flex;list-style:none;gap:2rem}.navbar-link{font-size:.95rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast);text-decoration:none;position:relative;padding:.5rem 0}.navbar-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent-gold);transition:width var(--transition-fast)}.navbar-link:hover{color:var(--text-primary)}.navbar-link:hover:after,.navbar-link.active:after{width:100%}.navbar-link.active{color:var(--text-primary);font-weight:600}.navbar-actions{display:flex;align-items:center;gap:1.5rem}.navbar-cta{padding:.75rem 1.5rem;font-size:.9rem;border-radius:100px}.navbar-toggle{display:none;flex-direction:column;gap:6px;background:none;border:2px solid var(--accent-gold);border-radius:8px;cursor:pointer;padding:.5rem;z-index:1002}.navbar-toggle span{width:24px;height:2px;background:var(--text-primary);transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:2px}.navbar-toggle.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.navbar-toggle.active span:nth-child(2){opacity:0;transform:translate(-10px)}.navbar-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.user-profile-wrapper{position:relative}.user-profile-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);background:var(--bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--text-secondary)}.user-profile-btn:hover{border-color:var(--accent-gold);background:var(--bg-hover);color:var(--text-primary);transform:scale(1.05)}.user-profile-btn.signed-in{background:linear-gradient(135deg,var(--accent-primary),var(--accent-gold));border:none;color:#fff;font-weight:700;font-size:1rem;box-shadow:0 4px 12px rgba(var(--accent-rgb),.3)}.user-profile-btn.signed-in:hover{transform:scale(1.08);box-shadow:0 6px 16px rgba(var(--accent-rgb),.4)}.user-initial{text-transform:uppercase;font-family:var(--font-display)}.user-dropdown{position:absolute;top:calc(100% + .75rem);right:0;min-width:200px;background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;box-shadow:0 10px 40px #0000004d;z-index:1002;overflow:hidden;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{padding:1rem;background:var(--bg-hover)}.user-email{font-size:.85rem;color:var(--text-secondary);word-break:break-all}.user-dropdown-divider{height:1px;background:var(--border)}.user-dropdown-item{width:100%;padding:.875rem 1rem;display:flex;align-items:center;gap:.75rem;background:none;border:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .15s ease;text-align:left}.user-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.user-dropdown-item svg{opacity:.7}.user-dropdown-row{padding:.875rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--text-secondary);font-size:.9rem}.dropdown-label{flex:1;font-weight:500}.user-dropdown-row .theme-toggle{width:36px;height:36px;padding:0;min-height:0;background:var(--bg-hover, rgba(0, 0, 0, .05));border:1px solid var(--border)}@media(max-width:992px){.navbar-menu{gap:1.5rem}.navbar-links{gap:1.25rem}}@media(max-width:768px){.navbar-container{padding:0 1rem}.navbar-toggle{display:flex}.navbar-menu{position:fixed;inset:0;width:100vw;height:100vh;height:100dvh;background:var(--bg-primary);flex-direction:column;justify-content:flex-start;align-items:center;padding:calc(var(--navbar-height, 70px) + 2rem) 2rem 2rem;gap:0;transform:translate(100%);opacity:0;visibility:hidden;pointer-events:none;z-index:999;overflow-y:auto;transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s ease,visibility .35s ease}.navbar-menu.open{transform:translate(0);opacity:1;visibility:visible;pointer-events:all}.navbar-links{flex-direction:column;align-items:center;width:100%;gap:0;margin-bottom:2rem}.navbar-links li{width:100%}.navbar-link{display:block;font-size:1.35rem;font-weight:500;padding:1.25rem 0;text-align:center;width:100%;border-bottom:1px solid var(--border-color, rgba(128, 128, 128, .2));color:var(--text-secondary)}.navbar-link:hover,.navbar-link.active{color:var(--accent-primary)}.navbar-links li:last-child .navbar-link{border-bottom:none}.navbar-link:after{display:none}.navbar-actions{flex-direction:column;width:100%;align-items:center;gap:1.5rem;margin-top:auto;padding-top:2rem;border-top:1px solid var(--border-color, rgba(128, 128, 128, .2))}.navbar-cta{width:100%;max-width:280px;text-align:center;padding:1rem 2rem;font-size:1rem}.user-profile-wrapper{width:100%;max-width:280px;display:flex;justify-content:center}.user-profile-btn{width:50px;height:50px}.user-dropdown{position:fixed;inset:auto 0 0;border-radius:1.5rem 1.5rem 0 0;min-width:100%;max-height:60vh;overflow-y:auto}}@media(max-width:480px){.navbar-title{font-size:1.25rem}.navbar-logo{width:28px;height:28px}.navbar-link{font-size:1.2rem;padding:1rem 0}.navbar-cta{max-width:100%}}.footer{margin-top:auto;padding:6rem 0 3rem;border-top:1px solid var(--border-color);background:var(--bg-secondary);transition:background-color var(--transition-base)}.footer-container{max-width:var(--container);margin:0 auto;padding:0 2rem}.footer-main{display:flex;justify-content:space-between;margin-bottom:4rem}.footer-brand{max-width:300px}.footer-logo-link{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;color:var(--text-primary)}.footer-logo{width:28px;height:28px;border-radius:6px}.footer-title{font-size:1.25rem;font-weight:700;font-family:var(--font-display);letter-spacing:-.01em;color:var(--text-primary)}.footer-tagline{font-size:.95rem;color:var(--text-secondary);line-height:1.5;margin:0}.footer-links{display:flex;gap:4rem}.footer-section h4{font-size:.75rem;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.5rem}.footer-section ul{list-style:none;padding:0}.footer-section li{margin-bottom:.75rem}.footer-section a{font-size:.9rem;color:var(--text-secondary);transition:color var(--transition-fast)}.footer-section a:hover{color:var(--accent-primary)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid var(--border-color)}.footer-bottom p{font-size:.85rem;color:var(--text-light);margin:0}.footer-legal{display:flex;align-items:center;gap:2rem}.legal-links{display:flex;gap:2rem}.footer-legal .theme-toggle{width:36px;height:36px;padding:0;min-height:0;background:transparent;border:1px solid var(--border-prominent)}.footer-legal a{font-size:.85rem;color:var(--text-light)}.footer-legal a:hover{color:var(--text-primary)}@media(max-width:992px){.footer-links{gap:2.5rem}}@media(max-width:768px){.footer{padding:4rem 0 2rem}.footer-main{flex-direction:column;gap:3rem}.footer-links{flex-wrap:wrap;gap:2rem}.footer-brand{max-width:100%}.footer-bottom{flex-direction:column;align-items:flex-start;gap:1.5rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes brushStroke{0%{width:0}to{width:100%}}@keyframes gentlePulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes revealText{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}.fade-in-up{animation:fadeInUp .8s cubic-bezier(.4,0,.2,1) forwards}.fade-in{animation:fadeIn .8s ease forwards}.delay-1{animation-delay:.2s}.delay-2{animation-delay:.4s}.delay-3{animation-delay:.6s}.hover-lift{transition:transform var(--transition-base)}.hover-lift:hover{transform:translateY(-5px)}.btn-shine{position:relative;overflow:hidden}.btn-shine:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(to right,transparent,rgba(255,255,255,.2),transparent);transform:skew(-25deg);transition:.75s}.btn-primary:hover.btn-shine:after{left:125%}.home{padding-top:var(--navbar-height);position:relative;overflow:hidden}.hero{min-height:85vh;display:flex;align-items:center;padding:6rem 0;position:relative}.hero-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:6rem;align-items:center}.hero-badge{margin-bottom:2.5rem}.brush-underline{font-family:var(--font-mono);font-size:.85rem;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.4em;position:relative;font-weight:500}.brush-underline:after{content:"";position:absolute;bottom:-6px;left:0;width:40px;height:2px;background:var(--accent-gold);border-radius:100px;opacity:.8}.hero-title{font-size:clamp(3.5rem,8vw,5.5rem);line-height:1.05;margin-bottom:2.5rem;display:flex;flex-direction:column}.title-scholar{color:var(--text-primary);font-weight:400}.title-ninja{color:var(--accent-primary);position:relative;display:inline-block}.hero-subtitle{display:flex;gap:2.5rem;align-items:flex-start;max-width:650px;margin-bottom:4rem}.percentile-box{display:flex;flex-direction:column;align-items:center;color:var(--accent-gold);padding-top:.5rem}.percentile-num{font-size:3.5rem;font-family:var(--font-display);font-weight:800;line-height:1}.percentile-label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em}.hero-subtitle p{font-size:1.15rem;color:var(--text-secondary);line-height:1.7;margin:0}.hero-cta{display:flex;gap:2rem;flex-wrap:wrap}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;position:relative;z-index:2}.stat-card{padding:3rem 2rem;text-align:center;display:flex;flex-direction:column;gap:1rem;border-radius:24px;background:var(--bg-secondary);border:1px solid var(--border-color)}.stat-card:nth-child(3){grid-column:span 2;flex-direction:row;justify-content:center;align-items:center;gap:3rem;padding:2rem}.stat-value{font-family:var(--font-display);font-size:2.75rem;font-weight:800;color:var(--text-primary)}.stat-label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;color:var(--text-light);letter-spacing:.15em;font-weight:600}.features{padding:10rem 0;background-color:var(--bg-primary);position:relative;border-top:1px solid var(--border-color)}.section-header{text-align:center;margin-bottom:6rem}.section-title{font-size:3.5rem;margin-bottom:1.5rem;letter-spacing:-.02em}.section-subtitle{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.3em;color:var(--accent-gold);font-size:.9rem;font-weight:500}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}.feature-card{padding:4rem 2.5rem;border-radius:32px;position:relative;display:flex;flex-direction:column;min-height:450px;transition:all var(--transition-base)}.card-tag{position:absolute;top:2.5rem;right:2.5rem;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;color:var(--accent-success);background:#3d8b6e14;padding:.5rem 1.25rem;border-radius:100px;font-weight:600;letter-spacing:.05em}.card-tag.premium{color:var(--accent-gold);background:#b88e441a}.card-icon-wrapper{width:72px;height:72px;background:var(--bg-secondary);border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:2.5rem;color:var(--accent-primary);border:1px solid var(--border-color)}.feature-card h3{font-size:2.25rem;margin-bottom:1.5rem}.feature-card p{font-size:1.05rem;color:var(--text-secondary);line-height:1.7;margin-bottom:2.5rem}.card-footer{margin-top:auto;display:flex;align-items:center;gap:1rem;font-weight:700;color:var(--accent-primary);font-size:1rem}.focus-card{background:var(--bg-secondary);border:1px solid var(--border-prominent)}.difficulty-pills{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}.pill{font-family:var(--font-mono);font-size:.75rem;padding:.5rem 1rem;border-radius:8px;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary);font-weight:500}.approach{padding:8rem 0}.approach-box{padding:6rem;border-radius:48px}.approach-content h3{font-size:3rem;margin-bottom:5rem;text-align:center}.steps-container{display:flex;justify-content:space-between;gap:4rem}.approach-step{flex:1;display:flex;flex-direction:column;gap:2rem}.step-num{font-family:var(--font-display);font-size:4.5rem;line-height:1;color:var(--accent-gold);opacity:.3}.step-info h4{font-size:1.75rem;margin-bottom:.75rem}.arcade-cta{margin:4rem auto 12rem}.arcade-banner{display:flex;justify-content:space-between;align-items:center;padding:5rem 6rem;border-radius:48px;background:var(--bg-secondary);border:1px solid var(--border-prominent)}.banner-tag{font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;color:var(--accent-gold);display:block;margin-bottom:1.25rem;letter-spacing:.2em;font-weight:600}.arcade-banner h2{font-size:4rem;margin-bottom:.75rem}.arcade-banner p{font-size:1.25rem}.arcade-banner-icon{color:var(--accent-primary);opacity:1;transition:transform var(--transition-base);background:var(--bg-primary);padding:2rem;border-radius:24px;border:1px solid var(--border-color)}.arcade-banner:hover .arcade-banner-icon{transform:scale(1.05) translateY(-5px)}@media(max-width:1200px){.arcade-banner{padding:4rem}}@media(max-width:992px){.hero-layout{grid-template-columns:1fr;text-align:center;gap:4rem}.hero-content{display:flex;flex-direction:column;align-items:center}.hero-subtitle{margin:0 auto 3rem}.hero-cta{justify-content:center}.features-grid{grid-template-columns:1fr 1fr}.focus-card{grid-column:span 2}.steps-container{flex-direction:column;gap:3rem}.arcade-banner{flex-direction:column;text-align:center;gap:4rem}}@media(max-width:768px){.hero-title{font-size:3rem}.hero-subtitle{flex-direction:column;gap:1.5rem;text-align:center;align-items:center}.percentile-box{flex-direction:row;gap:.5rem;justify-content:center}.hero-cta{flex-direction:column;gap:1rem;width:100%}.hero-cta .btn{width:100%;justify-content:center}.arcade-cta{margin:4rem auto 8rem}.arcade-banner{padding:3rem 2rem}.arcade-banner h2{font-size:2rem}.features{padding:5rem 0}.section-header{margin-bottom:3rem}.section-title{font-size:2.25rem}.section-subtitle{font-size:.75rem;letter-spacing:.15em}.features-grid{grid-template-columns:1fr;gap:1.5rem}.focus-card{grid-column:span 1}.feature-card{min-height:auto;padding:2.5rem 2rem}.feature-card h3{font-size:1.75rem;margin-bottom:1rem}.feature-card p{font-size:1rem;margin-bottom:1.5rem}.card-icon-wrapper{width:56px;height:56px;border-radius:16px;margin-bottom:1.5rem}.card-icon-wrapper svg{width:24px;height:24px}.card-tag{top:2rem;right:2rem;padding:.4rem 1rem;font-size:.65rem}.difficulty-pills{margin-bottom:1.5rem}.approach{padding:4rem 0}.approach-box{padding:3rem 1.5rem;border-radius:24px}.approach-content h3{font-size:2rem;margin-bottom:3rem}.steps-container{gap:2.5rem}.approach-step{gap:1rem;align-items:center;text-align:center}.step-num{font-size:2.5rem}.step-info h4{font-size:1.35rem}.step-info p{font-size:.95rem}.stats-grid{grid-template-columns:1fr 1fr;gap:1rem}.stat-card{padding:2rem 1rem;border-radius:16px}.stat-card:nth-child(3){flex-direction:column;gap:.5rem;padding:1.5rem}.stat-value{font-size:2rem}.stat-label{font-size:.65rem}}@media(max-width:480px){.hero-title,.percentile-num{font-size:2.5rem}.feature-card{padding:2rem 1.5rem}.approach-box{padding:2.5rem 1.25rem}.approach-content h3{font-size:1.75rem;margin-bottom:2.5rem}.arcade-banner{padding:2.5rem 1.5rem}.arcade-banner h2{font-size:1.75rem}.arcade-banner p{font-size:1rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.course-page{padding-top:var(--navbar-height);min-height:100vh;background-color:var(--bg-primary);position:relative;overflow-x:hidden;transition:background-color var(--transition-base)}.course-page.quiz-mode{padding-top:0}.course-page .container{position:relative;z-index:2}.page-header{padding:3rem 0 2rem;text-align:center}.back-link{display:inline-flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:2rem;transition:all var(--transition-fast);background:none;border:none;cursor:pointer;padding:0;text-decoration:none}.locked-content{max-width:800px;margin:0 auto;padding:4rem 2rem;text-align:center}.lock-icon{font-size:4rem;margin-bottom:2rem;color:var(--accent-gold);opacity:.8}.locked-content h2{font-size:2.5rem;margin-bottom:1.5rem;color:var(--text-primary)}.lock-desc{font-size:1.2rem;line-height:1.7;color:var(--text-secondary);margin-bottom:4rem}.pricing-card{background:var(--bg-secondary);border:1px solid var(--accent-gold);border-radius:32px;padding:4rem;box-shadow:var(--shadow-md);margin-bottom:3rem}.price-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding-bottom:3rem;margin-bottom:3rem;border-bottom:1px solid var(--border-color)}.price-tag-large{font-family:var(--font-display);font-size:4.5rem;font-weight:700;color:var(--accent-primary);line-height:1}.price-label{font-family:var(--font-mono);font-size:.9rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.1em}.whats-included{text-align:left;margin-bottom:4rem}.whats-included h3{font-size:1.75rem;margin-bottom:2rem;text-align:center;color:var(--text-primary)}.included-list{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.included-item{display:flex;align-items:flex-start;gap:1rem;font-size:1.1rem;color:var(--text-primary)}.check-icon{color:var(--accent-success);font-weight:700;font-size:1.25rem;flex-shrink:0}.preview-note{display:inline-flex;align-items:center;gap:1rem;padding:1.25rem 2.5rem;border-radius:100px;font-size:1rem;color:var(--text-primary)}.unlocked-content{max-width:1200px;margin:0 auto;padding:2rem}.access-badge{display:inline-block;background:linear-gradient(135deg,var(--accent-success),#2ecc71);color:#fff;padding:.5rem 1.5rem;border-radius:100px;font-family:var(--font-mono);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3rem}.browse-container{max-width:1000px;margin:0 auto;padding-bottom:5rem}.progress-header{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:24px;padding:2.5rem;margin-bottom:3rem;display:flex;align-items:center;gap:3rem;position:relative;overflow:hidden}.progress-info{flex:1}.progress-info h3{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary)}.progress-bar-outer{height:12px;background:var(--bg-primary);border-radius:100px;overflow:hidden;margin:1.5rem 0 .5rem}.progress-bar-inner{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-gold));border-radius:100px;transition:width 1s ease-out}.progress-stats-row{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.9rem;color:var(--text-secondary)}.filter-bar{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:3rem;background:var(--bg-secondary);padding:1rem;border-radius:16px;border:1px solid var(--border-color)}.filter-group{display:flex;align-items:center;gap:.75rem;flex:1;min-width:200px}.filter-label{font-size:.8rem;font-family:var(--font-mono);text-transform:uppercase;color:var(--text-muted)}.filter-select{flex:1;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;outline:none;cursor:pointer}.filter-select:focus{border-color:var(--accent-primary)}.filter-checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.filter-checkbox-label input{width:auto;margin:0}.reset-filters{padding:.75rem 1.5rem;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-family:var(--font-mono);font-size:.85rem;cursor:pointer;transition:all .2s}.reset-filters:hover{color:var(--accent-primary);border-color:var(--accent-primary)}.topics-list{display:flex;flex-direction:column;gap:2rem}.topic-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;overflow:hidden}.topic-header{padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;background:#9b7dd40d;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s}.topic-header:hover{background:#9b7dd41a}.topic-title-group{display:flex;align-items:center;gap:1.5rem}.topic-icon{font-size:1.8rem}.topic-name{font-size:1.4rem;font-weight:700;color:var(--text-primary)}.topic-meta{display:flex;align-items:center;gap:1.5rem}.topic-progress-text{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.topic-content{padding:2rem}.subtopics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.subtopic-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .2s}.subtopic-card:hover{border-color:var(--accent-primary);transform:translate(5px)}.subtopic-info{display:flex;flex-direction:column;gap:.25rem}.subtopic-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.subtopic-count{font-size:.8rem;color:var(--text-muted)}.subtopic-stats{text-align:right}.subtopic-percent{font-family:var(--font-mono);font-size:.9rem;font-weight:700;color:var(--accent-primary)}.preview-container{max-width:800px;margin:2rem auto;background:var(--bg-secondary);border-radius:32px;padding:3rem;border:1px solid var(--border-color)}.preview-list{margin:2rem 0;border-top:1px solid var(--border-color)}.preview-item{padding:1.25rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.preview-q-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:2rem;color:var(--text-primary);font-weight:500}.preview-actions{display:flex;justify-content:space-between;margin-top:3rem}.btn-start-random{position:fixed;bottom:2rem;right:2rem;padding:1rem 2rem;background:var(--accent-primary);color:#fff;border-radius:100px;font-weight:700;box-shadow:0 10px 30px #9b7dd466;display:flex;align-items:center;gap:1rem;border:none;cursor:pointer;transition:all .3s;z-index:100}.btn-start-random:hover{transform:scale(1.05) translateY(-5px);box-shadow:0 15px 40px #9b7dd499}.ready-screen{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:2rem}.ready-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:32px;padding:3.5rem 4rem;text-align:center;max-width:520px;width:100%;box-shadow:0 20px 60px #00000026;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.ready-title{font-size:2.2rem;font-weight:800;color:var(--text-primary);margin-bottom:2.5rem;letter-spacing:-.02em}.ready-stats{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:2rem;background:var(--bg-primary);border-radius:20px;margin-bottom:2rem}.ready-stat{display:flex;flex-direction:column;align-items:center;gap:.5rem}.ready-stat .stat-value{font-size:1.8rem;font-weight:800;color:var(--accent-primary);line-height:1}.ready-stat .stat-label{font-size:.75rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.ready-divider{width:1px;height:40px;background:var(--border-color)}.timer-toggle{display:flex;gap:.75rem;justify-content:center;margin-bottom:2rem}.toggle-btn{padding:.85rem 1.75rem;border-radius:100px;border:2px solid var(--border-color);background:transparent;color:var(--text-secondary);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .25s ease}.toggle-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.toggle-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 4px 20px #9b7dd466}.start-btn-big{width:100%;padding:1.25rem 2rem;background:linear-gradient(135deg,var(--accent-primary),#7c5fc2);border:none;border-radius:16px;color:#fff;font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:1rem;transition:all .3s ease;box-shadow:0 8px 30px #9b7dd466}.start-btn-big:hover{transform:translateY(-3px);box-shadow:0 12px 40px #9b7dd499}.start-btn-big:active{transform:translateY(0)}.start-arrow{font-size:1.4rem;transition:transform .3s ease}.start-btn-big:hover .start-arrow{transform:translate(5px)}.back-link-subtle{display:inline-block;margin-top:1.5rem;padding:.75rem 1.5rem;background:transparent;border:none;color:var(--text-muted);font-size:.9rem;font-family:var(--font-mono);cursor:pointer;transition:color .2s ease}.back-link-subtle:hover{color:var(--accent-primary)}@media(max-width:600px){.ready-card{padding:2.5rem 1.5rem}.ready-stats{flex-direction:column;gap:1.5rem}.ready-divider{width:60px;height:1px}.timer-toggle{flex-direction:column}.toggle-btn{width:100%}}.result-header h1{font-size:clamp(2rem,5vw,3rem)}.score-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:3rem 0}.score-card{background:var(--bg-secondary);padding:2.5rem;border-radius:24px;text-align:center;border:1px solid var(--border-color)}.score-total{font-size:2rem;color:var(--text-muted)}.score-label{margin-top:1rem;font-size:1.2rem;font-weight:700;color:var(--text-primary)}.stat-box{background:var(--bg-secondary);padding:1.5rem;border-radius:16px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border-color)}.stat-val{font-size:2rem;font-weight:800;color:var(--text-primary)}.stat-name{color:var(--text-secondary);font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase}.solutions-section{margin-top:4rem}.solution-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;margin-bottom:2rem;overflow:hidden;transition:all .3s ease}.solution-card.correct{border-left:8px solid #2ecc71}.solution-card.incorrect{border-left:8px solid #e74c3c}.solution-card.unattempted{border-left:8px solid #95a5a6}.solution-header{padding:1.5rem 2rem;display:flex;align-items:center;gap:1.5rem}.solution-status{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;color:#fff}.correct .solution-status{background:#2ecc71}.incorrect .solution-status{background:#e74c3c}.unattempted .solution-status{background:#95a5a6}.solution-body{padding:0 2rem 2rem}.answer-summary{background:var(--bg-primary);padding:1.5rem;border-radius:12px;margin-bottom:2rem}.btn-hint-toggle{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:#9b7dd41a;border:1px solid var(--accent-primary);border-radius:100px;color:var(--accent-primary);font-weight:700;cursor:pointer;transition:all .2s;margin:1rem 0}.btn-hint-toggle:hover{background:var(--accent-primary);color:#fff}.hint-content{background:var(--bg-primary);padding:2rem;border-radius:16px;border:1px dashed var(--accent-primary);margin-top:1.5rem;animation:slideDown .3s ease-out}.hint-content p{margin-bottom:1rem;line-height:1.7}.hint-content ul{list-style:none;padding:0;margin-top:1.5rem}.hint-content li{padding:.75rem 0 .75rem 2rem;position:relative;border-top:1px solid var(--border-color)}.hint-content li:before{content:"⚡";position:absolute;left:0}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:3000}.modal{background:var(--bg-secondary);padding:3rem;border-radius:32px;max-width:500px;width:90%;border:1px solid var(--border-color);text-align:center}.modal h3{font-size:2rem;margin-bottom:1rem}.modal input{width:100%;padding:1rem 1.5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1.5rem;color:var(--text-primary);font-size:1.1rem}@media(max-width:992px){.included-list{grid-template-columns:1fr}.pricing-card{padding:3rem 2rem}}@media(max-width:768px){.page-header h1{font-size:2.5rem}.price-tag-large{font-size:3.5rem}.locked-content h2{font-size:2rem}.progress-header{flex-direction:column;gap:2rem;text-align:center}.filter-group{min-width:100%}}.notes-page{min-height:100vh;padding-top:var(--navbar-height);background-color:var(--bg-primary);position:relative;overflow-x:hidden;transition:background-color var(--transition-base)}.notes-page.quiz-mode{padding-top:0}.notes-page .container{max-width:1200px;margin:0 auto;padding:0 1.5rem;position:relative;z-index:2}.page-header{text-align:center;padding:4rem 0 3rem}.page-header h1{font-size:clamp(2.5rem,6vw,4rem);margin-bottom:1rem;color:var(--text-primary)}.page-header p{font-size:1.15rem;color:var(--text-secondary);font-style:italic}.config-container{max-width:700px;margin:0 auto;padding-bottom:4rem}.config-section{padding:2.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:24px;margin-bottom:2rem}.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.section-icon{font-size:1.5rem;color:var(--accent-gold)}.config-section h3{font-size:1.5rem;color:var(--text-primary);margin:0}.upload-zone{border:2px dashed var(--border-color);border-radius:20px;padding:4rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--bg-primary)}.upload-zone:hover{border-color:var(--accent-primary);background:#9b7dd40d;transform:translateY(-4px)}.upload-icon{font-size:3rem;margin-bottom:1.5rem;color:var(--accent-primary)}.upload-text{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.upload-hint{font-size:.9rem;color:var(--text-secondary)}.notes-textarea{width:100%;padding:1.5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;font-family:var(--font-body);font-size:1.1rem;color:var(--text-primary);resize:vertical;min-height:180px;outline:none;transition:border-color var(--transition-fast)}.notes-textarea:focus{border-color:var(--accent-primary)}.option-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.option-btn{padding:1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;font-family:var(--font-mono);font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all var(--transition-fast)}.option-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.option-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 8px 16px var(--shadow-color)}.loading-container{max-width:600px;margin:0 auto;text-align:center;padding:8rem 2rem}.loading-spinner{width:80px;height:80px;border:4px solid var(--bg-secondary);border-top:4px solid var(--accent-primary);border-radius:50%;margin:0 auto 3rem;animation:spin 1s linear infinite}.progress-bar-container{width:100%;height:6px;background:var(--bg-secondary);border-radius:100px;margin:2rem 0 1rem;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-gold));width:100%;animation:progressFlow 10s ease-in-out infinite}.loading-subtext{font-style:italic;color:var(--text-secondary);font-size:1rem}@keyframes progressFlow{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}@keyframes spin{to{transform:rotate(360deg)}}.result-container{max-width:900px;margin:0 auto;padding-bottom:6rem}.result-header{text-align:center;margin-bottom:4rem}.result-header h1{font-size:3rem;margin-bottom:.5rem}.score-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem}.score-card.main-score{background:var(--bg-secondary);padding:3rem;border-radius:32px;text-align:center;border:1px solid var(--border-color)}.score-circle{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:1rem}.score-number{font-size:5rem;font-weight:800;color:var(--accent-primary);line-height:1}.score-total{font-size:2rem;color:var(--text-secondary)}.score-label{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.quick-stats{display:flex;flex-direction:column;gap:1rem}.stat-box{background:var(--bg-secondary);padding:1.5rem;border-radius:20px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border-color)}.stat-val{font-size:2rem;font-weight:800}.stat-name{color:var(--text-secondary);text-transform:uppercase;font-size:.8rem;letter-spacing:.1em}.analysis-breakdown{margin-bottom:4rem}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.insight-card{background:#9b7dd40d;padding:1.5rem;border-radius:16px;display:flex;align-items:center;gap:1rem;border:1px solid rgba(155,125,212,.1)}.insight-icon{font-size:1.5rem}.solutions-section h3{margin-bottom:2rem;font-size:1.75rem}.solution-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;margin-bottom:1.5rem;overflow:hidden;transition:all var(--transition-base)}.solution-card.correct{border-left:6px solid #4CAF50}.solution-card.incorrect{border-left:6px solid #FF5252}.solution-card.unattempted{border-left:6px solid #9E9E9E}.solution-header{padding:1.5rem 2rem;display:flex;align-items:center;gap:1.5rem;cursor:pointer}.solution-status{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900}.correct .solution-status{background:#4caf50;color:#fff}.incorrect .solution-status{background:#ff5252;color:#fff}.unattempted .solution-status{background:#9e9e9e;color:#fff}.solution-info{flex:1}.solution-meta{display:flex;gap:.5rem;margin-bottom:.5rem}.tag-pill{font-size:.65rem;padding:.2rem .6rem;border-radius:100px;text-transform:uppercase;font-weight:700}.source-tag{background:var(--bg-primary);color:var(--accent-gold)}.diff-tag{background:var(--bg-primary);color:var(--text-secondary)}.rel-tag{background:var(--accent-primary);color:#fff}.solution-q-text{font-weight:500;color:var(--text-primary)}.solution-toggle{font-size:.8rem;color:var(--accent-primary);font-weight:600}.solution-body{padding:2rem;background:var(--bg-primary);border-top:1px solid var(--border-color)}.q-content-box{margin-bottom:2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px}.option-review{padding:1rem 1.5rem;border:1px solid var(--border-color);border-radius:12px;margin-bottom:.75rem;position:relative;display:flex;justify-content:space-between;align-items:center}.correct-option{background:#4caf501a;border-color:#4caf50}.wrong-option{background:#ff52521a;border-color:#ff5252}.selection-badge,.correct-badge{font-size:.6rem;text-transform:uppercase;font-weight:800;padding:.2rem .5rem;border-radius:4px}.selection-badge{background:#ff5252;color:#fff}.correct-badge{background:#4caf50;color:#fff}.answer-summary{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin:2rem 0}.answer-item{padding:1.5rem;border-radius:16px;display:flex;flex-direction:column;gap:.5rem}.answer-item span{font-size:.8rem;color:var(--text-secondary)}.answer-item strong{font-size:1.5rem}.answer-item.correct{background:#4caf500d;color:#4caf50}.answer-item.incorrect{background:#ff52520d;color:#ff5252}.solution-explanation{background:var(--bg-secondary);padding:2rem;border-radius:20px}.explanation-header{font-weight:800;margin-bottom:1rem;color:var(--accent-gold)}.result-actions{display:flex;justify-content:center;gap:1.5rem}@media(max-width:768px){.score-summary-grid,.answer-summary{grid-template-columns:1fr}}:root{--cat-blue: #4a86e8;--cat-blue-dark: #3c6dbb;--cat-red: #ff0000;--cat-bg: #f5f7f9;--cat-border: #d1d9e0;--cat-status-answered: #28a745;--cat-status-not-answered: #dc3545;--cat-status-not-visited: #7e8c9a;--cat-status-marked: #6f42c1}.cat-quiz-container{display:flex!important;flex-direction:column!important;height:100vh!important;background-color:var(--cat-bg)!important;color:#333!important;font-family:Inter,system-ui,-apple-system,sans-serif!important;position:fixed!important;inset:0!important;z-index:1000!important}.cat-header{height:45px!important;background-color:var(--cat-blue)!important;display:flex!important;justify-content:space-between!important;align-items:center!important;padding:0 10px!important;flex-shrink:0!important}.cat-section-tabs{display:flex!important;height:100%!important}.section-tab{background:#1a4d8c!important;color:#fff!important;border:none!important;padding:0 25px!important;font-weight:600!important;font-size:.9rem!important;cursor:pointer!important;height:35px!important;align-self:center!important;border-radius:4px!important;margin-left:5px!important}.cat-timer{background:#fff!important;padding:5px 15px!important;border-radius:4px!important;display:flex!important;align-items:center!important;gap:10px!important;height:35px!important}.timer-label{color:#555!important;font-size:.9rem!important}.timer-value{color:#c00!important;font-weight:700!important;font-size:1.2rem!important;font-family:monospace!important}.timer-value.warning{animation:cat-pulse 1s infinite!important}.cat-question-info{background-color:#e8f1f8!important;border-bottom:1px solid var(--cat-border)!important;padding:8px 20px!important;display:flex!important;gap:30px!important;flex-shrink:0!important}.question-type,.question-marks{color:var(--cat-red)!important;font-weight:600!important;font-size:.85rem!important}.cat-body{display:grid!important;grid-template-columns:1fr 300px!important;flex:1!important;overflow:hidden!important}.cat-question-panel{background:#fff!important;display:flex!important;flex-direction:column!important;overflow-y:auto!important;border-right:1px solid var(--cat-border)!important;padding:25px!important}.question-number{font-size:1.1rem!important;font-weight:700!important;margin-bottom:20px!important;color:#222!important}.question-text{font-size:1.05rem!important;line-height:1.6!important;margin-bottom:25px!important;padding:20px!important;border:1px solid #eee!important;background:#fafafa!important;border-radius:6px!important;white-space:pre-wrap!important}.question-header-row{display:flex!important;justify-content:space-between!important;align-items:center!important;margin-bottom:20px!important}.question-actions{display:flex!important;align-items:center!important;gap:15px!important}.bookmark-btn{background:none!important;border:1px solid var(--cat-border)!important;padding:5px 12px!important;border-radius:4px!important;font-size:.85rem!important;font-weight:600!important;color:#666!important;cursor:pointer!important;transition:all .2s!important}.bookmark-btn:hover{background-color:#f8f9fa!important;border-color:var(--cat-blue)!important;color:var(--cat-blue)!important}.bookmark-btn.active{background-color:#fff9e6!important;border-color:#f39c12!important;color:#f39c12!important}.question-counter{font-family:monospace!important;font-weight:700!important;background:#eee!important;padding:2px 8px!important;border-radius:4px!important;font-size:.9rem!important}.options-list{display:flex!important;flex-direction:column!important;gap:12px!important}.quiz-option{display:flex!important;align-items:center!important;padding:12px 15px!important;border:1px solid #e0e0e0!important;border-radius:6px!important;background:#fff!important;cursor:pointer!important;transition:all .2s!important;text-align:left!important;width:100%!important}.quiz-option:hover{background-color:#f0f7ff!important;border-color:#bed6f3!important}.quiz-option.selected{background-color:#eaf1fb!important;border-color:var(--cat-blue)!important;position:relative!important;padding-left:20px!important}.quiz-option.selected:before{content:""!important;position:absolute!important;left:0!important;top:0!important;bottom:0!important;width:5px!important;background:var(--cat-blue)!important;border-radius:6px 0 0 6px!important}.option-radio{margin-right:15px!important;font-size:1.2rem!important;color:var(--cat-blue)!important}.option-text{font-size:1rem!important;color:#444!important}.tita-section{max-width:400px!important}.tita-input-display{height:50px!important;border:2px solid var(--cat-blue)!important;background:#fff!important;display:flex!important;align-items:center!important;padding:0 15px!important;font-size:1.5rem!important;font-weight:600!important;margin-bottom:20px!important;border-radius:4px!important}.tita-cursor{color:var(--cat-blue)!important;animation:cat-blink 1s infinite!important}.number-pad{display:flex!important;flex-direction:column!important;gap:5px!important}.numpad-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:5px!important}.numpad-btn{height:45px!important;background:#fff!important;border:1px solid #ccc!important;border-radius:4px!important;font-size:1.1rem!important;font-weight:600!important;cursor:pointer!important;transition:background .2s!important}.numpad-btn:hover{background:#f0f0f0!important}.numpad-btn.backspace,.numpad-btn.clear-all{width:100%!important}.cat-controls{margin-top:auto!important;padding-top:30px!important;display:flex!important;justify-content:space-between!important;border-top:1px solid #eee!important}.controls-left,.controls-right{display:flex!important;gap:15px!important;flex:1!important}.controls-center{display:flex!important;gap:15px!important;justify-content:center!important;flex:2!important}.controls-right{justify-content:flex-end!important}.cat-btn{padding:10px 20px!important;border-radius:4px!important;font-weight:600!important;font-size:.9rem!important;cursor:pointer!important;transition:all .2s!important;border:1px solid transparent!important}.cat-btn.mark-review{background-color:#5b6e84!important;color:#fff!important}.cat-btn.clear{background-color:#e9ecef!important;color:#343a40!important;border-color:#ced4da!important}.cat-btn.save-next{background-color:var(--cat-blue)!important;color:#fff!important}.cat-btn:hover:not(:disabled){filter:brightness(.9)!important}.cat-btn.prev{background-color:#f8f9fa!important;color:#333!important;border:1px solid #ccc!important}.cat-btn:disabled{opacity:.5!important;cursor:not-allowed!important}.cat-sidebar{background-color:#f0f4f8!important;display:flex!important;flex-direction:column!important;padding:0!important;border-left:1px solid var(--cat-border)!important}.cat-stats-legend{display:grid!important;grid-template-columns:1fr 1fr!important;gap:8px!important;padding:15px!important;background:#fff!important;border-bottom:1px solid var(--cat-border)!important}.cat-legend{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;padding:15px!important;background:#fff!important;border-top:1px solid var(--cat-border)!important;border-bottom:1px solid var(--cat-border)!important;margin-top:auto!important}.legend-item{display:flex!important;align-items:center!important;gap:10px!important;font-size:.8rem!important;color:#444!important}.legend-box{width:22px!important;height:22px!important;border-radius:2px!important;border:1px solid #ddd!important}.legend-box.answered{background-color:var(--cat-status-answered)!important}.legend-box.not-answered{background-color:var(--cat-status-not-answered)!important;border-radius:0 0 8px 8px!important}.legend-box.not-visited{background-color:#fff!important;border:1px solid #ccc!important}.legend-box.marked{background-color:var(--cat-status-marked)!important;border-radius:50%!important}.legend-box.answered-marked{background-color:var(--cat-status-answered)!important;position:relative!important}.legend-box.answered-marked:after{content:""!important;position:absolute!important;width:8px!important;height:8px!important;background:var(--cat-status-marked)!important;border-radius:50%!important;top:-3px!important;right:-3px!important;border:1px solid white!important}.cat-section-header{background-color:var(--cat-blue)!important;color:#fff!important;padding:8px 15px!important;font-weight:600!important;font-size:.9rem!important}.cat-nav-title{padding:10px 15px!important;font-weight:700!important;font-size:.85rem!important;color:#444!important}.cat-question-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:10px!important;padding:0 15px 15px!important;overflow-y:auto!important}.grid-btn{width:100%!important;aspect-ratio:1!important;display:flex!important;align-items:center!important;justify-content:center!important;background:#fff!important;border:1px solid #ccc!important;border-radius:2px!important;font-weight:600!important;cursor:pointer!important;font-size:.9rem!important;position:relative!important}.grid-btn.current{box-shadow:0 0 0 2px var(--cat-blue) inset!important}.grid-btn.answered{background-color:var(--cat-status-answered)!important;color:#fff!important;border-color:var(--cat-status-answered)!important}.grid-btn.not-answered{background-color:var(--cat-status-not-answered)!important;color:#fff!important;border-color:var(--cat-status-not-answered)!important;border-radius:0 0 10px 10px!important}.grid-btn.marked{background-color:var(--cat-status-marked)!important;color:#fff!important;border-color:var(--cat-status-marked)!important;border-radius:50%!important}.grid-btn.answered-marked{background-color:var(--cat-status-answered)!important;color:#fff!important;border-color:var(--cat-status-answered)!important}.grid-btn.answered-marked:after{content:""!important;position:absolute!important;width:10px!important;height:10px!important;background:var(--cat-status-marked)!important;border-radius:50%!important;top:-4px!important;right:-4px!important;border:1px solid white!important}.cat-submit-btn{margin:auto 15px 15px!important;padding:12px!important;background-color:var(--cat-blue)!important;color:#fff!important;border:none!important;border-radius:4px!important;font-weight:700!important;cursor:pointer!important;transition:background .2s!important}.cat-submit-btn:hover{background-color:var(--cat-blue-dark)!important}.modal-overlay{position:fixed!important;inset:0!important;background:#0009!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:2000!important;-webkit-backdrop-filter:blur(4px)!important;backdrop-filter:blur(4px)!important}.modal-content{background:#fff!important;padding:30px!important;border-radius:12px!important;width:90%!important;max-width:450px!important;box-shadow:0 20px 40px #0003!important}.modal-content h3{margin-top:0!important;font-size:1.5rem!important;color:#222!important}.modal-stats{background:#f8f9fa!important;padding:20px!important;border-radius:8px!important;margin:20px 0!important}.modal-stats p{margin:8px 0!important;display:flex!important;justify-content:space-between!important}.modal-warning{color:#dc3545!important;font-size:.9rem!important;font-weight:600!important}.modal-actions{display:flex!important;gap:15px!important;margin-top:25px!important}.modal-btn{flex:1!important;padding:12px!important;border-radius:6px!important;font-weight:700!important;cursor:pointer!important;border:none!important}.modal-btn.cancel{background:#e9ecef!important;color:#495057!important}.modal-btn.confirm{background:var(--cat-blue)!important;color:#fff!important}@keyframes cat-pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}@keyframes cat-blink{50%{opacity:0}}.cat-quiz-wrapper{position:fixed;inset:0;z-index:2000;display:flex;flex-direction:column;background:#e8eaef;font-family:Segoe UI,system-ui,-apple-system,sans-serif;color:#222}.cat-top-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#4a86e8;color:#fff;flex-shrink:0}.header-section{display:flex;align-items:center;gap:1rem}.header-section.left{flex:1}.header-section.center{flex:2;justify-content:flex-end}.header-section.right{flex:1;justify-content:flex-end}.section-label{font-weight:500;font-size:.95rem}.cat-timer-box{display:flex!important;align-items:center!important;justify-content:center!important;gap:10px!important;background:#ffffff26!important;padding:5px 15px!important;border-radius:6px!important;font-size:1.1rem!important;white-space:nowrap!important;position:relative!important;min-width:max-content!important}.cat-timer-box span{position:static!important;display:inline-block!important;margin:0!important;padding:0!important;line-height:1!important}.cat-timer-box .timer-text{opacity:.8!important;font-weight:500!important}.cat-timer-box .timer-digits{font-weight:800!important;font-family:JetBrains Mono,Courier New,monospace!important;color:#fff!important}.cat-timer-box.warning{background:#ffc1074d}.cat-timer-box.critical{background:#dc354566;animation:pulse-warn 1s infinite}@keyframes pulse-warn{0%,to{opacity:1}50%{opacity:.7}}.cat-tool-btn{background:#fff3;border:none;padding:.4rem .8rem;border-radius:4px;color:#fff;font-size:1.2rem;cursor:pointer;transition:background .2s}.cat-tool-btn:hover{background:#ffffff4d}.cat-exit-btn{background:#dc3545;border:none;padding:.4rem 1rem;border-radius:4px;color:#fff;font-weight:600;cursor:pointer;transition:background .2s}.cat-exit-btn:hover{background:#c82333}.cat-type-bar{background:#f5f5f5;border-bottom:1px solid #ddd;padding:.5rem 1.5rem;font-size:.9rem}.type-info .positive{color:#28a745;font-weight:600}.type-info .negative{color:#dc3545;font-weight:600}.cat-main-layout{display:flex;flex:1;overflow:hidden}.cat-question-area{flex:1;display:flex;flex-direction:column;background:#fff;overflow:hidden}.question-scroll-container{flex:1;overflow-y:auto;padding:2rem 3rem}.cat-q-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #eee}.q-number{font-size:1.2rem;font-weight:700;color:#333;margin:0}.action-btn.bookmark{background:none;border:1px solid #666;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem;color:#666;transition:all .2s}.action-btn.bookmark.active{background:#ffc107;border-color:#ffc107;color:#333}.cat-question-text{font-size:1.15rem;line-height:1.8;color:#222;margin-bottom:2rem}.cat-question-text p{margin:0}.cat-options{display:flex;flex-direction:column;gap:.75rem}.cat-option{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;background:#fafafa;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease}.cat-option:hover{background:#f0f8ff;border-color:#4a86e8}.cat-option.selected{background:#e3f2fd;border-color:#4a86e8}.cat-option input[type=radio]{display:none}.option-letter{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#4a86e8;color:#fff;font-weight:700;font-size:.85rem;border-radius:50%;flex-shrink:0}.option-content{font-size:1.05rem;line-height:1.6;color:#333;padding-top:2px}.cat-tita-section{max-width:300px}.tita-input-box input{width:100%;padding:.75rem 1rem;font-size:1.2rem;border:2px solid #ccc;border-radius:4px;background:#fff;margin-bottom:1rem}.cat-numpad{display:flex;flex-direction:column;gap:.5rem}.np-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}.np-btn{padding:.6rem .8rem;font-size:1rem;border:1px solid #ccc;background:#f8f8f8;border-radius:3px;cursor:pointer;transition:all .15s}.np-btn:hover{background:#e8e8e8}.np-btn.fn{background:#eee;font-size:.85rem}.np-btn.fn.clear{background:#ffecec;color:#c00}.cat-bottom-controls{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#f5f5f5;border-top:1px solid #ddd;flex-shrink:0;gap:1rem}.controls-left,.controls-right{display:flex;gap:.75rem}.cat-ctrl-btn{padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;border:1px solid #aaa;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s}.cat-ctrl-btn:hover:not(:disabled){background:#f0f0f0}.cat-ctrl-btn:disabled{opacity:.5;cursor:not-allowed}.cat-ctrl-btn.mark{background:#f0f4ff;border-color:#4a86e8;color:#4a86e8}.cat-ctrl-btn.mark.active{background:#4a86e8;color:#fff}.cat-ctrl-btn.clear{background:#fff}.cat-ctrl-btn.primary{background:#4a86e8;border-color:#4a86e8;color:#fff}.cat-ctrl-btn.primary:hover{background:#3a76d8}.cat-sidebar-panel{width:280px;background:#f7f9fc;border-left:1px solid #ddd;display:flex;flex-direction:column;flex-shrink:0}.sidebar-scroll{flex:1;overflow-y:auto;padding:1rem}.panel-header{font-size:1rem;font-weight:700;color:#333;padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:2px solid #4a86e8}.palette-stats{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.ps-item{font-size:.75rem;padding:.25rem .5rem;border-radius:3px;font-weight:600}.ps-item.answered{background:#d4edda;color:#155724}.ps-item.not-answered{background:#f8d7da;color:#721c24}.ps-item.marked{background:#e2d4f0;color:#6f42c1}.question-palette{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:1.5rem}.palette-btn{width:100%;aspect-ratio:1;border:1px solid #ccc;border-radius:4px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;background:#fff;color:#333}.palette-btn.current{box-shadow:0 0 0 3px #4a86e8}.palette-btn.answered{background:#28a745;border-color:#28a745;color:#fff}.palette-btn.not-answered{background:#dc3545;border-color:#dc3545;color:#fff}.palette-btn.not-visited{background:#e9ecef;border-color:#ced4da;color:#495057}.palette-btn.marked{background:#6f42c1;border-color:#6f42c1;color:#fff}.palette-btn.answered-marked{background:linear-gradient(135deg,#28a745 50%,#6f42c1 50%);border-color:#28a745;color:#fff}.palette-legend{display:flex;flex-direction:column;gap:.4rem;font-size:.8rem;color:#555}.legend-item{display:flex;align-items:center;gap:.5rem}.lg-box{width:16px;height:16px;border-radius:3px;border:1px solid #ccc}.lg-box.answered{background:#28a745;border-color:#28a745}.lg-box.not-answered{background:#dc3545;border-color:#dc3545}.lg-box.not-visited{background:#e9ecef}.lg-box.marked{background:#6f42c1;border-color:#6f42c1}.lg-box.answered-marked{background:linear-gradient(135deg,#28a745 50%,#6f42c1 50%)}.cat-submit-test{margin:1rem;padding:.75rem;background:#4a86e8;border:none;border-radius:6px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s}.cat-submit-test:hover{background:#3a76d8}.calc-modal{position:fixed;top:50px;right:50px;z-index:3000}.calc-container{background:#f0f0f0;border:1px solid #999;border-radius:8px;box-shadow:0 8px 32px #0000004d;overflow:hidden;width:260px}.calc-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#4a86e8;color:#fff;font-weight:600}.calc-close{background:none;border:none;color:#fff;font-size:1rem;cursor:pointer;padding:.25rem}.calc-display{background:#fff;padding:.5rem .75rem;text-align:right;border-bottom:1px solid #ccc}.calc-expression{min-height:1rem;font-size:.85rem;color:#666}.calc-result{font-size:1.5rem;font-weight:700;color:#222;font-family:monospace}.calc-buttons{padding:.5rem}.calc-row{display:flex;gap:4px;margin-bottom:4px}.calc-row.memory button{flex:1;padding:.35rem;font-size:.75rem;background:#e8e8e8;border:1px solid #ccc;border-radius:3px;cursor:pointer}.calc-row button{flex:1;padding:.5rem;font-size:.95rem;background:#f8f8f8;border:1px solid #ccc;border-radius:3px;cursor:pointer;transition:background .15s}.calc-row button:hover{background:#e0e0e0}.calc-row button.fn-btn{background:#e8e8e8}.calc-row button.fn-btn.red{background:#fcc;color:#c00}.calc-row button.fn-btn.green{background:#28a745;color:#fff}.calc-row button.equals{grid-row:span 2}.cat-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:4000}.cat-modal{background:#fff;border-radius:12px;padding:2rem;max-width:400px;width:90%;box-shadow:0 16px 48px #0000004d}.cat-modal h3{margin:0 0 1rem;font-size:1.4rem;color:#222}.cat-modal p{color:#555;line-height:1.6}.modal-summary{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1rem}.modal-summary p{margin:.3rem 0;color:#333}.modal-summary .good{color:#28a745;font-weight:700}.modal-summary .warn{color:#dc3545;font-weight:700}.warning-text{color:#dc3545;font-weight:600;margin:1rem 0}.modal-btns{display:flex;gap:1rem;margin-top:1.5rem}.modal-btn{flex:1;padding:.75rem 1rem;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.modal-btn.cancel{background:#e9ecef;color:#495057}.modal-btn.cancel:hover{background:#dee2e6}.modal-btn.submit{background:#28a745;color:#fff}.modal-btn.submit:hover{background:#218838}.modal-btn.exit{background:#dc3545;color:#fff}.modal-btn.exit:hover{background:#c82333}@media(max-width:900px){.cat-main-layout{flex-direction:column}.cat-sidebar-panel{width:100%;max-height:40vh;border-left:none;border-top:1px solid #ddd}.question-palette{grid-template-columns:repeat(8,1fr)}.question-scroll-container{padding:1.5rem}.cat-bottom-controls{flex-wrap:wrap;padding:1rem}.controls-left,.controls-right{width:100%;justify-content:center}}@media(max-width:600px){.cat-top-header{padding:.4rem .75rem}.question-scroll-container{padding:1rem}.cat-question-text{font-size:1rem}.cat-option{padding:.75rem 1rem}.option-content{font-size:.95rem}.question-palette{grid-template-columns:repeat(6,1fr)}.palette-btn{font-size:.75rem}.cat-ctrl-btn{padding:.5rem .75rem;font-size:.8rem}}.premium-badge{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#9b7dd426,#ffb74d1a);border:1px solid var(--accent-primary);border-radius:16px;margin-bottom:2rem}.premium-badge .badge-icon{font-size:1.5rem}.premium-badge .badge-text{font-size:.95rem;font-weight:600;color:var(--accent-primary);letter-spacing:.02em}.section-header .file-count{margin-left:auto;font-size:.85rem;color:var(--text-secondary);font-family:var(--font-mono)}.upload-buttons-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.upload-method-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.25rem;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all var(--transition-base)}.upload-method-btn:hover:not(:disabled){border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 8px 20px #9b7dd426}.upload-method-btn:disabled{opacity:.5;cursor:not-allowed}.upload-method-btn .btn-icon{font-size:2rem}.upload-method-btn .btn-label{font-size:.9rem;font-weight:600;color:var(--text-primary)}.camera-btn:hover:not(:disabled){border-color:#4caf50;background:#4caf500d}.file-btn:hover:not(:disabled){border-color:var(--accent-primary);background:#9b7dd40d}.upload-zone.disabled{opacity:.6;cursor:not-allowed;border-color:var(--border-color)}.upload-zone.disabled:hover{transform:none;background:var(--bg-primary)}.upload-zone .upload-icon-box{font-size:2.5rem;margin-bottom:1rem}.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:1rem;margin-top:1.5rem}.preview-card{position:relative;aspect-ratio:3/4;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:all var(--transition-fast)}.preview-card:hover{transform:scale(1.02);box-shadow:0 8px 20px var(--shadow-color)}.preview-image{width:100%;height:100%;object-fit:cover}.preview-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary))}.preview-placeholder .pdf-icon{font-size:2.5rem;margin-bottom:.5rem}.preview-placeholder .pdf-label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.preview-overlay{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:linear-gradient(180deg,rgba(0,0,0,.6),transparent)}.preview-overlay .file-num{font-size:.7rem;font-weight:700;color:#fff;background:var(--accent-primary);padding:.2rem .5rem;border-radius:6px}.preview-overlay .remove-btn{width:24px;height:24px;border:none;background:#ff5252e6;color:#fff;border-radius:50%;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);opacity:0}.preview-card:hover .remove-btn{opacity:1}.remove-btn:hover{transform:scale(1.15);background:#ff5252}.preview-filename{position:absolute;bottom:0;left:0;right:0;padding:.5rem;background:linear-gradient(0deg,rgba(0,0,0,.7),transparent);font-size:.65rem;color:#fff;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.premium-loading-indicator{margin-top:2rem}.ai-chip{display:inline-block;padding:.5rem 1rem;background:linear-gradient(135deg,var(--accent-primary),#9c27b0);color:#fff;font-size:.85rem;font-weight:600;border-radius:100px;box-shadow:0 4px 15px #9b7dd466;animation:chip-pulse 2s ease-in-out infinite}@keyframes chip-pulse{0%,to{box-shadow:0 4px 15px #9b7dd466}50%{box-shadow:0 4px 25px #9b7dd4b3}}@media(max-width:600px){.upload-buttons-row{grid-template-columns:1fr 1fr;gap:.75rem}.upload-method-btn{padding:1rem}.upload-method-btn .btn-icon{font-size:1.5rem}.upload-method-btn .btn-label{font-size:.8rem}.image-preview-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}.preview-overlay .remove-btn{opacity:1;width:20px;height:20px}}@media(max-width:480px){.notes-page .container{padding:0 1rem}.page-header{padding:2rem 0 1.5rem}.page-header h1{font-size:2rem;margin-bottom:.5rem}.page-header p{font-size:.9rem;line-height:1.4;padding:0 .5rem}.back-link{font-size:.75rem;margin-bottom:1rem;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:8px}.premium-badge{padding:.75rem 1rem;margin-bottom:1rem;flex-direction:row;gap:.5rem}.premium-badge .badge-icon{font-size:1.2rem}.premium-badge .badge-text{font-size:.8rem}.config-container{padding-bottom:2rem}.config-section{padding:1.25rem;border-radius:16px;margin-bottom:1rem}.section-header{margin-bottom:1rem;gap:.75rem}.section-header .file-count{font-size:.75rem}.config-section h3{font-size:1.1rem}.section-icon{font-size:1.2rem}.option-buttons{grid-template-columns:repeat(2,1fr);gap:.6rem}.option-btn{padding:.75rem .5rem;font-size:.75rem;border-radius:10px;text-align:center}.upload-buttons-row{grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1rem}.upload-method-btn{padding:.75rem;border-radius:12px}.upload-method-btn .btn-icon{font-size:1.25rem}.upload-method-btn .btn-label{font-size:.7rem}.upload-zone{padding:2rem 1rem;border-radius:14px}.upload-zone .upload-icon-box{font-size:2rem;margin-bottom:.75rem}.upload-text{font-size:1rem}.upload-hint{font-size:.75rem}.image-preview-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:1rem}.preview-card{border-radius:8px}.preview-overlay .file-num{font-size:.6rem;padding:.15rem .35rem}.notes-textarea{padding:1rem;font-size:.95rem;min-height:120px;border-radius:12px}.or-divider{font-size:.75rem;margin:1rem 0}.submit-btn,.btn-primary{padding:.875rem 1.5rem;font-size:.9rem;border-radius:12px;width:100%}.loading-container{padding:4rem 1rem}.loading-spinner{width:60px;height:60px;margin-bottom:2rem}.loading-text{font-size:1.1rem}.loading-subtext{font-size:.85rem}.ai-chip{font-size:.75rem;padding:.4rem .8rem}.quiz-container{padding:1rem}.quiz-question{font-size:1rem;padding:1rem}.quiz-option{padding:.75rem;font-size:.9rem}.premium-loading-indicator{margin-top:1.5rem}}@media(max-width:360px){.page-header h1{font-size:1.75rem}.config-section{padding:1rem}.option-buttons{gap:.5rem}.option-btn{padding:.6rem .4rem;font-size:.65rem}.upload-method-btn{padding:.6rem}.upload-method-btn .btn-label{font-size:.65rem}.image-preview-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.cat-quiz-container{height:auto!important;min-height:100vh!important;display:flex!important;flex-direction:column!important}.cat-header{flex-wrap:wrap!important;padding:8px 12px!important;gap:8px!important}.cat-section-tabs{order:1!important}.section-tab{padding:6px 12px!important;font-size:.8rem!important}.cat-timer{order:2!important;padding:6px 12px!important}.timer-label{font-size:.8rem!important}.timer-value{font-size:1.1rem!important}.cat-question-info{flex-direction:column!important;align-items:flex-start!important;gap:4px!important;padding:10px 12px!important}.question-type,.question-marks{font-size:.75rem!important}.cat-body{display:flex!important;flex-direction:column!important;grid-template-columns:unset!important;overflow:visible!important}.cat-question-panel{width:100%!important;border-right:none!important;border-bottom:1px solid var(--cat-border)!important;padding:15px!important;order:1!important;overflow:visible!important}.question-number{font-size:1rem!important;margin-bottom:12px!important}.question-text{font-size:.95rem!important;line-height:1.5!important;padding:12px!important;margin-bottom:15px!important}.options-list{gap:10px!important}.quiz-option{padding:10px 12px!important}.option-radio{margin-right:10px!important;font-size:1rem!important}.option-text{font-size:.9rem!important}.tita-section{max-width:100%!important}.tita-input-display{height:45px!important;font-size:1.2rem!important;margin-bottom:15px!important}.numpad-btn{height:40px!important;font-size:1rem!important}.cat-controls{padding-top:15px!important;flex-wrap:wrap!important;gap:10px!important}.controls-left,.controls-center,.controls-right{flex:unset!important;width:100%!important;justify-content:center!important}.controls-center{order:-1!important}.cat-btn{padding:8px 14px!important;font-size:.8rem!important;flex:1!important;text-align:center!important}.cat-sidebar{width:100%!important;border-left:none!important;border-top:2px solid var(--cat-blue)!important;order:2!important}.cat-stats-legend{grid-template-columns:1fr 1fr!important;gap:6px!important;padding:10px 12px!important}.legend-item{font-size:.7rem!important;gap:6px!important}.legend-box{width:18px!important;height:18px!important}.cat-section-header{padding:6px 12px!important;font-size:.85rem!important}.cat-question-grid{grid-template-columns:repeat(5,1fr)!important;gap:8px!important;padding:10px 12px!important}.grid-btn{font-size:.8rem!important}.cat-submit-section{padding:10px 12px!important}.cat-submit-btn{padding:10px!important;font-size:.9rem!important}.cat-legend{padding:10px 12px!important;gap:6px!important}}@media(max-width:400px){.cat-question-grid{grid-template-columns:repeat(4,1fr)!important}.cat-controls{flex-direction:column!important}.controls-left,.controls-center,.controls-right,.cat-btn{width:100%!important}.question-text{font-size:.9rem!important;padding:10px!important}.option-text{font-size:.85rem!important}}.pattern-page{min-height:100vh;background:var(--bg-primary);padding:3rem 1rem;color:var(--text-primary)}.pattern-page .container{max-width:900px;margin:0 auto}.back-link{color:var(--accent-primary);text-decoration:none;font-weight:600;font-size:.9rem;margin-bottom:1rem;display:block;transition:transform .2s;background:none;border:none;cursor:pointer;padding:0;text-align:left}.back-link:hover{transform:translate(-4px)}.page-header{text-align:center;margin-bottom:3.5rem}.page-header h1{font-size:3.5rem;font-weight:800;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-primary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem;letter-spacing:-2px}.subtitle{color:var(--text-light);font-size:1.25rem;font-weight:500}.start-container{display:grid;grid-template-columns:1.5fr 1fr;gap:2.5rem;animation:slideUp .6s ease-out}.config-card{background:var(--bg-secondary);padding:2.5rem;border-radius:32px;box-shadow:0 20px 40px var(--shadow-color);border:1px solid var(--border-color)}.config-card h2{font-size:1.75rem;margin-bottom:2rem;font-weight:700}.config-section{margin-bottom:2rem}.config-section label{display:block;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-light);margin-bottom:1rem}.selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}.selector-btn{padding:.75rem 1rem;border-radius:12px;border:2px solid var(--border-color);background:var(--bg-secondary);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.95rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.selector-btn span{font-size:.75rem;color:var(--text-light)}.selector-btn:hover{border-color:var(--border-prominent);background:var(--bg-primary)}.selector-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.selector-btn.active span{color:#fffc}.start-btn{width:100%;padding:1.25rem;border-radius:16px;background:var(--accent-primary);color:#fff;font-size:1.1rem;font-weight:700;border:none;cursor:pointer;box-shadow:0 10px 20px var(--shadow-color);transition:all .2s;margin-top:1rem}.start-btn:hover{background:#4f46e5;transform:translateY(-2px);box-shadow:0 12px 24px #6366f14d}.training-info{display:flex;flex-direction:column;gap:1.5rem;justify-content:center}.info-item{display:flex;gap:1.25rem;padding:1.5rem;background:var(--glass-bg);border-radius:20px;border:1px solid var(--border-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.info-item .icon{font-size:1.75rem;display:flex;align-items:center}.info-item h3{font-size:1.1rem;margin-bottom:.25rem;color:var(--text-primary)}.info-item p{font-size:.9rem;color:var(--text-light);line-height:1.5}.game-stage{max-width:700px;margin:0 auto}.game-progress{margin-bottom:2.5rem}.progress-bar{height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;margin-bottom:.75rem}.progress-fill{height:100%;background:var(--accent-primary);transition:width .4s ease}.stats{display:flex;justify-content:space-between;font-weight:700;color:var(--text-light);font-size:.9rem}.timer-display{font-size:5rem;font-weight:900;text-align:center;margin:1.5rem 0;color:var(--accent-primary);font-variant-numeric:tabular-nums;transition:color .3s}.timer-display.urgent{color:#ef4444;animation:pulse 1s infinite}.timer-display.frozen{color:var(--text-light);background:var(--bg-secondary);padding:.5rem 1.5rem;border-radius:99px;display:inline-block;margin:1rem auto;width:fit-content;font-size:3rem}.pattern-stem-card{background:#1e1b4b;color:#fff;padding:3rem;border-radius:32px;text-align:center;margin-bottom:2.5rem;box-shadow:0 30px 60px var(--shadow-color)}.pattern-stem-card p{font-size:1.5rem;font-weight:600;line-height:1.6;font-family:Outfit,sans-serif}.pattern-options{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.pattern-option{padding:1.5rem;border-radius:20px;border:2px solid var(--border-color);background:var(--bg-secondary);font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:1.1rem;display:flex;justify-content:space-between;align-items:center;position:relative;text-align:left}.pattern-option:hover:not(:disabled){border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 10px 20px var(--shadow-color)}.pattern-option.user-correct{background:#f0fdf4;border-color:#22c55e;color:#166534;box-shadow:0 0 0 4px #22c55e1a}.pattern-option.user-wrong{background:#fef2f2;border-color:#ef4444;color:#991b1b;box-shadow:0 0 0 4px #ef44441a}.pattern-option.reveal-correct{background:#f0fdf4;border-color:#22c55e;border-style:dashed;color:#166534}.feedback-icon{font-size:1.4rem;font-weight:900}.feedback-icon.pulse{animation:pulse-sm .5s ease}.feedback-icon.shake{animation:shake-sm .5s ease}@keyframes pulse-sm{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}@keyframes shake-sm{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.feedback-header{margin-bottom:2.5rem}.result{display:flex;gap:1.5rem;padding:2rem;border-radius:24px;align-items:center}.result.correct{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.result.wrong{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.result .icon{width:56px;height:56px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;flex-shrink:0}.comparison-card{background:var(--bg-secondary);padding:2.5rem;border-radius:32px;border:1px solid var(--border-color);box-shadow:0 20px 40px var(--shadow-color)}.comparison-card h4{font-size:.85rem;text-transform:uppercase;letter-spacing:2px;color:var(--text-light);margin-bottom:2rem}.pyq-meta{display:flex;gap:1rem;margin-bottom:1.25rem}.pyq-meta span{padding:.4rem 1rem;background:var(--bg-primary);border-radius:99px;font-size:.8rem;font-weight:700;color:var(--text-light)}.pyq-text p{font-size:1.25rem;line-height:1.7;color:var(--text-primary);font-weight:500;margin-bottom:2.5rem}.reveal-btn{width:100%;padding:1.25rem;background:var(--accent-primary);color:#fff;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s}.reveal-btn:hover{background:#2d2a5d;transform:translateY(-2px)}.solution-content-card{background:var(--bg-secondary);padding:3rem;border-radius:40px;border:1px solid var(--border-color);box-shadow:0 40px 80px var(--shadow-color);display:flex;flex-direction:column;gap:2.5rem}.result-mini{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.mini-badge{padding:.5rem 1rem;border-radius:99px;font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.mini-badge.correct{background:#f0fdf4;color:#166534}.mini-badge.wrong{background:#fef2f2;color:#991b1b}.pattern-name-label{color:var(--text-light);font-size:.9rem}.pattern-name-label strong{color:var(--text-primary);margin-left:.5rem}.section-label{font-size:.75rem;font-weight:800;color:#94a3b8;letter-spacing:2px;margin-bottom:1.25rem}.formula-box{background:var(--bg-primary);padding:2.5rem;border-radius:24px;border:1px dashed var(--border-prominent);text-align:center}.formula-box code{font-size:1.6rem;font-weight:700;color:var(--accent-primary);font-family:JetBrains Mono,monospace;display:block}.solution-steps{display:flex;flex-direction:column;gap:1.25rem}.solution-step{display:flex;gap:1.25rem;align-items:flex-start}.step-number{width:28px;height:28px;background:var(--accent-primary);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex-shrink:0;margin-top:.2rem}.solution-step p{color:var(--text-secondary);font-size:1.05rem;line-height:1.6;margin:0}.next-btn{width:100%;padding:1.25rem;background:var(--accent-primary);color:#fff;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s}.next-btn:hover{background:var(--accent-primary);filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 10px 20px var(--shadow-color)}.done-container{padding:4rem 1rem}.results-card{background:var(--bg-secondary);padding:4rem;border-radius:48px;text-align:center;box-shadow:0 40px 80px var(--shadow-color)}.ready-brand-mark{width:2px;height:32px;background:var(--accent-primary);margin:0 auto 1.5rem;box-shadow:0 0 15px var(--accent-primary)}.big-score{font-size:6rem;font-weight:900;color:var(--accent-primary)}.score-circle .total{font-size:2rem;color:var(--text-light);font-weight:600}.score-summary p{font-size:1.25rem;color:var(--text-light);margin:1.5rem 0 3rem}.history-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1.5rem}.history-dot{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem}.history-dot.correct{background:#f0fdf4;color:#166534}.history-dot.wrong{background:#fef2f2;color:#991b1b}.action-buttons{display:flex;flex-direction:column;gap:1rem;margin-top:4rem;max-width:300px;margin-left:auto;margin-right:auto}.retry-btn{padding:1.25rem;background:var(--accent-primary);color:#fff;border:none;border-radius:16px;font-weight:700;cursor:pointer}.home-link{color:var(--text-light);text-decoration:none;font-weight:600;font-size:.95rem}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.animate-in{animation:slideUp .5s ease-out}@media(max-width:768px){.start-container{grid-template-columns:1fr}.page-header h1{font-size:2.5rem}.pattern-options{grid-template-columns:1fr}.pattern-stem-card{padding:2rem}.pattern-stem-card p{font-size:1.25rem}}.solution-content-card{background:var(--bg-secondary);padding:3rem;border-radius:40px;border:1px solid var(--border-color);box-shadow:0 40px 80px var(--shadow-color);display:flex;flex-direction:column;gap:2.5rem;max-width:1000px!important;margin:0 auto}.comparison-layout{display:flex;flex-direction:column;gap:2rem}.panels-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.signature-panel,.application-panel{background:var(--bg-primary);padding:2rem;border-radius:24px;border:1px solid var(--border-color);text-align:left}.signature-panel h4,.application-panel h4{font-size:.75rem;text-transform:uppercase;letter-spacing:2px;color:var(--text-light);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.stem-text,.pyq-text-small{font-size:1.1rem;line-height:1.6;color:var(--text-primary);margin-bottom:1.5rem}.trigger-highlight{background:#6366f126;border-bottom:2px solid var(--accent-primary);padding:0 2px;font-weight:600;color:var(--accent-primary)}.trigger-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.trigger-tag{padding:.3rem .8rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:.75rem;font-weight:700;color:var(--accent-primary)}.approach-section{display:grid;grid-template-columns:1fr;gap:1.5rem}.approach-card{background:var(--glass-bg);padding:2rem;border-radius:24px;border:2px solid var(--accent-primary);text-align:left}.approach-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:2rem}.approach-main h5,.approach-side h5{font-size:.8rem;font-weight:800;margin-bottom:1rem;color:var(--text-light)}.approach-text{font-size:1.2rem;font-weight:600;line-height:1.5;margin-bottom:1.5rem;color:var(--text-primary)}.formula-display{background:var(--bg-primary);padding:1.5rem;border-radius:16px;font-family:JetBrains Mono,monospace;font-size:1.25rem;color:var(--accent-primary);text-align:center;border:1px dashed var(--accent-primary)}.trap-callout,.memory-callout{padding:1.25rem;border-radius:16px;margin-bottom:1rem}.trap-callout{background:#fef2f2;border-left:4px solid #ef4444;color:#991b1b}.memory-callout{background:#f0f9ff;border-left:4px solid #0ea5e9;color:#0c4a6e}.trap-callout span,.memory-callout span{display:block;font-size:.7rem;font-weight:800;text-transform:uppercase;margin-bottom:.4rem}.solution-collapsible{border-top:1px solid var(--border-color);padding-top:1.5rem}.collapsible-trigger{width:100%;background:none;border:none;color:var(--text-light);font-weight:600;cursor:pointer;display:flex;justify-content:center;align-items:center;gap:.5rem;padding:1rem;transition:color .2s}.collapsible-trigger:hover{color:var(--accent-primary)}.variant-stage{text-align:center;max-width:600px;margin:0 auto}.variant-header{margin-bottom:3rem}.variant-header .badge{display:inline-block;padding:.4rem 1rem;background:#6366f11a;color:var(--accent-primary);border-radius:99px;font-size:.8rem;font-weight:800;letter-spacing:1px;margin-bottom:1rem}.variant-header h2{font-size:2.5rem;font-weight:800;margin-bottom:1rem}.variant-card{background:var(--bg-secondary);padding:3rem;border-radius:32px;border:2px solid var(--accent-primary);margin-top:2rem;box-shadow:0 20px 40px var(--shadow-color)}.variant-question{font-size:1.4rem;font-weight:600;line-height:1.6;margin-bottom:2.5rem}.variant-actions{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.performance-analysis{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem;text-align:left}.analysis-card{background:var(--bg-primary);padding:2rem;border-radius:24px;border:1px solid var(--border-color)}.analysis-card h3{font-size:.9rem;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:1px;margin-bottom:1.5rem}.speed-metric{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.metric-label{font-weight:600}.speed-tag{padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:700}.speed-tag.fast{background:#dcfce7;color:#166534}.speed-tag.slow{background:#fee2e2;color:#991b1b}.weak-list{display:flex;flex-direction:column;gap:.75rem}.weak-item{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary)}.weak-item .icon{color:#ef4444}@media(max-width:768px){.panels-grid,.approach-grid,.performance-analysis{grid-template-columns:1fr}}.arcade-page{min-height:100vh;padding:calc(var(--navbar-height) + 4rem) 0 4rem;background-color:var(--bg-primary);position:relative;overflow:hidden;transition:background-color var(--transition-base)}.arcade-container{max-width:900px;margin:0 auto;padding:0 1.5rem}.arcade-header{text-align:center;margin-bottom:5rem}.back-link{display:inline-flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:2rem;transition:all var(--transition-fast)}.back-link:hover{color:var(--accent-primary);transform:translate(-5px)}.arcade-title{font-size:clamp(2.5rem,6vw,4rem);margin-bottom:1rem;color:var(--text-primary)}.arcade-subtitle{font-size:1.1rem;color:var(--text-secondary);font-style:italic;font-family:var(--font-body)}.battle-modes{margin-bottom:4rem}.section-label{display:flex;align-items:center;gap:.75rem;font-family:var(--font-mono);font-size:.9rem;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.2em;margin-bottom:2rem}.mode-cards{display:flex;flex-direction:column;gap:1.5rem}.mode-card{display:flex;align-items:center;gap:2rem;padding:2rem;border-radius:24px}.mode-icon-wrapper{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--accent-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.mode-info{flex:1}.mode-title-row{display:flex;align-items:center;gap:1.25rem;margin-bottom:.5rem}.mode-title{font-size:1.5rem;font-family:var(--font-display);color:var(--text-primary);margin:0}.mode-badge{font-family:var(--font-mono);font-size:.7rem;padding:.3rem .8rem;border-radius:100px;text-transform:uppercase;border:1px solid var(--accent-success);color:var(--accent-success);background:#3d8b6e1a}.mode-desc{font-size:1rem;color:var(--text-secondary)}.play-btn{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;border-radius:100px;background:var(--accent-primary);color:#fff;font-weight:700;text-decoration:none;transition:all var(--transition-base)}.play-btn:hover{background:var(--accent-gold);transform:translateY(-2px);box-shadow:0 10px 20px var(--shadow-color)}.arcade-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.stat-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;border-radius:20px}.stat-icon-wrapper{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--accent-gold);border:1px solid var(--border-color)}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-family:var(--font-display);font-weight:700;color:var(--text-primary)}.stat-label{font-size:.75rem;font-family:var(--font-mono);text-transform:uppercase;color:var(--text-secondary);letter-spacing:.1em}@media(max-width:768px){.mode-card{flex-direction:column;text-align:center;gap:1.5rem}.stat-card{flex-direction:column;text-align:center;padding:2rem 1rem}.arcade-stats{grid-template-columns:1fr}.arcade-title{font-size:3rem}}.classic-page{min-height:calc(100vh - var(--navbar-height));padding:calc(var(--navbar-height) + 2rem) 2rem 2rem 2rem;display:flex;justify-content:center;background-color:var(--bg-primary)}.lobby{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1.5rem;padding-top:10vh}.lobby-spinner{width:60px;height:60px;border:4px solid var(--border-color);border-top:4px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.battle-layout{display:grid;grid-template-columns:1fr 320px;gap:2rem;width:100%;max-width:1100px;margin:0 auto}.question-panel{background:transparent;border:none;border-radius:24px;padding:2.5rem;box-shadow:none;display:flex;flex-direction:column;gap:2rem}.question-header{display:flex;justify-content:space-between;align-items:center}.category-badge{background:var(--bg-secondary);color:var(--accent-primary);padding:.5rem 1rem;border-radius:100px;font-size:.875rem;font-weight:600;letter-spacing:.05em}.timer-circle{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.timer-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.timer-bg{fill:none;stroke:var(--border-color);stroke-width:3}.timer-progress{fill:none;stroke-width:4;stroke-linecap:round;transition:stroke-dasharray .3s ease,stroke .3s ease}.timer-text{position:absolute;font-family:var(--font-mono);font-size:1.25rem;font-weight:700}.score-popup{position:absolute;top:-20px;font-weight:700;color:var(--accent-success);animation:fadeUp 1.5s forwards}@keyframes fadeUp{0%{transform:translateY(0);opacity:1}to{transform:translateY(-40px);opacity:0}}.classic-page .question-text{font-family:var(--font-display)!important;font-size:1.5rem!important;line-height:1.5!important;color:var(--text-primary)!important;background:var(--bg-secondary)!important;padding:1.5rem!important;border-radius:12px!important;border:1px solid var(--border-color)!important;margin-bottom:0!important}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.option-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:1.25rem;font-family:var(--font-body);font-size:1.1rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all var(--transition-base);text-align:left;display:flex;align-items:center;justify-content:space-between}.option-btn:hover:not(:disabled){border-color:var(--accent-primary);background:var(--bg-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.option-btn.selected{background:var(--bg-primary);border-color:var(--accent-primary);border-width:2px}.option-btn.correct{background:#3d8b6e1a;border-color:var(--accent-success);color:var(--accent-success);font-weight:600}.option-btn.wrong{background:#ff6b6b1a;border-color:#ff6b6b;color:#ff6b6b}.check-icon{font-weight:700}.question-footer{display:flex;flex-direction:column;gap:1rem;margin-top:auto}.hint-btn{background:none;border:1px dashed var(--border-color);padding:.75rem 1rem;border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.95rem;transition:all var(--transition-fast);align-self:flex-start}.hint-btn:hover:not(:disabled){border-color:var(--accent-gold);color:var(--accent-gold)}.hint-btn.active{background:#c9a55c1a;border-color:var(--accent-gold);color:var(--accent-gold)}.hint-content{background:var(--bg-secondary);padding:1rem;border-radius:12px;display:flex;align-items:flex-start;gap:.75rem;font-size:.95rem;animation:slideDown .3s ease}.next-btn{background:var(--accent-primary);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:1.1rem;transition:all var(--transition-base);align-self:flex-end}.next-btn:hover{background:var(--accent-gold);transform:translate(5px)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sidebar{display:flex;flex-direction:column;gap:1.5rem}.score-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.score-title{font-size:.75rem;font-weight:700;color:var(--text-secondary);letter-spacing:.1em}.score-num{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--accent-primary)}.opponent-score{border-top:4px solid var(--accent-primary)}.opponent-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.5rem}.bot-info{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.bot-avatar{width:44px;height:44px;background:var(--accent-primary);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:700}.bot-details{display:flex;flex-direction:column}.bot-name{font-weight:600;font-size:.95rem}.bot-status{font-size:.75rem;color:var(--accent-gold)}.bot-progress{height:6px;background:var(--bg-secondary);border-radius:10px;overflow:hidden}.bot-progress-bar{height:100%;background:var(--accent-gold);transition:width 1s linear}.session-id{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);text-align:center;margin-top:auto}.result-container{width:100%;max-width:800px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:32px;padding:0;overflow:hidden;box-shadow:var(--shadow-lg);animation:fadeIn .6s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.result-banner{padding:3rem 2rem;text-align:center;color:#fff}.result-banner.victory{background:linear-gradient(135deg,var(--accent-primary),#4e3571)}.result-banner.defeat{background:linear-gradient(135deg,#1a1614,#3a2e28)}.result-banner h1{font-size:3.5rem;color:#fff;margin-bottom:.5rem}.score-comparison{display:flex;padding:2rem;align-items:center;border-bottom:1px solid var(--border-color)}.score-side{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem}.score-value{font-family:var(--font-display);font-size:3rem;font-weight:700}.score-divider{width:1px;height:60px;background:var(--border-color)}.rating-change{font-weight:600;font-size:.875rem}.rating-change.positive{color:var(--accent-success)}.rating-change.negative{color:#ff6b6b}.performance-chart{padding:2rem}.chart-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.chart-title{font-weight:700;font-family:var(--font-display)}.chart-legend{margin-left:auto;display:flex;gap:1rem;font-size:.8rem}.legend-you{color:var(--accent-primary)}.legend-bot{color:var(--accent-gold)}.chart-placeholder{height:200px;display:flex;flex-direction:column}.chart-bars{flex:1;display:flex;align-items:flex-end;gap:1.5rem;padding:0 1rem;border-bottom:1px solid var(--border-color)}.chart-bar-group{flex:1;display:flex;align-items:flex-end;gap:4px;height:100%}.chart-bar{flex:1;border-radius:4px 4px 0 0;min-height:4px;transition:height 1s ease}.you-bar{background:var(--accent-primary)}.bot-bar{background:var(--accent-gold)}.chart-labels{display:flex;justify-content:space-between;padding-top:.75rem;font-size:.7rem;color:var(--text-secondary)}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:0 2rem 2rem}.stat-box{background:var(--bg-secondary);padding:1.5rem;border-radius:20px;text-align:center;display:flex;flex-direction:column;gap:.25rem}.stat-num{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.stat-txt{font-size:.7rem;font-weight:700;color:var(--text-secondary);letter-spacing:.1em}.detailed-log{padding:2rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.log-title{margin-bottom:.25rem}.log-subtitle{font-size:.9rem;margin-bottom:1.5rem}.log-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:1rem;margin-bottom:.75rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem}.log-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.log-icon.correct{background:#3d8b6e1a;color:var(--accent-success)}.log-icon.wrong{background:#ff6b6b1a;color:#ff6b6b}.log-info{display:flex;flex-direction:column}.log-question{font-weight:600;font-size:.95rem}.log-stats{font-size:.8rem;color:var(--text-secondary)}.view-solution{background:none;border:none;color:var(--accent-primary);font-weight:600;font-size:.85rem;cursor:pointer}.solution-text{grid-column:1 / -1;background:var(--bg-secondary);padding:1rem;border-radius:12px;margin-top:.5rem;font-size:.9rem;line-height:1.5;animation:fadeIn .3s ease}.solution-label{display:block;font-weight:700;font-size:.75rem;margin-bottom:.5rem;text-transform:uppercase;color:var(--text-secondary)}.result-actions{padding:2rem;display:flex;gap:1rem}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border-radius:16px;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.action-btn.primary{background:var(--accent-primary);color:#fff;border:none}.action-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000;overflow:hidden}.confetti{position:absolute;width:10px;height:10px;animation:confettiFall 3s ease-out forwards}@keyframes confettiFall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}@media(max-width:900px){.battle-layout{grid-template-columns:1fr}.sidebar{order:-1;flex-direction:row}.score-card{flex:1}.session-id{display:none}}@media(max-width:600px){.options-grid{grid-template-columns:1fr}.result-banner h1{font-size:2.5rem}.stats-row{grid-template-columns:1fr}.sidebar{flex-direction:column}}.challenge-page{min-height:100vh;background:#fff;display:flex;align-items:center;justify-content:center}.challenge-page.split-screen{flex-direction:column;padding:0;overflow:hidden}.setup-container{max-width:500px;margin:0 auto;padding:100px 1.5rem 40px;text-align:center}.setup-container .back-link{display:inline-block;color:#64648c;font-size:.9rem;margin-bottom:2rem;text-decoration:none}.setup-container .back-link:hover{color:#5b4cfd}.setup-title{font-size:2.5rem;font-weight:800;color:#1a1a2e;margin-bottom:.5rem}.setup-subtitle{color:#64648c;font-size:1.1rem;margin-bottom:1.5rem}.mobile-notice{display:flex;align-items:center;justify-content:center;gap:.75rem;background:#ffa5001a;border:1px solid rgba(255,165,0,.3);border-radius:12px;padding:1rem;margin-bottom:2rem}.mobile-notice .notice-icon{font-size:1.5rem}.mobile-notice p{color:#cc8400;font-size:.9rem;margin:0}.player-inputs{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.player-input{flex:1;display:flex;flex-direction:column;gap:.5rem}.player-number{font-size:.75rem;font-weight:700;color:#64648c;text-transform:uppercase;letter-spacing:.1em}.player-input input{background:#f8f8fc;border:2px solid #e5e5f0;border-radius:12px;padding:1rem;color:#1a1a2e;font-size:1rem;font-weight:600;text-align:center;outline:none;transition:border-color .2s}.player-input input:focus{border-color:#5b4cfd}.player-input input::placeholder{color:#a0a0b0}.vs-badge{font-size:.85rem;font-weight:800;color:#a0a0b0;margin-top:1.5rem}.rules-box{background:#f8f8fc;border:1px solid #e5e5f0;border-radius:16px;padding:1.5rem;margin-bottom:2rem;text-align:left}.rules-box h3{color:#1a1a2e;font-size:1rem;margin-bottom:1rem}.rules-box ul{list-style:none;padding:0;margin:0}.rules-box li{color:#64648c;font-size:.9rem;padding:.5rem 0 .5rem 1.5rem;position:relative}.rules-box li:before{content:"•";position:absolute;left:0;color:#5b4cfd}.start-btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#00d4aa,#00b894);color:#fff;font-size:1.1rem;font-weight:700;padding:1rem 2.5rem;border-radius:14px;border:none;cursor:pointer;transition:all .2s;box-shadow:0 8px 30px #00d4aa4d}.start-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00d4aa66}.player-half{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;width:100%;min-height:0}.player1-half{background:linear-gradient(180deg,#f0f0ff,#fff);transform:rotate(180deg);border-bottom:2px solid #e5e5f0}.player2-half{background:linear-gradient(180deg,#fff,#f0fff0)}.half-header{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:400px;margin-bottom:.75rem}.half-name{font-size:1rem;font-weight:700;color:#1a1a2e}.half-score{font-size:1.5rem;font-weight:800;color:#5b4cfd}.half-question{background:#fff;border:1px solid #e5e5f0;border-radius:16px;padding:1rem 1.5rem;margin-bottom:.75rem;width:100%;max-width:400px;text-align:center;box-shadow:0 2px 10px #0000000d}.half-question p{color:#1a1a2e;font-size:1.25rem;font-weight:700;margin:0}.half-options{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;width:100%;max-width:400px}.half-option{background:#fff;border:2px solid #e5e5f0;border-radius:12px;padding:.75rem;color:#1a1a2e;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s}.half-option:hover:not(:disabled){background:#f0f0ff;border-color:#5b4cfd}.half-option.selected{background:#00d4aa26;border-color:#00d4aa;color:#00a884}.half-option.disabled{opacity:.5;cursor:not-allowed}.half-option:disabled{cursor:not-allowed}.waiting-badge{margin-top:.5rem;font-size:.8rem;color:#64648c;font-weight:600}.center-divider{display:flex;align-items:center;justify-content:center;gap:2rem;padding:.5rem 1rem;background:#1a1a2e;width:100%}.center-timer{font-size:1.5rem;font-weight:800;color:#fff;background:#5b4cfd;padding:.25rem .75rem;border-radius:8px;min-width:50px;text-align:center}.center-timer.danger{background:#ff6b6b;animation:pulse .5s infinite}.center-score{font-size:1.25rem;font-weight:700;color:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.round-result-container{max-width:500px;padding:100px 1.5rem 40px;text-align:center}.result-header{margin-bottom:2rem}.winner-icon,.draw-icon{font-size:3rem;display:block;margin-bottom:.5rem}.result-header h2{color:#1a1a2e;font-size:1.5rem}.round-comparison{display:flex;align-items:center;justify-content:space-between;background:#f8f8fc;border:1px solid #e5e5f0;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem}.comparison-side{display:flex;flex-direction:column;gap:.5rem}.comparison-name{color:#1a1a2e;font-weight:600}.comparison-result{font-size:.9rem;font-weight:600;padding:.35rem .75rem;border-radius:6px}.comparison-result.correct{background:#00d4aa26;color:#00a884}.comparison-result.wrong{background:#ff6b6b26;color:#e05555}.comparison-answer{color:#64648c;font-size:.85rem}.score-tracker{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:2rem}.tracker-side{display:flex;flex-direction:column;align-items:center}.tracker-wins{font-size:3rem;font-weight:800;color:#1a1a2e}.tracker-name{color:#64648c;font-size:.9rem}.tracker-vs{font-size:2rem;color:#a0a0b0}.next-round-btn{background:linear-gradient(135deg,#5b4cfd,#8a2be2);color:#fff;font-size:1rem;font-weight:700;padding:1rem 2rem;border-radius:12px;border:none;cursor:pointer;transition:all .2s}.next-round-btn:hover{transform:translateY(-2px)}.final-result-container{text-align:center;padding:100px 1.5rem 40px}.celebration{margin-bottom:2rem}.trophy{font-size:5rem;display:block;margin-bottom:1rem;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.winner-name{font-size:3rem;font-weight:900;color:gold;text-shadow:0 0 40px rgba(255,215,0,.3);margin-bottom:.25rem}.winner-title{font-size:1rem;color:#64648c;text-transform:uppercase;letter-spacing:.3em}.final-score{margin-bottom:3rem}.final-score-text{font-size:4rem;font-weight:800;color:#1a1a2e}.final-actions{display:flex;gap:1rem;justify-content:center}.rematch-btn,.exit-btn{display:inline-flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;padding:1rem 2rem;border-radius:12px;cursor:pointer;transition:all .2s;text-decoration:none}.rematch-btn{background:linear-gradient(135deg,#00d4aa,#00b894);color:#fff;border:none}.rematch-btn:hover{transform:translateY(-2px)}.exit-btn{background:#f8f8fc;border:1px solid #e5e5f0;color:#1a1a2e}.exit-btn:hover{background:#f0f0ff;border-color:#5b4cfd}@media(max-width:600px){.player-inputs{flex-direction:column}.vs-badge{margin-top:0}.half-question p{font-size:1.1rem}.half-options{grid-template-columns:1fr 1fr}.final-actions{flex-direction:column}}@media(orientation:landscape)and (max-height:500px){.challenge-page.split-screen{flex-direction:row}.player1-half{transform:rotate(90deg);border-bottom:none;border-right:2px solid #e5e5f0}.center-divider{flex-direction:column;width:auto;height:100%;padding:1rem .5rem}}:root{--font-display: "Playfair Display", serif;--font-body: "Instrument Sans", sans-serif;--font-mono: "Space Mono", monospace;--bg-primary: #FDFBF7;--bg-secondary: #F7F3EB;--text-primary: #1A1614;--text-secondary: #5C544D;--text-light: #8E847B;--accent-primary: #6B4C9A;--accent-gold: #B88E44;--accent-success: #3D8B6E;--border-color: rgba(26, 22, 20, .08);--border-prominent: rgba(26, 22, 20, .15);--shadow-color: rgba(0, 0, 0, .04);--glass-bg: rgba(253, 251, 247, .85);--container: 1200px;--navbar-height: 80px;--space-unit: 1rem;--section-padding: 8rem;--transition-fast: .2s cubic-bezier(.16, 1, .3, 1);--transition-base: .5s cubic-bezier(.16, 1, .3, 1)}[data-theme=dark]{--bg-primary: #0D0B0E;--bg-secondary: #161318;--text-primary: #E8E4E0;--text-secondary: #A39B94;--text-light: #6E6660;--accent-primary: #A385D9;--accent-gold: #D4AF5A;--accent-success: #4CAF8C;--border-color: rgba(232, 228, 224, .08);--border-prominent: rgba(232, 228, 224, .15);--shadow-color: rgba(0, 0, 0, .4);--glass-bg: rgba(13, 11, 14, .85)}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);line-height:1.6;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-base),color var(--transition-base);overflow-x:hidden}#root{width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;color:var(--text-primary);line-height:1.05;letter-spacing:-.01em}a{color:var(--accent-primary);text-decoration:none;transition:all var(--transition-fast)}p{color:var(--text-secondary);font-size:1.125rem;font-weight:400;line-height:1.6}.container{max-width:var(--container);margin:0 auto;padding:0 2rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 2rem;font-family:var(--font-body);font-size:.95rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none;position:relative;overflow:hidden;letter-spacing:.01em}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 2px 10px #6b4c9a26}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6b4c9a40;background:#7a5bb1}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border-prominent)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--accent-primary)}.btn-shimmer:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 20%,rgba(255,255,255,.1) 50%,transparent 80%);transform:rotate(45deg);animation:shimmer 5s infinite}@keyframes shimmer{0%{transform:translate(-100%) rotate(45deg)}to{transform:translate(100%) rotate(45deg)}}.glass{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color)}.section-airy{padding:var(--section-padding) 0}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-prominent);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}
