:root{--ink:#08090f;--ink-soft:#0b0d15;--surface:#111320;--surface-2:#171a28;--surface-3:#1f2335;--line:#ffffff12;--line-2:#ffffff1f;--text:#e8eaf2;--text-strong:#fff;--muted:#9398ab;--faint:#656b81;--accent:#f5c451;--accent-2:#ffd877;--accent-soft:#f5c4511f;--accent-line:#f5c45147;--shadow:0 24px 70px #00000073;--shadow-soft:0 16px 40px #00000052;--radius:14px;--radius-sm:10px;--radius-lg:22px;--container:1140px;--header-height:72px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + 28px);-webkit-text-size-adjust:100%}body{background:var(--ink);min-width:320px;color:var(--text);letter-spacing:-.01em;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:#f5c45133;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6;overflow-x:hidden}::selection{background:var(--accent);color:var(--ink)}a{color:inherit;text-decoration:none}img,svg{display:block}button,a{touch-action:manipulation}h1,h2,h3,p{margin:0}h1,h2,h3{text-wrap:balance;letter-spacing:-.025em}p{text-wrap:pretty}section[id]{scroll-margin-top:calc(var(--header-height) + 30px)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.skip-link{z-index:20;border-radius:var(--radius-sm);background:var(--accent);color:var(--ink);padding:10px 14px;font-weight:700;transition:transform .16s;position:fixed;inset-block-start:12px;inset-inline-start:12px;transform:translateY(-160%)}.skip-link:focus-visible{transform:translateY(0)}.site-canvas{background:radial-gradient(820px 520px at 84% -10%, var(--accent-soft), transparent 62%), radial-gradient(680px 460px at -8% 6%, #78aaff0f, transparent 58%), var(--ink);min-height:100vh;position:relative}.section-shell{width:min(100% - 48px, var(--container));margin-inline:auto}.site-header{z-index:10;padding-block:max(10px, env(safe-area-inset-top));border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(16px);background:#08090fb3;position:sticky;top:0}.site-header__inner{width:min(100% - 48px, var(--container));justify-content:space-between;align-items:center;gap:24px;min-height:52px;margin-inline:auto;display:flex}.site-header__brand{opacity:.95;min-width:0;transition:opacity .16s;display:inline-flex}.site-header__brand:hover{opacity:1}.site-header__brand img{width:190px;height:auto}.site-header__nav{color:var(--muted);justify-content:center;align-items:center;gap:2px;font-size:.9rem;font-weight:600;display:flex}.site-header__nav a{border-radius:999px;align-items:center;min-height:44px;padding:0 13px;transition:background-color .16s,color .16s;display:inline-flex}.site-header__nav a:hover{background:var(--surface-2);color:var(--text-strong)}.site-header__tools{align-items:center;gap:12px;display:flex}.lang-toggle{border:1px solid var(--line-2);background:var(--surface);border-radius:999px;padding:3px;display:inline-flex}.lang-toggle__option{min-width:44px;min-height:38px;color:var(--muted);font:inherit;letter-spacing:.02em;cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:center;align-items:center;padding:6px 10px;font-size:.78rem;font-weight:700;transition:background-color .16s,color .16s;display:inline-flex}.lang-toggle__option:hover{color:var(--text-strong)}.lang-toggle__option[aria-pressed=true]{background:var(--accent);color:var(--ink)}.button-link{text-align:center;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:9px;min-height:44px;padding:11px 20px;font-size:.92rem;font-weight:700;line-height:1;transition:background-color .16s,border-color .16s,color .16s,transform .16s,box-shadow .16s;display:inline-flex}.button-link:hover{transform:translateY(-1px)}.button-link svg{flex:none;width:1.05em;height:1.05em}.button-link--primary{background:var(--accent);color:var(--ink);box-shadow:0 10px 26px #f5c45138}.button-link--primary:hover{background:var(--accent-2);color:var(--ink);box-shadow:0 14px 32px #f5c4514d}.button-link--secondary{background:var(--surface-2);border-color:var(--line-2);color:var(--text-strong)}.button-link--secondary:hover{background:var(--surface-3);border-color:#ffffff3d}.button-link--quiet{color:var(--text);border-color:var(--line-2);background:0 0}.button-link--quiet:hover{background:var(--surface-2);border-color:var(--accent-line);color:var(--accent)}.hero{min-height:calc(100svh - var(--header-height));grid-template-columns:minmax(0,1fr) minmax(300px,420px);align-items:center;gap:48px 64px;padding-block:40px 64px;display:grid;position:relative}.hero__content{flex-direction:column;grid-area:auto;align-items:flex-start;gap:22px;display:flex}.hero__location{border:1px solid var(--line-2);background:var(--surface);color:var(--muted);border-radius:999px;align-items:center;gap:8px;padding:7px 13px 7px 11px;font-size:.82rem;font-weight:600;display:inline-flex}.hero__location svg{width:1em;height:1em;color:var(--accent)}.hero h1{max-width:14ch;color:var(--text-strong);font-size:clamp(2.8rem,7.5vw,5rem);font-weight:800;line-height:.98}.hero__role{color:var(--accent);text-wrap:nowrap;font-size:clamp(1.2rem,2.6vw,1.6rem);font-weight:700;line-height:1.2}.hero__copy{max-width:52ch;color:var(--muted);font-size:1.1rem}.hero__actions{flex-wrap:wrap;gap:12px;display:flex}.hero__visual{flex-direction:column;gap:16px;min-width:0;display:flex}.profile-card{border:1px solid var(--line-2);border-radius:var(--radius-lg);background:linear-gradient(180deg, #ffffff0b, #fff0), var(--surface);box-shadow:var(--shadow);overflow:hidden}.profile-card__bar{border-bottom:1px solid var(--line);background:#ffffff05;align-items:center;gap:8px;padding:13px 18px;display:flex}.profile-card__bar span{background:#ffffff29;border-radius:50%;width:11px;height:11px}.profile-card__bar em{color:var(--faint);margin-inline-start:auto;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.78rem;font-style:normal}.profile-card__body{gap:14px;padding:22px 18px;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.9rem;display:grid}.profile-card__body p{min-width:0;color:var(--text);grid-template-columns:62px minmax(0,1fr);gap:14px;display:grid}.profile-card__body p span{color:var(--accent)}.profile-card__status{border-top:1px solid var(--line);color:var(--muted);background:#ffffff05;align-items:center;gap:10px;padding:14px 18px;font-size:.86rem;font-weight:500;display:flex}.profile-card__status .status-dot{background:var(--accent);border-radius:50%;width:9px;height:9px;position:relative;box-shadow:0 0 0 4px #f5c45129}.badge-row{flex-wrap:wrap;gap:8px;display:flex}.badge{border:1px solid var(--line-2);min-height:32px;color:var(--text);background:var(--surface);border-radius:999px;align-items:center;gap:7px;padding:6px 12px;font-size:.82rem;font-weight:600;line-height:1.1;display:inline-flex}.badge svg{width:1em;height:1em;color:var(--accent)}.badge--muted{border-color:var(--line-2);background:var(--surface-2);color:var(--text)}.badge--accent{background:var(--accent);color:var(--ink);border-color:#0000}.badge--accent svg{color:var(--ink)}.section-block{border-top:1px solid var(--line);padding-block:86px}.section-heading{gap:14px;max-width:60ch;margin-bottom:40px;display:grid}.section-heading__eyebrow,.contact-band__label,.timeline__period{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:8px;font-size:.76rem;font-weight:700;line-height:1.2;display:inline-flex}.section-heading__eyebrow:before{content:"";background:var(--accent-line);width:18px;height:1px}.section-heading h2,.contact-band h2{color:var(--text-strong);font-size:clamp(2rem,4.5vw,2.8rem);font-weight:800;line-height:1.05}.section-heading p,.about-copy p,.card__description,.card__content,.timeline__item p,.contact-band p{color:var(--muted)}.about-grid{grid-template-columns:clamp(280px,34vw,400px) minmax(0,1fr);align-items:center;gap:56px;display:grid}.about-copy{gap:20px;font-size:1.12rem;line-height:1.7;display:grid}.about-copy p{color:var(--text)}.about-photo{aspect-ratio:1;border:1px solid var(--line-2);border-radius:var(--radius-lg);background:radial-gradient(120% 90% at 80% 0%, var(--accent-soft), transparent 55%), linear-gradient(180deg, var(--surface-2), var(--surface));width:100%;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.about-photo:after{content:"";background-image:url(/img/abel.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;position:absolute;inset:0}.about-photo__fallback{color:var(--accent);letter-spacing:.04em;opacity:.5;place-items:center;font-size:3.4rem;font-weight:800;display:grid;position:absolute;inset:0}.card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);transition:border-color .18s,transform .18s,background-color .18s}.card:hover{border-color:var(--line-2);background:var(--surface-2);transform:translateY(-2px)}.card__header,.card__content,.card__footer{padding-inline:22px}.card__header{gap:8px;padding-top:22px;padding-bottom:12px;display:grid}.card__title{color:var(--text-strong);font-size:1.12rem;font-weight:700;line-height:1.25}.card__description{font-size:.94rem;line-height:1.5}.card__content{padding-bottom:18px}.card__footer{padding-bottom:22px}.card__footer a:not(.button-link){color:var(--text-strong);align-items:center;gap:8px;font-size:.92rem;font-weight:600;transition:color .16s,gap .16s;display:inline-flex}.card__footer a:not(.button-link):hover{color:var(--accent);gap:11px}.card__footer svg{width:1em;height:1em}.split-grid{grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);align-items:start;gap:56px;display:grid}.split-grid>.section-heading{top:calc(var(--header-height) + 28px);margin-bottom:0;position:sticky}.timeline{gap:34px;margin:0;padding:4px 0;list-style:none;display:grid;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, var(--accent) 0%, var(--accent-line) 55%, transparent);width:2px;position:absolute;inset-block:10px;inset-inline-start:6px}.timeline__item{padding-inline-start:34px;position:relative}.timeline__node{inset-inline-start:0;background:var(--accent);border:3px solid var(--ink);width:14px;height:14px;box-shadow:0 0 0 1px var(--accent-line);border-radius:50%;position:absolute;top:5px}.timeline__period{color:var(--accent);letter-spacing:.1em;text-transform:uppercase;font-variant-numeric:tabular-nums;margin-bottom:8px;font-size:.76rem;font-weight:700;display:inline-block}.timeline__title{color:var(--text-strong);font-size:1.2rem;font-weight:700;line-height:1.25}.timeline__company{color:var(--text);margin-bottom:10px;font-weight:600}.timeline__summary{color:var(--muted)}.projects-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.project-card{flex-direction:column;display:flex}.project-card .card__content{margin-top:auto}.research-grid,.skills-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.skills-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.card-icon{border-radius:var(--radius-sm);border:1px solid var(--accent-line);background:var(--accent-soft);width:44px;height:44px;color:var(--accent);place-items:center;margin-bottom:4px;display:inline-grid}.card-icon svg{width:1.3rem;height:1.3rem}.research-card,.skill-card{flex-direction:column;min-height:100%;display:flex}.research-card .card__footer{margin-top:auto}.tag-list{flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none;display:flex}.tag-list li{border:1px solid var(--line-2);background:var(--surface-2);color:var(--text);border-radius:999px;padding:6px 11px;font-size:.83rem;font-weight:600}.contact-band{border:1px solid var(--accent-line);border-radius:var(--radius-lg);background:radial-gradient(640px 320px at 100% 0%, var(--accent-soft), transparent 60%), linear-gradient(180deg, var(--surface-2), var(--surface));box-shadow:var(--shadow);grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:32px;margin-block:90px;padding:44px;display:grid}.contact-band h2{color:var(--text-strong)}.contact-band__title-action{color:var(--accent);display:block}.contact-band p:not(.contact-band__label){max-width:56ch;color:var(--muted);margin-top:14px}.contact-band__label{margin-bottom:14px}.contact-band__social{flex-wrap:wrap;gap:18px;margin-top:22px;display:flex}.contact-band__social a{color:var(--muted);align-items:center;gap:7px;font-size:.9rem;font-weight:600;transition:color .16s;display:inline-flex}.contact-band__social a:hover{color:var(--accent)}.contact-band__social svg{width:1.05em;height:1.05em;color:var(--accent)}.contact-band__actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;display:flex}.site-footer{border-top:1px solid var(--line);background:var(--ink-soft);padding-block:32px}.site-footer__inner{color:var(--faint);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;font-size:.9rem;display:flex}.site-footer__links{color:var(--muted);flex-wrap:wrap;gap:18px;font-weight:600;display:flex}.site-footer__links a{align-items:center;gap:7px;transition:color .16s;display:inline-flex}.site-footer__links svg{width:1em;height:1em}.site-footer__links a:hover{color:var(--accent)}@media (max-width:1040px){.site-header__inner{flex-wrap:wrap}.site-header__nav{order:3;justify-content:flex-start;width:100%;padding-bottom:2px;overflow-x:auto}.hero{grid-template-columns:1fr;padding-top:52px}.hero__visual{max-width:520px}.research-grid,.skills-grid,.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.about-grid{gap:32px}}@media (max-width:760px){:root{--header-height:104px}.section-shell,.site-header__inner{width:min(100% - 32px, var(--container))}.site-header__brand img{width:164px}.site-header__cta{display:none}.hero{gap:32px;padding-block:44px 36px}.hero__copy,.about-copy{font-size:1rem}.hero__role{text-wrap:pretty}.about-grid,.split-grid,.projects-grid,.research-grid,.skills-grid,.contact-band{grid-template-columns:1fr}.split-grid{gap:36px}.split-grid>.section-heading{margin-bottom:0;position:static}.about-photo{order:-1;width:100%;max-width:300px}.section-block{padding-block:60px}.contact-band{margin-block:60px;padding:28px}.contact-band__actions{justify-content:stretch}.contact-band__actions .button-link{width:100%}}@media (max-width:460px){.hero__actions .button-link{width:100%}}.reveal-ready [data-reveal]{opacity:0;transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);transform:translateY(18px)}.reveal-ready [data-reveal].reveal-in{opacity:1;transform:none}.reveal-ready .projects-grid>[data-reveal]:nth-child(2),.reveal-ready .research-grid>[data-reveal]:nth-child(2),.reveal-ready .skills-grid>[data-reveal]:nth-child(2){transition-delay:80ms}.reveal-ready .projects-grid>[data-reveal]:nth-child(3),.reveal-ready .research-grid>[data-reveal]:nth-child(3),.reveal-ready .skills-grid>[data-reveal]:nth-child(3){transition-delay:.16s}.reveal-ready .skills-grid>[data-reveal]:nth-child(4){transition-delay:.24s}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:1ms!important;animation-duration:1ms!important}.reveal-ready [data-reveal]{opacity:1;transform:none}}
