:root{--font: "LXGW WenKai", "LXGW WenKai GB", "霞鹜文楷", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-mono: ui-monospace, "SF Mono", "Menlo", monospace;--bg: #faf8f5;--bg-elevated: #ffffff;--text: #1c1917;--text-muted: #57534e;--border: #e7e5e4;--link: #0969da;--link-hover: #0550ae;--accent: #c2410c;--accent-soft: color-mix(in srgb, var(--accent) 10%, var(--bg));--nav-height: 3.25rem;--container: 46rem;--container-wide: 72rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--shadow-sm: 0 1px 2px rgba(28, 25, 23, .06);--shadow-md: 0 10px 36px rgba(28, 25, 23, .09);--shadow-lg: 0 24px 56px rgba(28, 25, 23, .14);--ease-out: cubic-bezier(.22, 1, .36, 1);--page-pad: clamp(1rem, 4vw, 1.5rem);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--touch-min: 44px}[data-dark-mode]{--bg: #0c0a09;--bg-elevated: #1c1917;--text: #fafaf9;--text-muted: #a8a29e;--border: #292524;--link: #58a6ff;--link-hover: #79c0ff;--accent: #fb923c;--accent-soft: color-mix(in srgb, var(--accent) 8%, var(--bg));--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 8px 32px rgba(0, 0, 0, .45);--shadow-lg: 0 24px 56px rgba(0, 0, 0, .55)}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-height) + var(--safe-top) + .5rem);font-size:16px;-webkit-text-size-adjust:100%}body.nav-open{overflow:hidden;touch-action:none}body{margin:0;font-family:var(--font);font-size:1rem;line-height:1.75;color:var(--text);background:var(--bg);background-image:radial-gradient(ellipse 120% 70% at 80% -20%,color-mix(in srgb,var(--link) 8%,transparent),transparent 50%),radial-gradient(ellipse 90% 60% at 10% 0%,var(--accent-soft),transparent 55%);transition:background .25s,color .25s;padding-left:var(--safe-left);padding-right:var(--safe-right)}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.35;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}::-moz-selection{background:var(--link);color:#fff}::selection{background:var(--link);color:#fff}a{color:var(--link);text-decoration:none}a:hover{color:var(--link-hover);text-decoration:underline}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--link);outline-offset:2px}.wrapper{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;position:relative;z-index:1}.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--page-pad)}.container--wide{width:100%;max-width:var(--container-wide);margin-inline:auto}.navigation{border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:sticky;top:0;z-index:50;padding-top:var(--safe-top)}.navigation .container{display:flex;align-items:center;min-height:var(--nav-height);gap:.5rem 1rem;position:relative;flex-wrap:wrap}@media (min-width: 769px){.navigation .container{flex-wrap:nowrap}.navigation-links{margin-left:auto;margin-right:.5rem}}.navigation-links{position:relative;display:flex;align-items:center}.navigation-start{display:flex;align-items:center;gap:.45rem;margin-right:auto;flex-shrink:0;min-width:0}.navigation-brand{font-size:1.05rem;font-weight:600;color:var(--text);text-decoration:none;flex-shrink:0;padding:.35rem 0;letter-spacing:.02em}.navigation-start__sep{color:var(--text-muted);opacity:.45;font-weight:300;-webkit-user-select:none;-moz-user-select:none;user-select:none}.navigation-back{display:inline-flex;align-items:center;gap:.2rem;padding:.35rem 0;font-size:.875rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .28s linear}.navigation-back:hover{color:var(--link);text-decoration:none}.navigation-back__icon{display:flex;opacity:.85}.navigation-brand:hover{color:var(--link);text-decoration:none}.navigation-tools{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.navigation-list{position:relative;display:flex;align-items:center;flex-wrap:wrap;gap:.25rem 1.25rem;list-style:none;margin:0;padding:0}.navigation-indicator{position:absolute;bottom:0;left:0;height:2px;width:0;border-radius:1px;background:var(--link);opacity:0;z-index:0;pointer-events:none;transition:left .28s linear,width .28s linear,opacity .2s linear}.page-halpin .navigation-indicator{background:var(--halpin-accent)}.navigation-link{position:relative;z-index:1;color:var(--text);font-size:.95rem;text-decoration:none;padding:.35rem 0 .45rem;min-height:var(--touch-min);display:inline-flex;align-items:center}.navigation-link:hover,.navigation-link.active{color:var(--link);text-decoration:none}@media (max-width: 768px){.navigation-link:after{display:none}}.menu-separator{color:var(--text-muted);-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:0 .15rem}.navigation-dark button{display:flex;align-items:center;justify-content:center;width:var(--touch-min);height:var(--touch-min);padding:0;border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:var(--radius-sm)}.navigation-dark button:hover{background:color-mix(in srgb,var(--text) 8%,transparent)}[data-dark-mode] .toggle-light{display:inline}[data-dark-mode] .toggle-dark{display:none}:not([data-dark-mode]) .toggle-light{display:none}:not([data-dark-mode]) .toggle-dark{display:inline}.menu-toggle-input,#menu-toggle{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.menu-button,.nav-backdrop{display:none}@media (max-width: 768px){.navigation .container{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;flex-wrap:nowrap}.navigation-start{grid-column:1;grid-row:1;margin-right:0;max-width:none}.navigation-tools,.menu-toggle-input{grid-column:2;grid-row:1}.menu-button{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:var(--touch-min);height:var(--touch-min);cursor:pointer;border-radius:var(--radius-sm);border:none;background:transparent;padding:0}.menu-button span{display:block;width:1.25rem;height:2px;background:var(--text);border-radius:1px;transition:transform .2s,opacity .2s}#menu-toggle:checked~.navigation-tools .menu-button span:nth-child(1){transform:translateY(7px) rotate(45deg)}#menu-toggle:checked~.navigation-tools .menu-button span:nth-child(2){opacity:0}#menu-toggle:checked~.navigation-tools .menu-button span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-backdrop{position:fixed;inset:0;top:calc(var(--nav-height) + var(--safe-top));background:#00000059;z-index:40;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}#menu-toggle:checked~.nav-backdrop{display:block;opacity:1;visibility:visible}.navigation-links{grid-column:1 / -1;grid-row:2;width:100%}.navigation-links .navigation-list{display:none;position:fixed;top:calc(var(--nav-height) + var(--safe-top));left:var(--safe-left);right:var(--safe-right);flex-direction:column;align-items:stretch;padding:.75rem var(--page-pad) calc(1rem + var(--safe-bottom));background:var(--bg-elevated);border-bottom:1px solid var(--border);box-shadow:var(--shadow-md);gap:0;z-index:45;max-height:calc(100dvh - var(--nav-height) - var(--safe-top));overflow-y:auto}#menu-toggle:checked~.navigation-links .navigation-list{display:flex}.navigation-links .navigation-indicator{display:none}.page-halpin .navigation-link.active{box-shadow:inset 0 -2px 0 var(--halpin-accent)}.navigation-list .navigation-item{border-bottom:1px solid var(--border)}.navigation-list .navigation-item:last-child{border-bottom:none}.navigation-list .navigation-link{width:100%;padding:.85rem 0;font-size:1.05rem}.navigation-list .menu-separator{display:none}}#content{flex:1;padding:2rem 0 2.5rem}.page-title{font-size:clamp(1.5rem,4vw,1.75rem);font-weight:600;margin:0 0 1.5rem;color:var(--text)}.post-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.post-header h1{font-size:clamp(1.5rem,4vw,1.75rem);font-weight:600;margin:0 0 .5rem;line-height:1.35}.post-content{font-size:1.05rem;line-height:1.85}.post-content p{margin:1rem 0}.post-content h2{font-size:1.35rem;font-weight:600;margin:2rem 0 .75rem}.post-content ul{padding-left:1.5rem;margin:1rem 0}.post-content li{margin:.35rem 0}.post-actions{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:var(--touch-min);padding:.5rem 1.25rem;font-family:var(--font);font-size:.95rem;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);text-decoration:none;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.btn:hover{border-color:var(--link);color:var(--link);text-decoration:none}.btn-primary{background:var(--link);border-color:var(--link);color:#fff}.btn-primary:hover{background:var(--link-hover);border-color:var(--link-hover);color:#fff}.btn-muted{opacity:.65;cursor:default}.feature-list{list-style:none;padding:0;margin:1.5rem 0 0}.feature-list li{padding:1rem 0;border-top:1px solid var(--border)}.feature-list li:first-child{border-top:none;padding-top:0}.feature-list strong{display:block;font-size:1.05rem;margin-bottom:.25rem}.blog-meta{font-size:.875rem;color:var(--text-muted);margin:0 0 .75rem}.back-link{display:inline-flex;align-items:center;min-height:var(--touch-min);margin:0 0 1.25rem;font-size:.95rem;color:var(--text-muted)}.back-link:hover{color:var(--link)}.footer{border-top:1px solid var(--border);padding:1.25rem 0 calc(1.5rem + var(--safe-bottom));text-align:center;font-size:.875rem;color:var(--text-muted);background:color-mix(in srgb,var(--bg) 92%,transparent)}.footer p{margin:0;line-height:1.6}.footer a{color:var(--text-muted)}.footer a:hover{color:var(--link)}.footer-meta{margin-top:.35rem;font-size:.8rem;opacity:.85}.footer-legal{line-height:1.65}.footer-legal a{color:var(--text-muted)}.footer-legal a:hover{color:var(--link)}.footer-beian a{color:var(--text-muted)}.footer-beian a:hover{color:var(--link)}.site-beian{margin:0;padding:1.25rem var(--page-pad) calc(1.25rem + var(--safe-bottom));text-align:center;font-size:.8rem;line-height:1.6;color:var(--text-muted)}.site-beian a{color:var(--text-muted);text-decoration:none}.site-beian a:hover{color:var(--link)}.top-link{position:fixed;right:calc(1rem + var(--safe-right));bottom:calc(1rem + var(--safe-bottom));width:var(--touch-min);height:var(--touch-min);display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s,transform .2s;box-shadow:var(--shadow-md);z-index:30}.top-link.visible{opacity:1;visibility:visible}.top-link:hover{color:var(--link);transform:translateY(-2px);text-decoration:none}.content--home{flex:1;display:flex;flex-direction:column;padding:0}.content--home .container--wide:not(.halpin-hero__inner){flex:1;display:flex;flex-direction:column;align-items:center}.split-layout{flex:1;display:grid;grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);gap:clamp(1rem,3vw,2rem);align-items:flex-end;min-height:min(760px,calc(100dvh - var(--nav-height) - 4rem));padding:clamp(1.25rem,4vw,2.5rem) 0 clamp(1rem,3vw,1.5rem)}.split-left{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;max-width:26rem}.home-eyebrow{margin:0 0 .75rem;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);font-family:var(--font-mono)}.home-name{font-size:clamp(1.85rem,6vw,2.5rem);font-weight:600;margin:0;line-height:1.2;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text) 0%,color-mix(in srgb,var(--accent) 55%,var(--text)) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}[data-dark-mode] .home-name{background:linear-gradient(135deg,var(--text) 0%,color-mix(in srgb,var(--accent) 70%,var(--text)) 100%);-webkit-background-clip:text;background-clip:text}.home-id{margin:.85rem 0 0}.id-badge{display:inline-flex;align-items:center;padding:.2rem .65rem;font-family:var(--font-mono);font-size:.9rem;letter-spacing:.04em;color:var(--accent);background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:999px}.home-lead{margin:1.25rem 0 0;font-size:clamp(1.05rem,3.2vw,1.2rem);line-height:1.65;color:var(--text);font-weight:500;text-align:left;max-width:22em}.home-motto-wrap{margin:1rem 0 0;border:1px solid var(--border);border-radius:var(--radius-md);background:color-mix(in srgb,var(--bg-elevated) 70%,transparent);overflow:hidden}.home-motto-summary{padding:.75rem 1rem;font-size:.9rem;color:var(--link);cursor:pointer;list-style:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.home-motto-summary::-webkit-details-marker{display:none}.home-motto-summary:after{content:" ▾";opacity:.6}.home-motto-wrap[open] .home-motto-summary:after{content:" ▴"}.home-motto-wrap .home-motto{margin:0;padding:0 1rem 1rem;border-top:1px solid var(--border)}.home-motto--always{display:block}.home-motto-wrap{display:none}.home-motto{margin:1.25rem 0 0;font-size:clamp(.92rem,2.6vw,1.05rem);line-height:1.85;color:var(--text-muted);text-align:left}.highlights{list-style:none;margin:1.25rem 0 0;padding:0;display:flex;flex-direction:column;gap:.55rem;width:100%;max-width:22rem}.highlights-item{display:flex;align-items:flex-start;gap:.65rem;padding:.65rem .75rem;border:1px solid var(--border);border-radius:var(--radius-md);background:color-mix(in srgb,var(--bg-elevated) 75%,transparent);transition:border-color var(--dur-fast, .25s),transform var(--dur-fast, .25s)}@media (hover: hover){.highlights-item:hover{border-color:color-mix(in srgb,var(--link) 35%,var(--border));transform:translate(4px)}}.highlights-icon{font-size:1.15rem;line-height:1.4;flex-shrink:0}.highlights-text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.highlights-text strong{font-size:.92rem;font-weight:600;color:var(--text)}.highlights-text span{font-size:.78rem;color:var(--text-muted)}.home-actions{margin-top:1.75rem;display:flex;flex-wrap:wrap;gap:.65rem;width:100%}.btn-copy.is-copied{border-color:var(--link);color:var(--link)}.btn-contact{border-color:color-mix(in srgb,var(--link) 35%,var(--border));background:color-mix(in srgb,var(--link) 6%,var(--bg-elevated));font-size:.9rem;max-width:100%;word-break:break-all}.btn-contact:hover{background:color-mix(in srgb,var(--link) 12%,var(--bg-elevated))}.split-right{display:flex;align-items:center;justify-content:center;width:100%}.split-right--portrait{align-items:flex-end;justify-content:center;padding-bottom:0;overflow:visible}.hero-portrait{position:relative;width:100%;max-width:min(560px,108%);margin:0;padding:0;background:none;border:none;box-shadow:none;display:flex;align-items:flex-end;justify-content:center;line-height:0}.hero-portrait-glow{position:absolute;inset:5% 0 -5%;background:radial-gradient(ellipse 55% 50% at 50% 75%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 70%);pointer-events:none;z-index:0}.hero-portrait-img{position:relative;z-index:1;display:block;width:auto;max-width:100%;height:auto;max-height:min(78vh,720px);min-height:min(420px,55vh);-o-object-fit:contain;object-fit:contain;-o-object-position:bottom center;object-position:bottom center;margin:0}.hero-portrait-frame .hero-portrait-img{width:100%;height:100%;max-height:none;min-height:0;-o-object-position:center;object-position:center}.page-halpin .hero-portrait-img{min-height:0}.hero-portrait-frame .hero-portrait-img{filter:none}.page-halpin .hero-portrait-img,:not([data-dark-mode]) .hero-portrait:not(:has(.hero-portrait-frame)) .hero-portrait-img{filter:none;box-shadow:none}[data-dark-mode] body:not(.page-halpin) .hero-portrait:not(:has(.hero-portrait-frame)) .hero-portrait-img{filter:invert(1) brightness(1.05) drop-shadow(0 12px 40px rgba(0,0,0,.4))}.showcase{width:100%;max-width:440px;background:color-mix(in srgb,var(--bg-elevated) 92%,var(--bg));border:1px solid color-mix(in srgb,var(--border) 80%,var(--accent) 12%);border-radius:var(--radius-lg);padding:clamp(1.15rem,3vw,1.5rem);box-shadow:var(--shadow-md);transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out)}@media (hover: hover){.showcase:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}}.showcase-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin:.5rem 0 0;padding:0;list-style:none}.showcase-tags li{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.04em;padding:.15rem .45rem;border-radius:999px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border)}.showcase-head{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.showcase-app-icon{width:clamp(3.5rem,12vw,4.5rem);height:clamp(3.5rem,12vw,4.5rem);border-radius:14px;box-shadow:var(--shadow-sm);flex-shrink:0}.showcase-label{margin:0;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.showcase-title{margin:.1rem 0 0;font-size:clamp(1.15rem,4vw,1.35rem);font-weight:600}.showcase-title a{color:var(--text);text-decoration:none}.showcase-title a:hover{color:var(--link);text-decoration:none}.showcase-sub{margin:.15rem 0 0;font-size:.875rem;color:var(--text-muted)}.showcase-hint{margin:0 0 .5rem;font-size:.75rem;color:var(--text-muted);text-align:center}@media (min-width: 961px){.home-motto--always{display:block}.home-motto-wrap{display:none}}@media (min-width: 769px){.showcase-hint{display:none}}.slider{position:relative;display:flex;align-items:center;gap:.35rem;margin:.15rem 0 .5rem}.slider-viewport{flex:1;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.35rem 0 .85rem;overscroll-behavior-x:contain}.slider-viewport::-webkit-scrollbar{display:none}.slider-track{display:flex;gap:clamp(.85rem,3vw,1.25rem);width:-moz-max-content;width:max-content;padding:0 .35rem}.slider-slide{flex:0 0 auto;scroll-snap-align:center;width:min(220px,68vw)}.slider-arrow{flex-shrink:0;width:var(--touch-min);height:var(--touch-min);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-muted);font-size:1.35rem;line-height:1;cursor:pointer;display:grid;place-items:center;padding:0}.slider-arrow:hover{color:var(--text);border-color:var(--text-muted)}.phone{margin:0;text-align:center}.phone figcaption{margin-top:.45rem;font-size:.78rem;color:var(--text-muted)}.phone-bezel{position:relative;background:#1a1a1a;border-radius:clamp(22px,6vw,28px);padding:10px 8px 12px;box-shadow:var(--shadow-lg)}.phone-notch{position:absolute;top:12px;left:50%;transform:translate(-50%);width:64px;height:20px;background:#1a1a1a;border-radius:0 0 12px 12px;z-index:2}.phone-bezel img{display:block;width:100%;height:auto;border-radius:18px;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.slider-dots{display:flex;justify-content:center;gap:.5rem;margin-bottom:.85rem}.slider-dot{width:10px;height:10px;padding:0;border:none;border-radius:50%;background:var(--border);cursor:pointer;min-width:var(--touch-min);min-height:var(--touch-min);display:grid;place-items:center;background:transparent}.slider-dot:after{content:"";width:8px;height:8px;border-radius:50%;background:var(--border);transition:transform .15s,background .15s}.slider-dot.is-active:after{background:var(--link);transform:scale(1.2)}.download-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem;padding-top:1rem;border-top:1px solid var(--border)}.download-tile{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.4rem;min-height:3rem;padding:.55rem .65rem;font-family:var(--font);font-size:.95rem;font-weight:600;letter-spacing:.03em;color:var(--text);background:var(--bg);border:1.5px solid var(--text);border-radius:var(--radius-sm);text-decoration:none;transition:background .15s,color .15s,border-color .15s;text-align:center}.download-tile-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.9}.download-tile-text{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;min-width:0}.download-tile-label{line-height:1.2}.download-tile-status{font-size:.65rem;font-weight:400;letter-spacing:0;color:var(--text-muted);line-height:1}a.download-tile:hover{background:var(--text);color:var(--bg);text-decoration:none}a.download-tile:hover .download-tile-status{color:color-mix(in srgb,var(--bg) 75%,transparent)}.download-tile--disabled{color:var(--text-muted);border-color:var(--border);border-style:dashed;cursor:not-allowed;opacity:.75;background:transparent}.post-actions--downloads{padding-top:1.5rem;border-top:1px solid var(--border)}.post-actions--downloads .download-row{border-top:none;padding-top:0;max-width:100%}.works-collection{padding:clamp(2.5rem,6vw,4rem) 0 clamp(3rem,7vw,5rem);margin-top:clamp(.25rem,2vw,.75rem);border-top:1px solid var(--border);scroll-margin-top:calc(var(--nav-height) + var(--safe-top) + 1rem)}.works-collection-intro{text-align:center;margin-bottom:clamp(1.75rem,4vw,2.5rem)}.section-eyebrow{margin:0 0 .5rem;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}.section-head{margin-bottom:1.25rem;text-align:center}.section-title{margin:0;font-size:clamp(1.25rem,4vw,1.5rem);font-weight:600}.section-desc{margin:.35rem 0 0;font-size:.875rem;color:var(--text-muted)}.works-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));gap:1rem}.work-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);text-decoration:none;color:inherit;position:relative;overflow:hidden;transition:transform .3s var(--ease-out, cubic-bezier(.22, 1, .36, 1)),box-shadow .3s,border-color .25s}.work-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,color-mix(in srgb,var(--link) 6%,transparent),transparent 55%);opacity:0;transition:opacity .3s}@media (hover: hover){a.work-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--link) 30%,var(--border));text-decoration:none}a.work-card:hover:before{opacity:1}a.work-card:hover .work-card-arrow{transform:translate(4px);color:var(--link)}}.work-card--soon,.work-card--sample{opacity:.92;cursor:default}.work-card--sample{border-style:dashed;border-color:color-mix(in srgb,var(--link) 25%,var(--border))}.work-card-badge--sample{background:color-mix(in srgb,var(--link) 10%,var(--bg));color:var(--link);border-color:color-mix(in srgb,var(--link) 25%,transparent)}.work-card-icon{flex-shrink:0;width:3rem;height:3rem;border-radius:12px;overflow:hidden;display:grid;place-items:center;background:var(--bg);box-shadow:var(--shadow-sm)}.work-card-icon img{display:block;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.work-card-emoji{font-size:1.5rem}.work-card-body{flex:1;min-width:0}.work-card-tag{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.work-card-name{margin:.2rem 0 0;font-size:1.05rem;font-weight:600}.work-card-sub{margin:.2rem 0 0;font-size:.82rem;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.work-card-arrow{flex-shrink:0;font-size:1.25rem;color:var(--text-muted);transition:transform .25s,color .25s}.work-card-badge{position:absolute;top:.65rem;right:.65rem;font-size:.65rem;padding:.15rem .45rem;border-radius:999px;background:var(--accent-soft);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent)}.works-collection-featured{display:flex;justify-content:center;margin-bottom:clamp(1.5rem,4vw,2.25rem)}.works-collection-featured .showcase{max-width:min(100%,460px);width:100%}.works-collection-bridge{display:flex;align-items:center;gap:1rem;margin:0 auto clamp(1.5rem,4vw,2rem);max-width:28rem}.works-collection-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}.works-collection-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}.works-collection-grid .works-grid{gap:1.1rem}.page-404{text-align:center;padding:clamp(3rem,12vw,6rem) 0}.page-404-code{font-family:var(--font-mono);font-size:clamp(4rem,18vw,7rem);font-weight:600;line-height:1;margin:0;background:linear-gradient(180deg,var(--text-muted),color-mix(in srgb,var(--accent) 50%,var(--text-muted)));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.page-404 h1{margin:.5rem 0 0;font-size:clamp(1.35rem,4vw,1.75rem)}.page-404-desc{margin:.75rem auto 0;max-width:28rem;color:var(--text-muted)}.page-404 .post-actions{justify-content:center;margin-top:1.75rem}.toast{position:fixed;left:50%;bottom:calc(5.5rem + var(--safe-bottom));z-index:80;padding:.65rem 1.15rem;font-size:.9rem;color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);transform:translate(-50%) translateY(12px);opacity:0;visibility:hidden;transition:opacity .3s var(--ease-smooth, ease),transform .35s var(--ease-spring, ease),visibility .3s;pointer-events:none}.toast.is-visible{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}@media (max-width: 960px){.split-layout{grid-template-columns:1fr;gap:clamp(1.75rem,5vw,2.5rem);min-height:auto;padding:clamp(1rem,3vw,1.75rem) 0 clamp(1.75rem,4vw,2.5rem)}.split-left{max-width:none;order:1;text-align:center;align-items:center}.split-right{order:2}.split-right--portrait{order:1;margin-bottom:.25rem}.hero-portrait{max-width:min(380px,94vw)}.hero-portrait-img{max-height:min(480px,52vh);min-height:min(320px,42vh)}.home-lead,.home-motto,.home-motto--always{text-align:center;max-width:36rem;margin-left:auto;margin-right:auto}.home-motto--always{display:none}.home-motto-wrap{display:block;width:100%;max-width:36rem;text-align:left}.home-motto-wrap .home-motto{text-align:left}.highlights{max-width:36rem;margin-left:auto;margin-right:auto}.home-actions{justify-content:center}.btn-contact{word-break:normal;padding-left:1.5rem;padding-right:1.5rem}.showcase{max-width:min(100%,400px);margin-inline:auto}.slider-slide{width:min(200px,72vw)}}.slider-arrow:disabled{opacity:.35;cursor:not-allowed;transform:none}.post-header--app{display:flex;gap:1.25rem;align-items:flex-start}.post-app-icon{width:clamp(3.5rem,14vw,4rem);height:clamp(3.5rem,14vw,4rem);border-radius:14px;box-shadow:var(--shadow-sm);flex-shrink:0}.post-header-text .summary{margin:.5rem 0 0;color:var(--text-muted)}.post-tech{color:var(--text-muted);font-size:.95rem;margin:1.5rem 0 0}@media (max-width: 520px){.post-header--app{flex-direction:column;align-items:center;text-align:center}.post-header-text{width:100%}#content{padding:1.25rem 0 2rem}.slider-arrow{display:none}.download-row{grid-template-columns:1fr;gap:.5rem}.download-tile{min-height:var(--touch-min);flex-direction:row;justify-content:space-between;padding:.65rem 1rem}.download-tile-status{font-size:.75rem}.btn-contact{width:100%}.navigation-brand{font-size:.98rem;max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}@media (max-width: 380px){.home-name{font-size:1.65rem}.slider-slide{width:min(180px,78vw)}}.prose .en{display:none}.prose .perm-table{margin:1rem 0;border-top:1px solid var(--border);font-size:.95rem}.prose .perm-table>div{display:grid;grid-template-columns:1fr 2fr;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--border)}@media (max-width: 640px){.prose .perm-table>div{grid-template-columns:1fr}}:root{--dur-instant: .15s;--dur-fast: .25s;--dur-normal: .45s;--dur-slow: .7s;--dur-enter: .9s;--dur-ambient: 4s;--ease-spring: cubic-bezier(.34, 1.45, .64, 1);--ease-smooth: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--stagger: .08s}@keyframes motion-fade-up{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes motion-fade-down{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes motion-scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes motion-slide-in-right{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes motion-slide-in-left{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes motion-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes motion-glow-pulse{0%,to{opacity:.45;transform:scale(1)}50%{opacity:.75;transform:scale(1.05)}}@keyframes motion-shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes motion-bounce-soft{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}@keyframes motion-spin-slow{to{transform:rotate(360deg)}}@keyframes motion-top-in{0%{opacity:0;transform:translateY(12px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes motion-menu-item{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes motion-details-open{0%{opacity:0;max-height:0}to{opacity:1;max-height:800px}}@keyframes motion-gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:60;pointer-events:none;transform-origin:left;transform:scaleX(0);background:linear-gradient(90deg,var(--accent),var(--link));transition:transform .12s linear;padding-top:var(--safe-top)}.navigation{transition:background-color var(--dur-normal) var(--ease-smooth),border-color var(--dur-normal) var(--ease-smooth),box-shadow var(--dur-normal) var(--ease-smooth)}html.motion-ready .navigation{animation:motion-fade-down var(--dur-enter) var(--ease-smooth) both}.navigation.nav-scrolled{box-shadow:var(--shadow-sm);background:color-mix(in srgb,var(--bg) 94%,transparent)}.navigation-link{position:relative;transition:color var(--dur-fast) var(--ease-smooth)}.navigation-link:after{content:"";position:absolute;left:0;bottom:.2rem;width:100%;height:2px;background:var(--link);transform:scaleX(0);transform-origin:left;transition:transform var(--dur-normal) linear}.navigation-link:hover:after,.navigation-link.active:after{transform:scaleX(1)}.navigation-dark button{transition:transform var(--dur-fast) var(--ease-spring),background var(--dur-fast)}.navigation-dark button:active{transform:scale(.92)}html.theme-transitioning,html.theme-transitioning *,html.theme-transitioning *:before,html.theme-transitioning *:after{transition:background-color .5s var(--ease-smooth),color .45s var(--ease-smooth),border-color .45s var(--ease-smooth),box-shadow .45s var(--ease-smooth)!important}@media (max-width: 768px){.navigation-links .navigation-list{transform:translateY(-12px);opacity:0;transition:transform var(--dur-normal) var(--ease-smooth),opacity var(--dur-fast) var(--ease-smooth),visibility var(--dur-fast)}#menu-toggle:checked~.navigation-links .navigation-list{transform:translateY(0);opacity:1}#menu-toggle:checked~.navigation-links .navigation-list .navigation-item{animation:motion-menu-item var(--dur-normal) var(--ease-smooth) both}#menu-toggle:checked~.navigation-links .navigation-list .navigation-item:nth-child(1){animation-delay:.05s}#menu-toggle:checked~.navigation-links .navigation-list .navigation-item:nth-child(2){animation-delay:.1s}#menu-toggle:checked~.navigation-links .navigation-list .navigation-item:nth-child(3){animation-delay:.15s}.nav-backdrop{transition:opacity var(--dur-normal) var(--ease-smooth),visibility var(--dur-normal)}}[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity var(--dur-enter) var(--ease-smooth),transform var(--dur-enter) var(--ease-smooth);transition-delay:calc(var(--reveal-i, 0) * var(--stagger))}[data-reveal=scale]{transform:scale(.94)}[data-reveal=left]{transform:translate(-28px)}[data-reveal=right]{transform:translate(36px)}[data-reveal].is-revealed{opacity:1;transform:none}html.motion-ready [data-hero-seq]{animation:motion-fade-up var(--dur-enter) var(--ease-smooth) both;animation-delay:calc(var(--hero-i, 0) * .1s)}html.motion-ready [data-hero-seq=showcase]{animation-name:motion-slide-in-right;animation-duration:1s;animation-delay:.35s}html.motion-ready [data-hero-seq=portrait]{animation-name:motion-fade-up;animation-duration:1.05s;animation-delay:.25s}html.motion-ready [data-hero-seq=portrait] .hero-portrait-img{animation:motion-fade-up 1.05s var(--ease-smooth) .35s both}html.motion-ready body.page-halpin [data-hero-seq=portrait] .hero-portrait-img{animation:none;opacity:1;transform:none}.works-collection-intro.is-revealed{animation:motion-fade-up var(--dur-enter) var(--ease-smooth) both}.works-collection-featured.is-revealed .showcase{animation:motion-scale-in var(--dur-slow) var(--ease-smooth) .12s both}.works-collection-bridge.is-revealed{animation:motion-fade-up var(--dur-normal) var(--ease-smooth) .2s both}.works-collection-grid.is-revealed{animation:motion-fade-up var(--dur-enter) var(--ease-smooth) .28s both}.showcase-wrap{position:relative}.showcase-glow{position:absolute;inset:-20% -10%;z-index:0;pointer-events:none;background:radial-gradient(ellipse 60% 50% at 50% 40%,color-mix(in srgb,var(--accent) 22%,transparent),transparent 70%);animation:motion-glow-pulse var(--dur-ambient) var(--ease-in-out) infinite;opacity:0;transition:opacity 1s var(--ease-smooth)}.showcase-wrap.is-revealed .showcase-glow,.showcase-wrap:has(.showcase.is-revealed) .showcase-glow{opacity:1}.showcase{position:relative;z-index:1}.showcase-app-icon{transition:transform var(--dur-normal) var(--ease-spring)}html.motion-on .showcase.is-revealed .showcase-app-icon{animation:motion-float 4s var(--ease-in-out) infinite;animation-delay:.5s}.showcase-tags li{transition:transform var(--dur-fast) var(--ease-spring),border-color var(--dur-fast),background var(--dur-fast)}.showcase-tags li:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--link) 40%,var(--border))}html.motion-on .id-badge{background-image:linear-gradient(105deg,var(--accent-soft) 0%,color-mix(in srgb,var(--accent) 18%,var(--bg)) 45%,var(--accent-soft) 90%);background-size:200% auto;animation:motion-shimmer 6s linear infinite}.btn{position:relative;overflow:hidden;transition:transform var(--dur-fast) var(--ease-spring),box-shadow var(--dur-fast) var(--ease-smooth),border-color var(--dur-fast),color var(--dur-fast),background var(--dur-fast)}.btn:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--ripple-x, 50%) var(--ripple-y, 50%),color-mix(in srgb,#fff 35%,transparent) 0%,transparent 55%);opacity:0;transform:scale(0);transition:opacity var(--dur-fast),transform .5s var(--ease-smooth)}.btn:active:after{opacity:1;transform:scale(2.5);transition:0s}@media (hover: hover){.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none}.btn-primary:hover{box-shadow:0 8px 24px color-mix(in srgb,var(--link) 35%,transparent)}.btn:active{transform:translateY(0) scale(.98)}}.slider-slide{transition:transform var(--dur-normal) var(--ease-spring)}.slider-slide.is-active .phone-bezel{transform:scale(1.03);box-shadow:var(--shadow-lg),0 0 40px color-mix(in srgb,var(--link) 15%,transparent)}.slider-slide:not(.is-active) .phone-bezel{transform:scale(.96);opacity:.88;transition:transform var(--dur-normal) var(--ease-smooth),opacity var(--dur-normal)}.phone-bezel{transition:transform var(--dur-normal) var(--ease-spring),box-shadow var(--dur-slow) var(--ease-smooth),opacity var(--dur-normal)}.slider-arrow{transition:transform var(--dur-fast) var(--ease-spring),border-color var(--dur-fast),color var(--dur-fast),background var(--dur-fast)}.slider-arrow:hover{transform:scale(1.06)}.slider-arrow:active{transform:scale(.95)}.slider-dot:after{transition:transform var(--dur-fast) var(--ease-spring),background var(--dur-fast),width var(--dur-fast)}.slider-dot.is-active:after{width:20px;border-radius:4px}.showcase-hint{animation:motion-bounce-soft 2s var(--ease-in-out) infinite}.download-tile{transition:transform var(--dur-fast) var(--ease-spring),background var(--dur-fast),color var(--dur-fast),border-color var(--dur-fast)}@media (hover: hover){a.download-tile:hover{transform:translateY(-3px)}a.download-tile:active{transform:translateY(0) scale(.98)}}.top-link{transition:opacity var(--dur-normal) var(--ease-smooth),visibility var(--dur-normal),transform var(--dur-normal) var(--ease-spring),box-shadow var(--dur-fast),color var(--dur-fast)}.top-link.visible{animation:motion-top-in var(--dur-normal) var(--ease-spring) both}.top-link:hover svg{animation:motion-bounce-soft .6s var(--ease-in-out)}.footer{transition:opacity var(--dur-enter) var(--ease-smooth)}.footer.is-revealed{opacity:1}.feature-list li{opacity:0;transform:translate(-16px);transition:opacity var(--dur-normal) var(--ease-smooth),transform var(--dur-normal) var(--ease-smooth);transition-delay:calc(var(--reveal-i, 0) * .06s)}.feature-list.is-revealed li{opacity:1;transform:none}.scroll-hint{display:none;flex-direction:column;align-items:center;gap:.35rem;margin-top:1.5rem;font-size:.75rem;color:var(--text-muted);text-decoration:none;opacity:0;animation:motion-fade-up var(--dur-enter) var(--ease-smooth) 1.2s both}.scroll-hint svg{animation:motion-bounce-soft 2s var(--ease-in-out) infinite}@media (min-width: 769px){.scroll-hint{display:flex}}.scroll-hint:hover{color:var(--link);text-decoration:none}.home-motto-wrap[open] .home-motto{animation:motion-fade-up var(--dur-normal) var(--ease-smooth)}.home-motto-summary{transition:color var(--dur-fast)}html.motion-on body{background-size:200% 200%;animation:motion-gradient-shift 18s ease infinite}.split-left,.split-right{animation:none}@media (prefers-reduced-motion: reduce){[data-reveal],[data-hero-seq],.navigation,.showcase,.showcase-app-icon,.id-badge,.showcase-hint,.scroll-hint,body{animation:none!important;transition:none!important}[data-reveal],html.motion-ready [data-reveal]{opacity:1;transform:none}.slider-slide .phone-bezel{transform:none!important;opacity:1!important}}.page-halpin{--halpin-bg: #000000;--halpin-elevated: #111111;--halpin-card: #141414;--halpin-text: #fafaf9;--halpin-muted: #a8a29e;--halpin-accent: #ffb020;--halpin-accent-soft: rgba(255, 176, 32, .12);--halpin-role: #d6d3d1;--halpin-line: rgba(255, 255, 255, .08);--halpin-works-bg: #050505;--halpin-works-text: #fafaf9;--halpin-works-muted: #a8a29e;--halpin-font: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--halpin-mono: "JetBrains Mono", ui-monospace, monospace;--halpin-radius: 16px;--halpin-radius-lg: 24px;--halpin-shadow: 0 24px 80px rgba(0, 0, 0, .45);--hero-pad-top: 3.75rem}.page-halpin,.page-halpin .wrapper{font-family:var(--halpin-font)}.page-halpin body:before{display:none}.page-halpin .navigation{position:fixed;top:0;left:0;right:0;z-index:50;background:transparent;border-bottom:none;backdrop-filter:none;-webkit-backdrop-filter:none;transition:transform .45s cubic-bezier(.22,1,.36,1)}.page-halpin .navigation.navigation--hidden{transform:translateY(calc(-100% - var(--safe-top)))}.page-halpin .navigation-brand,.page-halpin .navigation-dark button,.page-halpin .menu-button span{color:var(--halpin-text)}.page-halpin .navigation-link{font-size:.875rem;font-weight:500;letter-spacing:.02em;opacity:.85;transition:color .28s linear,opacity .28s linear}.page-halpin .navigation-link:not(.active){color:var(--halpin-text);opacity:.72}.page-halpin .navigation-link:hover,.page-halpin .navigation-link.active{color:var(--halpin-accent);opacity:1}.page-halpin .navigation-link:after{display:none}.page-halpin .navigation-indicator{background:var(--halpin-accent);height:2px;bottom:0}.page-halpin .navigation-brand{font-weight:700;letter-spacing:-.02em;color:var(--halpin-text)}.page-halpin .navigation-start__sep,.page-halpin .navigation-back{color:var(--halpin-muted)}.page-halpin .navigation-back:hover{color:var(--halpin-accent)}.page-halpin .navigation-dark{display:none}.page-halpin .navigation-dark button{opacity:.7}.page-halpin .navigation-dark button:hover{opacity:1}.page-halpin .navigation.nav-scrolled{background:color-mix(in srgb,var(--halpin-bg) 88%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}body.page-home #content.content--home{padding:0;background:var(--halpin-bg)}.halpin-hero{--hero-col-gap: clamp(5rem, 10vw, 7.5rem);--hero-gap-since-title: 1.125rem;--hero-gap-title-tagline: 2rem;--hero-gap-tagline-actions: 3rem;--hero-gap-actions-pillars: 5rem;--hero-gap-pillar: 2.5rem;--hero-gap-pillar-icon: .75rem;--hero-gap-pillar-text: .375rem;--hero-gap-buttons: .875rem;position:relative;min-height:100dvh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;background:var(--halpin-bg);color:var(--halpin-text);overflow:hidden}.halpin-hero__glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 55% 45% at 78% 35%,rgba(255,176,32,.09),transparent 65%),radial-gradient(ellipse 40% 35% at 12% 80%,rgba(255,255,255,.04),transparent 60%)}.halpin-hero__grain{position:absolute;inset:0;pointer-events:none;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");mix-blend-mode:overlay}.page-halpin .halpin-hero__inner.container--wide{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);grid-template-areas:"copy visual";align-items:center}.halpin-hero__inner{position:relative;z-index:1;width:100%;max-width:var(--container-wide);margin:0 auto;padding:calc(var(--nav-height) + var(--safe-top) + var(--hero-pad-top)) var(--page-pad) clamp(4rem,10vh,5rem);gap:var(--hero-col-gap);min-height:calc(100dvh - var(--nav-height) - 4.5rem);min-height:calc(100svh - var(--nav-height) - 4.5rem)}.halpin-hero__copy{grid-area:copy;align-self:center;justify-self:start;max-width:36rem;padding-bottom:0;text-align:left}.halpin-hero__actions{display:flex;flex-wrap:wrap;gap:var(--hero-gap-buttons);margin-top:var(--hero-gap-tagline-actions)}.page-halpin .halpin-btn-primary{background:var(--halpin-accent);border-color:var(--halpin-accent);color:#1c1917;font-weight:600;border-radius:999px;padding:.65rem 1.35rem;box-shadow:0 8px 28px var(--halpin-accent-soft)}.page-halpin .halpin-btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}.page-halpin .halpin-btn-outline{color:var(--halpin-text);border:1px solid var(--halpin-line);background:#ffffff08;border-radius:999px;padding:.65rem 1.35rem;font-weight:500}.page-halpin .halpin-btn-outline:hover{border-color:color-mix(in srgb,var(--halpin-accent) 50%,var(--halpin-line));color:var(--halpin-accent)}.halpin-pillars{list-style:none;margin:var(--hero-gap-actions-pillars) 0 0;padding:0;display:flex;flex-direction:column;gap:var(--hero-gap-pillar);max-width:22rem}.halpin-pillar{display:flex;align-items:flex-start;gap:var(--hero-gap-pillar-icon);padding:0;border-radius:12px;border:1px solid transparent;transition:border-color .25s,background .25s}@media (hover: hover){.halpin-pillar:hover{background:#ffffff08;border-color:var(--halpin-line)}}.halpin-pillar__icon{font-size:1rem;line-height:1.4}.halpin-pillar__text{display:flex;flex-direction:column;gap:var(--hero-gap-pillar-text);min-width:0}.halpin-pillar__text strong{font-size:.88rem;font-weight:600;color:var(--halpin-text)}.halpin-pillar__text span{font-size:.78rem;color:var(--halpin-muted)}.halpin-hero__since{margin:0 0 var(--hero-gap-since-title);font-family:var(--halpin-mono);font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--halpin-muted)}.halpin-hero__title{margin:0;font-size:clamp(2.75rem,8.5vw,5.25rem);font-weight:700;line-height:1.08;letter-spacing:-.04em;color:var(--halpin-text)}.halpin-hero__name{display:inline;color:#fff}.halpin-hero__dot{font-weight:400;color:var(--halpin-muted)}.halpin-hero__role{display:inline;font-family:var(--halpin-mono);font-weight:500;font-size:.88em;letter-spacing:.04em;color:var(--halpin-muted)}.halpin-hero__tagline{margin:var(--hero-gap-title-tagline) 0 0;max-width:22em;font-size:clamp(.95rem,2.2vw,1.125rem);line-height:1.7;font-weight:400;color:var(--halpin-muted)}.halpin-hero__visual{grid-area:visual;display:flex;align-items:center;justify-content:flex-end;justify-self:end;width:100%;min-height:0;height:100%}.page-halpin .hero-portrait{position:relative;width:100%;max-width:min(540px,100%);margin:0;padding:0;background:none;border:none;box-shadow:none;display:flex;align-items:center;justify-content:flex-end;line-height:0}.page-halpin .hero-portrait-img{position:relative;z-index:1;display:block;width:auto;max-width:100%;height:auto;max-height:min(78vh,640px);min-height:0;-o-object-fit:contain;object-fit:contain;-o-object-position:center right;object-position:center right;background:transparent;filter:none;opacity:1}.halpin-scroll{position:absolute;z-index:2;left:50%;bottom:calc(1.5rem + var(--safe-bottom));transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--halpin-muted);text-decoration:none;transition:color .25s}.halpin-scroll:hover{color:#fff}.halpin-scroll__label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase}.halpin-scroll__wheel{animation:halpin-scroll-wheel 2s ease-in-out infinite}@keyframes halpin-scroll-wheel{0%,to{transform:translateY(0);opacity:1}55%{transform:translateY(10px);opacity:.35}}.home-footer{position:relative;background:var(--halpin-works-bg);color:var(--halpin-works-text);border-top:1px solid var(--halpin-line)}.home-footer__main{display:flex;flex-direction:column;gap:clamp(2.75rem,6vw,3.75rem);width:100%;max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,7vw,4.5rem) var(--page-pad) clamp(2rem,5vw,2.75rem)}#about{scroll-margin-top:calc(var(--nav-height) + var(--safe-top) + 1rem)}.home-footer__about{max-width:38rem;margin-inline:auto;text-align:center}.home-footer__about .section-eyebrow{font-family:var(--halpin-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--halpin-muted)}.home-footer__about-title{margin:.5rem 0 0;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.03em;color:var(--halpin-works-text)}.home-footer__about-text{margin:1.25rem 0 0;font-size:clamp(.95rem,2.2vw,1.05rem);line-height:1.85;color:var(--halpin-muted)}.home-footer__beian{padding:clamp(.85rem,2vw,1.1rem) var(--page-pad) calc(1.15rem + var(--safe-bottom));text-align:center;font-size:.8rem;line-height:1.6;border-top:1px solid var(--halpin-line)}.home-footer__beian a{color:var(--halpin-muted);text-decoration:none;transition:color .2s linear}.home-footer__beian a:hover{color:var(--halpin-accent)}.halpin-works-wrap{position:relative;background:var(--halpin-works-bg);color:var(--halpin-works-text);overflow:hidden}.halpin-works-wrap__glow{position:absolute;top:0;left:50%;transform:translate(-50%);width:min(900px,100%);height:320px;background:radial-gradient(ellipse 80% 100% at 50% 0%,rgba(255,176,32,.06),transparent 70%);pointer-events:none}.halpin-works-wrap__inner{position:relative;z-index:1;width:100%;margin-inline:auto;align-items:center}.page-halpin .halpin-works-wrap .container--wide{max-width:var(--container-wide);padding-left:var(--page-pad);padding-right:var(--page-pad)}#works{scroll-margin-top:calc(var(--nav-height) + var(--safe-top) + 1rem)}.page-halpin .halpin-works{padding:clamp(2.5rem,6vw,4rem) 0 clamp(2.5rem,5vw,3rem);display:flex;flex-direction:column;align-items:center;width:100%}.page-halpin .product-showcase__app,.page-halpin .product-showcase__app:hover,.page-halpin .product-showcase__app:focus-visible{color:inherit;text-decoration:none!important}.page-halpin .download-tile{background:#ffffff0a;border-color:var(--halpin-line)}.page-halpin .download-tile:not(.download-tile--disabled):hover{border-color:color-mix(in srgb,var(--halpin-accent) 45%,var(--halpin-line))}.site-beian{margin:0;padding:clamp(.75rem,2vw,1rem) var(--page-pad) calc(1rem + var(--safe-bottom));text-align:center;font-size:.8rem;line-height:1.6}.site-beian a{color:var(--halpin-muted, var(--text-muted));text-decoration:none;transition:color .2s linear}.site-beian a:hover{color:var(--halpin-accent, var(--link))}.page-halpin .site-beian-only{background:var(--halpin-works-bg, var(--halpin-bg))}.page-halpin .top-link{background:var(--halpin-card);border-color:var(--halpin-line);color:var(--halpin-text)}.page-halpin .top-link:hover{border-color:var(--halpin-accent);color:var(--halpin-accent)}.page-halpin .navigation.nav-scrolled{border-bottom:1px solid var(--halpin-line)}.page-halpin #works [data-reveal],.page-halpin #works [data-reveal].is-revealed,.page-halpin .home-footer [data-reveal],.page-halpin .home-footer [data-reveal].is-revealed{opacity:1;transform:none}.page-app-detail{--halpin-works-bg: #0a0a0a;--halpin-works-text: #f5f5f4;--halpin-works-muted: #a3a3a3;--app-detail-pad-top: 10px}body.page-app-detail #content.content--app-detail{padding-top:calc(var(--nav-height) + var(--safe-top) + var(--app-detail-pad-top));padding-right:var(--page-pad);padding-bottom:4rem;padding-left:var(--page-pad);background:var(--halpin-works-bg, #0a0a0a);color:var(--halpin-works-text, #f5f5f4);min-height:60vh}.page-app-detail .post-header h1,.page-app-detail .post-content,.page-app-detail .post-content h2,.page-app-detail .feature-list strong{color:var(--halpin-works-text, #f5f5f4)}.page-app-detail .blog-meta,.page-app-detail .summary,.page-app-detail .post-content p,.page-app-detail .post-tech{color:var(--halpin-works-muted, #a3a3a3)}.page-app-detail .post-header.post-header--app{margin-top:0;margin-bottom:2.5rem;padding-bottom:1.75rem;border-bottom-color:var(--halpin-line)}.page-app-detail .feature-list li{background:#141414;border-color:#ffffff14}.page-app-detail .post-app-gallery{margin-top:2.5rem}.page-app-detail .post-app-gallery h2{margin-bottom:1rem}.page-app-detail .product-showcase--embedded{padding:1.25rem 0 0;border-top:1px solid var(--halpin-line)}@media (max-width: 768px){.page-halpin .halpin-hero__inner.container--wide{grid-template-columns:minmax(0,1fr) minmax(0,.85fr);grid-template-areas:"copy visual";gap:.75rem;min-height:auto;padding-top:calc(var(--nav-height) + var(--safe-top) + var(--hero-pad-top));padding-bottom:4.5rem}.halpin-hero__visual{justify-content:flex-end;justify-self:end}.halpin-hero__copy{text-align:left;justify-self:start;max-width:none}.halpin-hero__title{font-size:clamp(1.35rem,5.5vw,2.25rem)}.page-halpin{--hero-pad-top: 2.5rem}.halpin-hero{--hero-col-gap: clamp(1.25rem, 4vw, 2rem);--hero-gap-since-title: .875rem;--hero-gap-title-tagline: 1.25rem;--hero-gap-tagline-actions: 2rem;--hero-gap-actions-pillars: 3.5rem;--hero-gap-pillar: 1.75rem}.halpin-hero__tagline{font-size:.8rem;line-height:1.55}.halpin-hero__since{font-size:.62rem}.page-halpin .hero-portrait{max-width:100%;justify-content:flex-end}.page-halpin .hero-portrait-img{max-height:min(42vh,320px);-o-object-position:center right;object-position:center right}.halpin-hero__actions{justify-content:flex-start}.halpin-pillars{max-width:none}}@media (min-width: 769px) and (max-width: 1024px){.halpin-hero__title{font-size:clamp(2.5rem,6vw,4rem)}.page-halpin .hero-portrait-img{max-height:min(70vh,560px)}}@media (max-width: 768px){.page-halpin .navigation-links .navigation-list{background:var(--halpin-bg);border-color:var(--halpin-line)}.page-halpin .navigation-links .navigation-list .navigation-link{color:var(--halpin-text)}}.page-404-wrap .content--404{min-height:calc(100dvh - var(--nav-height) - 12rem);display:flex;align-items:center;padding:calc(var(--nav-height) + 2rem) var(--page-pad) 4rem;background:var(--halpin-bg)}.page-404-wrap .page-404{text-align:center;margin:0 auto;max-width:28rem}.page-404-wrap .page-404-code{font-family:var(--halpin-mono);font-size:clamp(4rem,18vw,7rem);font-weight:700;line-height:1;margin:0;background:linear-gradient(180deg,var(--halpin-muted),var(--halpin-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.page-404-wrap .page-404 h1{margin:.75rem 0 0;color:var(--halpin-text)}.page-404-wrap .page-404-desc{color:var(--halpin-muted);margin:.85rem 0 0}.page-404-wrap .page-404-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem;margin-top:1.75rem}.cost-mock-frame{margin:0;text-align:center}.cost-mock-phone{position:relative;width:100%;aspect-ratio:9 / 19.5;border-radius:28px;background:#1a1a1a;padding:10px 8px 12px;box-shadow:0 16px 40px #0003}.cost-mock-notch{position:absolute;top:12px;left:50%;transform:translate(-50%);width:28%;height:5px;border-radius:99px;background:#2a2a2a;z-index:2}.cost-mock-screen{width:100%;height:100%;border-radius:22px;overflow:hidden;background:#f6f6f6}.cost-mock-frame figcaption{margin-top:.65rem;font-size:.8rem;color:var(--text-muted, #a3a3a3)}.cm{height:100%;padding:28px 12px 12px;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,sans-serif;font-size:11px;color:#1c1917;text-align:left;overflow:hidden}.cm-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cm-bar__title{font-size:15px;font-weight:700}.cm-bar__meta,.cm-bar__back{font-size:12px;color:#78716c}.cm-card{background:#fff;border-radius:14px;padding:12px;margin-bottom:10px;box-shadow:0 1px 3px #0000000a}.cm-card__label{margin:0;font-size:10px;color:#78716c}.cm-card__amount{margin:4px 0 8px;font-size:22px;font-weight:700}.cm-progress{height:6px;border-radius:99px;background:#f1f1f1;overflow:hidden}.cm-progress__fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#e55c5c,#f97316)}.cm-card__hint{margin:8px 0 0;font-size:10px;color:#78716c}.cm--warn{color:#e55c5c}.cm-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.cm-list li{display:flex;align-items:center;gap:8px;background:#fff;border-radius:12px;padding:10px}.cm-list li em{margin-left:auto;font-style:normal;font-size:10px;color:#57534e}.cm-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cm-dot--y{background:#fbbf24}.cm-dot--b{background:#60a5fa}.cm-dot--p{background:#f472b6}.cm-dot--g{background:#4ade80}.cm--auto .cm-auto-hero{background:#fff;border-radius:14px;padding:12px;text-align:center;margin-bottom:10px}.cm-auto-icon{font-size:24px}.cm--auto h3{margin:6px 0 4px;font-size:13px}.cm--auto p{margin:0;font-size:10px;color:#78716c}.cm-toggle-row{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:12px;padding:10px 12px;margin-bottom:8px;font-weight:600}.cm-switch{width:36px;height:20px;border-radius:99px;background:#e7e5e4;position:relative}.cm-switch--on{background:#ffb020}.cm-switch--on:after{content:"";position:absolute;right:2px;top:2px;width:16px;height:16px;border-radius:50%;background:#fff}.cm-pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.cm-pill{padding:4px 10px;border-radius:99px;background:#fff;color:#78716c;font-size:10px}.cm-pill--on{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.cm-queue{background:#fff;border-radius:14px;padding:10px}.cm-queue__title{margin:0 0 8px;font-size:10px;color:#78716c}.cm-queue__item{display:flex;justify-content:space-between;padding:6px 0;border-top:1px solid #f5f5f4}.cm-queue__item strong{color:#e55c5c}.cm-donut-wrap{position:relative;display:grid;place-items:center;margin:8px 0 12px}.cm-donut{width:120px;height:120px;border-radius:50%;background:conic-gradient(#fbbf24 0 58%,#60a5fa 58% 80%,#f472b6 80% 92%,#4ade80 92% 100%);mask:radial-gradient(circle at center,transparent 52%,#000 53%);-webkit-mask:radial-gradient(circle at center,transparent 52%,#000 53%)}.cm-donut__center{position:absolute;margin:0;text-align:center;font-size:10px;color:#78716c}.cm-donut__center strong{display:block;font-size:16px;color:#1c1917}.cm-chart-legend{list-style:none;margin:0 0 10px;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:6px;font-size:10px}.cm-chart-legend li{display:flex;align-items:center;gap:6px}.cm-mini-bars{display:flex;align-items:flex-end;gap:6px;height:56px;padding:8px 10px;background:#fff;border-radius:12px}.cm-mini-bar{flex:1;height:var(--h, 40%);border-radius:4px 4px 0 0;background:linear-gradient(180deg,#ffb020,#f97316);opacity:.85}.cm-sync-status{display:flex;gap:10px;align-items:center;background:#fff;border-radius:14px;padding:12px;margin-bottom:10px}.cm-sync-dot{width:10px;height:10px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 4px #4ade8040}.cm-sync-status strong{display:block;font-size:12px}.cm-sync-status p{margin:2px 0 0;font-size:10px;color:#78716c}.cm-list--sync li{justify-content:space-between}.cm-badge{font-size:9px;padding:2px 8px;border-radius:99px;background:#f5f5f4;color:#57534e}.cm-btn{width:100%;margin-top:10px;padding:10px;border:none;border-radius:12px;background:#ffb020;color:#1c1917;font-weight:700;font-size:12px}.cm-foot{margin:8px 0 0;text-align:center;font-size:9px;color:#a8a29e}.slider-slide--mock .cost-mock-phone{max-height:420px}.product-showcase{width:100%;max-width:920px;margin:0 auto;padding:0;text-align:center}.product-showcase__header{margin:0 auto 1.25rem;max-width:30rem}.product-showcase__eyebrow{margin:0;font-family:var(--halpin-mono);font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--halpin-muted)}.product-showcase__title{margin:.5rem 0 0;font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;letter-spacing:-.03em;color:var(--halpin-works-text);line-height:1.2}.product-showcase__lead{margin:.5rem 0 0;font-size:.92rem;line-height:1.6;color:var(--halpin-works-muted)}.product-showcase__app{display:flex;align-items:center;gap:.85rem;max-width:26rem;width:100%;margin:0 auto 1.25rem;padding:.75rem 1rem;text-align:left;text-decoration:none!important;color:inherit;background:var(--halpin-card);border:1px solid var(--halpin-line);border-radius:14px;transition:border-color .25s,transform .25s,box-shadow .25s}.product-showcase__app:hover{border-color:color-mix(in srgb,var(--halpin-accent) 35%,var(--halpin-line));box-shadow:0 12px 32px #00000059;transform:translateY(-2px);text-decoration:none!important;color:inherit}.product-showcase__app:hover .product-showcase__app-name,.product-showcase__app:hover .product-showcase__app-meta{text-decoration:none}.product-showcase__icon{width:52px;height:52px;border-radius:13px;flex-shrink:0}.product-showcase__app-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.product-showcase__app-name{font-size:.95rem;font-weight:600;color:var(--halpin-works-text)}.product-showcase__app-meta{font-size:.76rem;color:var(--halpin-works-muted);display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.product-showcase__tag{font-family:var(--halpin-mono);font-size:.62rem;letter-spacing:.05em;padding:.1rem .4rem;border-radius:999px;background:var(--halpin-accent-soft);color:var(--halpin-accent)}.product-showcase__app-link{flex-shrink:0;font-size:1.15rem;color:var(--halpin-muted);transition:color .2s,transform .2s}.product-showcase__app:hover .product-showcase__app-link{color:var(--halpin-accent);transform:translate(3px)}.product-showcase__stage{width:100%;padding:1.25rem clamp(.75rem,3vw,1.5rem) 1rem;background:color-mix(in srgb,var(--halpin-card) 65%,transparent);border:1px solid var(--halpin-line);border-radius:var(--halpin-radius-lg, 20px)}.product-showcase__gallery{position:relative;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}.product-showcase__viewport{flex:1;min-width:0;overflow-x:auto;overflow-y:visible;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.25rem 0 .5rem}.product-showcase__viewport::-webkit-scrollbar{display:none}.product-showcase__track{display:flex;align-items:flex-end;gap:clamp(.85rem,2.5vw,1.25rem);width:-moz-max-content;width:max-content;margin:0 auto;padding:0 .25rem}.product-showcase__slide{flex:0 0 auto;scroll-snap-align:center;width:min(176px,38vw)}.product-showcase__slide--mock{width:min(168px,36vw)}.product-showcase__nav{flex-shrink:0;width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--halpin-line);border-radius:50%;background:var(--halpin-bg, #000);color:var(--halpin-works-muted);cursor:pointer;transition:color .2s,border-color .2s}.product-showcase__nav:hover{color:var(--halpin-accent);border-color:color-mix(in srgb,var(--halpin-accent) 40%,var(--halpin-line))}.product-showcase__nav:disabled{opacity:.3;pointer-events:none}.product-phone{margin:0}.product-phone__bezel{position:relative;background:#111;border-radius:24px;padding:8px 6px 10px;box-shadow:0 16px 40px #0006}.product-phone__notch{position:absolute;top:10px;left:50%;transform:translate(-50%);width:26%;height:4px;border-radius:99px;background:#222;z-index:2}.product-phone__bezel img{display:block;width:100%;height:auto;border-radius:16px}.product-phone figcaption,.cost-mock-frame figcaption{margin-top:.45rem;font-size:.72rem;font-weight:500;color:var(--halpin-works-muted)}.product-showcase__dots{display:flex;justify-content:center;flex-wrap:wrap;gap:.35rem;margin:.85rem 0 0}.product-showcase__dot{width:6px;height:6px;padding:0;border:none;border-radius:50%;background:var(--halpin-line);cursor:pointer;transition:transform .2s,background .2s}.product-showcase__dot.is-active,.product-showcase__dot:hover{background:var(--halpin-accent);transform:scale(1.2)}.product-showcase__downloads{margin-top:1.15rem;display:flex;justify-content:center;width:100%}.product-showcase__downloads .download-row{width:100%;max-width:26rem;margin-inline:auto;justify-content:center;gap:.5rem;border-top:none;padding-top:0}.page-halpin .product-showcase__downloads .download-tile{min-width:5.5rem;padding:.55rem .65rem}.product-showcase--embedded{max-width:100%}.product-showcase--embedded .product-showcase__header{display:none}@media (max-width: 640px){.product-showcase__nav{display:none}.product-showcase__slide{width:min(150px,52vw)}.product-showcase__slide--mock{width:min(142px,48vw)}.product-showcase__app{max-width:100%}}
