.tech-shell{--tech-border:color-mix(in srgb,var(--text-color) 12%,transparent);--tech-border-strong:color-mix(in srgb,var(--text-color) 18%,transparent);--tech-bg:var(--card-background-color);--tech-bg-elevated:var(--tpcard-background-color);--tech-text:var(--text-color);--tech-text-muted:var( --gray-600,color-mix(in srgb,var(--text-color) 72%,transparent) );--tech-accent:var(--accent);--tech-shadow:none;--tech-radius:var(--border-radius,.5rem);--tech-radius-lg:var(--border-radius,.5rem);--tech-font-body:var(--font-serif);--tech-font-display:var(--font-serif);--tech-tag-bg:color-mix(in srgb,var(--gray-200) 75%,transparent);--tech-tag-bg-hover:color-mix(in srgb,var(--gray-300) 82%,transparent);--tech-tag-text:var( --gray-600,color-mix(in srgb,var(--text-color) 70%,transparent) );color:var(--tech-text);color-scheme:light dark;padding:clamp(2rem,5vw,4rem) 0 clamp(4rem,8vw,6rem)}.tech-shell__inner{margin:0 auto}.tech-shell__inner,.tech-shell__inner--wide{width:min(800px,calc(100vw - 2rem))}.tech-stack>*+*{margin-top:1.5rem}.tech-stack-lg>*+*{margin-top:3rem}.tech-showcase-list{margin-left:auto;margin-right:auto;max-width:50rem}.tech-showcase-list>*+*{border-top:1px solid var(--tech-border)}.tech-section-nav{border-bottom:1px solid var(--tech-border);display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin:0 0 clamp(1.5rem,3vw,2.5rem);padding-bottom:.75rem}.tech-section-nav__link{align-items:center;border-bottom:1px solid transparent;color:var(--tech-text-muted);display:inline-flex;font-size:.88rem;font-weight:600;min-height:2.15rem;padding:0 .05rem;text-decoration:none;transition:color .16s ease,border-color .16s ease}.tech-section-nav__link--current,.tech-section-nav__link:focus-visible,.tech-section-nav__link:hover{border-color:var(--tech-text);color:var(--tech-text)}.tech-panel{background:transparent;border:0;border-radius:0;box-shadow:none;overflow:visible}.tech-header{margin-bottom:clamp(1.75rem,4vw,3rem)}.tech-header--centered{text-align:center}.tech-backlink{align-items:center;color:var(--tech-text-muted);display:inline-flex;font-size:.875rem;font-weight:700;gap:.45rem;margin-bottom:.75rem;padding-right:.5rem;text-decoration:none;width:-moz-fit-content;width:fit-content}.tech-backlink:hover{color:var(--tech-text);text-decoration:underline;text-underline-offset:.18em}.tech-backlink__arrow{font-size:1rem;line-height:1}.tech-title{font-family:var(--tech-font-display);font-size:clamp(1.5rem,5vw,3rem);font-weight:800;letter-spacing:var(--tracking-tight,-.05em);line-height:1.05;margin:0}.tech-subtitle{color:var(--tech-text-muted);font-family:var(--tech-font-body);font-size:clamp(1rem,2.2vw,1.5rem);line-height:1.5;margin-top:var(--space-2,.5rem);max-width:48rem}.tech-header--centered .tech-subtitle{margin-left:auto;margin-right:auto}.tech-richtext{color:var(--tech-text-muted);font-size:1rem;line-height:1.75}.tech-richtext>:first-child{margin-top:0}.tech-richtext>:last-child{margin-bottom:0}.tech-richtext .tech-embed,.tech-richtext .tech-link-card,.tech-richtext .tech-portable-image,.tech-richtext .tech-timeline,.tech-richtext blockquote,.tech-richtext ol,.tech-richtext p,.tech-richtext pre,.tech-richtext ul{margin:1.1rem 0}.tech-richtext blockquote,.tech-richtext li,.tech-richtext p{font-family:var(--tech-font-body)}.tech-richtext h1,.tech-richtext h2,.tech-richtext h3,.tech-richtext h4,.tech-richtext h5,.tech-richtext h6{color:var(--tech-text);font-family:var(--tech-font-display);font-weight:600;line-height:1.15;margin:2rem 0 .8rem}.tech-richtext a{color:inherit;text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--tech-accent) 55%,transparent);text-underline-offset:.16em}.tech-richtext blockquote{border-left:.15rem solid color-mix(in srgb,var(--tech-accent) 60%,transparent);font-family:var(--tech-font-body);font-size:.95rem;font-style:italic;margin:1rem 0 2rem;padding-left:1rem}.tech-richtext ol,.tech-richtext ul{padding-left:1.5rem}.tech-hero{align-items:center;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.tech-hero__media{min-width:0}.tech-hero__copy{display:flex;flex-direction:column;justify-content:center;min-width:0;padding:0 1.25rem}.tech-hero--right .tech-hero__copy{order:2}.tech-hero--right .tech-hero__media{order:1}.tech-hero--center{grid-template-columns:1fr}.tech-hero__title{font-family:var(--tech-font-display);font-size:clamp(1.5rem,4vw,2.4rem);letter-spacing:var(--tracking-tight,-.05em);line-height:1.1;margin:0 0 1rem}.tech-button{align-items:center;background:var(--tech-text);border-radius:var(--tech-radius-lg);color:var(--background-color);display:inline-flex;font-size:.75rem;font-weight:700;gap:.5rem;letter-spacing:.05em;padding:.5rem 1rem;text-decoration:none;text-transform:uppercase;width:-moz-fit-content;width:fit-content}@media(max-width:720px){.tech-section-nav{gap:.25rem .7rem}.tech-section-nav__link{font-size:.84rem;min-height:1.95rem}}.tech-button:hover{opacity:.92}.tech-grid{display:grid;gap:1.25rem}.tech-link-card-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(275px,1fr))}.tech-link-card{align-items:center;background:transparent;border:1px solid var(--tech-border);border-radius:var(--tech-radius-lg);color:var(--tech-text);display:flex;flex-direction:column;gap:.75rem;justify-content:center;min-height:10rem;padding:clamp(1rem,2vw,1.25rem);text-align:center;text-decoration:none;transition:background-color .18s ease,opacity .18s ease}.tech-link-card:hover{border-color:var(--tech-border-strong);opacity:.98}.tech-link-card__icon{align-items:center;color:var(--tech-text);display:inline-flex;justify-content:center}.tech-link-card__title{font-family:var(--tech-font-display);font-weight:700;line-height:1.25}.tech-image{background:transparent;border-radius:var(--tech-radius-lg);overflow:hidden;position:relative}.tech-image img{content-visibility:visible!important;display:block;height:100%;-o-object-fit:var(--tech-image-fit,cover);object-fit:var(--tech-image-fit,cover);transition:filter .18s ease,opacity .18s ease;width:100%}.tech-image--glow{box-shadow:none;overflow:visible}.tech-image--glow img{filter:drop-shadow(0 0 100px var(--tech-glow-color,#0e9fff));transform:translateZ(0)}.tech-home-image{margin:0 auto}.tech-card{align-items:stretch;background:transparent;border-radius:0;color:inherit;display:grid;gap:clamp(1rem,2.5vw,1.75rem);grid-template-columns:minmax(0,1fr);margin:0;padding:clamp(1rem,2.2vw,1.2rem) 0;text-decoration:none;transition:transform .22s ease,opacity .22s ease;z-index:5}.tech-card:hover{opacity:.96;transform:translateY(-2px)}.tech-card__media{color:inherit;display:block;min-width:0;text-decoration:none;width:100%}.tech-card__image{aspect-ratio:16/10;background:color-mix(in srgb,var(--gray-200) 55%,transparent);border-radius:1rem}.tech-card--blog .tech-card__image{background:#fff}.tech-card__copy{display:flex;flex-direction:column;gap:0;justify-content:center;margin-top:0;min-width:0;padding:0}.tech-card__content-link{color:inherit;display:block;text-decoration:none}.tech-card__stack>*+*{margin-top:clamp(.55rem,1vw,.75rem)}.tech-card .tech-richtext{color:var(--tech-text-muted);font-size:1rem;line-height:1.65}.tech-card .tech-richtext ol,.tech-card .tech-richtext p,.tech-card .tech-richtext ul{margin:0}.tech-portable-image figcaption{color:var(--tech-text-muted);font-size:1rem;font-style:italic;margin:.5rem auto 1rem;max-width:clamp(66%,350px,100%);text-align:center}.tech-card__title{font-family:var(--tech-font-display);font-size:clamp(1.55rem,3vw,2.4rem);font-weight:800;letter-spacing:var(--tracking-tight,-.05em);line-height:1.02;margin:0;text-wrap:balance}.tech-card__meta{color:var(--gray-500,var(--tech-text-muted));display:flex;flex-wrap:wrap;font-size:.78rem;gap:.75rem;letter-spacing:.08em;margin-bottom:var(--space-1,.25rem);text-transform:uppercase}.tech-card:hover .tech-card__title,.tech-card__content-link:focus-visible .tech-card__title{text-decoration:underline;text-decoration-thickness:.05em;text-underline-offset:.14em}.tech-card:hover .tech-card__image img,.tech-card__media:focus-visible .tech-card__image img{filter:saturate(1.02) contrast(1.03)}.tech-detail__hero{margin-top:0}.tech-detail__body{padding:0}.tech-detail__prelude{display:grid;gap:1rem;margin-bottom:1rem}.tech-detail__action-row{align-items:center;display:flex;flex-wrap:nowrap;gap:1rem;justify-content:space-between;min-width:0}.tech-detail__action-row .tech-backlink{margin-bottom:0;min-width:0}.tech-detail__action-row .tech-button{flex:0 0 auto;margin-left:auto;white-space:nowrap}.tech-detail__action-row .tech-tags{flex:0 1 auto;flex-wrap:nowrap;max-width:min(50%,24rem);overflow-x:auto;overflow-y:hidden;padding-bottom:.15rem;scrollbar-width:none;width:min(50%,24rem);-webkit-overflow-scrolling:touch;-webkit-mask-image:linear-gradient(90deg,transparent,#000 .5rem,#000 calc(100% - .5rem),transparent);mask-image:linear-gradient(90deg,transparent,#000 .5rem,#000 calc(100% - .5rem),transparent)}.tech-detail__action-row .tech-tags::-webkit-scrollbar{display:none}.tech-detail__meta{background:none;border-top:.5px solid var(--tech-border);display:grid;grid-template-columns:1fr;margin-top:0}.tech-detail__meta-item{padding:.375rem .75rem}.tech-detail__meta-label{color:var(--tech-text-muted);display:block;font-size:.78rem;letter-spacing:.12em;margin-bottom:.35rem;text-transform:uppercase}.tech-divider{background-color:var(--tech-border);border:0;height:1px;margin:1.5rem 0}.tech-detail__cta-row{display:flex;flex:0 0 auto;justify-content:flex-end;margin:0 0 0 auto}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-card__copy .tech-tags{flex-wrap:nowrap;margin-top:var(--space-5,1.25rem);overflow-x:auto;overflow-y:hidden;padding-bottom:.15rem;scrollbar-width:none;width:100%;-webkit-overflow-scrolling:touch}.tech-card__copy .tech-tags::-webkit-scrollbar{display:none}.tech-tag{align-items:center;background:var(--tech-tag-bg);border-radius:999px;color:var(--tech-tag-text);display:inline-flex;flex:0 0 auto;font-family:var(--tech-font-body);font-size:.8rem;font-weight:500;justify-content:center;max-width:none;padding:.38rem .72rem;text-decoration:none;transition:background-color .18s ease,color .18s ease;white-space:nowrap;width:-moz-max-content;width:max-content}.tech-tag:hover{background:var(--tech-tag-bg-hover);color:var(--tech-text)}.tech-timeline{display:grid;gap:1rem}.tech-timeline__lane{padding:0}.tech-timeline__lane-title{font-size:1.15rem;margin:0 0 1rem}.tech-timeline__milestone+.tech-timeline__milestone{border-top:1px solid var(--tech-border);margin-top:1rem;padding-top:1rem}.tech-timeline__milestone-title{color:var(--tech-text);font-size:1rem;margin:0}.tech-timeline__duration{color:var(--tech-text-muted);display:block;font-size:.82rem;letter-spacing:.1em;margin-top:.3rem;text-transform:uppercase}.tech-timeline__desc{margin-top:.55rem}.tech-timeline__image{margin-top:.75rem;max-width:min(100%,30rem)}.tech-embed{background:transparent;border:0;padding:0}.tech-embed__header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.tech-embed__title{font-size:1.15rem;margin:0}.tech-embed__frame{background:var(--tech-bg-elevated);border:none;box-shadow:none;width:100%}.tech-code,.tech-embed__frame{border-radius:var(--tech-radius-lg)}.tech-code{background:#0f172a;color:#e2e8f0;display:block;font-size:.92rem;line-height:1.6;overflow:auto;padding:1rem 1.1rem}.tech-code__filename{color:#93c5fd;display:block;font-size:.8rem;letter-spacing:.08em;margin-bottom:.6rem;text-transform:uppercase}.tech-comments{margin-top:2rem}.tech-download-preview{background:var(--background-color);border:none;border-radius:0;min-height:72vh;width:100%}@media(prefers-color-scheme:dark){.tech-shell{--tech-border:hsla(0,0%,100%,.12);--tech-border-strong:hsla(0,0%,100%,.18);--tech-text-muted:hsla(0,0%,100%,.74);--tech-tag-bg:hsla(0,0%,100%,.06);--tech-tag-bg-hover:hsla(0,0%,100%,.12);--tech-tag-text:hsla(0,0%,100%,.78)}.tech-card--blog .tech-card__image{background:#fff}}@media(max-width:960px){.tech-card,.tech-hero{grid-template-columns:1fr}.tech-hero--right .tech-hero__copy,.tech-hero--right .tech-hero__media{order:0}.tech-showcase-list{max-width:min(100%,50rem)}}@media(min-width:700px){.tech-detail__meta{border-top:0;grid-template-columns:repeat(3,1fr)}.tech-detail__meta>*+*{border-left:.5px solid var(--tech-border)}}@media(max-width:699px){.tech-detail__meta>*+*{border-top:1px solid var(--tech-border)}}@media(min-width:1024px){.tech-card,.tech-card--reverse{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.tech-card--reverse .tech-card__media{order:2}.tech-card--reverse .tech-card__copy{order:1}.tech-card__image{aspect-ratio:auto;height:320px}}@media(max-width:699px){.tech-detail__action-row{align-items:center;flex-direction:row;gap:.75rem}.tech-detail__action-row .tech-tags{flex:0 1 min(50%,18rem);max-width:min(50%,18rem);width:min(50%,18rem)}.tech-detail__action-row .tech-button{margin-left:auto}.tech-shell__inner,.tech-shell__inner--wide{width:min(100%,calc(100vw - 1.5rem))}.tech-header{margin-bottom:1.5rem}.tech-card{gap:.95rem;padding:1rem 0}.tech-card__image{aspect-ratio:16/11;border-radius:.875rem}.tech-card__title{font-size:clamp(1.35rem,7vw,1.9rem);line-height:1.05}.tech-card .tech-richtext{font-size:.96rem;line-height:1.6}.tech-card__copy .tech-tags{margin-top:1rem}}
