body,html{margin:0;overflow-x:hidden;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}#root{overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100vh}.app.with-sidebar{box-sizing:border-box;min-height:100vh;padding-left:260px;transition:padding-left .3s cubic-bezier(.4,0,.2,1)}body.sidebar-collapsed .app.with-sidebar{padding-left:72px}.main-content{flex:1 1;margin-top:64px;padding:20px}.app.with-sidebar .main-content{margin-top:0}@media (max-width:768px){.app.with-sidebar,body.sidebar-collapsed .app.with-sidebar{padding-left:0!important}}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-top-color:#3498db;height:40px;margin:20px auto;width:40px}.footer{background:#fff;margin-top:4rem}.footer-inner{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:280px 1fr;margin:0 auto;max-width:1200px;padding:3rem 2rem 2rem;position:relative}.footer-brand{display:flex;flex-direction:column;gap:1rem}.footer-logo{align-items:center;display:flex;gap:.625rem}.footer-mascot{bottom:0;height:64px;object-fit:contain;opacity:.9;position:absolute;right:0;width:64px}.footer-logo-text{color:#1e293b;font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.footer-tagline{color:#64748b;font-size:.875rem;line-height:1.5;margin:0}.footer-social{display:flex;gap:.75rem;margin-top:.5rem}.footer-social a{align-items:center;background:#f1f5f9;border-radius:8px;color:#64748b;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.footer-social a:hover{background:#3b82f6;color:#fff}.footer-social svg{height:18px;width:18px}.footer-links-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(4,1fr)}.footer-section{display:flex;flex-direction:column;gap:.75rem}.footer-section h4{color:#1e293b;font-size:.8125rem;font-weight:600;letter-spacing:.05em;margin:0 0 .25rem;text-transform:uppercase}.footer-section a{color:#64748b;font-size:.875rem;text-decoration:none;transition:color .2s ease}.footer-section a:hover{color:#3b82f6}.footer-bottom{padding:1.25rem 2rem;text-align:center}.footer-bottom p{color:#94a3b8;font-size:.8125rem;margin:0}@media (max-width:900px){.footer-inner{gap:2.5rem;grid-template-columns:1fr;padding:2.5rem 1.5rem 1.5rem}.footer-brand{align-items:center;text-align:center}.footer-links-grid{gap:2rem;grid-template-columns:repeat(2,1fr)}}@media (max-width:500px){.footer-inner{padding:2rem 1.25rem 1.25rem}.footer-links-grid{gap:1.5rem;grid-template-columns:1fr 1fr}.footer-section h4{font-size:.75rem}.footer-section a{font-size:.8125rem}.footer-mascot{height:48px;opacity:.7;width:48px}.footer-bottom{padding:1rem 1.25rem}.footer-bottom p{font-size:.75rem}}*{margin:0;padding:0}.homepage{background:#fff;overflow-x:hidden;width:100%}.hero{align-items:center;background:#fff;display:flex;justify-content:center;min-height:75vh;padding:8rem 4rem 2rem;position:relative}.hero-content{animation:heroReveal 1.2s cubic-bezier(.16,1,.3,1);max-width:850px;position:relative;text-align:center;z-index:1}.hero-title{color:#0f172a;font-size:4rem;font-weight:900;letter-spacing:-.02em;line-height:1.2;margin-bottom:1.5rem}.hero-subtitle{color:#64748b;font-size:1.25rem;font-weight:400;line-height:1.6;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:600px}.hero-input-container{margin:0 auto;max-width:750px}.hero-input-wrapper{align-items:center;display:flex;margin-bottom:1rem;position:relative}.input-icon-left{align-items:center;color:#94a3b8;display:flex;justify-content:center;left:1.75rem;pointer-events:none;position:absolute;transition:color .3s ease;z-index:1}.hero-input-wrapper:focus-within .input-icon-left{color:#3b82f6}.hero-input{background:#fff;border:2.5px solid #e2e8f0;border-radius:16px;box-shadow:0 2px 8px #0000000a,0 1px 2px #0000000f;color:#1e293b;font-family:inherit;font-size:1.0625rem;outline:none;padding:1.5rem 5.5rem 1.5rem 4rem;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%}.hero-input::placeholder{color:#94a3b8;font-weight:400}.hero-input:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #0000000f,0 2px 4px #0000000a}.hero-input:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a,0 4px 16px #3b82f61f;transform:translateY(-1px)}.hero-send{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;box-shadow:0 2px 8px #3b82f64d;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;right:8px;transition:all .3s cubic-bezier(.16,1,.3,1);width:48px}.hero-send:hover{box-shadow:0 4px 16px #3b82f666;transform:scale(1.05)}.hero-send:active{transform:scale(.98)}.hero-input-hint{color:#94a3b8;font-size:.875rem;font-weight:500;margin-top:1rem;text-align:center}.example-prompts{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1.25rem}.example-prompt-btn{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 2px #0000000a;color:#475569;cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:500;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s cubic-bezier(.16,1,.3,1)}.example-prompt-btn:hover{background:#f8fafc;border-color:#cbd5e1;box-shadow:0 4px 8px #00000014;transform:translateY(-1px)}.example-prompt-btn:active{transform:translateY(0)}.example-icon{font-size:1.125rem;line-height:1}.example-text{white-space:nowrap}@media (max-width:768px){.hero{min-height:85vh;padding:6rem 1.5rem 2rem}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.0625rem;margin-bottom:2rem}.hero-input-container{max-width:100%;padding:0 .5rem}.hero-input-wrapper{margin-bottom:1rem}.hero-input{font-size:.9375rem;padding:1rem 3.75rem 1rem 1.25rem}.input-icon-left{display:none}.hero-send{height:40px;right:5px;width:40px}.hero-send svg{height:16px;width:16px}.example-prompts{gap:.5rem;margin-top:1rem}.example-prompt-btn{font-size:.8125rem;gap:.375rem;padding:.5rem .75rem}.example-icon{font-size:.9375rem}.example-text,.hero-input-hint{font-size:.8125rem}}@media (max-width:480px){.hero-title{font-size:2rem;margin-bottom:1rem}.hero-subtitle{font-size:.9375rem}.hero-input{font-size:.875rem;padding:.875rem 3.5rem .875rem 1rem}.input-icon-left{display:none}.hero-send{height:36px;width:36px}.hero-send svg{height:14px;width:14px}.example-prompt-btn{font-size:.75rem;padding:.5rem .625rem}.example-icon{font-size:.875rem}.example-text{font-size:.75rem}}.experience{background:#fff;padding:4rem}.section-heading{color:#0f172a;font-size:3.5rem;font-weight:900;letter-spacing:-.03em;margin-bottom:4rem;margin-left:auto;margin-right:auto;max-width:900px;text-align:center}.chat-demo-flow{margin:0 auto;max-width:900px}.demo-msg-wrapper{margin-bottom:2.5rem;opacity:0;transform:translateY(60px) scale(.95);transition:all 1s cubic-bezier(.16,1,.3,1)}.demo-msg-wrapper.visible{opacity:1;transform:translateY(0) scale(1)}.demo-msg{align-items:flex-start;display:flex;gap:1rem}.user-msg{flex-direction:row-reverse}.ai-msg,.user-msg{justify-content:flex-start}.ai-msg{flex-direction:row}.msg-avatar{background:#0000;border-radius:50%;flex-shrink:0;height:48px;overflow:hidden;width:48px}.msg-avatar .mascot-img{-ms-interpolation-mode:bicubic;height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:high-quality;object-fit:contain;width:100%}.msg-bubble{animation:bubbleAppear .6s cubic-bezier(.68,-.55,.265,1.55);border-radius:20px;box-shadow:0 4px 12px #00000014;font-size:1.0625rem;line-height:1.8;max-width:75%;padding:1.25rem 1.75rem}.msg-bubble p{margin:.75rem 0}.msg-bubble p:first-child{margin-top:0}.msg-bubble p:last-child{margin-bottom:0}.msg-bubble strong{color:inherit;font-weight:700}.user-bubble{background:#3b82f6}.ai-bubble{background:#fff;border-bottom-left-radius:6px;color:#1e293b}.demo-artifact-container{display:flex;justify-content:flex-start;margin-left:54px;margin-top:1rem}.artifact-quiz{animation:artifactReveal .8s cubic-bezier(.16,1,.3,1);background:#fff;border:1px solid #f1f5f9;border-radius:20px;box-shadow:0 8px 24px #0000001f;max-width:700px;padding:2rem;width:100%}.artifact-question{margin-bottom:2rem}.artifact-question h3{color:#1e293b;font-size:1.375rem;font-weight:700;line-height:1.6;margin:0}.artifact-choices{grid-gap:1.125rem;display:grid;gap:1.125rem;margin-bottom:1.75rem}.artifact-choice{align-items:center;border:2px solid #0000;border-radius:14px;color:#fff;cursor:pointer;display:flex;font-size:1.0625rem;font-weight:500;gap:1.125rem;padding:1.25rem 1.5rem;text-align:left;transition:all .4s cubic-bezier(.16,1,.3,1)}.artifact-choice:hover{box-shadow:0 8px 20px #0000002e;filter:brightness(1.12);transform:translateY(-4px) scale(1.02)}.choice-letter{font-size:.9375rem;height:36px;width:36px}.artifact-footer{align-items:center;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;padding-top:1.25rem}.artifact-badge{background:#eff6ff;border-radius:24px;color:#3b82f6;font-size:.9375rem;font-weight:600;padding:.5rem 1.125rem}.artifact-count{color:#64748b;font-size:.9375rem;font-weight:500}.tools-showcase{background:#fff;overflow:hidden;padding:5rem 2rem}.tools-showcase-inner{margin:0 auto;max-width:900px}.showcase-header{margin-bottom:3rem;text-align:center}.showcase-label{color:#8b5cf6;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.15em;margin-bottom:1rem;text-transform:uppercase}.showcase-header h2{color:#0f172a;font-size:2.5rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}.showcase-bento{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(2,160px)}.bento-item{border-radius:16px;box-shadow:0 2px 8px #00000014;cursor:pointer;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1)}.bento-item:hover{box-shadow:0 12px 24px #0000001f;transform:translateY(-4px)}.bento-content{height:calc(100% - 40px);justify-content:center;padding:1rem}.bento-content,.bento-label{align-items:center;display:flex}.bento-label{background:#00000026;bottom:0;color:#fffffff2;font-size:.8125rem;font-weight:600;justify-content:space-between;left:0;padding:.625rem 1rem;position:absolute;right:0}.bento-arrow{opacity:0;transform:translateX(-8px);transition:all .3s ease}.bento-item:hover .bento-arrow{opacity:1;transform:translateX(0)}.bento-flashcard{background:linear-gradient(145deg,#6366f1,#8b5cf6 50%,#a855f7);display:flex;flex-direction:column;grid-column:span 5;grid-row:span 2}.fc-demo{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:1.5rem 2rem;text-align:center}.fc-badge{background:#fff3;border-radius:20px;color:#fff;display:inline-block;font-size:.625rem;font-weight:700;letter-spacing:.12em;margin-bottom:1.25rem;padding:.375rem .875rem;text-transform:uppercase}.fc-question{color:#fff;font-size:1.25rem;font-weight:600;line-height:1.45;margin:0 0 1rem;max-width:260px}.fc-hint{color:#fff9;font-size:.75rem;font-style:italic;font-weight:500}.bento-quiz{background:#f8fafc;border:1px solid #e2e8f0;display:flex;flex-direction:column;grid-column:span 4;grid-row:span 1}.quiz-preview-content{display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:1rem 1.125rem}.quiz-preview-q{color:#1e293b;font-size:.875rem;font-weight:600;line-height:1.4;margin:0 0 .75rem}.quiz-preview-opts{display:flex;flex-direction:column;gap:.375rem}.quiz-preview-opt{align-items:center;border-radius:8px;color:#fff;display:flex;font-size:.75rem;font-weight:600;gap:.5rem;padding:.4375rem .625rem}.quiz-preview-opt span{align-items:center;background:#ffffff4d;border-radius:50%;display:flex;font-size:.625rem;font-weight:700;height:18px;justify-content:center;width:18px}.quiz-preview-opt.opt-a{background:#ff9f4a}.quiz-preview-opt.opt-b{background:#4a9eff}.quiz-preview-opt.opt-c{background:#4af67c}.bento-label.dark{background:#0000000a;color:#64748b}.bento-label.dark .bento-arrow{color:#94a3b8}.bento-summary{background:linear-gradient(145deg,#0ea5e9,#3b82f6);display:flex;flex-direction:column;grid-column:span 3;grid-row:span 1}.summary-content{align-items:center;display:flex;flex:1 1;justify-content:center;padding:1.25rem}.summary-lines{display:flex;flex-direction:column;gap:.625rem;width:85%}.line-full{background:#ffffffb3}.line-full,.line-short{border-radius:3px;height:6px}.line-short{background:#ffffff73;width:55%}.bento-fill{background:linear-gradient(145deg,#10b981,#059669);display:flex;flex-direction:column;grid-column:span 4;grid-row:span 1}.bento-fill .bento-content{align-items:center;display:flex;flex:1 1;justify-content:center;padding:.875rem 1.25rem}.mini-fill p{color:#fff;font-size:.9375rem;font-weight:500;line-height:1.6;margin:0}.fill-blank{background:#fff3;border-bottom:2px solid #fff;border-radius:4px 4px 0 0;display:inline-block;height:1.5rem;margin:0 .25rem;min-width:5rem;vertical-align:middle}.bento-cta{background:#f8fafc;border:2px dashed #cbd5e1;grid-column:span 3;grid-row:span 1}.bento-cta:hover{background:#faf5ff;border-color:#8b5cf6}.bento-cta-content{align-items:center;display:flex;flex-direction:column;gap:.375rem;height:100%;justify-content:center;width:100%}.cta-plus{color:#94a3b8;font-size:2rem;font-weight:300;line-height:1;transition:all .3s ease}.bento-cta:hover .cta-plus{color:#8b5cf6;transform:rotate(90deg)}.cta-text{color:#64748b;font-size:.8125rem;font-weight:600}.bento-cta:hover .cta-text{color:#7c3aed}@media (max-width:900px){.showcase-bento{gap:.875rem;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(4,130px)}.bento-flashcard{grid-column:span 6;grid-row:span 1}.fc-demo{flex-direction:row;gap:1rem;padding:1rem 1.25rem}.fc-badge{margin-bottom:0}.fc-question{font-size:1rem;margin:0;text-align:left}.fc-hint{display:none}.bento-quiz,.bento-summary{grid-column:span 3;grid-row:span 1}.bento-fill{grid-column:span 4;grid-row:span 1}.bento-cta{grid-column:span 2;grid-row:span 1}.showcase-header h2{font-size:2rem}}@media (max-width:600px){.tools-showcase{padding:3.5rem 1rem}.showcase-header h2{font-size:1.625rem}.showcase-bento{gap:.625rem;grid-template-columns:1fr 1fr;grid-template-rows:repeat(5,110px)}.bento-flashcard{grid-column:span 2;grid-row:span 1}.fc-demo{align-items:center;flex-direction:row;gap:.625rem;padding:.75rem 1rem}.fc-badge{font-size:.5rem;padding:.25rem .5rem}.fc-question{flex:1 1;font-size:.875rem}.bento-quiz{grid-column:span 2;grid-row:span 1}.quiz-preview-content{padding:.625rem .75rem}.quiz-preview-q{font-size:.6875rem;margin-bottom:.5rem}.quiz-preview-opts{gap:.25rem}.quiz-preview-opt{font-size:.625rem;gap:.375rem;padding:.3125rem .5rem}.quiz-preview-opt span{font-size:.5rem;height:14px;width:14px}.bento-summary{grid-column:span 1;grid-row:span 1}.summary-lines{gap:.4rem}.line-full,.line-short{height:4px}.bento-fill{grid-column:span 1;grid-row:span 1}.bento-fill .bento-content{padding:.625rem}.mini-fill p{font-size:.6875rem}.fill-blank{height:1.125rem;min-width:3rem}.bento-cta{grid-column:span 2;grid-row:span 1}.bento-label{font-size:.6875rem;padding:.4375rem .75rem}.quiz-q{font-size:.75rem;margin-bottom:.375rem}.quiz-opt{font-size:.625rem;padding:.3125rem .1875rem}.mm-icon svg{height:50px;width:50px}.mm-icon{padding:.5rem}.cta-plus{font-size:1.5rem}.cta-text{font-size:.75rem}}.ai-guide-section{background:#fff;border-top:1px solid #f1f5f9;padding:5rem 4rem}.ai-guide-container{margin:0 auto;max-width:1200px}.ai-guide-title{color:#0f172a;font-size:2.75rem;font-weight:800;line-height:1.2;margin-bottom:3rem;text-align:center}.guide-flow{align-items:center;display:flex;gap:0;justify-content:center;margin:0 auto;max-width:900px}.flow-step{flex:1 1;padding:2rem 1.5rem;position:relative;text-align:center}.step-label{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#0f172a;font-size:1.125rem;font-weight:700;margin-bottom:.5rem}.flow-step p{color:#64748b;font-size:.875rem;line-height:1.5;margin:0}.flow-connector{background:linear-gradient(90deg,#3b82f6,#8b5cf6);flex-shrink:0;height:2px;opacity:.3;width:40px}.personalized-section{background:linear-gradient(135deg,#f8fafc,#fff);border-top:1px solid #f1f5f9;padding:5rem 4rem}.personalized-container{margin:0 auto;max-width:1200px}.personalized-title{color:#0f172a;font-size:2.75rem;font-weight:800;line-height:1.2;margin-bottom:3rem;text-align:center}.adaptation-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:900px}.adapt-card{background:#fff;border:2px solid #0000;border-radius:16px;padding:2rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.adapt-card:hover{border-color:#3b82f633;box-shadow:0 8px 24px #3b82f614;transform:translateY(-4px)}.adapt-card h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#0f172a;font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.adapt-card p{color:#64748b;font-size:.95rem;line-height:1.6;margin:0}.features-modern{background:linear-gradient(180deg,#f8fafc,#fff);padding:12rem 4rem}.features-container{margin:0 auto;max-width:1400px}.features-header{margin-bottom:5rem;text-align:center}.features-title{color:#0f172a;font-size:3.5rem;font-weight:900;letter-spacing:-.03em;margin-bottom:1.5rem}.features-subtitle{color:#64748b;font-size:1.375rem;line-height:1.6;margin:0 auto;max-width:700px}.features-bento{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,320px)}.feature-card{background:#fff;border:1px solid #e2e8f0;border-radius:24px;cursor:pointer;overflow:hidden;padding:2.5rem;position:relative;transition:all .5s cubic-bezier(.16,1,.3,1)}.feature-card:before{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .5s ease}.feature-card:hover:before{opacity:1}.feature-card:hover{border-color:#3b82f6;box-shadow:0 20px 40px #0000001f;transform:translateY(-8px)}.feature-card.large{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;color:#fff;grid-column:span 2;grid-row:span 2}.feature-card.large h3,.feature-card.large p{color:#fff}.feature-card.medium{grid-column:span 1;grid-row:span 1}.feature-card.wide{grid-column:span 2;grid-row:span 1}.feature-card-content{display:flex;flex-direction:column;height:100%;justify-content:space-between;position:relative;z-index:1}.feature-card-content.horizontal{align-items:center;flex-direction:row;gap:2rem}.feature-icon-lg{font-size:5rem;margin-bottom:2rem}.feature-icon-md{font-size:3.5rem;margin-bottom:1.5rem}.feature-card h3{color:#0f172a;font-size:1.75rem;font-weight:700;letter-spacing:-.01em;margin-bottom:1rem}.feature-card p{color:#64748b;font-size:1.0625rem;line-height:1.7;margin-bottom:1.5rem}.feature-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:50px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.875rem 1.75rem;transition:all .3s ease}.feature-btn:hover{background:#ffffff4d;transform:translateX(4px)}.feature-btn.secondary{background:#3b82f6;border-color:#3b82f6;color:#fff;margin-left:auto}.feature-btn.secondary:hover{background:#2563eb}[data-aos]{opacity:0;transition-duration:.8s;transition-property:opacity,transform;transition-timing-function:cubic-bezier(.16,1,.3,1)}[data-aos=fade-up]{transform:translateY(40px)}[data-aos=fade-right]{transform:translateX(-60px)}[data-aos=fade-left]{transform:translateX(60px)}[data-aos=zoom-in]{transform:scale(.9)}[data-aos=fade]{transform:none}[data-aos].aos-animate{opacity:1;transform:translateY(0) translateX(0) scale(1)}.purpose-section{background:#fff;overflow:hidden;padding:5rem 4rem}.purpose-container{margin:0 auto;max-width:1400px}.purpose-content{margin-bottom:3rem}.purpose-label{color:#3b82f6;display:inline-block;font-size:.875rem;font-weight:600;letter-spacing:.1em;margin-bottom:1rem;text-transform:uppercase}.purpose-title{color:#0f172a;font-size:3rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.purpose-description{color:#64748b;font-size:1.125rem;line-height:1.8;margin-bottom:1rem;max-width:800px}.purpose-stats{display:flex;gap:3rem;margin-top:3rem}.stat-block{flex:1 1}.stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;display:block;font-size:3rem;margin-bottom:.5rem}.stat-label{font-size:1rem}.purpose-visual{display:flex;gap:2rem;justify-content:center;margin-top:4rem}.visual-card{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border:1px solid #3b82f61a;border-radius:16px;padding:2rem 3rem;transition:all .4s cubic-bezier(.16,1,.3,1)}.visual-card:hover{background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-color:#3b82f64d;transform:translateY(-8px)}.card-icon{display:block;text-align:center}.card-text{color:#0f172a;font-size:1rem;font-weight:600;text-align:center}.how-it-works{background:linear-gradient(180deg,#fafbfc,#fff);border-top:1px solid #f1f5f9;padding:6rem 2rem}.how-container{margin:0 auto;max-width:1400px}.how-header{margin-bottom:4rem;text-align:center}.how-title{color:#0f172a;font-size:3rem;font-weight:800;letter-spacing:-.02em;margin-bottom:1rem}.how-subtitle{color:#64748b;font-size:1.25rem;line-height:1.7;margin:0 auto;max-width:700px}.code-showcase-wrapper{display:flex;flex-direction:column;gap:2rem;margin:0 auto;max-width:900px}.demo-chat-conversation{width:100%}.demo-code-editor{position:relative;width:100%}.editor-window{background:#0f172a;border-radius:16px;box-shadow:0 20px 60px #0003,0 0 0 1px #ffffff0d;overflow:hidden}.editor-titlebar{align-items:center;background:#1e293b;border-bottom:1px solid #334155;display:flex;justify-content:space-between;padding:.75rem 1rem}.window-controls{display:flex;gap:.5rem}.control-dot{border-radius:50%;height:12px;width:12px}.control-dot.red{background:#ff5f57}.control-dot.yellow{background:#ffbd2e}.control-dot.green{background:#28c841}.editor-filename{align-items:center;color:#cbd5e1;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.file-icon{font-size:1.125rem}.run-code-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.8125rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.run-code-btn:hover{box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.editor-body{background:#0f172a;display:flex;font-family:Monaco,Menlo,Consolas,monospace;padding:1rem 0}.line-numbers{color:#475569;display:flex;flex-direction:column;font-size:.875rem;line-height:1.6;min-width:2.5rem;padding:0 .75rem;text-align:right;-webkit-user-select:none;user-select:none}.code-content{flex:1 1;padding-right:1rem;text-align:left}.code-line{color:#e2e8f0;font-size:.875rem;line-height:1.6;min-height:1.4rem;text-align:left}.code-line.indent{padding-left:1.5rem}.code-line.empty{min-height:1.4rem}.keyword{color:#c084fc;font-weight:600}.function{color:#60a5fa}.param{color:#fbbf24}.string{color:#34d399}.number{color:#f472b6}.builtin{color:#818cf8}.comment{color:#64748b}.console-output{background:#1e293b;border-top:1px solid #334155}.console-header{align-items:center;border-bottom:1px solid #334155;display:flex;justify-content:space-between;padding:.5rem 1rem}.console-label{color:#94a3b8;letter-spacing:.05em;text-transform:uppercase}.console-label,.status-badge{font-size:.75rem;font-weight:600}.status-badge{align-items:center;display:flex;gap:.375rem}.status-badge.success{color:#10b981}.console-body{font-family:Monaco,Menlo,Consolas,monospace;font-size:.875rem;padding:.75rem 1rem;text-align:left}.output-line{color:#e2e8f0}.chat-window{display:flex;flex-direction:column;gap:1.5rem;width:100%}.chat-message{display:flex;gap:.75rem}.chat-message.user{justify-content:flex-end}.chat-message.assistant{align-items:flex-start}.message-bubble{font-size:.9375rem;padding:1.125rem 1.5rem}.chat-message.user .message-bubble{background:linear-gradient(135deg,#3b82f6,#8b5cf6);box-shadow:0 4px 16px #3b82f640;color:#fff}.chat-message.assistant .message-bubble{background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a;color:#334155}.assistant-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 12px #667eea4d;display:flex;flex-shrink:0;height:48px;justify-content:center;overflow:hidden;width:48px}.mascot-img{-ms-interpolation-mode:bicubic;height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:high-quality;object-fit:cover;width:100%}.message-bubble p{margin:0 0 .75rem}.message-bubble p:last-child{margin-bottom:0}.inline-code{background:#8b5cf61a;border:1px solid #8b5cf633;border-radius:6px;color:#8b5cf6;display:inline-block;font-family:Monaco,Menlo,Consolas,monospace;font-size:.875rem;margin:.375rem 0;padding:.25rem .625rem}.steps-flow{align-items:flex-start;display:flex;gap:1rem;justify-content:center;position:relative}.steps-flow:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6);content:"";height:3px;left:18%;opacity:.2;position:absolute;right:18%;top:32px;z-index:0}.step-item{background:#fff;border:2px solid #0000;border-radius:20px;flex:1 1;max-width:350px;padding:2rem 1.5rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.16,1,.3,1);z-index:1}.step-item:hover{border-color:#3b82f6;box-shadow:0 16px 48px #3b82f626;transform:translateY(-12px)}.step-number{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:4px solid #fff;box-shadow:0 8px 24px #3b82f666;font-size:1.75rem;font-weight:800;height:64px;margin:0 auto 1.5rem;width:64px}.step-content h3{color:#0f172a;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.step-content p{color:#64748b;font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem}.step-example{display:flex;justify-content:center;margin-top:1.5rem}.example-bubble{background:#3b82f61a;border:2px solid #3b82f633;border-radius:20px;color:#3b82f6;display:inline-block}.example-bubble,.example-response{font-size:.95rem;font-weight:600;padding:.75rem 1.5rem}.example-response{align-items:center;background:#10b9811a;border:2px solid #10b98133;border-radius:20px;color:#10b981;display:flex;gap:.5rem}.response-icon{font-size:1.25rem}.quiz-mini-preview{background:#8b5cf61a;border:2px solid #8b5cf633;border-radius:12px;display:inline-block;padding:1rem}.quiz-q{color:#8b5cf6;font-size:.875rem;font-weight:600;margin-bottom:.75rem}.quiz-choices-mini{display:flex;gap:.5rem;justify-content:center}.quiz-choices-mini span{align-items:center;border-radius:8px;color:#fff;display:flex;font-size:.875rem;font-weight:700;height:32px;justify-content:center;width:32px}.step-arrow{align-items:center;color:#cbd5e1;display:flex;font-size:2.5rem;margin-top:4rem}.use-cases{background:#fff;border-top:1px solid #f1f5f9;padding:5rem 4rem}.cases-container{margin:0 auto;max-width:1400px}.cases-title{color:#0f172a;font-size:3rem;font-weight:800;margin-bottom:5rem;text-align:center}.cases-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(3,1fr)}.case-card{border:2px solid #0000;border-radius:16px;padding:3rem 2rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.16,1,.3,1)}.case-card:hover{background:#3b82f605;border-color:#3b82f633;transform:translateY(-8px)}.case-card.highlight{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-color:#3b82f64d}.case-badge{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:20px;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.4rem 1rem;position:absolute;right:1rem;text-transform:uppercase;top:1rem}.case-visual{margin-bottom:1.5rem}.case-emoji{display:inline-block;font-size:4rem}.case-card h3{color:#0f172a;font-size:1.75rem;font-weight:700;margin-bottom:1rem}.case-card p{color:#64748b;font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem}.case-benefits{list-style:none;margin-top:2rem;padding:0;text-align:left}.case-benefits li{color:#475569;font-size:.95rem;line-height:1.5;margin-bottom:.75rem;padding-left:1.75rem;position:relative}.case-benefits li:before{color:#10b981;content:"✓";font-size:1.1rem;font-weight:700;left:0;position:absolute}.transformation{background:#fff;border-top:1px solid #f1f5f9;padding:5rem 4rem}.transform-container{margin:0 auto;max-width:1400px}.transform-title{color:#0f172a;font-size:3rem;font-weight:800;margin-bottom:5rem;text-align:center}.transform-title:after{background:linear-gradient(90deg,#ef4444 50%,#10b981 0);border-radius:3px;content:"";display:block;height:5px;margin:1.5rem auto 0;width:80px}.comparison-grid{align-items:stretch;display:flex;gap:2rem;justify-content:center;margin:0 auto;max-width:1200px;position:relative}.comparison-side{border-radius:20px;flex:1 1;overflow:hidden;padding:3rem 2.5rem;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1)}.comparison-side:before{content:"";height:6px;left:0;position:absolute;right:0;top:0;transition:all .4s ease}.comparison-side:hover{box-shadow:0 20px 60px #0000001f;transform:translateY(-12px) scale(1.02)}.comparison-side.before{background:linear-gradient(135deg,#ef44440d,#ef444405);border:2px solid #ef444433}.comparison-side.before:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.comparison-side.after{background:linear-gradient(135deg,#10b9810d,#10b98105);border:2px solid #10b98133}.comparison-side.after:before{background:linear-gradient(90deg,#10b981,#059669)}.side-label{display:inline-block;font-size:.875rem;font-weight:700;letter-spacing:.1em;margin-bottom:2rem;text-transform:uppercase}.comparison-side.before .side-label{color:#dc2626}.comparison-side.after .side-label{color:#059669}.comparison-items{display:flex;flex-direction:column;gap:1rem}.comparison-item{align-items:flex-start;border-radius:12px;display:flex;font-size:1rem;gap:1rem;line-height:1.6;padding:1rem 1.25rem;transition:all .3s ease}.comparison-item:hover{transform:translateX(8px)}.comparison-item.negative{background:#ef444414;color:#991b1b}.comparison-item.positive{background:#10b98114;color:#065f46}.item-icon{flex-shrink:0;font-size:1.25rem;font-weight:700;margin-top:.1rem}.vs-divider{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;box-shadow:0 8px 24px #3b82f64d;color:#fff;display:flex;flex-shrink:0;font-size:2rem;font-weight:900;height:64px;justify-content:center;padding:1rem;position:relative;width:64px;z-index:2}.tools-section{background:#fff;border-top:1px solid #f1f5f9;padding:5rem 4rem}.tools-section-container{margin:0 auto;max-width:1400px}.tools-section-title{color:#0f172a;font-size:3rem;font-weight:800;margin-bottom:1rem;text-align:center}.tools-section-subtitle{color:#64748b;font-size:1.25rem;line-height:1.7;margin:0 auto 4rem;max-width:700px;text-align:center}.tools-grid-modern{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1200px}.tool-feature-card{background:#fff;border:2px solid #e2e8f0;border-radius:20px;display:flex;flex-direction:column;gap:2rem;padding:3rem;transition:all .4s cubic-bezier(.16,1,.3,1)}.tool-feature-card:hover{border-color:#3b82f6;box-shadow:0 12px 40px #3b82f626;transform:translateY(-8px)}.tool-feature-icon{align-items:center;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:20px;display:flex;height:80px;justify-content:center;width:80px}.feature-emoji{display:block;font-size:3rem}.tool-feature-content h3{color:#0f172a;font-size:1.75rem;font-weight:700;margin-bottom:1rem}.tool-feature-content p{color:#64748b;font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem}.tool-feature-list{list-style:none;margin-bottom:2rem;padding:0}.tool-feature-list li{color:#475569;font-size:.95rem;line-height:1.6;margin-bottom:.75rem;padding-left:1.75rem;position:relative}.tool-feature-list li:before{color:#10b981;content:"✓";font-size:1.1rem;font-weight:700;left:0;position:absolute}.tool-feature-btn{align-items:center;align-self:flex-start;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.75rem;padding:1rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.tool-feature-btn:hover{box-shadow:0 8px 24px #3b82f64d;transform:translateX(4px)}.tool-feature-btn svg{transition:transform .3s ease}.tool-feature-btn:hover svg{transform:translateX(4px)}.tools-modern{background:linear-gradient(180deg,#fff,#f8fafc);padding:12rem 4rem}.tools-container{margin:0 auto;max-width:1400px}.tools-title{color:#0f172a;font-size:3.5rem;font-weight:900;letter-spacing:-.03em;margin-bottom:5rem;text-align:center}.tools-grid{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:repeat(2,1fr)}.tool-card-modern{background:#fff;border:1px solid #e2e8f0;border-radius:24px;cursor:pointer;display:flex;flex-direction:column;gap:2rem;padding:3rem;transition:all .5s cubic-bezier(.16,1,.3,1)}.tool-card-modern:hover{border-color:#3b82f6;box-shadow:0 24px 48px #00000026;transform:translateY(-12px)}.tool-visual{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:16px;display:flex;height:180px;justify-content:center}.tool-icon-big{font-size:5rem}.tool-content h3{color:#0f172a;font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}.tool-content p{color:#64748b;font-size:1.0625rem;line-height:1.7;margin-bottom:1.5rem}.tool-link{align-items:center;color:#3b82f6;display:inline-flex;font-size:1.125rem;font-weight:600;gap:.5rem;transition:all .3s ease}.tool-card-modern:hover .tool-link{gap:1rem}.demo-cta{margin-top:3rem;padding:2rem 0;text-align:center}.demo-cta-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:70px;box-shadow:0 8px 24px #3b82f64d;color:#fff;cursor:pointer;display:inline-flex;font-size:1.125rem;font-weight:700;padding:1.25rem 3rem;transition:all .4s cubic-bezier(.16,1,.3,1)}.demo-cta-btn:hover{box-shadow:0 12px 32px #3b82f666;transform:translateY(-4px) scale(1.02)}.cta{background:#fff;border-top:1px solid #f1f5f9;padding:8rem 4rem;text-align:center}.cta-content{background:linear-gradient(135deg,#f8fafc,#fff);border:2px solid #e2e8f0;border-radius:24px;margin:0 auto;max-width:800px;padding:4rem}.cta-title{color:#0f172a;font-size:3rem;font-weight:900;letter-spacing:-.02em;margin-bottom:1.5rem}.cta-subtitle{color:#64748b;font-size:1.25rem;margin-bottom:3rem}.cta-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:70px;box-shadow:0 12px 36px #3b82f666;color:#fff;cursor:pointer;display:inline-flex;font-size:1.25rem;font-weight:700;gap:1rem;padding:1.5rem 4rem;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1)}.cta-btn:hover{box-shadow:0 20px 50px #3b82f680;transform:translateY(-6px) scale(1.02)}.cta-btn svg{transition:transform .4s cubic-bezier(.16,1,.3,1)}.cta-btn:hover svg{transform:translateX(8px)}@keyframes heroReveal{0%{opacity:0;transform:translateY(40px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bubbleAppear{0%{opacity:0;transform:scale(.9) translateY(10px)}60%{transform:scale(1.02) translateY(-2px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes artifactReveal{0%{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.aos-init{opacity:0}.aos-animate{opacity:1}@media (max-width:1200px){.features-bento{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}.feature-card.large{grid-column:span 2;grid-row:span 1}.feature-card.medium,.feature-card.wide{grid-column:span 1;grid-row:span 1}.tools-grid{grid-template-columns:1fr}.purpose-stats{gap:2rem}.purpose-stats,.purpose-visual{flex-direction:column}.ai-guide-section,.interactive-section,.personalized-section{padding:4rem 2rem}.ai-guide-title,.interactive-title,.personalized-title{font-size:2.25rem}.interactive-grid{gap:1.5rem;grid-template-columns:1fr}.guide-flow{flex-wrap:wrap;gap:1rem}.flow-step{flex:1 1 45%;padding:1.5rem 1rem}.flow-connector{display:none}.adaptation-grid{gap:1.5rem;grid-template-columns:1fr}.steps-flow{display:grid;grid-template-columns:repeat(2,1fr)}.steps-flow:before{display:none}.cases-grid{grid-template-columns:repeat(2,1fr)}.step-arrow{display:none}.comparison-grid{flex-direction:column;gap:2rem}.vs-divider{transform:rotate(90deg)}.tools-grid-modern{gap:2rem;grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.hero{min-height:70vh;padding:5rem 2rem 2rem}.hero-title{font-size:2.75rem}.hero-subtitle{font-size:1.125rem;margin-bottom:2.5rem}.experience{padding:3rem 2rem}.demo-cta{margin-top:2rem;padding:1.5rem 0}.cta{padding:5rem 2rem}.cta-content{padding:3rem 2rem}.cta-title{font-size:2.25rem}.section-heading{margin-bottom:4rem}.msg-bubble{font-size:1rem;max-width:85%}.cta,.features-modern,.tools-modern{padding:8rem 2rem}.features-title,.tools-title{font-size:2.5rem}.features-bento{gap:1.5rem;grid-template-columns:1fr}.feature-card.large,.feature-card.medium,.feature-card.wide{grid-column:span 1}.feature-card-content.horizontal{align-items:flex-start;flex-direction:column}.cta-title{font-size:2.5rem}.cta-subtitle{font-size:1.25rem}.experience{padding:2rem 2rem 3rem}.section-heading{font-size:2.5rem;margin-bottom:3rem}.coverage-section,.doc-transform,.how-it-works,.purpose-section,.tools-section,.use-cases{padding:4rem 2rem}.cases-title,.coverage-title,.doc-transform-title,.how-title,.purpose-title,.tools-section-title{font-size:2.25rem}.ai-guide-section,.interactive-section,.personalized-section{padding:3rem 1.5rem}.ai-guide-title,.interactive-title,.personalized-title{font-size:1.875rem;margin-bottom:2rem}.interactive-item{padding:1.5rem}.guide-flow{flex-direction:column}.flow-step{flex:1 1 100%;padding:1.25rem 1rem}.adaptation-grid{gap:1.25rem;grid-template-columns:1fr}.adapt-card{padding:1.5rem}.how-subtitle,.purpose-description,.tools-section-subtitle{font-size:1.1rem}.purpose-stats{flex-direction:column;gap:2rem}.purpose-visual{flex-direction:column;gap:1.5rem}.cases-grid,.features-highlight-grid,.steps-flow,.tools-grid-modern{gap:2rem;grid-template-columns:1fr}.step-arrow,.steps-flow:before{display:none}.case-card h3,.step-content h3,.tool-feature-content h3{font-size:1.35rem}.side-label{font-size:.75rem}.stat-value{font-size:2.5rem}.tool-feature-card{padding:2rem}.chat-demo-flow{padding:0 1rem}.msg-bubble{font-size:.9rem;max-width:100%;padding:.875rem 1rem}.demo-artifact-container{margin-left:0}.artifact-quiz{padding:1.25rem}.artifact-choice{font-size:.875rem;padding:.75rem 1rem}}@media (max-width:480px){.hero{min-height:65vh;padding:4rem 1.5rem 1.5rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem;margin-bottom:2rem}.hero-input{padding:1.125rem 4rem 1.125rem 1.5rem}.experience{padding:2rem 1.5rem 2.5rem}.demo-cta-btn{font-size:1rem;padding:1.125rem 2.5rem}.cta{padding:4rem 1.5rem}.cta-content{padding:2.5rem 1.5rem}.cta-title{font-size:1.875rem}.cta-subtitle{font-size:1rem;margin-bottom:2rem}.section-heading{font-size:1.75rem}.artifact-quiz{padding:1.5rem}.cta-title,.features-title,.tools-title{font-size:2rem}.cases-title,.how-title,.purpose-title,.tools-section-title,.transform-title{font-size:1.85rem}.case-card,.comparison-side,.tool-feature-card,.visual-card{padding:1.5rem}.stat-value{font-size:2rem}.step-number{font-size:1.5rem;height:56px;width:56px}.case-emoji,.feature-emoji{font-size:2.5rem}.tool-feature-icon{height:64px;width:64px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}button:focus-visible,input:focus-visible{outline:3px solid #3b82f6;outline-offset:3px}html{scroll-behavior:smooth}::selection{background:#3b82f6;color:#fff}.review-modal-overlay{align-items:center;background-color:#000000bf;bottom:0;display:flex;justify-content:center;left:0;overflow:hidden;padding:20px;position:fixed;right:0;top:0;z-index:1000}.review-modal-content{animation:reviewModalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;height:90vh;max-height:850px;max-width:950px;overflow:hidden;width:100%}.review-modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:none;display:flex;flex-shrink:0;justify-content:space-between;padding:1.75rem 2rem}.review-modal-header h2{color:#fff;font-size:1.625rem;font-weight:600;letter-spacing:-.025em;margin:0}.review-close-button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.75rem;height:40px;justify-content:center;line-height:1;padding:.5rem;transition:all .2s ease;width:40px}.review-close-button:hover{background:#ffffff4d;transform:rotate(90deg)}.review-modal-body{background:#f9fafb;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:2rem 2rem 1rem}.review-modal-body::-webkit-scrollbar{width:8px}.review-modal-body::-webkit-scrollbar-track{background:#f1f5f9}.review-modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.review-modal-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.review-title-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;padding:1.5rem}.review-title-section label{color:#374151;display:block;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.75rem;text-transform:uppercase}.review-quiz-title-input{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:1.125rem;font-weight:500;padding:.875rem 1rem;transition:all .2s ease;width:100%}.review-quiz-title-input:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.review-questions-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1rem}.review-question-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden;transition:all .2s ease}.review-question-card:hover{border-color:#667eea;box-shadow:0 6px 16px #0000001a;transform:translateY(-2px)}.review-question-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.review-question-number{color:#667eea;font-size:.95rem;font-weight:700;letter-spacing:.025em}.review-question-actions{display:flex;gap:.75rem}.review-icon-button{background:#fff;border:1.5px solid;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:600;letter-spacing:.025em;padding:.5rem 1rem;text-transform:uppercase;transition:all .2s ease}.review-icon-button.review-edit{border-color:#667eea;color:#667eea}.review-icon-button.review-edit:hover{background:#667eea;box-shadow:0 2px 4px #667eea4d;color:#fff;transform:translateY(-1px)}.review-icon-button.review-delete{border-color:#ef4444;color:#ef4444}.review-icon-button.review-delete:hover{background:#ef4444;box-shadow:0 2px 4px #ef44444d;color:#fff;transform:translateY(-1px)}.review-question-content{padding:1.5rem}.review-question-text{background:#f9fafb;border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:1rem;line-height:1.6;margin-bottom:1.5rem;min-height:100px;padding:1rem 1.25rem;resize:vertical;transition:all .2s ease;width:100%}.review-question-text:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.review-question-text:disabled{background:#f9fafb;color:#374151;cursor:not-allowed}.review-choices-list{display:flex;flex-direction:column;gap:.875rem;margin-bottom:1rem}.review-choice-item{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;gap:.875rem;padding:.875rem 1rem;position:relative;transition:all .2s ease}.review-choice-item:has(.review-choice-radio:checked){background:#f0f4ff;border-color:#667eea}.review-choice-item:hover{background:#f8fafc;border-color:#cbd5e1}.review-choice-item:has(.review-choice-radio:checked):hover{background:#e8eeff;border-color:#667eea}.review-choice-radio{accent-color:#667eea;cursor:pointer;flex-shrink:0;height:1.25rem;width:1.25rem}.review-choice-input{background:#fff;border:1px solid #e2e8f0;border-radius:6px;flex:1 1;font-size:.9375rem;padding:.625rem .875rem;transition:all .2s ease}.review-choice-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.review-choice-input:disabled{background:#f9fafb;border-color:#e2e8f0;color:#374151;cursor:not-allowed}.review-delete-choice{align-items:center;background:#fef2f2;border:none;border-radius:50%;color:#ef4444;cursor:pointer;display:flex;flex-shrink:0;font-size:1.25rem;height:28px;justify-content:center;opacity:0;padding:.25rem;transition:all .2s ease;width:28px}.review-delete-choice:hover{background:#ef4444;color:#fff}.review-choice-item:hover .review-delete-choice{opacity:1}.review-add-choice-button{align-items:center;background:#fff;border:2px dashed #cbd5e1;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem;transition:all .2s ease;width:100%}.review-add-choice-button:hover{background:#f8fafc;border-color:#667eea;border-style:solid}.review-add-question-button{align-items:center;background:#fff;border:2px dashed #cbd5e1;border-radius:12px;color:#667eea;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.625rem;justify-content:center;margin-bottom:1rem;margin-top:1.5rem;padding:1.125rem;transition:all .2s ease;width:100%}.review-add-question-button:hover{background:#f8fafc;border-color:#667eea;border-style:solid;box-shadow:0 2px 4px #667eea33;transform:translateY(-1px)}.review-modal-footer{align-items:center;background:#fff;border-top:2px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:1.5rem 2rem}.review-primary-actions{display:flex;gap:.875rem}.review-accent-button,.review-primary-button,.review-secondary-button{border:none;border-radius:8px;cursor:pointer;font-size:.9375rem;font-weight:600;padding:.875rem 1.75rem;transition:all .2s ease}.review-secondary-button{background:#f1f5f9;border:2px solid #e2e8f0;color:#64748b}.review-secondary-button:hover{background:#e2e8f0;color:#475569;transform:translateY(-1px)}.review-primary-button{background:#667eea;color:#fff}.review-primary-button:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.review-primary-button:disabled{background:#cbd5e1;cursor:not-allowed;opacity:.6}.review-accent-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.review-accent-button:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#63398a);box-shadow:0 4px 12px #764ba24d;transform:translateY(-1px)}.review-accent-button:disabled{background:#cbd5e1;cursor:not-allowed;opacity:.6}@keyframes reviewModalSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.review-modal-overlay{padding:0}.review-modal-content{border-radius:0;height:100vh;max-height:100vh;width:100%}.review-modal-header{padding:1.25rem 1rem}.review-modal-header h2{font-size:1.375rem}.review-modal-body{padding:1.5rem 1rem}.review-title-section{padding:1.25rem}.review-question-card{margin-bottom:.5rem}.review-question-header{flex-wrap:wrap;gap:.5rem;padding:.875rem 1rem}.review-question-actions{justify-content:flex-end;width:100%}.review-question-content{padding:1.25rem}.review-modal-footer{flex-direction:column-reverse;gap:.75rem;padding:1rem}.review-primary-actions{flex-direction:column;gap:.625rem;width:100%}.review-accent-button,.review-primary-button,.review-secondary-button{padding:1rem 1.5rem;width:100%}}@media (max-width:480px){.review-modal-header h2{font-size:1.25rem}.review-quiz-title-input{font-size:1rem}.review-icon-button{font-size:.75rem;padding:.4rem .75rem}.review-choice-item{padding:.75rem .875rem}.review-choice-input{font-size:.875rem}}.upgrade-modal-overlay{align-items:center;animation:upgradeModalFadeIn .25s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}@keyframes upgradeModalFadeIn{0%{opacity:0}to{opacity:1}}.upgrade-modal-wrapper{align-items:flex-end;display:flex;justify-content:center;position:relative}.upgrade-mascot-outside{animation:upgradeMascotAppear .5s ease .15s both;bottom:-20px;left:-60px;position:absolute;z-index:10}.upgrade-mascot-outside img{filter:drop-shadow(0 6px 16px rgba(0,0,0,.18));height:130px;object-fit:contain;width:130px}@keyframes upgradeMascotAppear{0%{opacity:0;transform:scale(.6) translateY(30px) rotate(-10deg)}70%{transform:scale(1.05) translateY(-5px) rotate(2deg)}to{opacity:1;transform:scale(1) translateY(0) rotate(0deg)}}.upgrade-modal-container{animation:upgradeBubbleAppear .35s ease both;background:#fff;border-radius:24px;box-shadow:0 4px 24px #667eea1f,0 16px 56px #0000001f;margin-left:50px;max-width:calc(100vw - 40px);position:relative;width:540px}@keyframes upgradeBubbleAppear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.upgrade-close-btn{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#94a3b8;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;line-height:1;position:absolute;right:16px;top:16px;transition:all .2s ease;width:36px;z-index:10}.upgrade-close-btn:hover{background:#e2e8f0;color:#64748b;transform:rotate(90deg)}.upgrade-modal-content{padding:2rem 2.5rem}.upgrade-header{margin-bottom:1.25rem;padding-right:30px;text-align:left}.upgrade-header h2{color:#1e293b;font-size:1.625rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:.5rem}.upgrade-subtitle{color:#64748b;font-size:.9375rem;line-height:1.5;margin:0}.upgrade-description{color:#475569;font-size:1rem;font-weight:600;margin:.625rem 0 0}.upgrade-benefits{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:14px;margin-bottom:1.5rem;padding:1rem 1.5rem}.upgrade-benefits ul{grid-gap:.625rem 2rem;display:grid;gap:.625rem 2rem;grid-template-columns:1fr 1fr;list-style:none;margin:0;padding:0}.upgrade-benefits li{align-items:center;display:flex;gap:.5rem}.upgrade-benefits li svg{color:#667eea;flex-shrink:0;height:18px;width:18px}.upgrade-benefits li span{color:#334155;font-size:.9375rem;font-weight:500;line-height:1.3}.upgrade-actions{align-items:center;display:flex;gap:1rem}.upgrade-primary-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 16px #667eea66;color:#fff;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.9rem 2rem;transition:all .2s ease}.upgrade-primary-btn:hover{box-shadow:0 6px 24px #667eea80;transform:translateY(-2px)}.upgrade-primary-btn:active{transform:translateY(0)}.upgrade-cancel-btn{background:#0000;border:none;color:#94a3b8;cursor:pointer;font-size:.9375rem;font-weight:500;padding:.9rem 1.25rem;transition:all .2s ease;white-space:nowrap}.upgrade-cancel-btn:hover{color:#64748b}@media (max-width:768px){.upgrade-modal-overlay{padding:16px}.upgrade-modal-wrapper{align-items:center;flex-direction:column}.upgrade-mascot-outside{bottom:auto;left:auto;margin-bottom:-40px;position:relative;z-index:10}.upgrade-mascot-outside img{height:100px;width:100px}.upgrade-modal-container{border-radius:20px;margin-left:0;max-width:100%;width:100%}.upgrade-modal-content{padding:2.5rem 1.5rem 1.5rem}.upgrade-header{padding-right:0;text-align:center}.upgrade-header h2{font-size:1.375rem}.upgrade-subtitle{font-size:.875rem}.upgrade-description{font-size:.9375rem}.upgrade-benefits{padding:1rem 1.25rem}.upgrade-benefits ul{gap:.5rem 1.5rem}.upgrade-benefits li span{font-size:.875rem}.upgrade-actions{flex-direction:column;gap:.5rem}.upgrade-primary-btn{padding:.875rem 1.5rem;width:100%}.upgrade-cancel-btn{padding:.5rem}.upgrade-close-btn{right:12px;top:12px}}@media (max-width:480px){.upgrade-modal-overlay{padding:12px}.upgrade-mascot-outside{margin-bottom:-35px}.upgrade-mascot-outside img{height:85px;width:85px}.upgrade-modal-container{border-radius:16px}.upgrade-modal-content{padding:2.25rem 1.25rem 1.25rem}.upgrade-header h2{font-size:1.25rem}.upgrade-benefits{padding:.875rem 1rem}.upgrade-benefits ul{gap:.5rem;grid-template-columns:1fr}.upgrade-benefits li svg{height:16px;width:16px}.upgrade-benefits li span{font-size:.8125rem}.upgrade-primary-btn{font-size:.9375rem;padding:.75rem 1.25rem}.upgrade-close-btn{font-size:18px;height:32px;width:32px}}:root{--qgen-primary:#3b82f6;--qgen-primary-dark:#2563eb;--qgen-accent:#8b5cf6;--qgen-accent-dark:#7c3aed;--qgen-success:#10b981;--qgen-error:#ef4444;--qgen-text:#0f172a;--qgen-text-secondary:#64748b;--qgen-text-muted:#94a3b8;--qgen-border:#e2e8f0;--qgen-bg:#fff;--qgen-bg-subtle:#f8fafc;--qgen-bg-dark:#0f172a;--qgen-gradient:linear-gradient(135deg,var(--qgen-primary) 0%,var(--qgen-accent) 100%);--qgen-radius:16px;--qgen-radius-sm:10px;--qgen-radius-lg:24px;--qgen-shadow:0 4px 24px #0f172a14;--qgen-shadow-lg:0 12px 48px #0f172a1f;--qgen-transition:cubic-bezier(0.16,1,0.3,1)}.qgen-page{background:#fff;background:var(--qgen-bg);color:#0f172a;color:var(--qgen-text);min-height:100vh;overflow-x:hidden;position:relative}.qgen-ambient{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.qgen-ambient-orb{border-radius:50%;filter:blur(120px);position:absolute}.qgen-ambient-orb--1{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:linear-gradient(135deg,var(--qgen-primary) 0,var(--qgen-accent) 100%);height:800px;opacity:.08;right:-300px;top:-400px;width:800px}.qgen-ambient-orb--2{background:#8b5cf6;background:var(--qgen-accent);bottom:-200px;height:600px;left:-200px;opacity:.06;width:600px}.qgen-hero{margin:0 auto;max-width:800px;padding:3rem 2rem 2rem;position:relative;text-align:center;z-index:1}.qgen-hero-content{animation:qgen-fadeUp .8s cubic-bezier(.16,1,.3,1) forwards;animation:qgen-fadeUp .8s var(--qgen-transition) forwards}@keyframes qgen-fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.qgen-hero-label{display:none}.qgen-hero-title{color:#0f172a;color:var(--qgen-text);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;margin:0 0 1rem}.qgen-hero-title-accent{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);-webkit-background-clip:text;background-clip:text;display:inline-block;padding-bottom:.1em}.qgen-hero-subtitle{color:#64748b;color:var(--qgen-text-secondary);font-size:1.0625rem;font-weight:400;line-height:1.6;margin:0 auto;max-width:500px}.qgen-main{margin:0 auto;max-width:800px;padding:0 1.5rem 4rem;position:relative;z-index:1}.qgen-upload-wrapper{background:#fff;background:var(--qgen-bg);border:1px solid #e2e8f0;border:1px solid var(--qgen-border);border-radius:24px;border-radius:var(--qgen-radius-lg);box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--qgen-shadow-lg);overflow:hidden;position:relative}.qgen-upload-wrapper:before{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0}.qgen-dropzone{background:linear-gradient(180deg,#f8fafc,#fff);background:linear-gradient(180deg,var(--qgen-bg-subtle) 0,var(--qgen-bg) 100%);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--qgen-border);cursor:pointer;padding:3rem 2.5rem;position:relative}.qgen-dropzone,.qgen-dropzone:before{transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--qgen-transition)}.qgen-dropzone:before{border:2px dashed #e2e8f0;border:2px dashed var(--qgen-border);border-radius:16px;border-radius:var(--qgen-radius);content:"";inset:1.25rem;pointer-events:none;position:absolute}.qgen-dropzone:hover:before{background:linear-gradient(135deg,#3b82f608,#8b5cf608);border-color:#3b82f6;border-color:var(--qgen-primary)}.qgen-dropzone--dragging:before{background:linear-gradient(135deg,#3b82f60f,#8b5cf60f);border-color:#3b82f6;border-color:var(--qgen-primary);border-style:solid;transform:scale(1.01)}.qgen-dropzone--has-file{background:linear-gradient(180deg,#3b82f60a,#fff);background:linear-gradient(180deg,#3b82f60a 0,var(--qgen-bg) 100%)}.qgen-dropzone--has-file:before{background:#3b82f605;border-color:#3b82f6;border-color:var(--qgen-primary);border-style:solid}.qgen-dropzone-content{align-items:center;display:flex;flex-direction:column;gap:.875rem;position:relative;z-index:1}.qgen-dropzone-icon{align-items:center;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:50%;color:#3b82f6;color:var(--qgen-primary);display:flex;height:64px;justify-content:center;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--qgen-transition);width:64px}.qgen-dropzone-icon svg{height:28px;width:28px}.qgen-dropzone:hover .qgen-dropzone-icon{background:linear-gradient(135deg,#3b82f626,#8b5cf626);box-shadow:0 8px 24px #3b82f633;transform:translateY(-4px) scale(1.05)}.qgen-dropzone--dragging .qgen-dropzone-icon{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);color:#fff;transform:scale(1.1)}.qgen-dropzone-text{text-align:center}.qgen-dropzone-primary{color:#0f172a;color:var(--qgen-text);display:block;font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.qgen-dropzone-secondary{color:#94a3b8;color:var(--qgen-text-muted);display:block;font-size:.9rem}.qgen-browse-btn{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);border-radius:10px;border-radius:var(--qgen-radius-sm);box-shadow:0 4px 16px #3b82f659;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;margin-top:.25rem;padding:.875rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-browse-btn:hover{box-shadow:0 8px 28px #3b82f673;transform:translateY(-2px)}.qgen-browse-btn input{display:none}.qgen-formats{display:flex;flex-wrap:wrap;gap:.375rem;justify-content:center;margin-top:.5rem}.qgen-formats span{background:#fff;background:var(--qgen-bg);border:1px solid #e2e8f0;border:1px solid var(--qgen-border);border-radius:4px;color:#94a3b8;color:var(--qgen-text-muted);font-size:.65rem;font-weight:600;letter-spacing:.05em;padding:.25rem .5rem;transition:all .2s}.qgen-formats span:hover{border-color:#3b82f6;border-color:var(--qgen-primary);color:#3b82f6;color:var(--qgen-primary)}.qgen-file-display{align-items:center;background:linear-gradient(135deg,#3b82f614,#8b5cf60d);border:1px solid #3b82f633;border-radius:10px;border-radius:var(--qgen-radius-sm);display:flex;gap:1rem;margin:0 auto;max-width:400px;padding:1rem 1.5rem;position:relative;width:100%;z-index:1}.qgen-file-icon{align-items:center;background:linear-gradient(135deg,#3b82f626,#8b5cf61a);border-radius:10px;color:#3b82f6;color:var(--qgen-primary);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.qgen-file-info{flex:1 1;min-width:0}.qgen-file-name{color:#0f172a;color:var(--qgen-text);display:block;font-size:.95rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qgen-file-size{color:#64748b;color:var(--qgen-text-secondary);display:block;font-size:.8rem;margin-top:.125rem}.qgen-file-remove{background:none;border:none;border-radius:8px;color:#94a3b8;color:var(--qgen-text-muted);cursor:pointer;flex-shrink:0;padding:.5rem;transition:all .2s}.qgen-file-remove:hover{background:#ef44441a;color:#ef4444;color:var(--qgen-error)}.qgen-options{padding:1.75rem 2.5rem}.qgen-options-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.qgen-options-label{color:#64748b;color:var(--qgen-text-secondary);font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.qgen-upgrade-hint{align-items:center;background:linear-gradient(135deg,#8b5cf61f,#fbbf241f);border:1px solid #8b5cf640;border-radius:100px;color:#8b5cf6;color:var(--qgen-accent);cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:700;gap:.4rem;padding:.4rem .875rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-upgrade-hint:hover{background:linear-gradient(135deg,#8b5cf62e,#fbbf242e);transform:translateY(-1px)}.qgen-count-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem}.qgen-count-btn{align-items:center;background:#fff;background:var(--qgen-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--qgen-border);border-radius:10px;border-radius:var(--qgen-radius-sm);color:#0f172a;color:var(--qgen-text);cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.25rem;justify-content:center;min-width:52px;padding:.625rem 1rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-count-btn:hover:not(:disabled):not(.qgen-count-btn--active){border-color:#3b82f6;border-color:var(--qgen-primary);box-shadow:0 4px 12px #3b82f626;color:#3b82f6;color:var(--qgen-primary);transform:translateY(-3px)}.qgen-count-btn--active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);border-color:#0000;box-shadow:0 6px 20px #3b82f666;color:#fff;transform:translateY(-2px)}.qgen-count-btn--locked{cursor:not-allowed;opacity:.45}.qgen-count-btn--custom{color:#94a3b8;color:var(--qgen-text-muted)}.qgen-lock-icon{opacity:.7}.qgen-custom-input{align-items:center;display:flex;flex-wrap:wrap;gap:.875rem;justify-content:center;margin-bottom:1.75rem}.qgen-custom-input input{border:2px solid #e2e8f0;border:2px solid var(--qgen-border);border-radius:10px;border-radius:var(--qgen-radius-sm);font-size:1.125rem;font-weight:700;padding:.875rem 1rem;text-align:center;transition:all .2s;width:100px}.qgen-custom-input input:focus{border-color:#3b82f6;border-color:var(--qgen-primary);box-shadow:0 0 0 4px #3b82f61a;outline:none}.qgen-custom-input span{font-weight:500}.qgen-back-btn,.qgen-custom-input span{color:#64748b;color:var(--qgen-text-secondary)}.qgen-back-btn{background:none;border:2px solid #e2e8f0;border:2px solid var(--qgen-border);border-radius:10px;border-radius:var(--qgen-radius-sm);cursor:pointer;padding:.75rem;transition:all .2s}.qgen-back-btn:hover{border-color:#64748b;border-color:var(--qgen-text-secondary);color:#0f172a;color:var(--qgen-text)}.qgen-generate-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);border:none;border-radius:10px;border-radius:var(--qgen-radius-sm);box-shadow:0 4px 16px #3b82f659;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;overflow:hidden;padding:1rem 2rem;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--qgen-transition);width:100%}.qgen-generate-btn:before{background:linear-gradient(135deg,#ffffff26,#0000 50%);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s}.qgen-generate-btn:hover:not(:disabled):before{opacity:1}.qgen-generate-btn:hover:not(:disabled){box-shadow:0 12px 36px #3b82f680;transform:translateY(-3px)}.qgen-generate-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.qgen-spinner{animation:qgen-spin .8s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:22px;width:22px}@keyframes qgen-spin{to{transform:rotate(1turn)}}.qgen-message{border-radius:10px;border-radius:var(--qgen-radius-sm);font-size:.9rem;font-weight:600;margin-top:1.25rem;padding:1rem 1.25rem;text-align:center}.qgen-message--error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444;color:var(--qgen-error)}.qgen-message--success{background:#10b9811a;border:1px solid #10b98133;color:#10b981;color:var(--qgen-success)}.qgen-success{animation:qgen-slideUp .5s cubic-bezier(.16,1,.3,1);animation:qgen-slideUp .5s var(--qgen-transition);background:linear-gradient(135deg,#fff,#3b82f605);background:linear-gradient(135deg,var(--qgen-bg) 0,#3b82f605 100%);border:1px solid #e2e8f0;border:1px solid var(--qgen-border);border-radius:24px;border-radius:var(--qgen-radius-lg);box-shadow:0 4px 24px #0f172a14;box-shadow:var(--qgen-shadow);margin-top:1.5rem;overflow:hidden;padding:1.75rem 2rem;position:relative}.qgen-success:before{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);content:"";height:3px;left:0;position:absolute;right:0;top:0}@keyframes qgen-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.qgen-success-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.qgen-success-check{align-items:center;animation:qgen-pop .5s cubic-bezier(.16,1,.3,1);animation:qgen-pop .5s var(--qgen-transition);background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);border-radius:50%;box-shadow:0 4px 12px #3b82f64d;color:#fff;display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.qgen-success-check svg{height:20px;width:20px}@keyframes qgen-pop{0%{transform:scale(0)}50%{transform:scale(1.15)}to{transform:scale(1)}}.qgen-success-text h2{color:#0f172a;color:var(--qgen-text);font-size:1.25rem;font-weight:700;margin:0 0 .125rem}.qgen-success-text p{color:#64748b;color:var(--qgen-text-secondary);font-size:.9rem;margin:0}.qgen-actions{grid-gap:.625rem;display:grid;gap:.625rem;grid-template-columns:repeat(2,1fr)}.qgen-action{align-items:center;border:none;border-radius:10px;border-radius:var(--qgen-radius-sm);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.375rem;justify-content:center;padding:.75rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-action--primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);box-shadow:0 2px 8px #3b82f64d;color:#fff}.qgen-action--primary:hover{box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.qgen-action--secondary{background:#fff;background:var(--qgen-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--qgen-border);color:#0f172a;color:var(--qgen-text)}.qgen-action--secondary:hover:not(.qgen-action--locked){background:#3b82f60a;border-color:#3b82f6;border-color:var(--qgen-primary);color:#3b82f6;color:var(--qgen-primary);transform:translateY(-2px)}.qgen-action--locked{cursor:not-allowed;opacity:.5}.qgen-lock-badge{margin-left:.25rem;opacity:.7}.qgen-upgrade-banner{align-items:center;background:linear-gradient(135deg,#8b5cf61a,#fbbf2414);border:1px solid #8b5cf633;border-radius:10px;border-radius:var(--qgen-radius-sm);display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin-top:1.25rem;padding:1rem 1.25rem}.qgen-upgrade-content{align-items:center;color:#8b5cf6;color:var(--qgen-accent);display:flex;flex:1 1;gap:.5rem;min-width:180px}.qgen-upgrade-content span{color:#64748b;color:var(--qgen-text-secondary);font-size:.85rem;font-weight:500}.qgen-upgrade-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);background:linear-gradient(135deg,var(--qgen-accent) 0,var(--qgen-accent-dark) 100%);border:none;border-radius:10px;border-radius:var(--qgen-radius-sm);box-shadow:0 4px 12px #8b5cf64d;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.625rem 1.25rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-upgrade-btn:hover{box-shadow:0 8px 24px #8b5cf673;transform:translateY(-2px)}.qgen-process{background:linear-gradient(180deg,#f8fafc,#fff);background:linear-gradient(180deg,var(--qgen-bg-subtle) 0,var(--qgen-bg) 100%);overflow:hidden;padding:6rem 2rem 8rem;position:relative;z-index:1}.qgen-process:before{background:radial-gradient(circle,#3b82f608 0,#0000 70%);content:"";height:800px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:800px}.qgen-process-flow{display:flex;flex-direction:column;gap:0;margin:0 auto;max-width:900px}.qgen-flow-item{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:auto 1fr auto;padding:2rem 0;position:relative}.qgen-flow-item--left{text-align:left}.qgen-flow-item--right{text-align:right}.qgen-flow-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(4rem,10vw,7rem);font-weight:900;line-height:1;opacity:.15;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--qgen-transition);-webkit-user-select:none;user-select:none}.qgen-flow-item:hover .qgen-flow-number{opacity:.35;transform:scale(1.05)}.qgen-flow-content{max-width:340px}.qgen-flow-item--right .qgen-flow-content{margin-left:auto}.qgen-flow-content h3{color:#0f172a;color:var(--qgen-text);font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .625rem;transition:color .3s}.qgen-flow-item:hover .qgen-flow-content h3{color:#3b82f6;color:var(--qgen-primary)}.qgen-flow-content p{color:#64748b;color:var(--qgen-text-secondary);font-size:1rem;line-height:1.7;margin:0}.qgen-flow-visual{align-items:center;display:flex;height:100px;justify-content:center;width:100px}.qgen-flow-icon{color:#94a3b8;color:var(--qgen-text-muted);height:80px;opacity:.4;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--qgen-transition);width:80px}.qgen-flow-item:hover .qgen-flow-icon{color:#3b82f6;color:var(--qgen-primary);opacity:.7;transform:scale(1.1)}.qgen-flow-connector{display:flex;height:60px;justify-content:center;opacity:.4}.qgen-flow-connector svg{height:100%;width:40px}.qgen-value{margin:0 auto;max-width:1100px;padding:6rem 2rem 8rem;position:relative;z-index:1}.qgen-value-header{margin-bottom:4rem;text-align:center}.qgen-value-header h2{color:#0f172a;color:var(--qgen-text);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;margin:0}.qgen-value-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-auto-rows:minmax(180px,auto);grid-template-columns:repeat(12,1fr)}.qgen-value-card{background:#fff;background:var(--qgen-bg);border:1px solid #e2e8f0;border:1px solid var(--qgen-border);border-radius:24px;border-radius:var(--qgen-radius-lg);grid-column:span 6;overflow:hidden;position:relative;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--qgen-transition)}.qgen-value-card:hover{border-color:#0000;box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--qgen-shadow-lg);transform:translateY(-8px)}.qgen-value-card-blob{border-radius:50%;filter:blur(60px);height:200px;opacity:0;pointer-events:none;position:absolute;transition:all .6s cubic-bezier(.16,1,.3,1);transition:all .6s var(--qgen-transition);width:200px}.qgen-value-card:first-child .qgen-value-card-blob{background:#3b82f6;background:var(--qgen-primary);right:-50px;top:-50px}.qgen-value-card:nth-child(2) .qgen-value-card-blob{background:#8b5cf6;background:var(--qgen-accent);bottom:-50px;left:-50px}.qgen-value-card:nth-child(3) .qgen-value-card-blob{background:#10b981;left:-50px;top:-50px}.qgen-value-card:nth-child(4) .qgen-value-card-blob{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:linear-gradient(135deg,var(--qgen-primary),var(--qgen-accent));bottom:-50px;right:-50px}.qgen-value-card:hover .qgen-value-card-blob{opacity:.15;transform:scale(1.2)}.qgen-value-card-inner{display:flex;flex-direction:column;height:100%;padding:2rem;position:relative;z-index:1}.qgen-value-card-icon{align-items:center;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:14px;display:flex;height:52px;justify-content:center;margin-bottom:1.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--qgen-transition);width:52px}.qgen-value-card-icon svg{color:#3b82f6;color:var(--qgen-primary);height:26px;transition:all .3s;width:26px}.qgen-value-card:hover .qgen-value-card-icon{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);transform:scale(1.1) rotate(-5deg)}.qgen-value-card:hover .qgen-value-card-icon svg{color:#fff}.qgen-value-card h3{color:#0f172a;color:var(--qgen-text);font-size:1.375rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .75rem;transition:color .3s}.qgen-value-card:hover h3{color:#3b82f6;color:var(--qgen-primary)}.qgen-value-card p{color:#64748b;color:var(--qgen-text-secondary);flex:1 1;font-size:1rem;line-height:1.7;margin:0}.qgen-value-card--featured{grid-column:span 7;grid-row:span 2}.qgen-value-card--featured .qgen-value-card-inner{padding:2.5rem}.qgen-value-card--featured .qgen-value-card-icon{border-radius:18px;height:64px;width:64px}.qgen-value-card--featured .qgen-value-card-icon svg{height:32px;width:32px}.qgen-value-card--featured h3{font-size:1.75rem}.qgen-value-card--featured p{font-size:1.0625rem;max-width:400px}.qgen-value-card--wide{grid-column:span 12}.qgen-value-card--wide .qgen-value-card-inner{align-items:center;flex-direction:row;gap:2rem}.qgen-value-card--wide .qgen-value-card-icon{flex-shrink:0;margin-bottom:0}.qgen-value-card--wide h3{margin-bottom:.5rem}.qgen-value-card:nth-child(2),.qgen-value-card:nth-child(3){grid-column:span 5}.qgen-faq{background:linear-gradient(180deg,#fff,#f8fafc);background:linear-gradient(180deg,var(--qgen-bg) 0,var(--qgen-bg-subtle) 100%);padding:6rem 2rem;position:relative;z-index:1}.qgen-faq-header{margin:0 auto 3.5rem;max-width:500px;text-align:center}.qgen-faq-eyebrow{align-items:center;background:#3b82f61a;border-radius:100px;color:#3b82f6;color:var(--qgen-primary);display:inline-flex;font-size:.8rem;font-weight:700;gap:.5rem;letter-spacing:.15em;margin-bottom:1rem;padding:.5rem 1rem;text-transform:uppercase}.qgen-faq-header h2{color:#0f172a;color:var(--qgen-text);font-size:clamp(2rem,5vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin:0}.qgen-faq-list{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:760px}.qgen-faq-item{background:#fff;background:var(--qgen-bg);border:1px solid #e2e8f0;border:1px solid var(--qgen-border);border-radius:16px;border-radius:var(--qgen-radius);overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-faq-item:hover{border-color:#3b82f64d;box-shadow:0 4px 16px #3b82f60f}.qgen-faq-item--open{border-color:#3b82f6;border-color:var(--qgen-primary);box-shadow:0 8px 32px #3b82f61f}.qgen-faq-trigger{align-items:center;background:none;border:none;color:#0f172a;color:var(--qgen-text);cursor:pointer;display:flex;font-size:1.0625rem;font-weight:700;gap:1rem;justify-content:space-between;padding:1.375rem 1.5rem;text-align:left;transition:all .2s;width:100%}.qgen-faq-trigger:hover{color:#3b82f6;color:var(--qgen-primary)}.qgen-faq-trigger svg{color:#94a3b8;color:var(--qgen-text-muted);flex-shrink:0;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-faq-item--open .qgen-faq-trigger svg{color:#3b82f6;color:var(--qgen-primary);transform:rotate(45deg)}.qgen-faq-content{max-height:0;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--qgen-transition)}.qgen-faq-item--open .qgen-faq-content{max-height:400px}.qgen-faq-content p{color:#64748b;color:var(--qgen-text-secondary);font-size:1rem;line-height:1.75;margin:0;padding:0 1.5rem 1.5rem}.qgen-cta{align-items:center;background:#f8fafc;background:var(--qgen-bg-subtle);border-top:1px solid #e2e8f0;border-top:1px solid var(--qgen-border);display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:4rem 2rem;position:relative;z-index:1}.qgen-cta p{color:#0f172a;color:var(--qgen-text);font-size:1.25rem;font-weight:600;margin:0}.qgen-cta-btn{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--qgen-gradient);border:none;border-radius:10px;border-radius:var(--qgen-radius-sm);box-shadow:0 4px 16px #3b82f64d;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:1rem 2.5rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--qgen-transition)}.qgen-cta-btn:hover{box-shadow:0 8px 24px #3b82f666;transform:translateY(-2px)}@media (max-width:900px){.qgen-flow-item{gap:1rem;grid-template-columns:1fr;text-align:center!important}.qgen-flow-item--right .qgen-flow-content{margin-left:0}.qgen-flow-content{max-width:100%;order:2}.qgen-flow-number{font-size:4rem;order:1}.qgen-flow-visual{margin:0 auto;order:3}.qgen-flow-connector{height:40px}.qgen-value-grid{grid-template-columns:repeat(2,1fr)}.qgen-value-card--featured{grid-column:span 2;grid-row:span 1}.qgen-value-card:nth-child(2),.qgen-value-card:nth-child(3){grid-column:span 1}.qgen-value-card--wide{grid-column:span 2}}@media (max-width:768px){.qgen-page{padding-top:3.5rem}.qgen-hero{padding:4rem 1.5rem 2.5rem}.qgen-hero-subtitle{font-size:1.0625rem}.qgen-main{padding:0 1.25rem 4rem}.qgen-dropzone{padding:3rem 1.5rem}.qgen-dropzone:before{inset:.75rem}.qgen-dropzone-icon{height:60px;width:60px}.qgen-options,.qgen-success{padding:2rem 1.5rem}.qgen-success-header{flex-direction:column;text-align:center}.qgen-actions{grid-template-columns:1fr}.qgen-upgrade-banner{flex-direction:column;text-align:center}.qgen-upgrade-btn{width:100%}.qgen-process{padding:4rem 1.5rem 5rem}.qgen-flow-number{font-size:3.5rem}.qgen-flow-content h3{font-size:1.25rem}.qgen-flow-content p{font-size:.95rem}.qgen-flow-visual{height:80px;width:80px}.qgen-flow-icon{height:60px;width:60px}.qgen-value{padding:4rem 1.5rem}.qgen-value-grid{gap:1.25rem;grid-template-columns:1fr}.qgen-value-card,.qgen-value-card--featured,.qgen-value-card--wide,.qgen-value-card:nth-child(2),.qgen-value-card:nth-child(3){grid-column:span 1;grid-row:span 1}.qgen-value-card--featured .qgen-value-card-inner{padding:2rem}.qgen-value-card--featured h3{font-size:1.375rem}.qgen-value-card--wide .qgen-value-card-inner{align-items:flex-start;flex-direction:column}.qgen-value-card--wide .qgen-value-card-icon{margin-bottom:1.25rem}.qgen-value-card:hover{transform:translateY(-4px)}.qgen-faq{padding:4rem 1.5rem}.qgen-faq-trigger{font-size:1rem;padding:1.125rem 1.25rem}.qgen-faq-content p{font-size:.95rem;padding:0 1.25rem 1.25rem}.qgen-cta{flex-direction:column;gap:1.5rem;padding:3rem 1.5rem;text-align:center}.qgen-cta p{font-size:1.125rem}.qgen-cta-btn{max-width:280px;width:100%}}@media (max-width:480px){.qgen-hero{padding:3rem 1rem 2rem}.qgen-hero-title{font-size:2.25rem}.qgen-dropzone{padding:2rem 1rem}.qgen-dropzone:before{inset:.5rem}.qgen-dropzone-primary{font-size:1.125rem}.qgen-browse-btn{font-size:.95rem;padding:.875rem 1.75rem}.qgen-count-btn{font-size:.95rem;min-width:50px;padding:.75rem 1rem}.qgen-generate-btn{font-size:1.0625rem;padding:1.125rem 1.5rem}.qgen-success-check{height:52px;width:52px}.qgen-success-check svg{height:26px;width:26px}.qgen-success-text h2{font-size:1.375rem}.qgen-process-title,.qgen-value-header h2{font-size:1.75rem}.qgen-value-card h3{font-size:1.25rem}.qgen-value-card p{font-size:.95rem}.qgen-value-card-inner{padding:1.5rem}.qgen-value-card-icon{height:44px;margin-bottom:1rem;width:44px}.qgen-value-card-icon svg{height:22px;width:22px}.qgen-faq-header h2{font-size:1.75rem}}.qgen-step{animation:qgen-fadeUp .6s cubic-bezier(.16,1,.3,1) forwards;animation:qgen-fadeUp .6s var(--qgen-transition) forwards;opacity:0}.qgen-step:nth-child(2){animation-delay:.1s}.qgen-step:nth-child(3){animation-delay:.2s}.qgen-step:nth-child(4){animation-delay:.3s}.qgen-value-card{animation:qgen-fadeUp .6s cubic-bezier(.16,1,.3,1) forwards;animation:qgen-fadeUp .6s var(--qgen-transition) forwards;opacity:0}.qgen-value-card:first-child{animation-delay:.1s}.qgen-value-card:nth-child(2){animation-delay:.2s}.qgen-value-card:nth-child(3){animation-delay:.25s}.qgen-value-card:nth-child(4){animation-delay:.35s}.qgen-faq-item{animation:qgen-fadeUp .5s cubic-bezier(.16,1,.3,1) forwards;animation:qgen-fadeUp .5s var(--qgen-transition) forwards;opacity:0}.qgen-faq-item:first-child{animation-delay:.1s}.qgen-faq-item:nth-child(2){animation-delay:.15s}.qgen-faq-item:nth-child(3){animation-delay:.2s}.qgen-faq-item:nth-child(4){animation-delay:.25s}.qgen-faq-item:nth-child(5){animation-delay:.3s}@font-face{font-display:block;font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_AMS-Regular.73ea273a72f4aca30ca5.woff2) format("woff2"),url(/static/media/KaTeX_AMS-Regular.d562e886c52f12660a41.woff) format("woff"),url(/static/media/KaTeX_AMS-Regular.853be92419a6c3766b9a.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/static/media/KaTeX_Caligraphic-Bold.a1abf90dfd72792a577a.woff2) format("woff2"),url(/static/media/KaTeX_Caligraphic-Bold.d757c535a2e5902f1325.woff) format("woff"),url(/static/media/KaTeX_Caligraphic-Bold.7489a2fbfb9bfe704420.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Caligraphic-Regular.d6484fce1ef428d5bd94.woff2) format("woff2"),url(/static/media/KaTeX_Caligraphic-Regular.db074fa22cf224af93d7.woff) format("woff"),url(/static/media/KaTeX_Caligraphic-Regular.7e873d3833eb108a0758.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/static/media/KaTeX_Fraktur-Bold.931d67ea207ab37ee693.woff2) format("woff2"),url(/static/media/KaTeX_Fraktur-Bold.354501bac435c3264834.woff) format("woff"),url(/static/media/KaTeX_Fraktur-Bold.4c761b3711973ab04edf.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Fraktur-Regular.172d3529b26f8cedef6b.woff2) format("woff2"),url(/static/media/KaTeX_Fraktur-Regular.6fdf0ac577be0ba82a4c.woff) format("woff"),url(/static/media/KaTeX_Fraktur-Regular.ed305b5434865e06ffde.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/static/media/KaTeX_Main-Bold.39890742bc957b368704.woff2) format("woff2"),url(/static/media/KaTeX_Main-Bold.0c3b8929d377c0e9b2f3.woff) format("woff"),url(/static/media/KaTeX_Main-Bold.8169508bf58f8bd92ad8.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/static/media/KaTeX_Main-BoldItalic.20f389c4120be058d80a.woff2) format("woff2"),url(/static/media/KaTeX_Main-BoldItalic.428978dc7837d46de091.woff) format("woff"),url(/static/media/KaTeX_Main-BoldItalic.828abcb200061cffbaae.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/static/media/KaTeX_Main-Italic.fe2176f79edaa716e621.woff2) format("woff2"),url(/static/media/KaTeX_Main-Italic.fd947498bc16392e76c2.woff) format("woff"),url(/static/media/KaTeX_Main-Italic.fa675e5e4bec9eb250b6.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Main-Regular.f650f111a3b890d116f1.woff2) format("woff2"),url(/static/media/KaTeX_Main-Regular.4f35fbcc9ee8614c2bcc.woff) format("woff"),url(/static/media/KaTeX_Main-Regular.9eba1d77abcf2aa6e94e.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/static/media/KaTeX_Math-BoldItalic.dcbcbd93bac0470b462d.woff2) format("woff2"),url(/static/media/KaTeX_Math-BoldItalic.3f07ed67f06c720120ce.woff) format("woff"),url(/static/media/KaTeX_Math-BoldItalic.bf2d440b3a42ea78a998.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/static/media/KaTeX_Math-Italic.6d3d25f4820d0da8f01f.woff2) format("woff2"),url(/static/media/KaTeX_Math-Italic.96759856b4e70f3a8338.woff) format("woff"),url(/static/media/KaTeX_Math-Italic.8a5f936332e8028c7278.ttf) format("truetype")}@font-face{font-display:block;font-family:"KaTeX_SansSerif";font-style:normal;font-weight:700;src:url(/static/media/KaTeX_SansSerif-Bold.95591a929f0d32aa282a.woff2) format("woff2"),url(/static/media/KaTeX_SansSerif-Bold.b9cd458ac6d5889ff9c3.woff) format("woff"),url(/static/media/KaTeX_SansSerif-Bold.5b49f4993ae22d7975b4.ttf) format("truetype")}@font-face{font-display:block;font-family:"KaTeX_SansSerif";font-style:italic;font-weight:400;src:url(/static/media/KaTeX_SansSerif-Italic.7d393d382f3e7fb1c637.woff2) format("woff2"),url(/static/media/KaTeX_SansSerif-Italic.8d593cfaa96238d5e2f8.woff) format("woff"),url(/static/media/KaTeX_SansSerif-Italic.b257a18c016f37ee4543.ttf) format("truetype")}@font-face{font-display:block;font-family:"KaTeX_SansSerif";font-style:normal;font-weight:400;src:url(/static/media/KaTeX_SansSerif-Regular.cd5e231e0cc53b2cb2c0.woff2) format("woff2"),url(/static/media/KaTeX_SansSerif-Regular.02271ec5cb9f5b4588ac.woff) format("woff"),url(/static/media/KaTeX_SansSerif-Regular.2f7bc363fc5424ebda59.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Script-Regular.c81d1b2a4b75d3eded60.woff2) format("woff2"),url(/static/media/KaTeX_Script-Regular.073b3402d036714b4370.woff) format("woff"),url(/static/media/KaTeX_Script-Regular.fc9ba5249878cd8f8d88.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size1-Regular.6eec866c69313624be60.woff2) format("woff2"),url(/static/media/KaTeX_Size1-Regular.0108e89c9003e8c14ea3.woff) format("woff"),url(/static/media/KaTeX_Size1-Regular.6de7d4b539221a49e9e2.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size2-Regular.2960900c4f271311eb36.woff2) format("woff2"),url(/static/media/KaTeX_Size2-Regular.3a99e70aee4076660d38.woff) format("woff"),url(/static/media/KaTeX_Size2-Regular.57f5c1837853986ea1db.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size3-Regular.e1951519f6f0596f7356.woff2) format("woff2"),url(/static/media/KaTeX_Size3-Regular.7947224e8a9914fa332b.woff) format("woff"),url(/static/media/KaTeX_Size3-Regular.8d6b6822586eea3d3b20.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Size4-Regular.e418bf257af1052628d8.woff2) format("woff2"),url(/static/media/KaTeX_Size4-Regular.aeffd8025cba3647f1a6.woff) format("woff"),url(/static/media/KaTeX_Size4-Regular.4ad7c7e8bb8d10a34bb7.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/static/media/KaTeX_Typewriter-Regular.c295e7f71970f03c0549.woff2) format("woff2"),url(/static/media/KaTeX_Typewriter-Regular.4c6b94fd1d07f8beff7c.woff) format("woff"),url(/static/media/KaTeX_Typewriter-Regular.c5c02d763c89380dcb4e.ttf) format("truetype")}.katex{font:normal 1.21em KaTeX_Main,Times New Roman,serif;line-height:1.2;text-indent:0;text-rendering:auto}.katex *{-ms-high-contrast-adjust:none!important;border-color:currentColor}.katex .katex-version:after{content:"0.16.25"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.katex .katex-html>.newline{display:block}.katex .base{position:relative;white-space:nowrap;width:-webkit-min-content;width:min-content}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;display:inline-table;table-layout:fixed}.katex .vlist-r{display:table-row}.katex .vlist{display:table-cell;position:relative;vertical-align:bottom}.katex .vlist>span{display:block;height:0;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{overflow:hidden;width:0}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{display:table-cell;font-size:1px;min-width:2px;vertical-align:bottom;width:2px}.katex .vbox{align-items:baseline;display:inline-flex;flex-direction:column}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{display:inline-flex;flex-direction:row}.katex .thinbox{max-width:0;width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .clap,.katex .llap,.katex .rlap{position:relative;width:0}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline{border-bottom-style:dashed;display:inline-block;width:100%}.katex .sqrt>.root{margin-left:.2777777778em;margin-right:-.5555555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.1666666667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.6666666667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.4566666667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.1466666667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.7142857143em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.8571428571em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.1428571429em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.2857142857em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.4285714286em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.7142857143em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.0571428571em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.4685714286em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.9628571429em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.5542857143em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.7777777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.8888888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.1111111111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.3044444444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.7644444444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.5833333333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.7283333333em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.0733333333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.4861111111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.4402777778em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.7277777778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.2893518519em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.4050925926em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462962963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.5208333333em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.5787037037em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.2002314815em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.4398148148em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.2410800386em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.2892960463em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512054em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.3857280617em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.4339440694em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.4821600771em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.5785920926em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.6943105111em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.8331726133em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.1996142719em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.2009646302em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.2411575563em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.2813504823em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.3215434084em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.3617363344em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.4019292605em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.4823151125em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778135em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.6945337621em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.8336012862em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{display:inline-block;width:.12em}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{display:inline-block;min-width:1px}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;fill-rule:nonzero;fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;display:block;height:inherit;position:absolute;width:100%}.katex svg path{stroke:none}.katex img{border-style:none;max-height:none;max-width:none;min-height:0;min-width:0}.katex .stretchy{display:block;overflow:hidden;position:relative;width:100%}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{overflow:hidden;position:relative;width:100%}.katex .halfarrow-left{left:0;overflow:hidden;position:absolute;width:50.2%}.katex .halfarrow-right{overflow:hidden;position:absolute;right:0;width:50.2%}.katex .brace-left{left:0;overflow:hidden;position:absolute;width:25.1%}.katex .brace-center{left:25%;overflow:hidden;position:absolute;width:50%}.katex .brace-right{overflow:hidden;position:absolute;right:0;width:25.1%}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{border:.04em solid;box-sizing:border-box}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{border-right:.049em solid;border-top:.049em solid;box-sizing:border-box;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{display:inline-block;position:absolute;right:calc(50% + .3em);text-align:left}.katex .cd-label-right{display:inline-block;left:calc(50% + .3em);position:absolute;text-align:right}.katex-display{display:block;margin:1em 0;text-align:center}.katex-display>.katex{display:block;text-align:center;white-space:nowrap}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{padding-left:2em;text-align:left}body{counter-reset:katexEqnNo mmlEqnNo}.generator-flashcard-viewer{align-items:center;display:flex;flex-direction:column;gap:1.5rem;margin:0;max-width:100%;padding:0;width:100%}.generator-flashcard-title{color:#1e293b;font-size:1.125rem;font-weight:700;margin:0;text-align:center}.generator-flashcard-wrapper{margin:0 auto;max-width:650px;perspective:1200px;width:100%}.generator-flashcard{aspect-ratio:16/10;cursor:pointer;position:relative;transform-style:preserve-3d;-webkit-transform-style:preserve-3d;width:100%;will-change:transform}.generator-flashcard.flipped .generator-flashcard-inner{transform:rotateY(180deg)}.generator-flashcard-inner{height:100%;position:relative;transform-style:preserve-3d;-webkit-transform-style:preserve-3d;transition:transform .5s cubic-bezier(.4,0,.2,1);-webkit-transition:transform .5s cubic-bezier(.4,0,.2,1);width:100%;will-change:transform}.generator-flashcard-back,.generator-flashcard-front{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;align-items:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:24px;box-shadow:0 24px 48px #00000014,0 12px 24px #0000000f,0 0 0 1px #00000005;display:flex;flex-direction:column;height:100%;justify-content:center;overflow:hidden;padding:2.5rem 2rem;position:absolute;text-align:center;transform:translateZ(0);-webkit-transform:translateZ(0);transition:box-shadow .3s ease;width:100%}.generator-flashcard:hover .generator-flashcard-back,.generator-flashcard:hover .generator-flashcard-front{box-shadow:0 32px 64px #0000001f,0 16px 32px #00000014,0 0 0 1px #00000008}.generator-flashcard-front{background:#fff;color:#1e293b;transform:rotateY(0deg)}.generator-flashcard-back{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e293b;transform:rotateY(180deg)}.generator-flashcard-label{color:#3b82f6;flex-shrink:0;font-size:.7rem;font-weight:800;letter-spacing:2.5px;margin-bottom:1.5rem;text-transform:uppercase}.generator-flashcard-content{word-wrap:break-word;align-items:center;display:flex;flex-direction:column;flex-grow:1;font-size:1.2rem;font-weight:600;-webkit-hyphens:auto;hyphens:auto;justify-content:center;line-height:1.6;overflow:hidden;overflow-wrap:break-word;padding:0 1rem;width:100%}.generator-flashcard-hint{color:#94a3b8;flex-shrink:0;font-size:.75rem;font-weight:500;margin-top:1.5rem;opacity:.7}.generator-flashcard-controls{align-items:center;display:flex;gap:1.5rem;justify-content:center;margin:0 auto;max-width:650px;width:100%}.generator-flashcard-nav-button{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000a;color:#475569;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.875rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.generator-flashcard-nav-button:hover:not(:disabled){background:linear-gradient(135deg,#fff,#f8fafc);border-color:#3b82f6;box-shadow:0 4px 16px #3b82f626;color:#3b82f6;transform:translateY(-2px)}.generator-flashcard-nav-button:active:not(:disabled){transform:translateY(0)}.generator-flashcard-nav-button:disabled{cursor:not-allowed;opacity:.3;transform:none}.generator-flashcard-nav-button svg{height:18px;width:18px}.generator-flashcard-counter{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #3b82f633;border-radius:20px;color:#3b82f6;font-size:.95rem;font-weight:700;min-width:80px;padding:.625rem 1.25rem;text-align:center}@media (max-width:768px){.generator-flashcard-viewer{gap:1rem}.generator-flashcard-wrapper{max-width:100%}.generator-flashcard{aspect-ratio:4/3}.generator-flashcard-back,.generator-flashcard-front{-webkit-font-smoothing:subpixel-antialiased;-moz-osx-font-smoothing:auto;border-radius:20px;padding:1.75rem 1.5rem}.generator-flashcard-content{-webkit-font-smoothing:subpixel-antialiased;font-size:1rem;padding:0 .5rem}.generator-flashcard-label{font-size:.65rem;margin-bottom:1rem}.generator-flashcard-hint{font-size:.7rem;margin-top:1rem}.generator-flashcard-controls{gap:1rem}.generator-flashcard-nav-button{font-size:.8rem;padding:.75rem 1.25rem}.generator-flashcard-nav-button svg{height:16px;width:16px}.generator-flashcard-counter{font-size:.85rem;padding:.5rem 1rem}}@media (max-width:480px){.generator-flashcard{aspect-ratio:1/1}.generator-flashcard-back,.generator-flashcard-front{-webkit-font-smoothing:subpixel-antialiased;-moz-osx-font-smoothing:auto;padding:1.5rem 1.25rem}.generator-flashcard-content{-webkit-font-smoothing:subpixel-antialiased;font-size:.95rem}.generator-flashcard-nav-button{font-size:.75rem;padding:.625rem 1rem}}.generator-flashcard-wrapper{animation:fadeIn .4s ease-out}.immersive-fc-overlay{align-items:center;animation:immersiveFcFadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172afa;bottom:0;display:flex;flex-direction:column;height:100vh;justify-content:center;left:0;overflow:hidden;padding:2rem;position:fixed;right:0;top:0;width:100vw;z-index:999999}@keyframes immersiveFcFadeIn{0%{opacity:0}to{opacity:1}}.immersive-fc-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:2rem;top:2rem;transition:all .2s;width:48px;z-index:1000000}.immersive-fc-close:hover{background:#ffffff40;transform:scale(1.05)}.immersive-fc-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;display:flex;gap:1.25rem;left:50%;max-width:600px;padding:.875rem 2rem;position:fixed;top:2rem;transform:translateX(-50%);z-index:1000000}.immersive-fc-header h2{color:#fff;font-size:1.25rem;font-weight:600;margin:0;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.immersive-fc-header span{color:#fffc;font-size:.95rem;font-weight:500;white-space:nowrap}.immersive-fc-content{align-items:center;display:flex;justify-content:center;max-width:900px;padding:6rem 2rem 2rem;width:100%}.immersive-fc-completion{color:#fff;max-width:500px;padding:2rem;text-align:center}.immersive-fc-completion-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;box-shadow:0 8px 32px #3b82f666;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.immersive-fc-completion h2{font-size:1.75rem;font-weight:800;margin-bottom:.5rem}.immersive-fc-completion p{color:#fffc;margin-bottom:.5rem}.immersive-fc-saved-notice{color:#10b981!important;font-weight:600;margin-bottom:2rem!important}.immersive-fc-completion-actions{display:flex;flex-direction:column;gap:.75rem;margin:0 auto 1.5rem;max-width:280px}.immersive-fc-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .3s}.immersive-fc-btn--primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);box-shadow:0 4px 16px #3b82f659;color:#fff}.immersive-fc-btn--primary:hover{box-shadow:0 6px 24px #3b82f673;transform:translateY(-2px)}.immersive-fc-btn--secondary{background:#ffffff1a;border:1px solid #fff3;color:#fff}.immersive-fc-btn--secondary:hover{background:#fff3;transform:translateY(-2px)}.immersive-fc-upgrade{border-top:1px solid #ffffff1a;padding-top:1.5rem}.immersive-fc-upgrade p{margin-bottom:1rem!important}.immersive-fc-upgrade button{background:linear-gradient(135deg,#fef9c3,#fae8ff);border:none;border-radius:10px;color:#7c3aed;cursor:pointer;font-size:.9rem;font-weight:700;padding:.75rem 1.5rem;transition:all .3s}.immersive-fc-upgrade button:hover{box-shadow:0 4px 16px #7c3aed4d;transform:translateY(-2px)}.immersive-fc-overlay .generator-flashcard-title{display:none!important}.immersive-fc-overlay .generator-flashcard-viewer{align-items:center!important;background:#0000!important;box-shadow:none!important;display:flex!important;flex-direction:column!important;gap:2.5rem!important;max-width:none!important;padding:0!important;width:100%!important}.immersive-fc-overlay .generator-flashcard-wrapper{margin:0 auto!important;max-width:900px!important;perspective:1200px!important;width:100%!important}.immersive-fc-overlay .generator-flashcard{aspect-ratio:16/9!important;cursor:pointer!important;width:100%!important}.immersive-fc-overlay .generator-flashcard-inner{height:100%!important;width:100%!important}.immersive-fc-overlay .generator-flashcard-back,.immersive-fc-overlay .generator-flashcard-front{align-items:center!important;backface-visibility:hidden!important;-webkit-backface-visibility:hidden!important;border-radius:20px!important;box-shadow:0 25px 60px #00000080!important;display:flex!important;flex-direction:column!important;height:100%!important;justify-content:center!important;padding:3rem!important;position:absolute!important;text-align:center!important;width:100%!important}.immersive-fc-overlay .generator-flashcard-front{background:#fff!important;border:2px solid #e5e7eb!important}.immersive-fc-overlay .generator-flashcard-back{background:linear-gradient(135deg,#dbeafe,#bfdbfe)!important;border:2px solid #3b82f6!important}.immersive-fc-overlay .generator-flashcard-content{align-items:center!important;color:#1e293b!important;display:flex!important;flex:1 1!important;font-size:1.5rem!important;font-weight:500!important;justify-content:center!important;line-height:1.7!important;max-height:220px!important;max-width:100%!important;overflow-y:auto!important;text-align:center!important}.immersive-fc-overlay .generator-flashcard-label{color:#3b82f6!important;flex-shrink:0!important;font-size:.875rem!important;font-weight:700!important;letter-spacing:2px!important;margin-bottom:1.25rem!important;text-transform:uppercase!important}.immersive-fc-overlay .generator-flashcard-hint{color:#94a3b8!important;flex-shrink:0!important;font-size:.875rem!important;font-weight:500!important;margin-top:1.25rem!important}.immersive-fc-overlay .generator-flashcard-controls{align-items:center!important;display:flex!important;gap:1.5rem!important;justify-content:center!important;margin:0 auto!important;max-width:900px!important;width:100%!important}.immersive-fc-overlay .generator-flashcard-nav-button{align-items:center!important;background:#fff!important;border:2px solid #e2e8f0!important;border-radius:12px!important;box-shadow:0 2px 10px #0000001a!important;color:#1e293b!important;cursor:pointer!important;display:flex!important;flex-shrink:0!important;font-size:1rem!important;font-weight:600!important;gap:.5rem!important;padding:.875rem 1.75rem!important;transition:all .2s!important}.immersive-fc-overlay .generator-flashcard-nav-button:hover:not(:disabled){background:#f8fafc!important;border-color:#3b82f6!important;box-shadow:0 4px 16px #3b82f633!important;color:#3b82f6!important;transform:translateY(-2px)!important}.immersive-fc-overlay .generator-flashcard-nav-button:disabled{cursor:not-allowed!important;opacity:.4!important}.immersive-fc-overlay .generator-flashcard-nav-button svg{height:20px!important;width:20px!important}.immersive-fc-overlay .generator-flashcard-counter{-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;background:#ffffff26!important;border:1px solid #fff3!important;border-radius:10px!important;color:#fff!important;flex-shrink:0!important;font-size:1rem!important;font-weight:600!important;padding:.625rem 1.25rem!important}@media (max-width:768px){.immersive-fc-overlay{padding:1rem}.immersive-fc-close{height:40px;right:1rem;top:1rem;width:40px}.immersive-fc-header{left:1rem;max-width:calc(100% - 5rem);padding:.625rem 1.25rem;right:4rem;top:1rem;transform:none}.immersive-fc-header h2{font-size:1rem;max-width:200px}.immersive-fc-header span{font-size:.85rem}.immersive-fc-content{padding:5rem 1rem 1rem}.immersive-fc-overlay .generator-flashcard-wrapper{max-width:100%!important}.immersive-fc-overlay .generator-flashcard{aspect-ratio:4/3!important}.immersive-fc-overlay .generator-flashcard-back,.immersive-fc-overlay .generator-flashcard-front{border-radius:16px!important;padding:2rem!important}.immersive-fc-overlay .generator-flashcard-content{font-size:1.125rem!important;max-height:160px!important}.immersive-fc-overlay .generator-flashcard-nav-button{font-size:.9rem!important;padding:.75rem 1.25rem!important}.immersive-fc-overlay .generator-flashcard-counter{font-size:.875rem!important;padding:.5rem 1rem!important}.immersive-fc-completion-icon{height:64px;width:64px}.immersive-fc-completion h2{font-size:1.5rem}}@media (max-width:480px){.immersive-fc-overlay .generator-flashcard{aspect-ratio:1/1!important}.immersive-fc-overlay .generator-flashcard-back,.immersive-fc-overlay .generator-flashcard-front{padding:1.5rem!important}.immersive-fc-overlay .generator-flashcard-content{font-size:1rem!important;max-height:140px!important}.immersive-fc-overlay .generator-flashcard-controls{gap:1rem!important}.immersive-fc-overlay .generator-flashcard-nav-button{font-size:.85rem!important;padding:.625rem 1rem!important}.immersive-fc-completion-actions{gap:.5rem}.immersive-fc-btn{font-size:.875rem;padding:.75rem 1.25rem}}:root{--fgen-primary:#3b82f6;--fgen-primary-dark:#2563eb;--fgen-accent:#8b5cf6;--fgen-accent-dark:#7c3aed;--fgen-success:#10b981;--fgen-error:#ef4444;--fgen-text:#0f172a;--fgen-text-secondary:#64748b;--fgen-text-muted:#94a3b8;--fgen-border:#e2e8f0;--fgen-bg:#fff;--fgen-bg-subtle:#f8fafc;--fgen-bg-dark:#0f172a;--fgen-gradient:linear-gradient(135deg,var(--fgen-primary) 0%,var(--fgen-accent) 100%);--fgen-radius:16px;--fgen-radius-sm:10px;--fgen-radius-lg:24px;--fgen-shadow:0 4px 24px #0f172a14;--fgen-shadow-lg:0 12px 48px #0f172a1f;--fgen-transition:cubic-bezier(0.16,1,0.3,1)}.fgen-page{background:#fff;background:var(--fgen-bg);color:#0f172a;color:var(--fgen-text);min-height:100vh;overflow-x:hidden;position:relative}.fgen-ambient{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.fgen-ambient-orb{border-radius:50%;filter:blur(120px);position:absolute}.fgen-ambient-orb--1{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:linear-gradient(135deg,var(--fgen-primary) 0,var(--fgen-accent) 100%);height:800px;opacity:.08;right:-300px;top:-400px;width:800px}.fgen-ambient-orb--2{background:#8b5cf6;background:var(--fgen-accent);bottom:-200px;height:600px;left:-200px;opacity:.06;width:600px}.fgen-hero{margin:0 auto;max-width:800px;padding:3rem 2rem 2rem;position:relative;text-align:center;z-index:1}.fgen-hero-content{animation:fgen-fadeUp .8s cubic-bezier(.16,1,.3,1) forwards;animation:fgen-fadeUp .8s var(--fgen-transition) forwards}@keyframes fgen-fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fgen-hero-title{color:#0f172a;color:var(--fgen-text);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;margin:0 0 1rem}.fgen-hero-title-accent{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);-webkit-background-clip:text;background-clip:text;padding-bottom:.1em}.fgen-hero-subtitle{color:#64748b;color:var(--fgen-text-secondary);font-size:1.0625rem;line-height:1.6;margin:0 auto;max-width:500px}.fgen-main{margin:0 auto;max-width:800px;padding:0 1.5rem 4rem;position:relative;z-index:1}.fgen-upload-wrapper{background:#fff;background:var(--fgen-bg);border:1px solid #e2e8f0;border:1px solid var(--fgen-border);border-radius:24px;border-radius:var(--fgen-radius-lg);box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--fgen-shadow-lg);overflow:hidden;position:relative}.fgen-upload-wrapper:before{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0}.fgen-dropzone{background:linear-gradient(180deg,#f8fafc,#fff);background:linear-gradient(180deg,var(--fgen-bg-subtle) 0,var(--fgen-bg) 100%);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--fgen-border);cursor:pointer;padding:3rem 2.5rem;position:relative}.fgen-dropzone,.fgen-dropzone:before{transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--fgen-transition)}.fgen-dropzone:before{border:2px dashed #e2e8f0;border:2px dashed var(--fgen-border);border-radius:16px;border-radius:var(--fgen-radius);content:"";inset:1.25rem;pointer-events:none;position:absolute}.fgen-dropzone:hover:before{background:linear-gradient(135deg,#3b82f608,#8b5cf608);border-color:#3b82f6;border-color:var(--fgen-primary)}.fgen-dropzone--dragging:before{background:linear-gradient(135deg,#3b82f60f,#8b5cf60f);border-color:#3b82f6;border-color:var(--fgen-primary);border-style:solid}.fgen-dropzone--has-file{background:linear-gradient(180deg,#3b82f60a,#fff);background:linear-gradient(180deg,#3b82f60a 0,var(--fgen-bg) 100%)}.fgen-dropzone--has-file:before{background:#3b82f605;border-color:#3b82f6;border-color:var(--fgen-primary);border-style:solid}.fgen-dropzone-content{align-items:center;display:flex;flex-direction:column;gap:.875rem;position:relative;z-index:1}.fgen-dropzone-icon{align-items:center;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:50%;color:#3b82f6;color:var(--fgen-primary);display:flex;height:64px;justify-content:center;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--fgen-transition);width:64px}.fgen-dropzone:hover .fgen-dropzone-icon{background:linear-gradient(135deg,#3b82f626,#8b5cf626);box-shadow:0 8px 24px #3b82f633;transform:translateY(-4px) scale(1.05)}.fgen-dropzone-text{text-align:center}.fgen-dropzone-primary{color:#0f172a;color:var(--fgen-text);display:block;font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.fgen-dropzone-secondary{color:#94a3b8;color:var(--fgen-text-muted);display:block;font-size:.9rem}.fgen-browse-btn{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);border-radius:10px;border-radius:var(--fgen-radius-sm);box-shadow:0 4px 16px #3b82f659;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;margin-top:.25rem;padding:.875rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-browse-btn:hover{box-shadow:0 8px 28px #3b82f673;transform:translateY(-2px)}.fgen-browse-btn input{display:none}.fgen-formats{display:flex;flex-wrap:wrap;gap:.375rem;justify-content:center;margin-top:.5rem}.fgen-formats span{background:#fff;background:var(--fgen-bg);border:1px solid #e2e8f0;border:1px solid var(--fgen-border);border-radius:4px;color:#94a3b8;color:var(--fgen-text-muted);font-size:.65rem;font-weight:600;letter-spacing:.05em;padding:.25rem .5rem}.fgen-file-display{align-items:center;background:linear-gradient(135deg,#3b82f614,#8b5cf60d);border:1px solid #3b82f633;border-radius:10px;border-radius:var(--fgen-radius-sm);display:flex;gap:1rem;margin:0 auto;max-width:400px;padding:1rem 1.5rem;position:relative;width:100%;z-index:1}.fgen-file-icon{align-items:center;background:linear-gradient(135deg,#3b82f626,#8b5cf61a);border-radius:10px;color:#3b82f6;color:var(--fgen-primary);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.fgen-file-info{flex:1 1;min-width:0}.fgen-file-name{color:#0f172a;color:var(--fgen-text);display:block;font-size:.9rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fgen-file-size{color:#64748b;color:var(--fgen-text-secondary);display:block;font-size:.75rem;margin-top:.125rem}.fgen-file-remove{background:none;border:none;border-radius:6px;color:#94a3b8;color:var(--fgen-text-muted);cursor:pointer;padding:.375rem;transition:all .2s}.fgen-file-remove:hover{background:#ef44441a;color:#ef4444;color:var(--fgen-error)}.fgen-options{padding:1.75rem 2.5rem}.fgen-options-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.fgen-options-label{color:#64748b;color:var(--fgen-text-secondary);font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.fgen-upgrade-hint{align-items:center;background:linear-gradient(135deg,#8b5cf61f,#fbbf241f);border:1px solid #8b5cf640;border-radius:100px;color:#8b5cf6;color:var(--fgen-accent);cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:700;gap:.4rem;padding:.4rem .875rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-upgrade-hint:hover{background:linear-gradient(135deg,#8b5cf62e,#fbbf242e)}.fgen-count-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem}.fgen-count-btn{align-items:center;background:#fff;background:var(--fgen-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--fgen-border);border-radius:10px;border-radius:var(--fgen-radius-sm);color:#0f172a;color:var(--fgen-text);cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.25rem;justify-content:center;min-width:52px;padding:.625rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-count-btn:hover:not(:disabled):not(.fgen-count-btn--active){border-color:#3b82f6;border-color:var(--fgen-primary);color:#3b82f6;color:var(--fgen-primary);transform:translateY(-2px)}.fgen-count-btn--active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);border-color:#0000;box-shadow:0 4px 12px #3b82f659;color:#fff}.fgen-count-btn--locked{cursor:not-allowed;opacity:.45}.fgen-count-btn--custom{color:#94a3b8;color:var(--fgen-text-muted)}.fgen-lock-icon{opacity:.7}.fgen-custom-input{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.fgen-custom-input input{border:1.5px solid #e2e8f0;border:1.5px solid var(--fgen-border);border-radius:10px;border-radius:var(--fgen-radius-sm);font-size:1rem;font-weight:600;padding:.625rem .75rem;text-align:center;width:80px}.fgen-custom-input input:focus{border-color:#3b82f6;border-color:var(--fgen-primary);outline:none}.fgen-custom-input span{color:#64748b;color:var(--fgen-text-secondary);font-size:.9rem}.fgen-back-btn{background:none;border:1.5px solid #e2e8f0;border:1.5px solid var(--fgen-border);border-radius:10px;border-radius:var(--fgen-radius-sm);color:#64748b;color:var(--fgen-text-secondary);cursor:pointer;padding:.5rem}.fgen-generate-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);border:none;border-radius:10px;border-radius:var(--fgen-radius-sm);box-shadow:0 4px 16px #3b82f659;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 2rem;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--fgen-transition);width:100%}.fgen-generate-btn:hover:not(:disabled){box-shadow:0 8px 24px #3b82f673;transform:translateY(-2px)}.fgen-generate-btn:disabled{cursor:not-allowed;opacity:.5}.fgen-spinner{animation:fgen-spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes fgen-spin{to{transform:rotate(1turn)}}.fgen-message{border-radius:10px;border-radius:var(--fgen-radius-sm);font-size:.85rem;font-weight:600;margin-top:1rem;padding:.875rem 1rem;text-align:center}.fgen-message--error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444;color:var(--fgen-error)}.fgen-message--success{background:#10b9811a;border:1px solid #10b98133;color:#10b981;color:var(--fgen-success)}.fgen-success{animation:fgen-slideUp .5s cubic-bezier(.16,1,.3,1);animation:fgen-slideUp .5s var(--fgen-transition);background:linear-gradient(135deg,#fff,#3b82f605);background:linear-gradient(135deg,var(--fgen-bg) 0,#3b82f605 100%);border:1px solid #e2e8f0;border:1px solid var(--fgen-border);border-radius:24px;border-radius:var(--fgen-radius-lg);box-shadow:0 4px 24px #0f172a14;box-shadow:var(--fgen-shadow);margin-top:1.5rem;overflow:hidden;padding:1.75rem 2rem;position:relative}.fgen-success:before{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);content:"";height:3px;left:0;position:absolute;right:0;top:0}@keyframes fgen-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fgen-success-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.fgen-success-check{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);border-radius:50%;box-shadow:0 4px 12px #3b82f64d;color:#fff;display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.fgen-success-text h2{color:#0f172a;color:var(--fgen-text);font-size:1.25rem;font-weight:700;margin:0 0 .125rem}.fgen-success-text p{color:#64748b;color:var(--fgen-text-secondary);font-size:.9rem;margin:0}.fgen-actions{grid-gap:.625rem;display:grid;gap:.625rem;grid-template-columns:repeat(2,1fr)}.fgen-action{align-items:center;border:none;border-radius:10px;border-radius:var(--fgen-radius-sm);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.375rem;justify-content:center;padding:.75rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-action--primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);box-shadow:0 2px 8px #3b82f64d;color:#fff}.fgen-action--primary:hover{box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.fgen-action--secondary{background:#fff;background:var(--fgen-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--fgen-border);color:#0f172a;color:var(--fgen-text)}.fgen-action--secondary:hover{border-color:#3b82f6;border-color:var(--fgen-primary);color:#3b82f6;color:var(--fgen-primary);transform:translateY(-2px)}.fgen-upgrade-banner{align-items:center;background:linear-gradient(135deg,#8b5cf61a,#fbbf2414);border:1px solid #8b5cf633;border-radius:10px;border-radius:var(--fgen-radius-sm);display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin-top:1.25rem;padding:1rem 1.25rem}.fgen-upgrade-content{align-items:center;color:#8b5cf6;color:var(--fgen-accent);display:flex;flex:1 1;gap:.5rem}.fgen-upgrade-content span{color:#64748b;color:var(--fgen-text-secondary);font-size:.85rem;font-weight:500}.fgen-upgrade-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);background:linear-gradient(135deg,var(--fgen-accent) 0,var(--fgen-accent-dark) 100%);border:none;border-radius:10px;border-radius:var(--fgen-radius-sm);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.625rem 1.25rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-upgrade-btn:hover{transform:translateY(-2px)}.fgen-immersive{align-items:center;animation:fgen-fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172afa;bottom:0;display:flex;flex-direction:column;height:100vh;justify-content:center;left:0;overflow:hidden;padding:2rem;position:fixed;right:0;top:0;width:100vw;z-index:999999}@keyframes fgen-fadeIn{0%{opacity:0}to{opacity:1}}.fgen-immersive-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:2rem;top:2rem;transition:all .2s;width:48px;z-index:1000000}.fgen-immersive-close:hover{background:#ffffff40;transform:scale(1.05)}.fgen-immersive-title{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;display:flex;gap:1.25rem;left:50%;max-width:600px;padding:.875rem 2rem;position:fixed;top:2rem;transform:translateX(-50%);z-index:1000000}.fgen-immersive-title h2{color:#fff;font-size:1.25rem;font-weight:600;margin:0;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fgen-immersive-title span{color:#fffc;font-size:.95rem;font-weight:500;white-space:nowrap}.fgen-immersive-content{align-items:center;display:flex;justify-content:center;max-width:900px;padding:6rem 2rem 2rem;width:100%}.fgen-completion{color:#fff;padding:2rem;text-align:center}.fgen-completion-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.fgen-completion h2{font-size:1.75rem;font-weight:800;margin-bottom:.5rem}.fgen-completion p{color:#fffc;margin-bottom:.5rem}.fgen-saved-notice{color:#10b981!important;color:var(--fgen-success)!important;font-weight:600;margin-bottom:2rem!important}.fgen-completion-actions{display:flex;flex-direction:column;gap:.75rem;margin:0 auto 1.5rem;max-width:280px}.fgen-comp-btn{border:none;border-radius:10px;border-radius:var(--fgen-radius-sm);cursor:pointer;font-size:.95rem;font-weight:600;padding:.875rem 1.5rem;transition:all .3s}.fgen-comp-btn--primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);color:#fff}.fgen-comp-btn--secondary{background:#ffffff1a;border:1px solid #fff3;color:#fff}.fgen-comp-btn:hover{transform:translateY(-2px)}.fgen-completion-upgrade{border-top:1px solid #ffffff1a;padding-top:1.5rem}.fgen-completion-upgrade p{margin-bottom:1rem!important}.fgen-completion-upgrade button{background:linear-gradient(135deg,#fef9c3,#fae8ff);border:none;border-radius:10px;border-radius:var(--fgen-radius-sm);color:#7c3aed;cursor:pointer;font-size:.9rem;font-weight:700;padding:.75rem 1.5rem}.fgen-process{background:linear-gradient(180deg,#f8fafc,#fff);background:linear-gradient(180deg,var(--fgen-bg-subtle) 0,var(--fgen-bg) 100%);overflow:hidden;padding:5rem 2rem 6rem;position:relative;z-index:1}.fgen-process-flow{display:flex;flex-direction:column;margin:0 auto;max-width:900px}.fgen-flow-item{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:auto 1fr auto;padding:2rem 0}.fgen-flow-item--left{text-align:left}.fgen-flow-item--right{text-align:right}.fgen-flow-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(3.5rem,8vw,5rem);font-weight:900;line-height:1;opacity:.15;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--fgen-transition)}.fgen-flow-item:hover .fgen-flow-number{opacity:.35}.fgen-flow-content{max-width:340px}.fgen-flow-item--right .fgen-flow-content{margin-left:auto}.fgen-flow-content h3{color:#0f172a;color:var(--fgen-text);font-size:1.25rem;font-weight:800;margin:0 0 .5rem;transition:color .3s}.fgen-flow-item:hover .fgen-flow-content h3{color:#3b82f6;color:var(--fgen-primary)}.fgen-flow-content p{color:#64748b;color:var(--fgen-text-secondary);font-size:.95rem;line-height:1.6;margin:0}.fgen-flow-visual{align-items:center;display:flex;height:80px;justify-content:center;width:80px}.fgen-flow-icon{color:#94a3b8;color:var(--fgen-text-muted);height:60px;opacity:.4;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--fgen-transition);width:60px}.fgen-flow-item:hover .fgen-flow-icon{color:#3b82f6;color:var(--fgen-primary);opacity:.7}.fgen-flow-connector{display:flex;height:50px;justify-content:center;opacity:.4}.fgen-flow-connector svg{height:100%;width:40px}.fgen-value{margin:0 auto;max-width:1100px;padding:5rem 2rem 6rem;position:relative;z-index:1}.fgen-value-header{margin-bottom:3rem;text-align:center}.fgen-value-header h2{color:#0f172a;color:var(--fgen-text);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;letter-spacing:-.03em;margin:0}.fgen-value-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-auto-rows:minmax(160px,auto);grid-template-columns:repeat(12,1fr)}.fgen-value-card{background:#fff;background:var(--fgen-bg);border:1px solid #e2e8f0;border:1px solid var(--fgen-border);border-radius:24px;border-radius:var(--fgen-radius-lg);grid-column:span 6;overflow:hidden;position:relative;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--fgen-transition)}.fgen-value-card:hover{border-color:#0000;box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--fgen-shadow-lg);transform:translateY(-6px)}.fgen-value-card-blob{border-radius:50%;filter:blur(60px);height:180px;opacity:0;pointer-events:none;position:absolute;transition:all .6s cubic-bezier(.16,1,.3,1);transition:all .6s var(--fgen-transition);width:180px}.fgen-value-card:first-child .fgen-value-card-blob{background:#3b82f6;background:var(--fgen-primary);right:-50px;top:-50px}.fgen-value-card:nth-child(2) .fgen-value-card-blob{background:#8b5cf6;background:var(--fgen-accent);bottom:-50px;left:-50px}.fgen-value-card:nth-child(3) .fgen-value-card-blob{background:#10b981;left:-50px;top:-50px}.fgen-value-card:nth-child(4) .fgen-value-card-blob{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:linear-gradient(135deg,var(--fgen-primary),var(--fgen-accent));bottom:-50px;right:-50px}.fgen-value-card:hover .fgen-value-card-blob{opacity:.15}.fgen-value-card-inner{display:flex;flex-direction:column;height:100%;padding:1.75rem;position:relative;z-index:1}.fgen-value-card-icon{align-items:center;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:12px;display:flex;height:46px;justify-content:center;margin-bottom:1.25rem;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--fgen-transition);width:46px}.fgen-value-card-icon svg{color:#3b82f6;color:var(--fgen-primary);height:22px;width:22px}.fgen-value-card:hover .fgen-value-card-icon{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);transform:scale(1.1) rotate(-5deg)}.fgen-value-card:hover .fgen-value-card-icon svg{color:#fff}.fgen-value-card h3{color:#0f172a;color:var(--fgen-text);font-size:1.125rem;font-weight:700;margin:0 0 .5rem;transition:color .3s}.fgen-value-card:hover h3{color:#3b82f6;color:var(--fgen-primary)}.fgen-value-card p{color:#64748b;color:var(--fgen-text-secondary);font-size:.9rem;line-height:1.6;margin:0}.fgen-value-card--featured{grid-column:span 7;grid-row:span 2}.fgen-value-card--featured .fgen-value-card-inner{padding:2rem}.fgen-value-card--featured .fgen-value-card-icon{height:56px;width:56px}.fgen-value-card--featured .fgen-value-card-icon svg{height:28px;width:28px}.fgen-value-card--featured h3{font-size:1.375rem}.fgen-value-card--wide{grid-column:span 12}.fgen-value-card--wide .fgen-value-card-inner{align-items:center;flex-direction:row;gap:1.5rem}.fgen-value-card--wide .fgen-value-card-icon{flex-shrink:0;margin-bottom:0}.fgen-value-card--wide h3{margin-bottom:.25rem}.fgen-value-card:nth-child(2),.fgen-value-card:nth-child(3){grid-column:span 5}.fgen-faq{background:linear-gradient(180deg,#fff,#f8fafc);background:linear-gradient(180deg,var(--fgen-bg) 0,var(--fgen-bg-subtle) 100%);padding:5rem 2rem;position:relative;z-index:1}.fgen-faq-header{margin:0 auto 3rem;max-width:500px;text-align:center}.fgen-faq-eyebrow{background:#3b82f61a;border-radius:100px;color:#3b82f6;color:var(--fgen-primary);display:inline-flex;font-size:.75rem;font-weight:700;letter-spacing:.15em;margin-bottom:.75rem;padding:.4rem .875rem;text-transform:uppercase}.fgen-faq-header h2{color:#0f172a;color:var(--fgen-text);font-size:clamp(1.75rem,4vw,2rem);font-weight:800;margin:0}.fgen-faq-list{display:flex;flex-direction:column;gap:.75rem;margin:0 auto;max-width:700px}.fgen-faq-item{background:#fff;background:var(--fgen-bg);border:1px solid #e2e8f0;border:1px solid var(--fgen-border);border-radius:16px;border-radius:var(--fgen-radius);overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-faq-item:hover{border-color:#3b82f64d}.fgen-faq-item--open{border-color:#3b82f6;border-color:var(--fgen-primary);box-shadow:0 4px 16px #3b82f61a}.fgen-faq-trigger{align-items:center;background:none;border:none;color:#0f172a;color:var(--fgen-text);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:1rem;justify-content:space-between;padding:1.125rem 1.25rem;text-align:left;width:100%}.fgen-faq-trigger:hover{color:#3b82f6;color:var(--fgen-primary)}.fgen-faq-trigger svg{color:#94a3b8;color:var(--fgen-text-muted);flex-shrink:0;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-faq-item--open .fgen-faq-trigger svg{color:#3b82f6;color:var(--fgen-primary);transform:rotate(45deg)}.fgen-faq-content{max-height:0;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--fgen-transition)}.fgen-faq-item--open .fgen-faq-content{max-height:400px}.fgen-faq-content p{color:#64748b;color:var(--fgen-text-secondary);font-size:.9rem;line-height:1.7;margin:0;padding:0 1.25rem 1.25rem}.fgen-cta{align-items:center;background:#f8fafc;background:var(--fgen-bg-subtle);border-top:1px solid #e2e8f0;border-top:1px solid var(--fgen-border);display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:3.5rem 2rem;position:relative;z-index:1}.fgen-cta p{color:#0f172a;color:var(--fgen-text);font-size:1.125rem;font-weight:600;margin:0}.fgen-cta-btn{background:linear-gradient(135deg,#3b82f6,#8b5cf6);background:var(--fgen-gradient);border:none;border-radius:10px;border-radius:var(--fgen-radius-sm);box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.875rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--fgen-transition)}.fgen-cta-btn:hover{box-shadow:0 6px 16px #3b82f666;transform:translateY(-2px)}@media (max-width:900px){.fgen-flow-item{gap:1rem;grid-template-columns:1fr;text-align:center!important}.fgen-flow-item--right .fgen-flow-content{margin-left:0}.fgen-flow-content{max-width:100%;order:2}.fgen-flow-number{font-size:3.5rem;order:1}.fgen-flow-visual{margin:0 auto;order:3}.fgen-flow-connector{height:35px}.fgen-value-grid{grid-template-columns:repeat(2,1fr)}.fgen-value-card--featured{grid-column:span 2;grid-row:span 1}.fgen-value-card:nth-child(2),.fgen-value-card:nth-child(3){grid-column:span 1}.fgen-value-card--wide{grid-column:span 2}}@media (max-width:768px){.fgen-page{padding-top:3.5rem}.fgen-hero{padding:2.5rem 1.5rem 2rem}.fgen-hero-subtitle{font-size:1rem}.fgen-main{padding:0 1rem 3rem}.fgen-dropzone{padding:2.5rem 1.5rem}.fgen-dropzone:before{inset:.75rem}.fgen-options,.fgen-success{padding:1.5rem}.fgen-success-header{flex-direction:column;text-align:center}.fgen-actions{grid-template-columns:1fr}.fgen-upgrade-banner{flex-direction:column;text-align:center}.fgen-upgrade-btn{width:100%}.fgen-process{padding:3.5rem 1.5rem 4rem}.fgen-flow-number{font-size:3rem}.fgen-flow-content h3{font-size:1.125rem}.fgen-value{padding:3.5rem 1.5rem}.fgen-value-grid{gap:1rem;grid-template-columns:1fr}.fgen-value-card,.fgen-value-card--featured,.fgen-value-card--wide,.fgen-value-card:nth-child(2),.fgen-value-card:nth-child(3){grid-column:span 1;grid-row:span 1}.fgen-value-card--featured .fgen-value-card-inner{padding:1.5rem}.fgen-value-card--featured h3{font-size:1.125rem}.fgen-value-card--wide .fgen-value-card-inner{align-items:flex-start;flex-direction:column}.fgen-value-card--wide .fgen-value-card-icon{margin-bottom:1rem}.fgen-value-card:hover{transform:translateY(-4px)}.fgen-faq{padding:3.5rem 1.5rem}.fgen-faq-trigger{font-size:.9rem;padding:1rem}.fgen-faq-content p{font-size:.85rem;padding:0 1rem 1rem}.fgen-cta{flex-direction:column;gap:1.25rem;padding:2.5rem 1.5rem;text-align:center}.fgen-cta p{font-size:1rem}.fgen-cta-btn{max-width:260px;width:100%}.fgen-immersive-title{left:1rem;max-width:calc(100% - 5rem);padding:.625rem 1.25rem;right:4rem;top:1rem;transform:none}.fgen-immersive-title h2{font-size:1rem;max-width:200px}.fgen-immersive-title span{font-size:.85rem}.fgen-immersive-close{height:40px;right:1rem;top:1rem;width:40px}.fgen-immersive-content{padding:5rem 1rem 1rem}}@media (max-width:480px){.fgen-hero{padding:2rem 1rem 1.5rem}.fgen-hero-title{font-size:1.75rem}.fgen-dropzone{padding:2rem 1rem}.fgen-dropzone:before{inset:.5rem}.fgen-dropzone-primary{font-size:1rem}.fgen-dropzone-icon{height:56px;width:56px}.fgen-browse-btn{font-size:.875rem;padding:.75rem 1.5rem}.fgen-count-btn{font-size:.875rem;min-width:44px;padding:.5rem .75rem}.fgen-generate-btn{font-size:.9375rem;padding:.875rem 1.5rem}.fgen-success-check{height:38px;width:38px}.fgen-success-text h2{font-size:1.125rem}.fgen-value-header h2{font-size:1.5rem}.fgen-value-card h3{font-size:1rem}.fgen-value-card p{font-size:.85rem}.fgen-completion h2,.fgen-faq-header h2{font-size:1.5rem}.fgen-completion-icon{height:64px;width:64px}}.fgen-value-card{animation:fgen-fadeUp .6s cubic-bezier(.16,1,.3,1) forwards;animation:fgen-fadeUp .6s var(--fgen-transition) forwards;opacity:0}.fgen-value-card:first-child{animation-delay:.1s}.fgen-value-card:nth-child(2){animation-delay:.2s}.fgen-value-card:nth-child(3){animation-delay:.25s}.fgen-value-card:nth-child(4){animation-delay:.35s}.fgen-faq-item{animation:fgen-fadeUp .5s cubic-bezier(.16,1,.3,1) forwards;animation:fgen-fadeUp .5s var(--fgen-transition) forwards;opacity:0}.fgen-faq-item:first-child{animation-delay:.1s}.fgen-faq-item:nth-child(2){animation-delay:.15s}.fgen-faq-item:nth-child(3){animation-delay:.2s}.fgen-faq-item:nth-child(4){animation-delay:.25s}.fgen-faq-item:nth-child(5){animation-delay:.3s}.fgen-immersive .generator-flashcard-title{display:none!important}.fgen-immersive .generator-flashcard-viewer{align-items:center!important;background:#0000!important;box-shadow:none!important;display:flex!important;flex-direction:column!important;gap:2.5rem!important;max-width:none!important;padding:0!important;width:100%!important}.fgen-immersive .generator-flashcard-wrapper{margin:0 auto!important;max-width:900px!important;perspective:1200px!important;width:100%!important}.fgen-immersive .generator-flashcard{aspect-ratio:16/9!important;cursor:pointer!important;width:100%!important}.fgen-immersive .generator-flashcard-inner{height:100%!important;width:100%!important}.fgen-immersive .generator-flashcard-back,.fgen-immersive .generator-flashcard-front{align-items:center!important;backface-visibility:hidden!important;-webkit-backface-visibility:hidden!important;border-radius:20px!important;box-shadow:0 25px 60px #00000080!important;display:flex!important;flex-direction:column!important;height:100%!important;justify-content:center!important;padding:3rem!important;position:absolute!important;text-align:center!important;width:100%!important}.fgen-immersive .generator-flashcard-front{background:#fff!important;border:2px solid #e5e7eb!important}.fgen-immersive .generator-flashcard-back{background:linear-gradient(135deg,#dbeafe,#bfdbfe)!important;border:2px solid #3b82f6!important}.fgen-immersive .generator-flashcard-content{align-items:center!important;color:#1e293b!important;display:flex!important;flex:1 1!important;font-size:1.5rem!important;font-weight:500!important;justify-content:center!important;line-height:1.7!important;max-height:220px!important;max-width:100%!important;overflow-y:auto!important;text-align:center!important}.fgen-immersive .generator-flashcard-label{color:#3b82f6!important;flex-shrink:0!important;font-size:.875rem!important;font-weight:700!important;letter-spacing:2px!important;margin-bottom:1.25rem!important;text-transform:uppercase!important}.fgen-immersive .generator-flashcard-hint{color:#94a3b8!important;flex-shrink:0!important;font-size:.875rem!important;font-weight:500!important;margin-top:1.25rem!important}.fgen-immersive .generator-flashcard-controls{align-items:center!important;display:flex!important;gap:1.5rem!important;justify-content:center!important;margin:0 auto!important;max-width:900px!important;width:100%!important}.fgen-immersive .generator-flashcard-nav-button{align-items:center!important;background:#fff!important;border:2px solid #e2e8f0!important;border-radius:12px!important;box-shadow:0 2px 10px #0000001a!important;color:#1e293b!important;cursor:pointer!important;display:flex!important;flex-shrink:0!important;font-size:1rem!important;font-weight:600!important;gap:.5rem!important;padding:.875rem 1.75rem!important;transition:all .2s!important}.fgen-immersive .generator-flashcard-nav-button:hover:not(:disabled){background:#f8fafc!important;border-color:#3b82f6!important;box-shadow:0 4px 16px #3b82f633!important;color:#3b82f6!important;transform:translateY(-2px)!important}.fgen-immersive .generator-flashcard-nav-button:disabled{cursor:not-allowed!important;opacity:.4!important}.fgen-immersive .generator-flashcard-nav-button svg{height:20px!important;width:20px!important}.fgen-immersive .generator-flashcard-counter{-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;background:#ffffff26!important;border:1px solid #fff3!important;border-radius:10px!important;color:#fff!important;flex-shrink:0!important;font-size:1rem!important;font-weight:600!important;padding:.625rem 1.25rem!important}@media (max-width:768px){.fgen-immersive .generator-flashcard-wrapper{max-width:100%!important}.fgen-immersive .generator-flashcard{aspect-ratio:4/3!important}.fgen-immersive .generator-flashcard-back,.fgen-immersive .generator-flashcard-front{border-radius:16px!important;padding:2rem!important}.fgen-immersive .generator-flashcard-content{font-size:1.125rem!important;max-height:160px!important}.fgen-immersive .generator-flashcard-nav-button{font-size:.9rem!important;padding:.75rem 1.25rem!important}.fgen-immersive .generator-flashcard-counter{font-size:.875rem!important;padding:.5rem 1rem!important}}@media (max-width:480px){.fgen-immersive .generator-flashcard{aspect-ratio:1/1!important}.fgen-immersive .generator-flashcard-back,.fgen-immersive .generator-flashcard-front{padding:1.5rem!important}.fgen-immersive .generator-flashcard-content{font-size:1rem!important;max-height:140px!important}.fgen-immersive .generator-flashcard-controls{gap:1rem!important}.fgen-immersive .generator-flashcard-nav-button{font-size:.85rem!important;padding:.625rem 1rem!important}}.cwp-container{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:1100px;width:100%}.cwp-container--immersive{max-width:1300px}.cwp-title{color:#0f172a;font-size:1.25rem;font-weight:700;margin:0 0 .5rem;text-align:center}.cwp-empty-state{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}.cwp-empty-icon{margin-bottom:1rem;opacity:.4}.cwp-empty-state p{font-size:.95rem;margin:0}.cwp-success{align-items:center;animation:cwpSuccessPulse .5s ease;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:12px;display:flex;gap:.75rem;justify-content:center;padding:1rem 1.5rem}@keyframes cwpSuccessPulse{0%{opacity:0;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.cwp-success-icon{color:#10b981}.cwp-success-text{color:#065f46;font-size:1rem;font-weight:700}.cwp-layout{grid-gap:1.5rem;align-items:start;display:grid;gap:1.5rem;grid-template-columns:minmax(300px,1fr) minmax(280px,380px)}.cwp-grid-container{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 24px #0f172a14;min-width:0;overflow:hidden;padding:1.5rem}.cwp-grid-wrapper{display:flex;justify-content:center;overflow-x:auto;padding-bottom:.5rem}.cwp-grid{grid-gap:3px;background:linear-gradient(135deg,#1e293b,#334155);border-radius:12px;box-shadow:0 4px 12px #00000026,inset 0 1px 0 #ffffff1a;display:grid;gap:3px;max-width:100%;overflow:auto;padding:8px}.cwp-cell{border-radius:4px;height:38px;position:relative;transition:all .15s ease;width:38px}.cwp-cell--empty{background:#0000;box-shadow:none}.cwp-cell--filled{background:#fff;box-shadow:0 1px 3px #0000001a,inset 0 1px 0 #fffc;cursor:pointer}.cwp-cell--filled:hover{background:#f8fafc;box-shadow:0 2px 6px #0000001f}.cwp-cell--highlighted{background:#dbeafe;box-shadow:0 1px 3px #3b82f633,inset 0 1px 0 #fffc}.cwp-cell--active{background:#3b82f6!important;box-shadow:0 0 0 2px #1d4ed8,0 2px 8px #3b82f666;z-index:2}.cwp-cell--active input{color:#fff}.cwp-cell--correct{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.cwp-cell--correct input{color:#059669}.cwp-cell input{background:#0000;border:none;border-radius:4px;caret-color:#3b82f6;color:#1e293b;cursor:pointer;font-size:1.125rem;font-weight:700;height:100%;padding:0;text-align:center;text-transform:uppercase;width:100%}.cwp-cell input:focus{outline:none}.cwp-cell input.cwp-revealed{color:#6366f1;font-style:italic}.cwp-cell input:disabled{cursor:default;opacity:1}.cwp-cell-number{color:#64748b;font-size:.6rem;font-weight:700;left:3px;line-height:1;pointer-events:none;position:absolute;top:2px;z-index:1}.cwp-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.cwp-actions,.cwp-btn{justify-content:center}.cwp-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s ease}.cwp-btn--primary{background:linear-gradient(135deg,#3b82f6,#6366f1);box-shadow:0 4px 12px #3b82f64d;color:#fff}.cwp-btn--primary:hover{box-shadow:0 6px 16px #3b82f666;transform:translateY(-2px)}.cwp-btn--secondary{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.cwp-btn--secondary:hover{background:#e2e8f0;color:#1e293b}.cwp-btn--hint{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d;color:#92400e}.cwp-btn--hint:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);box-shadow:0 4px 12px #fbbf244d}.cwp-clues{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 24px #0f172a14;gap:1.25rem;max-height:550px;min-width:0;overflow-x:hidden;overflow-y:auto;padding:1.25rem}.cwp-clues,.cwp-clues-section{display:flex;flex-direction:column}.cwp-clues-heading{align-items:center;border-bottom:2px solid #e2e8f0;color:#3b82f6;display:flex;font-size:.75rem;font-weight:700;gap:.5rem;letter-spacing:.1em;margin:0 0 .75rem;padding-bottom:.5rem;text-transform:uppercase}.cwp-clues-list{display:flex;flex-direction:column;gap:.375rem;list-style:none;margin:0;padding:0}.cwp-clue{align-items:flex-start;background:#f8fafc;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:.625rem;padding:.625rem .75rem;transition:all .15s ease}.cwp-clue:hover{background:#dbeafe;border-color:#93c5fd}.cwp-clue--active{background:#dbeafe;border-color:#3b82f6}.cwp-clue-number{color:#3b82f6;flex-shrink:0;font-weight:700;min-width:1.25rem}.cwp-clue-text{word-wrap:break-word;color:#475569;font-size:.875rem;line-height:1.4;overflow-wrap:break-word}.cwp-hint{border-top:1px solid #e2e8f0;display:flex;gap:2rem;justify-content:center;padding-top:.75rem}.cwp-hint span{color:#94a3b8;font-size:.75rem}.cwp-container--immersive .cwp-layout{grid-template-columns:1fr 420px}.cwp-container--immersive .cwp-grid-container{background:#fffffffa}.cwp-container--immersive .cwp-clues{background:#fffffffa;max-height:650px}.cwp-container--immersive .cwp-cell{height:42px;width:42px}.cwp-container--immersive .cwp-cell input{font-size:1.25rem}@media (max-width:1000px){.cwp-layout{gap:1.25rem;grid-template-columns:1fr}.cwp-clues{max-height:400px}.cwp-grid-container{padding:1rem}}@media (max-width:600px){.cwp-container{gap:.75rem}.cwp-cell{height:32px;width:32px}.cwp-cell input{font-size:.95rem}.cwp-cell-number{font-size:.5rem}.cwp-grid{gap:2px;padding:6px}.cwp-actions{flex-direction:column;gap:.5rem}.cwp-btn{justify-content:center;width:100%}.cwp-hint{align-items:center;flex-direction:column;gap:.25rem}.cwp-clue{padding:.5rem .625rem}.cwp-clue-text{font-size:.8rem}.cwp-clues{padding:1rem}}:root{--cgen-primary:#f59e0b;--cgen-primary-dark:#d97706;--cgen-accent:#ef4444;--cgen-accent-dark:#dc2626;--cgen-success:#10b981;--cgen-error:#ef4444;--cgen-text:#0f172a;--cgen-text-secondary:#64748b;--cgen-text-muted:#94a3b8;--cgen-border:#e2e8f0;--cgen-bg:#fff;--cgen-bg-subtle:#fffbeb;--cgen-gradient:linear-gradient(135deg,var(--cgen-primary) 0%,var(--cgen-accent) 100%);--cgen-radius:16px;--cgen-radius-sm:10px;--cgen-radius-lg:24px;--cgen-shadow:0 4px 24px #0f172a14;--cgen-shadow-lg:0 12px 48px #0f172a1f;--cgen-transition:cubic-bezier(0.16,1,0.3,1)}.cgen-page{background:#fff;background:var(--cgen-bg);color:#0f172a;color:var(--cgen-text);min-height:100vh;overflow-x:hidden;position:relative}.cgen-ambient{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.cgen-ambient-orb{border-radius:50%;filter:blur(120px);position:absolute}.cgen-ambient-orb--1{background:linear-gradient(135deg,#f59e0b,#ef4444);background:linear-gradient(135deg,var(--cgen-primary) 0,var(--cgen-accent) 100%);height:800px;opacity:.07;right:-300px;top:-400px;width:800px}.cgen-ambient-orb--2{background:#f59e0b;background:var(--cgen-primary);bottom:-200px;height:600px;left:-200px;opacity:.05;width:600px}.cgen-grid-pattern{background-image:linear-gradient(#f59e0b08 1px,#0000 0),linear-gradient(90deg,#f59e0b08 1px,#0000 0);background-size:40px 40px;bottom:0;left:0;position:absolute;right:0;top:0}.cgen-hero{margin:0 auto;max-width:800px;padding:3rem 2rem 2rem;position:relative;text-align:center;z-index:1}.cgen-hero-content{animation:cgen-fadeUp .8s cubic-bezier(.16,1,.3,1) forwards;animation:cgen-fadeUp .8s var(--cgen-transition) forwards}@keyframes cgen-fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.cgen-hero-badge{align-items:center;background:linear-gradient(135deg,#f59e0b26,#ef44441a);border:1px solid #f59e0b4d;border-radius:100px;color:#d97706;color:var(--cgen-primary-dark);display:inline-flex;font-size:.8rem;font-weight:700;gap:.5rem;margin-bottom:1.25rem;padding:.5rem 1rem}.cgen-hero-title{color:#0f172a;color:var(--cgen-text);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;margin:0 0 1rem}.cgen-hero-title-accent{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);-webkit-background-clip:text;background-clip:text;padding-bottom:.1em}.cgen-hero-subtitle{color:#64748b;color:var(--cgen-text-secondary);font-size:1.0625rem;line-height:1.6;margin:0 auto;max-width:520px}.cgen-main{margin:0 auto;max-width:1250px;padding:0 1.5rem 4rem;position:relative;z-index:1}.cgen-upload-wrapper{background:#fff;background:var(--cgen-bg);border:1px solid #e2e8f0;border:1px solid var(--cgen-border);border-radius:24px;border-radius:var(--cgen-radius-lg);box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--cgen-shadow-lg);overflow:hidden;position:relative}.cgen-upload-wrapper:before{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0}.cgen-dropzone{background:linear-gradient(180deg,#fffbeb,#fff);background:linear-gradient(180deg,var(--cgen-bg-subtle) 0,var(--cgen-bg) 100%);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--cgen-border);cursor:pointer;padding:3rem 2.5rem;position:relative}.cgen-dropzone,.cgen-dropzone:before{transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--cgen-transition)}.cgen-dropzone:before{border:2px dashed #e2e8f0;border:2px dashed var(--cgen-border);border-radius:16px;border-radius:var(--cgen-radius);content:"";inset:1.25rem;pointer-events:none;position:absolute}.cgen-dropzone:hover:before{background:linear-gradient(135deg,#f59e0b0a,#ef444405);border-color:#f59e0b;border-color:var(--cgen-primary)}.cgen-dropzone--dragging:before{background:linear-gradient(135deg,#f59e0b14,#ef44440a);border-color:#f59e0b;border-color:var(--cgen-primary);border-style:solid}.cgen-dropzone--has-file{background:linear-gradient(180deg,#f59e0b0d,#fff);background:linear-gradient(180deg,#f59e0b0d 0,var(--cgen-bg) 100%)}.cgen-dropzone--has-file:before{border-color:#f59e0b;border-color:var(--cgen-primary);border-style:solid}.cgen-dropzone-content{align-items:center;display:flex;flex-direction:column;gap:.875rem;position:relative;z-index:1}.cgen-dropzone-icon{align-items:center;background:linear-gradient(135deg,#f59e0b26,#ef44441a);border-radius:16px;color:#f59e0b;color:var(--cgen-primary);display:flex;height:72px;justify-content:center;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--cgen-transition);width:72px}.cgen-dropzone:hover .cgen-dropzone-icon{box-shadow:0 8px 24px #f59e0b40;transform:translateY(-4px) scale(1.05)}.cgen-dropzone-text{text-align:center}.cgen-dropzone-primary{color:#0f172a;color:var(--cgen-text);display:block;font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.cgen-dropzone-secondary{color:#94a3b8;color:var(--cgen-text-muted);display:block;font-size:.9rem}.cgen-browse-btn{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);border-radius:10px;border-radius:var(--cgen-radius-sm);box-shadow:0 4px 16px #f59e0b59;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;margin-top:.25rem;padding:.875rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--cgen-transition)}.cgen-browse-btn:hover{box-shadow:0 8px 28px #f59e0b73;transform:translateY(-2px)}.cgen-browse-btn input{display:none}.cgen-formats{display:flex;flex-wrap:wrap;gap:.375rem;justify-content:center;margin-top:.5rem}.cgen-formats span{background:#fff;background:var(--cgen-bg);border:1px solid #e2e8f0;border:1px solid var(--cgen-border);border-radius:4px;color:#94a3b8;color:var(--cgen-text-muted);font-size:.65rem;font-weight:600;letter-spacing:.05em;padding:.25rem .5rem}.cgen-file-display{align-items:center;background:linear-gradient(135deg,#f59e0b1a,#ef44440d);border:1px solid #f59e0b40;border-radius:10px;border-radius:var(--cgen-radius-sm);display:flex;gap:1rem;margin:0 auto;max-width:400px;padding:1rem 1.5rem;position:relative;width:100%;z-index:1}.cgen-file-icon{align-items:center;background:linear-gradient(135deg,#f59e0b33,#ef44441a);border-radius:10px;color:#f59e0b;color:var(--cgen-primary);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.cgen-file-info{flex:1 1;min-width:0}.cgen-file-name{color:#0f172a;color:var(--cgen-text);display:block;font-size:.9rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cgen-file-size{color:#64748b;color:var(--cgen-text-secondary);display:block;font-size:.75rem;margin-top:.125rem}.cgen-file-remove{background:none;border:none;border-radius:6px;color:#94a3b8;color:var(--cgen-text-muted);cursor:pointer;padding:.375rem;transition:all .2s}.cgen-file-remove:hover{background:#ef44441a;color:#ef4444;color:var(--cgen-error)}.cgen-options{padding:1.75rem 2.5rem}.cgen-info-box{align-items:center;background:linear-gradient(135deg,#f59e0b14,#ef44440a);border:1px solid #f59e0b33;border-radius:10px;border-radius:var(--cgen-radius-sm);color:#d97706;color:var(--cgen-primary-dark);display:flex;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.cgen-info-box span{color:#64748b;color:var(--cgen-text-secondary);font-size:.9rem}.cgen-generate-btn{align-items:center;background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);border:none;border-radius:10px;border-radius:var(--cgen-radius-sm);box-shadow:0 4px 16px #f59e0b59;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 2rem;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--cgen-transition);width:100%}.cgen-generate-btn:hover:not(:disabled){box-shadow:0 8px 24px #f59e0b73;transform:translateY(-2px)}.cgen-generate-btn:disabled{cursor:not-allowed;opacity:.5}.cgen-spinner{animation:cgen-spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes cgen-spin{to{transform:rotate(1turn)}}.cgen-message{border-radius:10px;border-radius:var(--cgen-radius-sm);font-size:.85rem;font-weight:600;margin-top:1rem;padding:.875rem 1rem;text-align:center}.cgen-message--error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444;color:var(--cgen-error)}.cgen-message--success{background:#10b9811a;border:1px solid #10b98133;color:#10b981;color:var(--cgen-success)}.cgen-success{animation:cgen-slideUp .5s cubic-bezier(.16,1,.3,1);animation:cgen-slideUp .5s var(--cgen-transition);background:linear-gradient(135deg,#fff,#f59e0b08);background:linear-gradient(135deg,var(--cgen-bg) 0,#f59e0b08 100%);border:1px solid #e2e8f0;border:1px solid var(--cgen-border);border-radius:24px;border-radius:var(--cgen-radius-lg);box-shadow:0 4px 24px #0f172a14;box-shadow:var(--cgen-shadow);margin-top:2rem;padding:2rem;position:relative}.cgen-success:before{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);content:"";height:3px;left:0;position:absolute;right:0;top:0}@keyframes cgen-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cgen-success-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:1.5rem}.cgen-success-header,.cgen-success-header-left{align-items:center;display:flex;gap:1rem}.cgen-success-check{align-items:center;background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);border-radius:50%;box-shadow:0 4px 12px #f59e0b59;color:#fff;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.cgen-success-text h2{color:#0f172a;color:var(--cgen-text);font-size:1.25rem;font-weight:700;margin:0 0 .125rem}.cgen-success-text p{color:#64748b;color:var(--cgen-text-secondary);font-size:.9rem;margin:0}.cgen-success-actions{align-items:center;display:flex;gap:.625rem}.cgen-header-action{align-items:center;background:#fff;background:var(--cgen-bg);border:1px solid #e2e8f0;border:1px solid var(--cgen-border);border-radius:10px;color:#64748b;color:var(--cgen-text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1rem;transition:all .2s ease}.cgen-header-action:hover{background:#f1f5f9;border-color:#cbd5e1;color:#0f172a;color:var(--cgen-text)}.cgen-header-action--new{border:none;box-shadow:0 2px 8px #f59e0b4d}.cgen-header-action--new,.cgen-header-action--new:hover{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);color:#fff}.cgen-header-action--new:hover{box-shadow:0 4px 12px #f59e0b66;transform:translateY(-1px)}.cgen-puzzle-preview{margin:1rem 0}.cgen-actions{display:flex;flex-wrap:wrap;gap:.75rem}.cgen-action{align-items:center;border:none;border-radius:10px;border-radius:var(--cgen-radius-sm);cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;min-width:140px;padding:.875rem 1.25rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--cgen-transition)}.cgen-action--primary{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);box-shadow:0 2px 8px #f59e0b4d;color:#fff}.cgen-action--primary:hover{box-shadow:0 4px 12px #f59e0b66;transform:translateY(-2px)}.cgen-action--secondary{background:#fff;background:var(--cgen-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--cgen-border);color:#0f172a;color:var(--cgen-text)}.cgen-action--secondary:hover{border-color:#f59e0b;border-color:var(--cgen-primary);color:#f59e0b;color:var(--cgen-primary);transform:translateY(-2px)}.cgen-upgrade-banner{align-items:center;background:linear-gradient(135deg,#f59e0b1a,#ef444414);border:1px solid #f59e0b40;border-radius:10px;border-radius:var(--cgen-radius-sm);display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin-top:1.5rem;padding:1rem 1.25rem}.cgen-upgrade-content{align-items:center;color:#d97706;color:var(--cgen-primary-dark);display:flex;flex:1 1;gap:.5rem}.cgen-upgrade-content span{color:#64748b;color:var(--cgen-text-secondary);font-size:.85rem;font-weight:500}.cgen-upgrade-btn{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);border:none;border-radius:10px;border-radius:var(--cgen-radius-sm);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.625rem 1.25rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--cgen-transition)}.cgen-upgrade-btn:hover{transform:translateY(-2px)}.cgen-process{background:linear-gradient(180deg,#fffbeb,#fff);background:linear-gradient(180deg,var(--cgen-bg-subtle) 0,var(--cgen-bg) 100%);overflow:hidden;padding:5rem 2rem 6rem;position:relative;z-index:1}.cgen-process-flow{display:flex;flex-direction:column;margin:0 auto;max-width:900px}.cgen-flow-item{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:auto 1fr auto;padding:2rem 0}.cgen-flow-item--left{text-align:left}.cgen-flow-item--right{text-align:right}.cgen-flow-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(3.5rem,8vw,5rem);font-weight:900;line-height:1;opacity:.15;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--cgen-transition)}.cgen-flow-item:hover .cgen-flow-number{opacity:.35}.cgen-flow-content{max-width:340px}.cgen-flow-item--right .cgen-flow-content{margin-left:auto}.cgen-flow-content h3{color:#0f172a;color:var(--cgen-text);font-size:1.25rem;font-weight:800;margin:0 0 .5rem;transition:color .3s}.cgen-flow-item:hover .cgen-flow-content h3{color:#f59e0b;color:var(--cgen-primary)}.cgen-flow-content p{color:#64748b;color:var(--cgen-text-secondary);font-size:.95rem;line-height:1.6;margin:0}.cgen-flow-visual{align-items:center;display:flex;height:80px;justify-content:center;width:80px}.cgen-flow-icon{color:#94a3b8;color:var(--cgen-text-muted);height:60px;opacity:.4;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--cgen-transition);width:60px}.cgen-flow-item:hover .cgen-flow-icon{color:#f59e0b;color:var(--cgen-primary);opacity:.7}.cgen-flow-connector{display:flex;height:50px;justify-content:center;opacity:.4}.cgen-flow-connector svg{height:100%;width:40px}.cgen-value{margin:0 auto;max-width:1100px;padding:5rem 2rem 6rem;position:relative;z-index:1}.cgen-value-header{margin-bottom:3rem;text-align:center}.cgen-value-header h2{color:#0f172a;color:var(--cgen-text);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;letter-spacing:-.03em;margin:0}.cgen-value-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-auto-rows:minmax(160px,auto);grid-template-columns:repeat(12,1fr)}.cgen-value-card{background:#fff;background:var(--cgen-bg);border:1px solid #e2e8f0;border:1px solid var(--cgen-border);border-radius:24px;border-radius:var(--cgen-radius-lg);grid-column:span 6;overflow:hidden;position:relative;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--cgen-transition)}.cgen-value-card:hover{border-color:#0000;box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--cgen-shadow-lg);transform:translateY(-6px)}.cgen-value-card-blob{border-radius:50%;filter:blur(60px);height:180px;opacity:0;pointer-events:none;position:absolute;transition:all .6s cubic-bezier(.16,1,.3,1);transition:all .6s var(--cgen-transition);width:180px}.cgen-value-card:first-child .cgen-value-card-blob{background:#f59e0b;background:var(--cgen-primary);right:-50px;top:-50px}.cgen-value-card:nth-child(2) .cgen-value-card-blob{background:#ef4444;background:var(--cgen-accent);bottom:-50px;left:-50px}.cgen-value-card:nth-child(3) .cgen-value-card-blob{background:#10b981;left:-50px;top:-50px}.cgen-value-card:nth-child(4) .cgen-value-card-blob{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);bottom:-50px;right:-50px}.cgen-value-card:hover .cgen-value-card-blob{opacity:.15}.cgen-value-card-inner{display:flex;flex-direction:column;height:100%;padding:1.75rem;position:relative;z-index:1}.cgen-value-card-icon{align-items:center;background:linear-gradient(135deg,#f59e0b26,#ef44441a);border-radius:12px;display:flex;height:46px;justify-content:center;margin-bottom:1.25rem;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--cgen-transition);width:46px}.cgen-value-card-icon svg{color:#f59e0b;color:var(--cgen-primary);height:22px;width:22px}.cgen-value-card:hover .cgen-value-card-icon{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);transform:scale(1.1) rotate(-5deg)}.cgen-value-card:hover .cgen-value-card-icon svg{color:#fff}.cgen-value-card h3{color:#0f172a;color:var(--cgen-text);font-size:1.125rem;font-weight:700;margin:0 0 .5rem;transition:color .3s}.cgen-value-card:hover h3{color:#f59e0b;color:var(--cgen-primary)}.cgen-value-card p{color:#64748b;color:var(--cgen-text-secondary);font-size:.9rem;line-height:1.6;margin:0}.cgen-value-card--featured{grid-column:span 7;grid-row:span 2}.cgen-value-card--featured .cgen-value-card-inner{padding:2rem}.cgen-value-card--featured .cgen-value-card-icon{height:56px;width:56px}.cgen-value-card--featured .cgen-value-card-icon svg{height:28px;width:28px}.cgen-value-card--featured h3{font-size:1.375rem}.cgen-value-card--wide{grid-column:span 12}.cgen-value-card--wide .cgen-value-card-inner{align-items:center;flex-direction:row;gap:1.5rem}.cgen-value-card--wide .cgen-value-card-icon{flex-shrink:0;margin-bottom:0}.cgen-value-card--wide h3{margin-bottom:.25rem}.cgen-value-card:nth-child(2),.cgen-value-card:nth-child(3){grid-column:span 5}.cgen-faq{background:linear-gradient(180deg,#fff,#fffbeb);background:linear-gradient(180deg,var(--cgen-bg) 0,var(--cgen-bg-subtle) 100%);padding:5rem 2rem;position:relative;z-index:1}.cgen-faq-header{margin:0 auto 3rem;max-width:500px;text-align:center}.cgen-faq-eyebrow{background:#f59e0b1a;border-radius:100px;color:#f59e0b;color:var(--cgen-primary);display:inline-flex;font-size:.75rem;font-weight:700;letter-spacing:.15em;margin-bottom:.75rem;padding:.4rem .875rem;text-transform:uppercase}.cgen-faq-header h2{color:#0f172a;color:var(--cgen-text);font-size:clamp(1.75rem,4vw,2rem);font-weight:800;margin:0}.cgen-faq-list{display:flex;flex-direction:column;gap:.75rem;margin:0 auto;max-width:700px}.cgen-faq-item{background:#fff;background:var(--cgen-bg);border:1px solid #e2e8f0;border:1px solid var(--cgen-border);border-radius:16px;border-radius:var(--cgen-radius);overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--cgen-transition)}.cgen-faq-item:hover{border-color:#f59e0b4d}.cgen-faq-item--open{border-color:#f59e0b;border-color:var(--cgen-primary);box-shadow:0 4px 16px #f59e0b1a}.cgen-faq-trigger{align-items:center;background:none;border:none;color:#0f172a;color:var(--cgen-text);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:1rem;justify-content:space-between;padding:1.125rem 1.25rem;text-align:left;width:100%}.cgen-faq-trigger:hover{color:#f59e0b;color:var(--cgen-primary)}.cgen-faq-trigger svg{color:#94a3b8;color:var(--cgen-text-muted);flex-shrink:0;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--cgen-transition)}.cgen-faq-item--open .cgen-faq-trigger svg{color:#f59e0b;color:var(--cgen-primary);transform:rotate(45deg)}.cgen-faq-content{max-height:0;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--cgen-transition)}.cgen-faq-item--open .cgen-faq-content{max-height:400px}.cgen-faq-content p{color:#64748b;color:var(--cgen-text-secondary);font-size:.9rem;line-height:1.7;margin:0;padding:0 1.25rem 1.25rem}.cgen-cta{align-items:center;background:#fffbeb;background:var(--cgen-bg-subtle);border-top:1px solid #e2e8f0;border-top:1px solid var(--cgen-border);display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:3.5rem 2rem;position:relative;z-index:1}.cgen-cta p{color:#0f172a;color:var(--cgen-text);font-size:1.125rem;font-weight:600;margin:0}.cgen-cta-btn{background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);border:none;border-radius:10px;border-radius:var(--cgen-radius-sm);box-shadow:0 4px 12px #f59e0b4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.875rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--cgen-transition)}.cgen-cta-btn:hover{box-shadow:0 6px 16px #f59e0b66;transform:translateY(-2px)}.cgen-immersive{animation:cgen-fadeIn .3s ease;background:linear-gradient(180deg,#1e293b,#0f172a);bottom:0;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;right:0;top:0;width:100vw;z-index:999999}@keyframes cgen-fadeIn{0%{opacity:0}to{opacity:1}}.cgen-immersive-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:1.5rem;top:1.5rem;transition:all .2s;width:48px;z-index:1000001}.cgen-immersive-close:hover{background:#fff3;transform:scale(1.05)}.cgen-immersive-header{border-bottom:1px solid #ffffff1a;padding:1.5rem 2rem;text-align:center}.cgen-immersive-header h2{color:#fff;font-size:1.5rem;font-weight:700;margin:0}.cgen-immersive-content{display:flex;flex:1 1;justify-content:center;padding:2rem}@media (max-width:900px){.cgen-flow-item{gap:1rem;grid-template-columns:1fr;text-align:center!important}.cgen-flow-item--right .cgen-flow-content{margin-left:0}.cgen-flow-content{max-width:100%;order:2}.cgen-flow-number{font-size:3.5rem;order:1}.cgen-flow-visual{margin:0 auto;order:3}.cgen-flow-connector{height:35px}.cgen-value-grid{grid-template-columns:repeat(2,1fr)}.cgen-value-card--featured{grid-column:span 2;grid-row:span 1}.cgen-value-card:nth-child(2),.cgen-value-card:nth-child(3){grid-column:span 1}.cgen-value-card--wide{grid-column:span 2}}@media (max-width:768px){.cgen-page{padding-top:3.5rem}.cgen-hero{padding:2.5rem 1.5rem 2rem}.cgen-main{padding:0 1rem 3rem}.cgen-dropzone{padding:2.5rem 1.5rem}.cgen-dropzone:before{inset:.75rem}.cgen-options,.cgen-success{padding:1.5rem}.cgen-success-header{gap:1rem}.cgen-success-header,.cgen-success-header-left{flex-direction:column;text-align:center}.cgen-success-actions{justify-content:center;width:100%}.cgen-header-action span{display:none}.cgen-header-action{padding:.75rem}.cgen-actions,.cgen-upgrade-banner{flex-direction:column}.cgen-upgrade-banner{text-align:center}.cgen-process{padding:3.5rem 1.5rem 4rem}.cgen-value{padding:3.5rem 1.5rem}.cgen-value-grid{gap:1rem;grid-template-columns:1fr}.cgen-value-card,.cgen-value-card--featured,.cgen-value-card--wide,.cgen-value-card:nth-child(2),.cgen-value-card:nth-child(3){grid-column:span 1;grid-row:span 1}.cgen-value-card--wide .cgen-value-card-inner{align-items:flex-start;flex-direction:column}.cgen-value-card--wide .cgen-value-card-icon{margin-bottom:1rem}.cgen-faq{padding:3.5rem 1.5rem}.cgen-cta{flex-direction:column;gap:1.25rem;padding:2.5rem 1.5rem;text-align:center}.cgen-cta-btn{max-width:260px;width:100%}.cgen-immersive-content{padding:1.5rem}}@media (max-width:480px){.cgen-hero{padding:2rem 1rem 1.5rem}.cgen-hero-title{font-size:1.75rem}.cgen-dropzone{padding:2rem 1rem}.cgen-dropzone-icon{height:60px;width:60px}.cgen-browse-btn{font-size:.875rem;padding:.75rem 1.5rem}.cgen-generate-btn{font-size:.9375rem;padding:.875rem 1.5rem}}.cgen-share-modal-overlay{align-items:center;animation:cgen-fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172ab3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000000}.cgen-share-modal{animation:cgen-slideUp .3s ease;background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000040;max-width:450px;padding:2rem;position:relative;width:100%}.cgen-share-modal-close{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s;width:36px}.cgen-share-modal-close:hover{background:#e2e8f0;color:#334155}.cgen-share-modal-icon{align-items:center;background:linear-gradient(135deg,#f59e0b26,#ef44441a);border-radius:50%;color:#f59e0b;color:var(--cgen-primary);display:flex;height:64px;justify-content:center;margin:0 auto 1.25rem;width:64px}.cgen-share-modal h3{color:#0f172a;color:var(--cgen-text);font-size:1.25rem;font-weight:700;margin:0 0 .5rem;text-align:center}.cgen-share-modal p{color:#64748b;color:var(--cgen-text-secondary);font-size:.9375rem;margin:0 0 1.5rem;text-align:center}.cgen-share-link-box{background:#f8fafc;border:1px solid #e2e8f0;border:1px solid var(--cgen-border);border-radius:12px;display:flex;gap:.5rem;padding:.5rem}.cgen-share-link-box input{background:none;border:none;color:#0f172a;color:var(--cgen-text);flex:1 1;font-size:.875rem;min-width:0;padding:.5rem .75rem}.cgen-share-link-box input:focus{outline:none}.cgen-share-link-box button{align-items:center;background:linear-gradient(135deg,#f59e0b,#ef4444);background:var(--cgen-gradient);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.375rem;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.cgen-share-link-box button:hover{box-shadow:0 4px 12px #f59e0b4d;transform:translateY(-1px)}.cgen-share-link-box button.copied{background:linear-gradient(135deg,#10b981,#059669)}.tf-viewer{margin:0 auto;max-width:700px;width:100%}.tf-viewer--immersive{max-width:800px}.tf-viewer-title{color:#0f172a;font-size:1.25rem;font-weight:700;margin:0 0 1.5rem;text-align:center}.tf-viewer-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.tf-viewer-spinner{animation:tf-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#10b981;height:40px;margin-bottom:1rem;width:40px}@keyframes tf-spin{to{transform:rotate(1turn)}}.tf-progress{margin-bottom:1.5rem}.tf-progress-bar{background:#e2e8f0;border-radius:100px;height:6px;margin-bottom:.75rem;overflow:hidden}.tf-progress-fill{background:linear-gradient(135deg,#10b981,#14b8a6);border-radius:100px;height:100%;transition:width .4s ease}.tf-progress-text{color:#64748b;display:flex;font-size:.875rem;justify-content:space-between}.tf-score{color:#10b981;font-weight:600}.tf-statement-card{background:#fff;border:2px solid #e2e8f0;border-radius:20px;box-shadow:0 4px 24px #0f172a0f;margin-bottom:1.5rem;padding:2rem;transition:all .3s ease}.tf-statement-card--correct{background:linear-gradient(180deg,#f0fdf4,#fff 50%);border-color:#10b981}.tf-statement-card--wrong{background:linear-gradient(180deg,#fef2f2,#fff 50%);border-color:#ef4444}.tf-statement-content{margin-bottom:2rem;text-align:center}.tf-statement-text{color:#0f172a;font-size:1.25rem;font-weight:600;line-height:1.6;margin:0}.tf-answer-buttons{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.tf-answer-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:16px;cursor:pointer;display:flex;flex-direction:column;font-size:1.125rem;font-weight:700;gap:.75rem;justify-content:center;padding:1.5rem 1rem;transition:all .3s ease}.tf-answer-btn--true{color:#10b981}.tf-answer-btn--true:hover{background:linear-gradient(180deg,#f0fdf4,#fff);border-color:#10b981;box-shadow:0 8px 24px #10b98133;transform:translateY(-4px)}.tf-answer-btn--false{color:#ef4444}.tf-answer-btn--false:hover{background:linear-gradient(180deg,#fef2f2,#fff);border-color:#ef4444;box-shadow:0 8px 24px #ef444433;transform:translateY(-4px)}.tf-result{text-align:center}.tf-result-badge{align-items:center;border-radius:100px;display:inline-flex;font-size:1rem;font-weight:700;gap:.5rem;margin-bottom:1rem;padding:.75rem 1.5rem}.tf-result-badge--correct{background:linear-gradient(135deg,#10b981,#14b8a6);color:#fff}.tf-result-badge--wrong{background:linear-gradient(135deg,#ef4444,#f97316);color:#fff}.tf-result-answer{color:#64748b;font-size:1rem;margin:0 0 1rem}.tf-result-answer strong{color:#0f172a}.tf-explanation-toggle{align-items:center;background:none;border:none;color:#3b82f6;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.375rem;padding:.5rem;transition:all .2s}.tf-explanation-toggle:hover{color:#2563eb}.tf-explanation-toggle svg{transition:transform .2s}.tf-explanation{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:1rem;padding:1rem 1.25rem;text-align:left}.tf-explanation p{color:#475569;font-size:.9rem;line-height:1.6;margin:0}.tf-navigation{display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.tf-nav-btn{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;color:#475569;cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.875rem 1.5rem;transition:all .2s ease}.tf-nav-btn:hover:not(:disabled){border-color:#10b981;color:#10b981;transform:translateY(-2px)}.tf-nav-btn:disabled{cursor:not-allowed;opacity:.4}.tf-nav-btn--primary{background:linear-gradient(135deg,#10b981,#14b8a6);border-color:#0000;box-shadow:0 4px 12px #10b9814d;color:#fff}.tf-nav-btn--primary:hover:not(:disabled){border-color:#0000;box-shadow:0 6px 16px #10b98166;color:#fff;transform:translateY(-2px)}.tf-dots{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.tf-dot{background:#fff;border:2px solid #e2e8f0;border-radius:50%;cursor:pointer;height:12px;padding:0;transition:all .2s ease;width:12px}.tf-dot--active,.tf-dot:hover{border-color:#10b981;transform:scale(1.2)}.tf-dot--active,.tf-dot--correct{background:#10b981}.tf-dot--correct{border-color:#10b981}.tf-dot--wrong{background:#ef4444;border-color:#ef4444}.tf-completion{background:#fff;border:1px solid #e2e8f0;border-radius:24px;box-shadow:0 4px 24px #0f172a0f;padding:2.5rem;text-align:center}.tf-completion-icon{align-items:center;background:linear-gradient(135deg,#10b981,#14b8a6);border-radius:50%;box-shadow:0 8px 24px #10b9814d;color:#fff;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.tf-completion-icon--perfect{background:linear-gradient(135deg,#fbbf24,#f59e0b);box-shadow:0 8px 24px #f59e0b59}.tf-completion-title{color:#0f172a;font-size:1.75rem;font-weight:800;margin:0 0 .5rem}.tf-completion-score{color:#64748b;font-size:1.125rem;margin:0 0 1.5rem}.tf-completion-score strong{color:#10b981}.tf-completion-percentage{align-items:center;display:flex;gap:1rem;margin:0 auto 2rem;max-width:300px}.tf-completion-bar{background:#e2e8f0;border-radius:100px;flex:1 1;height:10px;overflow:hidden}.tf-completion-fill{background:linear-gradient(135deg,#10b981,#14b8a6);border-radius:100px;height:100%;transition:width .6s ease}.tf-completion-percentage span{color:#10b981;font-size:1.25rem;font-weight:700;min-width:50px}.tf-completion-actions{align-items:center;display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2rem}.tf-action-btn{align-items:center;background:#f1f5f9;border:1.5px solid #0000;border-radius:12px;color:#475569;cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1.75rem;transition:all .2s ease}.tf-action-btn:hover{transform:translateY(-2px)}.tf-action-btn--primary{background:linear-gradient(135deg,#10b981,#14b8a6);box-shadow:0 4px 12px #10b9814d;color:#fff;font-size:1rem;padding:1rem 2rem}.tf-action-btn--primary:hover{box-shadow:0 6px 20px #10b98166}.tf-completion-secondary{display:flex;flex-wrap:wrap;gap:.625rem;justify-content:center}.tf-action-btn--secondary{background:#fff;border-color:#e2e8f0;font-size:.8125rem;gap:.375rem;padding:.625rem 1rem}.tf-action-btn--secondary:hover{background:#f0fdf4;border-color:#10b981;color:#10b981}.tf-action-btn--secondary svg{flex-shrink:0}.tf-btn{border:none;display:inline-flex;font-size:1rem;gap:.5rem;padding:.875rem 1.75rem;transition:all .3s ease}.tf-btn--primary{background:linear-gradient(135deg,#10b981,#14b8a6);box-shadow:0 4px 12px #10b9814d;color:#fff}.tf-btn--primary:hover{box-shadow:0 6px 16px #10b98166;transform:translateY(-2px)}.tf-review{border-top:1px solid #e2e8f0;padding-top:2rem;text-align:left}.tf-review h4{color:#0f172a;font-size:1rem;font-weight:700;margin:0 0 1rem}.tf-review-list{display:flex;flex-direction:column;gap:.75rem}.tf-review-item{align-items:flex-start;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:1rem;padding:1rem}.tf-review-item--correct{background:#10b9810d;border-color:#10b9814d}.tf-review-item--wrong{background:#ef44440d;border-color:#ef44444d}.tf-review-number{align-items:center;background:#e2e8f0;border-radius:50%;color:#64748b;display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:28px;justify-content:center;width:28px}.tf-review-item--correct .tf-review-number{background:#10b981;color:#fff}.tf-review-item--wrong .tf-review-number{background:#ef4444;color:#fff}.tf-review-content{flex:1 1;min-width:0}.tf-review-statement{color:#0f172a;font-size:.9rem;font-weight:500;line-height:1.5;margin:0 0 .5rem}.tf-review-answer{color:#64748b;font-size:.8rem}.tf-review-answer strong{color:#10b981}.tf-review-explanation{color:#64748b;font-size:.8rem;font-style:italic;margin:.5rem 0 0}.tf-review-icon{flex-shrink:0}.tf-review-item--correct .tf-review-icon{color:#10b981}.tf-review-item--wrong .tf-review-icon{color:#ef4444}.tf-viewer--immersive .tf-statement-card{background:#fffffff2;box-shadow:0 8px 32px #00000026}.tf-viewer--immersive .tf-statement-text{font-size:1.5rem}.tf-viewer--immersive .tf-answer-btn{background:#fffffff2;font-size:1.25rem;padding:2rem 1.5rem}.tf-viewer--immersive .tf-completion{background:#fffffff2}.tf-viewer--immersive .tf-action-btn--secondary{background:#ffffffe6}@media (max-width:600px){.tf-statement-card{padding:1.5rem}.tf-statement-text{font-size:1.125rem}.tf-answer-buttons{gap:.75rem;grid-template-columns:1fr}.tf-answer-btn{flex-direction:row;font-size:1rem;padding:1rem 1.5rem}.tf-navigation{flex-direction:column}.tf-nav-btn{justify-content:center}.tf-completion{padding:1.5rem}.tf-completion-title{font-size:1.5rem}.tf-completion-icon{height:64px;width:64px}.tf-completion-icon svg{height:32px;width:32px}.tf-review-item{padding:.875rem}.tf-viewer--immersive .tf-statement-text{font-size:1.25rem}.tf-completion-secondary{flex-direction:column;width:100%}.tf-action-btn--secondary{justify-content:center;width:100%}.tf-action-btn--primary{width:100%}}:root{--tfgen-primary:#10b981;--tfgen-primary-dark:#059669;--tfgen-accent:#14b8a6;--tfgen-accent-dark:#0d9488;--tfgen-false:#ef4444;--tfgen-success:#10b981;--tfgen-error:#ef4444;--tfgen-text:#0f172a;--tfgen-text-secondary:#64748b;--tfgen-text-muted:#94a3b8;--tfgen-border:#e2e8f0;--tfgen-bg:#fff;--tfgen-bg-subtle:#f0fdf4;--tfgen-gradient:linear-gradient(135deg,var(--tfgen-primary) 0%,var(--tfgen-accent) 100%);--tfgen-radius:16px;--tfgen-radius-sm:10px;--tfgen-radius-lg:24px;--tfgen-shadow:0 4px 24px #0f172a14;--tfgen-shadow-lg:0 12px 48px #0f172a1f;--tfgen-transition:cubic-bezier(0.16,1,0.3,1)}.tfgen-page{background:#fff;background:var(--tfgen-bg);color:#0f172a;color:var(--tfgen-text);min-height:100vh;overflow-x:hidden;position:relative}.tfgen-ambient{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.tfgen-ambient-orb{border-radius:50%;filter:blur(120px);position:absolute}.tfgen-ambient-orb--1{background:linear-gradient(135deg,#10b981,#14b8a6);background:linear-gradient(135deg,var(--tfgen-primary) 0,var(--tfgen-accent) 100%);height:800px;opacity:.07;right:-300px;top:-400px;width:800px}.tfgen-ambient-orb--2{background:#14b8a6;background:var(--tfgen-accent);bottom:-200px;height:600px;left:-200px;opacity:.05;width:600px}.tfgen-hero{margin:0 auto;max-width:800px;padding:3rem 2rem 2rem;position:relative;text-align:center;z-index:1}.tfgen-hero-content{animation:tfgen-fadeUp .8s cubic-bezier(.16,1,.3,1) forwards;animation:tfgen-fadeUp .8s var(--tfgen-transition) forwards}@keyframes tfgen-fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.tfgen-hero-icons{display:flex;gap:1rem;justify-content:center;margin-bottom:1.25rem}.tfgen-icon-false,.tfgen-icon-true{align-items:center;border-radius:50%;display:flex;height:48px;justify-content:center;width:48px}.tfgen-icon-true{background:linear-gradient(135deg,#10b98133,#14b8a626);color:#10b981;color:var(--tfgen-primary)}.tfgen-icon-false{background:linear-gradient(135deg,#ef444426,#f973161a);color:#ef4444;color:var(--tfgen-false)}.tfgen-hero-title{color:#0f172a;color:var(--tfgen-text);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;margin:0 0 1rem}.tfgen-hero-title-accent{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);-webkit-background-clip:text;background-clip:text;padding-bottom:.1em}.tfgen-hero-subtitle{color:#64748b;color:var(--tfgen-text-secondary);font-size:1.0625rem;line-height:1.6;margin:0 auto;max-width:520px}.tfgen-main{margin:0 auto;max-width:800px;padding:0 1.5rem 4rem;position:relative;z-index:1}.tfgen-upload-wrapper{background:#fff;background:var(--tfgen-bg);border:1px solid #e2e8f0;border:1px solid var(--tfgen-border);border-radius:24px;border-radius:var(--tfgen-radius-lg);box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--tfgen-shadow-lg);overflow:hidden;position:relative}.tfgen-upload-wrapper:before{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0}.tfgen-dropzone{background:linear-gradient(180deg,#f0fdf4,#fff);background:linear-gradient(180deg,var(--tfgen-bg-subtle) 0,var(--tfgen-bg) 100%);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--tfgen-border);cursor:pointer;padding:3rem 2.5rem;position:relative}.tfgen-dropzone,.tfgen-dropzone:before{transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--tfgen-transition)}.tfgen-dropzone:before{border:2px dashed #e2e8f0;border:2px dashed var(--tfgen-border);border-radius:16px;border-radius:var(--tfgen-radius);content:"";inset:1.25rem;pointer-events:none;position:absolute}.tfgen-dropzone:hover:before{background:linear-gradient(135deg,#10b9810a,#14b8a605);border-color:#10b981;border-color:var(--tfgen-primary)}.tfgen-dropzone--dragging:before{background:linear-gradient(135deg,#10b98114,#14b8a60a);border-color:#10b981;border-color:var(--tfgen-primary);border-style:solid}.tfgen-dropzone--has-file{background:linear-gradient(180deg,#10b9810d,#fff);background:linear-gradient(180deg,#10b9810d 0,var(--tfgen-bg) 100%)}.tfgen-dropzone--has-file:before{border-color:#10b981;border-color:var(--tfgen-primary);border-style:solid}.tfgen-dropzone-content{align-items:center;display:flex;flex-direction:column;gap:.875rem;position:relative;z-index:1}.tfgen-dropzone-icon{align-items:center;background:linear-gradient(135deg,#10b98126,#14b8a61a);border-radius:50%;color:#10b981;color:var(--tfgen-primary);display:flex;height:64px;justify-content:center;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--tfgen-transition);width:64px}.tfgen-dropzone:hover .tfgen-dropzone-icon{box-shadow:0 8px 24px #10b98140;transform:translateY(-4px) scale(1.05)}.tfgen-dropzone-text{text-align:center}.tfgen-dropzone-primary{color:#0f172a;color:var(--tfgen-text);display:block;font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.tfgen-dropzone-secondary{color:#94a3b8;color:var(--tfgen-text-muted);display:block;font-size:.9rem}.tfgen-browse-btn{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);border-radius:10px;border-radius:var(--tfgen-radius-sm);box-shadow:0 4px 16px #10b98159;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;margin-top:.25rem;padding:.875rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--tfgen-transition)}.tfgen-browse-btn:hover{box-shadow:0 8px 28px #10b98173;transform:translateY(-2px)}.tfgen-browse-btn input{display:none}.tfgen-formats{display:flex;flex-wrap:wrap;gap:.375rem;justify-content:center;margin-top:.5rem}.tfgen-formats span{background:#fff;background:var(--tfgen-bg);border:1px solid #e2e8f0;border:1px solid var(--tfgen-border);border-radius:4px;color:#94a3b8;color:var(--tfgen-text-muted);font-size:.65rem;font-weight:600;letter-spacing:.05em;padding:.25rem .5rem}.tfgen-file-display{align-items:center;background:linear-gradient(135deg,#10b9811a,#14b8a60d);border:1px solid #10b98140;border-radius:10px;border-radius:var(--tfgen-radius-sm);display:flex;gap:1rem;margin:0 auto;max-width:400px;padding:1rem 1.5rem;position:relative;width:100%;z-index:1}.tfgen-file-icon{align-items:center;background:linear-gradient(135deg,#10b98133,#14b8a61a);border-radius:10px;color:#10b981;color:var(--tfgen-primary);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.tfgen-file-info{flex:1 1;min-width:0}.tfgen-file-name{color:#0f172a;color:var(--tfgen-text);display:block;font-size:.9rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tfgen-file-size{color:#64748b;color:var(--tfgen-text-secondary);display:block;font-size:.75rem;margin-top:.125rem}.tfgen-file-remove{background:none;border:none;border-radius:6px;color:#94a3b8;color:var(--tfgen-text-muted);cursor:pointer;padding:.375rem;transition:all .2s}.tfgen-file-remove:hover{background:#ef44441a;color:#ef4444;color:var(--tfgen-error)}.tfgen-options{padding:1.75rem 2.5rem}.tfgen-options-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.tfgen-options-label{color:#64748b;color:var(--tfgen-text-secondary);font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.tfgen-upgrade-hint{align-items:center;background:linear-gradient(135deg,#10b9811f,#14b8a61f);border:1px solid #10b98140;border-radius:100px;color:#10b981;color:var(--tfgen-primary);cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:700;gap:.4rem;padding:.4rem .875rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--tfgen-transition)}.tfgen-upgrade-hint:hover{background:linear-gradient(135deg,#10b9812e,#14b8a62e)}.tfgen-count-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem}.tfgen-count-btn{align-items:center;background:#fff;background:var(--tfgen-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--tfgen-border);border-radius:10px;border-radius:var(--tfgen-radius-sm);color:#0f172a;color:var(--tfgen-text);cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.25rem;justify-content:center;min-width:52px;padding:.625rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--tfgen-transition)}.tfgen-count-btn:hover:not(:disabled):not(.tfgen-count-btn--active){border-color:#10b981;border-color:var(--tfgen-primary);color:#10b981;color:var(--tfgen-primary);transform:translateY(-2px)}.tfgen-count-btn--active{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);border-color:#0000;box-shadow:0 4px 12px #10b98159;color:#fff}.tfgen-count-btn--locked{cursor:not-allowed;opacity:.45}.tfgen-count-btn--custom{color:#94a3b8;color:var(--tfgen-text-muted)}.tfgen-lock-icon{opacity:.7}.tfgen-custom-input{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.tfgen-custom-input input{border:1.5px solid #e2e8f0;border:1.5px solid var(--tfgen-border);border-radius:10px;border-radius:var(--tfgen-radius-sm);font-size:1rem;font-weight:600;padding:.625rem .75rem;text-align:center;width:80px}.tfgen-custom-input input:focus{border-color:#10b981;border-color:var(--tfgen-primary);outline:none}.tfgen-custom-input span{color:#64748b;color:var(--tfgen-text-secondary);font-size:.9rem}.tfgen-back-btn{background:none;border:1.5px solid #e2e8f0;border:1.5px solid var(--tfgen-border);border-radius:10px;border-radius:var(--tfgen-radius-sm);color:#64748b;color:var(--tfgen-text-secondary);cursor:pointer;padding:.5rem}.tfgen-generate-btn{align-items:center;background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);border:none;border-radius:10px;border-radius:var(--tfgen-radius-sm);box-shadow:0 4px 16px #10b98159;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 2rem;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--tfgen-transition);width:100%}.tfgen-generate-btn:hover:not(:disabled){box-shadow:0 8px 24px #10b98173;transform:translateY(-2px)}.tfgen-generate-btn:disabled{cursor:not-allowed;opacity:.5}.tfgen-spinner{animation:tfgen-spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes tfgen-spin{to{transform:rotate(1turn)}}.tfgen-message{border-radius:10px;border-radius:var(--tfgen-radius-sm);font-size:.85rem;font-weight:600;margin-top:1rem;padding:.875rem 1rem;text-align:center}.tfgen-message--error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444;color:var(--tfgen-error)}.tfgen-message--success{background:#10b9811a;border:1px solid #10b98133;color:#10b981;color:var(--tfgen-success)}.tfgen-success{animation:tfgen-slideUp .5s cubic-bezier(.16,1,.3,1);animation:tfgen-slideUp .5s var(--tfgen-transition);background:#fff;background:var(--tfgen-bg);border:1px solid #e2e8f0;border:1px solid var(--tfgen-border);border-radius:24px;border-radius:var(--tfgen-radius-lg);box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--tfgen-shadow-lg);margin-top:2rem;overflow:hidden;position:relative}.tfgen-success:before{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);content:"";height:3px;left:0;position:absolute;right:0;top:0}@keyframes tfgen-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tfgen-success-header{align-items:center;background:linear-gradient(180deg,#10b9810a,#0000);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--tfgen-border);display:flex;gap:1rem;justify-content:space-between;padding:1.25rem 1.5rem}.tfgen-success-info{flex:1 1;min-width:0}.tfgen-success-title{color:#0f172a;color:var(--tfgen-text);font-size:1.125rem;font-weight:700;margin:0 0 .375rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tfgen-success-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.tfgen-meta-item{align-items:center;color:#64748b;color:var(--tfgen-text-secondary);display:inline-flex;font-size:.8125rem;gap:.375rem}.tfgen-meta-saved{color:#10b981;color:var(--tfgen-primary);font-weight:600}.tfgen-success-actions{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.tfgen-action-btn{align-items:center;background:#fff;background:var(--tfgen-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--tfgen-border);border-radius:10px;color:#64748b;color:var(--tfgen-text-secondary);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.tfgen-action-btn:hover{border-color:#10b981;border-color:var(--tfgen-primary);box-shadow:0 4px 12px #10b98126;color:#10b981;color:var(--tfgen-primary);transform:translateY(-2px)}.tfgen-action-btn--fullscreen{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);border-color:#0000;box-shadow:0 2px 8px #10b9814d;color:#fff}.tfgen-action-btn--fullscreen:hover{border-color:#0000;box-shadow:0 4px 16px #10b98166;color:#fff;transform:translateY(-2px)}.tfgen-action-btn--library:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;color:#3b82f6}.tfgen-action-btn--new:hover{border-color:#64748b;border-color:var(--tfgen-text-secondary);color:#0f172a;color:var(--tfgen-text)}.tfgen-quiz-container{padding:1.5rem}.tfgen-upgrade-banner{align-items:center;background:linear-gradient(135deg,#10b9811a,#14b8a614);border:1px solid #10b98140;border-radius:10px;border-radius:var(--tfgen-radius-sm);display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin:0 1.5rem 1.5rem;padding:1rem 1.25rem}.tfgen-upgrade-content{align-items:center;color:#10b981;color:var(--tfgen-primary);display:flex;flex:1 1;gap:.5rem}.tfgen-upgrade-content span{color:#64748b;color:var(--tfgen-text-secondary);font-size:.85rem;font-weight:500}.tfgen-upgrade-btn{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);border:none;border-radius:10px;border-radius:var(--tfgen-radius-sm);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.625rem 1.25rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--tfgen-transition)}.tfgen-upgrade-btn:hover{transform:translateY(-2px)}.tfgen-process{background:linear-gradient(180deg,#f0fdf4,#fff);background:linear-gradient(180deg,var(--tfgen-bg-subtle) 0,var(--tfgen-bg) 100%);overflow:hidden;padding:5rem 2rem 6rem;position:relative;z-index:1}.tfgen-process-flow{display:flex;flex-direction:column;margin:0 auto;max-width:900px}.tfgen-flow-item{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:auto 1fr auto;padding:2rem 0}.tfgen-flow-item--left{text-align:left}.tfgen-flow-item--right{text-align:right}.tfgen-flow-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(3.5rem,8vw,5rem);font-weight:900;line-height:1;opacity:.15;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--tfgen-transition)}.tfgen-flow-item:hover .tfgen-flow-number{opacity:.35}.tfgen-flow-content{max-width:340px}.tfgen-flow-item--right .tfgen-flow-content{margin-left:auto}.tfgen-flow-content h3{color:#0f172a;color:var(--tfgen-text);font-size:1.25rem;font-weight:800;margin:0 0 .5rem;transition:color .3s}.tfgen-flow-item:hover .tfgen-flow-content h3{color:#10b981;color:var(--tfgen-primary)}.tfgen-flow-content p{color:#64748b;color:var(--tfgen-text-secondary);font-size:.95rem;line-height:1.6;margin:0}.tfgen-flow-visual{align-items:center;display:flex;height:80px;justify-content:center;width:80px}.tfgen-flow-icon{color:#94a3b8;color:var(--tfgen-text-muted);height:60px;opacity:.4;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--tfgen-transition);width:60px}.tfgen-flow-item:hover .tfgen-flow-icon{color:#10b981;color:var(--tfgen-primary);opacity:.7}.tfgen-flow-connector{display:flex;height:50px;justify-content:center;opacity:.4}.tfgen-flow-connector svg{height:100%;width:40px}.tfgen-value{margin:0 auto;max-width:1100px;padding:5rem 2rem 6rem;position:relative;z-index:1}.tfgen-value-header{margin-bottom:3rem;text-align:center}.tfgen-value-header h2{color:#0f172a;color:var(--tfgen-text);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;letter-spacing:-.03em;margin:0}.tfgen-value-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-auto-rows:minmax(160px,auto);grid-template-columns:repeat(12,1fr)}.tfgen-value-card{background:#fff;background:var(--tfgen-bg);border:1px solid #e2e8f0;border:1px solid var(--tfgen-border);border-radius:24px;border-radius:var(--tfgen-radius-lg);grid-column:span 6;overflow:hidden;position:relative;transition:all .5s cubic-bezier(.16,1,.3,1);transition:all .5s var(--tfgen-transition)}.tfgen-value-card:hover{border-color:#0000;box-shadow:0 12px 48px #0f172a1f;box-shadow:var(--tfgen-shadow-lg);transform:translateY(-6px)}.tfgen-value-card-blob{border-radius:50%;filter:blur(60px);height:180px;opacity:0;pointer-events:none;position:absolute;transition:all .6s cubic-bezier(.16,1,.3,1);transition:all .6s var(--tfgen-transition);width:180px}.tfgen-value-card:first-child .tfgen-value-card-blob{background:#10b981;background:var(--tfgen-primary);right:-50px;top:-50px}.tfgen-value-card:nth-child(2) .tfgen-value-card-blob{background:#14b8a6;background:var(--tfgen-accent);bottom:-50px;left:-50px}.tfgen-value-card:nth-child(3) .tfgen-value-card-blob{background:#3b82f6;left:-50px;top:-50px}.tfgen-value-card:nth-child(4) .tfgen-value-card-blob{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);bottom:-50px;right:-50px}.tfgen-value-card:hover .tfgen-value-card-blob{opacity:.15}.tfgen-value-card-inner{display:flex;flex-direction:column;height:100%;padding:1.75rem;position:relative;z-index:1}.tfgen-value-card-icon{align-items:center;background:linear-gradient(135deg,#10b98126,#14b8a61a);border-radius:12px;display:flex;height:46px;justify-content:center;margin-bottom:1.25rem;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--tfgen-transition);width:46px}.tfgen-value-card-icon svg{color:#10b981;color:var(--tfgen-primary);height:22px;width:22px}.tfgen-value-card:hover .tfgen-value-card-icon{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);transform:scale(1.1) rotate(-5deg)}.tfgen-value-card:hover .tfgen-value-card-icon svg{color:#fff}.tfgen-value-card h3{color:#0f172a;color:var(--tfgen-text);font-size:1.125rem;font-weight:700;margin:0 0 .5rem;transition:color .3s}.tfgen-value-card:hover h3{color:#10b981;color:var(--tfgen-primary)}.tfgen-value-card p{color:#64748b;color:var(--tfgen-text-secondary);font-size:.9rem;line-height:1.6;margin:0}.tfgen-value-card--featured{grid-column:span 7;grid-row:span 2}.tfgen-value-card--featured .tfgen-value-card-inner{padding:2rem}.tfgen-value-card--featured .tfgen-value-card-icon{height:56px;width:56px}.tfgen-value-card--featured .tfgen-value-card-icon svg{height:28px;width:28px}.tfgen-value-card--featured h3{font-size:1.375rem}.tfgen-value-card--wide{grid-column:span 12}.tfgen-value-card--wide .tfgen-value-card-inner{align-items:center;flex-direction:row;gap:1.5rem}.tfgen-value-card--wide .tfgen-value-card-icon{flex-shrink:0;margin-bottom:0}.tfgen-value-card--wide h3{margin-bottom:.25rem}.tfgen-value-card:nth-child(2),.tfgen-value-card:nth-child(3){grid-column:span 5}.tfgen-faq{background:linear-gradient(180deg,#fff,#f0fdf4);background:linear-gradient(180deg,var(--tfgen-bg) 0,var(--tfgen-bg-subtle) 100%);padding:5rem 2rem;position:relative;z-index:1}.tfgen-faq-header{margin:0 auto 3rem;max-width:500px;text-align:center}.tfgen-faq-eyebrow{background:#10b9811a;border-radius:100px;color:#10b981;color:var(--tfgen-primary);display:inline-flex;font-size:.75rem;font-weight:700;letter-spacing:.15em;margin-bottom:.75rem;padding:.4rem .875rem;text-transform:uppercase}.tfgen-faq-header h2{color:#0f172a;color:var(--tfgen-text);font-size:clamp(1.75rem,4vw,2rem);font-weight:800;margin:0}.tfgen-faq-list{display:flex;flex-direction:column;gap:.75rem;margin:0 auto;max-width:700px}.tfgen-faq-item{background:#fff;background:var(--tfgen-bg);border:1px solid #e2e8f0;border:1px solid var(--tfgen-border);border-radius:16px;border-radius:var(--tfgen-radius);overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--tfgen-transition)}.tfgen-faq-item:hover{border-color:#10b9814d}.tfgen-faq-item--open{border-color:#10b981;border-color:var(--tfgen-primary);box-shadow:0 4px 16px #10b9811a}.tfgen-faq-trigger{align-items:center;background:none;border:none;color:#0f172a;color:var(--tfgen-text);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:1rem;justify-content:space-between;padding:1.125rem 1.25rem;text-align:left;width:100%}.tfgen-faq-trigger:hover{color:#10b981;color:var(--tfgen-primary)}.tfgen-faq-trigger svg{color:#94a3b8;color:var(--tfgen-text-muted);flex-shrink:0;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--tfgen-transition)}.tfgen-faq-item--open .tfgen-faq-trigger svg{color:#10b981;color:var(--tfgen-primary);transform:rotate(45deg)}.tfgen-faq-content{max-height:0;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--tfgen-transition)}.tfgen-faq-item--open .tfgen-faq-content{max-height:400px}.tfgen-faq-content p{color:#64748b;color:var(--tfgen-text-secondary);font-size:.9rem;line-height:1.7;margin:0;padding:0 1.25rem 1.25rem}.tfgen-cta{align-items:center;background:#f0fdf4;background:var(--tfgen-bg-subtle);border-top:1px solid #e2e8f0;border-top:1px solid var(--tfgen-border);display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:3.5rem 2rem;position:relative;z-index:1}.tfgen-cta p{color:#0f172a;color:var(--tfgen-text);font-size:1.125rem;font-weight:600;margin:0}.tfgen-cta-btn{background:linear-gradient(135deg,#10b981,#14b8a6);background:var(--tfgen-gradient);border:none;border-radius:10px;border-radius:var(--tfgen-radius-sm);box-shadow:0 4px 12px #10b9814d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.875rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all .3s var(--tfgen-transition)}.tfgen-cta-btn:hover{box-shadow:0 6px 16px #10b98166;transform:translateY(-2px)}.tfgen-immersive{animation:tfgen-fadeIn .3s ease;background:linear-gradient(180deg,#1e293b,#0f172a);bottom:0;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;right:0;top:0;width:100vw;z-index:999999}@keyframes tfgen-fadeIn{0%{opacity:0}to{opacity:1}}.tfgen-immersive-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:1.5rem;top:1.5rem;transition:all .2s;width:48px;z-index:1000001}.tfgen-immersive-close:hover{background:#fff3;transform:scale(1.05)}.tfgen-immersive-header{border-bottom:1px solid #ffffff1a;padding:1.5rem 2rem;text-align:center}.tfgen-immersive-header h2{color:#fff;font-size:1.5rem;font-weight:700;margin:0}.tfgen-immersive-content{align-items:flex-start;display:flex;flex:1 1;justify-content:center;padding:2rem}@media (max-width:900px){.tfgen-flow-item{gap:1rem;grid-template-columns:1fr;text-align:center!important}.tfgen-flow-item--right .tfgen-flow-content{margin-left:0}.tfgen-flow-content{max-width:100%;order:2}.tfgen-flow-number{font-size:3.5rem;order:1}.tfgen-flow-visual{margin:0 auto;order:3}.tfgen-flow-connector{height:35px}.tfgen-value-grid{grid-template-columns:repeat(2,1fr)}.tfgen-value-card--featured{grid-column:span 2;grid-row:span 1}.tfgen-value-card:nth-child(2),.tfgen-value-card:nth-child(3){grid-column:span 1}.tfgen-value-card--wide{grid-column:span 2}}@media (max-width:768px){.tfgen-page{padding-top:3.5rem}.tfgen-hero{padding:2.5rem 1.5rem 2rem}.tfgen-main{padding:0 1rem 3rem}.tfgen-dropzone{padding:2.5rem 1.5rem}.tfgen-dropzone:before{inset:.75rem}.tfgen-options{padding:1.5rem}.tfgen-success-header{align-items:stretch;flex-direction:column;gap:1rem;padding:1rem}.tfgen-success-info{text-align:center}.tfgen-success-title{font-size:1rem;white-space:normal}.tfgen-success-actions,.tfgen-success-meta{justify-content:center}.tfgen-quiz-container{padding:1rem}.tfgen-upgrade-banner{flex-direction:column;margin:0 1rem 1rem;text-align:center}.tfgen-process{padding:3.5rem 1.5rem 4rem}.tfgen-value{padding:3.5rem 1.5rem}.tfgen-value-grid{gap:1rem;grid-template-columns:1fr}.tfgen-value-card,.tfgen-value-card--featured,.tfgen-value-card--wide,.tfgen-value-card:nth-child(2),.tfgen-value-card:nth-child(3){grid-column:span 1;grid-row:span 1}.tfgen-value-card--wide .tfgen-value-card-inner{align-items:flex-start;flex-direction:column}.tfgen-value-card--wide .tfgen-value-card-icon{margin-bottom:1rem}.tfgen-faq{padding:3.5rem 1.5rem}.tfgen-cta{flex-direction:column;gap:1.25rem;padding:2.5rem 1.5rem;text-align:center}.tfgen-cta-btn{max-width:260px;width:100%}.tfgen-immersive-content{padding:1.5rem}}@media (max-width:480px){.tfgen-hero{padding:2rem 1rem 1.5rem}.tfgen-hero-title{font-size:1.75rem}.tfgen-hero-icons{gap:.75rem}.tfgen-icon-false,.tfgen-icon-true{height:40px;width:40px}.tfgen-dropzone{padding:2rem 1rem}.tfgen-dropzone-icon{height:56px;width:56px}.tfgen-browse-btn{font-size:.875rem;padding:.75rem 1.5rem}.tfgen-generate-btn{font-size:.9375rem;padding:.875rem 1.5rem}.tfgen-action-btn{height:36px;width:36px}}.concept-map-artifact{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:20px;box-shadow:0 4px 24px #0000000f,0 0 0 1px #0000000a;display:flex;flex-direction:column;max-height:800px;min-height:500px;overflow:hidden;padding:1.5rem;position:relative}.concept-map-artifact.concept-map-fullscreen{border-radius:0;box-shadow:none;height:100%;max-height:100%;min-height:100%;padding:0}.concept-map-artifact.concept-map-fullscreen .concept-map-container{border-radius:0;flex:1 1}.concept-map-header{flex-shrink:0;margin-bottom:1rem;position:relative;text-align:center;z-index:10}.concept-map-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#334155);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.5rem}.concept-map-subtitle{align-items:center;color:#64748b;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center}.concept-map-subtitle:after,.concept-map-subtitle:before{background:linear-gradient(90deg,#0000,#cbd5e1,#0000);content:"";height:1px;width:40px}.concept-map-controls{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000001a;display:flex;gap:.5rem;padding:.5rem;position:absolute;right:1.5rem;top:1.5rem;z-index:100}.control-btn{background:linear-gradient(135deg,#3b82f6,#6366f1);border-radius:8px;box-shadow:0 2px 4px #3b82f633;color:#fff;font-size:1.25rem;font-weight:700;height:36px;transition:all .2s cubic-bezier(.4,0,.2,1);width:36px}.control-btn:hover{box-shadow:0 4px 8px #3b82f64d;transform:translateY(-2px)}.control-btn:active{transform:translateY(0)}.zoom-indicator{color:#64748b;font-size:.75rem;font-weight:600;min-width:50px;padding:0 .5rem;text-align:center}.concept-map-container{-webkit-overflow-scrolling:auto;background:linear-gradient(90deg,#e2e8f04d 1px,#0000 0),linear-gradient(#e2e8f04d 1px,#0000 0),#fff;background-size:40px 40px;border-radius:16px;box-shadow:inset 0 2px 4px #0000000a,0 1px 2px #00000005;cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Cpath stroke='%23fff' d='m10 0 3 5h-2v4h4V7l5 3-5 3v-2h-4v4h2l-3 5-3-5h2v-4H5v2l-5-3 5-3v2h4V5H7z'/%3E%3C/svg%3E") 10 10,move;flex:1 1;overflow:hidden;position:relative;touch-action:none;-webkit-user-select:none;user-select:none}.concept-map-container:active{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Cpath fill='%23333' stroke='%23fff' d='m10 0 3 5h-2v4h4V7l5 3-5 3v-2h-4v4h2l-3 5-3-5h2v-4H5v2l-5-3 5-3v2h4V5H7z'/%3E%3C/svg%3E") 10 10,grabbing}.concept-map-canvas{position:relative;transition:transform .1s ease-out;will-change:transform}.concept-map-svg{pointer-events:none;z-index:1}.connection-line{opacity:.5;transition:all .3s cubic-bezier(.4,0,.2,1)}.connection-line.highlighted{animation:pulse-line 2s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(59,130,246,.3));opacity:1!important}@keyframes pulse-line{0%,to{opacity:1}50%{opacity:.7}}.concept-node{animation:fadeInScale .5s cubic-bezier(.4,0,.2,1) backwards;cursor:grab;position:absolute;transform:translate(-50%,-50%);transition:z-index 0s,box-shadow .2s ease,border-color .2s ease;will-change:left,top;z-index:5}.concept-node:nth-child(2){animation-delay:.1s}.concept-node:nth-child(3){animation-delay:.15s}.concept-node:nth-child(4){animation-delay:.2s}.concept-node:nth-child(5){animation-delay:.25s}.concept-node:nth-child(6){animation-delay:.3s}.concept-node:nth-child(7){animation-delay:.35s}.concept-node:nth-child(8){animation-delay:.4s}.concept-node:nth-child(9){animation-delay:.45s}.concept-node:nth-child(10){animation-delay:.5s}.root-node .concept-node-inner{background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;box-shadow:0 4px 16px #3b82f64d,0 0 0 3px #3b82f61a;color:#fff;min-width:120px;padding:1rem 1.5rem}.root-node .concept-node-label{color:#fff;font-size:1rem;font-weight:800}.root-node:hover .concept-node-inner{box-shadow:0 8px 24px #3b82f666,0 0 0 4px #3b82f626;transform:translateY(-3px)}.concept-node-inner{background:#fff;border:2px solid var(--node-light);border-radius:12px;box-shadow:0 2px 8px #00000014,0 0 0 1px #00000008;max-width:200px;min-width:100px;padding:.75rem 1rem;position:relative;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.concept-node:hover .concept-node-inner{border-color:var(--node-color);box-shadow:0 6px 20px #0000001f,0 0 0 2px var(--node-light);transform:translateY(-3px)}.concept-node.selected .concept-node-inner{border-color:var(--node-color);border-width:2.5px;box-shadow:0 8px 28px #00000026,0 0 0 3px var(--node-light);max-width:280px;min-width:140px;padding:1rem 1.25rem;transform:translateY(-4px)}.concept-node-label{word-wrap:break-word;color:#1e293b;font-size:.875rem;font-weight:700;line-height:1.4;margin-bottom:0;text-align:center}.concept-node-description{word-wrap:break-word;animation:slideDown .3s cubic-bezier(.4,0,.2,1);border-top:1px solid #e2e8f0;color:#475569;font-size:.75rem;line-height:1.6;margin-top:.75rem;max-height:200px;overflow-y:auto;padding-top:.75rem;text-align:left}.concept-node-glow{background:var(--node-color);border-radius:16px;filter:blur(24px);height:100%;left:50%;opacity:0;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .2s ease;width:100%;z-index:-1}.concept-node:hover .concept-node-glow{opacity:.25}.concept-node.selected .concept-node-glow{animation:glow-pulse 2s ease-in-out infinite;opacity:.35}@keyframes glow-pulse{0%,to{opacity:.35}50%{opacity:.2}}.concept-node.dragging{cursor:grabbing!important;transition:none!important;z-index:100}.concept-node.dragging .concept-node-inner{border-color:var(--node-color);box-shadow:0 12px 40px #0003,0 0 0 3px var(--node-color);transform:translateY(-6px) scale(1.05);transition:none!important}.concept-node.dragging .concept-node-glow{opacity:.5;transition:none!important}.concept-map-hint{color:#94a3b8;flex-shrink:0;font-size:.75rem;font-style:italic;font-weight:500;margin-top:1rem;opacity:.9;text-align:center}.concept-map-container::-webkit-scrollbar{height:10px;width:10px}.concept-map-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.concept-map-container::-webkit-scrollbar-thumb{background:#cbd5e1;border:2px solid #f1f5f9;border-radius:10px}.concept-map-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:1024px){.concept-map-artifact{max-height:700px;padding:1.25rem}.concept-map-title{font-size:1.35rem}.concept-map-controls{padding:.4rem;right:1.25rem;top:1.25rem}.control-btn{font-size:1.1rem;height:32px;width:32px}.zoom-indicator{font-size:.7rem;min-width:45px}.concept-node-inner{max-width:180px;min-width:90px;padding:.65rem .9rem}.concept-node.selected .concept-node-inner{max-width:250px;min-width:130px;padding:.9rem 1.1rem}.root-node .concept-node-inner{min-width:110px;padding:.9rem 1.3rem}}@media (max-width:768px){.concept-map-artifact{max-height:600px;min-height:400px;padding:1rem}.concept-map-header{margin-bottom:.75rem}.concept-map-title{font-size:1.25rem}.concept-map-subtitle{font-size:.75rem}.concept-map-subtitle:after,.concept-map-subtitle:before{width:30px}.concept-map-controls{gap:.35rem;padding:.35rem;right:1rem;top:1rem}.control-btn{font-size:1rem;height:30px;width:30px}.zoom-indicator{font-size:.65rem;min-width:40px;padding:0 .35rem}.concept-node-inner{max-width:150px;min-width:80px;padding:.6rem .8rem}.concept-node.selected .concept-node-inner{max-width:200px;min-width:110px;padding:.75rem .95rem}.root-node .concept-node-inner{min-width:100px;padding:.8rem 1.1rem}.concept-node-label{font-size:.8rem}.root-node .concept-node-label{font-size:.9rem}.concept-node-description{font-size:.7rem}.concept-map-hint{font-size:.7rem;margin-top:.75rem}}@media (max-width:480px){.concept-map-artifact{max-height:500px;min-height:350px;padding:.75rem}.concept-map-title{font-size:1.1rem}.concept-map-subtitle{font-size:.7rem}.concept-map-subtitle:after,.concept-map-subtitle:before{width:20px}.concept-map-controls{gap:.3rem;padding:.3rem;right:.75rem;top:.75rem}.control-btn{font-size:.95rem;height:28px;width:28px}.zoom-indicator{font-size:.6rem;min-width:36px}.concept-node-inner{max-width:130px;min-width:70px;padding:.5rem .7rem}.concept-node.selected .concept-node-inner{max-width:170px;min-width:100px;padding:.65rem .85rem}.root-node .concept-node-inner{min-width:90px;padding:.7rem 1rem}.concept-node-label{font-size:.75rem}.root-node .concept-node-label{font-size:.85rem}.concept-node-description{font-size:.65rem;max-height:150px}.concept-map-hint{font-size:.65rem}}@media (hover:none) and (pointer:coarse){.concept-node-inner{padding:.75rem 1rem}.concept-node.selected .concept-node-inner{transform:translateY(-4px)}.concept-node:hover .concept-node-inner{transform:none}.concept-node:hover .concept-node-glow{opacity:0}.concept-node:active .concept-node-inner{transform:scale(.98)}.control-btn{height:40px;width:40px}}@media (prefers-color-scheme:dark){.concept-map-artifact{background:linear-gradient(135deg,#1e293b,#0f172a)}.concept-map-container{background:linear-gradient(90deg,#4755694d 1px,#0000 0),linear-gradient(#4755694d 1px,#0000 0),#1e293b;background-size:40px 40px;box-shadow:inset 0 2px 4px #0003,0 1px 2px #0000001a}.concept-map-controls{background:#1e293b;box-shadow:0 2px 12px #0000004d}.concept-node-inner{background:#334155;border-color:#475569}.concept-node-label{color:#f1f5f9}.concept-node-description{border-top-color:#475569;color:#cbd5e1}.concept-map-hint{color:#64748b}.concept-map-container::-webkit-scrollbar-track{background:#0f172a}.concept-map-container::-webkit-scrollbar-thumb{background:#475569;border-color:#0f172a}.concept-map-container::-webkit-scrollbar-thumb:hover{background:#64748b}}@media print{.concept-map-artifact{border:1px solid #e2e8f0;box-shadow:none}.concept-map-controls{display:none}.concept-map-container{height:auto;overflow:visible}.concept-map-canvas{transform:none!important}}.immersive-mindmap-overlay{animation:immersiveMindmapFadeIn .3s ease;background:linear-gradient(180deg,#0f172a,#1e293b 50%,#0f172a);bottom:0;display:flex;flex-direction:column;left:0;overflow:hidden;position:fixed;right:0;top:0;touch-action:none;z-index:999999}@keyframes immersiveMindmapFadeIn{0%{opacity:0}to{opacity:1}}.immersive-mindmap-topbar{align-items:center;display:flex;left:.75rem;position:absolute;top:.75rem;z-index:1000001}.immersive-mindmap-title{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:10px;color:#fff;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;max-width:300px;overflow:hidden;padding:.5rem .875rem;text-overflow:ellipsis;white-space:nowrap}.immersive-mindmap-title svg{color:#a78bfa;flex-shrink:0}.immersive-mindmap-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.immersive-mindmap-hint{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000004d;border:1px solid #ffffff14;border-radius:16px;bottom:2rem;color:#ffffff80;font-size:.75rem;font-weight:500;left:50%;padding:.375rem 1rem;pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:1000000}.immersive-mindmap-controls{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:16px;bottom:2rem;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;gap:.5rem;left:2rem;padding:.75rem;position:absolute;z-index:1000001}.immersive-mindmap-control-btn{align-items:center;background:#ffffff26;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;height:42px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:42px}.immersive-mindmap-control-btn:hover{background:#8b5cf680;transform:scale(1.05)}.immersive-mindmap-control-btn:active{transform:scale(.95)}.immersive-mindmap-zoom-indicator{color:#ffffffe6;font-size:.75rem;font-weight:700;min-width:45px;padding:.25rem 0;text-align:center}.immersive-mindmap-actions{display:flex;gap:.5rem;position:absolute;right:1rem;top:1rem;z-index:1000001}.immersive-mindmap-action-btn{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:10px;box-shadow:0 4px 16px #0003;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.immersive-mindmap-action-btn:hover:not(:disabled){background:#8b5cf666;border-color:#8b5cf680;box-shadow:0 6px 20px #8b5cf64d;transform:translateY(-2px)}.immersive-mindmap-action-btn:disabled{cursor:not-allowed;opacity:.5}.immersive-mindmap-action-btn span{display:none}@media (min-width:768px){.immersive-mindmap-action-btn span{display:inline}}.immersive-mindmap-close{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ef444433;border:1px solid #ffffff26;border-radius:10px;box-shadow:0 4px 16px #0003;color:#fff;cursor:pointer;display:flex;height:42px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:42px}.immersive-mindmap-close:hover{background:#ef444480;border-color:#ef444499;transform:scale(1.05)}.immersive-mindmap-content{flex:1 1;height:100%;margin-top:0;overflow:hidden;width:100%}.immersive-mindmap-content .concept-map-artifact{background:#0000;border-radius:0;box-shadow:none;height:100%;max-height:100%;padding:0}.immersive-mindmap-content .concept-map-container{background:#ffffff08}.immersive-mindmap-save-status{align-items:center;animation:immersiveMindmapStatusFadeIn .3s ease;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:10px;bottom:4.5rem;color:#ffffffe6;display:flex;font-size:.8rem;font-weight:500;gap:.5rem;left:50%;padding:.5rem 1rem;position:absolute;transform:translateX(-50%);z-index:1000001}@keyframes immersiveMindmapStatusFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.immersive-mindmap-save-status--saving{color:#fffc}.immersive-mindmap-save-status--saved{background:#10b98133;border-color:#10b9814d;color:#6ee7b7}.immersive-mindmap-save-status--error{background:#ef444433;border-color:#ef44444d;color:#fca5a5}.immersive-mindmap-save-spinner{animation:immersiveMindmapSpin 1s linear infinite;border:2px solid #fff3;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes immersiveMindmapSpin{to{transform:rotate(1turn)}}@media (max-width:768px){.immersive-mindmap-topbar{left:.5rem;top:.5rem}.immersive-mindmap-title{font-size:.75rem;max-width:180px;padding:.375rem .625rem}.immersive-mindmap-hint{bottom:1rem;font-size:.65rem;padding:.25rem .75rem}.immersive-mindmap-controls{bottom:4rem;gap:.25rem;left:.5rem;padding:.375rem}.immersive-mindmap-control-btn{height:32px;width:32px}.immersive-mindmap-zoom-indicator{font-size:.65rem;min-width:36px}.immersive-mindmap-actions{gap:.375rem;right:.5rem;top:.5rem}.immersive-mindmap-action-btn{font-size:.75rem;padding:.375rem .625rem}.immersive-mindmap-close{height:34px;width:34px}.immersive-mindmap-save-status{bottom:3rem;font-size:.7rem;padding:.375rem .75rem}.immersive-mindmap-content{margin-top:0}}:root{--cmgen-primary:#8b5cf6;--cmgen-primary-dark:#7c3aed;--cmgen-accent:#a78bfa;--cmgen-text:#0f172a;--cmgen-text-secondary:#64748b;--cmgen-text-muted:#94a3b8;--cmgen-border:#e2e8f0;--cmgen-bg:#fff;--cmgen-bg-subtle:#faf5ff;--cmgen-gradient:linear-gradient(135deg,#8b5cf6,#a78bfa);--cmgen-radius:16px;--cmgen-radius-sm:10px;--cmgen-radius-lg:24px;--cmgen-shadow:0 4px 24px #8b5cf614;--cmgen-shadow-lg:0 12px 48px #8b5cf61f;--cmgen-transition:cubic-bezier(0.16,1,0.3,1)}.cmgen-page{background:#fff;background:var(--cmgen-bg);color:#0f172a;color:var(--cmgen-text);min-height:100vh;overflow-x:hidden;position:relative}.cmgen-ambient{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.cmgen-orb{border-radius:50%;filter:blur(120px);position:absolute}.cmgen-orb--1{background:linear-gradient(135deg,#8b5cf6,#a78bfa);background:linear-gradient(135deg,var(--cmgen-primary) 0,var(--cmgen-accent) 100%);height:800px;opacity:.08;right:-300px;top:-400px;width:800px}.cmgen-orb--2{background:#a78bfa;background:var(--cmgen-accent);bottom:-200px;height:600px;left:-200px;opacity:.06;width:600px}.cmgen-hero{margin:0 auto;max-width:800px;padding:3rem 2rem 2rem;position:relative;text-align:center;z-index:1}.cmgen-hero-content{animation:cmgen-fadeUp .8s cubic-bezier(.16,1,.3,1) forwards;animation:cmgen-fadeUp .8s var(--cmgen-transition) forwards}@keyframes cmgen-fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.cmgen-hero-badge{display:none}.cmgen-hero-title{color:#0f172a;color:var(--cmgen-text);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;margin:0 0 1rem}.cmgen-gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#8b5cf6,#a78bfa);background:var(--cmgen-gradient);-webkit-background-clip:text;background-clip:text;display:inline-block;padding-bottom:.1em}.cmgen-hero-subtitle{color:#64748b;color:var(--cmgen-text-secondary);font-size:1.0625rem;font-weight:400;line-height:1.6;margin:0 auto;max-width:500px}.cmgen-hero-visual{display:none}.cmgen-generator{margin:0 auto;max-width:800px;padding:0 1.5rem 4rem;position:relative;z-index:1}.cmgen-generator-card{background:#fff;background:var(--cmgen-bg);border:1px solid #e2e8f0;border:1px solid var(--cmgen-border);border-radius:24px;border-radius:var(--cmgen-radius-lg);box-shadow:0 12px 48px #8b5cf61f;box-shadow:var(--cmgen-shadow-lg);overflow:hidden;position:relative}.cmgen-generator-card:before{background:linear-gradient(135deg,#8b5cf6,#a78bfa);background:var(--cmgen-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0}.cmgen-card-header{display:none}.cmgen-dropzone{background:linear-gradient(180deg,#faf5ff,#fff);background:linear-gradient(180deg,var(--cmgen-bg-subtle) 0,var(--cmgen-bg) 100%);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--cmgen-border);cursor:pointer;padding:3rem 2.5rem;position:relative}.cmgen-dropzone,.cmgen-dropzone:before{transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--cmgen-transition)}.cmgen-dropzone:before{border:2px dashed #e2e8f0;border:2px dashed var(--cmgen-border);border-radius:16px;border-radius:var(--cmgen-radius);content:"";inset:1.25rem;pointer-events:none;position:absolute}.cmgen-dropzone:hover:before{background:linear-gradient(135deg,#8b5cf608,#a78bfa08);border-color:#8b5cf6;border-color:var(--cmgen-primary)}.cmgen-dropzone--active:before{background:linear-gradient(135deg,#8b5cf60f,#a78bfa0f);border-color:#8b5cf6;border-color:var(--cmgen-primary);border-style:solid;transform:scale(1.01)}.cmgen-dropzone--has-file{background:linear-gradient(180deg,#8b5cf60a,#fff);background:linear-gradient(180deg,#8b5cf60a 0,var(--cmgen-bg) 100%)}.cmgen-dropzone--has-file:before{background:#8b5cf605;border-color:#8b5cf6;border-color:var(--cmgen-primary);border-style:solid}.cmgen-dropzone-content{align-items:center;display:flex;flex-direction:column;gap:.875rem;position:relative;z-index:1}.cmgen-dropzone-icon{align-items:center;background:linear-gradient(135deg,#8b5cf61a,#a78bfa1a);border-radius:50%;color:#8b5cf6;color:var(--cmgen-primary);display:flex;height:64px;justify-content:center;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--cmgen-transition);width:64px}.cmgen-dropzone-icon svg{height:28px;width:28px}.cmgen-dropzone:hover .cmgen-dropzone-icon{background:linear-gradient(135deg,#8b5cf626,#a78bfa26);box-shadow:0 8px 24px #8b5cf633;transform:translateY(-4px) scale(1.05)}.cmgen-dropzone--active .cmgen-dropzone-icon{background:linear-gradient(135deg,#8b5cf6,#a78bfa);background:var(--cmgen-gradient);color:#fff;transform:scale(1.1)}.cmgen-dropzone-text{text-align:center}.cmgen-dropzone-primary{color:#0f172a;color:var(--cmgen-text);display:block;font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.cmgen-dropzone-secondary{color:#94a3b8;color:var(--cmgen-text-muted);display:block;font-size:.9rem}.cmgen-dropzone-hint{color:#94a3b8;color:var(--cmgen-text-muted);font-size:.875rem}.cmgen-file-preview{align-items:center;display:flex;gap:1rem}.cmgen-file-icon{align-items:center;background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.cmgen-file-info{flex:1 1;text-align:left}.cmgen-file-name{color:#0f172a;display:block;font-weight:600;margin-bottom:.25rem}.cmgen-file-size{color:#64748b;font-size:.875rem}.cmgen-file-remove{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.cmgen-file-remove:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.cmgen-options{margin-bottom:1.5rem}.cmgen-option-group{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.cmgen-option-label{align-items:center;color:#0f172a;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:1rem}.cmgen-option-label svg{color:#8b5cf6}.cmgen-count-selector{display:flex;flex-wrap:wrap;gap:.5rem}.cmgen-count-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.25rem;justify-content:center;min-width:50px;padding:.625rem 1rem;transition:all .2s}.cmgen-count-btn:hover:not(:disabled){border-color:#a78bfa;color:#8b5cf6}.cmgen-count-btn--active{background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-color:#0000;box-shadow:0 4px 12px #8b5cf64d;color:#fff}.cmgen-count-btn--locked{cursor:not-allowed;opacity:.5}.cmgen-count-btn--locked svg{color:#94a3b8}.cmgen-error{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;font-size:.9375rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.cmgen-error,.cmgen-generate-btn{align-items:center;display:flex;gap:.75rem}.cmgen-generate-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:14px;box-shadow:0 4px 16px #8b5cf659;color:#fff;cursor:pointer;font-size:1.0625rem;font-weight:700;justify-content:center;padding:1rem 2rem;transition:all .3s ease;width:100%}.cmgen-generate-btn:hover:not(:disabled){box-shadow:0 8px 24px #8b5cf666;transform:translateY(-2px)}.cmgen-generate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.cmgen-btn-spinner{animation:cmgen-spin .8s linear infinite;border:2.5px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes cmgen-spin{to{transform:rotate(1turn)}}.cmgen-result{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #8b5cf61a;border-radius:24px;box-shadow:0 8px 32px #8b5cf61a;padding:2rem}.cmgen-result-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.cmgen-result-header h2{color:#0f172a;font-size:1.375rem;font-weight:700;margin:0}.cmgen-result-actions{display:flex;gap:.75rem}.cmgen-action-btn{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:10px;box-shadow:0 4px 12px #8b5cf640;color:#fff;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s}.cmgen-action-btn:hover{box-shadow:0 6px 16px #8b5cf659;transform:translateY(-2px)}.cmgen-action-btn--secondary{background:#fff;border:1.5px solid #e2e8f0;box-shadow:none;color:#64748b}.cmgen-action-btn--secondary:hover{border-color:#a78bfa;box-shadow:0 4px 12px #8b5cf626;color:#8b5cf6}.cmgen-action-btn:disabled{cursor:not-allowed;opacity:.6}.cmgen-action-btn:disabled:hover{box-shadow:0 4px 12px #8b5cf640;transform:none}.cmgen-save-status{align-items:center;border-radius:8px;display:flex;font-size:.8rem;gap:.5rem;margin-top:.75rem;padding:.5rem 1rem}.cmgen-save-status--saving{background:#fef3c7;color:#92400e}.cmgen-save-status--saved{background:#d1fae5;color:#065f46}.cmgen-save-status--error{background:#fee2e2;color:#991b1b}.cmgen-viewer-wrapper{background:#f8fafc;border-radius:16px;padding:1.5rem}.cmgen-process{background:linear-gradient(180deg,#faf5ff,#fff);overflow:hidden;padding:6rem 2rem 8rem;position:relative;z-index:1}.cmgen-process:before{background:radial-gradient(circle,#8b5cf608 0,#0000 70%);content:"";height:800px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:800px}.cmgen-process-flow{display:flex;flex-direction:column;gap:0;margin:0 auto;max-width:900px}.cmgen-flow-item{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:auto 1fr auto;padding:2rem 0;position:relative}.cmgen-flow-item--left{text-align:left}.cmgen-flow-item--right{text-align:right}.cmgen-flow-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#8b5cf6,#a78bfa);-webkit-background-clip:text;background-clip:text;font-size:clamp(4rem,10vw,7rem);font-weight:900;line-height:1;opacity:.15;transition:all .5s cubic-bezier(.16,1,.3,1);-webkit-user-select:none;user-select:none}.cmgen-flow-item:hover .cmgen-flow-number{opacity:.35;transform:scale(1.05)}.cmgen-flow-content{max-width:340px}.cmgen-flow-item--right .cmgen-flow-content{margin-left:auto}.cmgen-flow-content h3{color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .625rem;transition:color .3s}.cmgen-flow-item:hover .cmgen-flow-content h3{color:#8b5cf6}.cmgen-flow-content p{color:#64748b;font-size:1rem;line-height:1.7;margin:0}.cmgen-flow-visual{align-items:center;display:flex;height:100px;justify-content:center;width:100px}.cmgen-flow-icon{color:#94a3b8;height:80px;opacity:.4;transition:all .5s cubic-bezier(.16,1,.3,1);width:80px}.cmgen-flow-item:hover .cmgen-flow-icon{color:#8b5cf6;opacity:.7;transform:scale(1.1)}.cmgen-flow-connector{display:flex;height:60px;justify-content:center;opacity:.4}.cmgen-flow-connector svg{height:100%;width:40px}.cmgen-value{margin:0 auto;max-width:1100px;padding:6rem 2rem 8rem;position:relative;z-index:1}.cmgen-value-header{margin-bottom:4rem;text-align:center}.cmgen-value-header h2{color:#0f172a;font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;margin:0}.cmgen-value-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-auto-rows:minmax(180px,auto);grid-template-columns:repeat(12,1fr)}.cmgen-value-card{background:#fff;border:1px solid #e2e8f0;border-radius:24px;grid-column:span 6;overflow:hidden;position:relative;transition:all .5s cubic-bezier(.16,1,.3,1)}.cmgen-value-card:hover{border-color:#0000;box-shadow:0 12px 48px #8b5cf61f;transform:translateY(-8px)}.cmgen-value-card-blob{border-radius:50%;filter:blur(60px);height:200px;opacity:0;pointer-events:none;position:absolute;transition:all .6s cubic-bezier(.16,1,.3,1);width:200px}.cmgen-value-card:first-child .cmgen-value-card-blob{background:#8b5cf6;right:-50px;top:-50px}.cmgen-value-card:nth-child(2) .cmgen-value-card-blob{background:#a78bfa;bottom:-50px;left:-50px}.cmgen-value-card:nth-child(3) .cmgen-value-card-blob{background:#c4b5fd;left:-50px;top:-50px}.cmgen-value-card:nth-child(4) .cmgen-value-card-blob{background:linear-gradient(135deg,#8b5cf6,#a78bfa);bottom:-50px;right:-50px}.cmgen-value-card:hover .cmgen-value-card-blob{opacity:.15;transform:scale(1.2)}.cmgen-value-card-inner{display:flex;flex-direction:column;height:100%;padding:2rem;position:relative;z-index:1}.cmgen-value-card-icon{align-items:center;background:linear-gradient(135deg,#8b5cf61a,#a78bfa1a);border-radius:14px;display:flex;height:52px;justify-content:center;margin-bottom:1.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);width:52px}.cmgen-value-card-icon svg{color:#8b5cf6;height:26px;transition:all .3s;width:26px}.cmgen-value-card:hover .cmgen-value-card-icon{background:linear-gradient(135deg,#8b5cf6,#a78bfa);transform:scale(1.1) rotate(-5deg)}.cmgen-value-card:hover .cmgen-value-card-icon svg{color:#fff}.cmgen-value-card h3{color:#0f172a;font-size:1.375rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .75rem;transition:color .3s}.cmgen-value-card:hover h3{color:#8b5cf6}.cmgen-value-card p{color:#64748b;flex:1 1;font-size:1rem;line-height:1.7;margin:0}.cmgen-value-card--featured{grid-column:span 7;grid-row:span 2}.cmgen-value-card--featured .cmgen-value-card-inner{padding:2.5rem}.cmgen-value-card--featured .cmgen-value-card-icon{border-radius:18px;height:64px;width:64px}.cmgen-value-card--featured .cmgen-value-card-icon svg{height:32px;width:32px}.cmgen-value-card--featured h3{font-size:1.75rem}.cmgen-value-card--featured p{font-size:1.0625rem;max-width:400px}.cmgen-value-card--wide{grid-column:span 12}.cmgen-value-card--wide .cmgen-value-card-inner{align-items:center;flex-direction:row;gap:2rem}.cmgen-value-card--wide .cmgen-value-card-icon{flex-shrink:0;margin-bottom:0}.cmgen-value-card--wide h3{margin-bottom:.5rem}.cmgen-value-card:nth-child(2),.cmgen-value-card:nth-child(3){grid-column:span 5}.cmgen-faq{background:linear-gradient(180deg,#fff,#faf5ff);padding:6rem 2rem;position:relative;z-index:1}.cmgen-faq-header{margin:0 auto 3.5rem;max-width:500px;text-align:center}.cmgen-faq-eyebrow{align-items:center;background:#8b5cf61a;border-radius:100px;color:#8b5cf6;display:inline-flex;font-size:.8rem;font-weight:700;gap:.5rem;letter-spacing:.15em;margin-bottom:1rem;padding:.5rem 1rem;text-transform:uppercase}.cmgen-faq-header h2{color:#0f172a;font-size:clamp(2rem,5vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin:0}.cmgen-faq-list{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:760px}.cmgen-faq-item{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1)}.cmgen-faq-item:hover{border-color:#8b5cf64d;box-shadow:0 4px 16px #8b5cf60f}.cmgen-faq-item--open{border-color:#8b5cf6;box-shadow:0 8px 32px #8b5cf61f}.cmgen-faq-trigger{align-items:center;background:none;border:none;color:#0f172a;cursor:pointer;display:flex;font-size:1.0625rem;font-weight:700;gap:1rem;justify-content:space-between;padding:1.375rem 1.5rem;text-align:left;transition:all .2s;width:100%}.cmgen-faq-trigger:hover{color:#8b5cf6}.cmgen-faq-trigger svg{color:#94a3b8;flex-shrink:0;transition:all .3s cubic-bezier(.16,1,.3,1)}.cmgen-faq-item--open .cmgen-faq-trigger svg{color:#8b5cf6;transform:rotate(45deg)}.cmgen-faq-content{max-height:0;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1)}.cmgen-faq-item--open .cmgen-faq-content{max-height:400px}.cmgen-faq-content p{color:#64748b;font-size:1rem;line-height:1.75;margin:0;padding:0 1.5rem 1.5rem}.cmgen-cta{align-items:center;background:#faf5ff;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:4rem 2rem;position:relative;z-index:1}.cmgen-cta p{color:#0f172a;font-size:1.25rem;font-weight:600;margin:0}.cmgen-cta-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;box-shadow:0 4px 16px #8b5cf64d;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:1rem 2.5rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.cmgen-cta-btn:hover{box-shadow:0 8px 24px #8b5cf666;transform:translateY(-2px)}@media (max-width:900px){.cmgen-flow-item{gap:1rem;grid-template-columns:1fr;text-align:center!important}.cmgen-flow-item--right .cmgen-flow-content{margin-left:0}.cmgen-flow-content{max-width:100%;order:2}.cmgen-flow-number{font-size:4rem;order:1}.cmgen-flow-visual{margin:0 auto;order:3}.cmgen-flow-connector{height:40px}.cmgen-value-grid{grid-template-columns:repeat(2,1fr)}.cmgen-value-card--featured{grid-column:span 2;grid-row:span 1}.cmgen-value-card:nth-child(2),.cmgen-value-card:nth-child(3){grid-column:span 1}.cmgen-value-card--wide{grid-column:span 2}}@media (max-width:768px){.cmgen-page{padding:1rem .75rem 0}.cmgen-hero{padding:1rem 0 2rem}.cmgen-generator-card{border-radius:20px;padding:1.5rem}.cmgen-dropzone{padding:2rem 1.5rem}.cmgen-result-header{align-items:flex-start;flex-direction:column}.cmgen-result-actions{width:100%}.cmgen-action-btn{flex:1 1;justify-content:center}.cmgen-process{padding:4rem 1.5rem 5rem}.cmgen-flow-number{font-size:3.5rem}.cmgen-flow-content h3{font-size:1.25rem}.cmgen-flow-content p{font-size:.95rem}.cmgen-flow-visual{height:80px;width:80px}.cmgen-flow-icon{height:60px;width:60px}.cmgen-value{padding:4rem 1.5rem}.cmgen-value-grid{gap:1.25rem;grid-template-columns:1fr}.cmgen-value-card,.cmgen-value-card--featured,.cmgen-value-card--wide,.cmgen-value-card:nth-child(2),.cmgen-value-card:nth-child(3){grid-column:span 1;grid-row:span 1}.cmgen-value-card--featured .cmgen-value-card-inner{padding:2rem}.cmgen-value-card--featured h3{font-size:1.375rem}.cmgen-value-card--wide .cmgen-value-card-inner{align-items:flex-start;flex-direction:column}.cmgen-value-card--wide .cmgen-value-card-icon{margin-bottom:1.25rem}.cmgen-value-card:hover{transform:translateY(-4px)}.cmgen-faq{padding:4rem 1.5rem}.cmgen-faq-trigger{font-size:1rem;padding:1.125rem 1.25rem}.cmgen-faq-content p{font-size:.95rem;padding:0 1.25rem 1.25rem}.cmgen-cta{flex-direction:column;gap:1.5rem;padding:3rem 1.5rem;text-align:center}.cmgen-cta p{font-size:1.125rem}.cmgen-cta-btn{max-width:280px;width:100%}}@media (max-width:480px){.cmgen-hero-title{font-size:1.75rem}.cmgen-hero-subtitle{font-size:1rem}.cmgen-node-cluster{height:160px;width:160px}.cmgen-node{font-size:.75rem;height:40px;width:40px}.cmgen-node--central{height:52px;width:52px}.cmgen-count-selector{justify-content:center}.cmgen-value-header h2{font-size:1.75rem}.cmgen-value-card h3{font-size:1.25rem}.cmgen-value-card p{font-size:.95rem}.cmgen-value-card-inner{padding:1.5rem}.cmgen-value-card-icon{height:44px;margin-bottom:1rem;width:44px}.cmgen-value-card-icon svg{height:22px;width:22px}.cmgen-faq-header h2{font-size:1.75rem}}.mg-viewer{margin:0 auto;max-width:950px;padding:1rem;width:100%}.mg-viewer--immersive{max-width:1100px;padding:1.5rem}.mg-viewer-title{color:#0f172a;font-size:1.375rem;font-weight:700;letter-spacing:-.02em;margin:0 0 1.5rem;text-align:center}.mg-viewer-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.mg-viewer-spinner{animation:mg-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#0ea5e9;height:44px;margin-bottom:1rem;width:44px}@keyframes mg-spin{to{transform:rotate(1turn)}}.mg-header{margin-bottom:1.5rem}.mg-progress-section{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:16px;padding:1rem 1.25rem}.mg-progress-bar{background:#e2e8f0;border-radius:100px;height:10px;margin-bottom:.75rem;overflow:hidden}.mg-progress-fill{background:linear-gradient(135deg,#10b981,#06b6d4);border-radius:100px;height:100%;position:relative;transition:width .5s cubic-bezier(.4,0,.2,1)}.mg-progress-fill:after{animation:mg-shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes mg-shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.mg-progress-info{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between}.mg-progress-text{color:#475569;font-size:.9375rem}.mg-progress-text strong{color:#0ea5e9;font-weight:700}.mg-stats-inline{display:flex;gap:1rem}.mg-stat-inline{align-items:center;color:#64748b;display:flex;font-size:.875rem;font-weight:600;gap:.375rem}.mg-stat-inline svg{color:#0ea5e9}.mg-game-board{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 60px 1fr;margin-bottom:1.5rem;min-height:400px;position:relative}.mg-connections-svg{height:100%;left:0;overflow:visible;pointer-events:none;position:absolute;top:0;width:100%;z-index:10}.mg-connection-line,.mg-connection-line line{animation:mg-draw-line .5s ease-out forwards}.mg-connection-line line{stroke-dasharray:1000;stroke-dashoffset:1000}.mg-connection-line circle{animation:mg-pop-in .3s ease-out .4s both}@keyframes mg-draw-line{to{stroke-dashoffset:0}}@keyframes mg-pop-in{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.mg-column{display:flex;flex-direction:column;gap:.625rem;z-index:5}.mg-column-label{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:10px;color:#64748b;font-size:.75rem;font-weight:700;gap:.5rem;letter-spacing:.75px;margin-bottom:.25rem;padding:.625rem;text-transform:uppercase}.mg-column-icon,.mg-column-label{align-items:center;display:flex;justify-content:center}.mg-column-icon{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;height:28px;width:28px}.mg-column--left .mg-column-icon svg{color:#0ea5e9}.mg-column--right .mg-column-icon svg{color:#8b5cf6}.mg-center-connector{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:2rem 0}.mg-connector-line{background:linear-gradient(180deg,#0000,#cbd5e1 20%,#cbd5e1 80%,#0000);flex:1 1;min-height:40px;width:2px}.mg-viewer--immersive .mg-connector-line{background:linear-gradient(180deg,#0000,#64748b33 20%,#64748b33 80%,#0000)}.mg-connector-icon{align-items:center;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px;color:#94a3b8;display:flex;height:44px;justify-content:center;margin:.5rem 0;width:44px}.mg-viewer--immersive .mg-connector-icon{background:#ffffffe6;color:#64748b}.mg-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#1e293b;cursor:pointer;display:flex;font-size:.9375rem;font-weight:500;gap:.75rem;min-height:52px;overflow:hidden;padding:.875rem 1rem;position:relative;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1)}.mg-card:before{background:linear-gradient(135deg,#0000,#0ea5e90d);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.mg-card:hover:not(:disabled):before{opacity:1}.mg-card:hover:not(:disabled){border-color:#0ea5e9;box-shadow:0 8px 20px -4px #0ea5e933;transform:translateY(-2px) scale(1.01)}.mg-card--term{border-right-color:#e2e8f0;border-right-width:4px;justify-content:space-between}.mg-card--term:hover:not(:disabled){border-right-color:#0ea5e9}.mg-card--definition{border-left-color:#e2e8f0;border-left-width:4px;justify-content:flex-start}.mg-card--definition:hover:not(:disabled){border-left-color:#8b5cf6}.mg-card-text{flex:1 1;line-height:1.5;word-break:break-word}.mg-card-status{align-items:center;display:flex;flex-shrink:0;height:24px;justify-content:center;width:24px}.mg-card-dot{animation:mg-pulse 1s ease infinite;background:#0ea5e9;border-radius:50%;height:10px;width:10px}@keyframes mg-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.mg-card--selected{background:linear-gradient(135deg,#f0f9ff,#fff);border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e926,0 4px 12px -2px #0ea5e933;transform:scale(1.02)}.mg-card--term.mg-card--selected{border-right-color:#0ea5e9}.mg-card--definition.mg-card--selected{border-left-color:#8b5cf6}.mg-card--correct{animation:mg-correct-pulse .6s ease;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981!important}.mg-card--term.mg-card--correct{border-right-color:#10b981!important}.mg-card--definition.mg-card--correct{border-left-color:#10b981!important}@keyframes mg-correct-pulse{0%{transform:scale(1)}30%{transform:scale(1.05)}60%{transform:scale(.98)}to{transform:scale(1)}}.mg-card--matched{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-color:#10b981;cursor:default;opacity:.85}.mg-card--term.mg-card--matched{border-right-color:#10b981}.mg-card--definition.mg-card--matched{border-left-color:#10b981}.mg-card--matched:hover{box-shadow:none;transform:none}.mg-card--matched .mg-card-status svg{animation:mg-check-pop .4s ease;color:#10b981}@keyframes mg-check-pop{0%{transform:scale(0) rotate(-45deg)}50%{transform:scale(1.2) rotate(0deg)}to{transform:scale(1) rotate(0deg)}}.mg-card--wrong{animation:mg-shake .5s ease;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#ef4444!important}.mg-card--term.mg-card--wrong{border-right-color:#ef4444!important}.mg-card--definition.mg-card--wrong{border-left-color:#ef4444!important}@keyframes mg-shake{0%,to{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-6px)}80%{transform:translateX(6px)}}.mg-instructions{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:.75rem;justify-content:center;padding:1rem 1.5rem}.mg-instruction-step{align-items:center;color:#475569;display:flex;font-size:.875rem;gap:.5rem}.mg-instruction-num{align-items:center;background:linear-gradient(135deg,#0ea5e9,#06b6d4);border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:700;height:22px;justify-content:center;width:22px}.mg-instructions>svg{color:#94a3b8}.mg-completion{background:#fff;border:1px solid #e2e8f0;border-radius:20px;box-shadow:0 4px 20px #0000000f;margin:0 auto;max-width:500px;padding:1.5rem}.mg-completion-header{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.mg-completion-icon{align-items:center;background:linear-gradient(135deg,#10b981,#06b6d4);border-radius:14px;box-shadow:0 6px 16px #10b9814d;color:#fff;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.mg-completion-icon--perfect{background:linear-gradient(135deg,#fbbf24,#f59e0b);box-shadow:0 6px 16px #f59e0b59}.mg-completion-text{flex:1 1;text-align:left}.mg-completion-title{color:#0f172a;font-size:1.375rem;font-weight:700;letter-spacing:-.01em;margin:0 0 .25rem}.mg-completion-subtitle{color:#64748b;font-size:.875rem;margin:0}.mg-completion-stats{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.25rem}.mg-stat-pill{align-items:center;background:#f1f5f9;border-radius:100px;color:#475569;display:flex;font-size:.8125rem;font-weight:600;gap:.375rem;padding:.5rem .875rem}.mg-stat-pill svg{color:#64748b}.mg-stat-pill--accent{background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#059669}.mg-stat-pill--accent svg{color:#10b981}.mg-completion-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.mg-action-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.25rem;transition:all .2s ease}.mg-action-btn--primary{background:linear-gradient(135deg,#0ea5e9,#06b6d4);box-shadow:0 4px 12px #0ea5e94d;color:#fff}.mg-action-btn--primary:hover{box-shadow:0 6px 16px #0ea5e966;transform:translateY(-1px)}.mg-completion-secondary{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.mg-action-btn--secondary{background:#f8fafc;border:1px solid #e2e8f0;color:#475569;font-size:.8125rem;padding:.625rem 1rem}.mg-action-btn--secondary:hover{background:#f1f5f9;border-color:#cbd5e1;color:#1e293b}.mg-action-btn--secondary svg{color:#64748b}.mg-review{border-top:1px solid #e2e8f0;margin-top:1rem}.mg-review-toggle{align-items:center;color:#64748b;cursor:pointer;display:flex;font-size:.8125rem;font-weight:600;gap:.5rem;justify-content:center;list-style:none;padding:.875rem;transition:color .2s ease}.mg-review-toggle::-webkit-details-marker{display:none}.mg-review-toggle:hover{color:#0ea5e9}.mg-review-toggle svg{transition:transform .2s ease}details[open] .mg-review-toggle svg{transform:rotate(180deg)}.mg-review-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;padding:0 .5rem .5rem}.mg-review-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:.75rem;padding:.75rem}.mg-review-number{align-items:center;background:linear-gradient(135deg,#0ea5e9,#06b6d4);border-radius:6px;color:#fff;display:flex;flex-shrink:0;font-size:.7rem;font-weight:700;height:24px;justify-content:center;width:24px}.mg-review-content{align-items:center;display:flex;flex:1 1;font-size:.8125rem;gap:.5rem;min-width:0}.mg-review-term{color:#0f172a;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mg-review-arrow{color:#10b981;flex-shrink:0;font-weight:700}.mg-review-definition{color:#475569;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.mg-viewer{padding:.75rem}.mg-game-board{gap:1.5rem;grid-template-columns:1fr}.mg-center-connector,.mg-center-hint,.mg-connections-svg{display:none}.mg-column-label{background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff;padding:.75rem 1rem}.mg-column-icon{background:#fff3}.mg-column--left .mg-column-icon svg,.mg-column--right .mg-column-icon svg{color:#fff}.mg-card{font-size:.9rem;padding:1rem}.mg-card--term{border-left-color:#0ea5e9;border-left-width:4px;border-right-width:2px}.mg-card--definition{border-left-width:2px;border-right-color:#8b5cf6;border-right-width:4px}.mg-header{margin-bottom:1rem}.mg-instructions,.mg-progress-section{padding:.875rem 1rem}.mg-instructions{flex-direction:column;gap:.5rem}.mg-instructions>svg{transform:rotate(90deg)}.mg-completion{padding:1.25rem}.mg-completion-header{flex-direction:column;gap:.75rem;text-align:center}.mg-completion-text{text-align:center}.mg-completion-title{font-size:1.25rem}.mg-completion-icon{height:48px;width:48px}.mg-completion-icon svg{height:24px;width:24px}.mg-completion-stats{gap:.375rem}.mg-stat-pill{font-size:.75rem;padding:.375rem .625rem}.mg-completion-secondary{flex-direction:column;width:100%}.mg-action-btn--secondary{justify-content:center;width:100%}.mg-review-term{max-width:80px}}@media (max-width:480px){.mg-card{font-size:.85rem;min-height:48px;padding:.875rem}.mg-stat-pill{font-size:.6875rem;padding:.375rem .5rem}.mg-action-btn{font-size:.8125rem;padding:.625rem 1rem}.mg-progress-info{align-items:flex-start;flex-direction:column;gap:.5rem}.mg-review-item{padding:.625rem}.mg-review-content{flex-wrap:wrap}.mg-review-definition,.mg-review-term{max-width:none;white-space:normal}}.mg-game-board--dragging,.mg-game-board--dragging .mg-card:not(.mg-card--matched){cursor:crosshair}.mg-drag-line{pointer-events:none}.mg-drag-end-dot{filter:drop-shadow(0 1px 3px rgba(139,92,246,.4))}.mg-card--drag-target{animation:mg-target-pulse 1s ease infinite;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-color:#8b5cf6!important;box-shadow:0 0 0 3px #8b5cf633,0 4px 12px #8b5cf626}.mg-viewer--immersive .mg-card--drag-target{background:#8b5cf626;border-color:#8b5cf6cc!important}@keyframes mg-target-pulse{0%,to{box-shadow:0 0 0 3px #8b5cf633,0 4px 12px #8b5cf626}50%{box-shadow:0 0 0 5px #8b5cf640,0 6px 16px #8b5cf633}}.mg-center-hint{flex-direction:column;gap:.5rem;padding:1rem}.mg-center-hint,.mg-hint-icon{align-items:center;display:flex;justify-content:center}.mg-hint-icon{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:14px;box-shadow:0 2px 8px #0000000d;color:#64748b;height:48px;width:48px}.mg-viewer--immersive .mg-hint-icon{background:#ffffff26;color:#ffffffb3}.mg-hint-text{color:#94a3b8;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.mg-viewer--immersive .mg-hint-text{color:#fff9}.mg-instruction-item{align-items:center;color:#475569;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.mg-viewer--immersive .mg-instruction-item{color:#ffffffd9}.mg-instruction-item svg{color:#0ea5e9}.mg-viewer--immersive .mg-instruction-item svg{color:#67e8f9}.mg-instruction-divider{color:#94a3b8;font-size:.75rem;font-weight:600;padding:0 .25rem;text-transform:uppercase}.mg-viewer--immersive .mg-instruction-divider{color:#fff6}.mg-viewer--immersive .mg-completion{margin:0 auto;max-width:700px}.mg-viewer--immersive .mg-review-item{background:#fffc}.mg-viewer--immersive .mg-viewer-title{color:#fff;font-size:1.75rem;font-weight:700;margin-bottom:1.75rem;text-shadow:0 2px 12px #0000004d}.mg-viewer--immersive .mg-progress-section{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff2;border-color:#fffc;box-shadow:0 4px 24px #0000001f}.mg-viewer--immersive .mg-progress-bar{background:#e2e8f0;border:none}.mg-viewer--immersive .mg-progress-fill{box-shadow:0 0 12px #10b98166}.mg-viewer--immersive .mg-progress-text{color:#1e293b;font-weight:500}.mg-viewer--immersive .mg-progress-text strong{color:#0ea5e9;text-shadow:none}.mg-viewer--immersive .mg-stat-inline{background:#f1f5f9;border-radius:8px;color:#475569;padding:.375rem .625rem}.mg-viewer--immersive .mg-stat-inline svg{color:#0ea5e9}.mg-viewer--immersive .mg-column-label{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid #fffc;box-shadow:0 2px 12px #00000014;color:#1e293b}.mg-viewer--immersive .mg-column-icon{background:#f1f5f9;border:none}.mg-viewer--immersive .mg-column--left .mg-column-icon svg{color:#0ea5e9}.mg-viewer--immersive .mg-column--right .mg-column-icon svg{color:#8b5cf6}.mg-viewer--immersive .mg-card{background:#fff;border-color:#e2e8f0;box-shadow:0 4px 16px #0000001a}.mg-viewer--immersive .mg-card:hover:not(:disabled){background:#fff;box-shadow:0 8px 28px #00000026;transform:translateY(-2px) scale(1.01)}.mg-viewer--immersive .mg-card--matched{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-color:#10b981}.mg-viewer--immersive .mg-card--selected{background:linear-gradient(135deg,#f0f9ff,#fff);border-color:#0ea5e9}.mg-viewer--immersive .mg-instructions{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border-color:#fffc;box-shadow:0 2px 12px #00000014}.mg-viewer--immersive .mg-instruction-item{color:#475569}.mg-viewer--immersive .mg-instruction-item svg{color:#0ea5e9}.mg-viewer--immersive .mg-instruction-divider{color:#94a3b8}.mg-viewer--immersive .mg-hint-icon{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffe6;box-shadow:0 2px 8px #0000001a;color:#64748b}.mg-viewer--immersive .mg-hint-text{color:#ffffffe6;text-shadow:0 1px 4px #0000004d}.mg-viewer--immersive .mg-connection-line path{filter:drop-shadow(0 2px 8px rgba(16,185,129,.5))}.mg-viewer--immersive .mg-connection-dot{filter:drop-shadow(0 2px 6px rgba(16,185,129,.6))}.share-modal-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;pointer-events:auto;position:fixed;top:0;width:100%;z-index:999999}.share-modal-content{background:#fff;border-radius:8px;box-shadow:0 8px 20px #0003;max-width:420px;padding:2rem 1.5rem;position:relative;text-align:center;width:90%;z-index:1000000}.modal-close-btn{background:none;border:none;color:#333;cursor:pointer;font-size:1.5rem;position:absolute;right:14px;top:10px;z-index:1000001}.modal-close-btn:hover{color:#666}.modal-title{color:#2d3748;font-size:1.4rem;font-weight:600;margin-bottom:.5rem}.modal-subtitle{color:#4a5568;margin-bottom:1.5rem}.share-link-wrapper{align-items:stretch;display:flex;gap:8px;margin-bottom:1rem}.share-link-wrapper input{border:1px solid #ccc;border-radius:4px;flex:1 1;font-size:.95rem;padding:.6rem;text-align:center}.share-copy-btn{background:#3b82f6;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:0 1rem;transition:background-color .2s}.share-copy-btn:hover{background:#2563eb}:root{--mgen-primary:#0ea5e9;--mgen-primary-dark:#0284c7;--mgen-accent:#38bdf8;--mgen-secondary:#06b6d4;--mgen-text:#0f172a;--mgen-text-secondary:#64748b;--mgen-text-muted:#94a3b8;--mgen-border:#e2e8f0;--mgen-bg:#fff;--mgen-bg-subtle:#f0f9ff;--mgen-gradient:linear-gradient(135deg,#0ea5e9,#06b6d4);--mgen-radius:16px;--mgen-radius-sm:10px;--mgen-radius-lg:24px;--mgen-shadow:0 4px 24px #0ea5e914;--mgen-shadow-lg:0 12px 48px #0ea5e91f;--mgen-transition:cubic-bezier(0.16,1,0.3,1)}.mgen-page{background:#fff;background:var(--mgen-bg);color:#0f172a;color:var(--mgen-text);min-height:100vh;overflow-x:hidden;position:relative}.mgen-ambient{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.mgen-orb{border-radius:50%;filter:blur(120px);position:absolute}.mgen-orb--1{background:linear-gradient(135deg,#0ea5e9,#38bdf8);background:linear-gradient(135deg,var(--mgen-primary) 0,var(--mgen-accent) 100%);height:800px;opacity:.08;right:-300px;top:-400px;width:800px}.mgen-orb--2{background:#06b6d4;background:var(--mgen-secondary);bottom:-200px;height:600px;left:-200px;opacity:.06;width:600px}.mgen-hero{margin:0 auto;max-width:800px;padding:3rem 2rem 2rem;position:relative;text-align:center;z-index:1}.mgen-hero-badge{display:none}.mgen-hero-title{color:#0f172a;color:var(--mgen-text);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;margin:0 0 1rem}.mgen-gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0ea5e9,#06b6d4);background:var(--mgen-gradient);-webkit-background-clip:text;background-clip:text;display:inline-block;padding-bottom:.1em}.mgen-hero-subtitle{color:#64748b;color:var(--mgen-text-secondary);font-size:1.0625rem;font-weight:400;line-height:1.6;margin:0 auto;max-width:500px}.mgen-hero-visual{display:none}.mgen-generator{margin:0 auto;max-width:800px;padding:0 1.5rem 4rem;position:relative;z-index:1}.mgen-generator-card{background:#fff;background:var(--mgen-bg);border:1px solid #e2e8f0;border:1px solid var(--mgen-border);border-radius:24px;border-radius:var(--mgen-radius-lg);box-shadow:0 12px 48px #0ea5e91f;box-shadow:var(--mgen-shadow-lg);overflow:hidden;position:relative}.mgen-generator-card:before{background:linear-gradient(135deg,#0ea5e9,#06b6d4);background:var(--mgen-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0}.mgen-card-header{display:none}.mgen-dropzone{background:linear-gradient(180deg,#f0f9ff,#fff);background:linear-gradient(180deg,var(--mgen-bg-subtle) 0,var(--mgen-bg) 100%);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--mgen-border);cursor:pointer;padding:3rem 2.5rem;position:relative}.mgen-dropzone,.mgen-dropzone:before{transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--mgen-transition)}.mgen-dropzone:before{border:2px dashed #e2e8f0;border:2px dashed var(--mgen-border);border-radius:16px;border-radius:var(--mgen-radius);content:"";inset:1.25rem;pointer-events:none;position:absolute}.mgen-dropzone:hover:before{background:linear-gradient(135deg,#0ea5e908,#06b6d408);border-color:#0ea5e9;border-color:var(--mgen-primary)}.mgen-dropzone--active:before{background:linear-gradient(135deg,#0ea5e90f,#06b6d40f);border-color:#0ea5e9;border-color:var(--mgen-primary);border-style:solid;transform:scale(1.01)}.mgen-dropzone--has-file{background:linear-gradient(180deg,#0ea5e90a,#fff);background:linear-gradient(180deg,#0ea5e90a 0,var(--mgen-bg) 100%)}.mgen-dropzone--has-file:before{background:#0ea5e905;border-color:#0ea5e9;border-color:var(--mgen-primary);border-style:solid}.mgen-dropzone-content{align-items:center;display:flex;flex-direction:column;gap:.875rem;position:relative;z-index:1}.mgen-dropzone-icon{align-items:center;background:linear-gradient(135deg,#0ea5e91a,#06b6d41a);border-radius:50%;color:#0ea5e9;color:var(--mgen-primary);display:flex;height:64px;justify-content:center;transition:all .4s cubic-bezier(.16,1,.3,1);transition:all .4s var(--mgen-transition);width:64px}.mgen-dropzone-icon svg{height:28px;width:28px}.mgen-dropzone:hover .mgen-dropzone-icon{background:linear-gradient(135deg,#0ea5e926,#06b6d426);box-shadow:0 8px 24px #0ea5e933;transform:translateY(-4px) scale(1.05)}.mgen-dropzone--active .mgen-dropzone-icon{background:linear-gradient(135deg,#0ea5e9,#06b6d4);background:var(--mgen-gradient);color:#fff;transform:scale(1.1)}.mgen-dropzone-text{text-align:center}.mgen-dropzone-hint{color:#94a3b8;color:var(--mgen-text-muted);font-size:.875rem}.mgen-file-preview{align-items:center;display:flex;gap:1rem}.mgen-file-icon{align-items:center;background:linear-gradient(135deg,#0ea5e9,#06b6d4);border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.mgen-file-info{flex:1 1;text-align:left}.mgen-file-name{color:#0f172a;display:block;font-weight:600;margin-bottom:.25rem}.mgen-file-size{color:#64748b;font-size:.875rem}.mgen-file-remove{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.mgen-file-remove:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.mgen-options{margin-bottom:1.5rem}.mgen-option-group{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.mgen-option-label{align-items:center;color:#0f172a;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:1rem}.mgen-option-label svg{color:#0ea5e9}.mgen-count-selector{display:flex;flex-wrap:wrap;gap:.5rem}.mgen-count-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.25rem;justify-content:center;min-width:50px;padding:.625rem 1rem;transition:all .2s}.mgen-count-btn:hover:not(:disabled){border-color:#38bdf8;color:#0ea5e9}.mgen-count-btn--active{background:linear-gradient(135deg,#0ea5e9,#06b6d4);border-color:#0000;box-shadow:0 4px 12px #0ea5e94d;color:#fff}.mgen-count-btn--locked{cursor:not-allowed;opacity:.5}.mgen-count-btn--locked svg{color:#94a3b8}.mgen-upgrade-hint{align-items:center;background:linear-gradient(135deg,#f59e0b1a,#fbbf240d);border:1px solid #f59e0b33;border-radius:6px;color:#d97706;cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;gap:.375rem;margin-left:auto;padding:.25rem .625rem;transition:all .2s}.mgen-upgrade-hint:hover{background:linear-gradient(135deg,#f59e0b26,#fbbf241a);border-color:#f59e0b4d;transform:translateY(-1px)}.mgen-upgrade-hint svg{color:#f59e0b}.mgen-upgrade-banner{align-items:center;background:linear-gradient(135deg,#0ea5e914,#06b6d40a);border:1px solid #0ea5e926;border-radius:12px;display:flex;gap:1rem;justify-content:space-between;margin-top:1.5rem;padding:1rem 1.5rem}.mgen-upgrade-content{align-items:center;color:#0284c7;display:flex;font-size:.9375rem;font-weight:500;gap:.75rem}.mgen-upgrade-content svg{color:#0ea5e9;flex-shrink:0}.mgen-upgrade-btn{background:linear-gradient(135deg,#0ea5e9,#06b6d4);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:all .2s;white-space:nowrap}.mgen-upgrade-btn:hover{box-shadow:0 4px 12px #0ea5e959;transform:translateY(-2px)}@media (max-width:640px){.mgen-upgrade-banner{flex-direction:column;text-align:center}.mgen-upgrade-content{flex-direction:column;gap:.5rem}}.mgen-error{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;font-size:.9375rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.mgen-error,.mgen-generate-btn{align-items:center;display:flex;gap:.75rem}.mgen-generate-btn{background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:14px;box-shadow:0 4px 16px #0ea5e959;color:#fff;cursor:pointer;font-size:1.0625rem;font-weight:700;justify-content:center;padding:1rem 2rem;transition:all .3s ease;width:100%}.mgen-generate-btn:hover:not(:disabled){box-shadow:0 8px 24px #0ea5e966;transform:translateY(-2px)}.mgen-generate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.mgen-btn-spinner{animation:mgen-spin .8s linear infinite;border:2.5px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes mgen-spin{to{transform:rotate(1turn)}}.mgen-result{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #0ea5e91a;border-radius:24px;box-shadow:0 8px 32px #0ea5e91a;padding:2rem}.mgen-result-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.mgen-result-header h2{color:#0f172a;font-size:1.375rem;font-weight:700;margin:0}.mgen-result-actions{display:flex;gap:.75rem}.mgen-action-btn{align-items:center;background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:10px;box-shadow:0 4px 12px #0ea5e940;color:#fff;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s}.mgen-action-btn:hover{box-shadow:0 6px 16px #0ea5e959;transform:translateY(-2px)}.mgen-action-btn--secondary{background:#fff;border:1.5px solid #e2e8f0;box-shadow:none;color:#64748b}.mgen-action-btn--secondary:hover{border-color:#38bdf8;box-shadow:0 4px 12px #0ea5e926;color:#0ea5e9}.mgen-viewer-wrapper{background:#f8fafc;border-radius:16px;padding:1.5rem}.mgen-immersive-overlay{background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);bottom:0;display:flex;flex-direction:column;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.mgen-immersive-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem;padding:.5rem 1rem}.mgen-immersive-header h2{color:#0f172a;font-size:1.25rem;font-weight:700;margin:0}.mgen-immersive-close{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s;width:44px}.mgen-immersive-close:hover{background:#f1f5f9;color:#0f172a}.mgen-immersive-content{flex:1 1;overflow:auto;padding:1rem}.mgen-process{background:linear-gradient(180deg,#f0f9ff,#fff);background:linear-gradient(180deg,var(--mgen-bg-subtle) 0,var(--mgen-bg) 100%);overflow:hidden;padding:6rem 2rem 8rem;position:relative;z-index:1}.mgen-process:before{background:radial-gradient(circle,#0ea5e908 0,#0000 70%);content:"";height:800px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:800px}.mgen-process-flow{display:flex;flex-direction:column;gap:0;margin:0 auto;max-width:900px}.mgen-flow-item{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:auto 1fr auto;padding:2rem 0;position:relative}.mgen-flow-item--left{text-align:left}.mgen-flow-item--right{text-align:right}.mgen-flow-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0ea5e9,#06b6d4);-webkit-background-clip:text;background-clip:text;font-size:clamp(4rem,10vw,7rem);font-weight:900;line-height:1;opacity:.15;transition:all .5s cubic-bezier(.16,1,.3,1);-webkit-user-select:none;user-select:none}.mgen-flow-item:hover .mgen-flow-number{opacity:.35;transform:scale(1.05)}.mgen-flow-content{max-width:340px}.mgen-flow-item--right .mgen-flow-content{margin-left:auto}.mgen-flow-content h3{color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .625rem;transition:color .3s}.mgen-flow-item:hover .mgen-flow-content h3{color:#0ea5e9}.mgen-flow-content p{color:#64748b;font-size:1rem;line-height:1.7;margin:0}.mgen-flow-visual{align-items:center;display:flex;height:100px;justify-content:center;width:100px}.mgen-flow-icon{color:#94a3b8;height:80px;opacity:.4;transition:all .5s cubic-bezier(.16,1,.3,1);width:80px}.mgen-flow-item:hover .mgen-flow-icon{color:#0ea5e9;opacity:.7;transform:scale(1.1)}.mgen-flow-connector{display:flex;height:60px;justify-content:center;opacity:.4}.mgen-flow-connector svg{height:100%;width:40px}.mgen-value{margin:0 auto;max-width:1100px;padding:6rem 2rem 8rem;position:relative;z-index:1}.mgen-value-header{margin-bottom:4rem;text-align:center}.mgen-value-header h2{color:#0f172a;font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;margin:0}.mgen-value-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-auto-rows:minmax(180px,auto);grid-template-columns:repeat(12,1fr)}.mgen-value-card{background:#fff;border:1px solid #e2e8f0;border-radius:24px;grid-column:span 6;overflow:hidden;position:relative;transition:all .5s cubic-bezier(.16,1,.3,1)}.mgen-value-card:hover{border-color:#0000;box-shadow:0 12px 48px #0ea5e91f;transform:translateY(-8px)}.mgen-value-card-blob{border-radius:50%;filter:blur(60px);height:200px;opacity:0;pointer-events:none;position:absolute;transition:all .6s cubic-bezier(.16,1,.3,1);width:200px}.mgen-value-card:first-child .mgen-value-card-blob{background:#0ea5e9;right:-50px;top:-50px}.mgen-value-card:nth-child(2) .mgen-value-card-blob{background:#06b6d4;bottom:-50px;left:-50px}.mgen-value-card:nth-child(3) .mgen-value-card-blob{background:#38bdf8;left:-50px;top:-50px}.mgen-value-card:nth-child(4) .mgen-value-card-blob{background:linear-gradient(135deg,#0ea5e9,#06b6d4);bottom:-50px;right:-50px}.mgen-value-card:hover .mgen-value-card-blob{opacity:.15;transform:scale(1.2)}.mgen-value-card-inner{display:flex;flex-direction:column;height:100%;padding:2rem;position:relative;z-index:1}.mgen-value-card-icon{align-items:center;background:linear-gradient(135deg,#0ea5e91a,#06b6d41a);border-radius:14px;display:flex;height:52px;justify-content:center;margin-bottom:1.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);width:52px}.mgen-value-card-icon svg{color:#0ea5e9;height:26px;transition:all .3s;width:26px}.mgen-value-card:hover .mgen-value-card-icon{background:linear-gradient(135deg,#0ea5e9,#06b6d4);transform:scale(1.1) rotate(-5deg)}.mgen-value-card:hover .mgen-value-card-icon svg{color:#fff}.mgen-value-card h3{color:#0f172a;font-size:1.375rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .75rem;transition:color .3s}.mgen-value-card:hover h3{color:#0ea5e9}.mgen-value-card p{color:#64748b;flex:1 1;font-size:1rem;line-height:1.7;margin:0}.mgen-value-card--featured{grid-column:span 7;grid-row:span 2}.mgen-value-card--featured .mgen-value-card-inner{padding:2.5rem}.mgen-value-card--featured .mgen-value-card-icon{border-radius:18px;height:64px;width:64px}.mgen-value-card--featured .mgen-value-card-icon svg{height:32px;width:32px}.mgen-value-card--featured h3{font-size:1.75rem}.mgen-value-card--featured p{font-size:1.0625rem;max-width:400px}.mgen-value-card--wide{grid-column:span 12}.mgen-value-card--wide .mgen-value-card-inner{align-items:center;flex-direction:row;gap:2rem}.mgen-value-card--wide .mgen-value-card-icon{flex-shrink:0;margin-bottom:0}.mgen-value-card--wide h3{margin-bottom:.5rem}.mgen-value-card:nth-child(2),.mgen-value-card:nth-child(3){grid-column:span 5}.mgen-faq{background:linear-gradient(180deg,#fff,#f0f9ff);background:linear-gradient(180deg,var(--mgen-bg) 0,var(--mgen-bg-subtle) 100%);padding:6rem 2rem;position:relative;z-index:1}.mgen-faq-header{margin:0 auto 3.5rem;max-width:500px;text-align:center}.mgen-faq-eyebrow{align-items:center;background:#0ea5e91a;border-radius:100px;color:#0ea5e9;display:inline-flex;font-size:.8rem;font-weight:700;gap:.5rem;letter-spacing:.15em;margin-bottom:1rem;padding:.5rem 1rem;text-transform:uppercase}.mgen-faq-header h2{color:#0f172a;font-size:clamp(2rem,5vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin:0}.mgen-faq-list{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:760px}.mgen-faq-item{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1)}.mgen-faq-item:hover{border-color:#0ea5e94d;box-shadow:0 4px 16px #0ea5e90f}.mgen-faq-item--open{border-color:#0ea5e9;box-shadow:0 8px 32px #0ea5e91f}.mgen-faq-trigger{align-items:center;background:none;border:none;color:#0f172a;cursor:pointer;display:flex;font-size:1.0625rem;font-weight:700;gap:1rem;justify-content:space-between;padding:1.375rem 1.5rem;text-align:left;transition:all .2s;width:100%}.mgen-faq-trigger:hover{color:#0ea5e9}.mgen-faq-trigger svg{color:#94a3b8;flex-shrink:0;transition:all .3s cubic-bezier(.16,1,.3,1)}.mgen-faq-item--open .mgen-faq-trigger svg{color:#0ea5e9;transform:rotate(45deg)}.mgen-faq-content{max-height:0;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1)}.mgen-faq-item--open .mgen-faq-content{max-height:400px}.mgen-faq-content p{color:#64748b;font-size:1rem;line-height:1.75;margin:0;padding:0 1.5rem 1.5rem}.mgen-cta{align-items:center;background:#f0f9ff;background:var(--mgen-bg-subtle);border-top:1px solid #e2e8f0;border-top:1px solid var(--mgen-border);display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;padding:4rem 2rem;position:relative;z-index:1}.mgen-cta p{color:#0f172a;font-size:1.25rem;font-weight:600;margin:0}.mgen-cta-btn{background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:12px;box-shadow:0 4px 16px #0ea5e94d;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:1rem 2.5rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.mgen-cta-btn:hover{box-shadow:0 8px 24px #0ea5e966;transform:translateY(-2px)}@media (max-width:900px){.mgen-flow-item{gap:1rem;grid-template-columns:1fr;text-align:center!important}.mgen-flow-item--right .mgen-flow-content{margin-left:0}.mgen-flow-content{max-width:100%;order:2}.mgen-flow-number{font-size:4rem;order:1}.mgen-flow-visual{margin:0 auto;order:3}.mgen-flow-connector{height:40px}.mgen-value-grid{grid-template-columns:repeat(2,1fr)}.mgen-value-card--featured{grid-column:span 2;grid-row:span 1}.mgen-value-card:nth-child(2),.mgen-value-card:nth-child(3){grid-column:span 1}.mgen-value-card--wide{grid-column:span 2}}@media (max-width:768px){.mgen-page{padding:0}.mgen-hero{padding:2rem 1.5rem 1.5rem}.mgen-generator{padding:0 1rem 3rem}.mgen-dropzone{padding:2.5rem 2rem}.mgen-result-header{align-items:flex-start;flex-direction:column}.mgen-result-actions{width:100%}.mgen-action-btn{flex:1 1;justify-content:center}.mgen-process{padding:4rem 1.5rem 5rem}.mgen-flow-number{font-size:3.5rem}.mgen-flow-content h3{font-size:1.25rem}.mgen-flow-content p{font-size:.95rem}.mgen-flow-visual{height:80px;width:80px}.mgen-flow-icon{height:60px;width:60px}.mgen-value{padding:4rem 1.5rem}.mgen-value-grid{gap:1.25rem;grid-template-columns:1fr}.mgen-value-card,.mgen-value-card--featured,.mgen-value-card--wide,.mgen-value-card:nth-child(2),.mgen-value-card:nth-child(3){grid-column:span 1;grid-row:span 1}.mgen-value-card--featured .mgen-value-card-inner{padding:2rem}.mgen-value-card--featured h3{font-size:1.375rem}.mgen-value-card--wide .mgen-value-card-inner{align-items:flex-start;flex-direction:column}.mgen-value-card--wide .mgen-value-card-icon{margin-bottom:1.25rem}.mgen-value-card:hover{transform:translateY(-4px)}.mgen-faq{padding:4rem 1.5rem}.mgen-faq-trigger{font-size:1rem;padding:1.125rem 1.25rem}.mgen-faq-content p{font-size:.95rem;padding:0 1.25rem 1.25rem}.mgen-cta{flex-direction:column;gap:1.5rem;padding:3rem 1.5rem;text-align:center}.mgen-cta p{font-size:1.125rem}.mgen-cta-btn{max-width:280px;width:100%}}@media (max-width:480px){.mgen-hero-title{font-size:1.75rem}.mgen-hero-subtitle{font-size:1rem}.mgen-card-pair{flex-direction:column;gap:.5rem}.mgen-pair-connector{transform:rotate(90deg)}.mgen-demo-card{height:60px;width:120px}.mgen-count-selector{justify-content:center}.mgen-value-header h2{font-size:1.75rem}.mgen-value-card h3{font-size:1.25rem}.mgen-value-card p{font-size:.95rem}.mgen-value-card-inner{padding:1.5rem}.mgen-value-card-icon{height:44px;margin-bottom:1rem;width:44px}.mgen-value-card-icon svg{height:22px;width:22px}.mgen-faq-header h2{font-size:1.75rem}}.genpage{background:#fff;min-height:100vh;overflow-x:hidden;position:relative}.genpage-ambient{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.genpage-orb{border-radius:50%;filter:blur(120px);position:absolute}.genpage-orb--1{background:linear-gradient(135deg,#3b82f6,#8b5cf6);height:600px;opacity:.07;right:-200px;top:-300px;width:600px}.genpage-orb--2{background:#f59e0b;bottom:20%;height:500px;left:-200px;opacity:.05;width:500px}.genpage-orb--3{background:#10b981;bottom:-100px;height:400px;opacity:.05;right:20%;width:400px}.genpage-hero{margin:0 auto;max-width:700px;padding:4rem 2rem 2rem;position:relative;text-align:center;z-index:1}.genpage-hero-title{color:#0f172a;font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;margin:0 0 1rem}.genpage-gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6 50%,#ec4899);-webkit-background-clip:text;background-clip:text;display:inline-block;padding-bottom:.1em}.genpage-hero-subtitle{color:#64748b;font-size:1.0625rem;font-weight:400;line-height:1.6;margin:0 auto;max-width:550px}.genpage-quick{margin:0 auto;max-width:900px;padding:2rem 2rem 3rem;position:relative;z-index:1}.genpage-quick-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(6,1fr)}.genpage-quick-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;display:flex;flex-direction:column;gap:.75rem;padding:1.25rem 1rem;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1)}.genpage-quick-card:hover{border-color:var(--card-color);box-shadow:0 8px 24px #00000014;transform:translateY(-4px)}.genpage-quick-icon{align-items:center;background:linear-gradient(135deg,color-mix(in srgb,var(--card-color) 10%,#0000) 0,color-mix(in srgb,var(--card-color) 15%,#0000) 100%);border-radius:12px;display:flex;height:48px;justify-content:center;transition:all .3s cubic-bezier(.16,1,.3,1);width:48px}.genpage-quick-icon svg{color:var(--card-color);height:24px;transition:all .3s;width:24px}.genpage-quick-card:hover .genpage-quick-icon{background:var(--card-gradient);transform:scale(1.1) rotate(-5deg)}.genpage-quick-card:hover .genpage-quick-icon svg{color:#fff}.genpage-quick-title{color:#0f172a;font-size:.8125rem;font-weight:600;line-height:1.3;text-align:center}.genpage-learning{margin:0 auto;max-width:900px;padding:2rem 2rem 3rem;position:relative;z-index:1}.genpage-learning-card{align-items:center;background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #94a3b826;border-radius:24px;display:flex;gap:3rem;overflow:hidden;padding:2.5rem;position:relative}.genpage-learning-glow{background:radial-gradient(circle,#a78bfa33 0,#0000 70%);height:400px;pointer-events:none;position:absolute;right:-20%;top:-50%;width:400px}.genpage-learning-content{flex:1 1;position:relative;z-index:1}.genpage-learning-badge{align-items:center;background:linear-gradient(135deg,#a78bfa40,#f472b633);border:1px solid #a78bfa59;border-radius:100px;color:#d8b4fe;display:inline-flex;font-size:.75rem;font-weight:600;gap:.5rem;margin-bottom:1.25rem;padding:.4rem .875rem}.genpage-learning-badge svg{color:#c4b5fd}.genpage-learning-title{color:#fff;font-size:1.75rem;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:0 0 .75rem}.genpage-learning-title span{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#a78bfa,#f472b6);-webkit-background-clip:text;background-clip:text}.genpage-learning-desc{color:#cbd5e1;font-size:.9375rem;line-height:1.6;margin:0 0 1.5rem;max-width:380px}.genpage-learning-tools{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.75rem}.genpage-learning-tool{align-items:center;display:flex;flex-direction:column;gap:.5rem}.genpage-learning-tool-icon{align-items:center;border-radius:12px;display:flex;height:44px;justify-content:center;transition:transform .3s cubic-bezier(.16,1,.3,1);width:44px}.genpage-learning-tool:hover .genpage-learning-tool-icon{transform:translateY(-4px) scale(1.05)}.genpage-learning-tool-icon svg{color:#fff;height:22px;width:22px}.genpage-learning-tool span{color:#cbd5e1;font-size:.6875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.genpage-learning-tool--more .genpage-learning-tool-icon{background:#cbd5e126;border:1px dashed #cbd5e166}.genpage-learning-tool--more .genpage-learning-tool-icon span{color:#94a3b8;font-size:.875rem;font-weight:700;letter-spacing:0;text-transform:none}.genpage-learning-btn{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:12px;box-shadow:0 4px 20px #8b5cf666;color:#fff;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.625rem;padding:.875rem 1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1)}.genpage-learning-btn:hover{box-shadow:0 8px 30px #8b5cf680;transform:translateY(-2px)}.genpage-learning-btn svg{transition:transform .3s}.genpage-learning-btn:hover svg{transform:translateX(4px)}.genpage-learning-visual{flex-shrink:0;height:200px;position:relative;width:200px}.genpage-learning-stack{height:100%;position:relative;width:100%}.genpage-stack-item{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1.5px solid #ffffff26;border-radius:14px;display:flex;height:75px;justify-content:center;position:absolute;transition:all .4s cubic-bezier(.16,1,.3,1);width:110px}.genpage-stack-item svg{height:32px;width:32px}.genpage-stack-item--1{background:linear-gradient(135deg,#3b82f640,#3b82f61a);border-color:#3b82f666;box-shadow:0 4px 20px #3b82f633;left:0;top:5px;transform:rotate(-10deg)}.genpage-stack-item--1 svg{color:#60a5fa}.genpage-stack-item--2{background:linear-gradient(135deg,#f59e0b40,#f59e0b1a);border-color:#f59e0b66;box-shadow:0 4px 20px #f59e0b33;right:0;top:25px;transform:rotate(10deg)}.genpage-stack-item--2 svg{color:#fbbf24}.genpage-stack-item--3{background:linear-gradient(135deg,#10b98140,#10b9811a);border-color:#10b98166;bottom:15px;box-shadow:0 4px 20px #10b98133;left:10px;transform:rotate(-6deg)}.genpage-stack-item--3 svg{color:#34d399}.genpage-stack-item--4{background:linear-gradient(135deg,#ec489940,#ec48991a);border-color:#ec489966;bottom:25px;box-shadow:0 4px 20px #ec489933;height:68px;right:15px;transform:rotate(6deg);width:100px}.genpage-stack-item--4 svg{color:#f472b6;height:28px;width:28px}.genpage-stack-center{align-items:center;background:linear-gradient(135deg,#a78bfa,#8b5cf6 50%,#7c3aed);border-radius:18px;box-shadow:0 8px 32px #8b5cf680,inset 0 0 0 1px #ffffff1a;display:flex;height:72px;justify-content:center;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:72px;z-index:2}.genpage-stack-center svg{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));height:36px;width:36px}.genpage-learning-card:hover .genpage-stack-item--1{transform:rotate(-14deg) translate(-8px,-5px)}.genpage-learning-card:hover .genpage-stack-item--2{transform:rotate(14deg) translate(8px,-5px)}.genpage-learning-card:hover .genpage-stack-item--3{transform:rotate(-10deg) translate(-5px,8px)}.genpage-learning-card:hover .genpage-stack-item--4{transform:rotate(10deg) translate(5px,8px)}.genpage-learning-card:hover .genpage-stack-center{box-shadow:0 12px 40px #8b5cf699,inset 0 0 0 1px #ffffff26;transform:translate(-50%,-50%) scale(1.08)}.genpage-category{margin:0 auto;max-width:1000px;padding:3rem 2rem;position:relative;z-index:1}.genpage-category:nth-child(odd){background:linear-gradient(180deg,#f8fafc,#fff)}.genpage-category-header{margin-bottom:2rem}.genpage-category-header h2{color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .5rem}.genpage-category-header p{color:#64748b;font-size:.9375rem;margin:0}.genpage-cards{display:flex;flex-direction:column;gap:1rem}.genpage-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;display:flex;gap:1.5rem;padding:1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1)}.genpage-card:hover{border-color:var(--card-color);box-shadow:0 8px 24px #0000000f;transform:translateX(8px)}.genpage-card-icon{align-items:center;background:linear-gradient(135deg,color-mix(in srgb,var(--card-color) 10%,#0000) 0,color-mix(in srgb,var(--card-color) 15%,#0000) 100%);border-radius:14px;display:flex;flex-shrink:0;height:56px;justify-content:center;transition:all .3s cubic-bezier(.16,1,.3,1);width:56px}.genpage-card-icon svg{color:var(--card-color);height:28px;transition:all .3s;width:28px}.genpage-card:hover .genpage-card-icon{background:var(--card-gradient);transform:scale(1.05) rotate(-3deg)}.genpage-card:hover .genpage-card-icon svg{color:#fff}.genpage-card-content{flex:1 1;min-width:0}.genpage-card-content h3{color:#0f172a;font-size:1.125rem;font-weight:700;margin:0 0 .375rem;transition:color .2s}.genpage-card:hover .genpage-card-content h3{color:var(--card-color)}.genpage-card-content p{color:#64748b;font-size:.9375rem;line-height:1.5;margin:0}.genpage-card-features{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.genpage-feature-tag{background:linear-gradient(135deg,color-mix(in srgb,var(--card-color) 8%,#0000) 0,color-mix(in srgb,var(--card-color) 12%,#0000) 100%);border-radius:100px;color:var(--card-color);font-size:.75rem;font-weight:500;padding:.25rem .625rem;white-space:nowrap}.genpage-card-arrow{align-items:center;display:flex;flex-shrink:0;height:32px;justify-content:center;opacity:0;transform:translateX(-8px);transition:all .3s cubic-bezier(.16,1,.3,1);width:32px}.genpage-card-arrow svg{color:var(--card-color);height:20px;width:20px}.genpage-card:hover .genpage-card-arrow{opacity:1;transform:translateX(0)}.genpage-tutor{margin:0 auto;max-width:800px;padding:4rem 2rem;position:relative;z-index:1}.genpage-tutor-content{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:24px;padding:3rem;text-align:center}.genpage-tutor-badge{align-items:center;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:100px;color:#3b82f6;display:inline-flex;font-size:.8125rem;font-weight:600;gap:.5rem;margin-bottom:1.5rem;padding:.5rem 1rem}.genpage-tutor-badge svg{color:#8b5cf6}.genpage-tutor-content h2{color:#0f172a;font-size:1.75rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .75rem}.genpage-tutor-content p{color:#64748b;font-size:1rem;line-height:1.6;margin:0 auto 1.5rem;max-width:400px}.genpage-tutor-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;box-shadow:0 4px 16px #3b82f64d;color:#fff;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.875rem 1.75rem;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1)}.genpage-tutor-btn:hover{box-shadow:0 8px 24px #3b82f666;transform:translateY(-2px)}.genpage-faq{margin:0 auto;max-width:800px;padding:4rem 2rem;position:relative;z-index:1}.genpage-faq-header{margin-bottom:2.5rem;text-align:center}.genpage-faq-header h2{color:#0f172a;font-size:1.75rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .5rem}.genpage-faq-header p{color:#64748b;font-size:1rem;margin:0}.genpage-faq-list{display:flex;flex-direction:column;gap:.75rem}.genpage-faq-item{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1)}.genpage-faq-item:hover{border-color:#cbd5e1}.genpage-faq-item.open{border-color:#3b82f6;box-shadow:0 4px 16px #3b82f61a}.genpage-faq-question{align-items:center;background:#0000;border:none;color:#0f172a;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:1rem;justify-content:space-between;padding:1.25rem 1.5rem;text-align:left;transition:all .2s;width:100%}.genpage-faq-question:hover{color:#3b82f6}.genpage-faq-icon{color:#94a3b8;flex-shrink:0;height:20px;transition:transform .3s cubic-bezier(.16,1,.3,1);width:20px}.genpage-faq-item.open .genpage-faq-icon{color:#3b82f6;transform:rotate(180deg)}.genpage-faq-answer{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.16,1,.3,1),padding .3s cubic-bezier(.16,1,.3,1)}.genpage-faq-item.open .genpage-faq-answer{max-height:500px}.genpage-faq-answer p{color:#64748b;font-size:.9375rem;line-height:1.7;margin:0;padding:0 1.5rem 1.25rem}@media (max-width:900px){.genpage-quick-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.genpage-hero{padding:3rem 1.5rem 1.5rem}.genpage-learning,.genpage-quick{padding:1.5rem 1.5rem 2.5rem}.genpage-learning-card{flex-direction:column;gap:2rem;padding:2rem 1.5rem;text-align:center}.genpage-learning-content{align-items:center;display:flex;flex-direction:column}.genpage-learning-title{font-size:1.5rem}.genpage-learning-desc{max-width:100%;text-align:center}.genpage-learning-tools{justify-content:center}.genpage-learning-visual{display:none;height:160px;width:160px}.genpage-quick-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.genpage-quick-card{padding:1rem .75rem}.genpage-quick-icon{height:44px;width:44px}.genpage-quick-icon svg{height:22px;width:22px}.genpage-quick-title{font-size:.75rem}.genpage-category{padding:2.5rem 1.5rem}.genpage-category-header h2{font-size:1.25rem}.genpage-card{gap:1rem;padding:1.25rem}.genpage-card:hover{transform:translateX(4px)}.genpage-card-icon{height:48px;width:48px}.genpage-card-icon svg{height:24px;width:24px}.genpage-card-content h3{font-size:1rem}.genpage-card-content p{font-size:.875rem}.genpage-card-arrow,.genpage-card-features{display:none}.genpage-tutor{padding:3rem 1.5rem}.genpage-tutor-content{padding:2rem 1.5rem}.genpage-tutor-content h2{font-size:1.5rem}.genpage-tutor-content p{font-size:.9375rem}}@media (max-width:480px){.genpage-hero-title{font-size:1.75rem}.genpage-hero-subtitle{font-size:1rem}.genpage-learning{padding:1rem 1rem 2rem}.genpage-learning-card{border-radius:20px;padding:1.5rem 1.25rem}.genpage-learning-title{font-size:1.25rem}.genpage-learning-desc{font-size:.875rem}.genpage-learning-tools{gap:.625rem}.genpage-learning-tool-icon{border-radius:10px;height:38px;width:38px}.genpage-learning-tool-icon svg{height:18px;width:18px}.genpage-learning-tool span{font-size:.625rem}.genpage-learning-btn{justify-content:center;padding:.875rem 1.25rem;width:100%}.genpage-quick-grid{grid-template-columns:repeat(2,1fr)}.genpage-quick-card{gap:.5rem;padding:1rem .5rem}.genpage-quick-icon{border-radius:10px;height:40px;width:40px}.genpage-quick-icon svg{height:20px;width:20px}.genpage-quick-title{font-size:.6875rem}.genpage-category{padding:2rem 1rem}.genpage-card{padding:1rem}.genpage-card-icon{border-radius:12px;height:44px;width:44px}.genpage-card-icon svg{height:22px;width:22px}.genpage-tutor-content{border-radius:20px;padding:1.5rem 1rem}.genpage-tutor-content h2{font-size:1.25rem}.genpage-tutor-btn{justify-content:center;padding:.875rem 1.5rem;width:100%}.genpage-faq{padding:3rem 1rem}.genpage-faq-header h2{font-size:1.5rem}.genpage-faq-question{font-size:.9375rem;padding:1rem 1.25rem}.genpage-faq-answer p{font-size:.875rem;padding:0 1.25rem 1rem}}.navbar{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;left:0;padding:.75rem 0;position:fixed;right:0;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.navbar-brand{align-items:center;color:#1e293b;display:flex;font-size:1.75rem;font-weight:800;gap:.5rem;letter-spacing:-.5px;text-decoration:none}.brand-highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#0000;display:inline-block;font-weight:900}.nav-links{display:flex;gap:2.5rem;list-style:none;margin:0;padding:0}.nav-links a{color:#64748b;font-size:.95rem;font-weight:500;padding:.5rem 0;position:relative;text-decoration:none;transition:all .2s}.nav-links a.active,.nav-links a:hover{color:#3b82f6}.nav-links a.active:after{background:#3b82f6;border-radius:2px;bottom:-2px;content:"";height:2px;left:0;position:absolute;width:100%}.nav-dropdown-container{position:relative}.nav-dropdown-trigger{align-items:center;display:flex;gap:.375rem}.nav-dropdown-arrow{color:#94a3b8;font-size:.6rem;transition:transform .2s}.nav-dropdown-container:hover .nav-dropdown-arrow{transform:rotate(180deg)}.nav-dropdown-menu{animation:dropdownFadeIn .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001f,0 0 0 1px #0000000d;left:50%;min-width:180px;overflow:hidden;position:absolute;top:calc(100% + .5rem);transform:translateX(-50%);z-index:100}.nav-dropdown-item{align-items:center;color:#1e293b;display:flex;font-size:.875rem;font-weight:500;gap:.625rem;padding:.75rem 1rem;text-decoration:none;transition:all .15s}.nav-dropdown-item:hover{background:#f8fafc;color:#3b82f6}.nav-dropdown-item.active{background:#eff6ff;color:#3b82f6}.nav-dropdown-icon{align-items:center;color:#64748b;display:flex;font-size:.8rem;height:20px;justify-content:center;width:20px}.nav-dropdown-item.active .nav-dropdown-icon,.nav-dropdown-item:hover .nav-dropdown-icon{color:#3b82f6}.nav-dropdown-divider{background:#e2e8f0;height:1px;margin:.25rem 0}.nav-dropdown-all{color:#3b82f6!important;font-weight:600}.nav-dropdown-all:hover{background:#eff6ff}.auth-section{align-items:center;display:flex;gap:1rem}.auth-buttons{display:flex;gap:.75rem}.login-button,.register-button{border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.login-button{background:#f8fafc;border:1px solid #e2e8f0;color:#1e293b}.login-button:hover{background:#f1f5f9;border-color:#cbd5e1}.register-button{background:#3b82f6;border:none;color:#fff}.register-button:hover{background:#2563eb;transform:translateY(-1px)}.profile-menu{position:relative}.profile-button{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;display:flex;gap:1rem;padding:.5rem 1rem;transition:all .2s}.profile-button:hover{background:#f1f5f9;border-color:#cbd5e1}.user-email{font-size:.875rem;font-weight:500}.plan-badge{background:#eff6ff;border-radius:9999px;color:#3b82f6;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.plan-badge.premium{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.dropdown-arrow{color:#64748b;font-size:.75rem;transition:transform .2s}.dropdown-arrow.up{transform:rotate(180deg)}.dropdown-menu{animation:dropdownFadeIn .2s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);width:260px}.dropdown-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:1.25rem}.dropdown-header .user-email{color:#1e293b;display:block;font-weight:500;margin-bottom:.375rem}.subscription-status{color:#64748b;font-size:.75rem;font-weight:500}.dropdown-item{background:none;color:#1e293b;gap:.75rem;padding:.875rem 1.25rem;text-decoration:none;transition:all .2s}.dropdown-item:hover{background-color:#f8fafc}.dropdown-item.upgrade{color:#3b82f6;font-weight:500}.dropdown-item.upgrade:hover{background:#eff6ff}.dropdown-item.logout{color:#ef4444}.dropdown-item.logout:hover{background:#fef2f2}.mobile-menu-button{background:none;border:none;border-radius:6px;color:#1e293b;cursor:pointer;display:none;margin-left:.5rem;padding:.5rem;transition:all .2s}.mobile-menu-button:hover{background:#f8fafc;color:#3b82f6}.mobile-menu-button:active{transform:scale(.95)}.mobile-menu-overlay{animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:9999}.mobile-menu{animation:slideInRight .3s cubic-bezier(.4,0,.2,1);background:#fff;box-shadow:-4px 0 16px #00000026;display:flex;flex-direction:column;height:100vh;max-width:320px;overflow-y:auto;padding:6rem 0 2rem;position:fixed;right:0;top:0;width:75%}.mobile-menu a{border-left:4px solid #0000;color:#1e293b;display:block;font-size:1rem;font-weight:500;padding:1.125rem 2rem;position:relative;text-decoration:none;transition:all .2s}.mobile-menu a:active{transform:scale(.98)}.mobile-menu a:hover{background:#f8fafc;color:#3b82f6;padding-left:2.25rem}.mobile-menu a.active{background:#eff6ff;border-left-color:#3b82f6;color:#3b82f6;font-weight:600}.mobile-menu a.active:before{background:#3b82f6;border-radius:50%;content:"";height:6px;position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);width:6px}@media (max-width:768px){.navbar-container{padding:0 1rem}.navbar-brand{font-size:1.5rem}.nav-links{display:none}.mobile-menu-button,.mobile-menu-overlay{display:block}.auth-buttons{gap:.5rem}.login-button,.register-button{font-size:.8125rem;padding:.5rem 1rem}.profile-button{gap:.5rem;padding:.5rem .75rem}.user-email{display:none}.dropdown-menu{width:220px}.dropdown-header{padding:1rem}.dropdown-item{font-size:.8125rem;padding:.75rem 1rem}}@media (max-width:480px){.navbar{padding:.5rem 0}.navbar-container{padding:0 .75rem}.navbar-brand{font-size:1.25rem}.auth-buttons{gap:.375rem}.login-button,.register-button{font-size:.75rem;padding:.5rem .75rem}.profile-button{padding:.5rem}.plan-badge{font-size:.625rem;padding:.2rem .5rem}.mobile-menu{max-width:280px;padding:5rem 0 2rem;width:85%}.mobile-menu a{font-size:.9375rem;padding:1rem 1.5rem}.mobile-menu a:hover{padding-left:1.75rem}.mobile-menu-button{padding:.375rem}.mobile-menu-button svg{height:22px;width:22px}.dropdown-menu{right:-.5rem;width:200px}.dropdown-header{padding:.875rem}.dropdown-header .user-email{display:block;font-size:.8125rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subscription-status{font-size:.6875rem}.dropdown-item{font-size:.75rem;gap:.5rem;padding:.625rem .875rem}.unsubscribe-modal{max-width:320px;padding:1.5rem;width:95%}.unsubscribe-modal h2{font-size:1.25rem}.unsubscribe-modal p{font-size:.875rem}.unsubscribe-buttons{flex-direction:column;gap:.75rem}.confirm-unsub-button,.keep-sub-button{padding:.875rem;width:100%}}.unsubscribe-overlay{align-items:center;background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.unsubscribe-modal{animation:fadeInScale .3s ease;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0003;max-width:400px;padding:2rem;text-align:center;width:90%}.unsubscribe-modal h2{color:#1e293b;margin-bottom:1rem;margin-top:0}.unsubscribe-modal p{color:#4b5563;line-height:1.5;margin-bottom:1.5rem}.unsubscribe-buttons{display:flex;gap:1rem;justify-content:center}.confirm-unsub-button{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.confirm-unsub-button:hover{background:#b91c1c}.keep-sub-button{background:#f3f4f6;border:none;border-radius:6px;color:#111827;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.keep-sub-button:hover{background:#e5e7eb}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.pricing-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000bf;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:9999}.pricing-modal-content{animation:pricingModalAppear .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;max-width:700px;overflow-y:auto;padding:2rem;position:relative;width:95%}.pricing-modal-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.25rem;font-weight:900;margin-bottom:1.75rem;text-align:center}.pricing-modal-features{grid-gap:2rem;background:linear-gradient(135deg,#f8fafc,#f0f9ff);border:1px solid #e2e8f0;border-radius:16px;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem;padding:1.5rem}.pricing-features-current,.pricing-features-upcoming{display:flex;flex-direction:column;gap:.875rem}.pricing-features-upcoming{position:relative}.pricing-coming-soon-label{color:#8b5cf6;font-size:.75rem;font-weight:700;letter-spacing:.5px;margin-bottom:.5rem;position:absolute;top:-1.75rem}.pricing-feature-item{align-items:center;color:#1e293b;display:flex;font-size:.9375rem;font-weight:500;gap:.625rem;line-height:1.4}.pricing-check-icon,.pricing-star-icon{flex-shrink:0}.pricing-check-icon{color:#3b82f6}.pricing-star-icon{color:#8b5cf6}.pricing-feature-coming-soon{color:#64748b}.pricing-plans-container{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.pricing-plan-card{background:#fff;border:3px solid #e2e8f0;border-radius:18px;padding:2.25rem 1.75rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.pricing-plan-card:hover{border-color:#667eea;box-shadow:0 15px 35px #0000002e;transform:translateY(-6px) scale(1.02)}.pricing-plan-highlight{background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border:3px solid #667eea;box-shadow:0 12px 28px #667eea40}.pricing-popular-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:25px;box-shadow:0 4px 12px #667eea80;color:#fff;font-size:.75rem;font-weight:800;left:50%;letter-spacing:1px;padding:.5rem 1.125rem;position:absolute;text-transform:uppercase;top:-13px;transform:translateX(-50%)}.pricing-plan-title{color:#1e293b;font-size:1.375rem;font-weight:700;margin-bottom:1rem}.pricing-price-container{margin-bottom:1rem}.pricing-original-price{color:#94a3b8;display:block;font-size:1rem;margin-bottom:.5rem;text-decoration:line-through}.pricing-current-price{align-items:baseline;display:flex;gap:.25rem;justify-content:center}.pricing-amount{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.75rem;font-weight:900;line-height:1}.pricing-period{color:#64748b;font-size:1.125rem;font-weight:600}.pricing-discount-badge{animation:pulseBadge 2s ease-in-out infinite;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:25px;box-shadow:0 4px 12px #f5576c66;color:#fff;display:inline-block;font-size:.8125rem;font-weight:700;letter-spacing:.5px;margin:.625rem 0;padding:.5rem 1rem;text-transform:uppercase}.pricing-discount-badge.popular{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea66}@keyframes pulseBadge{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.pricing-plan-note{color:#64748b;font-size:.9375rem;font-weight:500;line-height:1.6;margin-bottom:1.5rem}.pricing-savings-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:25px;box-shadow:0 4px 12px #667eea66;color:#fff;font-size:.75rem;padding:.5rem 1rem;position:absolute;right:1.5rem;top:-.75rem}.pricing-plan-button,.pricing-savings-badge{font-weight:700;letter-spacing:.5px;text-transform:uppercase}.pricing-plan-button{border:none;border-radius:50px;box-shadow:0 6px 18px #00000026;cursor:pointer;font-size:1rem;padding:1.125rem 2rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.pricing-plan-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.pricing-monthly-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.pricing-monthly-button:hover:not(:disabled){box-shadow:0 10px 25px #667eea66;transform:translateY(-3px)}.pricing-yearly-button{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.pricing-yearly-button:hover:not(:disabled){box-shadow:0 10px 25px #f5576c66;transform:translateY(-3px)}.pricing-modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#94a3b8;cursor:pointer;display:flex;font-size:2rem;height:36px;justify-content:center;line-height:1;padding:.5rem;position:absolute;right:1rem;top:1rem;transition:all .2s;width:36px}.pricing-modal-close:hover{background-color:#f1f5f9;color:#1e293b}@keyframes pricingModalAppear{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width:768px){.pricing-modal-content{max-height:95vh;padding:1.5rem}.pricing-modal-title{font-size:1.5rem;margin-bottom:1.25rem}.pricing-modal-features{gap:1.5rem;grid-template-columns:1fr;padding:1.25rem}.pricing-coming-soon-label{margin-bottom:.5rem;position:relative;top:0}.pricing-plans-container{gap:1.25rem;grid-template-columns:1fr}.pricing-plan-card{padding:1.5rem 1.25rem}.pricing-amount{font-size:2.25rem}.pricing-plan-button{font-size:.9375rem;padding:.875rem 1.25rem}}@media (max-width:480px){.pricing-modal-content{border-radius:16px;padding:1.25rem;width:100%}.pricing-modal-title{font-size:1.25rem}.pricing-modal-features{padding:1rem}.pricing-feature-item{font-size:.875rem}.pricing-plan-card{padding:1.25rem 1rem}.pricing-amount{font-size:2rem}.pricing-period{font-size:1rem}.pricing-popular-badge{font-size:.625rem;padding:.25rem .625rem}.pricing-discount-badge{font-size:.6875rem;padding:.3rem .75rem}}.modal-overlay{background-color:#000000bf;height:100%;width:100%}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:420px;padding:2rem;position:relative;width:100%}.close-button{background:#0000;color:#666;font-size:1.5rem;position:absolute;right:1rem;top:1rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form h2{color:#1a1a1a;font-size:1.6rem;font-weight:600;margin-bottom:1rem;text-align:center}.input-group{display:flex;flex-direction:column;gap:.5rem}.auth-button{align-items:center;display:inline-flex;justify-content:center;margin-top:.5rem}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #fff;border-radius:50%;border-top-color:#0000;height:18px;margin-right:.5rem;width:18px}.divider{align-items:center;color:#6b7280;display:flex;font-size:.875rem;margin:1rem 0;text-transform:uppercase}.divider:after,.divider:before{background-color:#e5e7eb;content:"";flex:1 1;height:1px}.divider span{font-weight:500;padding:0 1rem}.google-button{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#1a1a1a;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;justify-content:center;padding:.75rem;transition:background-color .2s;width:100%}.footer-text,.google-button:hover{background-color:#f9fafb}.footer-text{border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;font-size:.875rem;margin-top:1.5rem;padding:1rem;text-align:center}.text-button{background:none;border:none;border-radius:4px;color:#4f46e5;cursor:pointer;font-size:.875rem;font-weight:600;padding:.25rem .5rem;text-decoration:none;transition:all .2s}.text-button:hover{background-color:#eef2ff;color:#4338ca}.message.success{background-color:#dcfce7;color:#16a34a}.form-description{color:#6b7280;font-size:.9rem;margin-bottom:1rem;text-align:center}.mt-4{margin-top:1rem}.password-requirements{background-color:#f9fafb;border-radius:8px;font-size:.875rem;margin:1rem 0;padding:1rem}.password-requirements p{color:#374151;font-weight:500;margin-bottom:.5rem}.password-requirements ul{list-style:none;margin:0;padding:0}.password-requirements li{align-items:center;color:#6b7280;display:flex;font-size:.75rem;gap:.5rem;margin-bottom:.25rem}.auth-form{box-sizing:border-box;max-height:80vh;overflow-y:auto;padding-right:.5rem}.quiz-page{-webkit-tap-highlight-color:transparent;background:linear-gradient(180deg,#f8fafc,#e2e8f0);color:#1e293b;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;max-width:100%;min-height:100vh;min-height:100dvh;overflow-x:hidden;position:relative;touch-action:manipulation;width:100vw}*,.quiz-page{box-sizing:border-box}.quiz-header{border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;box-sizing:border-box;gap:2rem;justify-content:space-between;max-width:100vw;padding:1.25rem 2rem;width:100%}.pause-button,.quiz-header{align-items:center;background:#fff;display:flex}.pause-button{-webkit-tap-highlight-color:transparent;border:1.5px solid #cbd5e1;border-radius:8px;cursor:pointer;flex-shrink:0;height:40px;justify-content:center;touch-action:manipulation;transition:all .2s ease;width:40px}.pause-button svg{fill:#64748b;height:18px;pointer-events:none;width:18px}.pause-button:hover{background:#f8fafc;border-color:#94a3b8}.pause-button:active{background:#f1f5f9;transform:scale(.96)}.progress-container{display:flex;flex:1 1;flex-direction:column;gap:.75rem;max-width:600px}.progress-info{align-items:center;display:flex;justify-content:center}.progress-text{color:#64748b;font-size:.875rem;font-weight:500}.progress-bar{background:#e2e8f0;height:8px;overflow:hidden}.progress-bar,.progress-fill{border-radius:100px;position:relative}.progress-fill{background:linear-gradient(90deg,#6366f1,#8b5cf6);height:100%;transition:width .4s ease}.score-display{align-items:center;background:#fef3c7;border:1.5px solid #fde68a;border-radius:8px;display:flex;flex-shrink:0;gap:.5rem;padding:.5rem 1rem}.score-icon{font-size:1.25rem}.score-text{color:#92400e;font-size:1.125rem;font-weight:700}.high-score-badge{align-items:center;animation:slideInRight .3s ease;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px #0000000f;display:flex;gap:.5rem;padding:.5rem .875rem;position:absolute;right:1rem;top:5.5rem;z-index:10}.trophy-icon{font-size:1.125rem}.high-score-text{color:#64748b;font-size:.875rem;font-weight:600}.quiz-content{box-sizing:border-box;flex:1 1;flex-direction:column;gap:2.5rem;margin:0 auto;max-width:1000px;padding:2rem 1.5rem;width:100%}.quiz-content,.timer-circle{align-items:center;display:flex;justify-content:center}.timer-circle{animation:fadeIn .3s ease;flex-shrink:0;height:80px;position:relative;width:80px}.timer-ring{height:100%;left:0;position:absolute;top:0;transform:rotate(-90deg);width:100%}.timer-ring-bg{fill:none;stroke:#e2e8f0;stroke-width:6}.timer-ring-progress{fill:none;stroke:#10b981;stroke-width:6;stroke-linecap:round;transition:stroke-dasharray 1s linear,stroke .3s ease}.timer-circle.warning .timer-ring-progress{stroke:#f59e0b}.timer-circle.danger .timer-ring-progress{stroke:#ef4444}.timer-text{color:#1e293b;font-size:1.5rem;font-weight:700;z-index:1}.question-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-sizing:border-box;max-width:800px;padding:2.5rem 3rem;text-align:center;width:100%}.question-card.question-enter{animation:questionFadeIn .4s ease}.question-card.question-shown{animation:none}@keyframes questionFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.question-number{background:#f1f5f9;border-radius:6px;color:#475569;display:inline-block;font-size:.8125rem;font-weight:600;letter-spacing:.025em;margin-bottom:1.5rem;padding:.375rem .875rem}.question-text{color:#0f172a;font-size:1.5rem;font-weight:600;line-height:1.5;margin:0}.answer-grid{grid-gap:1rem;animation:answersSlideUp .4s ease;box-sizing:border-box;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);max-width:800px;width:100%}@keyframes answersSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.answer-button{-webkit-tap-highlight-color:transparent;align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 2px #0000000d;color:#334155;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.875rem;min-height:60px;padding:1.125rem 1.25rem;position:relative;text-align:left;touch-action:manipulation;transition:all .2s ease;-webkit-user-select:none;user-select:none}.answer-button:hover:not(.disabled){border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.answer-button:active:not(.disabled){background:#f8fafc;transform:translateY(0)}.answer-letter{align-items:center;border-radius:6px;display:flex;flex-shrink:0;font-size:.875rem;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;width:32px}.answer-text{flex:1 1;line-height:1.4;word-break:break-word}.answer-icon{flex-shrink:0;font-size:1.25rem;margin-left:auto}.answer-button.answer-1 .answer-letter{background:#fef3c7;color:#92400e}.answer-button.answer-2 .answer-letter{background:#dbeafe;color:#1e40af}.answer-button.answer-3 .answer-letter{background:#d1fae5;color:#065f46}.answer-button.answer-4 .answer-letter{background:#f3e8ff;color:#6b21a8}.answer-button.correct{background:#d1fae5;border-color:#10b981;color:#065f46}.answer-button.correct .answer-letter{background:#10b981;color:#fff}.answer-button.incorrect{animation:shake .4s ease;background:#fee2e2;border-color:#ef4444;color:#991b1b}.answer-button.incorrect .answer-letter{background:#ef4444;color:#fff}.answer-button.show-correct{background:#d1fae5;border-color:#10b981;color:#065f46}.answer-button.show-correct .answer-letter{background:#10b981;color:#fff}.answer-button.locked{animation:pulse 1.5s ease-in-out infinite;background:#e0e7ff;border-color:#6366f1;color:#3730a3}.answer-button.locked .answer-letter{background:#6366f1;color:#fff}.answer-button.disabled{cursor:not-allowed}.quiz-feedback{animation:fadeIn .3s ease;flex:1 1;flex-direction:column;gap:2rem;margin:0 auto;max-width:600px;padding:2rem 1.5rem}.feedback-animation,.quiz-feedback{align-items:center;display:flex;justify-content:center}.feedback-animation{background:#fff;border-radius:50%;box-shadow:0 4px 6px -1px #0000001a;height:100px;width:100px}.success-animation{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.success-circle{border:3px solid #10b981;border-radius:50%;height:100%;position:absolute;width:100%}.feedback-icon{font-size:3rem;z-index:1}.feedback-title{color:#0f172a;font-size:2rem;font-weight:700;margin:0;text-align:center}.quiz-feedback.correct .feedback-title{color:#10b981}.quiz-feedback.incorrect .feedback-title{color:#ef4444}.feedback-message{color:#64748b;font-size:1.125rem;margin:0;text-align:center}.correct-answer-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;padding:1.5rem 2rem;text-align:center;width:100%}.correct-answer-label{color:#64748b;font-weight:500;margin:0 0 .5rem}.correct-answer-text{color:#0f172a;font-size:1.25rem;font-weight:600;margin:0}.feedback-buttons{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.feedback-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.875rem 1.5rem;transition:all .2s ease}.feedback-button:hover{transform:translateY(-2px)}.feedback-button:active{transform:translateY(0)}.feedback-button.reveal{background:#6366f1;box-shadow:0 4px 6px -1px #6366f14d;color:#fff}.feedback-button.reveal:hover{background:#4f46e5}.feedback-button.extra-time{background:#f59e0b;box-shadow:0 4px 6px -1px #f59e0b4d;color:#fff}.feedback-button.extra-time:hover{background:#d97706}.next-button{align-items:center;background:#6366f1;border:none;border-radius:8px;box-shadow:0 4px 6px -1px #6366f14d;color:#fff;cursor:pointer;display:flex;font-size:1.125rem;font-weight:600;gap:.75rem;justify-content:center;min-width:180px;padding:1rem 2rem;transition:all .2s ease}.next-button:hover{background:#4f46e5;transform:translateY(-2px)}.next-button:active{transform:translateY(0)}.next-arrow{font-size:1.25rem;transition:transform .2s ease}.next-button:hover .next-arrow{transform:translateX(3px)}.pause-overlay{animation:fadeIn .2s ease;background:#00000080;height:100%;width:100%}.pause-modal{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a;max-width:380px;padding:2.5rem 2rem;text-align:center;width:90%}.pause-icon-large{font-size:3rem;margin-bottom:1rem}.pause-title{color:#0f172a;font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.pause-subtitle{color:#64748b;font-size:1rem;margin:0 0 2rem}.pause-buttons{display:flex;flex-direction:column;gap:.625rem}.pause-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.625rem;justify-content:center;padding:.875rem 1.25rem;transition:all .2s ease}.pause-btn:hover{transform:translateY(-1px)}.pause-btn:active{transform:translateY(0)}.pause-btn.resume{background:#10b981;box-shadow:0 2px 4px #10b98133;color:#fff}.pause-btn.resume:hover{background:#059669}.pause-btn.retry{background:#f59e0b;box-shadow:0 2px 4px #f59e0b33;color:#fff}.pause-btn.retry:hover{background:#d97706}.pause-btn.quit{background:#ef4444;box-shadow:0 2px 4px #ef444433;color:#fff}.pause-btn.quit:hover{background:#dc2626}.btn-icon{font-size:1.125rem}.quiz-page.final{background:linear-gradient(180deg,#f8fafc,#e2e8f0)}.final-screen{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:2rem;justify-content:center;margin:0 auto;max-width:700px;padding:2rem 1.5rem;width:100%}.final-header{animation:fadeIn .4s ease;text-align:center}.final-emoji{font-size:4rem;margin-bottom:1rem}.final-message{color:#0f172a;font-size:2rem;font-weight:700;margin:0}.final-score-card{align-items:center;animation:slideUp .4s ease .1s both;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;display:flex;flex-direction:column;gap:1.5rem;padding:2.5rem 2rem;width:100%}.score-circle{height:160px;position:relative;width:160px}.score-circle svg{transform:rotate(-90deg)}.score-circle-bg{fill:none;stroke:#e2e8f0;stroke-width:10}.score-circle-progress{fill:none;stroke:#6366f1;stroke-width:10;stroke-linecap:round;transition:stroke-dasharray 1.5s ease}.score-content{align-items:baseline;display:flex;gap:.25rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.score-number{color:#0f172a;font-size:2.5rem;font-weight:700}.score-divider,.score-total{color:#94a3b8;font-size:1.75rem}.star-rating{display:flex;gap:.375rem}.star{font-size:1.75rem}.new-record{animation:slideUp .3s ease}.record-badge{background:#fef3c7;border:2px solid #fde68a;border-radius:8px;color:#92400e;display:inline-block;font-size:1rem;font-weight:600;padding:.625rem 1.25rem}.final-actions{grid-gap:.75rem;animation:fadeIn .4s ease .3s both;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr);width:100%}.final-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 1.25rem;transition:all .2s ease}.final-btn:hover{transform:translateY(-2px)}.final-btn:active{transform:translateY(0)}.final-btn.primary{background:#6366f1;box-shadow:0 2px 4px #6366f14d;color:#fff}.final-btn.primary:hover{background:#4f46e5}.final-btn.secondary{background:#10b981;box-shadow:0 2px 4px #10b9814d;color:#fff}.final-btn.secondary:hover{background:#059669}.final-btn.tertiary{background:#fff;border:1.5px solid #e2e8f0;box-shadow:0 1px 2px #0000000d;color:#334155}.final-btn.tertiary:hover{background:#f8fafc;border-color:#cbd5e1}.final-btn.outline{background:#fff;border:1.5px solid #e2e8f0;box-shadow:0 1px 2px #0000000d;color:#334155}.final-btn.outline:hover{background:#f8fafc;border-color:#cbd5e1}.confetti-container{height:100%;left:0;overflow:hidden;pointer-events:none;position:fixed;top:0;width:100%;z-index:1}.confetti-piece{animation:confettiFall 3s linear infinite;height:8px;opacity:0;position:absolute;top:-10px;width:8px}.confetti-piece:nth-child(odd){background:#fbbf24}.confetti-piece:nth-child(2n){background:#a78bfa}.confetti-piece:nth-child(3n){background:#60a5fa}.confetti-piece:nth-child(5n){background:#34d399}.confetti-piece:first-child{animation-delay:0s;left:10%}.confetti-piece:nth-child(2){animation-delay:.2s;left:20%}.confetti-piece:nth-child(3){animation-delay:.4s;left:30%}.confetti-piece:nth-child(4){animation-delay:.6s;left:40%}.confetti-piece:nth-child(5){animation-delay:.8s;left:50%}.confetti-piece:nth-child(6){animation-delay:1s;left:60%}.confetti-piece:nth-child(7){animation-delay:1.2s;left:70%}.confetti-piece:nth-child(8){animation-delay:1.4s;left:80%}.confetti-piece:nth-child(9){animation-delay:1.6s;left:90%}.confetti-piece:nth-child(10){animation-delay:1.8s;left:15%}@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0deg)}to{opacity:0;transform:translateY(100vh) rotate(1turn)}}@media (max-width:768px){.quiz-header{gap:1rem;padding:1rem 1.25rem}.progress-container{gap:.5rem}.high-score-badge,.progress-text{font-size:.8125rem}.high-score-badge{padding:.4rem .75rem;right:1.25rem;top:4.75rem}.quiz-content{gap:2rem;padding:1.75rem 1.25rem}.timer-circle{height:70px;width:70px}.timer-text{font-size:1.25rem}.timer-ring{height:70px;width:70px}.question-card{padding:2rem 1.75rem}.question-text{font-size:1.25rem}.answer-grid{gap:.75rem;grid-template-columns:1fr}.answer-button{font-size:.9375rem;padding:1rem}.answer-letter{font-size:.8125rem;height:30px;width:30px}.feedback-title{font-size:1.75rem}.feedback-icon{font-size:2.5rem}.final-emoji{font-size:3.5rem}.final-message{font-size:1.75rem}.score-circle{height:140px;width:140px}.score-number{font-size:2.25rem}.final-actions{grid-template-columns:1fr}}@media (max-width:480px){.quiz-header{gap:.5rem;padding:.875rem .75rem}.pause-button{flex-shrink:0;height:36px;width:36px}.pause-button svg{height:16px;width:16px}.progress-container{flex:1 1;gap:.5rem;min-width:0}.progress-text{font-size:.75rem}.progress-bar{height:6px}.score-display{flex-shrink:0;padding:.4rem .75rem}.score-icon{font-size:1rem}.score-text{font-size:.9375rem}.high-score-badge{font-size:.75rem;gap:.375rem;padding:.35rem .625rem;right:.75rem;top:4.5rem}.trophy-icon{font-size:1rem}.quiz-content{gap:1.75rem;padding:1.5rem .875rem}.timer-circle,.timer-ring{height:70px;width:70px}.timer-text{font-size:1.25rem}.question-card{max-width:calc(100vw - 1.75rem);padding:1.5rem 1.25rem;width:100%}.question-number{font-size:.75rem;margin-bottom:1rem;padding:.35rem .75rem}.question-text{font-size:1.0625rem;line-height:1.6}.answer-grid{gap:.75rem;max-width:calc(100vw - 1.75rem);width:100%}.answer-button{font-size:.9375rem;gap:.75rem;min-height:56px;padding:.875rem 1rem}.answer-letter{font-size:.8125rem;height:32px;width:32px}.answer-icon{font-size:1.125rem}.quiz-feedback{gap:1.75rem;padding:2rem 1rem}.feedback-animation{height:90px;width:90px}.feedback-icon{font-size:2.5rem}.feedback-title{font-size:1.625rem}.feedback-message{font-size:1rem}.correct-answer-card{padding:1.25rem 1.5rem;width:100%}.correct-answer-label{font-size:.8125rem}.correct-answer-text{font-size:1.125rem}.feedback-buttons{gap:.625rem;width:100%}.feedback-button{font-size:.9375rem;max-width:300px;padding:.875rem 1.5rem;width:100%}.next-button{font-size:1.0625rem;min-width:180px;padding:1rem 2rem}.pause-modal{padding:2.25rem 1.75rem;width:92%}.pause-icon-large{font-size:2.75rem}.pause-title{font-size:1.625rem}.pause-subtitle{font-size:.9375rem}.pause-buttons{gap:.75rem}.pause-btn{font-size:1rem;padding:1rem 1.5rem}.final-screen{gap:1.75rem;padding:2rem 1rem}.final-emoji{font-size:3.5rem}.final-message{font-size:1.625rem}.final-score-card{gap:1.25rem;padding:2rem 1.5rem;width:100%}.score-circle{height:140px;width:140px}.score-number{font-size:2.25rem}.score-divider,.score-total{font-size:1.625rem}.star-rating{gap:.5rem}.star{font-size:1.625rem}.record-badge{font-size:.9375rem;padding:.625rem 1.125rem}.final-actions{gap:.875rem;width:100%}.final-btn{font-size:.9375rem;padding:1rem 1.25rem}}@media (max-width:375px){.quiz-header{padding:.75rem .625rem}.pause-button{flex-shrink:0;height:34px;width:34px}.progress-container{min-width:0}.progress-text{font-size:.6875rem}.score-display{padding:.35rem .625rem}.score-text{font-size:.875rem}.high-score-badge{font-size:.6875rem;padding:.3rem .5rem;right:.625rem;top:4rem}.quiz-content{gap:1.5rem;padding:1.25rem .75rem}.timer-circle,.timer-ring{height:64px;width:64px}.timer-text{font-size:1.125rem}.question-card{max-width:calc(100vw - 1.5rem);padding:1.25rem 1rem}.question-text{font-size:1rem}.answer-grid{max-width:calc(100vw - 1.5rem)}.answer-button{font-size:.875rem;min-height:54px;padding:.75rem .875rem}.answer-letter{font-size:.75rem;height:28px;width:28px}.feedback-title{font-size:1.5rem}.correct-answer-text{font-size:1.0625rem}.next-button{font-size:1rem;padding:.875rem 1.75rem}.pause-modal{padding:2rem 1.5rem}.pause-title{font-size:1.5rem}.final-emoji{font-size:3rem}.final-message{font-size:1.5rem}.score-circle{height:130px;width:130px}.score-number{font-size:2rem}.final-btn{font-size:.875rem;padding:.875rem 1rem}}.toast-container{align-items:center;background:#323232;border-radius:4px;box-shadow:0 2px 6px #0003;color:#fff;display:flex;min-width:200px;padding:12px 16px;right:20px;top:20px;z-index:9999}.toast-container.info{background-color:#3b82f6}.toast-container.success{background-color:#10b981}.toast-container.error{background-color:#ef4444}.toast-close{background:none;border:none;color:#fff;cursor:pointer;font-size:1.1rem;line-height:1;margin-left:8px}.toast-message{flex:1 1}.reset-overlay{align-items:center;background-color:#000000bf;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.reset-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:420px;padding:2rem;position:relative;text-align:center;width:100%}.reset-form{display:flex;flex-direction:column;gap:1rem}.input-group{margin-bottom:1rem}.input-with-icon{align-items:center;display:flex;position:relative}.input-icon{color:#9ca3af;font-size:1.2rem;left:.75rem;position:absolute}.auth-input{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;padding:.75rem .75rem .75rem 2.5rem;transition:border-color .2s;width:100%}.auth-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.auth-button{background-color:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem;transition:background-color .2s;width:100%}.auth-button:hover{background-color:#4338ca}.message{border-radius:8px;font-size:.875rem;margin-bottom:1rem;padding:.75rem;text-align:center}.message.error{background-color:#fee2e2;color:#dc2626}.pricing-page-container{background:linear-gradient(180deg,#f8fafc 0,#fff);min-height:100vh;padding:90px 1.5rem 2rem}.pricing-header{margin-bottom:1rem;text-align:center}.pricing-title{color:#1e293b;font-size:2rem;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin-bottom:.5rem}.pricing-subtitle{color:#64748b;font-size:1.0625rem;font-weight:400;line-height:1.5;margin:0 auto;max-width:420px}.feature-item.subtle-text{padding-bottom:.25rem;padding-left:1.75rem;padding-top:0}.tool-list{color:#94a3b8;font-size:.75rem;font-style:italic;line-height:1.4}.current-plan-indicator{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:100px;box-shadow:0 4px 12px #667eea4d;display:inline-flex;gap:.5rem;margin-top:1rem;padding:.5rem 1rem}.current-plan-label{color:#ffffffe6;font-size:.875rem;font-weight:500}.current-plan-name{color:#fff;font-size:.875rem;font-weight:700;text-transform:capitalize}.cancel-badge{background:#fbbf2433;border-radius:12px;color:#fbbf24;font-size:.75rem;font-weight:600;padding:.15rem .5rem}.billing-toggle{background:#f8fafc;border:1px solid #e2e8f0;border-radius:100px;box-shadow:0 1px 3px #0000000f;display:flex;gap:0;justify-content:center;margin:0 auto 1rem;max-width:320px;padding:4px}.toggle-btn{background:#0000;border:none;border-radius:100px;color:#64748b;cursor:pointer;flex:1 1;font-size:.8125rem;font-weight:600;padding:.625rem 1.25rem;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.toggle-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d;color:#fff}.toggle-btn .save-badge{background:#10b981;border-radius:20px;color:#fff;display:inline-block;font-size:.625rem;font-weight:700;margin-left:.375rem;padding:.15rem .45rem;vertical-align:middle}.plans-container{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin:0 auto 1rem;max-width:1200px;padding:0 .5rem}.plans-container.two-plans{gap:1.5rem;grid-template-columns:repeat(2,1fr);max-width:900px}.plan-card{background:#fff;border-radius:16px;display:flex;flex-direction:column;min-height:500px;padding:1.5rem 1.25rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.plan-card:hover{transform:translateY(-2px)}.free-card{background:#f8fafc;border:1px solid #e2e8f0;box-shadow:none}.free-card:hover{border-color:#cbd5e1}.basic-card,.free-card:hover{box-shadow:0 2px 8px #0000000a}.basic-card{background:#fff;border:1.5px solid #e2e8f0}.basic-card:hover{border-color:#cbd5e1;box-shadow:0 4px 16px #0000000f}.premium-card{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#667eea,#764ba2) border-box;border:2px solid #0000;box-shadow:0 8px 24px #667eea26;position:relative}.premium-card:hover{box-shadow:0 12px 32px #667eea40}.popular-badge{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea66;z-index:1}.current-plan-badge,.popular-badge{border-radius:100px;color:#fff;font-size:.625rem;font-weight:700;left:50%;letter-spacing:.5px;padding:.3rem 1rem;position:absolute;text-transform:uppercase;top:-10px;transform:translateX(-50%)}.current-plan-badge{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;z-index:10}.plan-header{margin-bottom:.75rem;text-align:center}.plan-header h2{color:#0f172a;font-size:1.5rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.25rem}.premium-card .plan-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text}.plan-tagline{color:#64748b;font-size:.8125rem;line-height:1.4;margin:0}.price-section{border-bottom:none;margin-bottom:1rem;padding-bottom:0;text-align:center}.price{align-items:baseline;display:flex;justify-content:center;margin-bottom:.125rem}.currency{font-size:1.125rem;margin-right:.125rem}.amount,.currency{color:#0f172a;font-weight:700}.amount{font-feature-settings:"tnum" 1;font-size:2.5rem;letter-spacing:-.02em;line-height:1}.premium-card .amount,.premium-card .currency{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text}.period{color:#64748b;font-size:.8125rem;font-weight:600;margin-left:.125rem}.billing-info{color:#94a3b8;font-size:.6875rem;font-weight:500;margin:0}.plan-features{flex-grow:1;padding:0 0 1rem}.features-section,.plan-features{display:flex;flex-direction:column;gap:0;margin:0}.features-section{padding:0}.section-label{color:#94a3b8;font-size:.6875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.625rem;margin-top:0;text-transform:uppercase}.feature-item{align-items:flex-start;color:#475569;display:flex;font-size:.875rem;gap:.625rem;line-height:1.5;padding:.5rem 0}.feature-item svg{flex-shrink:0;height:18px;margin-top:.125rem;width:18px}.feature-item span{flex:1 1}.icon-check{color:#10b981}.icon-x{color:#94a3b8}.icon-star{color:#fbbf24}.basic-card .features-not-included{margin:0 0 .75rem;padding:0}.basic-card .features-not-included .feature-item{opacity:.5}.basic-card .features-not-included .feature-item span{color:#64748b;text-decoration:line-through}.basic-card .features-included{margin:0;padding:0}.premium-card .premium-highlights{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid #667eea1a;border-radius:10px;margin:0 0 .75rem;padding:.75rem}.premium-card .premium-highlights .premium-feature{padding:.5rem 0}.premium-card .premium-highlights .premium-feature span{color:#0f172a;font-size:.875rem;font-weight:500;line-height:1.6}.premium-card .premium-highlights .premium-feature span strong{color:#0f172a;font-weight:600}.premium-card .premium-highlights .premium-feature .icon-star{color:#667eea}.premium-card .features-included{margin:0;padding:0}.premium-card .features-included .icon-check{color:#667eea}.features-divider{background:linear-gradient(90deg,#0000,#e2e8f0,#0000);height:1px;margin:.5rem 0}.cta-button{align-items:center!important;border:none!important;border-radius:8px!important;cursor:pointer!important;display:flex!important;font-size:1rem!important;font-weight:600!important;justify-content:center!important;line-height:1.5!important;margin-top:auto!important;padding:.875rem 1.75rem!important;text-align:center!important;transition:all .2s ease!important;width:100%!important}.free-button{background:#0000!important;border:1.5px solid #cbd5e1!important;box-shadow:none!important;color:#64748b!important}.free-button:hover:not(:disabled){background:#f8fafc!important;border-color:#94a3b8!important;color:#475569!important}.basic-button{background:#fff!important;border:2px solid #e2e8f0!important;box-shadow:0 1px 3px #00000014!important;color:#0f172a!important}.basic-button:hover:not(:disabled){background:#f8fafc!important;border-color:#cbd5e1!important;box-shadow:0 2px 8px #0000001f!important;transform:translateY(-1px)!important}.premium-button{background:linear-gradient(135deg,#667eea,#764ba2)!important;border:2px solid #0000!important;box-shadow:0 2px 10px #667eea40!important;color:#fff!important}.premium-button:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a4091)!important;box-shadow:0 4px 16px #667eea59!important;transform:translateY(-1px)!important}.cta-button:disabled{cursor:not-allowed!important;opacity:.5!important}.faq-section{margin:0 auto;max-width:700px;padding:3rem 1rem 2.5rem}.faq-section h3{color:#0f172a;font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem;text-align:center}.faq-accordion{background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:0;overflow:hidden}.faq-accordion-item{border-bottom:1px solid #e2e8f0}.faq-accordion-item:last-child{border-bottom:none}.faq-accordion-header{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;justify-content:space-between;padding:1rem 1.25rem;text-align:left;transition:background-color .2s ease;width:100%}.faq-accordion-header:hover{background:#f8fafc}.faq-question{color:#0f172a;flex:1 1;font-size:.9375rem;font-weight:600;line-height:1.4;padding-right:1rem}.faq-chevron{color:#94a3b8;flex-shrink:0;height:20px;transition:transform .25s ease;width:20px}.faq-accordion-item.open .faq-chevron{color:#667eea;transform:rotate(180deg)}.faq-accordion-content{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}.faq-accordion-item.open .faq-accordion-content{max-height:200px}.faq-accordion-content p{color:#64748b;font-size:.875rem;line-height:1.6;margin:0;padding:0 1.25rem 1rem}.support-section{margin:2rem auto 0;max-width:950px;padding:0 1rem}.support-content{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 6px 20px #667eea40;overflow:hidden;padding:2.5rem 2rem;position:relative;text-align:center}.support-content:before{background:#ffffff14;border-radius:50%;content:"";filter:blur(60px);height:250px;position:absolute;right:-10%;top:-50%;width:250px}.support-content h3{color:#fff;font-size:1.875rem;font-weight:700;letter-spacing:-.015em;line-height:1.3;margin-bottom:.875rem;position:relative;z-index:1}.support-content p{color:#ffffffeb;font-size:1rem;font-weight:400;line-height:1.6;margin:0 auto 1.75rem;max-width:680px;position:relative;z-index:1}.support-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;position:relative;z-index:1}.support-btn,.support-btn-secondary{border:none;border-radius:10px;cursor:pointer;font-size:.9375rem;font-weight:700;letter-spacing:.5px;padding:.875rem 2rem;text-transform:uppercase;transition:all .25s cubic-bezier(.4,0,.2,1)}.support-btn{background:#fff;box-shadow:0 3px 12px #00000026;color:#667eea}.support-btn:hover{box-shadow:0 6px 16px #0003;transform:translateY(-2px)}.support-btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #ffffff4d;color:#fff}.support-btn-secondary:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-2px)}@media (max-width:968px){.plans-container{gap:1.25rem;grid-template-columns:1fr;margin:0 auto 1.5rem;max-width:450px}}@media (max-width:768px){.pricing-page-container{padding:75px 1rem 2rem}.pricing-header{margin-bottom:1rem}.pricing-title{font-size:1.5rem;font-weight:600}.pricing-subtitle{font-size:.9375rem}.tool-list{font-size:.6875rem}.faq-section{padding:2rem 1rem}.faq-section h3{font-size:1.5rem;margin-bottom:1rem}.faq-accordion-header{padding:.875rem 1rem}.faq-question{font-size:.875rem}.faq-accordion-content p{font-size:.8125rem;padding:0 1rem .875rem}.billing-toggle{margin-bottom:1rem;max-width:300px}.toggle-btn{font-size:.75rem;padding:.5rem 1rem}.toggle-btn .save-badge{font-size:.5625rem;padding:.125rem .375rem}.plans-container{gap:1rem;margin-bottom:1.5rem}.plan-card{min-height:auto;padding:1.25rem 1rem}.plan-header{margin-bottom:.5rem}.plan-header h2{font-size:1.25rem;margin-bottom:.125rem}.plan-tagline{font-size:.75rem;line-height:1.3}.price-section{margin-bottom:.75rem;padding-bottom:.75rem}.amount{font-size:2rem}.currency{font-size:1rem}.period{font-size:.75rem}.billing-info{font-size:.6875rem}.popular-badge{font-size:.5625rem;padding:.3rem .875rem;top:-9px}.basic-card .features-not-included .feature-item:nth-child(n+4),.features-included .feature-item:nth-child(n+5),.premium-card .premium-highlights .premium-feature:nth-child(n+4),.section-label{display:none}.feature-item{font-size:.8125rem;gap:.5rem;line-height:1.4;padding:.375rem 0}.feature-item svg{height:15px;width:15px}.premium-card .premium-highlights{margin-bottom:.5rem;padding:.625rem}.premium-card .premium-highlights .premium-feature{padding:.375rem 0}.premium-card .premium-highlights .premium-feature span{font-size:.8125rem;line-height:1.4}.features-divider{margin:.375rem 0}.plan-features{padding-bottom:.75rem}.basic-card .features-not-included{margin-bottom:.5rem}.cta-button{font-size:.9375rem!important;padding:.75rem 1.5rem!important}.support-section{margin-top:1.25rem}.support-content{padding:1.75rem 1.25rem}.support-content h3{font-size:1.25rem}.support-content p{font-size:.8125rem;margin-bottom:1.25rem}.support-actions{flex-direction:column}.support-btn,.support-btn-secondary{font-size:.875rem;max-width:280px;padding:.75rem 1.5rem;width:100%}}@media (max-width:480px){.pricing-page-container{padding:80px 1rem 2.5rem}.pricing-header{margin-bottom:1.5rem}.pricing-title{font-size:1.375rem;font-weight:600}.pricing-subtitle{font-size:.875rem}.billing-toggle{margin-bottom:1.75rem;max-width:280px}.toggle-btn{font-size:.8125rem;padding:.625rem 1rem}.toggle-btn .save-badge{font-size:.5625rem;padding:.125rem .375rem}.plan-card{padding:1.5rem 1.25rem}.plan-header{margin-bottom:1.25rem}.plan-header h2{font-size:1.375rem}.plan-tagline{font-size:.75rem}.price-section{margin-bottom:1.5rem;padding-bottom:1.5rem}.amount{font-size:2.5rem}.currency{font-size:1.25rem}.period{font-size:.875rem}.billing-info{font-size:.75rem}.popular-badge{font-size:.625rem;padding:.35rem 1rem;top:-11px}.feature-item{font-size:.75rem;gap:.625rem;padding:.5rem}.feature-item svg{height:15px;width:15px}.section-label{font-size:.625rem}.premium-card .premium-highlights .premium-feature{padding:.75rem .625rem}.premium-card .premium-highlights .premium-feature span{font-size:.8125rem}.cta-button{font-size:.875rem;margin-top:1.25rem;padding:.75rem 1.5rem}.faq-section{padding:2rem .75rem 1.5rem}.faq-section h3{font-size:1.375rem;margin-bottom:1rem}.faq-accordion-header{padding:.75rem 1rem}.faq-question{font-size:.8125rem}.faq-chevron{height:18px;width:18px}.faq-accordion-content p{font-size:.75rem;padding:0 1rem .75rem}.support-section{margin-top:1.25rem}.support-content{border-radius:12px;padding:2rem 1.25rem}.support-content h3{font-size:1.25rem;margin-bottom:.625rem}.support-content p{font-size:.8125rem;margin-bottom:1.25rem}.support-btn,.support-btn-secondary{font-size:.875rem;padding:.75rem 1.5rem}}.privacy-policy-container{background:#fff;margin:0 auto;max-width:720px;padding:3rem 2rem 4rem}.privacy-policy-container h1{color:#1e293b;font-size:2.25rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .5rem}.privacy-policy-container .last-updated{color:#94a3b8;font-size:.875rem;margin:0 0 2.5rem}.privacy-policy-container h2{color:#1e293b;font-size:1.25rem;font-weight:600;margin:2rem 0 .75rem;padding-top:1rem}.privacy-policy-container h2:first-of-type{margin-top:0;padding-top:0}.privacy-policy-container h3{color:#475569;font-size:1rem;font-weight:600;margin:1.25rem 0 .5rem}.privacy-policy-container p{color:#64748b;font-size:.9375rem;line-height:1.7;margin:0 0 1rem}.privacy-policy-container a{color:#3b82f6;font-weight:500;text-decoration:none}.privacy-policy-container a:hover{text-decoration:underline}@media (max-width:768px){.privacy-policy-container{padding:2rem 1.5rem 3rem}.privacy-policy-container h1{font-size:1.75rem}.privacy-policy-container h2{font-size:1.125rem}.privacy-policy-container p{font-size:.875rem}}.contact-page{background:#f0f9ff;min-height:100vh;padding:6rem 1rem 3rem}.contact-container{margin:0 auto;max-width:1200px}.contact-header{margin-bottom:3rem;text-align:center}.contact-header h1{color:#1e293b;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.contact-header p{color:#64748b;font-size:1.1rem;line-height:1.6}.contact-content{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr 1.5fr}.contact-info{display:flex;flex-direction:column;gap:1.5rem}.info-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:1.5rem;transition:all .2s ease}.info-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.info-icon{font-size:2rem;margin-bottom:.5rem}.info-card h3{color:#1e293b;font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.info-card p{color:#3b82f6;font-weight:500;margin-bottom:.25rem}.info-card span{color:#64748b;font-size:.9rem}.social-links{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.social-links a{color:#3b82f6;font-weight:500;text-decoration:none;transition:color .2s}.social-links a:hover{color:#2563eb;text-decoration:underline}.contact-form{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#1e293b;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group textarea{border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group textarea{font-family:inherit;resize:vertical}.submit-button{background:#3b82f6;border:none;border-radius:8px;box-shadow:0 2px 4px #3b82f633;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem;transition:all .2s ease;width:100%}.submit-button:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width:968px){.contact-content{grid-template-columns:1fr}.contact-header h1{font-size:2rem}}@media (max-width:576px){.contact-page{padding:5rem 1rem 2rem}.contact-form{padding:1.5rem}}.about-page{background:#fff;min-height:100vh;padding:6rem 0 0}.about-container{margin:0 auto;max-width:900px;padding:0 4rem}.about-hero{border-bottom:1px solid #f1f5f9;padding:3rem 0 5rem;text-align:center}.about-hero h1{color:#0f172a;font-size:3.5rem;font-weight:900;letter-spacing:-.02em;line-height:1.2;margin-bottom:1.5rem}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;padding-bottom:.1em}.hero-lead{color:#64748b;font-size:1.375rem;font-weight:400;line-height:1.6}.about-content{padding:4rem 0 2rem}.content-section{margin-bottom:5rem}.content-section h2{color:#0f172a;font-size:2.25rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.content-section p{color:#475569;font-size:1.0625rem;line-height:1.8;margin-bottom:1.25rem}.highlight-section{background:linear-gradient(135deg,#f8fafc,#fff);border:2px solid #e2e8f0;border-radius:20px;margin:5rem -3rem;padding:3rem}.highlight-content h2{margin-bottom:2rem}.approach-grid{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:repeat(3,1fr);margin-top:2.5rem}.approach-item{position:relative}.approach-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:900;line-height:1;margin-bottom:1rem;opacity:.15}.approach-item h3{color:#0f172a;font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.approach-item p{color:#64748b;font-size:.9375rem;line-height:1.7;margin:0}.values-intro{color:#64748b;font-size:1.0625rem;font-style:italic;margin-bottom:2.5rem}.values-list{display:flex;flex-direction:column;gap:2.5rem}.value-item{border-image:linear-gradient(180deg,#3b82f6,#8b5cf6);border-image-slice:1;border-left:3px solid #0000;padding-left:2rem;transition:all .3s ease}.value-item:hover{padding-left:2.5rem}.value-item h3{color:#0f172a;font-size:1.375rem;font-weight:700;margin-bottom:.75rem}.value-item p{color:#64748b;font-size:1rem;line-height:1.8;margin:0}.team-section{background:linear-gradient(135deg,#f8fafc,#fff);border:2px solid #e2e8f0;border-radius:20px;padding:3rem}.team-section h2{margin-bottom:2rem}.team-section p{color:#475569}.about-cta{border-top:1px solid #f1f5f9;margin-top:3rem;padding:5rem 0 6rem;text-align:center}.about-cta h2{color:#0f172a;font-size:2.5rem;font-weight:900;letter-spacing:-.02em;margin-bottom:1rem}.about-cta p{color:#64748b;font-size:1.125rem;margin-bottom:2.5rem}.cta-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:70px;box-shadow:0 8px 24px #3b82f64d;color:#fff;cursor:pointer;display:inline-flex;font-size:1.125rem;font-weight:700;padding:1.25rem 3.5rem;transition:all .4s cubic-bezier(.16,1,.3,1)}.cta-button:hover{box-shadow:0 12px 32px #3b82f666;transform:translateY(-4px) scale(1.02)}@media (max-width:768px){.about-container{padding:0 2rem}.about-hero{padding:2rem 0 3rem}.about-hero h1{font-size:2.5rem}.hero-lead{font-size:1.125rem}.about-content{padding:3rem 0 1rem}.content-section{margin-bottom:3.5rem}.content-section h2{font-size:1.875rem}.content-section p{font-size:1rem}.highlight-section,.team-section{margin-left:-2rem;margin-right:-2rem;padding:2rem}.approach-grid{gap:2rem;grid-template-columns:1fr}.approach-number{font-size:2.5rem}.value-item{padding-left:1.5rem}.value-item:hover{padding-left:2rem}.about-cta{padding:4rem 0 5rem}.about-cta h2{font-size:2rem}.about-cta p{font-size:1rem}}@media (max-width:480px){.about-container{padding:0 1.5rem}.about-hero{padding:1.5rem 0 2.5rem}.about-hero h1{font-size:2rem}.hero-lead{font-size:1rem}.about-content{padding:2.5rem 0 1rem}.content-section{margin-bottom:3rem}.content-section h2{font-size:1.625rem}.content-section p,.values-intro{font-size:.9375rem}.highlight-section,.team-section{border-radius:16px;margin-left:-1.5rem;margin-right:-1.5rem;padding:1.5rem}.approach-item h3,.value-item h3{font-size:1.125rem}.approach-item p,.value-item p{font-size:.875rem}.values-list{gap:2rem}.about-cta{padding:3rem 0 4rem}.about-cta h2{font-size:1.75rem}.about-cta p{font-size:.9375rem;margin-bottom:2rem}.cta-button{font-size:1rem;padding:1.125rem 2.5rem}}.multiplayer-page{align-items:center;background:linear-gradient(180deg,#f8fafc,#e2e8f0);display:flex;justify-content:center;min-height:100vh;overflow-x:hidden;padding:2rem 1rem}.multiplayer-leaderboard,.multiplayer-leaderboard-final{margin:2rem auto;max-width:600px;padding:1rem;width:100%}.multiplayer-leaderboard-final h3{color:#1e293b;font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.leaderboard-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;gap:1rem;margin-bottom:.75rem;padding:1rem;transition:transform .2s ease}.leaderboard-item.highlight{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;transform:scale(1.02)}.leaderboard-item .rank{color:#64748b;font-size:1.5rem;font-weight:700;min-width:50px;text-align:center}.leaderboard-item .player-info{flex:1 1}.leaderboard-item .name{color:#1e293b;font-size:1.125rem;font-weight:600;overflow-wrap:break-word;word-break:break-word}.leaderboard-item .stats{color:#64748b;font-size:.875rem;margin-top:.25rem}.leaderboard-item .streak,.leaderboard-item .trophy{font-size:1.5rem}.leaderboard-title{color:#1e293b;font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}.leaderboard-subtitle{color:#64748b;font-size:1.125rem;margin-bottom:2rem;text-align:center}.next-question-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;color:#fff;cursor:pointer;display:block;font-size:1.125rem;font-weight:600;margin:2rem auto 0;max-width:400px;padding:1rem 2rem;transition:transform .2s ease,box-shadow .2s ease;width:100%}.next-question-btn:hover{box-shadow:0 8px 16px #6366f14d;transform:translateY(-2px)}.waiting-text{color:#64748b;font-size:1.125rem;font-style:italic;margin-top:2rem;text-align:center}.correct-answer-display{animation:slideDown .4s ease;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;border-radius:12px;margin:0 auto 2rem;max-width:600px;padding:1.25rem 1.5rem;text-align:center}.correct-answer-label{color:#065f46;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.correct-answer-value{color:#047857;font-size:1.25rem;font-weight:700}.score-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-top:1.5rem;width:100%}.stat-item{background:#f8fafc;border-radius:12px;flex-direction:column;gap:.5rem;padding:1rem;transition:transform .2s ease}.stat-item:hover{transform:translateY(-2px)}.stat-emoji{font-size:1.75rem}.stat-label{font-size:.75rem;font-weight:600;letter-spacing:.05em}.stat-value{color:#1e293b;font-size:1.25rem;font-weight:700}.loading-screen{padding:4rem 2rem;text-align:center}.loading-screen h2{color:#1e293b;font-size:1.75rem;margin-bottom:1.5rem}.connection-status{gap:.5rem;justify-content:center}.status-indicator{font-size:1rem;font-weight:500}.status-indicator.connected{color:#10b981}.status-indicator.disconnected{color:#ef4444}.multiplayer-container{box-sizing:border-box;margin:0 auto;max-width:1200px;padding:0 .5rem;width:100%}.multiplayer-hero{animation:fadeIn .6s ease;margin-bottom:3rem;text-align:center}.multiplayer-hero h1{color:#1e293b;font-size:3rem;font-weight:800;margin-bottom:.5rem}.multiplayer-hero .subtitle{color:#64748b;font-size:1.25rem}.action-cards{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:4rem}.action-card{animation:slideUp .6s ease;background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;padding:2.5rem;transition:transform .3s ease,box-shadow .3s ease}.action-card:hover{box-shadow:0 12px 24px #0000001a;transform:translateY(-8px)}.card-icon{font-size:3rem;margin-bottom:1rem}.action-card h2{color:#1e293b;font-size:1.75rem;font-weight:700;margin-bottom:.75rem}.action-card p{color:#64748b;line-height:1.6;margin-bottom:1.5rem}.features-list{list-style:none;margin:1.5rem 0 2rem;padding:0}.features-list li{color:#475569;padding:.5rem 0 .5rem 1.5rem;position:relative}.features-list li:before{color:#10b981;content:"✓";font-weight:700;left:0;position:absolute}.how-it-works{animation:fadeIn .8s ease;margin-top:4rem;text-align:center}.how-it-works h2{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:2.5rem}.steps{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.step{position:relative}.step-number{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:1.5rem;font-weight:700;height:60px;margin:0 auto 1rem;width:60px}.step h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.step p{color:#64748b;line-height:1.6}.multiplayer-card{animation:slideUp .5s ease;background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;margin:0 auto;max-width:600px;padding:2.5rem}.card-header{margin-bottom:2rem;text-align:center}.card-header h1{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:.5rem}.card-header p{color:#64748b}.create-room-form,.join-room-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{display:flex;flex-direction:column;gap:.5rem}.form-section label{align-items:center;color:#334155;display:flex;font-weight:600;justify-content:space-between}.setting-value{color:#6366f1;font-size:1.1rem;font-weight:700}.form-section input[type=email],.form-section input[type=text],.form-section select{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.875rem 1rem;transition:border-color .2s ease}.form-section input[type=email]:focus,.form-section input[type=text]:focus,.form-section select:focus{border-color:#6366f1;outline:none}.room-code-input{font-size:2rem!important;font-weight:700;letter-spacing:.3em;text-align:center;text-transform:uppercase}.form-section input[type=range]{-webkit-appearance:none;background:#e2e8f0;border-radius:5px;height:8px;outline:none;width:100%}.form-section input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#6366f1;border-radius:50%;cursor:pointer;height:20px;-webkit-transition:transform .2s ease;transition:transform .2s ease;width:20px}.form-section input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.form-section input[type=range]::-moz-range-thumb{background:#6366f1;border:none;border-radius:50%;cursor:pointer;height:20px;-moz-transition:transform .2s ease;transition:transform .2s ease;width:20px}.form-section input[type=range]::-moz-range-thumb:hover{transform:scale(1.2)}.checkbox-section{align-items:center;flex-direction:row}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-weight:500;gap:.75rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:20px;width:20px}.form-section small{color:#94a3b8;font-size:.875rem}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;text-align:center;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 8px 16px #6366f14d;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#f1f5f9;color:#475569}.btn-secondary:hover{background:#e2e8f0}.btn-lg{font-size:1.125rem;padding:1.125rem 2.5rem}.form-actions{display:flex;gap:1rem;margin-top:1rem}.form-actions button{flex:1 1}.lobby-container{margin:0 auto;max-width:900px}.lobby-header{align-items:center;animation:slideUp .4s ease;background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;display:flex;justify-content:space-between;margin-bottom:2rem;padding:2rem}.room-info h1{word-wrap:break-word;color:#1e293b;font-size:1.75rem;font-weight:700;-webkit-hyphens:auto;hyphens:auto;margin-bottom:1rem;overflow-wrap:break-word}.room-code-display{align-items:center;display:flex;gap:1rem}.room-code-display .label{color:#64748b;font-weight:500}.room-code-display .code{color:#6366f1;font-size:2rem;font-weight:800;letter-spacing:.2em}.copy-btn{background:#6366f1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:background .2s ease}.copy-btn:hover{background:#4f46e5}.connection-status{align-items:center;display:flex}.status-indicator{border-radius:20px;font-size:.875rem;font-weight:600;padding:.5rem 1rem}.status-indicator.connected{background:#dcfce7;color:#166534}.status-indicator.disconnected{background:#fee2e2;color:#991b1b}.game-info{grid-gap:1rem;animation:fadeIn .6s ease;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem}.info-item{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:1.25rem;text-align:center}.info-item .icon{display:block;font-size:1.5rem;margin-bottom:.5rem}.info-item span:last-child{color:#475569;font-weight:600}.players-section{animation:slideUp .6s ease;background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;margin-bottom:2rem;padding:2rem}.players-section h2{color:#1e293b;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.players-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.player-card{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:transform .2s ease,border-color .2s ease}.player-card:hover{border-color:#cbd5e1;transform:translateY(-2px)}.player-rank{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;width:40px}.player-info{flex:1 1}.player-name{align-items:center;color:#1e293b;display:flex;flex-wrap:wrap;font-weight:600;gap:.5rem;max-width:100%;word-break:break-word}.host-badge,.you-badge{border-radius:4px;font-size:.75rem;font-weight:700;padding:.125rem .5rem;text-transform:uppercase}.host-badge{background:#fef3c7;color:#92400e}.you-badge{background:#dbeafe;color:#1e40af}.lobby-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.waiting-message{animation:pulse 2s infinite;background:#fef3c7;border-radius:8px;color:#92400e;flex:1 1;font-weight:600;padding:1.125rem 2.5rem;text-align:center}.instructions{color:#64748b;line-height:1.8;text-align:center}.countdown-screen{animation:fadeIn .3s ease;text-align:center}.countdown-screen h1{color:#1e293b;font-size:2.5rem;font-weight:700;margin-bottom:2rem}.countdown-number{align-items:center;animation:countdownPulse 1s infinite;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:6rem;font-weight:800;height:200px;justify-content:center;margin:0 auto 2rem;width:200px}.countdown-screen p{color:#64748b;font-size:1.5rem}.error-banner,.error-message{background:#fee2e2;border-radius:8px;color:#991b1b;font-weight:600;padding:1rem;text-align:center}.error-banner{animation:shake .5s ease;margin-bottom:1.5rem}.loading{color:#64748b;font-size:1.25rem;padding:3rem;text-align:center}.no-quizzes{border-radius:8px;margin-top:.5rem;padding:2rem}.no-quizzes p{margin-bottom:1rem}.help-text{border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:2rem;text-align:center}.help-text p{color:#64748b;margin-bottom:.5rem}.link-button{background:none;border:none;color:#6366f1;cursor:pointer;font-weight:600;text-decoration:underline;transition:color .2s ease}.link-button:hover{color:#4f46e5}@keyframes countdownPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width:768px){.multiplayer-page{padding:4.5rem .75rem 1.5rem}.multiplayer-container{padding:0}.multiplayer-hero h1{word-wrap:break-word;font-size:2rem}.multiplayer-hero .subtitle{font-size:1rem}.action-cards{grid-template-columns:1fr}.action-card{padding:1.5rem}.steps{grid-template-columns:1fr}.lobby-header{flex-direction:column;gap:1.5rem;text-align:center}.room-code-display{flex-direction:column;width:100%}.room-code-display .code{font-size:1.5rem}.game-info,.players-grid{grid-template-columns:1fr}.lobby-actions{flex-direction:column}.countdown-number{font-size:4rem;height:150px;width:150px}.lobby-container,.multiplayer-card{box-sizing:border-box;width:100%}}.pause-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.pause-content{animation:slideUp .4s ease;background:#fff;border-radius:20px;box-shadow:0 25px 80px #0006;padding:3rem 4rem;text-align:center}.pause-content h2{animation:pulse 2s ease-in-out infinite;color:#1e293b;font-size:2.5rem;margin-bottom:1rem}.pause-content p{color:#64748b;font-size:1.2rem;margin-bottom:.5rem}.pause-content .loading-dots{animation:dotPulse 1.4s infinite;display:inline-block}@keyframes dotPulse{0%,20%,to{opacity:0}50%{opacity:1}}@keyframes bounceIn{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@media (max-width:480px){.multiplayer-page{padding:4rem .5rem 1rem}.multiplayer-container{padding:0 .25rem}.multiplayer-card{box-sizing:border-box;margin:0;padding:1.5rem}.form-actions{flex-direction:column}.room-code-input{font-size:1.5rem!important}.pause-content{box-sizing:border-box;max-width:90vw;padding:1.5rem}.pause-content h2{word-wrap:break-word;font-size:1.25rem}.pause-content p{word-wrap:break-word;font-size:.95rem}.leaderboard-item{gap:.75rem;padding:.75rem}.leaderboard-item .rank{font-size:1.25rem;min-width:40px}.leaderboard-item .name{font-size:1rem}.leaderboard-item .stats{font-size:.8rem}.leaderboard-item .streak,.leaderboard-item .trophy{font-size:1.25rem}.leaderboard-title{font-size:1.75rem}.leaderboard-subtitle{font-size:1rem}.lobby-container{padding:0}.lobby-header{margin-bottom:1rem;padding:1.5rem}.room-info h1{font-size:1.25rem}.players-section{margin-bottom:1rem;padding:1.5rem}.players-section h2{font-size:1.25rem;margin-bottom:1rem}.player-card{padding:.75rem}.player-rank{font-size:.9rem;height:35px;width:35px}.player-name{font-size:.95rem}.host-badge,.you-badge{font-size:.65rem;padding:.1rem .4rem}.btn-primary,.btn-secondary{font-size:.95rem;min-height:44px;padding:1rem 1.5rem}.btn-lg{font-size:1rem;padding:1.25rem 2rem}.copy-btn{min-height:44px;padding:.75rem 1rem}.next-question-btn{font-size:1rem;margin-top:1.5rem;padding:1.25rem 2rem}.countdown-screen h1{font-size:1.75rem;margin-bottom:1.5rem}.countdown-number{font-size:3rem;height:120px;width:120px}.countdown-screen p{font-size:1.125rem}.info-item{padding:1rem}.info-item .icon{font-size:1.25rem}.info-item span:last-child{font-size:.9rem}}@media (max-width:375px){.multiplayer-hero h1{font-size:1.5rem}.room-code-display .code{font-size:1.25rem;letter-spacing:.15em}.lobby-header,.pause-content,.players-section{padding:1rem}.pause-content h2{font-size:1.125rem}.pause-content p{font-size:.875rem}.leaderboard-title{font-size:1.5rem}.countdown-number{font-size:2.5rem;height:100px;width:100px}.quiz-header .pause-button{height:44px;min-height:44px;min-width:44px;width:44px}.pause-overlay .pause-content{max-height:90vh;max-width:85vw;overflow-y:auto}.leaderboard-screen{padding:1rem}.multiplayer-leaderboard{padding:.5rem}}@media (max-height:600px) and (orientation:landscape){.pause-content{max-height:80vh;overflow-y:auto;padding:1rem 1.5rem}.countdown-number{font-size:2rem;height:80px;width:80px}.timer-circle{height:60px;width:60px}.quiz-content{gap:1rem;padding:1rem}.question-card{padding:1rem 1.25rem}.answer-grid{gap:.5rem}.answer-button{min-height:50px;padding:.75rem 1rem}}.profile-page-container{background:#fafbfc;margin:0 auto;max-width:1200px;min-height:calc(100vh - 80px);padding:6rem 2rem 4rem}@media (max-width:768px){.profile-page-container{padding:5rem 1rem 2rem}}.profile-unauthorized{padding:4rem 2rem;text-align:center}.profile-unauthorized h2{color:#1e293b;margin-bottom:1.5rem}.btn-home{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-home:hover{background:#2563eb;transform:translateY(-2px)}.profile-header{align-items:center;background:#fff;border-left:4px solid #3b82f6;border-radius:12px;box-shadow:0 1px 3px #00000014;display:flex;gap:2rem;margin-bottom:3rem;padding:3rem}.profile-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;box-shadow:0 8px 24px #3b82f633;color:#fff;display:flex;flex-shrink:0;font-size:2.5rem;height:96px;justify-content:center;width:96px}.profile-header-info h1{color:#0f172a;font-size:2.25rem;font-weight:700;letter-spacing:-.02em;margin:0}.profile-subtitle{color:#64748b;font-size:1rem;font-weight:400;margin:.75rem 0 0}.profile-content{display:flex;flex-direction:column;gap:1.5rem}.profile-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:2.5rem;transition:box-shadow .2s ease}.profile-section:hover{box-shadow:0 4px 12px #00000014}.section-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.25rem}.section-title{color:#0f172a!important;font-size:1.5rem!important;font-weight:700!important;letter-spacing:-.025em!important;line-height:1.2!important;margin:0!important}.section-header-simple{border-bottom:2px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1.25rem}.btn-cancel-edit,.btn-edit,.btn-save{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;letter-spacing:.01em;padding:.625rem 1.125rem;transition:all .2s}.btn-edit{background:#3b82f6;box-shadow:0 1px 2px #0000000d;color:#fff}.btn-edit:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f633;transform:translateY(-1px)}.edit-actions{display:flex;gap:.625rem}.btn-save{background:#10b981;box-shadow:0 1px 2px #0000000d;color:#fff}.btn-save:hover:not(:disabled){background:#059669;box-shadow:0 4px 12px #10b98133;transform:translateY(-1px)}.btn-cancel-edit{background:#fff;border:1px solid #cbd5e1;color:#64748b}.btn-cancel-edit:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8;transform:translateY(-1px)}.btn-cancel-edit:disabled,.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.info-item{flex-direction:column}.info-item,.info-label{display:flex;gap:.625rem}.info-label{align-items:center;color:#475569;font-size:.8125rem;font-weight:600;letter-spacing:.075em;text-transform:uppercase}.info-icon{color:#64748b;font-size:.9375rem}.info-icon.verified{color:#10b981}.info-icon.unverified{color:#ef4444}.info-value{font-size:1rem;line-height:1.5}.info-input,.info-value{color:#0f172a;font-weight:500}.info-input{background:#fff;border:1px solid #cbd5e1;border-radius:6px;font-family:inherit;font-size:.9375rem;padding:.875rem 1rem;transition:all .2s;width:100%}.info-input:hover{border-color:#94a3b8}.info-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f614;outline:none}.verification-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:.8125rem;font-weight:600;letter-spacing:.02em;padding:.375rem .875rem}.verification-badge.verified{background:#d1fae5;color:#065f46}.verification-badge.unverified{background:#fee2e2;color:#991b1b}.subscription-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.subscription-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:2rem}.plan-info{align-items:flex-start;display:flex;gap:1rem}.crown-icon{font-size:2rem;margin-top:.25rem}.crown-icon.premium{color:#764ba2;filter:drop-shadow(0 2px 4px rgba(118,75,162,.3))}.crown-icon.basic{color:#3b82f6;filter:drop-shadow(0 2px 4px rgba(59,130,246,.3))}.crown-icon.free{color:#64748b}.plan-name{align-items:center;color:#0f172a;display:flex;flex-wrap:wrap;font-size:1.5rem;font-weight:700;gap:.75rem;letter-spacing:-.01em;margin:0}.plan-price{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#3b82f6;font-size:.875rem;font-weight:700;padding:.375rem .875rem}.plan-description{color:#475569;font-size:.9375rem;line-height:1.6;margin:.75rem 0 0}.subscription-features{background:#fff;padding:2rem}.subscription-features h4{color:#0f172a;font-size:.9375rem;font-weight:700;letter-spacing:.05em;margin:0 0 1.25rem;text-transform:uppercase}.subscription-features ul{grid-gap:.875rem;display:grid;gap:.875rem;list-style:none;margin:0;padding:0}.subscription-features li{align-items:center;color:#475569;display:flex;font-size:.9375rem;font-weight:500;gap:.75rem}.subscription-features li.active{color:#0f172a}.subscription-features li.inactive{color:#94a3b8}.cancellation-notice{background:#fff3cd;border:2px solid #ffc107;border-radius:8px;margin:1rem 0;padding:1rem}.notice-text{color:#856404;font-size:.95rem;font-weight:600;margin:0 0 .5rem}.notice-subtext{color:#856404;font-size:.875rem;margin:0}.subscription-actions{background:#fafbfc;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding:2rem}.btn-cancel-sub,.btn-upgrade{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.625rem;letter-spacing:.01em;padding:.875rem 1.75rem;transition:all .2s}.btn-upgrade{background:#3b82f6;box-shadow:0 1px 3px #0000001a;color:#fff}.btn-upgrade:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f640;transform:translateY(-1px)}.btn-cancel-sub{background:#fff;border:1px solid #dc2626;color:#dc2626}.btn-cancel-sub:hover{background:#dc2626;color:#fff;transform:translateY(-1px)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;justify-content:center;overflow-y:auto;padding:1rem}.survey-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:550px;overflow-y:auto;padding:2.5rem;width:90%}.survey-modal h2{color:#1e293b;font-size:1.75rem;font-weight:700;margin:0 0 .5rem;text-align:center}.survey-modal>p{color:#64748b;font-size:1rem;margin:0 0 2rem;text-align:center}.survey-form{gap:1.5rem}.reason-options,.survey-form{display:flex;flex-direction:column}.reason-options{gap:.75rem}.reason-option{align-items:center;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:1rem;transition:all .2s}.reason-option:hover{background:#f0f9ff;border-color:#3b82f6}.reason-option input[type=radio]{accent-color:#3b82f6;cursor:pointer;height:20px;width:20px}.reason-option input[type=radio]:checked+span{color:#1e293b;font-weight:600}.reason-option span{color:#475569;flex:1 1;font-size:.95rem}.feedback-textarea{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:.95rem;min-height:100px;padding:1rem;resize:vertical;transition:border-color .2s;width:100%}.feedback-textarea:focus{border-color:#3b82f6;outline:none}.feedback-textarea::placeholder{color:#94a3b8}.btn-back,.btn-continue{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .2s}.btn-back{background:#3b82f6;color:#fff}.btn-back:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.btn-continue{background:#64748b;color:#fff}.btn-continue:hover{background:#475569;transform:translateY(-2px)}.btn-back:disabled,.btn-continue:disabled{cursor:not-allowed;opacity:.6;transform:none}.cancel-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;padding:2.5rem;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-icon-warning{font-size:3rem;margin-bottom:1rem;text-align:center}.cancel-modal h2{color:#1e293b;font-size:1.75rem;font-weight:700;margin:0 0 1rem;text-align:center}.cancel-modal>p{color:#64748b;font-size:1rem;margin:0 0 1.5rem;text-align:center}.warning-box{background:#fef2f2;border:2px solid #fecaca;border-radius:8px;margin-bottom:1.5rem;padding:1.25rem}.warning-box strong{color:#dc2626;display:block;font-size:.95rem;margin-bottom:.75rem}.warning-box ul{color:#991b1b;margin:0;padding-left:1.25rem}.warning-box li{font-size:.9rem;margin:.5rem 0}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.btn-cancel,.btn-keep{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .2s}.btn-keep{background:#3b82f6;color:#fff}.btn-keep:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.btn-cancel{background:#fff;border:2px solid #ef4444;color:#ef4444}.btn-cancel:hover{background:#ef4444;color:#fff;transform:translateY(-2px)}.btn-cancel:disabled,.btn-keep:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.profile-header{flex-direction:column;padding:1.5rem;text-align:center}.profile-avatar{font-size:2rem;height:60px;width:60px}.profile-header-info h1{font-size:1.5rem}.profile-subtitle{font-size:.875rem}.profile-section{padding:1.5rem}.section-title{font-size:1.25rem}.info-grid{gap:1rem;grid-template-columns:1fr}.info-value{font-size:1rem}.subscription-header{padding:1rem}.crown-icon{font-size:1.5rem}.plan-name{font-size:1.25rem}.plan-description{font-size:.8rem}.subscription-features{padding:1rem}.subscription-features li{font-size:.875rem}.subscription-actions{padding:1rem}.btn-cancel-sub,.btn-upgrade{font-size:.9rem;padding:.75rem 1.5rem}.survey-modal{max-width:95%;padding:1.5rem}.survey-modal h2{font-size:1.25rem}.survey-modal>p{font-size:.9rem;margin-bottom:1.5rem}.reason-option{padding:.875rem}.reason-option span{font-size:.875rem}.feedback-textarea{font-size:.875rem;min-height:80px}.cancel-modal{max-width:90%;padding:1.5rem}.modal-icon-warning{font-size:2rem}.cancel-modal h2{font-size:1.25rem}.cancel-modal>p{font-size:.9rem}.warning-box{padding:1rem}.warning-box strong{font-size:.875rem}.warning-box li{font-size:.825rem}.modal-actions{flex-direction:column;gap:.75rem}.btn-back,.btn-cancel,.btn-continue,.btn-keep{font-size:.9rem;padding:.75rem 1rem;width:100%}}@media (max-width:480px){.profile-page-container{padding:4.5rem .5rem 1rem}.profile-header{margin-bottom:1rem;padding:1rem}.profile-section{padding:1rem}.info-label{font-size:.75rem}.subscription-features ul{gap:.5rem}}.flashcard-artifact{background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;margin:0 auto;max-width:600px;padding:1.5rem;width:100%}.flashcard-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.flashcard-title{color:#1e293b;flex:1 1;font-size:1.125rem;font-weight:700;margin:0;text-align:center}.flashcard-fullscreen-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .2s ease;width:36px}.flashcard-fullscreen-btn:hover{background:#e5e7eb;color:#3b82f6}.flashcard-fullscreen-btn svg{height:18px;width:18px}.flashcard-wrapper{margin-bottom:1.5rem;perspective:1000px}.flashcard{cursor:pointer;height:300px;position:relative;transform-style:preserve-3d;transition:transform .6s;width:100%}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-inner{height:100%;position:relative;transform-style:preserve-3d;transition:transform .6s;width:100%}.flashcard-back,.flashcard-front{align-items:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:12px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;height:100%;justify-content:center;padding:2rem;position:absolute;text-align:center;width:100%}.flashcard-front{background:#fff;border:2px solid #e5e7eb;color:#1e293b;transform:rotateY(0deg)}.flashcard-back{background:#f8fafc;border:2px solid #3b82f6;color:#1e293b;transform:rotateY(180deg)}.flashcard-label{color:#3b82f6;font-size:.75rem;font-weight:700;letter-spacing:1.5px;margin-bottom:1rem;text-transform:uppercase}.flashcard-content{font-size:1.25rem;font-weight:600;line-height:1.6}.flashcard-hint{color:#64748b;font-size:.8rem;font-weight:500;margin-top:auto;padding-top:1rem}.flashcard-controls{align-items:center;display:flex;gap:1rem;justify-content:space-between}.flashcard-nav-button{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s}.flashcard-nav-button:hover:not(:disabled){background:#e5e7eb}.flashcard-nav-button:disabled{cursor:not-allowed;opacity:.4}.flashcard-nav-button svg{height:20px;width:20px}.flashcard-counter{color:#64748b;font-size:.875rem;font-weight:600}@media (max-width:768px){.flashcard-artifact{max-width:100%;padding:1rem}.flashcard{min-height:250px}.flashcard-back,.flashcard-front{padding:1.25rem}.flashcard-content{font-size:1em}.flashcard-nav-button{font-size:.8rem;padding:.625rem 1rem}.flashcard-label{font-size:.7rem}.flashcard-hint{font-size:.75rem}}.mini-quiz-artifact{background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;margin:0 auto;max-width:700px;padding:1.5rem;width:100%}.quiz-question{margin-bottom:1.5rem}.quiz-question h3{color:#1e293b;font-size:1em;font-weight:700;line-height:1.6;margin:0}.quiz-choices{grid-gap:1rem;display:grid;gap:1rem;margin-bottom:1.5rem}.quiz-choice{align-items:center;border:2px solid #0000;border-radius:12px;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:1rem;padding:1rem 1.25rem;position:relative;text-align:left;transition:all .3s ease}.quiz-choice:not(:disabled):hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.quiz-choice.selected{border-width:3px}.choice-letter{align-items:center;background:#ffffff4d;border-radius:50%;display:flex;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.choice-text{flex:1 1;line-height:1.5}.choice-indicator{font-size:1.5rem;font-weight:700}.quiz-explanation{animation:slideDown .3s ease-out;border-radius:12px;padding:1.25rem}.correct-explanation{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981}.incorrect-explanation{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.explanation-header{font-size:1.125rem;font-weight:700;margin-bottom:.75rem}.explanation-emoji{display:inline-block}.explanation-text{color:#1e293b;font-size:.95rem;line-height:1.6;margin:0}.confetti-celebration{animation:celebrate 2s ease-out;font-size:5rem;left:50%;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:1000}@keyframes celebrate{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:0;transform:translate(-50%,-50%) scale(1) translateY(-100px)}}@media (max-width:768px){.mini-quiz-artifact{max-width:100%;padding:1rem}.quiz-question h3{font-size:.95em}.quiz-choice{font-size:.9em;padding:.875rem 1rem}.choice-letter{font-size:.875rem;height:28px;width:28px}.quiz-explanation{padding:1rem}.explanation-header{font-size:.95em}.explanation-text{font-size:.875em}}.timeline-artifact{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;max-width:100%;padding:1.25rem}.timeline-title{border-bottom:2px solid #f1f5f9;color:#0f172a;font-size:1rem;font-weight:600;margin-bottom:1.25rem;padding-bottom:.75rem}.timeline-container{padding:.5rem 0;position:relative}.timeline-line{background:linear-gradient(180deg,#6366f1,#a855f7 50%,#ec4899);bottom:0;left:8px;opacity:.3;position:absolute;top:0;width:2px}.timeline-event{cursor:pointer;margin-bottom:1rem;padding-left:32px;position:relative;transition:all .2s ease}.timeline-event:last-child{margin-bottom:0}.timeline-event:hover{transform:translateX(4px)}.timeline-marker{left:0;position:absolute;top:2px;z-index:2}.timeline-dot{background:linear-gradient(135deg,#6366f1,#a855f7);border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 2px #f1f5f9,0 2px 4px #6366f133;height:18px;transition:all .2s ease;width:18px}.timeline-event:hover .timeline-dot{box-shadow:0 0 0 2px #e0e7ff,0 4px 8px #6366f14d;transform:scale(1.2)}.timeline-event.expanded .timeline-dot{background:linear-gradient(135deg,#a855f7,#ec4899);box-shadow:0 0 0 2px #fce7f3,0 4px 8px #a855f766}.timeline-content{background:#fafafa;border-left:2px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;transition:all .2s ease}.timeline-event:hover .timeline-content{background:#fff;border-left-color:#6366f1;box-shadow:0 2px 8px #0000000f}.timeline-event.expanded .timeline-content{background:#fff;border-left-color:#a855f7;box-shadow:0 2px 12px #a855f71f}.timeline-date{color:#6366f1;font-size:.75rem;font-weight:600;letter-spacing:.02em;margin-bottom:.35rem;text-transform:uppercase}.timeline-event-title{color:#0f172a;font-size:.9rem;font-weight:600;line-height:1.4}.timeline-description{animation:expandDown .25s ease-out;border-top:1px solid #e2e8f0;color:#475569;font-size:.85rem;line-height:1.5;margin-top:.65rem;padding-top:.65rem}.timeline-hint{border-top:1px dashed #e2e8f0;color:#94a3b8;font-size:.75rem;margin-top:1rem;opacity:.8;padding-top:1rem;text-align:center}@media (max-width:768px){.timeline-artifact{padding:1rem}.timeline-event{padding-left:28px}.timeline-line{left:7px}.timeline-dot{height:16px;width:16px}.timeline-content{padding:.65rem .85rem}.timeline-date{font-size:.7rem}.timeline-event-title{font-size:.85rem}.timeline-description{font-size:.8rem}}.formula-artifact{background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;max-width:600px;padding:1.5rem}.formula-header{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.formula-icon{font-size:1.5rem}.formula-title{color:#1e293b;font-size:1.25rem;font-weight:700;margin:0}.formula-display{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #3b82f6;border-radius:12px;display:flex;justify-content:center;margin-bottom:1.5rem;overflow-x:auto;padding:2rem}.formula-display .katex-display{font-size:1.4em;margin:0}.formula-display .katex{color:#1e293b}.formula-variables{background:#f8fafc;border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.formula-variables h4{color:#1e293b;font-size:1rem;font-weight:700;margin:0 0 1rem}.variables-list{grid-gap:.75rem;display:grid;gap:.75rem;list-style:none;margin:0;padding:0}.variable-item{align-items:center;background:#fff;border-left:3px solid #3b82f6;border-radius:8px;display:flex;gap:1rem;padding:.5rem}.variable-symbol{align-items:center;color:#3b82f6;display:flex;font-weight:700;min-width:40px}.variable-symbol .katex{font-size:1.1em}.variable-meaning{color:#64748b;flex:1 1;font-size:.95rem;line-height:1.5}.formula-example{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;padding:1.25rem}.formula-example h4{color:#1e293b;font-size:1rem;font-weight:700;margin:0 0 .75rem}.example-content{color:#1e293b;font-size:.95rem;line-height:1.6;white-space:pre-wrap}@media (max-width:768px){.formula-artifact{padding:1rem}.formula-display{padding:1.5rem 1rem}.formula-display .katex-display{font-size:1.1em}.formula-example,.formula-variables{padding:1rem}.variable-item{align-items:flex-start;flex-direction:column;gap:.5rem}}.button-options-artifact{margin:1rem 0}.options-title{color:#334155;font-size:1rem;font-weight:600;margin-bottom:.75rem;text-align:center}.options-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.option-button{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#1e293b;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:1rem;justify-content:space-between;padding:1rem 1.25rem;text-align:left;transition:all .3s ease}.option-button:hover{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-color:#0000;box-shadow:0 8px 16px #3b82f64d;color:#fff;transform:translateY(-2px)}.option-button:active{transform:translateY(0)}.option-text{flex:1 1;line-height:1.5}.option-arrow{font-size:1.25rem;font-weight:700;opacity:.6;transition:all .3s ease}.option-button:hover .option-arrow{opacity:1;transform:translateX(4px)}@media (max-width:768px){.options-grid{gap:.625rem;grid-template-columns:1fr}.option-button{font-size:.9rem;padding:.875rem 1rem}}.definition-box-artifact{animation:fadeSlideIn .3s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #00000014,0 4px 12px #0000000a;overflow:hidden;transition:all .2s ease}.definition-box-artifact:hover{border-color:#d1d5db;box-shadow:0 2px 6px #0000001a,0 8px 20px #0000000f}.definition-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e5e7eb;display:flex;gap:.875rem;padding:1rem 1.25rem}.definition-icon-badge{align-items:center;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.definition-icon{font-size:1.5rem}.definition-term{color:#1f2937;font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin:0}.definition-content{padding:1.25rem}.definition-text{color:#374151;font-size:.95rem;line-height:1.7;margin:0}.definition-example{background:#eff6ff;border-left:3px solid #3b82f6;border-radius:6px;margin-top:1rem;padding:1rem}.example-label{align-items:center;color:#1e40af;display:flex;font-size:.8rem;font-weight:600;gap:.375rem;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.example-icon,.example-text{font-size:.9rem}.example-text{color:#1e3a8a;font-style:italic;line-height:1.6;margin:0}.related-terms{border-top:1px solid #e5e7eb;margin-top:1rem;padding-top:1rem}.related-label{align-items:center;color:#6b7280;display:flex;font-size:.8rem;font-weight:600;gap:.375rem;letter-spacing:.05em;margin-bottom:.625rem;text-transform:uppercase}.related-icon{font-size:.9rem}.related-terms-list{display:flex;flex-wrap:wrap;gap:.5rem}.related-term{align-items:center;background:#f3f4f6;border:1px solid #0000;border-radius:6px;color:#374151;display:inline-flex;font-size:.85rem;font-weight:500;padding:.375rem .75rem;transition:all .15s ease}.related-term:hover{background:#e5e7eb;border-color:#d1d5db;cursor:default;transform:translateY(-1px)}@media (max-width:768px){.definition-box-artifact{border-radius:6px}.definition-header{gap:.75rem;padding:.875rem 1rem}.definition-icon-badge{border-radius:8px;height:36px;width:36px}.definition-icon{font-size:1.3rem}.definition-term{font-size:1.15rem}.definition-content{padding:1rem}.definition-text{font-size:.9rem}.definition-example{padding:.875rem}.example-text{font-size:.875rem}.related-term{font-size:.8rem;padding:.3rem .625rem}}@media (max-width:480px){.definition-header{gap:.625rem;padding:.75rem}.definition-icon-badge{height:32px;width:32px}.definition-icon{font-size:1.15rem}.definition-term{font-size:1.05rem}.definition-content{padding:.875rem}.definition-text{font-size:.875rem}.definition-example{margin-top:.875rem;padding:.75rem}.example-label{font-size:.75rem}.example-text{font-size:.825rem}.related-label{font-size:.75rem}.related-terms-list{gap:.375rem}.related-term{font-size:.75rem;padding:.25rem .5rem}}.comparison-table-artifact{animation:fadeIn .4s ease-out;background:#fff;border-radius:12px;box-shadow:0 2px 10px #00000014;padding:1.5rem}.comparison-title{align-items:center;color:#2d3748;display:flex;font-size:1.3rem;font-weight:600;gap:.75rem;margin:0 0 1.5rem}.comparison-icon{font-size:1.4rem}.table-container{border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}.comparison-table{border-collapse:collapse;font-size:.95rem;width:100%}.comparison-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.comparison-table th{border-right:1px solid #ffffff1a;font-size:.95rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.comparison-table th:last-child{border-right:none}.comparison-table th.first-column{background:#0000001a;min-width:120px}.comparison-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background .2s ease}.comparison-table tbody tr:hover{background:#f7fafc}.comparison-table tbody tr:last-child{border-bottom:none}.comparison-table td{color:#4a5568;line-height:1.5;padding:.875rem 1rem}.comparison-table td.first-column{background:#f7fafc;border-right:1px solid #e2e8f0;color:#2d3748;font-weight:600}@media (max-width:768px){.comparison-table-artifact{padding:1rem}.comparison-table{font-size:.875rem}.comparison-table td,.comparison-table th{padding:.75rem}}.code-snippet-artifact{animation:slideInFromRight .4s ease-out;background:#1e1e1e;border-radius:12px;box-shadow:0 4px 15px #0003;overflow:hidden}.code-header{background:#2d2d2d;border-bottom:1px solid #3e3e3e;justify-content:space-between;padding:1rem 1.5rem}.code-header,.code-title{align-items:center;display:flex}.code-title{gap:.75rem}.code-icon{font-size:1.2rem}.code-title h3{color:#e1e1e1;font-size:1.1rem;font-weight:500;margin:0}.code-actions{align-items:center;display:flex;gap:1rem}.language-badge{background:#3e3e3e;border-radius:20px;color:#61dafb;font-size:.85rem;font-weight:500}.copy-button{background:#3e3e3e;color:#e1e1e1;font-size:.9rem;gap:.4rem;padding:.4rem .8rem}.copy-button:hover{background:#4e4e4e}.code-container{background:#1e1e1e;overflow-x:auto;padding:1.5rem}.code-container pre{font-family:Fira Code,Courier New,monospace;font-size:.95rem;line-height:1.6;margin:0}.code-container code{color:#d4d4d4}.keyword{color:#c586c0;font-weight:500}.string{color:#ce9178}.comment{color:#6a9955;font-style:italic}.number{color:#b5cea8}.function{color:#dcdcaa}.code-explanation{background:#2d2d2d;border-top:1px solid #3e3e3e;padding:1rem 1.5rem}.code-explanation strong{color:#e1e1e1;display:block;font-size:.9rem;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.code-explanation p{color:#b0b0b0;font-size:.95rem;line-height:1.5;margin:0}@media (max-width:768px){.code-header{align-items:flex-start;flex-direction:column;gap:.75rem}.code-actions{justify-content:space-between;width:100%}.code-container{padding:1rem}.code-container pre{font-size:.85rem}}.key-takeaways-artifact{animation:pulseIn .5s ease-out;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;box-shadow:0 4px 20px #f093fb4d;color:#fff;padding:1.5rem}@keyframes pulseIn{0%{opacity:0;transform:scale(.9)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.takeaways-header{align-items:center;display:flex;gap:.75rem;margin-bottom:1.5rem}.takeaways-icon{animation:sparkle 2s infinite;font-size:1.8rem}@keyframes sparkle{0%,to{transform:scale(1) rotate(0deg)}50%{transform:scale(1.1) rotate(5deg)}}.takeaways-header h3{font-size:1.5rem;font-weight:700;margin:0;text-shadow:0 2px 4px #0000001a}.takeaways-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:10px;padding:1.25rem}.takeaways-list{list-style:none;margin:0;padding:0}.takeaway-item{align-items:flex-start;background:#ffffff1a;border-radius:8px;display:flex;gap:1rem;margin-bottom:1rem;padding:.75rem;transition:all .3s ease}.takeaway-item:last-child{margin-bottom:0}.takeaway-item:hover{background:#fff3;transform:translateX(5px)}.takeaway-number{align-items:center;background:#ffffff4d;border-radius:50%;display:flex;font-size:.9rem;font-weight:700;height:28px;justify-content:center;min-width:28px;width:28px}.takeaway-text{flex:1 1;font-size:1.05rem;line-height:1.5}.next-topic{border-top:2px dashed #ffffff4d;margin-top:1.5rem;padding-top:1.5rem}.next-topic-label{font-size:.9rem;font-weight:600;letter-spacing:1px;margin-bottom:.5rem;opacity:.9;text-transform:uppercase}.next-topic-content{align-items:center;background:#fff3;border-radius:8px;display:flex;font-size:1.1rem;gap:.75rem;padding:.75rem 1rem;transition:all .3s ease}.next-topic-content:hover{background:#ffffff4d;transform:translateX(5px)}.next-arrow{animation:arrowPulse 1.5s infinite;font-size:1.3rem}@keyframes arrowPulse{0%,to{transform:translateX(0)}50%{transform:translateX(3px)}}@media (max-width:768px){.key-takeaways-artifact{padding:1rem}.takeaway-item{padding:.5rem}.takeaway-text{font-size:.95rem}}.fill-blank-artifact{animation:slideUp .4s ease-out;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 15px #00000014;padding:1.5rem}.fill-blank-header{align-items:center;border-bottom:2px solid #f0f4f8;display:flex;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem}.fill-blank-icon{font-size:1.5rem}.fill-blank-header h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin:0}.fill-blank-content{padding:.5rem 0}.sentence-container{background:#f7fafc;border-left:4px solid #667eea;border-radius:8px;margin-bottom:2rem;padding:1rem}.sentence{align-items:baseline;color:#2d3748;display:flex;flex-wrap:wrap;font-size:1.1rem;gap:.3rem;line-height:2}.blank-wrapper{align-items:center;display:inline-flex;margin:0 .5rem;padding-right:30px;position:relative}.blank-input{background:#fff;border:none;border-bottom:2px solid #cbd5e0;border-radius:4px 4px 0 0;color:#2d3748;display:inline-block;font-size:1rem;font-weight:500;min-width:100px;padding:.3rem .6rem;text-align:center;transition:all .2s ease;width:auto}.blank-input:focus{background:#edf2f7;border-bottom-color:#667eea;outline:none}.blank-input::placeholder{color:#a0aec0;font-weight:400}.blank-input.correct{background:#c6f6d5;border-bottom-color:#48bb78;color:#22543d}.blank-input.incorrect{background:#fed7d7;border-bottom-color:#f56565;color:#742a2a}.hint-button{align-items:center;background:#fef3c7;border:1px solid #f59e0b;border-radius:50%;cursor:pointer;display:flex;font-size:.8rem;height:24px;justify-content:center;position:absolute;right:2px;top:50%;transform:translateY(-50%);transition:all .2s ease;width:24px;z-index:10}.hint-button:hover{background:#fde68a;transform:translateY(-50%) scale(1.1)}.correct-answer{animation:popIn .3s ease-out;background:#48bb78;border-radius:4px;color:#fff;font-size:.85rem;font-weight:600;left:0;padding:.25rem .5rem;position:absolute;right:30px;text-align:center;top:-28px;white-space:nowrap;z-index:5}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.hints-container{margin-top:.75rem}.hint-message{animation:slideInLeft .3s ease-out;background:#fef3c7;border-left:3px solid #f59e0b;border-radius:6px;color:#92400e;font-size:.9rem;margin-top:.5rem;padding:.5rem .75rem}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.fill-blank-actions{display:flex;justify-content:center;margin:2rem 0 1rem}.check-button,.reset-button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.5px;padding:.75rem 2rem;text-transform:uppercase;transition:all .2s ease}.check-button{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea4d;color:#fff}.check-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.reset-button{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 15px #f093fb4d;color:#fff}.reset-button:hover{box-shadow:0 6px 20px #f093fb66;transform:translateY(-2px)}.results-summary{background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:8px;margin-top:1.5rem;padding:1.5rem;text-align:center}.score{color:#2d3748;font-size:1.3rem;font-weight:600;margin-bottom:.75rem}.perfect-score{animation:bounce .5s ease;color:#48bb78;font-size:1.1rem;font-weight:600}.good-score{color:#4299e1;font-weight:500}.try-again{color:#ed8936;font-weight:500}@media (max-width:768px){.fill-blank-artifact{padding:1rem}.sentence{font-size:1rem}.blank-input{font-size:.95rem;min-width:80px}.blank-wrapper{padding-right:28px}.hint-button{font-size:.75rem;height:22px;right:0;width:22px}.correct-answer{font-size:.8rem;right:28px}}.math-keyboard-container{width:100%}.math-input-wrapper{margin-bottom:12px;position:relative}.math-input-display{background:#ffffff0d;border:1px solid #ffffff1f;border-radius:10px;color:#f3f4f6;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:15px;font-weight:500;min-height:48px;padding:12px 110px 12px 14px;transition:all .2s ease;width:100%}.math-input-display:hover{background:#ffffff0f;border-color:#ffffff2e}.math-input-display:focus{background:#818cf814;border-color:#818cf8;box-shadow:0 0 0 3px #818cf826;outline:none}.math-input-display::placeholder{color:#6b7280;font-size:14px;font-weight:400}.input-controls{display:flex;gap:4px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.control-btn{align-items:center;background:#ffffff0f;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-size:16px;font-weight:600;height:32px;justify-content:center;transition:all .15s ease;width:32px}.control-btn:hover{background:#ffffff1a;color:#e5e7eb}.control-btn.backspace{font-size:18px}.control-btn.clear{font-size:14px;font-weight:700}.control-btn.keyboard-toggle{font-size:14px}.control-btn.keyboard-toggle.active{background:#818cf8;color:#fff}.math-keyboard{animation:slideDown .2s ease;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;padding:14px}.keyboard-tabs{border-bottom:1px solid #ffffff0f;display:flex;gap:6px;margin-bottom:12px;padding-bottom:10px}.tab-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:12px;font-weight:600;gap:3px;padding:8px 6px;transition:all .15s ease}.tab-btn:hover{background:#ffffff0d;color:#9ca3af}.tab-btn.active{background:#818cf826;border-color:#818cf84d;color:#818cf8}.tab-icon{font-size:18px;line-height:1}.tab-label{font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.keyboard-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,1fr);margin-bottom:10px}.key-btn{align-items:center;aspect-ratio:1;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:8px;color:#e5e7eb;cursor:pointer;display:flex;font-size:16px;font-weight:600;justify-content:center;min-height:44px;overflow:hidden;position:relative;transition:all .15s ease}.key-btn:hover{background:#818cf81f;border-color:#818cf840;transform:translateY(-1px)}.key-btn:active{background:#818cf833;transform:translateY(0)}.key-btn .katex{color:#e5e7eb;font-size:1em}.key-btn:hover .katex{color:#a5b4fc}.key-label{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;font-size:15px;font-weight:600}.key-btn[title*=frac],.key-btn[title*=int],.key-btn[title*=sqrt]{background:#818cf814}.key-btn[title*=frac]:hover,.key-btn[title*=int]:hover,.key-btn[title*=sqrt]:hover{background:#818cf82e}.keyboard-helper{align-items:center;background:#fbbf240f;border-radius:6px;display:flex;gap:8px;padding:8px 10px}.helper-icon{flex-shrink:0;font-size:14px}.helper-text{color:#fbbf24;font-size:11px;line-height:1.4;opacity:.9}@media (prefers-color-scheme:light){.math-input-display{background:#fff;border-color:#e5e7eb;color:#1f2937}.math-input-display:hover{background:#fff;border-color:#d1d5db}.math-input-display:focus{background:#fff;border-color:#818cf8;box-shadow:0 0 0 3px #818cf81a}.math-input-display::placeholder{color:#9ca3af}.control-btn{background:#f3f4f6;color:#6b7280}.control-btn:hover{background:#e5e7eb;color:#374151}.control-btn.keyboard-toggle.active{background:#818cf8;color:#fff}.math-keyboard{background:#fafafa;border-color:#e5e7eb}.keyboard-tabs{border-bottom-color:#f3f4f6}.tab-btn{color:#9ca3af}.tab-btn:hover{background:#f3f4f6;color:#6b7280}.tab-btn.active{background:#818cf81a;border-color:#818cf833;color:#6366f1}.key-btn{background:#fff;border-color:#e5e7eb;color:#374151}.key-btn:hover{background:#818cf814;border-color:#818cf84d}.key-btn:active{background:#818cf826}.key-btn .katex{color:#374151}.key-btn:hover .katex{color:#6366f1}.key-btn[title*=frac],.key-btn[title*=int],.key-btn[title*=sqrt]{background:#818cf80f}.key-btn[title*=frac]:hover,.key-btn[title*=int]:hover,.key-btn[title*=sqrt]:hover{background:#818cf81f}.keyboard-helper{background:#fbbf2414}.helper-text{color:#b45309}}@media (max-width:640px){.keyboard-grid{gap:5px}.key-btn{font-size:14px;min-height:40px}.tab-icon{font-size:16px}.tab-label{font-size:9px}.math-input-display{font-size:14px;min-height:44px;padding:10px 100px 10px 12px}.math-input-display::placeholder{font-size:13px}.control-btn{font-size:14px;height:28px;width:28px}.keyboard-helper{padding:6px 8px}.helper-text{font-size:10px}}@media (max-width:480px){.keyboard-tabs{gap:4px}.tab-btn{padding:6px 4px}.keyboard-grid{gap:4px}.key-btn{min-height:38px}.key-btn,.key-label{font-size:13px}}.interactive-math-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;width:100%}.math-section-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;justify-content:space-between;margin-bottom:8px;padding:12px 0}.math-section-title{color:#9ca3af;font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase}.math-progress-mini{align-items:center;display:flex}.progress-dots{display:flex;gap:6px}.progress-dot{background:#ffffff26;border-radius:50%;height:8px;transition:all .3s ease;width:8px}.progress-dot.active{background:#818cf8;box-shadow:0 0 8px #818cf880}.progress-dot.completed{background:#34d399}.math-problem-display{background:linear-gradient(135deg,#818cf81f,#6366f114);border:1px solid #818cf840;border-radius:14px;margin-bottom:20px;padding:20px 24px;text-align:center}.problem-label{color:#818cf8;font-size:11px;font-weight:700;letter-spacing:1.5px;margin-bottom:12px;text-transform:uppercase}.problem-equation{padding:8px 0}.problem-equation .katex-display{margin:0}.problem-equation .katex{color:#f3f4f6;font-size:1.6em;font-weight:600}@media (prefers-color-scheme:light){.math-problem-display{background:linear-gradient(135deg,#818cf81a,#6366f10d);border-color:#818cf833}.problem-equation .katex{color:#1e293b}}.math-steps-list{display:flex;flex-direction:column}.math-step-item{border-bottom:1px solid #ffffff0f;position:relative;transition:all .2s ease}.math-step-item:last-child{border-bottom:none}.math-step-item.active{background:#818cf80d;border-bottom:none;border-radius:12px;margin:8px 0}.math-step-item.completed{opacity:.85}.math-step-item.locked{opacity:.5}.math-step-item.correct-animation{animation:correctFlash .5s ease}.math-step-item.incorrect-animation{animation:incorrectShake .4s ease}@keyframes correctFlash{0%,to{background:#0000}50%{background:#34d39926}}@keyframes incorrectShake{0%,to{transform:translateX(0)}20%,60%{transform:translateX(-4px)}40%,80%{transform:translateX(4px)}}.step-header-row{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:14px;padding:16px 12px;transition:background .2s ease}.step-header-row:hover{background:#ffffff08}.math-step-item.active .step-header-row:hover{background:#818cf814}.step-header-row.locked{cursor:not-allowed;position:relative}.step-header-row.locked:hover{background:#ffffff05}.step-header-row.locked:after{background:#1f2937;border-radius:8px;bottom:calc(100% + 8px);box-shadow:0 4px 12px #0000004d;color:#f3f4f6;content:"Complete the previous step first";font-size:12px;font-weight:500;padding:8px 14px;white-space:nowrap}.step-header-row.locked:after,.step-header-row.locked:before{left:50%;opacity:0;pointer-events:none;position:absolute;transform:translateX(-50%);transition:all .2s ease;visibility:hidden;z-index:100}.step-header-row.locked:before{border:6px solid #0000;border-top-color:#1f2937;bottom:calc(100% + 4px);content:""}.step-header-row.locked:hover:after,.step-header-row.locked:hover:before{opacity:1;visibility:visible}.step-number{align-items:center;background:#ffffff14;border-radius:50%;display:flex;flex-shrink:0;height:32px;justify-content:center;min-width:32px;width:32px}.step-number span{color:#9ca3af;font-size:14px;font-weight:600;line-height:1}.math-step-item.active .step-number{background:#818cf8}.math-step-item.active .step-number span{color:#fff}.math-step-item.completed .step-number{background:#34d399}.math-step-item.completed .step-number span{color:#fff}.step-main-content{display:flex;flex:1 1;flex-direction:column;justify-content:center;min-width:0}.step-description-text{color:#e5e7eb;font-size:14px;font-weight:500;line-height:1.5}.math-step-item.completed .step-description-text{color:#9ca3af}.step-equation-display{margin-top:12px;padding:8px 0}.step-equation-display .katex-display{margin:0;text-align:center}.step-equation-display .katex{color:#f3f4f6;font-size:1.35em;font-weight:600}.step-equation-display .katex .mathbf,.step-equation-display .katex .mathdefault,.step-equation-display .katex .mathnormal{font-weight:600}.step-completed-answer{align-items:center;background:#34d3991a;border-radius:6px;display:inline-flex;gap:8px;margin-top:8px;padding:6px 12px}.completed-check{color:#34d399;font-size:14px;font-weight:700}.step-completed-answer .katex{color:#34d399;font-size:1em}.step-chevron{align-items:center;color:#6b7280;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:transform .2s ease;width:20px}.step-chevron svg{height:100%;width:100%}.math-step-item.expanded .step-chevron{transform:rotate(180deg)}.step-expandable-content{animation:slideDown .25s ease;padding:0 16px 20px}.step-input-wrapper{margin-top:20px}.step-question-label{color:#9ca3af;font-size:13px;font-weight:500;margin-bottom:12px;text-align:center}.step-check-btn{background:linear-gradient(135deg,#818cf8,#6366f1);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:12px;padding:14px 24px;transition:all .2s ease;width:100%}.step-check-btn:hover:not(:disabled){box-shadow:0 4px 16px #818cf866;transform:translateY(-1px)}.step-check-btn:active:not(:disabled){transform:translateY(0)}.step-check-btn:disabled{cursor:not-allowed;opacity:.4}.step-feedback{align-items:center;animation:fadeIn .3s ease;border-radius:8px;display:flex;font-size:13px;font-weight:600;gap:8px;margin-top:12px;padding:10px 14px}.step-feedback.success{background:#34d39926;color:#34d399}.step-feedback.error{background:#f8717126;color:#f87171}.step-help-actions{display:flex;gap:10px;justify-content:center;margin-top:16px}.help-action-btn{background:#0000;border:1px solid #ffffff1a;border-radius:8px;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;max-width:180px;padding:10px 16px;text-align:center;transition:all .2s ease}.help-action-btn.hint-btn{color:#fbbf24}.help-action-btn.hint-btn:hover{background:#fbbf241a;border-color:#fbbf244d}.help-action-btn.solution-btn{color:#818cf8}.help-action-btn.solution-btn:hover{background:#818cf81a;border-color:#818cf84d}.step-hint-content{background:#fbbf2414;border-left:3px solid #fbbf24;border-radius:0 8px 8px 0;color:#fcd34d;font-size:13px;line-height:1.6}.step-hint-content,.step-solution-content{animation:fadeIn .3s ease;margin-top:12px;padding:12px 14px}.step-solution-content{background:#818cf814;border-radius:8px}.solution-answer-row{align-items:center;display:flex;gap:10px}.solution-label-text{color:#818cf8;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.solution-answer-row .katex{color:#e5e7eb;font-size:1.1em}.math-completion-card{animation:scaleIn .4s ease;background:linear-gradient(135deg,#34d3991a,#10b9810d);border:1px solid #34d39933;border-radius:16px;margin-top:24px;padding:28px;text-align:center}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.completion-emoji{font-size:48px;margin-bottom:12px}.math-completion-card h3{color:#34d399;font-size:20px;font-weight:700;margin:0 0 6px}.math-completion-card p{color:#9ca3af;font-size:14px;margin:0 0 20px}.final-answer-display{background:#ffffff0d;border-radius:10px;padding:16px}.final-answer-display .final-label{color:#6b7280;font-size:11px;font-weight:700;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}.final-answer-display .katex-display{margin:0}.final-answer-display .katex{color:#f3f4f6;font-size:1.3em}.full-solution-toggle{align-items:center;background:#ffffff08;border:1px solid #ffffff14;border-radius:10px;cursor:pointer;display:flex;justify-content:space-between;margin-top:16px;padding:14px 16px;transition:all .2s ease}.full-solution-toggle:hover{background:#ffffff0d;border-color:#ffffff1f}.full-solution-toggle.expanded{border-bottom-color:#0000;border-radius:10px 10px 0 0}.full-solution-toggle-text{color:#9ca3af;font-size:13px;font-weight:600}.full-solution-toggle-arrow{color:#6b7280;font-size:10px;transition:transform .2s ease}.full-solution-toggle.expanded .full-solution-toggle-arrow{transform:rotate(180deg)}.full-solution-panel{animation:slideDown .3s ease;background:#ffffff05;border:1px solid #ffffff14;border-radius:0 0 10px 10px;border-top:none;padding:16px}.full-solution-steps-list{display:flex;flex-direction:column;gap:12px}.full-solution-step-item{background:#ffffff08;border-radius:8px;padding:14px}.full-step-header{align-items:center;display:flex;gap:10px;margin-bottom:10px}.full-step-badge{background:#818cf826;border-radius:4px;color:#818cf8;font-size:11px;font-weight:700;padding:4px 10px}.full-step-desc{color:#d1d5db;font-size:13px;font-weight:500}.full-step-equation{background:#0003;border-radius:6px;margin:10px 0;padding:10px}.full-step-equation .katex-display{margin:0}.full-step-equation .katex{color:#e5e7eb;font-size:1.05em}.full-step-answer-box{align-items:center;background:#34d3991a;border-radius:6px;display:flex;gap:10px;padding:8px 12px}.full-answer-label{color:#34d399;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.full-step-answer-box .katex{color:#34d399;font-size:1em}.full-solution-final-answer{background:linear-gradient(135deg,#34d39926,#10b9811a);border-radius:10px;margin-top:16px;padding:18px;text-align:center}.full-solution-final-answer .final-answer-title{color:#34d399;font-size:11px;font-weight:700;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}.full-solution-final-answer .katex-display{margin:0}.full-solution-final-answer .katex{color:#f3f4f6;font-size:1.2em}@media (prefers-color-scheme:light){.math-section-title{color:#6b7280}.progress-dot{background:#e5e7eb}.math-step-item{border-bottom-color:#f3f4f6}.math-step-item.active{background:#818cf814}.step-header-row:hover{background:#00000005}.step-header-row.locked:after{background:#374151;color:#f9fafb}.step-header-row.locked:before{border-top-color:#374151}.step-number{background:#e5e7eb}.step-number span{color:#4b5563}.step-description-text{color:#374151}.math-step-item.completed .step-description-text{color:#6b7280}.step-equation-display .katex{color:#1f2937;font-weight:600}.step-completed-answer{background:#34d3991a}.step-chevron{color:#9ca3af}.step-question-label{color:#6b7280}.help-action-btn{border-color:#e5e7eb}.step-hint-content{background:#fbbf2414;color:#b45309}.step-solution-content{background:#818cf814}.solution-answer-row .katex{color:#374151}.math-completion-card{background:linear-gradient(135deg,#34d39914,#10b9810a);border-color:#34d39926}.final-answer-display{background:#00000008}.final-answer-display .katex{color:#1f2937}.full-solution-toggle{background:#fafafa;border-color:#e5e7eb}.full-solution-toggle:hover{background:#f5f5f5}.full-solution-toggle-text{color:#6b7280}.full-solution-panel{background:#fafafa;border-color:#e5e7eb}.full-solution-step-item{background:#fff}.full-step-desc{color:#4b5563}.full-step-equation{background:#f9fafb}.full-step-equation .katex{color:#1f2937}.full-solution-final-answer{background:linear-gradient(135deg,#34d3991a,#10b9810d)}.full-solution-final-answer .katex{color:#1f2937}}@media (max-width:640px){.step-header-row{gap:12px;padding:14px 8px}.step-number{height:28px;min-width:28px;width:28px}.step-number span{font-size:12px}.step-description-text{font-size:13px}.step-expandable-content{padding-left:12px;padding-right:12px}.step-help-actions{align-items:stretch;flex-direction:column}.help-action-btn{max-width:none}.math-completion-card{padding:20px}.completion-emoji{font-size:40px}.math-completion-card h3{font-size:18px}}.code-executor-artifact{animation:slideInFromRight .4s ease-out;background:#1e1e1e;border-radius:12px;box-shadow:0 4px 20px #0000004d;max-width:100%;overflow:hidden}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.code-executor-header{align-items:center;background:linear-gradient(135deg,#2d2d2d,#1e1e1e);border-bottom:1px solid #3e3e3e;display:flex;justify-content:space-between;padding:.75rem 1rem}.header-left{flex:1 1;gap:.75rem}.code-icon{font-size:1.3rem}.header-left h3{color:#e1e1e1;flex:1 1;font-size:1rem;font-weight:600;margin:0}.language-badge{background:linear-gradient(135deg,#4caf50,#45a049);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.code-executor-explanation{background:#252525;border-bottom:1px solid #3e3e3e;color:#b0b0b0;font-size:.9rem;line-height:1.6;padding:.75rem 1rem}.code-executor-explanation p{margin:.5rem 0}.code-executor-explanation strong{color:#4caf50;font-weight:600}.code-executor-explanation code{background:#1e1e1e;border-radius:3px;color:#4caf50;font-family:Fira Code,Courier New,monospace;font-size:.85rem;padding:.15rem .4rem}.explanation-list{list-style:none;margin:.5rem 0;padding:0}.explanation-list li{padding:.4rem 0 .4rem 1.5rem;position:relative}.explanation-list li:before{color:#4caf50;content:"▸";font-weight:700;left:0;position:absolute}.code-executor-content{background:#1a1a1a;display:flex;height:450px;position:relative}.editor-panel{display:flex;flex-direction:column;overflow:hidden;transition:width .05s linear}.editor-wrapper{flex:1 1;overflow:hidden}.resizer{align-items:center;background:#2d2d2d;cursor:col-resize;display:flex;flex-shrink:0;justify-content:center;position:relative;transition:background .2s ease;width:8px}.resizer.resizing,.resizer:hover{background:#4caf50}.resizer-line{background:#555;border-radius:2px;height:40px;pointer-events:none;width:2px}.resizer.resizing .resizer-line,.resizer:hover .resizer-line{background:#fff}.side-panel{background:#1a1a1a;display:flex;flex:1 1;flex-direction:column;min-width:150px}.editor-actions{background:#252525;border-top:1px solid #3e3e3e;display:flex;gap:.5rem;padding:.75rem}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex-shrink:0;font-size:.9rem;font-weight:500;gap:.4rem;justify-content:center;max-width:none;min-width:44px;padding:.6rem 1rem;transition:all .2s ease;white-space:nowrap}.action-btn.compact{min-width:44px;padding:.6rem;width:44px}.btn-text{flex-shrink:0}.run-btn{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 2px 8px #4caf504d;color:#fff}.run-btn:not(.compact){flex:2 1}.run-btn:hover:not(:disabled){box-shadow:0 4px 12px #4caf5066;transform:translateY(-2px)}.run-btn:disabled{cursor:not-allowed;opacity:.7}.copy-btn,.reset-btn{background:#3e3e3e;color:#e1e1e1}.copy-btn:not(.compact),.reset-btn:not(.compact){flex:1 1}.copy-btn:hover,.reset-btn:hover{background:#4e4e4e;transform:translateY(-2px)}.panel-tabs{background:#252525;border-bottom:1px solid #3e3e3e;display:flex}.panel-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#888;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:500;padding:.6rem;transition:all .2s ease}.panel-tab.active{background:#1e1e1e;border-bottom-color:#4caf50;color:#4caf50}.panel-tab:hover{background:#2d2d2d}.panel-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.input-panel,.output-panel{display:flex;flex-direction:column;height:100%}.panel-label{background:#1e1e1e;border-bottom:1px solid #3e3e3e;color:#888;display:block;font-size:.8rem;padding:.5rem 1rem}.input-textarea{background:#1e1e1e;border:none;color:#e1e1e1;flex:1 1;font-family:Fira Code,Courier New,monospace;font-size:.9rem;outline:none;padding:1rem;resize:none;width:100%}.input-textarea::placeholder{color:#555}.stats-bar{background:#1e1e1e;border-bottom:1px solid #3e3e3e;display:flex;gap:1rem;padding:.5rem 1rem}.stat{color:#4caf50;font-size:.8rem;font-weight:500}.output-display{flex:1 1;overflow-y:auto;padding:1rem}.output-loading{color:#888;flex-direction:column;gap:1rem}.output-loading,.output-placeholder{align-items:center;display:flex;height:100%;justify-content:center}.output-placeholder{color:#666;font-size:.9rem;padding:2rem;text-align:center}.output-error,.output-success{animation:fadeIn .3s ease-in}.error-header,.success-header{font-size:.9rem;font-weight:600;margin-bottom:.75rem}.success-header{color:#4caf50}.error-header{color:#f44336}.output-error pre,.output-success pre{background:#252525;border-left:3px solid #4caf50;border-radius:6px;color:#e1e1e1;font-family:Fira Code,Courier New,monospace;font-size:.85rem;line-height:1.6;margin:0;overflow-x:auto;padding:1rem}.output-error pre{border-left-color:#f44336;color:#ffcdd2}.expected-section{background:#1e1e1e;border-top:1px solid #3e3e3e;padding:.5rem}.collapse-btn{background:#0000;border:none;color:#888;cursor:pointer;font-size:.8rem;padding:.5rem;text-align:left;transition:color .2s ease;width:100%}.collapse-btn:hover{color:#4caf50}.expected-output{background:#252525;border-left:3px solid #2196f3;border-radius:4px;color:#b0b0b0;font-family:Fira Code,Courier New,monospace;font-size:.85rem;line-height:1.6;margin:.5rem 0 0;overflow-x:auto;padding:.75rem}.spinner-small{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:12px;width:12px}.spinner-large{animation:spin .8s linear infinite;border:4px solid #4caf504d;border-radius:50%;border-top-color:#4caf50;display:inline-block;height:40px;width:40px}.input-textarea::-webkit-scrollbar,.output-display::-webkit-scrollbar{height:6px;width:6px}.input-textarea::-webkit-scrollbar-track,.output-display::-webkit-scrollbar-track{background:#1e1e1e}.input-textarea::-webkit-scrollbar-thumb,.output-display::-webkit-scrollbar-thumb{background:#4e4e4e;border-radius:3px}.input-textarea::-webkit-scrollbar-thumb:hover,.output-display::-webkit-scrollbar-thumb:hover{background:#5e5e5e}@media (max-width:1024px){.code-executor-content{flex-direction:column;height:auto}.editor-panel{border-bottom:1px solid #3e3e3e;width:100%!important}.resizer{display:none}.side-panel{min-height:300px}}@media (max-width:768px){.code-executor-header{align-items:flex-start;flex-direction:column;gap:.5rem}.header-left{width:100%}.code-executor-explanation,.explanation-list li{font-size:.85rem}.language-badge{font-size:.7rem;padding:.2rem .6rem}.side-panel{min-height:250px}.output-display{padding:.75rem}.action-btn{font-size:.85rem;padding:.5rem .75rem}}.writing-pad-artifact{animation:fadeSlideIn .3s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #00000014,0 4px 12px #0000000a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;max-width:100%;overflow:hidden;transition:all .2s ease}.writing-pad-artifact:hover{border-color:#d1d5db;box-shadow:0 2px 6px #0000001a,0 8px 20px #0000000f}.writing-pad-header{align-items:center;background:#fafafa;border-bottom:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:space-between;padding:.75rem 1rem}.writing-pad-title{align-items:center;display:flex;flex:1 1;gap:.5rem;min-width:0}.writing-pad-icon{flex-shrink:0;font-size:1.25rem}.writing-pad-title h3{color:#374151;font-size:.95rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.writing-pad-controls{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.writing-pad-stats{font-feature-settings:"tnum";color:#6b7280;font-size:.75rem;font-variant-numeric:tabular-nums;font-weight:500;gap:.5rem}.stat-item,.writing-pad-stats{align-items:center;display:flex}.stat-item{background:#f3f4f6;border-radius:4px;cursor:default;padding:.25rem .5rem;transition:all .15s ease;white-space:nowrap}.stat-item:hover{background:#e5e7eb;transform:translateY(-1px)}.copy-button{align-items:center;background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;min-width:36px;padding:.4rem .6rem;transition:all .2s ease}.copy-button:hover{background:#2563eb;transform:translateY(-1px)}.copy-button:active{transform:translateY(0)}.copy-button.success{background:#10b981}.writing-pad-content{background:#fff;padding:1rem;position:relative}.writing-pad-content:before{background:linear-gradient(#0000 1.4rem,#f3f4f6 0);background-size:100% 1.5rem;bottom:0;content:"";left:0;opacity:.3;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.writing-textarea{background:#0000;border:none;color:#1f2937;font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Helvetica Neue,Arial,sans-serif;font-size:.95rem;line-height:1.5rem;min-height:120px;outline:none;overflow:hidden;padding:0;position:relative;resize:none;width:100%;z-index:1}.writing-textarea::placeholder{color:#9ca3af;font-style:italic}.writing-textarea:focus{outline:none}@media (max-width:768px){.writing-pad-artifact{border-radius:6px}.writing-pad-header{gap:.75rem;padding:.625rem .875rem}.writing-pad-title h3{font-size:.9rem}.writing-pad-icon{font-size:1.15rem}.writing-pad-stats{font-size:.7rem;gap:.375rem}.stat-item{padding:.2rem .4rem}.copy-button{font-size:.95rem;height:28px;min-width:32px;padding:.35rem .5rem}.writing-pad-content{padding:.875rem}.writing-textarea{font-size:.9rem;min-height:100px}}@media (max-width:480px){.writing-pad-header{flex-wrap:wrap;padding:.5rem .75rem}.writing-pad-title{margin-bottom:.5rem;order:1;width:100%}.writing-pad-controls{justify-content:space-between;order:2;width:100%}.writing-pad-stats{font-size:.7rem;gap:.375rem}.writing-pad-content{padding:.75rem}.writing-textarea{font-size:.875rem;min-height:80px}}@media (hover:none) and (pointer:coarse){.copy-button{min-height:40px;min-width:40px}}*{-webkit-tap-highlight-color:transparent}.writing-textarea{-webkit-appearance:none;appearance:none}.writing-textarea::selection{background:#dbeafe;color:#1f2937}.artifact-container{animation:fadeSlideIn .4s ease-out}.inline-artifact .artifact-container{margin:0}.message-wrapper{align-items:flex-start;animation:fadeSlideIn .3s ease-out;display:flex;gap:.75rem;margin-bottom:1.5rem;position:relative;z-index:1}.user-message-wrapper{flex-direction:row-reverse;justify-content:flex-start}.assistant-message-wrapper{flex-direction:row;justify-content:flex-start}.message-avatar{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;width:40px}.assistant-avatar{background:#0000;padding:0}.mascot-avatar{height:100%;object-fit:contain;width:100%}.message-bubble{max-width:85%;padding:.875rem 1.125rem}.user-bubble{background:#6366f1;border-bottom-right-radius:6px;box-shadow:0 2px 8px #6366f133;color:#fff}.assistant-bubble{background:#fff;border-bottom-left-radius:6px;box-shadow:0 2px 8px #00000014;color:#1e293b}.artifact-only-bubble{background:#0000;box-shadow:none;max-width:100%!important;padding:0}.artifact-only-bubble .message-time{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;display:inline-block;padding:0 .5rem}.message-content{font-size:.95rem;line-height:1.5}.streaming-content{position:relative}.streaming-cursor{animation:cursorBlink .8s infinite;color:#6366f1;vertical-align:initial}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}.message-content h2{color:#6366f1;font-size:1.25rem;font-weight:700;letter-spacing:-.01em;line-height:1.3;margin:.5rem 0 .25rem}.assistant-bubble .message-content h2{color:#6366f1}.user-bubble .message-content h2{color:#fffffffa}.message-content h3{color:#6366f1;font-size:1.08rem;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin:.4rem 0 .2rem}.assistant-bubble .message-content h3{color:#6366f1}.user-bubble .message-content h3{color:#fffffff2}.message-content h4{color:#6366f1;font-size:.98rem;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin:.3rem 0 .15rem}.assistant-bubble .message-content h4{color:#6366f1}.user-bubble .message-content h4{color:#ffffffeb}.message-content h2:first-child,.message-content h3:first-child,.message-content h4:first-child{margin-top:0}.message-content strong{color:inherit;font-weight:700}.message-content em{font-style:italic}.message-content p{margin:.2rem 0}.message-content p:first-child{margin-top:0}.message-content p:last-child{margin-bottom:0}.message-content .inline-code{background:#ffffff1a;border-radius:3px;color:#e83e8c;font-family:Consolas,Monaco,Courier New,monospace;font-size:.875em;padding:.2em .4em}.assistant-bubble .inline-code{background:#f3f4f6;color:#d63384}.user-bubble .inline-code{background:#fff3;color:#fff}.message-content .code-block{background:#1e1e1e;border-radius:6px;box-shadow:0 2px 4px #0000001a;margin:.75rem 0;overflow-x:auto;padding:1rem}.message-content .code-block code{color:#d4d4d4;display:block;font-family:Consolas,Monaco,Courier New,monospace;font-size:.875rem;line-height:1.5;white-space:pre}.message-content .inline-math-container,.message-content .math-block-container{display:inline-block;margin:0 2px}.message-content .math-block-container{display:block;margin:12px 0;text-align:center}.message-content .inline-math-rendered,.message-content .math-block-rendered{display:inline-block}.message-content .math-block-rendered{background:#667eea0d;border-left:3px solid #667eea;border-radius:8px;display:block;padding:12px}.user-bubble .math-block-rendered{background:#ffffff1a;border-left-color:#ffffff80}.message-content .katex{font-size:1.1em}.assistant-bubble .katex{color:#1e293b}.user-bubble .katex{color:#fff}.message-content .katex-display{margin:8px 0}.inline-artifact{border-top:1px solid #00000014;margin-top:1rem;overflow:hidden;padding-top:1rem;width:100%}.assistant-bubble .inline-artifact{border-top-color:#00000014}.user-bubble .inline-artifact{border-top-color:#fff3}.artifact-only-bubble .inline-artifact{border-top:none;margin-top:0;padding-top:0}.message-time{font-size:.7rem;font-weight:500;margin-top:.4rem;opacity:.65}.user-bubble .message-time{color:#ffffffbf;text-align:right}.assistant-bubble .message-time{color:#94a3b8}.system-message{margin:1rem 0;text-align:center}.system-message-content{background:#3b82f61a;border-radius:16px;color:#3b82f6;display:inline-block;font-size:.875rem;font-weight:500;padding:.5rem 1rem}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.processing-message{overflow:hidden;position:relative}.processing-message:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#3b82f600,#3b82f61a 50%,#3b82f600);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}.enhanced-loading-container{display:flex;flex-direction:column;gap:8px;margin-top:8px}.processing-indicator{align-items:center;background:#3b82f61a;border-radius:8px;color:#3b82f6;display:inline-flex;font-size:.875rem;gap:4px;padding:8px 12px}.processing-indicator span{animation:pulse 1.4s ease-in-out infinite;background:#3b82f6;border-radius:50%;height:6px;width:6px}.processing-indicator span:nth-child(2){animation-delay:.2s}.processing-indicator span:nth-child(3){animation-delay:.4s}.loading-message{animation:fadeInMessage .5s ease-in;color:#6b7280;font-size:.875rem;font-style:italic;padding:0 12px}.document-processing-skeleton{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border:2px solid #3b82f633;border-radius:12px;padding:1.5rem}.skeleton-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.skeleton-icon{animation:gentle-bounce 2s ease-in-out infinite;font-size:2.5rem}.skeleton-text-container{flex:1 1}.skeleton-title{color:#1f2937;font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.skeleton-subtitle{color:#6b7280;font-size:.9rem}.skeleton-steps{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.skeleton-step{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:.75rem;opacity:.7;padding:.75rem 1rem}.skeleton-step-icon{font-size:1.25rem}.skeleton-step-text{color:#4b5563;font-size:.9rem}.skeleton-pulse{animation:skeleton-fade 2s ease-in-out infinite}.skeleton-delay-1{animation-delay:.3s}.skeleton-delay-2{animation-delay:.6s}.skeleton-progress{margin-top:1rem}.skeleton-progress-bar{background:#3b82f61a;border-radius:3px;height:6px;margin-bottom:.5rem;overflow:hidden}.skeleton-progress-fill{animation:progress-fill 12s ease-in-out infinite;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:3px;height:100%}.skeleton-time{color:#6b7280;font-size:.85rem;font-style:italic;text-align:center}@keyframes skeleton-fade{0%,to{opacity:.5}50%{opacity:1}}@keyframes gentle-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes progress-fill{0%{width:0}80%{width:95%}to{width:100%}}@media (max-width:768px){.message-wrapper{align-items:center;flex-direction:column!important;gap:.5rem;margin-bottom:1rem}.assistant-message-wrapper{align-items:flex-start}.user-message-wrapper{align-items:flex-end}.message-bubble{max-width:100%;padding:.875rem 1rem;width:100%}.artifact-only-bubble{width:auto}.message-avatar{flex-shrink:0;font-size:1.25rem;height:32px;margin-bottom:.25rem;width:32px}.message-content{font-size:.9rem}}.document-processing-animated{background:linear-gradient(135deg,#3b82f614,#8b5cf614);border:2px solid #3b82f640;border-radius:16px;max-width:500px;padding:1.75rem}.processing-header{align-items:center;border-bottom:1px solid #3b82f626;display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.processing-icon-large{animation:gentle-pulse 2.5s ease-in-out infinite;font-size:3rem}.processing-title-container{flex:1 1}.processing-filename{color:#1f2937;font-size:1.1rem;font-weight:600;line-height:1.3;margin-bottom:.25rem}.processing-filesize{color:#6b7280;font-size:.85rem;font-weight:500}.processing-message-rotating{align-items:center;animation:messageSlideIn .5s ease-out;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:1rem;margin-bottom:1.5rem;min-height:80px;padding:1.25rem}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rotating-emoji{animation:emojiRotate 3s ease-in-out infinite;font-size:2.5rem}@keyframes emojiRotate{0%,to{transform:rotate(0deg) scale(1)}25%{transform:rotate(-10deg) scale(1.1)}75%{transform:rotate(10deg) scale(1.1)}}.rotating-text{flex:1 1}.rotating-main{color:#1f2937;font-size:1.05rem;font-weight:600;margin-bottom:.25rem}.rotating-sub{color:#6b7280;font-size:.9rem;font-style:italic}.processing-progress-steps{display:flex;gap:.5rem;justify-content:space-between;margin-bottom:1.25rem;padding:0 .5rem}.progress-step{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:.5rem;opacity:.4;transition:opacity .3s ease}.progress-step.active{opacity:1}.step-icon-container{align-items:center;background:#e5e7eb;border-radius:50%;color:#9ca3af;display:flex;font-size:.9rem;font-weight:600;height:32px;justify-content:center;transition:all .3s ease;width:32px}.progress-step.active .step-icon-container{background:linear-gradient(135deg,#3b82f6,#8b5cf6);box-shadow:0 2px 8px #3b82f666;color:#fff}.progress-step.done .step-icon-container{background:#10b981;color:#fff}.step-spinner{animation:spin .8s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;height:14px;width:14px}@keyframes fadeInMessage{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.step-label{color:#6b7280;font-size:.75rem;font-weight:500;text-align:center}.progress-step.active .step-label{color:#1f2937;font-weight:600}.processing-estimate{align-items:center;background:#3b82f61a;border-radius:8px;color:#1f2937;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1rem}.estimate-icon{font-size:1.1rem}@media (max-width:768px){.document-processing-animated{padding:1.25rem}.processing-icon-large{font-size:2.5rem}.processing-filename{font-size:1rem}.processing-message-rotating{min-height:70px;padding:1rem}.rotating-emoji{font-size:2rem}.rotating-main{font-size:.95rem}.rotating-sub{font-size:.85rem}.processing-progress-steps{gap:.25rem;padding:0}.step-icon-container{height:28px;width:28px}.step-label{font-size:.7rem}.processing-estimate{font-size:.85rem;padding:.625rem .875rem}}.message-attachment{align-items:center;background:#ffffff26;border:1px solid #fff3;border-radius:10px;display:flex;gap:.625rem;margin-bottom:.5rem;padding:.625rem .875rem}.message-attachment .attachment-icon{flex-shrink:0;font-size:1.25rem}.message-attachment .attachment-info{display:flex;flex:1 1;flex-direction:column;gap:.125rem;min-width:0}.message-attachment .attachment-name{color:#fff;font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-attachment .attachment-size{color:#ffffffbf;font-size:.75rem}.message-image{border-radius:12px;margin-bottom:.5rem;overflow:hidden}.user-attached-image{border-radius:12px;display:block;max-height:300px;max-width:100%;object-fit:contain}@media (max-width:768px){.user-attached-image{max-height:200px}}.chat-input-container{background:#0000;bottom:0;left:260px;padding:1rem 1.5rem 1.25rem;pointer-events:none;position:fixed;right:0;transition:left .3s cubic-bezier(.4,0,.2,1);z-index:50}.chat-input-container.dragging{pointer-events:auto}.drag-overlay{align-items:center;animation:dragOverlayIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#3b82f614;border-radius:20px;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:-100px;z-index:100}@keyframes dragOverlayIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.drag-overlay-content{align-items:center;background:#fff;border:2px dashed #3b82f6;border-radius:16px;box-shadow:0 8px 32px #3b82f633;display:flex;flex-direction:column;gap:.75rem;padding:2rem 3rem}.drag-overlay-content svg{animation:bounceUp .6s ease-in-out infinite alternate;color:#3b82f6;height:48px;width:48px}@keyframes bounceUp{0%{transform:translateY(4px)}to{transform:translateY(-4px)}}.drag-overlay-content span{color:#3b82f6;font-size:1rem;font-weight:600}body.sidebar-collapsed .chat-input-container{left:72px}.panel-open .chat-input-container{right:360px}@media (max-width:768px){.chat-input-container{left:0!important;padding:.75rem .75rem 1rem}.panel-open .chat-input-container{right:0}}.attached-document-preview{align-items:center;animation:slideInUp .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;display:flex;gap:.625rem;margin:0 auto .625rem;max-width:780px;padding:.625rem .875rem;pointer-events:auto}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.attachment-icon{flex-shrink:0;font-size:1.25rem}.attachment-info{display:flex;flex:1 1;flex-direction:column;gap:.0625rem;min-width:0}.attachment-name{color:#1e293b;font-size:.8125rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-size{color:#64748b;font-size:.6875rem}.remove-attachment-btn{align-items:center;background:#0000;border:none;border-radius:5px;color:#9ca3af;cursor:pointer;display:flex;flex-shrink:0;height:26px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:26px}.remove-attachment-btn:hover{background:#ef44441a;color:#ef4444;transform:scale(1.05)}.remove-attachment-btn svg{height:14px;width:14px}.chat-input-form{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border:1px solid #e5e7ebcc;border-radius:28px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;display:flex;gap:.625rem;margin:0 auto;max-width:780px;padding:.5rem;pointer-events:auto;transition:all .3s cubic-bezier(.4,0,.2,1)}.chat-input-form:focus-within{background:#fffffffa;border-color:#3b82f699;box-shadow:0 12px 40px #3b82f633,0 4px 12px #3b82f61f}.attach-button-wrapper{flex-shrink:0;position:relative}.attach-button{align-items:center;background:#f9fafb;border:none;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:38px}.attach-button:hover:not(:disabled){background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);transform:scale(1.05)}.attach-button:disabled{cursor:not-allowed;opacity:.4}.attach-button svg{color:#64748b;height:18px;width:18px}.upload-dropdown{animation:dropdownSlideUp .2s ease-out;background:#fff;border-radius:12px;bottom:calc(100% + 8px);box-shadow:0 8px 24px #00000026;left:0;min-width:240px;padding:.5rem;position:absolute;z-index:100}.upload-option{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;text-align:left;transition:all .15s;width:100%}.upload-option:hover{background:linear-gradient(135deg,#3b82f614,#8b5cf614)}.upload-option+.upload-option{margin-top:.25rem}.option-icon{font-size:1.5rem}.option-text{display:flex;flex-direction:column;gap:.125rem}.option-title{align-items:center;color:#1e293b;display:flex;font-size:.875rem;font-weight:600;gap:.375rem}.option-desc{color:#64748b;font-size:.75rem}.image-button{align-items:center;background:#f9fafb;border:none;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:38px}.image-button:hover:not(:disabled){background:linear-gradient(135deg,#10b9811a,#3b82f61a);transform:scale(1.05)}.image-button:disabled{cursor:not-allowed;opacity:.4}.image-button svg{color:#64748b;height:18px;width:18px}.image-button-wrapper{flex-shrink:0;position:relative}.image-dropdown{animation:dropdownSlideUp .2s ease-out;background:#fff;border-radius:12px;bottom:calc(100% + 8px);box-shadow:0 8px 24px #00000026;left:50%;min-width:160px;padding:.5rem;position:absolute;transform:translateX(-50%);z-index:100}.image-option{align-items:center;background:#0000;border:none;border-radius:8px;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.625rem;padding:.625rem .75rem;text-align:left;transition:all .15s;width:100%}.image-option:hover{background:linear-gradient(135deg,#10b98114,#3b82f614)}.image-option+.image-option{margin-top:.25rem}.image-option svg{color:#64748b;flex-shrink:0;height:18px;width:18px}.attached-image-preview{align-items:center;animation:slideInUp .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;display:flex;gap:.625rem;margin:0 auto .625rem;max-width:780px;padding:.625rem .875rem;pointer-events:auto}.image-preview-thumbnail{border:1px solid #e5e7eb;border-radius:8px;flex-shrink:0;height:48px;object-fit:cover;width:48px}.chat-input-field{background:#0000;border:none;color:#1e293b;flex:1 1;font-family:inherit;font-size:.9375rem;line-height:1.5;max-height:120px;outline:none;padding:.625rem .5rem;resize:none;transition:all .2s}.chat-input-field:disabled{cursor:not-allowed;opacity:.5}.chat-input-field::placeholder{color:#9ca3af}.send-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:50%;box-shadow:0 2px 6px #3b82f64d;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);width:38px}.send-button:hover:not(:disabled){box-shadow:0 4px 14px #3b82f673;transform:scale(1.08) translateY(-1px)}.send-button:active:not(:disabled){transform:scale(1.02)}.send-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.35;transform:none}.send-button svg{color:#fff;height:18px;width:18px}@media (max-width:768px){.drag-overlay{border-radius:16px;top:-80px}.drag-overlay-content{padding:1.5rem 2rem}.drag-overlay-content svg{height:36px;width:36px}.drag-overlay-content span{font-size:.875rem}.attached-image-preview{border-radius:10px;margin-bottom:.5rem;padding:.5rem .75rem}.image-preview-thumbnail{height:40px;width:40px}.image-button{height:36px;width:36px}.image-button svg{height:16px;width:16px}.attached-document-preview{border-radius:10px;margin-bottom:.5rem;padding:.5rem .75rem}.attachment-icon{font-size:1.125rem}.attachment-name{font-size:.75rem}.attachment-size{font-size:.625rem}.remove-attachment-btn{height:24px;width:24px}.remove-attachment-btn svg{height:13px;width:13px}.chat-input-form{background:#fffffffa;border-radius:24px;box-shadow:0 6px 24px #0000001a,0 2px 6px #0000000f;gap:.5rem;padding:.4375rem}.chat-input-form:focus-within{box-shadow:0 10px 32px #3b82f62e,0 4px 10px #3b82f61a}.attach-button,.send-button{height:36px;width:36px}.attach-button svg,.send-button svg{height:16px;width:16px}.chat-input-field{font-size:16px;padding:.5rem .375rem}.upload-dropdown{border-radius:10px;min-width:210px;padding:.375rem}.upload-option{border-radius:7px;padding:.625rem}.option-icon{font-size:1.25rem}.option-title{font-size:.75rem}.option-desc{font-size:.625rem}.image-dropdown{border-radius:10px;min-width:140px;padding:.375rem}.image-option{font-size:.8125rem;gap:.5rem;padding:.5rem .625rem}.image-option svg{height:16px;width:16px}}.document-overlay{animation:fadeIn .2s ease-out forwards;background:#00000080;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;z-index:44}.document-sections-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffffa;border-left:none;border-radius:20px 0 0 20px;bottom:0;box-shadow:-8px 0 40px #0000001f,-2px 0 8px #0000000f;display:flex;flex-direction:column;max-width:90vw;overflow:hidden;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:360px;z-index:999}.document-sections-panel.open{transform:translateX(0)}.document-panel-header{background:#0000;border-bottom:1px solid #e5e7eb80;flex-shrink:0;padding:1rem 1.25rem}.header-top{margin-bottom:.5rem}.header-title-row{align-items:center;display:flex;gap:.5rem;margin-bottom:.375rem}.header-title-row>svg{color:#3b82f6;flex-shrink:0;height:16px;width:16px}.header-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;flex:1 1;font-size:.8125rem;font-weight:700;margin:0}.header-meta{align-items:center;display:flex;gap:.375rem;padding-left:1.5rem}.document-name{color:#64748b;font-size:.625rem;font-weight:500;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meta-divider{color:#d1d5db;font-size:.625rem}.concept-count{color:#9ca3af;font-size:.625rem;font-weight:500;white-space:nowrap}.panel-close-btn{align-items:center;background:#0000;border:none;border-radius:5px;color:#9ca3af;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;margin-left:auto;transition:all .2s cubic-bezier(.4,0,.2,1);width:24px}.panel-close-btn:hover{background:#f3f4f6;color:#1e293b}.panel-close-btn svg{height:14px;width:14px}.inline-progress{align-items:center;display:flex;gap:.5rem;padding-left:1.5rem}.inline-progress .progress-bar{background:#e5e7eb;border-radius:2px;flex:1 1;height:4px;overflow:hidden}.inline-progress .progress-fill{background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:2px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.inline-progress .progress-percentage{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#3b82f6);-webkit-background-clip:text;background-clip:text;font-size:.6875rem;font-weight:700;min-width:32px;text-align:right}.document-summary{background:#0000;border-bottom:1px solid #f3f4f680;flex-shrink:0}.summary-toggle{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:flex;font-size:.6875rem;font-weight:600;gap:.375rem;padding:.625rem .875rem;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.summary-toggle:hover{background:#fafbfc}.summary-toggle>svg:first-child{color:#ea580c;flex-shrink:0;height:13px;width:13px}.summary-toggle span{color:#64748b;flex:1 1}.toggle-arrow{color:#9ca3af;flex-shrink:0;height:12px;transition:transform .2s cubic-bezier(.4,0,.2,1);width:12px}.summary-text{animation:expandDown .2s ease-out;color:#64748b;font-size:.6875rem;line-height:1.5;margin:0;padding:0 .875rem .625rem 2.125rem}.sections-list{background:#0000;flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:.75rem 1rem}.sections-list::-webkit-scrollbar{width:4px}.sections-list::-webkit-scrollbar-track{background:#0000}.sections-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}.sections-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.sections-list-header{color:#9ca3af;font-size:.625rem;font-weight:700;letter-spacing:.05em;padding:.375rem .5rem .5rem;text-transform:uppercase}.section-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb3;border:1px solid #e5e7eb99;border-radius:14px;box-shadow:0 2px 8px #0000000a;margin-bottom:.5rem;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.section-card:hover{background:#ffffffd9;border-color:#d1d5dbcc;box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.section-card.active{background:linear-gradient(135deg,#3b82f614,#8b5cf614);border-color:#3b82f666;box-shadow:0 4px 20px #3b82f626,0 2px 8px #3b82f61a}.section-card.completed{background:linear-gradient(135deg,#10b9810d,#34d3990d);border-color:#10b9814d}.section-card-header{align-items:center;display:flex;gap:.5rem;padding:.625rem}.section-status-badge{align-items:center;background:#f3f4f6;border-radius:5px;color:#9ca3af;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:26px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:26px}.section-card.active .section-status-badge{background:linear-gradient(135deg,#3b82f6,#8b5cf6);box-shadow:0 2px 5px #3b82f640;color:#fff}.section-card.completed .section-status-badge{background:#10b981;color:#fff}.section-status-badge svg{height:14px;width:14px}.section-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.section-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#1e293b;display:-webkit-box;font-size:.75rem;font-weight:600;line-height:1.35;margin:0;overflow:hidden}.difficulty-badge{border-radius:8px;display:inline-block;font-size:.5625rem;font-weight:700;letter-spacing:.025em;padding:.0625rem .375rem;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.difficulty-badge.beginner{background:#dcfce7;color:#16a34a}.difficulty-badge.intermediate{background:#fef3c7;color:#d97706}.difficulty-badge.advanced{background:#fecaca;color:#dc2626}.current-badge{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:8px;color:#fff;display:inline-block;font-size:.5625rem;font-weight:700;letter-spacing:.025em;padding:.0625rem .375rem;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.section-actions{align-items:center;display:flex;flex-shrink:0;gap:.125rem}.expand-btn,.jump-btn{align-items:center;background:#0000;border:none;border-radius:5px;color:#9ca3af;cursor:pointer;display:flex;height:26px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:26px}.jump-btn:hover{background:#3b82f61a;color:#3b82f6;transform:scale(1.05)}.expand-btn:hover{color:#64748b}.expand-btn svg{transition:transform .2s cubic-bezier(.4,0,.2,1)}.expand-btn svg,.jump-btn svg{height:14px;width:14px}.section-card-content{animation:slideDown .2s ease-out;background:#fafbfc;border-top:1px solid #f3f4f6;overflow:hidden;padding:0}.module-details{color:#64748b;font-size:.75rem;padding:.75rem}.module-section{margin-bottom:.75rem}.module-section:last-child{margin-bottom:0}.module-section-header{align-items:center;color:#475569;display:flex;font-size:.6875rem;font-weight:600;gap:.25rem;margin-bottom:.375rem}.section-icon{font-size:.8125rem}.module-description{background:#fff;border-left:2px solid #3b82f6;border-radius:5px;color:#64748b;font-size:.75rem;line-height:1.45;margin:0;padding:.5rem}.objectives-list{list-style-type:none;margin:0;padding-left:1rem}.objectives-list li{color:#64748b;font-size:.75rem;line-height:1.4;margin-bottom:.3rem;padding-left:.375rem;position:relative}.objectives-list li:before{color:#3b82f6;content:"•";font-weight:700;left:-.875rem;position:absolute}.concepts-tags{display:flex;flex-wrap:wrap;gap:.25rem}.concept-tag{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;color:#64748b;display:inline-flex;font-size:.625rem;font-weight:500;padding:.1875rem .5rem;text-transform:capitalize;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.concept-tag:hover{background:#f0f9ff;border-color:#bfdbfe;color:#3b82f6;transform:translateY(-1px)}.more-tag{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;color:#fff;font-weight:600}.more-tag:hover{background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 2px 4px #3b82f633;transform:translateY(-1px)}.module-time-estimate{align-items:center;background:#f0f9ff;border:1px solid #dbeafe;border-radius:5px;color:#64748b;display:flex;font-size:.6875rem;gap:.25rem;margin-top:.625rem;padding:.375rem .625rem}.time-icon{font-size:.8125rem}@media (max-width:768px){.document-sections-panel{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff;border-radius:0;max-width:100vw;width:100%}.document-panel-header{padding:.625rem .75rem}.header-title-row{gap:.375rem;margin-bottom:.3rem}.header-title-row>svg{height:14px;width:14px}.header-title{font-size:.75rem}.header-meta{gap:.3rem;padding-left:1.25rem}.document-name{max-width:140px}.concept-count,.document-name{font-size:.5625rem}.panel-close-btn{height:40px;width:40px}.panel-close-btn svg{height:20px;width:20px}.inline-progress{gap:.375rem;padding-left:1.25rem}.inline-progress .progress-bar{height:3px}.inline-progress .progress-percentage{font-size:.625rem;min-width:28px}.summary-toggle{font-size:.625rem;gap:.3rem;padding:.5rem .75rem}.summary-toggle>svg:first-child{height:12px;width:12px}.toggle-arrow{height:11px;width:11px}.summary-text{font-size:.625rem;padding:0 .75rem .5rem 1.875rem}.sections-list{padding:.5rem}.sections-list-header{font-size:.5625rem;padding:.25rem .375rem .375rem}.section-card{border-radius:7px;margin-bottom:.3rem}.section-card-header{gap:.375rem;padding:.5rem}.section-status-badge{font-size:.6875rem;height:24px;width:24px}.section-status-badge svg{height:12px;width:12px}.section-title{font-size:.6875rem}.current-badge,.difficulty-badge{font-size:.5rem;padding:.0625rem .3125rem}.expand-btn,.jump-btn{height:24px;width:24px}.expand-btn svg,.jump-btn svg{height:12px;width:12px}.module-details{font-size:.6875rem;padding:.625rem}.module-section{margin-bottom:.625rem}.module-section-header{font-size:.625rem;gap:.1875rem}.section-icon{font-size:.75rem}.module-description{font-size:.6875rem;padding:.4375rem}.objectives-list{padding-left:.875rem}.objectives-list li{font-size:.6875rem;margin-bottom:.25rem}.concept-tag{font-size:.5625rem;padding:.125rem .375rem}.module-time-estimate{font-size:.625rem;padding:.3125rem .5rem}.time-icon{font-size:.75rem}}@media (min-width:769px){.document-overlay{display:none}}.step-renderer{display:flex;flex-direction:column;min-height:400px;padding:48px 64px}.step-content-wrapper{margin:0 auto;max-width:700px;width:100%}.step-heading{align-items:flex-start;display:flex;gap:16px;margin-bottom:32px}.step-emoji{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0;font-size:48px}.step-heading h2{color:#0f172a;font-size:32px;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin:0}.step-text{font-size:18px;line-height:1.75;margin-bottom:32px}.step-text p{margin:0 0 20px}.step-text ul{list-style:none;margin:24px 0;padding:0}.step-text li{line-height:1.6;padding:12px 0 12px 36px;position:relative}.step-text li:before{color:#667eea;content:"•";font-size:20px;font-weight:700;left:12px;line-height:1.6;position:absolute}.step-artifact{background:#fff;border-radius:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #0000000d;margin:40px 0;padding:32px;transition:all .3s cubic-bezier(.16,1,.3,1)}.step-artifact:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d,0 0 0 1px #667eea1a;transform:translateY(-2px)}.interactive-hint{align-items:center;background:#667eea0d;border-radius:16px;color:#667eea;display:flex;font-size:15px;font-weight:500;gap:12px;margin-top:32px;padding:16px 24px}.interactive-hint svg{stroke-width:2;flex-shrink:0;height:20px;width:20px}@media (max-width:768px){.step-renderer{min-height:300px;padding:32px 24px}.step-heading{gap:12px;margin-bottom:24px}.step-emoji{font-size:36px}.step-heading h2{font-size:24px}.step-text{font-size:16px;line-height:1.7}.step-text li{padding-left:28px}.step-artifact{margin:32px 0;padding:24px}.interactive-hint{font-size:14px;padding:14px 20px}}.step-renderer>*{will-change:transform,opacity}.qa-panel-overlay{bottom:0;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:10001}.qa-panel{bottom:20px;flex-direction:column;gap:12px;padding:20px;pointer-events:auto;width:450px}.close-panel-btn,.qa-panel{display:flex;position:absolute;right:20px;top:20px}.close-panel-btn{align-items:center;background:#fff;border:none;border-radius:50%;box-shadow:0 4px 12px #00000014;color:#64748b;cursor:pointer;height:36px;justify-content:center;transition:all .2s ease;width:36px;z-index:100}.close-panel-btn:hover{background:#f1f5f9;color:#334155;transform:scale(1.05)}.close-panel-btn svg{stroke-width:2.5;height:18px;width:18px}.qa-messages{display:flex;flex:1 1;flex-direction:column;gap:10px;overflow-y:auto;padding:50px 0 0}.qa-messages::-webkit-scrollbar{width:3px}.qa-messages::-webkit-scrollbar-track{background:#0000}.qa-messages::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.qa-message-group{display:flex;flex-direction:column;gap:10px}.qa-message{animation:slideIn .3s ease;display:flex}.qa-message.user{justify-content:flex-end}.qa-message.ai{justify-content:flex-start}.message-bubble{word-wrap:break-word;border-radius:18px;box-shadow:0 3px 10px #00000014;font-size:14px;line-height:1.6;max-width:90%;padding:12px 16px}.qa-message.user .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom-right-radius:6px;color:#fff}.qa-message.ai .message-bubble{background:#fff;border-bottom-left-radius:6px;color:#334155}.message-bubble.markdown-content{line-height:1.7}.markdown-content p{margin:0 0 12px}.markdown-content p:last-child{margin-bottom:0}.markdown-content strong{color:#667eea;font-weight:600}.markdown-content ol,.markdown-content ul{margin:8px 0;padding-left:20px}.markdown-content li{margin:4px 0}.markdown-content code{background:#f1f5f9;border-radius:4px;color:#667eea;font-family:Monaco,Consolas,monospace;font-size:12px;padding:2px 6px}.markdown-content pre{background:#f1f5f9;border-radius:8px;margin:8px 0;overflow-x:auto;padding:12px}.markdown-content pre code{background:#0000;font-size:13px;padding:0}.message-bubble.typing{align-items:center;background:#fff;display:flex;gap:4px;padding:12px 16px}.message-bubble.typing span{animation:typing 1.4s infinite;background:#94a3b8;border-radius:50%;height:5px;width:5px}.message-bubble.typing span:nth-child(2){animation-delay:.2s}.message-bubble.typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.quick-questions-compact{display:flex;flex-direction:column;flex-shrink:0;gap:8px;margin-bottom:4px;padding:0}.quick-btn-compact{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:16px;box-shadow:0 2px 8px #0000000f;color:#475569;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;padding:10px 16px;text-align:left;transition:all .2s ease;width:100%}.quick-btn-compact:before{content:"💬";flex-shrink:0;font-size:16px}.quick-btn-compact:hover{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff;transform:translateX(4px)}.quick-btn-compact:hover:before{content:"✨"}.qa-input-form{align-items:center;background:#fff;border-radius:24px;box-shadow:0 3px 12px #00000014;display:flex;flex-shrink:0;gap:8px;padding:8px 8px 8px 16px}.qa-input{border:none;flex:1 1;font-family:inherit;font-size:13px;padding:8px 4px}.qa-input,.qa-input:focus{background:#0000;box-shadow:none;outline:none}.qa-input::placeholder{color:#94a3b8}.qa-send-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.qa-send-btn svg{stroke-width:2;height:16px;transform:rotate(45deg);width:16px}.qa-send-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.qa-send-btn:active:not(:disabled){transform:scale(.95)}.qa-send-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.qa-panel{bottom:0;padding:16px;right:0;top:0;width:100%}.close-panel-btn{right:16px;top:16px}.qa-messages{padding:56px 0 0}.message-bubble{max-width:80%}.quick-questions-compact{padding:0 2px}.qa-input-form{padding:6px 6px 6px 14px}.qa-input{font-size:16px}}@media (min-width:769px) and (max-width:1200px){.qa-panel{bottom:16px;right:16px;top:16px;width:380px}.message-bubble{max-width:88%}}.learning-modal-overlay{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.learning-modal-container{background:#fff;border-radius:32px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;position:relative;transition:transform .3s cubic-bezier(.16,1,.3,1);width:100%}.learning-modal-container.qa-open{transform:translateX(-245px)!important}@media (max-width:1200px){.learning-modal-container.qa-open{transform:translateX(-150px)!important}}@media (max-width:768px){.learning-modal-container.qa-open{transform:none!important}}.modal-close{align-items:center;background:#0000000d;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;font-size:28px;font-weight:300;height:44px;justify-content:center;line-height:1;padding:0;position:absolute;right:24px;top:24px;transition:all .2s cubic-bezier(.16,1,.3,1);width:44px;z-index:10}.modal-close:hover{background:#ef44441a;color:#ef4444;transform:rotate(90deg) scale(1.05)}.modal-header-compact{align-items:center;background:#fff;border-bottom:1px solid #0000000f;display:flex;justify-content:space-between;padding:20px 24px}.header-left{align-items:center;display:flex;gap:16px}.title-icon{flex-shrink:0;font-size:32px;line-height:1}.session-title{color:#1e293b;font-size:18px;font-weight:700;letter-spacing:-.3px;margin:0}.step-indicator{color:#64748b;font-size:13px;font-weight:500;gap:8px}.generating-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:11px;font-weight:600;letter-spacing:.3px;padding:3px 10px}.modal-body{background:#fff;flex:1 1;overflow-y:auto;padding:0;position:relative}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:#0000}.modal-body::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}.modal-body::-webkit-scrollbar-thumb:hover{background:#0003}.modal-navigation{background:#fff;border-top:1px solid #0000000d;justify-content:space-between;padding:20px 32px 28px}.modal-navigation,.nav-btn{align-items:center;display:flex}.nav-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:16px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;gap:8px;padding:14px 28px;transition:all .2s cubic-bezier(.16,1,.3,1)}.nav-btn svg{height:20px;transition:transform .2s ease;width:20px}.nav-btn:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.nav-btn:active:not(:disabled){transform:translateY(0)}.nav-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.3;transform:none}.nav-btn.prev{background:#0000000d;box-shadow:none;color:#64748b}.nav-btn.prev:hover:not(:disabled){background:#00000014;box-shadow:0 4px 12px #0000001a}.nav-btn.prev svg{margin-right:4px}.nav-btn.next svg{margin-left:4px}.nav-btn:hover svg{transform:translateX(2px)}.nav-btn.prev:hover svg{transform:translateX(-2px)}.nav-center{align-items:center;display:flex;flex:1 1;justify-content:center;text-align:center}.nav-right{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.step-count{font-feature-settings:"tnum";color:#64748b;font-size:15px;font-variant-numeric:tabular-nums;font-weight:600}.generating-status{margin-bottom:4px}.interaction-required{align-items:center;animation:gentle-pulse 2s ease-in-out infinite;background:#f59e0b14;border:1px solid #f59e0b33;border-radius:8px;color:#f59e0b;display:flex;font-size:13px;font-weight:500;gap:8px;margin-bottom:8px;padding:8px 12px}.interaction-required svg{flex-shrink:0;height:18px;width:18px}@keyframes gentle-pulse{0%,to{opacity:1}50%{opacity:.85}}.generating-spinner{border:2px solid #667eea33;border-radius:50%;border-top-color:#667eea}.desktop-only{display:block}@media (max-width:768px){.desktop-only{display:none!important}}.floating-actions{bottom:32px;display:flex;flex-direction:column;gap:12px;position:fixed;right:32px;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:10002}.floating-actions.qa-open{bottom:36px;right:482px}@media (max-width:1200px){.floating-actions.qa-open{bottom:36px;right:340px}}@media (max-width:768px){.floating-actions.qa-open{bottom:32px;right:32px}}.floating-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 10px 25px #667eea4d,inset 0 0 0 1px #ffffff1a;color:#fff;cursor:pointer;display:flex;height:64px;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:64px}.floating-btn svg{stroke-width:2;height:24px;width:24px}.floating-btn.mascot-btn{background:#fff;box-shadow:0 8px 20px #0000001f;overflow:hidden;padding:0}.floating-btn.mascot-btn img{height:100%;object-fit:contain;width:100%}.floating-btn.mascot-btn:hover{box-shadow:0 12px 30px #0003;transform:translateY(-4px) scale(1.1) rotate(5deg)}.floating-btn.mascot-btn:active{transform:translateY(-2px) scale(1.05) rotate(2deg)}.floating-btn:hover{box-shadow:0 15px 35px #667eea66,inset 0 0 0 1px #fff3;transform:translateY(-4px) scale(1.05)}.floating-btn:active{transform:translateY(-2px) scale(1.02)}.learning-modal-loading{align-items:center;background:#fff;border-radius:32px;box-shadow:0 25px 50px -12px #00000040;display:flex;justify-content:center;min-height:420px;padding:60px 40px;position:relative;text-align:center;width:460px}.loading-content{align-items:center;display:flex;flex-direction:column;gap:24px;width:100%}.learning-modal-loading h3{align-items:center;color:#1e293b;display:flex;font-size:20px;font-weight:700;justify-content:center;letter-spacing:-.4px;margin:0;min-height:60px}.learning-modal-error{align-items:center;background:#fff;border-radius:32px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;gap:20px;max-width:400px;padding:60px 40px;text-align:center}.error-icon{animation:shake .5s ease-in-out;font-size:64px;line-height:1}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.learning-modal-error p{color:#ef4444;font-size:17px;font-weight:600;margin:0}.learning-modal-error button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 32px;transition:all .2s ease}.learning-modal-error button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}@media (max-width:768px){.learning-modal-overlay{align-items:center;padding:20px}.learning-modal-container{border-radius:24px;max-height:100vh;max-width:100%}.learning-modal-loading{border-radius:24px;max-width:100%;min-height:380px;padding:40px 24px;width:calc(100vw - 40px)}.loading-icon{font-size:56px;height:56px}.loading-mascot{height:100px}.loading-spinner-ring{height:80px;width:80px}.spinner-ring{border-width:2px}.loading-text{font-size:16px;min-height:48px}.learning-modal-loading h3{font-size:18px;min-height:54px}.session-title-loading{font-size:14px;min-height:20px}.loading-hint{font-size:12px;min-height:18px}.loading-dots .dot{height:6px;width:6px}.learning-modal-error{border-radius:24px;max-width:100%;padding:40px 24px}.error-icon{font-size:48px}.learning-modal-error p{font-size:15px}.learning-modal-error button{font-size:14px;padding:12px 28px}.modal-header-compact{padding:16px 20px}.session-title{font-size:16px}.title-icon{font-size:28px}.step-indicator{font-size:12px}.generating-badge{font-size:10px;padding:2px 8px}.modal-navigation{flex-wrap:wrap;gap:12px;padding:16px 20px 24px}.nav-btn{font-size:14px;padding:12px 20px}.nav-center{flex:1 0 100%;margin-bottom:12px;order:-1}.nav-right{align-items:stretch;width:100%}.nav-btn.next{width:100%}.generating-status{font-size:12px;justify-content:center;margin-bottom:6px;padding:0}.interaction-required{font-size:12px;justify-content:center;margin-bottom:8px;padding:6px 10px}.interaction-required svg{height:16px;width:16px}.generating-spinner{height:12px;width:12px}.floating-actions{bottom:24px;right:20px}.floating-btn{height:48px;width:48px}.floating-btn svg{height:20px;width:20px}}.completion-modal{max-width:520px;width:90%}.completion-wrapper{padding:40px 36px 36px}@media (max-width:768px){.completion-modal{max-width:95%}.completion-wrapper{padding:32px 20px 28px}.completion-mascot{height:80px;margin-bottom:12px;width:80px}.completion-header{margin-bottom:20px}.completion-header h2{font-size:22px;margin-bottom:6px}.completion-message{font-size:13px}.completion-stats-grid{gap:10px;margin-bottom:20px}.stat-card{padding:16px 12px}.stat-number{font-size:32px}.stat-title{font-size:11px}.completion-buttons .completion-submessage{font-size:12px}.continue-btn,.library-btn{font-size:14px;padding:13px 20px}}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.lesson-content-panel{height:100%;overflow-y:auto;padding-right:.5rem}.lesson-content-panel::-webkit-scrollbar{width:8px}.lesson-content-panel::-webkit-scrollbar-track{background:#0000}.lesson-content-panel::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.lesson-content-panel::-webkit-scrollbar-thumb:hover{background:#9ca3af}.lesson-card{box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;height:100%}.lesson-card-scroll{flex:1 1;overflow-y:auto;padding:2rem 3rem}.lesson-card-scroll::-webkit-scrollbar{width:8px}.lesson-card-scroll::-webkit-scrollbar-track{background:#0000}.lesson-card-scroll::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.lesson-card-scroll::-webkit-scrollbar-thumb:hover{background:#9ca3af}.step-header{margin-bottom:1.5rem}.step-title{align-items:center;color:#1a1a1a;display:flex;font-size:1.75rem;font-weight:700;gap:.75rem;line-height:1.3;margin:0}.step-emoji{font-size:2rem;line-height:1}.step-content{margin-bottom:1rem;max-width:900px}.step-text{color:#334155;font-size:1rem;line-height:1.65}.step-text p{margin:0 0 12px}.step-text p:last-child{margin-bottom:0}.step-text strong{color:#667eea;font-weight:600}.step-text em{color:#64748b;font-style:italic}.lesson-content-panel .step-text ul{list-style:disc;margin:10px 0;padding-left:20px}.lesson-content-panel .step-text ol{list-style:decimal;margin:10px 0;padding-left:20px}.lesson-content-panel .step-text li{color:#334155;line-height:1.5;padding:4px 0;position:static}.lesson-content-panel .step-text li:before{content:none;display:none}.lesson-content-panel .step-text ul li::marker{color:#667eea}.lesson-content-panel .step-text ol li::marker{color:#667eea;font-weight:600}.step-text code{background-color:#f1f5f9;border-radius:4px;color:#e11d48;font-family:Monaco,Menlo,Courier New,monospace;font-size:.9em;padding:2px 6px}.step-text pre{background-color:#1e293b;border-radius:8px;color:#e2e8f0;font-size:.875rem;line-height:1.5;margin:12px 0;overflow-x:auto;padding:16px}.step-text pre code{background:none;color:inherit;font-size:inherit;padding:0}.step-artifact{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;margin-top:1.5rem;padding:1.5rem}.lesson-navigation{background:#fff;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:1rem;padding:1.25rem 3rem}.nav-buttons{align-items:flex-end;display:flex;gap:1rem;justify-content:space-between;max-width:900px}.nav-right-section{align-items:center;display:flex;flex-direction:row;gap:16px}.generating-status{align-items:center;color:#64748b;display:flex;font-size:13px;font-weight:500;gap:8px;padding:0 4px}.generating-spinner{height:14px;width:14px}.button-spinner,.generating-spinner{animation:spin .8s linear infinite;flex-shrink:0}.button-spinner{height:16px;width:16px}.nav-button{align-items:center;background-color:#f3f4f6;border:none;border-radius:10px;color:#374151;cursor:pointer;display:flex;font-size:.9375rem;font-weight:500;gap:.5rem;padding:.875rem 1.5rem;transition:all .2s}.nav-button:hover:not(:disabled){background-color:#e5e7eb;transform:translateY(-1px)}.nav-button:disabled{cursor:not-allowed;opacity:.5}.nav-button.primary{background-color:#4f46e5;color:#fff}.nav-button.primary:hover:not(:disabled){background-color:#4338ca;box-shadow:0 4px 12px #4f46e54d}.nav-button.prev{flex:0 1}.nav-button.finish,.nav-button.next{flex:0 1;margin-left:auto}.step-indicator{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:1rem;justify-content:center;max-width:900px}.step-count{font-weight:500}.completed-indicator{align-items:center;color:#10b981;display:flex;font-weight:500;gap:.25rem}@media (max-width:1200px){.lesson-card-scroll{padding:1.75rem 2.5rem}.lesson-navigation{padding:1.25rem 2.5rem}.step-content{max-width:100%}}@media (max-width:1024px){.lesson-card-scroll{padding:2rem}.lesson-navigation{padding:1.25rem 2rem}.step-title{font-size:1.75rem}.step-text{font-size:1.0625rem}}@media (max-width:768px){.lesson-card-scroll{padding:1.5rem}.lesson-navigation{padding:1rem 1.5rem}.step-title{font-size:1.5rem}.step-emoji{font-size:2rem}.step-text{font-size:1rem}.nav-buttons{flex-direction:column}.nav-button.prev{order:2}.nav-button.finish,.nav-button.next{margin-left:0;order:1}}.completion-step .lesson-card-scroll{align-items:center;display:flex;flex-direction:column;padding-top:3rem;text-align:center}.completion-step-header{align-items:center;display:flex;flex-direction:column;margin-bottom:1.5rem}.completion-step-mascot{height:100px;margin-bottom:1.5rem;width:100px}.completion-step-mascot img{height:100%;object-fit:contain;width:100%}.completion-step .step-title{font-size:2rem;justify-content:center}.completion-step .step-content{max-width:600px;text-align:center}.completion-step-message{color:#475569;font-size:1.1rem;line-height:1.7;margin-bottom:2rem}.completion-step-message strong{color:#667eea;font-weight:600}.completion-step-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin:0 auto 2rem;max-width:400px;width:100%}.completion-stat-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:16px;padding:1.5rem 1rem;text-align:center;transition:all .2s ease}.completion-stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.completion-stat-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.completion-stat-title{color:#64748b;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.completion-step-next{background:linear-gradient(135deg,#667eea08,#764ba208);border:1px solid #667eea20;border-radius:12px;padding:1.5rem;text-align:center}.completion-step-next h3{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.completion-step-next p{color:#64748b;font-size:.95rem;line-height:1.6;margin:0}.nav-button.secondary{background-color:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.nav-button.secondary:hover:not(:disabled){background-color:#e2e8f0;border-color:#cbd5e1}.completion-actions .nav-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 4px 14px #667eea59;color:#fff;font-weight:600;padding:.875rem 1.75rem}.completion-actions .nav-button.primary:hover:not(:disabled){box-shadow:0 6px 20px #667eea73;transform:translateY(-2px)}.completion-actions .nav-button.primary:disabled{cursor:wait;opacity:.7}.completion-actions .nav-button.primary .loading-spinner{animation:button-spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes button-spin{to{transform:rotate(1turn)}}.completed-text{color:#10b981;font-weight:600}@media (max-width:768px){.completion-step .lesson-card-scroll{padding-top:2rem}.completion-step-mascot{height:80px;width:80px}.completion-step .step-title{font-size:1.5rem}.completion-step-message{font-size:1rem}.completion-step-stats{max-width:100%}.completion-stat-number{font-size:2rem}.completion-actions{flex-direction:column;width:100%}.completion-actions .nav-button{justify-content:center;width:100%}}.tool-card{padding:1.5rem}.tool-card:first-child{padding-top:0}.tool-header{align-items:center;display:flex;gap:.75rem;margin-bottom:1rem}.tool-icon{font-size:1.5rem;line-height:1}.tool-title{color:#1a1a1a;font-size:1rem;font-weight:600;margin:0}.tool-body{display:flex;flex-direction:column;gap:1rem}.tool-description{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0}.tool-scope{display:flex;flex-direction:column;gap:.5rem}.scope-label,.setting-label{color:#374151;font-size:.8125rem;font-weight:500}.number-options,.scope-options{display:flex;gap:.5rem}.number-option,.scope-option{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;flex:1 1;font-size:.8125rem;font-weight:500;padding:.5rem .75rem;transition:all .2s}.number-option:hover,.scope-option:hover{background-color:#f3f4f6;border-color:#d1d5db}.number-option.active,.scope-option.active{background-color:#eef2ff;border-color:#4f46e5;color:#4f46e5}.tool-setting{display:flex;flex-direction:column;gap:.5rem}.tool-message{border-radius:6px;line-height:1.4;padding:.75rem}.tool-message.success{background-color:#dcfce7;border:1px solid #bbf7d0;color:#16a34a}.tool-message.error{background-color:#fee2e2;color:#dc2626}.tool-message.info{background-color:#dbeafe;border:1px solid #bfdbfe;color:#2563eb}.tool-action-button{align-items:center;background-color:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem;transition:all .2s;width:100%}.tool-action-button:hover:not(:disabled){background-color:#4338ca;box-shadow:0 4px 12px #4f46e54d;transform:translateY(-1px)}.tool-action-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:1024px){.tool-card{padding:1.25rem}.number-options,.scope-options{flex-wrap:wrap}.number-option,.scope-option{min-width:calc(50% - .25rem)}}.ai-tutor-body,.ai-tutor-tool{display:flex;flex:1 1;flex-direction:column;height:100%;min-height:0}.ai-tutor-body{padding:1rem}.ai-messages-container{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;flex:1 1;min-height:0;overflow-y:auto;padding:1rem}.ai-messages-container::-webkit-scrollbar{width:6px}.ai-messages-container::-webkit-scrollbar-track{background:#0000}.ai-messages-container::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.ai-messages-container::-webkit-scrollbar-thumb:hover{background:#9ca3af}.ai-empty-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;padding:2rem 1rem;text-align:center}.ai-empty-state p{color:#374151;font-size:.9375rem;font-weight:500;margin:0 0 1.25rem}.suggestion-chips{display:flex;flex-direction:column;gap:.5rem;max-width:280px;width:100%}.suggestion-chip{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.75rem 1rem;text-align:center;transition:all .15s ease}.suggestion-chip:hover{background-color:#eef2ff;border-color:#4f46e5;color:#4f46e5;transform:translateY(-1px)}.ai-messages{gap:1rem}.ai-message-group,.ai-messages{display:flex;flex-direction:column}.ai-message-group{gap:.5rem}.ai-message{animation:messageIn .3s ease;display:flex}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ai-message.user{justify-content:flex-end}.ai-message.assistant{justify-content:flex-start}.ai-message .message-content{word-wrap:break-word;border-radius:14px;font-size:.875rem;line-height:1.6;max-width:85%;min-width:0;overflow-wrap:break-word;padding:.875rem 1rem;word-break:normal}.ai-message.user .message-content{background:linear-gradient(135deg,#4f46e5,#6366f1);border-bottom-right-radius:4px;box-shadow:0 2px 8px #4f46e540;color:#fff}.ai-message.assistant .message-content{background-color:#fff;border:1px solid #e5e7eb;border-bottom-left-radius:4px;box-shadow:0 1px 3px #0000000a;color:#1a1a1a}.ai-message .message-content.markdown-content p{margin:0 0 .5rem}.ai-message .message-content.markdown-content p:last-child{margin-bottom:0}.ai-message .message-content.markdown-content ol,.ai-message .message-content.markdown-content ul{margin:.5rem 0;padding-left:1.25rem}.ai-message .message-content.markdown-content li{margin-bottom:.25rem}.ai-message .message-content.markdown-content code{background:#f3f4f6;border-radius:4px;font-family:Monaco,Menlo,Consolas,monospace;font-size:.8125rem;padding:.125rem .375rem}.ai-message .message-content.markdown-content pre{background:#1f2937;border-radius:8px;margin:.5rem 0;overflow-x:auto;padding:.75rem}.ai-message .message-content.markdown-content pre code{background:#0000;color:#e5e7eb;padding:0}.ai-message .message-content.markdown-content strong{font-weight:600}.ai-message .message-content.markdown-content em{font-style:italic}.ai-message .message-content.markdown-content h1,.ai-message .message-content.markdown-content h2,.ai-message .message-content.markdown-content h3{font-weight:600;margin:.75rem 0 .375rem}.ai-message .message-content.markdown-content h1{font-size:1.125rem}.ai-message .message-content.markdown-content h2{font-size:1rem}.ai-message .message-content.markdown-content h3{font-size:.9375rem}.ai-message .message-content.typing{align-items:center;display:flex;gap:4px;padding:1rem}.ai-message .message-content.typing span{animation:typing-bounce 1.4s ease-in-out infinite;background-color:#9ca3af;border-radius:50%;height:8px;width:8px}.ai-message .message-content.typing span:first-child{animation-delay:0s}.ai-message .message-content.typing span:nth-child(2){animation-delay:.2s}.ai-message .message-content.typing span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{opacity:.6;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.ai-message.assistant .message-content .spinning{color:#4f46e5;display:inline-block;margin-right:.5rem}.tool-message{animation:slideIn .25s ease;font-size:.8125rem;margin-top:.75rem;padding:.75rem 1rem}.tool-message.error{border:1px solid #fecaca}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ai-input-form{display:flex;gap:.625rem;margin-top:.75rem;padding-top:.75rem}.ai-input{background-color:#fff;border:1px solid #e5e7eb;border-radius:10px;flex:1 1;font-size:.875rem;padding:.875rem 1rem;transition:all .15s ease}.ai-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.ai-input:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.ai-input::placeholder{color:#9ca3af}.ai-send-button{align-items:center;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;border-radius:10px;box-shadow:0 2px 8px #4f46e540;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.875rem 1.125rem;transition:all .15s ease}.ai-send-button:hover:not(:disabled){box-shadow:0 4px 12px #4f46e559;transform:translateY(-1px)}.ai-send-button:active:not(:disabled){transform:translateY(0)}.ai-send-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.spinning{animation:spin 1s linear infinite}@media (max-width:1024px){.ai-messages-container,.ai-tutor-body{padding:.875rem}.ai-message .message-content{font-size:.8125rem;max-width:90%;padding:.75rem .875rem}.suggestion-chip{padding:.625rem .875rem}}@media (max-width:768px){.ai-tutor-body{padding:.75rem}.ai-empty-state{padding:1.5rem 1rem}.ai-empty-state p{font-size:.875rem}.ai-input{padding:.75rem .875rem}.ai-send-button{padding:.75rem 1rem}}.match-container{display:flex;flex-direction:column;gap:12px;position:relative}.match-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.match-empty-state span{font-size:36px;margin-bottom:12px;opacity:.5}.match-empty-state p{color:#6b7280;font-size:14px;margin:0}.match-header{align-items:center;display:flex;justify-content:space-between;padding:0 4px}.match-score{align-items:baseline;display:flex;gap:2px}.match-score-correct{color:#10b981;font-size:20px;font-weight:700}.match-score-divider{color:#9ca3af;font-size:14px;margin:0 1px}.match-score-total{color:#6b7280;font-size:14px;font-weight:600}.match-score-label{color:#9ca3af;font-size:11px;margin-left:6px}.match-reset-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s ease;width:32px}.match-reset-btn:hover{background:#e5e7eb;color:#374151}.match-success{align-items:center;animation:matchSlideIn .3s ease;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #10b981;border-radius:10px;display:flex;gap:10px;padding:10px 14px}@keyframes matchSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.match-success.perfect{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.match-success-icon{font-size:18px}.match-success-text{color:#065f46;flex:1 1;font-size:13px;font-weight:600}.match-success.perfect .match-success-text{color:#92400e}.match-success-btn{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:background .15s ease}.match-success.perfect .match-success-btn{background:#f59e0b}.match-success-btn:hover{background:#059669}.match-success.perfect .match-success-btn:hover{background:#d97706}.match-game-area{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;position:relative}.match-lines-svg{height:100%;left:0;overflow:visible;pointer-events:none;position:absolute;top:0;width:100%;z-index:10}.match-line{fill:none;stroke-width:2;stroke-linecap:round}.match-line.correct{stroke:#10b981}.match-line.incorrect{stroke:#ef4444}.match-dot{stroke:#fff;stroke-width:2}.match-dot.correct{fill:#10b981}.match-dot.incorrect{fill:#ef4444}.match-column{display:flex;flex-direction:column;gap:6px;position:relative;z-index:2}.match-column-label{color:#9ca3af;font-size:10px;font-weight:700;letter-spacing:.5px;padding:0 2px 6px;text-transform:uppercase}.match-card{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:8px;justify-content:space-between;line-height:1.35;min-height:38px;padding:10px 12px;position:relative;text-align:left;transition:all .15s ease}.match-card:hover:not(.correct):not(.incorrect){background:#fafaff;border-color:#c7d2fe}.match-card.selected{background:#eef2ff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.match-card.available:not(.selected){background:#f5f3ff;border-color:#c7d2fe}.match-card.correct{background:#ecfdf5;border-color:#10b981;cursor:pointer}.match-card.correct:hover{background:#d1fae5}.match-card.correct .match-card-text{color:#065f46}.match-card.incorrect{background:#fef2f2;border-color:#ef4444;cursor:pointer}.match-card.incorrect:hover{background:#fee2e2}.match-card.incorrect .match-card-text{color:#991b1b}.match-card-text{flex:1 1}.match-card-status{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:18px;justify-content:center;width:18px}.match-card-status.correct{background:#10b981;color:#fff}.match-card-status.incorrect{background:#ef4444;color:#fff}.match-hint{color:#9ca3af;font-size:11px;padding:4px 0;text-align:center}@media (max-width:500px){.match-game-area{gap:20px}.match-card{font-size:11px;min-height:34px;padding:8px 10px}}.tools-panel{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;height:100%;overflow:hidden}.tool-card-wrapper{position:relative}.generate-popover{animation:popoverSlideIn .15s ease;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #00000026;left:0;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:100}.generate-popover-right{left:auto;min-width:220px;right:0;top:calc(100% + 4px)}@keyframes popoverSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.generate-popover-header{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;padding:12px 14px 8px;text-transform:uppercase}.generate-popover-option{align-items:center;background:none;border:none;border-top:1px solid #f3f4f6;cursor:pointer;display:flex;gap:10px;padding:12px 14px;text-align:left;transition:all .15s;width:100%}.generate-popover-option:hover{background:#f9fafb}.generate-popover-option:active{background:#f3f4f6}.generate-popover-icon{flex-shrink:0;font-size:18px}.generate-popover-label{color:#1a1a1a;flex:1 1;font-size:14px;font-weight:500}.generate-popover-desc{color:#9ca3af;font-size:12px}.generate-popover-desc.generating{align-items:center;color:#f59e0b;display:flex;font-weight:500;gap:6px}.generate-popover-option.disabled{background:#f9fafb;cursor:not-allowed;opacity:.7}.generate-popover-option.disabled:hover{background:#f9fafb}.generate-popover-option.disabled .generate-popover-label{color:#9ca3af}.generate-popover-option.disabled .generate-popover-icon{opacity:.5}.spinner-tiny{animation:spin 1s linear infinite;flex-shrink:0;height:12px;width:12px}.expanded-view.compact{position:relative}.compact-header{background:#fafafa;border-bottom:1px solid #e5e7eb;gap:8px;min-height:40px;padding:8px 12px}.compact-back-btn,.compact-header{align-items:center;display:flex;flex-shrink:0}.compact-back-btn{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;height:28px;justify-content:center;transition:all .15s;width:28px}.compact-back-btn:hover{background:#f3f4f6;border-color:#d1d5db;color:#374151}.compact-tabs{-ms-overflow-style:none;display:flex;flex:1 1;gap:4px;mask-image:linear-gradient(90deg,#0000,#000 8px,#000 calc(100% - 8px),#0000);-webkit-mask-image:linear-gradient(90deg,#0000,#000 8px,#000 calc(100% - 8px),#0000);overflow-x:auto;padding:2px 0;position:relative;scrollbar-width:none}.compact-tabs::-webkit-scrollbar{display:none}.compact-tabs-wrapper{display:flex;flex:1 1;min-width:0;position:relative}.compact-tabs-wrapper:after,.compact-tabs-wrapper:before{bottom:0;content:"";opacity:0;pointer-events:none;position:absolute;top:0;transition:opacity .2s;width:20px;z-index:2}.compact-tabs-wrapper:before{background:linear-gradient(90deg,#fafafa 30%,#0000);left:0}.compact-tabs-wrapper:after{background:linear-gradient(270deg,#fafafa 30%,#0000);right:0}.compact-tabs-wrapper.scroll-left:before,.compact-tabs-wrapper.scroll-right:after{opacity:1}.compact-tabs-wrapper .compact-tabs{mask-image:none;-webkit-mask-image:none}.compact-tab{background:#fff;border:1px solid #e5e7eb;border-radius:14px;color:#6b7280;cursor:pointer;flex-shrink:0;font-size:11px;font-weight:500;padding:5px 10px;transition:all .15s;white-space:nowrap}.compact-tab:hover{border-color:#d1d5db;color:#374151}.compact-tab.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.compact-actions{flex-shrink:0;position:relative}.generating-inline{align-items:center;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#4f46e5;display:flex;font-size:11px;font-weight:500;gap:6px;padding:5px 10px}.generating-inline .spinner{color:#4f46e5}.generate-more-text-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:4px;padding:5px 10px;transition:all .15s;white-space:nowrap}.generate-more-text-btn:hover:not(:disabled){background:#eef2ff;border-color:#4f46e5;color:#4f46e5}.generate-more-text-btn:disabled{cursor:not-allowed;opacity:.7}.generate-more-text-btn.loading{background:#eef2ff;border-color:#c7d2fe;color:#4f46e5}.compact-body{padding:12px!important}.generating-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#ffffffeb;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:40px;z-index:50}.generating-content{align-items:center;color:#4f46e5;display:flex;flex-direction:column;gap:12px}.generating-content span{color:#6b7280;font-size:13px;font-weight:500}.section-tabs-container{align-items:center;background:#fafafa;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:8px;padding:8px 12px}.section-tabs{-ms-overflow-style:none;display:flex;flex:1 1;gap:4px;overflow-x:auto;scrollbar-width:none}.section-tabs::-webkit-scrollbar{display:none}.section-tab{background:#fff;border:1px solid #e5e7eb;border-radius:16px;color:#6b7280;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:500;padding:6px 12px;transition:all .15s;white-space:nowrap}.section-tab:hover{border-color:#d1d5db;color:#374151}.section-tab.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.section-tabs-actions{flex-shrink:0;position:relative}.generate-more-btn{align-items:center;background:#fff;border:1px dashed #d1d5db;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s;width:32px}.generate-more-btn:hover{background:#eef2ff;border-color:#4f46e5;border-style:solid;color:#4f46e5}.tool-btn-chevron{color:#9ca3af;flex-shrink:0;transition:transform .15s}.tool-btn:hover .tool-btn-chevron{color:#6b7280}.flashcard-viewer.compact-viewer{padding-top:4px}.flashcard-viewer.compact-viewer .fc-progress{margin-bottom:8px}.flashcard-viewer.compact-viewer .fc-hint{margin:6px 0 8px}.quiz-viewer.compact-viewer .qz-header{margin-bottom:8px}.quiz-viewer.compact-viewer .qz-progress-bar{margin-bottom:10px}.quiz-viewer.compact-viewer .qz-question{margin-bottom:12px}.tf-container.compact-viewer .tf-header{margin-bottom:10px}.tf-container.compact-viewer .tf-statement{margin-bottom:14px}.fc-progress{align-items:center;display:flex;gap:2px;justify-content:center}.fc-progress-current{color:#4f46e5;font-weight:700}.fc-progress-divider{color:#d1d5db;margin:0 2px}.fc-progress-total{color:#9ca3af}.tools-header{align-items:center;background:#fafafa;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:0 4px 0 0}.tools-tabs{display:flex;flex:1 1}.tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:12px 16px;transition:all .15s}.tab:hover{background:#00000005;color:#374151}.tab.active{background:#fff;border-bottom-color:#4f46e5;color:#4f46e5}.close-btn{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;height:32px;justify-content:center;margin-right:4px;transition:all .15s;width:32px}.close-btn:hover{background:#f3f4f6;color:#374151}.tools-body{flex:1 1;min-height:0;overflow-y:auto}.tools-body::-webkit-scrollbar{width:5px}.tools-body::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px}.tools-main{gap:16px;padding:16px}.tool-buttons,.tools-main{display:flex;flex-direction:column}.tool-buttons{gap:10px}.tool-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:12px;text-align:left;transition:all .15s;width:100%}.tool-btn:hover:not(:disabled){border-color:#d1d5db;box-shadow:0 2px 4px #0000000a}.tool-btn:disabled{cursor:not-allowed;opacity:.6}.tool-btn.loading{background:#fffbeb;border-color:#fde047}.tool-btn.has-content{background:#eef2ff;border-color:#c7d2fe}.tool-btn-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:18px;height:36px;justify-content:center;width:36px}.tool-btn-icon.flashcard{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}.tool-btn-icon.quiz{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.tool-btn-icon.mindmap{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.tool-btn-icon.crossword{background:linear-gradient(135deg,#fef3c7,#fde68a)}.tool-btn-icon.matching{background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.tool-btn-content{flex:1 1;min-width:0}.tool-btn-title{color:#1a1a1a;display:block;font-size:14px;font-weight:600}.tool-btn-subtitle{color:#6b7280;display:block;font-size:12px;margin-top:1px}.tool-btn .spinner{color:#f59e0b;flex-shrink:0}.tool-btn.locked{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#667eea,#764ba2) border-box;border:2px solid #0000;box-shadow:0 2px 8px #667eea26;position:relative;transition:all .3s ease}.tool-btn.locked:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;content:"";inset:-2px;opacity:0;position:absolute;transition:opacity .3s ease;z-index:-1}.tool-btn.locked:hover{background:linear-gradient(#faf8ff,#faf8ff) padding-box,linear-gradient(135deg,#667eea,#764ba2) border-box;box-shadow:0 4px 16px #667eea40;transform:translateY(-2px)}.tool-btn.locked:hover:before{opacity:.08}.tool-btn.locked .tool-btn-icon{opacity:.85;position:relative}.tool-btn.locked .tool-btn-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text}.tool-btn.locked .tool-btn-subtitle{color:#8b7db8;font-size:11px;font-weight:500}.tool-btn-lock{color:#9ca3af;flex-shrink:0;font-size:14px;transition:color .2s ease}.tool-btn.locked:hover .tool-btn-lock{color:#6b7280}.tool-btn-actions{display:flex;flex-shrink:0;gap:4px}.mini-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .15s;width:28px}.mini-btn:hover{background:#eef2ff;border-color:#4f46e5;color:#4f46e5}.tool-message{border-radius:8px;font-size:13px;font-weight:500;padding:10px 12px;text-align:center}.tool-message.success{background:#ecfdf5;border:1px solid #10b981;color:#065f46}.tool-message.error{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b}.expanded-view{display:flex;flex-direction:column;height:100%}.expanded-nav{background:#fafafa;border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;padding:10px 12px}.back-btn,.expanded-nav{align-items:center;display:flex}.back-btn{border-radius:6px;color:#6b7280;font-size:13px;font-weight:500;gap:6px;padding:6px 10px;transition:all .15s}.back-btn:hover{background:#f3f4f6;color:#374151}.expand-btn{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;height:30px;justify-content:center;transition:all .15s;width:30px}.expand-btn:hover{background:#f3f4f6;color:#4f46e5}.expanded-body{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:16px}.expanded-body.full-height{display:flex;flex-direction:column;overflow:hidden;padding:0}.expanded-body.full-height>*{flex:1 1}.expanded-title{color:#1a1a1a;font-size:14px;font-weight:600}.concept-map-expanded{height:100%}.concept-map-body{padding:8px}.concept-map-body .concept-map-artifact{height:100%;max-height:none;min-height:400px}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.empty-state span{font-size:36px;margin-bottom:12px;opacity:.5}.empty-state p{color:#6b7280;font-size:14px;margin:0 0 16px}.empty-state button{background:#4f46e5;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .15s}.empty-state button:hover{background:#4338ca}.flashcard-viewer{display:flex;flex-direction:column;gap:12px;height:100%}.fc-progress{color:#6b7280;font-size:12px;font-weight:500;text-align:center}.fc-card{cursor:pointer;flex:1 1;min-height:160px;perspective:1000px}.fc-inner{height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s;width:100%}.fc-card.flipped .fc-inner{transform:rotateY(180deg)}.fc-back,.fc-front{-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#fff;border:1px solid #e5e7eb;border-radius:10px;display:flex;flex-direction:column;height:100%;padding:16px;position:absolute;width:100%}.fc-back{background:#eef2ff;border-color:#c7d2fe;transform:rotateY(180deg)}.fc-label{color:#9ca3af;font-size:10px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.fc-back p,.fc-front p{align-items:center;color:#1a1a1a;display:flex;flex:1 1;font-size:14px;justify-content:center;line-height:1.5;margin:0;text-align:center}.fc-hint{color:#9ca3af;font-size:11px;margin:0;text-align:center}.fc-nav{display:flex;gap:8px;justify-content:center}.fc-nav button{background:#f3f4f6;border:none;border-radius:6px;color:#374151;cursor:pointer;font-size:12px;font-weight:500;padding:8px 16px;transition:all .15s}.fc-nav button:hover:not(:disabled){background:#e5e7eb}.fc-nav button:disabled{cursor:not-allowed;opacity:.4}.quiz-viewer{display:flex;flex-direction:column;gap:10px}.qz-header{align-items:center;display:flex;justify-content:space-between}.qz-progress-info{align-items:baseline;display:flex;gap:4px}.qz-question-num{color:#1a1a1a;font-size:13px;font-weight:600}.qz-question-total{color:#9ca3af;font-size:12px}.qz-score-badge{align-items:center;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:12px;color:#059669;display:flex;font-size:12px;font-weight:600;gap:3px;padding:4px 10px}.qz-progress-bar{background:#e5e7eb;border-radius:2px;height:3px;overflow:hidden}.qz-progress-fill{background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:2px;height:100%;transition:width .3s ease}.qz-question{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:13px;font-weight:500;line-height:1.5;padding:12px}.qz-options{display:flex;flex-direction:column;gap:6px}.qz-option{align-items:center;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:13px;gap:10px;padding:10px 12px;text-align:left;transition:all .15s;width:100%}.qz-option:hover:not(:disabled){background:#fafafe;border-color:#c7d2fe}.qz-option.selected{background:#eef2ff;border-color:#4f46e5}.qz-option.correct{background:#ecfdf5;border-color:#10b981}.qz-option.incorrect{background:#fef2f2;border-color:#ef4444}.qz-option:disabled{cursor:default}.qz-letter{align-items:center;background:#f3f4f6;border-radius:6px;color:#6b7280;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;transition:all .15s;width:22px}.qz-option.selected .qz-letter{background:#4f46e5;color:#fff}.qz-option.correct .qz-letter{background:#10b981;color:#fff}.qz-option.incorrect .qz-letter{background:#ef4444;color:#fff}.qz-option-text{flex:1 1;line-height:1.3}.qz-result-icon{flex-shrink:0;font-size:14px}.qz-option.correct .qz-result-icon{color:#059669}.qz-option.incorrect .qz-result-icon{color:#dc2626}.qz-actions{display:flex;justify-content:center;padding-top:4px}.qz-btn{background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:10px 24px;transition:all .15s}.qz-btn:hover:not(:disabled){background:#4338ca}.qz-btn:disabled{cursor:not-allowed;opacity:.5}.qz-complete-screen{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:24px 16px;text-align:center}.qz-complete-icon{font-size:40px;margin-bottom:12px}.qz-complete-screen h3{color:#1a1a1a;font-size:18px;font-weight:700;margin:0 0 8px}.qz-final-score{color:#4f46e5;font-size:32px;font-weight:800;margin-bottom:2px}.qz-percentage{color:#6b7280;font-size:13px;margin-bottom:16px}.qz-restart{align-items:center;background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:10px 20px;transition:all .15s}.qz-restart:hover{background:#4338ca}.spinner{animation:spin 1s linear infinite}.crossword-container{display:flex;flex-direction:column;gap:12px;padding:0;position:relative}.crossword-scroll-hint{align-items:center;color:#94a3b8;cursor:pointer;display:flex;font-size:11px;gap:4px;justify-content:center;margin:-8px 0 0}.crossword-scroll-hint:hover{color:#64748b}.scroll-hint-pill{display:contents}.crossword-success{align-items:center;animation:successPulse .5s ease;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:12px;display:flex;gap:10px;justify-content:center;padding:14px 20px}@keyframes successPulse{0%{opacity:0;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.crossword-success .success-icon{font-size:24px}.crossword-success .success-text{color:#065f46;font-size:16px;font-weight:700}.crossword-wrapper{display:flex;justify-content:center}.crossword-grid{grid-gap:3px;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);border-radius:12px;box-shadow:0 4px 12px #00000014,inset 0 1px 0 #ffffff80;display:grid;gap:3px;max-width:100%;overflow:auto;padding:8px}.crossword-cell{border-radius:4px;height:36px;position:relative;transition:all .15s ease;width:36px}.crossword-cell.empty{background:#0000;box-shadow:none}.crossword-cell.filled{background:#fff;box-shadow:0 1px 3px #0000001a,inset 0 1px 0 #fffc;cursor:pointer}.crossword-cell.filled:hover{background:#f8fafc;box-shadow:0 2px 6px #0000001f}.crossword-cell.highlighted{background:#eef2ff;box-shadow:0 1px 3px #4f46e533,inset 0 1px 0 #fffc}.crossword-cell.active{background:#c7d2fe;box-shadow:0 0 0 2px #4f46e5,0 2px 8px #4f46e54d;z-index:2}.crossword-cell.correct{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.crossword-cell.correct input{color:#059669}.crossword-cell input{background:#0000;border:none;border-radius:4px;caret-color:#4f46e5;color:#1e293b;cursor:pointer;font-size:18px;font-weight:700;height:100%;padding:0;text-align:center;text-transform:uppercase;width:100%}.crossword-cell input:focus{outline:none}.crossword-cell input.revealed{color:#4f46e5;font-style:italic}.crossword-cell input:disabled{cursor:default;opacity:1}.cell-number{color:#64748b;font-size:9px;font-weight:700;left:3px;line-height:1;pointer-events:none;position:absolute;top:2px;z-index:1}.crossword-clues{grid-gap:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:grid;gap:16px;grid-template-columns:1fr 1fr;padding:16px}.clue-section h4{align-items:center;border-bottom:2px solid #e2e8f0;color:#1e293b;display:flex;font-size:13px;font-weight:700;gap:6px;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;text-transform:uppercase}.clue-section h4 .clue-icon{color:#4f46e5;font-size:14px;font-weight:700}.clue-list{display:flex;flex-direction:column;gap:6px}.clue{align-items:flex-start;background:#fff;border:1px solid #0000;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:13px;gap:8px;line-height:1.5;padding:8px 10px;transition:all .15s ease}.clue:hover{background:#eef2ff;border-color:#c7d2fe}.clue.active{background:#eef2ff;border-color:#4f46e5;color:#1e293b}.clue-number{color:#4f46e5;flex-shrink:0;font-weight:700;min-width:20px}.clue-text{flex:1 1}.crossword-actions{flex-wrap:wrap;gap:10px}.crossword-actions,.cw-btn{display:flex;justify-content:center}.cw-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;gap:6px;padding:10px 18px;transition:all .15s ease}.cw-btn.primary{background:#4f46e5;color:#fff}.cw-btn.primary:hover{background:#4338ca;box-shadow:0 4px 12px #4f46e54d}.cw-btn.secondary{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.cw-btn.secondary:hover{background:#e2e8f0;color:#1e293b}.cw-btn.hint{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d;color:#92400e}.cw-btn.hint:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);box-shadow:0 4px 12px #fbbf244d}.matching-container{display:flex;flex-direction:column;gap:16px}.matching-result{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;color:#374151;font-size:15px;font-weight:600;padding:12px;text-align:center}.matching-result.perfect{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981;color:#065f46}.matching-columns{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.matching-column h4{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-align:center;text-transform:uppercase}.matching-column{display:flex;flex-direction:column;gap:6px}.match-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:12px;line-height:1.4;padding:10px 12px;position:relative;text-align:left;transition:all .15s;width:100%}.match-item:hover:not(:disabled){background:#fafafa;border-color:#d1d5db}.match-item.term.selected{background:#eef2ff;border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e533}.match-item.term.correct{background:#ecfdf5;border-color:#10b981}.match-item.term.incorrect{background:#fef2f2;border-color:#ef4444}.match-item.definition.clickable:not(.used){background:#f5f3ff;border-color:#c7d2fe}.match-item.definition.used{cursor:default;opacity:.5}.match-item:disabled{cursor:default}.match-icon{font-size:14px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.match-item.correct .match-icon{color:#10b981}.match-item.incorrect .match-icon{color:#ef4444}.matching-actions{display:flex;justify-content:center}.matching-actions button{align-items:center;background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:10px 16px;transition:all .15s}.matching-actions button:hover{background:#4338ca}.tf-container{display:flex;flex-direction:column;gap:16px}.tf-header{align-items:center;display:flex;font-size:13px;font-weight:500;justify-content:space-between}.tf-progress{color:#6b7280}.tf-score{color:#4f46e5}.tf-streak{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;color:#92400e;font-size:12px;font-weight:600;padding:4px 8px}.tf-statement{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;color:#1a1a1a;display:flex;font-size:15px;justify-content:center;line-height:1.6;min-height:80px;padding:20px;text-align:center}.tf-buttons{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.tf-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-size:15px;font-weight:600;gap:8px;padding:20px 16px;transition:all .2s}.tf-btn.true{color:#059669}.tf-btn.true:hover:not(:disabled){background:#ecfdf5;border-color:#10b981}.tf-btn.false{color:#dc2626}.tf-btn.false:hover:not(:disabled){background:#fef2f2;border-color:#ef4444}.tf-btn.selected{transform:scale(.98)}.tf-btn.correct{background:#ecfdf5;border-color:#10b981;color:#065f46}.tf-btn.wrong{background:#fef2f2;border-color:#ef4444;color:#991b1b}.tf-btn:disabled{cursor:default;opacity:.7}.tf-feedback{border-radius:10px;padding:16px;text-align:center}.tf-feedback.correct{background:#ecfdf5;border:1px solid #10b981}.tf-feedback.incorrect{background:#fef2f2;border:1px solid #fca5a5}.tf-feedback-header{font-size:16px;font-weight:600;margin-bottom:8px}.tf-feedback.correct .tf-feedback-header{color:#065f46}.tf-feedback.incorrect .tf-feedback-header{color:#991b1b}.tf-explanation{color:#374151;font-size:13px;line-height:1.5;margin:0 0 12px}.tf-next{background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:10px 20px;transition:all .15s}.tf-next:hover{background:#4338ca}.tf-complete{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.tf-complete-icon{font-size:48px;margin-bottom:16px}.tf-complete h3{color:#1a1a1a;font-size:20px;font-weight:600;margin:0 0 12px}.tf-final-score{color:#4f46e5;font-size:36px;font-weight:700;margin-bottom:4px}.tf-percentage{color:#6b7280;font-size:14px;margin-bottom:8px}.tf-best-streak{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;color:#92400e;font-size:13px;font-weight:600;margin-bottom:20px;padding:6px 12px}.tf-restart{align-items:center;background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:12px 24px;transition:all .15s}.tf-restart:hover{background:#4338ca}.tool-btn-icon.truefalse{background:linear-gradient(135deg,#fecaca,#fca5a5)}.mm-container{background:linear-gradient(135deg,#f8fafc,#f1f5f9);flex:1 1;min-height:0;overflow:hidden;position:relative}.mm-container,.mm-modal-container{border:none;border-radius:0;height:100%}.mm-controls{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:4px;padding:4px;position:absolute;right:8px;top:8px;z-index:10}.mm-controls button{align-items:center;background:#f3f4f6;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .15s;width:28px}.mm-controls button:hover{background:#4f46e5;color:#fff}.mm-zoom-level{color:#6b7280;font-size:11px;font-weight:600;min-width:36px;padding:0 6px;text-align:center}.mm-expand-btn{border-left:1px solid #e5e7eb!important;margin-left:4px;padding-left:8px!important}.mm-canvas{position:absolute;transform-origin:0 0;will-change:transform}.mm-svg{left:0;pointer-events:none;position:absolute;top:0}.mm-line{fill:none;stroke:#cbd5e1;stroke-width:2}.mm-line.active{stroke:#4f46e5;stroke-width:2.5}.mm-node{background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;max-width:140px;padding:8px 14px;position:absolute;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none;z-index:5}.mm-node:hover{border-color:var(--node-color);box-shadow:0 4px 12px #0000001a;transform:translate(-50%,-50%) scale(1.05)}.mm-node.selected{border-color:var(--node-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--node-color) 20%,#0000);max-width:200px}.mm-node.dragging{border-color:var(--node-color);box-shadow:0 8px 24px #0003;cursor:grabbing;transform:translate(-50%,-50%) scale(1.08);z-index:100!important}.mm-hint{background:#ffffffe6;border-radius:12px;bottom:12px;color:#94a3b8;font-size:11px;left:50%;padding:4px 12px;pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap}.mm-root{background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;padding:10px 18px}.mm-root .mm-label{color:#fff;font-weight:700}.mm-root:hover{box-shadow:0 6px 20px #4f46e559;transform:translate(-50%,-50%) scale(1.08)}.mm-label{color:#1e293b;display:block;font-size:12px;font-weight:600;line-height:1.3;text-align:center}.mm-desc{border-top:1px solid #e2e8f0;color:#64748b;font-size:11px;line-height:1.4;margin-top:6px;padding-top:6px;text-align:left}.mm-fullscreen-overlay{animation:mmFadeIn .25s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172af2;bottom:0;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes mmFadeIn{0%{opacity:0}to{opacity:1}}.mm-fullscreen-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:2rem;top:2rem;transition:all .2s;width:48px;z-index:10001}.mm-fullscreen-close:hover{background:#ffffff40;transform:scale(1.05)}.mm-fullscreen-title{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;color:#fff;display:flex;gap:1rem;left:50%;padding:.875rem 2rem;position:fixed;top:2rem;transform:translateX(-50%);z-index:10001}.mm-fullscreen-icon{font-size:1.5rem}.mm-fullscreen-title>span:nth-child(2){font-size:1.25rem;font-weight:600;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mm-fullscreen-count{border-left:1px solid #fff3;color:#ffffffb3;font-size:.95rem;font-weight:500;padding-left:1rem}.mm-fullscreen-canvas{bottom:0;left:0;padding:6rem 2rem 2rem;position:absolute;right:0;top:0}.mm-fullscreen-canvas .mm-container,.mm-fullscreen-container{background:#ffffff08;border:1px solid #ffffff1a;border-radius:16px;height:100%;width:100%}.mm-fullscreen-canvas .mm-controls,.mm-fullscreen-container .mm-controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;gap:6px;padding:6px;right:16px;top:16px}.mm-fullscreen-canvas .mm-controls button,.mm-fullscreen-container .mm-controls button{background:#ffffff1a;border:none;color:#fff;height:36px;width:36px}.mm-fullscreen-canvas .mm-controls button:hover,.mm-fullscreen-container .mm-controls button:hover{background:#4f46e5;color:#fff}.mm-fullscreen-canvas .mm-zoom-level,.mm-fullscreen-container .mm-zoom-level{color:#fffc}.mm-fullscreen-canvas .mm-node,.mm-fullscreen-container .mm-node{background:#fff;box-shadow:0 8px 32px #0000004d;max-width:180px;padding:12px 18px}.mm-fullscreen-canvas .mm-node:hover,.mm-fullscreen-container .mm-node:hover{box-shadow:0 12px 40px #0006;transform:translate(-50%,-50%) scale(1.08)}.mm-fullscreen-canvas .mm-node.selected,.mm-fullscreen-container .mm-node.selected{max-width:260px}.mm-fullscreen-canvas .mm-label,.mm-fullscreen-container .mm-label{font-size:14px}.mm-fullscreen-canvas .mm-root,.mm-fullscreen-container .mm-root{background:linear-gradient(135deg,#4f46e5,#6366f1);box-shadow:0 12px 40px #4f46e566;padding:14px 24px}.mm-fullscreen-canvas .mm-root .mm-label,.mm-fullscreen-container .mm-root .mm-label{color:#fff;font-size:16px}.mm-fullscreen-canvas .mm-line,.mm-fullscreen-container .mm-line{stroke:#ffffff4d;stroke-width:2.5}.mm-fullscreen-canvas .mm-line.active,.mm-fullscreen-container .mm-line.active{stroke:#818cf8;stroke-width:3}@media (max-width:1024px){.tools-main{gap:12px;padding:12px}.tool-btn{padding:10px}.tool-btn-icon{font-size:16px;height:32px;width:32px}.crossword-cell{height:30px;width:30px}.crossword-cell input{font-size:15px}.cell-number{font-size:8px}.crossword-clues{gap:12px;grid-template-columns:1fr;padding:12px}.clue{font-size:12px;padding:6px 8px}.matching-columns{gap:16px;grid-template-columns:1fr}}@media (max-width:480px){.crossword-cell{height:28px;width:28px}.crossword-cell input{font-size:14px}.crossword-grid{gap:2px;padding:6px}.crossword-actions{flex-direction:column}.cw-btn{width:100%}}.fullscreen-learning-viewer{background-color:#f5f5f7;display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100vw;z-index:10000}.fullscreen-learning-viewer.loading{align-items:center;justify-content:center}.fullscreen-completion-overlay,.fullscreen-loading-overlay{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10001}.fullscreen-completion-content,.fullscreen-loading-content{align-items:center;background:#fff;border-radius:32px;box-shadow:0 25px 50px -12px #00000040;display:flex;justify-content:center;max-width:90%;min-height:420px;padding:60px 40px;position:relative;text-align:center;width:460px}.loading-close-button{align-items:center;background:#0000000d;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:44px;justify-content:center;position:absolute;right:24px;top:24px;transition:all .2s;width:44px;z-index:10}.loading-close-button:hover{background:#ef44441a;color:#ef4444;transform:rotate(90deg) scale(1.05)}.loading-inner{align-items:center;display:flex;flex-direction:column;gap:24px;width:100%}.loading-icon{animation:float 2s ease-in-out infinite;font-size:72px;height:72px;line-height:1}.loading-icon,.loading-mascot{align-items:center;display:flex;justify-content:center}.loading-mascot{height:120px}.loading-mascot img{height:100%;object-fit:contain;width:auto}.loading-spinner-ring{height:100px;position:relative;width:100px}.spinner-ring{animation:spin 2s linear infinite;border:3px solid #0000;border-radius:50%;height:100%;position:absolute;width:100%}.spinner-ring:first-child{animation-duration:1.5s;border-top-color:#667eea}.spinner-ring:nth-child(2){animation-direction:reverse;animation-duration:2s;border-right-color:#764ba2}.spinner-ring:nth-child(3){animation-duration:2.5s;border-bottom-color:#f093fb}.loading-text{align-items:center;color:#1e293b;display:flex;font-size:18px;font-weight:600;justify-content:center;letter-spacing:-.3px;margin:0;min-height:54px}.session-title-loading{color:#64748b;font-size:15px;font-weight:500;margin:-12px 0 0;min-height:22px}.loading-hint{color:#94a3b8;font-size:13px;font-weight:500;margin:-12px 0 0;min-height:20px}.loading-dots{align-items:center;display:flex;gap:8px;justify-content:center;margin-top:-8px}.loading-dots .dot{animation:dot-bounce 1.4s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;height:8px;width:8px}.loading-dots .dot:first-child{animation-delay:0s}.loading-dots .dot:nth-child(2){animation-delay:.2s}.loading-dots .dot:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,60%,to{opacity:.5;transform:scale(.8)}30%{opacity:1;transform:scale(1.2)}}@keyframes spin{to{transform:rotate(1turn)}}.fullscreen-completion-content{min-height:auto;padding:40px 36px 36px}.completion-wrapper{align-items:center;display:flex;flex-direction:column;width:100%}.completion-header{margin-bottom:28px;text-align:center}.completion-mascot{display:inline-block;height:100px;margin-bottom:16px;width:100px}.completion-mascot img{height:100%;object-fit:contain;width:100%}.completion-header h2{color:#1e293b;font-size:26px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.completion-message{color:#64748b;font-size:14px;line-height:1.5;margin:0}.completion-message strong{color:#1e293b;font-weight:600}.completion-stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:24px;width:100%}.stat-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:14px;padding:20px 16px;text-align:center;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.stat-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:36px;font-weight:700;line-height:1;margin-bottom:6px}.stat-title{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.completion-buttons{display:flex;flex-direction:column;gap:10px;width:100%}.completion-buttons .completion-submessage{color:#94a3b8;font-size:13px;line-height:1.4;margin:0 0 4px;text-align:center}.continue-btn,.library-btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px 24px;transition:all .2s cubic-bezier(.16,1,.3,1);width:100%}.continue-btn{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 16px #667eea4d;color:#fff}.continue-btn:hover{box-shadow:0 6px 24px #667eea66;transform:translateY(-2px)}.library-btn{background:#fff;border:2px solid #e2e8f0;color:#64748b}.library-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#475569}.continue-btn:active,.library-btn:active{transform:translateY(0)}.fullscreen-header{align-items:center;background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;padding:1rem 1.5rem;z-index:10}.header-title{align-items:center;display:flex;gap:.75rem}.header-icon{font-size:1.5rem}.header-info{display:flex;flex-direction:column;gap:4px}.header-title h1{color:#1a1a1a;font-size:1.125rem;font-weight:600;margin:0}.step-indicator-text{color:#64748b;font-size:13px;font-weight:500}.close-button{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s}.close-button:hover{background-color:#f3f4f6;color:#1a1a1a}.fullscreen-content{display:flex;flex:1 1;gap:1.5rem;overflow:hidden;padding:1.5rem;position:relative}.lesson-content-container,.tools-container{display:flex;flex-direction:column;height:100%;transition:width .3s ease}.tools-container{max-width:50%;min-width:280px}.resize-divider{align-items:center;cursor:col-resize;display:flex;flex-shrink:0;height:100%;justify-content:center;position:relative;-webkit-user-select:none;user-select:none;width:12px}.resize-divider.resizing .resize-handle,.resize-divider:hover .resize-handle{background-color:#4f46e5;width:4px}.resize-handle{background-color:#d1d5db;border-radius:2px;height:40px;transition:all .2s;width:2px}.resize-divider.resizing{cursor:col-resize}.toggle-tools-button{align-items:center;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;border-radius:10px;bottom:1.5rem;box-shadow:0 4px 12px #4f46e54d;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.875rem 1.5rem;position:fixed;right:1.5rem;transition:all .2s ease;z-index:100}.toggle-tools-button:hover{background:linear-gradient(135deg,#4338ca,#4f46e5);box-shadow:0 6px 16px #4f46e566;transform:translateY(-2px)}.toggle-tools-button:active{transform:translateY(0)}@media (max-width:768px){.fullscreen-header{padding:.75rem 1rem}.header-title h1{font-size:1rem}.fullscreen-content{gap:1rem;padding:1rem}.resize-divider{display:none}.lesson-content-container{width:100%!important}.tools-container{display:none}}.learning-setup-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.learning-setup-modal{background:#fff;border-radius:32px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;max-width:700px;overflow-y:auto;width:100%}.setup-modal-header{background:#fff;border-bottom:1px solid #f1f5f9;padding:32px 48px 24px;text-align:center}.setup-modal-header h2{color:#0f172a;font-size:20px;font-weight:600;letter-spacing:-.3px;margin:0 0 8px}.setup-modal-header p{color:#64748b;font-size:14px;margin:0}.mode-selection{display:flex;gap:20px;padding:32px 48px 40px}.mode-option{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:16px;cursor:pointer;flex:1 1;padding:28px 24px;text-align:center;transition:all .2s ease}.mode-option:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.mode-icon{font-size:40px;margin-bottom:16px}.mode-option h3{color:#0f172a;font-size:16px;font-weight:600;margin:0 0 8px}.mode-option p{color:#64748b;font-size:13px;line-height:1.5;margin:0}.setup-form{padding:32px 48px 40px}.back-btn{background:none;border:none;color:#64748b;cursor:pointer;font-size:15px;font-weight:600;margin-bottom:32px;padding:8px 0;transition:color .2s}.back-btn:hover{color:#667eea}.form-group{margin-bottom:28px}.form-group label{color:#0f172a;display:block;font-size:15px;font-weight:600;margin-bottom:12px}.topic-input{border:2px solid #e2e8f0;border-radius:16px;font-family:inherit;font-size:16px;outline:none;padding:16px 20px;transition:all .2s;width:100%}.topic-input:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.topic-input::placeholder{color:#94a3b8}.input-hint{color:#64748b;font-size:13px;font-weight:500;margin:8px 0 0}.form-group select{background:#fff;border:2px solid #e2e8f0;border-radius:16px;cursor:pointer;font-family:inherit;font-size:15px;outline:none;padding:16px 20px;transition:all .2s;width:100%}.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.file-upload-area{margin-top:12px}.file-upload-label{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:20px;cursor:pointer;display:block;padding:48px 32px;position:relative;text-align:center;transition:all .3s}.file-upload-label:hover{background:#f0f4ff;border-color:#667eea}.file-prompt{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:12px}.upload-icon{font-size:48px;opacity:.6}.file-prompt span:nth-child(2){color:#0f172a;font-size:16px;font-weight:600}.file-hint{color:#94a3b8;font-size:14px}.file-selected{align-items:center;color:#0f172a;display:flex;gap:12px;justify-content:center}.file-icon{flex-shrink:0;font-size:32px}.file-info{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.file-name{font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#64748b;font-size:13px}.remove-file-btn{align-items:center;background:#ef44441a;border:none;border-radius:50%;color:#ef4444;cursor:pointer;display:flex;flex-shrink:0;font-size:22px;font-weight:300;height:28px;justify-content:center;line-height:1;position:absolute;right:12px;top:12px;transition:all .2s ease;width:28px;z-index:10}.remove-file-btn:hover{background:#ef444433;transform:scale(1.1)}.start-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea40;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:16px;overflow:hidden;padding:16px 32px;position:relative;transition:all .2s ease;width:100%}.start-btn:before{background:linear-gradient(135deg,#ffffff1a,#fff0);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.start-btn:hover:not(:disabled):before{opacity:1}.start-btn:hover:not(:disabled){box-shadow:0 8px 20px #667eea59;transform:translateY(-2px)}.start-btn:active:not(:disabled){transform:translateY(0)}.start-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:768px){.learning-setup-modal{border-radius:24px 24px 0 0;margin-top:auto;max-width:100%}.setup-modal-header{padding:24px 20px 20px}.setup-modal-header h2{font-size:18px}.setup-modal-header p{font-size:13px}.mode-selection{flex-direction:column}.mode-selection,.setup-form{padding:24px 20px 32px}}.chatbot-page-new{background:#f9fafb;display:flex;min-height:100vh;overflow:hidden}.chatbot-main-container{display:flex;flex:1 1;flex-direction:column;height:100vh;overflow:hidden;position:relative;transition:margin-right .3s cubic-bezier(.4,0,.2,1)}.chatbot-page-new.panel-open .chatbot-main-container{margin-right:360px}.chatbot-header-new{align-items:center;background:#0000;border:none;display:flex;gap:1rem;justify-content:flex-end;left:260px;min-height:auto;padding:1rem 1.5rem;pointer-events:none;position:fixed;right:0;top:0;transition:left .3s cubic-bezier(.4,0,.2,1),right .3s cubic-bezier(.4,0,.2,1);z-index:40}body.sidebar-collapsed .chatbot-header-new{left:72px}.chatbot-page-new.panel-open .chatbot-header-new{right:380px}.sections-floating-btn{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border:1px solid #e5e7ebcc;border-radius:28px;box-shadow:0 4px 20px #0000001a,0 2px 8px #0000000f;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.625rem;padding:.625rem 1rem;pointer-events:auto;transition:all .3s cubic-bezier(.4,0,.2,1)}.sections-floating-btn:hover{background:#fffffffa;border-color:#3b82f699;box-shadow:0 8px 32px #3b82f633,0 4px 12px #3b82f61f;color:#3b82f6;transform:translateY(-2px)}.sections-floating-btn:active{box-shadow:0 2px 8px #3b82f626;transform:translateY(0)}.sections-floating-btn svg{height:18px;width:18px}.chatbot-messages-new{display:flex;flex:1 1;flex-direction:column;margin-bottom:0;overflow-x:hidden;overflow-y:auto;padding:1rem 1rem 0;scroll-behavior:smooth}.chatbot-messages-new:after{content:"";display:block;flex-shrink:0;height:55px}.chatbot-messages-new::-webkit-scrollbar{width:8px}.chatbot-messages-new::-webkit-scrollbar-track{background:#0000}.chatbot-messages-new::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.chatbot-messages-new::-webkit-scrollbar-thumb:hover{background:#9ca3af}.welcome-message-new{animation:fadeInUp .5s ease-out;margin:0 auto;max-width:700px;padding:0 1rem;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-mascot-container{animation:bounce 2s ease-in-out infinite;margin-bottom:.75rem}.welcome-mascot{filter:drop-shadow(0 4px 12px rgba(59,130,246,.2));height:80px;object-fit:contain;width:80px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.welcome-message-new h2{color:#1e293b;font-size:1.25rem;font-weight:800;margin:0 0 .25rem}.welcome-message-new p{color:#64748b;font-size:.875rem;line-height:1.4;margin:0 0 .75rem}.learning-mode-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:1.5rem;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.learning-mode-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.learning-mode-card.dragging{background:#faf5ff;border-color:#667eea;box-shadow:0 8px 24px #667eea33}.learning-mode-header{border-bottom:1px solid #f3f4f6;margin-bottom:.5rem;padding-bottom:.5rem}.learning-mode-text{width:100%}.learning-mode-text h3{color:#111827;font-size:1.125rem;font-weight:600;line-height:1.3;margin:0 0 .25rem}.learning-mode-text p{color:#6b7280;font-size:.875rem;line-height:1.4;margin:0}.learning-mode-actions{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.learning-action-btn{align-items:center;background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:1rem;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1)}.learning-action-btn:hover{background:#f5f5f5;border-color:#667eea;box-shadow:0 2px 8px #0000000f;transform:translateY(-1px)}.learning-action-btn:active{transform:translateY(0)}.btn-icon{flex-shrink:0}.btn-icon svg{color:#667eea;height:20px;transition:transform .2s ease;width:20px}.learning-action-btn:hover .btn-icon svg{transform:scale(1.05)}.btn-content{display:flex;flex:1 1;flex-direction:column;gap:.125rem}.btn-title{color:#111827;font-size:.875rem;font-weight:600;line-height:1.3}.btn-subtitle{color:#9ca3af;font-size:.75rem;line-height:1.3}.btn-arrow{flex-shrink:0;opacity:0;transform:translateX(-4px);transition:all .2s ease}.btn-arrow svg{color:#667eea;height:16px;width:16px}.learning-action-btn:hover .btn-arrow{opacity:1;transform:translateX(0)}.drop-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#667eeaf2;border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.drop-content{color:#fff;text-align:center}.drop-content svg{animation:float 1.5s ease-in-out infinite;height:40px;margin-bottom:.625rem;width:40px}.drop-content p{font-size:1rem;font-weight:600;letter-spacing:-.01em;margin:0}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.chat-divider{align-items:center;display:flex;gap:.75rem;margin:1rem 0}.chat-divider span{color:#9ca3af;font-size:.75rem;font-weight:500;white-space:nowrap}.chat-divider:after,.chat-divider:before{background:#e5e7eb;content:"";flex:1 1;height:1px}.welcome-quick-actions{display:flex;flex-wrap:wrap;gap:.625rem;justify-content:center}.quick-action-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #00000014;color:#1e293b;cursor:pointer;display:flex;font-size:.8125rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.quick-action-btn:hover{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633;transform:translateY(-2px)}.quick-action-btn span{font-size:1.25rem}.typing-indicator-new{align-items:center;animation:fadeIn .3s ease-out;background:#fff;border-radius:18px;border-bottom-left-radius:6px;box-shadow:0 2px 8px #00000014;display:inline-flex;gap:.5rem;max-width:-webkit-fit-content;max-width:fit-content;min-width:80px;padding:.875rem 1.125rem}.thinking-text-container{align-items:center;display:flex;flex-shrink:0;min-height:1.2rem}.thinking-text{-webkit-text-fill-color:#0000;animation:fadeIn .5s ease-out forwards;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:.9rem;font-weight:600;line-height:1.2;opacity:0;white-space:nowrap}.thinking-text.fade-out{animation:fadeOut .3s ease-out forwards}.typing-dots{align-items:center;display:flex;flex-shrink:0;gap:.3rem}.typing-dot{animation:wave 1.4s ease-in-out infinite;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;box-shadow:0 1px 3px #3b82f626;height:5px;width:5px}.typing-dot:first-child{animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}@keyframes wave{0%,60%,to{opacity:.5;transform:scale(.8)}30%{opacity:1;transform:scale(1.3)}}.streaming-message{position:relative}.streaming-message .message-content{display:inline;position:relative}.streaming-cursor{animation:blink .8s infinite;color:#3b82f6;display:inline-block;font-weight:600;margin-left:2px}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.streaming-message .artifact-container{animation:artifactFadeIn .4s ease-out}@keyframes artifactFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.toast-container{animation:slideInRight .3s ease-out;position:fixed;right:1rem;top:1rem;z-index:1000}@keyframes slideInRight{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.toast{align-items:center;background:#fff;border-left:4px solid;border-radius:10px;box-shadow:0 4px 16px #00000026;display:flex;gap:.75rem;max-width:400px;min-width:300px;padding:1rem 1.25rem}.toast-success{background:#f0fdf4;border-left-color:#10b981}.toast-error{background:#fef2f2;border-left-color:#ef4444}.toast-info{background:#eff6ff;border-left-color:#3b82f6}.toast span{color:#1e293b;flex:1 1;font-size:.875rem;font-weight:500}.toast button{align-items:center;background:#0000;border:none;border-radius:4px;color:#64748b;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:24px}.toast button:hover{background:#0000000d;color:#1e293b}@media (max-width:768px){.chatbot-page-new.panel-open .chatbot-main-container{margin-right:0}.chatbot-header-new{left:0!important;min-height:56px;padding:.625rem .75rem;right:0!important}.chatbot-page-new.panel-open .chatbot-header-new{right:0!important}.chatbot-title-new h1{font-size:1.125rem}.chatbot-icon-new{font-size:1.5rem}.sidebar-toggle-btn{height:36px;width:36px}.sidebar-toggle-btn svg{height:20px;width:20px}.btn-label{display:none}.toggle-panel-btn{padding:.5rem}.new-chat-btn-header{font-size:.8125rem;padding:.5rem .75rem}.chatbot-messages-new{padding:4.5rem .75rem 1rem}.chatbot-messages-new:after{height:80px}.welcome-message-new{margin:.75rem auto;padding:0 .75rem}.welcome-icon-large{font-size:2.5rem;margin-bottom:.375rem}.welcome-message-new h2{font-size:1.25rem}.welcome-message-new p{font-size:.875rem;margin-bottom:.75rem}.quick-action-btn{font-size:.8125rem;padding:.625rem 1rem}.quick-action-btn span{font-size:1.125rem}.learning-mode-card{margin-bottom:1.25rem;padding:1.125rem}.learning-mode-header{margin-bottom:1rem;padding-bottom:1rem}.learning-mode-text h3{font-size:1rem}.learning-mode-text p{font-size:.8125rem}.learning-mode-actions{gap:.625rem;grid-template-columns:1fr}.learning-action-btn{gap:.625rem;padding:.875rem}.btn-icon svg{height:18px;width:18px}.btn-title{font-size:.8125rem}.btn-subtitle{font-size:.6875rem}.btn-arrow svg{height:14px;width:14px}.drop-content svg{height:36px;width:36px}.drop-content p{font-size:.9375rem}.upload-document-btn{font-size:.875rem;padding:.625rem 1.25rem}.upload-document-btn svg{height:18px;width:18px}.typing-indicator-new{padding:.875rem 1rem}.toast-container{bottom:1rem;left:1rem;right:1rem;top:auto}.toast{max-width:100%;min-width:auto}}@media (min-width:769px) and (max-width:1024px){.chatbot-messages-new{padding:1.5rem}.welcome-message-new{max-width:500px}}@media (min-width:1440px){.chatbot-messages-new{padding:2rem}.welcome-message-new{max-width:700px}}.modal-overlay{animation:fadeIn .2s ease-out;background:#0009;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}.upload-mode-modal{animation:slideInScale .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;left:50%;max-width:540px;padding:2rem;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:1001}@keyframes slideInScale{0%{opacity:0;transform:translate(-50%,-48%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.upload-mode-modal h3{color:#1e293b;font-size:1.5rem;font-weight:800;margin:0 0 .5rem;text-align:center}.modal-subtitle{color:#64748b;font-size:.95rem;margin:0 0 1.5rem;text-align:center}.upload-mode-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.upload-mode-option{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;gap:1rem;padding:1.25rem;text-align:left;transition:all .2s}.upload-mode-option:hover{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-color:#3b82f6;box-shadow:0 8px 24px #3b82f626;transform:translateY(-2px)}.option-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.option-mascot{filter:drop-shadow(0 2px 8px rgba(59,130,246,.15));height:64px;object-fit:contain;transition:transform .3s ease;width:64px}.upload-mode-option:hover .option-mascot{transform:scale(1.1) rotate(-5deg)}.option-content h4{align-items:center;color:#1e293b;display:flex;font-size:1.125rem;font-weight:700;gap:.5rem;margin:0 0 .25rem}.option-content p{color:#64748b;font-size:.875rem;line-height:1.5;margin:0}.beta-badge{background:linear-gradient(135deg,#f59e0b,#f97316);border-radius:4px;box-shadow:0 2px 4px #f59e0b40;color:#fff;display:inline-block;font-size:.625rem;font-weight:700;letter-spacing:.5px;padding:.15rem .4rem;text-transform:uppercase}.modal-cancel-btn{background:#0000;border:2px solid #e5e7eb;border-radius:10px;color:#64748b;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem;transition:all .2s;width:100%}.modal-cancel-btn:hover{background:#f3f4f6;color:#1e293b}.message-wrapper{margin-left:auto;margin-right:auto;max-width:900px;width:100%}@media (max-width:768px){.chatbot-header-new{height:60px;padding:.75rem .875rem}.logo-sidebar-btn{padding:.375rem}.logo-image{height:40px;width:40px}.sections-floating-btn{font-size:.8125rem;padding:.5rem .75rem}.sections-floating-btn .btn-label{display:none}.sections-floating-btn svg{height:20px;width:20px}.message-wrapper{max-width:100%}.upload-mode-modal{max-width:95%;padding:1.5rem}.upload-mode-modal h3{font-size:1.25rem}.modal-subtitle{font-size:.875rem}.option-mascot{height:56px;width:56px}.welcome-mascot{height:100px;width:100px}.upload-mode-option{padding:1rem}.option-content h4{font-size:1rem}.option-content p{font-size:.8125rem}}.unified-sidebar{background:#0000;bottom:0;display:flex;flex-direction:column;left:0;overflow:hidden;padding:.75rem;position:fixed;top:0;transition:width .3s cubic-bezier(.4,0,.2,1);width:260px;z-index:1000}.unified-sidebar.collapsed{padding:.75rem .5rem;width:72px}.sidebar-header-compact{align-items:center;display:flex;flex-shrink:0;gap:.25rem;justify-content:space-between;margin-bottom:.5rem;padding:.5rem}.sidebar-logo-compact{align-items:center;cursor:pointer;display:flex;flex-shrink:0;gap:.5rem;transition:all .2s}.sidebar-logo-compact:hover{opacity:.8}.sidebar-logo-img{flex-shrink:0;height:32px;object-fit:contain;width:32px}.sidebar-logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:.875rem;font-weight:800;letter-spacing:.5px;white-space:nowrap}.sidebar-header-actions{gap:.25rem}.sidebar-header-actions,.sidebar-icon-btn{align-items:center;display:flex;flex-shrink:0}.sidebar-icon-btn{background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;justify-content:center;padding:.375rem;transition:all .2s}.sidebar-icon-btn:hover{background:#f3f4f6;color:#3b82f6}.sidebar-icon-btn.active{background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);color:#3b82f6}.sidebar-icon-btn svg{height:18px;width:18px}.sidebar-collapsed-actions{border-bottom:1px solid #f3f4f6;display:flex;justify-content:center;padding:.75rem}.sidebar-icon-btn-large{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:8px;box-shadow:0 2px 8px #3b82f640;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar-icon-btn-large:hover{box-shadow:0 4px 16px #3b82f659;transform:translateY(-2px)}.sidebar-icon-btn-large svg{height:20px;width:20px}.collapsed .sidebar-header-compact{align-items:center;flex-direction:column;gap:.5rem}.collapsed .sidebar-logo-compact{justify-content:center;position:relative}.sidebar-expand-on-hover{align-items:center;background:linear-gradient(135deg,#3b82f6f2,#8b5cf6f2);border:none;border-radius:6px;box-shadow:0 2px 8px #3b82f64d;color:#fff;cursor:pointer;display:flex;justify-content:center;left:50%;opacity:0;padding:.5rem;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .2s}.sidebar-logo-compact:hover .sidebar-expand-on-hover{opacity:1;pointer-events:auto}.sidebar-expand-on-hover:hover{box-shadow:0 4px 12px #3b82f666;transform:translate(-50%,-50%) scale(1.1)}.sidebar-expand-on-hover svg{height:18px;width:18px}.sidebar-search-expanded{align-items:center;animation:slideDown .2s ease-out;background:#fff;border:2px solid #3b82f6;border-radius:8px;box-shadow:0 0 0 3px #3b82f61a;display:flex;gap:.5rem;margin:0 .75rem .75rem;padding:.625rem .75rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sidebar-search-expanded input{background:#0000;border:none;color:#1e293b;flex:1 1;font-size:.875rem;outline:none}.sidebar-search-expanded input::placeholder{color:#9ca3af}.search-close-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.25rem;transition:all .2s}.search-close-btn:hover{background:#f3f4f6;color:#64748b}.search-close-btn svg{height:16px;width:16px}.sidebar-content{display:flex;flex:1 1;flex-direction:column;overflow-x:hidden;overflow-y:auto;padding:0}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:#0000}.sidebar-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}.sidebar-section{margin-bottom:1rem}.sidebar-section-centered{align-items:center;display:flex;flex:1 1;justify-content:center;margin-bottom:0}.sidebar-section-centered .sidebar-tools-compact{width:100%}.sidebar-divider{background:#00000014;height:1px;margin:.5rem 0}.sidebar-section-header{margin-bottom:.25rem;padding:.375rem .75rem}.sidebar-section-header span{color:#9ca3af;font-size:.6875rem;font-weight:700;letter-spacing:.5px}.sidebar-section-header-compact{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem;padding:.375rem .75rem}.sidebar-section-header-compact span{color:#9ca3af;font-size:.6875rem;font-weight:700;letter-spacing:.5px}.header-action-btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:.6875rem;font-weight:600;gap:.25rem;padding:.25rem .5rem;transition:all .2s}.header-action-btn:hover{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-color:#3b82f6;color:#3b82f6}.header-action-btn svg{height:12px;width:12px}.recent-header-left{align-items:center;display:flex;gap:.5rem}.show-toggle-btn{align-items:center;background:#667eea14;border:1px solid #667eea33;border-radius:4px;color:#667eea;cursor:pointer;display:flex;height:20px;justify-content:center;padding:0;transition:all .2s ease;width:20px}.show-toggle-btn:hover{background:#667eea26;border-color:#667eea66;transform:scale(1.05)}.show-toggle-btn svg{height:12px;width:12px}.sidebar-loading{color:#9ca3af;font-size:.875rem;padding:1rem .75rem;text-align:center}.sidebar-loading-dot{animation:pulse 1.5s ease-in-out infinite;background:#3b82f6;border-radius:50%;height:8px;margin:0 auto;width:8px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.sidebar-empty-compact{padding:.75rem;text-align:center}.sidebar-empty-compact p{color:#9ca3af;font-size:.8125rem;margin:0}.sidebar-lessons-list{animation:fadeIn .3s ease-in-out;display:flex;flex-direction:column;gap:.125rem}.sidebar-lesson-item{align-items:center;border-left:3px solid #0000;border-radius:6px;cursor:pointer;display:flex;gap:.625rem;padding:.5rem .75rem;position:relative;transition:background-color .2s ease,border-left .2s ease,padding-left .2s ease,box-shadow .2s ease}.sidebar-lesson-item:hover{background:#f9fafb}.sidebar-lesson-item:active{background:#f3f4f6}.sidebar-lesson-item.active{background:#f3f4f6;border-left-color:#3b82f6}.sidebar-lesson-item.active:hover{background:#e5e7eb}.collapsed .sidebar-lesson-item{border-left:none;box-shadow:inset 0 0 0 2px #0000;justify-content:center;padding:.5rem}.collapsed .sidebar-lesson-item.active{box-shadow:inset 0 0 0 2px #3b82f6}.lesson-icon{align-items:center;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:6px;display:flex;flex-shrink:0;font-size:1.125rem;height:28px;justify-content:center;width:28px}.lesson-content{flex:1 1;min-width:0}.lesson-title{color:#1e293b;font-size:.8125rem;font-weight:600;margin-bottom:.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-artifacts{align-items:center;display:flex;flex-wrap:wrap;gap:.375rem}.artifact-badge{align-items:center;color:#64748b;display:flex;font-size:.625rem;gap:.125rem}.artifact-badge.mode-badge{background:#667eea1a;border-radius:4px;color:#667eea;font-weight:600;padding:.125rem .375rem}.lesson-time{color:#9ca3af;flex-shrink:0;font-size:.625rem}.sidebar-tools-compact{display:flex;flex-direction:column;gap:.25rem}.sidebar-tool-compact{align-items:center;background:#0000;border:none;border-radius:8px;color:#52525b;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;padding:.625rem .75rem;text-align:left;transition:all .15s ease;width:100%}.sidebar-tool-compact:hover{background:#0000000d;color:#18181b}.sidebar-tool-compact.active{background:#3b82f61a;color:#2563eb;font-weight:600}.sidebar-tool-compact.new-chat-btn-highlight{background:linear-gradient(135deg,#3b82f6,#8b5cf6);box-shadow:0 2px 8px #3b82f640;color:#fff;font-weight:600;margin-bottom:.5rem}.sidebar-tool-compact.new-chat-btn-highlight:hover{background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 4px 12px #3b82f659;color:#fff;transform:translateY(-1px)}.sidebar-tool-compact.new-chat-btn-highlight:active{transform:translateY(0)}.sidebar-tool-compact.new-chat-btn-highlight .tool-icon{color:#fff}.sidebar-tool-compact.new-lesson-btn-highlight{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea40;color:#fff;font-weight:600;margin-bottom:.5rem}.sidebar-tool-compact.new-lesson-btn-highlight:hover{background:linear-gradient(135deg,#5568d3,#66398d);box-shadow:0 4px 12px #667eea59;color:#fff;transform:translateY(-1px)}.sidebar-tool-compact.new-lesson-btn-highlight:active{transform:translateY(0)}.sidebar-tool-compact.new-lesson-btn-highlight .tool-icon{color:#fff}.collapsed .sidebar-tool-compact{justify-content:center;padding:.5rem}.tool-icon{align-items:center;display:flex;flex-shrink:0;font-size:1.125rem;justify-content:center}.tool-icon svg{color:currentColor}.tool-label{flex:1 1}.sidebar-bottom{flex-shrink:0;margin-top:.5rem;padding:.5rem 0}.sidebar-user-section{position:relative}.sidebar-user-btn{align-items:center;background:#0000;border:none;border-radius:6px;cursor:pointer;display:flex;gap:.625rem;padding:.5rem .625rem;text-align:left;transition:all .2s;width:100%}.sidebar-user-btn:hover{background:#f9fafb}.collapsed .sidebar-user-btn{justify-content:center;padding:.5rem}.user-avatar{align-items:center;background:#e5e7eb;border-radius:50%;color:#6b7280;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s;width:32px}.sidebar-user-btn:hover .user-avatar{background:#d1d5db;color:#374151}.user-avatar svg{height:18px;width:18px}.user-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.user-name{color:#1e293b;font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subscription-badge-sidebar{align-items:center;border-radius:4px;display:inline-flex;font-size:.6875rem;font-weight:600;gap:.25rem;letter-spacing:.02em;padding:.125rem .5rem;width:-webkit-fit-content;width:fit-content}.subscription-badge-sidebar.free{background:#f8fafc;border:1px solid #e2e8f0;color:#64748b}.subscription-badge-sidebar.basic{background:#eff6ff;border:1px solid #bfdbfe;color:#3b82f6}.subscription-badge-sidebar.basic svg{font-size:.625rem}.subscription-badge-sidebar.premium{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.subscription-badge-sidebar.premium svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.1));font-size:.625rem}.user-menu-icon{color:#9ca3af;flex-shrink:0;height:14px;width:14px}.sidebar-dropdown-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.sidebar-user-dropdown{animation:dropdownSlideUp .2s cubic-bezier(.4,0,.2,1);background:#fff;border:1px solid #e5e7eb;border-radius:12px;bottom:100%;box-shadow:0 10px 40px #00000026;left:.75rem;margin-bottom:.5rem;padding:.5rem;position:absolute;right:.75rem;z-index:100}@keyframes dropdownSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{align-items:center;background:#0000;border:none;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.625rem;padding:.625rem .75rem;text-align:left;transition:all .15s;width:100%}.dropdown-item:hover{background:#f3f4f6}.dropdown-item-danger{color:#ef4444}.dropdown-item-danger:hover{background:#fef2f2}.dropdown-icon{flex-shrink:0;font-size:1.125rem}.dropdown-icon-svg{color:#6b7280;flex-shrink:0;height:18px;width:18px}.dropdown-item:hover .dropdown-icon-svg{color:#374151}.dropdown-item-danger .dropdown-icon-svg{color:#ef4444}.dropdown-divider{background:#f3f4f6;height:1px;margin:.5rem 0}.dropdown-submenu{border-left:2px solid #f3f4f6;display:flex;flex-direction:column;margin-left:1.5rem;margin-top:.25rem;padding-left:.5rem}.dropdown-subitem{color:#6b7280;font-size:.8125rem;padding:.5rem .75rem}.dropdown-subitem:hover{background:#f9fafb;color:#374151}.sidebar-auth-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem;transition:all .2s;width:100%}.sidebar-auth-btn:hover{box-shadow:0 4px 16px #3b82f666;transform:translateY(-1px)}.sidebar-auth-btn svg{height:18px;width:18px}.collapsed .sidebar-auth-btn span,.mobile-menu-toggle{display:none}.sidebar-mobile-backdrop{display:none!important}@media (max-width:768px){.sidebar-mobile-backdrop{display:block!important}}.logout-confirm-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.logout-confirm-modal{animation:slideUp .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:1.5rem;width:90%}.logout-confirm-header{align-items:center;display:flex;gap:.75rem;margin-bottom:1rem}.logout-confirm-header svg{color:#ef4444;flex-shrink:0;height:24px;width:24px}.logout-confirm-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.logout-confirm-message{color:#64748b;font-size:.9375rem;line-height:1.5;margin:0 0 1.5rem}.logout-confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.logout-cancel-btn,.logout-confirm-btn{border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:all .2s}.logout-cancel-btn{background:#f3f4f6;color:#374151}.logout-cancel-btn:hover{background:#e5e7eb}.logout-confirm-btn{background:#ef4444;color:#fff}.logout-confirm-btn:hover{background:#dc2626;box-shadow:0 4px 12px #ef44444d;transform:translateY(-1px)}.logout-confirm-btn:active{transform:translateY(0)}.sidebar-study-tools-btn,.sidebar-study-tools-wrapper{position:relative}.sidebar-study-tools-btn.expanded{background:#3b82f614;color:#3b82f6}.sidebar-study-tools-btn.has-active,.sidebar-study-tools-btn.has-active .tool-icon{color:#3b82f6}.sidebar-study-tools-btn .study-tools-arrow{color:#9ca3af;flex-shrink:0}.sidebar-study-tools-btn.expanded .study-tools-arrow{color:#3b82f6}.study-tools-dropdown{animation:dropdownFadeIn .15s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #0000001f,0 4px 12px #00000014;left:0;margin-top:.25rem;padding:.5rem;position:absolute;right:0;top:100%;z-index:100}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.study-tools-dropdown-item{align-items:center;background:#0000;border:none;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:.625rem;padding:.5rem .75rem;text-align:left;transition:all .15s;width:100%}.study-tools-dropdown-item:hover{background:#f3f4f6}.study-tools-dropdown-item.active{background:#3b82f614;color:#2563eb}.study-tools-dropdown-item .tool-icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.study-tools-dropdown-item .tool-label{flex:1 1}.study-tools-dropdown-divider{background:#f3f4f6;height:1px;margin:.375rem 0}.study-tools-view-all{color:#3b82f6;font-weight:600}.study-tools-view-all:hover{background:#3b82f614}.study-tools-view-all .tool-icon{color:#3b82f6}@media (max-width:768px){.mobile-menu-toggle{align-items:center;background:#fff;border:none;border-radius:14px;box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a;cursor:pointer;display:flex;justify-content:center;left:1.25rem;padding:.75rem;position:fixed;top:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:50}.mobile-menu-toggle:hover{background:#f8f9fa;box-shadow:0 6px 16px #0000001f,0 3px 6px #0000000f;transform:translateY(-1px)}.mobile-menu-toggle:active{transform:scale(.96) translateY(0)}.mobile-menu-toggle svg{color:#3b82f6;height:24px;width:24px}.unified-sidebar{background:linear-gradient(180deg,#fff 0,#fafbfc);border-bottom-right-radius:28px;border-top-right-radius:28px;bottom:0;height:100vh;height:100dvh;left:0;max-width:320px;overflow:hidden;padding:1.25rem;top:0;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1);width:85%}.unified-sidebar,.unified-sidebar.collapsed{box-shadow:none;transform:translateX(-100%)}.unified-sidebar:not(.collapsed){box-shadow:12px 0 32px #0000001a,8px 0 16px #0000000f,4px 0 8px #0000000a;transform:translateX(0)}.sidebar-mobile-backdrop{animation:fadeIn .25s ease-out;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);background:#00000073;bottom:0;display:block;left:0;position:fixed;right:0;top:0;z-index:999}@keyframes fadeIn{0%{backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);opacity:0}to{backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:1}}.sidebar-collapse-btn{border-radius:10px;order:-1}.unified-sidebar .sidebar-header-compact{margin-bottom:1.25rem;padding:.5rem}.unified-sidebar .sidebar-content{margin-bottom:1rem;padding:0}.unified-sidebar .sidebar-footer{margin-top:auto;padding:0}.sidebar-lesson-item,.sidebar-tool-compact{border-radius:12px;margin-bottom:.25rem}.sidebar-user-btn{border-radius:12px}.sidebar-lesson-item,.sidebar-lesson-item:hover,.sidebar-tool-compact,.sidebar-tool-compact:hover,.sidebar-user-btn,.sidebar-user-btn:hover{transform:none!important}.sidebar-section-header span{font-size:.75rem}.sidebar-section{margin-bottom:1.25rem}.sidebar-logo-img{height:36px;width:36px}.sidebar-logo-text{font-size:.9375rem}.sidebar-icon-btn{border-radius:10px;padding:.5rem}.sidebar-user-dropdown{border-radius:16px;box-shadow:0 12px 40px #0003}.dropdown-item{border-radius:10px}}@media (min-width:769px){.collapsed .sidebar-library-btn,.collapsed .sidebar-new-lesson-btn,.collapsed .sidebar-tool-item,.collapsed .sidebar-user-btn{position:relative}.collapsed .sidebar-library-btn:hover:after,.collapsed .sidebar-new-lesson-btn:hover:after,.collapsed .sidebar-tool-item:hover:after{background:#1e293b;border-radius:6px;box-shadow:0 4px 12px #00000026;color:#fff;content:attr(title);font-size:.875rem;left:calc(100% + .5rem);padding:.5rem .75rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap;z-index:1000}}.library-page{margin:0 auto;max-width:1200px;min-height:calc(100vh - 64px);padding:80px 2rem 2rem;width:100%}.library-header{border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1.5rem}.library-header-content{align-items:center;display:flex;gap:1.5rem;justify-content:space-between}.library-header-left{align-items:center;display:flex;gap:.875rem}.library-icon{align-items:center;background:#f3f4f6;border-radius:10px;display:flex;height:44px;justify-content:center;width:44px}.library-icon svg{color:#6b7280;height:24px;width:24px}.library-header-text h1{color:#111827;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0}.library-header-text p{color:#6b7280;font-size:.8125rem;font-weight:500;margin:.125rem 0 0}.library-search{flex-shrink:0;position:relative;width:280px}.library-search .search-icon{color:#9ca3af;height:18px;left:.875rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:18px}.library-search input{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;color:#111827;font-size:.875rem;padding:.625rem 2.25rem .625rem 2.625rem;transition:all .2s;width:100%}.library-search input::placeholder{color:#9ca3af}.library-search input:focus{background:#fff;border-color:#d1d5db;outline:none}.library-search .clear-search{align-items:center;background:#0000;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;height:22px;justify-content:center;padding:.25rem;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:all .15s;width:22px}.library-search .clear-search:hover{background:#f3f4f6;color:#6b7280}.library-search .clear-search svg{height:14px;width:14px}.library-header-right{align-items:center;display:flex;gap:.75rem}.create-new-wrapper{position:relative}.create-new-btn{align-items:center;background:#3b82f6;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1rem;transition:all .15s ease}.create-new-btn:hover{background:#2563eb}.create-new-btn svg{height:18px;width:18px}.create-new-btn .chevron{height:16px;margin-left:-.125rem;opacity:.7;width:16px}.create-dropdown{animation:dropdownFade .15s ease;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 12px 32px #0000001f;min-width:260px;padding:.5rem;position:absolute;right:0;top:calc(100% + .5rem);z-index:200}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.create-option{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;text-align:left;transition:all .15s ease;width:100%}.create-option:hover{background:#f3f4f6}.create-option .option-icon{align-items:center;background:#f3f4f6;border-radius:8px;color:#6b7280;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.create-option:hover .option-icon{background:#e5e7eb;color:#374151}.create-option .option-icon svg{height:18px;width:18px}.create-option .option-text{display:flex;flex-direction:column;gap:.125rem}.create-option .option-label{color:#111827;font-size:.875rem;font-weight:600}.create-option .option-desc{color:#6b7280;font-size:.75rem}.library-tabs{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2.25rem}.library-tab{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;font-size:1.05rem;font-weight:500;gap:.5rem;padding:.75rem 1.75rem;transition:all .2s}.library-tab:hover{border-color:#3b82f6;border-color:var(--tab-color,#3b82f6);box-shadow:0 2px 6px #3b82f626;transform:translateY(-2px)}.library-tab:hover,.library-tab:hover .tab-icon{color:#3b82f6;color:var(--tab-color,#3b82f6)}.library-tab.active{background:#3b82f6;border-color:#3b82f6;box-shadow:0 3px 10px #3b82f659;color:#fff}.library-tab.active .tab-icon{color:inherit}.tab-icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.tab-icon svg{height:100%;width:100%}.tab-count,.tab-label{font-weight:600}.tab-count{background:#fff3;border-radius:12px;color:inherit;font-size:.85rem;min-width:24px;padding:.15rem .5rem;text-align:center}.library-tab.active .tab-count{background:#ffffff40}.library-controls{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem}.library-filters{display:flex;flex:1 1;flex-wrap:wrap;gap:.375rem}.library-sort{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.library-sort label{align-items:center;color:#94a3b8;display:flex;font-size:.8125rem;font-weight:500;gap:.375rem}.library-sort label svg{display:none}.library-sort select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .375rem center;background-repeat:no-repeat;background-size:14px;border:1.5px solid #e2e8f0;border-radius:8px;color:#374151;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.4375rem 1.75rem .4375rem .625rem;transition:all .15s ease}.library-sort select:hover{border-color:#cbd5e1}.library-sort select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.filter-chip{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:.25rem;padding:.375rem .75rem;transition:all .15s ease}.filter-chip:hover{background:color-mix(in srgb,#3b82f6 5%,#fff);background:color-mix(in srgb,var(--chip-color,#3b82f6) 5%,#fff);color:#3b82f6;color:var(--chip-color,#3b82f6)}.filter-chip.active,.filter-chip:hover{border-color:#3b82f6;border-color:var(--chip-color,#3b82f6)}.filter-chip.active{background:#3b82f6;background:var(--chip-color,#3b82f6);color:#fff}.chip-icon{align-items:center;display:flex;height:14px;justify-content:center;width:14px}.chip-icon svg{height:100%;width:100%}.chip-count{background:#0000000f;border-radius:6px;font-size:.6875rem;font-weight:600;min-width:18px;padding:.0625rem .3125rem;text-align:center}.filter-chip.active .chip-count{background:#ffffff40}.library-feed{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.content-card{border:1px solid #e5e7eb;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;transition:all .2s ease}.content-card:hover{border-color:#d1d5db;border-color:var(--card-color,#d1d5db);box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.content-card-header{align-items:center;justify-content:space-between;padding:1rem 1.25rem .5rem}.card-type-indicator{align-items:center;color:#6b7280;color:var(--card-color,#6b7280);display:flex;gap:.5rem}.card-type-indicator .type-icon{align-items:center;display:flex;height:20px;justify-content:center;width:20px}.card-type-indicator .type-icon svg{height:100%;width:100%}.card-type-indicator .type-label{font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.card-date{color:#9ca3af;font-size:.75rem;font-weight:500}.content-card-body{flex:1 1;padding:.25rem 1.25rem 1rem}.content-card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#111827;display:-webkit-box;font-size:1.0625rem;font-weight:600;line-height:1.35;margin:0 0 .5rem;overflow:hidden}.content-card-stat{color:#6b7280;font-size:.8125rem;font-weight:500;margin:0}.content-card-actions{align-items:center;background:#f9fafb;border-top:1px solid #f3f4f6;gap:.75rem;justify-content:space-between;padding:.875rem 1.25rem}.card-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-weight:600;gap:.375rem;justify-content:center;transition:all .15s ease}.card-btn.primary{background:#3b82f6;background:var(--card-color,#3b82f6);color:#fff;font-size:.8125rem;padding:.5rem 1.125rem}.card-btn.primary:hover{filter:brightness(1.1)}.card-btn.primary svg{height:14px;width:14px}.card-secondary-actions{align-items:center;display:flex;gap:.375rem}.card-btn.secondary{background:#fff;border:1px solid #e5e7eb;color:#6b7280;height:34px;padding:0;width:34px}.card-btn.secondary:hover{background:#f3f4f6;border-color:#d1d5db;color:#374151}.card-btn.secondary.danger:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.card-btn.secondary svg{height:16px;width:16px}.card-menu-item.delete{color:#ef4444}.card-menu-item.delete:hover{background:#fef2f2;color:#dc2626}.card-menu-item svg{height:16px;width:16px}.library-empty-state{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;display:flex;flex-direction:column;justify-content:center;margin:2rem auto;max-width:500px;padding:4rem 2rem;text-align:center}.library-empty-state .empty-icon{color:#94a3b8;margin-bottom:1.5rem}.library-empty-state .empty-icon svg{height:64px;width:64px}.library-empty-state h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.library-empty-state p{color:#64748b;font-size:.9375rem;margin:0 0 1.5rem;max-width:350px}.library-empty-state .empty-cta{align-items:center;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:10px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.library-empty-state .empty-cta:hover{box-shadow:0 6px 16px #3b82f666;transform:translateY(-2px)}@media (max-width:768px){.library-page{padding:70px 1rem 1.5rem}.library-header{margin-bottom:1.25rem;padding-bottom:1.25rem}.library-header-content{align-items:stretch;flex-direction:column;gap:1rem}.library-header-left{justify-content:flex-start}.library-header-right{flex-direction:row;gap:.625rem}.library-icon{height:40px;width:40px}.library-icon svg{height:22px;width:22px}.library-header-text h1{font-size:1.375rem}.library-header-text p{font-size:.75rem}.library-search{flex:1 1;width:auto}.create-new-btn{padding:.625rem .875rem}.create-new-btn .chevron,.create-new-btn span{display:none}.create-dropdown{min-width:240px;right:0}.library-controls{align-items:stretch;flex-direction:column;gap:.75rem}.library-sort{justify-content:flex-end}.library-filters{gap:.375rem}}@media (max-width:640px){.filter-chip{font-size:.75rem;gap:.1875rem;padding:.3125rem .5rem}.chip-icon{height:12px;width:12px}.chip-count{font-size:.625rem;min-width:14px;padding:0 .25rem}.library-feed{gap:1rem;grid-template-columns:1fr}.content-card-header{padding:.875rem 1rem .375rem}.card-type-indicator .type-icon{height:18px;width:18px}.card-type-indicator .type-label{font-size:.6875rem}.content-card-body{padding:.25rem 1rem .75rem}.content-card-title{font-size:.9375rem;margin-bottom:.375rem}.content-card-stat{font-size:.75rem}.content-card-actions{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.card-btn.primary{flex:1 1;font-size:.75rem;justify-content:center;padding:.5rem .875rem}.card-secondary-actions{flex:1 1;justify-content:flex-end}.card-btn.secondary{height:32px;width:32px}.card-btn.secondary svg{height:14px;width:14px}.library-title-section h1{font-size:1.5rem}}.quizzes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));margin-top:2rem;padding:0}.quiz-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 2px 6px #00000014;cursor:pointer;display:flex;flex-direction:column;padding:2rem;transition:all .3s}.quiz-card:hover{border-color:#cbd5e1;box-shadow:0 6px 12px #0000001f;transform:translateY(-4px)}.quiz-info{flex:1 1;margin-bottom:1.75rem}.quiz-card h3{color:#1e293b;font-size:1.375rem;font-weight:600;line-height:1.3;margin-bottom:.875rem}.subject-badge{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:6px;color:#3b82f6;display:inline-block;font-size:.85rem;font-weight:600;margin-bottom:.75rem;padding:.25rem .75rem}.quiz-metadata{color:#64748b;display:flex;flex-wrap:wrap;font-size:.875rem;gap:1rem;margin-bottom:1rem}.quiz-metadata span{align-items:center;display:flex;gap:.25rem}.progress-badge{color:#10b981!important;font-weight:600}.high-score{color:#f59e0b;font-weight:500}.quiz-actions{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.quiz-actions button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all .2s}.play-button{background:#3b82f6;color:#fff;grid-column:span 1}.play-button:hover{background:#2563eb;transform:translateY(-1px)}.multiplayer-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.multiplayer-button:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed);transform:translateY(-1px)}.edit-button{background:#8b5cf6;color:#fff}.edit-button:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px)}.edit-button.disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.share-button{background:#10b981;color:#fff}.share-button:hover{background:#059669;transform:translateY(-1px)}.download-pdf-button{background:#f59e0b;color:#fff}.download-pdf-button:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.download-pdf-button.disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.delete-button{background:#f1f5f9;border:1px solid #ef4444;color:#ef4444}.delete-button:hover:not(:disabled){background:#fef2f2;transform:translateY(-1px)}.delete-button.disabled{background:#e2e8f0;border:1px solid #cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.6}.loading-container{padding:4rem 2rem;text-align:center}.loading-text{color:#64748b;font-size:1.1rem}.no-quizzes{background:#f8fafc;border:2px dashed #e2e8f0;border-radius:12px;margin-top:2rem;padding:3rem;text-align:center}.no-quizzes p{color:#64748b;font-size:1.1rem;margin-bottom:1.5rem}.create-quiz-button{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:1.1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.create-quiz-button:hover{background:#2563eb;box-shadow:0 4px 6px #3b82f633;transform:translateY(-2px)}@media (max-width:768px){.saved-quizzes-container{padding:80px 1rem 1rem}.saved-quizzes-header{padding:1.5rem}.saved-quizzes-header h2{font-size:2rem}.quizzes-grid{grid-template-columns:1fr}.quiz-actions{grid-template-columns:repeat(2,1fr)}.play-button{grid-column:span 2}.quiz-metadata{flex-direction:column;gap:.5rem}.library-tabs{gap:.5rem}.library-tab{font-size:.9rem;padding:.625rem 1rem}.tab-label{display:none}.tab-icon{font-size:1.5rem}}.lesson-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;overflow:hidden;padding:0;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.lesson-card:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.lesson-card:hover{border-color:#cbd5e1;box-shadow:0 12px 24px #0000001f,0 4px 8px #00000014;transform:translateY(-4px)}.lesson-card:hover:before{opacity:1}.lesson-header{align-items:flex-start;background:linear-gradient(135deg,#f9fafb99,#fff);display:flex;justify-content:space-between;padding:1.25rem 1.5rem 1rem}.lesson-title-section{flex:1 1;min-width:0}.lesson-title-section h3{align-items:center;color:#0f172a;display:flex;font-size:1.25rem;font-weight:700;gap:.5rem;letter-spacing:-.01em;line-height:1.3;margin:0 0 .625rem}.lesson-title-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:1.5rem}.lesson-badges{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.lesson-subject-badge{align-items:center;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:6px;box-shadow:0 1px 2px #3b82f61a;color:#1e40af;display:inline-flex;font-size:.75rem;font-weight:700;gap:.3rem;letter-spacing:.025em;padding:.25rem .625rem;text-transform:uppercase}.lesson-date{align-items:center;color:#64748b;display:flex;font-size:.8125rem;font-weight:500;gap:.375rem;white-space:nowrap}.lesson-stats{grid-gap:.625rem;background:#fafbfc;border-top:1px solid #f1f5f9;display:grid;gap:.625rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));padding:1rem 1.5rem}.lesson-stat-item{align-items:center;background:#fff;border:1.5px solid #0000;border-radius:10px;box-shadow:0 1px 2px #0000000a;display:flex;gap:.625rem;padding:.75rem .875rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.lesson-stat-item:hover{border-color:currentColor;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.stat-icon{filter:drop-shadow(0 2px 3px rgba(0,0,0,.1));font-size:1.5rem;line-height:1}.stat-info{display:flex;flex:1 1;flex-direction:column;gap:.125rem;min-width:0}.stat-value{color:#0f172a;font-size:1.125rem;font-weight:800;letter-spacing:-.02em;line-height:1}.stat-label{color:#64748b;font-size:.625rem;font-weight:700;letter-spacing:.075em;text-transform:uppercase}.quiz-stat{border-left:3.5px solid #3b82f6;color:#3b82f6}.flashcard-stat{border-left:3.5px solid #10b981;color:#10b981}.progress-stat{border-left:3.5px solid #f59e0b;color:#f59e0b}.empty-stat{background:#fff;border:1.5px dashed #e2e8f0;color:#94a3b8;font-size:.875rem;font-style:italic;grid-column:1/-1;justify-content:center;padding:1.25rem}.lesson-progress-bar{background:#e5e7eb;height:4px;overflow:hidden;position:relative}.lesson-progress-fill{animation:shimmer 2s infinite;background:linear-gradient(90deg,#10b981,#059669 50%,#10b981);background-size:200% 100%;height:100%;position:relative;transition:width .6s cubic-bezier(.4,0,.2,1)}.lesson-progress-fill:after{background:linear-gradient(90deg,#0000,#ffffff4d);bottom:0;content:"";position:absolute;right:0;top:0;width:30px}@keyframes shimmer{0%{background-position:-100% 0}to{background-position:100% 0}}.lesson-actions{background:#fff;display:flex;gap:.5rem;padding:1rem 1.5rem}.lesson-continue-btn,.lesson-delete-btn,.lesson-expand-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:.875rem;font-weight:700;gap:.5rem;justify-content:center;overflow:hidden;padding:.75rem 1.125rem;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.lesson-continue-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f633;color:#fff;flex:1 1}.lesson-continue-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.lesson-continue-btn:hover:before{left:100%}.lesson-continue-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 12px #3b82f659;transform:translateY(-2px)}.lesson-continue-btn:active{transform:translateY(0)}.lesson-expand-btn{background:#f1f5f9;border:1.5px solid #e2e8f0;color:#475569}.lesson-expand-btn:hover{background:#e2e8f0;border-color:#cbd5e1;box-shadow:0 4px 8px #00000014;color:#0f172a;transform:translateY(-2px)}.lesson-delete-btn{background:#fff;border:1.5px solid #fecaca;color:#ef4444;min-width:42px;padding:.75rem}.lesson-delete-btn:hover:not(:disabled){background:#fef2f2;border-color:#f87171;box-shadow:0 4px 8px #ef444433;transform:translateY(-2px) scale(1.05)}.lesson-delete-btn.disabled{background:#e2e8f0;border-color:#cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.6}.lesson-content-expanded{animation:expandDown .3s ease-out;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-top:1px solid #e2e8f0;padding:1.5rem}@keyframes expandDown{0%{max-height:0;opacity:0}to{max-height:2000px;opacity:1}}.content-section{margin-bottom:1.75rem}.content-section:last-child{margin-bottom:0}.content-section-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:1.125rem;padding-bottom:.75rem}.content-section-header h4{align-items:center;color:#0f172a;display:flex;font-size:1.125rem;font-weight:800;gap:.625rem;letter-spacing:-.01em;margin:0}.content-count{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;box-shadow:0 2px 4px #3b82f64d;color:#fff;font-size:.8125rem;font-weight:800;min-width:28px;padding:.25rem .75rem;text-align:center}.content-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.content-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;overflow:hidden;padding:1.25rem;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.content-card:before{background:currentColor;content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.content-card:hover:before{transform:scaleX(1)}.content-card:hover{border-color:currentColor;box-shadow:0 8px 16px #0000001f,0 4px 8px #00000014;transform:translateY(-3px)}.content-card-header{align-items:flex-start;display:flex;gap:.875rem;margin-bottom:1rem}.content-card-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0;font-size:1.875rem;line-height:1}.content-card-info{display:flex;flex:1 1;flex-direction:column;gap:.375rem;min-width:0}.content-card-info strong{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#0f172a;display:-webkit-box;font-size:.9375rem;font-weight:700;line-height:1.3;overflow:hidden}.content-card-info span{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.content-card-actions{display:flex;gap:.5rem;position:relative;z-index:10}.content-card-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.8125rem;font-weight:700;gap:.375rem;justify-content:center;overflow:hidden;padding:.625rem .875rem;pointer-events:auto;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:1}.content-card-btn.primary{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f640;color:#fff;flex:1 1}.content-card-btn.primary:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.content-card-btn.primary:hover:before{left:100%}.content-card-btn.primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 10px #3b82f666;transform:translateY(-2px)}.content-card-btn.secondary{background:#f1f5f9;border:1.5px solid #e2e8f0;color:#475569;font-size:1.125rem;min-width:40px;padding:.625rem .75rem}.content-card-btn.secondary:hover{background:#e2e8f0;border-color:#cbd5e1;box-shadow:0 3px 8px #0000001a;color:#0f172a;transform:translateY(-2px) scale(1.05)}.quiz-content-card{color:#3b82f6}.flashcard-content-card{color:#10b981}@media (min-width:1400px){.saved-quizzes-container{max-width:1800px;padding:2.5rem 6rem}.saved-quizzes-header{margin-bottom:3.5rem;padding:3.5rem 3rem}.saved-quizzes-header h2{font-size:3rem}.library-search{max-width:800px}.library-tabs{margin-bottom:3.5rem}.quizzes-grid{gap:3rem;grid-template-columns:repeat(auto-fill,minmax(420px,1fr))}.quiz-card{padding:2.25rem}.lesson-header{padding:1.75rem 2.25rem 1.5rem}.lesson-actions,.lesson-stats{padding:1.5rem 2.25rem}.content-grid{gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (max-width:1024px){.saved-quizzes-container{padding:2rem 3rem}.quizzes-grid{gap:2rem;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}}@media (max-width:768px){.saved-quizzes-container{padding:1.5rem 2rem}.quizzes-grid{gap:1.5rem;grid-template-columns:1fr}.lesson-header{flex-direction:column;gap:.75rem}.lesson-date{align-self:flex-start}.lesson-stats{gap:.75rem}.lesson-stat-item{flex:1 1;min-width:120px}.lesson-actions{flex-direction:column}.lesson-expand-btn{order:-1}.content-grid{grid-template-columns:1fr}.content-card-actions{flex-wrap:wrap}}@media (max-width:480px){.saved-quizzes-header h2{font-size:1.75rem}.saved-quizzes-header p{font-size:1rem}.lesson-card{margin-bottom:1rem}.lesson-header{padding:1rem 1.25rem .75rem}.lesson-title-section h3{font-size:1.125rem}.lesson-stats{gap:.5rem;padding:.875rem 1.25rem}.lesson-stat-item{gap:.5rem;min-width:100px;padding:.625rem .875rem}.stat-icon{font-size:1.25rem}.stat-value{font-size:1rem}.stat-label{font-size:.7rem}.empty-stat{font-size:.8rem;padding:.5rem}.lesson-actions{gap:.5rem;padding:.875rem 1.25rem}.lesson-continue-btn,.lesson-expand-btn{font-size:.85rem;padding:.625rem 1rem}.lesson-delete-btn{padding:.625rem}.lesson-content-expanded{padding:1rem}.content-section-header h4{font-size:1rem}.content-card{padding:1rem}.content-card-icon{font-size:1.5rem}.content-card-info strong{font-size:.9rem}.content-card-actions{flex-direction:column}.content-card-btn{justify-content:center;width:100%}.quiz-card{padding:1rem}.quiz-actions button{padding:.5rem}}.flashcard-preview-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:280px;padding:3rem 2rem;position:relative;text-align:center;transition:all .3s ease}.flashcard-preview-card:hover{border-color:#3b82f6;box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.flashcard-preview-icon{font-size:3rem;margin-bottom:.5rem}.flashcard-preview-card h3{color:#1e293b;font-size:1.5rem;font-weight:600;line-height:1.3;margin:0}.flashcard-preview-count{color:#64748b;font-size:1rem;font-weight:500;margin:0}.flashcard-preview-date{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:.5rem;margin-top:.5rem}.flashcard-preview-hint{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;margin-top:.75rem;opacity:0;padding:.5rem 1rem;transition:opacity .3s ease}.flashcard-preview-card:hover .flashcard-preview-hint{opacity:1}.flashcard-preview-actions{display:flex;gap:.5rem;position:absolute;right:1rem;top:1rem;z-index:10}.flashcard-preview-delete,.flashcard-preview-share{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:1.125rem;padding:.5rem .75rem;transition:all .2s}.flashcard-preview-share{color:#3b82f6}.flashcard-preview-share:hover{background:#eff6ff;border-color:#3b82f6;transform:scale(1.1)}.flashcard-preview-delete{background:#fef2f2;border-color:#fecaca;color:#ef4444}.flashcard-preview-delete:hover:not(:disabled){background:#fee2e2;border-color:#ef4444;transform:scale(1.1)}.flashcard-preview-delete.disabled{background:#e2e8f0;border-color:#cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.6}.immersive-flashcard-view{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172af2;bottom:0;left:0;overflow-y:auto;padding:2rem;right:0;top:0;z-index:10000}.close-immersive-floating,.immersive-flashcard-view{align-items:center;display:flex;justify-content:center;position:fixed}.close-immersive-floating{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;font-size:2rem;height:48px;line-height:1;padding:0;right:2rem;top:2rem;transition:all .2s;width:48px;z-index:10001}.close-immersive-floating:hover{background:#ffffff40;transform:scale(1.05)}.immersive-title-floating{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;display:flex;gap:1.25rem;left:50%;max-width:600px;padding:.875rem 2rem;position:fixed;top:2rem;transform:translateX(-50%);z-index:10001}.immersive-title-floating h2{color:#fff;font-size:1.25rem;font-weight:600;margin:0;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.immersive-title-floating .card-progress{color:#fffc;font-size:.95rem;font-weight:500;white-space:nowrap}.immersive-flashcard-direct{align-items:center;display:flex;justify-content:center;margin:0 auto;max-width:1000px;padding:6rem 2rem 2rem;width:100%}.immersive-flashcard-view .flashcard-title{display:none!important}.immersive-flashcard-view .flashcard-artifact{align-items:center!important;background:#0000!important;box-shadow:none!important;display:flex!important;flex-direction:column!important;gap:2.5rem!important;max-width:none!important;padding:0!important;width:100%!important}.immersive-flashcard-view .flashcard-wrapper{height:350px!important;margin:0 auto!important;max-width:900px!important;perspective:1000px!important;width:100%!important}.immersive-flashcard-view .flashcard{cursor:pointer!important}.immersive-flashcard-view .flashcard,.immersive-flashcard-view .flashcard-inner{height:100%!important;width:100%!important}.immersive-flashcard-view .flashcard-back,.immersive-flashcard-view .flashcard-front{align-items:center!important;backface-visibility:hidden!important;-webkit-backface-visibility:hidden!important;border-radius:16px!important;box-shadow:0 20px 60px #00000080!important;display:flex!important;flex-direction:column!important;height:100%!important;justify-content:center!important;padding:3rem!important;position:absolute!important;text-align:center!important;width:100%!important}.immersive-flashcard-view .flashcard-front{background:#fff!important;border:2px solid #e5e7eb!important;transform:rotateY(0deg)!important}.immersive-flashcard-view .flashcard-back{background:#f8fafc!important;border:2px solid #3b82f6!important;transform:rotateY(180deg)!important}.immersive-flashcard-view .flashcard-content{align-items:center!important;color:#1e293b!important;display:flex!important;flex:1 1!important;font-size:1.5rem!important;font-weight:500!important;justify-content:center!important;line-height:1.7!important;max-height:200px!important;max-width:100%!important;overflow-y:auto!important;text-align:center!important}.immersive-flashcard-view .flashcard-label{color:#3b82f6!important;flex-shrink:0!important;font-size:.875rem!important;font-weight:700!important;letter-spacing:1.5px!important;margin-bottom:1rem!important;text-transform:uppercase!important}.immersive-flashcard-view .flashcard-hint{color:#94a3b8!important;flex-shrink:0!important;font-size:.875rem!important;font-weight:500!important;margin-top:1rem!important;padding-top:1rem!important}.immersive-flashcard-view .flashcard-controls{align-items:center!important;display:flex!important;gap:1.5rem!important;justify-content:center!important;margin:0 auto!important;max-width:900px!important;width:100%!important}.immersive-flashcard-view .flashcard-nav-button{align-items:center!important;background:#fff!important;border:2px solid #e2e8f0!important;border-radius:10px!important;box-shadow:0 2px 8px #0000001a!important;color:#1e293b!important;cursor:pointer!important;display:flex!important;flex-shrink:0!important;font-size:1rem!important;font-weight:600!important;gap:.5rem!important;padding:.875rem 1.75rem!important;transition:all .2s!important}.immersive-flashcard-view .flashcard-nav-button:hover:not(:disabled){background:#f8fafc!important;border-color:#cbd5e1!important;box-shadow:0 4px 12px #00000026!important;transform:translateY(-2px)!important}.immersive-flashcard-view .flashcard-nav-button:disabled{cursor:not-allowed!important;opacity:.4!important}.immersive-flashcard-view .flashcard-nav-button svg{height:20px!important;width:20px!important}.immersive-flashcard-view .flashcard-counter{-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;background:#ffffff1a!important;border:1px solid #fff3!important;border-radius:8px!important;color:#fff!important;flex-shrink:0!important;font-size:1rem!important;font-weight:600!important;padding:.5rem 1rem!important}.completion-screen-floating{left:50%;max-width:500px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:10001}.completion-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffffa;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:2rem 1.75rem;text-align:center}.completion-icon{font-size:3rem;margin-bottom:.75rem}.completion-content h2{color:#1e293b;font-size:1.5rem;margin-bottom:.5rem}.completion-content p{color:#64748b;font-size:.9rem;margin-bottom:1.25rem}.completion-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:.75rem;justify-content:center}.completion-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.4rem;justify-content:center;min-width:140px;padding:.75rem 1.25rem;transition:all .2s}.completion-button.primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.completion-button.primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.completion-button.secondary{background:#f1f5f9;color:#475569}.completion-button.secondary:hover{background:#e2e8f0;color:#1e293b;transform:translateY(-2px)}.completion-button span{font-size:1.25rem}@media (max-width:768px){.immersive-flashcard-view{padding:1rem}.close-immersive-floating{font-size:1.5rem;height:40px;right:1rem;top:1rem;width:40px}.immersive-title-floating{max-width:calc(100% - 5rem);padding:.625rem 1.25rem;top:1rem}.immersive-title-floating h2{font-size:1rem;max-width:200px}.immersive-title-floating .card-progress{font-size:.85rem}.immersive-flashcard-direct{padding:5rem 1rem 1rem}.immersive-flashcard-view .flashcard-wrapper{height:300px!important;max-width:100%!important}.immersive-flashcard-view .flashcard-back,.immersive-flashcard-view .flashcard-front{padding:2rem!important}.immersive-flashcard-view .flashcard-content{font-size:1.25rem!important;max-height:150px!important}.immersive-flashcard-view .flashcard-nav-button{font-size:.9rem!important;padding:.625rem 1.25rem!important}.immersive-flashcard-view .flashcard-counter{font-size:.875rem!important;padding:.375rem .75rem!important}.completion-content{padding:2rem 1.5rem}.completion-icon{font-size:3rem}.completion-content h2{font-size:1.5rem}.completion-button{font-size:.95rem;padding:.875rem 1.5rem}.close-immersive-floating{font-size:1.5rem!important;height:36px!important;right:1rem!important;top:1rem!important;width:36px!important}.immersive-title-floating{left:1rem!important;max-width:calc(100% - 5rem)!important;padding:.5rem .875rem!important;right:4rem!important;top:1rem!important;transform:none!important}.immersive-title-floating h2{font-size:.85rem!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.card-progress{font-size:.75rem!important;padding-left:.5rem!important}.immersive-flashcard-direct{top:5rem!important;transform:translateX(-50%)!important;width:calc(100% - 2rem)!important}}.learning-session-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;box-shadow:0 2px 8px #0000000f;cursor:pointer;display:flex;flex-direction:column;gap:1.25rem;overflow:hidden;padding:1.75rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.learning-session-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.learning-session-card:hover:before{transform:scaleX(1)}.learning-session-card:hover{border-color:#cbd5e1;box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.learning-card-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.learning-card-title{color:#0f172a;flex:1 1;font-size:1.25rem;font-weight:700;letter-spacing:-.01em;line-height:1.4;margin:0}.learning-card-delete{align-items:center;background:#0000;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.375rem;transition:all .2s}.learning-card-delete:hover{background:#fef2f2;color:#ef4444;transform:scale(1.1)}.learning-card-delete svg{display:block}.learning-card-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.learning-stat{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:1rem;transition:all .2s}.learning-stat:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);transform:scale(1.02)}.learning-stat-icon{font-size:1.75rem;margin-bottom:.5rem}.learning-stat-value{color:#0f172a;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;line-height:1;margin-bottom:.25rem}.learning-stat-label{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.learning-card-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;padding-top:1rem}.learning-card-date{color:#64748b;font-size:.875rem;font-weight:500}.learning-card-badge{border-radius:8px;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.375rem .875rem;text-transform:uppercase;transition:all .2s}.learning-card-badge.completed{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.learning-card-badge.in-progress{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}@media (max-width:768px){.learning-session-card{padding:1.5rem}.learning-card-title{font-size:1.125rem}.learning-card-stats{gap:.75rem}.learning-stat{padding:.875rem}.learning-stat-icon{font-size:1.5rem}.learning-stat-value{font-size:1.25rem}}@media (max-width:480px){.learning-session-card{padding:1.25rem}.learning-card-title{font-size:1rem}.learning-card-stats{grid-template-columns:1fr}}.delete-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172abf;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.delete-modal-content{animation:slideUp .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:460px;padding:2rem;text-align:center;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.delete-modal-icon{align-items:center;background:linear-gradient(135deg,#fee2e2,#fecaca);border-radius:50%;color:#ef4444;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.delete-modal-icon svg{display:block}.delete-modal-title{color:#0f172a;font-size:1.5rem;font-weight:700;letter-spacing:-.01em;margin:0 0 .875rem}.delete-modal-message{color:#64748b;font-size:1rem;line-height:1.6;margin:0 0 2rem}.delete-modal-message strong{color:#1e293b;font-weight:600}.delete-modal-actions{display:flex;gap:.75rem;justify-content:center}.delete-modal-cancel,.delete-modal-confirm{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;min-width:120px;padding:.875rem 1.75rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.delete-modal-cancel{background:#f1f5f9;border:2px solid #e2e8f0;color:#475569}.delete-modal-cancel:hover{background:#e2e8f0;border-color:#cbd5e1;box-shadow:0 4px 12px #0000001a;color:#1e293b;transform:translateY(-2px)}.delete-modal-confirm{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d;color:#fff}.delete-modal-confirm:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 20px #ef444466;transform:translateY(-2px)}.delete-modal-cancel:active,.delete-modal-confirm:active{transform:translateY(0)}.delete-modal-confirm svg{display:block}@media (max-width:480px){.delete-modal-content{max-width:90%;padding:1.5rem}.delete-modal-icon{height:64px;margin-bottom:1rem;width:64px}.delete-modal-icon svg{height:36px;width:36px}.delete-modal-title{font-size:1.25rem}.delete-modal-message{font-size:.9rem;margin-bottom:1.5rem}.delete-modal-actions{flex-direction:column;gap:.5rem}.delete-modal-cancel,.delete-modal-confirm{width:100%}}.truefalse-preview-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:280px;padding:3rem 2rem;position:relative;text-align:center;transition:all .3s ease}.truefalse-preview-card:hover{border-color:#10b981;box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.truefalse-preview-icon{align-items:center;background:linear-gradient(135deg,#10b98126,#14b8a61a);border-radius:50%;color:#10b981;display:flex;height:64px;justify-content:center;margin-bottom:.5rem;width:64px}.truefalse-preview-card h3{color:#1e293b;font-size:1.5rem;font-weight:600;line-height:1.3;margin:0}.truefalse-preview-count{color:#64748b;font-size:1rem;font-weight:500;margin:0}.truefalse-preview-date{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:.5rem;margin-top:.5rem}.truefalse-preview-hint{background:linear-gradient(135deg,#10b981,#14b8a6);border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;margin-top:.75rem;opacity:0;padding:.5rem 1rem;transition:opacity .3s ease}.truefalse-preview-card:hover .truefalse-preview-hint{opacity:1}.truefalse-preview-actions{display:flex;gap:.5rem;position:absolute;right:1rem;top:1rem;z-index:10}.truefalse-preview-delete,.truefalse-preview-share{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:1.125rem;padding:.5rem .75rem;transition:all .2s}.truefalse-preview-share{color:#10b981}.truefalse-preview-share:hover{background:#f0fdf4;border-color:#10b981;transform:scale(1.1)}.truefalse-preview-delete{background:#fef2f2;border-color:#fecaca;color:#ef4444}.truefalse-preview-delete:hover:not(:disabled){background:#fee2e2;border-color:#ef4444;transform:scale(1.1)}.truefalse-preview-delete.disabled{background:#e2e8f0;border-color:#cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.6}.truefalse-immersive-overlay{animation:truefalse-fadeIn .3s ease;background:linear-gradient(180deg,#1e293b,#0f172a);bottom:0;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;right:0;top:0;width:100vw;z-index:999999}@keyframes truefalse-fadeIn{0%{opacity:0}to{opacity:1}}.truefalse-immersive-modal{display:flex;flex:1 1;flex-direction:column}.truefalse-immersive-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:1.5rem;top:1.5rem;transition:all .2s;width:48px;z-index:1000001}.truefalse-immersive-close:hover{background:#fff3;transform:scale(1.05)}.truefalse-immersive-header{border-bottom:1px solid #ffffff1a;padding:1.5rem 2rem;text-align:center}.truefalse-immersive-header h2{color:#fff;font-size:1.5rem;font-weight:700;margin:0}.truefalse-immersive-content{align-items:flex-start;display:flex;flex:1 1;justify-content:center;padding:2rem}@media (max-width:768px){.truefalse-preview-card{min-height:240px;padding:2rem 1.5rem}.truefalse-preview-card h3{font-size:1.25rem}.truefalse-preview-icon{height:48px;width:48px}.truefalse-preview-icon svg{height:24px;width:24px}.truefalse-immersive-close{height:40px;right:1rem;top:1rem;width:40px}.truefalse-immersive-header{padding:1rem}.truefalse-immersive-header h2{font-size:1.25rem}.truefalse-immersive-content{padding:1rem}}.mindmap-preview-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:280px;padding:3rem 2rem;position:relative;text-align:center;transition:all .3s ease}.mindmap-preview-card:hover{border-color:#8b5cf6;box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.mindmap-preview-icon{align-items:center;background:linear-gradient(135deg,#8b5cf626,#7c3aed1a);border-radius:50%;color:#8b5cf6;display:flex;height:64px;justify-content:center;margin-bottom:.5rem;width:64px}.mindmap-preview-card h3{color:#1e293b;font-size:1.5rem;font-weight:600;line-height:1.3;margin:0}.mindmap-preview-count{color:#64748b;font-size:1rem;font-weight:500;margin:0}.mindmap-preview-date{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:.5rem;margin-top:.5rem}.mindmap-preview-hint{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;margin-top:.75rem;opacity:0;padding:.5rem 1rem;transition:opacity .3s ease}.mindmap-preview-card:hover .mindmap-preview-hint{opacity:1}.mindmap-preview-actions{display:flex;gap:.5rem;position:absolute;right:1rem;top:1rem;z-index:10}.mindmap-preview-delete,.mindmap-preview-share{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:1.125rem;padding:.5rem .75rem;transition:all .2s}.mindmap-preview-share{color:#8b5cf6}.mindmap-preview-share:hover{background:#f5f3ff;border-color:#8b5cf6;transform:scale(1.1)}.mindmap-preview-delete{background:#fef2f2;border-color:#fecaca;color:#ef4444}.mindmap-preview-delete:hover:not(:disabled){background:#fee2e2;border-color:#ef4444;transform:scale(1.1)}.mindmap-preview-delete.disabled{background:#e2e8f0;border-color:#cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.6}@media (max-width:768px){.mindmap-preview-card{min-height:240px;padding:2rem 1.5rem}.mindmap-preview-card h3{font-size:1.25rem}.mindmap-preview-icon{height:48px;width:48px}.mindmap-preview-icon svg{height:24px;width:24px}}.matching-preview-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:280px;padding:3rem 2rem;position:relative;text-align:center;transition:all .3s ease}.matching-preview-card:hover{border-color:#0ea5e9;box-shadow:0 8px 30px #00000026;transform:translateY(-5px)}.matching-preview-icon{align-items:center;background:linear-gradient(135deg,#0ea5e926,#06b6d41a);border-radius:50%;color:#0ea5e9;display:flex;height:64px;justify-content:center;margin-bottom:.5rem;width:64px}.matching-preview-card h3{color:#1e293b;font-size:1.5rem;font-weight:600;line-height:1.3;margin:0}.matching-preview-count{color:#64748b;font-size:1rem;font-weight:500;margin:0}.matching-preview-date{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:.5rem;margin-top:.5rem}.matching-preview-hint{background:linear-gradient(135deg,#0ea5e9,#06b6d4);border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;margin-top:.75rem;opacity:0;padding:.5rem 1rem;transition:opacity .3s ease}.matching-preview-card:hover .matching-preview-hint{opacity:1}.matching-preview-actions{display:flex;gap:.5rem;position:absolute;right:1rem;top:1rem;z-index:10}.matching-preview-delete,.matching-preview-share{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:1.125rem;padding:.5rem .75rem;transition:all .2s}.matching-preview-share{color:#0ea5e9}.matching-preview-share:hover{background:#f0f9ff;border-color:#0ea5e9;transform:scale(1.1)}.matching-preview-delete{background:#fef2f2;border-color:#fecaca;color:#ef4444}.matching-preview-delete:hover:not(:disabled){background:#fee2e2;border-color:#ef4444;transform:scale(1.1)}.matching-preview-delete.disabled{background:#e2e8f0;border-color:#cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.6}@media (max-width:768px){.matching-preview-card{min-height:240px;padding:2rem 1.5rem}.matching-preview-card h3{font-size:1.25rem}.matching-preview-icon{height:48px;width:48px}.matching-preview-icon svg{height:24px;width:24px}}.matching-immersive-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ae6;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.matching-immersive-modal{background:#fff;border-radius:24px;box-shadow:0 25px 50px -12px #0006;display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;width:100%}.matching-immersive-close{background:#ffffffe6;border:none;border-radius:12px;color:#64748b;cursor:pointer;padding:.75rem;position:absolute;right:1.5rem;top:1.5rem;transition:all .2s;z-index:10}.matching-immersive-close:hover{background:#fff;color:#1e293b;transform:scale(1.1)}.matching-immersive-header{background:linear-gradient(135deg,#0ea5e91a,#06b6d40d);border-bottom:1px solid #e2e8f0;padding:1.5rem 2rem}.matching-immersive-header h2{color:#1e293b;font-size:1.5rem;font-weight:700;margin:0}.matching-immersive-content{flex:1 1;overflow:auto;padding:2rem}@media (max-width:768px){.matching-immersive-overlay{padding:1rem}.matching-immersive-modal{border-radius:16px;max-height:95vh}.matching-immersive-header{padding:1rem 1.5rem}.matching-immersive-header h2{font-size:1.25rem}.matching-immersive-content{padding:1rem}.matching-immersive-close{padding:.5rem;right:1rem;top:1rem}}.page-header-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:800;left:5.5rem;letter-spacing:.5px;line-height:1;margin:0;padding:0;position:fixed;top:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:50}.page-header-title.hidden{opacity:0;pointer-events:none}.page-header-title.visible{opacity:1;pointer-events:auto}body:not(.sidebar-collapsed) .page-header-title{left:17rem}@media (max-width:768px){.page-header-title{align-items:center;display:flex;font-size:1.125rem;height:48px;left:4.75rem;top:1.25rem}}.not-found-page{align-items:center;background:linear-gradient(135deg,#0f0f23,#1a1a2e);display:flex;justify-content:center;min-height:100vh;padding:2rem}.not-found-container{max-width:600px;text-align:center}.not-found-content{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;padding:3rem}.not-found-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6 50%,#a855f7);-webkit-background-clip:text;background-clip:text;font-size:8rem;font-weight:800;line-height:1;margin:0}.not-found-subtitle{color:#fff;font-size:1.75rem;font-weight:600;margin:1rem 0}.not-found-description{color:#ffffffb3;font-size:1.1rem;margin-bottom:2rem}.not-found-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2.5rem}.not-found-btn{border-radius:12px;font-weight:600;padding:.875rem 1.75rem;text-decoration:none;transition:all .2s ease}.not-found-btn.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.not-found-btn.primary:hover{box-shadow:0 8px 20px #6366f166;transform:translateY(-2px)}.not-found-btn.secondary{background:#ffffff1a;border:1px solid #fff3;color:#fff}.not-found-btn.secondary:hover{background:#ffffff26}.not-found-suggestions{border-top:1px solid #ffffff1a;padding-top:2rem}.not-found-suggestions h3{color:#fff9;font-size:.875rem;letter-spacing:.05em;margin-bottom:1rem;text-transform:uppercase}.not-found-suggestions ul{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;list-style:none;margin:0;padding:0}.not-found-suggestions li a{background:#6366f11a;border-radius:8px;color:#a5b4fc;font-size:.9rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.not-found-suggestions li a:hover{background:#6366f133;color:#c4b5fd}@media (max-width:640px){.not-found-title{font-size:5rem}.not-found-content{padding:2rem}.not-found-actions{flex-direction:column}}