:root{--bg: #ffffff;--bg-soft: #f6f7f9;--bg-tint: #eef1f6;--surface: #ffffff;--surface-translucent: rgba(255,255,255,.88);--dot: var(--line);--scrim: rgba(19,22,28,.62);--ink: #13161c;--ink-soft: #5a6372;--inline-code-ink: #2d3340;--line: #e4e7ec;--line-strong: #cdd3dc;--accent: #1f48e6;--accent-soft: #eaeefc;--accent-border: #d4ddfb;--c1: #1f48e6;--c1-soft: #eaeefc;--c2: #c2730a;--c2-soft: #fbf0db;--c3: #0a8f63;--c3-soft: #e2f4ed;--code-bg: #171b26;--code-ink: #e7ebf2;--code-lang-bg: #2b3142;--code-lang-ink: #9aa6bd;--radius: 14px;--shadow: 0 1px 2px rgba(19,22,28,.04), 0 8px 24px -12px rgba(19,22,28,.12)}[data-theme=dark]{--bg: #0f1115;--bg-soft: #181b22;--bg-tint: #1f232c;--surface: #1a1d24;--surface-translucent: rgba(15,17,21,.82);--dot: rgba(255,255,255,.05);--scrim: rgba(0,0,0,.74);--ink: #e8ebf2;--ink-soft: #9aa3b3;--inline-code-ink: #c8cfde;--line: #262a33;--line-strong: #353a44;--accent: #6e8bff;--accent-soft: #1a2452;--accent-border: #2b3a78;--c1: #6e8bff;--c1-soft: #1a2452;--c2: #e2a04a;--c2-soft: #3a2a0f;--c3: #2db585;--c3-soft: #0e2c20;--shadow: 0 1px 2px rgba(0,0,0,.4), 0 8px 24px -12px rgba(0,0,0,.6)}body,.nav,.module,.card,.workshop,.note,.diagram,.fstep,.tablewrap,.arch-stage,.arch-modal-card,.arch-modal-close,.theme-toggle,.nav-links button,footer{transition:background-color .25s ease,border-color .25s ease,color .25s ease}[data-theme=dark] .arch-img{filter:brightness(.92) contrast(1.02)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:IBM Plex Sans,system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.62;-webkit-font-smoothing:antialiased;background-image:radial-gradient(var(--dot) .7px,transparent .7px);background-size:26px 26px;background-attachment:fixed}.nav{position:sticky;top:0;z-index:100;background:var(--surface-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.nav-inner{position:relative;max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.6rem;flex-wrap:wrap;gap:.6rem}.nav-org-logo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);height:44px;width:auto;pointer-events:none;-webkit-user-select:none;user-select:none}[data-theme=dark] .nav-org-logo{filter:brightness(.95) invert(.92) hue-rotate(180deg)}@media (max-width: 720px){.nav-org-logo{display:none}}.brand{display:flex;align-items:center;gap:.6rem;font-family:Bricolage Grotesque,system-ui,sans-serif;font-weight:800;font-size:1.12rem;letter-spacing:-.02em;background:none;border:none;cursor:pointer;color:inherit;padding:0}.brand .mark{width:30px;height:30px;border-radius:8px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;transform:rotate(-8deg)}.nav-links{display:flex;gap:.15rem;flex-wrap:wrap}.nav-links button{font-family:inherit;font-size:.83rem;font-weight:500;color:var(--ink-soft);background:none;border:1px solid transparent;padding:.4rem .72rem;border-radius:8px;cursor:pointer;transition:.18s}.nav-links button:hover{color:var(--ink);background:var(--bg-soft)}.nav-links button.active{color:var(--accent);background:var(--accent-soft);border-color:var(--accent-border);font-weight:600}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;margin-left:.35rem;color:var(--ink);background:var(--bg-soft);border:1.5px solid var(--line-strong);border-radius:10px;cursor:pointer;box-shadow:0 1px 2px #13161c0a;transition:color .18s,background .18s,border-color .18s,transform .18s,box-shadow .18s}[data-theme=dark] .theme-toggle{box-shadow:0 1px 2px #0000004d}.theme-toggle:hover{color:var(--accent);background:var(--accent-soft);border-color:var(--accent);box-shadow:0 2px 6px -2px #1f48e64d}.theme-toggle:active{transform:scale(.94)}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.logout-btn:hover{color:#c0392b;background:#fbecec;border-color:#e89e98;box-shadow:0 2px 6px -2px #c0392b4d}[data-theme=dark] .logout-btn:hover{color:#ffb4ad;background:#3a1d1c;border-color:#8a3d38}.section{display:none;max-width:1180px;margin:0 auto;padding:3.4rem 1.6rem 5rem}.section.active{display:block;animation:rise .45s ease}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}h1{font-family:Bricolage Grotesque,sans-serif;font-weight:800;font-size:2.7rem;line-height:1.08;letter-spacing:-.03em;margin-bottom:.5rem}h2{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1.62rem;letter-spacing:-.02em;margin:2.8rem 0 1rem}h3{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1.15rem;letter-spacing:-.01em}h4{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-soft);margin-bottom:.55rem}p{color:var(--ink-soft);margin-bottom:.8rem}.lead{font-size:1.12rem;color:var(--ink-soft);max-width:70ch}a{color:var(--accent)}ul{margin:.2rem 0 .9rem 1.1rem}li{color:var(--ink-soft);margin-bottom:.32rem}code:not(.code-block code){font-family:JetBrains Mono,monospace;font-size:.86em;background:var(--bg-tint);padding:.08em .38em;border-radius:5px;color:var(--inline-code-ink)}.kicker{display:inline-block;font-family:JetBrains Mono,monospace;font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.9rem}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow)}.classcard.k1{border-top:3px solid var(--c1)}.classcard.k2{border-top:3px solid var(--c2)}.classcard.k3{border-top:3px solid var(--c3)}.tag{display:inline-block;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:6px;letter-spacing:.02em}.tag.k1{background:var(--c1-soft);color:var(--c1)}.tag.k2{background:var(--c2-soft);color:var(--c2)}.tag.k3{background:var(--c3-soft);color:var(--c3)}.tag.neutral{background:var(--bg-tint);color:var(--ink-soft)}.tablewrap{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:1.2rem 0}table{width:100%;border-collapse:collapse;font-size:.9rem}th{background:var(--bg-soft);text-align:left;font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);padding:.7rem .9rem}td{padding:.7rem .9rem;border-top:1px solid var(--line);color:var(--ink-soft);vertical-align:top}tr:hover td{background:var(--bg-soft)}.code-block{background:var(--code-bg);border-radius:12px;padding:1.15rem 1.25rem;margin:1rem 0;overflow-x:auto;position:relative}.code-block pre{font-family:JetBrains Mono,monospace;font-size:.82rem;line-height:1.7;color:var(--code-ink);white-space:pre}.code-block .lang{position:absolute;top:0;right:0;font-family:JetBrains Mono,monospace;font-size:.66rem;font-weight:600;letter-spacing:.06em;background:var(--code-lang-bg);color:var(--code-lang-ink);padding:.18rem .6rem;border-bottom-left-radius:8px}.kw{color:#ff8e7d}.fn{color:#c9a6ff}.st{color:#9ed29a}.cm{color:#6b7488;font-style:italic}.de{color:#f3c969}.ty{color:#6cc3ff}.nu{color:#f3c969}.module{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);margin:1.2rem 0;overflow:hidden}.module-head{display:flex;align-items:center;gap:.9rem;padding:1.05rem 1.3rem;cursor:pointer;-webkit-user-select:none;user-select:none;border-left:4px solid var(--accent);transition:background-color .18s ease}.module.k1 .module-head{border-left-color:var(--c1)}.module.k2 .module-head{border-left-color:var(--c2)}.module.k3 .module-head{border-left-color:var(--c3)}.module-head:hover{background:var(--bg-soft)}.module-head:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;background:var(--bg-soft)}.module-head h3{flex:1;color:var(--ink)}.chev{transition:transform .25s ease;color:var(--ink-soft);font-size:1.1rem;flex-shrink:0}.module.open .chev{transform:rotate(90deg)}.module.open{box-shadow:0 2px 4px #13161c0a,0 12px 32px -16px #13161c2e}[data-theme=dark] .module.open{box-shadow:0 2px 4px #0006,0 12px 32px -16px #000000b3}.module-body{display:none;padding:.4rem 1.5rem 1.6rem;border-top:1px solid var(--line)}.module.open .module-body{display:block}.block{margin:1.3rem 0}.block:first-child{margin-top:1rem}.section-label{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-soft);margin:1.3rem 0 .55rem}.workshop{border:1px solid var(--line-strong);border-radius:12px;background:var(--bg-soft);padding:1.15rem 1.3rem;margin:1.3rem 0 .3rem;border-left:4px solid var(--accent)}.module.k1 .workshop{border-left-color:var(--c1)}.module.k2 .workshop{border-left-color:var(--c2)}.module.k3 .workshop{border-left-color:var(--c3)}.ws-label{display:inline-flex;align-items:center;gap:.4rem;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}.module.k2 .ws-label{color:var(--c2)}.module.k3 .ws-label{color:var(--c3)}.ws-label:before{content:"";width:7px;height:7px;border-radius:2px;background:currentColor}.workshop .wt{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1rem;margin-bottom:.35rem}.workshop ol{margin:.4rem 0 .2rem 1.1rem}.workshop ol li{margin-bottom:.28rem;font-size:.92rem}.deliv{font-size:.84rem;margin-top:.6rem;color:var(--ink)}.deliv b{color:var(--ink)}.note{border-left:3px solid var(--accent);background:var(--accent-soft);padding:.7rem 1rem;border-radius:0 8px 8px 0;margin:1rem 0;font-size:.9rem;color:var(--ink)}.note b{color:var(--ink)}.note.cloud{border-left-color:var(--c2);background:var(--c2-soft)}.objlist li{margin-bottom:.4rem}.gloss-entry{margin:.6rem 0 .95rem;padding:1rem 1.15rem 1.05rem;background:var(--bg-soft);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:10px}.gloss-entry+.gloss-entry{margin-top:.75rem}.gloss-entry-term{font-family:Bricolage Grotesque,sans-serif;font-size:1.05rem;font-weight:700;color:var(--ink);margin:0 0 .25rem;line-height:1.25}.gloss-entry-short{color:var(--ink-soft);font-style:italic;font-size:.9rem;line-height:1.5;margin-bottom:.65rem}.gloss-entry-long{font-size:.92rem;line-height:1.6;color:var(--ink)}.gloss-entry-long p{margin-bottom:.55rem}.gloss-entry-long p:last-child{margin-bottom:0}.gloss-entry-example{margin-top:.7rem}.gloss-entry-example .code-block{margin:0}.gloss-entry-modules{margin-top:.75rem;display:flex;align-items:center;flex-wrap:wrap;gap:.35rem}.gloss-entry-modules-label{font-size:.78rem;color:var(--ink-soft);font-style:italic;margin-right:.15rem}.module-figure{margin:1.1rem 0 1.4rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden;box-shadow:var(--shadow)}.module-figure img{display:block;width:100%;height:auto}[data-theme=dark] .module-figure img{filter:brightness(.92) contrast(1.02)}.module-figure figcaption{padding:.55rem .9rem .7rem;font-size:.82rem;color:var(--ink-soft);text-align:center;border-top:1px solid var(--line);background:var(--bg-soft);font-style:italic}.m1-flow{margin:.6rem 0 1rem;padding:.7rem 1rem;background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:8px;color:var(--ink);font-family:JetBrains Mono,monospace;font-size:.86rem;font-weight:600;text-align:center;line-height:1.6}.ascii-block{margin:.6rem 0 .8rem;padding:.75rem 1rem;background:var(--bg-soft);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:8px;font-family:JetBrains Mono,monospace;font-size:.82rem;color:var(--ink);line-height:1.6;white-space:pre;overflow-x:auto}.m1-recap{margin:.5rem 0 .8rem 1.4rem;counter-reset:recap;list-style:none}.m1-recap li{position:relative;padding-left:1.8rem;margin-bottom:.45rem;counter-increment:recap}.m1-recap li:before{content:counter(recap);position:absolute;left:0;top:.1rem;width:1.35rem;height:1.35rem;border-radius:50%;background:var(--accent);color:#fff;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center}.arch-hint{font-size:.9rem;color:var(--ink-soft);display:flex;align-items:center;gap:.5rem;margin:.5rem 0 1rem}.arch-hint:before{content:"☞";color:var(--accent);font-size:1.15rem}.arch-explorer{margin:.6rem 0 1.3rem}.arch-stage{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:var(--surface)}.arch-img{width:100%;aspect-ratio:1536/1024;background-image:var(--arch);background-size:100% 100%;background-repeat:no-repeat;display:block}.arch-hotspots{position:absolute;top:0;right:0;bottom:0;left:0}.hotspot{position:absolute;border:1.6px solid rgba(31,72,230,.3);border-radius:7px;background:transparent;cursor:pointer;padding:0;z-index:2;transition:border-color .15s,background .15s}.hotspot:hover{background:#1f48e61f;border-color:var(--accent)}.hotspot.k1:hover{background:#1f48e621;border-color:var(--c1)}.hotspot.k2:hover{background:#c2730a26;border-color:var(--c2)}.hotspot.k3:hover{background:#0a8f6326;border-color:var(--c3)}.hotspot.neutral:hover{background:#5a637221;border-color:var(--ink-soft)}.hotspot.active{z-index:6;border-width:3px}.hotspot.active.k1{border-color:#6e8bff}.hotspot.active.k2{border-color:#e7a23c}.hotspot.active.k3{border-color:#3fc191}.hotspot.active.neutral{border-color:#fff}.arch-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:none;align-items:center;justify-content:center;background:var(--scrim);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.arch-modal.open{display:flex}.arch-modal-card{position:relative;display:flex;flex-direction:column;background:var(--surface);width:90vw;height:90vh;max-width:none;border-top:5px solid var(--line-strong);box-shadow:0 24px 64px #13161c66;overflow:hidden;animation:archPop .19s ease-out}[data-theme=dark] .arch-modal-card{box-shadow:0 24px 64px #000000b3}.arch-modal-card.k1{border-top-color:var(--c1)}.arch-modal-card.k2{border-top-color:var(--c2)}.arch-modal-card.k3{border-top-color:var(--c3)}.arch-modal-card.neutral{border-top-color:var(--ink-soft)}@keyframes archPop{0%{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}.arch-modal-close{position:absolute;top:.8rem;right:.85rem;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:var(--bg-soft);color:var(--ink-soft);font-size:1.35rem;line-height:1;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;transition:background .15s}.arch-modal-close:hover{background:var(--bg-tint);color:var(--ink)}.arch-modal-scroll{flex:1;overflow-y:auto;padding:2rem 2.4rem 2.6rem}.arch-detail-grid{display:grid;grid-template-columns:300px 1fr;gap:1.5rem;align-items:start}.arch-crop{border:1px solid var(--line);border-radius:10px;background-repeat:no-repeat;width:100%;box-shadow:var(--shadow)}.arch-detail-body h3{margin:.15rem 0 .55rem}.arch-ref{display:inline-block;font-family:JetBrains Mono,monospace;font-size:.71rem;font-weight:600;background:var(--bg-tint);color:#3a414e;padding:.22rem .55rem;border-radius:6px;margin-bottom:.5rem}.arch-gloss{margin-top:1rem;border-top:1px solid var(--line);padding-top:.85rem}.arch-gloss h4{margin-bottom:.55rem}.arch-lead{margin:.15rem 0 .7rem;color:var(--ink);font-size:.95rem;line-height:1.5}.arch-list{list-style:none;margin:.2rem 0 .55rem;padding:0}.arch-list li{position:relative;padding-left:1.15rem;margin-bottom:.5rem;font-size:.9rem;color:var(--ink-soft);line-height:1.5}.arch-list li:before{content:"—";position:absolute;left:0;color:var(--accent);font-weight:700}.arch-list li b{color:var(--ink)}.arch-note{margin:.5rem 0 .15rem;font-size:.88rem;color:var(--ink-soft);line-height:1.5;border-left:3px solid var(--accent);padding-left:.7rem}.gloss-hint{font-size:.78rem;color:var(--ink-soft);margin-bottom:.6rem;font-style:italic}.gloss-item{position:relative;display:block;width:100%;text-align:left;font-family:inherit;font-size:.86rem;color:var(--ink-soft);margin-bottom:.4rem;padding:.55rem 1.8rem .55rem .7rem;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;cursor:pointer;line-height:1.45;transition:background-color .15s ease,border-color .15s ease,transform .12s ease}.gloss-item:hover,.gloss-item:focus-visible{background:var(--accent-soft);border-color:var(--accent-border);outline:none}.gloss-item:active{transform:translateY(1px)}.gloss-item b{color:var(--ink);font-family:Bricolage Grotesque,sans-serif;font-weight:700}.gloss-item-chev{position:absolute;right:.65rem;top:50%;transform:translateY(-50%);color:var(--ink-soft);font-size:1.1rem;line-height:1;transition:transform .15s ease,color .15s ease}.gloss-item:hover .gloss-item-chev,.gloss-item:focus-visible .gloss-item-chev{color:var(--accent);transform:translateY(-50%) translate(3px)}.gloss-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:none;align-items:center;justify-content:center;background:var(--scrim);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);padding:1.5rem}.gloss-modal.open{display:flex}.gloss-modal-card{position:relative;background:var(--surface);width:100%;max-width:640px;max-height:86vh;border-radius:var(--radius);border-top:4px solid var(--accent);box-shadow:0 24px 64px #13161c73;overflow:hidden;animation:archPop .18s ease-out;display:flex;flex-direction:column}[data-theme=dark] .gloss-modal-card{box-shadow:0 24px 64px #000000bf}.gloss-modal-scroll{flex:1;overflow-y:auto;padding:1.6rem 1.8rem 1.8rem}.gloss-modal-kicker{display:inline-block;font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-border);padding:.2rem .55rem;border-radius:6px;margin-bottom:.55rem}.gloss-modal-term{margin:.1rem 0 .4rem;font-size:1.45rem;line-height:1.2}.gloss-modal-short{font-size:.92rem;color:var(--ink-soft);font-style:italic;margin-bottom:.85rem;line-height:1.5}.gloss-modules{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}.gloss-module-badge{font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:600;background:var(--bg-tint);color:var(--ink);border:1px solid var(--line);padding:.18rem .5rem;border-radius:5px}.gloss-modal-long{font-size:.92rem;line-height:1.6;color:var(--ink)}.gloss-modal-long p{margin-bottom:.7rem}.gloss-modal-long p:last-child{margin-bottom:0}.gloss-modal-example{margin-top:1rem}.gloss-modal-example .code-block{margin:0}.gloss-related{margin-top:1.2rem;padding-top:.85rem;border-top:1px solid var(--line)}.gloss-related-label{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:.82rem;color:var(--ink);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.06em}.gloss-related-chips{display:flex;flex-wrap:wrap;gap:.4rem}.gloss-chip{font-family:inherit;font-size:.82rem;font-weight:600;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-border);padding:.3rem .7rem;border-radius:999px;cursor:pointer;transition:background-color .15s ease,transform .12s ease}.gloss-chip:hover:not(:disabled),.gloss-chip:focus-visible:not(:disabled){background:var(--accent);color:#fff;outline:none}.gloss-chip:active:not(:disabled){transform:translateY(1px)}.gloss-chip:disabled{opacity:.5;cursor:default}@media (max-width: 680px){.gloss-modal{padding:0}.gloss-modal-card{max-width:none;max-height:100vh;height:100vh;border-radius:0}.gloss-modal-scroll{padding:1.3rem 1.1rem 1.6rem}}.arch-dia-block{margin-top:1.3rem;border-top:1px solid var(--line);padding-top:1rem}.arch-dia-block h4{margin-bottom:.6rem}.hp-tagline{font-size:.9rem;color:var(--ink-soft);margin-bottom:.8rem;font-style:italic}.hp-page-title{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1rem;margin:.8rem 0 .4rem}.hp-page-body{font-size:.92rem}@media (max-width: 680px){.arch-detail-grid{grid-template-columns:1fr}.arch-crop{max-width:340px}.arch-modal-card{width:100vw}.arch-modal-scroll{padding:1.5rem 1.2rem 2rem}}.diagram{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:1.3rem;margin:1.2rem 0;box-shadow:var(--shadow)}.diagram .dia-cap{display:flex;align-items:center;gap:.5rem;margin-bottom:.9rem;flex-wrap:wrap}.dia-tag{font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:var(--accent-soft);color:var(--accent);padding:.2rem .55rem;border-radius:6px}.dia-src{font-size:.76rem;color:var(--ink-soft);font-family:JetBrains Mono,monospace}.mermaid-target{display:flex;justify-content:center;overflow-x:auto}.mermaid-target svg{max-width:100%;height:auto}.flow6{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.3rem 0}.fstep{flex:1;min-width:140px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:.85rem .9rem;box-shadow:var(--shadow)}.fstep .fn-n{width:22px;height:22px;border-radius:6px;background:var(--accent);color:#fff;font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:.45rem}.fstep .fn-t{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:.92rem}.fstep .fn-d{font-size:.76rem;color:var(--ink-soft)}footer{border-top:1px solid var(--line);background:var(--bg-soft);text-align:center;padding:2.6rem 1.5rem}footer .ft{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1.05rem}footer p{font-size:.86rem;margin:.3rem 0 0}.login-screen{--l-bg: #f8f9ff;--l-surface: #ffffff;--l-surface-low: #eff4ff;--l-fg: #0b1c30;--l-fg-muted: #444650;--l-fg-dim: #757781;--l-primary: #14316c;--l-primary-container: #2f4884;--l-accent: #a73a06;--l-accent-bright: #ff7945;--l-outline-variant: rgba(20, 49, 108, .2);--l-r-sm: .125rem;--l-r-md: .25rem;--l-r-lg: .5rem;--l-ease: cubic-bezier(.22, 1, .36, 1);position:fixed;top:0;right:0;bottom:0;left:0;overflow-y:auto;font-family:Inter,system-ui,sans-serif;background:var(--l-bg);color:var(--l-fg);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}.login-screen *{box-sizing:border-box}.login-screen a{color:inherit;text-decoration:none}.login-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.login-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--l-outline-variant) 1px,transparent 1px),linear-gradient(90deg,var(--l-outline-variant) 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);opacity:.55}.login-bg-arab{position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;opacity:.04;animation:l-arab-drift 80s linear infinite}.login-bg-arab svg{width:100%;height:100%}@keyframes l-arab-drift{0%{transform:translate(0)}to{transform:translate(-160px,-160px)}}.login-bg-zellij{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;perspective:1600px}.login-zring{position:absolute;transform-style:preserve-3d}.login-zring-1{width:720px;height:720px;color:var(--l-primary);opacity:.12;animation:l-spin-cw 60s linear infinite}.login-zring-2{width:1040px;height:1040px;color:var(--l-accent);opacity:.1;animation:l-spin-ccw 90s linear infinite}.login-zring-3{width:1380px;height:1380px;color:var(--l-primary-container);opacity:.07;animation:l-spin-cw 140s linear infinite}.login-zring svg{width:100%;height:100%}@keyframes l-spin-cw{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes l-spin-ccw{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.login-bg-shape{position:absolute;border:1.5px solid var(--l-accent)}.login-shape-sq{width:220px;height:220px;top:12%;left:8%;animation:l-drift-a 22s ease-in-out infinite}.login-shape-sq2{width:140px;height:140px;border-color:var(--l-primary);bottom:14%;right:10%;animation:l-drift-b 28s ease-in-out infinite}.login-shape-dot{width:14px;height:14px;background:var(--l-accent);border:none;top:24%;right:18%;animation:l-drift-c 18s ease-in-out infinite}.login-shape-dot2{width:10px;height:10px;background:var(--l-primary);border:none;bottom:28%;left:22%;animation:l-drift-d 24s ease-in-out infinite}@keyframes l-drift-a{0%,to{transform:rotate(0) translate(0)}50%{transform:rotate(35deg) translate(40px,-30px)}}@keyframes l-drift-b{0%,to{transform:rotate(0) translate(0)}50%{transform:rotate(-25deg) translate(-30px,40px)}}@keyframes l-drift-c{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-30px,50px) scale(1.4)}}@keyframes l-drift-d{0%,to{transform:translate(0) scale(1)}50%{transform:translate(40px,-30px) scale(.7)}}.login-net-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.login-topbar{position:fixed;top:0;left:0;right:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:22px 32px}.login-brand{display:inline-flex;align-items:center;gap:10px}.login-brand-logo{height:36px;width:auto;display:block}.login-stage{position:relative;z-index:5;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:88px 24px 32px}.login-card{position:relative;width:100%;max-width:440px;background:var(--l-surface);border:1.5px solid var(--l-primary);border-radius:var(--l-r-lg);padding:40px 36px 36px;box-shadow:8px 8px 0 0 var(--l-primary);animation:l-card-in .7s var(--l-ease) both}@keyframes l-card-in{0%{opacity:0;transform:translate(-6px,-6px);box-shadow:0 0 0 0 var(--l-primary)}to{opacity:1;transform:none;box-shadow:8px 8px 0 0 var(--l-primary)}}.login-kicker{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--l-accent);margin-bottom:14px}.login-kicker-dot{width:6px;height:6px;background:var(--l-accent);border-radius:999px}.login-h1{font-family:Space Grotesk,sans-serif;font-size:32px;font-weight:700;line-height:1.05;letter-spacing:-.025em;color:var(--l-primary);margin:0 0 8px}.login-h1 em{color:var(--l-accent);font-style:normal}.login-sub{color:var(--l-fg-muted);font-size:14px;margin:0 0 28px}.login-screen form{display:flex;flex-direction:column;gap:14px}.login-field{position:relative}.login-field-label{display:block;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--l-fg-dim);margin-bottom:6px}.login-input{width:100%;height:48px;padding:0 14px;border:1.5px solid var(--l-outline-variant);border-radius:var(--l-r-md);background:var(--l-surface);font-family:inherit;font-size:15px;color:var(--l-fg);transition:all .16s var(--l-ease);outline:none}.login-input::placeholder{color:var(--l-fg-dim)}.login-input:hover{border-color:var(--l-primary)}.login-input:focus{border-color:var(--l-accent);box-shadow:3px 3px 0 0 var(--l-accent);transform:translate(-1px,-1px)}.login-field-pw .login-input{padding-right:46px}.login-pw-toggle{position:absolute;right:6px;bottom:6px;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;color:var(--l-fg-dim);cursor:pointer;padding:0;border-radius:var(--l-r-sm);transition:color .14s var(--l-ease),background .14s var(--l-ease)}.login-pw-toggle:hover{color:var(--l-primary);background:var(--l-surface-low)}.login-error{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--l-accent);margin:6px 0 -4px}.login-btn{margin-top:18px;display:inline-flex;align-items:center;justify-content:center;gap:10px;height:52px;padding:0 22px;border-radius:var(--l-r-md);border:1.5px solid var(--l-accent);background:var(--l-accent);color:#fff;font-family:inherit;font-weight:700;font-size:15px;cursor:pointer;box-shadow:4px 4px 0 0 var(--l-primary);transition:all .18s var(--l-ease)}.login-btn:hover{background:var(--l-accent-bright);border-color:var(--l-accent-bright);box-shadow:6px 6px 0 0 var(--l-primary);transform:translate(-2px,-2px)}.login-btn:active{transform:translate(1px,1px);box-shadow:2px 2px 0 0 var(--l-primary)}.login-pagefoot{position:relative;z-index:5;text-align:center;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--l-fg-dim);letter-spacing:.04em;padding-bottom:24px}@media (max-width: 480px){.login-card{padding:32px 24px 28px;box-shadow:6px 6px 0 0 var(--l-primary)}.login-topbar{padding:16px 18px}.login-h1{font-size:26px}.login-shape-sq,.login-shape-sq2{display:none}}@media (prefers-reduced-motion: reduce){.login-screen *,.login-screen *:before,.login-screen *:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}@media (max-width: 720px){h1{font-size:2.1rem}.section{padding:2.2rem 1.1rem 4rem}.module-body{padding:.4rem 1rem 1.3rem}}
