/* FORCE LIGHT MODE — ignore device dark mode */
:root{
  color-scheme: light only;
  -webkit-color-scheme: light only;
  forced-color-adjust: none;
}
html{
  color-scheme: light only;
  background:#FAF8F5;
}
@media (prefers-color-scheme: dark){
  :root{
    color-scheme: light only !important;
  }
  html, body{
    background:#FAF8F5 !important;
    color:#1A1816 !important;
  }
}


/* ════════════════════════════════════
   STYLE: Marchisio-inspired
   White/cream + huge photography
   Massive whitespace, minimal type
════════════════════════════════════ */

:root{
  --bg: #FAF8F5;
  --bg2: #F2EFE8;
  --ink: #1A1816;
  --ink2: #6B6660;
  --ink3: #B8B2A8;
  --line: rgba(26,24,22,.10);
  --line2: rgba(26,24,22,.05);
  --acc: #1A1816;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Inter', sans-serif;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-weight:300;line-height:1.6;
  overflow-x:hidden;cursor:none;
  -webkit-font-smoothing:antialiased;
}

/* CURSOR */
#C,#CR{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;top:0;left:0}
#C{width:5px;height:5px;background:var(--ink)}
#CR{width:30px;height:30px;border:1px solid rgba(26,24,22,.4);transition:width .25s,height .25s,background .2s}
body.h #CR{width:60px;height:60px;background:rgba(26,24,22,.05)}

/* PAGES */
.pg{display:none;min-height:100vh}
.pg.on{display:block}

/* ═══════════════
   NAV — minimal sidebar style
═══════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;justify-content:space-between;align-items:center;
  padding:32px 48px;
  transition:padding .3s,background .3s;
}
#nav.sc{padding:20px 48px;background:rgba(250,248,245,.96);backdrop-filter:blur(16px);}

.nav-l{
  font-family:var(--serif);font-size:24px;letter-spacing:1px;
  color:var(--ink);text-decoration:none;font-weight:300;
  transition:color .4s;
}
.nav-l em{font-style:italic;font-weight:400}
.nav-hero .nav-l{color:#FFF}

.nav-toggle{
  background:none;border:none;cursor:none;
  display:flex;flex-direction:column;gap:5px;align-items:flex-end;
  color:var(--ink);transition:color .4s;
}
.nav-hero .nav-toggle{color:#FFF}
.nav-toggle span{
  display:block;width:28px;height:1px;background:currentColor;
  transition:transform .3s,width .3s;
}
.nav-toggle span:nth-child(2){width:18px}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg);width:28px}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);width:28px}

/* MENU OVERLAY */
#menu{
  position:fixed;inset:0;z-index:190;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;
  opacity:0;pointer-events:none;
  transition:opacity .5s;
  overflow:hidden;
}
#menu.open{opacity:1;pointer-events:auto}
.menu-list{
  list-style:none;text-align:center;
  display:flex;flex-direction:column;justify-content:center;
  gap:0;
}
.menu-list li{
  font-family:var(--serif);
  font-size:clamp(42px,6vw,88px);
  font-weight:300;line-height:1.15;
  opacity:0;transform:translateY(14px);
  transition:opacity .5s,transform .5s cubic-bezier(.16,1,.3,1);
}
#menu.open .menu-list li{opacity:1;transform:translateY(0)}
#menu.open .menu-list li:nth-child(1){transition-delay:.05s}
#menu.open .menu-list li:nth-child(2){transition-delay:.11s}
#menu.open .menu-list li:nth-child(3){transition-delay:.17s}
#menu.open .menu-list li:nth-child(4){transition-delay:.23s}
#menu.open .menu-list li:nth-child(5){transition-delay:.29s}

.menu-list a{
  color:var(--ink);text-decoration:none;cursor:none;
  display:inline-block;padding:4px 0;
  transition:letter-spacing .4s ease, color .3s;
}
.menu-list a:hover{
  letter-spacing:4px;
  color:var(--ink2);
}

/* Bottom info strip */
.menu-bottom{
  position:absolute;bottom:36px;left:48px;right:48px;
  display:flex;justify-content:space-between;align-items:flex-end;
  opacity:0;transition:opacity .4s .4s;
}
#menu.open .menu-bottom{opacity:1}
.menu-bottom-info{
  font-family:var(--sans);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--ink3);line-height:1.9;
}
.menu-bottom-cta{
  font-family:var(--sans);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink2);text-decoration:none;
  cursor:none;transition:color .2s;
}
.menu-bottom-cta:hover{color:var(--ink)}

/* Thin top line */
#menu::after{
  content:'';position:absolute;top:80px;left:48px;right:48px;
  height:1px;background:rgba(26,24,22,.07);
}

/* ═══════════════
   HOME HERO — single huge image
═══════════════ */
#hero{
  height:100vh;min-height:680px;
  position:relative;overflow:hidden;
}
.hero-img{position:absolute;inset:0}
.hero-img img{
  width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity 2s ease;
  position:absolute;inset:0;
  filter:brightness(.7) saturate(.8);
}
.hero-img img.on{opacity:1}
.hero-veil{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.75) 0%,rgba(0,0,0,.45) 50%,rgba(0,0,0,.6) 100%);
}

.hero-content{
  position:absolute;left:48px;bottom:48px;right:48px;
  display:flex;justify-content:space-between;align-items:flex-end;
  z-index:5;color:#FFF;
  text-shadow:0 1px 10px rgba(0,0,0,.8);
}
.hero-meta{
  font-family:var(--sans);font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;font-weight:300;opacity:.9;
}
.hero-meta-r{text-align:right}
.hero-meta-r .pno{
  font-family:var(--serif);font-size:48px;font-style:italic;
  font-weight:300;line-height:1;margin-bottom:4px;
}

.hero-title{
  position:absolute;top:50%;left:48px;transform:translateY(-50%);
  z-index:5;color:#FFF;max-width:680px;
}
.hero-title h1{
  font-family:var(--serif);font-size:clamp(54px,8vw,120px);
  font-weight:300;line-height:.95;letter-spacing:-1px;
  opacity:0;animation:fu 1.2s .3s forwards;
}
.hero-title h1 em{font-style:italic;font-weight:400}
.hero-title .sub{
  margin-top:20px;font-size:14px;letter-spacing:1px;
  font-weight:300;max-width:380px;opacity:0;
  animation:fu 1s .8s forwards;
}

.hero-nav{
  position:absolute;right:48px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:10px;z-index:5;
}
.hero-nav button{
  width:30px;height:1px;background:rgba(255,255,255,.4);
  border:none;cursor:none;transition:background .3s,width .3s;
}
.hero-nav button.on{background:#FFF;width:50px}

@keyframes fu{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════
   SECTION SPACER & TITLES
═══════════════ */
.section{padding:120px 48px}
.s-tag{
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--ink3);font-weight:400;margin-bottom:24px;
}
.s-h{
  font-family:var(--serif);font-size:clamp(48px,6vw,80px);
  font-weight:300;line-height:1.05;letter-spacing:-1px;
}
.s-h em{font-style:italic}

/* ═══════════════
   ABOUT (home)
═══════════════ */
#h-about{padding:140px 48px 100px}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:120px;align-items:start;max-width:1400px;margin:0 auto;
}
.about-grid h2{
  font-family:var(--serif);font-size:clamp(44px,5vw,72px);
  font-weight:300;line-height:1.05;letter-spacing:-1px;
}
.about-grid h2 em{font-style:italic}
.about-grid .text p{
  font-size:15px;line-height:1.85;color:var(--ink2);font-weight:300;
}
.about-grid .text p+p{margin-top:18px}
.about-grid .text .cta{margin-top:40px}

/* ═══════════════
   PROJECTS — magazine layout
═══════════════ */
#h-proj{padding:80px 48px 140px}
.proj-intro{
  display:flex;justify-content:space-between;align-items:flex-end;
  max-width:1400px;margin:0 auto 80px;flex-wrap:wrap;gap:24px;
}
.proj-counter{
  font-size:11px;letter-spacing:2px;color:var(--ink3);
  font-weight:400;text-transform:uppercase;
}

/* Gallery — alternating sizes */
.gallery{
  max-width:1400px;margin:0 auto;
  display:flex;flex-direction:column;gap:140px;
}
.g-item{
  cursor:none;display:block;text-decoration:none;color:inherit;
}
.g-item-img{
  width:100%;overflow:hidden;
  background:var(--bg2);
}
.g-item-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.5s cubic-bezier(.25,.46,.45,.94);
}
.g-item:hover .g-item-img img{transform:scale(1.04)}

/* Variations */
.g-item.full .g-item-img{aspect-ratio:16/9}
.g-item.split{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
}
.g-item.split .g-item-img{aspect-ratio:3/4}
.g-item.split-3{
  display:grid;grid-template-columns:1fr 1.4fr;gap:20px;align-items:center;
}
.g-item.split-3 .g-item-img{aspect-ratio:4/5}
.g-item.split-3.right{grid-template-columns:1.4fr 1fr}

.g-meta{
  margin-top:32px;
  display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:baseline;
}
.g-meta .num{
  font-size:11px;color:var(--ink3);letter-spacing:2px;font-weight:400;
}
.g-meta h3{
  font-family:var(--serif);font-size:clamp(28px,3vw,42px);
  font-weight:300;line-height:1.1;letter-spacing:-.5px;
}
.g-meta h3 em{font-style:italic}
.g-meta .info{
  font-size:11px;color:var(--ink2);letter-spacing:1.5px;
  text-transform:uppercase;text-align:right;font-weight:400;
}

.g-side-text{
  align-self:center;padding:40px;
}
.g-side-text h3{
  font-family:var(--serif);font-size:clamp(28px,3vw,42px);
  font-weight:300;line-height:1.1;margin-bottom:16px;
}
.g-side-text h3 em{font-style:italic}
.g-side-text .info{
  font-size:11px;color:var(--ink3);letter-spacing:2px;
  text-transform:uppercase;margin-bottom:20px;
}
.g-side-text p{
  font-size:14px;line-height:1.8;color:var(--ink2);max-width:400px;
}

/* ═══════════════
   CTA BUTTONS
═══════════════ */
.cta{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--ink);text-decoration:none;background:transparent;
  padding:16px 0;cursor:none;border:none;border-bottom:1px solid var(--ink);
  transition:padding .3s;font-weight:400;
}
.cta:hover{padding-right:8px}
.cta svg{transition:transform .3s}
.cta:hover svg{transform:translateX(6px)}

/* ══════════════════════════════
   PROJECTS PAGE — LIBESKIND STYLE
══════════════════════════════ */
#pg-proj { padding-top:100px; }

.pj-page-hdr {
  padding:80px 48px 48px;
  border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:flex-end;
}
.pj-page-hdr h1 {
  font-family:var(--serif);font-size:clamp(48px,6vw,96px);
  font-weight:300;line-height:.95;letter-spacing:-1px;
}
.pj-page-hdr h1 em{font-style:italic}
.pj-count {
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--ink3);font-family:var(--sans);padding-bottom:8px;
}

/* ── CATEGORY LABEL STRIP ── */
.pj-cat-strip {
  display:flex;gap:0;overflow-x:auto;scrollbar-width:none;
  border-bottom:1px solid var(--line);
  padding:0 48px;
}
.pj-cat-strip::-webkit-scrollbar{display:none}
.pj-cat-btn {
  font-family:var(--sans);font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--ink3);background:none;border:none;cursor:none;
  padding:18px 28px 18px 0;white-space:nowrap;
  position:relative;transition:color .2s;flex-shrink:0;
}
.pj-cat-btn.on { color:var(--ink); }
.pj-cat-btn.on::after {
  content:'';position:absolute;bottom:0;left:0;width:calc(100% - 28px);height:2px;
  background:var(--ink);
}

/* ── PROJECT LIST — LIBESKIND VERTICAL ── */
.pj-vert-list { padding:0 48px 120px; }

.pj-vert-item {
  display:grid;
  grid-template-columns:80px 1fr auto;
  gap:0 40px;
  align-items:stretch;
  border-bottom:1px solid var(--line);
  cursor:none;
  position:relative;
  transition:background .25s;
  text-decoration:none;
  color:inherit;
}
.pj-vert-item:first-child { border-top:1px solid var(--line); }
.pj-vert-item:hover { background:var(--bg2); }

/* Left: index number */
.pj-vi-num {
  font-family:var(--sans);font-size:10px;letter-spacing:1px;color:var(--ink3);
  padding:32px 0;display:flex;align-items:flex-start;padding-top:34px;
  flex-shrink:0;
}

/* Center: image + title */
.pj-vi-main {
  display:flex;gap:32px;align-items:center;
  padding:28px 0;
}
.pj-vi-img {
  width:140px;height:88px;flex-shrink:0;overflow:hidden;background:var(--bg2);
  clip-path:inset(0 100% 0 0);
  transition:clip-path .8s cubic-bezier(.77,0,.18,1),width .4s ease;
}
.pj-vert-item.revealed .pj-vi-img { clip-path:inset(0 0% 0 0); }
.pj-vi-img img {
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s cubic-bezier(.25,.46,.45,.94);
  filter:saturate(.9);
}
.pj-vert-item:hover .pj-vi-img img { transform:scale(1.06); }
.pj-vi-text {}
.pj-vi-cat {
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--ink3);margin-bottom:8px;font-family:var(--sans);
}
.pj-vi-name {
  font-family:var(--serif);font-size:clamp(22px,2.5vw,34px);
  font-weight:300;line-height:1.15;letter-spacing:-.3px;
}

/* Right: location + year + arrow */
.pj-vi-right {
  display:flex;flex-direction:column;justify-content:center;
  align-items:flex-end;gap:6px;padding:28px 0;
  text-align:right;flex-shrink:0;min-width:160px;
}
.pj-vi-loc {
  font-size:11px;color:var(--ink2);letter-spacing:.5px;
}
.pj-vi-year {
  font-family:var(--sans);font-size:11px;letter-spacing:2px;color:var(--ink3);
}
.pj-vi-arrow {
  width:32px;height:1px;background:var(--ink3);
  position:relative;transition:width .4s cubic-bezier(.16,1,.3,1);margin-top:8px;
}
.pj-vi-arrow::after {
  content:'';position:absolute;right:0;top:-3px;
  width:7px;height:7px;border-top:1px solid var(--ink3);border-right:1px solid var(--ink3);
  transform:rotate(45deg);
}
.pj-vert-item:hover .pj-vi-arrow { width:52px;background:var(--ink); }
.pj-vert-item:hover .pj-vi-arrow::after { border-color:var(--ink); }

/* ═══════════════
   SINGLE PROJECT
═══════════════ */
#pg-single{padding-top:80px}
.sp-back{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--ink2);background:none;border:none;cursor:none;
  margin:32px 48px;font-family:var(--sans);font-weight:400;
  transition:color .2s;
}
.sp-back:hover{color:var(--ink)}
.sp-back svg{transition:transform .2s}
.sp-back:hover svg{transform:translateX(-4px)}

.sp-hero{
  width:100%;aspect-ratio:21/9;overflow:hidden;
  background:var(--bg2);
}
.sp-hero img{width:100%;height:100%;object-fit:cover}

.sp-content{
  max-width:1400px;margin:0 auto;
  padding:80px 48px;
  display:grid;grid-template-columns:1fr 1fr;gap:120px;
}
.sp-cat{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--ink3);margin-bottom:24px}
.sp-title{
  font-family:var(--serif);font-size:clamp(40px,5vw,72px);
  font-weight:300;line-height:1.05;letter-spacing:-1px;
}
.sp-title em{font-style:italic}
.sp-text{padding-top:60px}
.sp-text p{font-size:15px;line-height:1.9;color:var(--ink2)}
.sp-text p+p{margin-top:18px}
.sp-data{
  margin-top:40px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;
}
.sp-di{
  padding:18px 0;border-bottom:1px solid var(--line2);
  border-right:1px solid var(--line2);padding-right:20px;
}
.sp-di:nth-child(2n){border-right:none;padding-left:20px;padding-right:0}
.sp-dl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--ink3);margin-bottom:6px;font-weight:400}
.sp-dv{font-size:14px;color:var(--ink);font-weight:300}

.sp-imgs{padding:60px 48px 120px;max-width:1400px;margin:0 auto;}
.sp-imgs-title{
  font-family:var(--sans);font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--ink3);margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--line);
}
.sp-imgs-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
/* First image full width */
.sp-imgs-grid .sp-img-item:first-child{
  grid-column:span 2;
}
.sp-imgs-grid .sp-img-item:first-child .sp-img-inner{aspect-ratio:16/7}
.sp-img-item{overflow:hidden;}
.sp-img-inner{
  width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--bg2);
  position:relative;
}
.sp-img-inner img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s cubic-bezier(.25,.46,.45,.94);
}
.sp-img-item:hover .sp-img-inner img{transform:scale(1.04)}

/* ═══════════════
   ESTUDIO
═══════════════ */
#pg-estudio{padding-top:120px}
.est-hero{padding:80px 48px;max-width:1400px;margin:0 auto}
.est-hero h1{
  font-family:var(--serif);font-size:clamp(64px,9vw,140px);
  font-weight:300;line-height:.95;letter-spacing:-2px;margin-bottom:48px;
}
.est-hero h1 em{font-style:italic}
.est-photo{
  width:100%;aspect-ratio:21/9;overflow:hidden;background:var(--bg2);
  margin-bottom:80px;
}
.est-photo img{width:100%;height:100%;object-fit:cover}

.est-cols{
  max-width:1400px;margin:0 auto;padding:0 48px 80px;
  display:grid;grid-template-columns:1fr 1.5fr;gap:120px;
}
.est-cols .l h2{
  font-family:var(--serif);font-size:clamp(36px,4vw,52px);
  font-weight:300;line-height:1.1;
}
.est-cols .l h2 em{font-style:italic}
.est-cols .r p{font-size:15px;line-height:1.85;color:var(--ink2)}
.est-cols .r p+p{margin-top:16px}

.est-team{
  max-width:1400px;margin:0 auto;padding:80px 48px;
  border-top:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
}
.team-c{display:grid;grid-template-columns:1fr 1.5fr;gap:32px;align-items:start}
.team-portrait{
  aspect-ratio:3/4;background:var(--bg2);overflow:hidden;
  border:1px solid var(--line2);
}
.team-portrait svg{width:100%;height:100%}
.team-c h3{font-family:var(--serif);font-size:24px;font-weight:300;margin-bottom:6px}
.team-role{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--ink3);margin-bottom:14px;font-weight:400}
.team-c p{font-size:13px;line-height:1.75;color:var(--ink2)}

.est-expos{
  max-width:1400px;margin:0 auto;padding:80px 48px;
  border-top:1px solid var(--line);
}
.est-expos .s-h{margin-bottom:48px}
.exp-row{
  display:grid;grid-template-columns:80px 1fr 280px;gap:32px;
  padding:20px 0;border-top:1px solid var(--line2);align-items:baseline;
}
.exp-yr{font-size:11px;color:var(--ink3);letter-spacing:1px}
.exp-nm{font-family:var(--serif);font-size:18px;font-weight:300}
.exp-pl{font-size:12px;color:var(--ink2);text-align:right}

/* ═══════════════
   PREMIOS
═══════════════ */
#pg-premios{padding-top:120px}
.pm-hero{max-width:1400px;margin:0 auto;padding:80px 48px}
.pm-hero h1{font-family:var(--serif);font-size:clamp(64px,9vw,140px);font-weight:300;line-height:.95;letter-spacing:-2px}
.pm-hero h1 em{font-style:italic}
.pm-list{max-width:1400px;margin:0 auto;padding:0 48px 120px}
.pm-row{
  display:grid;grid-template-columns:80px 1fr 1fr 24px;gap:32px;
  padding:32px 0;border-top:1px solid var(--line);align-items:center;
  cursor:none;transition:padding .3s;
}
.pm-row:last-child{border-bottom:1px solid var(--line)}
.pm-row:hover{padding-left:16px;padding-right:16px}
.pm-yr{font-size:11px;color:var(--ink3);letter-spacing:1px;font-weight:400}
.pm-nm{font-family:var(--serif);font-size:22px;font-weight:300}
.pm-tp{font-size:12px;color:var(--ink2)}
.pm-ar{color:var(--ink3);opacity:0;transition:opacity .3s,transform .3s}
.pm-row:hover .pm-ar{opacity:1;transform:translateX(8px)}

/* ═══════════════
   CONTACTO
═══════════════ */
#pg-cont{padding-top:120px}
.ct-hero{max-width:1400px;margin:0 auto;padding:80px 48px 60px}
.ct-hero h1{
  font-family:var(--serif);font-size:clamp(64px,9vw,140px);
  font-weight:300;line-height:.95;letter-spacing:-2px;
}
.ct-hero h1 em{font-style:italic}
.ct-body{
  max-width:1400px;margin:0 auto;padding:60px 48px 120px;
  display:grid;grid-template-columns:1fr 1.2fr;gap:120px;
}
.ct-info{display:flex;flex-direction:column;gap:0}
.ct-row{
  display:grid;grid-template-columns:120px 1fr;gap:24px;
  padding:24px 0;border-top:1px solid var(--line);align-items:baseline;
}
.ct-row:last-child{border-bottom:1px solid var(--line)}
.ct-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--ink3);font-weight:400}
.ct-val{font-size:15px;color:var(--ink)}
.ct-val a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line);transition:border-color .2s}
.ct-val a:hover{border-color:var(--ink)}

.ct-form{display:flex;flex-direction:column}
.ff{
  border-bottom:1px solid var(--line);padding:20px 0;transition:border-color .3s;
}
.ff:focus-within{border-color:var(--ink)}
.ff label{
  display:block;font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink3);margin-bottom:10px;font-weight:400;
}
.ff input,.ff textarea,.ff select{
  width:100%;background:transparent;border:none;outline:none;
  font-family:var(--sans);font-size:16px;color:var(--ink);font-weight:300;resize:none;
}
.ff textarea{height:80px}
.ct-sub{
  margin-top:36px;align-self:flex-start;
  display:inline-flex;align-items:center;gap:14px;
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  background:var(--ink);color:var(--bg);border:none;padding:18px 36px;
  cursor:none;font-family:var(--sans);font-weight:400;
  transition:background .3s;
}
.ct-sub:hover{background:#000}

/* ═══════════════
   FOOTER
═══════════════ */
footer{
  border-top:1px solid var(--line);
  padding:60px 48px 40px;
  background:var(--bg);
}
.f-grid{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
}
.f-logo{
  font-family:var(--serif);font-size:32px;font-weight:300;letter-spacing:1px;
  margin-bottom:14px;
}
.f-logo em{font-style:italic}
.f-tagline{font-size:13px;color:var(--ink2);max-width:280px;line-height:1.6}
.f-col h4{
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:var(--ink3);margin-bottom:16px;font-weight:500;
}
.f-col a{
  display:block;color:var(--ink);text-decoration:none;
  font-size:14px;font-weight:300;line-height:2;cursor:none;
  transition:color .2s;
}
.f-col a:hover{color:var(--ink2)}
.f-bottom{
  max-width:1400px;margin:60px auto 0;padding-top:24px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;
  font-size:11px;color:var(--ink3);letter-spacing:1px;
}

/* REVEAL */
.rv{opacity:0;transform:translateY(24px);transition:opacity 1s ease,transform 1s ease}
.rv.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

/* RESPONSIVE */

@media(max-width:900px){
  .pj-page-hdr{flex-direction:column;align-items:flex-start;gap:12px;padding:60px 24px 24px}
  .pj-filters{padding:28px 24px;gap:8px}
  .pj-f{padding:10px 18px;font-size:10px}
  .pj-vert-list{padding:0 24px 80px}
  .pj-vi-img{width:80px;height:56px}
  .pj-vi-name{font-size:18px}
  .pj-vi-right{display:none}
  .pj-cat-strip{padding:0 24px}
  .pj-cat-btn{padding:14px 16px 14px 0}
}
@media(max-width:900px){
  body{cursor:auto}
  #C,#CR{display:none}
  *{cursor:auto !important}
  #nav{padding:20px 24px}
  #nav.sc{padding:14px 24px}
  .hero-content{left:24px;right:24px;bottom:24px;flex-direction:column;gap:16px;align-items:flex-start}
  .hero-meta-r{text-align:left}
  .hero-title{left:24px;right:24px;max-width:none}
  .hero-title h1{font-size:42px}
  .hero-nav{right:16px;gap:6px}
  .section,#h-about,#h-proj{padding:80px 24px}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .proj-page-hdr,.est-hero,.pm-hero,.ct-hero,.est-cols,.est-team,.est-expos,.pm-list,.proj-list,.ct-body,.sp-content,.sp-imgs{padding-left:24px;padding-right:24px}
  .gallery{gap:80px}
  .g-item.split,.g-item.split-3,.g-item.split-3.right{grid-template-columns:1fr;gap:16px}
  .g-side-text{padding:0}
  .g-meta{grid-template-columns:1fr;gap:8px}
  .g-meta .info{text-align:left}
  .proj-list{grid-template-columns:1fr;gap:60px}
  .pl-item:nth-child(even){margin-top:0}
  .est-cols{grid-template-columns:1fr;gap:40px}
  .est-team{grid-template-columns:1fr;gap:40px}
  .team-c{grid-template-columns:80px 1fr;gap:20px}
  .pm-row{grid-template-columns:60px 1fr 16px;gap:16px}
  .pm-tp{display:none}
  .ct-body{grid-template-columns:1fr;gap:60px}
  .sp-content{grid-template-columns:1fr;gap:40px}
  .sp-imgs{grid-template-columns:1fr}
  .exp-row{grid-template-columns:60px 1fr;gap:16px}
  .exp-pl{display:none}
  .f-grid{grid-template-columns:1fr 1fr;gap:32px}
  .f-bottom{flex-direction:column;gap:8px;text-align:center}
}
@media(max-width:540px){
  .f-grid{grid-template-columns:1fr}
  .menu-list li{font-size:36px}
}

@media(max-width:900px){
  .sp-imgs{padding:40px 24px 80px}
  .sp-imgs-grid{grid-template-columns:1fr}
  .sp-imgs-grid .sp-img-item:first-child{grid-column:span 1}
  .sp-imgs-grid .sp-img-item:first-child .sp-img-inner{aspect-ratio:4/3}
}


/* ═══════════════════════════════════════════════
   RESPONSIVE — TABLET / MOBILE / SMALL MOBILE
═══════════════════════════════════════════════ */

/* TABLET (≤ 1024px) */
@media(max-width:1024px){
  .nav{padding:18px 32px}
  .hero-meta{padding:0 32px 32px}
  .hero-title{font-size:clamp(48px, 9vw, 90px)}
  .gal-grid{grid-template-columns:repeat(8,1fr);padding:60px 32px}
  .pj-page-hdr{padding:60px 32px 32px}
  .pj-cat-strip{padding:0 32px}
  .pj-vert-list{padding:0 32px 80px}
  .sp-hdr,.sp-text-grid,.sp-imgs{padding-left:32px;padding-right:32px}
  .estudio-grid,.equipo-grid,.contact-grid{padding:0 32px}
  .premios-list{padding:0 32px}
  .f-grid{padding:60px 32px 40px}
}

/* MOBILE (≤ 700px) */
@media(max-width:700px){
  /* NAV */
  .nav{padding:14px 20px}
  .logo{font-size:22px}
  .menu-btn{width:36px;height:36px}
  
  /* HERO */
  .hero{height:85vh;min-height:560px}
  .hero-meta{padding:0 20px 24px;flex-direction:column;align-items:flex-start;gap:12px}
  .hero-title{font-size:clamp(38px, 11vw, 60px);line-height:1.02;letter-spacing:-1px}
  .hero-sub{font-size:13px}
  .hero-scroll{font-size:9px;letter-spacing:2px}
  
  /* MENU OVERLAY */
  .menu-list a{font-size:clamp(36px, 10vw, 60px)}
  .menu-meta{flex-direction:column;gap:20px;text-align:center;padding:0 20px}
  
  /* GALLERY HOME */
  .gal-grid{grid-template-columns:1fr;gap:16px;padding:40px 20px}
  .gal-card{grid-column:span 1!important;grid-row:span 1!important}
  .gal-card .gal-img{aspect-ratio:4/3!important}
  .gal-cap{font-size:11px}
  
  /* SECTION TITLE */
  .sec-title{font-size:clamp(32px,8vw,48px);padding:60px 20px 20px}
  .sec-sub{padding:0 20px 32px;font-size:13px}
  
  /* PROJECTS PAGE */
  .pj-page-hdr{flex-direction:column;align-items:flex-start;gap:8px;padding:60px 20px 24px}
  .pj-page-hdr h1{font-size:clamp(40px, 10vw, 64px)}
  .pj-count{font-size:10px}
  
  /* CATEGORY STRIP */
  .pj-cat-strip{padding:0 20px;overflow-x:auto;scrollbar-width:none}
  .pj-cat-strip::-webkit-scrollbar{display:none}
  .pj-cat-btn{padding:14px 18px 14px 0;font-size:10px;letter-spacing:1.5px}
  
  /* PROJECT VERTICAL LIST */
  .pj-vert-list{padding:0 20px 60px}
  .pj-vert-item{
    grid-template-columns:auto 1fr;
    gap:16px;
    padding:0;
  }
  .pj-vi-num{
    font-size:9px;padding:18px 0 0 0;
    align-items:flex-start;
  }
  .pj-vi-main{
    padding:18px 0;gap:16px;flex-wrap:wrap;
  }
  .pj-vi-img{width:96px;height:64px;flex-shrink:0}
  .pj-vi-text{flex:1;min-width:160px}
  .pj-vi-cat{font-size:9px;letter-spacing:1.5px;margin-bottom:4px}
  .pj-vi-name{font-size:17px;line-height:1.2;letter-spacing:-.2px}
  .pj-vi-right{
    grid-column:1/-1;
    flex-direction:row;
    align-items:center;justify-content:space-between;
    padding:0 0 18px 0;min-width:auto;
    gap:12px;text-align:left;
  }
  .pj-vi-loc{font-size:11px}
  .pj-vi-year{font-size:10px}
  .pj-vi-arrow{display:none}
  
  /* SINGLE PROJECT */
  .sp-hdr{padding:80px 20px 24px}
  .sp-cat{font-size:10px;letter-spacing:2px;margin-bottom:12px}
  .sp-title{font-size:clamp(36px, 9vw, 56px);letter-spacing:-.5px}
  .sp-img-wrap{aspect-ratio:4/3;margin:0 -20px 40px}
  .sp-text-grid{
    grid-template-columns:1fr;
    gap:32px;padding:0 20px 40px;
  }
  .sp-text p{font-size:15px;line-height:1.6}
  .sp-data{
    grid-template-columns:1fr 1fr;
    gap:20px;padding-top:24px;
  }
  .sp-dl{font-size:9px;letter-spacing:1.5px}
  .sp-dv{font-size:14px}
  
  /* SINGLE PROJECT GALLERY */
  .sp-imgs{padding:40px 20px 60px}
  .sp-imgs-title{font-size:9px;letter-spacing:2px;margin-bottom:20px}
  .sp-imgs-grid{grid-template-columns:1fr;gap:12px}
  .sp-imgs-grid .sp-img-item:first-child{grid-column:span 1}
  .sp-imgs-grid .sp-img-item:first-child .sp-img-inner{aspect-ratio:4/3}
  
  /* ESTUDIO PAGE */
  .estudio-grid{grid-template-columns:1fr;gap:32px;padding:40px 20px}
  .estudio-img{aspect-ratio:4/3}
  .estudio-text h2{font-size:clamp(32px,8vw,48px)}
  .estudio-text p{font-size:15px;line-height:1.7}
  
  /* EQUIPO */
  .equipo-grid{grid-template-columns:1fr;gap:40px;padding:40px 20px}
  .equipo-img{aspect-ratio:3/4;max-width:280px;margin:0 auto}
  .equipo-info{text-align:center}
  .equipo-name{font-size:24px}
  
  /* PREMIOS */
  .premios-list{padding:40px 20px 80px}
  .premio-item{
    grid-template-columns:1fr;
    gap:6px;padding:24px 0;
  }
  .premio-year{font-size:10px;color:var(--ink3)}
  .premio-name{font-size:17px;line-height:1.3}
  .premio-place{font-size:12px}
  
  /* CONTACT */
  .contact-grid{grid-template-columns:1fr;gap:40px;padding:40px 20px 80px}
  .contact-info h2{font-size:clamp(36px,9vw,56px)}
  .contact-data li{font-size:14px;padding:12px 0}
  .contact-form input,.contact-form textarea{font-size:15px;padding:14px 0}
  
  /* FOOTER */
  .f-grid{
    grid-template-columns:1fr;
    gap:32px;padding:60px 20px 32px;
    text-align:center;
  }
  .f-logo{font-size:32px}
  .f-col h4{font-size:10px;margin-bottom:12px}
  .f-col a{font-size:13px}
  .f-bottom{padding:24px 20px;font-size:10px;flex-direction:column;gap:12px;text-align:center}
  
  /* Disable cursor on touch */
  body,a,button,.pj-vert-item,.pj-cat-btn{cursor:auto!important}
  .cursor-dot,.cursor-ring{display:none!important}
  
  /* Marquee scroll */
  .marquee{font-size:60px}
}

/* SMALL MOBILE (≤ 480px) */
@media(max-width:480px){
  .nav{padding:12px 16px}
  .logo{font-size:20px}
  .hero-meta{padding:0 16px 20px}
  .hero-title{font-size:clamp(34px, 11vw, 48px)}
  .gal-grid{padding:32px 16px;gap:12px}
  .pj-page-hdr{padding:48px 16px 20px}
  .pj-cat-strip{padding:0 16px}
  .pj-vert-list{padding:0 16px 48px}
  .pj-vi-img{width:80px;height:54px}
  .pj-vi-name{font-size:15px}
  .sp-hdr{padding:64px 16px 20px}
  .sp-img-wrap{margin:0 -16px 32px}
  .sp-text-grid{padding:0 16px 32px}
  .sp-imgs{padding:32px 16px 48px}
  .estudio-grid{padding:32px 16px}
  .equipo-grid{padding:32px 16px}
  .premios-list{padding:32px 16px 64px}
  .contact-grid{padding:32px 16px 64px}
  .f-grid{padding:48px 16px 24px}
}

