@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Sora:wght@500;600;700&display=swap";:root{color:#4b5b78;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--heading-color:#132344;--muted:#586987;--subtle:#7f8ea9;--accent:#2f79ff;--display:"Syne", sans-serif;--shadow-card:0 20px 56px #7599d629;--shadow-soft:0 10px 28px #8bace61f;background:radial-gradient(circle at 0 0,#fff 0%,#f4f9ff 42%,#eef5ff 100%);font-family:Manrope,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100vh;margin:0}body:before{content:"";pointer-events:none;background:linear-gradient(120deg,#ffffff70,#0000 32%),radial-gradient(circle at 80% 20%,#72acff24,#0000 18%);position:fixed;inset:0}a{color:inherit}img{max-width:100%;display:block}h1,h2,h3,p{margin:0}h1,h2,h3{color:var(--heading-color);font-family:var(--display);line-height:1.05}h1{letter-spacing:-.04em;font-size:clamp(2.35rem,6.2vw,4.35rem)}h2{letter-spacing:-.03em;font-size:clamp(1.5rem,3.4vw,2.2rem)}h3{font-size:1.12rem}#root{min-height:100vh}.site-shell{min-height:100vh;position:relative}.scene-background{z-index:0;pointer-events:none;opacity:1;position:fixed;inset:0}.scene-background--fallback{background:radial-gradient(circle at 20% 20%,#6ca6ff2e,#0000 22%),radial-gradient(circle at 78% 18%,#4881ff1f,#0000 18%),linear-gradient(#fffc,#f4f9ffb8)}.site-header,.page-shell{z-index:1;position:relative}.site-header{justify-content:space-between;align-items:center;width:min(1040px,100% - 56px);margin:0 auto;padding:18px 0 0;display:flex}.brand{width:48px;height:48px;color:var(--heading-color);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-family:var(--display);background:#ffffff70;border:1px solid #6294ff24;border-radius:14px;place-items:center;font-size:1.05rem;text-decoration:none;display:grid;overflow:hidden}.brand__image{object-fit:cover;width:100%;height:100%;display:block}.site-nav{box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff6b;border:1px solid #6294ff24;border-radius:999px;gap:8px;padding:6px;display:flex}.site-nav__link{color:var(--muted);border-radius:999px;padding:8px 14px;text-decoration:none;transition:color .16s,background .16s,transform .16s}.site-nav__link:hover,.site-nav__link.is-active{color:var(--heading-color);background:#407eff1a;transform:translateY(-1px)}.page-shell{width:min(1040px,100% - 56px);margin:0 auto;padding:20px 0 56px}.page-stack{gap:34px;display:grid}.hero-section,.about-hero,.project-detail-hero,.content-section,.page-intro{box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#ffffff94,#f5f9ff4d);border:1px solid #5487ff1c;border-radius:28px;position:relative;overflow:hidden}.hero-section,.about-hero,.project-detail-hero{grid-template-columns:1.2fr .8fr;gap:20px;padding:28px;display:grid}.about-hero{grid-template-columns:minmax(280px,.9fr) minmax(0,1.9fr);align-items:start}.hero-copy,.project-detail-hero__copy{align-content:center;gap:14px;display:grid}.hero-copy h1{white-space:pre-line;font-size:clamp(2rem,4.8vw,3.5rem)}.projects-intro__title{font-size:clamp(1.35rem,3vw,2.2rem);line-height:1.16}.project-detail-hero__title{font-size:clamp(1.25rem,2.7vw,2.05rem);line-height:1.12}.about-page-hero{justify-content:space-between;align-items:center;gap:24px;display:flex}.about-page-hero__copy{gap:8px;display:grid}.about-page-hero h1{font-size:clamp(2rem,5vw,3.4rem)}.about-page-hero__image{aspect-ratio:1;object-fit:cover;width:clamp(110px,18vw,180px);box-shadow:var(--shadow-soft);border:1px solid #5487ff24;border-radius:24px}.hero-lead,.page-intro p,.content-card p,.project-detail-hero__copy p{color:var(--muted);font-size:.98rem;line-height:1.72}.hero-actions,.contact-row,.chip-row,.project-card__meta,.project-summary-grid{flex-wrap:wrap;gap:12px;display:flex}.button-link,.button-link--ghost,.text-link{justify-content:center;align-items:center;text-decoration:none;transition:transform .18s,box-shadow .18s,background .18s;display:inline-flex}.button-link{color:#fff;background:linear-gradient(135deg,#327cff,#77b4ff);border-radius:999px;padding:12px 18px;box-shadow:0 12px 28px #4a82ff2e}.button-link--ghost{color:var(--heading-color);background:#ffffff57;border:1px solid #4c80ff1f}.button-link:hover,.button-link--ghost:hover,.text-link:hover{transform:translateY(-2px)}.text-link{color:var(--accent);font-weight:600}.profile-card,.content-card,.project-card,.hobby-card{box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff75;border:1px solid #5487ff1c;border-radius:24px}.profile-card{align-content:start;gap:16px;padding:16px;display:grid}.profile-card--hero{align-content:center}.about-hero__profile{gap:14px}.about-hero__profile img{aspect-ratio:1/.92}.about-hero__profile h1{font-size:clamp(1.6rem,2.6vw,2.6rem);line-height:.98}.about-hero__intro{align-self:start;min-height:0}.profile-card img{aspect-ratio:1;object-fit:cover;background:linear-gradient(145deg,#eff6ff,#cfe1ff);border-radius:20px;width:100%}.profile-card__body{gap:8px;display:grid}.section-eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-size:.72rem;font-weight:700}.section-heading{gap:4px;margin-bottom:20px;display:grid}.section-heading--split{justify-content:space-between;align-items:end;gap:16px;display:flex}.content-section,.page-intro{padding:26px}.skill-matrix,.project-grid,.hobby-grid,.detail-sections{gap:16px;display:grid}.skill-matrix{grid-template-columns:repeat(3,minmax(0,1fr))}.skill-panel,.content-card{padding:20px}.skill-list{gap:14px;margin-top:14px;display:grid}.skill-item{justify-content:space-between;align-items:center;gap:12px;display:flex}.skill-item__name{color:var(--heading-color);font-weight:600}.skill-item__meta,.timeline-item__period,.timeline-item__org,.project-card__meta{color:var(--subtle);font-size:.88rem}.skill-dots{gap:8px;display:flex}.skill-dots__dot{background:#437eff1f;border:1px solid #437eff14;border-radius:999px;width:10px;height:10px}.skill-dots__dot.is-filled{background:linear-gradient(#7ab3ff,#357dff);border-color:#357dff66;box-shadow:0 0 18px #3f7eff33}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-card{overflow:hidden}.project-card__visual,.detail-visual{color:#1d4ca3e0;font-family:var(--display);letter-spacing:.06em;background:radial-gradient(circle at 0 0,#4583ff3d,#0000 40%),linear-gradient(135deg,#ebf4ff8f,#d2e3ff57);place-items:center;font-size:clamp(1.45rem,3.2vw,2.4rem);display:grid}.project-card__visual{aspect-ratio:16/9;min-height:0;overflow:hidden}.detail-visual{background:0 0;min-height:260px;overflow:hidden}.project-card__visual img{object-fit:cover;object-position:center;width:100%;height:100%}.detail-visual img{object-fit:contain;object-position:center;width:100%;height:100%}.project-card__body{gap:12px;padding:20px;display:grid}.project-card__points,.detail-list{color:var(--muted);margin:0;padding-left:1.1rem;line-height:1.65}.project-card__points{font-size:.9rem}.detail-list--compact{font-size:.9rem;line-height:1.6}.project-card h3,.timeline-item h3{margin:0}.chip{color:var(--heading-color);background:#3e7aff0d;border:1px solid #3e7aff1a;border-radius:999px;padding:8px 12px;font-size:.88rem}.timeline{gap:14px;display:grid}.timeline-item{background:#ffffff6b;border:1px solid #5487ff1a;border-radius:22px;grid-template-columns:72px 1fr;gap:16px;padding:18px;display:grid}.timeline-item__badge{height:fit-content;color:var(--accent);text-align:center;background:#3e7aff0d;border-radius:999px;padding:9px 10px;font-size:.8rem;font-weight:700}.timeline-item__body{gap:6px;display:grid}.hobby-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.cert-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.cert-card{align-content:start;gap:10px;display:grid}.hobby-card{min-height:96px;color:var(--heading-color);align-content:start;gap:12px;padding:18px;font-weight:600;display:grid}.project-summary-grid{margin-top:8px}.project-summary-grid .content-card,.content-card--detail{flex:280px}.detail-sections{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-visual{border-radius:28px;min-height:100%}.site-footer{z-index:1;width:min(1040px,100% - 56px);margin:0 auto 24px;position:relative}.site-footer__inner{box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#ffffff80,#f5f9ff47);border:1px solid #5487ff1c;border-radius:24px;justify-content:space-between;align-items:center;gap:18px;padding:18px 22px;display:flex}.site-footer__copy{gap:6px;display:grid}.site-footer__copy p{color:var(--heading-color);font-family:var(--display);font-size:1rem}.site-footer__links{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.site-footer__link{color:var(--heading-color);background:#ffffff70;border:1px solid #5487ff1a;border-radius:999px;align-items:center;gap:10px;padding:10px 14px;text-decoration:none;transition:transform .18s,background .18s,border-color .18s;display:inline-flex}.site-footer__link:hover{background:#ffffff9e;border-color:#5487ff2e;transform:translateY(-2px)}.site-footer__icon{width:18px;height:18px;color:var(--accent);justify-content:center;align-items:center;display:inline-flex}.site-footer__icon svg{width:100%;height:100%;display:block}.site-footer__label{font-size:.9rem;font-weight:600}@media (width<=960px){.hero-section,.about-hero,.project-detail-hero,.skill-matrix,.project-grid,.hobby-grid,.cert-grid,.detail-sections{grid-template-columns:1fr}.site-header,.page-shell,.site-footer{width:min(100% - 24px,1040px)}.site-header{flex-direction:column;align-items:stretch;gap:14px}.site-nav{justify-content:space-between}.section-heading--split{justify-content:start;display:grid}.site-footer__inner{flex-direction:column;align-items:start}.site-footer__links{justify-content:start}}@media (width<=640px){.site-header{padding-top:16px}.site-nav{overflow-x:auto}.about-page-hero{flex-direction:column;align-items:start}.hero-section,.about-hero,.project-detail-hero,.content-section,.page-intro{border-radius:22px;padding:20px}.project-card__body,.content-card,.skill-panel,.timeline-item,.hobby-card{padding:16px}.timeline-item{grid-template-columns:1fr}}
