@import "https://fonts.googleapis.com/css2?family=Syne:wght@500;700;800&family=Manrope:wght@400;500;600;700&display=swap";:root{color:#1b1714;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-soft:#fcf8f3;--panel:#ffffffbd;--panel-strong:#fffdf9;--text:#1d1916;--text-soft:#37302a;--muted:#786d62;--accent:#ff6d00;--accent-deep:#1c1816;--border:#1d181414;--shadow:0 24px 80px #452d171a;background:radial-gradient(circle at 0 0,#ff6d0014,#0000 20%),radial-gradient(circle at 100% 100%,#241d180d,#0000 22%),linear-gradient(#f5efe8 0%,#efe5d8 100%);font-family:Manrope,sans-serif;font-weight:500;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;opacity:.18;background-color:#0000;background-image:linear-gradient(90deg,#ffffff14 1px,#0000 1px),linear-gradient(#ffffff0f 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:120px 120px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:fixed;inset:0;-webkit-mask-image:radial-gradient(circle,#000 38%,#0000 85%);mask-image:radial-gradient(circle,#000 38%,#0000 85%)}body,input,textarea,button{font-family:Manrope,sans-serif}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}img{max-width:100%;display:block}::selection{color:#1d1916;background:#ff6d0029}#root{width:min(1400px,100% - 28px);margin:0 auto;padding:18px 0 40px}.page-shell{gap:22px;display:grid}.site-header{z-index:50;position:sticky;top:14px}.page-shell>*{z-index:2;position:relative}.topbar,.hero-panel,.timeline-panel,.projects-panel,.contact-panel,.site-footer{background:linear-gradient(#fffdf9eb,#f8f3ece6),radial-gradient(circle at 0 0,#ff6d0014,#0000 30%);border:1px solid #1f181414;border-radius:34px;position:relative;overflow:hidden;box-shadow:0 20px 60px #3d2b1814,inset 0 1px #ffffffd1}.topbar:after,.hero-panel:after,.timeline-panel:after,.projects-panel:after,.contact-panel:after,.site-footer:after{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff4d,#0000 34%),linear-gradient(315deg,#ffffff24,#0000 24%);position:absolute;inset:0}.topbar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);justify-content:space-between;align-items:center;gap:20px;min-height:82px;padding:14px 22px;display:flex}.reveal{opacity:0;transition:opacity .52s,transform .52s cubic-bezier(.2,.7,.2,1);transform:translateY(24px)}.reveal.is-visible{opacity:1;transform:translateY(0)}.scroll-dot{z-index:1;opacity:0;pointer-events:none;will-change:transform;contain:layout paint style;width:40px;height:40px;margin-top:-20px;margin-left:-20px;transition:opacity .18s;position:fixed;top:0;left:0;transform:translate(-9999px,-9999px)}.scroll-dot.is-visible{opacity:1}.hero-actions,.topbar,.project,.timeline-card,.contact-form,.footer-meta{z-index:3;position:relative}.primary-button,.secondary-link{z-index:4;position:relative}.scroll-dot-core,.scroll-dot-ring{border-radius:50%;position:absolute;inset:0}.scroll-dot-core{background:radial-gradient(circle at 30% 30%,#ffd8b2 0%,#ff9d52 32%,#ff6d00 68%,#dc5500 100%);box-shadow:0 8px 20px #ff6d002e,0 0 0 1px #ffffff3d}.scroll-dot-ring{border:1px solid #ff6d0024;animation:2.6s ease-in-out infinite pulseRing;inset:-11px}@keyframes pulseRing{0%,to{opacity:.38;transform:scale(.96)}50%{opacity:.72;transform:scale(1.08)}}.topbar-links{color:var(--muted);letter-spacing:.16em;text-transform:uppercase;align-items:center;gap:26px;font-size:.76rem;font-weight:800;transition:all .3s;display:flex}.hamburger-button{cursor:pointer;z-index:60;background:0 0;border:none;flex-direction:column;justify-content:space-around;width:30px;height:24px;padding:0;display:none}.hamburger-button span{background:var(--muted);transform-origin:1px;border-radius:2px;width:30px;height:3px;transition:all .3s linear;position:relative}.hamburger-button.is-active span:first-child{transform:rotate(45deg)}.hamburger-button.is-active span:nth-child(2){opacity:0}.hamburger-button.is-active span:nth-child(3){transform:rotate(-45deg)}@media (width<=860px){.hamburger-button{display:flex}.topbar-links{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);opacity:0;pointer-events:none;z-index:55;background:#fffdf9f5;border:1px solid #1f181414;border-radius:24px;flex-direction:column;justify-content:flex-start;align-items:center;gap:20px;min-width:180px;padding:20px 30px;position:absolute;top:calc(100% + 14px);right:0;transform:translateY(-10px);box-shadow:0 20px 60px #3d2b181f}.topbar-links.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}}.topbar-links a,.header-link,.secondary-link,.contact-copy a,.footer-links a{transition:color .18s,opacity .18s,border-color .18s}.topbar-links a:hover,.header-link:hover,.secondary-link:hover,.contact-copy a:hover,.footer-links a:hover{color:var(--accent)}.brand-mark{background:#12100f;border-radius:18px;justify-self:center;place-items:center;width:58px;height:58px;display:grid;overflow:hidden;box-shadow:0 12px 28px #100c0a29}.brand-mark img{object-fit:cover;width:100%;height:100%}.header-link,.primary-button{border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:.88rem 1.3rem;font-size:.88rem;font-weight:800;display:inline-flex}.header-link{white-space:nowrap;background:#ffffffb3;border:1px solid #1e171314;max-width:100%}.hero-panel{min-height:min(92vh,960px);padding:42px 42px 44px}.hero-panel:before{content:"";background:radial-gradient(circle,#ff6d001c,#0000 68%);width:46vw;height:46vw;position:absolute;inset:auto -10% -24% auto}.hero-grid{z-index:1;grid-template-columns:minmax(0,1fr) minmax(460px,.98fr);align-items:center;gap:34px;min-height:100%;display:grid;position:relative}.hero-copy{max-width:580px;padding:32px 0 12px 8px}.eyebrow{color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin:0 0 16px;font-size:.72rem;font-weight:800}h1,h2,h3{color:var(--text);margin:0}h1,h2{font-family:Syne,sans-serif}h1{white-space:nowrap;letter-spacing:-.07em;max-width:none;font-size:clamp(3.5rem,6vw,6.4rem);line-height:.9}h2{letter-spacing:-.06em;max-width:12ch;font-size:clamp(2.5rem,4.3vw,4.2rem);line-height:.92}.hero-text,.section-copy,.timeline-meta,.timeline-location,.project-copy p{color:var(--muted)}.hero-text{max-width:34rem;margin-top:24px;font-size:1.04rem;line-height:1.75}.hero-actions{flex-wrap:wrap;align-items:center;gap:16px;margin-top:34px;display:flex}.primary-button{cursor:pointer;color:#fff;background:linear-gradient(135deg,#ff7d25 0%,#ff6500 100%);border:none;box-shadow:0 16px 30px #ff6d002e}.primary-button:hover{filter:brightness(1.03)}.secondary-link{color:var(--text-soft);font-weight:800}.hero-highlights{grid-template-columns:repeat(2,minmax(0,240px));gap:18px;margin-top:46px;display:grid}.hero-highlights article{background:linear-gradient(#ffffffc7,#fff9f394),radial-gradient(circle at 100% 0,#ff6d0014,#0000 40%);border:1px solid #1f181412;border-radius:24px;padding:18px 20px 20px}.hero-highlights strong{font-family:Syne,sans-serif;font-size:2rem;line-height:.95;display:block}.hero-highlights span{color:var(--muted);margin-top:10px;line-height:1.55;display:block}.hero-art{place-items:center;min-height:660px;display:grid;position:relative}.hero-mesh,.hero-gridline{position:absolute}.hero-mesh-a{clip-path:polygon(26% 0,100% 0,100% 58%,68% 100%,14% 100%,0 34%);background:linear-gradient(135deg,#ff9550 0%,#ff6d00 52%,#e45b00 100%);border-radius:44px;inset:0 -60px 120px 34%}.hero-mesh-b{background:linear-gradient(#fffc,#f7f0e780);border:1px solid #1d18130f;border-radius:36px;width:210px;height:210px;bottom:18px;left:28px;transform:rotate(44deg)}.hero-gridline{opacity:.26;background-image:linear-gradient(#12100f1f 1px,#0000 1px),linear-gradient(90deg,#12100f1f 1px,#0000 1px);background-size:24px 24px;width:180px;height:180px;top:24px;right:22px}.portrait-shell{aspect-ratio:.95;background:linear-gradient(#faf4ecf0,#e8dfd4d1),radial-gradient(circle at 50% 22%,#fffc,#0000 28%);border-radius:44px;place-items:center;width:min(100%,560px);display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffffd1,0 24px 60px #3c2a171f}.portrait-grain{opacity:.12;background-image:radial-gradient(#fff9 .6px,#0000 .6px),radial-gradient(#ffffff47 .6px,#0000 .6px);background-position:0 0,14px 14px;background-size:28px 28px;position:absolute;inset:0}.portrait-frame{z-index:1;aspect-ratio:1;background:#efe7dd;border:12px solid #fffbf6db;border-radius:50%;width:min(74%,370px);position:relative;overflow:hidden;box-shadow:0 28px 52px #2b1f1429,inset 0 1px #fff9}.portrait-image{object-fit:cover;object-position:center 22%;width:100%;height:100%;transform:scale(1.02)}.hero-fall{will-change:transform, opacity;opacity:0;animation:1.04s cubic-bezier(.18,.82,.22,1) forwards heroFallIn}.hero-fall-image{animation-delay:.12s}.hero-fall-role{animation-delay:.24s}.hero-fall-study{animation-delay:.36s}@keyframes heroFallIn{0%{opacity:0;transform:translateY(-38px)scale(.97)}60%{opacity:1;transform:translateY(6px)scale(1.01)}to{opacity:1;transform:translate(0,0)scale(1)}}.floating-panel{z-index:2;color:#fff;background:#131110eb;border-radius:24px;max-width:238px;padding:18px 18px 16px;position:absolute;box-shadow:0 20px 42px #120e0c2e}.floating-panel span{color:#ffffff9e;letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px;font-size:.68rem;font-weight:800;display:inline-block}.floating-panel strong{font-size:1.02rem;line-height:1.15;display:block}.floating-panel p{color:#ffffffbd;margin:8px 0 0;font-size:.88rem}.floating-panel-top{top:80px;left:-12px}.floating-panel-bottom{bottom:56px;right:18px}.timeline-panel,.projects-panel,.contact-panel,.site-footer{padding:40px 34px}.timeline-panel{--path-progress:0}.section-head{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.section-copy{max-width:35rem;font-size:1rem;line-height:1.72}.timeline-stage{contain:layout paint;min-height:var(--timeline-height);background:linear-gradient(#ffffffbd,#fcf8f270),radial-gradient(circle at 0 0,#ff6d000f,#0000 32%);border:1px solid #1b16120f;border-radius:34px;margin-top:38px;position:relative}.timeline-svg{width:100%;height:var(--timeline-height);display:block}.timeline-track-shadow,.timeline-track-base,.timeline-track-progress{fill:none;stroke-linecap:round;stroke-linejoin:round}.timeline-track-shadow{stroke:#ff6d000f;stroke-width:22px}.timeline-track-base{stroke:#201a1612;stroke-width:6px}.timeline-track-progress{stroke:url(#timelineGlow);stroke-width:8px;stroke-dasharray:calc(var(--path-progress) * 1) 1;transition:stroke-dasharray .12s linear}.timeline-cards{position:absolute;inset:0}.timeline-card{will-change:transform, opacity;opacity:0;background:linear-gradient(#ffffffe6,#fffbf6d1);border:1px solid #211a1512;border-radius:24px;width:228px;padding:18px 18px 20px;transition:opacity .22s,transform .26s cubic-bezier(.2,.7,.2,1),box-shadow .18s,border-color .18s;position:absolute;transform:translateY(18px)scale(.985);box-shadow:0 12px 28px #50371c0f}.timeline-card[data-state=active],.timeline-card[data-state=past]{opacity:1;transform:translate(0,0)scale(1)}.timeline-card[data-state=active]{border-color:#ff6d002e;box-shadow:0 18px 36px #50371c1a}.timeline-card[data-state=past]{box-shadow:0 10px 24px #50371c0d}.timeline-card[data-kind=education][data-state=active]{border-color:#48987047;box-shadow:0 18px 36px #3570521f}.timeline-card[data-kind=education] .timeline-type{color:#357052;background:#4898701f}.timeline-card:hover{transform:translateY(-3px);box-shadow:0 18px 34px #50371c14}.timeline-card:before{content:"";background:#ff6d0029;width:54px;height:1px;position:absolute;top:50%}.timeline-card[data-side=left]:before{right:-54px}.timeline-card[data-side=right]:before{left:-54px}.timeline-card[data-side=center]:before{display:none}.timeline-type{color:var(--accent);letter-spacing:.16em;text-transform:uppercase;background:#ff6d001a;border-radius:999px;padding:.42rem .72rem;font-size:.68rem;font-weight:800;display:inline-flex}.timeline-card h3{margin-top:14px;font-size:1.04rem;line-height:1.12}.timeline-meta,.timeline-period,.timeline-location{margin:10px 0 0;font-size:.9rem;line-height:1.58}.timeline-period{color:var(--text);font-weight:800}.projects-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start;gap:22px;margin-top:32px;display:grid}.project{gap:18px;display:grid}.project-lowered{margin-top:76px}.project-visual{background:radial-gradient(circle at 100% 0,#ffffff26,#0000 34%),linear-gradient(#181513 0%,#3b2d22 100%);border:1px solid #ffffff24;border-radius:32px;min-height:350px;position:relative;overflow:hidden}.project:nth-child(2) .project-visual{background:radial-gradient(circle at 100% 0,#ffffff38,#0000 34%),linear-gradient(#f6d0ad 0%,#efe2d5 100%)}.project:nth-child(3) .project-visual{background:radial-gradient(circle at 100% 0,#ffffff3d,#0000 34%),linear-gradient(#d7dce3 0%,#f4f0ea 100%)}.project-tag,.project-id,.project-shape{position:absolute}.project-tag{z-index:2;color:#fff;letter-spacing:.12em;text-transform:uppercase;background:#ffffff29;border-radius:999px;padding:.52rem .82rem;font-size:.7rem;font-weight:800;top:18px;left:18px}.project:nth-child(2) .project-tag,.project:nth-child(3) .project-tag{color:#1d1815;background:#ffffffa3}.project-id{z-index:2;color:#fff;background:#110f0ee6;border-radius:20px;place-items:center;width:62px;height:62px;font-family:Syne,sans-serif;font-size:1.45rem;display:grid;bottom:18px;right:18px}.project-shape-a{clip-path:polygon(0 0,66% 0,54% 42%,100% 42%,100% 100%,0 100%);background:#ff6d00f2;border-radius:32px;width:64%;height:64%;top:18%;left:10%}.project-shape-b{background:#120f0edb;border-radius:999px;width:24%;height:78%;top:8%;left:48%}.project-shape-c{background:radial-gradient(circle,#ffffff47,#0000 66%);border-radius:50%;width:250px;height:250px;top:-48px;right:-24px}.project-copy h3{font-size:1.14rem}.project-copy p{margin:8px 0 0;line-height:1.68}.contact-panel{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:start;gap:28px;display:grid}.contact-copy{padding-top:6px}.contact-form{background:linear-gradient(#ffffffb8,#fffaf59e),radial-gradient(circle at 0 0,#ff6d000d,#0000 38%);border:1px solid #221a140f;border-radius:30px;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding:28px;display:grid}.contact-form label{gap:10px;display:grid}.contact-form span{color:var(--muted);letter-spacing:.16em;text-transform:uppercase;font-size:.7rem;font-weight:800}.contact-form input,.contact-form textarea{width:100%;color:var(--text);font:inherit;resize:vertical;background:#ffffffe0;border:1px solid #221b1514;border-radius:18px;padding:1rem 1.06rem;transition:border-color .18s,box-shadow .18s,background-color .18s}.contact-form input:focus,.contact-form textarea:focus{background:#fffffff5;border-color:#ff6d004d;outline:none;box-shadow:0 0 0 4px #ff6d0014}.contact-form-wide{grid-column:1/-1}.contact-submit{justify-self:end;margin-left:auto}.site-footer{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:end;gap:24px;display:grid}.footer-meta{justify-items:end;gap:14px;display:grid}.footer-year{letter-spacing:-.04em;margin:0;font-family:Syne,sans-serif;font-size:2rem}.footer-links{flex-wrap:wrap;justify-content:flex-end;gap:16px;display:flex}.footer-links a{color:var(--text);font-weight:700}@media (width<=1180px){.header-link{text-overflow:ellipsis;max-width:290px;overflow:hidden}.hero-grid{grid-template-columns:minmax(0,1fr) minmax(380px,.94fr)}}@media (width<=1060px){#root{width:min(100%,100% - 20px)}.hero-grid,.contact-panel,.site-footer,.section-head{flex-direction:column;grid-template-columns:1fr;align-items:flex-start}.projects-grid{grid-template-columns:1fr}.project-lowered{margin-top:0}.hero-art{min-height:560px}.topbar{grid-template-columns:1fr auto}.topbar-actions{display:none}}@media (width<=860px){.hero-panel,.timeline-panel,.projects-panel,.contact-panel,.site-footer{padding:26px 22px 28px}.hero-highlights{grid-template-columns:1fr}.timeline-card{width:min(100% - 28px,310px)}.contact-form{grid-template-columns:1fr}.contact-form-wide{grid-column:auto}.contact-submit{justify-self:end;margin-left:auto}}@media (prefers-reduced-motion:reduce){.hero-fall,.reveal,.timeline-card,.timeline-track-progress,.scroll-dot-ring{transition:none!important;animation:none!important}.hero-fall,.timeline-card,.reveal{opacity:1!important;transform:none!important}}@media (width<=720px){#root{width:min(100%,100% - 14px);padding-top:8px}.scroll-dot{width:34px;height:34px;margin-top:-17px;margin-left:-17px}.topbar,.hero-panel,.timeline-panel,.projects-panel,.contact-panel,.site-footer{border-radius:26px;padding:16px 16px 20px}.site-header{top:8px}.topbar{grid-template-columns:auto auto;justify-content:space-between;min-height:68px}.topbar-links{display:none}.brand-mark{justify-self:start;width:46px;height:46px}h1{font-size:clamp(2.1rem,8vw,3.1rem)}h2{font-size:clamp(2rem,9vw,3.2rem)}.hero-copy{padding-top:18px}.hero-art{min-height:420px}.hero-mesh-a{inset:-10px -50px 84px 34%}.hero-mesh-b{width:140px;height:140px}.hero-gridline{width:120px;height:120px}.portrait-shell{width:min(100%,330px)}.floating-panel{max-width:186px;padding:14px 14px 13px}.floating-panel-top{top:26px;left:0}.floating-panel-bottom{bottom:18px;right:0}.timeline-card{width:calc(100% - 18px)}.project-visual{min-height:250px}.footer-meta{justify-items:start}.footer-links{justify-content:flex-start}}
