@font-face{font-family:Josefin;src:url(/assets/JosefinSans-VariableFont_wght.ttf);font-display:swap}*,*:before,*:after{box-sizing:border-box}:root{color-scheme:dark;--bg: #071923;--panel: #07292f;--panel-strong: #06313d;--surface: #032f3c;--text: #e6fcff;--muted: #9fd6ec;--line: rgba(159, 214, 236, .2);--accent: #6fe6ff;--accent-2: #9befff;--ink: #002b36;--shadow: 0 14px 36px rgba(0, 0, 0, .45)}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:linear-gradient(180deg,#06151f 0%,var(--bg) 46%,#04141c 100%);color:var(--text);font-family:Josefin,Inter,system-ui,sans-serif}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-2;background:linear-gradient(rgba(159,214,236,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(159,214,236,.045) 1px,transparent 1px),radial-gradient(circle at 1px 1px,rgba(111,230,255,.1) 1px,transparent 1.6px);background-size:52px 52px,52px 52px,104px 104px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.78),rgba(0,0,0,.38) 60%,transparent 100%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.78),rgba(0,0,0,.38) 60%,transparent 100%)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:repeating-linear-gradient(90deg,transparent 0 38px,rgba(111,230,255,.05) 38px 74px,transparent 74px 112px),repeating-linear-gradient(0deg,transparent 0 46px,rgba(159,214,236,.035) 46px 48px,transparent 48px 142px),linear-gradient(90deg,transparent 0 12%,rgba(111,230,255,.055) 12% 12.2%,transparent 12.2% 100%),linear-gradient(90deg,transparent 0 83%,rgba(159,214,236,.05) 83% 83.2%,transparent 83.2% 100%);background-size:380px 220px,460px 260px,100% 100%,100% 100%;opacity:.58;-webkit-mask-image:linear-gradient(to right,transparent 0,rgba(0,0,0,.8) 12%,rgba(0,0,0,.76) 88%,transparent 100%),linear-gradient(to bottom,rgba(0,0,0,.64),rgba(0,0,0,.28) 70%,transparent 100%);mask-image:linear-gradient(to right,transparent 0,rgba(0,0,0,.8) 12%,rgba(0,0,0,.76) 88%,transparent 100%),linear-gradient(to bottom,rgba(0,0,0,.64),rgba(0,0,0,.28) 70%,transparent 100%);-webkit-mask-composite:source-in;mask-composite:intersect}#root{isolation:isolate;position:relative}a{color:inherit;text-decoration:none}button{font:inherit}img{max-width:100%}main{width:min(1160px,calc(100% - 32px));margin:0 auto}.site-header{position:sticky;top:10px;z-index:10;width:min(1180px,calc(100% - 28px));min-height:68px;margin:10px auto 0;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#032f3cdb;box-shadow:0 10px 40px #0000003d;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{display:inline-flex;align-items:center;gap:12px;min-width:0;font-weight:700}.brand img{width:44px;height:44px;border-radius:8px;object-fit:cover;border:1px solid var(--line)}.nav-links{display:flex;justify-content:center;gap:8px}.nav-links a,.icon-button,.social-strip a{min-width:42px;min-height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid transparent;color:var(--muted);transition:.16s ease}.nav-links a{padding:0 14px}.nav-links a:hover,.nav-links a.active,.icon-button:hover,.social-strip a:hover{color:var(--text);border-color:var(--line);background:#ffffff0f}.social-strip{display:flex;align-items:center;gap:4px}.social-strip img{width:22px;height:22px;object-fit:contain;filter:brightness(0) invert(1)}.quick-link svg,.button svg{color:currentColor}.icon-button{display:none;background:transparent;cursor:pointer}.hero{min-height:auto;padding:30px 0 18px}.hero-copy{display:grid;grid-template-columns:minmax(0,1fr) clamp(240px,25vw,340px);align-items:center;column-gap:clamp(24px,4vw,56px)}.hero-avatar{width:clamp(240px,25vw,340px);aspect-ratio:1;grid-column:2;grid-row:1;align-self:center;justify-self:center;padding:7px;border-radius:50%;object-fit:cover;border:1px solid rgba(155,239,255,.28);background:linear-gradient(var(--panel),var(--panel)) padding-box,linear-gradient(135deg,#9befffb8,#6fb7d82e,#cfeffb7a) border-box;box-shadow:0 18px 44px #00000047;transform:translateY(-6px)}.hero-content{min-width:0;max-width:760px}.hero-title-row{display:block;margin:18px 0 12px}.hero-copy h1{max-width:720px;margin:0;font-size:clamp(4rem,15vw,6rem);line-height:.82;letter-spacing:0}.hero-text{max-width:650px;margin:0 0 18px;color:#dff8ff;font-size:clamp(1.15rem,2vw,1.45rem);line-height:1.48}.eyebrow{display:inline-flex;align-items:center;gap:8px;margin:0;color:var(--accent);font-weight:700;text-transform:uppercase;font-size:.8rem}.hero-actions,.quick-links,.meta-row{display:flex;flex-wrap:wrap;gap:10px}.button,.quick-link,.back-link{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:44px;border-radius:8px;transition:.16s ease}.button{padding:0 18px;font-weight:800}.button.primary{background:var(--accent);color:var(--ink)}.button.secondary,.quick-link{border:1px solid var(--line);background:#ffffff09;color:var(--text)}.button:hover,.quick-link:hover,.back-link:hover{transform:translateY(-2px);border-color:#9befff8c}.intro-panel,.project-group,.detail-shell,.resume-shell,.loading{position:relative;border:1px solid var(--line);border-radius:8px;background:#07292fdb;box-shadow:var(--shadow)}.intro-panel{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,340px);gap:32px;padding:32px;margin-top:12px}.intro-panel>div:first-child{max-width:820px}.intro-panel h2,.section-heading h2,.detail-header h1,.resume-hero h1{margin:8px 0 10px;font-size:clamp(2rem,6vw,4rem);letter-spacing:0}.intro-panel p,.article-flow p,.resume-section p,.timeline p{color:#cfeffb;font-size:1.05rem;line-height:1.65}.intro-panel a:not(.quick-link),.article-flow a{color:var(--accent);font-weight:700}.quick-links{display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));align-self:start;margin-top:98px}.quick-link{padding:0 14px}.projects-section{padding:72px 0 32px}.section-heading{margin-bottom:24px}.project-group{padding:24px;margin-bottom:22px}.project-group-heading{display:flex;justify-content:space-between;gap:24px;margin-bottom:20px;border-bottom:1px solid var(--line);padding-bottom:16px}.project-group-heading h3{margin:0;font-size:1.65rem}.project-group-heading p{max-width:520px;margin:0;color:var(--muted)}.project-grid{display:grid;grid-template-columns:repeat(var(--project-columns, 4),minmax(0,1fr));gap:16px}.project-card{position:relative;min-height:100%;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:8px;background:var(--panel-strong);color:inherit;cursor:pointer;transition:.18s ease}.project-card:hover{transform:translateY(-5px);border-color:#9befff8c}.project-card img{width:100%;aspect-ratio:16 / 10;object-fit:cover;background:#0a0f14}.project-body{display:flex;flex:1;flex-direction:column;padding:16px}.project-card-top{display:flex;justify-content:space-between;gap:8px;color:var(--muted);text-transform:uppercase;font-size:.72rem;font-weight:800}.project-card-top p{margin:0;color:var(--accent-2)}.project-card h3{margin:12px 0 8px;font-size:1.35rem}.project-card p{color:#cfeffb;line-height:1.45}.stretched-link{display:flex;align-items:center;gap:8px;margin:0 16px 16px;color:var(--accent);font-weight:800}.hero-feature .project-card{transform:rotate(1.5deg)}.hero-feature .project-card:hover{transform:translateY(-5px) rotate(0)}.detail-shell,.resume-shell,.loading{margin:42px auto;padding:32px}.back-link{width:fit-content;color:var(--muted);margin-bottom:22px}.detail-header{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,460px);gap:34px;align-items:start}.detail-title-row{display:flex;align-items:center;gap:14px;margin:8px 0 10px}.detail-title-row h1{margin:0}.github-title-link{width:46px;height:46px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px;color:var(--text);background:#ffffff09;transition:.16s ease}.github-title-link:hover{transform:translateY(-2px);border-color:#9befff8c}.meta-row{margin:20px 0}.meta-row span,.feature-list span{padding:7px 10px;border-radius:8px;color:var(--text);border:1px solid var(--line);background:#ffffff09;font-weight:700}.button.inline{width:fit-content}.article-flow{max-width:880px;margin-top:34px}.detail-copy .article-flow{margin-top:24px}.feature-list,.project-gallery{margin-top:34px}.feature-list.compact{margin:0 0 20px}.feature-list h2,.resume-section h2{margin:0 0 16px}.feature-list.compact h2{margin-bottom:10px;color:var(--muted);font-size:.86rem;text-transform:uppercase}.feature-list div{display:flex;flex-wrap:wrap;gap:10px}.project-gallery{margin-top:0;min-width:0}.gallery-stage{position:relative;overflow:hidden;border-radius:8px;border:1px solid var(--line);background:#041821}.gallery-zoom-trigger{width:100%;display:block;padding:0;border:0;background:transparent;color:var(--text);cursor:zoom-in}.gallery-zoom-trigger>img{width:100%;aspect-ratio:16 / 10;display:block;object-fit:cover}.gallery-zoom-trigger span{position:absolute;right:12px;bottom:12px;display:inline-flex;align-items:center;gap:7px;min-height:36px;padding:0 11px;border:1px solid var(--line);border-radius:8px;background:#032f3cd1;font-weight:800}.gallery-control{position:absolute;top:50%;z-index:1;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px;background:#032f3cd1;color:var(--text);cursor:pointer;transform:translateY(-50%);transition:.16s ease}.gallery-control:hover{background:#07292ff2;border-color:#9befff8c}.gallery-control.previous{left:12px}.gallery-control.next{right:12px}.gallery-strip{display:flex;gap:10px;margin-top:12px;padding-bottom:4px;overflow-x:auto;scrollbar-color:var(--muted) transparent}.gallery-strip button{width:96px;aspect-ratio:16 / 10;flex:0 0 auto;overflow:hidden;padding:0;border:1px solid var(--line);border-radius:8px;background:var(--surface);cursor:pointer;opacity:.62;transition:.16s ease}.gallery-strip button:hover,.gallery-strip button.active{opacity:1;border-color:#9befffb8}.gallery-strip img{width:100%;height:100%;display:block;object-fit:cover}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;grid-template-rows:auto 1fr;padding:18px;background:#040e14e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.lightbox-toolbar{justify-self:center;display:inline-flex;align-items:center;gap:6px;margin-bottom:14px;padding:6px;border:1px solid var(--line);border-radius:8px;background:#032f3ce6}.lightbox-toolbar button{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text);cursor:pointer}.lightbox-toolbar button:hover{border-color:var(--line);background:#ffffff0f}.lightbox-toolbar span{min-width:58px;text-align:center;color:var(--muted);font-weight:800}.lightbox-stage{position:relative;overflow:auto;display:grid;place-items:center;border-radius:8px;cursor:zoom-out}.lightbox-stage img{grid-area:1 / 1;max-width:min(100%,1200px);max-height:100%;border-radius:8px;transform-origin:center;transition:transform .14s ease;cursor:default}.lightbox-control{position:sticky;top:50%;z-index:2;width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;grid-area:1 / 1;border:1px solid var(--line);border-radius:8px;background:#032f3ce6;color:var(--text);cursor:pointer;transform:translateY(-50%);transition:.16s ease}.lightbox-control:hover{background:#07292ff5;border-color:#9befff9e}.lightbox-control.previous{left:18px;justify-self:start}.lightbox-control.next{right:18px;justify-self:end}.lightbox-count{padding:0 8px}.resume-hero{display:grid;grid-template-columns:116px 1fr auto;gap:24px;align-items:center;padding-bottom:24px;border-bottom:1px solid var(--line)}.resume-hero img{width:116px;height:116px;border-radius:8px;object-fit:cover;border:1px solid var(--line)}.resume-hero p{margin:0;color:#dff8ff;font-weight:700}.language-switch{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--line);border-radius:8px}.language-switch button{min-width:44px;min-height:38px;border:0;border-radius:6px;color:var(--muted);background:transparent;cursor:pointer}.language-switch button.active{color:var(--ink);background:var(--accent);font-weight:800}.resume-contact{display:flex;flex-wrap:wrap;gap:10px;margin:24px 0 34px}.resume-contact a,.resume-contact span{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:0 12px;border:1px solid var(--line);border-radius:8px;color:#dff8ff}.resume-section{padding:26px 0;border-top:1px solid var(--line)}.resume-section h2{display:flex;align-items:center;gap:10px;color:var(--accent)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.skill-card,.timeline article{border:1px solid var(--line);border-radius:8px;padding:16px;background:#ffffff09}.skill-card h3,.timeline h3{margin:0 0 8px}.skill-card p,.timeline p{margin:0}.timeline{display:grid;gap:14px}footer{width:min(1160px,calc(100% - 32px));margin:0 auto;padding:28px 0 40px;display:flex;justify-content:space-between;gap:16px;color:var(--muted)}footer a{color:var(--accent)}@media(max-width:860px){.site-header{grid-template-columns:auto auto}.nav-toggle{display:inline-flex;justify-self:end}.nav-links,.social-strip{display:none}.nav-links.open{grid-column:1 / -1;display:grid;grid-template-columns:1fr;justify-content:stretch}.nav-links.open a{justify-content:flex-start}.intro-panel,.detail-header,.resume-hero{grid-template-columns:1fr}.hero{min-height:auto;padding-top:34px}.hero-avatar{width:clamp(220px,34vw,300px);transform:translateY(6px)}.hero-title-row{display:block}.quick-links{margin-top:0;max-width:420px}.project-grid{grid-template-columns:repeat(auto-fit,minmax(min(220px,100%),1fr))}.resume-hero{text-align:left}}@media(max-width:560px){main,footer{width:min(100% - 22px,1160px)}.site-header{top:8px;width:calc(100% - 16px);margin-top:8px}.brand span{max-width:145px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero-copy h1{font-size:clamp(3.6rem,24vw,6rem)}.hero-title-row{display:block}.hero-avatar{grid-column:1;grid-row:1;width:min(72vw,250px);align-self:center;transform:none;margin-bottom:10px}.hero-content{grid-row:2}.hero-copy{grid-template-columns:1fr}.quick-links{grid-template-columns:1fr 1fr;max-width:none}.project-grid{grid-template-columns:1fr}.intro-panel,.project-group,.detail-shell,.resume-shell{padding:18px}.project-group-heading,footer{flex-direction:column}.resume-contact a,.resume-contact span{width:100%}.lightbox{padding:10px}.lightbox-toolbar{gap:3px;max-width:100%}.lightbox-toolbar button{width:36px;height:36px}.lightbox-toolbar span{min-width:48px}.lightbox-control{width:40px;height:40px}.lightbox-control.previous{left:8px}.lightbox-control.next{right:8px}}@media print{body{background:#fff;color:#111}body:before,.site-header,footer,.language-switch{display:none}main,.resume-shell{width:100%;margin:0;box-shadow:none;border:0}}
