:root{--accent-hue:285;--accent:oklch(.78 .18 var(--accent-hue));--accent-soft:oklch(.78 .18 var(--accent-hue) / .18);--accent-glow:oklch(.78 .18 var(--accent-hue) / .35);--bg-0:#040613;--bg-1:#080b1e;--bg-2:#10132c;--line:#42456238;--line-strong:#5c608566;--text-0:#f5f1ea;--text-1:#cbc3b6;--text-2:#828598;--text-3:#5e617a;--serif:var(--font-serif,"Iowan Old Style", Georgia, serif);--sans:var(--font-sans,system-ui, -apple-system, sans-serif);--mono:var(--font-mono,ui-monospace, "SF Mono", Menlo, monospace);--max:1320px}@supports (color:lab(0% 0 0)){:root{--bg-0:lab(1.871% .900246 -6.03712);--bg-1:lab(3.45114% 2.22586 -12.0133);--bg-2:lab(6.71287% 5.06946 -17.6699);--line:lab(29.9186% 4.80408 -17.9622/.22);--line-strong:lab(41.428% 5.68184 -21.5795/.4);--text-0:lab(95.3886% .58049 3.77289);--text-1:lab(79.1727% 1.24216 7.60216);--text-2:lab(55.6733% 2.25773 -11.0128);--text-3:lab(41.6484% 3.34992 -14.5372)}}*{box-sizing:border-box}html,body{background:var(--bg-0);color:var(--text-0);font-family:var(--sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.005em;margin:0;padding:0;font-size:16px;line-height:1.55}body{background:radial-gradient(1200px 700px at 80% -10%, oklch(.32 .12 var(--accent-hue) / .22), transparent 60%), radial-gradient(900px 600px at -10% 30%, #00295238, transparent 60%), var(--bg-0);background-attachment:fixed}@supports (color:lab(0% 0 0)){body{background:radial-gradient(1200px 700px at 80% -10%, oklch(.32 .12 var(--accent-hue) / .22), transparent 60%), radial-gradient(900px 600px at -10% 30%, lab(15.7768% 1.05359 -33.2927/.22), transparent 60%), var(--bg-0)}}body:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle at 1px 1px,#989cbe0f 1px,#0000 0);background-image:radial-gradient(circle at 1px 1px,lab(64.7683% 4.0715 -18.2179/.06) 1px,#0000 0);background-size:28px 28px;position:fixed;inset:0}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:0}.mono{font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);font-size:.78rem}.app{z-index:1;position:relative}.topbar{z-index:30;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);background:#04061399;background:lab(1.871% .900246 -6.03712/.6);grid-template-columns:1fr auto;align-items:center;gap:24px;padding:18px 40px;display:grid;position:sticky;top:0}.topbar--detail{grid-template-columns:auto 1fr auto}.topbar__brand{font-family:var(--mono);align-items:center;gap:10px;font-size:.78rem;display:flex}.topbar__mark{background:linear-gradient(135deg, var(--accent), #0073d2);color:#05091c;color:lab(2.83153% 1.85607 -11.069);letter-spacing:0;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-weight:600;display:inline-flex}@supports (color:lab(0% 0 0)){.topbar__mark{background:linear-gradient(135deg, var(--accent), lab(46.3662% 2.61197 -66.5624))}}.topbar__sep{color:var(--text-3)}.topbar__name{color:var(--text-1)}.topbar__nav{justify-self:center;gap:28px;display:flex}.topbar__nav a{color:var(--text-1);font-size:.92rem;transition:color .2s}.topbar__nav a:hover{color:var(--text-0)}.topbar__right{justify-self:end}.topbar__crumb{color:var(--text-3);font-family:var(--mono);letter-spacing:.04em;justify-self:center;gap:8px;font-size:.78rem;display:flex}.topbar__crumb-cur{color:var(--text-1)}.langswitch{border:1px solid var(--line);border-radius:999px;align-items:center;gap:8px;padding:6px 12px;display:inline-flex}.langswitch button{font-family:var(--mono);letter-spacing:.06em;color:var(--text-2);padding:0 2px;font-size:.72rem}.langswitch button.is-on{color:var(--text-0)}.langswitch span{color:var(--text-3)}.hero{flex-direction:column;min-height:calc(100vh - 60px);padding:0 40px 80px;display:flex}.hero__grid{max-width:var(--max);flex:1;grid-template-rows:auto 1fr auto;grid-template-columns:1fr;align-items:center;width:100%;margin:0 auto;padding-top:60px;display:grid}.hero__meta{justify-content:space-between;align-items:center;margin-bottom:80px;display:flex}.hero__pill{border:1px solid var(--line);font-family:var(--mono);letter-spacing:.06em;color:var(--text-1);text-transform:uppercase;border-radius:999px;align-items:center;gap:10px;padding:8px 14px;font-size:.72rem;display:inline-flex}.hero__pill-dot{background:#45ba50;background:lab(67.3528% -50.581 42.6409);border-radius:50%;width:8px;height:8px;animation:2.4s ease-in-out infinite pulse;box-shadow:0 0 0 4px #45ba502e;box-shadow:0 0 0 4px lab(67.3528% -50.581 42.6409/.18)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hero__loc{color:var(--text-2)}.hero__title{text-align:left}.hero__role{font-family:var(--mono);color:var(--text-2);letter-spacing:.16em;margin-bottom:28px;font-size:.78rem}.hero__name{font-family:var(--serif);letter-spacing:-.04em;color:var(--text-0);margin:0;font-size:clamp(60px,11vw,120px);font-weight:400;line-height:.92}.hero__name>span{display:inline}.hero__name>span+span{margin-left:.18em}.hero__name-2 em{color:#0000;background:linear-gradient(120deg, var(--accent), #33a2ff);-webkit-background-clip:text;background-clip:text;font-style:italic}@supports (color:lab(0% 0 0)){.hero__name-2 em{background:linear-gradient(120deg, var(--accent), lab(64.0837% -3.35455 -66.9452))}}.hero__degree{font-family:var(--serif);color:var(--text-1);max-width:700px;margin-top:28px;font-size:clamp(20px,2vw,28px);font-style:italic;line-height:1.3}.hero__bottom{margin-top:80px}.hero__bottom-rule{background:var(--line);height:1px;margin-bottom:24px}.hero__bottom-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:60px;display:flex}.hero__quote{font-family:var(--serif);color:var(--text-1);max-width:580px;font-size:clamp(18px,1.6vw,22px);font-style:italic;line-height:1.4}.hero__scroll{border:1px solid var(--line);color:var(--text-1);border-radius:999px;align-items:center;gap:10px;padding:10px 16px;transition:all .2s;display:inline-flex}.hero__scroll:hover{border-color:var(--accent);color:var(--text-0)}.sec-head{margin-bottom:56px}.sec-head__row{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-2);align-items:center;gap:14px;margin-bottom:16px;font-size:.72rem;display:flex}.sec-head__index{color:var(--accent)}.sec-head__rule{background:var(--line);flex:1;max-width:80px;height:1px}.sec-head__kicker{color:var(--text-3)}.sec-head__title{font-family:var(--serif);letter-spacing:-.025em;color:var(--text-0);margin:0;font-size:clamp(40px,5vw,72px);font-weight:400;line-height:1}.about{max-width:var(--max);margin:0 auto;padding:80px 40px}.about__grid{grid-template-columns:320px 1fr;align-items:start;gap:64px;display:grid}.about__card{position:sticky;top:100px}.portrait{aspect-ratio:320/380;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;width:100%;position:relative;overflow:hidden}.portrait__svg{width:100%;height:100%;display:block}.portrait__corner{border:1px solid var(--accent);width:16px;height:16px;position:absolute}.portrait__corner--tl{border-bottom:0;border-right:0;top:8px;left:8px}.portrait__corner--tr{border-bottom:0;border-left:0;top:8px;right:8px}.portrait__corner--bl{border-top:0;border-right:0;bottom:8px;left:8px}.portrait__corner--br{border-top:0;border-left:0;bottom:8px;right:8px}.contact{border:1px solid var(--line);background:#080b1e66;background:lab(3.45114% 2.22586 -12.0133/.4);border-radius:14px;width:100%;margin-top:24px;padding:20px}.contact__title{color:var(--text-3);margin-bottom:14px}.contact__row{color:var(--text-1);border-bottom:1px dashed var(--line);align-items:center;gap:10px;padding:8px 0;font-size:.92rem;transition:color .2s;display:flex}.contact__row:last-of-type{border-bottom:0}.contact__row:hover{color:var(--accent)}.contact__row svg{color:var(--text-3)}.contact__cv{justify-content:center;align-items:center;gap:10px;width:100%;margin-top:14px;display:inline-flex}.contact__cv--disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.btn{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;border-radius:10px;padding:12px 18px;font-size:.78rem;transition:all .2s}.btn--ghost{border:1px solid var(--line);color:var(--text-1)}.btn--ghost:hover{border-color:var(--accent);color:var(--text-0);background:var(--accent-soft)}.about__body{padding-top:8px}.about__summary{font-family:var(--serif);color:var(--text-0);text-wrap:pretty;text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto;max-width:760px;margin:0 0 64px;font-size:clamp(18px,1.7vw,24px);line-height:1.4}.about__summary:first-letter{float:left;color:var(--accent);padding:6px 12px 0 0;font-size:1.6em;line-height:.8}@media (max-width:768px){.skills{display:none}}.skills__head{border-bottom:1px solid var(--line);color:var(--text-2);justify-content:space-between;margin-bottom:28px;padding-bottom:14px;display:flex}.skills__grid{grid-template-columns:repeat(2,1fr);gap:28px 56px;display:grid}.skillgroup__label{color:var(--text-3);margin-bottom:12px}.skillgroup__chips{flex-wrap:wrap;gap:6px;display:flex}.chip{border:1px solid var(--line);font-family:var(--mono);color:var(--text-1);background:#0b102380;background:lab(4.97027% 2.53645 -13.4835/.5);border-radius:6px;align-items:center;padding:5px 10px;font-size:.78rem;transition:all .2s;display:inline-flex}.chip:hover{color:var(--text-0);border-color:var(--accent);background:var(--accent-soft)}.edu{max-width:var(--max);margin:0 auto;padding:80px 40px}.timeline{margin:0;padding:0;list-style:none;position:relative}.timeline:before{content:"";background:var(--line);width:1px;position:absolute;top:14px;bottom:14px;left:200px}.timeline__item{border-bottom:1px solid var(--line);grid-template-columns:200px 1fr;gap:48px;padding:28px 0;display:grid;position:relative}.timeline__item:last-child{border-bottom:0}.timeline__period{color:var(--text-2);padding-top:8px}.timeline__core{padding-left:48px}.timeline__node{justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:absolute;top:36px;left:192px}.timeline__node span{background:var(--bg-0);border:1px solid var(--accent);width:10px;height:10px;box-shadow:0 0 0 4px var(--bg-0), 0 0 12px var(--accent-glow);border-radius:50%}.timeline__tag{font-family:var(--mono);letter-spacing:.06em;background:var(--accent-soft);color:var(--accent);border-radius:4px;margin-bottom:10px;padding:3px 8px;font-size:.7rem;display:inline-block}.timeline__title{font-family:var(--serif);color:var(--text-0);margin:0 0 6px;font-size:28px;font-weight:400;line-height:1.2}.timeline__place{color:var(--text-2);margin-bottom:8px;font-size:.95rem}.timeline__detail{color:var(--text-1);max-width:600px;margin:0;font-size:.95rem}.edu__meta{flex-direction:column;gap:4px;margin:0;padding-left:18px;list-style:outside;display:flex}.edu__meta li{color:var(--text-1);font-size:.95rem}.edu__desc{color:var(--text-2);max-width:600px;margin:10px 0 0;font-size:.92rem}.exp{max-width:var(--max);margin:0 auto;padding:80px 40px}.exp__list{flex-direction:column;display:flex}.exp__row{border-top:1px solid var(--line);grid-template-columns:200px 1fr 60px;align-items:start;gap:48px;padding:36px 0;transition:background .2s;display:grid}.exp__row:hover{background:linear-gradient(90deg, transparent, var(--accent-soft) 50%, transparent)}.exp__row:last-child{border-bottom:1px solid var(--line)}.exp__period{color:var(--text-2);padding-top:8px}.exp__role{font-family:var(--serif);letter-spacing:-.02em;color:var(--text-0);margin:0 0 6px;font-size:32px;font-weight:400;line-height:1.15}.exp__place{color:var(--text-2);margin-bottom:10px;font-size:.95rem}.exp__detail{color:var(--text-1);white-space:pre-line;text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto;max-width:640px;margin:0;font-size:1rem}.exp__index{text-align:right;color:var(--text-3);padding-top:12px}.activities{max-width:var(--max);margin:0 auto;padding:80px 40px}.activities__list{flex-direction:column;gap:48px;padding-top:8px;display:flex}.activities__group{flex-direction:column;gap:16px;display:flex}.activities__category{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--line);margin:0 0 20px;padding-bottom:8px;font-size:.75rem}.activities__items{flex-direction:column;gap:20px;margin:0;padding:0;list-style:none;display:flex}.activities__item{flex-direction:column;gap:6px;display:flex}.activities__item:not(:only-child){padding-left:18px;position:relative}.activities__item:not(:only-child):before{content:"·";color:var(--accent);font-weight:700;position:absolute;top:2px;left:0}.activities__title{color:var(--text-0);font-size:1.05rem;font-weight:700}.activities__detail{color:var(--text-1);white-space:pre-line;text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto;max-width:720px;margin:0;font-size:.95rem}.about__summary strong em,.exp__detail strong em,.activities__detail strong em,.pcard__desc strong em{color:var(--text-0);font-style:italic;font-weight:600}.proj{z-index:25;padding:80px 0 100px;position:relative}.proj__head{max-width:var(--max);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:48px;margin:0 auto;padding-left:40px;display:flex}.proj__head-left{flex-direction:column;gap:6px;display:flex}.proj__coming{color:var(--text-3);letter-spacing:.03em;align-items:center;gap:5px;font-size:.78rem;display:inline-flex}.proj__controls{align-items:center;gap:14px;display:flex}.proj__counter{color:var(--text-2)}.iconbtn{border:1px solid var(--line);width:40px;height:40px;color:var(--text-1);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.iconbtn:hover:not([disabled]){border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.iconbtn:disabled{opacity:.35;cursor:not-allowed}.proj__hint{max-width:var(--max);color:var(--text-3);margin:16px auto 32px;padding:0 40px}.proj__track{max-width:var(--max);scroll-snap-type:x mandatory;scrollbar-width:none;scroll-behavior:smooth;gap:24px;margin:0 auto;padding:12px 40px 36px;scroll-padding-inline:40px;display:flex;overflow:auto visible}.proj__track::-webkit-scrollbar{display:none}.pcard{scroll-snap-align:start;border:1px solid var(--line);cursor:pointer;background:linear-gradient(#0c0f2799,#05091c66);background:linear-gradient(lab(4.83055% 4.45358 -16.8136/.6),lab(2.83153% 1.85607 -11.069/.4));border-radius:18px;flex:0 0 calc(33.3333% - 42.6667px);min-width:0;transition:all .4s cubic-bezier(.2,.7,.2,1);position:relative}.pcard:hover{border-color:var(--accent);box-shadow:0 30px 60px -20px #00000080, 0 0 0 1px var(--accent-soft), 0 0 60px -20px var(--accent-glow);transform:translateY(-6px)}@supports (color:lab(0% 0 0)){.pcard:hover{box-shadow:0 30px 60px -20px lab(0% 0 0/.5), 0 0 0 1px var(--accent-soft), 0 0 60px -20px var(--accent-glow)}}.pcard__media{aspect-ratio:16/10;border-radius:18px 18px 0 0;position:relative;overflow:hidden}.pcard__media .thumb{width:100%;height:100%}.thumb{display:block;position:relative}.thumb__shape{width:100%;height:100%;display:block}.pcard__index{font-family:var(--mono);letter-spacing:.04em;color:#ffffffd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;border-radius:4px;padding:4px 8px;font-size:.72rem;position:absolute;top:14px;left:16px}.pcard__year{font-family:var(--mono);letter-spacing:.04em;color:#ffffffd9;font-size:.72rem;position:absolute;top:14px;right:16px}.pcard__body{padding:24px}.pcard__kicker{color:var(--text-3);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px;font-size:.78rem}.pcard__title{font-family:var(--serif);letter-spacing:-.02em;color:var(--text-0);text-wrap:balance;min-height:2.3em;margin:0 0 14px;font-size:26px;font-weight:400;line-height:1.15}.pcard__desc{color:var(--text-1);min-height:3em;margin:0 0 24px;font-size:.95rem}.pcard__foot{border-top:1px solid var(--line);justify-content:space-between;align-items:center;padding-top:16px;display:flex}.pcard__tech{gap:8px;display:flex}.techdot{border:1px solid var(--line);width:32px;height:32px;color:var(--text-1);background:#04061399;background:lab(1.871% .900246 -6.03712/.6);border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:relative}.techdot:after{content:attr(data-tooltip);white-space:nowrap;background:var(--bg-2,#0c111f);color:var(--text-0);font-family:var(--mono);letter-spacing:.04em;border:1px solid var(--line);pointer-events:none;opacity:0;z-index:10;border-radius:6px;padding:4px 10px;font-size:.72rem;transition:opacity .15s;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%)}@supports (color:lab(0% 0 0)){.techdot:after{background:var(--bg-2,lab(5.07922% 1.24426 -10.0691))}}.techdot:hover:after{opacity:1}.pcard__tech .techdot:first-child:after{left:0;transform:none}.pcard__tech .techdot:last-child:after{left:auto;right:0;transform:none}.pcard:hover .techdot{color:var(--accent);border-color:var(--accent-soft)}.pcard__cta{color:var(--text-1);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:8px;font-size:.78rem;transition:color .2s;display:inline-flex}.pcard:hover .pcard__cta{color:var(--accent)}.proj__progress{max-width:var(--max);gap:8px;margin:32px auto 0;padding:0 40px;display:flex}.proj__pip{background:var(--line);cursor:pointer;border-radius:2px;flex:1;height:2px;transition:background .3s}.proj__pip.is-on{background:var(--accent)}.sideindex{z-index:20;border:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#040613b3;background:lab(1.871% .900246 -6.03712/.7);border-radius:12px;min-width:180px;padding:16px;transition:opacity .2s,transform .2s;position:fixed;top:50%;right:24px;transform:translateY(-50%)}.sideindex--hidden{opacity:0;pointer-events:none;transform:translateY(-50%)translate(18px)}.sideindex__title{color:var(--text-3);border-bottom:1px solid var(--line);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px;padding-bottom:8px;font-size:.78rem}.sideindex ul{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.sideindex li a{color:var(--text-2);border-radius:6px;align-items:center;gap:12px;padding:8px 6px;font-size:.86rem;transition:all .2s;display:flex}.sideindex li a:hover{color:var(--text-0);background:#10142899;background:lab(6.87534% 2.85874 -14.2765/.6)}.sideindex li.is-on a{color:var(--text-0)}.sideindex li.is-on .sideindex__n{color:var(--accent)}.sideindex__n{color:var(--text-3);width:20px;font-family:var(--mono);font-size:.78rem}@media (max-width:1240px){.sideindex{display:none}}.foot{max-width:var(--max);margin:0 auto;padding:80px 40px 40px}.foot__rule{background:var(--line);height:1px;margin-bottom:24px}.foot__row{color:var(--text-3);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.foot__brand{object-fit:contain;opacity:.92;mix-blend-mode:multiply;width:auto;max-width:min(70vw,360px);height:112px}@media (max-width:700px){.foot__brand{height:88px}}.detail{animation:.5s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.btn--back{border-radius:999px;align-items:center;gap:10px;padding:10px 14px;display:inline-flex}.detail__hero{text-align:center;max-width:980px;margin:80px auto 56px;padding:0 40px}.detail__kicker{color:var(--text-2);font-family:var(--mono);letter-spacing:.04em;gap:10px;margin-bottom:24px;font-size:.78rem;display:inline-flex}.detail__kicker>:first-child{color:var(--accent)}.detail__title{font-family:var(--serif);letter-spacing:-.03em;text-wrap:balance;margin:0 0 28px;font-size:clamp(48px,7vw,92px);font-weight:400;line-height:.98}.detail__lead{font-family:var(--serif);color:var(--text-1);text-wrap:pretty;text-align:left;max-width:760px;margin:0;font-size:clamp(20px,1.8vw,26px);font-style:italic;line-height:1.5}.detail__leadwrap{max-width:var(--max);margin:0 auto 80px;padding:0 40px}.detail__media{max-width:var(--max);margin:0 auto 48px;padding:0 40px}.slider__viewport{border:1px solid var(--line);background:var(--bg-1);border-radius:18px;position:relative;overflow:hidden}.slider__track{width:100%;transition:transform .6s cubic-bezier(.7,0,.2,1);display:flex}.slider__slide{background:var(--bg-1);flex:0 0 100%;justify-content:center;align-items:center;min-height:260px;display:flex;position:relative}.slider__img{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:520px;display:block}.slider__art{position:absolute;inset:0}.slider__caption{color:var(--text-1);font-family:var(--serif);text-align:center;min-height:1.4em;margin:14px 4px 0;font-size:.95rem;font-style:italic}.slider__nav{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);width:44px;height:44px;color:var(--text-0);background:#040613b3;background:lab(1.871% .900246 -6.03712/.7);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%)}.slider__nav:hover{border-color:var(--accent);color:var(--accent)}.slider__nav--prev{left:16px}.slider__nav--next{right:16px}.slider__chrome{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);color:var(--text-1);font-family:var(--mono);letter-spacing:.04em;background:#040613b3;background:lab(1.871% .900246 -6.03712/.7);border-radius:999px;align-items:center;gap:16px;padding:8px 14px;font-size:.78rem;display:flex;position:absolute;bottom:16px;right:24px}@media (max-width:768px){.slider__chrome{display:none}}.slider__pips{gap:6px;display:flex}.slider__pips button{background:var(--line-strong);border-radius:50%;width:8px;height:8px;transition:all .2s}.slider__pips button.is-on{background:var(--accent);border-radius:4px;width:22px}.detail__meta{max-width:var(--max);border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:repeat(3,1fr);gap:32px;margin:0 auto 80px;padding:24px 40px;display:grid}.metarow__label{color:var(--text-3);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px;font-size:.78rem}.metarow__val{color:var(--text-0);font-size:.95rem}.metarow__tags{flex-wrap:wrap;gap:6px;display:flex}.tag{font-family:var(--mono);border:1px solid var(--line);color:var(--text-1);background:#0b102399;background:lab(4.97027% 2.53645 -13.4835/.6);border-radius:4px;padding:3px 8px;font-size:.74rem;display:inline-block}.detail__body{max-width:var(--max);grid-template-columns:220px 1fr;align-items:start;gap:80px;margin:0 auto;padding:0 40px;display:grid}.detail__index{border:1px solid var(--line);background:#080b1e66;background:lab(3.45114% 2.22586 -12.0133/.4);border-radius:12px;padding:16px;position:sticky;top:100px}.detail__index ul{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.detail__index li a{color:var(--text-2);border-radius:6px;align-items:center;gap:12px;padding:8px 6px;font-size:.9rem;transition:all .2s;display:flex}.detail__index li button{width:100%;color:var(--text-2);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:6px;align-items:center;gap:12px;padding:8px 6px;font-size:.9rem;transition:all .2s;display:flex}.detail__index li a:hover,.detail__index li button:hover{color:var(--text-0);background:#10142899;background:lab(6.87534% 2.85874 -14.2765/.6)}.detail__index li.is-on a,.detail__index li.is-on button{color:var(--text-0)}.detail__index li.is-on .sideindex__n{color:var(--accent)}.detail__sections{flex-direction:column;gap:100px;display:flex}.dsec{scroll-margin-top:100px}.dsec__body{color:var(--text-1);text-wrap:pretty;text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto;max-width:720px;margin:0;font-size:1.05rem;line-height:1.65}.dsec__body--rich ul{margin:14px 0 0 22px;padding:0;list-style:outside}.dsec__body--rich li{display:list-item}.dsec__body--rich li+li{margin-top:8px}.dsec__body--rich em{color:var(--text-0);font-style:italic}.dsec__body--rich strong{color:var(--text-0);font-weight:600}.dsec__stack{flex-wrap:wrap;gap:10px;margin-top:28px;display:flex}.stackchip{border:1px solid var(--line);font-family:var(--mono);color:var(--text-1);background:#080b1e66;background:lab(3.45114% 2.22586 -12.0133/.4);border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:.78rem;display:inline-flex}.stackchip svg{color:var(--accent)}.dsec--featured{background:radial-gradient(800px 300px at 80% -10%, var(--accent-soft), transparent 60%), linear-gradient(180deg, #0c0f2799, #05091c66);border:1px solid var(--line);border-radius:20px;padding:48px;position:relative}@supports (color:lab(0% 0 0)){.dsec--featured{background:radial-gradient(800px 300px at 80% -10%, var(--accent-soft), transparent 60%), linear-gradient(180deg, lab(4.83055% 4.45358 -16.8136/.6), lab(2.83153% 1.85607 -11.069/.4))}}.dsec--featured:before{content:"";background:linear-gradient(180deg, var(--accent), transparent);border-radius:4px 0 0 4px;width:4px;height:60%;position:absolute;top:0;left:0}.actcards{flex-direction:column;gap:0;margin:28px 0 0;padding:0;list-style:none;display:flex}.actcard{border-bottom:1px solid var(--line);grid-template-columns:60px 1fr;align-items:start;gap:24px;padding:24px 0;display:grid;position:relative}.actcard:last-child{border-bottom:0}.actcard__n{color:var(--accent);font-family:var(--mono);letter-spacing:.04em;padding-top:4px;font-size:.78rem}.actcard__body{color:var(--text-0);font-size:1.05rem;line-height:1.5}.detail__nav{border-top:1px solid var(--line);justify-content:space-between;padding-top:48px;display:flex}.navbtn{border:1px solid var(--line);color:var(--text-1);border-radius:14px;align-items:center;gap:14px;padding:16px 22px;transition:all .2s;display:inline-flex}.navbtn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.navbtn__lbl{color:var(--text-3);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;font-size:.78rem}@media (max-width:920px){.topbar{grid-template-columns:1fr auto;padding:14px 24px}.topbar__nav{display:none}.hero{padding:0 24px 60px}.about,.edu,.exp{padding:60px 24px}.about__grid{grid-template-columns:1fr;gap:32px}.about__card{flex-direction:row;align-items:flex-start;gap:24px;max-width:none;display:flex;position:static}.about__card .portrait{flex:0 0 200px}.about__card .contact{flex:1;margin-top:0}.skills__grid{grid-template-columns:1fr;gap:24px}.timeline:before{left:14px}.timeline__item{grid-template-columns:1fr;gap:8px;padding-left:36px}.timeline__node{top:32px;left:6px}.timeline__core{padding-left:0}.exp__row{grid-template-columns:1fr;gap:6px}.exp__index{display:none}.pcard{flex:0 0 80vw;min-width:280px}.detail__body{grid-template-columns:1fr;gap:40px}.detail__index{position:static}.detail__meta{grid-template-columns:repeat(2,1fr)}.dsec--featured{padding:28px}.actcard{grid-template-columns:40px 1fr;gap:12px}}@media (max-width:768px){.about__card{flex-direction:column}.about__card .portrait{flex:none;width:100%}.about__card .contact{margin-top:24px}}
