*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--black: #0a0a0a;--white: #f5f4f0;--gray: #7a7a7a;--light: #ebebeb;--accent: #c8b89a;--serif: "DM Serif Display", Georgia, serif;--sans: "DM Sans", sans-serif}html{scroll-behavior:smooth}body{background:var(--white);color:var(--black);font-family:var(--sans);font-weight:300;overflow-x:hidden;cursor:none}@media(max-width:900px){body{cursor:auto}#cur-dot,#cur-ring{display:none}}nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 3rem;background:#f5f4f0d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s}nav.site-nav.scrolled{border-color:var(--light)}.logo{font-family:var(--serif);font-size:1.4rem;letter-spacing:-.02em;color:var(--black);text-decoration:none}.logo span{color:var(--gray);font-style:italic}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{font-size:.8rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;color:var(--gray);transition:color .2s;position:relative}.nav-links a:hover,.nav-links a.active{color:var(--black)}.nav-links a.active:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:3px;height:3px;border-radius:50%;background:var(--accent)}.nav-cta{font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;color:var(--white);background:var(--black);padding:.6rem 1.4rem;border-radius:2px;transition:background .2s,color .2s;position:relative;overflow:hidden}.nav-cta:hover{background:var(--accent);color:var(--black)}#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;padding:5rem 3rem 0;position:relative;overflow:hidden}.hero-left{display:flex;flex-direction:column;justify-content:center;padding-right:4rem;animation:fadeUp .9s ease both}.hero-tag{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.hero-tag:before{content:"";display:block;width:2rem;height:1px;background:var(--accent)}h1{font-family:var(--serif);font-size:clamp(3rem,6vw,5.5rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:1.5rem}h1 em{font-style:italic;color:var(--gray)}.hero-sub{font-size:1rem;color:var(--gray);line-height:1.7;max-width:36ch;margin-bottom:2.5rem}.hero-actions{display:flex;gap:1rem;align-items:center}.btn-primary{font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;color:var(--white);background:var(--black);padding:.9rem 2rem;border-radius:2px;transition:background .2s,color .2s;position:relative;overflow:hidden}.btn-primary:hover{background:var(--accent);color:var(--black)}.btn-ghost{font-size:.8rem;font-weight:400;letter-spacing:.08em;text-decoration:none;color:var(--gray);display:flex;align-items:center;gap:.5rem;transition:color .2s}.btn-ghost:hover{color:var(--black)}.btn-ghost:after{content:"→";transition:transform .2s}.btn-ghost:hover:after{transform:translate(4px)}.hero-right{display:flex;align-items:center;justify-content:center;position:relative;animation:fadeUp .9s .15s ease both}.hero-visual{width:100%;max-width:480px;aspect-ratio:3/4;background:var(--black);border-radius:4px;position:relative;overflow:hidden;transition:transform .6s cubic-bezier(.16,1,.3,1)}.hero-visual:hover{transform:translateY(-6px) scale(1.01)}.hero-visual:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#1a1a1a,#0a0a0a 60%),repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(200,184,154,.04) 40px,rgba(200,184,154,.04) 41px),repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(200,184,154,.04) 40px,rgba(200,184,154,.04) 41px)}.hero-visual-inner{position:absolute;top:2rem;right:2rem;bottom:2rem;left:2rem;display:flex;flex-direction:column;justify-content:flex-end;gap:.5rem}.code-line{height:2px;background:#c8b89a4d;border-radius:1px;animation:expandWidth 1s ease both}.code-line:nth-child(1){width:65%;animation-delay:.6s}.code-line:nth-child(2){width:80%;animation-delay:.75s}.code-line:nth-child(3){width:50%;animation-delay:.9s}.code-line:nth-child(4){width:90%;animation-delay:1.05s}.code-line:nth-child(5){width:40%;animation-delay:1.2s}.code-line:nth-child(6){width:70%;animation-delay:1.35s}.code-line:nth-child(7){width:55%;animation-delay:1.5s}.visual-badge{position:absolute;top:2rem;right:2rem;background:var(--white);padding:.75rem 1rem;border-radius:2px;font-size:.7rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--black);animation:fadeUp .6s 1.2s ease both}.avail-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#22c55e;margin-right:.5rem;animation:dotPulse 2s ease-in-out infinite;vertical-align:middle}.avail-dot.unavailable{background:var(--gray);animation:none}.hero-stats{position:absolute;bottom:3rem;left:3rem;display:flex;gap:3rem;animation:fadeUp .6s .5s ease both}.stat-item{display:flex;flex-direction:column;gap:.2rem}.stat-num{font-family:var(--serif);font-size:2rem;letter-spacing:-.02em;transition:color .3s}.stat-item:hover .stat-num{color:var(--accent)}.stat-label{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray)}section{padding:6rem 3rem}.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--light)}.section-tag{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.5rem);line-height:1.1;letter-spacing:-.02em}h2 em{font-style:italic;color:var(--gray)}#services{background:var(--white)}.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--light)}.service-card{padding:2.5rem 2rem;border-right:1px solid var(--light);transition:background .35s cubic-bezier(.16,1,.3,1);cursor:default}.service-card:last-child{border-right:none}.service-card:hover{background:var(--black)}.service-card:hover .service-icon,.service-card:hover .service-title,.service-card:hover .service-desc{color:var(--white)}.service-card:hover .service-num{color:#ffffff26}.service-num{font-family:var(--serif);font-size:3rem;color:var(--light);line-height:1;margin-bottom:1.5rem;transition:color .25s}.service-icon{font-size:1.5rem;margin-bottom:1rem;transition:color .25s}.service-title{font-family:var(--serif);font-size:1.2rem;margin-bottom:.75rem;transition:color .25s}.service-desc{font-size:.82rem;color:var(--gray);line-height:1.7;transition:color .25s}#portfolio{background:var(--black);color:var(--white)}#portfolio .section-tag,#portfolio h2 em{color:var(--accent)}#portfolio .section-header{border-color:#ffffff14}.portfolio-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5px;background:#ffffff0d}.project-card{background:var(--black);padding:2.5rem;display:flex;flex-direction:column;gap:1rem;cursor:pointer;position:relative;overflow:hidden;transition:background .25s,transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s cubic-bezier(.16,1,.3,1)}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.project-card:hover:before{transform:scaleX(1)}.project-card:hover{background:#111;transform:translateY(-4px);box-shadow:0 20px 60px #0006}.project-thumb{width:100%;aspect-ratio:16/9;background:#1a1a1a;border-radius:2px;margin-bottom:.5rem;overflow:hidden;position:relative}.project-meta{display:flex;align-items:center;justify-content:space-between}.project-type{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent)}.project-year{font-size:.65rem;color:#ffffff4d}.project-name{font-family:var(--serif);font-size:1.5rem;letter-spacing:-.01em}.project-desc{font-size:.82rem;color:#ffffff80;line-height:1.7}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.tag{font-size:.65rem;letter-spacing:.08em;padding:.3rem .7rem;border:1px solid rgba(255,255,255,.1);border-radius:1px;color:#fff6}#about{background:var(--accent);padding:5rem 3rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}#about h2{color:var(--black)}#about h2 em{color:#0006}.about-text{font-size:.95rem;line-height:1.8;color:#000000a6}.about-list{list-style:none;display:flex;flex-direction:column;gap:1rem}.about-list li{font-size:.82rem;color:#0009;padding-left:1.25rem;position:relative}.about-list li:before{content:"→";position:absolute;left:0;color:#00000059}#contact{background:var(--white);display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}.contact-left h2{margin-bottom:1rem}.contact-sub{font-size:.9rem;color:var(--gray);line-height:1.7;margin-bottom:2.5rem}.contact-info{display:flex;flex-direction:column;gap:1.2rem}.contact-item{display:flex;flex-direction:column;gap:.2rem}.contact-item-label{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray)}.contact-item-val{font-size:.9rem;color:var(--black);text-decoration:none}.contact-item-val:hover{text-decoration:underline;text-underline-offset:3px}.contact-form{display:flex;flex-direction:column;gap:1.2rem}.form-group{display:flex;flex-direction:column;gap:.4rem;position:relative}.form-group label{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray)}.form-group input,.form-group textarea,.form-group select{font-family:var(--sans);font-size:.88rem;font-weight:300;color:var(--black);background:transparent;border:1px solid var(--light);border-radius:2px;padding:.85rem 1rem;outline:none;transition:border-color .2s;resize:none}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--black);box-shadow:0 2px 0 0 var(--accent)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-submit{font-family:var(--sans);font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--white);background:var(--black);border:none;padding:1rem 2rem;border-radius:2px;cursor:pointer;transition:background .2s;align-self:flex-start;position:relative;overflow:hidden}.btn-submit:hover{background:var(--accent);color:var(--black)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.form-success{padding:1rem;background:#22c55e14;border:1px solid rgba(34,197,94,.2);border-radius:2px;font-size:.82rem;color:#166534}footer{background:var(--black);color:#fff6;padding:2rem 3rem;display:flex;align-items:center;justify-content:space-between;font-size:.72rem;letter-spacing:.08em}.footer-logo{font-family:var(--serif);font-size:1rem;color:var(--white);text-decoration:none}.footer-links{display:flex;gap:2rem}.footer-links a{color:#fff6;text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--white)}.marquee-strip{overflow:hidden;border-top:1px solid var(--light);border-bottom:1px solid var(--light);padding:.85rem 0;background:var(--white);-webkit-user-select:none;user-select:none}.marquee-inner{display:flex;width:max-content;animation:marqueeTick 28s linear infinite}.marquee-inner:hover{animation-play-state:paused}.marquee-item{font-size:.68rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);padding:0 2.5rem;white-space:nowrap}.marquee-item span{color:var(--accent);margin-right:2.5rem;font-size:.55rem}#progress-bar{position:fixed;top:0;left:0;z-index:9000;height:2px;background:var(--accent);width:0%;transition:width .1s linear;pointer-events:none}#loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--black);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}#loader.done{animation:loaderOut .6s .2s cubic-bezier(.76,0,.24,1) forwards}.loader-logo{font-family:var(--serif);font-size:1.6rem;color:var(--white);letter-spacing:-.02em}.loader-logo span{color:var(--accent);font-style:italic}.loader-track{width:160px;height:1px;background:#ffffff1f;border-radius:1px;overflow:hidden}.loader-bar{height:100%;background:var(--accent);animation:loaderBarFill .9s cubic-bezier(.76,0,.24,1) forwards}#cur-dot{position:fixed;z-index:8000;width:8px;height:8px;border-radius:50%;background:var(--black);pointer-events:none;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,opacity .25s;mix-blend-mode:multiply}#cur-ring{position:fixed;z-index:7999;width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(10,10,10,.35);pointer-events:none;transform:translate(-50%,-50%);transition:width .45s cubic-bezier(.16,1,.3,1),height .45s cubic-bezier(.16,1,.3,1),border-color .3s}body.cursor-hover #cur-dot{width:48px;height:48px;background:var(--accent);opacity:.18}body.cursor-hover #cur-ring{border-color:#0a0a0a99;width:10px;height:10px}body.cursor-dark #cur-dot{background:var(--white)}body.cursor-dark #cur-ring{border-color:#fff6}.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:none}.reveal-delay-1{transition-delay:.08s}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes expandWidth{0%{width:0!important;opacity:0}to{opacity:1}}@keyframes loaderOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%);pointer-events:none}}@keyframes loaderBarFill{0%{width:0}to{width:100%}}@keyframes marqueeTick{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}@media(max-width:900px){nav.site-nav{padding:1.2rem 1.5rem}.nav-links{display:none}#hero{grid-template-columns:1fr;padding:6rem 1.5rem 3rem}.hero-right{display:none}.hero-stats{position:static;margin-top:3rem}section{padding:4rem 1.5rem}.services-grid{grid-template-columns:1fr 1fr}.service-card{border-right:none;border-bottom:1px solid var(--light)}.portfolio-grid{grid-template-columns:1fr}#about{grid-template-columns:1fr;gap:2rem;padding:4rem 1.5rem}#contact{grid-template-columns:1fr;gap:3rem}.form-row{grid-template-columns:1fr}footer{flex-direction:column;gap:1rem;text-align:center}.footer-links{flex-wrap:wrap;justify-content:center}}
