:root{--font-family: "Noto Sans TC", "SF Pro Display", "SF Pro Text", -apple-system, BlinkMacSystemFont, "PingFang TC", "Microsoft JhengHei", sans-serif;--color-bg: #f2f2f7;--color-surface: rgba(255, 255, 255, .7);--color-surface-strong: rgba(255, 255, 255, .9);--color-surface-solid: #ffffff;--color-text: #1d1d1f;--color-muted: #6e6e73;--color-primary: #0071e3;--color-primary-soft: rgba(0, 113, 227, .12);--color-border: rgba(22, 22, 23, .08);--shadow-soft: 0 22px 55px rgba(17, 17, 19, .12);--shadow-hover: 0 32px 80px rgba(17, 17, 19, .16);--frost-blur: blur(28px);--radius-large: 28px;--radius-medium: 16px;--radius-small: 10px;--transition: .22s cubic-bezier(.22, 1, .36, 1);--sky: #6ab9ff;--sun: #FFD54F;--sun-glow: #FFE082;--moon: #cfeaff;--hill: #2e5b3b}:root.theme-dark,body.theme-dark{--color-bg: #000000;--color-surface: rgba(17, 17, 19, .76);--color-surface-strong: rgba(28, 28, 30, .88);--color-surface-solid: #1d1d1f;--color-text: #f5f5f7;--color-muted: #b1b1b6;--color-primary: #66a9ff;--color-primary-soft: rgba(102, 169, 255, .18);--color-border: rgba(209, 209, 214, .16);--shadow-soft: 0 28px 70px rgba(0, 0, 0, .55);--shadow-hover: 0 36px 110px rgba(0, 0, 0, .6);--frost-blur: blur(32px);--hill: rgba(44, 111, 187)}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-family);color:var(--color-text);background:var(--color-bg);scroll-behavior:smooth}.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}body.has-scroll-snap main[data-scroll-root]{scroll-snap-type:y proximity;scroll-padding-top:96px}body.has-scroll-snap [data-snap-section]{scroll-snap-align:start;scroll-snap-stop:always}@media(max-width:768px){body.has-scroll-snap main[data-scroll-root]{scroll-snap-type:none}}body:before{content:"";position:fixed;inset:0;background:linear-gradient(180deg,#ffffffb3,#f2f2f7f2 40%,#ebebf0e6);pointer-events:none;z-index:-2}:root.theme-dark body:before,body.theme-dark:before{background:linear-gradient(180deg,#070a12e0,#000000f5 45%,#020408f0)}.bg-accent{position:fixed;inset:0;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.6),transparent 55%),radial-gradient(circle at 80% 0%,rgba(0,113,227,.14),transparent 60%),radial-gradient(circle at 90% 70%,rgba(120,120,128,.12),transparent 62%);filter:var(--frost-blur);opacity:.8;z-index:-3}:root.theme-dark .bg-accent,body.theme-dark .bg-accent{background:radial-gradient(circle at 20% 10%,rgba(70,86,112,.18),transparent 55%),radial-gradient(circle at 80% 0%,rgba(71,117,189,.16),transparent 60%),radial-gradient(circle at 90% 70%,rgba(22,26,36,.24),transparent 62%);opacity:.58}.container{width:min(1160px,92vw);margin:0 auto;padding-inline:clamp(1.5rem,4vw,3rem)}@keyframes float-soft{0%,to{transform:translateZ(0) scale(1)}50%{transform:translate3d(0,-14px,0) scale(1.02)}}@keyframes badge-glow{0%,to{opacity:.65}50%{opacity:1}}.animations-ready [data-animate]{--animate-delay: 0ms;--animate-translate-y: 24px;--animate-scale: 1;--animate-blur: 0px;--animate-rotate-x: 0deg;--animate-rotate-y: 0deg;opacity:0;transform:translate3d(0,var(--animate-translate-y),0) scale(var(--animate-scale)) rotateX(var(--animate-rotate-x)) rotateY(var(--animate-rotate-y));filter:blur(var(--animate-blur));transition:opacity .68s cubic-bezier(.22,1,.36,1),transform .74s cubic-bezier(.22,1,.36,1),filter .74s cubic-bezier(.22,1,.36,1);transition-delay:var(--animate-delay);transform-style:preserve-3d;will-change:opacity,transform}[data-animate=fade-up]{--animate-translate-y: 36px}[data-animate=rise]{--animate-translate-y: 48px}[data-animate=fade]{--animate-translate-y: 0px;--animate-blur: 12px}[data-animate=scale]{--animate-translate-y: 24px;--animate-scale: .94}[data-animate=tilt]{--animate-translate-y: 90px;--animate-rotate-x: 12deg;--animate-blur: 8px;transform-origin:top center}@media(max-width:768px){[data-animate=tilt]{--animate-translate-y: 60px;--animate-rotate-x: 8deg}}[data-animate=panel]{--animate-translate-y: clamp(28px, 3.8vw, 48px);--animate-rotate-x: 12deg;--animate-scale: .94;--animate-blur: 10px;transform-origin:top center}.animations-ready .is-visible[data-animate]{opacity:1;transform:translateZ(0) scale(1) rotateX(0) rotateY(0);filter:blur(0)}.site-header{position:sticky;top:0;z-index:10;backdrop-filter:var(--frost-blur);background:color-mix(in srgb,var(--color-surface) 85%,transparent);border-bottom:1px solid var(--color-border)}.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:1rem}.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;letter-spacing:.02em;color:inherit;text-decoration:none}.brand__logo{display:grid;place-items:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-small);background:color-mix(in srgb,var(--color-text) 92%,transparent);color:var(--color-surface-solid);font-weight:700;font-size:1.05rem;letter-spacing:.08em}.site-nav{display:flex;align-items:center;gap:clamp(1.25rem,3vw,1.8rem);font-size:.95rem;letter-spacing:.04em}.site-nav a{color:color-mix(in srgb,var(--color-text) 86%,transparent);text-decoration:none;padding-block:.25rem;transition:color var(--transition),border-color var(--transition);border-bottom:2px solid transparent}.site-nav a:hover,.site-nav a:focus{color:var(--color-primary);border-color:currentColor}.theme-toggle-fab{position:fixed;top:18px;right:18px;z-index:1200;height:42px;width:42px;border-radius:999px;border:1px solid rgba(255,255,255,.55);background:#141a2261;color:#fff;backdrop-filter:blur(8px) saturate(140%);box-shadow:0 10px 24px #1018282e;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s ease,background .3s ease;overflow:hidden;padding:0;outline:none;-webkit-tap-highlight-color:transparent}:root:not(.theme-dark) .theme-toggle-fab{background:linear-gradient(180deg,var(--sky),color-mix(in srgb,var(--sky) 85%,#ffffff));border-color:#0071e333;color:#1d1d1f}.theme-toggle-fab:hover{transform:translateY(-2px) scale(1.04);background:#141a2280;box-shadow:0 14px 32px #10182847}:root:not(.theme-dark) .theme-toggle-fab:hover{background:linear-gradient(180deg,var(--sky),color-mix(in srgb,var(--sky) 92%,#ffffff));box-shadow:0 14px 32px #2c6fbb38}.theme-toggle-fab:before{content:"";position:absolute;bottom:0;left:50%;width:130%;height:50%;transform:translate(-50%) translateY(18%);background:radial-gradient(120% 120% at 50% 100%,var(--hill) 63%,transparent 64%);opacity:.9;transition:transform .8s cubic-bezier(.16,1,.3,1),opacity .6s ease;z-index:2}.theme-toggle-fab:hover:before{transform:translate(-50%) translateY(4%) scale(1.04);opacity:1}.theme-toggle-fab:after{content:"";position:absolute;inset:0;margin:auto;width:140%;height:140%;pointer-events:none;background:radial-gradient(circle at 50% 60%,var(--sun-glow) 0%,transparent 55%);opacity:0;transform:scale(.6);transition:opacity .6s ease,transform .6s cubic-bezier(.16,1,.3,1);filter:blur(8px);z-index:0}.theme-toggle-fab:hover:after{opacity:.25;transform:scale(1)}.theme-toggle-fab .icon-sun,.theme-toggle-fab .icon-moon{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;transition:transform .9s cubic-bezier(.2,.8,.2,1),filter .9s ease,opacity .9s ease;will-change:transform,filter,opacity}.theme-toggle-fab svg{width:20px;height:20px;display:block}.theme-toggle-fab .icon-sun{color:var(--sun)}.theme-toggle-fab .icon-moon{color:var(--moon);display:none}:root.theme-dark .theme-toggle-fab .icon-sun{display:none}:root.theme-dark .theme-toggle-fab .icon-moon{display:flex}.theme-toggle-fab:hover .icon-sun{animation:sun-rise-ref .9s cubic-bezier(.2,.8,.2,1) both}:root.theme-dark .theme-toggle-fab:hover .icon-moon{animation:moon-rise-ref .9s cubic-bezier(.2,.8,.2,1) both}@keyframes sun-rise-ref{0%{transform:translateY(10px) scale(.92) rotate(-8deg);filter:drop-shadow(0 0 0 rgba(255,200,0,0))}60%{transform:translateY(-2px) scale(1.06) rotate(2deg);filter:drop-shadow(0 2px 8px rgba(255,200,10,.45))}to{transform:translateY(0) scale(1) rotate(0);filter:drop-shadow(0 0 6px rgba(255,200,10,.35))}}@keyframes moon-rise-ref{0%{transform:translateY(10px) scale(.92) rotate(8deg);filter:drop-shadow(0 0 0 rgba(207,234,255,0))}60%{transform:translateY(-2px) scale(1.06) rotate(-2deg);filter:drop-shadow(0 2px 8px rgba(207,234,255,.45))}to{transform:translateY(0) scale(1) rotate(0);filter:drop-shadow(0 0 6px rgba(207,234,255,.35))}}body.theme-switching:before,body.theme-switching:after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none}body.theme-switching.sunrise:before{background:linear-gradient(180deg,#3a7bd5,#fff);animation:sky-fade-ref 1.8s ease-in-out forwards}body.theme-switching.sunset:before{background:linear-gradient(180deg,#0b1a30,#440a0a);animation:sky-fade-ref 1.8s ease-in-out forwards}@keyframes sky-fade-ref{0%{opacity:0}20%{opacity:1}80%{opacity:1}to{opacity:0}}body.theme-switching:after{width:150px;height:150px;border-radius:50%;top:10%;left:25%;right:auto;transform:translate(-50%);filter:blur(28px);opacity:0}body.theme-switching.sunrise:after{background:var(--sun);box-shadow:0 0 55px var(--sun-glow);transform:translate(-50%) translateY(80vh) scale(.92);animation:sun-up-ref 1.4s cubic-bezier(.16,1,.3,1) .1s forwards}body.theme-switching.sunset:after{background:#ff4d00;box-shadow:0 0 60px #ff4d00;transform:translate(-50%) translateY(-15vh) scale(1.06);animation:sun-down-ref 1.4s cubic-bezier(.16,1,.3,1) .1s forwards}@keyframes sun-up-ref{0%{transform:translate(-50%) translateY(80vh) scale(.92);opacity:.7}60%{transform:translate(-50%) translateY(10vh) scale(1.06);opacity:.9}to{transform:translate(-50%) translateY(-20vh) scale(1);opacity:0}}@keyframes sun-down-ref{0%{transform:translate(-50%) translateY(-15vh) scale(1.06);opacity:.7}60%{transform:translate(-50%) translateY(65vh) scale(.94);opacity:.9}to{transform:translate(-50%) translateY(110vh) scale(.9);opacity:0}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.7rem;border-radius:var(--radius-medium);font-weight:600;text-decoration:none;transition:transform var(--transition),box-shadow var(--transition),background var(--transition),color var(--transition)}.btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 18px 40px #0071e33d}.btn--primary:hover,.btn--primary:focus{transform:translateY(-2px);box-shadow:0 24px 55px #0071e347}.btn--ghost{background:color-mix(in srgb,var(--color-surface) 88%,transparent);color:color-mix(in srgb,var(--color-text) 85%,transparent);border:1px solid var(--color-border)}.btn--ghost:hover,.btn--ghost:focus{background:color-mix(in srgb,var(--color-primary-soft) 50%,var(--color-surface))}.section{padding:5.5rem 0}.section--intro{padding-block:clamp(5rem,12vh,7rem) clamp(5.5rem,14vh,8rem)}.intro{display:grid;grid-template-columns:minmax(0,320px) minmax(0,1fr);align-items:center;gap:clamp(2rem,6vw,4rem)}.intro__media{position:relative;display:flex;align-items:center;justify-content:center;padding:clamp(1.6rem,4vw,2.5rem);border-radius:var(--radius-large);background:color-mix(in srgb,var(--color-surface) 90%,transparent);border:1px solid var(--color-border);box-shadow:0 18px 45px #1111131f;backdrop-filter:var(--frost-blur);min-height:clamp(220px,28vw,260px);width:clamp(200px,28vw,260px);isolation:isolate}.intro__badge{position:relative;width:100%;aspect-ratio:5 / 6;border-radius:var(--radius-medium);padding:clamp(1.2rem,3.6vw,1.6rem);display:flex;flex-direction:column;justify-content:flex-end;gap:.6rem;background:linear-gradient(160deg,#0071e3d9,#005accc7);color:#f5f5f7;box-shadow:0 28px 55px #0071e361;overflow:hidden}.intro__badge:after{content:"";position:absolute;inset:12% auto auto 12%;width:clamp(38px,10vw,46px);height:clamp(38px,10vw,46px);border-radius:8px;background:#ffffff40;opacity:.5;transform:rotate(-8deg)}.intro__badge-mark{position:relative;z-index:1;font-size:clamp(2.3rem,5.4vw,2.9rem);font-weight:800;letter-spacing:.08em}.intro__badge-caption{position:relative;z-index:1;font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;color:#ffffffbf}.intro__glow{display:none}.intro__content{display:flex;flex-direction:column;gap:1.6rem}.intro__eyebrow{font-size:.95rem;letter-spacing:.26em;text-transform:uppercase;color:color-mix(in srgb,var(--color-text) 70%,transparent)}.intro__title{display:flex;flex-direction:column;gap:clamp(.45rem,1.4vw,.75rem);font-size:clamp(2.3rem,4vw,3.1rem);line-height:1.18;margin:0}.intro__title-visual{display:inline-flex;flex-direction:column;gap:clamp(.3rem,1vw,.5rem)}.intro__title-name{font-weight:800;letter-spacing:-.01em}.intro__title-line{display:flex;flex-wrap:wrap;align-items:baseline;gap:clamp(.2rem,.9vw,.45rem)}.intro__title-text{display:inline-flex;align-items:baseline}.intro__title-rotator{display:inline-block;min-width:2.4ch;color:var(--color-primary);font-weight:700}.intro__description{margin:0;color:color-mix(in srgb,var(--color-text) 88%,transparent);font-size:1.05rem;line-height:1.7;max-width:58ch}.intro__highlights{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.9rem}.intro__highlights li{display:flex;align-items:center;gap:.6rem;padding:.85rem 1rem;border-radius:var(--radius-medium);background:color-mix(in srgb,var(--color-surface-strong) 92%,transparent);border:1px solid var(--color-border);font-weight:500;backdrop-filter:var(--frost-blur)}.intro__highlights span{font-size:1.45rem;font-weight:700;color:var(--color-primary)}.intro__actions{display:flex;flex-wrap:wrap;gap:1rem}@media(max-width:960px){.intro{grid-template-columns:minmax(0,1fr)}.intro__media{max-width:min(260px,78vw);justify-self:center}}@media(max-width:640px){.section--intro{padding-block:4.6rem 5.4rem}.intro__highlights{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}.section--soft{position:relative}.section--soft:before{content:none}.section--layered{position:relative;overflow:hidden}.section--layered:before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(79,70,229,.12),transparent 55%),radial-gradient(circle at 85% 15%,rgba(236,72,153,.1),transparent 60%);z-index:-1;opacity:.8;pointer-events:none}.section__float{display:none}.section--accent{position:relative;overflow:hidden;color:var(--color-text)}.section--accent:before{content:"";position:absolute;inset:0;background:linear-gradient(145deg,#0071e31f,#00000005);z-index:-1;opacity:1;pointer-events:none}.section__header{max-width:720px;margin-bottom:3rem}.section__eyebrow{font-size:.75rem;letter-spacing:.2em;color:var(--color-primary);margin-bottom:.5rem}.section__title{margin:0;font-size:clamp(1.8rem,2vw + 1rem,2.6rem)}.section__subtitle{margin-top:.9rem;color:var(--color-muted);line-height:1.7;word-break:keep-all}.section--soft .section__header{max-width:none}.section--soft .section__subtitle{max-width:100%}.section--sticky{padding-block:clamp(6rem,5vw + 4rem,8rem) clamp(8.5rem,9vw,12rem);overflow:clip}.about-list{margin-top:clamp(2.4rem,5vw,3.8rem);border-radius:var(--radius-large);background:color-mix(in srgb,var(--color-surface-strong) 92%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 85%,transparent);box-shadow:0 22px 50px #1111131f;overflow:hidden}.about-item{display:grid;grid-template-columns:minmax(180px,240px) minmax(0,1fr);gap:clamp(1.2rem,3vw,2.6rem);padding:clamp(1.6rem,3vw,2.6rem) clamp(1.8rem,4vw,3rem);align-items:start;border-bottom:1px solid color-mix(in srgb,var(--color-border) 70%,transparent)}.about-item--full{grid-template-columns:minmax(0,1fr);gap:clamp(.9rem,2.2vw,1.8rem);text-align:left;justify-items:start}.about-item--full .about-item__header{flex-direction:row;justify-content:center;align-items:baseline;gap:clamp(.9rem,2vw,1.6rem)}.about-item--full .about-item__eyebrow{order:-1;font-size:clamp(.78rem,.4vw + .7rem,.95rem);letter-spacing:.26em}.about-item--full .about-item__title{font-size:clamp(1.6rem,1.8vw + 1.2rem,2.4rem)}.about-item:last-child{border-bottom:none}.about-item__header{display:flex;flex-direction:column;gap:.45rem;position:relative}.about-item__eyebrow{margin:0;font-size:.78rem;letter-spacing:.2em;color:var(--color-primary);text-transform:uppercase}.about-item__title{margin:0;font-size:clamp(1.35rem,1.1vw + 1.2rem,2rem);line-height:1.35}.about-item__body{display:grid;gap:clamp(.8rem,2vw,1.4rem);color:var(--color-text);font-size:clamp(1.02rem,.6vw + .95rem,1.2rem);line-height:1.7}.about-item__body p{margin:0}.about-item__facts{margin:0;padding:0;display:grid;gap:clamp(.8rem,2vw,1.2rem)}.about-item__fact{display:grid;gap:.35rem}.about-item__fact dt{font-weight:600;color:var(--color-primary)}.about-item__fact dd{margin:0}.about-item__list{margin:0;padding:0;list-style:none;display:grid;gap:clamp(.7rem,1.6vw,1.1rem)}.about-item__list li{position:relative;padding-left:1.25rem}.about-item__list li:before{content:"";position:absolute;left:0;top:.55rem;width:.5rem;height:.5rem;border-radius:50%;background:var(--color-primary);opacity:.5}.about-item strong{color:var(--color-text)}@media(max-width:880px){.about-item{grid-template-columns:minmax(0,1fr);gap:1rem}.about-item--full{text-align:left}.about-item--full .about-item__header{flex-direction:column;align-items:flex-start;gap:.45rem}.about-item__header{padding-bottom:.3rem;border-bottom:1px solid color-mix(in srgb,var(--color-border) 65%,transparent)}.about-item__body{padding-top:.5rem}}@media(max-width:640px){.about-list{margin-top:2.1rem;border-radius:1.8rem}.about-item{padding:clamp(1.4rem,5vw,1.9rem) clamp(1.3rem,6vw,2rem)}.about-item__title{font-size:clamp(1.25rem,4.2vw,1.65rem)}.about-item__body{font-size:clamp(1.02rem,4vw,1.12rem)}.section__subtitle{word-break:normal}}.theme-dark .about-list{background:color-mix(in srgb,var(--color-surface-strong) 88%,transparent);border-color:color-mix(in srgb,var(--color-border) 40%,transparent);box-shadow:0 18px 40px #02061773}.filter-controls{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:.75rem;margin:0 auto 2.8rem;padding:clamp(.9rem,2vw,1.2rem) clamp(1rem,3vw,1.6rem);border-radius:var(--radius-large);background:color-mix(in srgb,var(--color-surface) 90%,transparent);border:1px solid var(--color-border);box-shadow:0 20px 50px #1111131f;backdrop-filter:var(--frost-blur);width:min(100%,820px)}.filter-btn{border:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface-strong) 95%,transparent);color:inherit;border-radius:var(--radius-medium);padding:.6rem 1.35rem;cursor:pointer;transition:background var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition);font-weight:500}.filter-btn.is-active{background:var(--color-primary);color:#fff;box-shadow:0 18px 42px #0071e359}.filter-btn:hover,.filter-btn:focus-visible{transform:translateY(-1px)}.filter-btn:hover,.filter-btn:focus{box-shadow:var(--shadow-soft)}@media(max-width:640px){.filter-controls{justify-content:flex-start;border-radius:1.2rem;padding:.85rem 1rem;gap:.6rem}.filter-btn{flex:1 1 calc(50% - .6rem);min-width:0;text-align:center;padding:.55rem .75rem}}.project-timeline{position:relative;display:flex;flex-direction:column;gap:clamp(2.6rem,6vw,3.6rem);padding-left:clamp(2.8rem,7vw,4rem);isolation:isolate}.project-timeline:before{content:"";position:absolute;top:0;bottom:0;left:clamp(1.4rem,4.2vw,2.2rem);width:2px;background:color-mix(in srgb,var(--color-border) 70%,transparent);border-radius:999px;pointer-events:none;z-index:0}.project-card{--accent: var(--color-primary);--accent-soft: color-mix(in srgb, var(--color-primary) 26%, transparent);--accent-glow: color-mix(in srgb, var(--color-primary) 40%, transparent);position:relative;display:grid;grid-template-columns:minmax(120px,170px) minmax(0,1fr);gap:clamp(1.6rem,4vw,2.8rem);padding:clamp(1.9rem,4vw,2.6rem) clamp(2rem,5vw,3rem);padding-left:clamp(3.4rem,8vw,4.6rem);border-radius:var(--radius-large);background:color-mix(in srgb,var(--color-surface) 92%,transparent);border:1px solid var(--color-border);box-shadow:0 24px 60px #11111324;backdrop-filter:var(--frost-blur);text-decoration:none;color:inherit;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);transform-style:preserve-3d;backface-visibility:hidden;overflow:visible;z-index:1;scroll-margin-block:clamp(4.5rem,12vw,6.5rem)}@keyframes project-card-refresh{0%{opacity:0;transform:translate3d(0,42px,0) scale(.985) rotateX(10deg);filter:blur(8px)}to{opacity:1;transform:translateZ(0) scale(1) rotateX(0);filter:blur(0)}}.project-card.is-filter-refreshing{animation:project-card-refresh .72s cubic-bezier(.22,1,.36,1) both;animation-delay:var(--filter-refresh-delay, 0ms);will-change:opacity,transform,filter}.project-card:before,.project-card:after{content:none}.project-card:hover,.project-card:focus-visible{transform:translate3d(0,-8px,0);box-shadow:0 32px 80px #1111132e;border-color:color-mix(in srgb,var(--accent-safe) 30%,var(--color-border))}.project-card:focus-visible{outline:none}.project-card__rail{display:none}.project-card__timeline{position:relative;display:flex;flex-direction:row;align-items:center;gap:.75rem;flex-wrap:nowrap;padding-left:clamp(.9rem,2.4vw,1.4rem);font-weight:600;color:color-mix(in srgb,var(--color-text) 92%,transparent);z-index:1;white-space:nowrap}.project-card__timeline:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:.9rem;height:.9rem;border-radius:var(--radius-small);background:color-mix(in srgb,var(--accent-safe) 80%,var(--color-surface-solid));box-shadow:0 0 0 1px var(--color-border)}.project-card__timeline:after{content:none}.project-card__time{font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.project-card__tag{font-size:.95rem;color:color-mix(in srgb,var(--accent-safe) 70%,var(--color-text));white-space:nowrap}.project-card__body{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,280px);gap:clamp(1.3rem,3.6vw,2.2rem);align-items:stretch;z-index:1}.project-card__content{position:relative;z-index:1}.project-card__header{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1rem}.project-card__heading{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.project-card__title{margin:0;font-size:1.45rem}.project-card__badge{display:inline-flex;align-items:center;gap:.3rem;padding:.28rem .7rem;border-radius:var(--radius-small);background:color-mix(in srgb,var(--accent-safe) 20%,var(--color-surface-strong) 80%);color:color-mix(in srgb,var(--accent-safe) 80%,var(--color-text));font-size:.82rem;font-weight:700;letter-spacing:.04em;white-space:nowrap}.project-card__meta{color:color-mix(in srgb,var(--accent-safe) 70%,var(--color-text));font-weight:600;font-size:.96rem}.project-card p{color:color-mix(in srgb,var(--color-muted) 92%,transparent);line-height:1.74;margin:0 0 1.3rem}.project-card__highlights{margin:0;padding-left:1.2rem;display:grid;gap:.42rem;color:var(--color-text)}.project-card__highlights li{line-height:1.62}.project-card__cta{display:inline-flex;align-items:center;gap:.35rem;margin-top:1.5rem;font-weight:600;color:var(--accent-safe)}.project-card__cta:after{content:"→";transition:transform var(--transition)}.project-card:hover .project-card__cta:after,.project-card:focus-visible .project-card__cta:after{transform:translate(4px)}.project-card__media{position:relative;border-radius:var(--radius-medium);background:color-mix(in srgb,var(--accent-safe) 15%,transparent);overflow:hidden;min-height:clamp(200px,24vw,260px);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent-safe) 20%,transparent)}.project-card__thumb{position:absolute;inset:0;border-radius:inherit;background:var(--project-image, linear-gradient(135deg, rgba(0, 113, 227, .35), rgba(0, 113, 227, .05)));filter:saturate(108%) contrast(102%);transition:transform .7s cubic-bezier(.22,1,.36,1)}.project-card:hover .project-card__thumb,.project-card:focus-visible .project-card__thumb{transform:scale(1.05) translateZ(0)}@media(max-width:1024px){.project-card{grid-template-columns:minmax(0,1fr);padding-left:clamp(2.6rem,7vw,3.6rem)}.project-card__body{grid-template-columns:minmax(0,1fr)}.project-card__media{min-height:clamp(200px,36vw,240px)}}@media(max-width:720px){.project-timeline{padding-left:clamp(1.8rem,7vw,2.6rem);gap:clamp(2.1rem,7vw,2.9rem)}.project-timeline:before{left:clamp(.9rem,5vw,1.5rem)}.project-card{gap:clamp(1.1rem,5vw,1.7rem);padding:clamp(1.5rem,6vw,2rem) clamp(1.4rem,6vw,2rem);padding-left:clamp(2rem,8vw,2.6rem)}.project-card__rail{left:clamp(1.1rem,5vw,1.8rem)}.project-card__timeline{flex-direction:row;align-items:center;gap:.75rem}.project-card__timeline:before{top:50%;transform:translateY(-50%);box-shadow:0 0 0 1px var(--color-border)}.project-card__timeline:after{display:none}.project-card__body{gap:1.4rem}.project-card__media{min-height:clamp(180px,52vw,220px)}}@media(max-width:540px){.project-card{padding:clamp(1.3rem,6.5vw,1.7rem) clamp(1.1rem,6vw,1.5rem);padding-left:clamp(1.4rem,6.5vw,1.8rem);border-radius:1.6rem;gap:clamp(1rem,5.5vw,1.4rem)}.project-card__time{font-size:.95rem}.project-card__tag{font-size:.88rem}.project-card__body{gap:1.25rem}.project-card__media{min-height:clamp(150px,56vw,200px)}.project-card__highlights{gap:.5rem}.project-timeline{padding-left:0;gap:clamp(1.8rem,8vw,2.4rem)}.project-timeline:before{display:none}.project-card__rail{display:none}.project-card__timeline{padding-left:0;justify-content:flex-start;gap:.55rem}.project-card__timeline:before{position:static;transform:none;margin-right:.4rem;width:.65rem;height:.65rem;box-shadow:none}}.project-card[data-hidden=true]{display:none}.contact{text-align:center}.contact .section__header{margin-left:auto;margin-right:auto;text-align:center}.section--accent .section__header,.section--accent .contact__actions{position:relative;z-index:1}.section--accent .section__eyebrow{color:color-mix(in srgb,var(--color-text) 70%,transparent)}.section--accent .section__title{color:var(--color-text)}.section--accent .section__subtitle{color:var(--color-muted)}.contact__actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:2rem}.section--accent .btn--primary{box-shadow:0 24px 60px #0071e342}.section--accent .btn--ghost{background:color-mix(in srgb,var(--color-surface) 88%,transparent);border:1px solid var(--color-border);color:color-mix(in srgb,var(--color-text) 85%,transparent)}.section--accent .btn--ghost:hover,.section--accent .btn--ghost:focus{background:color-mix(in srgb,var(--color-primary-soft) 40%,var(--color-surface))}.site-footer{padding:2rem 0 3rem;text-align:center;color:var(--color-muted)}.back-to-top{position:fixed;right:1.5rem;bottom:1.5rem;width:3.2rem;height:3.2rem;border-radius:var(--radius-medium);border:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface-strong) 90%,transparent);color:var(--color-text);display:grid;place-items:center;font-size:1.2rem;cursor:pointer;box-shadow:0 18px 45px #11111324;opacity:0;visibility:hidden;transform:translateY(20px);transition:opacity var(--transition),transform var(--transition),visibility var(--transition)}.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover,.back-to-top:focus-visible{background:var(--color-primary);color:#fff;border-color:transparent}.project-hero{padding-top:clamp(4rem,8vw,6rem);position:relative;overflow:hidden}.project-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,113,227,.12),transparent 55%),radial-gradient(circle at 20% 20%,rgba(255,255,255,.55),transparent 65%);z-index:-1;opacity:.9;pointer-events:none}.project-hero .section__eyebrow{margin-bottom:1rem}.project-hero__content{display:grid;gap:1.5rem}.project-breadcrumb{display:inline-flex;align-items:center;gap:.4rem;color:var(--color-muted);font-size:.95rem}.project-breadcrumb a{color:var(--color-primary);text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.project-hero__title{font-size:clamp(2rem,6vw,3rem);margin:0}.project-hero__meta{color:var(--color-primary);font-weight:600}.project-hero__description{margin:0;color:var(--color-muted);line-height:1.8}.project-hero__tags{display:flex;flex-wrap:wrap;gap:.6rem;margin:0;padding:0;list-style:none}.project-hero__tags li{background:color-mix(in srgb,var(--color-surface) 90%,transparent);color:color-mix(in srgb,var(--color-text) 85%,transparent);padding:.35rem .8rem;border-radius:var(--radius-small);border:1px solid var(--color-border);font-size:.9rem;font-weight:600;backdrop-filter:var(--frost-blur)}.project-detail{padding-top:clamp(2rem,6vw,3rem);position:relative;overflow:hidden}.project-detail:before{content:"";position:absolute;inset:0;background:linear-gradient(140deg,rgba(0,0,0,.04),transparent 55%);z-index:-1;pointer-events:none}.project-detail__grid{display:grid;gap:clamp(2rem,5vw,3rem);grid-template-columns:minmax(0,2fr) minmax(0,1fr);align-items:start}.project-detail__main{display:grid;gap:2.5rem}.project-section{display:grid;gap:1rem}.project-section h2{margin:0;font-size:1.5rem}.project-section p{margin:0;line-height:1.8;color:var(--color-text)}.project-section ul{margin:0;padding-left:1.2rem;display:grid;gap:.6rem;line-height:1.7;color:var(--color-text)}.project-sidebar{display:grid;gap:1.5rem}.info-card{position:relative;padding:1.8rem;border-radius:var(--radius-medium);background:color-mix(in srgb,var(--color-surface-strong) 94%,transparent);border:1px solid var(--color-border);box-shadow:0 20px 50px #11111324;display:grid;gap:1rem;overflow:hidden;backdrop-filter:var(--frost-blur)}.info-card>*{position:relative;z-index:1}.info-card:after{display:none}.info-card h3{margin:0;font-size:1.15rem}.info-card dl{margin:0;display:grid;gap:.6rem}.info-card dt{font-weight:600;color:var(--color-muted);font-size:.9rem}.info-card dd{margin:0;font-weight:600;color:var(--color-text)}.info-card ul{margin:0;padding-left:1.2rem;display:grid;gap:.4rem;color:var(--color-text)}.project-cta{padding-top:clamp(2rem,6vw,3rem);position:relative;overflow:hidden}.project-cta__content{text-align:center;display:grid;gap:1rem;position:relative;z-index:1}.project-cta:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#0071e326,#0000000a);opacity:.85;z-index:0;pointer-events:none}.project-cta__actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:1rem}@media(max-width:960px){.project-detail__grid{grid-template-columns:1fr}.project-sidebar{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media(max-width:640px){.project-hero__tags{gap:.4rem}.info-card{padding:1.4rem}}@media(max-width:768px){.site-nav{display:none}.theme-toggle{padding:.45rem .6rem;border-radius:999px}.theme-toggle__label{display:none}.project-card{padding:1.75rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}[data-animate]{opacity:1!important;transform:none!important;filter:none!important}}@media(max-width:720px){.container{width:min(1160px,95vw);padding-inline:clamp(1.5rem,5vw,2.5rem)}.about-list{border:none!important;background:transparent!important;box-shadow:none!important;border-radius:0!important}.about-item{padding:clamp(1rem,4vw,1.4rem) clamp(.8rem,3.5vw,1rem)!important}.about-item__header{border-bottom:none!important;padding-bottom:0!important}}@media(max-width:540px){.project-card{border:none!important;background:transparent!important;box-shadow:none!important;padding:clamp(1rem,5vw,1.4rem) 0!important;padding-left:0!important;border-radius:0!important}.project-card__media{border-radius:1rem!important;box-shadow:none!important}.filter-controls{border:none!important;background:transparent!important;box-shadow:none!important;padding:0!important;margin-left:0!important;margin-right:0!important}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
