:root{--bg: #0d6f38;--bg-deep: #09592d;--paper: #fcfaf6;--ink: #f8f7f2;--ink-soft: rgba(248, 247, 242, .82);--line: rgba(248, 247, 242, .35);--shadow: 0 30px 70px rgba(6, 35, 20, .22);--sans: "Avenir Next", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--serif: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;--focus-ring: 0 0 0 3px rgba(223, 243, 106, .55);--ease-out: cubic-bezier(.22, 1, .36, 1)}*{box-sizing:border-box}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.button{transition:none}.hero-block,.hero-visual,.portrait-frame,.hero:after,.section-transition{animation:none!important;opacity:1!important;transform:none!important}}html{scroll-behavior:smooth}body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);touch-action:manipulation;-webkit-tap-highlight-color:transparent}#root{height:100dvh;height:100vh;overflow:hidden}a{color:inherit;text-decoration:none}.page-shell{height:100%}.page-stack{height:100dvh;height:100vh;transition:transform .72s var(--ease-out);will-change:transform}.page-section{height:100dvh;height:100vh;overflow:hidden}.site-nav-shell{position:fixed;top:0;left:50%;z-index:30;width:min(1180px,calc(100% - 32px));transform:translate(-50%);pointer-events:none}.site-nav-trigger{height:24px;pointer-events:auto}.site-nav{position:fixed;top:16px;left:50%;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:24px;width:min(1180px,calc(100% - 32px));padding:14px 18px;border-radius:999px;transform:translate(-50%,calc(-100% - 22px));background:#0a532aad;border:1px solid rgba(248,247,242,.14);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 14px 40px #051c0f2e;opacity:0;pointer-events:auto;transition:transform .26s var(--ease-out),opacity .22s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease}.site-nav-shell:hover .site-nav,.site-nav-shell:focus-within .site-nav{transform:translate(-50%);opacity:1;background:#0a532ad1;border-color:#f8f7f233}.site-nav__brand{display:flex;align-items:baseline;gap:12px;min-width:0}.site-nav__name{font-family:var(--serif);font-size:22px;line-height:1}.site-nav__role{color:#f8f7f299;font-size:12px;letter-spacing:.1em;text-transform:uppercase}.site-nav__links{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.site-nav__links a,.site-nav__links button{color:#f8f7f2e6;font-size:14px;padding:8px 12px;border-radius:999px;border:0;background:transparent;font-family:inherit;cursor:pointer;transition:background .16s ease,color .16s ease}.site-nav__links a:hover,.site-nav__links button:hover{background:#ffffff14}.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.92fr);min-height:100dvh;min-height:100vh;background:var(--bg);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;inset:auto -80px -120px auto;width:min(420px,55vw);height:min(420px,55vw);border-radius:50%;background:#dff36a14;filter:blur(20px);pointer-events:none;animation:hero-blob-drift 20s ease-in-out infinite alternate}@keyframes hero-blob-drift{0%{opacity:.75;transform:translate(0) scale(1)}to{opacity:1;transform:translate(-16px,-12px) scale(1.06)}}.hero-copy,.hero-visual{position:relative;z-index:1}.hero-copy{padding:clamp(56px,6vw,84px) clamp(28px,5vw,72px) clamp(40px,5vw,72px);display:flex;flex-direction:column;justify-content:center;gap:clamp(32px,4.5vw,52px);max-width:720px}.hero-block{opacity:0;animation:hero-enter .72s var(--ease-out) forwards;animation-delay:var(--enter-delay, 0ms)}@keyframes hero-enter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.greeting{font-size:clamp(14px,1.8vw,16px);letter-spacing:.06em;color:var(--ink-soft);margin:0 0 14px}.hero h1{margin:0 0 clamp(20px,3vw,28px);font-family:var(--serif);font-size:clamp(52px,12vw,118px);line-height:.92;letter-spacing:-.04em;font-weight:700}.bio{margin:0;max-width:38em;padding-left:20px;border-left:3px solid rgba(248,247,242,.85);font-size:clamp(16px,1.9vw,18px);line-height:1.85;color:var(--ink-soft)}.companies{display:flex;flex-direction:column;gap:16px}.companies-label{margin:0;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#f8f7f28c}.company-row{display:flex;flex-wrap:wrap;gap:14px}.company-pill{display:inline-flex;align-items:center;justify-content:center;min-height:48px;min-width:120px;padding:10px 16px;border-radius:12px;background:#fff;color:var(--bg-deep);font-size:14px;font-weight:600;box-shadow:0 4px 14px #00000014}.company-pill--logo{padding:10px 18px}.company-pill__img{display:block;max-height:32px;max-width:140px;width:auto;height:auto;object-fit:contain}.company-pill--fallback{min-width:auto}.cta-row{display:flex;flex-wrap:wrap;align-items:stretch;gap:12px}.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 18px;border-radius:999px;border:1px solid transparent;font-size:15px;font-family:inherit;cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease,opacity .16s ease}.button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.button:active:not(:disabled){transform:scale(.98)}.button.primary{flex:1 1 220px;background:var(--paper);color:var(--bg-deep);font-weight:700}.button.primary:hover{opacity:.95}.button.ghost{min-width:108px;border-color:var(--line);color:var(--ink);background:transparent}.button.ghost:hover{background:#ffffff0f}.button .icon{flex-shrink:0}.hero-visual{display:flex;align-items:stretch;justify-content:center;padding:clamp(56px,6vw,84px) clamp(16px,3vw,32px) clamp(24px,3.5vw,48px);background:linear-gradient(180deg,rgba(9,89,45,.35) 0%,var(--bg-deep) 100%);opacity:0;animation:hero-enter-side .88s var(--ease-out) forwards;animation-delay:var(--enter-delay, 0ms)}@keyframes hero-enter-side{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}.portrait-frame{position:relative;width:min(100%,520px);align-self:center;aspect-ratio:3 / 4;border-radius:28px;overflow:hidden;background:#0003;box-shadow:var(--shadow);transform:scale(1.04);animation:portrait-reveal .88s var(--ease-out) .18s forwards}@keyframes portrait-reveal{to{transform:scale(1)}}.portrait-photo{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block}.portrait-fallback{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,#14281ee6,#093c238c,#062316d9)}.portrait-tint{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,#0d6f3826,#09592d8c 45%,#06321cb8);mix-blend-mode:multiply}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);padding:12px 20px;border-radius:12px;background:#112117eb;color:var(--ink);font-size:14px;box-shadow:0 12px 40px #00000040;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s ease}.toast.show{opacity:1}.project-page{min-height:100dvh;min-height:100vh;padding:clamp(54px,6vw,80px) clamp(28px,4vw,40px) clamp(28px,4vw,40px);background:var(--bg);position:relative;overflow:hidden}.project-page__inner{min-height:calc(100dvh - clamp(82px,9vw,120px));min-height:calc(100vh - clamp(82px,9vw,120px));display:flex;flex-direction:column;justify-content:center}.project-page__header{display:flex;justify-content:space-between;gap:32px;margin-bottom:clamp(24px,3vw,36px)}.project-page__eyebrow{margin:0 0 12px;color:#f8f7f294;letter-spacing:.14em;text-transform:uppercase;font-size:13px}.project-page__title{margin:0;font-family:var(--serif);font-size:clamp(42px,6.8vw,74px);line-height:.94;letter-spacing:-.05em}.project-page__header-actions{display:flex;flex-direction:column;align-items:flex-end;gap:14px;max-width:700px}.project-page__summary{margin:0;max-width:40em;color:var(--ink-soft);font-size:15px;line-height:1.65;text-align:right}.project-page__links{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:12px 16px}.project-link{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:14px;color:#f8f7f2f5}.project-link--button{min-height:46px;padding:0 18px;border:1px solid rgba(248,247,242,.18);border-radius:999px;color:var(--bg-deep);background:var(--paper);font-weight:700;transition:transform .16s ease,opacity .16s ease,background .16s ease,border-color .16s ease}.project-link--button:hover{opacity:.96}.project-link--button:active{transform:scale(.985)}.project-link--secondary{color:var(--ink);background:#f8f7f214;border-color:#f8f7f229}.project-link--secondary:hover{background:#f8f7f21f}.project-board{flex:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.98fr);gap:clamp(14px,1.8vw,20px);align-items:stretch}.project-panel{min-width:0;padding:clamp(14px,1.6vw,18px);border-radius:24px;background:#f8f7f20b;box-shadow:inset 0 0 0 1px #f8f7f214;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.project-video-frame{position:relative;width:100%;aspect-ratio:16 / 9;background:#041a0d66;border-radius:20px;overflow:hidden;box-shadow:0 24px 50px #051e1129}.project-video-frame iframe{display:block;width:100%;height:100%;border:0}.project-meta{margin-top:18px;display:flex;flex-direction:column;gap:18px}.project-meta__group{display:flex;flex-direction:column;gap:10px}.project-meta__label,.project-prompt__label{margin:0;color:#f8f7f28f;font-size:13px;letter-spacing:.08em}.project-flow,.project-stack{display:flex;flex-wrap:wrap;gap:10px}.project-flow__item,.project-stack__item{display:inline-flex;align-items:center;gap:10px;min-height:36px;padding:0 14px;border-radius:999px;background:#f8f7f20d;color:#f8f7f2f0;font-weight:600;font-size:13px}.project-flow__arrow{color:#f8f7f280;font-size:20px;line-height:1}.project-prompt{margin-top:12px;border-radius:20px;background:#07582c3d;min-height:min(58vh,620px);overflow:hidden;box-shadow:inset 0 0 0 1px #f8f7f21a}.project-prompt__topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid rgba(248,247,242,.12)}.project-prompt__lights{display:inline-flex;gap:10px}.project-prompt__lights span{width:12px;height:12px;border-radius:50%}.project-prompt__lights span:nth-child(1){background:#d57e4f}.project-prompt__lights span:nth-child(2){background:#c3a447}.project-prompt__lights span:nth-child(3){background:#4ba65d}.project-prompt__title{text-align:center;color:#f8f7f27a;letter-spacing:.16em;font-size:12px}.project-prompt__copy{border:0;padding:0;background:transparent;color:#f8f7f280;font-size:14px}.project-prompt__scroll{max-height:calc(min(58vh,620px) - 48px);overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(248,247,242,.34) transparent}.project-prompt__scroll::-webkit-scrollbar{width:10px}.project-prompt__scroll::-webkit-scrollbar-track{background:transparent}.project-prompt__scroll::-webkit-scrollbar-thumb{border-radius:999px;background:#f8f7f242;border:2px solid transparent;background-clip:padding-box}.project-prompt__content{margin:0;padding:16px 18px 20px;color:#f8f7f2eb;font-family:ui-monospace,SFMono-Regular,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.65;white-space:pre-wrap}.section-transition{opacity:0;transform:translateY(0);filter:blur(6px);transition:opacity .52s var(--ease-out),filter .52s var(--ease-out);transition-delay:var(--panel-delay, 0ms)}.section-transition--left,.section-transition--right{transform:translateY(0)}.project-page.is-visible .section-transition,.datahub-page.is-visible .section-transition{opacity:1;filter:blur(0)}.datahub-page{min-height:100dvh;min-height:100vh;padding:clamp(54px,6vw,80px) clamp(28px,4vw,40px) clamp(28px,4vw,40px);background:radial-gradient(circle at 16% 18%,rgba(223,243,106,.08),transparent 24%),linear-gradient(180deg,#09592d61,#09592d00 18%),var(--bg);position:relative;overflow:hidden}.datahub-page__inner{min-height:calc(100dvh - clamp(82px,9vw,120px));min-height:calc(100vh - clamp(82px,9vw,120px));display:flex;flex-direction:column;justify-content:center}.datahub-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:clamp(14px,2vw,22px)}.datahub-page__eyebrow,.datahub-panel__label{margin:0 0 12px;color:#f8f7f294;letter-spacing:.14em;text-transform:uppercase;font-size:13px}.datahub-page__title{margin:0;font-family:var(--serif);font-size:clamp(42px,6.8vw,74px);line-height:.94;letter-spacing:-.05em}.datahub-page__header-actions{display:flex;flex-direction:column;align-items:flex-end;gap:12px;max-width:560px}.datahub-page__summary{margin:0;max-width:36em;color:var(--ink-soft);font-size:14px;line-height:1.6;text-align:right}.datahub-board{flex:1;display:grid;grid-template-columns:1.04fr 1fr .92fr;gap:clamp(12px,1.4vw,16px)}.datahub-panel{min-width:0;padding:clamp(12px,1.5vw,16px);border-radius:22px;background:#f8f7f20b;box-shadow:inset 0 0 0 1px #f8f7f214;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.datahub-panel__title{margin:0 0 14px;font-size:clamp(20px,2vw,28px);line-height:1.1;font-family:var(--serif)}.datahub-pipeline{display:flex;flex-direction:column;gap:8px}.datahub-step{position:relative;display:grid;grid-template-columns:42px 1fr;gap:10px;align-items:start}.datahub-step__icon{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:#f8f7f214;box-shadow:inset 0 0 0 1px #f8f7f22e}.datahub-step__icon span{width:14px;height:14px;border-radius:4px;background:#dff36ac7}.datahub-step__body{padding:10px 12px;border-radius:16px;background:#f8f7f20a;box-shadow:inset 0 0 0 1px #f8f7f21a}.datahub-step__row{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:4px}.datahub-step__row h4{margin:0;font-size:15px}.datahub-step__row span{color:#f8f7f259;font-size:18px;font-family:var(--serif)}.datahub-step__body p{margin:0;color:var(--ink-soft);font-size:12.5px;line-height:1.45}.datahub-step__connector{grid-column:1 / 2;justify-self:center;width:1px;height:12px;background:linear-gradient(180deg,#f8f7f247,#f8f7f200)}.datahub-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.datahub-card{display:flex;flex-direction:column;gap:6px}.datahub-card__screen{position:relative;border:0;padding:0;border-radius:18px;background:#f7f6f1;overflow:hidden;min-height:124px;box-shadow:0 12px 24px #071a0f1a;cursor:zoom-in}.datahub-card__image,.datahub-card__fallback{display:block;width:100%;height:124px}.datahub-card__image{object-fit:cover;background:#e9e5dc}.datahub-card__fallback{display:flex;flex-direction:column;justify-content:flex-end;gap:8px;padding:18px;background:linear-gradient(180deg,#0d6f3838,#0d6f386b),#e9e5dc;color:#0f4023}.datahub-card__fallback span{font-size:14px;letter-spacing:.16em;text-transform:uppercase}.datahub-card__fallback strong{font-size:16px;line-height:1.2}.datahub-card__zoom{position:absolute;right:10px;bottom:10px;padding:5px 8px;border-radius:999px;background:#082716b3;color:#f8f7f2eb;font-size:11px;line-height:1}.datahub-card__meta{display:flex;flex-direction:column;gap:4px}.datahub-card__meta strong{font-size:14px}.datahub-card__meta span{color:#f8f7f2a8;font-size:12px}.datahub-config{border-radius:20px;background:#07582c3d;min-height:auto;overflow:hidden;box-shadow:inset 0 0 0 1px #f8f7f21a}.datahub-config__topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid rgba(248,247,242,.12)}.datahub-config__scroll{overflow:visible;max-height:none}.datahub-config .project-prompt__content{padding:12px 14px 14px;font-size:12px;line-height:1.5}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:28px}.lightbox__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#04100ac7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox__figure{position:relative;z-index:1;width:min(1120px,calc(100vw - 56px));margin:0}.lightbox__image{display:block;width:100%;max-height:calc(100vh - 120px);object-fit:contain;border-radius:20px;box-shadow:0 24px 80px #0000004d;background:#ffffff0a}.lightbox__close{position:absolute;top:-10px;right:-10px;width:38px;height:38px;border:0;border-radius:999px;background:#f8f7f2eb;color:var(--bg-deep);font-size:28px;line-height:1;cursor:pointer}.lightbox__caption{margin-top:10px;text-align:center;color:#f8f7f2d1;font-size:14px}@media(max-width:900px){.site-nav{top:12px;width:calc(100% - 20px);padding:12px 14px;border-radius:22px}.site-nav__brand{gap:8px}.site-nav__role{display:none}.site-nav__links{gap:8px}.hero{grid-template-columns:1fr;grid-template-rows:auto 1fr}.hero-visual{order:-1;padding:52px 20px 16px}.portrait-frame{max-height:min(52vh,480px);margin:0 auto}.hero-copy{padding:16px clamp(20px,5vw,28px) clamp(36px,6vw,48px);max-width:none}.cta-row .button.primary{flex-basis:100%}.project-page{padding:52px 20px 20px}.project-page__inner{min-height:calc(100dvh - 72px);min-height:calc(100vh - 72px)}.project-page__header{flex-direction:column;gap:18px}.project-page__header-actions{align-items:flex-start}.project-page__summary{text-align:left}.project-page__links{justify-content:flex-start}.project-board{grid-template-columns:1fr}.project-panel{padding:16px;border-radius:22px}.project-video-frame{aspect-ratio:4 / 3}.project-prompt{min-height:52vh}.project-prompt__scroll{max-height:calc(52vh - 48px)}.datahub-page{padding:52px 20px 20px}.datahub-page__inner{min-height:calc(100dvh - 72px);min-height:calc(100vh - 72px)}.datahub-page__header{flex-direction:column;gap:18px}.datahub-page__header-actions{align-items:flex-start}.datahub-page__summary{text-align:left}.datahub-board{grid-template-columns:1fr}.datahub-panel{padding:14px;border-radius:18px}.datahub-gallery{grid-template-columns:1fr}.lightbox{padding:18px}.lightbox__figure{width:calc(100vw - 36px)}.lightbox__image{max-height:calc(100vh - 88px);border-radius:16px}.lightbox__close{top:-8px;right:-2px}}
