@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;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-serif:ui-serif,Georgia,Cambria,"Times New Roman",Times,serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--font-weight-bold:700;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@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{.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.my-6{margin-block:calc(var(--spacing)*6)}.mt-8{margin-top:calc(var(--spacing)*8)}.contents{display:contents}.flex{display:flex}.inline{display:inline}.table{display:table}.min-h-screen{min-height:100vh}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.leading-none{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.italic{font-style:italic}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.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))}}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;overflow-x:hidden;background:var(--bg)!important}:root{--bg:#fbfaf9;--bg-raised:#fff;--bg-hover:#f4f2ef;--bg-muted:#f1efec;--fg:#191918;--fg-2:#37352f;--fg-3:#787771;--fg-4:#a5a39b;--border:#e8e6e1;--border-strong:#d7d4cc;--accent:#111;--accent-soft:#efefee;--accent-fg:#111;--shadow-sm:0 1px 2px #11100f0a,0 2px 6px #11100f08;--shadow-md:0 8px 24px #11100f0f,0 2px 6px #11100f0a;--shadow-lg:0 24px 48px #11100f14,0 4px 12px #11100f0d;--shadow-pop:0 20px 60px #11100f24,0 4px 12px #11100f14;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--sans:var(--font-inter),"Inter","Zen Kaku Gothic New",-apple-system,BlinkMacSystemFont,sans-serif;--mono:var(--font-mono),"JetBrains Mono",ui-monospace,monospace;--serif:var(--font-serif),"Instrument Serif","Times New Roman",serif;--jp:var(--font-jp),"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;--hero-title-size:36px;--section-heading-size:32px;--detail-title-size:28px;--section-px:6%;--section-pr:6%}@media (min-width:768px){:root{--hero-title-size:5vw;--section-heading-size:4vw;--detail-title-size:3.5vw;--section-px:10%;--section-pr:8vw}}@media (min-width:1024px){:root{--hero-title-size:6vw;--section-heading-size:5vw;--detail-title-size:4vw}}[data-theme=dark]{--bg:#0b0b0d;--bg-raised:#131316;--bg-hover:#1a1a1f;--bg-muted:#16161a;--fg:#f4f4f5;--fg-2:#e4e4e7;--fg-3:#8b8b93;--fg-4:#5a5a63;--border:#232328;--border-strong:#33333a;--accent:#f5f5f5;--accent-soft:#1c1c1c;--accent-fg:#f5f5f5;--shadow-sm:0 1px 2px #0003,0 2px 6px #00000026;--shadow-md:0 8px 24px #0006,0 2px 6px #00000040;--shadow-lg:0 24px 48px #00000080,0 4px 12px #0000004d;--shadow-pop:0 24px 70px #0000008c,0 6px 16px #00000059}body{font-family:var(--sans);font-feature-settings:"cv11","ss01","ss03";background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;transition:background .4s,color .4s}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}::selection{background:var(--accent);color:var(--bg)}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 24px}@media (min-width:768px){.container{padding:0 48px}}.mono{font-family:var(--mono);font-feature-settings:"zero","ss01"}.serif{font-family:var(--serif)}.jp{font-family:var(--jp)}.nav{z-index:40;background:var(--bg);position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.nav{background:color-mix(in oklab,var(--bg)80%,transparent)}}.nav{-webkit-backdrop-filter:saturate(140%)blur(16px);border-bottom:1px solid #0000;transition:border-color .3s}.nav.scrolled{border-bottom-color:var(--border)}.nav-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:14px 24px;display:flex}@media (min-width:768px){.nav-inner{padding:14px 48px}}.brand{letter-spacing:-.01em;align-items:center;gap:10px;font-size:15px;font-weight:600;display:flex}.brand-mark{background:var(--fg);width:26px;height:26px;color:var(--bg);font-family:var(--serif);border-radius:7px;justify-content:center;align-items:center;font-size:16px;font-style:italic;font-weight:400;display:flex;position:relative;overflow:hidden}.brand-mark:after{content:"";background:radial-gradient(circle at 30% 20%,#ffffff2e,#0000 60%);position:absolute;inset:0}.brand-name{color:var(--fg)}.brand-name em{color:var(--fg-3);margin-left:6px;font-style:normal;font-weight:400}.nav-right{align-items:center;gap:4px;display:flex}.nav-links{gap:2px;margin-right:8px;display:none}@media (min-width:720px){.nav-links{display:flex}}.nav-link{border-radius:var(--radius-sm);color:var(--fg-3);padding:6px 12px;font-size:13.5px;font-weight:450;transition:background .15s,color .15s}.nav-link:hover{background:var(--bg-hover);color:var(--fg)}.icon-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--fg-3);justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.icon-btn:hover{background:var(--bg-hover);color:var(--fg)}.hero{padding:120px 0 80px;position:relative}@media (min-width:768px){.hero{padding:160px 0 120px}}.hero-badge{background:var(--bg-raised);border:1px solid var(--border);color:var(--fg-2);box-shadow:var(--shadow-sm);border-radius:999px;align-items:center;gap:8px;margin-bottom:36px;padding:5px 12px 5px 6px;font-size:12.5px;font-weight:450;transition:border-color .2s,transform .2s;display:inline-flex}.hero-badge:hover{border-color:var(--border-strong);transform:translateY(-1px)}.hero-badge .pill{background:var(--accent-soft);color:var(--accent-fg);letter-spacing:.01em;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:550}.hero-badge .arrow{color:var(--fg-3);transition:transform .2s}.hero-badge:hover .arrow{transform:translate(2px)}.hero-title{font-family:var(--sans);letter-spacing:-.035em;color:var(--fg);text-wrap:balance;max-width:860px;margin-bottom:28px;font-size:clamp(42px,6.5vw,76px);font-weight:600;line-height:1.04}.hero-title em{font-family:var(--serif);letter-spacing:-.02em;color:var(--fg-2);font-style:italic;font-weight:400}.hero-title .accent{color:var(--accent-fg);background:linear-gradient(transparent 65%,var(--accent-soft)65%);padding:0 4px}[data-theme=dark] .hero-title .accent{color:var(--accent);background:linear-gradient(transparent 65%,var(--accent-soft)65%)}.hero-sub{color:var(--fg-3);max-width:580px;margin-bottom:40px;font-size:17px;font-weight:400;line-height:1.65}.hero-sub strong{color:var(--fg-2);font-weight:550}.hero-ctas{flex-wrap:wrap;gap:10px;display:flex}.btn{border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:9px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--fg);color:var(--bg);box-shadow:var(--shadow-sm),inset 0 1px 0 #ffffff1a}.btn-primary:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-raised);color:var(--fg);border-color:var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.hero-stats{border-top:1px solid var(--border);grid-template-columns:repeat(2,1fr);gap:0;margin-top:64px;display:grid}@media (min-width:640px){.hero-stats{grid-template-columns:repeat(4,1fr)}}.hero-stat{border-right:1px solid var(--border);padding:20px 16px 20px 0}.hero-stat:last-child{border-right:none}@media (max-width:639px){.hero-stat:nth-child(2n){border-right:none}.hero-stat:nth-child(n+3){border-top:1px solid var(--border);padding-top:20px}}.hero-stat-v{letter-spacing:-.02em;color:var(--fg);align-items:baseline;gap:3px;font-size:24px;font-weight:600;display:flex}.hero-stat-v .unit{color:var(--fg-3);letter-spacing:0;font-size:14px;font-weight:500}.hero-stat-k{color:var(--fg-3);letter-spacing:0;margin-top:4px;font-size:12px;font-weight:450}.section{padding:80px 0;position:relative}@media (min-width:768px){.section{padding:110px 0}}.section-label{font-family:var(--mono);color:var(--fg-3);letter-spacing:.02em;align-items:center;gap:8px;margin-bottom:14px;font-size:12px;font-weight:500;display:inline-flex}.section-label:before{content:"";background:var(--accent);border-radius:50%;width:5px;height:5px}.section-title{letter-spacing:-.025em;color:var(--fg);text-wrap:balance;margin-bottom:10px;font-size:clamp(26px,3vw,34px);font-weight:600}.section-desc{color:var(--fg-3);max-width:560px;margin-bottom:48px;font-size:15.5px;line-height:1.65}.projects{grid-template-columns:1fr;gap:12px;display:grid}@media (min-width:900px){.projects{grid-template-columns:1fr 1fr;gap:16px}}.project-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;min-height:280px;padding:24px;transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.project-head{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.project-mark{background:var(--bg-muted);border:1px solid var(--border);width:36px;height:36px;color:var(--fg-2);font-family:var(--serif);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-style:italic;display:flex;overflow:hidden}.project-mark.has-img{background:0 0;padding:0}.project-mark img{object-fit:cover;width:100%;height:100%;display:block}.project-status{color:var(--fg-3);font-size:11.5px;font-family:var(--mono);letter-spacing:.01em;align-items:center;gap:6px;display:inline-flex}.project-status .dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 0 3px var(--accent-soft);border-radius:50%}.project-title{letter-spacing:-.02em;color:var(--fg);align-items:center;gap:10px;margin-bottom:6px;font-size:22px;font-weight:600;display:flex}.project-title .ext{color:var(--fg-3);font-size:14px;transition:transform .2s,color .2s}.project-card:hover .project-title .ext{color:var(--accent-fg);transform:translate(2px,-2px)}[data-theme=dark] .project-card:hover .project-title .ext{color:var(--accent)}.project-desc{color:var(--fg-3);font-size:14px;line-height:1.65;font-family:var(--jp);flex:1;margin-bottom:20px;font-weight:400}.project-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;display:flex}.project-meta-cell{flex-direction:column;gap:2px;display:flex}.project-meta-cell .k{color:var(--fg-4);font-size:10.5px;font-family:var(--mono);letter-spacing:.02em}.project-meta-cell .v{color:var(--fg-2);font-size:12.5px;font-weight:500}.project-meta-sep{background:var(--border);width:1px;height:22px}.project-tags{flex-wrap:wrap;gap:5px;margin-top:auto;display:flex}.tag{background:var(--bg-muted);color:var(--fg-2);font-size:11px;font-weight:450;font-family:var(--mono);letter-spacing:0;border-radius:5px;padding:3px 8px}.cursor-preview{border-radius:var(--radius-lg);background:var(--bg-raised);border:1px solid var(--border);width:320px;height:200px;box-shadow:var(--shadow-pop);pointer-events:none;z-index:60;opacity:0;transition:opacity .18s,transform .18s;position:fixed;top:0;left:0;overflow:hidden;transform:translate(-50%,16px)scale(.96)}.cursor-preview.show{opacity:1;transform:translate(-50%,16px)scale(1)}.cursor-preview-body{width:100%;height:100%;color:var(--fg-3);background:radial-gradient(circle at 50% 0%,var(--accent)0%,transparent 60%),var(--bg-muted);justify-content:center;align-items:center;display:flex;position:relative}@supports (color:color-mix(in lab, red, red)){.cursor-preview-body{background:radial-gradient(circle at 50% 0%,color-mix(in oklab,var(--accent)18%,transparent)0%,transparent 60%),var(--bg-muted)}}.cursor-preview-chrome{border-bottom:1px solid var(--border);background:var(--bg-raised);align-items:center;gap:6px;height:30px;padding:0 12px;display:flex;position:absolute;top:0;left:0;right:0}.cursor-preview-chrome .dot{background:var(--border-strong);border-radius:50%;width:9px;height:9px}.cursor-preview-chrome .url{font-family:var(--mono);color:var(--fg-4);margin-left:auto;font-size:10.5px}.cursor-preview-big{font-family:var(--serif);color:var(--accent);opacity:.85;font-size:88px;font-style:italic;line-height:1}.cursor-preview-img{object-fit:cover;border-radius:22px;width:108px;height:108px;display:block;box-shadow:0 12px 30px #0000002e,0 2px 6px #00000014}.cursor-preview-label{font-family:var(--mono);color:var(--fg-3);align-items:center;gap:6px;font-size:11px;display:flex;position:absolute;bottom:10px;left:12px}.cursor-preview-label .live{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.6s infinite pulseDot}@keyframes pulseDot{0%,to{opacity:1}50%{opacity:.3}}.about-grid{grid-template-columns:1fr;gap:48px;display:grid}@media (min-width:900px){.about-grid{grid-template-columns:1fr 1fr;gap:72px}}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom,var(--border-strong),var(--border)80%,transparent);width:1px;position:absolute;top:6px;bottom:6px;left:4px}.milestone{padding:8px 0 24px;position:relative}.milestone:before{content:"";background:var(--bg);border:2px solid var(--border-strong);border-radius:50%;width:9px;height:9px;position:absolute;top:12px;left:-23px}.milestone.now:before{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.milestone-year{font-family:var(--mono);color:var(--fg-3);letter-spacing:.02em;margin-bottom:4px;font-size:11.5px;font-weight:500}.milestone.now .milestone-year{color:var(--accent-fg)}[data-theme=dark] .milestone.now .milestone-year{color:var(--accent)}.milestone-text{color:var(--fg);font-size:15px;font-weight:500;line-height:1.45;font-family:var(--jp);margin-bottom:3px}.milestone-text a{color:inherit;border-bottom:1px solid var(--border-strong);transition:border-color .2s,color .2s}.milestone-text a:hover{color:var(--accent-fg);border-bottom-color:var(--accent)}[data-theme=dark] .milestone-text a:hover{color:var(--accent)}.milestone-sub{color:var(--fg-3);font-size:13px;line-height:1.55;font-family:var(--jp);font-weight:400}.philosophy-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:32px}.philosophy-mark{font-family:var(--serif);color:var(--accent);opacity:.7;margin-bottom:18px;font-size:56px;font-style:italic;line-height:.4}.philosophy-text{font-family:var(--jp);color:var(--fg);letter-spacing:.005em;margin-bottom:20px;font-size:18px;font-weight:500;line-height:1.75}.philosophy-foot{font-family:var(--jp);color:var(--fg-3);font-size:13.5px;font-weight:400;line-height:1.75}.caps{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--border);grid-template-columns:1fr;gap:1px;display:grid;overflow:hidden}@media (min-width:700px){.caps{grid-template-columns:1fr 1fr}}.cap-cell{background:var(--bg-raised);flex-direction:column;gap:10px;padding:28px 28px 30px;transition:background .2s;display:flex;position:relative}.cap-cell:hover{background:var(--bg-hover)}.cap-k{font-family:var(--mono);color:var(--accent-fg);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:600}.cap-t{font-family:var(--sans);letter-spacing:-.01em;color:var(--fg);font-size:19px;font-weight:550;line-height:1.4}.cap-d{color:var(--fg-3);font-size:14px;line-height:1.7;font-family:var(--jp);margin-top:2px}.skills{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--border);grid-template-columns:1fr;gap:1px;display:grid;overflow:hidden}@media (min-width:700px){.skills{grid-template-columns:1fr 1fr}}.skill-cell{background:var(--bg-raised);flex-direction:column;gap:10px;padding:22px 24px;transition:background .2s;display:flex}.skill-cell:hover{background:var(--bg-hover)}.skill-head{font-family:var(--mono);color:var(--fg-3);letter-spacing:.02em;text-transform:uppercase;align-items:center;gap:8px;font-size:11px;font-weight:500;display:flex}.skill-head .ico{width:14px;height:14px;color:var(--fg-3)}.skill-items{flex-wrap:wrap;gap:6px;display:flex}.skill-item{color:var(--fg);background:var(--bg-muted);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:13.5px;font-weight:450}.contact-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:48px;position:relative;overflow:hidden}.contact-card:before{content:"";background:radial-gradient(circle,var(--accent),transparent 70%);width:340px;height:340px;position:absolute;top:-120px;right:-120px}@supports (color:color-mix(in lab, red, red)){.contact-card:before{background:radial-gradient(circle,color-mix(in oklab,var(--accent)16%,transparent),transparent 70%)}}.contact-card:before{pointer-events:none}.contact-headline{letter-spacing:-.025em;color:var(--fg);max-width:620px;margin-bottom:16px;font-size:clamp(28px,4vw,42px);font-weight:600;line-height:1.15;position:relative}.contact-headline em{font-family:var(--serif);font-style:italic;font-weight:400}.contact-blurb{font-family:var(--jp);color:var(--fg-3);max-width:540px;margin-bottom:32px;font-size:15px;font-weight:400;line-height:1.75;position:relative}.contact-links{grid-template-columns:1fr;gap:8px;display:grid;position:relative}@media (min-width:640px){.contact-links{grid-template-columns:1fr 1fr}}.contact-link{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:14px 16px;transition:all .15s;display:flex}.contact-link:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}[data-theme=dark] .contact-link:hover{background:var(--bg-hover)}.contact-link-l{align-items:center;gap:10px;display:flex}.contact-link-k{font-family:var(--mono);color:var(--fg-3);letter-spacing:.02em;text-transform:uppercase;font-size:11px}.contact-link-v{color:var(--fg);letter-spacing:-.005em;font-size:14.5px;font-weight:500}.contact-link .ext{color:var(--fg-3);font-family:var(--mono);font-size:12px;transition:transform .15s}.contact-link:hover .ext{color:var(--accent-fg);transform:translate(2px,-2px)}[data-theme=dark] .contact-link:hover .ext{color:var(--accent)}.footer{border-top:1px solid var(--border);padding:40px 0 48px}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.footer-brand{color:var(--fg-3);align-items:center;gap:10px;font-size:13.5px;font-weight:500;display:flex}.footer-meta{font-family:var(--mono);color:var(--fg-4);letter-spacing:.02em;font-size:11.5px}.reveal{opacity:0;transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1);transform:translateY(14px)}.reveal.in{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transition:none;transform:none}}.toc{z-index:30;pointer-events:auto;flex-direction:column;gap:6px;display:none;position:fixed;top:50%;right:24px;transform:translateY(-50%)}@media (min-width:1200px){.toc{display:flex}}.toc-item{font-family:var(--mono);color:var(--fg-4);align-items:center;gap:10px;padding:4px 0;font-size:11px;transition:color .2s;display:flex}.toc-item .bar{transform-origin:100%;background:currentColor;width:20px;height:1px;transition:transform .24s cubic-bezier(.2,.8,.2,1),background-color .24s}.toc-item:hover,.toc-item.active{color:var(--fg)}.toc-item.active .bar{background:var(--accent);transform:scaleX(1.4)}.kbd{font-family:var(--mono);background:var(--bg-muted);border:1px solid var(--border);box-shadow:0 1px 0 var(--border);color:var(--fg-2);border-radius:4px;padding:1px 6px;font-size:11px}.detail-header{padding:96px 0 28px}@media (min-width:768px){.detail-header{padding:132px 0 36px}}.detail-badge-row{margin-bottom:28px;display:flex}.detail-head{align-items:flex-start;gap:20px;margin-bottom:26px;display:flex}.detail-head .project-mark{border-radius:14px;flex-shrink:0;width:58px;height:58px;font-size:30px}.detail-head-body{min-width:0}.detail-title{font-family:var(--sans);letter-spacing:-.03em;color:var(--fg);text-wrap:balance;margin-top:6px;font-size:clamp(30px,4.8vw,52px);font-weight:600;line-height:1.08}.detail-lead{font-family:var(--jp);color:var(--fg-3);max-width:680px;margin-bottom:30px;font-size:17px;font-weight:400;line-height:1.75}.detail-meta{border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:28px;padding:18px 0;display:flex}.detail-meta .meta-cell{flex-direction:column;gap:2px;display:flex}.detail-meta .meta-cell .k{color:var(--fg-4);font-size:10.5px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}.detail-meta .meta-cell .v{color:var(--fg-2);align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.detail-meta .meta-cell .v .dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 0 3px var(--accent-soft);border-radius:50%}.detail-meta .meta-sep{background:var(--border);width:1px;height:22px}.detail-tags{flex-wrap:wrap;gap:5px;display:flex}.detail-content{padding:40px 0 80px}@media (min-width:768px){.detail-content{padding:60px 0 120px}}.project-content{font-family:var(--jp);color:var(--fg-2);max-width:720px}.project-content>:first-child{margin-top:0}.project-content h1{font-family:var(--sans);letter-spacing:-.025em;color:var(--fg);margin:48px 0 18px;font-size:30px;font-weight:600;line-height:1.2}.project-content h2{font-family:var(--sans);letter-spacing:-.02em;color:var(--fg);border-top:1px solid var(--border);margin:56px 0 16px;padding-top:28px;font-size:22px;font-weight:600;line-height:1.3}.project-content h3{font-family:var(--sans);letter-spacing:-.005em;color:var(--fg);margin:32px 0 10px;font-size:17px;font-weight:600;line-height:1.4}.project-content p{font-family:var(--jp);color:var(--fg-2);margin-bottom:16px;font-size:15px;font-weight:400;line-height:1.9}.project-content strong{color:var(--fg);font-weight:600}.project-content ul,.project-content ol{font-family:var(--jp);color:var(--fg-2);margin-bottom:16px;padding-left:22px;font-size:15px;font-weight:400;line-height:1.9}.project-content li{margin-bottom:6px}.project-content li::marker{color:var(--fg-4)}.project-content a{color:var(--fg);border-bottom:1px solid var(--border-strong);transition:border-color .15s,color .15s}.project-content a:hover{color:var(--accent-fg);border-bottom-color:var(--accent)}[data-theme=dark] .project-content a:hover{color:var(--accent)}.project-content code{font-family:var(--mono);background:var(--bg-muted);border:1px solid var(--border);color:var(--fg);border-radius:4px;padding:1px 6px;font-size:12.5px}.project-content pre{font-family:var(--mono);background:var(--bg-muted);border:1px solid var(--border);color:var(--fg-2);border-radius:var(--radius-md);margin:20px 0;padding:20px;font-size:13px;line-height:1.7;overflow-x:auto}.project-content pre code{color:inherit;font-size:inherit;background:0 0;border:none;padding:0}.project-content blockquote{border-left:2px solid var(--border-strong);color:var(--fg-3);margin:20px 0;padding:2px 0 2px 20px;font-style:italic}.project-content hr{border:none;border-top:1px solid var(--border);margin:40px 0}@media (max-width:767px){.project-content h1{font-size:24px}.project-content h2{margin-top:40px;padding-top:22px;font-size:19px}.project-content h3{font-size:16px}.project-content pre{padding:14px;font-size:12px}}.detail-nav{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;margin-top:40px;padding:32px 0;display:flex}.detail-nav-link{border-radius:var(--radius-md);background:var(--bg-raised);border:1px solid var(--border);color:var(--fg-2);align-items:center;gap:10px;padding:12px 16px;font-size:13.5px;font-weight:500;transition:all .15s;display:inline-flex}.detail-nav-link:hover{border-color:var(--border-strong);background:var(--bg-hover);transform:translateY(-1px)}.detail-nav-link .arrow{color:var(--fg-3);font-family:var(--mono)}.link-hover{text-decoration:none;transition:color .25s;position:relative}.link-hover:after{content:"";background:var(--fg-3);width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.link-hover:hover:after{width:100%}@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}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
