:root{--bg:#fdf3ec;--bg-tint:#f9e6da;--text:#6b4a46;--text-h:#3a1e1b;--muted:#a07b76;--border:#ead7cc;--accent:#c2686f;--accent-soft:#e4a5ab;--accent-bg:#c2686f14;--accent-border:#c2686f59;--shadow:0 10px 30px -12px #8a43492e;--sans:"Poppins", system-ui, "Segoe UI", Roboto, sans-serif;--serif:"Playfair Display", Georgia, "Times New Roman", serif;--script:"Caveat", "Brush Script MT", cursive;--mono:"DM Mono", ui-monospace, Consolas, monospace;font:16px/1.6 var(--sans);letter-spacing:.1px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{background:radial-gradient(circle at 15% 10%, #e4a5ab40, transparent 45%), radial-gradient(circle at 85% 20%, #ffd6c159, transparent 50%), var(--bg);background-attachment:fixed;min-height:100svh;margin:0}html{scroll-behavior:smooth}#root{flex-direction:column;width:100%;min-height:100svh;display:flex}h1,h2,h3{font-family:var(--serif);color:var(--text-h);letter-spacing:-.5px;margin:0;font-weight:600}p{margin:0}a{color:inherit;text-decoration:none}button{font-family:inherit}.navbar{z-index:50;-webkit-backdrop-filter:saturate(160%)blur(10px);background:#fdf3ecbf;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:22px 56px;transition:border-color .2s;display:flex;position:sticky;top:0}.navbar__menu-toggle{cursor:pointer;background:0 0;border:0;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;padding:8px;display:none}.navbar__menu-toggle span{background:var(--text-h);border-radius:2px;width:20px;height:2px}.navbar__logo{font-family:var(--script);color:var(--accent);letter-spacing:.5px;font-size:38px;font-weight:700;line-height:1;transform:translateY(2px)}.navbar__logo:hover{color:var(--text-h)}.navbar__nav ul{gap:36px;margin:0;padding:0;list-style:none;display:flex}.navbar__nav a{color:var(--text);padding:6px 0;font-size:15px;font-weight:500;transition:color .18s;position:relative}.navbar__nav a:after{content:"";background:var(--accent);transform-origin:50%;height:1.5px;transition:transform .22s;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.navbar__nav a:hover,.navbar__nav a.is-active{color:var(--text-h)}.navbar__nav a.is-active:after,.navbar__nav a:hover:after{transform:scaleX(1)}@media (width<=780px){.navbar{padding:18px 22px}.navbar__logo{font-size:32px}.navbar__menu-toggle{display:inline-flex}.navbar__nav{opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;position:absolute;top:100%;left:16px;right:16px;transform:translateY(-8px)}.navbar__nav.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}.navbar__nav ul{background:#fdf3ecfa;border:1px solid #0000000f;border-radius:14px;flex-direction:column;gap:8px;padding:10px;box-shadow:0 14px 32px #1914101f}.navbar__nav a{border-radius:8px;padding:10px 12px;font-size:14px;display:block}.navbar__nav a:after{display:none}.navbar__nav a:hover,.navbar__nav a.is-active{background:#0000000d}}@media (width<=520px){.navbar{padding:14px 16px}.navbar__logo{font-size:30px}.navbar__menu-toggle{width:36px;height:36px;padding:7px}.navbar__nav{left:10px;right:10px}}.decrypted-text{white-space:pre;display:inline-block}.decrypted-text .char{transition:opacity .28s,color .28s;display:inline-block}.decrypted-text .char--hidden{opacity:0}.decrypted-text .char--scramble{opacity:.55;font-family:var(--mono)}.decrypted-text .char--done{opacity:1}.typewriter{align-items:baseline;display:inline-flex}.typewriter__cursor{color:var(--accent);margin-left:2px;font-weight:400;display:inline-block;transform:translateY(0)}.typewriter__cursor--blink{animation:1s steps(2,start) infinite typewriter-blink}@keyframes typewriter-blink{to{visibility:hidden}}.hero{width:100%;max-width:1200px;margin:0 auto;padding:120px 56px 0;position:relative}.hero__content{z-index:2;max-width:720px;position:relative}.hero__title{font-family:var(--serif);letter-spacing:-2px;color:var(--text-h);margin:0 0 18px;font-size:clamp(48px,8.5vw,104px);font-weight:600;line-height:1.05}.hero__subtitle{color:var(--muted);letter-spacing:.2px;margin-bottom:40px;font-size:clamp(18px,2vw,22px);font-weight:400}.hero__cta{flex-wrap:wrap;gap:14px;display:flex}.btn{letter-spacing:.2px;cursor:pointer;border:1.5px solid var(--border);color:var(--text-h);background:0 0;border-radius:999px;align-items:center;gap:10px;padding:12px 24px;font-size:15px;font-weight:500;transition:transform .18s,background .18s,border-color .18s,color .18s,box-shadow .18s;display:inline-flex}.btn span{transition:transform .22s}.btn:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.btn:hover span{transform:translate(3px)}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover{background:#b05962;border-color:#b05962}.btn--ghost{background:#ffffff80}.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}.hero__decor{pointer-events:none;z-index:1;position:absolute;inset:0}.sparkle{color:var(--accent-soft);font-size:28px;animation:3.5s ease-in-out infinite twinkle;position:absolute}.sparkle--1{font-size:22px;animation-delay:0s;top:90px;left:8%}.sparkle--2{color:var(--accent);font-size:34px;animation-delay:.9s;top:30%;right:14%}.sparkle--3{font-size:18px;animation-delay:1.6s;bottom:18%;right:8%}@keyframes twinkle{0%,to{opacity:.55;transform:scale(1)rotate(0)}50%{opacity:1;transform:scale(1.15)rotate(15deg)}}@media (width<=780px){.hero{padding:150px 22px 0}.hero__subtitle{margin-bottom:28px}.btn{padding:11px 20px;font-size:14px}}.scrapbook{width:100%;height:380vh;position:relative}.scrapbook__sticky{justify-content:center;align-items:center;height:100svh;display:flex;position:sticky;top:0;overflow:hidden}.scrapbook__stage{aspect-ratio:1;justify-content:center;align-items:center;width:820px;max-width:94vw;display:flex;position:relative}.scrapbook__book{z-index:2;filter:drop-shadow(0 18px 28px #8a43492e);-webkit-user-select:none;user-select:none;width:100%;height:auto;position:relative}.scrapbook__sticker{z-index:1;pointer-events:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 6px 12px #8a43492e);will-change:transform, opacity;max-width:120px;max-height:90px;position:absolute;top:50%;left:50%}@media (width<=780px){.scrapbook{height:340vh}.scrapbook__sticky{justify-content:center}.scrapbook__stage{transform-origin:50%;width:112vw;max-width:none}.scrapbook__stage--mobile{will-change:transform}.scrapbook__book{width:150%}.scrapbook__sticker{max-width:84px;max-height:62px}}.projects{width:100%;max-width:1200px;margin:0 auto;padding:120px 56px 140px;position:relative}.projects__header{text-align:center;margin-bottom:56px;position:relative}.projects__draggables{pointer-events:none;z-index:3;position:absolute;inset:0}.projects__drag{pointer-events:auto;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;filter:drop-shadow(0 6px 12px #8a43492e);transition:filter .18s;position:absolute}.projects__drag:active{cursor:grabbing;filter:drop-shadow(0 10px 18px #8a434947)}.projects__title{font-family:var(--serif);color:var(--accent);letter-spacing:-1px;align-items:center;gap:10px;margin:0 0 14px;font-size:clamp(42px,6vw,64px);font-weight:700;display:inline-flex;position:relative}.projects__pointer{color:var(--text-h);font-size:26px;display:inline-block;transform:rotate(-18deg)}.projects__subtitle{color:var(--muted);max-width:580px;margin:0 auto;font-size:17px}.projects__decor{pointer-events:none;position:absolute;inset:0}.decor{color:var(--accent);opacity:.7;font-size:22px;position:absolute}.decor--arrow-1{font-size:20px;top:90px;left:48%;transform:rotate(-10deg)}.decor--arrow-2{font-size:20px;top:150px;right:28%;transform:rotate(15deg)}.decor--arrow-3{font-size:18px;top:220px;left:8%;transform:rotate(-25deg)}.decor--star-1{font-size:22px;top:120px;right:14%}.decor--star-2{font-size:18px;top:42px;right:4%}.decor--sparkle{color:var(--accent-soft);font-size:16px;bottom:110px;right:42%}.decor--drag{font-family:var(--script);color:var(--text-h);opacity:.85;align-items:center;gap:6px;font-size:24px;display:inline-flex;top:32px;right:48px;transform:rotate(-6deg)}.decor__hook{color:var(--accent);font-size:20px}.projects__grid{z-index:1;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;display:grid;position:relative}@media (width<=900px){.projects__grid{grid-template-columns:1fr}.projects{padding:80px 22px 100px}}.project-card{border:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffd1;border-radius:20px;flex-direction:column;gap:14px;padding:26px 28px 24px;transition:transform .22s,box-shadow .22s,border-color .22s;display:flex}.project-card:hover{box-shadow:var(--shadow);border-color:var(--accent-border);transform:translateY(-3px)}.project-card__head{align-items:center;gap:12px;display:flex}.project-card__favicon{background:var(--bg-tint);border:1px solid var(--border);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:26px;line-height:1;display:inline-flex}.project-card__title{font-family:var(--serif);color:var(--text-h);margin:0;font-size:22px;font-weight:600}.project-card__desc{color:var(--text);font-size:14.5px;line-height:1.55}.project-card__stack{flex-wrap:wrap;gap:8px;margin:4px 0 8px;padding:0;list-style:none;display:flex}.project-card__stack li{color:var(--text-h);border:1px solid var(--border);background:#fff;border-radius:999px;padding:5px 12px;font-size:12.5px}.project-card__actions{gap:10px;margin-top:auto;padding-top:4px;display:flex}.pill-btn{border:1.5px solid var(--border);color:var(--text-h);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:13.5px;font-weight:500;transition:transform .18s,background .18s,border-color .18s,color .18s;display:inline-flex}.pill-btn:hover{transform:translateY(-1px)}.pill-btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.pill-btn--primary:hover{background:#b05962;border-color:#b05962}.pill-btn--ghost:hover{color:var(--accent);border-color:var(--accent)}.experience{width:100%;max-width:1100px;margin:0 auto;padding:100px 24px 60px;position:relative}.experience__header{text-align:center;margin-bottom:48px}.experience__title{font-family:var(--serif);color:var(--accent);letter-spacing:-1px;margin:0;font-size:clamp(42px,6vw,64px);font-weight:700}.experience__list{flex-direction:column;gap:24px;display:flex}.exp-card{border:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffd9;border-radius:18px;padding:26px 30px 24px;transition:transform .22s,box-shadow .22s,border-color .22s;box-shadow:0 2px 10px #8a43490d}.exp-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow);transform:translateY(-2px)}.exp-card__head{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:14px;display:flex}.exp-card__heading{min-width:0}.exp-card__role{font-family:var(--serif);color:var(--text-h);letter-spacing:-.2px;margin:0 0 4px;font-size:22px;font-weight:700}.exp-card__org{color:var(--text-h);opacity:.85;margin:0;font-size:15px;font-weight:600}.exp-card__meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.exp-card__meta-item{color:var(--muted);white-space:nowrap;align-items:center;gap:6px;font-size:13.5px;display:inline-flex}.exp-card__bullets{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.exp-card__bullets li{color:var(--text);padding-left:18px;font-size:14.5px;line-height:1.55;position:relative}.exp-card__bullets li:before{content:"";background:var(--accent);opacity:.7;border-radius:50%;width:5px;height:5px;position:absolute;top:9px;left:4px}.exp-card__skills{color:var(--text-h);margin:14px 0 0;font-size:15px;font-weight:700}@media (width<=700px){.experience{padding:70px 18px 40px}.exp-card{padding:22px 20px 20px}.exp-card__head{flex-direction:column;gap:10px}.exp-card__meta{flex-flow:wrap;align-items:flex-start;gap:10px 16px}}.skills-grid-section{width:100%;max-width:1100px;margin:0 auto;padding:40px 24px 140px;position:relative}.skills-section__header{text-align:center;margin-bottom:48px}.skills-grid__title{font-family:var(--serif);color:var(--accent);letter-spacing:-.5px;margin:0 0 12px;font-size:clamp(32px,4.4vw,44px);font-weight:700}.skills-section__subtitle{color:var(--muted);margin:0;font-size:16px}.skills-grid-wrap{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;width:100%;height:600px;position:relative;overflow:hidden}.skills-grid-wrap:active{cursor:grabbing}.skills-grid-canvas{width:100%;height:100%;display:block;position:absolute;inset:0}.skills-grid__fallback{text-align:center;color:var(--muted);place-items:center;padding:24px;font-size:14px;display:grid;position:absolute;inset:0}@media (width<=640px){.skills-grid-section{padding:20px 0 100px}.skills-grid-wrap{height:360px}}@media (width<=390px){.skills-grid-wrap{height:320px}}.contact{width:100%;max-width:1100px;margin:0 auto;padding:110px 24px 150px;position:relative}.contact__header{text-align:center;margin-bottom:36px}.contact__title{font-family:var(--serif);color:var(--accent);letter-spacing:-1px;margin:0 0 10px;font-size:clamp(42px,6vw,64px);font-weight:700}.contact__subtitle{color:var(--muted);font-size:16px}.contact__list{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.contact-card{border:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffd9;border-radius:18px;padding:24px 26px;transition:transform .22s,box-shadow .22s,border-color .22s;box-shadow:0 2px 10px #8a43490d}.contact-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow);transform:translateY(-2px)}.contact-card__label{letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:13px;font-weight:600}.contact-card__value{font-family:var(--mono);color:var(--text-h);word-break:break-word;margin-bottom:8px;font-size:clamp(16px,1.8vw,20px);transition:color .18s;display:inline-block}.contact-card__value:hover{color:var(--accent)}.contact-card__note{color:var(--text);font-size:14px}.contact-ascii-wrap{justify-content:center;width:100%;margin-top:36px;display:flex;overflow-x:auto}.contact-ascii{font-family:var(--mono);color:var(--text-h);white-space:pre;text-align:left;opacity:0;flex:0 0 122ch;width:122ch;max-width:122ch;margin:0;font-size:5.5px;line-height:1.1;transition:opacity .26s}.contact-ascii.is-visible{opacity:1}.contact-ascii__line{opacity:0;will-change:width, opacity;width:0;animation:.26s ease-out forwards contact-line-fade,.95s steps(80,end) forwards contact-line-type;animation-delay:calc(var(--line-index) * 70ms), calc(var(--line-index) * 70ms);display:block;overflow:hidden}@keyframes contact-line-fade{0%{opacity:0}to{opacity:1}}@keyframes contact-line-type{0%{width:0}to{width:var(--line-length)}}@media (width<=700px){.contact{padding:80px 18px 48px}.contact__list{grid-template-columns:1fr}.contact-card{padding:22px 20px}.contact-ascii-wrap{margin-top:28px}.contact-ascii{font-size:4.2px}}.site-footer{border-top:1px solid var(--border);width:min(1100px,100%);color:var(--muted);justify-content:space-between;align-items:center;gap:12px;margin:0 auto;padding:22px 24px 28px;display:flex}.site-footer__text{font-size:14px}.site-footer__meta{font-size:13px;font-family:var(--mono)}@media (width<=700px){.site-footer{flex-direction:column;align-items:flex-start;padding:18px 18px 24px}}main{flex-direction:column;flex:1;display:flex}.section-divider{justify-content:center;width:100%;padding:150px 24px;display:flex}.section-divider__image{opacity:.92;pointer-events:none;-webkit-user-select:none;user-select:none;width:min(1000px,100%);height:auto;display:block}@media (width<=700px){.section-divider{padding:22px 16px;overflow:hidden}.section-divider__image{width:150vw;max-width:none}}
