*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080808;--bg2: #101012;--bg3: #161618;--accent: rgba(243, 233, 216, .88);--accent2: rgba(243, 233, 216, .72);--accent3: rgba(243, 233, 216, .28);--text: #F3E9D8;--muted: rgba(243, 233, 216, .38);--border: rgba(255, 255, 255, .08);--glow: rgba(255, 255, 255, .04);--font-display: "Space Grotesk", sans-serif;--font-body: "DM Sans", sans-serif;--color-lavender: #A891C4;--color-cream: #F3E9D8;--color-olive: #A891C4;--color-blue: #A891C4;--color-pink: #F3E9D8;--color-coral: #A891C4;--text-meta: .75rem;--text-nav: .875rem;--text-body: 1rem;--text-body-lg: clamp(1.05rem, 1.4vw, 1.25rem);--text-lead: clamp(.95rem, 1.15vw, 1.15rem);--text-project-title: clamp(2.4rem, 4vw, 3.8rem);--text-card-title: var(--text-project-title);--text-section-title: clamp(3rem, 5vw, 4.6rem);--text-hero-title: clamp(3.2rem, 6.4vw, 6.4rem);--fs-hero-name: var(--text-hero-title);--fs-hero-role: var(--text-lead);--fs-section-title: var(--text-section-title);--fs-card-title: clamp(1rem, 1.4vw, 1.15rem);--fs-body: var(--text-body);--fs-label: var(--text-meta);--fs-btn: var(--text-nav);--fs-lead: var(--text-lead);--fs-nav: var(--text-nav);--radius-pill: 999px;--radius-card: 24px;--card-pad: 30px;--card-pad-mobile: 23px;--btn-h: 52px;--btn-h-mobile: 48px;--btn-px: 26px;--container-max: 1160px;--section-py: 120px;--section-py-mobile: 80px;--grid-gap: 28px;--text-max: 620px;--ease-standard: cubic-bezier(.22, .61, .36, 1);--t-hover: .22s;--t-entrance: .52s}.text-lavender{color:var(--color-lavender)}.text-cream{color:var(--color-cream)}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.65;cursor:none;overflow-x:hidden}h1,h2,h3,h4,h5{font-family:var(--font-display)}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}::selection{background:#ffffffe6;color:#080808}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:2px}.section{padding:var(--section-py) 0;position:relative}.container{max-width:var(--container-max);margin:0 auto;padding:0 40px}.section-label{font-family:var(--font-body);font-size:var(--fs-label);font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--color-lavender);margin-bottom:16px;display:flex;align-items:center;gap:12px}.section-label:before{content:"";display:block;width:28px;height:1px;background:var(--color-lavender);flex-shrink:0}.section-title{font-size:var(--fs-section-title);font-weight:700;line-height:1.05;color:var(--text);margin-bottom:20px;letter-spacing:-1px}#noise-overlay{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.07;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='256' height='256'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.62' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='256' height='256' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;mix-blend-mode:soft-light}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;border-radius:999px;border:1px solid rgba(243,233,216,.5);color:var(--color-cream);background:transparent;font-family:var(--font-body);font-size:var(--fs-btn);font-weight:600;letter-spacing:.4px;cursor:none;text-decoration:none;transition:border-color .22s var(--ease-standard),color .22s var(--ease-standard),box-shadow .22s var(--ease-standard),gap .22s var(--ease-standard)}.btn:hover{border-color:var(--color-lavender);color:var(--color-lavender);box-shadow:0 0 0 3px #a891c41a;gap:12px}.btn svg{flex-shrink:0;transition:transform .22s var(--ease-standard)}.btn:hover svg{transform:translate(3px)}.tag{display:inline-block;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:500;letter-spacing:.5px;background:#ffffff0a;color:#ffffffb3;border:1px solid rgba(255,255,255,.1)}.tag-olive,.tag-lavender{background:#a891c414;color:var(--color-lavender);border-color:#a891c433}.ui-card{border-radius:var(--radius-card);padding:var(--card-pad);background:#101012d9;border:1px solid rgba(255,255,255,.07);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform var(--t-hover) var(--ease-standard),border-color var(--t-hover) var(--ease-standard),box-shadow var(--t-hover) var(--ease-standard)}.ui-card:hover{transform:translateY(-2px);border-color:#a891c42e;box-shadow:0 14px 36px #00000080,0 0 0 1px #a891c414,0 0 22px #a891c40f,inset 0 1px #ffffff0d}.ui-body{font-size:var(--fs-body);color:#f3e9d894;line-height:1.72;max-width:var(--text-max)}.ui-pill-link{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:#ffffff9e;border:none;background:none;padding:0;min-height:unset;border-radius:0;text-decoration:none;transition:color var(--t-hover) var(--ease-standard),gap var(--t-hover) var(--ease-standard)}.ui-pill-link svg{flex-shrink:0;transition:transform var(--t-hover) var(--ease-standard)}.ui-pill-link:hover{color:var(--color-lavender);background:none;box-shadow:none;transform:none;gap:10px}.ui-pill-link:hover svg{transform:translate(3px)}.projects-editorial-list{display:flex;flex-direction:column}.wrapper{position:relative;width:100%;min-height:680px;overflow:hidden}.wrapper__bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;background-attachment:fixed;background-repeat:no-repeat;background-color:#0a0a0b;z-index:0;opacity:0;transition:opacity 1.4s cubic-bezier(.22,.61,.36,1)}.wrapper.is-revealed .wrapper__bg{opacity:1}.wrapper__gradient{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,#000000fa,#000000eb,#000000b8 48%,#00000057,#00000014),linear-gradient(to right,rgba(0,0,0,.92) 0%,rgba(0,0,0,.76) 24%,rgba(0,0,0,.42) 52%,transparent 78%);pointer-events:none}.wrapper__content{position:absolute;bottom:0;left:0;right:0;padding:52px 72px;z-index:2;opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.22,.61,.36,1) .22s,transform .8s cubic-bezier(.22,.61,.36,1) .22s}.wrapper.is-revealed .wrapper__content{opacity:1;transform:translateY(0)}.editorial-divider{width:48px;height:1px;background:#ffffff1f;margin-bottom:28px}.editorial-meta{display:flex;flex-wrap:wrap;align-items:center;margin-bottom:18px}.editorial-meta-dot{margin:0 10px;color:#ffffff2e;font-size:.65rem}.editorial-meta-tag{font-family:var(--font-body);font-size:.67rem;font-weight:500;color:#a891c4b8;letter-spacing:.1em;text-transform:uppercase}.editorial-title{font-family:var(--font-display);font-size:var(--text-card-title);font-weight:700;color:var(--color-cream);margin-bottom:16px;letter-spacing:-1.5px;line-height:1.02}.editorial-desc{font-family:var(--font-body);font-size:var(--text-body);color:#f3e9d88c;line-height:1.68;font-weight:300;max-width:480px;margin-bottom:40px}.editorial-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.editorial-stack{font-family:var(--font-body);font-size:.67rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;line-height:1;margin:0}.editorial-actions{display:flex;gap:10px;align-items:center;flex-shrink:0}@media(prefers-reduced-motion:reduce){.wrapper,.wrapper__bg,.wrapper__content,.wrapper .editorial-actions{opacity:1!important;transform:none!important;transition:none!important}}.project-feature-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:999px;border:1px solid rgba(243,233,216,.28);background:transparent;color:#f3e9d8b8;font-family:var(--font-body);font-size:.79rem;font-weight:500;letter-spacing:.03em;cursor:pointer;text-decoration:none;transition:border-color .22s var(--ease-standard),color .22s var(--ease-standard),box-shadow .22s var(--ease-standard),gap .22s var(--ease-standard)}.project-feature-btn svg{flex-shrink:0;transition:transform .22s var(--ease-standard)}.project-feature-btn:hover{border-color:var(--color-lavender);color:var(--color-lavender);box-shadow:0 0 0 2px #a891c41a;gap:10px;background:none}.project-feature-btn:hover svg{transform:translate(2px,-2px)}.project-feature-btn--primary{border-color:#f3e9d873;color:var(--color-cream);font-weight:600}.project-feature-btn--primary:hover{border-color:var(--color-lavender);color:var(--color-lavender);box-shadow:0 0 0 2px #a891c41a;gap:10px;background:none}.project-feature-btn--primary:hover svg{transform:translate(2px,-2px)}@media(max-width:900px){.section{padding:var(--section-py-mobile) 0}.container{padding:0 20px}.ui-card{padding:var(--card-pad-mobile)}.wrapper{min-height:unset;overflow:hidden;border-radius:16px;border:1px solid rgba(255,255,255,.07);background:#0d0d0f;margin:0 20px 14px;opacity:0;transform:translateY(28px) scale(.984);transition:opacity .62s cubic-bezier(.22,.61,.36,1),transform .62s cubic-bezier(.22,.61,.36,1);box-shadow:0 2px 24px #00000080}.wrapper.is-revealed{opacity:1;transform:translateY(0) scale(1);box-shadow:0 4px 40px #0009,0 0 28px #80b0e80d}.wrapper.is-revealed:hover{border-color:#80b0e824;box-shadow:0 4px 40px #0009,0 0 28px #80b0e817}.wrapper__bg{position:relative;height:220px;background-attachment:scroll;background-size:cover;background-position:center 25%;opacity:0;transition:opacity .5s ease .12s}.wrapper.is-revealed .wrapper__bg{opacity:1}.wrapper__gradient{position:absolute;inset:0 0 auto;height:220px;background:linear-gradient(to bottom,transparent 30%,rgba(13,13,15,.5) 65%,rgba(13,13,15,.9) 100%)}.wrapper__content{position:relative;bottom:auto;background:transparent;padding:22px 22px 28px;opacity:0;transform:translateY(10px);transition:opacity .5s cubic-bezier(.22,.61,.36,1) .26s,transform .5s cubic-bezier(.22,.61,.36,1) .26s}.wrapper.is-revealed .wrapper__content{opacity:1;transform:translateY(0)}.wrapper .editorial-actions{opacity:0;transform:translateY(5px);transition:opacity .4s ease .44s,transform .4s ease .44s}.wrapper.is-revealed .editorial-actions{opacity:1;transform:translateY(0)}}@media(max-width:600px){.wrapper__bg,.wrapper__gradient{height:200px}.wrapper__content{padding:18px 18px 24px}.editorial-divider{margin-bottom:16px}.editorial-title{font-size:clamp(1.5rem,6.5vw,2rem);letter-spacing:-1px;margin-bottom:10px}.editorial-desc{font-size:.88rem;margin-bottom:22px}.editorial-bottom{flex-direction:column;align-items:flex-start;gap:12px}}@media(max-width:480px){.wrapper{margin:0 12px 12px;border-radius:14px}.wrapper__bg,.wrapper__gradient{height:178px}.wrapper__content{padding:16px 16px 20px}}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.97) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.project-modal-wrap{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1001;padding:24px;pointer-events:none}.project-modal{width:100%;max-width:1040px;max-height:86vh;border-radius:20px;display:flex;flex-direction:column;overflow:hidden;pointer-events:all;animation:modalIn .28s cubic-bezier(.22,.61,.36,1)}.project-modal-header{padding:28px 36px 22px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-shrink:0}.project-modal-header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.project-modal-body{overflow-y:auto;flex:1;padding:28px 36px 48px}.project-modal-snap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}.project-modal-2col{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}@media(max-width:900px){.project-modal{max-width:92vw;max-height:88vh}}@media(max-width:600px){.project-modal-wrap{padding:0}.project-modal{max-width:100%;max-height:100%;height:100%;border-radius:0}.project-modal-header{padding:20px 20px 16px;flex-direction:column;gap:12px}.project-modal-header-actions{width:100%;justify-content:space-between}.project-modal-body{padding:20px 20px 40px}.project-modal-snap-grid{grid-template-columns:1fr 1fr}.project-modal-2col{grid-template-columns:1fr}}.about-hero{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start;margin-bottom:clamp(56px,8vw,96px)}.about-portrait-wrap{position:relative;padding-top:38px;display:flex;justify-content:center;flex-shrink:0}.about-portrait-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-44%);width:85%;height:75%;background:radial-gradient(ellipse at 50% 30%,rgba(200,200,212,.13) 0%,transparent 66%);filter:blur(56px);pointer-events:none;z-index:0}.about-portrait{position:relative;z-index:1;width:100%;max-width:360px;height:auto;display:block}@media(max-width:960px){.about-hero{grid-template-columns:1fr;gap:40px}.about-portrait-wrap{padding-top:0;max-height:400px;overflow:hidden}.about-portrait{max-width:280px;object-fit:cover;object-position:top center}}@media(max-width:480px){.about-portrait-wrap{display:none}}.vibe-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.vibe-card{padding:20px 22px}@media(max-width:900px){.vibe-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.vibe-grid{grid-template-columns:1fr}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in-up{animation:fadeInUp .68s var(--ease-standard) both}.fade-in{animation:fadeIn .85s var(--ease-standard) both}@media(prefers-reduced-motion:reduce){.fade-in-up,.fade-in{animation:none}}.design-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}@media(max-width:600px){.design-gallery{grid-template-columns:1fr}}@media(hover:none)and (pointer:coarse){body{cursor:auto!important}a,button,[role=button]{cursor:pointer!important}input,textarea,select{font-size:max(16px,1em)!important}}.nav-hamburger{display:none}@media(max-width:768px){.nav-desktop-links{display:none!important}.nav-hamburger{display:flex!important}.nav-inner{padding-left:20px!important;padding-right:20px!important}}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:48px}}@media(max-width:768px){.hero-chip,.hero-spin-circle{display:none!important}}@media(max-width:400px){.project-modal-snap-grid{grid-template-columns:1fr!important}.project-modal-header{padding:16px!important}.project-modal-body{padding:16px 16px 36px!important}}@media(max-width:600px){.section-title{letter-spacing:-.5px}}@media(hover:none){.ui-card:hover{transform:none;box-shadow:none}}.skills-sticker-section{width:100%;padding:70px 24px 52px;display:flex;justify-content:center;align-items:center;position:relative;z-index:1}.skills-sticker{width:min(420px,78vw);height:auto;display:block;object-fit:contain;filter:drop-shadow(0 24px 38px rgba(0,0,0,.32));animation:stickerFloat 5s ease-in-out infinite}@keyframes stickerFloat{0%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-14px) rotate(1deg)}to{transform:translateY(0) rotate(-1deg)}}@media(max-width:768px){.skills-sticker-section{padding:52px 20px 42px}.skills-sticker{width:min(300px,84vw)}}#root{min-height:100vh}
