:root{--ink: #0f1725;--muted: #4f5b6c;--panel: #ffffff;--line: #dfe7f1;--shadow: 0 18px 45px rgba(15, 23, 37, .13);--navy: #101a29;--brand: #1a2035;--lightblue: #2267b2;--blue: #386c8f;--orange: #df7a2b;--radius: 18px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--ink);background:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{min-width:320px;min-height:100%;background:#f8fafc}body{min-width:320px;min-height:100vh;margin:0;background:radial-gradient(circle at 18% 8%,rgba(34,103,178,.15),transparent 28rem),radial-gradient(circle at 80% 35%,rgba(26,32,53,.12),transparent 30rem),linear-gradient(180deg,#fff,#f8fafc 82%)}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}.page-shell{min-height:100vh;display:flex;flex-direction:column}.site-header{width:100%;min-height:66px;padding:0 clamp(1.25rem,5vw,4.25rem);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#0c1624,#111b2a);color:#fff;box-shadow:0 8px 26px #0f172533}.brand{display:inline-flex;align-items:center;gap:.65rem;font-weight:800;letter-spacing:-.04em}.brand-mark{width:clamp(36px,5vw,44px);height:clamp(36px,5vw,44px);border-radius:50%;object-fit:cover;object-position:center;border:2px solid rgba(255,255,255,.65);box-shadow:0 6px 16px #00000038}.brand-name{font-size:clamp(1.15rem,2.2vw,1.45rem)}.nav-links{display:flex;align-items:center;gap:clamp(1rem,3vw,2rem)}.nav-link{position:relative;display:inline-flex;align-items:center;gap:.45rem;padding:.6rem 0;font-size:.92rem;font-weight:650;opacity:.92;transition:opacity .18s ease,color .18s ease}.nav-link svg{width:1rem;height:1rem}.nav-link:hover,.nav-link:focus-visible{opacity:1;color:#77c7f0;outline:none}.nav-link-active:after{position:absolute;content:"";left:0;right:0;bottom:.5rem;height:3px;border-radius:999px;background:#4db1e7}.hero{padding:clamp(1rem,8vw,2rem) 1.25rem 2.25rem}.hero-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:clamp(1.25rem,4vw,2.25rem)}.hero-copy{max-width:760px;text-align:center}.profile-image{flex:0 0 auto}.photo-cutout{position:relative;isolation:isolate;overflow:visible;width:320px;aspect-ratio:.72;padding:18px;border-radius:999px;background:var(--background)}.photo-cutout:before{content:"";position:absolute;inset:12px;z-index:2;pointer-events:none;border-radius:inherit}.photo-frame{position:relative;z-index:1;width:100%;height:100%;overflow:hidden;background:var(--background);transform:translateY(5px) scale(.985)}.photo-frame img,.photo-frame-image{display:block;width:100%;height:100%;object-fit:cover}.photo-cutout-tall{width:min(100%,250px);aspect-ratio:3 / 4.4;border-radius:44% 56% 40% 60%/58% 36% 64% 42%}.photo-frame-tall{width:100%;height:100%;aspect-ratio:auto;border-radius:34px 22px 42px 24px}.photo-frame-curved,.photo-cutout-tall{border-radius:44% 56% 40% 60%/58% 36% 64% 42%}.photo-cutout-tall:before{border-radius:44% 56% 40% 60%/58% 36% 64% 42%}.photo-frame-feature{width:min(100%,420px);aspect-ratio:5 / 4;border-radius:38px 14px 42px 22px}.photo-frame-feature-top{width:min(100%,760px);aspect-ratio:21 / 9}.hero h1{margin:0;font-size:clamp(3rem,8vw,5.3rem);line-height:.96;letter-spacing:-.065em;color:#0d1828}.subtitle{margin:1.2rem 0 0;color:#313d4c;font-size:clamp(1.1rem,2vw,1.45rem);line-height:1.4}.divider{height:4px;margin:2rem 0 1.5rem;display:block;border-radius:999px;background:linear-gradient(90deg,#2267b2,#57b5e8)}.intro{max-width:690px;margin:0 auto;color:#1c2736;font-size:clamp(1.05rem,2vw,1.35rem);line-height:1.48}.hub-grid{width:min(100% - 2.5rem,1280px);margin:2.1rem auto 2.7rem;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.25rem,3vw,2.7rem)}.hub-card{min-height:390px;padding:clamp(1.8rem,4vw,2.5rem);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;text-align:center;background:#ffffffd1;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hub-card-lightblue{--accent: var(--lightblue);--accent-soft: rgba(34, 103, 178, .13);--accent-strong: #155da5;background:linear-gradient(145deg,#ffffffed,#eff7ffcc)}.hub-card-blue{--accent: var(--blue);--accent-soft: rgba(56, 108, 143, .16);--accent-strong: #2f5b79;background:linear-gradient(145deg,#ffffffed,#e8f2f7d1)}.hub-card-brand{--accent: var(--brand);--accent-soft: rgba(26, 32, 53, .12);--accent-strong: #1a2035;background:linear-gradient(145deg,#fffffff0,#f4f6fcd9)}.icon-wrap{width:92px;height:92px;border:1px solid color-mix(in srgb,var(--accent),transparent 72%);border-radius:999px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}.icon-wrap svg{width:48px;height:48px}.hub-card h2{margin:1.5rem 0 0;color:var(--accent);font-size:clamp(1.35rem,2.5vw,1.65rem);letter-spacing:-.035em}.hub-card p,.hub-card-description{margin:1rem 0 0;max-width:315px;color:#1f2937;font-size:1.03rem;line-height:1.52}.card-button{width:min(100%,290px);margin-top:1.5rem;padding:.9rem 1.25rem;border-radius:7px;display:inline-flex;justify-content:center;align-items:center;gap:.8rem;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-strong));font-size:1.08rem;font-weight:800;box-shadow:0 12px 25px color-mix(in srgb,var(--accent),transparent 72%);transition:transform .18s ease,box-shadow .18s ease}.card-button svg{width:1.35rem;height:1.35rem}.card-button:hover,.card-button:focus-visible{transform:translateY(-2px);box-shadow:0 16px 34px color-mix(in srgb,var(--accent),transparent 62%);outline:none}.site-footer{margin-top:auto;padding:1.2rem 1.25rem 1.5rem;border-top:1px solid #e3e8ef;text-align:center;background:#ffffffb8}.site-footer p{margin:0 0 .8rem;color:#111827;font-weight:750}.social-links{display:flex;justify-content:center;align-items:center;gap:clamp(.9rem,3vw,1.2rem);margin-bottom:1.3rem}.social-link{width:34px;height:34px;display:grid;place-items:center;color:#0e1725;border-radius:999px;transition:color .18s ease,transform .18s ease,background .18s ease}.social-link svg{width:1.65rem;height:1.65rem}.social-link:hover,.social-link:focus-visible{color:#2267b2;background:#2267b214;transform:translateY(-2px);outline:none}.site-footer small{color:#667085}.site-footer p{color:#2267b2}.tech-stack{width:min(100% - 2.5rem,1080px);margin:0 auto 2.5rem;padding:clamp(1.5rem,4vw,2.3rem);text-align:center}.tech-stack-label{margin:0;font-weight:800;color:#101a29;letter-spacing:.04em;text-transform:uppercase}.tech-stack h2{margin:.55rem 0 0;font-size:clamp(1.4rem,2.2vw,1.9rem);color:#101a29}.tech-stack-copy{margin:.85rem auto 0;max-width:700px;color:#334155;line-height:1.5}.tech-stack-logos{margin:1.5rem 0 0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.9rem}.tech-logo-card{padding:.9rem .6rem;display:flex;flex-direction:column;align-items:center;gap:.55rem}.tech-logo-mark{width:70px;height:70px;border-radius:999px;display:grid;place-items:center;color:#2267b2;font-weight:800;font-size:2rem}.tech-logo-name{font-size:.96rem;font-weight:700;color:#1f2a37}@media(max-width:940px){.site-header{padding-top:1rem;padding-bottom:1rem}.brand{padding-top:.5rem}.hub-grid{grid-template-columns:1fr;max-width:560px}.hub-card{min-height:350px}.hero-inner{flex-direction:column;text-align:center}.hero-copy{text-align:center}.divider{margin-right:auto;margin-left:auto}}@media(max-width:560px){.site-header{align-items:flex-start}.hero{padding-top:2.5rem}.hub-grid{width:min(100% - 1.5rem,1280px)}.hub-card{padding:1.5rem}.social-links{flex-wrap:wrap;column-gap:clamp(2rem,3vw,1.6rem);row-gap:clamp(.1rem,3vw,.6rem)}}
