*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0b;--bg-card: #111114;--bg-card-hover: #16161a;--fg: #ece9e3;--fg-muted: #a8a49c;--fg-dim: #6b6762;--accent-rose: #d4576a;--accent-rose-light: #e87a8a;--accent-rose-glow: rgba(212, 87, 106, .15);--accent-blue: #4a7fa8;--accent-blue-light: #6ba3cc;--accent-purple: #7a5fa8;--border: rgba(255,255,255,.07);--border-hover: rgba(255,255,255,.14);--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", "Courier New", monospace;--radius: 3px;--transition: .35s cubic-bezier(.25, .46, .45, .94);--transition-fast: .18s cubic-bezier(.25, .46, .45, .94)}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--fg);font-family:var(--font-body);font-weight:400;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:var(--accent-rose);color:#fff}img{display:block;max-width:100%;height:auto}a{color:inherit;text-decoration:none}#cursor-dot,#cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%);transition:opacity .3s}#cursor-dot{width:6px;height:6px;background:var(--accent-rose);transition:transform .1s,opacity .3s}#cursor-ring{width:32px;height:32px;border:1px solid rgba(212,87,106,.5);transition:transform .25s cubic-bezier(.25,.46,.45,.94),opacity .3s}body.cursor-hover #cursor-ring{transform:translate(-50%,-50%) scale(1.6)}@media(pointer:coarse){#cursor-dot,#cursor-ring{display:none}}#nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background var(--transition),backdrop-filter var(--transition);border-bottom:1px solid transparent}#nav.scrolled{background:#0a0a0bd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom-color:var(--border)}.nav-inner{max-width:1280px;margin:0 auto;padding:0 40px;height:64px;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--font-display);font-size:1.4rem;font-weight:500;letter-spacing:.05em;color:var(--fg);cursor:pointer;display:inline-flex;align-items:baseline}.nav-logo-r{color:var(--fg)}.nav-logo-l{color:var(--accent-rose);font-style:italic}.nav-links{display:flex;gap:40px;align-items:center}.nav-link{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#a8a49c;transition:color var(--transition-fast);position:relative}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;right:100%;height:1px;background:var(--accent-rose);transition:right var(--transition-fast)}.nav-link:hover{color:var(--fg)}.nav-link:hover:after{right:0}.nav-menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}.nav-menu-btn span{display:block;width:22px;height:1px;background:var(--fg);transition:transform var(--transition-fast),opacity var(--transition-fast)}.nav-menu-btn.open span:first-child{transform:rotate(45deg) translate(4px,4px)}.nav-menu-btn.open span:last-child{transform:rotate(-45deg) translate(4px,-4px)}#mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:40px;opacity:0;pointer-events:none;transition:opacity var(--transition)}#mobile-menu.open{opacity:1;pointer-events:all}.mobile-link{font-family:var(--font-display);font-size:3rem;font-weight:300;color:var(--fg);letter-spacing:.03em;transition:color var(--transition-fast)}.mobile-link:hover{color:var(--accent-rose)}.section-inner{max-width:1280px;margin:0 auto;padding:120px 40px}.section-label{display:flex;align-items:center;gap:16px;margin-bottom:60px}.label-line{width:40px;height:1px;background:var(--accent-rose)}.section-label span{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-rose)}#hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;padding:0}.hero-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 0%,transparent 100%);mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 0%,transparent 100%)}.hero-bg-glow{position:absolute;width:700px;height:700px;background:radial-gradient(ellipse,rgba(212,87,106,.08) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none}.hero-inner{max-width:1280px;margin:0 auto;padding:140px 40px 80px;position:relative;z-index:1}.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:32px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#a8a49c}.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-rose);animation:pulse 2.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.hero-name{font-family:var(--font-display);font-weight:300;margin-bottom:40px;display:inline-flex;align-items:baseline;gap:.15em;flex-wrap:wrap;line-height:.9}.hero-name-first{display:block;font-size:clamp(4rem,10vw,9rem);letter-spacing:-.02em;color:var(--fg)}.hero-name-last{display:block;font-size:clamp(4rem,10vw,9rem);letter-spacing:-.02em;color:var(--accent-rose);font-style:italic}.hero-tagline{font-size:clamp(1rem,1.6vw,1.25rem);line-height:1.7;color:#b8b4ac;max-width:560px;margin-bottom:48px}.hero-tagline em{color:var(--fg);font-style:italic;font-family:var(--font-display);font-size:1.1em}.hero-cta-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:80px}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--accent-rose);color:#fff;font-size:.82rem;font-family:var(--font-body);font-weight:400;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:var(--radius);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.btn-primary:hover{background:var(--accent-rose-light);transform:translateY(-2px);box-shadow:0 8px 30px #d4576a59}.btn-primary.btn-full{width:100%;justify-content:center}.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:13px 32px;background:transparent;color:var(--fg);font-size:.82rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--border-hover);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.btn-ghost:hover{border-color:var(--accent-rose);color:var(--accent-rose);transform:translateY(-2px)}.hero-marquee-wrap{position:absolute;bottom:0;left:0;right:0;overflow:hidden;border-top:1px solid var(--border);background:#ffffff04;padding:12px 0}.hero-marquee{display:flex;gap:24px;width:max-content;animation:marquee 35s linear infinite;white-space:nowrap}.hero-marquee span{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-muted)}.hero-marquee span:nth-child(2n){color:#908c88}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}#about{background:var(--bg)}.about-layout{display:grid;grid-template-columns:280px 1fr;gap:80px;align-items:start}.about-skills{margin-top:40px;display:flex;flex-direction:column;gap:20px}.skill-group-title{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px}[data-color=rose] .skill-group-title{color:var(--accent-rose)}[data-color=blue] .skill-group-title{color:var(--accent-blue-light)}[data-color=purple] .skill-group-title{color:var(--accent-purple)}[data-color=grey] .skill-group-title{color:var(--fg-muted)}.skill-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{padding:3px 10px;background:#ffffff0a;border:1px solid var(--border);border-radius:2px;font-size:.72rem;color:#a8a49c;font-family:var(--font-body);transition:border-color var(--transition-fast),color var(--transition-fast)}.tag:hover{border-color:var(--border-hover);color:var(--fg)}.about-text-col{padding-top:0}.about-headline{font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4.5rem);font-weight:300;line-height:1.1;letter-spacing:-.01em;color:var(--fg);margin-bottom:36px}.about-headline em{font-style:italic;color:var(--accent-rose)}.about-body{display:flex;flex-direction:column;gap:20px;font-size:1rem;line-height:1.8;color:#b8b4ac;font-weight:400;max-width:560px;margin-bottom:40px}.about-availability{display:flex;align-items:center;gap:10px;padding:12px 20px;border:1px solid rgba(212,87,106,.25);border-radius:var(--radius);background:#d4576a0a;width:fit-content;margin-bottom:20px}.avail-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-rose);animation:pulse 2.5s ease-in-out infinite;flex-shrink:0}.about-availability span{font-size:.78rem;font-family:var(--font-mono);letter-spacing:.08em;color:var(--accent-rose)}.about-sub{font-size:.88rem;color:#9e9a92;line-height:1.7;max-width:480px}#projects{background:var(--bg)}.projects-headline{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.5rem);font-weight:300;color:var(--fg);margin-bottom:80px;letter-spacing:-.01em}.project-card{display:grid;grid-template-columns:220px 1fr;gap:60px;padding:60px 0;border-top:1px solid var(--border);position:relative;transition:all var(--transition)}.project-card:last-child{border-bottom:1px solid var(--border)}.project-card:before{content:"";position:absolute;left:-40px;right:-40px;top:0;bottom:0;background:transparent;transition:background var(--transition);pointer-events:none;border-radius:2px}.project-card:hover:before{background:#ffffff03}.project-meta-col{display:flex;flex-direction:column;gap:24px}.project-number{font-family:var(--font-display);font-size:4rem;font-weight:300;color:#7a7672;line-height:1;letter-spacing:-.03em;font-style:italic}.project-tags{display:flex;flex-wrap:wrap;gap:5px}.ptag{padding:3px 8px;border-radius:2px;font-size:.65rem;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.ptag-blue{background:#4a7fa81f;color:var(--accent-blue-light);border:1px solid rgba(74,127,168,.2)}.ptag-purple{background:#7a5fa81f;color:#a889d4;border:1px solid rgba(122,95,168,.2)}.ptag-rose{background:#d4576a1a;color:var(--accent-rose-light);border:1px solid rgba(212,87,106,.2)}.project-link{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-family:var(--font-mono);color:#a8a49c;letter-spacing:.1em;text-transform:uppercase;transition:color var(--transition-fast);margin-top:auto}.project-link:hover{color:var(--accent-rose)}.project-metrics{display:flex;flex-direction:column;gap:16px}.metric{display:flex;flex-direction:column;gap:2px}.metric-val{font-family:var(--font-display);font-size:1.25rem;font-weight:500;color:var(--fg);line-height:1.1;letter-spacing:-.01em}.metric-label{font-family:var(--font-mono);font-size:.6rem;color:#9e9a92;letter-spacing:.1em;text-transform:uppercase}.project-title{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:400;color:var(--fg);line-height:1.1;letter-spacing:-.01em;margin-bottom:8px}.project-subtitle{font-size:.88rem;color:#b0aca4;font-family:var(--font-body);font-weight:400;margin-bottom:28px;letter-spacing:.01em}.project-accordion{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.accordion-btn{background:none;border:none;cursor:pointer;padding:10px 0;margin-right:24px;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#9e9a92;position:relative;transition:color var(--transition-fast)}.accordion-btn:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:var(--accent-rose);transform:scaleX(0);transition:transform var(--transition-fast)}.accordion-btn.active{color:var(--fg)}.accordion-btn.active:after{transform:scaleX(1)}.accordion-btn:hover{color:var(--fg)}.accordion-content{display:none;font-size:.92rem;line-height:1.8;color:#b8b4ac;margin-bottom:32px;max-width:620px;animation:fadeIn .25s ease}.accordion-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.project-screenshots{margin-top:8px}.slider-wrapper{position:relative;border-radius:4px;border:1px solid var(--border);background:#0d0d10;box-shadow:0 0 0 1px #ffffff0a inset,0 12px 40px #00000080;overflow:hidden}.slider-wrapper:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse at center,transparent 60%,rgba(10,10,11,.22) 100%)}.screenshot-strip{position:relative;width:100%}.screenshot-item{display:none;width:100%}.screenshot-item.active{display:block}.screenshot-item img{width:100%;height:auto;max-height:520px;display:block;object-fit:contain;object-position:top center;filter:saturate(.9) brightness(.96);transition:filter .3s ease}.slider-wrapper:hover .screenshot-item img{filter:saturate(1) brightness(1)}.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:#0a0a0bb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--fg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);opacity:0}.slider-arrow svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.slider-arrow.prev{left:12px}.slider-arrow.next{right:12px}.slider-wrapper:hover .slider-arrow{opacity:1}.slider-arrow:hover{background:#d4576a33;border-color:var(--accent-rose);color:var(--accent-rose)}.slider-label{position:absolute;bottom:0;left:0;right:0;z-index:5;padding:28px 16px 12px;background:linear-gradient(to top,rgba(10,10,11,.75) 0%,transparent 100%);font-family:var(--font-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:#ece9e38c;pointer-events:none;opacity:0;transition:opacity .3s ease}.slider-wrapper:hover .slider-label{opacity:1}.slider-dots{display:flex;gap:6px;justify-content:center;margin-top:12px}.slider-dot{width:5px;height:5px;border-radius:50%;background:var(--border);border:none;cursor:pointer;padding:0;transition:all .3s ease}.slider-dot.active{background:var(--accent-rose);transform:scale(1.4)}.slider-dot:hover:not(.active){background:var(--fg-muted)}#contact{background:var(--bg-card);border-top:1px solid var(--border)}.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.contact-headline{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.8rem);font-weight:300;color:var(--fg);line-height:1.15;letter-spacing:-.01em;margin-bottom:20px}.contact-headline em{font-style:italic;color:var(--accent-rose)}.contact-body{font-size:.95rem;color:#b8b4ac;line-height:1.7;margin-bottom:36px}.contact-social{display:flex;gap:16px;flex-wrap:wrap}.social-link{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border:1px solid var(--border);border-radius:var(--radius);font-size:.78rem;font-family:var(--font-mono);color:#a8a49c;letter-spacing:.08em;transition:all var(--transition-fast)}.social-link:hover{border-color:var(--accent-rose);color:var(--accent-rose)}.contact-form{display:flex;flex-direction:column;gap:20px}.form-field{display:flex;flex-direction:column;gap:8px}.form-field label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:#a8a49c}.form-field input,.form-field textarea{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-family:var(--font-body);font-size:.92rem;color:var(--fg);transition:border-color var(--transition-fast),background var(--transition-fast);outline:none;resize:none}.form-field input::placeholder,.form-field textarea::placeholder{color:#6b6762}.form-field input:focus,.form-field textarea:focus{border-color:var(--accent-rose);background:#d4576a08}.form-success{font-size:.85rem;color:var(--accent-rose);font-family:var(--font-mono);text-align:center;padding:12px;border:1px solid rgba(212,87,106,.25);border-radius:var(--radius);background:#d4576a0d}.hidden{display:none!important}#footer{border-top:1px solid var(--border);padding:32px 40px}.footer-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer-logo{font-family:var(--font-display);font-size:1.1rem;font-weight:500;color:#a8a49c;margin-right:20px}.footer-copy{font-size:.75rem;color:#8a8680;font-family:var(--font-mono)}.footer-left{display:flex;align-items:center;gap:16px}.footer-back{font-size:.72rem;color:#8a8680;font-family:var(--font-mono);transition:color var(--transition-fast)}.footer-back:hover{color:var(--accent-rose)}.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}@media(max-width:1024px){.about-layout{grid-template-columns:1fr;gap:60px}.portrait-frame{width:200px}.project-card{grid-template-columns:160px 1fr;gap:40px}.contact-inner{grid-template-columns:1fr}}@media(max-width:768px){.nav-links{display:none}.nav-menu-btn,#mobile-menu{display:flex}.section-inner{padding:80px 24px}.hero-inner{padding:120px 24px 80px}.project-card{grid-template-columns:1fr;gap:24px}.project-meta-col{flex-direction:row;flex-wrap:wrap;align-items:center;gap:16px}.project-number{font-size:2.5rem}.project-metrics{flex-direction:row;flex-wrap:wrap;gap:20px}.nav-inner{padding:0 24px}#footer{padding:24px}.footer-inner{flex-direction:column;gap:12px;text-align:center}}@media(max-width:480px){.hero-cta-row{flex-direction:column}.btn-primary,.btn-ghost{width:100%;justify-content:center}}.hero-name,.hero-eyebrow,.hero-tagline,.hero-bg-glow,#about,#projects,#contact{will-change:transform}.project-card{transition:opacity .6s ease,box-shadow var(--transition-base)}.preload-webhook-1{background-image:url(rl-webhook-dashboard.png)}.preload-webhook-2{background-image:url(rl-webhook-notebook.png)}.preload-webhook-3{background-image:url(rl-webhook-semantic-model.png)}.preload-sql{background-image:url(rl-sql-dashboard.jpg)}.preload-rt-1{background-image:url(rl-resume-tailor-editor.png)}.preload-rt-2{background-image:url(rl-resume-tailor-ai.png)}.preload-rt-3{background-image:url(rl-resume-tailor-export.png)}.preload-ef-1{background-image:url(rl-echoflow-home.png)}.preload-ef-2{background-image:url(rl-echoflow-voice.png)}.preload-ef-3{background-image:url(rl-echoflow-processing.png)}
/*# sourceMappingURL=/cdn/shop/t/36/assets/portfolio-v2.css.map */
