:root{--paper: #f7f5f0;--paper-2: #efece4;--ink: #1f1d1a;--ink-muted: #5c5852;--line: #d9d4ca;--accent: #4a5c46;--accent-soft: #e3ebe1;--warm: #8b6914;--radius: 12px;--shadow: 0 1px 2px rgba(31, 29, 26, .04), 0 8px 24px rgba(31, 29, 26, .06);--font-display: "Fraunces", Georgia, serif;--font-body: "Outfit", system-ui, sans-serif;--max: 1120px;--site-header-height: 3.65rem}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);font-weight:400;font-size:1.05rem;line-height:1.65;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--accent);text-decoration:none;transition:opacity .15s ease}a:hover{opacity:.85}img{max-width:100%;height:auto;display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.shell{max-width:var(--max);margin:0 auto;padding:0 1.5rem}.shell--wide{max-width:min(1200px,100%)}.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 88%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent)}.site-header__inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:.85rem 1.5rem;gap:1rem;min-height:var(--site-header-height)}.logo{font-family:var(--font-display);font-weight:600;font-size:1.1rem;letter-spacing:-.02em;color:var(--ink);z-index:2}.nav-toggle{display:none;flex-shrink:0;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;padding:0;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);cursor:pointer;z-index:2;transition:border-color .15s ease,background .15s ease}.nav-toggle:hover{border-color:var(--ink-muted);background:var(--paper-2)}.nav-toggle__bars{display:flex;flex-direction:column;justify-content:center;gap:5px;width:1.2rem}.nav-toggle__bars span{display:block;height:2px;border-radius:1px;background:currentColor;transition:transform .25s ease,opacity .2s ease;transform-origin:center}.nav-toggle--open .nav-toggle__bars span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-toggle--open .nav-toggle__bars span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-toggle--open .nav-toggle__bars span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;margin:0;padding:0;border:none;background:#1f1d1a6b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);cursor:pointer}.nav{display:flex;flex-wrap:wrap;gap:.35rem 1.25rem;align-items:center;justify-content:flex-end}.nav a{font-size:.92rem;font-weight:500;color:var(--ink-muted)}.nav a:hover{color:var(--ink);opacity:1}.nav__cta{display:inline-flex;align-items:center;padding:.45rem .95rem;border-radius:999px;background:var(--ink);color:var(--paper)!important;font-size:.88rem}.nav__cta:hover{opacity:.92}@media(max-width:767px){.nav-toggle{display:inline-flex}.nav{display:none;position:fixed;top:var(--site-header-height);left:0;right:0;z-index:95;flex-direction:column;flex-wrap:nowrap;align-items:stretch;gap:0;padding:.35rem 1.25rem 1.15rem;margin:0;background:color-mix(in srgb,var(--paper) 96%,#fff);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);box-shadow:0 16px 40px #1f1d1a1f}.nav--open{display:flex}.nav a{padding:.85rem .35rem;font-size:1rem;border-bottom:1px solid color-mix(in srgb,var(--line) 80%,transparent)}.nav a:last-child{border-bottom:none;margin-top:.35rem;padding-top:.75rem;text-align:center;justify-content:center}.nav .nav__cta{margin-top:.15rem}}@media(min-width:768px){.nav-toggle{display:none!important}.nav{display:flex!important}}.hero{padding:4.5rem 0 4rem;border-bottom:1px solid var(--line)}.hero__grid{display:grid;gap:2.5rem;align-items:start}@media(min-width:800px){.hero__grid{grid-template-columns:1fr 280px;gap:3rem}}.hero__eyebrow{font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--warm);margin:0 0 1rem}.hero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,4.5vw,2.85rem);line-height:1.15;letter-spacing:-.03em;margin:0 0 1.25rem;color:var(--ink)}.hero__lead{font-size:1.15rem;color:var(--ink-muted);max-width:38ch;margin:0 0 1.75rem;font-weight:300}.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.35rem;border-radius:999px;font-family:var(--font-body);font-size:.95rem;font-weight:500;border:none;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.btn:active{transform:scale(.98)}.btn--primary{background:var(--accent);color:var(--paper);box-shadow:var(--shadow)}.btn--primary:hover{opacity:.95}.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}.btn--ghost:hover{border-color:var(--ink-muted)}.email-choice{display:inline-flex;vertical-align:middle}.email-modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;background:#1f1d1a7a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);cursor:pointer}.email-modal__panel{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:251;width:min(22rem,calc(100vw - 2rem));padding:1.85rem 1.5rem 1.5rem;background:linear-gradient(180deg,#fff,#fcfbfa);border-radius:calc(var(--radius) + 6px);border:1px solid var(--line);box-shadow:0 1px 2px #1f1d1a0a,0 28px 64px #1f1d1a29;text-align:center}.email-modal__close{position:absolute;top:.65rem;right:.65rem;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background:transparent;color:var(--ink-muted);font-size:1.5rem;line-height:1;cursor:pointer;transition:background .15s ease,color .15s ease}.email-modal__close:hover{background:var(--paper-2);color:var(--ink)}.email-modal__title{font-family:var(--font-display);font-size:1.45rem;font-weight:600;margin:0 0 .5rem;letter-spacing:-.02em;color:var(--ink)}.email-modal__desc{margin:0 0 1.35rem;font-size:.94rem;color:var(--ink-muted);font-weight:300;line-height:1.5}.email-modal__actions{display:flex;flex-direction:column;gap:.75rem}.email-modal__btn{display:flex;align-items:center;justify-content:flex-start;gap:1rem;padding:.95rem 1.15rem;border-radius:var(--radius);border:1px solid var(--line);background:#fff;color:var(--ink);text-decoration:none;font-weight:600;font-size:1rem;transition:border-color .15s ease,box-shadow .15s ease,transform .12s ease}.email-modal__btn:hover{opacity:1;border-color:color-mix(in srgb,var(--accent) 35%,var(--line));box-shadow:0 6px 20px #1f1d1a14}.email-modal__btn:active{transform:scale(.99)}.email-modal__btn--gmail:hover{border-color:color-mix(in srgb,#ea4335 45%,var(--line))}.email-modal__btn--mail{color:var(--accent)}.email-modal__btn--mail:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--line))}.email-modal__btn-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:10px;background:var(--paper-2)}.email-modal__btn--gmail .email-modal__btn-icon{background:#fff;border:1px solid #eee}.email-modal__btn--mail .email-modal__btn-icon{background:color-mix(in srgb,var(--accent-soft) 80%,#fff);border:1px solid color-mix(in srgb,var(--accent) 15%,transparent)}.email-modal__icon-svg--mail{color:var(--accent)}.email-modal__btn-label{text-align:left}.hero__portrait{justify-self:center}@media(min-width:800px){.hero__portrait{justify-self:end}}.portrait-frame{width:220px;height:220px;border-radius:50%;overflow:hidden;border:3px solid var(--paper-2);box-shadow:var(--shadow);background:var(--paper-2)}.portrait-frame img{width:100%;height:100%;object-fit:cover;object-position:center 80%}.section{padding:4rem 0;border-bottom:1px solid var(--line)}.section:last-of-type{border-bottom:none}.section__head{margin-bottom:2.25rem;max-width:52ch}.section__head h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,2.5vw,1.85rem);margin:0 0 .5rem;letter-spacing:-.02em}.section__head p{margin:0;color:var(--ink-muted);font-weight:300}.inline-code{font-size:.9em;padding:.1em .35em;border-radius:4px;background:var(--paper-2);font-family:ui-monospace,monospace}.section__subhead{font-family:var(--font-display);font-size:1.1rem;margin:0 0 1rem;font-weight:600}.service-grid{display:grid;gap:1.15rem}@media(min-width:640px){.service-grid{grid-template-columns:repeat(2,1fr)}}.service-card{position:relative;padding:1.5rem 1.45rem 1.45rem;background:linear-gradient(165deg,#fff,#fcfbfa);border:1px solid var(--line);border-radius:calc(var(--radius) + 2px);box-shadow:0 1px #1f1d1a0a,0 14px 40px #1f1d1a0d;transition:transform .25s cubic-bezier(.25,.46,.45,.94),box-shadow .25s ease,border-color .25s ease;overflow:hidden}.service-card:after{content:"";position:absolute;inset:0 0 auto 0;height:3px;border-radius:3px 3px 0 0;opacity:.85}.service-card--frontend:after{background:linear-gradient(90deg,var(--accent),color-mix(in srgb,var(--accent) 65%,#2d3d2a))}.service-card--redesign:after{background:linear-gradient(90deg,#8b6914,color-mix(in srgb,var(--warm) 75%,#c4a35a))}.service-card--components:after{background:linear-gradient(90deg,#5a6b8c,#7a8bad)}.service-card--landing:after{background:linear-gradient(90deg,#4a6670,#6b8c96)}.service-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--accent) 18%,var(--line));box-shadow:0 1px #1f1d1a0d,0 20px 48px #1f1d1a17}.service-card__icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;color:var(--accent);background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 12%,transparent)}.service-card--redesign .service-card__icon{color:#6b5344;background:color-mix(in srgb,var(--warm) 14%,var(--paper-2));border-color:color-mix(in srgb,var(--warm) 22%,transparent)}.service-card--components .service-card__icon{color:#4a5568;background:#eef1f6;border-color:#dde3ec}.service-card--landing .service-card__icon{color:#3d5a62;background:#e8f0f2;border-color:#d0e0e4}.service-card h3{font-family:var(--font-display);font-size:1.12rem;font-weight:600;margin:0 0 .55rem;letter-spacing:-.02em;line-height:1.3}.service-card p{margin:0;font-size:.96rem;color:var(--ink-muted);font-weight:300;line-height:1.58}.skill-categories{display:flex;flex-direction:column;gap:2rem}.skill-category__title{font-family:var(--font-display);font-size:1.05rem;font-weight:600;margin:0 0 .75rem;letter-spacing:-.02em;color:var(--ink-muted)}.skill-chips{display:flex;flex-wrap:wrap;gap:.5rem}.skill-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;background:var(--accent-soft);color:var(--ink);border-radius:999px;font-size:.88rem;font-weight:500}.skill-chip small{font-weight:400;color:var(--ink-muted);font-size:.78rem}.timeline{display:flex;flex-direction:column;gap:1.5rem}.timeline-item{position:relative;padding-left:1.25rem;border-left:2px solid var(--line)}.timeline-item:before{content:"";position:absolute;left:-5px;top:.35rem;width:8px;height:8px;border-radius:50%;background:var(--accent)}.timeline-item h3{font-size:1.05rem;font-weight:600;margin:0 0 .15rem}.timeline-item .meta{font-size:.88rem;color:var(--ink-muted);margin:0 0 .5rem}.timeline-item p{margin:0;color:var(--ink-muted);font-weight:300;font-size:.98rem}.work-band{border-radius:calc(var(--radius) + 8px);padding:1.35rem 1.35rem 1.55rem;margin-bottom:2rem;border:1px solid var(--line);position:relative;overflow:hidden}.work-band:last-child{margin-bottom:0}.work-band:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:3px 0 0 3px}.work-band--github:before{background:#24292f}.work-band--github{background:linear-gradient(165deg,#f4f6f8,#eef1f4 55%,#e9eef3);border-color:#c9d4df}.work-band--product:before{background:var(--accent)}.work-band--product{background:linear-gradient(165deg,var(--accent-soft) 0%,#e4ebe0 48%,#eef3ea 100%);border-color:color-mix(in srgb,var(--accent) 24%,var(--line))}.work-band--studio:before{background:color-mix(in srgb,var(--warm) 75%,#6b5344 25%)}.work-band--studio{background:linear-gradient(165deg,#faf7f3,#f4ebe3 45%,#efe4d9);border-color:color-mix(in srgb,var(--warm) 30%,var(--line))}.work-band__header{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.35rem}.work-band__icon-badge{flex-shrink:0;width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #1f1d1a12}.work-band__icon-badge--github{background:#24292f;color:#fff}.work-band__icon-badge--product{background:#fff;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 28%,var(--line))}.work-band__icon-badge--studio{background:#fff;color:#6b5344;border:1px solid color-mix(in srgb,var(--warm) 38%,var(--line))}.work-band__titles{min-width:0}.work-band__title{font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin:0 0 .35rem;letter-spacing:-.02em;color:var(--ink)}.work-band__lede{margin:0;font-size:.94rem;color:var(--ink-muted);font-weight:300;line-height:1.5;max-width:54ch}.work-band .project-card{background:color-mix(in srgb,#fff 92%,transparent);box-shadow:0 1px #1f1d1a08}.work-band--github .project-card__link{color:#1f2328}.work-band--github .project-card__link:hover{color:#0969da}.work-legend{font-weight:600}.work-legend--github{color:#24292f}.work-legend--product{color:var(--accent)}.work-legend--studio{color:#6b5344}.project-grid{display:grid;gap:1rem}@media(min-width:700px){.project-grid{grid-template-columns:repeat(2,1fr)}}.project-card{padding:1.35rem 1.5rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;min-height:100%}.project-card--placeholder{border-style:dashed;background:transparent}.project-card h3{font-family:var(--font-display);font-size:1.05rem;margin:0 0 .5rem}.project-card p{flex:1;margin:0 0 1rem;font-size:.95rem;color:var(--ink-muted);font-weight:300}.project-card__meta{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem}.tag{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:.2rem .45rem;border-radius:4px;background:var(--paper-2);color:var(--ink-muted)}.project-card__link{font-size:.9rem;font-weight:500;margin-top:auto}.rec-carousel{position:relative;margin:0 -.5rem;padding:.25rem 0 0}.rec-carousel__scroller{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-padding-inline:max(1rem,calc(50vw - min(45vw,200px)));padding:2rem max(1rem,calc(50% - min(45vw,200px))) 2.75rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.rec-carousel__scroller:focus-visible{outline:2px solid var(--accent);outline-offset:4px}.rec-carousel__card{flex:0 0 min(88vw,400px);max-width:400px;scroll-snap-align:center;margin:0;transition:transform .4s cubic-bezier(.25,.46,.45,.94),box-shadow .4s ease,opacity .35s ease,border-color .35s ease;transform:scale(.94);opacity:.82;z-index:1}.rec-carousel__card--active{transform:scale(1.05);opacity:1;box-shadow:0 4px 6px #1f1d1a0a,0 18px 48px #1f1d1a1a;z-index:2;border-color:color-mix(in srgb,var(--accent) 28%,var(--line))}.rec-carousel__card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.rec-carousel__placeholder-text{margin:0 0 1rem;padding-top:.5rem;font-size:.95rem;color:var(--ink-muted);font-weight:300;line-height:1.55}.rec-carousel__placeholder-text a{font-weight:500}.rec-carousel__nav{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.25rem .5rem .5rem}.rec-carousel__dots{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center;max-width:min(100%,320px)}.rec-carousel__dot{width:8px;height:8px;border-radius:50%;border:none;padding:0;background:var(--line);cursor:pointer;transition:transform .15s ease,background .15s ease}.rec-carousel__dot.is-active{background:var(--accent);transform:scale(1.2)}.rec-carousel__dot:hover{background:var(--ink-muted)}.rec-carousel__dot.is-active:hover{background:var(--accent)}.rec-carousel__arrow{font-size:1.35rem;line-height:1;width:2.5rem;height:2.5rem;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;transition:opacity .15s ease,border-color .15s ease,background .15s ease;flex-shrink:0}.rec-carousel__arrow:hover:not(:disabled){border-color:var(--ink-muted);background:var(--paper-2)}.rec-carousel__arrow:disabled{opacity:.35;cursor:not-allowed}.section-read-more{display:flex;justify-content:center;margin-top:1.75rem}.quote-card{padding:1.5rem;background:#fff;border-radius:var(--radius);border:1px solid var(--line);position:relative}.quote-card:before{content:"“";font-family:var(--font-display);font-size:3rem;line-height:1;color:var(--accent-soft);position:absolute;top:.5rem;left:1rem}.quote-card--empty:before{display:none}.quote-card blockquote{margin:0 0 1rem;padding-top:.5rem;position:relative;font-style:italic;color:var(--ink-muted);font-weight:300;font-size:.98rem}.quote-card figcaption{font-size:.88rem}.quote-card .author{font-weight:600;color:var(--ink);text-decoration:none}.quote-card .author:hover{text-decoration:underline}.quote-card .relation{color:var(--ink-muted)}.contact-panel{padding:2.5rem 2rem;background:linear-gradient(145deg,var(--accent-soft) 0%,var(--paper-2) 100%);border-radius:calc(var(--radius) + 4px);border:1px solid var(--line);text-align:center}.contact-panel h2{font-family:var(--font-display);font-size:1.5rem;margin:0 0 .5rem}.contact-panel p{margin:0 0 1.5rem;color:var(--ink-muted);font-weight:300}.contact-links{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.site-footer{padding:2rem 1.5rem 3rem;text-align:center;font-size:.85rem;color:var(--ink-muted)}.site-footer a{color:var(--ink-muted)}
