@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600;700&display=swap";:root{--bg: #fafaf8;--surface: #ffffff;--content-bg: #f5f5f3;--line: #1a1a1a;--line-light: #e5e5e3;--font-display: "IBM Plex Mono", "SF Mono", "Menlo", monospace;--font-body: "IBM Plex Mono", "PingFang SC", "Noto Sans SC", monospace;--font-mono: "IBM Plex Mono", "SF Mono", "Menlo", monospace;--text: #1a1a1a;--text-2: #4a4a4a;--text-3: #8a8a8a;--accent: #d45d2c;--accent-hover: #b84a1f;--accent-soft: #f5e8e3;--color-blue: #2d6a9f;--color-green: #2d7a4f;--color-purple: #6b4d8a;--color-orange: #d45d2c;--color-pink: #a84d6a;--width: 960px;--radius: 0;--border: 2px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--bg);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}main{flex:1}a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s}a:hover{border-bottom-color:var(--accent)}img{max-width:100%;display:block}button,.button{appearance:none;border:0;cursor:pointer;font:inherit}:focus-visible{outline:3px solid rgba(212,93,44,.35);outline-offset:3px}.skip-link{position:absolute;left:16px;top:12px;z-index:200;padding:10px 14px;background:var(--text);color:var(--bg);border:var(--border) solid var(--line);transform:translateY(-160%);transition:transform .15s ease}.skip-link:focus-visible{transform:translateY(0)}.shell{width:min(var(--width),calc(100% - 48px));margin:0 auto}.site-header{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:var(--border) solid var(--line)}.site-header .shell{height:60px;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:12px}.brand__mark{width:36px;height:36px;display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--bg);background:var(--text);border:var(--border) solid var(--line)}.brand__title{font-family:var(--font-display);font-size:.85rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.nav{display:flex;gap:0}.nav a{padding:6px 12px;font-family:var(--font-display);font-size:.8rem;font-weight:500;color:var(--text-2);border:none;position:relative}.nav a:hover{color:var(--text);background:transparent}.nav a.is-active{color:var(--accent)}.nav a.is-active:after{content:"";position:absolute;bottom:0;left:12px;right:12px;height:2px;background:var(--accent)}.brand:focus-visible,.nav a:focus-visible,.button:focus-visible,.project-nav__link:focus-visible,.project-filter__btn:focus-visible,.project-card:focus-visible,.article-card:focus-visible,.hp-showcase__card:focus-visible,.contact-button:focus-visible,.footer-dev-link:focus-visible,.search-box__clear:focus-visible,.search-box__input:focus-visible{outline:3px solid rgba(212,93,44,.35);outline-offset:3px}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:var(--border) solid var(--line);font-family:var(--font-display);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;transition:all .15s;background:var(--surface);color:var(--text)}.button:hover{border-color:var(--accent);color:var(--accent)}.button--primary{background:var(--text);color:var(--bg);border-color:var(--text)}.button--primary:hover{background:var(--accent);border-color:var(--accent);color:var(--bg)}.button--ghost{border:var(--border) solid var(--line);background:transparent}.button--ghost:hover{border-color:var(--text);background:transparent}.hp-hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:var(--bg);border-bottom:var(--border) solid var(--line);padding-bottom:120px;transition:opacity .4s ease;will-change:opacity}.hp-hero.is-scrolled{opacity:.5}.hp-hero__inner{position:relative;z-index:1;max-width:700px;padding:0 24px;animation:fadeUp .6s cubic-bezier(.22,1,.36,1) both}.hp-hero__badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--surface);color:var(--accent);font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:28px;border:var(--border) solid var(--line)}.hp-hero__badge-dot{width:6px;height:6px;background:var(--accent);animation:pulse 2s ease-in-out infinite}.hp-hero__title{margin:0 0 20px;font-family:var(--font-display);display:flex;flex-direction:column;align-items:center}.hp-hero__line1{font-size:clamp(1rem,2vw,1.2rem);font-weight:500;color:var(--text-2);letter-spacing:.05em;margin-bottom:10px;text-transform:uppercase}.hp-hero__name-row{display:inline-flex;align-items:baseline}.hp-hero__name{font-size:clamp(2rem,5vw,3.2rem);font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--text)}.hp-hero__cursor{font-size:clamp(2rem,5vw,3.2rem);font-weight:300;color:var(--accent);animation:blink .8s step-end infinite;margin-left:2px}.hp-hero__desc{margin:24px auto 0;color:var(--text-2);font-size:1rem;line-height:1.7;max-width:500px}.hp-hero__actions{display:flex;gap:12px;justify-content:center;margin-top:36px}.hp-hero__scroll{position:absolute;bottom:70px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}.hp-hero__scroll-ripple{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;animation:scrollFloat 2.5s ease-in-out infinite}.hp-hero__scroll-ripple:before{content:"";position:absolute;width:60px;height:60px;border-radius:0;background:var(--accent-soft);animation:ripple 2s ease-out infinite}.hp-hero__scroll-ripple:after{content:"";position:absolute;width:60px;height:60px;border-radius:0;border:1px solid rgba(99,102,241,.2);animation:rippleRing 2s ease-out infinite;animation-delay:.5s}.hp-hero__scroll-icon{position:relative;z-index:1;color:var(--accent);opacity:.7;transition:all .3s ease}.hp-hero__scroll:hover .hp-hero__scroll-icon{opacity:1;transform:translateY(4px)}.hp-hero__scroll-text{position:relative;z-index:1;font-size:.72rem;font-weight:500;color:var(--text-3);letter-spacing:.05em;opacity:.7}.hp-hero__scroll:hover .hp-hero__scroll-text{opacity:1}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes scrollFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes ripple{0%{transform:scale(.8);opacity:.6}to{transform:scale(1.5);opacity:0}}@keyframes rippleRing{0%{transform:scale(.8);opacity:.4}to{transform:scale(1.4);opacity:0}}.button--bouncy{transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s,background .2s}.button--bouncy:hover{transform:translateY(-2px)}.button--bouncy:active{transform:translateY(0) scale(.97)}.hp-tech{padding:48px 24px;background:var(--surface)}.hp-tech__inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;place-items:center}.hp-tech__card{width:100%;max-width:100px;height:auto;object-fit:contain;transition:transform .2s ease;cursor:default;opacity:.85}.hp-tech__card:hover{transform:scale(1.1);opacity:1}.hp-stats{padding:56px 24px;background:var(--surface)}.hp-stats__inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.hp-stat{text-align:center;padding:28px 16px;background:var(--surface);border-radius:0;border:1px solid var(--line);transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .2s}.hp-stat:hover{box-shadow:0 8px 24px #0000000f}.hp-stat__icon{display:flex;align-items:center;justify-content:center;margin-bottom:8px}.hp-stat__icon--blue{color:var(--color-blue)}.hp-stat__icon--purple{color:var(--color-purple)}.hp-stat__icon--green{color:var(--color-green)}.hp-stat__icon--orange{color:var(--color-orange)}.hp-stat__num{font-family:var(--font-display);font-size:2.2rem;font-weight:700;letter-spacing:-.04em;color:var(--text)}.hp-stat__label{margin-top:4px;font-size:.82rem;color:var(--text-3);font-weight:500}.hp-stat{transition:none!important}body.loaded .hp-stat{transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .2s!important}.hp-section-tag{display:inline-block;padding:4px 12px;border-radius:0;background:var(--accent-soft);color:var(--accent);font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.04em;margin-bottom:12px}.hp-showcase{padding:64px 24px;background:var(--surface)}.hp-showcase__inner{max-width:1200px;margin:0 auto}.hp-showcase__head{text-align:center;margin-bottom:48px}.hp-showcase__head h2{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2rem);font-weight:700;letter-spacing:-.03em;margin:0}.hp-showcase__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.hp-showcase__card{display:flex;flex-direction:column;gap:16px;padding:24px;background:var(--surface);border-radius:0;border:1px solid var(--line);color:inherit;text-decoration:none;transition:border-color .2s,box-shadow .2s,transform .25s cubic-bezier(.34,1.56,.64,1)}.hp-showcase__card:hover{border-color:#6366f126;box-shadow:0 4px 20px #6366f114}.hp-showcase__card:focus-visible{border-color:#6366f126;box-shadow:0 4px 20px #6366f114}.hp-showcase__card-icon{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;flex-shrink:0}.hp-showcase__card-icon--blue{background:#3b82f61a;color:var(--color-blue)}.hp-showcase__card-icon--purple{background:#8b5cf61a;color:var(--color-purple)}.hp-showcase__card-icon--green{background:#22c55e1a;color:var(--color-green)}.hp-showcase__card-content h3{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin:0 0 8px;letter-spacing:-.01em}.hp-showcase__card-content p{margin:0 0 12px;font-size:.9rem;color:var(--text-2);line-height:1.6}.hp-showcase__card-tags{display:flex;flex-wrap:wrap;gap:6px;list-style:none;padding:0;margin:0}.hp-showcase__card-tags li{padding:4px 10px;border-radius:0;background:var(--accent-soft);color:var(--accent);font-family:var(--font-mono);font-size:.72rem;font-weight:500}.hp-cta{padding:80px 24px;background:var(--surface);text-align:center}.hp-cta__inner{max-width:600px;margin:0 auto}.hp-cta__title{font-family:var(--font-display);font-size:clamp(1.5rem,4vw,2rem);font-weight:700;letter-spacing:-.03em;margin:0 0 16px;color:var(--text)}.hp-cta__desc{font-size:1rem;color:var(--text-2);margin:0 0 32px;line-height:1.6}.hp-cta__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.hp-explore{padding:48px 24px 64px;background:var(--surface)}.hp-explore__inner{max-width:640px;margin:0 auto}.hp-explore__head{text-align:center;margin-bottom:28px}.hp-explore__head h2{font-family:var(--font-display);font-size:clamp(1.3rem,2.5vw,1.6rem);font-weight:700;letter-spacing:-.03em;margin:0}.hp-explore__grid{display:flex;flex-direction:column;gap:10px}.hp-explore-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--surface);border-radius:0;border:1px solid var(--line);color:inherit;text-decoration:none;transition:border-color .2s,background .2s,transform .25s cubic-bezier(.34,1.56,.64,1)}.hp-explore-card:hover{border-color:#6366f126;background:#ffffffe6}.hp-explore-card__icon-wrap{width:40px;height:40px;border-radius:0;display:grid;place-items:center;flex-shrink:0}.hp-explore-card__icon-wrap--blue{background:#3b82f61a;color:var(--color-blue)}.hp-explore-card__icon-wrap--purple{background:#8b5cf61a;color:var(--color-purple)}.hp-explore-card__icon-wrap--green{background:#22c55e1a;color:var(--color-green)}.hp-explore-card__text{flex:1}.hp-explore-card__text h3{font-family:var(--font-display);font-size:.92rem;font-weight:600;margin:0;letter-spacing:-.01em}.hp-explore-card__arrow{color:var(--text-3);flex-shrink:0;transition:transform .2s,color .2s}.hp-explore-card:hover .hp-explore-card__arrow{color:var(--accent)}.site-footer{padding:32px 0;margin-top:64px;border-top:1px solid var(--line);background:var(--surface)}.site-footer .shell{display:flex;align-items:center;justify-content:center}.footer-note{margin:0;font-size:.95rem;color:var(--text-2);font-weight:500;letter-spacing:.02em;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.footer-divider{color:var(--line)}.footer-filing{color:var(--text-2);text-decoration:none;transition:color .2s}.footer-filing:hover{color:var(--accent)}.section{padding-top:0;padding-bottom:32px}.section__head{margin-bottom:16px;display:flex;align-items:baseline;justify-content:space-between;gap:16px}.section__head h2{font-family:var(--font-display);font-size:1.3rem;font-weight:700;letter-spacing:-.02em;margin:0}.section__head a{font-family:var(--font-display);font-size:.82rem;font-weight:500;color:var(--accent);white-space:nowrap}.project-nav{display:flex;gap:8px;margin:32px 0 24px;padding-bottom:16px;border-bottom:1px solid var(--line)}.project-nav__link{padding:8px 16px;border-radius:0;font-family:var(--font-display);font-size:.92rem;font-weight:500;color:var(--text-2);text-decoration:none;transition:all .2s}.project-nav__link:hover,.project-nav__link--active{color:var(--accent);background:var(--accent-soft)}.project-filter{display:flex;gap:8px;margin-bottom:0;flex-wrap:wrap}.project-filter__btn{padding:8px 16px;border-radius:0;border:1px solid var(--line);background:var(--surface);font-family:var(--font-display);font-size:.85rem;font-weight:500;color:var(--text-2);cursor:pointer;transition:all .2s}.project-filter__btn:hover{border-color:var(--accent);color:var(--accent)}.project-filter__btn--active,.project-filter__btn--active:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:16px}.project-card{position:relative;display:flex;flex-direction:column;padding:24px;background:var(--surface);border-radius:0;border:1px solid var(--line);color:inherit;text-decoration:none;transition:all .25s ease;opacity:1}.project-card:hover{border-color:var(--accent)}.project-card:focus-visible{border-color:var(--accent)}.project-card--featured{grid-column:1 / -1;background:var(--content-bg);border:1px solid rgba(99,102,241,.1)}.project-card--featured:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);border-radius:0 0 0 16px}.project-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.project-card__icon{width:48px;height:48px;border-radius:0;display:grid;place-items:center;flex-shrink:0}.project-card__icon--blue{background:#3b82f61a;color:var(--color-blue)}.project-card__icon--purple{background:#8b5cf61a;color:var(--color-purple)}.project-card__icon--green{background:#22c55e1a;color:var(--color-green)}.project-card__icon--orange{background:#f973161a;color:var(--color-orange)}.project-card__icon--pink{background:#ec48991a;color:var(--color-pink)}.project-card__meta{display:flex;gap:8px;align-items:center}.project-card__badge{padding:4px 10px;border-radius:0;font-family:var(--font-mono);font-size:.68rem;font-weight:500;background:var(--accent-soft);color:var(--accent)}.project-card__year{font-size:.82rem;color:var(--text-3);font-weight:500}.project-card__title{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin:0 0 8px;letter-spacing:-.02em;line-height:1.4}.project-card--featured .project-card__title{font-size:1.3rem}.project-card__desc{margin:0 0 16px;font-size:.9rem;color:var(--text-2);line-height:1.6}.project-card--featured .project-card__desc{font-size:.95rem}.project-card__highlights{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.project-card__highlight{padding:4px 12px;border-radius:0;background:var(--text);color:#fff;font-family:var(--font-mono);font-size:.72rem;font-weight:500}.project-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.project-card__tag{padding:4px 10px;border-radius:0;font-family:var(--font-mono);font-size:.68rem;font-weight:500}.project-card__tag--tech{background:#3b82f61a;color:var(--color-blue)}.project-card__tag--biz{background:#8b5cf61a;color:var(--color-purple)}.project-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}.project-card__link{font-family:var(--font-display);font-size:.85rem;font-weight:500;color:var(--accent)}.project-card__arrow{color:var(--text-3);transition:transform .2s,color .2s}.project-card:hover .project-card__arrow{color:var(--accent)}.search-box{position:relative;display:flex;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:0;padding:0 16px;transition:all .2s ease}.search-box:focus-within{border-color:#6366f14d;box-shadow:0 0 0 3px #6366f114}.search-box__icon{display:flex;align-items:center;justify-content:center;color:var(--text-3);pointer-events:none}.search-box__input{flex:1;border:none;background:transparent;padding:14px 12px;font-size:.95rem;color:var(--text-1);outline:none}.search-box__input::placeholder{color:var(--text-3)}.search-box__clear{display:none;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--bg);border-radius:0;color:var(--text-3);cursor:pointer;transition:all .15s ease}.search-box__clear:hover{background:var(--surface);color:var(--text-1)}.search-box:not(:empty) .search-box__clear{display:flex}.search-results{display:none;margin-top:16px;padding:16px;background:var(--surface);border-radius:0;text-align:center;color:var(--text-2)}.search-results--visible{display:block}.article-list{display:grid;gap:16px}.article-card{display:flex;flex-direction:column;padding:24px;background:var(--surface);border-radius:0;border:1px solid var(--line);color:inherit;text-decoration:none;transition:all .25s ease}.article-card:hover{border-color:#6366f126;box-shadow:0 8px 32px #6366f114}.article-card:focus-visible{border-color:#6366f126;box-shadow:0 8px 32px #6366f114}.article-card--featured{background:var(--content-bg);border:1px solid rgba(99,102,241,.1);position:relative}.article-card--featured:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);border-radius:0 0 0 16px}.article-card__header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.article-card__icon{width:40px;height:40px;border-radius:0;display:grid;place-items:center;flex-shrink:0}.article-card__icon--blue{background:#3b82f61a;color:var(--color-blue)}.article-card__icon--green{background:#22c55e1a;color:var(--color-green)}.article-card__icon--purple{background:#8b5cf61a;color:var(--color-purple)}.article-card__icon--orange{background:#f973161a;color:var(--color-orange)}.article-card__meta{display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.article-card__badge{padding:4px 10px;border-radius:0;font-family:var(--font-mono);font-size:.68rem;font-weight:500;background:var(--text);color:#fff}.article-card__badge--featured{background:var(--text)}.article-card__date,.article-card__duration{font-size:.82rem;color:var(--text-3);font-weight:500}.article-card__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0 0 8px;letter-spacing:-.02em;line-height:1.4;color:var(--text-1)}.article-card--featured .article-card__title{font-size:1.35rem}.article-card__desc{margin:0 0 12px;font-size:.9rem;color:var(--text-2);line-height:1.6}.article-card--featured .article-card__desc{font-size:.95rem}.article-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.article-card__tag{padding:4px 10px;border-radius:0;font-family:var(--font-mono);font-size:.68rem;font-weight:500}.article-card__tag--blue{background:#3b82f61a;color:var(--color-blue)}.article-card__tag--green{background:#22c55e1a;color:var(--color-green)}.article-card__tag--purple{background:#8b5cf61a;color:var(--color-purple)}.article-card__tag--orange{background:#f973161a;color:var(--color-orange)}.project-list{display:grid;gap:12px}.project-item{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;padding:24px 28px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--line);transition:border-color .2s,box-shadow .2s,transform .2s}.project-item:hover{border-color:#6366f126;box-shadow:0 4px 24px #0000000d}.project-item__tags{display:flex;gap:6px;margin-top:8px}.project-item__tags span{font-family:var(--font-mono);font-size:.68rem;font-weight:500;color:var(--accent);padding:2px 8px;border-radius:0;background:var(--accent-soft);border:1px solid rgba(79,70,229,.08)}.project-item h3{font-family:var(--font-display);font-size:1rem;font-weight:600;margin:0;letter-spacing:-.01em}.project-item p{margin:4px 0 0;font-size:.85rem;color:var(--text-2);line-height:1.55}.project-item__arrow{color:var(--text-3);font-size:1.2rem;transition:transform .2s,color .2s}.project-item:hover .project-item__arrow{transform:translate(4px);color:var(--accent)}.project-featured{position:relative;display:block;padding:32px;background:var(--surface);border-radius:0;overflow:hidden;border:1px solid transparent;background-clip:padding-box;transition:box-shadow .2s,transform .2s}.project-featured:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);background-size:100% 200%;animation:gradientSlide 3s ease-in-out infinite}.project-featured:hover{box-shadow:0 8px 32px #6366f11a}.project-featured h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin:0;letter-spacing:-.02em}.project-featured p{margin:8px 0 0;font-size:.9rem;color:var(--text-2);line-height:1.6}.project-featured__tags{display:flex;gap:6px;margin-top:14px}.project-featured__tags span{font-family:var(--font-mono);font-size:.68rem;font-weight:500;color:var(--accent);padding:3px 10px;border-radius:0;background:var(--accent-soft);border:1px solid rgba(79,70,229,.08)}.project-featured__arrow{position:absolute;right:28px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:1.3rem;transition:transform .2s,color .2s}.project-featured:hover .project-featured__arrow{transform:translateY(-50%) translate(4px);color:var(--accent)}.page-intro{padding:44px 0 0;margin-bottom:32px}.page-intro h1{margin:16px 0 0;font-family:var(--font-display);font-size:clamp(1.5rem,3.5vw,2rem);line-height:1.15;letter-spacing:-.03em;font-weight:700}.page-intro__lead{margin:12px 0 0;color:var(--text-2);font-size:.95rem;max-width:52ch}.page-intro__tag{display:inline-block;padding:3px 10px;border-radius:0;background:var(--accent-soft);color:var(--accent);font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.04em;margin-bottom:14px}.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.cards-grid--three{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.card{padding:24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);transition:border-color .2s,box-shadow .2s}.card:hover{border-color:var(--line-hover);box-shadow:0 4px 16px #0000000a}.card h3{font-family:var(--font-display);font-size:.95rem;font-weight:600;margin:0;letter-spacing:-.01em}.card p{margin:6px 0 0;font-size:.85rem;color:var(--text-2);line-height:1.55}.list-inline{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.list-inline span{font-family:var(--font-mono);font-size:.68rem;font-weight:500;color:var(--accent);padding:2px 8px;border-radius:0;background:var(--accent-soft);border:1px solid rgba(79,70,229,.08)}.detail-layout{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start}.two-column{display:grid;grid-template-columns:1.3fr 1fr;gap:20px;align-items:start}.detail-block{padding:24px 0;border:none;background:transparent}.detail-block+.detail-block{margin-top:24px}.detail-block h2{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin:0 0 12px;letter-spacing:-.02em;color:var(--text-1)}.detail-block p{margin:0;font-size:.98rem;color:var(--text-2);line-height:1.75}.list-plain{list-style:none;padding:0;margin:0;display:grid;gap:10px}.list-plain li{position:relative;padding-left:16px;font-size:.98rem;color:var(--text-2);line-height:1.7}.list-plain li:before{content:"";position:absolute;left:0;top:.7em;width:6px;height:6px;border-radius:0;background:var(--accent)}.inline-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.inline-actions .button{padding:6px 14px;font-size:.78rem}.profile-card{display:flex;align-items:center;gap:24px;padding:32px;background:var(--content-bg);border:1px solid rgba(99,102,241,.1);border-radius:0;margin-bottom:8px}.profile-card__avatar{width:72px;height:72px;border-radius:0;background:var(--accent);color:#fff;display:grid;place-items:center;flex-shrink:0;box-shadow:0 4px 12px #6366f133}.profile-card__info{flex:1}.profile-card__name{font-size:1.3rem;font-weight:700;margin:0 0 4px;color:var(--text-1);letter-spacing:-.02em}.profile-card__title{font-size:.95rem;color:var(--text-2);margin:0 0 8px;font-weight:500}.profile-card__location{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-3);padding:4px 10px;background:#fff9;border-radius:0}.contact-links{display:flex;flex-wrap:wrap;gap:10px}.contact-button{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;background:var(--accent);color:#fff;border:none;border-radius:0;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #6366f133}.contact-button:hover{background:#4f46e5;box-shadow:0 4px 16px #6366f14d}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.contact-button:active{transform:translateY(0)}.footer-meta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.footer-dev-link{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3)}.footer-dev-link:hover{color:var(--accent)}.editor-callout{display:grid;gap:14px;margin-bottom:24px;padding:18px 20px;border:var(--border) solid var(--line);background:var(--accent-soft)}.editor-callout__title{margin:0;font-family:var(--font-display);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.editor-callout__desc{margin:0;color:var(--text-2)}.editor-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:24px}.editor-nav{position:sticky;top:92px;align-self:start;display:grid;gap:12px}.editor-nav__item{display:grid;gap:4px;padding:14px 16px;border:var(--border) solid var(--line);background:var(--surface);text-align:left;cursor:pointer;transition:border-color .16s ease,color .16s ease,background-color .16s ease}.editor-nav__item.is-active{border-color:var(--accent);background:var(--accent-soft)}.editor-nav__item strong{font-family:var(--font-display);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text)}.editor-nav__item span{color:var(--text-2);font-size:.88rem}.editor-workspace{display:grid;gap:0}.editor-workspace>.editor-panel{padding-top:0}.editor-panel{display:none}.editor-panel.is-active{display:block}.editor-panel+.editor-panel{margin-top:0}.editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.editor-form{display:grid;gap:16px}.editor-form__row{display:grid;gap:8px}.editor-form__row label{font-family:var(--font-display);font-size:.76rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2)}.editor-input,.editor-textarea,.editor-select{width:100%;border:var(--border) solid var(--line);background:var(--surface);color:var(--text);border-radius:0;padding:12px 14px;font-family:var(--font-body);font-size:.92rem}.editor-textarea{min-height:120px;resize:vertical}.editor-tags{display:flex;flex-wrap:wrap;gap:8px}.editor-chip{display:inline-flex;align-items:center;padding:7px 10px;border:1px solid var(--line);color:var(--text-2);background:var(--surface);font-size:.8rem}.editor-chip.is-selected{border-color:var(--accent);color:var(--accent)}.editor-chip.is-focused{background:var(--accent-soft);border-color:var(--accent);color:var(--text)}.editor-chip--danger{color:#a13c2c;border-color:#a13c2c}.editor-select-search{display:grid;gap:10px}.editor-combobox,.editor-tagbox,.editor-date{position:relative;display:grid;gap:10px}.editor-select-results{display:flex;flex-wrap:wrap;gap:8px}.editor-upload__box,.editor-preview-box{display:grid;gap:8px;padding:18px;border:var(--border) dashed var(--line);background:var(--surface)}.editor-upload__box strong,.editor-preview-box strong{font-family:var(--font-display);font-size:.8rem;letter-spacing:.05em;text-transform:uppercase}.editor-upload__box span,.editor-preview-box span{color:var(--text-2)}.editor-upload{display:block}.editor-upload__input{display:none}.editor-upload__box{cursor:pointer;transition:border-color .16s ease,color .16s ease}.editor-upload__box:hover{border-color:var(--accent)}.editor-date-field{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.editor-dropdown{display:none;position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:8;border:var(--border) solid var(--line);background:var(--surface)}.editor-dropdown.is-open{display:block}.editor-dropdown button{width:100%;padding:11px 12px;border:0;border-bottom:1px solid var(--line-light);background:var(--surface);color:var(--text);text-align:left}.editor-dropdown button:last-child{border-bottom:0}.editor-dropdown button:hover{background:var(--accent-soft)}.editor-tagbox__selected{display:flex;flex-wrap:wrap;gap:8px}.editor-tagbox__inputwrap{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.editor-chip-delete{white-space:nowrap}.editor-subcard{margin-top:24px}.editor-item-list{display:grid;gap:10px}.editor-item-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);background:var(--surface)}.editor-item-row.is-current{border-color:var(--accent)}.editor-item-row__main{border:0;background:transparent;color:var(--text);text-align:left;font-family:var(--font-body);cursor:pointer}.editor-calendar{display:none;position:absolute;top:calc(100% + 2px);left:0;width:280px;z-index:8;border:var(--border) solid var(--line);background:var(--surface);padding:14px}.editor-calendar.is-open{display:block}.editor-calendar__head{margin-bottom:12px;font-family:var(--font-display);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.editor-calendar__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.editor-calendar__grid button{padding:10px 0;border:1px solid var(--line);background:var(--surface);color:var(--text)}.editor-calendar__grid button.is-selected,.editor-calendar__grid button:hover{border-color:var(--accent);color:var(--accent)}.editor-modal[hidden]{display:none}.editor-modal{position:fixed;inset:0;z-index:120}.editor-modal__backdrop{position:absolute;inset:0;background:#00000059}.editor-modal__dialog{position:relative;width:min(760px,calc(100% - 32px));margin:10vh auto 0;border:var(--border) solid var(--line);background:var(--surface)}.editor-modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line-light)}.editor-modal__body{padding:18px}.editor-table{width:100%;border-collapse:collapse;font-size:.9rem}.editor-table th,.editor-table td{border-bottom:1px solid var(--line-light);padding:12px 10px;text-align:left;vertical-align:top}.editor-table th{font-family:var(--font-display);font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2)}.editor-table td{color:var(--text-2)}.editor-table__status{color:var(--accent);font-weight:600}.editor-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}[data-editor-panel=about] .editor-form,[data-editor-panel=about] .editor-form__row{align-content:start}.editor-note{margin:0;color:var(--text-3);font-size:.84rem}.editor-savebar{display:flex;justify-content:center;padding:28px 0 4px}.article-meta{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--surface);border:1px solid var(--line);border-radius:0;flex-wrap:wrap;gap:12px;margin-bottom:20px}.article-meta--header{margin-top:4px}.article-meta__info{display:flex;align-items:center;gap:16px}.article-meta__date,.article-meta__duration{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-2)}.article-meta__date svg,.article-meta__duration svg{flex-shrink:0}.article-meta__tags{display:flex;gap:8px;flex-wrap:wrap}.article-meta__tag{padding:4px 10px;font-family:var(--font-mono);font-size:.7rem;font-weight:500;background:var(--accent-soft);color:var(--accent);border-radius:0}.content-page-wrapper{width:100%;position:relative;min-height:100vh;display:flex;flex-direction:column}.content-page-wrapper>.site-header{width:100vw!important;margin-left:calc(50% - 50vw)!important;flex-shrink:0}.content-page-wrapper>.site-header>.shell{width:66.67vw;max-width:1200px;margin-left:auto;margin-right:auto}.content-page-wrapper>main.shell{width:66.67vw!important;max-width:1200px!important;margin-left:auto!important;margin-right:auto!important;flex:1}.content-page-wrapper>.site-footer{width:100vw!important;margin-left:calc(50% - 50vw)!important;flex-shrink:0}.content-page-wrapper>.site-footer>.shell{width:66.67vw;max-width:1200px;margin-left:auto;margin-right:auto}body[data-page=home] .content-page-wrapper{min-height:auto;display:block}body[data-page=home] .content-page-wrapper>.site-footer{width:100vw!important;margin-left:calc(50% - 50vw)!important;margin-top:0!important}body[data-page=home] .content-page-wrapper>.site-footer>.shell{width:66.67vw;max-width:1200px;margin-left:auto;margin-right:auto}body[data-page=home] .content-page-wrapper>section{width:100%;margin-left:0;margin-right:0}body[data-page=home] .hp-cta{padding-bottom:32px}body[data-page=home] .site-footer,body[data-page=project-detail] .site-footer{margin-top:0}.article-page-wrapper{width:100%;position:relative;min-height:100vh;display:flex;flex-direction:column}.article-page-wrapper>.site-header{width:100vw!important;margin-left:calc(50% - 50vw)!important;flex-shrink:0}.article-page-wrapper>.site-header>.shell{width:66.67vw;max-width:1200px;margin-left:auto;margin-right:auto}.article-page-wrapper>main.shell{width:66.67vw!important;max-width:1200px!important;margin-left:auto!important;margin-right:auto!important;flex:1}.article-page-wrapper>.site-footer{width:100vw!important;margin-left:calc(50% - 50vw)!important;flex-shrink:0}.article-page-wrapper>.site-footer>.shell{width:66.67vw;max-width:1200px;margin-left:auto;margin-right:auto}.article-toc-sidebar{position:fixed;left:calc(83.33% + 20px);top:180px;width:200px;max-height:calc(100vh - 200px);overflow-y:auto}.article-toc{padding-right:4px}.article-toc__title{font-size:.75rem;font-weight:600;margin:0 0 16px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.article-toc__list{list-style:none;padding:0;margin:0;display:grid;gap:2px}.article-toc__list a{display:block;font-size:.82rem;color:var(--text-3);text-decoration:none;transition:all .15s ease;border-left:2px solid transparent;padding:6px 0 6px 12px;margin-left:-14px}.article-toc__list a:hover{color:var(--accent);border-left-color:var(--accent);padding-left:16px}.article-content{display:block;color:var(--text-1);font-size:1rem;line-height:1.85}.article-content>:first-child{margin-top:0}.article-content>:last-child{margin-bottom:0}.article-content h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin:36px 0 14px;letter-spacing:-.02em;color:var(--text-1)}.article-content p{margin:0 0 16px;font-size:1rem;line-height:1.85;color:var(--text-2)}.article-content p.has-soft-breaks{white-space:pre-line;line-height:1.8}body[data-page=about] .article-content p.has-soft-breaks{line-height:1.2}.article-content ul,.article-content ol{margin:0 0 18px;color:var(--text-2)}.article-content ul{list-style:none;padding-left:0}.article-content ol{list-style-position:outside;padding-left:30px}.article-content li{margin:0 0 8px;line-height:1.8}.article-content ul li{position:relative;padding-left:20px}.article-content ul li:before{content:"•";position:absolute;left:0;top:0;font-size:1rem;line-height:1.8;font-weight:700;color:var(--text-1)}.article-content ol li::marker{color:var(--text-1);font-weight:600}.article-content li:last-child{margin-bottom:0}.article-content strong{color:var(--text-1);font-weight:600}.article-content code{font-family:var(--font-mono);font-size:.92em;padding:.14em .4em;border-radius:8px;background:#0f172a0f}.article-content pre{margin:20px 0}.article-content img{display:block;width:100%;height:auto;margin:22px 0;border-radius:20px;border:1px solid rgba(15,23,42,.08);box-shadow:0 18px 40px #0f172a14;background:#f8fafc}.article-content img.is-zoomable{cursor:zoom-in;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.article-content img.is-zoomable:hover{transform:translateY(-2px);border-color:#2563eb2e;box-shadow:0 22px 44px #0f172a1f}.article-content blockquote{margin:16px 0;padding:12px 16px;border-left:4px solid var(--accent);background:#4f46e50a}.article-content blockquote p{margin:0;font-size:.95rem;line-height:1.7;color:var(--text-2);font-style:italic}.has-md-lightbox{overflow:hidden}.md-image-lightbox{position:fixed;inset:0;z-index:1200;display:none;align-items:center;justify-content:center;padding:24px;background:#0f172ac7;backdrop-filter:blur(8px)}.md-image-lightbox.is-open{display:flex}.md-image-lightbox__panel{position:relative;width:100%;max-width:min(1280px,calc(100vw - 48px));max-height:calc(100vh - 48px);display:flex;flex-direction:column;align-items:center}.md-image-lightbox__close{position:fixed;top:24px;right:24px;z-index:1201;padding:8px 14px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:#0f172a85;color:#f8fafc;font-size:.85rem;line-height:1;backdrop-filter:blur(8px)}.md-image-lightbox__image{display:block;width:auto;max-width:min(1280px,calc(100vw - 48px));max-height:calc(100vh - 120px);margin:0 auto;border-radius:22px;box-shadow:0 30px 70px #0f172a59;background:#fff;object-fit:contain;transform-origin:center center;transition:transform .14s ease;cursor:zoom-in;will-change:transform}.md-image-lightbox__image.is-zoomed{cursor:zoom-out}.md-image-lightbox__caption{margin:14px auto 0;max-width:72ch;text-align:center;font-size:.92rem;line-height:1.6;color:#f8fafce0}.article-content pre code{padding:0;border-radius:0;background:transparent;font-size:.88rem;line-height:1.7}.md-code-block{margin:20px 0;border:1px solid var(--line);border-radius:0;background:var(--bg);overflow:hidden;box-shadow:none}.md-code-block__header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;background:#00000005;border-bottom:1px solid var(--line)}.md-code-block__meta{display:flex;align-items:center;gap:10px;min-width:0}.md-code-block__lang{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;color:var(--text-3)}.md-code-block__actions{display:flex;align-items:center;gap:8px}.md-code-block__toggle,.md-code-block__copy{padding:4px 10px;border:1px solid var(--line);border-radius:4px;background:var(--surface);color:var(--text-1);font-size:.75rem;line-height:1;transition:background .16s ease,border-color .16s ease,transform .16s ease}.md-code-block__toggle:hover,.md-code-block__copy:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:none}.md-code-block__toggle.is-collapsed{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.md-code-block__copy.is-copied{background:var(--text);border-color:var(--text);color:#fff}.md-code-block__body{overflow:hidden}.md-code-block.is-collapsed .md-code-block__body{display:none}.md-code-block .astro-code{margin:0;padding:16px;border-radius:0;border:0;box-shadow:none;background:transparent!important}.md-code-block .astro-code code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem;line-height:1.6;color:var(--text-1)}.md-code-block .astro-code code{counter-reset:code-line}.md-code-block .astro-code .line{display:block;min-height:1.6em;padding-left:56px;position:relative}.md-code-block .astro-code .line:before{counter-increment:code-line;content:counter(code-line);position:absolute;left:0;top:0;display:block;width:42px;padding-right:14px;color:var(--text-3);text-align:right;user-select:none}.md-code-block .astro-code .line>span{line-height:1.6}.md-code-block.is-plain .astro-code code,.md-code-block.is-plain .astro-code .line,.md-code-block.is-plain .astro-code .line>span,.md-code-block.is-plain .astro-code .line>span span{color:#2f241c!important}.md-code-block .astro-code .line>span[style*="color:#6A737D"],.md-code-block .astro-code .line>span span[style*="color:#6A737D"],.md-code-block .astro-code .line>span[style*="color:#6a737d"],.md-code-block .astro-code .line>span span[style*="color:#6a737d"],.md-code-block .astro-code .line>span[style*="color:#586069"],.md-code-block .astro-code .line>span span[style*="color:#586069"],.md-code-block .astro-code .line>span[style*="color:#959DA5"],.md-code-block .astro-code .line>span span[style*="color:#959DA5"],.md-code-block .astro-code .line>span[style*="color:#959da5"],.md-code-block .astro-code .line>span span[style*="color:#959da5"]{color:#4a372c!important}.md-code-block .astro-code .line>span[style*="color:#E1E4E8"],.md-code-block .astro-code .line>span span[style*="color:#E1E4E8"],.md-code-block .astro-code .line>span[style*="color:#e1e4e8"],.md-code-block .astro-code .line>span span[style*="color:#e1e4e8"]{color:#2f241c!important}.content-section h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--line);letter-spacing:-.02em}.content-section>p{font-size:1rem;line-height:1.75;color:var(--text-1);margin:0 0 16px}.content-section>p:last-child{margin-bottom:0}.content-list{list-style:none;padding:0;margin:16px 0;display:grid;gap:10px}.content-list li{font-size:.98rem;line-height:1.7;color:var(--text-2);padding-left:20px;position:relative}.content-list li:before{content:"•";position:absolute;left:0;color:var(--accent);font-weight:700}.content-list--numbered{counter-reset:content-counter}.content-list--numbered li{counter-increment:content-counter}.content-list--numbered li:before{content:counter(content-counter) ".";font-size:.9rem}.content-list strong{color:var(--text-1);font-weight:600}.code-block{margin:16px 0;background:var(--bg);border:1px solid var(--line);border-radius:0;overflow:hidden}.code-block__header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#00000005;border-bottom:1px solid var(--line)}.code-block__lang{font-family:var(--font-mono);font-size:.75rem;color:var(--text-3);text-transform:uppercase}.code-block__copy{padding:4px 10px;font-size:.75rem;background:var(--surface);border:1px solid var(--line);border-radius:4px;cursor:pointer;transition:all .15s ease}.code-block__copy:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.code-block__content{margin:0;padding:16px;overflow-x:auto}.code-block__content code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem;line-height:1.6;color:var(--text-1)}.content-quote{margin:16px 0;padding:12px 16px;border-left:4px solid var(--accent);background:#4f46e50a}.content-quote p{margin:0;font-size:.95rem;line-height:1.7;color:var(--text-2);font-style:italic}.article-content+.section{margin-top:28px}.back-button{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:var(--surface);border:1px solid var(--line);border-radius:0;color:var(--text-1);text-decoration:none;font-size:.95rem;font-weight:500;transition:all .2s ease}.back-button:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);transform:translate(-2px)}.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:var(--radius);overflow:hidden}.stat-item{padding:24px 20px;background:var(--surface);text-align:center}.stat-item:first-child{border-radius:var(--radius) 0 0 var(--radius)}.stat-item:last-child{border-radius:0 var(--radius) var(--radius) 0}.stat-item__number{font-family:var(--font-display);font-size:1.8rem;font-weight:700;letter-spacing:-.03em;background:var(--text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-item__label{margin-top:4px;font-size:.78rem;color:var(--text-3);font-weight:500}.cap-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.cap-item{padding:20px 22px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--line);transition:border-color .2s,box-shadow .2s}.cap-item:hover{border-color:#6366f11f;box-shadow:0 4px 16px #0000000a}.cap-item__icon{width:36px;height:36px;border-radius:0;background:var(--accent-soft);display:grid;place-items:center;font-size:1rem;margin-bottom:12px}.cap-item h3{font-family:var(--font-display);font-size:.92rem;font-weight:600;margin:0;letter-spacing:-.01em}.cap-item p{margin:4px 0 0;font-size:.82rem;color:var(--text-2);line-height:1.5}.cta-light{margin-top:80px;padding:56px 0;background:var(--surface);border-top:2px solid transparent;border-image:none;border-top:2px solid var(--accent);text-align:center}.cta-light h2{font-family:var(--font-display);font-size:clamp(1.3rem,2.5vw,1.6rem);font-weight:700;letter-spacing:-.02em;color:var(--text);margin:0}.cta-light p{color:var(--text-2);font-size:.92rem;max-width:380px;margin:8px auto 0}.cta-light__actions{display:flex;gap:10px;justify-content:center;margin-top:24px}@keyframes shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes gradientSlide{0%{background-position:0% 0%}50%{background-position:0% 100%}to{background-position:0% 0%}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-in-wait{opacity:0;transform:translateY(16px);transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1)}.fade-in-wait.is-visible{opacity:1;transform:translateY(0)}.detail-block.fade-in-wait:nth-child(2){transition-delay:60ms}.detail-block.fade-in-wait:nth-child(3){transition-delay:.12s}.detail-block.fade-in-wait:nth-child(4){transition-delay:.18s}.detail-block.fade-in-wait:nth-child(5){transition-delay:.24s}@media(max-width:1024px){.detail-layout,.two-column,.cards-grid--three{grid-template-columns:1fr}.content-page-wrapper>main.shell,.article-page-wrapper>main.shell{width:70vw}.content-page-wrapper>.site-header,.article-page-wrapper>.site-header{width:100vw!important;margin-left:calc(50% - 50vw)!important}.content-page-wrapper>.site-footer,.article-page-wrapper>.site-footer{width:100vw!important;margin-left:calc(50% - 50vw)!important}.content-page-wrapper>.site-header>.shell,.article-page-wrapper>.site-header>.shell{width:70vw;margin-left:auto;margin-right:auto}.content-page-wrapper>.site-footer>.shell,.article-page-wrapper>.site-footer>.shell{width:70vw;margin-left:auto;margin-right:auto}.article-toc-sidebar{left:calc(85% + 16px);width:160px}.article-toc__list a{font-size:.78rem}}@media(max-width:760px){.shell{width:min(var(--width),calc(100% - 32px))}.site-header .shell{height:auto;padding:10px 0;flex-direction:column;align-items:flex-start;gap:6px}.nav{width:100%;overflow-x:auto;gap:2px;padding-bottom:2px;-webkit-overflow-scrolling:touch}.nav a{white-space:nowrap;font-size:.8rem}.page-intro{padding-top:32px}.cards-grid,.cards-grid--three{grid-template-columns:1fr}.project-item{grid-template-columns:1fr;padding:18px 20px}.project-item__arrow{display:none}.project-featured{padding:22px 20px}.project-featured__arrow{display:none}.section{padding-top:0;padding-bottom:24px}.site-footer .shell{flex-direction:column;align-items:flex-start}.cta-light{margin-top:48px;padding:40px 0}.stats-bar{grid-template-columns:repeat(2,1fr)}.cap-grid{grid-template-columns:1fr}.project-nav{overflow-x:auto;padding-bottom:12px}.project-nav__link{white-space:nowrap}.project-filter{overflow-x:auto;padding-bottom:8px}.project-filter__btn{white-space:nowrap}.projects-grid{grid-template-columns:1fr}.project-card,.project-card--featured{padding:20px}.project-card__icon{width:40px;height:40px}.project-card__header,.project-card__meta,.project-card__footer,.project-card__tags{flex-wrap:wrap}.project-card__header{gap:12px;align-items:flex-start}.project-card__footer{gap:10px}.search-box{padding-inline:10px}.search-box__input{min-width:0;padding-inline:8px}.article-card,.article-card--featured{padding:20px}.article-card__header{flex-wrap:wrap}.article-card__icon{width:36px;height:36px}.article-card__meta{flex-wrap:wrap;gap:8px;margin-left:0}.article-card__title{font-size:1.15rem}.article-card--featured .article-card__title{font-size:1.25rem}.content-page-wrapper>main.shell,.article-page-wrapper>main.shell{width:100%}.content-page-wrapper>.site-header,.article-page-wrapper>.site-header{width:100vw!important;margin-left:calc(50% - 50vw)!important}.content-page-wrapper>.site-footer,.article-page-wrapper>.site-footer{width:100vw!important;margin-left:calc(50% - 50vw)!important}.content-page-wrapper>.site-header>.shell,.article-page-wrapper>.site-header>.shell{width:100%;margin-left:0;margin-right:0}.content-page-wrapper>.site-footer>.shell,.article-page-wrapper>.site-footer>.shell{width:100%;margin-left:0;margin-right:0}.article-toc-sidebar{display:none}.article-meta{flex-direction:column;align-items:flex-start}.content-section h2{font-size:1.2rem}.code-block__content{padding:12px;font-size:.8rem}.article-content+.section{margin-top:20px}.back-button{width:100%;justify-content:center}.md-image-lightbox{padding:18px 14px}.md-image-lightbox__close{top:14px;right:14px}.md-image-lightbox__image{max-height:72vh;border-radius:18px}.profile-card{flex-direction:column;text-align:center;padding:24px;gap:16px}.profile-card__avatar{width:64px;height:64px}.profile-card__name{font-size:1.2rem}.profile-card__info{text-align:center}.profile-card__location{display:inline-flex}.contact-button{width:100%;justify-content:center}.inline-actions{flex-direction:column;align-items:stretch}.inline-actions .button,.inline-actions .contact-button{width:100%}.editor-layout,.editor-grid{grid-template-columns:1fr}.editor-nav{position:static}.footer-meta{align-items:flex-start}.editor-date-field,.editor-tagbox__inputwrap,.editor-item-row{grid-template-columns:1fr}.editor-calendar{width:100%}.hp-hero{min-height:90vh;min-height:90dvh;padding-bottom:120px}.hp-hero.is-scrolled{padding-bottom:50px}.hp-hero__actions{flex-direction:column;align-items:center}.hp-hero__actions .button{width:min(320px,100%)}.hp-hero__scroll{bottom:50px}.hp-hero__scroll-ripple:before,.hp-hero__scroll-ripple:after{width:50px;height:50px}.hp-tech__inner{grid-template-columns:repeat(2,1fr);gap:10px}.hp-tech__inner{gap:10px}.hp-stats__inner{grid-template-columns:repeat(2,1fr);gap:10px}.hp-showcase__grid{grid-template-columns:1fr}.hp-showcase__card{flex-direction:column}.hp-showcase__card-tags{flex-wrap:wrap}.hp-cta{padding:56px 24px}.hp-cta__actions{flex-direction:column}.hp-cta__actions .button{width:100%}}
