@font-face{font-family:Geist;src:url(/assets/geist-latin-wght-normal-BgDaEnEv.woff2)format("woff2");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Geist Mono;src:url(/assets/geist-mono-latin-wght-normal-B_7UjwxQ.woff2)format("woff2");font-weight:100 900;font-style:normal;font-display:swap}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0c;--surface:#141417;--surface-2:#1b1b20;--border:#ffffff17;--border-strong:#ffffff29;--text-primary:#ececf1;--text-secondary:#9a9aa6;--text-muted:#86868f;--accent:#7c9cff;--accent-hover:#9ab2ff;--on-accent:#0a0a0c;--shadow-hover:0 12px 32px #0000002e;--nav-bg:#0a0a0cd1;--font-sans:"Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--fs-display:clamp(2.75rem, 7vw, 5.25rem);--fs-h2:clamp(1.75rem, 3.5vw, 2.5rem);--fs-h3:1.25rem;--fs-lg:1.125rem;--fs-base:1rem;--fs-sm:.875rem;--fs-xs:.75rem;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-6:24px;--sp-8:32px;--sp-12:48px;--sp-16:64px;--sp-24:96px;--sp-32:128px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-full:999px;--container:1080px;--gutter:clamp(24px, 5vw, 48px);--ease-out:cubic-bezier(.22, 1, .36, 1);--duration-fast:.2s;--duration-base:.28s;--duration-reveal:.6s;--duration-enter:.7s;--shadow-base:none}@media (prefers-color-scheme:light){:root:not([data-theme]){--bg:#fafafa;--surface:#fff;--surface-2:#f4f4f5;--border:#00000017;--border-strong:#00000029;--text-primary:#18181b;--text-secondary:#55555f;--text-muted:#6c6c75;--accent:#3a55e6;--accent-hover:#2c44c9;--on-accent:#fff;--shadow-hover:0 12px 28px #00000014;--nav-bg:#fafafad1}}[data-theme=light]{--bg:#fafafa;--surface:#fff;--surface-2:#f4f4f5;--border:#00000017;--border-strong:#00000029;--text-primary:#18181b;--text-secondary:#55555f;--text-muted:#6c6c75;--accent:#3a55e6;--accent-hover:#2c44c9;--on-accent:#fff;--shadow-hover:0 12px 28px #00000014;--nav-bg:#fafafad1}[data-theme=dark]{--bg:#0a0a0c;--surface:#141417;--surface-2:#1b1b20;--border:#ffffff17;--border-strong:#ffffff29;--text-primary:#ececf1;--text-secondary:#9a9aa6;--text-muted:#86868f;--accent:#7c9cff;--accent-hover:#9ab2ff;--on-accent:#0a0a0c;--shadow-hover:0 12px 32px #0000002e;--nav-bg:#0a0a0cd1}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:88px}body{font-family:var(--font-sans);font-size:var(--fs-base);background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;transition:background var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);line-height:1.65;overflow-x:hidden}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:var(--on-accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}img{max-width:100%;display:block}.hero-canvas{z-index:0;pointer-events:none;position:absolute;inset:0}.skip-link{left:var(--sp-4);z-index:200;padding:var(--sp-2) var(--sp-4);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);transition:top var(--duration-fast) var(--ease-out);position:absolute;top:-120px}.skip-link:focus{top:var(--sp-4)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.container{width:100%;max-width:var(--container);padding-inline:var(--gutter);margin-inline:auto}.section{padding-block:var(--sp-24)}@media (width<=720px){.section{padding-block:var(--sp-16)}}.divider{background:var(--border);border:0;height:1px}.section-head{margin-bottom:var(--sp-12)}.eyebrow{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--sp-3)}.section-title{font-size:var(--fs-h2);letter-spacing:-.02em;color:var(--text-primary);font-weight:600;line-height:1.05}.section-lead{margin-top:var(--sp-4);max-width:60ch;font-size:var(--fs-lg);color:var(--text-secondary)}.reveal{opacity:0;transition:opacity var(--duration-reveal) var(--ease-out), translate var(--duration-reveal) var(--ease-out);translate:0 20px}.reveal.is-visible{opacity:1;translate:none}[data-reveal]{opacity:0;transition:opacity var(--duration-reveal) var(--ease-out), translate var(--duration-reveal) var(--ease-out);translate:0 20px}[data-reveal].is-visible{opacity:1;translate:none}@media (prefers-reduced-motion:no-preference){.rise{opacity:0;animation:rise var(--duration-enter) var(--ease-out) forwards}.rise.d1{animation-delay:0s}.rise.d2{animation-delay:.1s}.rise.d3{animation-delay:.2s}.rise.d4{animation-delay:.3s}.rise.d5{animation-delay:.4s}}@keyframes rise{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}.site-nav{z-index:100;height:64px;transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), backdrop-filter var(--duration-fast) var(--ease-out);background:0 0;border-bottom:1px solid #0000;align-items:center;display:flex;position:fixed;inset:0 0 auto}.site-nav.is-scrolled{background:var(--nav-bg);border-bottom-color:var(--border);-webkit-backdrop-filter:blur(16px)saturate(180%)}.nav-inner{width:100%;max-width:var(--container);padding-inline:var(--gutter);justify-content:space-between;align-items:center;gap:var(--sp-4);margin-inline:auto;display:flex}.nav-brand{font-size:var(--fs-base);letter-spacing:-.01em;color:var(--text-primary);font-weight:600}.nav-links{align-items:center;gap:var(--sp-1);list-style:none;display:flex}.nav-link{padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);font-size:var(--fs-sm);color:var(--text-secondary);transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);font-weight:500;display:inline-block}.nav-link:hover{color:var(--text-primary)}.nav-link.is-active{color:var(--accent)}.nav-tools{align-items:center;gap:var(--sp-1);display:flex}.icon-btn{border-radius:var(--radius-md);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{color:var(--text-primary);border-color:var(--border)}.icon-btn svg{width:18px;height:18px}.nav-toggle,.nav-toggle .icon-close,.nav-toggle.is-open .icon-menu{display:none}.nav-toggle.is-open .icon-close{display:block}.nav-panel{z-index:99;background:var(--nav-bg);-webkit-backdrop-filter:blur(16px)saturate(180%);border-bottom:1px solid var(--border);padding:var(--sp-2) var(--gutter) var(--sp-4);gap:var(--sp-1);flex-direction:column;display:none;position:fixed;inset:64px 0 auto}.nav-panel.is-open{display:flex}.nav-panel .nav-link{padding:var(--sp-3) var(--sp-3);font-size:var(--fs-base)}.btn{align-items:center;gap:var(--sp-2);font-family:var(--font-sans);font-size:var(--fs-sm);padding:var(--sp-3) var(--sp-6);border-radius:var(--radius-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);border:1px solid #0000;font-weight:500;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:var(--on-accent)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{color:var(--text-primary);border-color:var(--border);background:0 0}.btn-secondary:hover{border-color:var(--border-strong);background:var(--surface)}.btn .arrow{transition:transform var(--duration-fast) var(--ease-out)}.hero{isolation:isolate;min-height:100dvh;padding-top:64px;padding-bottom:var(--sp-16);flex-direction:column;justify-content:center;display:flex;position:relative}.hero>:not(.hero-canvas){z-index:1;position:relative}.hero-avail{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.04em;color:var(--text-muted);margin-bottom:var(--sp-6);align-items:center;display:inline-flex}.hero-name{font-size:var(--fs-display);letter-spacing:-.03em;color:var(--text-primary);max-width:16ch;font-weight:700;line-height:.98}.hero-role{margin-top:var(--sp-6);font-size:var(--fs-lg);color:var(--text-primary);font-weight:500}.hero-role .accent{color:var(--accent)}.hero-desc{margin-top:var(--sp-3);max-width:56ch;font-size:var(--fs-lg);color:var(--text-secondary)}.hero-actions{margin-top:var(--sp-8);gap:var(--sp-3);flex-wrap:wrap;display:flex}.featured{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-8);transition:opacity var(--duration-reveal) var(--ease-out), translate var(--duration-reveal) var(--ease-out), transform var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);display:block}@media (hover:hover) and (pointer:fine){.featured:hover{border-color:var(--border-strong);box-shadow:var(--shadow-hover);transform:translateY(-3px)}}.featured-top{justify-content:space-between;align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-4);display:flex}.featured-label{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.04em;color:var(--accent)}.featured-title{letter-spacing:-.02em;color:var(--text-primary);font-size:clamp(1.5rem,3vw,2rem);font-weight:600}.featured-desc{margin-top:var(--sp-3);max-width:70ch;color:var(--text-secondary)}.featured-foot{margin-top:var(--sp-6);justify-content:space-between;align-items:center;gap:var(--sp-4);flex-wrap:wrap;display:flex}.work-list{margin-top:var(--sp-8);border-top:1px solid var(--border)}.work-row{align-items:center;gap:var(--sp-6);padding:var(--sp-6) var(--sp-3);border-bottom:1px solid var(--border);transition:opacity var(--duration-reveal) var(--ease-out), translate var(--duration-reveal) var(--ease-out), background var(--duration-fast) var(--ease-out), padding-left var(--duration-fast) var(--ease-out);grid-template-columns:auto 1fr auto;display:grid}.work-row:hover{background:var(--surface)}@media (hover:hover) and (pointer:fine){.work-row:hover{padding-left:var(--sp-6)}.work-row:hover .arrow{transform:translate(3px,-3px)}}.work-index{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text-muted);font-variant-numeric:tabular-nums}.work-main{min-width:0}.work-title{font-size:var(--fs-h3);letter-spacing:-.01em;color:var(--text-primary);font-weight:600}.work-desc{margin-top:var(--sp-1);font-size:var(--fs-sm);color:var(--text-secondary);max-width:62ch}.work-aside{align-items:center;gap:var(--sp-4);color:var(--text-muted);display:flex}.tags{gap:var(--sp-2);flex-wrap:wrap;display:flex}.tag{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-secondary);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-2);white-space:nowrap}.work-row .tags{display:none}@media (width>=880px){.work-row .tags{justify-content:flex-end;max-width:320px;display:flex}}.course-groups{gap:var(--sp-12);grid-template-columns:1fr 1fr;display:grid}@media (width<=720px){.course-groups{gap:var(--sp-8);grid-template-columns:1fr}}.course-group-title{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border);margin-bottom:var(--sp-2)}.course-row{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-2);border-radius:var(--radius-md);border-bottom:1px solid var(--border);color:var(--text-primary);transition:background var(--duration-fast) var(--ease-out);grid-template-columns:5.5rem 1fr auto;display:grid}.course-row:last-child{border-bottom:0}.course-row:hover{background:var(--surface-2)}@media (hover:hover) and (pointer:fine){.course-row:hover .arrow{transform:translate(3px)}}.course-code{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--accent)}.course-name{font-size:var(--fs-sm);font-weight:500}.course-row .grad{font-family:var(--font-mono);color:var(--text-muted);margin-left:var(--sp-2);font-size:.625rem}.course-row .arrow{color:var(--text-muted);transition:transform var(--duration-fast) var(--ease-out)}.about-grid{gap:var(--sp-12);grid-template-columns:1fr auto;align-items:start;display:grid}@media (width<=720px){.about-grid{gap:var(--sp-8);grid-template-columns:1fr}}.about-prose p{font-size:var(--fs-lg);color:var(--text-secondary);max-width:62ch}.about-prose p+p{margin-top:var(--sp-4)}.about-prose strong{color:var(--text-primary);font-weight:600}.about-photo{border-radius:var(--radius-full);object-fit:cover;border:1px solid var(--border);width:132px;height:132px}@media (width<=720px){.about-photo{width:96px;height:96px}}.facts{margin-top:var(--sp-8);gap:var(--sp-3) var(--sp-8);flex-wrap:wrap;display:flex}.fact{flex-direction:column;gap:2px;display:flex}.fact-value{font-size:var(--fs-lg);color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.fact-label{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-muted)}.skills{margin-top:var(--sp-12);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);padding:var(--sp-8);gap:var(--sp-6);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=540px){.skills{grid-template-columns:1fr}}.skill-group-title{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--sp-3)}.contact-lead{font-size:var(--fs-lg);color:var(--text-secondary);max-width:56ch;margin-bottom:var(--sp-8)}.contact-email{letter-spacing:-.02em;color:var(--text-primary);align-items:center;gap:var(--sp-3);transition:color var(--duration-fast) var(--ease-out);font-size:clamp(1.5rem,4vw,2.25rem);font-weight:600;display:inline-flex}.contact-email:hover{color:var(--accent)}.contact-email .arrow{transition:transform var(--duration-fast) var(--ease-out)}@media (hover:hover) and (pointer:fine){.contact-email:hover .arrow{transform:translate(3px,-3px)}}.contact-secondary{margin-top:var(--sp-8);gap:var(--sp-6);flex-wrap:wrap;display:flex}.contact-link{align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--text-secondary);transition:color var(--duration-fast) var(--ease-out);font-weight:500;display:inline-flex}.contact-link:hover{color:var(--text-primary)}.contact-link svg{width:18px;height:18px}.site-footer{border-top:1px solid var(--border);padding-block:var(--sp-8)}.footer-inner{justify-content:space-between;align-items:center;gap:var(--sp-4);flex-wrap:wrap;display:flex}.footer-name{color:var(--text-primary);font-weight:600}.footer-meta{font-size:var(--fs-sm);color:var(--text-muted);font-variant-numeric:tabular-nums}.footer-links{gap:var(--sp-6);display:flex}@view-transition{navigation:auto}::view-transition-old(root){animation-duration:var(--duration-fast);animation-timing-function:var(--ease-out)}::view-transition-new(root){animation-duration:var(--duration-fast);animation-timing-function:var(--ease-out)}@media (width<=720px){.nav-links{display:none}.nav-toggle{display:inline-flex}.hero-name{max-width:none}.featured{padding:var(--sp-6)}.work-row{gap:var(--sp-4);padding-inline:var(--sp-1);grid-template-columns:auto 1fr auto}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.reveal,[data-reveal]{opacity:1;transition:none;transform:translate(0,0)}.rise{opacity:1;animation:none}::view-transition-old(root){animation:none}::view-transition-new(root){animation:none}}@media (hover:none){.card,[data-card],.ds-card,.featured{box-shadow:var(--shadow-base);transform:none!important}}nav.ds-nav{z-index:100;justify-content:space-between;align-items:center;gap:var(--sp-4);height:64px;padding:0 var(--gutter);background:var(--nav-bg);-webkit-backdrop-filter:blur(16px)saturate(180%);border-bottom:1px solid var(--border);display:flex;position:fixed;top:0;left:0;right:0}.ds-nav-logo{font-weight:600;font-size:var(--fs-base);letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;flex-shrink:0}.ds-nav-back{align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--text-secondary);border:1px solid var(--border);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);transition:color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);background:0 0;font-weight:500;display:inline-flex}.ds-nav-back:hover{color:var(--text-primary);border-color:var(--border-strong);transform:translate(-2px)}.ds-nav-right{align-items:center;gap:var(--sp-2);flex-shrink:0;display:flex}.ds-theme-toggle{border-radius:var(--radius-md);cursor:pointer;width:38px;height:38px;color:var(--text-secondary);transition:color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.ds-theme-toggle:hover{color:var(--text-primary);border-color:var(--border)}.ds-theme-toggle svg{width:18px;height:18px}.ds-main{z-index:1;padding-top:64px;position:relative}.ds-page-hero{max-width:var(--container);padding:var(--sp-16) var(--gutter) var(--sp-12);margin:0 auto}.ds-badge{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.04em;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);background:var(--surface);color:var(--accent);border:1px solid var(--border);margin-bottom:var(--sp-6);align-items:center;display:inline-flex}.ds-page-title{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:var(--sp-4);font-size:clamp(2.2rem,6vw,3.5rem);font-weight:700;line-height:1}.ds-page-title em{color:var(--accent);font-style:normal}.ds-page-desc{font-size:var(--fs-lg);color:var(--text-secondary);max-width:62ch;line-height:1.6}.ds-section{max-width:var(--container);padding:var(--sp-12) var(--gutter);margin:0 auto}.ds-section-label{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--sp-3)}.ds-section-title{font-size:var(--fs-h2);letter-spacing:-.02em;color:var(--text-primary);margin-bottom:var(--sp-4);font-weight:600;line-height:1.05}.ds-section-title em{color:var(--accent);font-style:normal}.ds-body{font-size:var(--fs-base);color:var(--text-secondary);margin-bottom:var(--sp-4);max-width:70ch;line-height:1.7}.ds-body strong{color:var(--text-primary);font-weight:600}.ds-card-grid{gap:var(--sp-4);margin-top:var(--sp-8);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.ds-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-6);transition:opacity var(--duration-reveal) var(--ease-out), translate var(--duration-reveal) var(--ease-out), transform var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);opacity:0;translate:0 20px}.ds-card.visible,.ds-card.is-visible{opacity:1;translate:none}@media (hover:hover) and (pointer:fine){.ds-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-hover);transform:translateY(-3px)}}.ds-card.ds-card-featured{background:var(--surface);border-color:var(--border-strong);grid-column:1/-1}.ds-card-icon{border-radius:var(--radius-md);background:var(--surface-2);width:40px;height:40px;color:var(--accent);margin-bottom:var(--sp-4);justify-content:center;align-items:center;display:flex}.ds-card-icon svg{width:20px;height:20px}.ds-card-title{font-size:var(--fs-h3);color:var(--text-primary);margin-bottom:var(--sp-2);letter-spacing:-.01em;font-weight:600}.ds-card-title-lg{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:var(--sp-3);font-size:clamp(1.4rem,3vw,1.8rem);font-weight:600}.ds-card-desc{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--sp-4);line-height:1.6}.ds-highlight{background:var(--surface);border:1px solid var(--border);border-left:2px solid var(--accent);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:var(--sp-4) var(--sp-6);margin:var(--sp-6) 0;font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.65}.ds-highlight strong{color:var(--text-primary);font-weight:600}.ds-pill-row{gap:var(--sp-2);margin-top:var(--sp-4);flex-wrap:wrap;display:flex}.ds-pill{font-family:var(--font-mono);font-size:var(--fs-xs);padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary)}.ds-link{align-items:center;gap:var(--sp-1);font-size:var(--fs-sm);color:var(--accent);transition:gap var(--duration-fast) var(--ease-out);font-weight:500;display:inline-flex}.ds-link:hover{gap:var(--sp-2)}.ds-btn-primary{align-items:center;gap:var(--sp-2);background:var(--accent);color:var(--on-accent);font-size:var(--fs-sm);padding:var(--sp-3) var(--sp-6);border-radius:var(--radius-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);border:1px solid #0000;font-weight:500;display:inline-flex}.ds-btn-primary:hover{background:var(--accent-hover)}.ds-btn-primary:active{transform:scale(.97)}.ds-btn-ghost{align-items:center;gap:var(--sp-2);color:var(--text-primary);font-size:var(--fs-sm);padding:var(--sp-3) var(--sp-6);border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);background:0 0;font-weight:500;display:inline-flex}.ds-btn-ghost:hover{border-color:var(--border-strong);background:var(--surface)}.ds-btn-ghost:active{transform:scale(.97)}.ds-btn-row{gap:var(--sp-3);margin-top:var(--sp-6);flex-wrap:wrap;display:flex}.ds-divider{background:var(--border);height:1px;margin:0}footer.ds-footer{z-index:1;border-top:1px solid var(--border);padding:var(--sp-8) var(--gutter);justify-content:space-between;align-items:center;gap:var(--sp-4);max-width:var(--container);flex-wrap:wrap;margin:0 auto;display:flex;position:relative}.ds-footer-logo{color:var(--text-primary);letter-spacing:-.01em;font-weight:600}.ds-footer-text{font-size:var(--fs-sm);color:var(--text-muted)}.ds-code-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-6);font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text-primary);margin:var(--sp-3) 0 var(--sp-6);tab-size:4;line-height:1.7;overflow-x:auto}code{font-family:var(--font-mono)}.ds-body code,.ds-card-desc code,.ds-page-desc code{background:var(--surface-2);border:1px solid var(--border);padding:1px var(--sp-1);border-radius:var(--radius-sm);font-size:var(--fs-xs);color:var(--accent)}.ds-step-title{font-size:var(--fs-h3);color:var(--text-primary);margin-bottom:var(--sp-2);font-weight:600}.ds-body ul,.ds-body ol{margin:var(--sp-2) 0 var(--sp-4) var(--sp-6);color:var(--text-secondary);line-height:1.8}.ds-body li{margin-bottom:var(--sp-1)}.ds-fade-up{opacity:0;animation:rise var(--duration-enter) var(--ease-out) forwards;transform:translateY(24px)}.ds-fade-up-1{animation-delay:.1s}.ds-fade-up-2{animation-delay:.2s}.ds-fade-up-3{animation-delay:.3s}@media (prefers-reduced-motion:reduce){.ds-fade-up{opacity:1;animation:none;transform:none}.ds-card{opacity:1;transform:translate(0,0)}}
