:root{--ink:#F1F5F9;--muted:#94A3B8;--paper:#0A1020;--panel:#111A2E;--panel-strong:#18243D;--line:#253554;--accent:#38BDF8;--accent-hover:#7DD3FC;--shadow:0 20px 60px rgba(2,6,23,0.34);--shadow-soft:0 10px 30px rgba(2,6,23,0.24)}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:96px}body{min-width:320px;min-height:100vh;margin:0;color:var(--ink);background:radial-gradient(circle at 12% 0,rgba(56,189,248,.12),transparent 28%),radial-gradient(circle at 86% 12%,rgba(125,211,252,.08),transparent 30%),linear-gradient(180deg,rgba(24,36,61,.36),transparent 360px),var(--paper);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none;text-underline-offset:.2em}a:focus-visible,a:hover{text-decoration:underline}:focus-visible{outline:3px solid rgba(56,189,248,.56);outline-offset:3px}img{display:block;max-width:100%}::selection{background:var(--accent);color:var(--paper)}.site-shell{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:18px 0 64px}.topbar{position:-webkit-sticky;position:sticky;top:12px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:48px;margin-bottom:36px;padding:8px;border:1px solid var(--line);border-radius:14px;background:rgba(17,26,46,.9);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-soft)}.topbar.is-scrolled{width:max-content;margin-right:auto;padding:8px}.brand,.menu-toggle{display:inline-grid;width:44px;height:44px;place-items:center;border:1px solid var(--line);border-radius:12px;background:var(--panel-strong);box-shadow:inset 0 1px 0 rgba(241,245,249,.04)}.brand{font-weight:850}.brand img{width:28px;height:28px}.menu-toggle{display:none;padding:0;color:var(--ink);cursor:pointer}.menu-toggle span{grid-area:1/1;width:24px;height:4px;border-radius:999px;background-image:url(/favicon.ico);background-position:50%;background-size:28px 28px;box-shadow:0 0 0 1px rgba(56,189,248,.24),0 0 0 3px rgba(24,36,61,.76);transition:transform .16s ease,opacity .16s ease}.menu-toggle span:first-child{background-position:center calc(50% - 8px);transform:translateY(-8px)}.menu-toggle span:last-child{background-position:center calc(50% + 8px);transform:translateY(8px)}.menu-toggle:focus-visible,.menu-toggle:hover{border-color:var(--accent);background:rgba(56,189,248,.12)}.contact-actions,.hero-actions,.nav-links,.project-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.button,.hero-actions.centered,.nav-links a{justify-content:center}.button,.nav-links a{min-height:40px;display:inline-flex;align-items:center;border-radius:8px;font-size:.95rem;font-weight:750;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.nav-links a{padding:0 12px;color:var(--muted)}.nav-links a:focus-visible,.nav-links a:hover{color:var(--ink);background:rgba(56,189,248,.1);text-decoration:none}.topbar.is-scrolled .brand{display:none}.topbar.is-scrolled .menu-toggle{display:grid}.topbar.is-scrolled.is-menu-open{width:100%}.topbar.is-scrolled.is-menu-open .nav-links a{justify-content:center;width:auto}.topbar.is-scrolled .nav-links{position:absolute;top:calc(100% + 8px);right:auto;left:0;width:min(260px,calc(100vw - 32px));display:none;padding:8px;border:1px solid var(--line);border-radius:14px;background:rgba(17,26,46,.96);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.topbar.is-scrolled .nav-links.is-open{display:grid}.topbar.is-scrolled.is-menu-open .nav-links{position:static;width:auto;display:flex;padding:0;border:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.topbar.is-scrolled .nav-links a{justify-content:flex-start;width:100%;padding:0 12px}.contact,.hero-card,.project-card,.resume-frame,.service-grid article,.skill-group-grid article,.summary-strip article,.text-panel{border:1px solid var(--line);border-radius:16px;background:rgba(17,26,46,.92);box-shadow:var(--shadow)}.hero-card{position:relative;overflow:hidden;padding:clamp(28px,6vw,72px);text-align:center;background:linear-gradient(145deg,rgba(56,189,248,.11),transparent 42%),linear-gradient(180deg,rgba(24,36,61,.92),rgba(17,26,46,.94))}.hero-card:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;box-shadow:inset 0 1px 0 rgba(241,245,249,.06)}.avatar{width:132px;height:132px;margin:0 auto 24px;border-radius:50%;object-fit:cover;border:2px solid rgba(56,189,248,.42);box-shadow:0 0 0 8px rgba(56,189,248,.06)}.eyebrow,.project-type{margin:0 0 12px;color:var(--accent);font-size:.78rem;font-weight:850;letter-spacing:.08em;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1,h2,h3{color:var(--ink);letter-spacing:0}h1{max-width:860px;margin:0 auto 20px;font-size:clamp(3rem,8vw,6.15rem);line-height:.98}h2{margin-bottom:12px;font-size:clamp(2rem,4vw,3.25rem);line-height:1.06}h3{margin-bottom:10px;font-size:1.18rem}.contact p,.intro,.section-header p{color:var(--muted);line-height:1.65}.intro{max-width:720px;margin:0 auto 28px;font-size:clamp(1.12rem,2vw,1.36rem)}.button{padding:0 18px;border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(241,245,249,.04)}.button.primary{border-color:rgba(56,189,248,.68);background:var(--accent);color:var(--paper);box-shadow:0 12px 28px rgba(56,189,248,.18)}.button.secondary{background:var(--panel-strong);color:var(--ink)}.button:focus-visible,.button:hover{text-decoration:none;transform:translateY(-1px)}.button.primary:focus-visible,.button.primary:hover{border-color:var(--accent-hover);background:var(--accent-hover)}.button.secondary:focus-visible,.button.secondary:hover{border-color:var(--accent);background:rgba(56,189,248,.1)}.summary-strip{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin:24px 0 72px}.summary-strip article{padding:22px;background:var(--panel)}.summary-strip span{display:block;margin-bottom:8px;color:var(--accent);font-size:.78rem;font-weight:850;text-transform:uppercase}.summary-strip p{margin-bottom:0;color:var(--muted);line-height:1.55}.content-section{padding:52px 0}.section-header{max-width:760px;margin-bottom:24px}.centered-header{margin-right:auto;margin-left:auto;text-align:center}.about-section{display:grid;justify-items:center}.about-panel{width:min(100%,920px);padding:clamp(26px,4vw,42px);border:1px solid var(--line);border-radius:16px;background:linear-gradient(135deg,rgba(56,189,248,.08),transparent 44%),var(--panel);box-shadow:var(--shadow)}.about-panel p{max-width:760px;margin-right:auto;margin-left:auto;color:var(--muted);font-size:clamp(1.04rem,1.4vw,1.16rem);line-height:1.78}.about-panel p:last-of-type{margin-bottom:0}.about-highlights{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:28px;padding-top:24px;border-top:1px solid var(--line)}.about-highlights span{min-height:36px;display:inline-flex;align-items:center;padding:0 12px;border:1px solid rgba(56,189,248,.32);border-radius:999px;background:rgba(56,189,248,.08);color:var(--ink);font-size:.92rem;font-weight:750}.service-grid,.skill-group-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:18px;gap:18px}.service-grid article,.skill-group-grid article{padding:22px;transition:border-color .18s ease,background .18s ease,transform .18s ease,box-shadow .18s ease}.project-card:hover,.service-grid article:hover,.skill-group-grid article:hover{border-color:rgba(56,189,248,.42);background:var(--panel-strong);box-shadow:0 22px 58px rgba(2,6,23,.36);transform:translateY(-2px)}.project-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:20px;gap:20px}.project-card{overflow:hidden;transition:border-color .18s ease,background .18s ease,transform .18s ease,box-shadow .18s ease}.project-image{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;border-bottom:1px solid var(--line);background:var(--panel-strong)}.project-body,.service-grid article,.skill-group-grid article{padding:24px}.project-body p,.service-grid p,.skill-group-grid p{color:var(--muted);line-height:1.62}.project-actions a{min-height:34px;display:inline-flex;align-items:center;border-bottom:2px solid rgba(56,189,248,.7);color:var(--accent);font-weight:800}.project-actions a:focus-visible,.project-actions a:hover{border-color:var(--accent-hover);color:var(--accent-hover);text-decoration:none}.skill-group-grid ul{display:grid;grid-gap:8px;gap:8px;margin:0;padding:0;list-style:none}.skill-group-grid li{color:var(--muted);line-height:1.4}.skill-group-grid li:before{content:"";width:6px;height:6px;display:inline-block;margin-right:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px rgba(56,189,248,.34);vertical-align:.1em}.pill-list{display:flex;flex-wrap:wrap;gap:10px}.pill-list span{min-height:38px;display:inline-flex;align-items:center;padding:0 14px;border:1px solid var(--line);border-radius:999px;background:var(--panel-strong);color:var(--ink);font-weight:700;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease}.pill-list span:hover{border-color:rgba(56,189,248,.48);background:rgba(56,189,248,.1);color:var(--accent-hover);transform:translateY(-1px)}.contact{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);align-items:stretch;grid-gap:28px;gap:28px;margin-top:48px;padding:clamp(24px,4vw,40px);background:linear-gradient(135deg,rgba(56,189,248,.1),transparent 42%),var(--panel)}.contact-copy{display:flex;flex-direction:column;justify-content:center}.contact h2{max-width:760px;font-size:clamp(2rem,4vw,3.4rem)}.contact p{max-width:620px}.contact-panel{display:grid;grid-gap:10px;gap:10px;padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--panel-strong)}.contact-method{display:grid;grid-gap:4px;gap:4px;padding:14px;border:1px solid var(--line);border-radius:12px;background:rgba(17,26,46,.76);color:var(--ink);font-weight:750;overflow-wrap:anywhere;transition:border-color .16s ease,background .16s ease,transform .16s ease}.contact-method:focus-visible,.contact-method:hover{border-color:rgba(56,189,248,.5);background:rgba(56,189,248,.08);text-decoration:none;transform:translateY(-1px)}.contact-method span{color:var(--accent);font-size:.74rem;font-weight:850;letter-spacing:.08em;text-transform:uppercase}.primary-method{border-color:rgba(56,189,248,.5)}.contact-actions{margin-top:4px}.resume-section{min-height:calc(100vh - 128px);display:grid;grid-template-rows:auto minmax(0,1fr);grid-gap:18px;gap:18px;padding-top:8px}.resume-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding:18px;border:1px solid var(--line);border-radius:16px;background:var(--panel);box-shadow:var(--shadow)}.resume-header h1{max-width:none;margin:0;font-size:clamp(2rem,4vw,3.4rem);text-align:left}.resume-frame{overflow:hidden;min-height:880px;height:calc(100vh - 236px);border-color:var(--line)}.resume-frame iframe{width:100%;height:100%;border:0;background:white}.back-to-top{position:fixed;right:22px;bottom:22px;z-index:30;width:46px;height:46px;display:inline-grid;place-items:center;border:1px solid var(--line);border-radius:12px;background:var(--accent);color:var(--paper);box-shadow:var(--shadow);font-size:1.4rem;font-weight:850;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .16s ease,transform .16s ease}.back-to-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top:focus-visible,.back-to-top:hover{background:var(--accent-hover);text-decoration:none;transform:translateY(-2px)}.not-found{min-height:100vh;display:grid;place-items:center;padding:24px;text-align:center}.not-found h1{margin-bottom:16px}@media (max-width:900px){.contact,.project-grid,.service-grid,.skill-group-grid,.summary-strip{grid-template-columns:1fr}.summary-strip{margin-bottom:48px}}@media (max-width:560px){.site-shell{width:min(100% - 24px,1120px);padding-top:8px}.resume-header{align-items:flex-start;flex-direction:column}.topbar{top:8px;width:100%;align-items:center;gap:8px;margin-bottom:20px}.topbar.is-scrolled,.topbar.is-scrolled.is-menu-open{width:max-content}.menu-toggle{display:grid}.nav-links{position:absolute;top:calc(100% + 8px);right:0;left:0;width:100%;display:none;gap:4px;padding:8px;border:1px solid var(--line);border-radius:14px;background:rgba(17,26,46,.97);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.nav-links.is-open{display:grid}.nav-links a{justify-content:flex-start;width:100%;padding:0 12px}.topbar.is-scrolled .nav-links{top:calc(100% + 8px);right:auto;left:0;display:none}.topbar.is-scrolled .nav-links,.topbar.is-scrolled.is-menu-open .nav-links{position:absolute;width:min(260px,calc(100vw - 24px));padding:8px;border:1px solid var(--line);background:rgba(17,26,46,.97);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.topbar.is-scrolled.is-menu-open .nav-links{display:grid}.topbar.is-scrolled.is-menu-open .nav-links a{justify-content:flex-start;width:100%}.button,.contact-actions,.hero-actions{width:100%}.resume-frame{min-height:680px;height:calc(100vh - 260px)}.back-to-top{right:14px;bottom:14px}}