@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg: #f7f5ef;--bg-soft: #faf8f3;--surface: rgba(255, 255, 255, .58);--surface-solid: #fffdf8;--text: #181818;--text-soft: #3f4145;--muted: #6d706f;--faint: #9a9b96;--border: rgba(24, 24, 24, .1);--border-strong: rgba(24, 24, 24, .18);--accent: #47657d;--accent-soft: rgba(71, 101, 125, .1);--accent-warm: #85745f;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;--max-width: 1120px;--nav-height: 68px;--radius: 8px;--ease: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-height) + 28px)}body{min-width:320px;background:linear-gradient(180deg,#ffffffb8,#f7f5ef00 420px),var(--bg);color:var(--text);font-family:var(--font-sans);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body::selection,::selection{background:#47657d2e}button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}#root{min-height:100vh}.site-backdrop{position:fixed;inset:0;z-index:0;pointer-events:none;background:linear-gradient(90deg,rgba(24,24,24,.035) 1px,transparent 1px) 50% 0 / 112px 112px,linear-gradient(180deg,rgba(24,24,24,.025) 1px,transparent 1px) 50% 0 / 112px 112px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.34),transparent 520px);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.34),transparent 520px)}.container{position:relative;z-index:1;width:min(100% - 48px,var(--max-width));margin:0 auto}section{padding:104px 0}.section-header{max-width:720px;margin-bottom:36px}.section-label,.eyebrow{color:var(--accent);font-family:var(--font-mono);font-size:.76rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.section-title{max-width:780px;margin-top:12px;font-size:clamp(2rem,4vw,3.35rem);font-weight:650;letter-spacing:0;line-height:1.08}.section-subtitle{max-width:620px;margin-top:18px;color:var(--muted);font-size:1rem}.button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;border:1px solid var(--border);border-radius:var(--radius);background:#ffffff73;color:var(--text);font-size:.92rem;font-weight:550;line-height:1;transition:transform .18s ease,border-color .18s ease,background .18s ease}.button:hover{transform:translateY(-1px);border-color:var(--border-strong);background:#ffffffbf}.button-primary{border-color:#47657d47;background:var(--accent);color:#fffdf8}.button-primary:hover{border-color:var(--accent);background:#36556f}.text-link{position:relative;display:inline-flex;align-items:center;color:var(--accent);font-size:.92rem;font-weight:600}.text-link:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:currentColor;opacity:.28;transition:opacity .18s ease}.text-link:hover:after{opacity:.75}.nav{position:fixed;inset:0 0 auto;z-index:1000;height:var(--nav-height);transition:background .22s ease,border-color .22s ease,backdrop-filter .22s ease}.nav--scrolled,.blog-nav{border-bottom:1px solid var(--border);background:#f7f5efd6;backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%)}.nav .container,.blog-nav .nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.nav-logo{display:inline-flex;align-items:center;gap:10px;color:var(--text);font-size:.95rem;font-weight:650;letter-spacing:0}.nav-logo:hover{color:var(--accent)}.nav-logo-mark{display:grid;width:28px;height:28px;place-items:center;border:1px solid var(--border);border-radius:7px;background:#faf8f3;overflow:hidden}.nav-logo-mark img{width:100%;height:100%;object-fit:cover}.nav-logo-text{white-space:nowrap}.nav-links{display:flex;align-items:center;gap:4px;list-style:none}.nav-links a{display:inline-flex;align-items:center;min-height:36px;padding:8px 11px;border-radius:7px;color:var(--muted);font-size:.9rem;font-weight:520;transition:color .18s ease,background .18s ease}.nav-links a:hover,.nav-links a.active{background:#ffffff94;color:var(--text)}.nav-lang,.lang-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:34px;border:1px solid var(--border);border-radius:7px;background:#ffffff6b;color:var(--text-soft);cursor:pointer;font-family:var(--font-mono);font-size:.78rem;font-weight:600;transition:border-color .18s ease,color .18s ease,background .18s ease}.nav-lang:hover,.lang-toggle:hover{border-color:var(--border-strong);background:#ffffffbf;color:var(--text)}.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;border:1px solid var(--border);border-radius:7px;background:#ffffff6b;cursor:pointer}.nav-toggle span{display:block;width:16px;height:1px;margin:0 auto;border-radius:1px;background:var(--text);transition:transform .2s ease,opacity .2s ease}.nav-toggle.active span:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav-toggle.active span:nth-child(2){opacity:0}.nav-toggle.active span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.hero{min-height:88vh;display:flex;align-items:center;padding:calc(var(--nav-height) + 64px) 0 78px}.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 310px;gap:64px;align-items:center}.hero-content{max-width:790px;min-width:0}.hero h1{margin-top:18px;font-size:clamp(2.9rem,7.2vw,6.05rem);font-weight:680;letter-spacing:0;line-height:1;overflow-wrap:break-word}.hero-statement{max-width:760px;margin-top:26px;color:var(--text);font-size:clamp(1.35rem,2.65vw,2.16rem);font-weight:560;line-height:1.18}.hero-description{max-width:690px;margin-top:24px;color:var(--muted);font-size:1.05rem}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px}.hero-identity{display:grid;gap:18px;align-self:center;padding:22px;border:1px solid var(--border);border-radius:var(--radius);background:#ffffff85}.hero-identity-mark{width:76px;height:76px;margin-bottom:8px;border:1px solid rgba(71,101,125,.18);border-radius:16px;background:#faf8f3;overflow:hidden}.hero-identity-mark img{width:100%;height:100%;object-fit:cover}.identity-row{padding-top:14px;border-top:1px solid var(--border)}.identity-row span{display:block;color:var(--faint);font-family:var(--font-mono);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.identity-row strong{display:block;margin-top:5px;color:var(--text);font-size:.95rem;font-weight:620;line-height:1.35}.identity-row--current strong{color:var(--accent)}.portfolio-list{display:grid;gap:18px}.project-card{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:42px;align-items:stretch;padding:32px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:transform .22s var(--ease),border-color .22s ease,background .22s ease}.project-card:hover,.project-card:focus-within{transform:translateY(-2px);border-color:#47657d3d;background:#ffffffb3}.project-card:focus-within{box-shadow:0 0 0 3px #47657d29}.project-card-cover{position:absolute;inset:0;z-index:1;display:block;border-radius:inherit;cursor:pointer}.project-card-cover:focus{outline:none}.project-card-cover:focus-visible{outline:none}.project-card-main,.project-visual{position:relative;z-index:2;min-width:0;pointer-events:none}.project-links,.project-links a{pointer-events:auto}.project-kicker{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:18px;color:var(--muted);font-family:var(--font-mono);font-size:.76rem}.status-badge{display:inline-flex;align-items:center;min-height:26px;padding:4px 9px;border:1px solid rgba(71,101,125,.22);border-radius:999px;background:var(--accent-soft);color:var(--accent);font-family:var(--font-mono);font-size:.72rem;font-weight:600}.project-title{font-size:clamp(1.7rem,3.2vw,2.8rem);font-weight:650;line-height:1.06}.project-lead{max-width:640px;margin-top:14px;color:var(--text-soft);font-size:1.04rem;font-weight:540}.project-desc{max-width:710px;margin-top:14px;color:var(--muted);font-size:.98rem}.project-points{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px 24px;margin-top:22px;padding:0;list-style:none}.project-points li{position:relative;padding-left:16px;color:var(--text-soft);font-size:.9rem;line-height:1.45}.project-points li:before{content:"";position:absolute;top:.72em;left:0;width:5px;height:5px;border-radius:50%;background:var(--accent)}.project-links{display:flex;flex-wrap:wrap;gap:18px;margin-top:26px}.project-visual{min-height:100%;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-solid);overflow:hidden}.project-visual--image{display:flex;align-items:center;justify-content:center}.project-visual--image img{width:100%;height:100%;object-fit:cover}.project-visual--icon{padding:12px;background:#faf8f3}.project-visual--icon img{object-fit:contain;transform:scale(1.22)}.project-visual--beamline{display:grid;min-height:300px;place-items:center;background:radial-gradient(circle at 72% 42%,rgba(71,101,125,.11),transparent 34%),#faf8f3;padding:22px}.project-visual--beamline svg{width:min(100%,300px);height:auto;overflow:visible}.project-visual--beamline rect,.project-visual--beamline path,.project-visual--beamline circle{fill:none;stroke:#243244;stroke-linecap:round;stroke-linejoin:round}.project-visual--beamline .beamline-beam{stroke:var(--accent);stroke-width:5}.project-visual--beamline .beamline-target{fill:#47657d1c;stroke-width:4}.project-visual--beamline .beamline-track{stroke:#243244;stroke-width:3.5}.project-visual--beamline .beamline-track--soft{stroke:#47657d94;stroke-width:2.5}.project-visual--beamline .beamline-dot{fill:var(--accent);stroke:none;opacity:.9}.project-visual--mark{display:grid;place-items:center;min-height:260px;background:linear-gradient(135deg,rgba(71,101,125,.1),transparent 56%),var(--surface-solid)}.project-visual--mark span{color:var(--accent);font-family:var(--font-mono);font-size:5rem;font-weight:600}.hardware-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.hardware-card{min-height:100%;padding:22px;border:1px solid var(--border);border-radius:var(--radius);background:#ffffff7a}.hardware-card h3{margin-top:16px;color:var(--text);font-size:1.03rem;font-weight:620}.hardware-card p{margin-top:10px;color:var(--muted);font-size:.9rem;line-height:1.55}.hardware-icon{width:42px;height:42px}.hardware-icon rect,.hardware-icon path,.hardware-icon circle{fill:none;stroke:var(--accent);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.hardware-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}.hardware-tags span{display:inline-flex;align-items:center;min-height:24px;padding:3px 8px;border:1px solid var(--border);border-radius:999px;color:var(--text-soft);font-family:var(--font-mono);font-size:.68rem;background:#ffffff6b}.about-layout{display:grid;grid-template-columns:.8fr 1.2fr;gap:64px;align-items:start}.about-layout .section-header{margin-bottom:0}.about-content{color:var(--text-soft);font-size:clamp(1rem,1.6vw,1.18rem);line-height:1.6}.about-content p+p{margin-top:18px}.about-main{display:grid;gap:28px;min-width:0}.about-pillars{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.about-pillar{padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:#ffffff6b}.about-pillar h3{color:var(--text);font-size:.95rem;font-weight:620}.about-pillar p{margin-top:8px;color:var(--muted);font-size:.85rem;line-height:1.55}.contact{padding-bottom:48px}.contact-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:48px;align-items:end;padding:34px 0 48px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.contact-text{max-width:540px;margin-top:18px;color:var(--muted)}.contact-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.contact-link{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:9px 14px;border:1px solid var(--border);border-radius:var(--radius);background:#ffffff6b;color:var(--text);font-size:.9rem;font-weight:550;transition:transform .18s ease,border-color .18s ease,background .18s ease}.contact-link:hover{transform:translateY(-1px);border-color:var(--border-strong);background:#ffffffb8}.footer{padding-top:22px}.footer p{color:var(--faint);font-family:var(--font-mono);font-size:.78rem}.blog-nav{position:fixed;inset:0 0 auto;z-index:1000;height:var(--nav-height)}.blog-nav .nav-inner{width:min(100% - 48px,760px);margin:0 auto}.detail-nav-actions{display:flex;align-items:center;gap:12px}.back-link{color:var(--muted);font-size:.88rem;font-weight:540}.back-link:hover{color:var(--accent)}.article{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:calc(var(--nav-height) + 72px) 24px 96px}.article-header{margin-bottom:34px;padding-bottom:28px;border-bottom:1px solid var(--border)}.article-meta{display:flex;flex-wrap:wrap;gap:8px 12px;margin-bottom:18px;color:var(--muted);font-family:var(--font-mono);font-size:.76rem}.article-meta .tag{color:var(--accent)}.article-header h1{font-size:clamp(2.15rem,5vw,3.8rem);font-weight:650;line-height:1.04}.article-header .lead{margin-top:18px;color:var(--muted);font-size:1.08rem}.article-body h2{margin-top:36px;margin-bottom:10px;font-size:1.35rem;font-weight:620}.article-body h3{margin-top:28px;margin-bottom:8px;font-size:1.08rem;font-weight:620}.article-body p,.article-body li{color:var(--text-soft);font-size:1rem}.article-body p{margin-bottom:18px}.article-body strong{color:var(--text);font-weight:620}.article-body ul,.article-body ol{margin:0 0 20px 20px;color:var(--text-soft)}.article-body code{border:1px solid var(--border);border-radius:5px;background:#ffffff8c;color:var(--accent);font-family:var(--font-mono);font-size:.9em;padding:1px 5px}.article-body pre{margin:22px 0;padding:18px;overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:#fffdf8}.article-body pre code{border:0;background:transparent;color:var(--text);padding:0}.article-body blockquote{margin:24px 0;padding:16px 18px;border-left:2px solid var(--accent);background:var(--accent-soft)}.article-section{margin-bottom:24px}.project-hero-image{width:100%;max-height:430px;margin-bottom:34px;border:1px solid var(--border);border-radius:var(--radius);object-fit:cover}.project-detail-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px}.article-footer{margin-top:54px;padding-top:24px;border-top:1px solid var(--border)}.article-footer a{color:var(--accent);font-size:.92rem;font-weight:600}.reveal{opacity:0;transform:translateY(18px);transition:opacity .65s var(--ease),transform .65s var(--ease)}.reveal.visible{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@media(max-width:900px){.hero-grid,.project-card,.about-layout,.contact-panel{grid-template-columns:1fr}.hero-grid{gap:42px}.hero-identity{max-width:420px}.project-visual{min-height:260px}.hardware-grid,.about-pillars{grid-template-columns:repeat(2,minmax(0,1fr))}.contact-panel{align-items:start}.contact-links{justify-content:flex-start}}@media(max-width:760px){:root{--nav-height: 64px}.container{width:min(100% - 32px,var(--max-width))}section{padding:74px 0}.nav .container{gap:10px}.nav-logo-text{max-width:46vw;overflow:hidden;text-overflow:ellipsis}.nav-links{position:fixed;inset:var(--nav-height) 0 0;display:none;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:4px;padding:28px 24px;border-top:1px solid var(--border);background:#f7f5eff7;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.nav-links.active{display:flex}.nav-links a{justify-content:center;min-height:46px;font-size:1rem}.nav-toggle{display:flex}.hero{min-height:auto;padding:calc(var(--nav-height) + 48px) 0 64px}.hero h1{font-size:clamp(2.45rem,14vw,4.2rem)}.hero-statement{font-size:clamp(1.3rem,7vw,2rem)}.hero-description,.about-content{font-size:1rem}.project-card{padding:22px;gap:24px}.project-visual--icon img{transform:scale(1.14)}.project-points,.hardware-grid,.about-pillars{grid-template-columns:1fr}.blog-nav .nav-inner{width:min(100% - 32px,760px)}.detail-nav-actions{gap:8px}.back-link{font-size:.78rem}}@media(max-width:520px){.nav-logo-mark{width:26px;height:26px}.nav-logo-text{max-width:38vw}.hero-actions,.project-detail-links,.contact-links{flex-direction:column;align-items:stretch}.button,.contact-link{width:100%}.project-card{padding:18px}.project-title{font-size:1.7rem}.project-visual,.project-visual--beamline{min-height:210px}.article{padding-inline:16px}}
