:root{--bg: #fcfbf6;--ink: #2b3125;--muted: #767964;--line: #eceadc;--accent: #5d7a37;--coral: #ef7355;--g1: #8fb061;--g2: #f7d68c;--g3: #ff8a6b;--max: 1100px;--pad: clamp(1.25rem, 5vw, 4rem);--font-display: "Newsreader", Georgia, "Times New Roman", serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--ease: cubic-bezier(.22, 1, .36, 1);--grad: linear-gradient(120deg, var(--g1), var(--g2) 50%, var(--g3))}*{box-sizing:border-box}html{scroll-behavior:smooth;background:var(--bg);-webkit-text-size-adjust:100%}body{margin:0;color:var(--ink);font-family:var(--font-sans);font-size:clamp(1rem,.96rem + .25vw,1.1rem);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}a{color:inherit;text-decoration:none}h1,h2,h3{font-family:var(--font-display);font-weight:500;line-height:1.06;letter-spacing:-.015em;margin:0}.wrap{width:100%;max-width:var(--max);margin-inline:auto;padding-inline:var(--pad)}.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(140%) blur(12px);background:color-mix(in srgb,var(--bg) 80%,transparent);border-bottom:1px solid transparent;transition:border-color .4s var(--ease)}.nav[data-scrolled=true]{border-bottom-color:var(--line)}.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:66px}.nav__brand{font-family:var(--font-display);font-weight:600;font-size:1.15rem;letter-spacing:-.01em;white-space:nowrap}.nav__links{display:flex;align-items:center;gap:clamp(.9rem,2vw,2rem)}.nav__link{font-size:.85rem;font-weight:500;color:var(--muted);transition:color .25s var(--ease)}.nav__link:hover{color:var(--ink)}.nav__menu{display:flex;gap:clamp(.9rem,2vw,2rem)}@media(max-width:640px){.nav__menu{display:none}}.lang{font-size:.78rem;font-weight:600;letter-spacing:.06em;padding:.38rem .8rem;border-radius:999px;color:var(--accent);border:1px solid var(--line);transition:color .25s var(--ease),border-color .25s var(--ease)}.lang:hover{color:var(--ink);border-color:var(--accent)}.hero{min-height:min(88svh,820px);display:flex;flex-direction:column;justify-content:center;padding-block:clamp(4rem,12vh,8rem);position:relative}.hero:before{content:"";position:absolute;top:-20%;right:-12%;width:min(58vw,760px);height:min(58vw,760px);background:radial-gradient(closest-side at 68% 32%,color-mix(in srgb,var(--g3) 16%,transparent),transparent 70%),radial-gradient(closest-side at 30% 60%,color-mix(in srgb,var(--g1) 18%,transparent),transparent 70%),radial-gradient(closest-side at 60% 75%,color-mix(in srgb,var(--g2) 20%,transparent),transparent 70%);filter:blur(40px);pointer-events:none;z-index:-1}.hero__kicker{display:inline-flex;align-items:center;gap:.55rem;width:fit-content;font-size:.78rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:1.6rem;padding:.4rem .85rem;border-radius:999px;background:color-mix(in srgb,var(--g1) 12%,transparent)}.hero__kicker:before{content:"";width:7px;height:7px;border-radius:50%;background:linear-gradient(120deg,var(--g1),var(--g3))}.hero__title{font-size:clamp(2.6rem,1.5rem + 6.5vw,6rem);white-space:pre-line;max-width:16ch;font-weight:500}.hero__tagline{margin-top:1.8rem;max-width:48ch;font-size:clamp(1.05rem,1rem + .5vw,1.35rem);color:var(--muted)}.hero__cta{margin-top:2.6rem;display:inline-flex;align-items:center;gap:.6rem;font-size:.95rem;font-weight:500;color:var(--ink);width:fit-content;padding-bottom:.3rem;border-bottom:1px solid var(--ink);transition:gap .3s var(--ease)}.hero__cta:hover{gap:1rem}.section{padding-block:clamp(4.5rem,11vh,8rem);position:relative}.section+.section:before{content:"";position:absolute;top:0;left:var(--pad);right:var(--pad);height:1px;background:linear-gradient(90deg,color-mix(in srgb,var(--g1) 45%,var(--line)),var(--line) 35%,var(--line) 65%,color-mix(in srgb,var(--g3) 40%,var(--line)))}.section__head{display:flex;align-items:baseline;gap:1rem;margin-bottom:clamp(2.2rem,5vh,3.5rem)}.section__index{font-family:var(--font-sans);font-size:.78rem;font-weight:600;letter-spacing:.15em;color:var(--accent)}.section__title{font-size:clamp(1.8rem,1.4rem + 2.2vw,3rem);font-weight:500}.about__grid{display:grid;gap:clamp(1.1rem,2.5vw,2rem);max-width:60ch}.about__grid p{margin:0;color:var(--muted);font-size:clamp(1.05rem,1rem + .4vw,1.3rem);line-height:1.72}.about__grid p:first-child{color:var(--ink)}.projects__note{color:var(--muted);font-size:.85rem;margin-bottom:1.5rem}.projects__list{border-top:1px solid var(--line)}.project{display:grid;grid-template-columns:3rem 1fr auto;gap:clamp(1rem,3vw,2rem);align-items:start;padding:clamp(1.6rem,3vw,2.4rem) clamp(.9rem,2vw,1.5rem);border-bottom:1px solid var(--line);border-radius:18px;transition:transform .5s var(--ease),background .45s var(--ease),box-shadow .5s var(--ease),border-color .4s var(--ease)}.project:hover{transform:scale(1.03);background:color-mix(in srgb,var(--tone, var(--accent)) 7%,#ffffff);box-shadow:0 28px 60px -30px #3c3c2880;border-bottom-color:transparent;position:relative;z-index:2}.project:nth-child(4n+1){--tone: #6d8f43}.project:nth-child(4n+2){--tone: #e2643f}.project:nth-child(4n+3){--tone: #4f8da3}.project:nth-child(4n+4){--tone: #c99a2e}.project__tag{font-family:var(--font-display);font-size:1rem;color:var(--tone, var(--accent));padding-top:.35rem}.project__meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem 1rem;margin-bottom:.7rem}.project__title{font-size:clamp(1.35rem,1.1rem + 1.5vw,2.1rem);font-weight:500;transition:color .35s var(--ease)}.project:hover .project__title{color:color-mix(in srgb,var(--tone, var(--accent)) 80%,var(--ink))}.project__period{font-size:.8rem;letter-spacing:.04em;color:var(--muted);white-space:nowrap}.project__desc{color:var(--muted);max-width:60ch;font-size:.98rem;line-height:1.6}.project__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 0;padding:0}.project__tags li{font-size:.74rem;letter-spacing:.02em;color:color-mix(in srgb,var(--tone, var(--accent)) 75%,var(--ink));padding:.28rem .7rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--tone, var(--accent)) 22%,transparent);background:color-mix(in srgb,var(--tone, var(--accent)) 8%,transparent)}.project__more{font-size:1.2rem;color:var(--muted);transition:transform .4s var(--ease),color .35s var(--ease);padding-top:.3rem}.project:hover .project__more{transform:translate(5px,-5px);color:var(--tone, var(--accent))}@media(max-width:680px){.project{grid-template-columns:2.2rem 1fr}.project__more{display:none}}.skills__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:clamp(1.5rem,4vw,3rem)}.skillgroup:nth-child(4n+1){--tone: #6d8f43}.skillgroup:nth-child(4n+2){--tone: #e2643f}.skillgroup:nth-child(4n+3){--tone: #4f8da3}.skillgroup:nth-child(4n+4){--tone: #c99a2e}.skillgroup__name{font-family:var(--font-display);font-weight:500;font-size:1.3rem;margin-bottom:1.1rem;padding-bottom:.7rem;border-bottom:2px solid color-mix(in srgb,var(--tone, var(--accent)) 35%,transparent)}.skillgroup__list{list-style:none;margin:0;padding:0}.skillgroup__list li{padding:.42rem 0;color:var(--muted);display:flex;align-items:center;gap:.7rem}.skillgroup__list li:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--tone, var(--accent));opacity:.75;flex:none}.contact__body{max-width:42ch;color:var(--muted);font-size:clamp(1.05rem,1rem + .5vw,1.35rem);margin-bottom:2.2rem}.contact__email{font-family:var(--font-display);font-weight:500;font-size:clamp(1.8rem,1.1rem + 4vw,3.6rem);letter-spacing:-.02em;width:fit-content;display:inline-block;color:var(--ink);border-bottom:2px solid transparent;transition:border-color .4s var(--ease)}.contact__email:hover{border-bottom-color:var(--accent)}.footer{padding-block:2.5rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;color:var(--muted);font-size:.82rem;border-top:1px solid var(--line)}.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.is-visible{opacity:1;transform:none}.reveal[data-delay="1"]{transition-delay:.07s}.reveal[data-delay="2"]{transition-delay:.14s}.reveal[data-delay="3"]{transition-delay:.21s}
