:root{--primary-color:#3b82f6;--primary-hover:#2563eb;--success-color:#10b981;--success-bg:#d1fae5;--error-color:#ef4444;--error-bg:#fee2e2;--warning-color:#f59e0b;--warning-bg:#fef3c7;--background-color:#f9fafb;--surface-color:#fff;--text-color:#1f2937;--text-muted:#6b7280;--border-color:#e5e7eb;--sidebar-width:280px}*{box-sizing:border-box}body{background-color:var(--background-color);color:var(--text-color);margin:0;padding:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}header{z-index:100;background-color:#fff;padding:.75rem 1.5rem;position:sticky;top:0;box-shadow:0 1px 3px #0000001a}header nav{justify-content:flex-end;align-items:center;gap:1rem;display:flex}main{max-width:1400px;margin:0 auto;padding:1.5rem}.notice{background-color:var(--success-bg);color:#065f46;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.error{background-color:var(--error-bg);color:#991b1b;border-radius:.5rem;margin-bottom:1rem;padding:1rem}button,input[type=submit]{background-color:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;transition:background-color .15s}button:hover,input[type=submit]:hover{background-color:var(--primary-hover)}button:disabled{opacity:.6;cursor:not-allowed}.landing{background:#fafafa;min-height:100vh}.landing__header{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fafafad9;border-bottom:1px solid #eee;position:sticky;top:0}.landing__nav{justify-content:space-between;align-items:center;max-width:720px;margin:0 auto;padding:.875rem 1.5rem;display:flex}.landing__logo{color:var(--text-color);letter-spacing:-.01em;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;display:flex}.landing__logo-icon{background:var(--text-color);color:#fff;border-radius:.375rem;justify-content:center;align-items:center;width:1.625rem;height:1.625rem;font-size:.875rem;font-weight:700;display:inline-flex}.landing__stats{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.8125rem}.landing__hero{max-width:720px;margin:0 auto;padding:4rem 1.5rem 3rem}.landing__tagline{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 .75rem;font-size:.8125rem;font-weight:500}.landing__title{color:var(--text-color);letter-spacing:-.025em;margin:0 0 1rem;font-size:2.25rem;font-weight:700;line-height:1.15}.landing__title em{color:#dc2626;font-style:normal}.landing__subtitle{color:var(--text-muted);max-width:480px;margin:0;font-size:1.0625rem;line-height:1.6}.landing__modules{flex-direction:column;gap:3rem;max-width:720px;margin:0 auto;padding:0 1.5rem 4rem;display:flex}.landing__module-header{align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.landing__module-number{color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;padding-top:.25rem;font-size:.75rem;font-weight:600}.landing__module-title{color:var(--text-color);letter-spacing:-.015em;margin:0 0 .25rem;font-size:1.25rem;font-weight:600}.landing__module-description{color:var(--text-muted);margin:0;font-size:.875rem;line-height:1.5}.landing__grid{background:#e5e5e5;border:1px solid #e5e5e5;border-radius:.625rem;flex-direction:column;gap:1px;display:flex;overflow:hidden}.landing__loading{color:var(--text-muted);justify-content:center;align-items:center;gap:.75rem;padding:6rem 1.5rem;font-size:.9375rem;display:flex}.landing__spinner{border:2px solid #e5e5e5;border-top-color:var(--text-muted);border-radius:50%;width:1.125rem;height:1.125rem;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.landing__error{text-align:center;color:var(--error-color);padding:6rem 1.5rem;font-size:.9375rem}.landing__footer{text-align:center;max-width:720px;margin:0 auto;padding:0 1.5rem 3rem}.landing__footer p{color:#ccc;letter-spacing:.02em;margin:0;font-size:.8125rem}.lesson-card{cursor:pointer;background:#fff;padding:1rem 1.25rem;transition:background .1s}.lesson-card:hover{background:#f5f5f5}.lesson-card--complete{background:#fafff8}.lesson-card--complete:hover{background:#f2fef0}.lesson-card__top{align-items:flex-start;gap:.875rem;display:flex}.lesson-card__status{flex-shrink:0;padding-top:.125rem}.lesson-card__check{background:var(--success-color);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;font-size:.6875rem;font-weight:700;display:inline-flex}.lesson-card__in-progress{border:2px solid var(--primary-color);border-radius:50%;width:1.25rem;height:1.25rem;display:inline-block;position:relative}.lesson-card__in-progress:after{content:"";background:var(--primary-color);border-radius:50%;width:.375rem;height:.375rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.lesson-card__todo{border:2px solid #ddd;border-radius:50%;width:1.25rem;height:1.25rem;display:inline-block}.lesson-card__content{flex:1;min-width:0}.lesson-card__title{color:var(--text-color);margin:0 0 .125rem;font-size:.9375rem;font-weight:600}.lesson-card__description{color:var(--text-muted);margin:0;font-size:.8125rem;line-height:1.45}.lesson-card__arrow{color:#ccc;flex-shrink:0;padding-top:.0625rem;font-size:1.25rem;transition:color .1s,transform .1s}.lesson-card:hover .lesson-card__arrow{color:var(--text-muted);transform:translate(2px)}.lesson-card__bottom{align-items:center;gap:.625rem;margin-top:.5rem;padding-left:2.125rem;display:flex}.lesson-card__progress-bar{background:#eee;border-radius:2px;flex:1;height:3px;overflow:hidden}.lesson-card__progress-fill{background:var(--success-color);border-radius:2px;height:100%;transition:width .3s}.lesson-card__badge{color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.6875rem}.lesson-page__loading,.lesson-page__error{text-align:center;color:var(--text-muted);padding:3rem}.lesson-page__header{border-bottom:1px solid var(--border-color);align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.lesson-page__back{color:var(--text-muted);background:0 0;padding:.375rem .75rem;font-size:.875rem}.lesson-page__back:hover{background:var(--background-color);color:var(--text-color)}.lesson-page__title{margin:0;font-size:1.5rem;font-weight:700}.lesson-page__progress{color:var(--text-muted);margin:.25rem 0 0;font-size:.875rem}.lesson-page__content{gap:1.5rem;display:flex}.lesson-page__sidebar{width:var(--sidebar-width);flex-shrink:0}.lesson-page__main{flex:1;min-width:0}.lesson-page__exercise-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.lesson-page__exercise-header h2{margin:0;font-size:1.25rem}.lesson-page__difficulty{text-transform:uppercase;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600}.lesson-page__difficulty--beginner{background:var(--success-bg);color:#065f46}.lesson-page__difficulty--intermediate{background:var(--warning-bg);color:#92400e}.lesson-page__spec{background:#1e1e1e;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.lesson-page__spec h3{text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;margin:0 0 .5rem;font-size:.75rem}.lesson-page__spec-code{color:#d4d4d4;white-space:pre-wrap;word-break:break-word;margin:0;font-family:SF Mono,Fira Code,Fira Mono,Menlo,monospace;font-size:.8125rem;line-height:1.6}.monaco-editor-wrapper{border:1px solid var(--border-color);border-radius:.5rem;margin-bottom:1rem;overflow:hidden}.lesson-page__actions{gap:.75rem;margin-bottom:1rem;display:flex}.lesson-page__run-btn{background:var(--success-color);padding:.625rem 1.5rem;font-size:.9375rem;font-weight:600}.lesson-page__run-btn:hover:not(:disabled){background:#059669}.lesson-page__reset-btn{color:var(--text-muted);border:1px solid var(--border-color);background:0 0}.lesson-page__reset-btn:hover{background:var(--background-color);color:var(--text-color)}.exercise-list{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.75rem;max-height:calc(100vh - 120px);padding:1rem;position:sticky;top:80px;overflow-y:auto}.exercise-list__title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 .75rem;font-size:.875rem;font-weight:600}.exercise-list__items{margin:0;padding:0;list-style:none}.exercise-list__item{cursor:pointer;border-radius:.375rem;align-items:center;gap:.625rem;padding:.5rem .625rem;font-size:.8125rem;transition:background-color .1s;display:flex}.exercise-list__item:hover{background:var(--background-color)}.exercise-list__item--active{color:var(--primary-color);background:#eff6ff;font-weight:600}.exercise-list__item--passed .exercise-list__status{background:var(--success-color);color:#fff}.exercise-list__status{background:var(--background-color);width:1.5rem;height:1.5rem;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.6875rem;font-weight:700;display:flex}.exercise-list__item-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.result-panel{border-radius:.5rem;align-items:center;gap:.75rem;padding:1rem;display:flex}.result-panel--idle{background:var(--background-color);color:var(--text-muted)}.result-panel--submitting,.result-panel--running{color:var(--primary-color);background:#eff6ff}.result-panel--pass{background:var(--success-bg);color:#065f46}.result-panel--fail,.result-panel--error{background:var(--error-bg);color:#991b1b;flex-direction:column;align-items:flex-start}.result-panel__header{align-items:center;gap:.75rem;width:100%;display:flex}.result-panel__icon{font-size:1.25rem;font-weight:700}.result-panel__message{margin:0;font-size:.875rem}.result-panel__label{font-size:.875rem;font-weight:600}.result-panel__time{opacity:.7;margin-left:auto;font-size:.75rem}.result-panel__output{white-space:pre-wrap;word-break:break-word;background:#0000000d;border-radius:.375rem;width:100%;margin:.5rem 0 0;padding:.75rem;font-family:SF Mono,Fira Code,monospace;font-size:.8125rem;line-height:1.5;overflow-x:auto}.result-panel__spinner{border:2px solid;border-right-color:#0000;border-radius:50%;width:1.25rem;height:1.25rem;animation:.6s linear infinite spin}.app-header{background:var(--surface-color);border-bottom:1px solid var(--border-color);z-index:100;position:sticky;top:0}.app-header__inner{justify-content:space-between;align-items:center;max-width:1400px;height:3.5rem;margin:0 auto;padding:0 1.5rem;display:flex}.app-header__logo{color:var(--text-color);letter-spacing:-.01em;cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:0;font-size:.9375rem;font-weight:600;display:flex}.app-header__logo:hover{opacity:.8;background:0 0}.app-header__right{align-items:center;gap:1rem;display:flex}.app-header__email{color:var(--text-muted);font-size:.8125rem}.app-header__sign-out{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.375rem .75rem;font-size:.8125rem}.app-header__sign-out:hover{background:var(--background-color);color:var(--text-color)}.sign-in{background:var(--background-color);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.sign-in__card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.75rem;width:100%;max-width:400px;padding:2.5rem}.sign-in__brand{align-items:center;gap:.625rem;margin-bottom:.5rem;display:flex}.sign-in__brand-name{color:var(--text-color);letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.sign-in__tagline{color:var(--text-muted);margin:0 0 2rem;font-size:.875rem}.sign-in__form{flex-direction:column;gap:.75rem;display:flex}.sign-in__label{color:var(--text-color);font-size:.8125rem;font-weight:500}.sign-in__input{border:1px solid var(--border-color);width:100%;color:var(--text-color);background:var(--surface-color);border-radius:.375rem;outline:none;padding:.625rem .75rem;font-size:.9375rem;transition:border-color .15s}.sign-in__input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.sign-in__submit{margin-top:.25rem;padding:.625rem 1rem;font-size:.9375rem;font-weight:500}.sign-in__error{background:var(--error-bg);color:#991b1b;border-radius:.375rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.sign-in__field-error{color:var(--error-color);margin:0;font-size:.8125rem}.sign-in__sent{text-align:center}.sign-in__sent-title{color:var(--text-color);margin:0 0 .5rem;font-size:1.125rem;font-weight:600}.sign-in__sent-detail{color:var(--text-muted);margin:0 0 1.5rem;font-size:.875rem;line-height:1.5}.sign-in__retry{color:var(--primary-color);cursor:pointer;background:0 0;border:none;padding:0;font-size:.8125rem;text-decoration:underline}.sign-in__retry:hover{color:var(--primary-hover);background:0 0}@media (width<=768px){.lesson-page__content{flex-direction:column}.lesson-page__sidebar{width:100%}.exercise-list{max-height:none;position:static}}
