:root{--color-bg: #FAFAF8;--color-surface: #FFFFFF;--color-text: #1A1A1A;--color-text-secondary: #444444;--color-text-tertiary: #555555;--color-border: #E5E5E3;--color-border-light: #F0F0EE;--color-accent: #2E4FBB;--color-accent-hover: #2341A0;--color-accent-light: #EEF1FA;--color-status-concept: #9B8FA0;--color-status-exploring: #7B9EB8;--color-status-in-progress: #E8652B;--color-status-live: #2D8F5E;--color-status-paused: #B8A07B;--color-status-archive: #9B9B9B;--font-display: "Inter", system-ui, -apple-system, sans-serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--text-5xl: 3.25rem;--leading-tight: 1.15;--leading-snug: 1.3;--leading-normal: 1.6;--leading-relaxed: 1.75;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--space-5xl: 8rem;--max-width: 1200px;--content-width: 720px;--page-padding-x: var(--space-lg);--section-gap: var(--space-4xl);--grid-gap: var(--space-lg);--grid-unit: 48px;--grid-columns: 12;--grid-column-gap: 0px;--grid-line-color: #000000;--dot-size: .75px;--dot-color: rgba(46, 79, 187, .15);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--ease-default: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s}@media(min-width:768px){:root{--page-padding-x: var(--space-xl);--section-gap: var(--space-5xl)}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background:var(--color-bg)}img,picture,video,canvas,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{line-height:var(--leading-tight);font-weight:700}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--page-padding-x)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}.status-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.2em .65em;font-size:var(--text-xs);font-weight:500;letter-spacing:.03em;text-transform:none;border-radius:0;border:1px solid currentColor}.status-badge--concept{color:var(--color-status-concept)}.status-badge--exploring{color:var(--color-status-exploring)}.status-badge--in-progress{color:var(--color-status-in-progress)}.status-badge--live{color:var(--color-status-live)}.status-badge--paused{color:var(--color-status-paused)}.status-badge--archive{color:var(--color-status-archive)}.status-badge--inline{font-size:.65em;padding:.15em .5em;margin-left:auto;flex-shrink:0}.tag{display:inline-block;padding:.15em .5em;font-size:var(--text-xs);color:var(--color-text-secondary);background:var(--color-border-light);border-radius:0}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.5em 1.2em;font-size:var(--text-sm);font-weight:500;border-radius:0;transition:background var(--duration-fast) var(--ease-default),color var(--duration-fast) var(--ease-default),border-color var(--duration-fast) var(--ease-default)}.btn--primary{background:var(--color-accent);color:#fff}.btn--primary:hover{background:var(--color-accent-hover)}.btn--secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover{border-color:var(--color-text)}.page-section{padding:calc(var(--grid-unit) * 2) 0}.page-section+.page-section{border-top:1px solid var(--grid-line-color)}.section-header{margin-bottom:calc(var(--grid-unit) * 1)}.section-header__title{font-family:var(--font-display);font-size:var(--text-3xl);margin-bottom:var(--space-sm)}.section-header__subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:40ch}.project-card{display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--grid-line-color);border-radius:0;overflow:hidden;transition:box-shadow var(--duration-normal) var(--ease-default)}.project-card:hover{box-shadow:var(--shadow-lg)}.project-card__image-wrap{position:relative;overflow:hidden}.project-card__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000008c;color:#fff;font-size:var(--text-sm);font-weight:600;letter-spacing:.04em;opacity:0;transition:opacity var(--duration-fast) var(--ease-default)}.project-card:hover .project-card__overlay{opacity:1}.project-card__image{display:block;width:100%;height:auto;aspect-ratio:3 / 2;object-fit:cover;background:var(--color-border-light)}.project-card__body{padding:calc(var(--grid-unit) * .5);display:flex;flex-direction:column;gap:var(--space-sm)}.project-card__title{font-family:var(--font-body);font-size:var(--text-lg);font-weight:600;display:flex;align-items:center;gap:var(--space-sm)}.project-card__summary{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-normal);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-grid{display:grid;gap:0;grid-template-columns:1fr;border-top:1px solid var(--grid-line-color);border-left:1px solid var(--grid-line-color);border-right:1px solid var(--grid-line-color);border-bottom:1px solid var(--grid-line-color)}.project-grid>.project-card{border:none;border-bottom:1px solid var(--grid-line-color)}.project-grid>.project-card:last-child{border-bottom-color:transparent}.project-grid .project-card__image{aspect-ratio:1 / 1}@media(min-width:768px){.project-grid{grid-template-columns:repeat(2,1fr)}.project-grid>.project-card{border-right:1px solid var(--grid-line-color);border-bottom:1px solid var(--grid-line-color)}.project-grid>.project-card:nth-child(2n){border-right-color:transparent}.project-grid>.project-card:last-child,.project-grid>.project-card:nth-last-child(2):nth-child(odd){border-bottom-color:transparent}}@media(min-width:1024px){.project-grid{grid-template-columns:repeat(3,1fr)}.project-grid>.project-card:nth-child(2n){border-right-color:var(--grid-line-color)}.project-grid>.project-card:nth-last-child(2):nth-child(odd){border-bottom-color:var(--grid-line-color)}.project-grid>.project-card:nth-child(3n){border-right-color:transparent}.project-grid>.project-card:last-child{border-bottom-color:transparent}.project-grid>.project-card:nth-last-child(2):nth-child(3n+1),.project-grid>.project-card:nth-last-child(2):nth-child(3n+2),.project-grid>.project-card:nth-last-child(1){border-bottom-color:transparent}.project-grid>.project-card:nth-last-child(3):nth-child(3n+1),.project-grid>.project-card:nth-last-child(3):nth-child(3n+1)~.project-card{border-bottom-color:transparent}}.note-card{display:block;padding:calc(var(--grid-unit) * .5);background:var(--color-surface);border:none;border-radius:0;transition:background var(--duration-fast) var(--ease-default)}.note-card:hover{background:var(--color-border-light)}.note-card__date{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-xs)}.note-card__title{font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-xs)}.note-card__summary{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-normal)}.note-card__project{display:inline-block;margin-top:var(--space-sm);font-size:var(--text-xs);color:var(--color-accent)}.notes-grid{display:flex;flex-direction:column}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-xl)}.filter-bar__row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.filter-bar__row .filter-bar{margin-bottom:0}.filter-bar__count{font-size:var(--text-xs);color:var(--color-text-tertiary);white-space:nowrap}.filter-bar__sep{width:1px;height:1.2em;background:var(--color-border);margin:0 var(--space-xs)}.filter-pill{padding:.3em .8em;font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--duration-fast) var(--ease-default)}.filter-pill:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.filter-pill--active{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.form__field{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-lg)}.form__label{font-size:var(--text-sm);font-weight:500}.form__input,.form__select,.form__textarea{padding:.6em .8em;font:inherit;font-size:var(--text-base);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);transition:border-color var(--duration-fast) var(--ease-default)}.form__input:focus,.form__select:focus,.form__textarea:focus{border-color:var(--color-accent);outline:none}.form__textarea{resize:vertical;min-height:120px}.tw-drawer{border:1px solid var(--grid-line-color);border-radius:0;background:var(--color-surface)}.tw-drawer__header{border-bottom:1px solid var(--grid-line-color)}.tw-drawer__trigger{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:calc(var(--grid-unit) * .5) calc(var(--grid-unit) * .5);text-align:left;cursor:pointer}.tw-drawer__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.tw-drawer__preview{font-size:var(--text-sm);color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.tw-drawer__icon{flex-shrink:0;color:var(--color-text-tertiary);transition:transform var(--duration-normal) var(--ease-default);display:flex;align-items:center}.tw-drawer__icon--open{transform:rotate(180deg)}.tw-drawer__panel{overflow:hidden;max-height:0;opacity:0;transition:max-height var(--duration-slow) var(--ease-default),opacity var(--duration-normal) var(--ease-default)}.tw-drawer--open .tw-drawer__panel{max-height:500px;opacity:1}.tw-drawer__content{padding:calc(var(--grid-unit) * .5);padding-top:calc(var(--grid-unit) * .5);padding-bottom:calc(var(--grid-unit) * .5)}.tw-drawer__grid{display:grid;gap:calc(var(--grid-unit) * 1);grid-template-columns:1fr}.tw-drawer__item{padding:calc(var(--grid-unit) * .5) 0;border-bottom:1px solid var(--grid-line-color)}.tw-drawer__item:last-child{border-bottom:none}.tw-drawer__label{display:block;font-size:var(--text-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:var(--space-xs)}.tw-drawer__value{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-normal)}.tw-drawer__questions{list-style:none;padding:0}.tw-drawer__questions li{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-normal);margin-bottom:var(--space-xs);padding-left:var(--space-md);position:relative}.tw-drawer__questions li:before{content:"?";position:absolute;left:0;color:var(--color-accent);font-weight:600;font-size:var(--text-xs)}@media(min-width:768px){.tw-drawer__grid{grid-template-columns:repeat(3,1fr)}.tw-drawer__item--wide{grid-column:1 / -1}.tw-drawer__item{border-bottom:none;border-right:1px solid var(--grid-line-color);padding:calc(var(--grid-unit) * .5) calc(var(--grid-unit) * .5) calc(var(--grid-unit) * .5) 0}.tw-drawer__item:nth-child(3),.tw-drawer__item:last-child{border-right:none}.tw-drawer__item--wide{border-right:none;border-top:1px solid var(--grid-line-color);padding:calc(var(--grid-unit) * .5) 0 0 0;margin-top:calc(var(--grid-unit) * .5)}}.grid-bg{background-image:radial-gradient(circle,var(--dot-color) var(--dot-size),transparent var(--dot-size));background-size:var(--grid-unit) var(--grid-unit);background-position:0 0}@media(max-width:767px){.grid-bg{--dot-color: rgba(46, 79, 187, .12)}}.dot-mask{background-color:var(--color-bg)}.grid-layout{display:grid;grid-template-columns:repeat(var(--grid-columns),1fr);gap:0 var(--grid-column-gap);max-width:var(--max-width);margin:0 auto;padding:0 var(--page-padding-x)}.grid-span-full{grid-column:1 / -1}.grid-span-8{grid-column:span 8}.grid-span-6{grid-column:span 6}.grid-span-4{grid-column:span 4}.grid-span-3{grid-column:span 3}@media(max-width:767px){.grid-layout{grid-template-columns:1fr}.grid-span-8,.grid-span-6,.grid-span-4,.grid-span-3{grid-column:1 / -1}}.gu-1{height:calc(var(--grid-unit) * 1)}.gu-2{height:calc(var(--grid-unit) * 2)}.gu-3{height:calc(var(--grid-unit) * 3)}.gu-4{height:calc(var(--grid-unit) * 4)}.mt-gu-1{margin-top:calc(var(--grid-unit) * 1)}.mt-gu-2{margin-top:calc(var(--grid-unit) * 2)}.mt-gu-3{margin-top:calc(var(--grid-unit) * 3)}.mt-gu-4{margin-top:calc(var(--grid-unit) * 4)}.mb-gu-1{margin-bottom:calc(var(--grid-unit) * 1)}.mb-gu-2{margin-bottom:calc(var(--grid-unit) * 2)}.mb-gu-3{margin-bottom:calc(var(--grid-unit) * 3)}.mb-gu-4{margin-bottom:calc(var(--grid-unit) * 4)}.pt-gu-2{padding-top:calc(var(--grid-unit) * 2)}.pt-gu-3{padding-top:calc(var(--grid-unit) * 3)}.pb-gu-2{padding-bottom:calc(var(--grid-unit) * 2)}.pb-gu-3{padding-bottom:calc(var(--grid-unit) * 3)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.prose{max-width:var(--content-width)}.prose h2{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;margin-top:var(--space-3xl);margin-bottom:var(--space-md);line-height:var(--leading-tight)}.prose h3{font-size:var(--text-xl);font-weight:600;margin-top:var(--space-2xl);margin-bottom:var(--space-sm)}.prose p{margin-bottom:var(--space-md);line-height:var(--leading-relaxed)}.prose ul,.prose ol{margin-bottom:var(--space-md);padding-left:var(--space-lg);list-style:revert}.prose li{margin-bottom:var(--space-xs)}.prose a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}.prose a:hover{color:var(--color-accent-hover)}.prose strong{font-weight:600}.prose code{font-family:var(--font-mono);font-size:.9em;background:var(--color-border-light);padding:.15em .35em;border-radius:var(--radius-sm)}.prose pre{background:var(--color-text);color:var(--color-bg);padding:var(--space-lg);border-radius:var(--radius-md);overflow-x:auto;margin-bottom:var(--space-md)}.prose pre code{background:none;padding:0;font-size:var(--text-sm)}.prose img{border-radius:var(--radius-md);margin:var(--space-xl) 0}.prose blockquote{border-left:3px solid var(--color-accent);padding-left:var(--space-lg);color:var(--color-text-secondary);font-style:italic;margin-bottom:var(--space-md)}.prose hr{border:none;border-top:1px solid var(--color-border-light);margin:var(--space-2xl) 0}.skip-link[data-astro-cid-qlfjksao]{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.skip-link[data-astro-cid-qlfjksao]:focus{position:fixed;top:var(--space-sm);left:var(--space-sm);width:auto;height:auto;padding:var(--space-sm) var(--space-md);margin:0;overflow:visible;clip:auto;white-space:normal;background:var(--color-accent);color:#fff;border-radius:var(--radius-md);z-index:100}.site-header[data-astro-cid-qlfjksao]{position:sticky;top:0;z-index:50;background:var(--color-bg);border-bottom:1px solid var(--grid-line-color)}.site-header__inner[data-astro-cid-qlfjksao]{display:flex;align-items:center;justify-content:space-between;height:calc(var(--grid-unit) * 2 - 1px);max-width:none;padding:0 var(--grid-unit)}.site-header__logo[data-astro-cid-qlfjksao]{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;letter-spacing:-.01em}.site-header__nav[data-astro-cid-qlfjksao]{display:none;align-items:center;gap:var(--space-xl)}.site-header__link[data-astro-cid-qlfjksao]{font-size:var(--text-sm);font-weight:400;color:var(--color-text-secondary);transition:color var(--duration-fast) var(--ease-default)}.site-header__link[data-astro-cid-qlfjksao]:hover{color:var(--color-text)}.site-header__link--active[data-astro-cid-qlfjksao]{color:var(--color-accent);font-weight:500}.site-header__mobile-menu[data-astro-cid-qlfjksao]{position:relative}.site-header__burger[data-astro-cid-qlfjksao]{display:flex;flex-direction:column;gap:4px;padding:var(--space-sm);cursor:pointer;list-style:none}.site-header__burger[data-astro-cid-qlfjksao]::-webkit-details-marker{display:none}.site-header__burger-line[data-astro-cid-qlfjksao]{display:block;width:20px;height:2px;background:var(--color-text);border-radius:1px;transition:transform var(--duration-fast) var(--ease-default)}.site-header__mobile-nav[data-astro-cid-qlfjksao]{position:absolute;top:100%;right:0;min-width:180px;padding:var(--space-sm) 0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.site-header__mobile-link[data-astro-cid-qlfjksao]{padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);color:var(--color-text-secondary);transition:background var(--duration-fast) var(--ease-default),color var(--duration-fast) var(--ease-default)}.site-header__mobile-link[data-astro-cid-qlfjksao]:hover{background:var(--color-border-light);color:var(--color-text)}.site-header__mobile-link--active[data-astro-cid-qlfjksao]{color:var(--color-accent);font-weight:500}@media(min-width:768px){.site-header__nav[data-astro-cid-qlfjksao]{display:flex}.site-header__mobile-menu[data-astro-cid-qlfjksao]{display:none}}.site-footer[data-astro-cid-35ed7um5]{border-top:1px solid var(--color-border-light);padding:var(--space-2xl) 0;margin-top:var(--space-4xl)}.site-footer__inner[data-astro-cid-35ed7um5]{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-md);max-width:none;padding:0 var(--grid-unit)}.site-footer__copy[data-astro-cid-35ed7um5]{font-size:var(--text-sm);color:var(--color-text-tertiary)}.site-footer__nav[data-astro-cid-35ed7um5]{display:flex;gap:var(--space-lg)}.site-footer__link[data-astro-cid-35ed7um5]{font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--duration-fast) var(--ease-default)}.site-footer__link[data-astro-cid-35ed7um5]:hover{color:var(--color-text)}
