:root{color-scheme:light;--ink: #172331;--muted-ink: #627084;--panel: #ffffff;--soft-panel: #f3f9ff;--line: #d8eaf8;--accent: #4aa3df;--accent-strong: #1f6fa8;--warm: #d99a3d;--blue: #2f86c5;--shadow: 0 20px 60px rgba(54, 130, 184, .16);font-family:Roboto,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#fff;color:var(--ink)}*{box-sizing:border-box}html{scrollbar-width:none;scroll-behavior:smooth}body{margin:0;min-width:320px;background:linear-gradient(135deg,rgba(74,163,223,.16),transparent 34rem),linear-gradient(330deg,rgba(232,246,255,.92),transparent 30rem),#fff}::-webkit-scrollbar{width:0;height:0}.scroll-rider{position:fixed;top:88px;right:14px;bottom:26px;z-index:30;width:38px;pointer-events:none}.scroll-rider-track{position:absolute;top:0;bottom:0;left:50%;width:4px;border-radius:999px;background:linear-gradient(180deg,#e8f6ff40,#4aa3df57);box-shadow:inset 0 0 0 1px #4aa3df2e;transform:translate(-50%)}.scroll-rider-bike{position:absolute;right:-7px;width:50px;height:64px;object-fit:contain;overflow:visible;filter:drop-shadow(0 8px 14px rgba(31,111,168,.24));transform:rotate(180deg);transition:top .12s linear}a{color:inherit;text-decoration:none}.site-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:10;isolation:isolate;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:min(1120px,calc(100% - 40px));min-height:68px;margin:0 auto;padding:.8rem 0}.topbar:before{position:absolute;top:-14px;right:-22px;bottom:-34px;left:-22px;z-index:-1;border-radius:0 0 24px 24px;background:linear-gradient(180deg,#ffffffdb,#f3f9ff94 58%,#f3f9ff00);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);content:"";mask-image:linear-gradient(to bottom,#000 0%,#000 45%,rgba(0,0,0,.65) 72%,transparent 100%),linear-gradient(to right,transparent 0%,#000 7%,#000 93%,transparent 100%);mask-composite:intersect;pointer-events:none;-webkit-mask-composite:source-in;-webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 45%,rgba(0,0,0,.65) 72%,transparent 100%),linear-gradient(to right,transparent 0%,#000 7%,#000 93%,transparent 100%)}.brand{display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(74,163,223,.28);border-radius:8px;background:#ffffffc7;color:var(--accent-strong);font-weight:800;letter-spacing:0;box-shadow:0 10px 30px #3682b81f;transition:background .18s ease,box-shadow .18s ease,transform .18s ease}.brand:hover,.brand.active{transform:translateY(-1px)}.brand.active{background:linear-gradient(180deg,#fffffff5,#e8f6ffeb),radial-gradient(circle at 50% 100%,rgba(74,163,223,.28),transparent 68%);box-shadow:0 12px 28px #4aa3df2e,inset 0 0 0 1px #4aa3df3d}nav{display:flex;align-items:center;gap:clamp(.75rem,2vw,1.5rem);color:var(--accent-strong);font-size:.94rem;font-weight:650}nav a{position:relative;border-radius:999px;padding:.44rem .68rem;transition:background .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease}nav a:hover,nav a.active{color:var(--accent-strong);transform:translateY(-1px)}nav a.active{background:linear-gradient(180deg,#fffffff5,#e8f6ffe6),radial-gradient(circle at 50% 100%,rgba(74,163,223,.28),transparent 68%);box-shadow:0 12px 28px #4aa3df2e,inset 0 0 0 1px #4aa3df3d}.hero,.section,.footer{width:min(1120px,calc(100% - 40px));margin:0 auto}.hero{display:grid;grid-template-columns:minmax(0,1.06fr) minmax(320px,.94fr);gap:clamp(2rem,6vw,5rem);align-items:center;padding:clamp(3rem,8vw,6.5rem) 0 clamp(.5rem,1vw,1rem)}.eyebrow,.location-note,.section-heading p{display:inline-flex;align-items:center;gap:.45rem;font-size:1.1rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.eyebrow,.location-note{color:var(--accent-strong)}.section-heading p{color:var(--ink);font-size:clamp(1.65rem,3vw,2.65rem);line-height:1.12}h1,h2,h3,p{margin-top:0}h1{max-width:760px;margin-bottom:.85rem;font-size:clamp(2.6rem,6vw,5rem);line-height:.98;letter-spacing:0}.role{margin-bottom:1.4rem;color:var(--blue);font-size:clamp(1.35rem,3vw,2.3rem);font-weight:760}.intro{max-width:680px;color:var(--muted-ink);font-size:clamp(1.02rem,1.5vw,1.18rem);line-height:1.75}.hero-actions,.project-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}.button,.project-links a{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;border:1px solid rgba(74,163,223,.3);border-radius:8px;background:#ffffffb8;color:var(--accent-strong);font-weight:750;padding:.72rem 1rem}.button,.project-links a{transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease,background .18s ease}.location-note{justify-content:center;width:100%;max-width:360px;margin-top:.95rem}.button.primary{background:var(--accent);color:#fff}.button:hover,.project-links a:hover{border-color:#1f6fa880;box-shadow:0 12px 32px #3682b829;transform:translateY(-2px)}.hero-visual{min-height:460px;border:1px solid rgba(74,163,223,.22);border-radius:8px;background:var(--soft-panel);box-shadow:var(--shadow);overflow:hidden;position:relative}.hero-visual img{display:block;width:100%;height:100%;min-height:460px;object-fit:cover;object-position:50% 48%;transform:scale(1.01);transition:transform .7s ease}.hero-visual:hover img{transform:scale(1.035)}.skills-dock-section{width:min(1120px,calc(100% - 40px));margin:0 auto;padding:clamp(.5rem,1vw,1rem) 0 clamp(1.2rem,3vw,2.2rem);scroll-margin-top:120px}.skills-dock{display:flex;align-items:flex-start;justify-content:center;gap:clamp(.75rem,2vw,1.5rem);overflow:visible;min-height:130px;padding:2.35rem .4rem .75rem}.dock-item{display:grid;justify-items:center;min-width:74px;transform-origin:center top}.dock-button{display:grid;place-items:center;width:64px;height:64px;border:1px solid rgba(74,163,223,.22);border-radius:14px;background:linear-gradient(180deg,#fffffff5,#e8f6ffe6),#fff;color:var(--accent-strong);cursor:default;box-shadow:0 10px 26px #3682b81a;transition:border-color .18s ease,box-shadow .18s ease,transform .18s cubic-bezier(.2,.8,.2,1)}.dock-button svg{width:40px;height:40px;fill:currentColor}.dock-item:hover .dock-button,.dock-item:focus-within .dock-button{border-color:#1f6fa86b;box-shadow:0 16px 34px #3682b82e;transform:translateY(-10px) scale(1.55)}.dock-item:has(+.dock-item:hover) .dock-button,.dock-item:hover+.dock-item .dock-button,.dock-item:has(+.dock-item:focus-within) .dock-button,.dock-item:focus-within+.dock-item .dock-button{transform:translateY(-5px) scale(1.22)}.dock-item span{display:block;min-height:1.1rem;margin-top:.45rem;color:var(--ink);font-size:.76rem;font-weight:800;opacity:0;transform:translateY(-2px);transition:opacity .16s ease,transform .16s ease;white-space:nowrap}.dock-item:hover span,.dock-item:focus-within span{opacity:1;transform:translateY(0)}.section{padding:clamp(3rem,5.5vw,4.75rem) 0}.section.muted{width:100%;max-width:none;background:#f3f9ffdb;border-block:1px solid rgba(74,163,223,.18);padding-inline:max(20px,calc((100% - 1120px)/2))}.section-heading{max-width:780px;margin-bottom:clamp(1.15rem,3vw,2rem)}.timeline{display:grid;gap:1.2rem}.timeline-item{display:grid;grid-template-columns:220px minmax(0,1fr);gap:1.25rem;align-items:start}.timeline-meta{display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--accent-strong);font-weight:780;padding-top:1.1rem}.timeline-card,.project-card,.skill-card,.hobby-card,.education-item{border:1px solid rgba(74,163,223,.18);border-radius:8px;background:#ffffffd1;box-shadow:0 14px 42px #3682b81a}.timeline-card{padding:clamp(1.1rem,2.5vw,1.65rem)}.timeline-card h3,.project-card h3,.skill-card h3,.hobby-card h3,.education-item h3{margin-bottom:.35rem;font-size:1.08rem;line-height:1.25}.company,.timeline-card li,.project-card p,.skill-card p,.hobby-card p,.education-item p{color:var(--muted-ink);line-height:1.65}.company{margin-bottom:1rem;font-weight:700}ul{margin:0;padding-left:1.15rem}li+li{margin-top:.55rem}.project-grid,.skills-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.project-card,.skill-card{display:flex;min-height:100%;flex-direction:column;justify-content:space-between;padding:clamp(1.15rem,2.6vw,1.6rem);overflow:hidden}.project-thumbnail{display:block;margin:calc(-1*clamp(1.15rem,2.6vw,1.6rem));margin-bottom:clamp(.75rem,1.5vw,1rem)}.project-thumbnail img{width:100%;height:180px;object-fit:cover;display:block;transition:opacity .2s ease}.project-thumbnail:hover img{opacity:.85}.project-links{margin-top:1.25rem}.project-links a{min-height:38px;padding:.54rem .75rem;font-size:.92rem}.skill-card{gap:.8rem}.skill-card svg{color:var(--warm)}.skill-card p{margin-bottom:0}.education-list{display:grid;gap:1rem}.education-item{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem}.education-item svg{flex:0 0 auto;color:var(--blue);margin-top:.15rem}.education-logo{flex:0 0 auto;width:73px;height:73px;object-fit:contain}.experience-logo{float:right;width:56px;height:56px;object-fit:contain;margin:0 0 .5rem 1rem}.education-item span{color:var(--accent-strong);font-weight:760}.hobbies-section{padding-top:clamp(2.5rem,5vw,4rem)}.hobbies-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.hobby-card{display:flex;gap:.9rem;align-items:flex-start;min-height:100%;padding:clamp(1.1rem,2.4vw,1.45rem)}.hobby-card svg{flex:0 0 auto;color:var(--accent);margin-top:.15rem}.hobby-card p{margin-bottom:0}.contact-section{padding-top:clamp(2.5rem,5vw,4rem)}.contact-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;max-width:920px;border:1px solid rgba(74,163,223,.18);border-radius:8px;background:linear-gradient(135deg,#ffffffeb,#f3f9ffe6),#fff;box-shadow:0 14px 42px #3682b81a;padding:clamp(1rem,2.5vw,1.4rem)}.contact-card{display:grid;gap:.55rem;min-height:150px;border:1px solid rgba(74,163,223,.2);border-radius:8px;background:#ffffffc2;color:var(--accent-strong);padding:clamp(1.05rem,2vw,1.35rem);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease,background .18s ease}.contact-card:hover{border-color:#1f6fa87a;box-shadow:0 14px 34px #3682b829;transform:translateY(-2px)}.contact-card-title{display:inline-flex;align-items:center;gap:.55rem;font-size:.88rem;font-weight:900;text-transform:uppercase}.contact-card strong{color:inherit;font-size:clamp(1rem,1.5vw,1.18rem);line-height:1.25;overflow-wrap:anywhere}.footer{display:flex;flex-direction:column;align-items:center;gap:.4rem;border-top:1px solid rgba(74,163,223,.18);color:var(--muted-ink);padding:2rem 0 2.5rem}.footer p{margin-bottom:0}.footer a{color:var(--accent-strong);font-weight:760}.footer-disclaimer{width:100%;text-align:center;font-size:.75rem;opacity:.5;margin-top:.5rem}.section-animate{animation:enter .62s ease both}@keyframes enter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;scroll-behavior:auto!important;transition-duration:1ms!important}}@media(max-width:900px){.hero{grid-template-columns:1fr;min-height:auto}.hero-visual,.hero-visual img{min-height:360px}.timeline-item{grid-template-columns:1fr;gap:.6rem}.timeline-meta{justify-content:flex-start;padding-top:0}.project-grid,.skills-grid,.hobbies-grid{grid-template-columns:1fr}}@media(max-width:640px){.scroll-rider{display:none}.topbar{width:min(100% - 28px,1120px);align-items:flex-start;flex-direction:column;gap:.8rem;min-height:96px}nav{width:100%;justify-content:space-between;gap:.4rem;overflow-x:auto;padding-bottom:.25rem;font-size:.86rem}.hero,.section,.footer{width:min(100% - 28px,1120px)}.hero{padding-top:2.4rem}h1{font-size:clamp(2.35rem,13vw,3.4rem)}.skills-dock-section{width:min(100% - 28px,1120px);padding-top:1rem}.skills-dock{justify-content:flex-start;overflow-x:auto;overflow-y:hidden;min-height:96px;padding-inline:.1rem;padding-top:.6rem}.dock-item span{opacity:1;font-size:.72rem}.dock-item:hover .dock-button,.dock-item:focus-within .dock-button,.dock-item:has(+.dock-item:hover) .dock-button,.dock-item:hover+.dock-item .dock-button,.dock-item:has(+.dock-item:focus-within) .dock-button,.dock-item:focus-within+.dock-item .dock-button{transform:none}.hero-actions{display:grid;grid-template-columns:1fr}.button{width:100%}.contact-panel{display:grid;grid-template-columns:1fr}.hero-visual,.hero-visual img{min-height:310px}.footer{align-items:flex-start;flex-direction:column}}
