:root{--bg: #f3f4f6;--surface: #ffffff;--surface-2: #f6f7f8;--text: #0f172a;--muted: #475569;--border: rgba(15, 23, 42, .12);--shadow: rgba(15, 23, 42, .06);--accent: #334155;--accent-2: #0f172a;--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, Roboto, "Helvetica Neue", Arial, sans-serif;--radius: 14px;--radius-sm: 10px;--maxw: 1080px}:root[data-theme=dark]{--bg: #0b0c10;--surface: #101218;--surface-2: #0e1016;--text: #eef2f7;--muted: #a7b0be;--border: rgba(238, 242, 247, .12);--shadow: rgba(0, 0, 0, .35);--accent: #cbd5e1;--accent-2: #ffffff}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--sans);color:var(--text);background:radial-gradient(1200px 700px at 80% 0%,rgba(148,163,184,.18),transparent 55%),radial-gradient(900px 600px at 20% 10%,rgba(148,163,184,.14),transparent 60%),var(--bg);line-height:1.45}.bg-canvas{position:fixed;inset:0;width:100vw;height:100vh;z-index:0;pointer-events:none;opacity:.65}:root[data-theme=dark] .bg-canvas{opacity:.75}header,main,footer{position:relative;z-index:1}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}.container{width:min(var(--maxw),calc(100% - 40px));margin:0 auto}.skip{position:absolute;left:-999px;top:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 10px 30px var(--shadow)}.skip:focus{left:16px;z-index:50}.site-header{position:sticky;top:0;z-index:30;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:color-mix(in oklab,var(--bg) 78%,transparent);border-bottom:1px solid var(--border)}.header-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:14px 0}.brand{display:inline-flex;align-items:baseline;gap:8px;text-decoration:none}.brand:hover{text-decoration:none}.brand-mark{font-family:var(--mono);font-weight:600;letter-spacing:.08em;font-size:14px;color:var(--muted);padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:color-mix(in oklab,var(--surface) 90%,transparent)}.brand-name{font-weight:700;letter-spacing:-.02em}.site-nav{display:flex;gap:12px;justify-content:center}.nav-link{padding:8px 10px;border-radius:999px;color:var(--muted)}.nav-link.is-active{color:var(--text);background:color-mix(in oklab,var(--surface) 88%,transparent);border:1px solid var(--border)}.header-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center}.button{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;border:1px solid var(--border);background:color-mix(in oklab,var(--surface) 92%,transparent);color:var(--text);text-decoration:none;font-weight:600;letter-spacing:-.01em}.button:hover{text-decoration:none;background:color-mix(in oklab,var(--surface) 100%,transparent)}.button-primary{background:var(--accent-2);border-color:color-mix(in oklab,var(--accent-2) 65%,var(--border));color:color-mix(in oklab,var(--bg) 2%,#000)}:root[data-theme=dark] .button-primary{color:#0b0c10}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;padding:8px;border-radius:999px;border:1px solid var(--border);background:color-mix(in oklab,var(--surface) 92%,transparent);cursor:pointer;color:var(--muted)}.theme-toggle:hover{background:color-mix(in oklab,var(--surface) 100%,transparent);color:var(--text)}.hero{padding:56px 0 26px}.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:26px;align-items:start}.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 12px}.hero-title{margin:0;font-size:clamp(44px,6vw,64px);line-height:1;letter-spacing:-.05em}.hero-subtitle{margin:14px 0 0;font-size:18px;color:var(--muted);max-width:62ch}.hero-cta{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap}.hero-meta{margin-top:22px;display:grid;grid-template-columns:1fr;gap:10px}.meta-item{display:grid;grid-template-columns:90px 1fr;gap:10px;align-items:baseline;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in oklab,var(--surface) 90%,transparent);box-shadow:0 18px 40px var(--shadow)}.meta-label{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--muted)}.meta-value{font-weight:600}.hero-panel{position:relative}.panel-card{border-radius:calc(var(--radius) + 4px);border:1px solid var(--border);background:linear-gradient(180deg,color-mix(in oklab,var(--surface) 85%,transparent),color-mix(in oklab,var(--surface-2) 92%,transparent));padding:18px;box-shadow:0 30px 70px var(--shadow)}.panel-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:color-mix(in oklab,var(--surface) 90%,transparent);font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted)}.mono{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted)}.panel-title{margin:0;font-size:18px;letter-spacing:-.02em}.panel-body{margin:10px 0 0;color:var(--muted)}.panel-actions{margin-top:12px;display:flex;gap:14px;flex-wrap:wrap}.text-link{color:var(--accent);font-weight:600;text-decoration:none}.text-link:hover{text-decoration:underline}.section{padding:80px 0}.section-muted{background:color-mix(in oklab,var(--surface) 68%,transparent);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.section-head{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}.section-title{margin:0;font-size:16px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-family:var(--mono)}.section-impact{margin:4px 0 16px;font-size:clamp(28px,4vw,36px);letter-spacing:-.03em;font-weight:700;color:var(--text);line-height:1.1}.section-subtitle{grid-column:1 / -1;margin:0;color:var(--muted)}.section-link{justify-self:end;font-weight:600;color:var(--accent)}.cards{display:grid;grid-template-columns:repeat(3,minmax(0,340px));gap:20px;justify-content:start}@media(max-width:960px){.cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:600px){.cards{grid-template-columns:1fr}}.card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;background:color-mix(in oklab,var(--surface) 92%,transparent);box-shadow:0 22px 55px var(--shadow)}.card-wide{grid-column:1 / -1}.card-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.card-title{margin:0;font-size:18px;letter-spacing:-.02em}.card-body{margin:8px 0 0;color:var(--muted)}.card-actions{margin-top:10px;display:flex;gap:14px;flex-wrap:wrap}.card-image{width:100%;height:200px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:12px;background:var(--surface-2)}.card-wide .card-image{height:300px}.card-with-image{display:flex;flex-direction:column}.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:16px;align-items:start}.stack{display:grid;gap:12px}.service{padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in oklab,var(--surface) 88%,transparent)}.service-title{margin:0;font-size:16px}.service-body{margin:8px 0 0;color:var(--muted)}.callout{border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);padding:16px;background:linear-gradient(180deg,color-mix(in oklab,var(--surface) 95%,transparent),color-mix(in oklab,var(--surface-2) 90%,transparent));box-shadow:0 30px 70px var(--shadow)}.callout-title{margin:0;font-size:16px}.callout-body{margin:8px 0 14px;color:var(--muted)}.tiny{font-size:12px}.muted{color:var(--muted)}.makeover-item{margin-bottom:40px}.makeover-item h3{margin-bottom:20px;font-size:20px;font-weight:600}.makeover-result{margin-top:16px;padding:12px;background:var(--surface-2);border-radius:var(--radius-sm);font-size:14px}.comparison-slider{position:relative;width:100%;height:400px;overflow:hidden;border-radius:var(--radius-md);border:1px solid var(--border)}.comparison-before,.comparison-after{position:absolute;top:0;left:0;width:100%;height:100%}.comparison-image{width:100%;height:350px;object-fit:cover}.comparison-label{position:absolute;bottom:0;left:0;right:0;padding:12px;background:#000000b3;color:#fff;font-size:12px;text-align:center}.comparison-after{clip-path:inset(0 50% 0 0)}.slider-handle{position:absolute;top:0;left:50%;width:4px;height:100%;background:var(--accent);cursor:ew-resize;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:20px;transform:translate(-50%)}.tab-container{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.tab-buttons{display:flex;background:var(--surface-2);border-bottom:1px solid var(--border)}.tab-button{flex:1;padding:12px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.tab-button.active{background:var(--surface);color:var(--accent);border-bottom:2px solid var(--accent)}.tab-button:hover:not(.active){background:var(--surface)}.tab-content{position:relative;min-height:400px}.tab-pane{position:absolute;top:0;left:0;width:100%;padding:20px;opacity:0;visibility:hidden;transition:all .3s ease}.tab-pane.active{opacity:1;visibility:visible}.tab-image{width:100%;height:300px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:12px}.scroll-reveal{position:relative;width:100%;height:400px;overflow:hidden;border-radius:var(--radius-md);border:1px solid var(--border)}.reveal-before,.reveal-after{position:absolute;top:0;left:0;width:100%;height:100%;transition:transform .6s ease}.reveal-image{width:100%;height:350px;object-fit:cover}.reveal-label{position:absolute;bottom:0;left:0;right:0;padding:12px;background:#000000b3;color:#fff;font-size:12px;text-align:center}.reveal-after{transform:translate(100%)}.scroll-reveal:hover .reveal-before{transform:translate(-100%)}.scroll-reveal:hover .reveal-after{transform:translate(0)}.article-layout{max-width:650px;margin:0 auto;padding:0 24px}.article-content{max-width:none}.article-hero{margin-bottom:48px}.article-hero-image{width:100%;height:400px;object-fit:cover;border-radius:var(--radius-lg);margin-bottom:16px}.article-hero-caption{font-size:14px;color:var(--muted);font-style:italic;text-align:center;max-width:600px;margin:0 auto}.article-section{margin-bottom:48px}.article-section h2{font-size:28px;font-weight:600;color:var(--text);margin:0 0 24px;line-height:1.3}.article-section h3{font-size:20px;font-weight:600;color:var(--text);margin:32px 0 16px}.article-section p{font-size:18px;line-height:1.7;color:var(--text);margin:0 0 24px}.article-section ul{margin:24px 0;padding-left:24px}.article-section li{font-size:16px;line-height:1.6;margin-bottom:12px;color:var(--text)}.article-pullquote{font-size:24px;line-height:1.4;font-style:italic;color:var(--accent);border-left:4px solid var(--accent);margin:32px 0;background:var(--surface-2);padding:24px;border-radius:var(--radius-md)}.article-features{background:var(--surface-2);padding:24px;border-radius:var(--radius-md);margin:32px 0}.article-features h3{margin:0 0 16px;font-size:18px}.article-features ul{margin:0;padding-left:20px}.article-features li{margin-bottom:8px}.article-image{margin:32px 0}.article-image img{width:100%;height:300px;object-fit:cover;border-radius:var(--radius-md)}.image-caption{font-size:14px;color:var(--muted);font-style:italic;text-align:center;margin-top:12px}.tech-stack{background:var(--surface-2);padding:24px;border-radius:var(--radius-md);margin:32px 0}.tech-stack h3{margin:0 0 16px;font-size:18px}.tech-stack ul{margin:0;padding-left:20px}.tech-stack li{margin-bottom:8px}.results-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:32px 0}.metric{text-align:center;padding:24px;background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border)}.metric-number{font-size:36px;font-weight:700;color:var(--accent);margin-bottom:8px}.metric-label{font-size:14px;color:var(--text);font-weight:500}.article-sidebar-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}.article-sidebar{display:none}.sidebar-section{background:var(--surface-2);padding:24px;border-radius:var(--radius-md)}.sidebar-section h3{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--text)}.project-details{margin:0}.project-details dt{font-size:12px;color:var(--muted);font-weight:500;margin-top:12px}.project-details dd{font-size:14px;color:var(--text);font-weight:600;margin:4px 0 16px}.action-links,.related-projects{display:flex;flex-direction:column;gap:12px}.related-project{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-sm);text-decoration:none;color:var(--text);transition:background-color .3s ease}.related-project:hover{background:var(--surface)}.related-project img{width:60px;height:40px;object-fit:cover;border-radius:var(--radius-sm)}.related-project span{font-size:14px;font-weight:500}@media(max-width:1024px){.article-layout{grid-template-columns:1fr;gap:32px}.article-content{max-width:none}.article-sidebar{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}}@media(max-width:768px){.article-hero-image{height:300px}.article-section h2{font-size:24px}.article-section p{font-size:16px}.article-pullquote{font-size:20px;padding:20px}.results-metrics{grid-template-columns:1fr;gap:16px}.metric-number{font-size:28px}}@media(max-width:480px){.article-hero-image{height:250px}.article-section h2{font-size:22px}.article-section p{font-size:15px}.article-pullquote{font-size:18px;padding:16px}.article-sidebar{grid-template-columns:1fr}}.problem-gallery{margin-top:24px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.gallery-item{cursor:pointer;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);transition:all .3s ease}.gallery-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:var(--accent)}.gallery-preview{position:relative;height:200px;overflow:hidden}.gallery-image{width:100%;height:100%;object-fit:cover}.gallery-content{padding:16px;display:flex;flex-direction:column;gap:8px}.gallery-title{font-size:16px;font-weight:600;color:var(--text);margin:0;line-height:1.4}.gallery-description{font-size:14px;color:var(--text-muted);margin:0;line-height:1.4;flex:1}.gallery-meta{display:flex;align-items:center;gap:8px;margin-top:8px}.gallery-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:20px 16px 16px;color:#fff;transform:translateY(100%);transition:transform .3s ease}.gallery-item:hover .gallery-overlay{transform:translateY(0)}.gallery-tag{display:inline-block;padding:4px 8px;background:var(--accent);border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;margin-bottom:8px}.gallery-overlay h4{margin:0 0 4px;font-size:16px;font-weight:600}.gallery-overlay p{margin:0;font-size:14px;opacity:.9}.gallery-cta{text-align:center}.gallery-subtitle{margin-top:12px;color:var(--muted);font-size:14px}.problem-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:1000;overflow-y:auto}.modal-content{position:relative;background:var(--surface);margin:40px auto;max-width:800px;border-radius:var(--radius-lg);overflow:hidden}.modal-header{padding:24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-title{margin:0;font-size:24px;font-weight:600}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--muted);padding:8px;border-radius:var(--radius-sm)}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-body{padding:24px}.modal-image{width:100%;height:300px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:20px}.modal-analysis{display:grid;gap:20px}.analysis-section h4{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--accent)}.analysis-section p{margin:0;line-height:1.6}.modal-footer{padding:20px 24px;border-top:1px solid var(--border);background:var(--surface-2);text-align:center}.list{display:grid;gap:10px}.list-item{display:grid;grid-template-columns:90px 1fr auto;gap:12px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in oklab,var(--surface) 92%,transparent);box-shadow:0 18px 45px var(--shadow)}.list-title{font-weight:700;letter-spacing:-.01em}.list-meta{color:var(--muted);font-family:var(--mono);font-size:12px}.page{padding-bottom:24px}.page-head{padding:34px 0 10px}.page-title{margin:0;font-size:40px;letter-spacing:-.04em}.page-subtitle{margin:10px 0 0;color:var(--muted);font-size:16px;max-width:70ch}.prose h2{margin:0 0 10px;font-size:18px}.prose p{margin:0 0 14px;color:var(--muted)}.prose ul{margin:0;padding-left:18px;color:var(--muted)}.divider{height:1px;background:var(--border);margin:14px 0}.fact{display:grid;grid-template-columns:90px 1fr;gap:10px;padding:10px 0}.fact-label{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted)}.fact-value{font-weight:600}.post{padding-bottom:10px}.post-excerpt{margin:8px 4px 0;color:var(--muted)}.site-footer{border-top:1px solid var(--border);padding:24px 0;background:color-mix(in oklab,var(--bg) 70%,transparent)}.footer-inner{display:flex;gap:16px;justify-content:space-between;align-items:center;flex-wrap:wrap}.footer-brand{font-weight:800;letter-spacing:-.02em}.footer-meta{color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;margin-top:2px}.footer-links{display:flex;gap:14px;flex-wrap:wrap;align-items:center}@media(max-width:920px){.header-inner{grid-template-columns:1fr auto;grid-template-areas:"brand actions" "nav nav"}.brand{grid-area:brand}.site-nav{grid-area:nav;justify-content:flex-start;flex-wrap:wrap}.header-actions{grid-area:actions}.hero-inner{grid-template-columns:1fr}.cards{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}}@media(max-width:560px){.container{width:min(var(--maxw),calc(100% - 28px))}.cards{grid-template-columns:1fr}.list-item{grid-template-columns:1fr;gap:6px;align-items:start}}
