*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-dark:#1b2e4b;--blue-mid:#2d9cdb;--blue-light:#e8f4fb;--yellow:#f4a535;--yellow-dark:#d4891a;--white:#fff;--grey-100:#f7f9fc;--grey-200:#e4e8ee;--grey-400:#b0b7c3;--grey-600:#6b7280;--grey-800:#374151;--text:#1a1a2e;--radius:12px;--radius-sm:6px;--shadow:0 2px 12px #1a2f5e1a;--shadow-md:0 4px 24px #1a2f5e26;--transition:.2s ease;--max-width:1200px}html{scroll-behavior:smooth;font-size:16px}body{color:var(--text);background:var(--white);-webkit-font-smoothing:antialiased;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}img{max-width:100%;display:block}input,textarea,select{font-family:inherit}.navbar{background:var(--white);border-bottom:1px solid var(--grey-200);z-index:100;box-shadow:var(--shadow);position:sticky;top:0}.navbar__inner{max-width:var(--max-width);align-items:center;gap:32px;height:64px;margin:0 auto;padding:0 24px;display:flex}.navbar__logo{color:var(--blue-dark);letter-spacing:-.5px;flex-shrink:0;font-size:1.5rem;font-weight:800}.navbar__logo span{color:var(--yellow)}.navbar__links{flex:1;gap:4px;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--grey-600);transition:background var(--transition), color var(--transition);padding:6px 14px;font-size:.95rem;font-weight:500}.nav-link:hover{background:var(--blue-light);color:var(--blue-dark)}.nav-link.active{background:var(--blue-light);color:var(--blue-mid);font-weight:600}.navbar__actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.btn{border-radius:var(--radius-sm);transition:all var(--transition);white-space:nowrap;justify-content:center;align-items:center;padding:8px 20px;font-size:.9rem;font-weight:600;display:inline-flex}.btn--ghost{color:var(--blue-dark);border:1.5px solid var(--grey-200);background:0 0}.btn--ghost:hover{border-color:var(--blue-mid);color:var(--blue-mid)}.btn--primary{background:var(--blue-dark);color:var(--white);border:1.5px solid #0000}.btn--primary:hover{background:var(--blue-mid)}.btn--yellow{background:var(--yellow);color:var(--blue-dark);border:1.5px solid #0000;font-weight:700}.btn--yellow:hover{background:var(--yellow-dark)}.btn--lg{border-radius:var(--radius);padding:14px 32px;font-size:1.05rem}.navbar__user{color:var(--grey-600);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.88rem;font-weight:600;overflow:hidden}@media (width<=600px){.navbar__links,.navbar__actions .btn--ghost{display:none}}.footer{background:var(--blue-dark);color:#ffffffbf;margin-top:auto}.footer__inner{max-width:var(--max-width);flex-wrap:wrap;justify-content:space-between;gap:48px;margin:0 auto;padding:56px 24px 40px;display:flex}.footer__brand{flex:1;min-width:220px}.footer__logo{color:var(--white);letter-spacing:-.5px;margin-bottom:10px;font-size:1.5rem;font-weight:800;display:block}.footer__brand p{max-width:280px;font-size:.9rem;line-height:1.6}.footer__links{gap:48px;display:flex}.footer__col{flex-direction:column;gap:10px;display:flex}.footer__col h4{color:var(--white);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;font-size:.85rem;font-weight:700}.footer__col a{transition:color var(--transition);font-size:.9rem}.footer__col a:hover{color:var(--yellow)}.footer__bottom{text-align:center;border-top:1px solid #ffffff1a;padding:20px 24px;font-size:.85rem}@media (width<=600px){.footer__inner{flex-direction:column;gap:32px;padding:40px 24px 32px}.footer__links{gap:32px}}.site-wrapper{flex-direction:column;min-height:100vh;display:flex}.site-main{flex:1}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}.section-inner{max-width:var(--max-width);margin:0 auto;padding:0 24px}.section-header{text-align:center;margin-bottom:48px}.section-header h2{color:var(--blue-dark);margin-bottom:10px;font-size:2rem;font-weight:800}.section-header p{color:var(--grey-600);font-size:1.05rem}.hero{background:linear-gradient(135deg, var(--blue-dark) 0%, var(--blue-mid) 100%);color:var(--white);align-items:center;gap:64px;max-width:100%;padding:80px 24px;display:flex;overflow:hidden}.hero__inner{flex:1;max-width:580px;margin:0 auto;padding:0 24px}.hero__badge{color:var(--yellow);background:#f5c84226;border:1px solid #f5c84266;border-radius:999px;margin-bottom:24px;padding:6px 14px;font-size:.85rem;font-weight:600;display:inline-block}.hero__headline{letter-spacing:-1px;margin-bottom:20px;font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.15}.highlight{color:var(--yellow)}.hero__sub{color:#fffc;max-width:480px;margin-bottom:36px;font-size:1.1rem;line-height:1.7}.hero__cta{flex-wrap:wrap;gap:14px;display:flex}.hero__cta .btn--ghost{color:var(--white);border-color:#ffffff59}.hero__cta .btn--ghost:hover{border-color:var(--white);background:#ffffff14}.hero__visual{flex:1;max-width:400px;margin:0 auto;padding:0 24px}.chat-preview{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);flex-direction:column;gap:16px;padding:24px;display:flex}.chat-preview__msg{border-radius:var(--radius);max-width:85%;padding:12px 16px;font-size:.9rem;line-height:1.5}.chat-preview__msg--user{background:var(--blue-light);color:var(--blue-dark);border-bottom-right-radius:4px;align-self:flex-end}.chat-preview__msg--tutor{background:var(--grey-100);color:var(--text);border-bottom-left-radius:4px;align-self:flex-start}.tutor-label{color:var(--blue-mid);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.72rem;font-weight:700;display:block}.features{background:var(--grey-100);padding:96px 0}.features__grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;display:grid}.feature-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);transition:transform var(--transition), box-shadow var(--transition);padding:32px 28px}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.feature-card__icon{margin-bottom:16px;font-size:2rem}.feature-card h3{color:var(--blue-dark);margin-bottom:8px;font-size:1.1rem;font-weight:700}.feature-card p{color:var(--grey-600);font-size:.9rem;line-height:1.6}.pricing{padding:96px 0}.pricing__grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:760px;margin:0 auto;display:grid}.pricing-card{border:2px solid var(--grey-200);border-radius:var(--radius);transition:box-shadow var(--transition);padding:36px 32px;position:relative}.pricing-card:hover{box-shadow:var(--shadow-md)}.pricing-card--featured{border-color:var(--blue-mid);box-shadow:var(--shadow-md)}.pricing-card__badge{background:var(--yellow);color:var(--blue-dark);white-space:nowrap;border-radius:999px;padding:4px 16px;font-size:.8rem;font-weight:700;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.pricing-card__header{margin-bottom:28px}.pricing-card__header h3{color:var(--blue-dark);margin-bottom:10px;font-size:1.3rem;font-weight:700}.pricing-card__price{align-items:baseline;gap:4px;display:flex}.price-amount{color:var(--blue-dark);font-size:2.4rem;font-weight:800}.price-period{color:var(--grey-600);font-size:.9rem}.pricing-card__features{flex-direction:column;gap:12px;margin-bottom:32px;list-style:none;display:flex}.pricing-card__features li{color:var(--grey-800);font-size:.92rem}.pricing-card__cta{text-align:center;width:100%}.cta-banner{background:var(--blue-dark);color:var(--white);text-align:center;padding:80px 24px}.cta-banner .section-inner{flex-direction:column;align-items:center;gap:16px;display:flex}.cta-banner h2{color:var(--white);font-size:2rem;font-weight:800}.cta-banner p{color:#ffffffbf;margin-bottom:8px;font-size:1.05rem}@media (width<=900px){.hero{text-align:center;flex-direction:column;padding:60px 0}.hero__sub{margin-left:auto;margin-right:auto}.hero__cta{justify-content:center}.hero__visual{width:100%;max-width:100%}.hero__inner{max-width:100%}}@media (width<=600px){.features,.pricing{padding:64px 0}.section-header h2{font-size:1.6rem}}.dashboard{background:var(--grey-100);min-height:calc(100vh - 64px);padding:40px 0 80px}.dashboard__inner{max-width:var(--max-width);flex-direction:column;gap:48px;margin:0 auto;padding:0 24px;display:flex}.dashboard__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.dashboard__header h1{color:var(--blue-dark);margin-bottom:4px;font-size:1.8rem;font-weight:800}.dashboard__header p{color:var(--grey-600);font-size:1rem}.dashboard__section h2{color:var(--blue-dark);margin-bottom:20px;font-size:1.2rem;font-weight:700}.subjects-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.subject-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border-top:4px solid var(--card-color,var(--blue-mid));transition:transform var(--transition), box-shadow var(--transition);flex-direction:column;gap:8px;padding:28px 24px;display:flex}.subject-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.subject-card__icon{margin-bottom:4px;font-size:1.8rem}.subject-card h3{color:var(--blue-dark);font-size:1.05rem;font-weight:700}.subject-card p{color:var(--grey-600);flex:1;font-size:.85rem;line-height:1.5}.subject-card__cta{color:var(--blue-mid);margin-top:8px;font-size:.85rem;font-weight:600}.activity-list{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.activity-item{border-bottom:1px solid var(--grey-200);align-items:center;gap:16px;padding:16px 24px;display:flex}.activity-item:last-child{border-bottom:none}.activity-item__dot{background:var(--blue-mid);border-radius:50%;flex-shrink:0;width:10px;height:10px}.activity-item__content{flex-direction:column;flex:1;gap:2px;display:flex}.activity-item__subject{color:var(--blue-mid);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:700}.activity-item__topic{color:var(--text);font-size:.92rem}.activity-item__time{color:var(--grey-400);white-space:nowrap;font-size:.82rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;display:grid}.stat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;flex-direction:column;align-items:center;gap:6px;padding:24px;display:flex}.stat-card__number{color:var(--blue-dark);font-size:2rem;font-weight:800}.stat-card__label{color:var(--grey-600);font-size:.82rem}@media (width<=600px){.dashboard__header{flex-direction:column;align-items:flex-start}.subjects-grid{grid-template-columns:repeat(2,1fr)}}.tutor{background:var(--grey-100);flex-direction:column;height:calc(100vh - 64px);display:flex}.tutor__header{background:var(--white);border-bottom:1px solid var(--grey-200);box-shadow:var(--shadow);flex-shrink:0}.tutor__header-inner{justify-content:space-between;align-items:center;gap:16px;max-width:800px;margin:0 auto;padding:14px 24px;display:flex}.tutor__title{align-items:center;gap:10px;display:flex}.tutor__title-icon{font-size:1.4rem;line-height:1}.tutor__title h1{color:var(--blue-dark);margin:0;font-size:1.15rem;font-weight:700}.tutor__new-chat{white-space:nowrap;padding:7px 16px;font-size:.85rem}.tutor__chat{flex-direction:column;flex:1;width:100%;max-width:800px;min-height:0;margin:0 auto;padding:0 24px;display:flex}.chat-messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:18px;padding:28px 0 16px;display:flex;overflow-y:auto}.chat-msg{align-items:flex-end;gap:10px;animation:.18s msg-in;display:flex}@keyframes msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-msg--user{flex-direction:row-reverse}.chat-msg__avatar{background:var(--blue-dark);width:34px;height:34px;color:var(--white);-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;display:flex}.chat-msg__bubble{border-radius:18px;max-width:68%;padding:12px 16px;font-size:.94rem;line-height:1.65}.chat-msg--assistant .chat-msg__bubble{background:var(--white);color:var(--text);box-shadow:var(--shadow);border-bottom-left-radius:4px}.chat-msg--user .chat-msg__bubble{background:var(--blue-dark);color:var(--white);border-bottom-right-radius:4px}.chat-markdown{display:contents}.chat-markdown p{margin:0 0 .5em}.chat-markdown p:last-child{margin-bottom:0}.chat-markdown h1,.chat-markdown h2,.chat-markdown h3{color:var(--blue-dark);margin:.75em 0 .25em;font-size:1rem;font-weight:700}.chat-markdown h1:first-child,.chat-markdown h2:first-child,.chat-markdown h3:first-child{margin-top:0}.chat-markdown ul,.chat-markdown ol{margin:.4em 0 .5em;padding-left:1.4em}.chat-markdown li{margin-bottom:.2em}.chat-markdown code{background:#00000012;border-radius:3px;padding:1px 5px;font-family:ui-monospace,monospace;font-size:.88em}.chat-markdown pre{border-radius:var(--radius-sm);background:#00000012;margin:.5em 0;padding:10px 12px;overflow-x:auto}.chat-markdown pre code{background:0 0;padding:0;font-size:.85em}.chat-markdown strong{font-weight:700}.chat-markdown em{font-style:italic}.chat-markdown blockquote{border-left:3px solid var(--grey-400);color:var(--grey-600);margin:.5em 0;padding:2px 0 2px 12px}.chat-msg--user .chat-markdown code,.chat-msg--user .chat-markdown pre{background:#ffffff26}.chat-msg--user .chat-markdown h1,.chat-msg--user .chat-markdown h2,.chat-msg--user .chat-markdown h3{color:var(--white)}.chat-msg__bubble--typing{align-items:center;gap:5px;min-width:60px;padding:15px 18px;display:flex}.chat-msg__bubble--typing span{background:var(--grey-400);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite typing-bounce}.chat-msg__bubble--typing span:nth-child(2){animation-delay:.2s}.chat-msg__bubble--typing span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{opacity:.6;transform:translateY(0)}30%{opacity:1;transform:translateY(-7px)}}.tutor__error{color:#b91c1c;border-radius:var(--radius-sm);background:#fff0f0;border:1px solid #fca5a5;margin-bottom:8px;padding:10px 14px;font-size:.85rem}.tutor__input-bar{border-top:1px solid var(--grey-200);background:var(--grey-100);flex-shrink:0;align-items:flex-end;gap:10px;padding:14px 0 22px;display:flex}.tutor__input{resize:none;border:1.5px solid var(--grey-200);border-radius:var(--radius);background:var(--white);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);field-sizing:content;flex:1;max-height:140px;padding:12px 16px;font-size:.95rem;line-height:1.5;overflow-y:auto}.tutor__input:focus{border-color:var(--blue-mid);outline:none;box-shadow:0 0 0 3px #2d9cdb24}.tutor__input:disabled{opacity:.6;cursor:not-allowed}.tutor__send{border-radius:var(--radius);flex-shrink:0;align-items:center;gap:7px;padding:12px 20px;font-size:.92rem;display:flex}.tutor__send:disabled{opacity:.4;cursor:not-allowed}.tutor__limit-reached{text-align:center;border-top:2px solid var(--yellow);background:var(--white);flex-direction:column;flex-shrink:0;align-items:center;gap:12px;padding:28px 24px 24px;display:flex}.tutor__limit-icon{font-size:2.4rem;line-height:1}.tutor__limit-reached h3{color:var(--blue-dark);margin:0;font-size:1.1rem;font-weight:700}.tutor__limit-reached p{color:var(--grey-600);max-width:420px;margin:0;font-size:.92rem;line-height:1.6}.tutor__upgrade-btn{margin-top:4px}.tutor__limit-reset{color:var(--grey-400);font-size:.8rem}.tutor__not-found{height:100%;color:var(--grey-600);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}@media (width<=600px){.tutor__chat{padding:0 16px}.chat-msg__bubble{max-width:82%}.tutor__send span{display:none}.tutor__send{padding:12px 14px}}.auth-page{background:var(--grey-100);justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:40px 24px;display:flex}.auth-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;max-width:440px;padding:48px 40px}.auth-logo{color:var(--blue-dark);letter-spacing:-.5px;margin-bottom:28px;font-size:1.5rem;font-weight:800;display:inline-block}.auth-card h1{color:var(--blue-dark);margin-bottom:6px;font-size:1.6rem;font-weight:800}.auth-sub{color:var(--grey-600);margin-bottom:32px;font-size:.95rem}.auth-error{color:#b91c1c;border-radius:var(--radius-sm);background:#fff0f0;border:1px solid #fca5a5;margin-bottom:8px;padding:10px 14px;font-size:.88rem}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--grey-800);justify-content:space-between;align-items:center;font-size:.88rem;font-weight:600;display:flex}.form-group input,.form-group select{border:1.5px solid var(--grey-200);border-radius:var(--radius-sm);color:var(--text);background:var(--white);transition:border-color var(--transition), box-shadow var(--transition);width:100%;padding:11px 14px;font-size:.95rem}.form-group select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236c757d' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.form-group input:focus,.form-group select:focus{border-color:var(--blue-mid);outline:none;box-shadow:0 0 0 3px #2e4fa31f}.form-link{color:var(--blue-mid);transition:color var(--transition);font-size:.85rem;font-weight:600}.form-link:hover{color:var(--blue-dark)}.auth-submit{width:100%;margin-top:8px}.auth-switch{text-align:center;color:var(--grey-600);margin-top:24px;font-size:.9rem}@media (width<=480px){.auth-card{padding:36px 24px}}.notfound{text-align:center;background:var(--grey-100);justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:60px 24px;display:flex}.notfound__inner{max-width:480px}.notfound__number{color:var(--blue-light);letter-spacing:-4px;margin-bottom:16px;font-size:clamp(6rem,18vw,10rem);font-weight:900;line-height:1}.notfound__inner h1{color:var(--blue-dark);margin-bottom:12px;font-size:1.8rem;font-weight:800}.notfound__inner p{color:var(--grey-600);margin-bottom:36px;font-size:1rem}.notfound__actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}
