:root{--color-ink:#071827;--color-navy:#08233a;--color-navy-2:#031522;--color-blue:#1f7ae0;--color-blue-soft:#d8eaff;--color-violet:#7c4dff;--color-cyan:#36d6d9;--color-bg:#f7f9fc;--color-surface:#fff;--color-surface-muted:#eef3f8;--color-text:#132033;--color-text-muted:#667085;--color-border:#d8e0ea;--shadow-soft:0 18px 55px #0718271f;--shadow-card:0 12px 35px #07182714;--radius-lg:28px;--radius-md:18px;--container:1160px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{color:var(--color-text);background:var(--color-bg);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.65}body.menu-open{overflow:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}main{overflow:hidden}:focus-visible{outline:3px solid var(--color-cyan);outline-offset:3px}.container{width:min(100% - 40px, var(--container));margin-inline:auto}.container.narrow{width:min(100% - 40px,820px)}.section{background:var(--color-surface);padding:96px 0}.section.light{background:var(--color-bg)}.section.dark{background:linear-gradient(135deg, var(--color-navy-2), var(--color-navy));color:#fff}.section.compact{padding:24px 0}.site-header{z-index:50;height:72px;padding:0 max(20px, calc((100vw - var(--container)) / 2));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#f7f9fce0;border-bottom:1px solid #d8e0eab8;justify-content:space-between;align-items:center;gap:24px;display:flex;position:sticky;top:0}.site-header.is-scrolled{box-shadow:0 10px 30px #07182714}.brand{letter-spacing:-.02em;align-items:center;gap:12px;font-weight:800;display:inline-flex}.brand-mark{color:#fff;background:linear-gradient(135deg, var(--color-blue), var(--color-violet));border-radius:14px;place-items:center;width:40px;height:40px;display:grid;box-shadow:0 10px 24px #1f7ae038}.desktop-nav{align-items:center;gap:8px;display:flex}.nav-link{color:var(--color-text-muted);border-radius:999px;padding:10px 12px;font-size:.95rem;font-weight:700}.nav-link:hover,.nav-link.active{color:var(--color-ink);background:#d8eaffb8}.menu-toggle,.mobile-menu{display:none}.hero,.page-hero{padding:112px 0 96px}.hero-gradient{color:#fff;background:radial-gradient(circle at 84% 22%, #36d6d95c, transparent 28%), radial-gradient(circle at 18% 28%, #7c4dff57, transparent 30%), linear-gradient(135deg, var(--color-navy-2), var(--color-navy) 50%, #0b4a7c)}.dark-hero{color:#fff;background:linear-gradient(135deg, var(--color-navy-2), var(--color-navy))}.light-hero{background:linear-gradient(135deg, #fff, var(--color-blue-soft))}.warm-hero{background:linear-gradient(135deg,#fff8ed,#edf7ff)}.hero-grid,.split-grid,.resume-hero-grid,.resume-detail-grid,.hobby-section{grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);align-items:center;gap:56px;display:grid}h1,h2,h3{color:inherit;letter-spacing:-.04em;margin:0;line-height:1.08}h1{font-size:clamp(2.7rem,7vw,4.8rem)}h2{font-size:clamp(2rem,4vw,3rem)}h3{font-size:1.25rem}p{margin:0}p+p{margin-top:16px}.hero-lede{color:inherit;opacity:.92;font-size:clamp(1.15rem,2vw,1.45rem)}.eyebrow{color:var(--color-blue);letter-spacing:.16em;text-transform:uppercase;margin:0 0 12px;font-size:.78rem;font-weight:850}.dark .eyebrow,.hero .eyebrow,.dark-hero .eyebrow,.section-header.invert .eyebrow{color:var(--color-cyan)}.button-row{flex-wrap:wrap;gap:14px;margin-top:28px;display:flex}.button{border:1px solid #0000;border-radius:14px;justify-content:center;align-items:center;min-height:46px;padding:12px 18px;font-weight:800;transition:transform .18s,box-shadow .18s,border-color .18s;display:inline-flex}.button:hover{transform:translateY(-2px)}.button.primary{color:#fff;background:linear-gradient(135deg, var(--color-blue), var(--color-violet));box-shadow:0 14px 28px #1f7ae038}.button.secondary{color:var(--color-ink);border-color:var(--color-border);background:#fff}.button.secondary.on-dark{color:#fff;background:#ffffff14;border-color:#ffffff47}.hero-visual{position:relative}.hero-visual:before{content:"";opacity:.46;background-image:radial-gradient(#ffffff47 1.2px,#0000 1.2px);background-size:18px 18px;position:absolute;inset:-28px}.avatar-card{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff1f;border:1px solid #ffffff38;padding:28px;position:relative;box-shadow:0 30px 80px #00000038}.avatar-placeholder{aspect-ratio:4/5;color:var(--color-navy);background:linear-gradient(145deg,#fffffff2,#d8eaffc7);border-radius:24px;place-items:center;margin-bottom:18px;font-size:clamp(4rem,10vw,7rem);font-weight:900;display:grid}.section-header{max-width:760px;margin-bottom:34px}.section-header.align-center{text-align:center;margin-inline:auto}.section-header p:not(.eyebrow){color:var(--color-text-muted);font-size:1.06rem}.section-header.invert p:not(.eyebrow){color:#ffffffb8}.muted,.small-note{color:var(--color-text-muted)}.small-note{font-size:.9rem}.mini-card-grid,.project-grid,.skill-grid,.hobby-teaser-grid,.gallery-grid{gap:24px;display:grid}.mini-card-grid{grid-template-columns:1fr}.project-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.skill-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.hobby-teaser-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.gallery-grid{grid-template-columns:1fr}.mini-card,.skill-card,.project-card,.hobby-teaser,.gallery-card,.contact-card,.pdf-card,.timeline-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-card)}.mini-card,.skill-card,.contact-card,.pdf-card,.timeline-card{padding:24px}.mini-card p,.skill-card p,.project-card p,.hobby-teaser p,.timeline-card p{color:var(--color-text-muted)}.dark .skill-card{background:#ffffff14;border-color:#ffffff29}.light-card{background:var(--color-surface)}.project-card{scroll-margin-top:92px;transition:transform .18s,border-color .18s,box-shadow .18s;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-soft);border-color:#1f7ae05c;transform:translateY(-4px)}.project-card.featured{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);align-items:stretch;display:grid}.project-media{background:var(--color-surface-muted);display:block;overflow:hidden}.project-media img{object-fit:cover;width:100%;height:100%;min-height:220px;transition:transform .22s}.project-card:hover .project-media img{transform:scale(1.02)}.project-body{padding:24px}.card-meta{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.chip{min-height:28px;color:var(--color-navy);background:var(--color-blue-soft);border-radius:999px;align-items:center;margin-right:6px;padding:4px 10px;font-size:.78rem;font-weight:800;display:inline-flex}.chip.accent{color:#fff;background:linear-gradient(135deg, var(--color-blue), var(--color-violet))}.chip.muted{color:var(--color-text-muted);background:var(--color-surface-muted)}.project-detail-grid{gap:8px;margin-top:16px;display:grid}.highlight-list{color:var(--color-text-muted);margin:16px 0;padding-left:20px}.tag-list{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.tag-list span{background:var(--color-surface-muted);color:var(--color-text);border-radius:999px;align-items:center;padding:7px 10px;font-size:.86rem;font-weight:750;display:inline-flex}.dark .tag-list span{color:#fff;background:#ffffff1f}.text-link{color:var(--color-blue);margin-top:18px;font-weight:850;display:inline-flex}.hobby-teaser{transition:transform .18s,box-shadow .18s;overflow:hidden}.hobby-teaser:hover{box-shadow:var(--shadow-soft);transform:translateY(-4px)}.hobby-teaser img,.gallery-card img{aspect-ratio:16/10;object-fit:cover;width:100%}.hobby-teaser h3,.hobby-teaser p{margin:18px 20px 0}.hobby-teaser p{margin-bottom:22px}.page-hero h1{margin-bottom:16px}.page-hero p:not(.eyebrow){max-width:760px;color:inherit;opacity:.78;font-size:1.18rem}.filter-row{gap:10px;padding:4px 0 8px;display:flex;overflow-x:auto}.filter-row a{border:1px solid var(--color-border);color:var(--color-text-muted);background:#fff;border-radius:999px;flex:none;padding:10px 14px;font-weight:800}.filter-row a:hover{color:var(--color-ink);border-color:var(--color-blue)}.category-section{scroll-margin-top:92px}.empty-state{border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);background:#fff;padding:24px}.contact-card a{color:var(--color-blue);margin-top:10px;font-weight:800;display:block}.pdf-card{justify-content:space-between;align-items:center;gap:24px;display:flex}.timeline{gap:20px;display:grid;position:relative}.timeline-card{padding-left:34px;position:relative}.timeline-dot{background:var(--color-blue);width:10px;height:10px;box-shadow:0 0 0 6px var(--color-blue-soft);border-radius:50%;position:absolute;top:30px;left:16px}.timeline-card ul{color:var(--color-text-muted)}.resume-detail-grid{align-items:start}.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stacked-cards{gap:18px;display:grid}.hobby-section.reverse{grid-template-columns:minmax(320px,.95fr) minmax(0,1.05fr)}.hobby-section.reverse>:first-child{order:2}.large-tags span{border-radius:14px}.gallery-card{overflow:hidden}.gallery-card>div{padding:24px}.gallery-card p{color:var(--color-text-muted)}.footer{color:#fff;background:var(--color-navy-2);padding:80px 0 28px}.footer-grid{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:56px;display:grid}.footer p{color:#ffffffb8}.footer-links{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;display:grid}.footer-links a{color:#ffffffc7;margin-top:10px;display:block}.footer-links a:hover{color:#fff}.footer-bottom{color:#ffffff94;border-top:1px solid #ffffff1f;justify-content:space-between;gap:20px;margin-top:56px;padding-top:20px;font-size:.92rem;display:flex}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=1023px){.hero-grid,.split-grid,.resume-hero-grid,.resume-detail-grid,.hobby-section,.hobby-section.reverse{grid-template-columns:1fr;gap:36px}.hobby-section.reverse>:first-child{order:0}.project-grid.three,.skill-grid,.hobby-teaser-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-card.featured{grid-template-columns:1fr}}@media (width<=760px){.site-header{height:64px}.brand-name,.desktop-nav{display:none}.menu-toggle{border:1px solid var(--color-border);background:#fff;border-radius:14px;place-content:center;gap:4px;width:44px;height:44px;display:inline-grid}.menu-toggle span:not(.sr-only){background:var(--color-ink);border-radius:99px;width:20px;height:2px;display:block}.mobile-menu{border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-soft);background:#f7f9fcfa;gap:10px;padding:20px;transition:transform .18s;display:grid;position:fixed;inset:64px 0 auto;transform:translateY(-120%)}.mobile-menu.is-open{transform:translateY(0)}.mobile-nav-link{border-radius:14px;align-items:center;min-height:48px;padding:0 12px;font-weight:850;display:flex}.mobile-nav-link.active,.mobile-nav-link:hover{background:var(--color-blue-soft)}.mobile-menu-footer{border-top:1px solid var(--color-border);flex-wrap:wrap;gap:10px;padding-top:10px;display:flex}.mobile-menu-footer a{color:var(--color-blue);padding:8px 10px;font-weight:800}.hero,.page-hero{padding:76px 0 64px}.section{padding:64px 0}.project-grid.three,.skill-grid,.hobby-teaser-grid,.compact-grid{grid-template-columns:1fr}.button-row,.pdf-card,.footer-bottom{flex-direction:column;align-items:stretch}.button{width:100%}.footer-grid,.footer-links{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
