:root{--color-bg: #eeeeee;--color-bg-warm: #e8e7e5;--color-header: #cac9c7;--color-btn: #ececec;--color-border: rgba(26, 26, 26, .1);--color-border-strong: rgba(26, 26, 26, .18);--color-border-glow: rgba(37, 99, 235, .35);--color-text: #1a1a1a;--color-text-muted: #5a5a5a;--color-text-light: #888888;--color-accent: #2563eb;--color-accent-soft: rgba(37, 99, 235, .14);--color-accent-glow: rgba(37, 99, 235, .25);--color-surface: #ffffff;--color-surface-glass: rgba(255, 255, 255, .65);--color-surface-muted: #f4f4f4;--color-surface-dark: #1a1a1a;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 16px 40px -12px rgba(0, 0, 0, .12);--shadow-lg: 0 32px 64px -16px rgba(0, 0, 0, .14);--shadow-glow: 0 0 80px -20px var(--color-accent-glow);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-2xl: 36px;--radius-pill: 9999px;--container-max: 76rem;--container-pad: clamp(1.25rem, 4vw, 2rem);--section-py: clamp(5rem, 12vw, 9rem);--nav-height: 3.5rem;--nav-offset: 1.25rem;--font-sans: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--text-display: clamp(2.75rem, 7vw, 4.75rem);--text-h2: clamp(2rem, 4.5vw, 3.25rem);--text-h3: clamp(1.35rem, 2.5vw, 1.75rem);--text-body: 1.0625rem;--text-small: .8125rem;--text-label: .6875rem;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .2s;--duration-base: .4s;--duration-slow: .7s}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-height) + var(--nav-offset) * 2)}body{font-family:var(--font-sans);font-size:var(--text-body);line-height:1.6;margin:0;background:var(--color-bg);color:var(--color-text);overflow-x:hidden;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}img{max-width:100%;display:block}a{color:inherit}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad)}.section-label{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:var(--text-label);font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-light);margin-bottom:1rem}.section-label:before{content:"";width:1.5rem;height:1px;background:var(--color-border-strong)}.section-heading{font-size:var(--text-h2);font-weight:800;letter-spacing:-.04em;line-height:1.08;margin:0;color:var(--color-text)}.section-lead{font-size:clamp(1rem,2vw,1.2rem);color:var(--color-text-muted);line-height:1.65;margin:.85rem 0 0;max-width:36rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.35rem;font-family:var(--font-sans);font-size:.9rem;font-weight:600;text-decoration:none;border-radius:var(--radius-pill);border:1px solid transparent;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),box-shadow var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.btn:active{transform:scale(.98)}.btn--primary{background:var(--color-surface-dark);color:var(--color-surface);box-shadow:var(--shadow-sm)}.btn--primary:hover{background:var(--color-accent);box-shadow:var(--shadow-md),0 0 40px -10px var(--color-accent-glow);color:var(--color-surface)}.btn--ghost{background:var(--color-surface-glass);border-color:var(--color-border);color:var(--color-text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn--ghost:hover{border-color:var(--color-border-strong);background:var(--color-surface);box-shadow:var(--shadow-sm)}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:var(--text-small);font-weight:600;border-radius:var(--radius-pill);border:1px solid var(--color-border);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badge--live{border-color:#22c55e59;background:#22c55e14}.badge--live:before{content:"";width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e;animation:pulse-dot 2s ease infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.tag{font-family:var(--font-mono);font-size:.7rem;font-weight:500;padding:.3rem .65rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);letter-spacing:.02em;transition:border-color var(--duration-fast),color var(--duration-fast),background var(--duration-fast)}.tag:hover{border-color:var(--color-border-strong);color:var(--color-text)}.reveal{opacity:0;transform:translateY(26px);transition:opacity .52s var(--ease-out),transform .52s var(--ease-out)}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal--fade{transform:none}.reveal--left{transform:translate(-22px)}.reveal--left.is-visible{transform:translate(0)}.reveal--right{transform:translate(22px)}.reveal--right.is-visible{transform:translate(0)}.reveal--scale{transform:scale(.972)}.reveal--scale.is-visible{transform:scale(1)}@media (max-width: 768px){.reveal{transform:translateY(20px);transition:opacity .42s var(--ease-out),transform .42s var(--ease-out)}.reveal--left{transform:translate(-18px)}.reveal--right{transform:translate(18px)}.reveal--scale{transform:scale(.985)}}.seccion-home{position:relative;min-height:100vh;min-height:100dvh;padding-top:calc(var(--nav-height) + var(--nav-offset) + 2rem);padding-bottom:4rem;overflow:hidden;background:var(--color-bg)}.seccion-sobreMi{position:relative;padding-block:var(--section-py);background:var(--color-surface-dark);color:var(--color-surface)}.seccion-proyectos{position:relative;padding-block:var(--section-py);background:var(--color-bg-warm)}.seccion-footer{background:var(--color-bg);border-top:1px solid var(--color-border)}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.site-header{position:fixed;top:var(--nav-offset);left:0;right:0;z-index:1000;pointer-events:none}.site-header__bar{pointer-events:auto}.site-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:var(--nav-height);padding:.4rem .5rem .4rem .65rem;background:#cac9c78c;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border:1px solid rgba(255,255,255,.55);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-base) var(--ease-out),background var(--duration-base) var(--ease-out),border-color var(--duration-base) var(--ease-out)}.site-header.is-scrolled .site-nav{background:#cac9c7d1;box-shadow:var(--shadow-md);border-color:var(--color-border)}.site-nav__brand{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;font-size:.95rem;letter-spacing:-.02em;text-decoration:none;color:var(--color-text);flex-shrink:0}.site-nav__logo{display:block;width:2rem;height:2rem;object-fit:contain;flex-shrink:0}.site-nav__panel{display:flex;align-items:center;gap:.5rem}.site-nav__links{display:flex;align-items:center;gap:.15rem;list-style:none;margin:0;padding:0}.site-nav__link{display:block;padding:.45rem .85rem;font-size:.875rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;border-radius:var(--radius-pill);transition:color var(--duration-fast),background var(--duration-fast)}.site-nav__link:hover{color:var(--color-text);background:#ffffff59}.site-nav__link.is-active{color:var(--color-text);background:#ffffff80}.site-nav__actions{display:flex;align-items:center;gap:.5rem;margin-left:.5rem;padding-left:.75rem;border-left:1px solid var(--color-border)}.lang-switch{display:flex;gap:.15rem;padding:.2rem;background:#ffffff59;border-radius:var(--radius-pill)}.lang-switch__btn{padding:.3rem .55rem;font-family:var(--font-mono);font-size:.65rem;font-weight:600;letter-spacing:.05em;border:none;border-radius:var(--radius-pill);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:background var(--duration-fast),color var(--duration-fast)}.lang-switch__btn.is-active{background:var(--color-text);color:var(--color-bg)}.site-nav__cv{font-size:.8rem;padding:.5rem 1rem;white-space:nowrap}.site-nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:2.5rem;height:2.5rem;padding:0;border:none;border-radius:var(--radius-md);background:transparent;cursor:pointer}.site-nav__toggle-bar{display:block;width:1.25rem;height:2px;margin-inline:auto;background:var(--color-text);border-radius:1px;transition:transform var(--duration-base) var(--ease-out)}.site-header.menu-open .site-nav__toggle-bar:first-of-type{transform:translateY(3.5px) rotate(45deg)}.site-header.menu-open .site-nav__toggle-bar:last-of-type{transform:translateY(-3.5px) rotate(-45deg)}.site-nav__backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;margin:0;padding:0;border:none;background:#1a1a1a73;cursor:pointer;pointer-events:auto}.site-nav__panel--mobile{display:none}@media (max-width: 900px){.site-nav__toggle{display:flex}.site-nav__backdrop{display:block}.site-nav__panel--desktop{display:none!important}.site-nav__panel--mobile{display:flex;position:fixed;top:calc(var(--nav-offset) + var(--nav-height) + .75rem);left:1.25rem;right:1.25rem;z-index:1001;flex-direction:column;align-items:stretch;gap:1rem;padding:1.25rem;background:#eee;border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-12px) scale(.98);transition:opacity var(--duration-base),transform var(--duration-base),visibility var(--duration-base);pointer-events:auto}.site-nav__panel--mobile.is-open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.site-nav__links{flex-direction:column;align-items:stretch;gap:.25rem}.site-nav__link{padding:.85rem 1rem;font-size:1rem;border-radius:var(--radius-md);border-left:3px solid transparent}.site-nav__link.is-active{background:#2563eb14;border-left-color:var(--color-accent);color:var(--color-accent)}.site-nav__actions{flex-direction:column;margin:0;padding:0;border:none;gap:.75rem}.site-nav__cv{width:100%;justify-content:center}}.work__header{margin-bottom:clamp(3rem,7vw,5rem)}.work__list{display:flex;flex-direction:column;gap:0}.case-study{position:relative;padding-block:clamp(3.5rem,8vw,6rem);border-top:1px solid var(--color-border)}.case-study:last-child{border-bottom:1px solid var(--color-border)}.case-study--featured{background:linear-gradient(180deg,rgba(37,99,235,.04) 0%,transparent 100%)}.case-study--featured .case-study__browser{border-color:#2563eb33}.case-study--alt .case-study__inner{direction:rtl}.case-study--alt .case-study__inner>*{direction:ltr}.case-study__inner{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(2rem,5vw,4rem);align-items:center}.case-study__browser{border-radius:var(--radius-xl);overflow:hidden;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);transition:transform var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out)}.case-study:hover .case-study__browser{transform:translateY(-6px);box-shadow:var(--shadow-lg),0 0 60px -20px var(--color-accent-glow)}.case-study__browser-bar{display:flex;align-items:center;gap:6px;padding:.7rem 1rem;background:var(--color-surface-muted);border-bottom:1px solid var(--color-border)}.case-study__browser-bar span:nth-child(1){background:#ff5f57}.case-study__browser-bar span:nth-child(2){background:#febc2e}.case-study__browser-bar span:nth-child(3){background:#28c840}.case-study__browser-bar span:not(.case-study__url){width:9px;height:9px;border-radius:50%}.case-study__url{margin-left:auto;font-family:var(--font-mono);font-size:.65rem;color:var(--color-text-light)!important;background:none!important;width:auto!important;height:auto!important}.case-study__browser-body{position:relative;aspect-ratio:16 / 10;overflow:hidden;background:var(--color-bg)}.case-study__image-link{display:block;width:100%;height:100%;text-decoration:none}.case-study__image{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}.case-study__image--contain{object-fit:contain;padding:.75rem;background:var(--color-surface)}.case-study__image-link:hover .case-study__image{transform:scale(1.04)}.case-study__image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#1a1a1a80;opacity:0;transition:opacity var(--duration-base)}.case-study__image-link:hover .case-study__image-overlay{opacity:1}.case-study__image-overlay .btn{transform:translateY(12px);transition:transform var(--duration-base) var(--ease-out)}.case-study__image-link:hover .case-study__image-overlay .btn{transform:translateY(0)}.case-study__meta{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.case-study__meta-tags{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;min-width:0}.case-study__meta-tags .case-study__type,.case-study__meta-tags .case-study__badge{white-space:nowrap}.case-study__index{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--color-accent);letter-spacing:.05em}.case-study__type{font-family:var(--font-mono);font-size:var(--text-label);font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-light);padding:.25rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm)}.case-study__badge{font-family:var(--font-mono);font-size:var(--text-label);font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.25rem .55rem;border-radius:var(--radius-sm);background:#22c55e1a;border:1px solid rgba(34,197,94,.35);color:#15803d}.case-study__title{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:800;letter-spacing:-.04em;line-height:1.1;margin:0 0 .5rem;color:var(--color-text)}.case-study__tagline{font-size:1.05rem;font-weight:600;color:var(--color-text-muted);margin:0 0 .75rem}.case-study__desc{font-size:var(--text-body);color:var(--color-text-muted);line-height:1.7;margin:0 0 1.5rem;max-width:28rem}.case-study__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.75rem}.case-study__actions{display:flex;gap:.75rem}@media (max-width: 900px){.case-study__inner,.case-study--alt .case-study__inner{grid-template-columns:1fr;direction:ltr}.case-study__content{order:2}.case-study__media{order:1}.case-study__image-overlay{display:none}}.hero{position:relative;width:100%}.hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;pointer-events:none}.hero__grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(26,26,26,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(26,26,26,.04) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black,transparent);mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black,transparent)}.hero__spotlight{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}.hero__spotlight--1{width:50vw;max-width:32rem;height:32rem;top:-10%;right:-5%;background:radial-gradient(circle,var(--color-accent-soft),transparent 70%);animation:float-spot 12s ease-in-out infinite}.hero__spotlight--2{width:40vw;max-width:24rem;height:24rem;bottom:5%;left:-8%;background:radial-gradient(circle,rgba(202,201,199,.8),transparent 70%);animation:float-spot 14s ease-in-out infinite reverse}@keyframes float-spot{0%,to{transform:translate(0)}50%{transform:translate(20px,-16px)}}.hero__noise{position:absolute;top:0;right:0;bottom:0;left: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.9' 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")}.hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;min-height:calc(100vh - var(--nav-height) - var(--nav-offset) - 6rem)}.hero__content{display:flex;flex-direction:column;align-items:flex-start;gap:0}.hero__content .reveal{width:100%}.hero__title{margin:.75rem 0 0;font-size:var(--text-display);font-weight:800;letter-spacing:-.045em;line-height:1.02}.hero__title-line{display:block;font-size:.35em;font-weight:600;letter-spacing:-.02em;color:var(--color-text-muted);margin-bottom:.15em}.hero__title-accent{display:block;background:linear-gradient(135deg,var(--color-text) 0%,var(--color-text-muted) 50%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__lead{margin:1.25rem 0 0;font-size:clamp(1.05rem,2vw,1.2rem);color:var(--color-text-muted);line-height:1.65;max-width:32rem}.hero__cta{display:flex!important;flex-wrap:wrap;gap:.75rem;margin-top:1.75rem}.hero__social{display:flex!important;flex-wrap:wrap;gap:.5rem 1.25rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border);width:100%}.hero__social-link{font-size:var(--text-small);font-weight:600;color:var(--color-text-muted);text-decoration:none;transition:color var(--duration-fast)}.hero__social-link:hover{color:var(--color-accent)}.hero__stats{display:grid!important;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;width:100%;max-width:24rem}.hero__stat{padding:.85rem 0;border-top:1px solid var(--color-border)}.hero__stat-value{display:block;font-size:1.5rem;font-weight:800;letter-spacing:-.03em;color:var(--color-text)}.hero__stat-label{font-size:var(--text-small);color:var(--color-text-light)}.hero__visual{position:relative;min-height:28rem}.hero__terminal{position:relative;z-index:2;background:var(--color-surface-dark);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),var(--shadow-glow);overflow:hidden}.hero__terminal-bar{display:flex;align-items:center;gap:6px;padding:.75rem 1rem;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.06)}.hero__terminal-bar span:nth-child(1){background:#ff5f57}.hero__terminal-bar span:nth-child(2){background:#febc2e}.hero__terminal-bar span:nth-child(3){background:#28c840}.hero__terminal-bar span:not(.hero__terminal-title){width:10px;height:10px;border-radius:50%}.hero__terminal-title{margin-left:auto;font-family:var(--font-mono);font-size:.65rem;color:#fff6!important;background:none!important;width:auto!important;height:auto!important;border-radius:0!important}.hero__terminal-body{margin:0;padding:1.25rem 1.25rem 1.5rem;font-family:var(--font-mono);font-size:.78rem;line-height:1.85;color:#ffffffbf}.hero__terminal-body code{display:block}.hero__terminal-body .is-accent{color:#6ee7b7}.hero__prompt{color:var(--color-accent);opacity:.9}.hero__float{position:absolute;z-index:3;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.7);border-radius:var(--radius-md);box-shadow:var(--shadow-md);animation:float-card 6s ease-in-out infinite}@keyframes float-card{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.hero__float--avatar{right:-1rem;top:45%;padding:4px;border-radius:50%;animation-delay:-2s}.hero__avatar{width:5.5rem;height:5.5rem;border-radius:50%;object-fit:cover;border:2px solid var(--color-surface)}.hero__float-glow{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background:var(--color-accent-glow);filter:blur(24px);z-index:-1;border-radius:50%}.hero__float--stack{left:-1.5rem;bottom:12%;padding:.85rem 1rem;animation-delay:-4s}.hero__float-label{display:block;font-family:var(--font-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-light);margin-bottom:.4rem}.hero__float-tags{display:flex;gap:.35rem}.hero__float-tags span{font-family:var(--font-mono);font-size:.7rem;font-weight:600;padding:.2rem .45rem;background:var(--color-surface-muted);border-radius:var(--radius-sm);color:var(--color-text)}.hero__float--role{right:8%;top:8%;display:flex;align-items:center;gap:.65rem;padding:.75rem 1rem;animation-delay:-1s}.hero__float-icon{font-family:var(--font-mono);font-size:1.1rem;color:var(--color-accent)}.hero__float--role strong{display:block;font-size:.85rem;font-weight:700;color:var(--color-text)}.hero__scroll{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:2;text-decoration:none}.hero__scroll-line{display:block;width:1px;height:2.5rem;background:linear-gradient(to bottom,var(--color-text-muted),transparent);animation:scroll-line 2s ease infinite}@keyframes scroll-line{0%,to{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}@media (max-width: 960px){.hero__inner{grid-template-columns:1fr;min-height:auto;gap:3rem}.hero__visual{min-height:22rem;max-width:26rem;margin-inline:auto;width:100%}.hero__content{align-items:center;text-align:center}.hero__cta,.hero__social{justify-content:center}.hero__stats{margin-inline:auto}.hero__float--stack{left:0}.hero__float--avatar{right:0}}@media (max-width: 520px){.hero__stats{grid-template-columns:1fr;max-width:100%}.hero__stat{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;padding:.65rem 0}.hero__visual{min-height:20rem}.hero__float--role,.hero__scroll{display:none}}.stack{position:relative;padding-top:clamp(3rem,6vw,5rem);margin-top:clamp(2rem,4vw,3rem);border-top:1px solid rgba(255,255,255,.08)}.stack__header{margin-bottom:clamp(2rem,4vw,3rem)}.stack__title{font-size:clamp(1.75rem,3.5vw,2.35rem);font-weight:800;letter-spacing:-.04em;line-height:1.1;color:var(--color-surface);margin:0;max-width:20ch}.stack__lead{margin:.85rem 0 0;font-size:clamp(.95rem,1.8vw,1.1rem);color:#ffffff8c;line-height:1.65;max-width:42rem}.stack__core{padding:1.15rem 1.35rem;margin-bottom:1.25rem;background:#00000059;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);box-shadow:inset 0 1px #ffffff0d}.stack__core-header{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem .75rem;margin-bottom:.85rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.08)}.stack__core-prompt{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--color-accent)}.stack__core-command{font-family:var(--font-mono);font-size:.75rem;color:#ffffff80}.stack__core-badge{margin-left:auto;font-family:var(--font-mono);font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .5rem;border-radius:var(--radius-sm);background:#2563eb33;color:#93c5fd;border:1px solid rgba(37,99,235,.35)}.stack__core-list{display:flex;flex-wrap:wrap;gap:.5rem}.stack-tech{display:inline-flex;align-items:center;font-family:var(--font-mono);font-weight:500;border-radius:var(--radius-sm);border:1px solid transparent;transition:transform var(--duration-fast) var(--ease-out),background var(--duration-fast),border-color var(--duration-fast),box-shadow var(--duration-fast),color var(--duration-fast);cursor:default}.stack-tech--core{font-size:.8rem;padding:.45rem .85rem;background:#2563eb2e;border-color:#2563eb73;color:#dbeafe;box-shadow:0 0 20px -6px var(--color-accent-glow)}.stack-tech--core:hover{transform:translateY(-2px);background:#2563eb4d;box-shadow:0 0 28px -4px var(--color-accent-glow)}.stack-tech--strong{font-size:.75rem;padding:.38rem .7rem;background:#ffffff1a;border-color:#ffffff24;color:#ffffffe6}.stack-tech--strong:hover{transform:translateY(-2px);background:#ffffff29;border-color:#ffffff40}.stack-tech--familiar{font-size:.72rem;padding:.35rem .65rem;background:#ffffff0a;border-color:#ffffff14;color:#ffffff8c;border-style:dashed}.stack-tech--familiar:hover{color:#ffffffbf;border-style:solid}.stack__bento{display:grid;grid-template-columns:repeat(12,1fr);gap:.85rem;margin-bottom:1.25rem}.stack__card{min-height:0}.stack__card>article{position:relative;height:100%;padding:1.25rem 1.35rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--duration-base) var(--ease-out),background var(--duration-base) var(--ease-out),transform var(--duration-base) var(--ease-out),opacity var(--duration-base) var(--ease-out);outline:none}.stack__card>article:focus-visible{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-soft)}.stack__card--large{grid-column:span 6}.stack__card--medium{grid-column:span 4}.stack__card--wide{grid-column:span 12}.stack__bento.has-active .stack__card.is-dimmed>article{opacity:.45;transform:scale(.99)}.stack__card.is-active>article{border-color:#2563eb80;background:#ffffff12;transform:translateY(-3px)}.stack__card-glow{position:absolute;inset:auto -20% -40% -20%;height:60%;background:radial-gradient(ellipse at center,var(--color-accent-glow),transparent 70%);opacity:0;transition:opacity var(--duration-base);pointer-events:none}.stack__card.is-active .stack__card-glow{opacity:.5}.stack__card-head{display:flex;gap:.85rem;margin-bottom:1rem}.stack__card-index{font-family:var(--font-mono);font-size:.65rem;font-weight:600;color:var(--color-accent);opacity:.8;flex-shrink:0;margin-top:.15rem}.stack__card-title{font-size:1rem;font-weight:700;color:var(--color-surface);margin:0 0 .35rem;letter-spacing:-.02em}.stack__card-desc{font-size:.8rem;color:#ffffff73;line-height:1.5;margin:0}.stack__card-techs{display:flex;flex-wrap:wrap;gap:.4rem}.stack__architecture{margin-bottom:1.25rem}.stack__arch-panel{padding:1.35rem 1.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg)}.stack__arch-label{font-family:var(--font-mono);font-size:var(--text-label);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ffffff59;margin:0 0 1rem}.stack__arch-flow{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem}.stack__arch-node-wrap{display:flex;align-items:center;gap:.5rem}.stack__arch-node{display:flex;flex-direction:column;gap:.2rem;padding:.65rem 1rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);font-size:.85rem;font-weight:600;color:#ffffffd9;transition:border-color var(--duration-fast),background var(--duration-fast)}.stack__arch-node:hover{border-color:#2563eb66;background:#2563eb1a}.stack__arch-step{font-family:var(--font-mono);font-size:.6rem;color:var(--color-accent);letter-spacing:.05em}.stack__arch-arrow{font-family:var(--font-mono);font-size:.9rem;color:#ffffff40}.stack__arch-caption{margin:1rem 0 0;font-size:.8rem;color:#fff6;line-height:1.5}.stack__capabilities{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;margin-bottom:1.5rem}.stack__cap-card{padding:1.15rem 1.25rem!important;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-md);transition:border-color var(--duration-fast),transform var(--duration-fast)}.stack__cap-card:hover{border-color:#ffffff26;transform:translateY(-2px)}.stack__cap-icon{display:block;font-size:.65rem;color:var(--color-accent);margin-bottom:.5rem}.stack__cap-card h5{font-size:.9rem;font-weight:700;color:var(--color-surface);margin:0 0 .4rem;letter-spacing:-.02em}.stack__cap-card p{font-size:.78rem;color:#ffffff73;line-height:1.5;margin:0}.stack__footnote{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem 1.25rem;font-family:var(--font-mono);font-size:.65rem;color:#ffffff59;margin:0}.stack__footnote-dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:.35rem}.stack__footnote-dot--core{background:#2563eb99;box-shadow:0 0 8px var(--color-accent-glow)}.stack__footnote-dot--strong{background:#ffffff59}.stack__footnote-dot--familiar{background:transparent;border:1px dashed rgba(255,255,255,.3)}@media (max-width: 1024px){.stack__card--large,.stack__card--medium{grid-column:span 6}.stack__capabilities{grid-template-columns:1fr}}@media (max-width: 640px){.stack__card--large,.stack__card--medium,.stack__card--wide{grid-column:span 12}.stack__arch-flow,.stack__arch-node-wrap{flex-direction:column;align-items:stretch}.stack__arch-arrow{transform:rotate(90deg);align-self:center}.stack__core-badge{margin-left:0}}.about{position:relative;overflow:hidden}.about__glow{position:absolute;top:-20%;right:-10%;width:50vw;max-width:36rem;height:36rem;background:radial-gradient(circle,var(--color-accent-glow),transparent 65%);filter:blur(60px);opacity:.35;pointer-events:none}.about__header{margin-bottom:clamp(3rem,6vw,5rem)}.section-label--light:before{background:#ffffff40}.section-heading--light{color:var(--color-surface);max-width:16ch}.section-lead--light{color:#ffffff8c}.about__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,4vw,2.5rem);align-items:start;margin-bottom:clamp(4rem,8vw,6rem)}.about__bio-card{padding:clamp(1.75rem,4vw,2.5rem);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.about__bio-title{font-size:var(--text-h3);font-weight:700;color:var(--color-surface);margin:0 0 1.25rem;letter-spacing:-.03em}.about__bio-text{font-size:var(--text-body);color:#ffffffa6;line-height:1.75;margin:0 0 1rem}.about__quote{margin:1.75rem 0 0;padding:1.25rem 0 0;border-top:1px solid rgba(255,255,255,.1)}.about__quote p{margin:0;font-size:1.05rem;font-weight:500;font-style:italic;color:#ffffffd9;line-height:1.6}.about__aside{display:flex;flex-direction:column;gap:1.25rem}.about__stats-row{display:grid!important;grid-template-columns:repeat(3,1fr);gap:.65rem}.about__stat-card{padding:1rem .75rem;text-align:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);transition:border-color var(--duration-fast),background var(--duration-fast)}.about__stat-card:hover{background:#ffffff14;border-color:#ffffff26}.about__stat-value{display:block;font-size:1rem;font-weight:800;color:var(--color-surface);letter-spacing:-.02em}.about__stat-label{font-size:.65rem;color:#ffffff73;text-transform:uppercase;letter-spacing:.06em}.about__highlights,.about__timeline{padding:1.25rem 1.35rem;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-lg)}.about__block-title{font-family:var(--font-mono);font-size:var(--text-label);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#fff6;margin:0 0 1rem}.about__highlight-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.about__highlight-list li{position:relative;padding-left:1.1rem;font-size:.9rem;color:#ffffffb3;line-height:1.5}.about__highlight-list li:before{content:"";position:absolute;left:0;top:.55em;width:5px;height:5px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 8px var(--color-accent-glow)}.about__timeline-list{list-style:none;margin:0;padding:0}.about__timeline-item{display:flex;gap:.85rem;padding-bottom:1.1rem}.about__timeline-item:last-child{padding-bottom:0}.about__timeline-dot{flex-shrink:0;width:8px;height:8px;margin-top:.35em;border-radius:50%;background:var(--color-accent);box-shadow:0 0 12px var(--color-accent-glow)}.about__timeline-year{display:block;font-family:var(--font-mono);font-size:.65rem;color:var(--color-accent);letter-spacing:.05em;margin-bottom:.2rem}.about__timeline-item p{margin:0;font-size:.875rem;color:#ffffffa6;line-height:1.5}.about__bio-badge{display:inline-flex;font-family:var(--font-mono);font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .65rem;margin-bottom:1rem;border-radius:var(--radius-sm);background:#2563eb26;border:1px solid rgba(37,99,235,.35);color:#93c5fd}@media (max-width: 900px){.about__grid{grid-template-columns:1fr}.about__stats-row{grid-template-columns:repeat(3,1fr)}}@media (max-width: 520px){.about__stats-row{grid-template-columns:1fr}}.footer{padding:var(--section-py) 0 clamp(2rem,4vw,3rem)}.footer__cta-block{text-align:center;max-width:36rem;margin-inline:auto;padding-bottom:clamp(2.5rem,5vw,4rem)}.footer__headline{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.1;margin:0;color:var(--color-text)}.footer__text{margin:1rem 0 1.75rem;font-size:var(--text-body);color:var(--color-text-muted);line-height:1.65}.footer__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.footer__cta{margin-inline:0}.footer__bottom{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding-top:2rem;border-top:1px solid var(--color-border)}.footer__links{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1.5rem}.footer__links a{font-size:var(--text-small);font-weight:600;color:var(--color-text-muted);text-decoration:none;transition:color var(--duration-fast)}.footer__links a:hover{color:var(--color-accent)}.footer__copy{margin:0;font-size:var(--text-small);color:var(--color-text-light)}.footer__sep{margin-inline:.35rem;opacity:.5}.footer__role{color:var(--color-text-muted);font-weight:500}
