@import url("https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Inter:wght@300;400;500&display=swap");*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }

/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--bg:#0a0a0a;--surface:#111;--border:#1e1e1e;--accent:#e8ff47;--text:#f0f0f0;--muted:#555;--subtle:#222}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Inter,sans-serif;font-weight:300;line-height:1.6;overflow-x:hidden}.font-syne{font-family:Syne,sans-serif!important}.font-inter{font-family:Inter,sans-serif!important}.bg-bg{background:var(--bg)!important}.bg-surface{background:var(--surface)!important}.bg-subtle{background:var(--subtle)!important}.bg-accent{background:var(--accent)!important}.border-border{border-color:var(--border)!important}.text-accent{color:var(--accent)!important}.text-muted{color:var(--muted)!important}.text-bg{color:var(--bg)!important}.cursor{width:8px;height:8px;background:var(--accent);border-radius:50%;z-index:9999}.cursor,.cursor-ring{position:fixed;pointer-events:none}.cursor-ring{width:36px;height:36px;border:1px solid rgba(232,255,71,.4);border-radius:50%;z-index:9998;transition:all .25s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.hero-animate-1{opacity:0;animation:fadeUp 1.2s .1s forwards}.hero-animate-2{opacity:0;animation:fadeUp .8s .2s forwards}.hero-animate-3{opacity:0;animation:fadeUp .8s .4s forwards}.hero-animate-4{opacity:0;animation:fadeUp .8s .55s forwards}.hero-animate-5{opacity:0;animation:fadeUp .8s .6s forwards}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:none}.marquee-track{display:flex;gap:48px;white-space:nowrap;animation:marquee 20s linear infinite}nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 48px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid transparent;transition:background .3s,border-color .3s}nav.scrolled{background:hsla(0,0%,4%,.92);backdrop-filter:blur(12px);border-color:var(--border)}.nav-logo{font-family:Syne,sans-serif;font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.nav-logo span{color:var(--accent)}.nav-links{display:flex;gap:32px;list-style:none}.nav-links a{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--text)}#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:120px 48px 96px;position:relative;overflow:hidden}.hero-bg-photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 30%;filter:blur(2px) brightness(.28) grayscale(30%);transform:scale(1.06)}.hero-vignette{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 90% 80% at 50% 50%,transparent 20%,hsla(0,0%,4%,.8) 100%)}.hero-grid{position:absolute;inset:0;z-index:2;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:80px 80px;opacity:.25;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,#000 30%,transparent 100%);mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,#000 30%,transparent 100%)}.hero-content{position:relative;z-index:3;display:flex;flex-direction:column;align-items:flex-end}.hero-tag{font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);margin-bottom:24px;text-align:right}.hero-title{font-family:Syne,sans-serif;font-size:clamp(3rem,7vw,7rem);font-weight:800;line-height:.92;letter-spacing:-.04em;margin-bottom:32px;text-align:right}.hero-title .outline{color:transparent;-webkit-text-stroke:1px hsla(0,0%,94%,.3)}.hero-title .dot{color:var(--accent)}.hero-desc{max-width:480px;font-size:.95rem;color:hsla(0,0%,94%,.6);line-height:1.7;margin-bottom:32px;text-align:right}.hero-buttons{gap:16px;flex-wrap:wrap;justify-content:flex-end}.btn,.hero-buttons{display:flex;align-items:center}.btn{gap:12px;font-family:Syne,sans-serif;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;padding:16px 28px;text-decoration:none;transition:transform .2s,box-shadow .2s;cursor:pointer;border:none}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{box-shadow:0 12px 40px rgba(232,255,71,.25)}.btn-outline{background:transparent;color:var(--text);border:1px solid hsla(0,0%,94%,.2)}.btn svg{transition:transform .2s}.btn:hover svg{transform:translate(3px,-3px)}.marquee-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;padding:14px 0;background:var(--surface)}.marquee-item{font-family:Syne,sans-serif;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);display:flex;align-items:center;gap:16px}.marquee-item:after{content:"·";color:var(--accent)}.section{padding:120px 48px}.section-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.25em;color:var(--accent);margin-bottom:16px}.section-title{font-family:Syne,sans-serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:64px}#projects{border-top:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}@media (max-width:768px){.projects-grid{grid-template-columns:1fr;gap:16px}}.project-card{background:var(--bg);text-decoration:none;color:inherit;display:flex;flex-direction:column;overflow:hidden;transition:background .3s;position:relative;border:1px solid var(--border);border-radius:4px}.project-card:hover{background:var(--subtle)}.project-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}.project-card:hover:after{transform:scaleX(1)}.project-img-wrap{width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--subtle);position:relative}.project-img-wrap img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;transition:transform .5s ease,filter .3s;filter:brightness(.85)}.project-card:hover .project-img-wrap img{transform:scale(1.04);filter:brightness(1)}.project-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.15em}.project-body{padding:28px 32px 32px;flex:1;display:flex;flex-direction:column}.project-num{font-size:.7rem;color:var(--accent);letter-spacing:.15em;margin-bottom:10px}.project-name,.project-num{font-family:Syne,sans-serif}.project-name{font-size:1.25rem;font-weight:700;margin-bottom:8px;transition:color .2s}.project-card:hover .project-name{color:var(--accent)}.project-meta{font-size:.78rem;color:var(--muted);line-height:1.6;flex:1}.project-link{display:flex;align-items:center;gap:8px;margin-top:20px;font-family:Syne,sans-serif;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);transition:color .2s}.project-card:hover .project-link{color:var(--accent)}.project-link svg{transition:transform .2s}.project-card:hover .project-link svg{transform:translate(3px,-3px)}#skills{border-top:1px solid var(--border)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;background:var(--border);border:1px solid var(--border)}.skill-card{background:var(--bg);padding:40px;position:relative;overflow:hidden;transition:background .3s}.skill-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transition:transform .3s}.skill-card:hover{background:var(--subtle)}.skill-card:hover:before{transform:scaleX(1)}.skill-icon{font-size:1.8rem;margin-bottom:20px;display:block}.skill-name{font-family:Syne,sans-serif;font-size:1.1rem;font-weight:700;margin-bottom:10px}.skill-desc{font-size:.85rem;color:var(--muted);line-height:1.7}.skill-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px}.tag{font-size:.7rem;padding:4px 10px;border:1px solid var(--border);color:var(--muted);letter-spacing:.05em}#contact{border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;padding:120px 48px}.contact-big{font-family:Syne,sans-serif;font-size:clamp(2.5rem,5vw,4.5rem);font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:32px}.contact-big span{color:var(--accent)}.contact-email{font-family:Syne,sans-serif;font-size:1.1rem;font-weight:600;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:4px;transition:color .2s,border-color .2s}.contact-email:hover{color:var(--accent);border-color:var(--accent)}.contact-form{gap:20px}.contact-form,.form-group{display:flex;flex-direction:column}.form-group{gap:8px}.form-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}.form-input,.form-textarea{background:var(--surface);border:1px solid var(--border);padding:14px 18px;color:var(--text);font-family:Inter,sans-serif;font-size:.9rem;outline:none;transition:border-color .2s;resize:none}.form-input:focus,.form-textarea:focus{border-color:var(--accent)}.form-textarea{min-height:120px}.form-btn{background:var(--accent);color:var(--bg);font-family:Syne,sans-serif;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;padding:16px 28px;border:none;cursor:pointer;align-self:flex-start;transition:transform .2s,box-shadow .2s}.form-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(232,255,71,.25)}footer{border-top:1px solid var(--border);padding:32px 48px;display:flex;justify-content:space-between;align-items:center}.footer-copy{font-size:.75rem;color:var(--muted)}.social-links{display:flex;gap:24px}.social-links a{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);text-decoration:none;transition:color .2s}.social-links a:hover{color:var(--accent)}@media (max-width:768px){nav{padding:20px 24px}.nav-links{display:none}#hero{padding:100px 24px 80px}#contact,.section{padding:80px 24px}#contact{gap:48px}#contact,.projects-grid{grid-template-columns:1fr}footer{padding:24px;flex-direction:column;gap:16px;text-align:center}}.carousel-wrap{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--subtle)}.carousel-wrap.portrait{aspect-ratio:9/16;max-height:520px}.carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .5s ease;pointer-events:none}.carousel-slide.active{opacity:1;pointer-events:auto}.carousel-slide img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;filter:brightness(.85);transition:filter .3s}.project-card:hover .carousel-slide.active img{filter:brightness(1)}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:hsla(0,0%,4%,.7);border:1px solid rgba(232,255,71,.3);color:#e8ff47;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s;backdrop-filter:blur(4px)}.carousel-btn:hover{background:rgba(232,255,71,.15);border-color:rgba(232,255,71,.8)}.carousel-btn.prev{left:10px}.carousel-btn.next{right:10px}.carousel-dots{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10}.carousel-dot{width:6px;height:6px;border-radius:50%;background:hsla(0,0%,94%,.3);border:none;cursor:pointer;transition:background .2s,transform .2s;padding:0}.carousel-dot.active{background:#e8ff47;transform:scale(1.3)}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:32px}@media (max-width:900px){.pricing-grid{grid-template-columns:1fr}}.pricing-card{background:var(--bg);padding:40px 36px 36px;display:flex;flex-direction:column;gap:0;position:relative;transition:background .3s;overflow:hidden}.pricing-card--hovered,.pricing-card:hover{background:var(--subtle)}.pricing-card--accent{background:var(--surface)}.pricing-card--accent.pricing-card--hovered,.pricing-card--accent:hover{background:#161616}.pricing-top-bar{position:absolute;top:0;left:0;right:0;height:2px;background:var(--border);transform:scaleX(0);transform-origin:left;transition:transform .35s ease,background .35s}.pricing-card--accent .pricing-top-bar,.pricing-card:hover .pricing-top-bar{transform:scaleX(1);background:var(--accent)}.pricing-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:28px}.pricing-num{font-family:Syne,sans-serif;font-size:.7rem;font-weight:600;color:var(--accent);letter-spacing:.15em;line-height:1.8;flex-shrink:0}.pricing-title{font-family:Syne,sans-serif;font-size:1.15rem;font-weight:800;letter-spacing:-.02em;color:var(--text);line-height:1.2}.pricing-subtitle{font-size:.78rem;color:var(--muted);margin-top:3px;letter-spacing:.04em}.pricing-price-block{margin-bottom:24px}.pricing-from{font-size:.68rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);display:block;margin-bottom:6px}.pricing-range{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.pricing-value{font-family:Syne,sans-serif;font-size:1.7rem;font-weight:800;color:var(--accent);letter-spacing:-.03em;line-height:1}.pricing-sep{font-family:Syne,sans-serif;font-size:1rem;color:var(--muted)}.pricing-value-to{font-family:Syne,sans-serif;font-size:1.15rem;font-weight:700;color:hsla(0,0%,94%,.45);letter-spacing:-.02em}.pricing-divider{height:1px;background:var(--border);margin-bottom:24px}.pricing-features{list-style:none;display:flex;flex-direction:column;gap:13px;flex:1;margin-bottom:32px}.pricing-feature-item{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;line-height:1.5}.pricing-feature-icon{color:var(--accent);font-size:.65rem;margin-top:3px;flex-shrink:0}.pricing-feature-label{font-family:Syne,sans-serif;font-weight:600;font-size:.8rem;color:var(--text)}.pricing-feature-desc{color:var(--muted);font-size:.8rem}.pricing-cta{display:inline-flex;align-items:center;gap:10px;font-family:Syne,sans-serif;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;text-decoration:none;color:var(--muted);border:1px solid var(--border);padding:13px 20px;transition:color .2s,border-color .2s,transform .2s;align-self:flex-start}.pricing-cta:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-2px)}.pricing-cta svg{transition:transform .2s}.pricing-cta:hover svg{transform:translate(3px,-3px)}.pricing-cta--accent{background:var(--accent);color:var(--bg);border-color:var(--accent)}.pricing-cta--accent:hover{color:var(--bg);box-shadow:0 8px 32px rgba(232,255,71,.2)}.pricing-hosting-banner{border:1px solid var(--border);background:var(--surface);position:relative;overflow:hidden}.pricing-hosting-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent)}.pricing-hosting-inner{padding:32px 40px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}.pricing-hosting-left{display:flex;align-items:flex-start;gap:20px;flex:1;min-width:240px}.pricing-hosting-icon{font-size:1.5rem;color:var(--accent);line-height:1;margin-top:2px;flex-shrink:0}.pricing-hosting-title{font-family:Syne,sans-serif;font-size:1rem;font-weight:800;letter-spacing:-.01em;margin-bottom:6px;color:var(--text)}.pricing-hosting-title em{color:var(--accent);font-style:normal}.pricing-hosting-desc{font-size:.83rem;color:var(--muted);line-height:1.65;max-width:520px}@media (max-width:600px){.pricing-hosting-inner{padding:24px;flex-direction:column}.pricing-card{padding:32px 24px}}