:root{color-scheme:light;--bg: #f5f4ee;--surface: rgba(255, 255, 255, .62);--surface-strong: rgba(255, 255, 255, .78);--surface-muted: rgba(19, 23, 31, .04);--text: #111111;--text-soft: rgba(17, 17, 17, .72);--border: rgba(255, 255, 255, .42);--accent: #f2c230;--accent-strong: #d4a300;--shadow: 0 24px 80px rgba(17, 17, 17, .12);--glass-highlight: inset 0 1px 0 rgba(255, 255, 255, .58);--radius-lg: 28px;--radius-md: 20px;--radius-sm: 999px;--shell: 1180px}:root[data-theme=dark]{color-scheme:dark;--bg: #090b0f;--surface: rgba(16, 18, 24, .56);--surface-strong: rgba(18, 20, 27, .72);--surface-muted: rgba(255, 255, 255, .04);--text: #f5f1e8;--text-soft: rgba(245, 241, 232, .72);--border: rgba(255, 255, 255, .18);--accent: #ffd54a;--accent-strong: #ffdf73;--shadow: 0 28px 100px rgba(0, 0, 0, .35);--glass-highlight: inset 0 1px 0 rgba(255, 255, 255, .12)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text);font-family:Manrope,sans-serif;line-height:1.6;transition:background-color .18s ease,color .18s ease}a{color:inherit;text-decoration:none}img{display:block;max-width:100%;-webkit-user-drag:none;user-select:none}p,ul{margin:0}main{flex:1;padding-bottom:4rem}.shell{width:min(calc(100% - 2rem),var(--shell));margin:0 auto}.shell--wide{width:min(calc(100% - 2rem),1240px)}.site-header{position:sticky;top:0;z-index:20;backdrop-filter:blur(22px);background:color-mix(in oklab,var(--bg) 68%,transparent);border-bottom:1px solid var(--border)}.project-page-body .site-header{background:linear-gradient(180deg,#00000057,#00000014);border-bottom-color:transparent;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.project-page-body .nav a{background:#ffffff14;color:#f8f5efdb;border-color:#ffffff24}.project-page-body .nav a:hover,.project-page-body .nav a.active{color:#f8f5ef;border-color:#ffd54a75}.nav-wrap,.footer-wrap,.nav{display:flex;align-items:center}.nav-wrap{justify-content:center;gap:1rem;padding:.72rem 0}.nav{gap:.65rem;flex-wrap:wrap}.nav a{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);box-shadow:var(--glass-highlight);color:var(--text-soft);padding:.5rem .85rem;font-size:.84rem;line-height:1;transition:transform .18s ease,border-color .18s ease,color .18s ease,background-color .18s ease}.nav a:hover,.nav a.active,.theme-fab:hover,.button:hover,.project-card:hover,.project-links a:hover,.contact-links a:hover{transform:translateY(-2px);color:var(--text);border-color:color-mix(in oklab,var(--accent) 45%,var(--border))}.theme-toggle__track{display:inline-flex;align-items:center;width:3.4rem;padding:.2rem;border-radius:var(--radius-sm);background:var(--surface-muted)}.theme-toggle__thumb{width:1.25rem;height:1.25rem;border-radius:50%;background:var(--accent);transform:translate(0);transition:transform .18s ease}:root[data-theme=dark] .theme-toggle__thumb{transform:translate(1.6rem)}.theme-fab{position:fixed;left:1.25rem;bottom:1.25rem;z-index:40;display:inline-flex;align-items:center;justify-content:center;padding:.55rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-strong);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);color:var(--text-soft);box-shadow:var(--shadow),var(--glass-highlight);cursor:pointer;transition:transform .18s ease,border-color .18s ease,color .18s ease,background-color .18s ease}.hero,.project-hero{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.8fr);gap:1.5rem;align-items:stretch}.hero{padding:5rem 0 2rem}.home-main{display:flex;flex-direction:column;justify-content:center;padding-bottom:2rem;min-height:calc(100vh - 140px)}.home-hero{padding:clamp(1.5rem,4vw,3rem) 0 0}.home-hero__panel{padding:clamp(1.4rem,3vw,2.4rem);border:1px solid var(--border);border-radius:var(--radius-lg);background:linear-gradient(225deg,color-mix(in oklab,var(--accent) 18%,transparent),transparent 42%),var(--surface);backdrop-filter:blur(28px) saturate(150%);-webkit-backdrop-filter:blur(28px) saturate(150%);box-shadow:var(--shadow),var(--glass-highlight)}.home-hero__panel h1{margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(2.2rem,5vw,4.2rem);line-height:.95;letter-spacing:-.06em;max-width:14ch}.home-hero__lede{max-width:56ch;margin-top:1rem;color:var(--text-soft);font-size:1rem}.app-strip{padding:clamp(1.25rem,3vw,2rem) 0 1rem}.app-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;justify-content:center}.app-tile{display:grid;gap:1rem;padding:1.25rem;border:1px solid var(--border);border-radius:24px;background:var(--surface);backdrop-filter:blur(24px) saturate(145%);-webkit-backdrop-filter:blur(24px) saturate(145%);box-shadow:var(--shadow),var(--glass-highlight);overflow:hidden;position:relative;scroll-snap-align:start;transition:transform .18s ease,border-color .18s ease,background-color .18s ease}.app-tile__meta{display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap;position:absolute;top:1rem;right:1rem;max-width:calc(100% - 2rem)}.app-tile__meta span{display:inline-flex;align-items:center;padding:.42rem .7rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:color-mix(in oklab,var(--surface-strong) 72%,transparent);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);font-size:.8rem;color:var(--text-soft)}.app-tile:hover{transform:translateY(-4px);border-color:color-mix(in oklab,var(--accent) 45%,var(--border))}.app-tile__content{display:grid;grid-template-columns:auto minmax(0,1fr);gap:1rem;align-items:center;padding-top:.1rem}.app-tile__icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:clamp(6rem,12vw,7.8rem);height:clamp(6rem,12vw,7.8rem);border-radius:24px;background:color-mix(in oklab,var(--surface-strong) 88%,transparent);border:1px solid var(--border);overflow:hidden;box-shadow:0 18px 36px #1113,0 8px 16px #1111111f,var(--glass-highlight)}.app-tile__icon-wrap--astro{background:#35333b;border-color:#ffffff14}.app-tile__icon{width:100%;height:100%;object-fit:cover}.app-tile__body{display:flex;flex-direction:column;justify-content:center;align-self:center;gap:.4rem;min-width:0}.app-tile__body h3{margin:0;font-family:Space Grotesk,sans-serif;font-size:1.15rem;letter-spacing:-.04em}.app-tile__body p{color:var(--text-soft);font-size:.96rem}.projects-main,.contact-main{padding-top:2rem}.projects-hero{padding-top:1rem}.projects-hero__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.projects-hero__bar h1{margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(1.8rem,4vw,3rem);line-height:1;letter-spacing:-.05em}.hero__content,.hero__panel,.split-panel,.contact-panel,.project-card,.project-section,.project-hero__media{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);backdrop-filter:blur(24px) saturate(145%);-webkit-backdrop-filter:blur(24px) saturate(145%);box-shadow:var(--shadow),var(--glass-highlight)}.hero__content,.hero__panel,.split-panel,.contact-panel,.project-section{padding:clamp(1.5rem,3vw,2.4rem)}.hero__content h1,.section-heading h2,.split-panel h2,.contact-panel h2,.project-hero h1{margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(2.6rem,6vw,5.4rem);line-height:.95;letter-spacing:-.06em;max-width:12ch}.section-heading h2,.split-panel h2,.contact-panel h2{font-size:clamp(2rem,4vw,3.4rem);max-width:16ch}.eyebrow{margin-bottom:1rem;color:var(--accent-strong);font-size:.8rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.hero__lede,.section-heading p,.project-hero__summary,.project-card__summary,.split-panel p,.contact-panel p,.project-section p{color:var(--text-soft);font-size:1.05rem}.hero__lede{max-width:58ch;margin-top:1.4rem}.hero__actions,.contact-links,.project-links{display:flex;gap:.9rem;flex-wrap:wrap}.hero__actions{margin-top:2rem}.button,.contact-links a,.project-links a,.project-card__link,.back-link{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.9rem 1.2rem;transition:transform .18s ease,border-color .18s ease,background-color .18s ease}.button--primary{background:var(--accent);border-color:transparent;color:#111;font-weight:800}.button--ghost{background:var(--surface)}.button--glow{border-color:color-mix(in oklab,var(--accent) 58%,var(--border));background:color-mix(in oklab,var(--accent) 6%,transparent);color:var(--accent);box-shadow:0 0 0 1px color-mix(in oklab,var(--accent) 20%,transparent),0 0 24px color-mix(in oklab,var(--accent) 18%,transparent),inset 0 0 18px color-mix(in oklab,var(--accent) 8%,transparent);font-weight:700}.button--glow:hover{border-color:color-mix(in oklab,var(--accent) 78%,white 8%);background:color-mix(in oklab,var(--accent) 10%,transparent);box-shadow:0 0 0 1px color-mix(in oklab,var(--accent) 32%,transparent),0 0 30px color-mix(in oklab,var(--accent) 24%,transparent),inset 0 0 22px color-mix(in oklab,var(--accent) 12%,transparent)}.hero__panel{display:grid;gap:1rem;align-content:end;background:linear-gradient(180deg,color-mix(in oklab,var(--accent) 22%,transparent),transparent 28%),var(--surface)}.hero-metric{padding:1rem 0;border-bottom:1px solid var(--border)}.hero-metric:last-child{border-bottom:0}.hero-metric span,.site-footer p:first-child{color:var(--text-soft)}.hero-metric strong{display:block;margin-top:.3rem;font-size:1.25rem}.section{padding:1.5rem 0}.section-heading{max-width:62rem;margin-bottom:1.5rem}.project-grid{display:grid;grid-template-columns:1fr;gap:1rem;max-width:900px;margin:0 auto}.project-card{display:grid;gap:1.15rem;padding:1.4rem 1.4rem 0;min-height:100%;position:relative;border-radius:var(--radius-lg);transition:transform .18s ease,border-color .18s ease}.project-card__meta{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end;position:absolute;top:1rem;right:1rem;max-width:calc(100% - 2rem)}.project-card__content{display:grid;grid-template-columns:auto minmax(0,1fr);gap:1rem;align-items:center;padding-top:0}.project-card__icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:clamp(5.5rem,10vw,6.8rem);height:clamp(5.5rem,10vw,6.8rem);border-radius:24px;background:color-mix(in oklab,var(--surface-strong) 88%,transparent);border:1px solid var(--border);overflow:hidden;box-shadow:0 18px 36px #1111112e,0 8px 16px #1111111f,var(--glass-highlight)}.project-card__icon-wrap--astro{background:#35333b;border-color:#ffffff14}.project-card__icon{width:100%;height:100%;object-fit:cover}.project-card__body{display:flex;flex-direction:column;justify-content:center;gap:.45rem;min-width:0}.project-card__topline,.project-hero__title{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.project-card__meta{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end;width:100%}.project-card h3,.project-hero h1{margin:0}.status-pill,.tag-list li{display:inline-flex;align-items:center;padding:.45rem .8rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-muted);font-size:.82rem}.status-pill--released{background:#4ab07324;border-color:#4ab07347;color:#2d7046f2}.status-pill--beta{background:#f09a3729;border-color:#f09a374d;color:#9b5a14f5}.status-pill--alpha{background:#f2c23033;border-color:#f2c23057;color:#875e00f5}:root[data-theme=dark] .status-pill--beta{background:#ffaa4833;border-color:#ffaa4857;color:#ffdfbcf5}:root[data-theme=dark] .status-pill--alpha{background:#ffd54a38;border-color:#ffd54a61;color:#ffecb1fa}:root[data-theme=dark] .status-pill--released{background:#62cd852e;border-color:#62cd8552;color:#c4ffd2f2}.tag-list,.feature-list{list-style:none;padding:0}.tag-list{display:flex;gap:.6rem;flex-wrap:wrap}.project-card__link{justify-self:stretch;margin:auto -1.4rem 0;padding:.52rem 1rem;background:var(--accent);border-color:transparent;color:#111;font-weight:800;font-size:.86rem;border-radius:0 0 28px 28px;overflow:hidden;clip-path:inset(0 round 0 0 28px 28px)}.split-panel,.contact-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}.contact-panel--page{grid-template-columns:minmax(0,1fr) clamp(88px,9vw,118px);align-items:stretch}.contact-panel--stacked{grid-template-columns:1fr}.about-main{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 11rem);padding-top:2rem;padding-bottom:2rem}.about-stack{display:grid;justify-items:center;gap:1rem;width:100%}.about-card{display:grid;grid-template-columns:clamp(220px,27vw,300px) minmax(0,1fr);align-items:center;gap:0;width:min(100%,1020px);border:1px solid var(--border);border-radius:32px;overflow:hidden;background:color-mix(in oklab,var(--surface-strong) 84%,transparent);box-shadow:var(--shadow-soft),inset 0 0 0 1px #ffffff0a}.about-card__photo{display:flex;align-items:center;justify-content:center;align-self:stretch}.about-card__photo-frame{position:relative;display:flex;align-items:stretch;justify-content:center;width:100%;height:100%;min-height:100%;overflow:hidden;border-right:1px solid color-mix(in oklab,var(--accent) 24%,var(--border));background:color-mix(in oklab,var(--surface) 86%,black 6%);box-shadow:inset 0 0 0 1px #ffffff0d}.about-card__photo-frame:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0c0c0c0d,#0c0c0c2e),linear-gradient(90deg,#0c0c0c08,#0c0c0c24);pointer-events:none}.about-card__photo-image{width:100%;height:100%;object-fit:cover;object-position:42% center;transform:scale(1.12)}.about-card__content{display:grid;align-content:center;gap:.9rem;padding:clamp(1.2rem,2vw,1.8rem)}.about-card__identity{display:grid;gap:.22rem}.about-card__content h1,.about-card__content p{margin:0}.about-card__content h1{font-family:Space Grotesk,sans-serif;font-size:clamp(1.6rem,3vw,2.5rem);line-height:1.02;letter-spacing:-.05em}.about-card__content p{color:var(--text-soft);line-height:1.65}.about-card__meta{color:var(--accent-strong);font-size:.84rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.about-links{margin-top:.35rem}.about-actions{display:flex;justify-content:center}.contact-card{display:grid;grid-template-columns:minmax(0,1fr) clamp(88px,9vw,118px);align-items:stretch;gap:1.5rem;min-height:min(30rem,62vh);padding:clamp(1.2rem,2vw,1.7rem);border:1px solid var(--border);border-radius:28px;background:color-mix(in oklab,var(--surface-strong) 84%,transparent);box-shadow:var(--shadow-soft),inset 0 0 0 1px #ffffff0a}.contact-copy{display:grid;gap:.25rem;max-width:52rem}.contact-copy p{margin:0;color:var(--text-soft);line-height:1.42}.contact-copy a{color:var(--text);text-decoration:underline;text-underline-offset:.18em}.contact-app-links{display:grid;gap:.8rem;margin-top:.25rem}.contact-app-links strong{color:var(--text)}.contact-panel__intro{display:grid;gap:1rem}.contact-methods{display:grid;gap:.9rem}.contact-method{padding:1rem 1.05rem;border:1px solid var(--border);border-radius:22px;background:color-mix(in oklab,var(--surface-strong) 84%,transparent);box-shadow:inset 0 0 0 1px #ffffff0a}.contact-method__label,.contact-method__value,.contact-method__meta{margin:0}.contact-method__label{color:var(--accent-strong);font-size:.8rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.contact-method__value{margin-top:.55rem;font-family:Space Grotesk,sans-serif;font-size:clamp(1rem,2vw,1.22rem);letter-spacing:-.03em}.contact-method__link{display:inline-flex;color:var(--text);text-decoration:underline;text-underline-offset:.18em}.contact-method__meta{margin-top:.5rem;color:var(--text-soft);font-size:.94rem;line-height:1.5}.contact-form-shell{padding:1rem 1.05rem;border:1px solid var(--border);border-radius:22px;background:color-mix(in oklab,var(--surface-strong) 84%,transparent);box-shadow:inset 0 0 0 1px #ffffff0a;height:100%}.contact-form{display:grid;gap:.9rem}.contact-field{display:grid;gap:.45rem}.contact-field span{color:var(--accent-strong);font-size:.78rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.contact-field input,.contact-field textarea{width:100%;border:1px solid var(--border);border-radius:16px;background:var(--surface);color:var(--text);font:inherit;padding:.9rem 1rem;resize:vertical}.contact-field textarea{min-height:9.5rem}.contact-field input:focus,.contact-field textarea:focus{outline:none;border-color:color-mix(in oklab,var(--accent) 38%,var(--border));box-shadow:0 0 0 1px color-mix(in oklab,var(--accent) 22%,transparent),inset 0 0 0 1px #ffffff0a}.contact-form__footer{display:grid;gap:.7rem;margin-top:.3rem}.contact-form__submit{width:fit-content}.contact-form__note{margin:0;color:var(--text-soft);font-size:.92rem;line-height:1.5}.contact-social-shell{display:flex;height:100%}.contact-socials{display:flex;flex-direction:column;justify-content:space-between;gap:.8rem;width:100%;height:100%}.contact-social{display:inline-flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1 / 1;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:22px;background:var(--surface);color:var(--text);box-shadow:var(--glass-highlight);transition:transform .18s ease,border-color .18s ease,color .18s ease}.contact-social:hover{border-color:color-mix(in oklab,var(--accent) 34%,var(--border));color:var(--accent)}.contact-social svg{width:clamp(1.8rem,2.5vw,2.25rem);height:clamp(1.8rem,2.5vw,2.25rem)}.contact-social--placeholder{opacity:.55}.not-found-card{grid-template-columns:1fr;min-height:auto}.not-found-actions{flex-direction:row;flex-wrap:wrap;justify-content:flex-start;gap:.9rem;height:auto}.not-found-actions .button{min-width:140px}@media(max-width:720px){.about-card{grid-template-columns:1fr;width:min(100%,540px)}.about-card__photo{min-height:260px}.about-card__content{text-align:center}.contact-card{grid-template-columns:1fr;min-height:auto}.not-found-actions .button{width:100%}}.contact-links a,.project-links a{background:var(--surface-strong);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);box-shadow:var(--glass-highlight)}.site-footer{margin-top:auto;padding:0 0 2rem}.footer-wrap{justify-content:center;gap:1rem;border-top:1px solid var(--border);padding-top:1.2rem;text-align:center}.project-page{padding-top:0}.project-page__content{margin-top:1rem}.back-link{margin-bottom:1rem;background:var(--surface)}.project-banner,.availability-card,.project-article__section,.project-figure,.project-carousel{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);backdrop-filter:blur(24px) saturate(145%);-webkit-backdrop-filter:blur(24px) saturate(145%);box-shadow:var(--shadow),var(--glass-highlight)}.project-banner{position:relative;width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);min-height:clamp(300px,49vh,532px);overflow:hidden;border-radius:0;border-left:0;border-right:0;border-top:0;margin-top:-72px}.project-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center calc(100% + 25px)}.project-banner img[src*=astro-tracker-icon]{object-position:center center}.project-banner__overlay{position:absolute;inset:0;background:linear-gradient(180deg,#00000057,#0000001a 20%,#0000002e),linear-gradient(90deg,rgba(0,0,0,.28),transparent 55%)}.project-banner__content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;width:min(calc(100% - 2rem),1240px);margin:0 auto;padding:clamp(6rem,12vw,9rem) 0 clamp(2rem,5vw,3rem)}.project-banner__content h1{margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(3rem,8vw,6rem);line-height:.9;letter-spacing:-.08em;max-width:9ch;color:#f8f5ef}.project-banner .eyebrow,.project-banner .project-hero__summary{color:#f8f5efe0}.project-intro-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr);gap:1rem;margin-bottom:1rem}.availability-card,.project-article__section{padding:clamp(1.5rem,3vw,2.4rem)}.availability-list{display:grid;gap:.9rem}.availability-item{display:grid;gap:.8rem;padding:1rem;border:1px solid var(--border);border-radius:22px;background:color-mix(in oklab,var(--surface-strong) 84%,transparent)}.availability-item__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.availability-item p{color:var(--text-soft)}.availability-download{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1rem;border-radius:18px;background:var(--accent);color:#111;font-weight:800}.availability-download--disabled{background:#80808038;color:var(--text-soft);pointer-events:none}.project-article{display:grid;gap:1rem}.project-article__section h2{margin:0 0 1rem;font-family:Space Grotesk,sans-serif;font-size:clamp(1.8rem,4vw,2.8rem);line-height:.96;letter-spacing:-.05em;max-width:18ch}.project-article__section p+p,.project-article__section p+.feature-list,.project-article__section h2+p{margin-top:1rem}.project-video{margin-top:1.25rem;border-radius:22px;overflow:hidden;border:1px solid var(--border);background:#000}.project-video iframe{display:block;width:100%;aspect-ratio:16 / 9;height:auto;border:0}.branding-section{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);gap:1.25rem;align-items:start}.branding-section__copy{display:grid;gap:1rem}.branding-section__assets{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.branding-asset-link{display:block;padding:0;border:0;background:transparent;cursor:zoom-in}.branding-asset{margin:0;padding:1rem;border:1px solid color-mix(in oklab,var(--border) 65%,rgba(255,255,255,.35));border-radius:22px;background:color-mix(in oklab,var(--surface-strong) 84%,transparent);box-shadow:inset 0 0 0 1px #ffffff14,0 10px 24px #11111114;display:flex;align-items:center;justify-content:center;min-height:180px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.branding-asset img{width:100%;height:auto;max-height:180px;object-fit:contain}.branding-asset-link:hover .branding-asset{transform:translateY(-2px);border-color:color-mix(in oklab,var(--accent) 28%,var(--border));box-shadow:inset 0 0 0 1px #ffffff1f,0 14px 28px #1111111f}.branding-concepts{margin-top:1.5rem}.branding-concepts__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.branding-asset--concept{min-height:160px}.lightbox{width:min(92vw,1200px);max-width:1200px;padding:1rem;border:1px solid var(--border);border-radius:24px;background:color-mix(in oklab,var(--surface-strong) 88%,rgba(0,0,0,.12));backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);box-shadow:var(--shadow),var(--glass-highlight)}.lightbox::backdrop{background:#000000b8}.lightbox__close{display:inline-flex;margin-left:auto;margin-bottom:.75rem;padding:.5rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-soft);cursor:pointer}.lightbox__image{display:block;width:100%;max-height:80vh;object-fit:contain;border-radius:18px}.project-inline-link{color:var(--accent-strong);text-decoration:underline;text-underline-offset:.18em}.project-figure{overflow:hidden;margin:0}.project-carousel{--carousel-card-width: clamp(220px, 22vw, 320px);overflow:hidden;margin:0}.project-figure img{width:100%;max-height:560px;object-fit:cover}.project-figure__image--contain{object-fit:contain;background:#111}.project-figure__image--top-crop{object-position:center -25px}.project-figure figcaption{padding:.9rem 1.1rem 1.1rem;color:var(--text-soft);font-size:.92rem}.project-carousel__viewport{overflow-x:auto;overflow-y:hidden;padding:1.1rem max(calc(50% - (var(--carousel-card-width) / 2)),1rem);background:linear-gradient(180deg,#111111eb,#111111c7);scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none}.project-carousel__viewport::-webkit-scrollbar{display:none}.project-carousel__track{display:flex;align-items:flex-start;gap:1rem}.project-carousel__slide{flex:0 0 var(--carousel-card-width);margin:0;display:grid;gap:.85rem;align-content:start;scroll-snap-align:center;opacity:.42;transform:scale(.96);transition:opacity .22s ease,transform .22s ease}.project-carousel__slide.is-active{opacity:1;transform:scale(1)}.project-carousel__slide img{display:block;width:100%;height:auto;border-radius:24px;border:1px solid color-mix(in oklab,var(--border) 72%,rgba(255,255,255,.18));background:#111;box-shadow:0 18px 42px #0000003d,inset 0 0 0 1px #ffffff0a}.project-carousel__slide figcaption{padding:0 .15rem;color:var(--text-soft);font-size:.92rem;line-height:1.45}.project-carousel__controls{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 1.1rem 1.1rem;border-top:1px solid var(--border)}.project-carousel__button{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:.55rem .85rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in oklab,var(--surface-strong) 84%,transparent);color:var(--text);font-weight:700}.project-carousel__dots{display:flex;align-items:center;justify-content:center;gap:.55rem}.project-carousel__dot{width:.7rem;height:.7rem;border:0;border-radius:999px;background:color-mix(in oklab,var(--text-soft) 28%,transparent)}.project-carousel__dot[aria-current=true]{background:var(--accent)}.feature-list{display:grid;gap:.9rem}.feature-list li{position:relative;padding-left:1.2rem;color:var(--text-soft)}.feature-list li:before{content:"";position:absolute;left:0;top:.72rem;width:.42rem;height:.42rem;border-radius:50%;background:var(--accent)}@media(max-width:960px){.hero,.app-grid,.project-intro-grid,.project-hero,.project-grid,.split-panel,.contact-panel,.project-layout{grid-template-columns:1fr}.site-header{position:static}.footer-wrap,.nav-wrap{flex-direction:column;align-items:center}.projects-hero__bar{align-items:flex-start}}@media(max-width:640px){.project-carousel{--carousel-card-width: min(72vw, 260px)}.nav,.nav a,.button,.contact-links a,.project-links a,.project-card__link,.back-link{width:100%}.hero{padding-top:2rem}.theme-fab{left:1rem;bottom:1rem}.project-banner{margin-top:0;min-height:252px}.project-banner__content{padding-top:4rem}.projects-hero__bar{flex-direction:column}.app-tile__content{grid-template-columns:1fr;align-items:start;padding-top:2.5rem}.project-carousel__controls{flex-wrap:wrap;justify-content:center}.project-card__content{grid-template-columns:1fr;align-items:start}}
