:root{--hero-image: url(./MainPageImage.B3bkblFS.jpeg);--bg:#08130f;--panel:#0e1f19;--text:#e7f3ec;--muted:#9ab3a7;--brand:#2fbf71;--brand-strong:#23a55a;--border:#1a2d25;--shadow:0 8px 24px rgba(0,0,0,.35);--radius:16px;--maxw:72rem;--heather:#c9cdd3;--heather-700:#9aa1aa;--accent-white:#fff;--accent-black:#000;--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;--font-display: "Space Grotesk", "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial}@media (prefers-color-scheme:light){:root{--bg:#f4fbf6;--panel:#fff;--text:#0f1a16;--muted:#4c5f57;--border:#d9e8df;--shadow:0 10px 30px rgba(0,0,0,.08);--heather:#bfc4cb;--heather-700:#8f97a2}}@media (prefers-color-scheme:dark){:root{--bg:#08130f;--panel:#0e1f19;--text:#e7f3ec;--muted:#9aa1aa;--brand:#2fbf71;--brand-strong:#23a55a;--border:#1a2d25;--heather:#c9cdd3;--heather-700:#9aa1aa}}*{box-sizing:border-box}html,body{min-height:100%}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-variation-settings:"slnt" 0,"opsz" 14;font-feature-settings:"liga","kern","ss01","cv01";background:var(--bg)}body{margin:0;font-family:var(--font-sans);font-weight:400;color:var(--accent-white);background:radial-gradient(1200px 600px at 10% -10%,rgba(52,211,153,.12),transparent 60%),radial-gradient(900px 500px at 110% 20%,rgba(16,185,129,.1),transparent 60%),var(--bg);display:flex;flex-direction:column;min-height:100dvh;min-height:100vh}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--accent-white)}h1{font-size:clamp(2.1rem,4.5vw,3.2rem)}h2{font-size:clamp(1.5rem,3vw,2.2rem)}h3{font-size:clamp(1.15rem,2vw,1.5rem)}.container{width:100%;max-width:var(--maxw);padding:0 1rem;margin-inline:auto}a{color:var(--brand);text-decoration:none}a:hover{color:var(--brand-strong);text-decoration:underline}a:focus-visible{outline:2px solid var(--brand);outline-offset:2px}button,.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border-radius:12px;cursor:pointer;border:1px solid var(--border);background:linear-gradient(180deg,var(--panel),color-mix(in oklab,var(--panel),black 5%));color:var(--text);box-shadow:0 8px 24px #00000059,inset 0 1px #ffffff0f;transition:transform .08s ease,border-color .15s ease,background .15s ease}button:hover,.btn:hover{transform:translateY(-1px);border-color:color-mix(in oklab,var(--heather),var(--brand) 35%)}.boldWord{font-weight:700}.italicWord{font-style:italic}.underline{text-decoration:underline;text-decoration-thickness:.12em;text-underline-offset:.2em}main{flex:1 0 auto}#main-page{display:flex;flex-wrap:wrap;gap:1rem;align-items:stretch}#main-page{background-image:url(./MainPageImage.B3bkblFS.jpeg);min-height:85vh;width:100%;background-size:cover;background-position:center;background-repeat:no-repeat;border-radius:var(--radius);overflow:hidden;background-clip:padding-box}#intro{flex:1 1 clamp(22rem,33vw,36rem);height:21rem;max-width:clamp(22rem,33vw,36rem);padding:clamp(1rem,2.5vw,1.5rem);border:1px solid var(--border);border-radius:var(--radius);margin:1.5rem 0;background:linear-gradient(90deg,color-mix(in oklab,var(--panel),var(--accent-white) 2%),color-mix(in oklab,var(--panel),var(--accent-black) 3%));opacity:85%;box-shadow:var(--shadow);-webkit-backdrop-filter:saturate(120%);backdrop-filter:saturate(120%)}#intro h1{margin:0 0 .5rem;font-weight:800;letter-spacing:-.02em;line-height:1.1}#intro p{margin:.4rem 0;max-width:70ch}@media (max-width: 640px){#intro{max-width:100%}}@media (max-width: 900px){#intro{flex:1 1 100%;max-width:100%;margin:0 0 1rem}}#resume-header,#resume-profile,#resume-tech-skills,#resume-app-experience,#resume-work-experience,#resume-education{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:clamp(1rem,2.5vw,1.5rem);box-shadow:var(--shadow)}#resume-profile,#resume-tech-skills,#resume-app-experience,#resume-work-experience,#resume-education{margin-block:1rem}#resume-profile p,#resume-tech-skills p,#resume-app-experience p,#resume-work-experience p,#resume-education p{margin:.25rem 0 .5rem}#resume-app-experience ul,#resume-work-experience ul{margin:.5rem 0 0;padding-left:1.25rem}#resume-app-experience li,#resume-work-experience li{margin:.35rem 0;padding-left:.15rem}#resume-profile h2,#resume-tech-skills h2,#resume-app-experience h2,#resume-work-experience h2,#resume-education h2{margin:0 0 .5rem;font-size:clamp(1.05rem,1.5vw,1.2rem);letter-spacing:.2px}hr{font-size:clamp(1.25rem,2.6vw,1.75rem);line-height:1.05;margin:1.25rem 0;border:0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in oklab,var(--heather-700),var(--border) 35%),transparent)}#resume-header{margin-top:2rem;display:grid;align-items:start}#resume-header h1{margin:0 0 .2rem;font-size:clamp(1.4rem,3.2vw,2rem);line-height:1.1;letter-spacing:.2px}#resume-header p{margin:0;color:var(--muted)}#resume-contacts{display:flex;flex-wrap:wrap;margin-top:.1rem;gap:.4rem .6rem}#resume-image-download{display:flex;gap:.4rem;margin-top:.1rem}#resume-image-download img{display:block;max-width:120px;max-height:200px;height:auto;border-radius:12px;box-shadow:var(--shadow)}#resume-image-download a[download]{display:inline-flex}#resume-contacts p{margin:0;padding:0}#resume-header a[download]{justify-self:start;margin-top:.4rem;border-radius:999px;padding:.55rem .9rem;border:1px solid var(--border);background:color-mix(in oklab,var(--panel),black 3%);text-decoration:none}#resume-header a[download]:hover{border-color:color-mix(in oklab,var(--brand),white 15%)}@media (min-width:720px){#resume-header{grid-template-columns:1fr auto;grid-template-areas:"name download""meta download""links download"}#resume-header h1{grid-area:name}#resume-header p:nth-of-type(1),#resume-header p:nth-of-type(2){grid-area:meta}#resume-contacts{grid-area:links}#resume-header a[download]{grid-area:download;align-self:start}}#resume-tech-skills p{display:flex;flex-wrap:wrap;gap:.5rem .6rem;align-items:baseline;border:1px dashed var(--border);border-radius:12px;background:color-mix(in oklab,var(--panel),black 2%)}#resume-tech-skills .boldWord{min-width:12ch;color:var(--text)}#resume-app-experience p>a,#resume-work-experience p>a{margin-left:.5rem;font-weight:600}#resume-app-experience p span.boldWord,#resume-work-experience p span.boldWord{font-weight:800}#resume-app-experience li::marker,#resume-work-experience li::marker{content:"– ";color:var(--brand)}@media (min-width:1100px){#resume-profile p,#resume-app-experience ul,#resume-work-experience ul{max-width:85ch}}header.site{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid color-mix(in oklab,var(--heather-700),var(--border) 45%);background:linear-gradient(180deg,color-mix(in oklab,var(--panel),var(--accent-black) 6%),transparent),color-mix(in oklab,var(--bg),transparent 70%)}.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0}.nav a.brand{font-weight:700;letter-spacing:.2px;color:var(--text);text-decoration:none}nav ul{list-style:none;display:flex;gap:.75rem;padding:0;margin:0}nav a.link{padding:.55rem .8rem;border-radius:12px;color:var(--text);border:1px solid transparent;box-shadow:inset 0 1px #ffffff0a}nav a.link[aria-current=page],nav a.link:hover{border-color:color-mix(in oklab,var(--heather-700),var(--border) 30%);background:linear-gradient(180deg,color-mix(in oklab,var(--panel),var(--accent-white) 3%),color-mix(in oklab,var(--panel),var(--accent-black) 4%))}footer.site{border-top:1px solid var(--border);padding:2rem 0;color:var(--muted)}.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}.primary-toggle{display:none}@media (max-width:500px){.primary-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border);border-radius:12px;background:color-mix(in oklab,var(--panel),black 3%)}.primary-toggle .bars{position:relative;width:18px;height:2px;background:var(--text)}.primary-toggle .bars:before,.primary-toggle .bars:after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--text)}.primary-toggle .bars:before{top:-6px}.primary-toggle .bars:after{top:6px}.nav{position:relative}nav ul.primary-desktop{position:absolute;left:0;right:0;top:100%;margin-top:.5rem;padding:.5rem;border:1px solid var(--border);border-radius:12px;background:var(--panel);display:none;flex-direction:column;gap:.25rem}nav ul.primary-desktop.open{display:block}nav ul.primary-desktop li+li{margin-top:.25rem}}@media (min-width:501px){nav ul.primary-desktop{display:flex;gap:.75rem;position:static;margin:0;padding:0;border:0;background:transparent}}@media print{body{background:#fff;color:#000}#resume-header,#resume-profile,#resume-tech-skills,#resume-app-experience,#resume-work-experience,#resume-education{box-shadow:none;border-color:#ddd;background:#fff;break-inside:avoid}a{color:#0645ad;text-decoration:underline}#resume-header a[download]{display:none}hr{background:#ddd}}#blog-landing{padding:2.5rem 0}#blog-landing h1{margin:0 0 1rem;font-size:clamp(1.6rem,2.5vw,2.2rem);line-height:1.15}#blog-landing .post-list{margin:0 0 1rem;padding:1rem 1.2rem;position:relative;display:block;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);transform:translateZ(0);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}#blog-landing .post-list:hover{transform:scale(1.015);box-shadow:0 12px 36px #0006,inset 0 1px #ffffff0f;border-color:color-mix(in oklab,var(--heather),var(--brand) 30%)}#blog-landing .post-list h2{margin:0 0 .25rem;font-size:clamp(1.1rem,1.6vw,1.35rem);line-height:1.25}#blog-landing .muted{margin:0 0 .4rem;color:color-mix(in oklab,var(--muted),var(--heather-700) 40%);font-size:.95rem}#blog-landing a.link{color:var(--brand);text-decoration:none;background-image:linear-gradient(currentColor,currentColor);background-size:0% 2px;background-repeat:no-repeat;background-position:0 100%;transition:color .18s ease,background-size .18s ease}#blog-landing a.link:hover,#blog-landing .post-list:hover a.link{color:var(--brand-strong);background-size:100% 2px}@media (prefers-reduced-motion:reduce){#blog-landing .post-list,#blog-landing a.link{transition:none}}#resume-header,#resume-profile,#resume-tech-skills,#resume-app-experience,#resume-work-experience,#resume-education,#blog-landing .post-list{border-color:color-mix(in oklab,var(--border),var(--heather-700) 35%);box-shadow:0 8px 24px #00000059,inset 0 1px #ffffff0d;background:linear-gradient(180deg,color-mix(in oklab,var(--panel),var(--accent-white) 2%),color-mix(in oklab,var(--panel),var(--accent-black) 3%))}.card{display:flex;flex-direction:column;gap:.6rem;background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform .15s ease,order-color .15s ease}.card:hover{transform:translateY(-2px);border-color:var(--brand)}.media{display:block;aspect-ratio:4/3;overflow:hidden}.media img{width:100%;height:100%;object-fit:cover;display:block}.card-body{display:flex;flex-direction:column;gap:.5rem;padding:.9rem}.card-body h1{font-size:1.05rem;line-height:1.25;margin:0}.card-body h3{font-size:.95rem;line-height:1.35;margin:0}.link{color:inherit;text-decoration:none}.link:hover{color:var(--brand)}.muted{color:var(--muted)}.card-body ul{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;padding:0;margin:.25rem 0 0}.card-body li{font-size:.8rem;line-height:1;padding:.25rem .5rem;border:1px solid var(--border);border-radius:999px;background:var(--panel);color:var(--text)}.footer{margin-top:.25rem}.tag{font-size:.78rem;padding:.2rem .55rem;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text)}#splide-carousel{padding:5rem 0}@media (max-width:420px){.card{width:240px}}
