*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;font-family:Poppins,sans-serif;background:radial-gradient(circle at 40% 40%,#82cfff,#152935);color:var(--color-neutral);line-height:1.5;-webkit-font-smoothing:antialiased}#app{height:100%}.layout{display:flex;flex-direction:column;height:100%}.main-content{flex:1;overflow-y:auto}.button{position:relative;overflow:hidden;padding:10px 30px;border:none;border-radius:4px;cursor:pointer;font-size:14px;box-shadow:0 4px 8px var(--color-dark-shadow);max-height:40px;min-height:40px;-webkit-user-select:none;user-select:none;transition:all .1s ease}.button:before{content:"";position:absolute;top:0;left:0;right:0;height:30%;background:linear-gradient(180deg,var(--color-btn-glare) 0%,var(--color-alpha) 100%);border-radius:0;pointer-events:none}.button:hover{transform:translateY(-2px)}.button:active{transform:translateY(0)}.button-yellow{width:215px;background:linear-gradient(135deg,var(--color-btn-yellow-light) 0%,var(--color-btn-yellow-dark) 100%);color:var(--color-text-dark)}.button-yellow:hover{background:linear-gradient(135deg,var(--color-btn-yellow-dark) 0%,var(--color-btn-yellow-dark) 100%)}.button-orange{width:155px;background:linear-gradient(135deg,var(--color-btn-orange) 0%,var(--color-btn-orange-dark) 100%);color:var(--color-text-white)}.button-orange:hover{background:linear-gradient(135deg,var(--color-btn-orange-dark) 0%,var(--color-btn-orange-dark) 100%)}.button-grey{width:155px;background-color:#6c757d;color:var(--color-text-light)}.button-grey:hover{background-color:#464c52}.button:disabled{opacity:.4;pointer-events:none;cursor:not-allowed;background:var(--color-disabled);color:var(--color-text-light)}.button:disabled:before{height:0%}:root{--color-primary: #3697c1;--color-secondary: #ffc107;--color-success: #4ca330;--color-error: #ff7f2a;--color-neutral: #2c3e30;--color-bg-light: #f8fafb;--color-bg-dark: #152935;--color-accent: #82cfff;--color-text-light: #a7b3c1;--color-text-dark: #686e57;--color-disabled: #464c52;--color-btn-orange: #ff6b26;--color-btn-orange-light: #ffae00;--color-btn-orange-dark: #ff5e02;--color-btn-yellow-light: #ffe865;--color-btn-yellow-dark: #ffae00;--color-btn-glare: rgba(255, 255, 255, .8);--color-dark-shadow: rgba(0, 0, 0, .5);--color-alpha: rgba(0, 0, 0, 0);--color-text-white: white;--color-text-white-alpha: rgba(255, 255, 255, .521);--font-regular: 16px "Poppins", sans-serif;--font-semibold: 20px "Poppins", sans-serif;--font-bold: 32px "Poppins", sans-serif;--font-family: "Poppins", sans-serif;--font-size-regular: 16px;--font-size-semibold: 20px;--font-size-bold: 32px;--font-weight-regular: 400;--font-weight-semibold: 600;--font-weight-bold: 700}.input-wrapper{position:relative;width:100%;padding:1px;background:var(--color-bg-light);border-radius:4px}.input-wrapper .input{width:100%;padding:10px 14px;background:var(--color-bg-dark);border:none;border-radius:4px;color:#fff;font-size:14px}.input-wrapper .input:focus{outline:none;box-shadow:3px 3px 10px var(--color-bg-dark)}.input-wrapper .input::placeholder{color:var(--color-text-white-alpha)}.input-wrapper.error{background:var(--color-error)}.input-wrapper .input:-webkit-autofill,.input-wrapper .input:-webkit-autofill:hover,.input-wrapper .input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--color-bg-dark) inset!important;-webkit-text-fill-color:var(--color-text-white)!important}.app-header{width:100%;padding:16px 40px;background:linear-gradient(180deg,#2c3e50,#1f2d3a);border-bottom:1px solid rgba(255,255,255,.08)}.header-container{display:flex;justify-content:space-between;align-items:center}.header-title{font-family:var(--font-family);font-weight:var(--font-weight-semibold);font-size:20px;line-height:1;color:var(--color-text-white);letter-spacing:.2px}.logo-link .header-title .accent{color:var(--color-btn-yellow-dark)}.header-title .accent{color:var(--color-btn-yellow-dark);font-weight:var(--font-weight-bold)}.header-left{display:flex;align-items:center;gap:16px}.logo{width:38px;height:38px;background:var(--color-secondary);color:var(--color-neutral);font-family:var(--font-family);font-size:var(--font-size-semibold);font-weight:var(--font-weight-bold);border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.logo:hover{transform:scale(1.05);box-shadow:0 4px 10px var(--color-dark-shadow)}.logo-link{text-decoration:none;color:inherit}.header-right{display:flex;align-items:center;gap:14px}.auth-page{display:flex;align-items:stretch;justify-content:center;height:100%;background-color:#1a2332;padding:24px;box-sizing:border-box}.auth-container{width:100%;max-width:1200px;display:flex;flex-direction:column}.auth-content{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px;flex:1;background-color:#1e2d42;border-radius:16px;padding:48px;box-shadow:0 8px 32px #0006;overflow:visible}.auth-form-section{display:flex;flex-direction:column;gap:12px}.auth-title{font-size:28px;font-weight:700;color:#fff;margin:0 0 4px}.auth-subtitle{font-size:14px;color:#8a9bb5;margin:0 0 8px}.auth-form{display:flex;flex-direction:column;gap:12px}.input-wrapper{width:100%}.input-wrapper .input{width:100%;padding:12px 16px;background-color:#243447;border:1.5px solid #2e4060;border-radius:8px;color:#fff;font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.input-wrapper .input::placeholder{color:#5a7192}.input-wrapper .input:focus{border-color:#f07c2a}.input-wrapper.error .input{border-color:#e05555}.auth-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.auth-buttons .button{width:100%;padding:12px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.auth-buttons .button:hover{opacity:.9}.auth-buttons .button:active{transform:scale(.98)}.auth-buttons .button:disabled{opacity:.5;cursor:not-allowed}.button-orange{background-color:#f07c2a;color:#fff}.button-grey{background-color:#2e4060;color:#c5d4e8}.auth-divider{display:flex;align-items:center;gap:12px;margin:4px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:#2e4060}.divider-text{font-size:13px;color:#5a7192;white-space:nowrap}.google-button{width:100%;padding:12px;background-color:#2e4060;color:#c5d4e8;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.google-button:hover{opacity:.85}.forgot-password{display:inline-block;text-align:center;font-size:13px;color:#8a9bb5;text-decoration:underline;text-underline-offset:3px;transition:color .2s}.forgot-password:hover{color:#f07c2a}.error-message{display:none;font-size:13px;color:#e05555;padding:6px 10px;background-color:#e055551a;border-radius:6px;border-left:3px solid #e05555}.error-message.show{display:block}.auth-form.loading{opacity:.6;pointer-events:none}.auth-mascot{position:relative;display:flex;align-items:flex-end;justify-content:center}.auth-mascot:before{content:"";position:absolute;bottom:10%;left:50%;transform:translate(-50%);width:380px;height:380px;background:radial-gradient(circle,rgba(100,200,255,.35) 0%,transparent 70%);border-radius:50%;pointer-events:none}.mascot-image{position:relative;width:133%;height:auto;object-fit:contain;filter:drop-shadow(0 0 18px rgba(100,200,255,.4))}@media(max-width:640px){.auth-content{grid-template-columns:1fr;padding:32px 24px;gap:24px}.auth-mascot{order:-1}.mascot-image{max-width:160px}.auth-title{font-size:22px}}.topic-mode-page{flex:1;min-height:100%;padding:48px 56px;box-sizing:border-box;display:flex;justify-content:center;align-items:center;background:radial-gradient(circle at top center,rgba(64,98,170,.35),transparent 35%),linear-gradient(180deg,#0f1f3a,#0a1730)}.topic-mode-page__wrapper{width:100%;max-width:1200px;display:grid;grid-template-columns:2fr 1fr;align-items:center;gap:24px}.topic-mode-page__left{display:flex;flex-direction:column;align-items:center}.topic-mode-page__mode-icon{width:100px;height:100px;object-fit:cover;margin-bottom:14px}.topic-mode-page__right{display:flex;justify-content:flex-end;align-items:center;height:550px}.topic-mode-page__image{height:100%;max-width:500px;object-fit:cover;overflow:visible}.topic-mode-page__label{font-size:40px;font-weight:700;color:#fff;margin-bottom:12px}.topic-mode-page__title{font-size:26px;color:#d6e3ff;margin-bottom:32px}.topic-mode-page__back{margin-top:24px;margin-bottom:18px;border:none;background:transparent;color:#8fb3ff;font-size:16px;cursor:pointer}.topic-mode-page__back:hover{color:#fff}.topic-mode-page__modes{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:20px;width:100%;max-width:760px}.topic-mode-page__mode-card{padding:22px 24px;border-radius:20px;min-width:200px;text-align:center;cursor:pointer;border:1px solid rgba(255,255,255,.14);background:#ffffff0f;width:100%;color:#fff;box-shadow:inset 0 1px #ffffff14,0 14px 30px #00000040;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.topic-mode-page__mode-card:hover{transform:translateY(-4px);box-shadow:inset 0 1px #ffffff1a,0 20px 40px #0000004d}.topic-mode-page__mode-card--tests{border:1px solid rgba(57,255,20,.7);background:radial-gradient(circle at top left,rgba(57,255,20,.35),transparent 45%),linear-gradient(135deg,#145014d9,#051905f2);box-shadow:0 0 10px #39ff1473,0 0 24px #39ff1447,inset 0 1px #ffffff14}.topic-mode-page__mode-card--tasks{border:1px solid rgba(255,136,0,.75);background:radial-gradient(circle at top left,rgba(255,136,0,.35),transparent 45%),linear-gradient(135deg,#5f2d00db,#1c0c00f5);box-shadow:0 0 10px #ff88006b,0 0 24px #ff880042,inset 0 1px #ffffff14}.topic-mode-page__mode-card--ai{border:1px solid rgba(180,70,255,.75);background:radial-gradient(circle at top left,rgba(180,70,255,.34),transparent 45%),linear-gradient(135deg,#46146ed6,#120622f5);box-shadow:0 0 10px #b446ff6b,0 0 24px #b446ff42,inset 0 1px #ffffff14}.topic-mode-page__mode-title{font-size:24px;font-weight:700;margin-bottom:6px}.topic-mode-page__mode-description{font-size:16px;color:#ffffffd9}@media(max-width:900px){.topic-mode-page__wrapper{grid-template-columns:1fr}.topic-mode-page__right{order:2;min-height:auto;justify-content:center}.topic-mode-page__image{max-width:320px}.topic-mode-page__label{font-size:32px}.topic-mode-page__title{font-size:22px}.topic-mode-page__modes{grid-template-columns:repeat(2,minmax(180px,1fr))}}@media(max-width:640px){.topic-mode-page__image{width:280px}.topic-mode-page__modes{grid-template-columns:1fr}}.topic-card{position:relative;display:flex;align-items:center;justify-content:space-between;min-height:150px;padding:24px 26px;border-radius:28px;text-decoration:none;overflow:hidden;cursor:pointer;background:linear-gradient(180deg,#ffffff14,#ffffff08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.14);box-shadow:inset 0 1px #ffffff14,0 18px 40px #00000047;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.topic-card:hover{transform:translateY(-6px);box-shadow:inset 0 1px #ffffff1f,0 24px 52px #00000057}.topic-card__content{display:flex;align-items:center;justify-content:space-between;gap:20px;width:100%}.topic-card__icon{width:64px;height:64px;object-fit:contain;flex-shrink:0}.topic-card__title{color:#fff;font-size:18px;font-weight:var(--font-weight-semibold);margin:0}.topics-page__title{margin:0 0 18px;color:var(--color-text-white);font-size:28px;font-weight:var(--font-weight-bold)}.topic-core-js{background:radial-gradient(circle at top left,rgba(255,178,42,.38),transparent 45%),linear-gradient(135deg,#ff9d0052,#2d1a04db);border-color:#ffb9438c;box-shadow:inset 0 1px #ffebb429,0 0 0 1px #ffb0392e,0 0 28px #ffa60038,0 18px 40px #0000004d}.topic-closures{background:radial-gradient(circle at top left,rgba(76,164,255,.34),transparent 45%),linear-gradient(135deg,#2571e44d,#09214ce0);border-color:#59b7ff7a;box-shadow:inset 0 1px #b4e4ff24,0 0 0 1px #47aaff24,0 0 26px #3d9cff33,0 18px 40px #0000004d}.topic-asynchrony{background:radial-gradient(circle at top left,rgba(189,98,255,.3),transparent 45%),linear-gradient(135deg,#6739c947,#1e0f42e6);border-color:#be7fff75;box-shadow:inset 0 1px #e4c4ff24,0 0 0 1px #b26cff1f,0 0 26px #ad59ff2e,0 18px 40px #0000004d}.topic-data-structures{background:radial-gradient(circle at top left,rgba(94,255,140,.26),transparent 45%),linear-gradient(135deg,#26aa5147,#0a391ce6);border-color:#68ff906b;box-shadow:inset 0 1px #c1ffd41f,0 0 0 1px #57f1821a,0 0 24px #48ec7629,0 18px 40px #0000004d}.topic-card:hover .topic-card__icon{transform:translateY(-1px)}.topics-page{padding:24px;box-sizing:border-box;flex:1;min-height:100%;background-color:#1a2332;display:flex;flex-direction:column}.topics-page__wrapper{flex:1;min-height:0;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px;max-width:1200px;margin:0 auto}.topics-page__left{display:flex;flex-direction:column}.topics-page__right{display:flex;justify-content:flex-end;align-items:center;overflow:visible;height:550px}.topics-page__image{width:100%;height:100%;object-fit:cover;object-position:left center}.topics-page__title{font-size:28px;font-weight:700;color:#fff;margin:0 0 30px}.topics-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:18px;max-width:800px}@media(max-width:900px){.topics-page__wrapper{grid-template-columns:1fr}.topics-page__right{height:260px}.topics-page__image{max-width:none}.topics-grid{grid-template-columns:1fr}}
