:root{--bg: #f8f6f1;--ink: #18181b;--ink-2: #3f3f46;--muted: #52525b;--subtle: #71717a;--line: #e4e4e7;--card: #ffffff;--accent: #ec4899;--accent-2: #8b5cf6;--accent-3: #06b6d4;--accent-4: #f97316;--accent-5: #f43f5e;--font-display: "Archivo Black", "Impact", sans-serif;--font-body: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font-family:var(--font-body);color:var(--ink);background:var(--bg);line-height:1.5;font-weight:400}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink)}a{color:inherit;text-decoration:none}.site{min-height:100vh;display:flex;flex-direction:column}main{flex:1}.topbar{position:sticky;top:0;z-index:20;background:#f8f6f1f0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-inner{max-width:1500px;margin:0 auto;padding:1.25rem 2.5rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.topbar-rule{max-width:1500px;margin:0 auto;height:2px;background:var(--ink)}.brand{font-family:var(--font-display);font-size:clamp(1.1rem,2vw,1.6rem);text-transform:uppercase;letter-spacing:-.01em;color:var(--ink);line-height:1;display:inline-flex;align-items:center;gap:.6rem;transition:color .25s ease}.brand-spark{color:var(--accent);flex-shrink:0;transition:transform .4s ease,color .25s ease}.brand:hover .brand-spark{transform:rotate(90deg);color:var(--accent-2)}.brand:hover{color:var(--accent)}.nav{display:flex;gap:clamp(1.5rem,3.5vw,3.25rem);font-family:var(--font-display);font-size:clamp(.9rem,1.4vw,1.2rem);text-transform:uppercase;letter-spacing:.02em;color:var(--ink)}.nav a{position:relative;transition:color .25s ease;padding-bottom:4px;line-height:1}.nav a:nth-child(1):hover{color:var(--accent)}.nav a:nth-child(1):hover:after{background:var(--accent)}.nav a:nth-child(2):hover{color:var(--accent-2)}.nav a:nth-child(2):hover:after{background:var(--accent-2)}.nav a:nth-child(3):hover{color:var(--accent-3)}.nav a:nth-child(3):hover:after{background:var(--accent-3)}.nav a:nth-child(4):hover{color:var(--accent-4)}.nav a:nth-child(4):hover:after{background:var(--accent-4)}.nav a:nth-child(5):hover{color:var(--accent-5)}.nav a:nth-child(5):hover:after{background:var(--accent-5)}.nav a:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:3px;background:var(--accent);transition:width .3s ease}.nav a:hover:after,.nav a.active:after{width:100%}.nav a.active{color:var(--accent)}.nav a:nth-child(2).active{color:var(--accent-2)}.nav a:nth-child(2).active:after{background:var(--accent-2)}.nav a:nth-child(3).active{color:var(--accent-3)}.nav a:nth-child(3).active:after{background:var(--accent-3)}.nav a:nth-child(4).active{color:var(--accent-4)}.nav a:nth-child(4).active:after{background:var(--accent-4)}.nav a:nth-child(5).active{color:var(--accent-5)}.nav a:nth-child(5).active:after{background:var(--accent-5)}.section{max-width:1100px;margin:0 auto;padding:5rem 2rem;width:100%}.hero{padding-top:6rem;padding-bottom:5rem}.eyebrow{font-family:var(--font-body);font-size:.75rem;text-transform:uppercase;letter-spacing:.28em;color:var(--subtle);margin-bottom:1.5rem;font-weight:500}.eyebrow-light{color:#ffffffd9}.hero h1,.page-title{font-family:var(--font-display);font-size:clamp(3rem,8vw,6rem);line-height:.92;margin:0;letter-spacing:-.02em;text-transform:uppercase;color:var(--ink)}.accent{color:var(--accent)}.hero-text,.page-lead{font-family:var(--font-body);max-width:640px;margin-top:2rem;font-size:1.1rem;line-height:1.8;color:var(--muted)}.hero-cta{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap}.btn{display:inline-block;padding:.9rem 1.75rem;border-radius:4px;font-family:var(--font-display);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease}.btn-primary{background:var(--ink);color:var(--bg)}.btn-primary:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 10px 24px #f973164d}.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.split-section{display:grid;grid-template-columns:280px 1fr;gap:4rem}.split-left h2{font-family:var(--font-display);margin:.25rem 0 0;font-size:2.25rem;line-height:1;letter-spacing:-.01em;text-transform:uppercase;color:var(--ink)}.muted{font-family:var(--font-body);margin-top:0;color:var(--muted);line-height:1.8;font-size:1rem}.work-page-full{width:100%}.work-intro{max-width:1400px;margin:0 auto;padding:4rem 2rem 3rem}.work-grid-full{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:180px;gap:0;width:100%}.work-cell{position:relative;overflow:hidden;display:block;color:#fff;transition:filter .5s ease;min-height:360px}.work-grid-full:hover .work-cell{filter:brightness(.65) saturate(.8)}.work-grid-full .work-cell:hover{filter:brightness(1) saturate(1.1)}.work-cell-meta{position:absolute;top:1.5rem;left:1.75rem;right:1.75rem;display:flex;justify-content:space-between;font-family:var(--font-body);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:#ffffffd9;z-index:2;font-weight:500}.work-cell-hover{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:2rem;opacity:0;transform:translateY(16px);transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1);z-index:1}.work-cell:hover .work-cell-hover{opacity:1;transform:translateY(0)}.work-cell-title{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,3rem);text-transform:uppercase;letter-spacing:-.01em;line-height:1;max-width:90%}.work-cell-subtitle{font-family:var(--font-body);margin-top:.75rem;font-size:.8rem;opacity:.9;letter-spacing:.1em;text-transform:uppercase;font-weight:500}.project-page{padding-bottom:4rem}.project-hero{padding:8rem 2rem 6rem;color:#fff}.project-hero-inner{max-width:1100px;margin:0 auto}.project-hero-title{font-family:var(--font-display);margin:0;font-size:clamp(2.75rem,7vw,5rem);line-height:.95;letter-spacing:-.02em;text-transform:uppercase}.project-hero-tagline{font-family:var(--font-body);margin-top:1.75rem;font-size:1.15rem;line-height:1.7;max-width:640px;opacity:.95}.project-meta{padding-top:3rem;padding-bottom:2rem}.meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding-bottom:2rem;border-bottom:1px solid var(--line)}.meta-label{font-family:var(--font-body);font-size:.72rem;text-transform:uppercase;letter-spacing:.25em;color:var(--subtle);margin-bottom:.5rem;font-weight:500}.meta-value{font-family:var(--font-body);font-size:1rem;color:var(--ink);line-height:1.5}.highlights-list{display:grid;gap:1rem}.highlight-card{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:0 1rem 1rem 0;padding:1.75rem;box-shadow:0 6px 18px #0000000a;transition:transform .3s ease}.highlight-card:hover{transform:translate(4px)}.highlight-card p{margin:.5rem 0 0;color:var(--ink-2);line-height:1.75}.card-number{font-family:var(--font-body);font-size:.75rem;color:var(--subtle);letter-spacing:.15em;font-weight:500}.stack{display:flex;flex-wrap:wrap;gap:.5rem}.tag{font-family:var(--font-body);font-size:.75rem;padding:.45rem .9rem;border-radius:999px;background:var(--card);color:var(--muted);border:1px solid var(--line);transition:all .25s ease;text-transform:uppercase;letter-spacing:.08em;font-weight:500}.tag:hover{color:var(--accent);border-color:var(--accent)}.next-project{padding-top:2rem}.next-link{display:block;margin-top:1rem;border-radius:1.5rem;overflow:hidden;color:#fff;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease;box-shadow:0 10px 30px #00000014}.next-link:hover{transform:translateY(-4px);box-shadow:0 20px 40px #00000026}.next-inner{padding:2.5rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.next-label{font-family:var(--font-body);font-size:.72rem;text-transform:uppercase;letter-spacing:.25em;opacity:.85;margin-bottom:.5rem;font-weight:500}.next-title{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.5rem);text-transform:uppercase;letter-spacing:-.01em;line-height:1}.next-arrow{font-family:var(--font-body);font-size:2.5rem;transition:transform .3s ease}.next-link:hover .next-arrow{transform:translate(8px)}.experience-list{display:grid;gap:2rem}.experience-item{display:grid;grid-template-columns:100px 1fr;gap:2rem;padding-bottom:2rem;border-bottom:1px solid var(--line)}.experience-item:last-child{border-bottom:none}.experience-period{font-family:var(--font-body);font-size:.85rem;color:var(--subtle);letter-spacing:.1em;padding-top:.5rem;font-weight:500}.experience-role{font-family:var(--font-display);font-size:1.35rem;text-transform:uppercase;letter-spacing:-.01em;line-height:1.1}.experience-company{font-family:var(--font-body);font-size:.85rem;color:var(--accent);margin-top:.4rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em}.experience-item p{font-family:var(--font-body);margin-top:.85rem;color:var(--ink-2);line-height:1.75}.skills-grid{display:grid;gap:2rem}.skill-category{font-family:var(--font-body);font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--subtle);margin-bottom:1rem;font-weight:500}.skill-items{display:flex;flex-wrap:wrap;gap:.5rem}.contact-heading{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,4.5rem);line-height:.95;letter-spacing:-.02em;margin:0;text-transform:uppercase}.contact-links{margin-top:2.5rem;display:flex;flex-wrap:wrap;gap:1.75rem;font-size:1rem;font-family:var(--font-body);font-weight:500}.contact-links a{color:var(--ink);border-bottom:2px solid var(--subtle);padding-bottom:4px;transition:all .25s ease;text-transform:uppercase;letter-spacing:.05em}.contact-links a:hover{color:var(--accent);border-bottom-color:var(--accent)}.footer{max-width:1100px;margin:0 auto;padding:2rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-family:var(--font-body);font-size:.8rem;color:var(--subtle);width:100%;text-transform:uppercase;letter-spacing:.1em;font-weight:500}.work-cell-graphic{position:absolute;bottom:0;left:0;right:0;height:55%;display:flex;align-items:flex-end;justify-content:center;padding:1.5rem;pointer-events:none;opacity:.9;transition:opacity .5s ease,transform .6s cubic-bezier(.22,1,.36,1);z-index:1}.tile-graphic{width:100%;max-width:340px;height:auto}.work-cell:hover .work-cell-graphic{opacity:.35;transform:translateY(8px)}.divider-wrap{padding-top:1rem!important;padding-bottom:1rem!important}.divider-decorative{display:flex;align-items:center;gap:1.25rem;max-width:400px;margin:0 auto}.divider-line{flex:1;height:1px;background:var(--line)}.divider-star{color:var(--accent);flex-shrink:0;animation:spin 12s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.resume-page{max-width:1100px}.resume-header{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}.resume-download{white-space:nowrap}.pdf-frame{background:var(--ink);border-radius:1rem;padding:.5rem;box-shadow:0 20px 60px #00000026;overflow:hidden}.pdf-viewer{width:100%;height:85vh;min-height:600px;border:none;border-radius:.5rem;display:block;background:#f4f4f5}.pdf-fallback{padding:4rem 2rem;text-align:center;background:var(--card);border-radius:.5rem}.pdf-fallback p{font-family:var(--font-body);color:var(--muted);margin-bottom:1.5rem}.about-hero{padding-bottom:2rem}.about-rail{position:relative;max-width:1100px;margin:0 auto;padding:2rem 2rem 3rem}.about-rail-line{position:absolute;top:0;bottom:0;left:calc(2rem + 40px);width:2px;background:linear-gradient(to bottom,transparent 0%,var(--line) 8%,var(--line) 92%,transparent 100%);pointer-events:none}.rail-block{position:relative;display:grid;grid-template-columns:80px 1fr;gap:2rem;padding:1.75rem 0;align-items:flex-start}.rail-block-shifted{padding-left:clamp(0rem,8vw,5rem)}.rail-marker{position:relative;z-index:2;display:flex;justify-content:center;padding-top:.25rem}.rail-num{font-family:var(--font-display);font-size:1rem;color:var(--subtle);background:var(--bg);padding:.5rem 0;letter-spacing:.05em;line-height:1}.rail-body{max-width:620px}.rail-body-left{padding-right:2rem}.rail-body-right{margin-left:clamp(0rem,6vw,4rem)}.rail-body-wide{max-width:720px}.rail-heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.5rem);line-height:1;letter-spacing:-.015em;text-transform:uppercase;margin:.5rem 0 1rem;color:var(--ink)}.rail-heading-big{font-size:clamp(2rem,4.5vw,3.25rem)}.rail-body .muted{margin-top:0;line-height:1.8}.eyebrow-pink{color:#ec4899}.eyebrow-purple{color:#8b5cf6}.eyebrow-cyan{color:#06b6d4}.eyebrow-orange{color:#f97316}.in-progress-page{max-width:1100px}.ip-section{margin-top:4rem}.ip-row-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:2px solid;margin-bottom:1.75rem}.ip-row-label{font-family:var(--font-display);font-size:.9rem;text-transform:uppercase;letter-spacing:.18em}.ip-row-count{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--subtle);letter-spacing:.08em;font-weight:500}.ip-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start;padding-bottom:1.5rem}.ip-grid-cell-offset{transform:translateY(20px)}.term-card{background:#0f0f11;border-radius:0;overflow:hidden;box-shadow:0 12px 28px #00000029;border:1px solid #27272a;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease}.term-card:hover{transform:translateY(-4px);box-shadow:0 18px 36px #00000038}.ip-grid-cell-offset .term-card:hover{transform:translateY(16px)}.term-titlebar{background:#1a1a1d;padding:.7rem .95rem;display:flex;align-items:center;gap:.6rem;border-bottom:1px solid #27272a}.term-dots{display:flex;gap:.4rem}.term-dot{width:11px;height:11px;border-radius:50%}.dot-red{background:#ef4444}.dot-yellow{background:#eab308}.dot-green{background:#22c55e}.term-path{font-family:JetBrains Mono,monospace;font-size:.7rem;color:#71717a;margin-left:.4rem;letter-spacing:.03em}.term-body{padding:1rem 1.2rem 1.25rem;font-family:JetBrains Mono,monospace;font-size:.74rem;line-height:1.85}.term-comment{color:#71717a}.term-comment-spaced{margin-top:.65rem}.term-line{color:#e4e4e7}.term-prompt{color:#a3e635;margin-right:.25rem}.term-status{font-weight:500}.term-string{color:#f9a8d4}.term-notes{color:#a1a1aa;font-family:var(--font-body);font-size:.82rem;line-height:1.65;margin-top:.3rem;margin-bottom:.5rem}.term-cursor-line{margin-top:.5rem}.term-cursor-blink{display:inline-block;width:7px;height:12px;background:#a3e635;vertical-align:middle;margin-left:4px;animation:term-blink 1.1s infinite}@keyframes term-blink{0%,49%{opacity:1}50%,to{opacity:0}}.term-cursor-static{color:#a3e635;margin-left:4px}.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}.reveal.is-visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}.work-cell,.next-link,.btn{transition:none}}@media (max-width: 900px){.work-grid-full{grid-template-columns:1fr;grid-auto-rows:auto}.work-cell{grid-column:span 1!important;grid-row:auto!important;min-height:300px}.work-cell-hover{opacity:1;transform:none;background:linear-gradient(to top,rgba(0,0,0,.35),transparent 60%);justify-content:flex-end}.work-grid-full:hover .work-cell{filter:none}.work-intro{padding:3rem 1.25rem 2rem}.split-section{grid-template-columns:1fr;gap:2rem}.experience-item{grid-template-columns:1fr;gap:.5rem}.meta-grid{grid-template-columns:1fr;gap:1.5rem}.resume-header{flex-direction:column;align-items:flex-start}.pdf-viewer{height:70vh;min-height:500px}.about-rail{padding:1.5rem 1.25rem 2rem}.about-rail-line{left:calc(1.25rem + 24px)}.rail-block{grid-template-columns:48px 1fr;gap:1rem;padding:1.25rem 0}.rail-block-shifted{padding-left:0}.rail-body-left{padding-right:0}.rail-body-right{margin-left:0}.section.tight{padding:2.5rem 1.25rem}.ip-grid{grid-template-columns:1fr;gap:1rem;padding-bottom:0}.ip-grid-cell-offset{transform:none}.ip-grid-cell-offset .term-card:hover{transform:translateY(-4px)}.section{padding:4rem 1.25rem}.hero{padding-top:4rem}.topbar-inner{padding:1.5rem 1.25rem 1rem}.topbar-rule{margin:0 1.25rem}.nav{gap:1.5rem;font-size:1rem}.footer{flex-direction:column;gap:.5rem;padding:2rem 1.25rem}.project-hero{padding:5rem 1.25rem 4rem}.next-inner{padding:1.75rem}}
