@font-face{font-family:DM Serif Display;font-style:normal;font-weight:400;font-display:swap;src:url(../media/8dd8a3188b79fd8f-s.2o9_j983y90g0.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Serif Display;font-style:normal;font-weight:400;font-display:swap;src:url(../media/0c8f209abc35ee02-s.p.0c0g8ifvh7k7-.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Serif Display Fallback;src:local(Times New Roman);ascent-override:94.37%;descent-override:30.51%;line-gap-override:0.0%;size-adjust:109.78%}.dm_serif_display_4d81df74-module__Zko9_W__className{font-family:DM Serif Display,DM Serif Display Fallback;font-style:normal;font-weight:400}.dm_serif_display_4d81df74-module__Zko9_W__variable{--font-serif:"DM Serif Display", "DM Serif Display Fallback"}
@font-face{font-family:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/b12e986493c137cf-s.2njitm-prmz2_.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/36363bfb06833f56-s.p.38hmww4cj4vme.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/b2fa3ef4ca165ab4-s.12_ml6bnugnre.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/a73419dd2ba2d841-s.p.2yee423r7ahpo.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Mono Fallback;src:local(Arial);ascent-override:73.71%;descent-override:23.03%;line-gap-override:0.0%;size-adjust:134.59%}.dm_mono_5206bcc3-module__hEa1Ka__className{font-family:DM Mono,DM Mono Fallback;font-style:normal}.dm_mono_5206bcc3-module__hEa1Ka__variable{--font-mono:"DM Mono", "DM Mono Fallback"}
@font-face{font-family:DM Sans;font-style:normal;font-weight:300;font-display:swap;src:url(../media/c3cb240f9c892514-s.3z_x6eowsw16y.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:300;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.2_mbdogr7ni8i.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/c3cb240f9c892514-s.3z_x6eowsw16y.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.2_mbdogr7ni8i.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/c3cb240f9c892514-s.3z_x6eowsw16y.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.2_mbdogr7ni8i.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Fallback;src:local(Arial);ascent-override:94.9%;descent-override:29.66%;line-gap-override:0.0%;size-adjust:104.53%}.dm_sans_59c50d2d-module__tdxUBq__className{font-family:DM Sans,DM Sans Fallback;font-style:normal}.dm_sans_59c50d2d-module__tdxUBq__variable{--font-sans:"DM Sans", "DM Sans Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial}}}@layer theme{:root,:host{--font-sans:"DM Sans", sans-serif;--font-serif:"DM Serif Display", Georgia, serif;--font-mono:"DM Mono", monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"DM Sans", sans-serif;--default-mono-font-family:"DM Mono", monospace;--color-bg:#070e0c;--color-bg2:#0d1f1a;--color-surface:#111f1c;--color-border:#1e3830;--color-jun:#3d9e8a;--color-frost:#6ecfbc;--color-mist:#d4ede8;--color-dim:#6a9088;--color-amber:#c17f3a;--color-gold:#e8c96a}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--color-bg);color:var(--color-mist);font-weight:300;line-height:1.7;overflow-x:hidden}.light{--color-bg:#f2faf8;--color-bg2:#e4f4f0;--color-surface:#d6ede8;--color-border:#b2d9d0;--color-jun:#2a8070;--color-frost:#3d9e8a;--color-mist:#0d2620;--color-dim:#2d6a5e;--color-amber:#a6621e;--color-gold:#c4993a;--color-pine:#7abfb4}.light nav{background:#070e0cd9}@supports (color:color-mix(in lab, red, red)){.light nav{background:color-mix(in srgb, var(--color-bg) 85%, transparent)}}.theme-toggle,.lang-toggle{font-family:var(--font-mono);border:1px solid var(--color-border);color:var(--color-dim);cursor:pointer;letter-spacing:.06em;background:0 0;padding:5px 10px;font-size:12px;line-height:1;transition:border-color .2s,color .2s}.theme-toggle:hover,.lang-toggle:hover{border-color:var(--color-jun);color:var(--color-jun)}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-jun);border-radius:2px}.logo{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.08em;font-size:13px;font-weight:500;text-decoration:none}.nav-right{align-items:center;gap:2.5rem;display:flex}.nav-links{gap:2rem;list-style:none;display:flex}.nav-links a{font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.06em;font-size:12px;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--color-frost)}.nav-cta{font-family:var(--font-mono);border:1px solid var(--color-jun);color:var(--color-jun);letter-spacing:.06em;padding:7px 18px;font-size:12px;text-decoration:none;transition:background .2s,color .2s}.nav-cta:hover{background:var(--color-jun);color:var(--color-bg)}.hero-tag{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.12em;align-items:center;gap:8px;margin-bottom:2rem;font-size:11px;display:inline-flex}.hero-tag:before{content:"";background:var(--color-jun);width:24px;height:1px;display:block}.hero-name{font-family:var(--font-serif);color:var(--color-mist);letter-spacing:-.02em;margin-bottom:1.5rem;font-size:clamp(3rem,5.5vw,5.5rem);line-height:.95}.hero-name em{color:var(--color-jun);font-style:italic}.hero-desc{color:var(--color-dim);max-width:400px;margin-bottom:2.5rem;font-size:16px;line-height:1.75}.hero-actions{align-items:center;gap:1rem;display:flex}.btn-primary{font-family:var(--font-mono);letter-spacing:.08em;background:var(--color-jun);color:var(--color-bg);padding:12px 28px;font-size:12px;font-weight:500;text-decoration:none;transition:background .2s,transform .15s;display:inline-block}.btn-primary:hover{background:var(--color-frost);transform:translateY(-1px)}.btn-ghost{font-family:var(--font-mono);letter-spacing:.08em;border:1px solid var(--color-border);color:var(--color-dim);padding:12px 28px;font-size:12px;text-decoration:none;transition:border-color .2s,color .2s;display:inline-block}.btn-ghost:hover{border-color:var(--color-jun);color:var(--color-jun)}body:before{content:"";z-index:0;pointer-events:none;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px 200px;position:fixed;inset:0}nav{z-index:100;-webkit-backdrop-filter:blur(20px);background:#070e0ccc;justify-content:space-between;align-items:center;padding:1.5rem 3rem;display:flex;position:fixed;top:0;left:0;right:0}@supports (color:color-mix(in lab, red, red)){nav{background:color-mix(in srgb, var(--color-bg) 80%, transparent)}}nav{border-bottom:1px solid var(--color-border)}#hero{align-items:center;min-height:100vh;padding:8rem 3rem 4rem;display:flex;position:relative;overflow:hidden}.hero-content{z-index:10;opacity:0;width:100%;max-width:640px;margin-left:calc(50vw - 600px);padding:0 3rem;animation:.9s .1s forwards fadeUp;position:relative;transform:translateY(30px)}.hero-badge{border:1px solid #3d9e8a4d;border-radius:9999px;align-items:center;gap:8px;padding:6px 16px;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.hero-badge{border:1px solid color-mix(in srgb, var(--color-jun) 30%, transparent)}}.hero-badge{background:#3d9e8a1a}@supports (color:color-mix(in lab, red, red)){.hero-badge{background:color-mix(in srgb, var(--color-jun) 10%, transparent)}}.hero-badge{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.1em;margin-bottom:2rem;font-size:11px}.hero-badge-dot{background:var(--color-jun);width:6px;height:6px;box-shadow:0 0 8px var(--color-jun);border-radius:50%;animation:2.5s infinite pulse}@keyframes pulse{50%{opacity:.5}}.hero-gradient-text{background:linear-gradient(to right, var(--color-jun), var(--color-frost), var(--color-mist));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-role{font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.12em;min-height:1.7em;margin-bottom:1.5rem;font-size:14px}.hero-role-text{animation:.5s fadeRole;display:inline-block}.hero-role-cursor{color:var(--color-jun);margin-left:4px;font-weight:400;animation:1s step-end infinite blink;display:inline-block}@keyframes fadeRole{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-visual{z-index:1;width:50%;height:100%;position:absolute;bottom:0;right:0;overflow:hidden}.hero-visual img{object-fit:cover;object-position:center;opacity:.85;mix-blend-mode:multiply;width:100%;height:100%;-webkit-mask-image:radial-gradient(at 70%,#000 30%,#0000 85%);mask-image:radial-gradient(at 70%,#000 30%,#0000 85%)}.light .hero-visual img{mix-blend-mode:normal;opacity:.95}.hero-gradient-overlay{z-index:0;background:linear-gradient(to bottom right, var(--color-bg), #3d9e8a1f, var(--color-bg));position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.hero-gradient-overlay{background:linear-gradient(to bottom right, var(--color-bg), color-mix(in srgb, var(--color-jun) 12%, transparent), var(--color-bg))}}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}.section{max-width:1200px;margin:0 auto;padding:7rem 3rem;position:relative}.section-header{align-items:baseline;gap:1.5rem;margin-bottom:4rem;display:flex}.section-index{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.12em;font-size:11px}.section-title{font-family:var(--font-serif);color:var(--color-mist);letter-spacing:-.02em;font-size:clamp(2rem,3.5vw,3rem);line-height:1.1}.about-grid{grid-template-columns:1.2fr 1fr;align-items:start;gap:5rem;display:grid}.about-text p{color:var(--color-dim);margin-bottom:1.25rem;font-size:16px;line-height:1.8}.about-text p strong{color:var(--color-mist);font-weight:500}.about-links{flex-wrap:wrap;gap:1rem;margin-top:2rem;display:flex}.about-link{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.08em;align-items:center;gap:6px;font-size:11px;text-decoration:none;transition:color .2s;display:flex}.about-link:hover{color:var(--color-frost)}.about-link:after{content:"↗";font-size:10px}.stack-title{font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.25rem;font-size:11px}.stack-grid{background:var(--color-border);border:1px solid var(--color-border);grid-template-columns:1fr 1fr;gap:2px;display:grid}.stack-item{background:var(--color-surface);color:var(--color-mist);align-items:center;gap:10px;padding:.875rem 1rem;font-size:13px;transition:background .2s;display:flex}.stack-item:hover{background:var(--color-bg2)}.stack-icon{color:var(--color-jun);flex-shrink:0}.stack-icon.amber{color:var(--color-amber)}.tag-icon{vertical-align:middle;margin-right:4px;display:inline}.projects-intro{color:var(--color-dim);max-width:520px;margin-bottom:3rem;font-size:16px}.pc-img{aspect-ratio:16/11;border:1px solid var(--color-border);border-radius:6px;width:100%;transition:border-color .25s;overflow:hidden}.pc-img img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.project-card:hover .pc-img{border-color:var(--color-jun)}.project-card:hover .pc-img img{transform:scale(1.05)}.project-info{flex-direction:column;gap:1rem;padding:2.5rem;display:flex}.project-index{font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.12em;font-size:10px}.project-title{font-family:var(--font-serif);color:var(--color-mist);letter-spacing:-.01em;font-size:1.75rem;line-height:1.1}.project-desc{color:var(--color-dim);font-size:14px;line-height:1.75}.project-stack{flex-wrap:wrap;gap:6px;display:flex}.ptag{font-family:var(--font-mono);letter-spacing:.06em;border:1px solid var(--color-border);color:var(--color-dim);padding:3px 9px;font-size:10px}.ptag.hi{border-color:#3d9e8a4f}@supports (color:color-mix(in lab, red, red)){.ptag.hi{border-color:color-mix(in srgb, var(--color-jun) 31%, transparent)}}.ptag.hi{color:var(--color-jun)}.project-badge{font-family:var(--font-mono);color:var(--color-gold);letter-spacing:.08em;align-items:center;gap:6px;font-size:10px;display:inline-flex}.project-links{gap:10px;margin-top:auto;display:flex}.plink{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.06em;border:1px solid #3d9e8a40;padding:6px 14px;font-size:11px;text-decoration:none}@supports (color:color-mix(in lab, red, red)){.plink{border:1px solid color-mix(in srgb, var(--color-jun) 25%, transparent)}}.plink{transition:background .15s,color .15s}.plink:hover{background:var(--color-jun);color:var(--color-bg)}.plink.ghost{color:var(--color-dim);border-color:var(--color-border)}.plink.ghost:hover{border-color:var(--color-dim);color:var(--color-mist)}.projects-grid{background:var(--color-border);grid-template-columns:repeat(3,1fr);gap:2px;margin-top:2px;display:grid}.project-card{background:var(--color-surface);cursor:default;flex-direction:column;gap:.875rem;padding:1.75rem;transition:background .2s;display:flex}.project-card:hover{background:var(--color-bg2)}.pc-num{font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.1em;font-size:10px}.pc-title{font-family:var(--font-serif);color:var(--color-mist);font-size:1.2rem;line-height:1.2}.pc-desc{color:var(--color-dim);font-size:13px;line-height:1.7}.pc-stack{flex-wrap:wrap;gap:5px;display:flex}.pctag{font-family:var(--font-mono);letter-spacing:.05em;border:1px solid var(--color-border);color:var(--color-dim);padding:2px 7px;font-size:9px}.pc-footer{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-top:auto;padding-top:.875rem;display:flex}.pc-badge{font-family:var(--font-mono);color:var(--color-gold);font-size:10px}.pc-link{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.06em;font-size:10px;text-decoration:none;transition:color .2s}.pc-link:hover{color:var(--color-frost)}.skills-layout{grid-template-columns:1fr;gap:2rem;max-width:640px;display:grid}.skill-category{margin-bottom:2.5rem}.skill-cat-name{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid var(--color-border);margin-bottom:1.25rem;padding-bottom:.75rem;font-size:10px}.skill-row{border-bottom:1px solid #1e383080;justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}@supports (color:color-mix(in lab, red, red)){.skill-row{border-bottom:1px solid color-mix(in srgb, var(--color-border) 50%, transparent)}}.skill-row:last-child{border-bottom:none}.skill-name{color:var(--color-mist);font-size:14px;font-weight:400}.skill-bar-wrap{align-items:center;gap:12px;display:flex}.skill-dots{gap:4px;display:flex}.skill-dot{background:var(--color-border);border-radius:1px;width:6px;height:6px}.skill-dot.on{background:var(--color-jun)}.skill-dot.on.amber{background:var(--color-amber)}.skill-pct{font-family:var(--font-mono);color:var(--color-dim);text-align:right;width:28px;font-size:11px}.contact-wrap{max-width:640px;margin:0 auto}.contact-eyebrow{font-family:var(--font-mono);color:var(--color-jun);letter-spacing:.14em;margin-bottom:1.5rem;font-size:11px;display:block}.contact-title{font-family:var(--font-serif);color:var(--color-mist);letter-spacing:-.03em;margin-bottom:1.25rem;font-size:clamp(2.5rem,5vw,4.5rem);line-height:1}.contact-title em{color:var(--color-jun);font-style:italic}.contact-sub{color:var(--color-dim);margin-bottom:3rem;font-size:16px;line-height:1.7}.contact-email{font-family:var(--font-serif);color:var(--color-jun);margin-bottom:3rem;font-size:1.5rem;font-style:italic;text-decoration:none;transition:color .2s;display:block}.contact-email:hover{color:var(--color-frost)}.contact-divider{background:var(--color-border);width:40px;height:1px;margin:2rem auto}.social-links{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.social-link{font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.08em;font-size:11px;text-decoration:none;transition:color .2s}.social-link:hover{color:var(--color-jun)}footer{border-top:1px solid var(--color-border);font-family:var(--font-mono);color:var(--color-dim);letter-spacing:.06em;justify-content:space-between;align-items:center;padding:2rem 3rem;font-size:11px;display:flex}footer a{color:var(--color-jun);text-decoration:none}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(24px)}.reveal.visible{opacity:1;transform:translateY(0)}@media (max-width:1200px){.projects-grid{grid-template-columns:repeat(2,1fr)}.hero-content{max-width:520px;margin-left:0}}@media (max-width:1024px){.hero-visual{width:40%}.hero-content{max-width:440px}.hero-name{font-size:clamp(2.5rem,5vw,4rem)}}@media (max-width:900px){#hero{text-align:center;flex-direction:column;padding:7rem 1.5rem 3rem}.hero-visual{display:none}.hero-content{flex-direction:column;align-items:center;max-width:100%;padding:0 1.5rem;display:flex}.hero-desc{max-width:100%}.hero-actions{flex-wrap:wrap;justify-content:center}.about-grid{grid-template-columns:1fr;gap:2.5rem}.projects-grid{grid-template-columns:1fr}.skills-layout{max-width:100%}nav{padding:1.25rem 1.5rem}.nav-links{display:none}.section{padding:5rem 1.5rem}.section-header{flex-direction:column;gap:.5rem}footer{text-align:center;flex-direction:column;gap:.75rem}.stack-grid{grid-template-columns:1fr}.contact-email{word-break:break-all;font-size:1.25rem}.social-links{gap:1rem}}@media (max-width:600px){#hero{padding:6rem 1rem 2rem}.hero-name{font-size:clamp(2rem,10vw,2.8rem)}.hero-desc{font-size:14px}.hero-role{font-size:12px}.btn-primary,.btn-ghost{padding:10px 20px;font-size:11px}.section{padding:3.5rem 1rem}nav{padding:1rem}.nav-right{gap:.75rem}.theme-toggle,.lang-toggle{padding:4px 7px;font-size:10px}.nav-cta{padding:5px 12px;font-size:10px}.project-card{padding:1.25rem}.pc-title{font-size:1rem}.pc-desc{font-size:12px}.pc-img{aspect-ratio:16/9}.project-links{flex-direction:column;gap:6px}.plink{text-align:center;padding:5px 10px;font-size:10px}.pc-footer{flex-direction:column;gap:.75rem}.contact-title{font-size:clamp(2rem,8vw,2.5rem)}.contact-email{font-size:1.1rem}footer{padding:1.5rem 1rem;font-size:10px}.stack-grid{grid-template-columns:1fr 1fr}.stack-item{padding:.625rem .75rem;font-size:12px}}@media (max-width:400px){.stack-grid{grid-template-columns:1fr}.hero-actions{flex-direction:column;align-items:stretch}.btn-primary,.btn-ghost{text-align:center}.about-links{flex-direction:column;align-items:center}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}
