@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--font-display:"Inter",system-ui,-apple-system,sans-serif;--font-body:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"JetBrains Mono","SFMono-Regular","SF Mono",Menlo,monospace;--step--1:.8rem;--step-0:1rem;--step-1:1.25rem;--step-2:1.5625rem;--step-3:1.9531rem;--step-4:2.4414rem;--step-5:3.0518rem;--step-6:3.8147rem;--fw-normal:400;--fw-medium:500;--fw-bold:700;--bg-base:#0a0a0a;--bg-surface:#111;--bg-elevated:#161616;--border:#1e1e1e;--border-hover:#2e2e2e;--text-primary:#f5f5f5;--text-secondary:#888;--text-muted:#555;--accent:#6366f1;--accent-hover:#818cf8;--accent-subtle:#6366f11a;--accent-border:#6366f14d;--success:#4ade80;--warning:#fbbf24;--danger:#f87171;--highlight-new:#6366f11f;--highlight-prev:#6366f10f;--pc-current:#6366f11a;--pc-prev:#6366f10d;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--space-24:96px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:20px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 8px 40px #000000b3;--transition:.15s ease;--nav-height:64px}[data-theme=light]{--bg-base:#f7f5f2;--bg-surface:#fff;--bg-elevated:#f0ede8;--border:#e2ddd6;--border-hover:#c8c3bd;--text-primary:#1a1816;--text-secondary:#6b6560;--text-muted:#a09890;--accent:#4f52d9;--accent-hover:#3d40c4;--accent-subtle:#4f52d914;--accent-border:#4f52d940;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--highlight-new:#fef3c7;--highlight-prev:#f0fdf4;--pc-current:#4f52d914;--pc-prev:#4f52d90a;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 32px #00000024}html{font-size:15px}*,:before,:after{box-sizing:border-box}body{margin:0}::selection{background:var(--accent-subtle);color:var(--text-primary)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-display:"Inter",system-ui,-apple-system,sans-serif;--font-body:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"JetBrains Mono","SFMono-Regular","SF Mono",Menlo,monospace}html,body{margin:0;padding:0}html{font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.7}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-base);font-size:15px;line-height:1.7}code,pre,.mono{font-family:var(--font-mono);font-size:13px}.site-footer{border-top:1px solid var(--border);background:var(--bg-base)}.site-footer__inner{width:min(1440px,100% - 48px);margin:0 auto;padding:56px 0 32px}.site-footer__grid{grid-template-columns:1.3fr .8fr .8fr .8fr;gap:32px;display:grid}.site-footer__brand{color:var(--text-primary);font-family:var(--font-body);font-size:15px;font-weight:700}.site-footer__tagline,.site-footer__copyright,.site-footer__domain{color:var(--text-muted);font-family:var(--font-body);font-size:13px;line-height:1.5}.site-footer__tagline{max-width:240px;margin-top:8px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.site-footer__heading{color:var(--text-muted);font-family:var(--font-body);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600}.site-footer__links{gap:4px;display:grid}.site-footer__links a{color:var(--text-secondary);font-family:var(--font-body);font-size:13px;text-decoration:none;transition:color .15s}.site-footer__links a:hover{color:var(--text-primary)}.site-footer__bottom{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;margin-top:40px;padding-top:24px;display:flex}@media (width<=768px){.site-footer__grid{grid-template-columns:1fr}.site-footer__bottom{text-align:center;flex-direction:column}}@media (width<=480px){.site-footer__inner{width:min(1100px,100% - 32px)}}.site-nav{z-index:1000;width:100%;height:var(--nav-height,64px);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);background:#0a0a0ad1;transition:background .2s;position:fixed;inset:0 0 auto}.site-nav.is-scrolled{background:#0a0a0af5}.nav-inner{width:100%;height:var(--nav-height,64px);align-items:center;gap:8px;padding:0 clamp(16px,2.5vw,40px);display:flex}.nav-logo{font-family:var(--font-body);color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;flex-shrink:0;align-items:center;gap:8px;margin-right:24px;font-size:15px;font-weight:600;text-decoration:none;display:inline-flex}.nav-logo__badge{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.nav-logo__mark{flex-shrink:0;width:22px;height:22px}.nav-logo__fallback{color:var(--accent);font-family:var(--font-mono);letter-spacing:.06em;font-size:11px;font-weight:700;display:none}.nav-logo--fallback .nav-logo__mark{display:none}.nav-logo--fallback .nav-logo__fallback{display:inline-flex}.nav-logo__text{display:inline-block}.nav-links{flex:1;align-items:center;gap:2px;min-width:0;display:flex}.nav-link{font-family:var(--font-body);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 12px;font-size:14px;font-weight:500;line-height:1;text-decoration:none;transition:color .12s,background .12s;display:inline-flex}.nav-link:hover{color:var(--text-primary);background:#ffffff0d}.nav-link-active{position:relative;color:var(--accent-hover)!important}.nav-link-active:after{content:"";background:var(--accent);opacity:.7;border-radius:999px;height:1px;position:absolute;bottom:0;left:12px;right:12px}.nav-link--github{width:34px;height:34px;color:var(--text-secondary);border-radius:6px;justify-content:center;align-items:center;padding:0;transition:color .12s,background .12s;display:inline-flex}.nav-link--github:hover{color:var(--text-primary);background:#ffffff0f}.nav-link--github:after{display:none}.nav-chevron{opacity:.5;width:12px;height:12px;transition:transform .2s}.nav-dropdown-wrapper{position:relative}.nav-dropdown-wrapper.is-open .nav-chevron{transform:rotate(180deg)}.nav-dropdown{border:1px solid var(--border);opacity:0;pointer-events:none;z-index:200;background:#0f0f0f;border-radius:10px;min-width:256px;padding:6px;transition:opacity .14s,transform .14s;position:absolute;top:calc(100% + 8px);left:0;transform:translateY(-6px);box-shadow:0 8px 32px #000000b3}.nav-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-dropdown-item{border-left:2px solid #0000;border-radius:7px;align-items:flex-start;gap:10px;padding:10px 10px 10px 12px;text-decoration:none;transition:background .1s,border-color .1s;display:flex}.nav-dropdown-item:hover{background:#ffffff0a}.nav-dropdown-item.nav-dropdown-item-active{border-left-color:var(--accent)}.nav-dropdown-icon{background:var(--accent-subtle);width:30px;height:30px;color:var(--accent-hover);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav-dropdown-title{font-family:var(--font-body);color:var(--text-primary);font-size:13px;font-weight:500;line-height:1.3;display:block}.nav-dropdown-desc{font-family:var(--font-body);color:var(--text-muted);margin-top:2px;font-size:12px;line-height:1.4;display:block}.nav-actions{flex-shrink:0;align-items:center;gap:10px;margin-left:auto;display:flex}.nav-search-btn{border:1px solid var(--border);height:34px;color:var(--text-muted);font-family:var(--font-body);cursor:pointer;background:#ffffff08;border-radius:8px;align-items:center;gap:7px;padding:0 12px;font-size:13px;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.nav-search-btn:hover{border-color:var(--border-hover);color:var(--text-secondary);background:#ffffff0f}.nav-search-btn__text{font-weight:500}.nav-search-btn__kbd{border:1px solid var(--border);min-height:18px;color:var(--text-muted);font-family:var(--font-mono);background:#ffffff08;border-radius:4px;align-items:center;padding:0 5px;font-size:10px;line-height:1;display:inline-flex}.nav-status-badge{color:var(--text-muted);font-family:var(--font-body);font-size:11px;display:none}.nav-status-badge.visible{display:block}.nav-signin-btn{font-family:var(--font-body);color:var(--text-primary);border:1px solid var(--border-hover);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;height:34px;padding:0 14px;font-size:13px;font-weight:500;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.nav-signin-btn:hover{background:#ffffff0d;border-color:#fff3}.nav-theme-toggle,.nav-hamburger{border:1px solid var(--border);cursor:pointer;width:34px;height:34px;color:var(--text-secondary);background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:border-color .15s,color .15s,background .15s;display:flex}.nav-theme-toggle:hover,.nav-hamburger:hover{border-color:var(--border-hover);color:var(--text-primary);background:#ffffff0a}.nav-actions>:not(#nav-status-badge):not(.nav-signin-btn):not(#auth-signin-btn):not(.auth-menu):not(#theme-toggle):not(.nav-hamburger):not(.nav-user-btn):not(#auth-user-btn),#auth-user-btn:empty,#auth-user-btn:not([data-initialized]),.nav-user-btn:empty,.auth-avatar:empty,.nav-avatar:empty{display:none!important}.auth-menu:has(#auth-user-btn[hidden]){display:none}.auth-menu:not([data-ready]){display:none!important}.auth-menu{position:relative}.auth-menu:not([data-init]){visibility:hidden;width:0;margin:0;padding:0;overflow:hidden}.nav-user-menu,.nav-user-btn,.auth-user-btn{border:1px solid var(--border);cursor:pointer;min-height:34px;font-family:var(--font-body);color:var(--text-primary);white-space:nowrap;background:0 0;border-radius:999px;align-items:center;gap:8px;padding:4px 10px 4px 4px;font-size:13px;transition:background .15s,border-color .15s;display:inline-flex}.nav-user-menu:hover,.nav-user-btn:hover,.auth-user-btn:hover{border-color:var(--border-hover);background:#ffffff0a}.nav-avatar,.nav-user-avatar{background:var(--accent);color:#fff;width:26px;height:26px;font-family:var(--font-body);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex;overflow:hidden}.nav-avatar img,.nav-avatar .nav-user-avatar__image,.nav-user-avatar__image{object-fit:cover;width:100%;height:100%}.nav-avatar .nav-user-avatar__emoji,.nav-user-avatar__emoji{font-size:12px;line-height:1}.nav-username,.nav-user-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:13px;font-weight:500;overflow:hidden}.nav-tier-pill{font-family:var(--font-mono);letter-spacing:.06em;border-radius:4px;padding:2px 5px;font-size:9px;font-weight:700}.nav-tier-pill--pro{color:#fbbf24;background:#fbbf241f;border:1px solid #fbbf244d}.nav-tier-pill--free{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a}.nav-chevron,.nav-user-chevron{width:10px;height:10px;color:var(--text-muted);flex-shrink:0;transition:transform .2s}.auth-menu.is-open .nav-chevron,.auth-menu.is-open .nav-user-chevron{transform:rotate(180deg)}.auth-dropdown{border:1px solid var(--border);z-index:300;background:#0f0f0f;border-radius:10px;min-width:200px;padding:6px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 32px #000000b3}.auth-dropdown__email{font-family:var(--font-body);color:var(--text-muted);border-bottom:1px solid var(--border);word-break:break-all;margin-bottom:4px;padding:8px 12px;font-size:12px}.auth-dropdown__tier{font-family:var(--font-mono);letter-spacing:.08em;border-bottom:1px solid var(--border);margin-bottom:4px;padding:4px 12px 8px;font-size:10px;font-weight:700}.auth-dropdown__divider{background:var(--border);height:1px;margin:4px 0}.auth-dropdown__link{width:100%;color:var(--text-secondary);font-family:var(--font-body);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-size:13px;text-decoration:none;transition:background .12s,color .12s;display:block}.auth-dropdown__link:hover,.auth-dropdown__link--button:hover{color:var(--text-primary);background:#ffffff0a}.auth-dropdown__link--button{appearance:none}.auth-dropdown__signout{width:100%;font-family:var(--font-body);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-size:13px;transition:background .12s,color .12s}.auth-dropdown__signout:hover{color:var(--danger);background:#f8717114}.badge-manager-modal{z-index:1100;position:fixed;inset:0}.badge-manager-modal[hidden]{display:none}.badge-manager-modal__backdrop{backdrop-filter:blur(6px);background:#000000b3;position:absolute;inset:0}.badge-manager-modal__card{border:1px solid var(--border);background:#111;border-radius:16px;width:min(560px,100vw - 32px);padding:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 12px 48px #000c}.badge-manager-modal__close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;font-size:18px}.badge-manager-modal__grid{grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:12px;margin-top:18px;display:grid}.badge-manager-modal__badge{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer;border-radius:12px;gap:8px;padding:14px;transition:border-color .15s,background .15s;display:grid}.badge-manager-modal__badge.is-selected{border-color:var(--accent);background:var(--accent-subtle)}.badge-manager-modal__badge-icon{font-size:22px}.badge-manager-modal__badge-name{font-size:13px;font-weight:600}.badge-manager-modal__actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.badge-manager-modal__action{border:1px solid var(--border);background:var(--bg-elevated);min-height:36px;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;border-radius:8px;padding:0 14px;font-size:13px;font-weight:500}.badge-manager-modal__action--primary{background:var(--accent);border-color:var(--accent);color:#fff}.search-overlay{z-index:2000;position:fixed;inset:0}.search-overlay[hidden]{display:none}.search-overlay__backdrop{backdrop-filter:blur(4px);background:#000000b3;position:absolute;inset:0}.search-overlay__panel{border:1px solid var(--border);background:#111;border-radius:12px;width:min(640px,100vw - 32px);animation:.2s cubic-bezier(.16,1,.3,1) forwards search-panel-in;position:absolute;top:15vh;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 24px 64px #000c}@keyframes search-panel-in{0%{opacity:0;transform:translate(-50%)translateY(-8px)scale(.98)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.search-overlay__panel{animation:.12s ease-out forwards search-panel-fade}}@keyframes search-panel-fade{0%{opacity:0}to{opacity:1}}.search-overlay__input-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:14px 16px;display:flex}.search-overlay__icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.search-overlay__input{font-family:var(--font-body);color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:15px;line-height:1}.search-overlay__input::placeholder{color:var(--text-muted)}.search-overlay__esc{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:11px}.search-overlay__results{scrollbar-width:thin;scrollbar-color:var(--border)transparent;max-height:400px;padding:6px;overflow-y:auto}.search-overlay__results[hidden],.search-overlay__empty[hidden]{display:none}.search-overlay__results::-webkit-scrollbar{width:4px}.search-overlay__results::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}.search-overlay__results::-webkit-scrollbar-track{background:0 0}.search-result{cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;text-decoration:none;transition:background .1s;display:flex}.search-result:hover,.search-result.is-selected{background:#ffffff0d}.search-result__icon{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.search-result__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.search-result__title{font-family:var(--font-body);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.search-result__title mark{background:var(--accent-subtle);color:var(--accent-hover);border-radius:2px;padding:0 1px;font-weight:600}.search-result__desc{font-family:var(--font-body);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.search-result__category{flex-shrink:0;align-items:center;gap:6px;display:flex}.search-result__cat-label{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);white-space:nowrap;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.search-result[data-category=lesson] .search-result__cat-label,.search-result[data-category=instruction] .search-result__cat-label{color:var(--accent-hover);border-color:var(--accent-border);background:var(--accent-subtle)}.search-result[data-category=register] .search-result__cat-label{color:#fbbf24;background:#fbbf2414;border-color:#fbbf2440}.search-result[data-category=concept] .search-result__cat-label{color:#a78bfa;background:#a78bfa14;border-color:#a78bfa40}.search-result[data-category=challenge] .search-result__cat-label{color:#fb923c;background:#fb923c14;border-color:#fb923c40}.search-result__arrow{width:14px;height:14px;color:var(--text-muted)}.search-overlay__footer{border-top:1px solid var(--border);background:var(--bg-elevated);gap:16px;padding:8px 16px;display:flex}.search-overlay__footer span{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.search-overlay__empty{text-align:center;font-family:var(--font-body);color:var(--text-muted);padding:24px 16px;font-size:14px}.clip-chip-anchor{z-index:1000;--chip-body-top:#ffffff0d;--chip-body-bottom:#0003;--chip-stroke:var(--accent);--chip-die-fill:var(--bg-base);justify-content:center;align-items:center;width:74px;height:74px;display:flex;position:fixed;bottom:24px;right:24px}.clip-chip-anchor #chip-reactor,.clip-chip-anchor #chip-stage,.clip-chip-anchor .cpu-pet__svg{width:100%;height:100%}.clip-chip-anchor #chip-stage{transform-origin:50%;animation:5.5s ease-in-out infinite clip-chip-bob}.clip-chip-anchor .cpu-pet__pin-dot{animation:1.9s ease-in-out infinite clip-chip-pin-pulse;animation-delay:var(--pin-delay,0s)}.clip-chip-anchor .cpu-pet__eye{transform-box:fill-box;transform-origin:50%}.clip-chip-anchor--calm .cpu-pet__mouth--happy{opacity:0}@keyframes clip-chip-bob{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-3px)rotate(1deg)}}@keyframes clip-chip-pin-pulse{0%,to{opacity:.35}50%{opacity:.9}}#clip-bubble{z-index:1001;min-width:120px;max-width:220px;position:fixed;bottom:130px;right:32px}#clip-bubble[hidden]{display:none}.clip-bubble__text{border:1px solid var(--border);font-family:var(--font-mono);color:var(--text-primary);background:#1a1a1a;border-radius:10px;padding:10px 28px 10px 12px;font-size:12px;line-height:1.5;position:relative;box-shadow:0 4px 20px #0009}.clip-bubble__dismiss{width:16px;height:16px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;transition:color .15s,background .15s;display:flex;position:absolute;top:6px;right:6px}.clip-bubble__dismiss:hover{color:var(--text-primary);background:#ffffff0f}.clip-bubble__tail{width:12px;height:8px;position:absolute;bottom:-8px;right:32px;overflow:hidden}.clip-bubble__tail:before{content:"";border:1px solid var(--border);background:#1a1a1a;width:12px;height:12px;position:absolute;top:-6px;left:0;transform:rotate(45deg)}@keyframes clip-bubble-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes clip-bubble-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}.clip-bubble.is-entering{animation:.25s cubic-bezier(.16,1,.3,1) forwards clip-bubble-in}.clip-bubble.is-leaving{animation:.2s ease-in forwards clip-bubble-out}.theme-toggle__icon--sun{display:inline-flex!important}.theme-toggle__icon--moon,[data-theme=dark] .theme-toggle__icon--sun{display:none!important}[data-theme=dark] .theme-toggle__icon--moon{display:inline-flex!important}.nav-mobile-shell{position:relative}.nav-mobile-menu{top:var(--nav-height,64px);border-top:1px solid var(--border);z-index:999;background:#0a0a0a;display:none;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.nav-mobile-menu.is-open{display:block}.nav-mobile-link{border-bottom:1px solid var(--border);color:var(--text-primary);font-family:var(--font-body);padding:16px 24px;font-size:16px;font-weight:500;text-decoration:none;transition:color .12s;display:block}.nav-mobile-link:hover,.nav-mobile-link.nav-link-active{color:var(--accent-hover)}.nav-mobile-theme-row{border-bottom:1px solid var(--border);color:var(--text-primary);font-family:var(--font-body);justify-content:space-between;align-items:center;padding:16px 24px;font-size:16px;display:flex}.nav-mobile-actions{padding:24px}.nav-mobile-actions .nav-signin-btn{border-color:var(--border-hover);border-radius:10px;justify-content:center;align-items:center;width:100%;height:48px;font-size:15px;display:flex}.nav-hamburger{display:none}@media (width<=768px){.nav-inner{padding:0 16px 0 18px}.nav-logo{margin-right:0;font-size:14px}.nav-links{display:none!important}.nav-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.nav-status-badge{display:none!important}.nav-signin-btn{justify-content:center!important;align-items:center!important;height:34px!important;padding:0 14px!important;line-height:1!important;display:inline-flex!important}.nav-theme-toggle{border-radius:6px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.nav-search-btn{display:none}.nav-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:34px;height:34px;display:inline-flex!important}.nav-hamburger span{background:var(--text-primary);border-radius:999px;width:18px;height:2px;display:block}}body.auth-modal-open{overflow:hidden}.auth-modal{z-index:1000;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.auth-modal__backdrop{backdrop-filter:blur(4px);opacity:0;background:#0009;transition:opacity .2s;position:absolute;inset:0}.auth-modal__card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-surface);width:min(400px,100vw - 32px);box-shadow:var(--shadow-lg);opacity:0;padding:32px;transition:opacity .25s,transform .25s;position:relative;transform:translateY(16px)}.auth-modal.is-visible .auth-modal__backdrop{opacity:1}.auth-modal.is-visible .auth-modal__card{opacity:1;transform:translateY(0)}.auth-modal__close{color:var(--text-muted);font-family:var(--font-body);cursor:pointer;background:0 0;border:0;font-size:18px;line-height:1;position:absolute;top:12px;right:12px}.auth-modal__brand{color:var(--accent);font-family:var(--font-display);font-size:18px}.auth-modal__subhead{color:var(--text-secondary);font-family:var(--font-display);font-size:13px}.auth-modal__brand-lockup{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.auth-modal__brand-stack{flex-direction:column;gap:4px;display:flex}.auth-modal__logo{width:34px;height:34px;display:block}.auth-modal__form{flex-direction:column;gap:16px;margin-top:24px;display:flex}.auth-modal__field{flex-direction:column;gap:4px;display:flex}.auth-modal__field-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.auth-modal__label{color:var(--text-muted);font-family:var(--font-body);font-size:11px}.auth-modal__input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);width:100%;height:36px;color:var(--text-primary);font-family:var(--font-body);padding:0 12px;font-size:13px}.auth-modal__input:focus{border-color:var(--accent);outline:none}.auth-modal__checkbox{color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;align-items:center;gap:8px;font-size:12px;display:inline-flex}.auth-modal__checkbox input{width:14px;height:14px;accent-color:var(--accent);margin:0}.auth-modal__info{color:var(--text-muted);font-family:var(--font-body);text-align:center;font-size:12px}.auth-modal__error{color:var(--danger);font-family:var(--font-body);text-align:center;margin-top:-4px;font-size:12px}.auth-modal__field--turnstile{gap:8px}.auth-modal__turnstile-shell{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);place-items:center;min-height:66px;padding:10px;display:grid}.auth-modal__turnstile-status{color:var(--text-muted);font-family:var(--font-body);text-align:center;font-size:11px}.auth-modal__turnstile-status.is-success{color:var(--success)}.auth-modal__turnstile-status.is-error{color:var(--danger)}.auth-modal__primary{border-radius:var(--radius-md);background:var(--accent);color:#fff;width:100%;height:36px;font-family:var(--font-body);cursor:pointer;border:0;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:500;display:inline-flex}.auth-modal__primary:hover:not(:disabled){background:var(--accent-hover)}.auth-modal__primary:disabled{cursor:not-allowed;opacity:.7}.auth-modal__spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:999px;width:12px;height:12px;animation:.8s linear infinite auth-spin}.auth-modal__actions{flex-direction:column;gap:8px;margin-top:16px;display:flex}.auth-modal__text-button{color:var(--text-secondary);font-family:var(--font-body);text-align:center;cursor:pointer;background:0 0;border:0;font-size:12px}.auth-modal__text-button:hover{color:var(--text-primary)}.auth-modal__avatar-section{gap:10px;display:grid}.auth-modal__avatar-presets{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.auth-modal__avatar-option{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);height:40px;color:var(--text-primary);cursor:pointer;font-size:18px}.auth-modal__avatar-option.is-selected{border-color:var(--accent);background:var(--accent-subtle)}.auth-modal__upload{color:var(--text-secondary);font-family:var(--font-body);gap:6px;font-size:12px;display:grid;position:relative}.auth-modal__upload-button{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);min-height:36px;color:var(--text-primary);cursor:pointer;transition:border-color var(--transition),background-color var(--transition),transform var(--transition);justify-content:center;align-items:center;padding:0 14px;font-size:13px;font-weight:600;display:inline-flex}.auth-modal__upload:hover .auth-modal__upload-button{border-color:var(--accent-border);background:var(--accent-subtle);transform:translateY(-1px)}.auth-modal__upload input{opacity:0;cursor:pointer;position:absolute;inset:0}.auth-modal__avatar-preview{border:1px solid var(--border);border-radius:999px;width:56px;height:56px;overflow:hidden}.auth-modal__avatar-preview-image{object-fit:cover;width:100%;height:100%}@media (width<=480px){.auth-modal__card{padding:28px 20px 24px}.auth-modal__field-row{grid-template-columns:1fr;gap:16px}}@keyframes auth-spin{to{transform:rotate(360deg)}}
