:root{--primary-color: #4a90e2;--secondary-color: #16a085;--accent-color: #f59e0b;--danger-color: #e91e63;--font-family: "Google Sans Flex", "Google Sans", "Helvetica Neue", sans-serif;--font-family-display: "Google Sans Flex", "Google Sans", "Helvetica Neue", sans-serif;--font-family-mono: "JetBrains Mono", "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", monospace;--border-radius: 12px;--box-shadow: 0 4px 12px rgba(0, 0, 0, .08);--background-color: #f4f7f9;--surface-color: #ffffff;--subtle-bg-color: #f9fafb;--text-color: #000000;--light-text-color: #888888;--user-message-bg: #e1f5fe;--model-message-bg: #f1f3f4;--border-color: #e0e0e0;--hover-color: #f0f0f0;--code-bg-color: #e9ecef;--surface-transparent-color: rgba(255, 255, 255, .7);--weakness-hunter-bg: #fffbeb;--weakness-hunter-border: #fde68a;--weakness-hunter-text: #b45309;--weakness-hunter-header: #92400e;--weakness-hunter-button: #f59e0b;--weakness-hunter-button-hover: #d97706}body.dark-mode{--background-color: #121212;--surface-color: #1e1e1e;--subtle-bg-color: #242424;--text-color: #ffffff;--light-text-color: #888888;--user-message-bg: #2c3e50;--model-message-bg: #2a2a2a;--border-color: #333333;--hover-color: #2a2a2a;--code-bg-color: #282c34;--surface-transparent-color: rgba(30, 30, 30, .7);--box-shadow: 0 4px 12px rgba(0, 0, 0, .25);--secondary-color: #50e3c2;--weakness-hunter-bg: #422006;--weakness-hunter-border: #78350f;--weakness-hunter-text: #fef3c7;--weakness-hunter-header: #fed7aa;--weakness-hunter-button: #d97706;--weakness-hunter-button-hover: #b45309}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--background-color);color:var(--text-color);overflow-x:hidden;overflow-y:auto;margin:0;padding:0;width:100%;transition:background-color .3s,color .3s;font-feature-settings:"kern" 1,"liga" 1,"calt" 1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{font-family:var(--font-family);font-weight:700;line-height:1.15;letter-spacing:-.02em}code,pre{font-family:var(--font-family-mono);font-variant-ligatures:none}#root{display:flex;flex-direction:column;min-height:100vh;width:100%}@keyframes slide-down{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}.policy-modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:backdrop-fade-in .3s ease-out}.policy-modal-content{background-color:var(--surface-color);border-radius:12px;box-shadow:0 20px 60px #00000026;width:95%;max-width:700px;max-height:90vh;animation:policy-modal-slide-up .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.policy-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);flex-shrink:0;background:linear-gradient(135deg,var(--primary-color),#3a7ac8);color:#fff}.policy-modal-header h1{font-size:1.5rem;font-weight:600;margin:0}.policy-modal-header .version-tag{font-size:.85rem;opacity:.9;background:#fff3;padding:.25rem .75rem;border-radius:20px;font-weight:500}.policy-close-btn{background:none;border:none;font-size:2rem;line-height:1;color:#fff;cursor:pointer;opacity:.8;transition:opacity .2s ease}.policy-close-btn:hover{opacity:1}.policy-modal-body{flex:1;overflow-y:auto;padding:2rem;line-height:1.6}.policy-modal-body h2{color:var(--primary-color);font-size:1.1rem;font-weight:600;margin:2rem 0 1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.policy-modal-body h2:first-child{margin-top:0;padding-top:0;border-top:none}.policy-modal-body ol{margin:0 0 1.5rem;padding-left:1.25rem}.policy-modal-body li{margin-bottom:.75rem;color:var(--text-color)}.policy-modal-body p{margin-bottom:1rem;color:var(--text-color)}.policy-modal-body strong{color:var(--primary-color);font-weight:600}.policy-modal-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--border-color);background-color:var(--subtle-bg-color);flex-shrink:0}.policy-footer-left,.policy-footer-right{display:flex;gap:.75rem}.policy-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;border:none;transition:all .2s ease;white-space:nowrap}.policy-btn-secondary{background-color:var(--hover-color);color:var(--text-color);border:1px solid var(--border-color)}.policy-btn-secondary:hover{background-color:var(--border-color)}.policy-btn-primary{background-color:var(--primary-color);color:#fff}.policy-btn-primary:hover{background-color:#3a7ac8;transform:translateY(-1px);box-shadow:0 4px 12px #4a90e24d}.policy-btn-accept-all{background:linear-gradient(135deg,var(--secondary-color),#27ae60);color:#fff;font-weight:600}.policy-btn-accept-all:hover{background:linear-gradient(135deg,#27ae60,var(--secondary-color));transform:translateY(-1px);box-shadow:0 4px 12px #2ecc714d}.acceptance-required-notice{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #f39c12;border-radius:8px;padding:1rem 1.5rem;margin:1.5rem 0;color:#856404;font-weight:500;display:flex;align-items:center;gap:.75rem}.acceptance-required-notice:before{content:"⚠️";font-size:1.2rem}@media (max-width: 768px){.policy-modal-content{width:98%;max-height:95vh;margin:1rem}.policy-modal-header{padding:1rem 1.5rem}.policy-modal-header h1{font-size:1.25rem}.policy-modal-body{padding:1.5rem}.policy-modal-footer{padding:1rem 1.5rem;flex-direction:column;gap:1rem}.policy-footer-left,.policy-footer-right{width:100%;justify-content:center}.policy-btn{flex:1;text-align:center}}@keyframes backdrop-fade-in{0%{opacity:0}to{opacity:1}}@keyframes policy-modal-slide-up{0%{opacity:0;transform:translateY(50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.policy-modal-body::-webkit-scrollbar{width:8px}.policy-modal-body::-webkit-scrollbar-track{background:var(--subtle-bg-color);border-radius:4px}.policy-modal-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.policy-modal-body::-webkit-scrollbar-thumb:hover{background:var(--light-text-color)}.policy-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.policy-close-btn:focus{outline:2px solid white;outline-offset:2px;border-radius:4px}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:0 10px 30px #0000001a;width:90%;max-width:450px;animation:slide-down .3s ease-out;display:flex;flex-direction:column;max-height:80vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-header h2{font-size:1.25rem}.close-btn{background:none;border:none;font-size:2rem;line-height:1;color:var(--light-text-color);cursor:pointer}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto}.image-uploader{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;color:var(--primary-color);font-weight:500}.profile-preview{width:100px;height:100px;border-radius:50%;border:3px solid var(--secondary-color);object-fit:cover;background-color:var(--border-color)}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:500;color:var(--light-text-color)}.form-group input,.form-group textarea{padding:.75rem 1rem;border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);border-radius:var(--border-radius);font-size:1rem;font-family:var(--font-family)}.form-group textarea{resize:vertical;min-height:80px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a90e233}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background-color:var(--subtle-bg-color);border-bottom-left-radius:var(--border-radius);border-bottom-right-radius:var(--border-radius)}.modal-footer button{padding:.6rem 1.2rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;border:none}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#3a7ac8}.btn-secondary{background-color:var(--hover-color);color:var(--text-color)}.btn-secondary:hover{background-color:var(--border-color)}.subscription-info{border-top:1px solid var(--border-color);padding-top:1.5rem;text-align:center}.subscription-title{font-size:1.1rem;font-weight:600;color:var(--light-text-color);margin-bottom:.75rem}.status-badge{padding:.25rem .6rem;border-radius:12px;font-weight:600;font-size:.9rem;margin-right:.5rem;color:#fff}.status-badge.active{background-color:var(--secondary-color)}.status-badge.inactive{background-color:var(--danger-color)}.status-badge.trial{background-color:var(--accent-color, #f6c343);color:var(--primary-dark, #2d3436)}.status-badge.expired{background-color:var(--danger-color)}.subscription-note{font-size:.9rem;color:var(--text-muted, #777);margin:.75rem 0 0}.renew-btn{width:100%;margin-top:1rem;padding:.75rem;font-size:1rem}.readonly-field{background-color:var(--input-disabled-bg, #f5f5f5);color:var(--text-muted, #666);cursor:not-allowed;opacity:.7}.readonly-field:hover{background-color:var(--input-disabled-bg, #f5f5f5)}.readonly-indicator{font-size:.75rem;color:var(--danger-color, #e74c3c);font-weight:400;font-style:italic}.editable-indicator{font-size:.75rem;color:var(--success-color, #27ae60);font-weight:400;font-style:italic}.study-plan-modal .modal-content{max-width:600px}.study-plan-modal .modal-body{padding:1.5rem}.empty-state{text-align:center;color:var(--light-text-color);padding:2rem 0}.plan-details{display:flex;flex-direction:column;gap:1.5rem}.plan-topic{font-size:1.2rem;font-weight:600;text-align:center;padding-bottom:1rem;border-bottom:1px solid #eee}.plan-day{display:flex;flex-direction:column;gap:.75rem}.plan-day h4{font-size:1rem;font-weight:600;color:var(--primary-color)}.task-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.task-item{display:flex;align-items:center;gap:1rem;padding:.5rem;border-radius:8px;background-color:#f9fafb}.task-item.completed .task-text{text-decoration:line-through;color:var(--light-text-color)}.task-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--secondary-color);cursor:pointer;flex-shrink:0}.task-text{flex-grow:1;word-break:break-word;cursor:pointer}.help-modal{max-width:650px}.help-modal .modal-body{display:flex;flex-direction:column;gap:1.25rem}.help-intro{font-size:1rem;color:var(--light-text-color);text-align:center;margin-bottom:.5rem}.help-section h4{font-size:1.1rem;font-weight:600;color:var(--primary-color);margin-bottom:.5rem}.help-section p{line-height:1.6}.example-block{background-color:#f4f7f9;border-left:4px solid var(--secondary-color);padding:.75rem 1rem;margin-top:.75rem;border-radius:0 8px 8px 0}.example-block p{font-size:.95rem}.example-block strong{color:#555}.example-block code{font-family:Courier New,Courier,monospace;background-color:#e9ecef;padding:.2em .4em;border-radius:4px;font-size:90%}.action-words-list{padding-left:1.5rem;margin-top:.75rem}.action-words-list li{margin-bottom:.5rem}.welcome-page-container{display:flex;flex-direction:column;min-height:100vh;width:100%;background-color:var(--background-color);color:var(--text-color);overflow-x:hidden;overflow-y:auto;background-image:radial-gradient(circle at 10% 20%,rgba(239,246,255,.5),transparent 50%),radial-gradient(circle at 80% 90%,rgba(224,231,255,.5),transparent 50%)}body.dark-mode .welcome-page-container{background-image:radial-gradient(circle at 10% 20%,rgba(30,41,59,.5),transparent 50%),radial-gradient(circle at 80% 90%,rgba(51,65,85,.5),transparent 50%)}.welcome-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 3rem;border-bottom:1px solid var(--border-color);flex-shrink:0;animation:fade-in .5s ease-out}.welcome-logo{display:flex;align-items:center;gap:.75rem;font-family:var(--font-family);font-size:1.9rem;font-weight:700;letter-spacing:-.01em;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 1px 2px rgba(0,0,0,.1);transform:translateY(-1px)}.welcome-logo .logo-icon{width:32px;height:32px;background-size:contain;background-position:center;background-repeat:no-repeat;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.welcome-nav{display:flex;align-items:center;justify-content:flex-end;gap:1.5rem}.welcome-nav button{display:inline-flex;align-items:center;justify-content:center;line-height:1}.welcome-nav .welcome-btn-secondary:first-of-type,.welcome-nav .welcome-btn-primary{margin-left:.75rem}.welcome-btn-secondary,.welcome-btn-primary,.welcome-btn-tertiary{padding:.6rem 1.5rem;border-radius:var(--border-radius);font-family:var(--font-family);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.welcome-btn-secondary{background-color:transparent;color:var(--text-color);border-color:var(--border-color)}.welcome-btn-secondary:hover{background-color:var(--hover-color)}.welcome-btn-tertiary{background-color:transparent;color:var(--primary-color)}.welcome-btn-tertiary:hover{background-color:var(--hover-color)}.welcome-btn-primary{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.welcome-btn-primary:hover{background-color:#3a7ac8;border-color:#3a7ac8}.hero-section{flex-grow:1;display:flex;align-items:center;justify-content:flex-start;gap:3rem;padding:2.75rem 2.75rem 2.2rem;width:100%;max-width:1700px;margin:0 auto;box-sizing:border-box}.hero-content{flex:0 0 560px;max-width:560px;z-index:2}.hero-headline{font-family:var(--font-family);font-size:3.1rem;font-weight:700;line-height:1.18;letter-spacing:-.02em;margin-bottom:1.25rem;animation:fade-slide-up .6s .2s ease-out forwards;opacity:0;color:#111827}body.dark-mode .hero-headline{color:#f1f5f9}.brand-script{font-family:var(--font-family);font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 90%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block;padding-right:.15rem;padding-bottom:.08rem;position:relative}body.dark-mode .brand-script{filter:brightness(1.15)}.hero-subheadline{font-size:1.2rem;color:var(--light-text-color);margin-bottom:2.5rem;line-height:1.6;animation:fade-slide-up .6s .4s ease-out forwards;opacity:0}.feature-grid{width:100%;margin:0 0 2rem;display:grid;grid-template-columns:180px 1fr;row-gap:.55rem;column-gap:1.25rem;font-size:.9rem;line-height:1.35;animation:fade-slide-up .6s .5s ease-out forwards;opacity:0}.feat-row{display:contents}.feat-term{font-weight:600;color:var(--primary-color);position:relative}.feat-term:after{content:":";position:absolute;right:-6px}.feat-desc{color:var(--light-text-color)}@media (max-width: 640px){.feature-grid{grid-template-columns:1fr}.feat-term:after{display:none}.feat-term{margin-top:.4rem}.feat-desc{margin-top:-.25rem}}.hero-cta{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;animation:fade-slide-up .6s .6s ease-out forwards;opacity:0;width:100%}@media (max-width: 1024px){.hero-cta{align-items:flex-start;text-align:left}}.trust-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;font-size:.75rem;letter-spacing:.5px;color:var(--light-text-color)}.trust-badges span{background:var(--hover-color);padding:.35rem .6rem;border-radius:999px;border:1px solid var(--border-color)}.cta-btn-large{padding:1rem 2.5rem;font-size:1.2rem;font-weight:600;border:none;border-radius:var(--border-radius);background-color:#333;color:#fff;cursor:pointer;transition:all .3s ease}body.dark-mode .cta-btn-large{background-color:#f0f0f0;color:#121212}.cta-btn-large:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000001a}.login-prompt{font-size:1rem;color:var(--light-text-color)}.login-link{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.hero-illustration{flex:1;position:relative;display:flex;justify-content:stretch;align-items:flex-start;min-height:500px}.feature-panel{position:absolute;top:50%;right:2.75rem;transform:translateY(-50%);display:flex;flex-direction:column;gap:.85rem;width:330px;max-width:330px;z-index:5;pointer-events:none}.panel-card{background:#ffffffd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border-color);border-radius:18px;padding:1rem 1.1rem 1.05rem;box-shadow:0 4px 16px #0000000d;animation:fade-slide-up .6s ease both}body.dark-mode .panel-card{background:#1e293bb3}.panel-card h3{margin:0 0 .4rem;font-size:.95rem;font-weight:700;letter-spacing:.5px}.panel-card p{margin:0;font-size:.78rem;line-height:1.35;color:var(--light-text-color)}.stat-card{padding:.9rem 1rem .85rem}.stat-items{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem .9rem}.stat{display:flex;flex-direction:column}.stat strong{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.stat span{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;color:var(--light-text-color)}.feature-panel .panel-card:nth-child(2){animation-delay:.1s}.feature-panel .panel-card:nth-child(3){animation-delay:.18s}.feature-panel .panel-card:nth-child(4){animation-delay:.26s}.mini-stats{display:none}.mini-stats div{display:flex;flex-direction:column;align-items:flex-start}.mini-stats strong{font-size:1.05rem;color:var(--primary-color)}.mini-stats span{font-size:.6rem;text-transform:uppercase;letter-spacing:.5px;color:var(--light-text-color)}.mobile-only{display:none}.animation-container{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.background-animation-container{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;pointer-events:none;z-index:1;opacity:.7}.ai-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:250px;height:250px;display:flex;justify-content:center;align-items:center}.background-animation-container .ai-core{top:40%;left:70%;width:200px;height:200px;opacity:.5}.core-glow{position:absolute;width:100%;height:100%;background:radial-gradient(circle,var(--primary-color) 0%,transparent 70%);border-radius:50%;animation:pulse-glow 4s ease-in-out infinite;opacity:.3}.core-ring{position:absolute;border-radius:50%;border:2px solid;border-color:var(--primary-color) transparent transparent transparent;animation:orbit 10s linear infinite}.core-ring.ring1{width:150px;height:150px;animation-duration:8s;opacity:.8}.core-ring.ring2{width:200px;height:200px;animation-duration:12s;animation-direction:reverse;opacity:.6}.core-ring.ring3{width:250px;height:250px;animation-duration:15s;opacity:.4}.floating-icon{position:absolute;bottom:-50px;opacity:0;display:flex;align-items:center;justify-content:center;animation:float-up linear infinite;filter:drop-shadow(0 0 5px currentColor)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{transform:scale(.9);opacity:.3}50%{transform:scale(1.1);opacity:.5}}@keyframes orbit{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float-up{0%{transform:translateY(0) translate(0) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh) translate(20px) rotate(90deg);opacity:0}}@media (max-width: 1280px){.hero-section{padding:2.25rem 2.25rem 2rem;gap:2.5rem}.hero-headline{font-size:2.85rem}}@media (max-width: 1024px){.welcome-page-container{height:auto;min-height:100vh;overflow-y:auto}.hero-section{flex-direction:column;text-align:left;padding:2rem 1.5rem;gap:2rem;align-items:stretch}.hero-content{flex:none;max-width:100%;order:1}.hero-illustration,.feature-panel{display:none}.mini-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;margin-bottom:1.5rem}.mobile-only{display:grid}.hero-headline{font-size:2.4rem;text-align:center;margin-bottom:1rem}.hero-subheadline{text-align:center;font-size:1.1rem;margin-bottom:2rem}.hero-cta{align-items:center;text-align:center}}@media (max-width: 768px){.welcome-header{padding:1rem 1.5rem;flex-wrap:wrap;gap:1rem}.welcome-nav{flex:1 1 100%;flex-wrap:wrap;column-gap:.75rem;row-gap:.5rem;justify-content:flex-end}.welcome-nav .welcome-btn-secondary:first-of-type,.welcome-nav .welcome-btn-primary{margin-left:0}.welcome-logo{font-size:1.6rem}.welcome-logo .logo-icon{width:28px;height:28px}.welcome-btn-secondary,.welcome-btn-primary,.welcome-btn-tertiary{padding:.5rem 1rem;font-size:.9rem}.hero-section{padding:1.5rem 1.5rem 2rem}.hero-headline{font-size:2.2rem;line-height:1.2}.hero-subheadline{font-size:1rem;padding:0 1rem}.feature-grid{font-size:.85rem;margin-bottom:1.5rem}}@media (max-width: 640px){.hero-section{padding:.9rem 1rem 1.1rem;text-align:center;gap:1.25rem}.hero-headline{font-size:1.8rem;line-height:1.25;margin-bottom:.6rem}.hero-subheadline{font-size:.95rem;padding:0;margin-bottom:1.1rem}.mini-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem 1rem;margin-bottom:.95rem}.mini-stats div{align-items:center;text-align:center}.mini-stats span{line-height:1.15}.feature-grid{grid-template-columns:1fr;gap:.4rem;text-align:left;margin-bottom:.9rem}.feat-term:after{display:none}.feat-term{margin-bottom:.25rem;font-size:.9rem}.feat-desc{margin-bottom:.4rem;font-size:.8rem}.cta-btn-large{padding:.875rem 2rem;font-size:1.1rem;width:100%;max-width:300px}.hero-cta{gap:.75rem}}@media (max-width: 480px){.welcome-header{padding:.75rem 1rem;justify-content:space-between}.welcome-logo{font-size:1.3rem}.welcome-logo .logo-icon{width:24px;height:24px}.welcome-nav{width:100%;justify-content:center;column-gap:.5rem;row-gap:.35rem}.welcome-btn-secondary,.welcome-btn-primary,.welcome-btn-tertiary{padding:.4rem .8rem;font-size:.8rem}.hero-section{padding:.65rem .9rem 1rem;gap:1.1rem}.hero-headline{font-size:1.6rem;line-height:1.3;margin-bottom:.45rem}.hero-subheadline{font-size:.9rem;line-height:1.4;margin-bottom:1rem}.mini-stats{gap:.65rem;margin-bottom:.9rem}.mini-stats strong{font-size:1rem}.mini-stats span{font-size:.55rem}.feature-grid{gap:.35rem;margin-bottom:.8rem}.feat-term{font-size:.85rem}.feat-desc{font-size:.75rem;line-height:1.3;margin-bottom:.35rem}.hero-cta{gap:.65rem}.cta-btn-large{padding:.75rem 1.5rem;font-size:1rem}.login-prompt{font-size:.9rem}.trust-badges{flex-wrap:nowrap;overflow-x:auto;width:100%;gap:.4rem}.trust-badges::-webkit-scrollbar{display:none;width:0;height:0}.trust-badges span{flex:0 0 auto;white-space:nowrap;font-size:.7rem;padding:.3rem .5rem}}.ncert-band{width:100%;background:linear-gradient(90deg,#3b82f614,#6366f114);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:3rem 2rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}body.dark-mode .ncert-band{background:linear-gradient(90deg,#3b82f61f,#6366f11f)}.ncert-band-inner{max-width:1200px;margin:0 auto;text-align:center}.ncert-band-inner h2{font-size:1.9rem;margin:0 0 1rem;font-weight:700}.ncert-band-inner p{max-width:800px;margin:0 auto 2rem;font-size:1rem;line-height:1.5;color:var(--light-text-color)}.ncert-pill-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.ncert-pill-grid .pill{padding:.55rem 1rem;background:#fff;color:#1e293b;border-radius:999px;font-size:.8rem;font-weight:600;box-shadow:0 2px 4px #0000000d;border:1px solid var(--border-color)}body.dark-mode .ncert-pill-grid .pill{background:#1f2937;color:#f1f5f9}@media (max-width: 768px){.ncert-band{padding:2rem 1rem}.ncert-band-inner h2{font-size:1.5rem;margin-bottom:.75rem}.ncert-band-inner p{font-size:.9rem;margin-bottom:1.5rem}.ncert-pill-grid{gap:.5rem}.ncert-pill-grid .pill{padding:.4rem .75rem;font-size:.75rem}.testimonials-band{padding:2.5rem 1rem 3rem}.testimonials-inner h2{font-size:1.5rem;margin-bottom:.5rem}.testimonial-intro{font-size:.9rem;margin-bottom:2rem}.testimonial-grid{grid-template-columns:1fr;gap:1rem}.testimonial-card{padding:1rem}.background-animation-container{opacity:.3}.background-animation-container .ai-core{top:25%;left:55%;width:120px;height:120px;opacity:.25}.background-animation-container .floating-icon{opacity:.3}}@media (max-width: 480px){.ncert-band{padding:1.5rem .75rem}.ncert-band-inner h2{font-size:1.3rem}.ncert-band-inner p{font-size:.85rem}.ncert-pill-grid .pill{font-size:.7rem;padding:.35rem .6rem}.testimonials-band{padding:2rem .75rem 2.5rem}.testimonials-inner h2{font-size:1.3rem}.testimonial-intro{font-size:.85rem}.testimonial-card{padding:.875rem}.testimonial-card blockquote{font-size:.875rem}.background-animation-container{opacity:.2}.background-animation-container .ai-core{display:none}.background-animation-container .floating-icon{opacity:.2}}@media (min-width: 1200px){.testimonial-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.testimonials-band{padding:4rem 2rem 5rem;background:var(--background-color)}body.dark-mode .testimonials-band{background:#0f172a}.testimonials-inner{max-width:1200px;margin:0 auto;text-align:center}.testimonials-inner h2{font-size:1.9rem;margin:0 0 .75rem}.testimonial-intro{color:var(--light-text-color);margin:0 0 2.5rem}.testimonial-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.testimonial-card{background:#fff;border:1px solid var(--border-color);padding:1.25rem 1.25rem 1.5rem;border-radius:16px;box-shadow:0 4px 12px #0000000a;position:relative;text-align:left}body.dark-mode .testimonial-card{background:#1e293b}.testimonial-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem;flex-wrap:nowrap}.testimonial-header figcaption{text-align:left;min-width:0}.avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid var(--border-color);background:#f8fafc}.t-name{font-weight:700;font-size:.95rem}.t-meta{font-size:.8rem;color:var(--light-text-color)}.testimonial-card blockquote{font-size:.95rem;line-height:1.45;margin:0 0 .75rem;font-style:italic;text-align:left}.testimonial-card figcaption{font-size:.8rem;font-weight:600;color:var(--primary-color)}.visually-hidden{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}@media (max-width: 360px){.hero-section{padding:.55rem .75rem .85rem;gap:1rem}.hero-headline{font-size:1.4rem;margin-bottom:.35rem}.hero-subheadline{font-size:.85rem;margin-bottom:.85rem}.welcome-btn-secondary,.welcome-btn-primary,.welcome-btn-tertiary{padding:.35rem .65rem;font-size:.75rem}.cta-btn-large{font-size:.95rem;padding:.65rem 1.25rem}.feature-grid{margin-bottom:.65rem}}.subscription-container{display:flex;justify-content:center;align-items:flex-start;height:100vh;width:100vw;overflow-y:auto;background:linear-gradient(135deg,#e0f7fa,#d1c4e9);padding:2rem 1rem}.subscription-box{position:relative;background-color:var(--surface-color);padding:3rem 2rem 2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);text-align:center;max-width:950px;width:100%;animation:slide-down .5s ease-out}.subscription-title{font-size:2.2rem;font-weight:700;margin-bottom:.5rem}.subscription-subtitle{font-size:1.1rem;color:var(--light-text-color);margin-bottom:3rem}.trial-banner{background:#4a90e21f;border:1px solid rgba(74,144,226,.35);color:var(--primary-dark, #1b3a57);padding:.75rem 1rem;border-radius:12px;margin:-2rem auto 2rem;max-width:580px;line-height:1.4}.plans-wrapper{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;align-items:stretch}.plan-card{position:relative;background:linear-gradient(135deg,#667eea,#764ba2);padding:2.5rem 1.5rem 2rem;border-radius:var(--border-radius);border:2px solid rgba(255,255,255,.2);transition:all .3s ease;overflow:hidden;display:flex;flex-direction:column;color:#fff}.plan-card:hover{transform:translateY(-5px);border-color:gold;box-shadow:0 8px 24px #ffd7004d}.plan-card.popular{border-color:gold;box-shadow:0 8px 20px #ffd70066;transform:scale(1.05)}.popular-badge{position:absolute;top:0;right:0;background-color:gold;color:#333;padding:.4rem 1rem;font-size:.8rem;font-weight:600;border-top-right-radius:calc(var(--border-radius) - 2px);border-bottom-left-radius:var(--border-radius)}.plan-duration{font-size:1.25rem;font-weight:600;margin-bottom:.75rem;color:#fff}.plan-price{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;color:gold}.plan-price .currency{font-size:1.5rem;vertical-align:super;margin-right:.25rem;color:#ffffffe6}.savings-badge{background-color:#10b981;color:#fff;padding:.3rem .8rem;border-radius:12px;font-size:.8rem;font-weight:600;margin:0 auto 1.5rem;display:inline-block}.plan-features{list-style:none;padding:0;margin:1.5rem 0;text-align:left;flex-grow:1;color:#fffffff2;font-size:.95rem}.plan-features li{margin-bottom:.75rem;padding-left:1.75rem;position:relative;line-height:1.5}.plan-features li:before{content:"✔";position:absolute;left:0;color:#10b981;font-weight:700;font-size:1.2rem;top:-2px}.choose-plan-btn{width:100%;padding:.8rem 1.5rem;border:none;border-radius:8px;font-family:var(--font-family);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;background-color:#fff;color:#667eea;margin-top:auto}.plan-card:hover .choose-plan-btn,.plan-card.popular .choose-plan-btn{background-color:gold;color:#333;transform:translateY(-2px);box-shadow:0 4px 12px #ffd70066}.coupon-section{margin-bottom:2rem;padding:1.25rem;background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid rgba(102,126,234,.1);border-radius:12px}.coupon-input-group{display:flex;flex-direction:column;gap:.75rem}.coupon-input-group label{font-size:.9rem;font-weight:600;color:var(--text-color)}.coupon-input-wrapper{position:relative;display:flex;align-items:center}.coupon-input-wrapper input{flex:1;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:all .2s;text-transform:uppercase}.coupon-input-wrapper input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.coupon-input-wrapper input:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.coupon-input-wrapper .validating{position:absolute;right:1rem;font-size:.8rem;color:#ed8936;font-weight:600}.coupon-status{font-size:.85rem;font-weight:500;padding:.5rem .75rem;border-radius:6px;display:flex;align-items:center;gap:.5rem}.coupon-status.success{background:#2e7d321a;color:#2e7d32;border:1px solid rgba(46,125,50,.2)}.coupon-status.error{background:#c628281a;color:#c62828;border:1px solid rgba(198,40,40,.2)}.coupon-status .discount-info{margin-left:auto;font-weight:700;color:inherit}.discount-badge-inline{display:inline-block;background:#4caf5033;color:#2e7d32;padding:.35rem .75rem;border-radius:8px;font-size:.8rem;font-weight:600;margin-top:.5rem}@media (max-width: 980px){.plan-card.popular{transform:none}}@media (max-width: 600px){.subscription-box{padding:3rem 1rem 1rem}.subscription-title{font-size:1.8rem}.plans-wrapper{grid-template-columns:1fr}}.achievement-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.achievement-modal-content{background:#fff;border-radius:20px;padding:40px 30px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out}.achievement-modal-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:2rem;color:#999;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.achievement-modal-close:hover{background-color:#f0f0f0;color:#333}.achievement-modal-icon-container{display:flex;justify-content:center;margin-bottom:20px}.achievement-modal-icon{font-size:5rem;width:120px;height:120px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 30px #667eea4d;position:relative}.achievement-modal-icon.locked{filter:grayscale(1);opacity:.5;background:#e0e0e0;box-shadow:0 10px 30px #0000001a}.achievement-modal-icon.unlocked{animation:bounce .6s ease-out}.achievement-modal-title{text-align:center;font-size:1.8rem;font-weight:700;color:#333;margin-bottom:15px}.achievement-modal-rarity{display:inline-block;padding:6px 16px;border-radius:20px;color:#fff;font-weight:600;font-size:.75rem;letter-spacing:1px;margin:0 auto 20px;display:block;width:fit-content;text-shadow:0 1px 2px rgba(0,0,0,.2)}.achievement-modal-description{text-align:center;font-size:1.1rem;color:#666;line-height:1.6;margin-bottom:25px}.achievement-modal-category{text-align:center;font-size:.95rem;color:#999;margin-bottom:30px}.achievement-modal-category span{font-weight:600;color:#667eea;text-transform:capitalize}.achievement-modal-unlocked,.achievement-modal-locked{border-top:1px solid #e0e0e0;padding-top:25px;margin-top:25px}.achievement-modal-badge{display:inline-block;padding:10px 20px;border-radius:25px;background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;font-weight:700;font-size:.9rem;letter-spacing:1px;margin:0 auto 15px;display:block;width:fit-content;box-shadow:0 4px 15px #11998e4d}.achievement-modal-badge.locked-badge{background:linear-gradient(135deg,#868f96,#596164);box-shadow:0 4px 15px #0003}.achievement-modal-date{text-align:center;color:#999;font-size:.9rem}.achievement-modal-progress{margin-top:20px}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.95rem;color:#666}.progress-numbers{font-weight:700;color:#333}.progress-bar-large{height:12px;background-color:#e0e0e0;border-radius:10px;overflow:hidden;margin-bottom:8px;box-shadow:inset 0 2px 4px #0000001a}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .4s ease-out;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.progress-percentage{text-align:center;font-weight:600;color:#667eea;font-size:.9rem;margin-top:8px}@keyframes bounce{0%,to{transform:scale(1)}25%{transform:scale(1.1)}50%{transform:scale(.95)}75%{transform:scale(1.05)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.dark .achievement-modal-content{background:#1e1e1e;color:#e0e0e0}.dark .achievement-modal-title{color:#e0e0e0}.dark .achievement-modal-description{color:#b0b0b0}.dark .achievement-modal-close:hover{background-color:#333;color:#e0e0e0}@media (max-width: 600px){.achievement-modal-content{padding:30px 20px;width:95%}.achievement-modal-icon{font-size:4rem;width:100px;height:100px}.achievement-modal-title{font-size:1.5rem}.achievement-modal-description{font-size:1rem}}.dashboard-container{padding:2rem;display:flex;flex-direction:column;gap:2rem}.dashboard-header{text-align:center}.dashboard-header{position:relative}.dashboard-logout-btn{position:absolute;top:0;right:0;transform:translateY(-50%);background:var(--danger-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-weight:600}.dashboard-logout-btn:hover{filter:brightness(.95)}.dashboard-header h1{font-size:2.5rem;font-weight:700;color:var(--text-color)}.dashboard-header p{font-size:1.2rem;color:var(--light-text-color);margin-top:.5rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;max-width:1200px;width:100%;margin:0 auto}.card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:1.5rem;display:flex;flex-direction:column}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.card-header h2{font-size:1.2rem;font-weight:600}.card-header-icon{width:24px;height:24px;margin-right:.5rem;opacity:.7}.view-all-btn{background:none;border:none;color:var(--primary-color);font-weight:500;cursor:pointer}.main-actions{grid-column:1 / -1;flex-direction:row;flex-wrap:wrap;gap:1.5rem}.action-btn{flex:1;padding:1.5rem;border-radius:var(--border-radius);border:2px solid var(--border-color);background-color:var(--subtle-bg-color);color:var(--text-color);font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;transition:all .2s ease;text-align:center;min-width:200px}.action-btn:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 8px 20px #0000001a;border-color:var(--primary-color);color:var(--primary-color)}.action-btn:hover:not(:disabled) .action-icon{filter:invert(55%) sepia(52%) saturate(1542%) hue-rotate(185deg) brightness(90%) contrast(90%)}.action-btn:disabled{opacity:.6;cursor:not-allowed;background-color:var(--hover-color)}.action-btn:disabled:hover{transform:none;box-shadow:none;border-color:var(--border-color)}.subscribe-prompt{width:100%;text-align:center;color:var(--light-text-color);margin-top:.5rem}.link-btn{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.action-btn.primary{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.action-btn.primary:hover:not(:disabled){background-color:#3a7ac8;color:#fff}.action-btn.primary:hover:not(:disabled) .action-icon{filter:brightness(0) invert(1)}.action-icon{width:32px;height:32px;filter:grayscale(50%) opacity(.7);transition:filter .2s ease}.action-btn.primary .action-icon{filter:brightness(0) invert(1)}.stats-card{flex-direction:row;justify-content:space-around;align-items:center;text-align:center;padding:2rem 1.5rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-value{font-size:2rem;font-weight:700;color:var(--primary-color)}.stat-label{font-size:1rem;color:var(--light-text-color)}.list-card{gap:1rem}.todo-summary-list{list-style-type:none;padding-left:.5rem;display:flex;flex-direction:column;gap:.5rem}.empty-text{color:var(--light-text-color);text-align:center;padding:1rem 0}.empty-state-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.dual-buttons{display:flex;gap:1rem}.action-btn-small{padding:.6rem 1.2rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;border:none;background-color:var(--primary-color);color:#fff;transition:background-color .2s}.action-btn-small:hover{background-color:#3a7ac8}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1.5rem}.achievement-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;padding:15px;border-radius:12px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.achievement-item:hover{transform:translateY(-5px);box-shadow:0 8px 20px #00000026}.achievement-item.locked{opacity:.5;filter:grayscale(1);background:linear-gradient(135deg,#e0e0e0,#b0b0b0)}.achievement-item.unlocked{animation:achievementUnlock .5s ease-out}.achievement-item.common{background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.achievement-item.rare{background:linear-gradient(135deg,#a1c4fd,#c2e9fb)}.achievement-item.epic{background:linear-gradient(135deg,#d299c2,#fef9d7)}.achievement-item.legendary{background:linear-gradient(135deg,#ffecd2,#fcb69f);box-shadow:0 4px 15px #fcb69f66}.achievement-badge{font-size:2.5rem;margin-bottom:5px}.achievement-title{font-size:.85rem;font-weight:600;color:#333;margin-bottom:5px}.achievement-rarity{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:10px;background:#ffffffb3;margin-top:5px}.achievement-rarity.common{color:#95a5a6}.achievement-rarity.rare{color:#3498db}.achievement-rarity.epic{color:#9b59b6}.achievement-rarity.legendary{color:#f39c12}.achievement-progress{width:100%;margin-top:8px}.achievement-progress-bar{height:4px;background-color:#0000001a;border-radius:2px;overflow:hidden;margin-bottom:4px}.achievement-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;transition:width .4s ease}.achievement-progress-text{font-size:.7rem;color:#666;font-weight:500}@keyframes achievementUnlock{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.achievements-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.achievements-filter{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:6px 12px;border:2px solid #e0e0e0;background:#fff;border-radius:20px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:#667eea;color:#667eea}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.weakness-hunter-card{background-color:var(--weakness-hunter-bg);border:1px solid var(--weakness-hunter-border);align-items:center;text-align:center;gap:1rem}.weakness-hunter-card .card-header{border:none;padding:0;margin:0}.weakness-hunter-card h2{color:var(--weakness-hunter-header)}.weakness-hunter-card p{color:var(--weakness-hunter-text)}.weakness-hunter-card .action-btn-small{background-color:var(--weakness-hunter-button)}.weakness-hunter-card .action-btn-small:hover{background-color:var(--weakness-hunter-button-hover)}.saved-plans-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.saved-plan-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:var(--subtle-bg-color);border-radius:8px;border:1px solid var(--border-color);transition:border-color .2s}.saved-plan-item.active{border-color:var(--secondary-color)}.plan-info{display:flex;flex-direction:column;gap:.25rem;text-align:left;flex:1 1 auto;min-width:0}.active-badge{font-size:.75rem;font-weight:600;color:var(--secondary-color);text-transform:uppercase}.plan-topic-name{font-weight:600}.plan-duration{font-size:.9rem;color:var(--light-text-color)}.plan-actions{display:flex;gap:.5rem;flex-shrink:1;flex-wrap:wrap;justify-content:flex-end}.plan-actions .action-btn-small.view{background-color:var(--hover-color);color:var(--text-color)}.plan-actions .action-btn-small.view:hover{background-color:var(--border-color)}.plan-actions .action-btn-small.set-active,.plan-actions .action-btn-small.start-prep{background-color:var(--secondary-color)}.plan-actions .action-btn-small.set-active:hover,.plan-actions .action-btn-small.start-prep:hover{background-color:#3abfa2}.plan-actions .action-btn-small.delete{background-color:var(--danger-color)}.plan-actions .action-btn-small.delete:hover{background-color:#c91a56}@media (max-width: 768px){.dashboard-container{padding:1rem}.dashboard-header{padding-top:2.5rem}.dashboard-logout-btn{position:absolute;top:.5rem;right:.5rem;transform:none;margin:0}.dashboard-header h1{font-size:1.8rem}.dashboard-header p{font-size:1rem}.main-actions{flex-direction:column}.saved-plan-item{flex-direction:column;align-items:flex-start;gap:.75rem}}@media (max-width: 1024px){.saved-plan-item{flex-direction:column;align-items:flex-start;gap:.75rem}.plan-info{width:100%}.plan-actions{width:100%;justify-content:flex-start}}.quiz-container{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;height:100%;min-height:100vh}.quiz-card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:2.5rem;width:100%;max-width:700px;text-align:center;position:relative}.quiz-card.setup{padding-top:4.5rem}.quiz-container.results{gap:2rem}.back-btn{position:absolute;top:1.5rem;left:1.5rem;background:none;border:none;font-size:1rem;font-weight:500;color:var(--light-text-color);cursor:pointer;padding:.5rem}.quiz-title{font-size:2rem;font-weight:700;margin-bottom:.5rem}.quiz-subtitle{font-size:1.1rem;color:var(--light-text-color);margin-bottom:2rem}.quiz-setup-form{display:flex;flex-direction:column;gap:1rem}.form-label{font-size:1rem;font-weight:500;color:var(--light-text-color);margin-bottom:-.5rem}.quiz-topic-input{width:100%;padding:1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1.1rem}.quiz-btn{padding:1rem 1.5rem;border:none;border-radius:var(--border-radius);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.quiz-btn.primary{background-color:var(--primary-color);color:#fff}.quiz-btn.primary:hover:not(:disabled){background-color:#3a7ac8}.quiz-btn:disabled{background-color:#a0c3ed;cursor:not-allowed}.quiz-progress-bar{width:100%;height:8px;background-color:var(--border-color);border-radius:4px;margin-bottom:1.5rem}.quiz-progress{height:100%;background-color:var(--secondary-color);border-radius:4px;transition:width .3s ease}.quiz-header{text-align:right;color:var(--light-text-color);margin-bottom:1rem}.quiz-question-text{font-size:1.5rem;font-weight:500;margin-bottom:2rem;min-height:100px}.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.quiz-option-btn{padding:1rem;border:2px solid var(--border-color);border-radius:var(--border-radius);background-color:transparent;color:var(--text-color);text-align:left;font-size:1rem;cursor:pointer;transition:all .2s}.quiz-option-btn:hover:not(:disabled){border-color:var(--secondary-color);background-color:var(--hover-color)}.quiz-option-btn.selected{border-color:var(--primary-color);background-color:var(--user-message-bg);font-weight:600}.quiz-btn.submit{margin:1rem auto 0}.results-score-circle{position:relative;width:150px;height:150px;margin:1.5rem auto}.score-ring{width:100%;height:100%;transform:rotate(-90deg)}.score-ring-bg{fill:none;stroke:var(--border-color);stroke-width:3.8}.score-ring-fg{fill:none;stroke:var(--primary-color);stroke-width:4;stroke-linecap:round;transition:stroke-dasharray .5s ease}.score-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.score{font-size:3rem;font-weight:700;color:var(--primary-color)}.total{font-size:1.2rem;color:var(--light-text-color)}.results-feedback{font-size:1.2rem;font-weight:500;margin-bottom:2rem}.review-section{text-align:left}.review-title{font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.review-item{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.review-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.review-question{font-weight:500;margin-bottom:.75rem}.review-options{list-style:none;padding-left:0;display:flex;flex-direction:column;gap:.5rem}.review-options li{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border-color)}.review-options li.correct{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.review-options li.incorrect{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24;text-decoration:line-through}.ai-feedback{background-color:#fefbec;border:1px solid #ffeeba;border-radius:var(--border-radius);padding:1rem;margin-top:1rem}.feedback-title{font-size:1rem;font-weight:600;color:#856404;margin-bottom:.5rem}.add-to-plan-btn{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:0;margin-top:.75rem}.add-to-plan-btn:hover{text-decoration:underline}.duration-selector{display:flex;justify-content:center;gap:.75rem;margin:.5rem 0 1rem}.duration-btn{padding:.6rem 1.2rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--surface-color);color:var(--text-color);font-family:var(--font-family);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.duration-btn:hover:not(.selected){border-color:var(--primary-color);color:var(--primary-color);background-color:var(--hover-color)}.duration-btn.selected{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width: 600px){.quiz-container{padding:1rem}.quiz-card{padding:1.5rem}.quiz-options{grid-template-columns:1fr}}.header{position:relative;background:var(--surface-color);padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);box-shadow:0 2px 4px #0000000d;display:flex;align-items:center;justify-content:space-between;z-index:10}.header-group-left,.header-group-right{display:flex;align-items:center;gap:.75rem;flex:1}.header-group-right{justify-content:flex-end}.profile-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--primary-color);cursor:pointer;background-color:var(--primary-color);background-size:cover;background-position:center;padding:0;flex-shrink:0}.header-icon-btn{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;background-color:transparent;background-size:24px 24px;background-position:center;background-repeat:no-repeat;padding:0;opacity:.7;transition:opacity .2s,background-color .2s,filter .2s;flex-shrink:0}.header-icon-btn:hover:not(:disabled){opacity:1;background-color:var(--hover-color)}.header-icon-btn:disabled{opacity:.4;cursor:not-allowed}.todo-btn{filter:invert(55%) sepia(52%) saturate(1542%) hue-rotate(185deg) brightness(90%) contrast(90%)}.header-title-group{display:flex;align-items:center;justify-content:center;flex:2}.brand-container{display:flex;align-items:center;gap:.5rem;position:relative}.logo-icon{width:32px;height:32px;background-size:contain;background-position:center;background-repeat:no-repeat;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform .3s ease,filter .3s ease}.logo-icon:hover{transform:scale(1.05);filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.brand-title{display:flex;flex-direction:column;align-items:flex-start;line-height:1;margin:0}.brand-name{font-family:Dancing Script,Satisfy,cursive;font-size:2rem;font-weight:600;letter-spacing:.02em;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 1px 2px rgba(0,0,0,.1);transition:all .3s ease;transform:translateY(-1px)}.socratic-badge{font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:600;letter-spacing:.08em;color:var(--accent-color, #f59e0b);text-transform:uppercase;margin-top:-2px;opacity:.9;background:#f59e0b1a;padding:2px 6px;border-radius:4px;border:1px solid rgba(245,158,11,.2)}.hamburger-btn,.dashboard-btn-left{display:none}@media (max-width: 768px){.header{padding:.75rem 1rem}.header-title-group{position:absolute;left:50%;transform:translate(-50%);width:auto}.brand-container{gap:.4rem}.logo-icon{width:28px;height:28px}.brand-name{font-size:1.6rem;font-weight:600}.socratic-badge{font-size:.55rem;padding:1px 4px;margin-top:-1px}.header-group-left,.header-group-right{gap:.6rem;flex:initial}.header-group-right .nav-icon{display:none}.hamburger-btn{display:block}.dashboard-btn-left{display:inline-block;background-color:var(--surface-color);border:1px solid var(--border-color)}}@media (max-width: 480px){.brand-name{font-size:1.3rem;font-weight:600}.logo-icon{width:24px;height:24px}.socratic-badge{font-size:.5rem;padding:1px 3px}}body.dark-mode .header-icon-btn:not(.todo-btn){filter:invert(1)}body.dark-mode .brand-name{background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}body.dark-mode .logo-icon{filter:drop-shadow(0 2px 4px rgba(255,255,255,.1))}body.dark-mode .logo-icon:hover{filter:drop-shadow(0 4px 8px rgba(255,255,255,.15))}body.dark-mode .socratic-badge{background:#f59e0b33;border:1px solid rgba(245,158,11,.3);color:#fbbf24}.settings{display:flex;gap:1rem;padding:1rem 1.5rem;background:var(--surface-transparent-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);flex-wrap:wrap;padding-top:calc(1rem + env(safe-area-inset-top,0))}.select-wrapper{position:relative;flex:1;min-width:120px}.select-wrapper:after{content:"▼";font-size:.8rem;position:absolute;right:1rem;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--light-text-color)}.settings select{width:100%;padding:.75rem 1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--surface-color);color:var(--text-color);font-family:var(--font-family);font-size:1rem;-moz-appearance:none;appearance:none;-webkit-appearance:none}.settings select:invalid{color:var(--light-text-color)}.settings select option{color:var(--text-color)}@media (max-width: 768px){.settings{flex-direction:column;padding:.75rem 1rem}}@font-face{font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2) format("woff2"),url(/assets/KaTeX_AMS-Regular-DMm9YOAa.woff) format("woff"),url(/assets/KaTeX_AMS-Regular-DRggAlZN.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff) format("woff"),url(/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff) format("woff"),url(/assets/KaTeX_Fraktur-Regular-CB_wures.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Main-Bold-Cx986IdX.woff2) format("woff2"),url(/assets/KaTeX_Main-Bold-Jm3AIy58.woff) format("woff"),url(/assets/KaTeX_Main-Bold-waoOVXN0.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2) format("woff2"),url(/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff) format("woff"),url(/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2) format("woff2"),url(/assets/KaTeX_Main-Italic-BMLOBm91.woff) format("woff"),url(/assets/KaTeX_Main-Italic-3WenGoN9.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Main-Regular-B22Nviop.woff2) format("woff2"),url(/assets/KaTeX_Main-Regular-Dr94JaBh.woff) format("woff"),url(/assets/KaTeX_Main-Regular-ypZvNtVU.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2) format("woff2"),url(/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff) format("woff"),url(/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Math-Italic-t53AETM-.woff2) format("woff2"),url(/assets/KaTeX_Math-Italic-DA0__PXp.woff) format("woff"),url(/assets/KaTeX_Math-Italic-flOr_0UB.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:700;src:url(/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff) format("woff"),url(/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:italic;font-weight:400;src:url(/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff) format("woff"),url(/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:400;src:url(/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff) format("woff"),url(/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf) format("truetype")}@font-face{font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Script-Regular-D3wIWfF6.woff2) format("woff2"),url(/assets/KaTeX_Script-Regular-D5yQViql.woff) format("woff"),url(/assets/KaTeX_Script-Regular-C5JkGWo-.ttf) format("truetype")}@font-face{font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2) format("woff2"),url(/assets/KaTeX_Size1-Regular-C195tn64.woff) format("woff"),url(/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf) format("truetype")}@font-face{font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2) format("woff2"),url(/assets/KaTeX_Size2-Regular-oD1tc_U0.woff) format("woff"),url(/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf) format("truetype")}@font-face{font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA4oAA4AAAAAHbQAAA3TAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAABmAAgRQIDgmcDBEICo1oijYBNgIkA14LMgAEIAWJAAeBHAyBHBvbGiMRdnO0IkRRkiYDgr9KsJ1NUAf2kILNxgUmgqIgq1P89vcbIcmsQbRps3vCcXdYOKSWEPEKgZgQkprQQsxIXUgq0DqpGKmIvrgkeVGtEQD9DzAO29fM9jYhxZEsL2FeURH2JN4MIcTdO049NCVdxQ/w9NrSYFEBKTDKpLKfNkCGDc1RwjZLQcm3vqJ2UW9Xfa3tgAHz6ivp6vgC2yD4/6352ndnN0X0TL7seypkjZlMsjmZnf0Mm5Q+JykRWQBKCVCVPbARPXWyQtb5VgLB6Biq7/Uixcj2WGqdI8tGSgkuRG+t910GKP2D7AQH0DB9FMDW/obJZ8giFI3Wg8Cvevz0M+5m0rTh7XDBlvo9Y4vm13EXmfttwI4mBo1EG15fxJhUiCLbiiyCf/ZA6MFAhg3pGIZGdGIVjtPn6UcMk9A/UUr9PhoNsCENw1APAq0gpH73e+M+0ueyHbabc3vkbcdtzcf/fiy+NxQEjf9ud/ELBHAXJ0nk4z+MXH2Ev/kWyV4k7SkvpPc9Qr38F6RPWnM9cN6DJ0AdD1BhtgABtmoRoFCvPsBAumNm6soZG2Gk5GyVTo2sJncSyp0jQTYoR6WDvTwaaEcHsxHfvuWhHA3a6bN7twRKtcGok6NsCi7jYRrM2jExsUFMxMQYuJbMhuWNOumEJy9hi29Dmg5zMp/A5+hhPG19j1vBrq8JTLr8ki5VLPmG/PynJHVul440bxg5xuymHUFPBshC+nA9I1FmwbRBTNHAcik3Oae0cxKoI3MOriM42UrPe51nsaGxJ+WfXubAsP84aabUlQSJ1IiE0iPETLUU4CATgfXSCSpuRFRmCGbO+wSpAnzaeaCYW1VNEysRtuXCEL1kUFUbbtMv3Tilt/1c11jt3Q5bbMa84cpWipp8Elw3MZhOHsOlwwVUQM3lAR35JiFQbaYCRnMF2lxAWoOg2gyoIV4PouX8HytNIfLhqpJtXB4vjiViUI8IJ7bkC4ikkQvKksnOTKICwnqWSZ9YS5f0WCxmpgjbIq7EJcM4aI2nmhLNY2JIUgOjXZFWBHb+x5oh6cwb0Tv1ackHdKi0I9OO2wE9aogIOn540CCCziyhN+IaejtgAONKznHlHyutPrHGwCx9S6B8kfS4Mfi4Eyv7OU730bT1SCBjt834cXsf43zVjPUqqJjgrjeGnBxSG4aYAKFuVbeCfkDIjAqMb6yLNIbCuvXhMH2/+k2vkNpkORhR59N1CkzoOENvneIosjYmuTxlhUzaGEJQ/iWqx4dmwpmKjrwTiTGTCVozNAYqk/zXOndWxuWSmJkQpJw3pK5KX6QrLt5LATMqpmPAQhkhK6PUjzHUn7E0gHE0kPE0iKkolgkUx9SZmVAdDgpffdyJKg3k7VmzYGCwVXGz/tXmkOIp+vcWs+EMuhhvN0h9uhfzWJziBQmCREGSIFmQIkgVpAnSBRmC//6hkLZwaVhwxlrJSOdqlFtOYxlau9F2QN5Y98xmIAsiM1HVp2VFX+DHHGg6Ecjh3vmqtidX3qHI2qycTk/iwxSt5UzTmEP92ZBnEWTk4Mx8Mpl78ZDokxg/KWb+Q0QkvdKVmq3TMW+RXEgrsziSAfNXFMhDc60N5N9jQzjfO0kBKpUZl0ZmwJ41j/B9Hz6wmRaJB84niNmQrzp9eSlQCDDzazGDdVi3P36VZQ+Jy4f9UBNp+3zTjqI4abaFAm+GShVaXlsGdF3FYzZcDI6cori4kMxUECl9IjJZpzkvitAoxKue+90pDMvcKRxLl53TmOKCmV/xRolNKSqqUxc6LStOETmFOiLZZptlZepcKiAzteG8PEdpnQpbOMNcMsR4RR2Bs0cKFEvSmIjAFcnarqwUL4lDhHmnVkwu1IwshbiCcgvOheZuYyOteufZZwlcTlLgnZ3o/WcYdzZHW/WGaqaVfmTZ1aWCceJjkbZqsfbkOtcFlUZM/jy+hXHDbaUobWqqXaeWobbLO99yG5N3U4wxco0rQGGcOLASFMXeJoham8M+/x6O2WywK2l4HGbq1CoUyC/IZikQhdq3SiuNrvAEj0AVu9x2x3lp/xWzahaxidezFVtdcb5uEnzyl0ZmYiuKI0exvCd4Xc9CV1KB0db00z92wDPde0kukbvZIWN6jUWFTmPIC/Y4UPCm8UfDTFZpZNon1qLFTkBhxzB+FjQRA2Q/YRJT8pQigslMaUpFyAG8TMlXigiqmAZX4xgijKjRlGpLE0GdplRfCaJo0JQaSxNBk6ZmMzcya0FmrcisDdn0Q3HI2sWSppYigmlM1XT/kLQZSNpMJG0WkjYbSZuDpM1F0uYhFc1HxU4m1QJjDK6iL0S5uSj5rgXc3RejEigtcRBtqYPQsiTskmO5vosV+q4VGIKbOkDg0jtRrq+Em1YloaTFar3EGr1EUC8R0kus1Uus00usL97ABr2BjXoDm/QGNhuWtMVBKOwg/i78lT7hBsAvDmwHc/ao3vmUbBmhjeYySZNWvGkfZAgISDSaDo1SVpzGDsAEkF8B+gEapViUoZgUWXcRIGFZNm6gWbAKk0bp0k1MHG9fLYtV4iS2SmLEQFARzRcnf9PUS0LVn05/J9MiRRBU3v2IrvW974v4N00L7ZMk0wXP1409CHo/an8zTRHD3eSJ6m8D4YMkZNl3M79sqeuAsr/m3f+8/yl7A50aiAEJgeBeMWzu7ui9UfUBCe2TIqZIoOd/3/udRBOQidQZUERzb2/VwZN1H/Sju82ew2H2Wfr6qvfVf3hqwDvAIpkQVFy4B9Pe9e4/XvPeceu7h3dvO56iJPf0+A6cqA2ip18ER+iFgggiuOkvj24bby0N9j2UHIkgqIt+sVgfodC4YghLSMjSZbH0VR/6dMDrYJeKHilKTemt6v6kvzvn3/RrdWtr0GoN/xL+Sex/cPYLUpepx9cz/D46UPU5KXgAQa+NDps1v6J3xP1i2HtaDB0M9aX2deA7SYff//+gUCovMmIK/qfsFcOk+4Y5ZN97XlG6zebqtMbKgeRFi51vnxTQYBUik2rS/Cn6PC8ADR8FGxsRPB82dzfND90gIcshOcYUkfjherBz53odpm6TP8txlwOZ71xmfHHOvq053qFF/MRlS3jP0ELudrf2OeN8DHvp6ZceLe8qKYvWz/7yp0u4dKPfli3CYq0O13Ih71mylJ80tOi10On8wi+F4+LWgDPeJ30msSQt9/vkmHq9/Lvo2b461mP801v3W4xTcs6CbvF9UDdrSt+A8OUbpSh55qAUFXWznBBfdeJ8a4d7ugT5tvxUza3h9m4H7ptTqiG4z0g5dc0X29OcGlhpGFMpQo9ytTS+NViZpNdvU4kWx+LKxNY10kQ1yqGXrhe4/1nvP7E+nd5A92TtaRplbHSqoIdOqtRWti+fkB5/n1+/VvCmz12pG1kpQWsfi1ftlBobm0bpngs16CHkbIwdLnParxtTV3QYRlfJ0KFskH7pdN/YDn+yRuSd7sNH3aO0DYPggk6uWuXrfOc+fa3VTxFVvKaNxHsiHmsXyCLIE5yuOeN3/Jdf8HBL/5M6shjyhxHx9BjB1O0+4NLOnjLLSxwO7ukN4jMbOIcD879KLSi6Pk61Oqm2377n8079PXEEQ7cy7OKEC9nbpet118fxweTafpt69x/Bt8UqGzNQt7aelpc44dn5cqhwf71+qKp/Zf/+a0zcizOUWpl/iBcSXip0pplkatCchoH5c5aUM8I7/dWxAej8WicPL1URFZ9BDJelUwEwTkGqUhgSlydVes95YdXvhh9Gfz/aeFWvgVb4tuLbcv4+wLdutVZv/cUonwBD/6eDlE0aSiKK/uoH3+J1wDE/jMVqY2ysGufN84oIXB0sPzy8ollX/LegY74DgJXJR57sn+VGza0x3DnuIgABFM15LmajjjsNlYj+JEZGbuRYcAMOWxFkPN2w6Wd46xo4gVWQR/X4lyI/R6K/YK0110GzudPRW7Y+UOBGTfNNzHeYT0fiH0taunBpq9HEW8OKSaBGj21L0MqenEmNRWBAWDWAk4CpNoEZJ2tTaPFgbQYj8HxtFilErs3BTRwT8uO1NXQaWfIotchmPkAF5mMBAliEmZiOGVgCG9LgRzpscMAOOwowlT3JhusdazXGSC/hxR3UlmWVwWHpOIKheqONvjyhSiTHIkVUco5bnji8m//zL7PKaT1Vl5I6UE609f+gkr6MZKVyKc7zJRmCahLsdlyA5fdQkRSan9LgnnLEyGSkaKJCJog0wAgvepWBt80+1yKln1bMVtCljfNWDueKLsWwaEbBSfSPTEmVRsUcYYMnEjcjeyCZzBXK9E9BYBXLKjOSpUDR+nEV3TFSUdQaz+ot98QxgXwx0GQ+EEUAKB2qZPkQQ0GqFD8UPFMqyaCHM24BZmSGic9EYMagKizOw9Hz50DMrDLrqqLkTAhplMictiCAx5S3BIUQdeJeLnBy2CNtMfz6cV4u8XKoFZQesbf9YZiIERiHjaNodDW6LgcirX/mPnJIkBGDUpTBhSa0EIr38D5hCIszhCM8URGBqImoWjpvpt1ebu/v3Gl3qJfMnNM+9V+kiRFyROTPHQWOcs1dNW94/ukKMPZBvDi55i5CttdeJz84DLngLqjcdwEZ87bFFR8CIG35OAkDVN6VRDZ7aq67NteYqZ2lpT8oYB2CytoBd6VuAx4WgiAsnuj3WohG+LugzXiQRDeM3XYXlULv4dp5VFYC) format("woff2"),url(/assets/KaTeX_Size3-Regular-CTq5MqoE.woff) format("woff"),url(/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf) format("truetype")}@font-face{font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2) format("woff2"),url(/assets/KaTeX_Size4-Regular-BF-4gkZK.woff) format("woff"),url(/assets/KaTeX_Size4-Regular-DWFBv043.ttf) format("truetype")}@font-face{font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2) format("woff2"),url(/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff) format("woff"),url(/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf) format("truetype")}.katex{font: 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.22"}.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:-moz-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}.chat-window{flex:1 1 auto;min-height:0;max-height:100%;overflow-y:auto;overflow-x:hidden;padding:1rem 1.5rem 2rem;scroll-padding-bottom:2rem;display:flex;flex-direction:column;gap:.8rem;overscroll-behavior:contain;contain:layout style;scroll-behavior:smooth;transform:translateZ(0);scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.3) transparent}.chat-window::-webkit-scrollbar{width:8px}.chat-window::-webkit-scrollbar-track{background:transparent}.chat-window::-webkit-scrollbar-thumb{background-color:#0000004d;border-radius:4px}.chat-window::-webkit-scrollbar-thumb:hover{background-color:#00000080}.message{display:flex;align-items:flex-start;gap:.75rem;max-width:80%;margin:0}.message.user{align-self:flex-end;flex-direction:row-reverse}.message.model{align-self:flex-start}.message.user+.message.model,.message.model+.message.user{margin-top:.25rem}.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;flex-shrink:0}.avatar.user{background-color:var(--primary-color)}.avatar.model{background-color:var(--secondary-color);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM8.5 12.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm7 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zM12 17.5c-2.33 0-4.31-1.46-5.11-3.5h10.22c-.8 2.04-2.78 3.5-5.11 3.5z'/%3E%3C/svg%3E");background-size:70%;background-position:center;background-repeat:no-repeat}.message-content{padding:.85rem 1rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);word-wrap:break-word;overflow-wrap:break-word;line-height:1.6;text-align:left!important;display:block}.message-content *{text-align:left!important;color:var(--text-color)!important;line-height:1.6!important}.message-image{max-width:100%;max-height:250px;border-radius:8px;object-fit:contain;margin-bottom:8px}.message.user .message-content{background-color:var(--user-message-bg);color:var(--text-color);border-bottom-right-radius:4px}.message.model .message-content{background-color:var(--surface-color);border-bottom-left-radius:4px}.message-content p{margin:.5rem 0}.message-content h1,.message-content h2,.message-content h3,.message-content h4,.message-content h5,.message-content h6{margin:.75rem 0 .5rem}.speak-btn{background-color:transparent;border:none;width:24px;height:24px;background-size:contain;background-repeat:no-repeat;background-position:center;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z'/%3E%3C/svg%3E");cursor:pointer;opacity:.5;transition:opacity .2s;align-self:flex-start;flex-shrink:0;padding:0}.speak-btn:hover{opacity:1}.suggested-prompts{display:flex;flex-wrap:wrap;gap:.5rem;align-self:flex-start;width:min(90%,520px);padding-left:52px;margin-bottom:.5rem}.follow-ups-container{align-self:flex-start;width:min(90%,520px);margin-top:.75rem;display:flex;flex-direction:column;gap:.75rem}.follow-ups-container>.prompt-btn{width:100%;text-align:center;display:inline-flex;align-items:center;justify-content:center}.chat-window-spacer{height:1rem;flex-shrink:0}.prompt-btn{padding:.5rem 1rem;border:1px solid var(--primary-color);background-color:var(--hover-color);color:var(--primary-color);border-radius:20px;font-family:var(--font-family);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.prompt-btn:hover{background-color:var(--primary-color);color:#fff}.message-content pre{background-color:var(--code-bg-color);padding:1rem;border-radius:8px;white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,Courier,monospace;font-size:.9rem;margin:.5rem 0}.message-content code{font-family:Courier New,Courier,monospace;background-color:var(--code-bg-color);padding:.2em .4em;border-radius:4px;font-size:85%}.message-content pre>code{background-color:transparent;padding:0;font-size:inherit}.message-content blockquote{border-left:4px solid var(--border-color);padding-left:1rem;margin-left:0;color:var(--light-text-color);font-style:italic}.message-content ul,.message-content ol{padding-left:1.5rem;margin:.75rem 0}.message-content table{width:100%;border-collapse:collapse;margin:1rem 0}.math-inline{font-size:.95em}.math-block{margin:.75rem 0;overflow-x:auto;padding:.5rem .25rem}.math-block.standalone{text-align:center;padding:.75rem .25rem}.dark-theme .math-block{filter:brightness(1.05)}.message-content th,.message-content td{border:1px solid var(--border-color);padding:8px}.message-content th{background-color:var(--hover-color);font-weight:600}.typing-indicator{display:flex;align-items:center;gap:5px;padding:8px 0}.typing-indicator div{width:8px;height:8px;background-color:var(--light-text-color);border-radius:50%;animation:typing-bounce 1.2s infinite ease-in-out}.typing-indicator div:nth-child(1){animation-delay:-.2s}.typing-indicator div:nth-child(2){animation-delay:-.1s}@keyframes typing-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input-form{display:flex;flex-direction:column;background-color:var(--surface-color);border-top:1px solid var(--border-color);padding-bottom:env(safe-area-inset-bottom);width:100%;box-sizing:border-box;overflow:hidden;flex-shrink:0}.chat-input-wrapper{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem 1.25rem;max-width:800px;margin:0 auto;width:100%;box-sizing:border-box;flex-shrink:0}.chat-input-container{display:flex;align-items:center;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:24px;padding:.5rem;width:100%;box-sizing:border-box;box-shadow:0 2px 8px #0000001a;transition:all .2s ease;min-height:48px;flex-shrink:0}.chat-input-container:focus-within{border-color:var(--primary-color);box-shadow:0 2px 8px #4a90e233}.input-left-controls{display:flex;align-items:center;gap:.5rem;padding-left:.25rem;flex-shrink:0}.input-center{flex:1;padding:0 .75rem;min-width:0}.input-right-controls{display:flex;align-items:center;gap:.5rem;padding-right:.25rem;flex-shrink:0}.chat-input-field{width:100%;border:none;outline:none;background:transparent;font-family:var(--font-family);font-size:1rem;color:var(--text-color);padding:.5rem 0;line-height:1.5}.chat-input-field::placeholder{color:var(--light-text-color)}.attach-btn-rounded,.mic-btn-rounded,.send-btn-rounded{width:40px;height:40px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;font-size:18px;font-weight:700;-webkit-user-select:none!important;user-select:none!important;-webkit-touch-callout:none!important;-webkit-tap-highlight-color:transparent}.attach-btn-rounded,.mic-btn-rounded{background-size:20px 20px;background-position:center;background-repeat:no-repeat}.attach-btn-rounded{background-color:transparent;color:var(--light-text-color)}.attach-btn-rounded:hover:not(:disabled){background-color:var(--hover-color)}.mic-btn-rounded{background-color:transparent;color:var(--light-text-color)}.mic-btn-rounded:hover:not(:disabled){background-color:var(--hover-color)}.mic-btn-rounded.listening{background-color:var(--secondary-color);animation:pulse 1.5s infinite}.send-btn-rounded{background-color:var(--primary-color);color:#fff;transform:scale(0);animation:scale-in .2s ease forwards;font-size:16px}.send-btn-rounded:hover:not(:disabled){background-color:#3a7ac8;transform:scale(1.05)}.send-btn-rounded:disabled{background-color:#a0c3ed;cursor:not-allowed;transform:scale(1)}@keyframes scale-in{0%{transform:scale(0)}to{transform:scale(1)}}.voice-unsupported-rounded{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:var(--hover-color);color:var(--light-text-color);font-size:16px;opacity:.6}.voice-wave-container{margin-top:.75rem;display:flex;justify-content:center}.voice-wave-rounded{display:flex;align-items:flex-end;gap:3px;height:24px;padding:0 8px;background-color:var(--secondary-color);border-radius:12px}.voice-wave-rounded .bar{width:3px;background:#fff;border-radius:2px;animation:wave 1s ease-in-out infinite;height:6px}.voice-wave-rounded .bar:nth-child(2){animation-delay:.1s}.voice-wave-rounded .bar:nth-child(3){animation-delay:.2s}.voice-wave-rounded .bar:nth-child(4){animation-delay:.3s}.voice-wave-rounded .bar:nth-child(5){animation-delay:.4s}@keyframes wave{0%,to{height:6px}50%{height:18px}}.chat-input-controls{display:flex;gap:.75rem;padding:1rem 1.5rem 1.25rem;width:100%;box-sizing:border-box;align-items:center}.chat-input-form input[type=text]{flex-grow:1;padding:.75rem 1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1rem}.chat-input-form input[type=text]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a90e233}.chat-input-form button{padding:.75rem 1.5rem;border:none;background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);font-family:var(--font-family);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;flex-shrink:0}.chat-input-form .attach-btn,.chat-input-form .mic-btn{padding:.75rem;width:auto;min-width:48px;background-color:var(--hover-color);background-size:24px 24px;background-position:center;background-repeat:no-repeat}.no-select,.mic-btn.listening,.mic-btn-rounded.listening,.chat-input-controls:has(.mic-btn.listening),.chat-input-wrapper:has(.mic-btn-rounded.listening){-webkit-user-select:none!important;user-select:none!important;-webkit-touch-callout:none}.voice-wave{display:flex;align-items:flex-end;gap:2px;height:28px;padding:0 4px}.voice-wave .bar{width:4px;background:var(--secondary-color);border-radius:2px;animation:wave 1s ease-in-out infinite;height:6px}.voice-wave .bar:nth-child(2){animation-delay:.1s}.voice-wave .bar:nth-child(3){animation-delay:.2s}.voice-wave .bar:nth-child(4){animation-delay:.3s}.voice-wave .bar:nth-child(5){animation-delay:.4s}@keyframes wave{0%,to{height:6px}50%{height:24px}}.voice-unsupported{display:flex;align-items:center;font-size:.7rem;padding:0 .4rem;background:var(--hover-color);border-radius:6px;color:var(--light-text-color)}.voice-support-hint{font-size:.7rem;color:var(--light-text-color);padding:.25rem .75rem .5rem}.android-mic-tip{margin:.25rem auto .5rem;padding:.5rem .75rem;background:var(--hover-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:8px;font-size:.85rem;line-height:1.3;display:flex;align-items:center;justify-content:space-between;gap:.5rem;cursor:pointer;max-width:800px;width:calc(100% - 3rem);box-sizing:border-box}.android-mic-tip .close{opacity:.6}.android-mic-tip:hover .close{opacity:1}.voice-support-hint{font-size:.7rem;color:var(--light-text-color);padding:.25rem .75rem .5rem;text-align:center;max-width:800px;margin:0 auto}body.voice-blocking{overscroll-behavior:contain;touch-action:none;-webkit-user-select:none!important;user-select:none!important;-webkit-touch-callout:none!important}.chat-input-form .attach-btn:hover:not(:disabled),.chat-input-form .mic-btn:hover:not(:disabled){background-color:var(--border-color)}.chat-input-form .mic-btn.listening{background-color:var(--secondary-color);animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #50e3c2b3}70%{box-shadow:0 0 0 10px #50e3c200}to{box-shadow:0 0 #50e3c200}}.chat-input-form button:hover:not(:disabled){background-color:#3a7ac8}.chat-input-form button:disabled{background-color:#a0c3ed;cursor:not-allowed}.chat-input-form .attach-btn:disabled,.chat-input-form .mic-btn:disabled{background-color:var(--hover-color);opacity:.5}.image-preview-container{padding:.75rem 1.5rem 0;display:flex;align-items:flex-start;gap:.75rem;max-width:800px;margin:0 auto;width:100%;box-sizing:border-box}.image-preview{height:60px;width:auto;border-radius:var(--border-radius);border:1px solid var(--border-color);object-fit:cover}.remove-image-btn{width:24px;height:24px;border-radius:50%;border:none;background-color:#00000080;color:#fff;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.remove-image-btn:hover{background-color:#000000b3}@media (max-width: 600px){.chat-input-wrapper{padding:.75rem 1rem 1rem}.chat-input-container{border-radius:20px;padding:.4rem}.input-center{padding:0 .5rem}.chat-input-field{font-size:.95rem;padding:.4rem 0}.attach-btn-rounded,.mic-btn-rounded,.send-btn-rounded{width:36px;height:36px}.attach-btn-rounded,.mic-btn-rounded{background-size:18px 18px}.send-btn-rounded{font-size:14px}.voice-unsupported-rounded{width:36px;height:36px;font-size:14px}.voice-wave-container{margin-top:.5rem}.voice-wave-rounded{height:20px;padding:0 6px;border-radius:10px}.voice-wave-rounded .bar{width:2px;height:4px}@keyframes wave{0%,to{height:4px}50%{height:14px}}.image-preview-container{padding:.5rem 1rem 0}.android-mic-tip{margin:.25rem 1rem .5rem;width:calc(100% - 2rem)}.voice-support-hint{padding:.25rem 1rem .5rem}.message{max-width:95%}.suggested-prompts{width:100%;padding-left:0}.follow-ups-container{width:100%;gap:.6rem}.chat-window{padding:1rem .75rem;scroll-padding-bottom:1rem;max-height:100%;overscroll-behavior:contain}}@media (max-width: 480px){.chat-window{padding:.75rem 1rem 3rem;scroll-padding-bottom:3rem}.chat-input-wrapper{padding:.5rem .75rem .75rem;position:relative;z-index:10}.chat-input-container{border-radius:18px;padding:.35rem;min-height:42px}.input-center{padding:0 .4rem}.chat-input-field{font-size:.9rem;padding:.35rem 0}.attach-btn-rounded,.mic-btn-rounded,.send-btn-rounded{width:34px;height:34px;flex-shrink:0}.attach-btn-rounded,.mic-btn-rounded{background-size:16px 16px}.send-btn-rounded{font-size:13px}.voice-unsupported-rounded{width:34px;height:34px;font-size:13px}.image-preview-container{padding:.5rem .75rem 0}.android-mic-tip{margin:.25rem .75rem .5rem;width:calc(100% - 1.5rem)}.voice-support-hint{padding:.25rem .75rem .5rem}.follow-ups-container{width:100%;gap:.5rem}.follow-ups-container>.prompt-btn{font-size:.9rem;padding:.6rem .85rem}}@supports not (gap: 1rem){.chat-window .message{margin:.75rem 0}}@media (min-width: 601px) and (max-width: 1024px){.chat-window{padding:1rem 1.25rem;scroll-padding-bottom:1rem;max-height:100%;overscroll-behavior:contain}.message{max-width:85%}}.image-options-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.image-options-modal{background-color:var(--surface-color);border-radius:var(--border-radius);padding:1.5rem;box-shadow:0 10px 30px #0003;width:90%;max-width:320px;animation:slide-up .3s ease-out}.image-options-modal h3{margin:0 0 1rem;text-align:center;color:var(--text-color);font-size:1.1rem}.image-option-btn{width:100%;padding:.75rem 1rem;margin:.5rem 0;border:none;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.image-option-btn.camera-btn{background-color:var(--primary-color);color:#fff}.image-option-btn.camera-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.image-option-btn.gallery-btn{background-color:var(--secondary-color, #6c757d);color:#fff}.image-option-btn.gallery-btn:hover{background-color:var(--secondary-hover, #5a6268);transform:translateY(-1px)}.image-option-btn.cancel-btn{background-color:transparent;color:var(--text-muted);border:1px solid var(--border-color)}.image-option-btn.cancel-btn:hover{background-color:var(--danger-color);color:#fff;border-color:var(--danger-color)}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.image-options-modal{width:95%;padding:1rem}.image-option-btn{padding:1rem;font-size:1.1rem}}.follow-up-container{background-color:var(--model-message-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1.1rem 1.5rem 1.25rem;margin-top:1.1rem;align-self:stretch;width:100%;animation:slide-down .4s ease-out;text-align:left;box-sizing:border-box}.follow-up-title{font-size:1.1rem;font-weight:600;color:var(--text-color);margin-bottom:1rem}.question-block{margin-bottom:1.25rem}.question-block:last-child{margin-bottom:0}.question-text{font-weight:500;margin-bottom:.75rem;color:var(--text-color)}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.option-btn{width:100%;padding:.65rem 1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--surface-color);color:var(--text-color);cursor:pointer;text-align:left;font-family:var(--font-family);font-size:.95rem;transition:all .2s ease;line-height:1.4;white-space:normal}.option-btn:not(:disabled):hover{background-color:var(--hover-color);border-color:var(--primary-color);color:var(--primary-color)}.option-btn:disabled{cursor:not-allowed;opacity:.9}.option-btn.correct{background-color:#d4edda;border-color:#c3e6cb;color:#155724;font-weight:600}.option-btn.incorrect{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24;font-weight:600}.feedback-text{margin-top:.5rem;font-size:.9rem;padding:.75rem 1rem;border-radius:6px;line-height:1.5;white-space:pre-line}.feedback-text.correct{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.feedback-text.incorrect{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 768px){.follow-up-container{padding:1rem 1.25rem 1.1rem}.options-grid{gap:.6rem}}@media (max-width: 600px){.follow-up-container{padding:.9rem 1rem 1rem;margin-top:.9rem}.options-grid{grid-template-columns:1fr}}@media (max-width: 480px){.follow-up-title{font-size:1rem}.question-text{font-size:.95rem}.option-btn{font-size:.9rem;padding:.6rem .85rem}.options-grid{gap:.5rem}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media (pointer: coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.image-crop-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .2s ease-out}.image-crop-modal{background:var(--card-bg);border-radius:20px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0009,0 0 0 1px #ffffff0d;overflow:hidden;animation:slideUp .3s cubic-bezier(.4,0,.2,1);transform-origin:center}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.image-crop-header{padding:2rem 1.5rem 1.5rem;border-bottom:1px solid var(--border-color);text-align:center;background:linear-gradient(to bottom,var(--card-bg),transparent)}.image-crop-header h3{margin:0 0 .75rem;color:var(--text-color);font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.image-crop-header p{margin:0;color:var(--text-secondary);font-size:.9rem;opacity:.9}.image-crop-container{position:relative;width:100%;height:400px;background:#000;flex-shrink:0}.image-crop-container-new{position:relative;width:100%;max-height:500px;background:#000;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:auto;padding:1.5rem;box-shadow:inset 0 0 20px #00000080}.image-crop-container-new .ReactCrop{max-width:100%;max-height:100%}.image-crop-container-new img{display:block;max-width:100%;height:auto}@media (max-width: 768px){.image-crop-container{height:300px}.image-crop-container-new{max-height:400px;padding:.5rem}}.image-crop-controls{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:1.5rem}.zoom-control{display:flex;flex-direction:column;gap:.5rem}.zoom-control label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.crop-size-controls{display:flex;gap:1rem;flex-wrap:wrap}.crop-dimension{flex:1;min-width:150px;display:flex;flex-direction:column;gap:.5rem}.crop-dimension label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.crop-dimension span{color:var(--text-color);font-size:.85rem;font-weight:600;text-align:center}.zoom-control input[type=range]{width:100%;height:6px;border-radius:3px;background:var(--input-bg);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.zoom-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent-color);cursor:pointer;box-shadow:0 2px 4px #0003}.zoom-control input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent-color);cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.zoom-control input[type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 0 4px rgba(var(--accent-color-rgb),.2)}.zoom-control input[type=range]:focus::-moz-range-thumb{box-shadow:0 0 0 4px rgba(var(--accent-color-rgb),.2)}.image-crop-actions{padding:1.5rem;display:flex;gap:1rem;justify-content:flex-end;background:linear-gradient(to top,var(--card-bg),transparent)}.image-crop-actions button{padding:.875rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);border:none;min-width:130px;position:relative;overflow:hidden}.image-crop-actions button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff1a;transform:translate(-50%,-50%);transition:width .4s,height .4s}.image-crop-actions button:hover:before{width:300px;height:300px}.image-crop-actions .btn-cancel{background:var(--input-bg);color:var(--text-color);border:2px solid transparent}.image-crop-actions .btn-cancel:hover:not(:disabled){background:var(--border-color);border-color:var(--border-color);transform:translateY(-1px)}.image-crop-actions .btn-crop{background:linear-gradient(135deg,var(--accent-color),#6366f1);color:#fff;box-shadow:0 4px 12px #6366f14d}.image-crop-actions .btn-crop:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6366f166}.image-crop-actions .btn-crop:active:not(:disabled){transform:translateY(0)}.image-crop-actions button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.image-crop-tips{padding:1rem 1.5rem;background:linear-gradient(to top,rgba(99,102,241,.05),transparent);border-top:1px solid var(--border-color)}.image-crop-tips p{margin:0;color:var(--text-secondary);font-size:.85rem;text-align:center;line-height:1.5}.image-loading-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 8px 24px #6366f166,0 0 0 1px #ffffff1a;z-index:10001;display:flex;align-items:center;gap:.75rem;font-size:.95rem;font-weight:500;animation:toastSlideIn .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.image-loading-toast-exit{animation:toastSlideOut .2s ease-in forwards}@keyframes toastSlideOut{to{opacity:0;transform:translate(-50%) translateY(-20px)}}.image-loading-toast .toast-icon{font-size:1.25rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.image-loading-toast .toast-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}body.dark-mode .image-crop-modal{background:#1a1a1a;box-shadow:0 20px 60px #000000e6,0 0 0 1px #ffffff14}body.dark-mode .image-crop-header,body.dark-mode .image-crop-controls,body.dark-mode .image-crop-tips{border-color:#333}body.dark-mode .zoom-control input[type=range]{background:#333}body.dark-mode .image-crop-actions .btn-cancel{background:#2a2a2a;border-color:#333}body.dark-mode .image-crop-actions .btn-cancel:hover:not(:disabled){background:#333;border-color:#444}@media (max-width: 768px){.image-crop-modal{max-width:100%;max-height:100vh;border-radius:0}.image-crop-header{padding:1.5rem 1rem 1rem}.image-crop-header h3{font-size:1.25rem}.image-crop-container-new{max-height:400px;padding:1rem}.image-crop-controls{padding:1rem}.image-crop-actions{padding:1rem;flex-direction:column-reverse}.image-crop-actions button{width:100%;min-width:0;padding:1rem}.image-crop-tips{padding:.875rem 1rem}.image-loading-toast{top:10px;left:10px;right:10px;transform:none;padding:.875rem 1rem;font-size:.9rem}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideOut{to{opacity:0;transform:translateY(-20px)}}}.image-crop-actions button:disabled{position:relative}.image-crop-actions button:disabled:after{content:"";position:absolute;width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite;margin-left:8px}@keyframes spin{to{transform:rotate(360deg)}}.reactEasyCrop_Container{background:#000}.reactEasyCrop_CropArea{border:2px solid var(--accent-color);box-shadow:0 0 0 9999px #00000080}.reactEasyCrop_CropAreaGrid:before,.reactEasyCrop_CropAreaGrid:after{border-color:#ffffff4d}.chat-history-sidebar{width:260px;background-color:var(--subtle-bg-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:1rem}.sidebar-header h2{font-size:1.25rem;margin:0}.new-chat-btn{width:100%;padding:.75rem;border:none;border-radius:var(--border-radius);background-color:var(--primary-color);color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.new-chat-btn:hover{background-color:#3a7ac8}.chat-sessions-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex-grow:1;padding:.75rem}.session-btn{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.75rem 1rem;border-radius:8px;border:none;background-color:transparent;text-align:left;cursor:pointer;color:var(--text-color);transition:background-color .2s}.session-btn:hover{background-color:var(--hover-color)}.session-btn.active{background-color:var(--user-message-bg)}.session-title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.session-timestamp{font-size:.8rem;color:var(--light-text-color)}.session-info{font-size:.75rem;color:var(--primary-color);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.no-history-item{padding:1.5rem;text-align:center;color:var(--light-text-color);font-size:.9rem}.sidebar-actions{display:flex;gap:.5rem}.bulk-toggle-btn{padding:.55rem .75rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background:var(--hover-color);cursor:pointer;font-size:.8rem;font-weight:500}.bulk-toggle-btn.active{background:#d9534f;color:#fff;border-color:#d9534f}.bulk-toggle-btn.icon-only{width:40px;padding:.55rem;display:flex;align-items:center;justify-content:center}.bulk-toggle-btn .icon-img{width:18px;height:18px;display:inline-block;object-fit:contain}.bulk-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--border-color);background:var(--hover-color);font-size:.85rem;gap:.75rem}.bulk-buttons{display:flex;gap:.4rem}.bulk-bar button{padding:.35rem .6rem;font-size:.75rem;border-radius:6px;border:1px solid var(--border-color);background:var(--subtle-bg-color);cursor:pointer}.bulk-bar button:disabled{opacity:.4;cursor:not-allowed}.bulk-bar .danger-btn{background:#e53935;color:#fff;border-color:#e53935}.bulk-bar .danger-btn:hover:not(:disabled){background:#c62828}.bulk-bar .clear-btn{background:#777;color:#fff;border-color:#777}.bulk-bar .clear-btn:hover{background:#555}.session-btn.selected{outline:2px solid var(--primary-color)}.session-btn .checkbox{width:16px;height:16px;border:2px solid var(--primary-color);display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;margin-right:6px;border-radius:4px;flex-shrink:0;background:#fff}.session-btn.selected .checkbox{background:var(--primary-color);color:#fff}.chat-screen-layout{display:flex;height:100%;width:100%;background-color:var(--background-color);overflow:hidden;position:relative}.chat-content-area{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;height:100%;max-height:100%}@media (max-width: 768px){.chat-history-sidebar{display:none}.chat-screen-layout{height:100%}}@media (max-width: 480px){.chat-screen-layout{height:100%}}.enhanced-setup{max-width:700px;margin:0 auto}.enhanced-form{display:flex;flex-direction:column;gap:1.5rem}.form-label{font-size:.95rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.form-group.half{margin:0}.form-select{padding:.75rem;border:2px solid var(--surface-color);border-radius:8px;background:var(--background-color);color:var(--text-color);font-size:1rem;cursor:pointer;transition:all .3s ease}.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.advanced-toggle{background:var(--surface-color);color:var(--text-color);border:none;padding:.875rem 1rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:left;margin-top:.5rem}.advanced-toggle:hover{background:var(--primary-color);color:#fff;transform:translateY(-1px)}.advanced-options{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;background:#6366f10d;border-radius:12px;border:1px dashed var(--primary-color);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.difficulty-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.5rem}.difficulty-btn{padding:.625rem .75rem;border:2px solid var(--surface-color);background:var(--background-color);color:var(--text-color);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-transform:capitalize}.difficulty-btn:hover{border-color:var(--primary-color);transform:translateY(-2px)}.difficulty-btn.selected{background:linear-gradient(135deg,var(--primary-color),#7c3aed);color:#fff;border-color:var(--primary-color);box-shadow:0 4px 12px #6366f14d}.hours-slider{width:100%;height:6px;border-radius:3px;background:var(--surface-color);outline:none;transition:opacity .2s;cursor:pointer}.hours-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;box-shadow:0 2px 6px #6366f166;transition:all .2s ease}.hours-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 10px #6366f199}.hours-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none;box-shadow:0 2px 6px #6366f166;transition:all .2s ease}.hours-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 10px #6366f199}.slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-color);opacity:.6;margin-top:.25rem}.learning-style-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem}.style-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.875rem .5rem;border:2px solid var(--surface-color);background:var(--background-color);border-radius:10px;cursor:pointer;transition:all .3s ease}.style-btn:hover{border-color:var(--primary-color);transform:translateY(-3px);box-shadow:0 4px 12px #6366f133}.style-btn.selected{background:linear-gradient(135deg,var(--primary-color),#7c3aed);color:#fff;border-color:var(--primary-color);box-shadow:0 6px 16px #6366f14d}.style-icon{font-size:1.75rem}.style-label{font-size:.8rem;font-weight:500}.style-btn.selected .style-label{color:#fff}.goals-textarea{padding:.875rem;border:2px solid var(--surface-color);border-radius:8px;background:var(--background-color);color:var(--text-color);font-size:.95rem;font-family:inherit;resize:vertical;transition:all .3s ease}.goals-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.goals-textarea::placeholder{color:var(--text-color);opacity:.5}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.95rem;color:var(--text-color);padding:0;margin:0}.checkbox-label span{display:flex;align-items:center;gap:.5rem}.reminder-checkbox{width:20px;height:20px;min-width:20px;cursor:pointer;accent-color:var(--primary-color);flex-shrink:0;margin:0}@media (max-width: 640px){.form-row{grid-template-columns:1fr}.learning-style-selector,.difficulty-selector{grid-template-columns:repeat(2,1fr)}.enhanced-setup,.advanced-options{padding:1rem}}@media (prefers-color-scheme: dark){.advanced-options{background:#6366f11a}.form-select option{background:var(--background-color);color:var(--text-color)}}.exam-type-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.75rem}.exam-type-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.875rem .5rem;border:2px solid var(--border-color);background:var(--surface-color);border-radius:10px;cursor:pointer;transition:all .3s ease;color:var(--text-color)}.exam-type-btn:hover{border-color:var(--primary-color);transform:translateY(-3px);box-shadow:0 4px 12px #6366f133;background:var(--hover-color)}.exam-type-btn.selected{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#f59e0b;box-shadow:0 6px 16px #f59e0b4d}.exam-icon{font-size:1.75rem}.exam-label{font-size:.8rem;font-weight:500;color:inherit}.exam-type-btn.selected .exam-label{color:#fff;font-weight:600}.frequency-selector{display:flex;flex-wrap:nowrap;gap:.5rem;justify-content:space-between}.frequency-btn{flex:1;padding:.625rem .5rem;border:2px solid var(--surface-color);background:var(--background-color);color:var(--text-color);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.frequency-btn:hover{border-color:var(--primary-color);transform:translateY(-2px)}.frequency-btn.selected{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981;box-shadow:0 4px 12px #10b9814d}.test-prep-advanced{border-color:#f59e0b;background:#f59e0b0d}.test-prep-advanced .form-group{align-items:flex-start;text-align:left}.test-prep-advanced .form-group:has(.checkbox-label){display:inline-flex;width:auto;margin-right:1.5rem;vertical-align:top}.test-prep-advanced .checkbox-label{display:inline-flex;align-items:center;justify-content:flex-start;gap:.5rem;padding:0;margin:0;background:transparent;border:0;width:auto}.test-prep-advanced .checkbox-label span{white-space:normal}.helper-text{font-size:.8rem;opacity:.7;color:var(--text-color);margin-top:.25rem}.writing-container{padding:2rem}.writing-card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:4.5rem 2rem 2rem;width:100%;max-width:1200px;margin:0 auto;position:relative}.writing-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-align:center}.writing-subtitle{font-size:1.1rem;color:var(--light-text-color);margin-bottom:2rem;text-align:center}.writing-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.feedback-content{overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.feedback-section h3{font-size:1.1rem;font-weight:600;color:var(--primary-color);margin-bottom:.5rem}.feedback-section p,.feedback-section li{line-height:1.6}.feedback-section ul{padding-left:1.5rem}@media (max-width: 900px){.writing-grid{grid-template-columns:1fr}}.learning-zone-container{display:flex;justify-content:center;align-items:center;padding:2rem;min-height:100vh}.learning-zone-card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:2.5rem;width:100%;max-width:900px;position:relative;text-align:center}.learning-zone-card .back-btn.top-left+.learning-zone-header.with-offset{margin-top:.75rem}@media (min-width: 769px){.learning-zone-card{padding-top:4rem}}.learning-zone-header h1{font-size:2.2rem;font-weight:700;margin-bottom:.5rem}.learning-zone-header p{font-size:1.1rem;color:var(--light-text-color);margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.tool-card{background-color:var(--subtle-bg-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:2rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;transition:all .2s ease-in-out;cursor:pointer}.tool-card:hover:not(:disabled){transform:translateY(-5px);box-shadow:0 8px 25px #0000001a;border-color:var(--primary-color)}.tool-card:disabled{opacity:.6;cursor:not-allowed}.tool-card.coming-soon{opacity:.7;position:relative}.tool-card.coming-soon:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffff1a;border-radius:var(--border-radius);pointer-events:none}.tool-card h2{font-size:1.25rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.tool-card h2 .badge{font-size:.75rem;font-weight:600;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a1a;padding:.25rem .75rem;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.tool-icon{width:48px;height:48px;margin-bottom:.5rem;filter:invert(55%) sepia(52%) saturate(1542%) hue-rotate(185deg) brightness(90%) contrast(90%)}.tool-card p{font-size:.95rem;color:var(--light-text-color);line-height:1.5}.learning-zone-card .subscribe-prompt{margin-top:2rem}@media (max-width: 768px){.learning-zone-container{padding:1rem;align-items:flex-start}.learning-zone-card{padding:4rem 1.5rem 1.5rem}.learning-zone-header{margin-bottom:2rem}.learning-zone-header h1{font-size:1.8rem}.learning-zone-header p{font-size:1rem;margin-bottom:2rem}}.concept-container{display:flex;justify-content:center;align-items:flex-start;padding:2rem;min-height:100vh}.concept-card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:4.5rem 2.5rem 2.5rem;width:100%;max-width:800px;position:relative}.concept-header{text-align:center;margin-bottom:2rem}.concept-header h1{font-size:2rem;font-weight:700}.concept-header p{font-size:1.1rem;color:var(--light-text-color);margin-top:.5rem}.concept-input-area input{width:100%;padding:1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1.1rem;margin-bottom:1.5rem}.explanation-controls{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}.explanation-controls button{padding:.8rem 1.5rem;border:1px solid var(--primary-color);background-color:var(--hover-color);color:var(--primary-color);border-radius:20px;font-family:var(--font-family);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.explanation-controls button:hover:not(:disabled){background-color:var(--primary-color);color:#fff}.explanation-controls button:disabled{opacity:.6;cursor:not-allowed}.explanation-controls button.loading{background-color:var(--primary-color);color:#fff;cursor:wait}.explanation-result{background-color:var(--subtle-bg-color);border-radius:var(--border-radius);padding:2rem;min-height:200px;border:1px solid var(--border-color);display:flex;justify-content:center;align-items:center}.auth-container{display:flex;justify-content:center;align-items:flex-start;min-height:100dvh;height:auto;width:100vw;background:linear-gradient(135deg,#e0f7fa,#d1c4e9);padding:max(1.25rem,env(safe-area-inset-top)) 1rem max(1rem,env(safe-area-inset-bottom));overflow-y:auto;box-sizing:border-box}@media (min-height: 750px){.auth-container{align-items:center;padding:1rem}}.auth-box{position:relative;background-color:var(--surface-color);padding:5rem 2rem 2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);text-align:center;max-width:400px;width:100%;animation:slide-down .5s ease-out}.auth-header{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:.5rem}.auth-header.single{justify-content:center}.back-btn{background:none;border:none;font-size:.95rem;font-weight:500;color:var(--light-text-color);cursor:pointer;padding:.4rem .6rem;border-radius:6px;transition:background .15s ease,color .15s ease}.back-btn.top-left{position:absolute;top:.75rem;left:.75rem;font-size:.9rem;background:#ffffff8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 1px 2px #00000014}.back-btn.top-left:hover{background:#fffc;color:var(--primary-color)}.back-btn:hover{color:var(--primary-color)}.auth-title{font-size:2rem;font-weight:700;margin-bottom:0;color:var(--text-color)}.auth-subtitle{font-size:1.1rem;color:var(--light-text-color);margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem;text-align:left}.auth-form .form-group{display:flex;flex-direction:column;gap:.5rem}.auth-form label{font-weight:500}.auth-form input,.auth-form select{padding:.75rem 1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1rem;width:100%;box-sizing:border-box}.auth-form input:focus,.auth-form select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a90e233}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{padding-right:3rem}.password-toggle-btn{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;color:var(--light-text-color);padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.password-toggle-btn:hover{color:var(--text-color)}.password-toggle-btn:focus{outline:none;color:var(--primary-color)}.password-toggle-btn svg{width:20px;height:20px}@media (max-width: 480px){.password-input-container input{padding-right:2.75rem}.password-toggle-btn{right:.5rem;padding:.5rem}.password-toggle-btn svg{width:18px;height:18px}}.forgot-password-link{background:none;border:none;color:var(--primary-color);font-size:.9rem;cursor:pointer;text-align:right;margin-top:.5rem;padding:.25rem}.auth-btn{padding:.8rem 1.5rem;border:none;border-radius:var(--border-radius);font-family:var(--font-family);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease;background-color:var(--primary-color);color:#fff;margin-top:.5rem}.auth-btn:disabled{background-color:#a0c3ed;cursor:not-allowed}.auth-btn-secondary{padding:.8rem 1.5rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-family:var(--font-family);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;background-color:var(--hover-color);color:var(--text-color);margin-top:.5rem}.auth-btn-secondary:hover{background-color:var(--border-color)}.auth-footer-text{margin-top:1.5rem;color:var(--light-text-color)}.auth-footer-text button{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:0;font-size:inherit;font-family:inherit}.error-message{color:var(--danger-color);margin:-.75rem 0;font-size:.9rem;text-align:center}.message{color:var(--secondary-color);font-weight:500;margin:-.75rem 0;font-size:.9rem;text-align:center}.terms-agreement{margin-top:.5rem}.terms-agreement label{display:flex;align-items:flex-start;gap:.5rem;font-weight:400;font-size:.9rem;line-height:1.4;color:var(--text-color)}.terms-agreement input[type=checkbox]{margin-top:.2rem;flex-shrink:0;width:auto;cursor:pointer}.terms-agreement-text{color:var(--text-color)}.terms-link,.privacy-link{color:var(--accent-color);text-decoration:underline;background:none;border:none;padding:0;cursor:pointer;font-family:inherit;font-size:inherit;font-weight:500;transition:color .2s ease}.terms-link:hover,.privacy-link:hover{color:var(--primary-color)}@media (max-width: 400px){.auth-box{padding:3.75rem 1rem 1.5rem}.auth-title{font-size:1.6rem;line-height:1.2}.auth-subtitle{font-size:.95rem;margin-bottom:1.25rem}.auth-form{gap:1rem}.auth-btn{width:100%;min-height:44px}.terms-agreement label,.terms-link,.privacy-link{font-size:.85rem}}@media (max-width: 340px){.auth-box{padding:3.25rem .75rem 1.25rem}.auth-title{font-size:1.5rem}.terms-agreement label{font-size:.8rem;gap:.375rem}}.free-trial-banner{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:1.5rem;margin-bottom:2rem;color:#fff;box-shadow:0 8px 24px #667eea4d;position:relative;overflow:hidden}.free-trial-banner:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:shimmer 3s infinite}@keyframes shimmer{0%,to{transform:translate(0)}50%{transform:translate(-30px,-30px)}}.trial-badge{display:inline-flex;align-items:center;gap:.4rem;background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.4rem .9rem;border-radius:20px;font-size:.75rem;font-weight:700;letter-spacing:.5px;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.3)}.trial-badge svg{animation:sparkle 2s infinite}@keyframes sparkle{0%,to{transform:rotate(0) scale(1);opacity:1}50%{transform:rotate(180deg) scale(1.2);opacity:.8}}.trial-title{font-size:1.35rem;font-weight:700;margin:0 0 .5rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.1)}.trial-description{font-size:.9rem;margin:0 0 1rem;color:#fffffff2;line-height:1.5}.trial-features{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem}.trial-feature{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:#fffffff2}.trial-feature svg{flex-shrink:0;stroke:#4ade80;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}@media (max-width: 480px){.free-trial-banner{padding:1.25rem;margin-bottom:1.5rem}.trial-title{font-size:1.15rem}.trial-description{font-size:.85rem}.trial-feature{font-size:.8rem}}@media (max-width: 340px){.free-trial-banner{padding:1rem}.trial-title{font-size:1.05rem}.trial-badge{font-size:.7rem;padding:.35rem .75rem}}.tib-container{padding:2rem}.tib-card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:4.5rem 2rem 2rem;width:100%;max-width:1200px;margin:0 auto;position:relative}.tib-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-align:center}.tib-subtitle{font-size:1.1rem;color:var(--light-text-color);margin-bottom:2rem;text-align:center}.tib-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.editor-panel,.feedback-panel{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-weight:600;color:var(--text-color)}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1rem}.form-group textarea{resize:vertical}.submit-btn{padding:1rem 1.5rem;border:none;background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);font-family:var(--font-family);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.submit-btn:hover:not(:disabled){background-color:#3a7ac8}.submit-btn:disabled{background-color:#a0c3ed;cursor:not-allowed}.feedback-panel{background-color:var(--subtle-bg-color);border-radius:var(--border-radius);padding:1.5rem;border:1px solid var(--border-color)}.feedback-panel-title{font-size:1.5rem;font-weight:600;margin-bottom:0;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.empty-feedback{color:var(--light-text-color);text-align:center;margin:auto 0}.feedback-content{overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem;line-height:1.7}@media (max-width: 900px){.tib-grid{grid-template-columns:1fr}}.rws-container{display:flex;justify-content:center;align-items:flex-start;padding:2rem;min-height:100vh}.rws-card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:4.5rem 2.5rem 2.5rem;width:100%;max-width:800px;position:relative}.rws-header{text-align:center;margin-bottom:2rem}.rws-header h1{font-size:2rem;font-weight:700}.rws-header p{font-size:1.1rem;color:var(--light-text-color);margin-top:.5rem}.rws-input-area{display:flex;gap:1rem;margin-bottom:2rem}.rws-input-area input{flex-grow:1;padding:1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1.1rem}.rws-input-area button{padding:1rem 1.5rem;border:none;background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);font-family:var(--font-family);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.rws-input-area button:hover:not(:disabled){background-color:#3a7ac8}.rws-input-area button:disabled{background-color:#a0c3ed;cursor:not-allowed}.rws-result{background-color:var(--subtle-bg-color);border-radius:var(--border-radius);padding:2rem;min-height:200px;border:1px solid var(--border-color);display:flex;justify-content:center;align-items:center}.placeholder-text{color:var(--light-text-color);font-style:italic}.result-content{width:100%;text-align:left;line-height:1.7}.result-content p,.result-content ul,.result-content ol{margin-bottom:1rem}@media (max-width: 600px){.rws-input-area{flex-direction:column}}.timeline-page-container{display:flex;justify-content:center;align-items:flex-start;padding:2rem;min-height:100vh}.timeline-card{background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:4.5rem 2.5rem 2.5rem;width:100%;max-width:800px;position:relative}.timeline-header{text-align:center;margin-bottom:2rem}.timeline-header h1{font-size:2rem;font-weight:700}.timeline-header p{font-size:1.1rem;color:var(--light-text-color);margin-top:.5rem}.timeline-input-area{display:flex;gap:1rem;margin-bottom:2rem}.timeline-input-area input{flex-grow:1;padding:1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1.1rem}.timeline-input-area button{padding:1rem 1.5rem;border:none;background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);font-family:var(--font-family);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.timeline-input-area button:hover:not(:disabled){background-color:#3a7ac8}.timeline-input-area button:disabled{background-color:#a0c3ed;cursor:not-allowed}.timeline-result-area{min-height:200px;display:flex;justify-content:center;align-items:center;padding-top:1rem}.placeholder-text{color:var(--light-text-color);font-style:italic;text-align:center}.timeline-container{position:relative;width:100%;padding:1rem 0;margin-top:1rem}.timeline-container h2{text-align:center;margin-bottom:2rem;font-size:1.5rem}.timeline-container:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:3px;height:100%;background-color:var(--border-color)}.timeline-item{padding:10px 40px;position:relative;width:50%}.timeline-item:nth-child(odd){left:0;text-align:right}.timeline-item:nth-child(2n){left:50%;text-align:left}.timeline-dot{content:"";position:absolute;width:15px;height:15px;border-radius:50%;background-color:var(--surface-color);border:3px solid var(--primary-color);top:25px;z-index:1}.timeline-item:nth-child(odd) .timeline-dot{right:-7.5px}.timeline-item:nth-child(2n) .timeline-dot{left:-7.5px}.timeline-content{padding:1rem;background-color:var(--subtle-bg-color);border-radius:var(--border-radius);position:relative}.timeline-year{font-size:1.2rem;font-weight:700;color:var(--primary-color);margin-bottom:.5rem;display:inline-block}.timeline-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.timeline-description{font-size:.95rem;color:var(--light-text-color);line-height:1.5}@media (max-width: 768px){.timeline-container:before{left:20px}.timeline-item{width:100%;padding-left:50px;padding-right:15px}.timeline-item:nth-child(odd),.timeline-item:nth-child(2n){left:0;text-align:left}.timeline-item:nth-child(odd) .timeline-dot,.timeline-item:nth-child(2n) .timeline-dot{left:12.5px}}@media (max-width: 600px){.timeline-input-area{flex-direction:column}}.admin-container{display:flex;justify-content:center;align-items:flex-start;min-height:100vh;width:100vw;background:linear-gradient(135deg,#3a3a3a,#1c1c1c);padding:2rem 1rem;overflow-y:auto;box-sizing:border-box}.admin-box{position:relative;background-color:var(--surface-color);padding:2.5rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);text-align:center;max-width:450px;width:100%;animation:slide-down .5s ease-out}.admin-box.wide{max-width:700px}.admin-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:var(--text-color)}.admin-subtitle{font-size:1.1rem;color:var(--light-text-color);margin-bottom:2rem}.admin-form{display:flex;flex-direction:column;gap:1.25rem;text-align:left}.admin-form .form-row{display:flex;gap:1rem}.admin-form .form-row .form-group{flex:1}.admin-form .form-group{display:flex;flex-direction:column;gap:.5rem}.admin-form label{font-weight:500}.admin-form input,.admin-form select{padding:.75rem 1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--background-color);color:var(--text-color);font-family:var(--font-family);font-size:1rem}.admin-form input:focus,.admin-form select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a90e233}.admin-btn{padding:.8rem 1.5rem;border:none;border-radius:var(--border-radius);font-family:var(--font-family);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease;background-color:var(--secondary-color);color:#121212;margin-top:.5rem}.admin-btn:disabled{background-color:#a0c3ed;cursor:not-allowed}.error-message{color:var(--danger-color);margin-top:-.75rem;font-size:.9rem;text-align:center}.success-message{color:var(--secondary-color);margin-top:-.75rem;font-size:.9rem;text-align:center}.logout-button{position:absolute;top:1.5rem;right:1.5rem;background:var(--danger-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-weight:500}.admin-box.access-denied{max-width:500px;margin-top:10vh}.access-denied p{font-size:1.1rem;color:var(--light-text-color);margin-bottom:2rem}.access-denied .admin-btn{width:100%;background-color:var(--primary-color);color:#fff}@media (max-width: 600px){.admin-form .form-row{flex-direction:column}}.notes-preparation-container{display:flex;justify-content:center;align-items:flex-start;padding:2rem;min-height:100vh}.notes-preparation-card{width:100%;max-width:920px;background:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:4rem 2.5rem 2.5rem;position:relative}.notes-preparation-card .back-btn.top-left+.notes-preparation-header.with-offset{margin-top:.75rem}.notes-preparation-header{text-align:center;margin-bottom:2rem}.notes-preparation-header h1{color:var(--text-color);margin:0 0 .5rem;font-size:2.2rem;font-weight:700}.notes-preparation-header p{color:var(--light-text-color);font-size:1.05rem;max-width:520px;margin:0 auto}.notes-preparation-content{display:flex;flex-direction:column;gap:2rem}.hidden-file-input{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.upload-section{display:flex;flex-direction:column;gap:2rem}.notes-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.notes-action-card{background:var(--subtle-bg-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:2rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;box-shadow:0 18px 36px #0f172a14;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.notes-action-card:hover{transform:translateY(-6px);box-shadow:0 24px 40px #0f172a1f;border-color:var(--primary-color)}.notes-action-icon{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6770ff33,#9357d740);box-shadow:0 12px 26px #4f46e52e}.notes-action-card:nth-child(2) .notes-action-icon{background:linear-gradient(135deg,#ff7eb340,#ff758c47);box-shadow:0 12px 26px #ff758c38}.notes-action-icon img{width:34px;height:34px;display:block;filter:brightness(0) invert(1)}.notes-action-card h2{font-size:1.3rem;font-weight:600;color:var(--text-color);margin:0}.notes-action-card p{font-size:.95rem;color:var(--light-text-color);line-height:1.5;margin:0}.notes-action-btn{margin-top:1rem;border:none;border-radius:999px;padding:.85rem 1.75rem;font-size:.95rem;font-weight:600;color:#fff;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 12px 24px #3b82f640;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.notes-action-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 18px 30px #3b82f640}.notes-action-btn:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.notes-action-btn.pdf{background:linear-gradient(135deg,#6770ff,#9357d7)}.notes-action-btn.camera{background:linear-gradient(135deg,#ff7eb3,#ff758c)}.notes-action-btn.gallery{background:linear-gradient(135deg,#38bdf8,#6366f1);box-shadow:0 12px 24px #6366f140}.notes-action-buttons{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-top:.5rem}.notes-action-buttons .notes-action-btn{margin-top:0;width:100%}@media (min-width: 640px){.notes-action-buttons{flex-direction:row}.notes-action-buttons .notes-action-btn{width:auto;flex:1}}.notes-guidelines-card{background:var(--subtle-bg-color);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:1.75rem;box-shadow:0 12px 28px #0f172a14}.notes-guidelines-card h3{margin:0 0 1rem;font-size:1.1rem;color:var(--text-color)}.notes-guidelines-card ul{margin:0;padding-left:1.25rem;color:var(--light-text-color)}.notes-guidelines-card li{margin-bottom:.5rem}.content-workflow{display:flex;flex-direction:column;gap:2rem;background:var(--subtle-bg-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:2rem;box-shadow:0 22px 40px #0f172a1f}.uploaded-file-preview{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;background:var(--surface-color);border-radius:var(--border-radius);padding:1.5rem;border:1px solid var(--border-color);box-shadow:0 12px 25px #0f172a14}.file-info h3{color:var(--text-color);margin:0 0 .5rem;font-size:1.1rem}.file-details{display:flex;gap:.5rem;margin-bottom:.75rem}.file-name{color:var(--text-color);font-weight:500;word-break:break-word;overflow-wrap:anywhere}.file-type{color:var(--text-muted);font-size:.9rem}.file-preview-image{max-width:180px;max-height:140px;object-fit:cover;border-radius:12px;border:1px solid var(--border-color)}.change-file-button{background:linear-gradient(135deg,#10b981,#0ea5e9);color:#fff;border:none;border-radius:999px;padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 12px 20px #0ea5e947;display:inline-flex;align-items:center;gap:.5rem}.change-file-button:hover{transform:translateY(-2px);box-shadow:0 18px 26px #0ea5e952}.analysis-section{text-align:center;background:var(--surface-color);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:1.75rem;box-shadow:0 12px 24px #0f172a1f}.analyze-button{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;border:none;border-radius:999px;padding:.95rem 2.8rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1rem;box-shadow:0 18px 32px #4facfe59}.analyze-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 24px 40px #4facfe61}.analyze-button:disabled{opacity:.6;cursor:not-allowed}.analysis-description{color:var(--light-text-color);font-size:.95rem;margin:0}.analysis-results{background:var(--surface-color);border-radius:var(--border-radius);padding:1.75rem;border:1px solid var(--border-color);box-shadow:0 12px 24px #0f172a14}.analysis-results h3{color:var(--text-color);margin:0 0 1rem;font-size:1.2rem}.analysis-summary{margin-bottom:1.5rem;background:#3b82f60f;border-radius:10px;padding:1.25rem}.analysis-summary h4{color:var(--primary-color);margin:0 0 .5rem;font-size:1.05rem}.analysis-summary p{color:var(--text-muted);margin:0;line-height:1.5}.key-points h4{color:var(--text-color);margin:0 0 .5rem;font-size:1rem}.key-points ul{color:var(--text-muted);margin:0;padding-left:1.5rem}.key-points li{margin-bottom:.5rem;line-height:1.4}.generation-options{text-align:center;background:var(--surface-color);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:1.75rem;box-shadow:0 12px 24px #0f172a1a}.generation-options h3{color:var(--text-color);margin:0 0 1.5rem;font-size:1.2rem}.option-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.option-button{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-color);box-shadow:0 10px 20px #0f172a14}.option-button-icon{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#3b82f624;box-shadow:0 10px 22px #3b82f62e}.option-button-icon img{width:30px;height:30px;display:block;filter:brightness(0) invert(1)}.notes-option .option-button-icon{background:linear-gradient(135deg,#3b82f638,#0ea5e93d);box-shadow:0 12px 26px #0ea5e92e}.mocktest-option .option-button-icon{background:linear-gradient(135deg,#f59e0b38,#f973163d);box-shadow:0 12px 26px #f973162e}.mcq-option .option-button-icon{background:linear-gradient(135deg,#8b5cf638,#ec48993d);box-shadow:0 12px 26px #8b5cf62e}.explanation-option .option-button-icon{background:linear-gradient(135deg,#06b6d438,#2dd4bf3d);box-shadow:0 12px 26px #2dd4bf2e}.option-button-title{font-size:1.05rem;font-weight:600;color:var(--text-color)}.option-button-description{font-size:.85rem;font-weight:400;color:var(--text-muted);text-align:center}.option-button:hover:not(:disabled){border-color:var(--primary-color);transform:translateY(-4px);box-shadow:0 18px 30px #3b82f62e}.option-button:disabled{opacity:.6;cursor:not-allowed}.notes-option:hover:not(:disabled){border-color:#10b981;background:#10b9810d}.mocktest-option:hover:not(:disabled){border-color:#f59e0b;background:#f59e0b0d}.mcq-option:hover:not(:disabled){border-color:#8b5cf6;background:#8b5cf60d}.explanation-option:hover:not(:disabled){border-color:#06b6d4;background:#06b6d40d}.generating-indicator{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.generated-content{background:var(--surface-color);border-radius:var(--border-radius);border:1px solid var(--border-color);overflow:hidden;box-shadow:0 20px 36px #0f172a1a}.content-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:#3b82f60f}.content-header h3{color:var(--text-color);margin:0;font-size:1.2rem}.content-actions{display:flex;gap:.5rem;flex-wrap:wrap}.download-button,.generate-more-button{background:var(--primary-color);color:#fff;border:none;border-radius:999px;padding:.55rem 1.35rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 12px 26px #3b82f638;display:inline-flex;align-items:center;gap:.4rem}.download-button:hover{transform:translateY(-2px);box-shadow:0 18px 32px #3b82f640}.generate-more-button{background:linear-gradient(135deg,#f97316,#fb7185);box-shadow:0 12px 26px #f9731638}.button-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center}.button-icon img{width:20px;height:20px;display:block;filter:brightness(0) invert(1)}@media (max-width: 640px){.uploaded-file-preview,.file-details{flex-direction:column;align-items:flex-start}.change-file-button{width:100%;justify-content:center}.content-header{align-items:flex-start;flex-direction:column;gap:.75rem}.content-actions{width:100%}.content-actions .download-button,.content-actions .generate-more-button{width:100%;justify-content:center}}.generate-more-button:hover{transform:translateY(-2px);box-shadow:0 18px 32px #f9731647}.content-display{max-height:500px;overflow-y:auto;padding:1.5rem;background:var(--surface-color)}.content-html{color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.95rem;line-height:1.7}.content-html h1,.content-html h2,.content-html h3,.content-html h4{color:var(--text-color);margin-top:1.5rem;margin-bottom:.75rem;font-weight:600}.content-html h1:first-child,.content-html h2:first-child,.content-html h3:first-child,.content-html h4:first-child{margin-top:0}.content-html p{margin:0 0 1rem}.content-html ul,.content-html ol{margin:.5rem 0 1rem 1.25rem;padding-left:1rem}.content-html li{margin-bottom:.5rem}.content-html blockquote{margin:1rem 0;padding:.75rem 1rem;border-left:4px solid var(--primary-color);background:#00000008;color:var(--text-muted)}.content-html code{background:#00000014;padding:.15rem .35rem;border-radius:4px;font-size:.9rem}.content-html pre{background:#00000014;border-radius:6px;padding:1rem;overflow-x:auto;font-family:Fira Code,Source Code Pro,monospace}.content-html table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.92rem}.content-html th,.content-html td{border:1px solid var(--border-color);padding:.6rem .75rem;text-align:left}.content-html th{background:#0000000d;font-weight:600}.content-placeholder{color:var(--text-muted);font-style:italic}.content-display .follow-up-container{max-width:100%;margin-top:1.5rem;background-color:var(--bg-color)}.content-display .follow-up-title{margin-top:0}@media (max-width: 768px){.notes-preparation-container{padding:1rem}.notes-preparation-card{padding:4rem 1.5rem 1.5rem}.notes-preparation-header h1{font-size:1.8rem}.notes-preparation-header p{font-size:.95rem}.notes-action-grid{grid-template-columns:1fr}.uploaded-file-preview{flex-direction:column;gap:1rem}.option-buttons{grid-template-columns:1fr}.content-header{flex-direction:column;gap:1rem;align-items:stretch}.content-actions{justify-content:center}}.dark-mode .notes-preparation-container{color:var(--text-color)}.dark-mode .notes-action-card,.dark-mode .notes-guidelines-card,.dark-mode .content-workflow,.dark-mode .uploaded-file-preview,.dark-mode .analysis-results,.dark-mode .option-button,.dark-mode .generated-content{background:var(--surface-color);box-shadow:0 12px 26px #0006}.dark-mode .content-display{background:var(--surface-color)}.dark-mode .file-preview-image{border-color:var(--border-color)}.dark-mode .content-html blockquote{background:#ffffff0d;color:var(--text-color)}.dark-mode .content-html code,.dark-mode .content-html pre{background:#ffffff14}.dark-mode .content-html th{background:#ffffff0d}.formula-bank-container{max-width:900px;margin:0 auto;padding:1rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;box-sizing:border-box}.formula-bank-header{margin-bottom:2rem}.formula-bank-header .back-button{background:none;border:none;font-size:1rem;color:#007bff;cursor:pointer;padding:.5rem 1rem;margin-bottom:1rem;border-radius:6px;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;font-weight:600}.formula-bank-header .back-button:hover{background-color:#007bff1a;transform:translate(-4px)}.header-content{text-align:center;margin-bottom:2rem}.header-content h1{font-size:2.5rem;margin:0 0 .5rem;color:#1a202c;font-weight:800}.header-content .subtitle{font-size:1.1rem;color:#4a5568;margin:0}.filters-section{background:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #00000014;display:grid;grid-template-columns:auto 1fr 1fr auto;gap:1.5rem;align-items:end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-weight:700;font-size:.95rem;color:#2d3748}.class-display{display:flex;align-items:center}.class-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.95rem;box-shadow:0 2px 8px #667eea4d;white-space:nowrap}.subject-select,.search-input{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;background:#fff;color:#2d3748;transition:all .2s ease;box-sizing:border-box;width:100%}.subject-select:hover,.search-input:hover{border-color:#cbd5e0}.subject-select:focus,.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-input:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.search-group{grid-column:2 / 4}.generate-button-inline{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s ease;box-sizing:border-box;align-self:flex-end;white-space:nowrap}.generate-button-inline:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.generate-button-inline:disabled{opacity:.6;cursor:not-allowed}.results-info{text-align:center;padding:1rem 0;font-size:.95rem;color:#4a5568;font-weight:600;margin-bottom:1.5rem}.results-container{background:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #00000014}.formulas-content{width:100%}.formula-group{margin-bottom:3rem}.group-title{font-size:1.75rem;font-weight:800;color:#007bff;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:3px solid #e2e8f0;width:100%;padding-left:0;padding-right:0}.formulas-list{display:flex;flex-direction:column;gap:.75rem;list-style:none;padding:0;margin:0;align-items:stretch}.formula-item{border:2px solid #e2e8f0;border-radius:10px;overflow:hidden;transition:all .2s ease;background:#fff;animation:fadeInUp .3s ease-out forwards;opacity:0;width:100%;margin:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.formula-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.formula-item.expanded{border-color:#667eea;box-shadow:0 6px 16px #667eea33}.formula-row-wrapper{display:flex;align-items:center;gap:1rem;padding:1rem;width:100%;box-sizing:border-box}.formula-row{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;flex-grow:1;padding:.5rem;border-radius:6px}.formula-row:hover{background-color:#667eea0d}.formula-row:focus{outline:2px solid #667eea;outline-offset:-2px}.expand-icon{font-size:1.2rem;color:#667eea;flex-shrink:0;width:1.5rem;display:flex;align-items:center;justify-content:center;margin-top:.2rem;font-weight:700}.formula-summary{flex-grow:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.formula-name{font-size:1.15rem;color:#1a202c;margin:0;font-weight:700;word-break:break-word;line-height:1.3}.formula-code-preview{font-family:Courier New,monospace;font-size:1rem;color:#d63384;background:#f7fafc;padding:.6rem .9rem;border-radius:6px;border-left:3px solid #667eea;font-weight:600;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.copy-btn-row{background:#edf2f7;border:none;padding:.6rem;border-radius:6px;cursor:pointer;font-size:1.1rem;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;margin-left:.25rem}.copy-btn-row:hover{background:#667eea;color:#fff;transform:scale(1.1)}.copy-btn-row.copied{background:#48bb78;color:#fff}.formula-details{padding:1rem 1.5rem 1.5rem;border-top:1px solid #e2e8f0;background:#667eea05;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.formula-display{background:#f7fafc;padding:1rem;border-radius:8px;margin-bottom:1.5rem;border-left:4px solid #667eea;overflow-x:auto}.formula-display code{font-family:Courier New,monospace;font-size:1rem;color:#d63384;font-weight:600;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap;display:block;line-height:1.6}.formula-description{color:#4a5568;font-size:.95rem;line-height:1.6;margin:0 0 1.5rem}.variables-section,.example-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.variables-section h4,.example-section h4{font-size:.85rem;color:#4a5568;margin-bottom:.75rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.variables-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.variables-list li{padding:.25rem 0;font-size:.9rem;color:#4a5568}.variables-list li strong{color:#667eea;font-family:Courier New,monospace;font-weight:700}.example-section p{font-size:.9rem;color:#4a5568;line-height:1.6;font-style:italic;margin:0}.loading-state,.error-state,.empty-state{text-align:center;padding:3rem 1rem;background:#fff;border-radius:12px;margin:2rem auto}.spinner{border:4px solid #e2e8f0;border-top:4px solid #667eea;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state p,.error-state p,.empty-state p{font-size:1.1rem;color:#4a5568;margin:.75rem 0}.loading-subtitle,.empty-subtitle{font-size:.95rem;color:#718096}.empty-hint{font-size:.85rem;color:#667eea;margin-top:1rem;padding:.75rem 1rem;background:#667eea1a;border-radius:8px;display:inline-block}.retry-button{margin-top:1rem;padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease}.retry-button:hover{background:#764ba2;transform:translateY(-2px)}@media (min-width: 768px){.formula-bank-container{padding:1.5rem}.header-content h1{font-size:2.8rem}.header-content .subtitle{font-size:1.15rem}.filters-section{padding:2rem;gap:1.5rem}.results-container{padding:2rem}.formula-row-wrapper{padding:1.25rem}.formula-row{padding:.5rem}.formula-name{font-size:1.2rem}.formula-code-preview{font-size:1rem}.formula-details{padding:1.25rem 1.75rem 1.75rem}.group-title{font-size:1.9rem}}@media (min-width: 1024px){.formula-bank-container{padding:2rem;max-width:1100px}.header-content h1{font-size:3rem}.header-content .subtitle{font-size:1.2rem}.filters-section{padding:2.5rem;gap:2rem}.results-container{padding:2.5rem}.formula-row-wrapper{padding:1.5rem}.formula-row{padding:.6rem}.formula-name{font-size:1.3rem}.formula-code-preview{font-size:1.05rem}.formula-details{padding:1.5rem 2rem 2rem}.formula-display{padding:1.25rem}.group-title{font-size:2rem;margin-bottom:2rem}.formulas-list{gap:1rem}}@media (max-width: 639px){.formula-bank-container{padding:.75rem}.header-content h1{font-size:1.4rem;margin-bottom:.35rem}.header-content .subtitle{font-size:.9rem}.filters-section{padding:1rem;gap:.8rem;grid-template-columns:1fr;align-items:stretch}.results-container{padding:1rem}.filter-group{gap:.4rem}.filter-group label{font-size:.8rem}.class-badge{font-size:.8rem;padding:.4rem .8rem}.subject-select,.search-input{font-size:.85rem;padding:.6rem .8rem}.search-group{grid-column:auto}.generate-button-inline{font-size:.85rem;padding:.65rem 1.2rem;width:100%}.formula-row-wrapper{padding:.75rem;gap:.75rem}.formula-row{gap:.75rem;padding:.35rem}.expand-icon{font-size:1rem;width:1.2rem;min-width:1.2rem}.formula-name{font-size:1rem;line-height:1.25}.formula-code-preview{font-size:.85rem;padding:.5rem .7rem}.copy-btn-row{padding:.5rem;min-width:2.2rem;height:2.2rem;font-size:.95rem;margin-left:.15rem}.formula-details{padding:.75rem 1rem 1rem}.formula-display{padding:.8rem;margin-bottom:1rem}.formula-display code{font-size:.85rem;line-height:1.4}.formula-description{font-size:.85rem;margin-bottom:1rem}.group-title{font-size:1.2rem;margin-bottom:1rem;padding-bottom:.5rem}.variables-section h4,.example-section h4{font-size:.75rem}.variables-list li,.example-section p{font-size:.8rem}.results-info{font-size:.8rem;padding:.75rem 0}.loading-state,.error-state,.empty-state{padding:2rem .75rem;margin:1.5rem 0}.retry-button{padding:.6rem 1rem;font-size:.85rem}}@media (max-width: 360px){.formula-bank-container{padding:.5rem}.header-content h1{font-size:1.2rem;margin-bottom:.25rem}.header-content .subtitle{font-size:.8rem}.filters-section{padding:.75rem;gap:.6rem}.results-container{padding:.75rem}.formula-row-wrapper{padding:.6rem;gap:.6rem}.formula-row{gap:.6rem;padding:.3rem}.formula-name{font-size:.9rem;line-height:1.2}.formula-code-preview{font-size:.75rem;padding:.4rem .6rem}.copy-btn-row{padding:.4rem;min-width:2rem;height:2rem;font-size:.85rem}.group-title{font-size:1rem;margin-bottom:.75rem}.formulas-list{gap:.6rem}.formula-details{padding:.75rem}.formula-display code{font-size:.75rem}.generate-button-inline{font-size:.8rem;padding:.55rem 1rem}.subject-select,.search-input{font-size:.8rem;padding:.55rem .7rem}}.flashcards-container{padding:20px;min-height:100vh;display:flex;align-items:center;justify-content:center}.flashcards-setup-card{background:#fff;border-radius:16px;padding:32px;max-width:600px;width:100%;box-shadow:0 4px 12px #0000001a;position:relative}.flashcards-header{text-align:center;margin-bottom:32px}.flashcards-icon-wrapper{display:flex;justify-content:center;margin-bottom:16px}.flashcards-icon{width:64px;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.flashcards-icon img{width:40px;height:40px;filter:brightness(0) invert(1)}.flashcards-header h1{font-size:28px;font-weight:700;margin:12px 0 8px;color:#1a1a1a}.flashcards-header p{font-size:15px;color:#666;margin:0}.flashcards-form{display:flex;flex-direction:column;gap:24px}.class-display{padding:12px 16px;background:#f3f4f6;border-radius:8px;font-size:15px;color:#666;border:2px solid #e5e7eb}.topic-input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;transition:border-color .2s}.topic-input:focus{outline:none;border-color:#667eea}.number-options{display:flex;flex-wrap:wrap;gap:8px}.number-btn{padding:10px 20px;border:2px solid #e5e7eb;background:#fff;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;color:#333}.number-btn:hover{border-color:#667eea;background:#f0f4ff}.number-btn.active{background:#667eea;color:#fff;border-color:#667eea}.number-btn.custom{min-width:100px}.custom-input{margin-top:8px;padding:10px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px}.custom-input:focus{outline:none;border-color:#667eea}.flashcards-viewer{background:#fff;border-radius:16px;padding:24px;max-width:700px;width:100%;box-shadow:0 4px 12px #0000001a}.flashcards-controls-top{display:flex;justify-content:space-between;margin-bottom:24px}.exit-btn,.edit-btn{padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.exit-btn{background:#f3f4f6;color:#666}.exit-btn:hover{background:#e5e7eb}.edit-btn{background:#e0e7ff;color:#4f46e5}.edit-btn:hover{background:#c7d2fe}.flashcard-wrapper{perspective:1000px;margin-bottom:24px;min-height:400px;display:flex;align-items:center;justify-content:center}.flashcard{width:100%;height:400px;position:relative;transition:transform .6s;transform-style:preserve-3d;cursor:pointer}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:12px;padding:32px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.flashcard-front{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.flashcard-back{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;transform:rotateY(180deg)}.flashcard-label{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;opacity:.9;margin-bottom:16px}.flashcard-content{font-size:20px;font-weight:500;line-height:1.6;flex:1;display:flex;align-items:center;justify-content:center;padding:16px 0}.flashcard-hint{font-size:13px;opacity:.8;margin-top:16px}.flashcards-navigation{display:flex;align-items:center;justify-content:space-between;gap:16px}.nav-btn{padding:12px 24px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.nav-btn:hover:not(:disabled){background:#5568d3;transform:translateY(-2px)}.card-counter{font-size:16px;font-weight:600;color:#666}@media (max-width: 768px){.flashcards-setup-card{padding:24px 20px}.flashcards-header h1{font-size:24px}.number-options{justify-content:center}.flashcard{height:350px}.flashcard-content{font-size:18px}.flashcards-navigation{flex-direction:column}.nav-btn{width:100%}}.dark-mode .flashcards-setup-card,.dark-mode .flashcards-viewer{background:#1f2937}.dark-mode .flashcards-header h1{color:#f3f4f6}.dark-mode .flashcards-header p{color:#9ca3af}.dark-mode .class-display{background:#374151;color:#9ca3af;border-color:#4b5563}.dark-mode .topic-input,.dark-mode .custom-input,.dark-mode .number-btn{background:#374151;color:#f3f4f6;border-color:#4b5563}.dark-mode .number-btn:hover{border-color:#667eea;background:#4b5563}.dark-mode .exit-btn{background:#374151;color:#9ca3af}.dark-mode .exit-btn:hover{background:#4b5563}.dark-mode .card-counter{color:#9ca3af}.entrance-exam-container{padding:20px;min-height:100vh;display:flex;align-items:center;justify-content:center}.entrance-exam-card{background:#fff;border-radius:16px;padding:32px;max-width:700px;width:100%;box-shadow:0 4px 12px #0000001a;position:relative}.entrance-exam-card.results{max-width:900px}.entrance-exam-header{text-align:center;margin-bottom:32px}.icon-wrapper{display:flex;justify-content:center;margin-bottom:16px}.feature-icon{width:64px;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:32px}.entrance-exam-header h1{font-size:28px;font-weight:700;margin:12px 0 8px;color:#1a1a1a}.entrance-exam-header p{font-size:15px;color:#666;margin:0}.entrance-exam-form{display:flex;flex-direction:column;gap:24px}.form-group label{font-size:14px;font-weight:600;color:#333}.required{color:#ef4444}.optional{color:#999;font-weight:400}.exam-select,.custom-input,.context-textarea,.language-input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;font-family:inherit;transition:border-color .2s}.exam-select:focus,.custom-input:focus,.context-textarea:focus,.language-input:focus{outline:none;border-color:#667eea}.context-textarea{resize:vertical;min-height:100px}.toggle-group{gap:12px}.toggle-header{display:flex;justify-content:space-between;align-items:center}.toggle-btn{width:48px;height:28px;background:#e5e7eb;border:none;border-radius:14px;position:relative;cursor:pointer;transition:background-color .3s}.toggle-btn.active{background:#667eea}.toggle-slider{position:absolute;top:4px;left:4px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s}.toggle-btn.active .toggle-slider{transform:translate(20px)}.language-input{margin-top:8px}.generate-btn{padding:14px 24px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a1a;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #fbbf244d}.disclaimer{font-size:12px;color:#999;text-align:center;line-height:1.5;margin:0}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.icon-btn{background:#f3f4f6;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .2s}.icon-btn:hover{background:#e5e7eb}.exam-tips-content{background:#f9fafb;border-radius:12px;padding:24px;margin-bottom:24px;max-height:600px;overflow-y:auto}.tips-display{font-size:15px;line-height:1.8;color:#1a1a1a}.tips-display h1{font-size:24px;font-weight:700;margin:24px 0 16px;color:#667eea}.tips-display h1:first-child{margin-top:0}.tips-display h2{font-size:20px;font-weight:600;margin:20px 0 12px;color:#764ba2}.tips-display h3{font-size:17px;font-weight:600;margin:16px 0 8px;color:#333}.tips-display p{margin:12px 0}.tips-display strong{font-weight:600;color:#1a1a1a}.results-footer{margin-top:16px}@media (max-width: 768px){.entrance-exam-card{padding:24px 20px}.entrance-exam-header h1{font-size:24px}.exam-tips-content{max-height:500px;padding:20px}.tips-display{font-size:14px}.tips-display h1{font-size:20px}.tips-display h2{font-size:18px}.tips-display h3{font-size:16px}}.dark-mode .entrance-exam-card{background:#1f2937}.dark-mode .entrance-exam-header h1{color:#f3f4f6}.dark-mode .entrance-exam-header p{color:#9ca3af}.dark-mode .form-group label{color:#e5e7eb}.dark-mode .exam-select,.dark-mode .custom-input,.dark-mode .context-textarea,.dark-mode .language-input{background:#374151;color:#f3f4f6;border-color:#4b5563}.dark-mode .toggle-btn{background:#4b5563}.dark-mode .disclaimer{color:#6b7280}.dark-mode .exam-tips-content{background:#111827}.dark-mode .tips-display{color:#e5e7eb}.dark-mode .tips-display strong{color:#f3f4f6}.dark-mode .icon-btn{background:#374151;color:#9ca3af}.dark-mode .icon-btn:hover{background:#4b5563}.vocabulary-container{display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem;min-height:100vh}.vocabulary-card{background:var(--card-bg);border-radius:16px;padding:2rem;max-width:700px;width:100%;box-shadow:0 4px 20px #0000001a;position:relative}.vocabulary-card.results{max-width:800px}.vocabulary-header{text-align:center;margin-bottom:2rem}.vocabulary-header .icon-wrapper{margin-bottom:1rem}.vocabulary-header .feature-icon{font-size:4rem;animation:bounce 2s infinite}.vocabulary-header h1{font-size:2rem;color:var(--text-primary);margin-bottom:.5rem}.vocabulary-header p{color:var(--text-secondary);font-size:1rem}.vocabulary-form{display:flex;flex-direction:column;gap:1.5rem}.topic-input,.difficulty-select{padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s}.topic-input:focus,.difficulty-select:focus{outline:none;border-color:var(--primary-color)}.word-count-slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-color);border-radius:3px;outline:none}.word-count-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--primary-color);border-radius:50%;cursor:pointer}.word-count-slider::-moz-range-thumb{width:20px;height:20px;background:var(--primary-color);border-radius:50%;cursor:pointer;border:none}.slider-labels{display:flex;justify-content:space-between;margin-top:.25rem;font-size:.85rem;color:var(--text-secondary)}.vocabulary-content{display:flex;flex-direction:column;gap:2rem}.progress-indicator{text-align:center;font-size:.9rem;color:var(--text-secondary);font-weight:600;padding:.5rem;background:var(--bg-secondary);border-radius:8px}.flashcard-view{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:12px;padding:2rem;min-height:400px;display:flex;flex-direction:column;gap:1rem}.word-header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.vocabulary-word{font-size:2.5rem;color:var(--primary-color);margin:0;font-weight:700}.tts-btn{background:var(--primary-color);border:none;border-radius:50%;width:50px;height:50px;font-size:1.5rem;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center}.tts-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #0003}.tts-btn:active{transform:scale(.95)}.pronunciation{text-align:center;font-size:1.2rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:.5rem}.tts-btn-small{background:transparent;border:1px solid var(--border-color);border-radius:6px;padding:.25rem .5rem;font-size:.9rem;cursor:pointer;transition:background .2s}.tts-btn-small:hover{background:var(--bg-secondary)}.part-of-speech{text-align:center;font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.reveal-btn{background:var(--secondary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s;margin:1rem 0}.reveal-btn:hover{background:var(--primary-color)}.word-details{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem;animation:fadeIn .3s ease-in}.definition-section h3,.example-section h3,.synonyms-section h3,.antonyms-section h3{font-size:1.1rem;color:var(--primary-color);margin-bottom:.5rem}.definition-section p,.example-section p{color:var(--text-primary);line-height:1.6}.example-text{font-style:italic;color:var(--text-secondary);margin-bottom:.5rem}.word-chips{display:flex;flex-wrap:wrap;gap:.5rem}.word-chip{background:var(--primary-color);color:#fff;padding:.4rem .8rem;border-radius:20px;font-size:.9rem;font-weight:500}.word-chip.antonym{background:var(--error-color, #e74c3c)}.navigation-controls{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.nav-btn{background:var(--bg-secondary);border:2px solid var(--border-color);padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s}.nav-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.word-list-preview{margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border-color)}.word-list-preview h3{font-size:1.2rem;color:var(--text-primary);margin-bottom:1rem}.word-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.word-item{background:var(--bg-secondary);border:2px solid var(--border-color);padding:.75rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;color:var(--text-primary)}.word-item:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px)}.word-item.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width: 768px){.vocabulary-container{padding:1rem .5rem}.vocabulary-card{padding:1.5rem 1rem}.vocabulary-header h1{font-size:1.5rem}.vocabulary-word{font-size:2rem}.word-header{flex-direction:column;gap:.5rem}.flashcard-view{padding:1.5rem 1rem;min-height:350px}.word-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.navigation-controls{flex-direction:column}.nav-btn{width:100%}}.mock-exam-container{display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem;min-height:100vh}.mock-exam-card{background:var(--card-bg);border-radius:16px;padding:2rem;max-width:700px;width:100%;box-shadow:0 4px 20px #0000001a;position:relative}.mock-exam-card.results{max-width:900px}.mock-exam-header{text-align:center;margin-bottom:2rem}.mock-exam-header .icon-wrapper{margin-bottom:1rem}.mock-exam-header .feature-icon{font-size:4rem;animation:bounce 2s infinite}.mock-exam-header h1{font-size:2rem;color:var(--text-primary);margin-bottom:.5rem}.mock-exam-header p{color:var(--text-secondary);font-size:1rem}.mock-exam-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.95rem}.required{color:var(--error-color, #e74c3c)}.optional{color:var(--text-secondary);font-weight:400;font-size:.85rem}.helper-text{font-size:.85rem;color:var(--text-secondary);margin-top:-.25rem}.subject-select,.topic-input,.number-input,.context-textarea,.language-input{padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s}.subject-select:focus,.topic-input:focus,.number-input:focus,.context-textarea:focus,.language-input:focus{outline:none;border-color:var(--primary-color)}.number-input{text-align:center;font-weight:600}.checkbox-group{padding:1rem;background:var(--bg-secondary);border-radius:8px}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem;color:var(--text-primary)}.checkbox-group-horizontal{display:flex;gap:1.5rem;flex-wrap:wrap}.toggle-group{background:var(--bg-secondary);padding:1rem;border-radius:8px}.toggle-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.toggle-btn{position:relative;width:50px;height:26px;background:var(--border-color);border-radius:13px;border:none;cursor:pointer;transition:background .3s}.toggle-btn.active{background:var(--primary-color)}.toggle-slider{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s}.toggle-btn.active .toggle-slider{transform:translate(24px)}.generate-btn{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:1rem}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.generate-btn:disabled{opacity:.6;cursor:not-allowed}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.download-btn-fixed{position:absolute;top:2rem;right:2rem;background:var(--secondary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap;box-shadow:0 2px 8px #00000026;z-index:10}.download-btn-fixed:hover{background:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.download-btn{background:var(--secondary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap}.download-btn:hover{background:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.exam-header-info{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-color)}.exam-header-info h1{font-size:2rem;color:var(--primary-color);margin-bottom:1rem}.exam-meta{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;font-size:.95rem;color:var(--text-secondary)}.full-syllabus-badge{display:inline-block;background:var(--primary-color);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;margin-top:1rem}.exam-instructions{background:var(--bg-secondary);padding:1.5rem;border-radius:8px;margin-bottom:2rem}.exam-instructions h3{color:var(--primary-color);margin-bottom:1rem}.exam-instructions ul{list-style-position:inside;color:var(--text-primary);line-height:1.8}.exam-questions{margin-bottom:3rem}.exam-questions h2{color:var(--primary-color);font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color)}.question-block{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.question-number{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.question-marks{background:var(--primary-color);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.9rem;font-weight:600}.question-text{font-size:1.05rem;color:var(--text-primary);line-height:1.6;margin-bottom:1rem}.question-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.option-item{padding:.75rem;background:var(--bg-secondary);border-radius:6px;color:var(--text-primary)}.answer-space{margin-top:1rem;padding:2rem;border:2px dashed var(--border-color);border-radius:6px;text-align:center;color:var(--text-secondary);font-style:italic}.answer-key{background:var(--bg-secondary);padding:2rem;border-radius:8px;margin-top:3rem}.answer-key h2{color:var(--primary-color);font-size:1.5rem;margin-bottom:1.5rem}.answer-item{background:var(--card-bg);padding:1rem;border-radius:6px;margin-bottom:1rem;border-left:4px solid var(--primary-color)}.answer-item strong{color:var(--primary-color);font-size:1.05rem}.explanation{margin-top:.5rem;color:var(--text-secondary);line-height:1.6;font-size:.95rem}.disclaimer{text-align:center;font-size:.85rem;color:var(--text-secondary);margin-top:1rem;line-height:1.5}@media (max-width: 768px){.mock-exam-container{padding:1rem .5rem}.mock-exam-card{padding:1.5rem 1rem}.mock-exam-header h1{font-size:1.5rem}.form-row{grid-template-columns:1fr}.exam-meta{flex-direction:column;gap:.5rem;align-items:center}.results-header{flex-direction:row;justify-content:space-between;gap:.5rem}.back-btn{font-size:.9rem;padding:.6rem 1rem}.download-btn-fixed{position:fixed;top:auto;bottom:20px;right:20px;font-size:.9rem;padding:.75rem 1.25rem}.download-btn{font-size:.9rem;padding:.6rem 1rem}.checkbox-group-horizontal{flex-direction:column;gap:.75rem}.question-block{padding:1rem}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.landing-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);overflow-x:hidden}.hero-section{padding:2rem 1rem;text-align:center;color:#fff;min-height:100vh;display:flex;align-items:center;justify-content:center}.hero-content{max-width:600px;margin:0 auto}.hero-title{font-size:2rem;font-weight:800;line-height:1.2;margin-bottom:1rem}.hero-title .highlight{color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.hero-subtitle{font-size:1.1rem;margin-bottom:2rem;opacity:.95}.special-offer-badge{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:16px;padding:1.5rem;margin:2rem auto;max-width:400px;box-shadow:0 8px 24px #0003;display:flex;align-items:center;gap:1rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.badge-icon{font-size:2.5rem}.badge-text{text-align:left}.badge-text strong{font-size:1.2rem;display:block;margin-bottom:.25rem}.badge-text p{margin:0;font-size:.95rem}.coupon-highlight{background:#fff;color:#f5576c;padding:.25rem .75rem;border-radius:6px;font-weight:800;font-size:1.1rem;letter-spacing:1px}.pricing-hero{display:flex;align-items:center;justify-content:center;gap:1rem;margin:2rem 0;flex-wrap:wrap}.price-strike{font-size:1.5rem;text-decoration:line-through;opacity:.7}.price-final{font-size:3.5rem;font-weight:900;color:gold}.price-label{font-size:1.2rem;opacity:.9}.cta-primary{background:linear-gradient(135deg,gold,#fa0);color:#333;border:none;padding:1.25rem 3rem;font-size:1.2rem;font-weight:700;border-radius:50px;cursor:pointer;box-shadow:0 8px 24px #ffd70066;transition:all .3s ease;margin:2rem 0}.cta-primary:hover{transform:translateY(-3px);box-shadow:0 12px 32px #ffd70099}.trust-badges{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}.trust-badges .badge{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.75rem 1.5rem;border-radius:25px;font-size:.95rem;font-weight:600;color:#333;border:2px solid rgba(255,215,0,.3);box-shadow:0 4px 12px #00000026}.features-section{background:#fff;padding:4rem 1rem}.section-title{text-align:center;font-size:2rem;font-weight:800;color:#333;margin-bottom:.5rem}.section-subtitle{text-align:center;font-size:1.1rem;color:#666;margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:1200px;margin:0 auto}.feature-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:2rem;border-radius:16px;text-align:center;box-shadow:0 4px 16px #0000001a;transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-title{font-size:1.3rem;font-weight:700;color:#333;margin-bottom:.75rem}.feature-description{font-size:1rem;color:#555;line-height:1.6}.benefits-section{background:linear-gradient(135deg,#667eea,#764ba2);padding:4rem 1rem;color:#fff}.benefits-grid{display:grid;grid-template-columns:1fr;gap:1rem;max-width:800px;margin:0 auto}.benefit-item{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.25rem;border-radius:12px;font-size:1.1rem;font-weight:600}.testimonials-section{background:#fff;padding:4rem 1rem}.testimonials-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:1000px;margin:0 auto}.testimonial-card{background:linear-gradient(135deg,#ffecd2,#fcb69f);padding:2rem;border-radius:16px;box-shadow:0 4px 16px #0000001a}.testimonial-stars{color:gold;font-size:1.5rem;margin-bottom:1rem}.testimonial-text{font-size:1.05rem;font-style:italic;color:#333;margin-bottom:1.5rem;line-height:1.6}.testimonial-author{display:flex;flex-direction:column;gap:.25rem}.testimonial-author strong{font-size:1.1rem;color:#333}.testimonial-author span{font-size:.9rem;color:#666}.checkout-section{background:linear-gradient(135deg,#a8edea,#fed6e3);padding:4rem 1rem}.checkout-container{max-width:500px;margin:0 auto;background:#fff;padding:2rem;border-radius:24px;box-shadow:0 8px 32px #00000026}.checkout-title{font-size:1.8rem;font-weight:800;color:#333;text-align:center;margin-bottom:.5rem}.checkout-subtitle{text-align:center;color:#666;margin-bottom:2rem}.plan-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:16px;text-align:center;margin-bottom:2rem}.plan-header{font-size:.85rem;font-weight:600;letter-spacing:2px;opacity:.9;margin-bottom:.5rem}.plan-name{font-size:1.8rem;font-weight:700;color:gold;margin-bottom:1rem}.plan-pricing{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem}.plan-original{font-size:1.2rem;text-decoration:line-through;opacity:.7}.plan-final{font-size:2.5rem;font-weight:900}.plan-savings{font-size:.95rem;opacity:.9}.form-group label{font-weight:600;color:#333;font-size:.95rem}.form-group input,.form-group select{padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;background:#fff;color:#333;transition:border-color .3s ease}.form-group select option{background:#fff;color:#333}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.coupon-hint{font-size:.85rem;color:#667eea;background:#f0f4ff;padding:.75rem;border-radius:8px;margin-top:.5rem}.checkout-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1.25rem;font-size:1.2rem;font-weight:700;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #667eea66}.checkout-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #667eea99}.checkout-button:disabled{opacity:.6;cursor:not-allowed}.secure-payment{text-align:center;font-size:.9rem;color:#666;margin-top:1rem}.landing-footer{background:#2d3748;color:#fff;padding:2rem 1rem;text-align:center}.landing-footer p{margin:.5rem 0}.landing-footer a{color:gold;text-decoration:none;margin:0 .5rem}.landing-footer a:hover{text-decoration:underline}@media (min-width: 768px){.hero-title{font-size:3rem}.features-grid,.benefits-grid{grid-template-columns:repeat(2,1fr)}.testimonials-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.features-grid{grid-template-columns:repeat(4,1fr)}}.blog-screen{max-width:1200px;margin:0 auto;padding:2rem 1rem;background:var(--background-color);min-height:100vh}.blog-back-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--surface-color);border:2px solid var(--border-color);border-radius:12px;color:var(--text-color);cursor:pointer;font-size:.875rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);margin-bottom:1.5rem;box-shadow:0 2px 4px #0000000d}.blog-back-btn:hover{background:var(--surface-color);border-color:var(--primary-color);color:var(--primary-color);transform:translate(-4px);box-shadow:0 4px 12px #4a90e226}.blog-back-btn svg{transition:transform .3s ease}.blog-back-btn:hover svg{transform:translate(-2px)}.blog-header{text-align:center;margin-bottom:3rem;padding:2rem 1rem;background:var(--surface-color);border-radius:16px;box-shadow:0 2px 8px #0000000d}.blog-header h1{font-size:2.5rem;font-weight:700;color:var(--text-color);margin-bottom:.75rem;letter-spacing:-.02em}.blog-header p{font-size:1.1rem;color:var(--light-text-color);max-width:600px;margin:0 auto;line-height:1.6}.blog-filters{margin-bottom:2rem}.search-container{position:relative;max-width:500px;margin:0 auto 2rem}.search-container svg{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:var(--light-text-color);z-index:1}.search-input{width:100%;padding:1rem 1.25rem 1rem 3.25rem;border:2px solid var(--border-color);border-radius:12px;font-size:1rem;background:var(--surface-color);color:var(--text-color);transition:all .3s ease;box-shadow:0 2px 8px #0000000d;font-weight:500}.search-input::placeholder{color:var(--light-text-color);opacity:.7}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 4px 16px #4a90e226,0 0 0 3px #4a90e21a;background:var(--surface-color)}.category-filters{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;padding:1rem;background:var(--surface-color);border-radius:12px;box-shadow:0 2px 8px #0000000d}.filter-btn{padding:.625rem 1.25rem;border:2px solid var(--border-color);border-radius:24px;background:var(--surface-color);color:var(--text-color);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:.875rem;font-weight:600;letter-spacing:.01em}.filter-btn:hover{background:var(--surface-color);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #4a90e226}.filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff;box-shadow:0 4px 12px #4a90e240}.blog-stats{display:flex;justify-content:center;gap:3rem;margin-bottom:2rem;padding:1.5rem;background:var(--surface-color);border-radius:12px;border:2px solid var(--border-color);box-shadow:0 2px 8px #0000000d}.stats-item{text-align:center}.stats-number{display:block;font-size:2.25rem;font-weight:700;color:var(--primary-color);line-height:1;margin-bottom:.25rem}.stats-label{font-size:.875rem;color:var(--light-text-color);font-weight:500}.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.75rem;align-items:start}.blog-card{background:var(--surface-color);border:2px solid var(--border-color);border-radius:16px;padding:1.75rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);height:100%;display:flex;flex-direction:column;box-shadow:0 2px 8px #0000000d}.blog-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #4a90e226,0 4px 8px #00000014;border-color:var(--primary-color)}.blog-card-content{flex:1;display:flex;flex-direction:column}.blog-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.blog-category{padding:.375rem .875rem;background:#4a90e21a;color:var(--primary-color);border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(74,144,226,.2)}.blog-read-time{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--light-text-color);font-weight:500}.blog-read-time svg{opacity:.7}.blog-title{font-size:1.35rem;font-weight:700;color:var(--text-color);margin-bottom:.875rem;line-height:1.35;letter-spacing:-.01em}.blog-excerpt{color:var(--light-text-color);line-height:1.7;margin-bottom:1rem;font-size:.95rem}.blog-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.blog-tag{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--subtle-bg-color);color:var(--text-color);border-radius:8px;font-size:.75rem;font-weight:500;border:1px solid var(--border-color)}.blog-tag svg{opacity:.7}.blog-tag-more{padding:.375rem .75rem;background:var(--subtle-bg-color);color:var(--light-text-color);border-radius:8px;font-size:.75rem;font-style:italic;border:1px solid var(--border-color)}.blog-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.blog-meta{display:flex;gap:1rem;flex:1}.blog-author,.blog-date{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--light-text-color);font-weight:500}.blog-author svg,.blog-date svg{opacity:.7}.read-more-btn{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--primary-color);font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1)}.read-more-btn:hover{gap:.625rem;color:var(--primary-color)}.no-results{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.no-results-icon{font-size:3rem;opacity:.5;margin-bottom:1rem}.no-results h3{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.no-results p{margin-bottom:2rem;font-size:1rem}.reset-filters-btn{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease}.reset-filters-btn:hover{background:var(--primary-hover)}@media (max-width: 768px){.blog-screen{padding:1rem}.blog-header{padding:1.5rem 1rem;margin-bottom:2rem}.blog-header h1{font-size:2rem}.blog-header p{font-size:1rem}.search-container{max-width:100%}.blog-grid{grid-template-columns:1fr;gap:1.25rem}.category-filters{gap:.5rem;padding:.75rem}.filter-btn{font-size:.75rem;padding:.5rem .875rem}.blog-stats{gap:1.5rem;flex-wrap:wrap;padding:1rem}.stats-number{font-size:1.75rem}.blog-card{padding:1.25rem}.blog-title{font-size:1.2rem}.blog-meta{flex-direction:column;gap:.5rem}.blog-card-footer{flex-direction:column;gap:1rem;align-items:flex-start}}.blog-post-container{max-width:800px;margin:0 auto;padding:2rem 1rem}.blog-post-header{margin-bottom:3rem}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;margin-bottom:2rem}.back-btn:hover{background:var(--hover-bg);border-color:var(--primary);color:var(--primary)}.blog-post-category{display:inline-block;padding:.5rem 1rem;background:var(--primary-alpha);color:var(--primary);border-radius:2rem;font-size:.875rem;font-weight:600;text-transform:uppercase;margin-bottom:1rem}.blog-post-title{font-size:2.5rem;font-weight:700;color:var(--text-primary);line-height:1.2;margin-bottom:1.5rem}.blog-post-meta{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.meta-item{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.meta-item svg{opacity:.7}.share-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;margin-left:auto}.share-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}.blog-post-tags{display:flex;flex-wrap:wrap;gap:.5rem}.blog-post-tag{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:var(--bg-secondary);color:var(--text-secondary);border-radius:1rem;font-size:.875rem}.blog-post-tag svg{opacity:.6}.blog-post-content{line-height:1.7;color:var(--text-primary);margin-bottom:3rem}.blog-post-content h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin:2rem 0 1rem;line-height:1.3}.blog-post-content h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:1.5rem 0 .75rem;line-height:1.4}.blog-post-content h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:1.25rem 0 .5rem;line-height:1.4}.blog-post-content p{margin-bottom:1rem;color:var(--text-primary)}.blog-post-content ul{margin:1rem 0;padding-left:0;list-style:none}.blog-post-content li{margin-bottom:.5rem;padding-left:1.5rem;position:relative;color:var(--text-primary)}.blog-post-content li:before{content:"•";color:var(--primary);font-size:1.2rem;font-weight:700;position:absolute;left:.5rem}.blog-post-content strong{font-weight:600;color:var(--text-primary)}.blog-post-content em{font-style:italic;color:var(--text-secondary)}.blog-post-content blockquote{margin:1.5rem 0;padding:1rem 1.5rem;background:var(--card-bg);border-left:4px solid var(--primary);border-radius:.5rem;color:var(--text-secondary);font-style:italic}.blog-post-content code{background:var(--code-bg, var(--bg-secondary));color:var(--code-text, var(--primary));padding:.2rem .4rem;border-radius:.25rem;font-size:.875rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.blog-post-not-found{text-align:center;padding:4rem 2rem}.blog-post-not-found h1{font-size:2rem;color:var(--text-primary);margin-bottom:1rem}.blog-post-not-found p{color:var(--text-secondary);margin-bottom:2rem;font-size:1.1rem}.back-to-blogs-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease}.back-to-blogs-btn:hover{background:var(--primary-hover)}.related-posts{margin-top:4rem;padding-top:2rem;border-top:2px solid var(--border-color)}.related-posts h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:2rem;text-align:center}.related-posts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.related-post-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;cursor:pointer;transition:all .3s ease}.related-post-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px var(--shadow-color);border-color:var(--primary)}.related-post-category{display:inline-block;padding:.25rem .75rem;background:var(--primary-alpha);color:var(--primary);border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;margin-bottom:.75rem}.related-post-title{font-size:1rem;font-weight:600;color:var(--text-primary);line-height:1.4;margin-bottom:.5rem}.related-post-excerpt{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.related-post-meta{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary);font-size:.75rem}.related-post-meta svg{opacity:.7}@media (max-width: 768px){.blog-post-container{padding:1rem}.blog-post-title{font-size:2rem}.blog-post-content h1{font-size:1.75rem}.blog-post-content h2{font-size:1.375rem}.blog-post-content h3{font-size:1.125rem}.blog-post-meta{gap:1rem}.share-btn{margin-left:0;width:100%;justify-content:center}.related-posts-grid{grid-template-columns:1fr}.related-post-card{padding:1rem}}.subscription-success-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;position:relative;overflow:hidden}.success-card{background:#fff;border-radius:20px;padding:60px 40px;max-width:600px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.success-icon-wrapper{position:relative;display:inline-block;margin-bottom:30px}.success-icon{width:100px;height:100px;color:#10b981;animation:scaleIn .5s ease-out}.sparkle-icon{position:absolute;width:24px;height:24px;color:#fbbf24;animation:sparkle 1.5s ease-in-out infinite}.sparkle-1{top:-10px;right:-10px;animation-delay:0s}.sparkle-2{bottom:-10px;left:-10px;animation-delay:.5s}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0)}50%{opacity:.5;transform:scale(1.2) rotate(180deg)}}.success-title{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:16px;line-height:1.2}.success-subtitle{font-size:18px;color:#6b7280;margin-bottom:40px;line-height:1.6}.subscription-details{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:12px;padding:24px;margin-bottom:30px;border:2px solid rgba(102,126,234,.2)}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(102,126,234,.1)}.detail-item:last-child{border-bottom:none}.detail-label{font-size:14px;color:#6b7280;font-weight:500}.detail-value{font-size:16px;color:#1f2937;font-weight:600}.payment-id{font-family:Courier New,monospace;font-size:14px;background:#667eea1a;padding:4px 8px;border-radius:4px}.features-unlocked{text-align:left;margin:30px 0;background:#f9fafb;padding:24px;border-radius:12px}.features-unlocked h3{font-size:18px;color:#1f2937;margin-bottom:16px;font-weight:600}.features-unlocked ul{list-style:none;padding:0;margin:0}.features-unlocked li{font-size:14px;color:#4b5563;padding:8px 0;line-height:1.5}.receipt-actions{margin:20px 0}.receipt-button{background:#fff;border:2px solid #667eea;color:#667eea;padding:12px 24px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease}.receipt-button:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.share-section{margin:30px 0;position:relative}.share-toggle-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:14px 28px;font-size:15px;font-weight:600;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.share-toggle-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.share-menu{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:20px;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.share-button{display:flex;align-items:center;gap:8px;padding:12px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;color:#fff}.share-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.share-button.whatsapp{background:#25d366}.share-button.twitter{background:#1da1f2}.share-button.facebook{background:#4267b2}.share-button.linkedin{background:#0077b5}.share-button.copy{background:#6b7280}.success-actions{margin-top:40px}.primary-action-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;font-size:16px;font-weight:600;border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;box-shadow:0 4px 12px #667eea66}.primary-action-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.primary-action-button:active{transform:translateY(0)}.redirect-notice{margin-top:16px;font-size:14px;color:#6b7280}.receipt-notice{margin-top:30px;padding:16px;background:#3b82f61a;border-radius:8px;color:#1e40af;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px}.confetti{position:fixed;width:10px;height:10px;border-radius:50%;top:-10px;z-index:9999;animation:fall linear forwards}@keyframes fall{to{transform:translateY(100vh) rotate(360deg);opacity:0}}@media (max-width: 768px){.success-card{padding:40px 24px}.success-title{font-size:24px}.success-subtitle{font-size:16px}.success-icon{width:80px;height:80px}.features-unlocked li{font-size:13px}.primary-action-button{width:100%;justify-content:center}.share-menu{grid-template-columns:1fr}.share-button{justify-content:center}}@media (max-width: 480px){.subscription-success-container{padding:12px}.success-card{padding:30px 20px}.success-title{font-size:20px}.detail-value{font-size:14px}.payment-id{font-size:12px}.receipt-button,.share-toggle-button{width:100%;justify-content:center}}.guest-checkout-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.checkout-box{background:#fff;border-radius:16px;padding:2.5rem;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;position:relative}.checkout-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.checkout-heading{flex:1;display:flex;flex-direction:column;align-items:center}.checkout-title{font-size:2rem;font-weight:700;color:#1a202c;margin-bottom:.5rem;text-align:center}.checkout-subtitle{font-size:1rem;color:#718096;text-align:center;margin:.25rem 0 0}.plan-summary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.plan-summary h3{font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;opacity:.9}.plan-details{display:flex;justify-content:space-between;align-items:center}.plan-duration{font-size:1.25rem;font-weight:600}.plan-price{font-size:1.75rem;font-weight:700}.discount-badge{display:inline-block;background:#4caf5033;color:#2e7d32;padding:.35rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;margin-left:auto;margin-top:-.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.savings-badge-small{display:inline-block;background:#fff3;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;margin-top:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.checkout-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label .validating-indicator{font-size:.75rem;color:#ed8936;font-weight:500;margin-left:.5rem}.form-group input,.form-group select{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s;background:#fff}.form-group input.error,.form-group select.error{border-color:#f56565}.form-group input.success{border-color:#48bb78}.form-group input:disabled,.form-group select:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.error-message{color:#f56565;font-size:.875rem;margin-top:-.25rem}.coupon-message{font-size:.875rem;margin-top:.25rem;font-weight:500;display:flex;align-items:center;gap:.35rem}.coupon-message.success{color:#2e7d32}.coupon-message.error{color:#c62828}.pay-now-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.125rem;font-weight:600;padding:1rem;border:none;border-radius:8px;cursor:pointer;transition:all .2s;margin-top:.5rem}.pay-now-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.pay-now-btn:active:not(:disabled){transform:translateY(0)}.pay-now-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.checkout-footer{margin-top:2rem;text-align:center}.secure-note{color:#718096;font-size:.875rem;margin-bottom:1rem}.login-prompt{color:#4a5568;font-size:.875rem}.link-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.link-button:hover{color:#764ba2}.back-btn{background:none;border:none;font-size:1rem;color:#667eea;cursor:pointer;padding:.5rem;display:flex;align-items:center;gap:.25rem;font-weight:600;transition:all .2s;margin-right:auto}.back-btn:hover{color:#764ba2;transform:translate(-4px)}@media (max-width: 640px){.checkout-box{padding:2rem 1.5rem}.checkout-header{flex-direction:column;align-items:stretch;gap:.75rem}.checkout-heading{align-items:center}.checkout-title,.plan-price{font-size:1.5rem}.back-btn{align-self:flex-start;padding-left:0}}.checkout-success-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem 1rem;background:linear-gradient(135deg,#10b981,#059669)}.success-content{text-align:center;color:#fff}.success-icon-large{width:120px;height:120px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;display:flex;align-items:center;justify-content:center;font-size:4rem;margin:0 auto 2rem;animation:scaleIn .5s ease-out;border:4px solid rgba(255,255,255,.3)}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-title-large{font-size:3rem;font-weight:700;margin-bottom:1rem}.success-subtitle-large{font-size:1.5rem;opacity:.9;margin-bottom:3rem}.loading-spinner{font-size:1.125rem;opacity:.8;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.password-modal{background:#fff;border-radius:20px;padding:2.5rem;max-width:480px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 70px #0006;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{text-align:center;margin-bottom:2rem}.modal-header h2{font-size:1.75rem;font-weight:700;color:#1a202c;margin-bottom:.5rem}.modal-header p{font-size:1rem;color:#718096}.modal-form{display:flex;flex-direction:column;gap:1.25rem}.form-group-readonly{display:flex;flex-direction:column;gap:.5rem}.form-group-readonly label{font-size:.875rem;font-weight:600;color:#4a5568}.form-group-readonly input{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;background:#f7fafc;color:#4a5568;cursor:not-allowed}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:#2d3748}.form-group input{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-group input:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.error-banner{background:#fee;border:2px solid #f56565;color:#c53030;padding:.875rem 1rem;border-radius:10px;font-size:.875rem;text-align:center;font-weight:500}.modal-btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:1.125rem;font-weight:600;padding:1rem;border:none;border-radius:10px;cursor:pointer;transition:all .2s;margin-top:.5rem}.modal-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #10b98166}.modal-btn-primary:active:not(:disabled){transform:translateY(0)}.modal-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-btn-secondary{background:transparent;border:2px solid #e2e8f0;color:#718096;font-size:1rem;font-weight:500;padding:.875rem;border-radius:10px;cursor:pointer;transition:all .2s}.modal-btn-secondary:hover:not(:disabled){border-color:#cbd5e0;background:#f7fafc}.modal-btn-secondary:disabled{opacity:.5;cursor:not-allowed}.success-modal{text-align:center;padding:3rem 2.5rem}.success-modal .success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;align-items:center;justify-content:center;font-size:3rem;margin:0 auto 1.5rem;animation:scaleIn .5s ease-out}.success-modal h2{font-size:2rem;font-weight:700;color:#1a202c;margin-bottom:.5rem}.success-modal p{font-size:1.125rem;color:#718096}@media (max-width: 640px){.success-title-large{font-size:2rem}.success-subtitle-large{font-size:1.125rem}.success-icon-large{width:100px;height:100px;font-size:3rem}.password-modal{padding:2rem 1.5rem}.modal-header h2{font-size:1.5rem}}.coupon-management-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;display:flex;align-items:center;justify-content:center}.login-box{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;max-width:400px;width:100%}.login-box h1{text-align:center;color:#333;margin-bottom:10px;font-size:32px}.login-subtitle{text-align:center;color:#666;margin-bottom:30px;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-group input,.form-group select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:all .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease;margin-top:10px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button:disabled{opacity:.6;cursor:not-allowed}.back-button{background:transparent;color:#666;border:none;padding:10px;margin-top:20px;cursor:pointer;font-size:14px;transition:color .2s ease}.back-button:hover{color:#667eea}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px;text-align:center}.coupon-management-content{background:#fff;border-radius:20px;padding:40px;max-width:1200px;width:100%;box-shadow:0 20px 60px #0000004d}.header-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.header-section h1{color:#333;font-size:32px;margin:0}.header-actions{display:flex;gap:10px}.add-coupon-button{background:#10b981;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-coupon-button:hover{background:#059669;transform:translateY(-2px)}.logout-button{background:#ef4444;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#dc2626;transform:translateY(-2px)}.success-message{background:#d1fae5;color:#065f46;padding:16px;border-radius:8px;margin-bottom:20px;text-align:center;font-weight:600}.add-coupon-form{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:30px;margin-bottom:30px}.add-coupon-form h2{color:#333;margin-top:0;margin-bottom:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;margin-top:20px}.submit-button{background:#667eea;color:#fff;border:none;padding:12px 32px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.submit-button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.coupons-list h2{color:#333;margin-bottom:20px}.loading{text-align:center;padding:40px;color:#666;font-size:16px}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state p{font-size:16px;margin:0}.coupons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.coupon-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .3s ease}.coupon-card:hover{border-color:#667eea;box-shadow:0 10px 30px #667eea1a;transform:translateY(-2px)}.coupon-card.disabled{opacity:.6;background:#f9fafb}.coupon-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.coupon-header h3{margin:0;color:#333;font-size:24px;font-weight:700}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.coupon-description{color:#666;margin-bottom:16px;font-size:14px}.coupon-details{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.detail-item{display:flex;justify-content:space-between;align-items:center;font-size:14px}.detail-item .label{color:#666;font-weight:500}.detail-item .value{color:#333;font-weight:600}.toggle-button{width:100%;padding:10px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.toggle-button.disable{background:#fee2e2;color:#991b1b}.toggle-button.disable:hover:not(:disabled){background:#fecaca}.toggle-button.enable{background:#d1fae5;color:#065f46}.toggle-button.enable:hover:not(:disabled){background:#a7f3d0}.toggle-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.coupon-management-container{padding:10px}.login-box,.coupon-management-content{padding:20px}.header-section{flex-direction:column;align-items:flex-start}.header-actions{width:100%;flex-direction:column}.header-actions button{width:100%}.form-row,.coupons-grid{grid-template-columns:1fr}.add-coupon-form{padding:20px}}.mobile-menu-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:1001;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.mobile-menu-backdrop.open{opacity:1;visibility:visible}.mobile-menu{position:fixed;top:0;right:0;width:280px;height:100%;background-color:var(--surface-color);z-index:1002;box-shadow:-4px 0 15px #00000026;transform:translate(100%);transition:transform .3s ease-out;display:flex;flex-direction:column}.mobile-menu.open{transform:translate(0)}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.mobile-menu-header h3{font-size:1.2rem;font-weight:600}.header-buttons{display:flex;align-items:center;gap:.5rem}.close-menu-btn{background:none;border:none;font-size:2.5rem;line-height:1;color:var(--light-text-color);cursor:pointer;padding:0}.mobile-menu-links{list-style:none;padding:1rem 0;margin:0;flex-grow:1}.mobile-menu-links button{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem 1.5rem;background:none;border:none;text-align:left;font-size:1.1rem;font-family:var(--font-family);cursor:pointer;color:var(--text-color);transition:background-color .2s}.mobile-menu-links button:hover{background-color:var(--subtle-bg-color)}.mobile-menu-links img{width:24px;height:24px;opacity:.7}.logout-btn{padding:.5rem .75rem;border:none;border-radius:var(--border-radius);font-family:var(--font-family);font-size:.9rem;font-weight:600;cursor:pointer;background-color:var(--danger-color);color:#fff;text-align:center;white-space:nowrap}.logout-btn:hover{opacity:.9}.global-footer{background-color:var(--surface-color);border-top:1px solid var(--border-color);padding:1rem 0;width:100%;flex-shrink:0;z-index:20}.footer-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.footer-contact{font-size:.85rem;color:var(--light-text-color);font-weight:500}.footer-contact a{color:var(--primary-color);font-weight:600;text-decoration:none;margin-left:.25rem}.footer-contact a:hover,.footer-contact a:focus{text-decoration:underline}.copyright-text{font-size:.875rem;color:var(--light-text-color);font-weight:500}.made-in-india{font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.25rem;flex-wrap:wrap;justify-content:center}.made-text,.love-text{color:#ff6b35}.heart{color:#e74c3c;font-size:1rem;margin:0 .1rem}.in-text{color:#138808}.india-text{color:#138808;font-weight:700}@media (max-width: 768px){.footer-content{padding:0 .75rem;gap:.375rem}.copyright-text,.made-in-india,.footer-contact{font-size:.8rem}.heart{font-size:.9rem}}@media (max-width: 480px){.global-footer{padding:.75rem 0}.footer-content{padding:0 .5rem}.copyright-text,.made-in-india,.footer-contact{font-size:.75rem}.made-in-india{gap:.2rem}}.dark-theme .copyright-text{color:var(--light-text-color)}.pwa-install-prompt{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px;box-shadow:0 -4px 12px #00000026;z-index:10000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pwa-install-prompt__close{position:absolute;top:8px;right:8px;background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.pwa-install-prompt__close:hover{background:#ffffff4d}.pwa-install-prompt__content{display:flex;align-items:center;gap:12px;max-width:600px;margin:0 auto}.pwa-install-prompt__icon{flex-shrink:0;width:48px;height:48px;background:#fff;border-radius:12px;padding:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.pwa-install-prompt__logo{width:100%;height:100%;background-size:contain;background-repeat:no-repeat;background-position:center}.pwa-install-prompt__text{flex:1;min-width:0}.pwa-install-prompt__text h3{margin:0 0 4px;font-size:16px;font-weight:600;line-height:1.3}.pwa-install-prompt__text p{margin:0;font-size:13px;opacity:.95;line-height:1.4}.pwa-install-prompt__button{flex-shrink:0;background:#fff;color:#667eea;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 8px #0000001a}.pwa-install-prompt__button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.pwa-install-prompt__button:active{transform:translateY(0)}@media (max-width: 480px){.pwa-install-prompt{padding:12px}.pwa-install-prompt__content{gap:10px}.pwa-install-prompt__icon{width:40px;height:40px;padding:6px}.pwa-install-prompt__text h3{font-size:14px}.pwa-install-prompt__text p{font-size:12px}.pwa-install-prompt__button{padding:8px 16px;font-size:13px}}.dark-mode .pwa-install-prompt{background:linear-gradient(135deg,#4338ca,#5b21b6)}.dark-mode .pwa-install-prompt__icon{background:#fffffff2}.dark-mode .pwa-install-prompt__button{background:#fffffff2;color:#4338ca}.dark-mode .pwa-install-prompt__close{background:#ffffff26}.dark-mode .pwa-install-prompt__close:hover{background:#ffffff40}.app-container{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(135deg,#e0f7fa,#d1c4e9);max-width:100vw}.main-content{flex:1;display:flex;flex-direction:column;min-height:0}.page-container{height:100%;width:100%;overflow-y:auto;background-color:var(--background-color)}@media (max-width: 768px){.app-container{height:100vh}}@media (max-width: 480px){.app-container{height:100vh}}.app-toast{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:var(--toast-bg, #333);color:#fff;padding:12px 18px;border-radius:8px;box-shadow:0 4px 12px #00000040;font-family:var(--font-family);font-size:.95rem;font-weight:500;display:flex;align-items:center;gap:8px;z-index:1000;animation:fadeInUp .25s ease;max-width:90%;line-height:1.3;letter-spacing:-.005em}.app-toast-success{--toast-bg: #2e7d32}.app-toast-error{--toast-bg: #c62828}.app-toast-info{--toast-bg: #1565c0}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}@media (prefers-color-scheme: light){.app-toast{color:#fff}}.policy-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg-color);border-top:1px solid var(--border-color);padding:.75rem 1rem;display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;z-index:999;box-shadow:0 -4px 16px #0000000d}.policy-banner__text{font-size:.9rem;flex:1 1 200px;color:var(--text-color)}.policy-banner__actions{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.policy-banner__button{padding:.4rem .8rem;border-radius:6px;font-size:.85rem;font-weight:500;width:auto;min-height:unset}.policy-banner__button.mini-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-color);transition:background-color .2s ease,color .2s ease,border-color .2s ease}.policy-banner__button.mini-btn:hover{background:var(--hover-color)}.policy-banner__button--primary{padding:.45rem .9rem;background:var(--primary-color);color:#fff;border:none;transition:filter .2s ease}.policy-banner__button--primary:hover{filter:brightness(.95)}@media (max-width: 600px){.policy-banner{align-items:flex-start}.policy-banner__actions{width:100%;justify-content:flex-start}}
