*{margin:0;padding:0;box-sizing:border-box;cursor:none!important}
:root{--bg:#1f1f1e;--fg:#b4b4b4;--muted:#777;--accent:#00a884;--font-heading:'Anton',Impact,'Arial Black',sans-serif;--font-body:'DM Sans',Helvetica,sans-serif;--ease:cubic-bezier(0.16,1,0.3,1);color-scheme:dark}
html{background:var(--bg);scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none}

/* CURSOR */
.cursor-blob{position:fixed;width:24px;height:24px;border-radius:50%;background:var(--accent);mix-blend-mode:difference;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:width .4s var(--ease),height .4s var(--ease)}
.cursor-blob.expand{width:80px;height:80px}
.home-hidden{opacity:0;pointer-events:none}

/* NAV */
nav{cursor:none!important;position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:space-between;align-items:center;padding:1.8rem 3vw;mix-blend-mode:difference;color:#fff}
.nav-logo{cursor:none!important;font-family:var(--font-heading);font-size:1rem;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;color:inherit}
.nav-links{display:flex;gap:2rem}
.nav-links a{cursor:none!important;color:inherit;text-decoration:none;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;opacity:.6;transition:opacity .3s}
.nav-links a:hover,.nav-links a.active{opacity:1}

/* HAMBURGER */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:none;background:none;border:none;padding:10px;z-index:1002}
.hamburger span{display:block;width:24px;height:2px;background:rgba(255,255,255,.9);transition:transform .3s var(--ease),opacity .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-menu{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:var(--font-heading);font-size:2.5rem;text-transform:uppercase;color:#fff;text-decoration:none;opacity:.7;transition:opacity .3s}
.mobile-menu a:hover{opacity:1}

/* HERO */
.hero{height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 3vw 8vh;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('../images/index-1.webp') center/cover no-repeat;transform:scale(1.04);transition:transform 8s ease-out}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,rgba(0,0,0,.12) 30%,transparent 55%)}
.hero-bg.loaded{transform:scale(1)}
.hero-title{position:relative;z-index:2;font-family:var(--font-heading);font-size:clamp(4rem,15vw,18rem);line-height:.85;text-transform:uppercase;letter-spacing:-.03em;color:#fff}
.hero-sub{position:relative;z-index:2;margin-top:2rem;font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.5);max-width:500px}
.hero-year{position:absolute;bottom:3vh;right:3vw;z-index:2;font-family:var(--font-heading);font-size:.8rem;letter-spacing:.15em;color:rgba(255,255,255,.4)}
.hero-scroll{position:absolute;bottom:3vh;left:3vw;z-index:2;font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.4);display:flex;align-items:center;gap:.8rem}
.hero-scroll .line{width:40px;height:1px;background:rgba(255,255,255,.4);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scaleX(1)}50%{transform:scaleX(.4)}}

/* PROJECTS */
.projects{padding:10vh 3vw 15vh}
.projects-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5rem}
.projects-label{font-family:var(--font-heading);font-size:clamp(3rem,8vw,8rem);text-transform:uppercase;line-height:1}
.projects-count{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-item{position:relative;overflow:hidden;cursor:none}
.grid-item a{cursor:none}
[data-h]{cursor:none}
.grid-item a{display:block;text-decoration:none;color:inherit}
.grid-item .img-wrap{overflow:hidden;aspect-ratio:4/3;background:#222}
.grid-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease),filter .6s;filter:grayscale(.15)}
.grid-item:hover img{transform:scale(1.06);filter:grayscale(0)}
.grid-item .meta{padding:1.2rem 0 2rem}
.grid-item .meta .cat{font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.grid-item .meta h3{color:#fff;font-family:var(--font-heading);font-size:clamp(1.4rem,2.5vw,2.2rem);text-transform:uppercase;margin-top:.3rem;line-height:1.1;transition:color .3s}
.grid-item:hover .meta h3{color:var(--accent)}
.grid-item.featured{grid-column:1/-1}
.grid-item.featured .img-wrap{aspect-ratio:16/7}

/* ABOUT STRIP */
.about-strip{padding:12vh 3vw;display:flex;gap:6vw;align-items:center;border-top:1px solid #2a2a2a}
.about-strip .big-text{color:#fff;flex:1;font-family:var(--font-heading);font-size:clamp(2rem,5vw,5rem);text-transform:uppercase;line-height:1.05}
.about-strip .big-text span{-webkit-text-stroke:1.5px #fff;color:transparent}
.about-strip .side{flex:0 0 35%;font-size:.85rem;line-height:1.8;color:#b4b4b4}
.about-strip .side a{display:inline-flex;align-items:center;gap:.6rem;margin-top:1.5rem;font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);text-decoration:none;transition:gap .3s var(--ease)}
.about-strip .side a:hover{gap:1.2rem}
.about-strip .side a .arr{width:25px;height:1px;background:var(--accent)}

/* CONTACT */
.contact{padding:12vh 3vw;border-top:1px solid #2a2a2a}
.contact-heading{font-family:var(--font-heading);font-size:clamp(4rem,12vw,14rem);text-transform:uppercase;line-height:.88}
.contact-heading a{color:#fff;text-decoration:none;transition:color .3s}
.contact-heading a:hover{color:var(--accent)}
.contact-row{display:flex;justify-content:space-between;margin-top:3rem;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.contact-row a{color:var(--muted);text-decoration:none;transition:color .3s}
.contact-row a:hover{color:#fff}

/* FOOTER */
footer{padding:2rem 3vw;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);border-top:1px solid #2a2a2a;display:flex;justify-content:space-between}
footer a{color:var(--muted);text-decoration:none;transition:color .3s}
footer a:hover{color:#fff}

/* REVEAL */
.reveal{opacity:1;transform:translateY(0)}
@media(min-width:769px){.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}}
.reveal.visible{opacity:1;transform:translateY(0)}

/* MOBILE */
@media(max-width:768px){
    *{cursor:auto!important}
    .cursor-blob{display:none!important}
    .hero-bg{background-image:url('../images/index-1-mobile.webp');background-position:center center}
    .hero{padding-bottom:30px}
    .chrome-mobile .hero{padding-bottom:80px}
    .hero-sub{margin-top:1rem}
    .hero-scroll{position:relative;bottom:auto;left:auto;margin-top:2rem}
    .reveal{opacity:1!important;transform:none!important}
    .nav-links{display:none}
    .hamburger{display:flex}
    .grid{grid-template-columns:1fr}
    .grid-item img{filter:none;transform:none}
    .grid-item:hover img{transform:none;filter:none}
    .grid-item:hover .meta h3{color:#fff}
    .grid-item.featured .img-wrap{aspect-ratio:4/3}
    .about-strip{flex-direction:column;gap:3rem}
    .about-strip .side{flex:none}
    .contact-row{flex-direction:column;gap:1rem}
    footer{flex-direction:column;gap:.5rem}
}
