/* ══════════════════════════════════════════════════════════════════
   ALANDI DEVELOPMENTS — INTERACTIVE
   Boutique. Considered. Now in motion.
══════════════════════════════════════════════════════════════════ */

:root {
  --c-deep:      #0F0F0F;
  --c-phantom:   #1E1E24;
  --c-arsenic:   #40424D;
  --c-slate:     #3A4651;
  --c-graphite:  #6E7180;
  --c-space:     #9DA2B3;
  --c-steel:     #BCBFCC;
  --c-smoke:     #D3D6E0;
  --c-cloud:     #EDEFF7;
  --c-white:     #FFFFFF;
  --c-sand:      #C7BCA1;       /* signature accent — used very sparingly */

  --f:           'Manrope', system-ui, sans-serif;
  --f-xs:        0.625rem;
  --f-sm:        0.75rem;
  --f-base:      1rem;
  --f-md:        1.0625rem;
  --f-lg:        1.125rem;
  --f-h2:        clamp(1.5rem, 2.8vw, 2.125rem);
  --f-hero:      clamp(1.75rem, 3.4vw, 2.75rem);
  --f-mega:      clamp(6rem, 18vw, 18rem);

  --ls-head:     -0.025em;
  --ls-label:    0.22em;
  --ls-btn:      0.15em;

  --sp-section:  clamp(96px, 13vw, 152px);
  --sp-page:     clamp(24px, 5.5vw, 72px);
  --nav-h:       72px;

  --ease:        cubic-bezier(0.19, 1, 0.22, 1);
  --ease-io:     cubic-bezier(0.77, 0, 0.18, 1);
  --t-btn:       0.7s;
  --t-reveal:    1.6s;

  --b-rule:      1px solid var(--c-slate);
  --b-subtle:    0.5px solid rgba(255,255,255,0.07);
  --b-light:     0.5px solid var(--c-smoke);
}

/* ═══ RESET ═══ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; }
html, body { overflow-x: clip; }
body {
  font-family: var(--f);
  background: var(--c-deep);
  color: var(--c-white);
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: var(--f); background: none; border: none; cursor: none; color: inherit; }
ul, ol { list-style: none; }
:focus-visible { outline: 1.5px solid var(--c-steel); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

@media (hover: none), (pointer: coarse) {
  body, button { cursor: auto; }
  .cursor { display: none !important; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; animation-iteration-count: 1 !important; }
  body { cursor: auto; }
  .cursor, .marquee__inner { animation: none !important; }
}

/* ═══ LOADER ═══ */
.loader { display: none !important; }
.loader__name { font-size: clamp(1.5rem, 3vw, 2.25rem); font-weight: 300; letter-spacing: 0.5em; padding-left: 0.5em; color: var(--c-white); overflow: hidden; opacity: 0.85; }
.loader__name span { display: inline-block; transform: translateY(120%); animation: rise 1.4s var(--ease) 0.2s forwards; }
.loader__name span:nth-child(2) { animation-delay: 0.28s; }
.loader__name span:nth-child(3) { animation-delay: 0.36s; }
.loader__name span:nth-child(4) { animation-delay: 0.44s; }
.loader__name span:nth-child(5) { animation-delay: 0.52s; }
.loader__name span:nth-child(6) { animation-delay: 0.60s; }
.loader.gone { opacity: 0; pointer-events: none; }
@keyframes rise { to { transform: none; } }

/* ═══ CUSTOM CURSOR ═══ */
.cursor { display: none !important; }
.cursor__ring { width: 10px; height: 10px; border: 0.5px solid rgba(255,255,255,0.5); border-radius: 50%; transform: translate(-50%, -50%); transition: width 0.6s var(--ease), height 0.6s var(--ease), border-color 0.6s var(--ease), background 0.6s var(--ease); }
.cursor.is-hover .cursor__ring { width: 44px; height: 44px; border-color: rgba(255,255,255,0.7); background: transparent; }
.cursor.is-tap .cursor__ring { width: 8px; height: 8px; background: rgba(255,255,255,0.9); }
.cursor.is-text .cursor__ring { width: 4px; height: 22px; border-radius: 1px; background: var(--c-white); border: none; }

/* ═══ SCROLL PROGRESS ═══ */
.scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 1px; z-index: 200; background: rgba(255,255,255,0.05); pointer-events: none; }
.scroll-progress__bar { height: 100%; width: 0; background: var(--c-sand); transition: width 0.08s linear; }

/* ═══ NAV ═══ */
.nav {
  position: fixed; inset-block-start: 0; inset-inline: 0; z-index: 100;
  height: var(--nav-h); padding: 0 var(--sp-page);
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(15,15,15,0.72);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: var(--b-subtle);
  transition: transform 0.5s var(--ease), background 0.4s ease;
}
.nav.is-hidden { transform: translateY(-100%); }
.nav.is-light { background: rgba(255,255,255,0.86); border-bottom-color: rgba(0,0,0,0.06); color: var(--c-deep); }
.nav.is-light .nav__link { color: var(--c-graphite); }
.nav.is-light .nav__link:hover { color: var(--c-deep); }
.nav.is-light .nav__cta { color: var(--c-deep); border-color: rgba(0,0,0,0.2); }
.nav.is-light .nav__cta::after { background: var(--c-deep); }
.nav.is-light .nav__cta:hover { color: var(--c-white); border-color: var(--c-deep); }

.nav__logo { display: flex; align-items: center; gap: 12px; }
.nav__logo img { height: 32px; width: 32px; object-fit: contain; border-radius: 50%; }
.nav__logo-text { font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; }
.nav__links { display: flex; align-items: center; gap: 36px; }
.nav__link { font-size: var(--f-xs); font-weight: 600; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-space); padding: 4px 0; position: relative; transition: color var(--t-btn) var(--ease); }
.nav__link::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 1px; background: currentColor; transition: width var(--t-btn) var(--ease); }
.nav__link:hover { color: var(--c-white); }
.nav__link:hover::after { width: 100%; }
.nav__cta { font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-btn); text-transform: uppercase; color: var(--c-white); border: 1px solid rgba(255,255,255,0.2); padding: 12px 28px; min-height: 44px; position: relative; overflow: hidden; transition: color var(--t-btn) var(--ease), border-color var(--t-btn) var(--ease); display: inline-flex; align-items: center; will-change: transform; }
.nav__cta::after { content: ''; position: absolute; inset: 0; background: var(--c-white); transform: translateY(101%); transition: transform var(--t-btn) var(--ease); }
.nav__cta:hover { color: var(--c-deep); border-color: var(--c-white); }
.nav__cta:hover::after { transform: none; }
.nav__cta span { position: relative; z-index: 1; }

/* ═══ HERO ═══ */
.hero {
  position: relative; min-height: 92svh; padding: var(--nav-h) var(--sp-page) clamp(56px,8vw,88px);
  display: flex; flex-direction: column; justify-content: center;
  overflow: hidden;
}
.hero__bg { position: absolute; inset: 0; z-index: 0; overflow: hidden; will-change: transform; }
.hero__bg-img { width: 110%; height: 110%; margin: -5% 0 0 -5%; object-fit: cover; opacity: 0.85; filter: grayscale(15%); will-change: transform; }
.hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(15,15,15,0.15) 0%, rgba(15,15,15,0.35) 55%, rgba(15,15,15,0.78) 100%); }

/* Mega ALANDI text — quiet editorial backdrop, no kinetic motion */
.hero__mega { display: none; }

/* Vertical brand rule */
.hero__brand { position: absolute; left: var(--sp-page); top: 50%; transform: translateY(-50%); z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 16px; pointer-events: none; }
.hero__brand::before, .hero__brand::after { content: ''; width: 1px; height: 72px; background: var(--c-slate); flex-shrink: 0; }
.hero__brand-text { font-size: 9px; font-weight: 700; letter-spacing: 0.35em; text-transform: uppercase; color: var(--c-slate); writing-mode: vertical-rl; text-orientation: mixed; transform: rotate(180deg); }

.hero__body { position: relative; z-index: 2; max-width: 640px; padding-left: 0; }
.hero__kicker { display: inline-flex; align-items: center; gap: 14px; font-size: var(--f-xs); font-weight: 600; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-steel); margin-bottom: 36px; }
.hero__kicker::before { content: ''; width: 22px; height: 1px; background: var(--c-sand); flex-shrink: 0; }
.hero__h1 { font-size: var(--f-hero); font-weight: 300; letter-spacing: var(--ls-head); line-height: 1.1; color: var(--c-white); margin-bottom: 14px; }
.hero__h1 strong { font-weight: 400; display: inline; font-style: normal; letter-spacing: var(--ls-head); }
.hero__h1 .word { display: inline-block; overflow: hidden; vertical-align: top; }
.hero__h1 .word > span { display: inline-block; transform: none; transition: transform 1.6s var(--ease); }
.hero.in .hero__h1 .word > span { transform: none; }
.hero__h1 .w2 > span { transition-delay: 0.35s; }
.hero__tagline { font-size: var(--f-base); font-weight: 300; color: var(--c-steel); letter-spacing: 0.02em; margin-bottom: 36px; opacity: 1; transform: none; }
.hero.in .hero__tagline { opacity: 1; transform: none; }
.hero__actions { display: flex; gap: 14px; flex-wrap: wrap; opacity: 1; transform: none; }
.hero.in .hero__actions { opacity: 1; transform: none; }

.hero__divider { position: relative; z-index: 2; opacity: 1; }
.hero.in .hero__divider { opacity: 1; }
.hero__divider hr { border: none; border-top: 0.5px solid var(--c-slate); margin: clamp(56px,8vw,88px) 0 clamp(48px,6vw,72px); transform: none; }
.hero.in .hero__divider hr { transform: scaleX(1); }

.hero__stats { position: relative; z-index: 2; display: flex; }
.hstat { flex: 1; padding-right: clamp(20px,4vw,48px); border-right: 0.5px solid rgba(255,255,255,0.1); opacity: 1; transform: none; }
.hero.in .hstat { opacity: 1; transform: none; }
.hero.in .hstat:nth-child(1) { transition-delay: 1.6s; }
.hero.in .hstat:nth-child(2) { transition-delay: 1.75s; }
.hero.in .hstat:nth-child(3) { transition-delay: 1.9s; }
.hero.in .hstat:nth-child(4) { transition-delay: 2.05s; }
.hstat:last-child { border-right: none; padding-right: 0; }
.hstat:not(:first-child) { padding-left: clamp(20px,4vw,48px); }
.hstat__n { font-size: clamp(22px,2.8vw,32px); font-weight: 800; letter-spacing: -0.04em; line-height: 1; }
.hstat__l { font-size: var(--f-xs); color: var(--c-steel); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 600; margin-top: 8px; }

/* Scroll indicator */
.scroll-cue { position: absolute; right: var(--sp-page); bottom: clamp(56px,9vw,96px); z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 12px; font-size: 9px; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase; color: var(--c-graphite); opacity: 1; }
.hero.in .scroll-cue { opacity: 1; }
.scroll-cue__line { width: 1px; height: 48px; background: linear-gradient(to bottom, var(--c-graphite) 0%, transparent 100%); position: relative; overflow: hidden; }
.scroll-cue__line::after { content:''; position:absolute; left:0; right:0; top:-50%; height:50%; background: var(--c-white); animation: cueDrop 3.6s var(--ease) infinite; }
@keyframes cueDrop { to { top: 100%; } }

/* ═══ BUTTONS ═══ */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-btn); text-transform: uppercase; padding: 16px 36px; min-height: 48px; white-space: nowrap; transition: color var(--t-btn) var(--ease), background var(--t-btn) var(--ease), border-color var(--t-btn) var(--ease); will-change: transform; position: relative; }
.btn--primary { color: var(--c-deep); background: var(--c-white); border: 1px solid var(--c-white); }
.btn--primary:hover { background: var(--c-cloud); border-color: var(--c-cloud); }
.btn--ghost { color: var(--c-steel); background: transparent; border: 1px solid rgba(255,255,255,0.16); }
.btn--ghost:hover { color: var(--c-white); border-color: rgba(255,255,255,0.42); }
.btn--slate { color: var(--c-white); background: var(--c-slate); border: 1px solid var(--c-slate); position: relative; overflow: hidden; }
.btn--slate::after { content: ''; position: absolute; inset: 0; background: var(--c-deep); transform: translateX(-101%); transition: transform var(--t-btn) var(--ease); }
.btn--slate:hover::after { transform: none; }
.btn--slate span { position: relative; z-index: 1; }
.btn .arrow { display: inline-block; transition: transform 0.4s var(--ease); }
.btn:hover .arrow { transform: translateX(6px); }

/* ═══ EYEBROWS ═══ */
.eyebrow { display: inline-flex; align-items: center; gap: 12px; font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-graphite); margin-bottom: 20px; }
.eyebrow::before { content: ''; width: 18px; height: 1px; background: var(--c-sand); flex-shrink: 0; }
.eyebrow--inv { color: var(--c-space); }
.eyebrow--inv::before { background: var(--c-sand); }

/* ═══ SECTION BASE ═══ */
.s { padding: var(--sp-section) var(--sp-page); position: relative; }
.s--white { background: var(--c-white); color: var(--c-deep); }
.s--cloud { background: var(--c-cloud); color: var(--c-deep); }
.s--dark { background: var(--c-deep); color: var(--c-white); }
.s-h2 { font-size: var(--f-h2); font-weight: 300; letter-spacing: var(--ls-head); line-height: 1.12; margin-bottom: 16px; }

/* Curtain wipe section transition */
/* Curtain disabled — sections reveal via .reveal helpers only */
.curtain { display: none; }

/* General reveal helpers — long, calm fade-up */
.reveal { opacity: 0; transform: translateY(36px); transition: opacity var(--t-reveal) var(--ease), transform var(--t-reveal) var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.rv-1 { transition-delay: 0.2s; }
.rv-2 { transition-delay: 0.4s; }
.rv-3 { transition-delay: 0.6s; }

/* ═══ MARQUEE (kinetic) ═══ */
.marquee { overflow: hidden; padding: 36px 0; border-block: 0.5px solid rgba(255,255,255,0.08); }
.s--white .marquee, .s--cloud .marquee { border-block-color: rgba(0,0,0,0.08); }
.marquee__inner { display: flex; gap: 80px; white-space: nowrap; animation: marquee 140s linear infinite; will-change: transform; }
.marquee--reverse .marquee__inner { animation-direction: reverse; }
.marquee__item { display: inline-flex; align-items: center; gap: 64px; font-size: clamp(1.5rem,3.5vw,3rem); font-weight: 700; letter-spacing: var(--ls-head); color: transparent; -webkit-text-stroke: 1px currentColor; }
.marquee__item.solid { color: currentColor; -webkit-text-stroke: 0; }
.marquee__dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--c-sand); flex-shrink: 0; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ═══ PROJECTS — STICKY TITLE + 3D TILT GALLERY ═══ */
.proj { background: var(--c-deep); border-top: var(--b-rule); padding: var(--sp-section) 0 0; position: relative; }
.proj__head { padding: 0 var(--sp-page) clamp(48px,7vw,80px); display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(32px,5vw,72px); align-items: end; }
.proj__head-meta { display: flex; flex-direction: column; gap: 8px; }
.proj__status { display: inline-flex; align-items: center; gap: 10px; font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-sand); }
.proj__status::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--c-sand); flex-shrink: 0; opacity: 0.8; }
.proj__name { font-size: clamp(2rem, 4.5vw, 3.5rem); font-weight: 700; letter-spacing: var(--ls-head); line-height: 1.0; color: var(--c-white); }
.proj__type { font-size: var(--f-xs); color: var(--c-graphite); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 600; }
.proj__loc { font-size: var(--f-xs); color: var(--c-steel); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 600; align-self: end; }
.proj__details { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; padding: 32px var(--sp-page); border-block: 0.5px solid rgba(255,255,255,0.08); }
.proj__detail-l { font-size: 9px; color: var(--c-graphite); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 700; margin-bottom: 6px; }
.proj__detail-v { font-size: var(--f-md); color: var(--c-white); font-weight: 500; }

/* Horizontal-scroll gallery */
.gallery { padding: clamp(56px,9vw,96px) 0 clamp(56px,7vw,80px); position: relative; }
.gallery__row { display: flex; gap: clamp(20px,3vw,40px); padding: 0 var(--sp-page) 24px; overflow-x: auto; overflow-y: hidden; scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: var(--c-arsenic) transparent; cursor: grab; }
.gallery__row::-webkit-scrollbar { height: 4px; }
.gallery__row::-webkit-scrollbar-track { background: rgba(255,255,255,0.04); }
.gallery__row::-webkit-scrollbar-thumb { background: var(--c-arsenic); border-radius: 4px; }
.gallery__row.is-dragging { cursor: grabbing; scroll-snap-type: none; }
.gallery__card { flex: 0 0 clamp(320px, 42vw, 580px); aspect-ratio: 4/3; position: relative; overflow: hidden; background: #0a0a0a; scroll-snap-align: start; }
.gallery__card img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(25%); transition: transform 1.6s var(--ease), filter 1s ease; will-change: transform; pointer-events: none; }
.gallery__card:hover img { transform: scale(1.04); filter: grayscale(0%); }
.gallery__card-tag { position: absolute; bottom: 16px; left: 16px; right: 16px; display: flex; justify-content: space-between; align-items: end; pointer-events: none; }
.gallery__card-num { font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-label); color: var(--c-white); background: rgba(15,15,15,0.55); backdrop-filter: blur(8px); padding: 8px 12px; }
.gallery__card-label { font-size: var(--f-xs); color: var(--c-white); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 700; background: rgba(15,15,15,0.55); backdrop-filter: blur(8px); padding: 8px 12px; }

.gallery__hint { display: flex; align-items: center; justify-content: space-between; padding: 0 0 32px; color: var(--c-graphite); font-size: var(--f-xs); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 700; }
.gallery__hint-bar { flex: 1; max-width: 220px; height: 1px; background: rgba(255,255,255,0.08); position: relative; margin: 0 24px; }
.gallery__hint-bar::after { content: ''; position: absolute; left: 0; top: -1px; width: var(--prog, 18%); height: 3px; background: var(--c-sand); transition: width 0.2s linear; }

/* ═══ PRIOR EXPERIENCE TABLE ═══ */
.prior { padding: clamp(72px,10vw,120px) var(--sp-page) var(--sp-section); }
.prior__label { font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-graphite); margin-bottom: 24px; display: flex; align-items: center; gap: 12px; }
.prior__label::before { content: ''; width: 18px; height: 1px; background: var(--c-arsenic); }
.prior__head { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,72px); align-items: end; margin-bottom: 48px; }
.prior__title { font-size: clamp(1.5rem,2.6vw,2rem); font-weight: 400; letter-spacing: var(--ls-head); line-height: 1.18; color: var(--c-white); }
.prior__note { font-size: var(--f-sm); color: var(--c-graphite); line-height: 1.7; max-width: 460px; font-style: italic; }
.prior__table { width: 100%; border-collapse: collapse; }
.prior__row { display: grid; grid-template-columns: 1.2fr 60px 1fr 1fr 0.8fr; gap: 16px; padding: 22px 0; border-bottom: 0.5px solid rgba(255,255,255,0.07); transition: padding 0.5s var(--ease); position: relative; opacity: 0; transform: translateY(14px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease), padding 0.5s var(--ease), background 0.4s ease; }
.prior__row.in { opacity: 1; transform: none; }
.prior__row::before { content: ''; position: absolute; left: -100%; top: 50%; width: 100%; height: 1px; background: var(--c-sand); transform: scaleX(0); transform-origin: right; transition: transform 0.5s var(--ease), left 0s 0.5s; }
.prior__row:hover::before { left: 0; transform: scaleX(1); transform-origin: left; transition: transform 0.5s var(--ease), left 0s 0s; }
.prior__row:hover { padding-left: 18px; padding-right: 18px; background: rgba(255,255,255,0.015); }
.prior__row.head { color: var(--c-graphite); font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-label); text-transform: uppercase; padding: 12px 0; opacity: 1; transform: none; border-bottom: var(--b-rule); }
.prior__row.head:hover { padding-left: 0; padding-right: 0; }
.prior__row.head:hover::before { display: none; }
.prior__name { color: var(--c-white); font-weight: 600; font-size: var(--f-md); }
.prior__year, .prior__type, .prior__scale, .prior__loc { color: var(--c-steel); font-size: var(--f-base); font-weight: 400; }
.prior__loc { text-align: right; color: var(--c-graphite); }
.prior__year { color: var(--c-graphite); }

/* ═══ ABOUT ═══ */
.about-visual { position: relative; overflow: hidden; }
.about-visual img { width: 100%; height: clamp(360px, 52vw, 680px); object-fit: cover; object-position: center 60%; filter: saturate(0.85); transition: transform 3s var(--ease); will-change: transform; }
.about-visual:hover img { transform: scale(1.03); }
.about-cap { position: absolute; bottom: 0; inset-inline: 0; padding: 15px var(--sp-page); background: rgba(15,15,15,0.72); backdrop-filter: blur(10px); }
.about-cap p { font-size: var(--f-xs); color: var(--c-space); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 600; }
.about-body { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px,6vw,96px); margin-top: clamp(56px,7vw,88px); }
.about-body p { font-size: var(--f-md); line-height: 1.95; color: #5a5f72; margin-bottom: 22px; font-weight: 300; }
.founder-card { display: flex; gap: 20px; align-items: flex-start; padding: 28px; background: var(--c-phantom); border: var(--b-subtle); transition: transform 0.5s var(--ease), background 0.4s ease; will-change: transform; transform-style: preserve-3d; }
.founder-card:hover { background: #25252b; }
.founder-card img { width: 72px; height: 72px; object-fit: cover; object-position: center 12%; filter: grayscale(100%); flex-shrink: 0; }
.founder-name { font-size: var(--f-lg); font-weight: 800; color: var(--c-white); letter-spacing: -0.02em; }
.founder-role { font-size: var(--f-xs); color: var(--c-sand); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 700; margin-top: 4px; }
.founder-bio { font-size: var(--f-sm); color: var(--c-space); margin-top: 8px; line-height: 1.7; }

/* ═══ HOW WE WORK — STICKY SCROLL STORY ═══ */
.hww { background: var(--c-white); color: var(--c-deep); padding: 0; position: relative; }
.hww__head { padding: var(--sp-section) var(--sp-page) clamp(40px,6vw,80px); }
.hww__head h2 { font-size: var(--f-h2); font-weight: 300; letter-spacing: var(--ls-head); line-height: 1.12; }
.hww__sticky-wrap { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(32px,5vw,80px); padding: 0 var(--sp-page) var(--sp-section); align-items: start; }
.hww__sticky { position: sticky; top: calc(var(--nav-h) + 48px); align-self: start; padding-right: 24px; }
.hww__progress { display: flex; flex-direction: column; gap: 18px; margin-top: 32px; }
.hww__step-cue { display: grid; grid-template-columns: 36px 1fr; align-items: center; gap: 16px; opacity: 0.32; transition: opacity 0.5s var(--ease); cursor: pointer; }
.hww__step-cue.is-active { opacity: 1; }
.hww__step-num { font-size: 11px; font-weight: 800; letter-spacing: 0.2em; color: var(--c-deep); }
.hww__step-bar { height: 1px; background: var(--c-deep); transform: scaleX(0.18); transform-origin: left; transition: transform 0.6s var(--ease); }
.hww__step-cue.is-active .hww__step-bar { transform: scaleX(1); }
.hww__step-cue-name { grid-column: 2; font-size: var(--f-sm); font-weight: 600; color: var(--c-deep); }
.hww__sticky-eyebrow { font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-graphite); margin-bottom: 14px; display: flex; align-items: center; gap: 12px; }
.hww__sticky-eyebrow::before { content: ''; width: 18px; height: 1px; background: var(--c-sand); }
.hww__sticky-title { font-size: clamp(1.5rem,2.6vw,2.2rem); font-weight: 400; letter-spacing: var(--ls-head); line-height: 1.12; }
.hww__steps { display: flex; flex-direction: column; gap: clamp(40px,6vw,80px); }
.hww__step { padding: 56px 0; border-top: 0.5px solid rgba(0,0,0,0.06); min-height: 70vh; display: flex; flex-direction: column; justify-content: center; }
.hww__step:first-child { border-top: 0; padding-top: 0; }
.hww__step-mega { font-size: clamp(2.75rem,6.4vw,5.5rem); font-weight: 200; letter-spacing: var(--ls-head); line-height: 1.0; color: var(--c-deep); margin-bottom: 32px; }
.hww__step-mega em { font-style: italic; font-weight: 300; color: var(--c-graphite); }
.hww__step-body { font-size: var(--f-md); line-height: 1.95; color: #5a5f72; max-width: 480px; font-weight: 300; }
.hww__step-body strong { color: var(--c-deep); font-weight: 600; }

/* ═══ SERVICES ═══ */
.svc-section { background: var(--c-white); border-top: var(--b-rule); }
.svc-list { margin-top: 64px; border-top: var(--b-rule); }
.svc { display: grid; grid-template-columns: 80px 220px 1fr auto; align-items: start; padding: 72px 0; border-bottom: var(--b-rule); transition: padding 0.8s var(--ease), background 0.8s var(--ease); position: relative; overflow: hidden; }
.svc::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: var(--c-deep); transform: scaleX(0); transform-origin: left; transition: transform 0.6s var(--ease); }
.svc:hover { padding-left: 18px; padding-right: 18px; background: rgba(58,70,81,0.02); }
.svc:hover::before { transform: scaleX(1); }
.svc__n { font-size: clamp(1.5rem,2.4vw,2.2rem); color: var(--c-graphite); font-weight: 200; letter-spacing: -0.02em; padding-top: 5px; transition: color 0.8s var(--ease), transform 0.8s var(--ease); transform-origin: left; }
.svc:hover .svc__n { color: var(--c-sand); transform: scale(1.08); }
.svc__title { font-size: clamp(1.5rem,2.4vw,2rem); font-weight: 500; color: var(--c-deep); letter-spacing: var(--ls-head); line-height: 1.1; margin-bottom: 6px; }
.svc__tag { font-size: var(--f-xs); color: var(--c-graphite); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 600; }
.svc__body { font-size: var(--f-md); line-height: 1.78; color: #5a5f72; padding: 0 clamp(20px,3.5vw,48px); }
.svc__body strong { color: var(--c-deep); font-weight: 600; }

/* ═══ CONTACT ═══ */
.contact-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: clamp(40px,6vw,80px); align-items: start; }
.contact-info h2 { font-size: var(--f-h2); font-weight: 300; letter-spacing: var(--ls-head); line-height: 1.12; color: var(--c-white); margin-bottom: 20px; }
.contact-info > p { font-size: var(--f-md); color: var(--c-space); line-height: 1.8; margin-bottom: 40px; max-width: 420px; }
.contact-details { margin-bottom: 32px; }
.cd { margin-bottom: 16px; }
.cd__l { font-size: var(--f-xs); color: var(--c-graphite); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 700; margin-bottom: 4px; }
.cd__v { font-size: var(--f-md); color: var(--c-white); font-weight: 500; transition: color 0.3s ease; }
.cd a.cd__v:hover { color: var(--c-sand); }
.social-links { display: flex; gap: 12px; margin-top: 8px; }
.social-link { display: inline-flex; align-items: center; gap: 8px; font-size: var(--f-xs); font-weight: 700; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--c-space); border: 0.5px solid rgba(255,255,255,0.12); padding: 10px 18px; transition: color var(--t-btn) var(--ease), border-color var(--t-btn) var(--ease); }
.social-link:hover { color: var(--c-white); border-color: rgba(255,255,255,0.35); }

.fg { margin-bottom: 8px; position: relative; }
.fg label { display: block; font-size: var(--f-xs); color: var(--c-graphite); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 700; margin-bottom: 8px; transition: color 0.3s ease; }
.fg input, .fg textarea, .fg select { width: 100%; background: transparent; border: none; border-bottom: 0.5px solid rgba(255,255,255,0.18); color: var(--c-white); padding: 12px 0; font-family: var(--f); font-size: var(--f-md); outline: none; appearance: none; min-height: 48px; transition: border-color 0.4s ease; }
.fg input:focus, .fg textarea:focus, .fg select:focus { border-color: var(--c-sand); }
.fg:has(input:focus) label, .fg:has(textarea:focus) label, .fg:has(select:focus) label { color: var(--c-sand); }
.fg input::placeholder, .fg textarea::placeholder { color: var(--c-arsenic); }
.fg textarea { height: 86px; resize: none; min-height: unset; }
.fg select option { background: var(--c-phantom); }
.fg-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.f-submit { width: 100%; color: var(--c-deep); background: var(--c-white); border: 1px solid var(--c-white); padding: 18px; font-family: var(--f); font-size: var(--f-xs); font-weight: 800; letter-spacing: var(--ls-btn); text-transform: uppercase; margin-top: 28px; min-height: 52px; transition: background var(--t-btn) var(--ease), color var(--t-btn) var(--ease); position: relative; overflow: hidden; will-change: transform; cursor: none; }
.f-submit::after { content:''; position:absolute; inset:0; background: var(--c-sand); transform: translateY(101%); transition: transform 0.5s var(--ease); }
.f-submit:hover::after { transform: none; }
.f-submit span { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 12px; }
.f-submit .arrow { transition: transform 0.4s var(--ease); }
.f-submit:hover .arrow { transform: translateX(8px); }
.f-note { font-size: var(--f-xs); color: var(--c-graphite); margin-top: 14px; text-align: center; letter-spacing: 0.06em; }

/* ═══ FOOTER ═══ */
.footer-mega { background: var(--c-deep); border-top: var(--b-rule); padding: clamp(56px,8vw,112px) 0 0; overflow: hidden; }
.footer-mega__text { font-size: clamp(3.5rem, 12vw, 12rem); font-weight: 200; letter-spacing: -0.035em; line-height: 0.9; white-space: nowrap; color: transparent; -webkit-text-stroke: 0.5px rgba(255,255,255,0.18); display: flex; gap: 56px; will-change: transform; }
.footer-mega__text span { flex-shrink: 0; }
.footer { padding: 48px var(--sp-page); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px; background: var(--c-deep); }
.footer__mark img { height: 19px; filter: brightness(0) invert(0.32); }
.footer__copy { font-size: var(--f-xs); color: rgba(255,255,255,0.18); letter-spacing: 0.06em; }
.footer__nav { display: flex; gap: 24px; }
.footer__nav a { font-size: var(--f-xs); color: rgba(255,255,255,0.32); letter-spacing: var(--ls-label); text-transform: uppercase; font-weight: 700; transition: color var(--t-btn) var(--ease); }
.footer__nav a:hover { color: var(--c-sand); }

/* ═══ RESPONSIVE ═══ */
@media (max-width: 1100px) {
  .proj__head { grid-template-columns: 1fr; gap: 24px; align-items: start; }
  .proj__details { grid-template-columns: repeat(2, 1fr); }
  .hww__sticky-wrap { grid-template-columns: 1fr; }
  .hww__sticky { position: static; }
  .hww__step { min-height: auto; padding: 24px 0; }
  .prior__row { grid-template-columns: 1.2fr 0.6fr 1fr 0.8fr; }
  .prior__year { display: none; }
  .prior__row.head { grid-template-columns: 1.2fr 0.6fr 1fr 0.8fr; }
}
@media (max-width: 860px) {
  .nav__links { display: none; }
  .hero__stats { flex-direction: column; gap: 24px; }
  .hstat { border: none !important; padding: 0 !important; }
  .hero__brand { display: none; }
  .hero__body { padding-left: 0; }
  .about-body { grid-template-columns: 1fr; gap: 40px; }
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .fg-row { grid-template-columns: 1fr; }
  .footer { flex-direction: column; align-items: flex-start; }
  .proj__details { grid-template-columns: 1fr; }
  .svc { grid-template-columns: 60px 1fr; }
  .svc__body { grid-column: 1/-1; padding: 16px 0 0; }
  .prior__row, .prior__row.head { grid-template-columns: 1.5fr 1fr 0.8fr; }
  .prior__type { display: none; }
}
@media (max-width: 560px) {
  .hero__actions { flex-direction: column; align-items: stretch; }
  .btn { width: 100%; justify-content: center; }
  .prior__head { grid-template-columns: 1fr; }
  .gallery__card { flex: 0 0 80vw; }
}
