@import url(https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:wght@300;400;500&family=JetBrains+Mono:wght@400;500&display=swap);.elementor-561 .elementor-element.elementor-element-7197816{--display:flex}.elementor-widget-text-editor{font-family:var(--e-global-typography-text-font-family),Sans-serif;font-weight:var(--e-global-typography-text-font-weight);color:var(--e-global-color-text)}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var(--e-global-color-primary)}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap,.elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var(--e-global-color-primary);border-color:var(--e-global-color-primary)}body.elementor-page-561:not(.elementor-motion-effects-element-type-background),body.elementor-page-561>.elementor-motion-effects-container>.elementor-motion-effects-layer{background-color:#1F1F27}.eael-ext-scroll-to-top-wrap .eael-ext-scroll-to-top-button{bottom:15px;left:15px;width:50px;height:50px;z-index:9999;opacity:.7;background-color:#000;border-radius:5px}.eael-ext-scroll-to-top-wrap .eael-ext-scroll-to-top-button i{font-size:16px;color:red}.eael-ext-scroll-to-top-wrap .eael-ext-scroll-to-top-button svg{width:16px;height:16px;fill:red}:root{--navy:#0f1b2d;--accent:#4fc3a1;--accent2:#f4845f;--accent3:#7b8ff7;--text:#e8edf3;--text-muted:#8a97a8;--card-bg:#162234;--border:rgba(79,195,161,0.18);--tag-bg:rgba(79,195,161,0.1)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--navy);color:var(--text);font-family:'DM Sans',sans-serif;font-size:15px;line-height:1.8}.page-header{padding:3rem 0 2.5rem;border-bottom:1px solid var(--border);margin-bottom:3rem}.page-header .label{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:.6rem}.page-header h1{font-family:'DM Serif Display',serif;font-size:2.4rem;color:var(--text);margin-bottom:.6rem}.page-header p{color:var(--text-muted);max-width:620px}.header-meta{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.2rem}.hm-badge{font-size:.75rem;padding:.25rem .75rem;border-radius:99px;font-weight:500}.hm-green{background:var(--tag-bg);border:1px solid var(--border);color:var(--accent)}.hm-orange{background:rgb(244 132 95 / .1);border:1px solid rgb(244 132 95 / .3);color:var(--accent2)}.hm-blue{background:rgb(123 143 247 / .1);border:1px solid rgb(123 143 247 / .3);color:var(--accent3)}.section{margin-bottom:3.5rem}.section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:.5rem;display:flex;align-items:center;gap:.6rem}.section-label::after{content:'';flex:1;height:1px;background:var(--border)}.section h2{font-family:'DM Serif Display',serif;font-size:1.65rem;color:var(--text);margin-bottom:1.2rem}p{color:var(--text-muted);margin-bottom:1rem}p:last-child{margin-bottom:0}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1.4rem 1.6rem;margin-bottom:1.2rem}.card h3{font-size:1rem;font-weight:500;color:var(--text);margin-bottom:.5rem}.card .meta{font-size:.78rem;color:var(--accent2);font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.06em}.archi-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}@media (max-width:580px){.archi-grid{grid-template-columns:1fr}}.archi-col{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1.3rem 1.4rem}.archi-col .ac-title{font-size:.88rem;font-weight:500;color:var(--text);margin-bottom:.25rem}.archi-col .ac-sub{font-size:.75rem;color:var(--text-muted);margin-bottom:.9rem;font-style:italic}.archi-col ul{list-style:none;padding:0}.archi-col ul li{font-size:.84rem;color:var(--text-muted);padding:.28rem 0;border-bottom:1px solid rgb(255 255 255 / .04);display:flex;align-items:flex-start;gap:.5rem}.archi-col ul li:last-child{border-bottom:none}.archi-col ul li::before{content:'–';color:var(--accent);flex-shrink:0}.stack-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin-top:1rem}.stack-chip{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:.75rem 1rem;text-align:center}.stack-chip .sc-name{font-size:.85rem;font-weight:500;color:var(--text)}.stack-chip .sc-role{font-size:.7rem;color:var(--text-muted);margin-top:.1rem}.diff-item{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1.4rem 1.6rem;margin-bottom:1rem}.diff-item .diff-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.8rem}.diff-num{width:32px;height:32px;border-radius:8px;background:rgb(244 132 95 / .12);border:1px solid rgb(244 132 95 / .3);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:500;color:var(--accent2);flex-shrink:0}.diff-item h3{font-size:.97rem;font-weight:500;color:var(--text)}.diff-block{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:.5rem}@media (max-width:580px){.diff-block{grid-template-columns:1fr}}.diff-problem,.diff-solution{border-radius:8px;padding:.8rem 1rem;font-size:.83rem}.diff-problem{background:rgb(224 92 122 / .07);border:1px solid rgb(224 92 122 / .2)}.diff-problem .dp-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:#e05c7a;margin-bottom:.3rem}.diff-problem p{color:var(--text-muted);margin:0;font-size:.83rem}.diff-solution{background:rgb(79 195 161 / .06);border:1px solid rgb(79 195 161 / .2)}.diff-solution .ds-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.3rem}.diff-solution p{color:var(--text-muted);margin:0;font-size:.83rem}.ref-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.9rem;margin-top:1rem}.ref-block{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:1rem 1.2rem}.ref-block .rb-code{font-size:.7rem;font-family:'JetBrains Mono',monospace;color:var(--accent);background:var(--tag-bg);padding:.15rem .5rem;border-radius:4px;margin-bottom:.4rem;display:inline-block}.ref-block h4{font-size:.88rem;font-weight:500;color:var(--text);margin-bottom:.25rem}.ref-block p{font-size:.8rem;margin:0}.github-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1.4rem 1.6rem;display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}.gh-icon{flex-shrink:0;width:48px;height:48px;background:var(--tag-bg);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center}.gh-icon svg{width:24px;height:24px;fill:var(--accent)}.gh-info{flex:1;min-width:180px}.gh-info .gi-name{font-size:.95rem;font-weight:500;color:var(--text);margin-bottom:.2rem}.gh-info .gi-desc{font-size:.82rem;color:var(--text-muted)}.gh-link{background:var(--tag-bg);border:1px solid var(--border);color:var(--accent);font-size:.83rem;padding:.5rem 1.1rem;border-radius:8px;text-decoration:none;font-family:'DM Sans',sans-serif;transition:background 0.2s;white-space:nowrap}.gh-link:hover{background:rgb(79 195 161 / .22)}.diagram-wrapper{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1.5rem;overflow-x:auto;margin-top:1rem}.diagram-wrapper svg{display:block;margin:0 auto;max-width:100%}.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}.tag{background:var(--tag-bg);border:1px solid var(--border);color:var(--accent);font-size:.73rem;padding:.2rem .65rem;border-radius:99px}.timeline{position:relative;padding-left:1.6rem;margin-top:1rem}.timeline::before{content:'';position:absolute;left:0;top:.4rem;bottom:0;width:1px;background:var(--border)}.timeline-item{position:relative;margin-bottom:1.4rem}.timeline-item::before{content:'';position:absolute;left:-1.6rem;top:.45rem;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--navy)}.timeline-item .ti-date{font-size:.72rem;color:var(--accent2);font-weight:500;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.1rem}.timeline-item h4{font-size:.92rem;font-weight:500;color:var(--text);margin-bottom:.2rem}.timeline-item p{font-size:.84rem;margin:0}footer{text-align:center;margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--text-muted)}