:root{color-scheme:dark;--bg: #101314;--bg-soft: #161a1c;--panel: #171c1f;--panel-strong: #20272b;--text: #f4f1ec;--muted: #c9c4bc;--subtle: #9a9992;--line: rgba(244, 241, 236, .13);--accent: #d85d67;--accent-soft: rgba(216, 93, 103, .16);--focus: #f0b86f;--shadow: 0 28px 80px rgba(0, 0, 0, .35);--max: 1180px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-soft: cubic-bezier(.22, 1, .36, 1)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:var(--bg);color:var(--text);font-family:Raleway,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6;letter-spacing:0;text-rendering:optimizeLegibility}body:after{position:fixed;inset:auto -12vw -28vh auto;z-index:0;width:46vw;height:46vw;min-width:420px;min-height:420px;pointer-events:none;background:radial-gradient(circle,rgba(216,93,103,.08),transparent 62%);content:"";opacity:.72;animation:ambientDrift 18s var(--ease-soft) infinite alternate}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}a:focus-visible,button:focus-visible{outline:2px solid var(--focus);outline-offset:5px}img{display:block;max-width:100%}main{position:relative;z-index:1}.site-header{position:fixed;z-index:20;top:0;left:0;right:0;display:flex;align-items:flex-start;justify-content:space-between;gap:32px;padding:24px clamp(22px,4vw,56px);background:#101314eb;border-bottom:1px solid rgba(244,241,236,.08);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);pointer-events:auto}.brand{display:inline-flex;flex-direction:column;width:min-content;font-family:Georgia,Times New Roman,serif;font-size:clamp(1.62rem,2.5vw,2.15rem);font-weight:800;line-height:.96;letter-spacing:0;transition:color .26s var(--ease-out),transform .32s var(--ease-out)}.brand:hover{transform:translateY(-1px);color:#fff}.main-nav{display:flex;align-items:center;gap:clamp(18px,2.4vw,32px);color:var(--muted);font-size:.95rem;font-weight:600}.main-nav a{position:relative;padding-bottom:8px;transition:color .24s var(--ease-out),transform .26s var(--ease-out)}.main-nav a:after{position:absolute;left:0;right:0;bottom:0;height:2px;transform:scaleX(0);transform-origin:left;background:var(--accent);content:"";transition:transform .32s var(--ease-out)}.main-nav a:hover,.main-nav a.is-active{color:var(--text)}.main-nav a:hover{transform:translateY(-1px)}.main-nav a.is-active:after{transform:scaleX(1)}.nav-resume{border:1px solid rgba(244,241,236,.18);border-radius:999px;padding:7px 12px;color:var(--text)}.nav-resume:after{display:none}.side-rail{position:fixed;z-index:15;left:clamp(24px,3.6vw,56px);bottom:clamp(30px,7vh,78px);display:grid;gap:clamp(56px,8vh,88px);color:var(--text);pointer-events:auto}.rail-lines{display:grid;gap:12px}.rail-lines a{width:42px;height:3px;background:#f4f1ec73;transition:width .36s var(--ease-out),background .36s var(--ease-out),transform .36s var(--ease-out)}.rail-lines a.is-active{width:56px;background:var(--text);transform:translate(8px)}.scroll-label{display:flex;align-items:center;gap:10px;writing-mode:vertical-rl;text-transform:uppercase;font-size:.82rem;letter-spacing:.08em;color:var(--muted);transition:color .26s var(--ease-out),transform .36s var(--ease-out)}.scroll-label:hover{color:var(--text);transform:translateY(-3px)}.section-shell{position:relative;width:min(1320px,calc(100% - clamp(220px,18vw,340px)));margin-left:clamp(150px,12vw,230px);margin-right:auto;padding:clamp(76px,9vw,112px) 0;scroll-margin-top:50px;opacity:.72;transform:translateY(18px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);will-change:opacity,transform}.section-shell.hero,.section-shell.is-section-visible{opacity:1;transform:translateY(0)}.hero{min-height:100svh;display:grid;grid-template-columns:minmax(560px,1fr) minmax(340px,420px);align-items:center;gap:clamp(44px,5vw,76px);padding-top:clamp(118px,10vw,146px);padding-bottom:clamp(64px,7vw,92px)}.hero-copy{max-width:820px;animation:heroCopyIn .9s var(--ease-out) both}.kicker{display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;color:var(--accent);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.kicker:before{width:32px;height:1px;background:currentColor;content:""}h1,h2,h3,p{margin-top:0}h1{max-width:780px;margin-bottom:24px;font-size:clamp(3rem,4.5vw,5.125rem);line-height:1.05;letter-spacing:0}h2{max-width:760px;margin-bottom:20px;font-size:clamp(1.9rem,3.2vw,3.2rem);line-height:1.04;letter-spacing:0}h3{margin-bottom:12px;font-size:1.18rem;line-height:1.3}p{color:var(--muted);font-size:1.03rem;line-height:1.68}.hero-lede{max-width:720px;margin-bottom:26px;color:#d1ccc4;font-size:clamp(1.08rem,1.18vw,1.16rem);line-height:1.7}.hero-proof{display:grid;gap:9px;max-width:680px;margin:0 0 30px;padding:0;list-style:none}.hero-proof li{position:relative;padding-left:18px;color:#e1ddd6;font-size:1rem;line-height:1.55;opacity:0;transform:translateY(10px);animation:factIn .62s var(--ease-out) both}.hero-proof li:before{position:absolute;top:.72em;left:0;width:6px;height:6px;border-radius:999px;background:var(--accent);content:""}.hero-proof li:nth-child(1){animation-delay:.24s}.hero-proof li:nth-child(2){animation-delay:.34s}.hero-proof li:nth-child(3){animation-delay:.44s}.hero-actions,.contact-actions{display:flex;flex-wrap:wrap;gap:14px}.button,.contact-link{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;border:1px solid var(--line);border-radius:8px;padding:0 18px;color:#f7f3ed;font-size:1rem;font-weight:700;transition:transform .36s var(--ease-out),border-color .36s var(--ease-out),background .36s var(--ease-out),box-shadow .36s var(--ease-out)}.button:hover,.contact-link:hover{transform:translateY(-2px);border-color:#f4f1ec5c;box-shadow:0 16px 40px #00000038}.button-primary{border-color:var(--accent);background:var(--accent);color:#150f10}.button-ghost{background:#ffffff06}.hero-facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin:42px 0 0}.hero-facts div{border-top:1px solid var(--line);padding-top:16px;opacity:0;transform:translateY(10px);animation:factIn .62s var(--ease-out) both}.hero-facts div:nth-child(1){animation-delay:.28s}.hero-facts div:nth-child(2){animation-delay:.38s}.hero-facts div:nth-child(3){animation-delay:.48s}.hero-facts dt{color:var(--subtle);font-size:.78rem;text-transform:uppercase}.hero-facts dd{margin:5px 0 0;color:var(--text);font-weight:700}.hero-visual{position:relative;justify-self:end;width:min(100%,385px);animation:heroVisualIn .98s .16s var(--ease-out) both}.portrait-frame{position:relative;z-index:1;overflow:hidden;border:1px solid rgba(244,241,236,.14);border-radius:8px;background:var(--panel);box-shadow:0 20px 56px #00000047;transition:transform .7s var(--ease-out),border-color .48s var(--ease-out),box-shadow .7s var(--ease-out)}.portrait-frame:before{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to top,rgba(16,19,20,.16),transparent 34%);content:""}.portrait-frame img{width:100%;aspect-ratio:4 / 4.9;object-fit:cover;object-position:50% 28%;transform:scale(1.01);transition:transform .9s var(--ease-soft)}.portrait-frame:hover{transform:translateY(-6px) rotate(-.35deg);border-color:#d85d675c;box-shadow:0 28px 72px #00000057}.portrait-frame:hover img{transform:scale(1.045)}.portrait-labels{position:absolute;z-index:2;left:18px;right:18px;bottom:18px;display:flex;flex-wrap:wrap;gap:8px;max-width:none}.portrait-labels span{border:1px solid rgba(244,241,236,.14);border-radius:999px;padding:8px 11px;background:#101314c7;color:#f0ece5;font-size:.78rem;font-weight:700;line-height:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hero-visual:after{position:absolute;right:-6%;bottom:-6%;width:62%;height:48%;border-radius:8px;background:var(--panel-strong);content:"";transition:transform .7s var(--ease-out),background .7s var(--ease-out)}.hero-visual:hover:after{transform:translate(10px,10px);background:#252d31}.section-intro{max-width:810px;margin-bottom:clamp(32px,5vw,52px)}.section-intro p{max-width:720px;font-size:1.08rem}.panel{border:1px solid var(--line);border-radius:8px;background:#ffffff06}.work-grid,.projects-grid,.tools-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.work-card,.project-card,.tool-group{min-height:235px;padding:26px;transition:transform .42s var(--ease-out),border-color .42s var(--ease-out),background .42s var(--ease-out),box-shadow .42s var(--ease-out)}.work-card p,.tool-group p{color:#d2cdc5;font-size:.98rem;line-height:1.65}.step-number{display:inline-flex;margin-bottom:22px;color:#f4f1ec57;font-size:.82rem;font-weight:800;letter-spacing:.08em}.work-card:hover,.project-card:hover,.tool-group:hover{transform:translateY(-2px);border-color:#d85d678a;background:#d85d670b;box-shadow:0 18px 42px #00000038}.work-card svg,.project-card svg{transition:transform .42s var(--ease-out),color .42s var(--ease-out)}.work-card:hover svg,.project-card:hover svg{transform:translateY(-2px) scale(1.04)}.work-card svg,.project-card svg{margin-bottom:28px;color:var(--accent)}.timeline{display:grid;gap:22px}.timeline-item{display:grid;grid-template-columns:230px minmax(0,1fr);gap:36px}.timeline-meta{border-top:1px solid var(--line);padding-top:18px;color:var(--subtle)}.timeline-meta span,.timeline-meta strong{display:block}.timeline-meta strong{margin-top:7px;color:var(--muted)}.timeline-card{padding:28px;transition:transform .42s var(--ease-out),border-color .42s var(--ease-out),background .42s var(--ease-out)}.role-summary{color:#d1ccc4}.impact-label{display:inline-flex;margin-top:6px;color:var(--accent);font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.timeline-item:hover .timeline-card{transform:translate(4px);border-color:#f4f1ec33;background:#ffffff09}.timeline-card ul{display:grid;gap:9px;margin:22px 0 0;padding:0;list-style:none}.role-context{margin-bottom:14px;color:var(--accent);font-size:.88rem;font-weight:800}.timeline-card li{position:relative;padding-left:18px;color:#ded9d1;font-size:1rem;line-height:1.64}.timeline-card li:before{position:absolute;top:.72em;left:0;width:6px;height:6px;border-radius:999px;background:var(--accent);content:""}.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-card{position:relative;display:flex;flex-direction:column;min-height:640px}.project-outcome{color:#e1ddd6;font-size:1.02rem;font-weight:600;line-height:1.6}.project-index{position:absolute;top:24px;right:26px;color:#f4f1ec2e;font-family:Georgia,Times New Roman,serif;font-size:2.4rem;font-weight:800;line-height:1}.tag-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:auto;padding-top:22px}.story-points{display:grid;gap:13px;margin:20px 0 0}.story-points div{border-top:1px solid rgba(244,241,236,.09);padding-top:12px}.story-points dt{margin-bottom:4px;color:var(--accent);font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.story-points dd{margin:0;color:#ddd7ce;font-size:.98rem;line-height:1.65}.story-points .impact-point{border:1px solid rgba(216,93,103,.24);border-radius:8px;padding:15px;background:#d85d6711}.story-points .impact-point dt{color:#ff7b86}.story-points .impact-point dd{color:#f0ece5;font-weight:600}.tag-row span{border:1px solid rgba(244,241,236,.12);border-radius:999px;padding:7px 10px;color:#e1ddd6;font-size:.86rem;line-height:1}.tools-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.tool-group{min-height:220px}.contact-section{padding-bottom:clamp(92px,14vw,170px)}.contact-layout{display:grid;grid-template-columns:minmax(0,.95fr) minmax(280px,.55fr);gap:clamp(32px,8vw,92px);align-items:end;border-top:1px solid var(--line);padding-top:clamp(42px,7vw,72px)}.contact-layout p{max-width:650px;font-size:1.08rem}.contact-actions{justify-content:flex-start}.contact-link{width:100%;justify-content:flex-start;background:#ffffff06}[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .82s var(--ease-out) var(--reveal-delay, 0ms),transform .82s var(--ease-out) var(--reveal-delay, 0ms);will-change:opacity,transform}[data-reveal].is-visible{opacity:1;transform:translateY(0)}@keyframes heroCopyIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes heroVisualIn{0%{opacity:0;transform:translateY(28px) scale(.975)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes factIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes ambientDrift{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(-6vw,-4vh,0) scale(1.08)}}@media(max-width:1180px){.section-shell{width:min(100% - 210px,900px);margin-left:150px;margin-right:32px}.hero,.contact-layout{grid-template-columns:1fr}.hero-visual{justify-self:start;max-width:430px}.work-grid,.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:920px){.side-rail{display:none}.section-shell{width:min(100% - 48px,720px);margin-left:auto;margin-right:auto}}@media(max-width:820px){.site-header{position:sticky;align-items:center;padding:18px 20px;background:#101314db;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{font-size:1.42rem}.main-nav{max-width:64vw;overflow-x:auto;gap:18px;scrollbar-width:none;white-space:nowrap}.main-nav::-webkit-scrollbar{display:none}.section-shell{width:min(100% - 36px,680px);margin-left:auto;margin-right:auto;padding:82px 0}.hero{min-height:auto;padding-top:54px}h1{font-size:clamp(2.7rem,14vw,4.5rem)}.hero-facts,.work-grid,.projects-grid,.tools-grid,.timeline-item{grid-template-columns:1fr}.timeline-item{gap:14px}.hero-visual{width:min(100%,430px)}.portrait-labels{position:relative;left:auto;bottom:auto;margin-top:14px;max-width:none}.hero-visual:after{right:-4%;bottom:-4%}}@media(max-width:520px){.site-header{gap:16px}.main-nav{font-size:.88rem}.section-shell{width:min(100% - 28px,420px)}.hero-actions,.contact-actions{display:grid;grid-template-columns:1fr}.button,.contact-link{width:100%}.work-card,.project-card,.tool-group,.timeline-card{padding:22px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}[data-reveal],.section-shell{opacity:1;transform:none}body:after{display:none}}
