@font-face{font-family:Lora;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/lora-latin-400-normal-DnxXpLNu.woff2) format("woff2"),url(/assets/lora-latin-400-normal-DBJS-Hc6.woff) format("woff")}@font-face{font-family:Lora;font-style:italic;font-display:swap;font-weight:400;src:url(/assets/lora-latin-400-italic-DYjZp4sZ.woff2) format("woff2"),url(/assets/lora-latin-400-italic-wRLkZNVE.woff) format("woff")}@font-face{font-family:Lora;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/lora-latin-500-normal-Dh16O2IA.woff2) format("woff2"),url(/assets/lora-latin-500-normal-Dbc_1yrl.woff) format("woff")}@font-face{font-family:Lora;font-style:italic;font-display:swap;font-weight:500;src:url(/assets/lora-latin-500-italic-D1ptFfg7.woff2) format("woff2"),url(/assets/lora-latin-500-italic-DaWhScir.woff) format("woff")}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-400-normal-C38fXH4l.woff2) format("woff2"),url(/assets/inter-latin-400-normal-CyCys3Eg.woff) format("woff")}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-500-normal-Cerq10X2.woff2) format("woff2"),url(/assets/inter-latin-500-normal-BL9OpVg8.woff) format("woff")}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-latin-600-normal-LgqL8muc.woff2) format("woff2"),url(/assets/inter-latin-600-normal-CiBQ2DWP.woff) format("woff")}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-mono-latin-400-normal-DMJ8VG8y.woff2) format("woff2"),url(/assets/ibm-plex-mono-latin-400-normal-CvHOgSBP.woff) format("woff")}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/ibm-plex-mono-latin-500-normal-DSY6xOcd.woff2) format("woff2"),url(/assets/ibm-plex-mono-latin-500-normal-CB9ihrfo.woff) format("woff")}@font-face{font-family:Lora;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/lora-latin-700.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Lora;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/lora-latin-ext-700.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}:root{--ink: #1C1A17;--ink-soft: #2E2A25;--paper: #FAFAF7;--paper-2: #F2EFE8;--muted: #6B6660;--line: #DDD7C8;--ocre: #B8860B;--ocre-deep: #8E6708;--particle-rgb: 28, 26, 23;color-scheme:light;--serif: "Lora", Georgia, "Times New Roman", serif;--sans: "Inter", system-ui, -apple-system, sans-serif;--mono: "IBM Plex Mono", Consolas, monospace}:root[data-theme=dark]{color-scheme:dark;--ink: #F5EFE6;--ink-soft: #D4C5B0;--paper: #1C1A17;--paper-2: #24211D;--muted: #9A9183;--line: #3A352E;--ocre: #E8511A;--ocre-deep: #FF6A33;--particle-rgb: 245, 239, 230}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){color-scheme:dark;--ink: #F5EFE6;--ink-soft: #D4C5B0;--paper: #1C1A17;--paper-2: #24211D;--muted: #9A9183;--line: #3A352E;--ocre: #E8511A;--ocre-deep: #FF6A33;--particle-rgb: 245, 239, 230}}*{box-sizing:border-box}html,body,#root{margin:0;padding:0}body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none;border-bottom:1px solid var(--line);transition:border-color .15s ease,color .15s ease}a:hover{border-bottom-color:var(--ocre)}.skip-link{position:absolute;left:8px;top:-56px;z-index:1000;background:var(--paper);color:var(--ink);border:1px solid var(--line);border-radius:6px;padding:8px 14px;font-family:var(--mono);font-size:13px;transition:top .15s ease}.skip-link:focus{top:8px}:focus-visible{outline:2px solid var(--ocre);outline-offset:2px;border-radius:2px}.article-toc{margin:28px 0;padding:16px 20px;border:1px solid var(--line);border-radius:8px;background:var(--paper-2)}.article-toc-label{margin:0 0 8px;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.article-toc ol{margin:0;padding-left:18px;display:grid;gap:6px}.article-toc a{border-bottom:none}.article-toc a:hover{color:var(--ocre)}.article-toc a[aria-current=location]{color:var(--ocre);font-weight:600}.heading-anchor{margin-left:.4em;color:var(--muted);border-bottom:none;opacity:0;transition:opacity .15s ease}h2:hover .heading-anchor,.heading-anchor:focus{opacity:1}.article-layout h2{scroll-margin-top:80px}.reading-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:1100;background:transparent;pointer-events:none}.reading-progress-bar{height:100%;width:0;background:var(--ocre)}@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}.contact-strip{display:flex;flex-wrap:wrap;gap:6px 14px;align-items:baseline;margin:28px 0 0;padding-top:18px;border-top:1px solid var(--line);font-family:var(--mono);font-size:13px;color:var(--muted)}.contact-strip-name{color:var(--ink);font-weight:600}.contact-strip a{border-bottom:none;color:var(--ocre)}.contact-block{display:grid;gap:18px;margin:40px 0;padding:28px;border:1px solid var(--line);border-radius:10px;background:var(--paper-2)}.contact-block h2{margin:0 0 8px}.contact-block-actions{display:flex;flex-wrap:wrap;gap:18px;margin-top:14px}.contact-block-actions a{color:var(--ocre);border-bottom:none;font-family:var(--mono);font-size:14px}.contact-block-credibility{display:flex;flex-wrap:wrap;gap:8px 16px;list-style:none;margin:0;padding:0;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.writing-index{padding:0 0 60px}.writing-header{margin-bottom:36px}.writing-lead{font-size:19px;color:var(--ink-soft);max-width:60ch}.silo-card-list{display:grid;gap:18px}.silo-card{padding:26px;border:1px solid var(--line);border-radius:10px;background:var(--paper-2)}.silo-card h2{margin:0 0 8px}.silo-card p{max-width:62ch}.silo-card-meta{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:12px 0}.writing-recent{margin-top:48px}.about-experience{margin:28px 0}.about-experience-list{list-style:none;margin:0;padding:0;display:grid;gap:18px}.about-exp-head{margin:0 0 4px}.about-exp-summary{margin:0;color:var(--ink-soft)}.about-layout .contact-block{margin-top:40px}.newsletter-signup{margin:56px 0 0;padding:28px;border:1px solid var(--line);border-radius:10px;background:var(--paper-2)}.newsletter-signup h2{margin:0 0 8px}.newsletter-signup-text p{color:var(--ink-soft);max-width:56ch}.newsletter-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.newsletter-input{flex:1 1 220px;padding:11px 14px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:15px}.newsletter-btn{padding:11px 20px;border:none;border-radius:8px;background:var(--ocre);color:var(--paper);font-family:var(--mono);font-size:14px;cursor:pointer}.newsletter-btn:disabled{opacity:.6;cursor:default}.newsletter-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.newsletter-status{margin:10px 0 0;font-size:14px;min-height:1.2em}.newsletter-ok{color:var(--ocre-deep)}.newsletter-error,.newsletter-invalid{color:#b5482e}.angular-search{width:100%;max-width:360px;margin:18px 0 8px;padding:10px 14px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:15px}.share-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin:20px 0 0}.share-label{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.share-link{font-family:var(--mono);font-size:14px;color:var(--ocre);background:none;border:none;padding:0;cursor:pointer}.share-link:hover{color:var(--ocre-deep)}.container{max-width:1120px;margin:0 auto;padding:0 32px}.nav{padding:28px 0;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:13px}.nav-brand{font-weight:500;letter-spacing:-.01em;border-bottom:none}.nav-links{display:flex;gap:28px;list-style:none;margin:0;padding:0}.nav-links a{color:var(--muted);border-bottom:none}.nav-links a:hover{color:var(--ink)}.theme-toggle{background:none;border:none;padding:0;margin:0;cursor:pointer;color:var(--muted);font-size:15px;line-height:1;transition:color .15s ease}.theme-toggle:hover{color:var(--ocre)}.hero{position:relative;min-height:calc(100vh - 85px);display:flex;align-items:center;padding:20px 0 80px}.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;width:100%;align-items:center}.hero-text{max-width:480px}.hero-label{font-family:var(--mono);font-size:12px;color:var(--ocre);letter-spacing:.08em;margin:0 0 28px;font-weight:500}.hero-name{font-family:var(--serif);font-size:18px;color:var(--muted);font-weight:400;margin:0 0 10px;letter-spacing:.01em}.hero-role{font-family:var(--serif);font-size:clamp(44px,7vw,80px);font-weight:700;line-height:1.02;letter-spacing:-.02em;margin:0 0 28px;color:var(--ink)}.hero-tagline{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2vw,22px);line-height:1.45;color:var(--ink-soft);margin:0 0 44px;max-width:440px}.hero-meta{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.05em;margin:0 0 20px}.hero-cta{margin:0;font-family:var(--mono);font-size:13px;letter-spacing:.04em}.hero-cta a{color:var(--ocre);border-bottom:1px solid var(--ocre);padding-bottom:2px;font-weight:500}.hero-cta a:hover{color:var(--ocre-deep);border-bottom-color:var(--ocre-deep)}.hero-portrait{position:relative}.hero-portrait-fallback{width:100%;height:auto;display:block;opacity:.9}.hero-particles-container{position:relative;height:560px;min-height:420px}.hero-particles-container canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;pointer-events:none}section.block{padding:100px 0;border-top:1px solid var(--line)}.section-label{font-family:var(--mono);font-size:11px;color:var(--ocre);letter-spacing:.18em;text-transform:uppercase;margin:0 0 36px;font-weight:500}.case-featured{display:block}.case-company{font-family:var(--mono);font-size:12px;color:var(--muted);margin:0 0 14px;letter-spacing:.06em;text-transform:uppercase}.case-title{font-family:var(--serif);font-size:clamp(28px,3.6vw,44px);font-weight:700;line-height:1.15;letter-spacing:-.012em;margin:0 0 28px;max-width:780px;color:var(--ink)}.case-tldr{font-family:var(--serif);font-size:19px;line-height:1.55;color:var(--ink-soft);max-width:680px;margin:0 0 36px}.case-meta{display:flex;flex-wrap:wrap;gap:28px 32px;font-family:var(--mono);font-size:12px;color:var(--muted);margin:0 0 44px;letter-spacing:.02em}.case-meta-item strong{display:block;color:var(--muted);font-weight:500;margin-bottom:4px;text-transform:uppercase;letter-spacing:.1em;font-size:10px}.case-meta-item span{color:var(--ink);font-family:var(--sans);font-size:14px;font-weight:500;letter-spacing:0}.case-cta{font-family:var(--mono);font-size:13px;color:var(--ocre);border-bottom:1px solid var(--ocre);padding-bottom:3px;display:inline-block;letter-spacing:.04em;font-weight:500}.case-cta:hover{color:var(--ocre-deep);border-bottom-color:var(--ocre-deep)}.angular-teaser-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:56px;align-items:start}.angular-teaser h2{font-family:var(--serif);font-size:clamp(28px,3.4vw,42px);line-height:1.15;letter-spacing:-.012em;margin:0 0 22px;max-width:520px}.angular-teaser p{font-family:var(--serif);font-size:19px;line-height:1.6;color:var(--ink-soft);margin:0 0 32px;max-width:560px}.angular-teaser-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--line)}.angular-teaser-list li{border-bottom:1px solid var(--line)}.angular-teaser-list a{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:baseline;padding:22px 0;border-bottom:none}.angular-teaser-list span{font-family:var(--serif);font-weight:700;font-size:19px;line-height:1.35}.angular-teaser-list small{font-family:var(--mono);color:var(--muted);font-size:11px;white-space:nowrap}.angular-hub{max-width:920px;margin:0 auto;padding:20px 0 100px}.article-top-nav{display:flex;justify-content:space-between;gap:24px;align-items:baseline;margin-bottom:60px}.article-top-nav .case-back{margin-bottom:0}.language-switch{font-family:var(--mono);font-size:12px;color:var(--ocre);letter-spacing:.04em;border-bottom:1px solid var(--ocre);padding-bottom:2px}.language-switch:hover{color:var(--ocre-deep);border-bottom-color:var(--ocre-deep)}.angular-hub-header{max-width:720px;margin-bottom:68px}.angular-hub-header h1{font-family:var(--serif);font-size:clamp(36px,6vw,64px);line-height:1.08;letter-spacing:-.018em;margin:0 0 28px}.angular-hub-lead,.angular-hub-context{font-family:var(--serif);font-size:21px;line-height:1.55;color:var(--ink-soft);margin:0 0 22px}.angular-hub-context{font-size:18px;line-height:1.65;margin-bottom:0}.playbook-cta{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:28px;align-items:end;padding:28px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.angular-hub-header+.playbook-cta{margin:-28px 0 68px}.playbook-cta--article{margin:0 0 64px}.playbook-cta h2{font-family:var(--serif);font-size:clamp(24px,3vw,32px);line-height:1.18;letter-spacing:-.01em;margin:0 0 12px}.playbook-cta p:not(.section-sub-label){font-family:var(--serif);font-size:18px;line-height:1.6;color:var(--ink-soft);margin:0;max-width:680px}.playbook-cta .playbook-cta-note{margin-top:12px;font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--muted);max-width:620px}.playbook-cta-link{font-family:var(--mono);font-size:12px;color:var(--ocre);border-bottom:1px solid var(--ocre);padding-bottom:2px;white-space:nowrap}.angular-audience-paths{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;margin:0 0 68px;padding-top:30px;border-top:1px solid var(--line)}.angular-audience-path{border-top:1px solid var(--line);padding-top:18px}.angular-audience-path h2{font-family:var(--mono);font-size:11px;color:var(--ocre);letter-spacing:.14em;text-transform:uppercase;margin:0 0 12px}.angular-audience-path p{font-family:var(--sans);font-size:14px;line-height:1.6;color:var(--ink-soft);margin:0}.angular-filters{display:flex;flex-wrap:wrap;gap:8px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:40px}.angular-chip{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-soft);background:transparent;border:1px solid var(--line);border-radius:99px;padding:6px 14px;cursor:pointer;transition:border-color .15s ease,color .15s ease}.angular-chip:hover{border-color:var(--c, var(--ink));color:var(--c, var(--ink))}.angular-chip.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.angular-feature{margin-bottom:72px}.angular-hero{display:block;text-decoration:none;color:inherit;background:var(--paper-2);border:1px solid var(--line);border-radius:4px;padding:32px 34px;margin-bottom:64px;transition:border-color .15s ease}.angular-hero:hover{border-color:var(--ocre)}.angular-hero-label{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ocre);margin:0 0 14px}.angular-hero h2{font-family:var(--serif);font-size:clamp(26px,3.4vw,38px);line-height:1.12;letter-spacing:-.01em;margin:0 0 14px;overflow-wrap:break-word}.angular-hero-deck{font-family:var(--serif);font-size:18px;line-height:1.55;color:var(--ink-soft);margin:0 0 18px;max-width:44em}.angular-hero-meta{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0}.angular-section-head{display:flex;align-items:center;gap:10px;padding-bottom:12px;margin-bottom:26px;border-bottom:2px solid var(--c, var(--line))}.angular-section-dot{width:9px;height:9px;border-radius:99px;background:var(--c, var(--muted))}.angular-section-label{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--c, var(--ink));margin:0}.angular-section-count{font-family:var(--mono);font-size:11px;color:var(--muted)}.angular-list-section+.angular-list-section{margin-top:64px}.article-card-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:32px}.article-card{padding-top:24px;border-top:1px solid var(--line)}.article-card-meta,.article-meta{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 14px}.article-card-meta{display:flex;align-items:center;flex-wrap:wrap}.card-type-dot{width:7px;height:7px;border-radius:99px;background:var(--c, var(--muted));margin-right:6px}.card-type{color:var(--c, var(--muted));font-weight:600}.article-card h3{font-family:var(--serif);font-size:clamp(24px,3vw,34px);line-height:1.2;letter-spacing:-.01em;margin:0 0 16px;overflow-wrap:break-word}.article-card p:not(.article-card-meta){font-family:var(--serif);font-size:17px;line-height:1.6;color:var(--ink-soft);margin:0 0 22px}.article-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}.article-tags span{font-family:var(--mono);font-size:10px;color:var(--muted);border:1px solid var(--line);padding:4px 7px}.article-link{font-family:var(--mono);font-size:12px;color:var(--ocre);border-bottom:1px solid var(--ocre);padding-bottom:2px}.article-related{margin-top:64px;padding-top:32px;border-top:1px solid var(--line)}.article-related .section-sub-label{margin-bottom:32px}.article-pager{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}.article-pager-link{display:flex;flex-direction:column;gap:6px;padding-top:16px;border-top:1px solid var(--line);font-family:var(--serif);font-size:16px;color:var(--ink-soft);text-decoration:none}.article-pager-link span:first-child{font-family:var(--mono);font-size:11px;color:var(--ocre)}.article-pager-next{text-align:right}@media (max-width: 720px){.article-pager{grid-template-columns:1fr;gap:16px}.article-pager-next{text-align:left}}.angular-source-note{margin-top:58px;padding-top:24px;border-top:1px dashed var(--line)}.angular-source-note p{font-family:var(--mono);font-size:12px;line-height:1.7;color:var(--muted);margin:0}.article-layout{max-width:760px;margin:0 auto;padding:20px 0 100px}.article-header{margin-bottom:64px}.article-header h1{font-family:var(--serif);font-size:clamp(34px,5vw,58px);line-height:1.08;letter-spacing:-.018em;margin:0 0 28px;overflow-wrap:break-word}.article-deck{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.2vw,24px);line-height:1.5;color:var(--ink-soft);margin:0}.article-section,.article-artifact{margin-bottom:64px}.article-section h2,.article-artifact h2{font-family:var(--serif);font-size:clamp(24px,3vw,32px);line-height:1.2;letter-spacing:-.01em;margin:0 0 22px}.article-section p{font-family:var(--serif);font-size:19px;line-height:1.7;color:var(--ink-soft);margin:0 0 20px}.article-table-wrap{overflow-x:auto;margin-top:26px;border-top:1px solid var(--line)}.article-table{width:100%;border-collapse:collapse;font-size:14px;line-height:1.5}.article-table th{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;text-align:left;padding:16px 16px 12px 0;border-bottom:1px solid var(--line)}.article-table td{vertical-align:top;padding:16px 16px 16px 0;border-bottom:1px solid var(--line);color:var(--ink-soft)}.inline-code{display:inline-block;max-width:100%;background:#b8860b17;border:1px solid rgba(184,134,11,.22);border-radius:5px;color:#6f4f05;font-family:var(--mono);font-size:.78em;line-height:1.35;padding:.04em .36em .08em;vertical-align:.04em;white-space:nowrap}.article-code-block{position:relative;margin:30px 0 0;background:#0d1117;border:1px solid #30363d;border-radius:8px;box-shadow:0 18px 45px #1c1a1724;color:#e6edf3;overflow:hidden}.code-copy-button{position:absolute;top:7px;right:8px;z-index:2;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:#c9d1d9;background:#30363db8;border:1px solid #30363d;border-radius:6px;padding:5px 10px;cursor:pointer;transition:background .15s ease,color .15s ease}.code-copy-button:hover{background:#30363d;color:#fff}:root[data-theme=dark] .article-code-block{box-shadow:none}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .article-code-block{box-shadow:none}}.article-code-block figcaption{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:44px;background:#161b22;border-bottom:1px solid #30363d;font-family:var(--mono);font-size:12px;letter-spacing:0;color:#c9d1d9;padding:0 84px 0 72px;position:relative}.article-code-block figcaption:before{content:"";position:absolute;left:18px;top:50%;width:10px;height:10px;border-radius:50%;background:#ff5f56;box-shadow:16px 0 #ffbd2e,32px 0 #27c93f;transform:translateY(-50%)}.article-code-block figcaption span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.article-code-block figcaption span:last-child{color:#00ff94;font-size:10px;text-transform:uppercase}.article-code-block pre{margin:0;padding:22px;overflow-x:auto;scrollbar-color:#30363d #0d1117}.article-code-block pre::-webkit-scrollbar{height:10px}.article-code-block pre::-webkit-scrollbar-track{background:#0d1117}.article-code-block pre::-webkit-scrollbar-thumb{background:#30363d;border:2px solid #0d1117;border-radius:999px}.article-code-block code{font-family:var(--mono);font-size:13.5px;line-height:1.7;color:#e6edf3;white-space:pre}.code-token--comment{color:#8b949e;font-style:italic}.code-token--keyword{color:#ff7b72}.code-token--function{color:#d2a8ff}.code-token--type{color:#ffa657}.code-token--string{color:#a5d6ff}.code-token--number{color:#79c0ff}.code-token--operator{color:#c9d1d9}.code-token--label{color:#7ee787}.article-artifact{padding:30px;background:var(--paper-2)}.article-artifact ul,.source-list{margin:0;padding-left:20px}.article-artifact li,.source-list li{margin:12px 0;color:var(--ink-soft)}.source-list{font-family:var(--mono);font-size:12px;line-height:1.7;overflow-wrap:anywhere}.vignette-list{list-style:none;margin:0;padding:0}.vignette-item{padding:32px 0;border-top:1px solid var(--line)}.vignette-item:first-child{border-top:none;padding-top:0}.vignette-header{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin:0 0 14px}.vignette-title{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--ink);margin:0;letter-spacing:-.005em}.vignette-meta{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.02em;margin:0;white-space:nowrap}.vignette-body{font-family:var(--serif);font-size:17px;line-height:1.65;color:var(--ink-soft);margin:0;max-width:720px}.experience-list{list-style:none;margin:0;padding:0}.experience-item{display:grid;grid-template-columns:160px 1fr 140px;gap:32px;padding:22px 0;border-bottom:1px solid var(--line);align-items:baseline}.experience-item:last-child{border-bottom:none}.experience-company{font-family:var(--serif);font-weight:700;font-size:19px;color:var(--ink);letter-spacing:-.005em}.experience-details{font-family:var(--sans);font-size:15px;color:var(--muted);line-height:1.55}.experience-details strong{color:var(--ink);font-weight:500;display:block;margin-bottom:4px}.experience-details em{font-style:normal;color:var(--ocre);font-size:11px;font-family:var(--mono);margin-left:8px;letter-spacing:.05em;text-transform:uppercase}.experience-period{font-family:var(--mono);font-size:12px;color:var(--muted);text-align:right;letter-spacing:.02em}.case-layout{max-width:720px;margin:0 auto;padding:20px 0 100px}.case-back{display:inline-block;font-family:var(--mono);font-size:12px;color:var(--muted);border-bottom:1px solid transparent;letter-spacing:.04em;margin-bottom:60px;padding-bottom:2px}.case-back:hover{color:var(--ink);border-bottom-color:var(--ocre)}.case-header{margin-bottom:64px}.case-header .section-label{margin-bottom:24px}.case-heading{font-family:var(--serif);font-size:clamp(32px,5vw,56px);font-weight:700;line-height:1.1;letter-spacing:-.018em;margin:0 0 40px;color:var(--ink)}.case-meta-full{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:0;padding-top:32px;border-top:1px solid var(--line)}.case-meta-full>div{display:flex;flex-direction:column;gap:6px}.case-meta-full dt{font-family:var(--mono);font-size:10px;font-weight:500;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}.case-meta-full dd{font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ink);margin:0;line-height:1.45}.case-section{margin-bottom:72px}.case-section h2{font-family:var(--serif);font-size:clamp(24px,3vw,32px);font-weight:700;line-height:1.2;letter-spacing:-.01em;margin:0 0 24px;color:var(--ink)}.section-sub-label{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--ocre);letter-spacing:.18em;text-transform:uppercase;margin:0 0 18px}.case-prose{font-family:var(--serif);font-size:19px;line-height:1.7;color:var(--ink-soft);margin:0 0 20px}.case-prose:last-child{margin-bottom:0}.case-tldr-quote{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.2vw,24px);line-height:1.5;color:var(--ink);padding:4px 0 4px 24px;border-left:2px solid var(--ocre);margin:0}.approach-list{list-style:none;margin:0;padding:0}.approach-step{display:grid;grid-template-columns:56px 1fr;gap:20px;padding:32px 0;border-top:1px solid var(--line)}.approach-step:first-child{border-top:none;padding-top:4px}.step-number{font-family:var(--mono);font-size:13px;color:var(--ocre);letter-spacing:.08em;font-weight:500;padding-top:6px}.approach-body h3{font-family:var(--serif);font-size:22px;font-weight:500;line-height:1.3;margin:0 0 14px;color:var(--ink);letter-spacing:-.005em}.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding-top:8px}.result-card{display:flex;flex-direction:column;gap:10px;padding-top:20px;border-top:1px solid var(--line)}.result-value{font-family:var(--serif);font-size:clamp(30px,4vw,48px);font-weight:700;line-height:1;color:var(--ink);letter-spacing:-.02em;margin:0}.result-metric{font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ink);margin:0;line-height:1.4}.result-note{font-family:var(--sans);font-size:13px;font-style:italic;color:var(--muted);margin:0;line-height:1.55}.looking-back-list{list-style:none;margin:0;padding:0}.looking-back-list li{font-family:var(--serif);font-size:19px;line-height:1.7;color:var(--ink-soft);padding:22px 0 22px 28px;border-top:1px solid var(--line);position:relative}.looking-back-list li:before{content:"—";position:absolute;left:0;top:22px;color:var(--ocre);font-family:var(--mono)}.looking-back-list li:first-child{border-top:none;padding-top:4px}.looking-back-list li:first-child:before{top:4px}.loadtime-diagram{padding:32px;background:var(--paper-2);border-radius:2px}.loadtime-diagram .section-sub-label{margin-bottom:24px}.loadtime-bar-row{display:grid;grid-template-columns:60px 1fr 60px;align-items:center;gap:16px;margin-top:16px}.loadtime-bar-row:first-of-type{margin-top:0}.loadtime-label{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.loadtime-value{font-family:var(--mono);font-size:13px;color:var(--ink);font-weight:500;text-align:right}.loadtime-bar{height:10px;background:transparent;overflow:hidden}.loadtime-bar-before .loadtime-fill{height:100%;width:100%;background:var(--ink)}.loadtime-bar-after .loadtime-fill{height:100%;width:3.3%;background:var(--ocre)}.case-footer-nav{padding-top:40px;border-top:1px solid var(--line);margin-top:40px}.case-footer-nav .case-back{margin-bottom:0}.about-layout{max-width:620px;margin:0 auto;padding:20px 0 100px}.about-layout .section-label{margin-bottom:44px}.about-para{font-family:var(--serif);font-size:19px;line-height:1.75;color:var(--ink-soft);margin:0 0 24px}.about-para:last-of-type{margin-bottom:0}.about-now,.about-elsewhere{margin-top:56px;padding-top:32px;border-top:1px solid var(--line)}.about-now-body{font-family:var(--sans);font-size:16px;line-height:1.6;color:var(--muted);margin:0}.about-elsewhere-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:24px;font-family:var(--mono);font-size:13px;letter-spacing:.02em}.about-elsewhere-list a{color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:2px}.about-elsewhere-list a:hover{color:var(--ocre);border-bottom-color:var(--ocre)}footer.site-footer{padding:90px 0 70px;border-top:1px solid var(--line);font-family:var(--mono);font-size:13px;color:var(--muted)}.footer-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:44px}.footer-row p{margin:0}.footer-links{display:flex;gap:24px;flex-wrap:wrap}.footer-links a{color:var(--muted);border-bottom:1px solid transparent}.footer-links a:hover{color:var(--ink);border-bottom-color:var(--ocre)}.footer-dojo{margin:0;padding-top:20px;border-top:1px dashed var(--line)}.footer-dojo a{color:var(--ocre);border-bottom:1px solid var(--ocre);padding-bottom:2px}.footer-dojo a:hover{color:var(--ocre-deep);border-bottom-color:var(--ocre-deep)}@media (max-width: 820px){.container{padding:0 22px}.hero{min-height:auto;padding:20px 0 40px}.hero-grid{grid-template-columns:1fr;gap:32px}.hero-text{order:2;max-width:none}.hero-portrait{order:1}.hero-particles-container{height:380px;min-height:320px}section.block{padding:60px 0}.experience-item{grid-template-columns:1fr;gap:6px;padding:18px 0}.experience-period{text-align:left}footer.site-footer{padding:60px 0 50px}.footer-row{flex-direction:column;gap:16px}.case-layout{padding:10px 0 60px}.case-back{margin-bottom:32px}.case-header{margin-bottom:44px}.case-meta-full{grid-template-columns:repeat(2,1fr);gap:20px;padding-top:24px}.case-section{margin-bottom:52px}.results-grid{grid-template-columns:1fr;gap:28px}.approach-step{grid-template-columns:1fr;gap:10px;padding:28px 0}.step-number{padding-top:0}.loadtime-diagram{padding:22px}.loadtime-bar-row{grid-template-columns:54px 1fr 54px;gap:12px}.angular-teaser-grid,.angular-audience-paths,.article-card-list{grid-template-columns:1fr;gap:32px}.angular-teaser-list a{grid-template-columns:1fr;gap:6px}.angular-hub,.article-layout{padding:10px 0 60px}.playbook-cta{grid-template-columns:1fr;align-items:start;gap:18px}.angular-hub-header+.playbook-cta{margin:-26px 0 54px}.playbook-cta-link{justify-self:start}.article-top-nav{margin-bottom:36px}.angular-hub-header{margin-bottom:48px}.angular-audience-paths{margin:-18px 0 52px}.angular-feature,.article-section,.article-artifact{margin-bottom:48px}.article-artifact{padding:22px}.article-section p{font-size:18px}.article-code-block{margin-left:-6px;margin-right:-6px}.article-code-block figcaption{min-height:42px;padding:0 80px 0 68px}.article-code-block pre{padding:18px}.article-code-block code{font-size:13px}.vignette-header{flex-direction:column;gap:4px;margin-bottom:10px}.vignette-item{padding:26px 0}.vignette-body{font-size:16px}.about-layout{padding:10px 0 60px}.about-layout .section-label{margin-bottom:32px}.about-para{font-size:18px;margin-bottom:20px}.about-now,.about-elsewhere{margin-top:40px;padding-top:24px}.about-elsewhere-list{gap:16px 20px}}@media (prefers-reduced-motion: reduce){*{animation-duration:0s!important;transition-duration:0s!important}}
