/* ════════════════════════════════════════════════════════════
   SET DESIGN SRL · style.css v6
   Space Black #121313 · Neon Coral #FF6044
   Logo: Xtreem2 (script) + OL Round Gothic Bold (display)

   SECTIONS
   01 · Fonts & Imports
   02 · Reset & Variables
   03 · Cursor
   04 · Logo
   05 · Topbar
   06 · Ticker
   07 · Reveal
   08 · Manifesto
   09 · Hero
   10 · Statement
   11 · Mosaic Bar
   12 · Split
   13 · Clients
   14 · Process
   15 · Expertise
   16 · Full CTA
   17 · Contact
   18 · Gallery Page
   19 · Footer
   20 · Keyframes
   21 · Responsive
════════════════════════════════════════════════════════════ */


/* ── 01 · FONTS & IMPORTS ───────────────────────────────── */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Bebas+Neue&family=Pacifico&family=Nunito:wght@900&display=swap");

@font-face {
  font-family: "Xtreem2";
  src: url("assets/fonts/Xtreem2.woff2") format("woff2");
  font-weight: normal; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "OLRoundGothic";
  src: url("assets/fonts/OLRoundGothic.woff2") format("woff2");
  font-weight: bold; font-style: normal; font-display: swap;
}


/* ── 02 · RESET & VARIABLES ─────────────────────────────── */

*,*::before,*::after { margin: 0; padding: 0; box-sizing: border-box }

:root {
  --b:       #121313;
  --b-soft:  #1a1b1b;
  --b-card:  #1e1f1f;
  --coral:   #FF6044;
  --coral-d: #e04530;
  --w:       #F5F4F0;
  --g:       #7a7a7a;
  --border:  rgba(255,255,255,.09);

  --f-script:  "Xtreem2", cursive;
  --f-gothic:  "OLRoundGothic", sans-serif;
  --f-display: "Bebas Neue", sans-serif;
  --f-body:    "Inter", sans-serif;

  --nav-h: 62px;
  --px:    40px;
  --ease:  cubic-bezier(.23,1,.32,1);
}

html  { scroll-behavior: smooth; font-size: 17px }
body  { background: var(--b); color: var(--w); font-family: var(--f-body); overflow-x: hidden; cursor: none }
img   { display: block; max-width: 100% }
a     { text-decoration: none }
::selection { background: var(--coral); color: var(--b) }

/* gallery.html needs top padding to clear the fixed topbar */
.gallery-page { padding-top: var(--nav-h) }


/* ── 03 · CURSOR (desktop only) ─────────────────────────── */

#cur  { position: fixed; width: 6px; height: 6px; background: var(--coral); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); transition: width .25s var(--ease), height .25s var(--ease) }
#cur2 { position: fixed; width: 28px; height: 28px; border: 1px solid rgba(255,96,68,.35); border-radius: 50%; pointer-events: none; z-index: 9998; transform: translate(-50%,-50%); transition: all .14s ease }
#cur.expanded          { width: 44px; height: 44px; background: transparent; border: 1px solid var(--coral) }
#cur.expanded ~ #cur2  { opacity: 0 }

@media (pointer: coarse), (hover: none) {
  body       { cursor: auto !important }
  #cur, #cur2 { display: none !important }
}


/* ── 04 · LOGO ──────────────────────────────────────────── */

.logo-text   { display: inline-flex; align-items: baseline; gap: 2px; line-height: 1; cursor: pointer }
.logo-set    { font-family: var(--f-script);  font-size: 1.55rem; color: var(--w); font-weight: 400; letter-spacing: -.01em; line-height: 1 }
.logo-design { font-family: var(--f-gothic);  font-size: 1.05rem; color: var(--w); font-weight: bold; letter-spacing: .06em; text-transform: lowercase }
.logo-r      { font-size: .45em; vertical-align: super; color: rgba(245,244,240,.38); font-weight: 400; font-family: var(--f-body) }


/* ── 05 · TOPBAR ────────────────────────────────────────── */

.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  height: var(--nav-h);
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 var(--px);
  transition: transform .5s var(--ease), background .4s, border-color .4s;
  border-bottom: 1px solid transparent;
}
.topbar.solid  { background: rgba(18,19,19,.97); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px); border-color: var(--border) }
.topbar.hidden { transform: translateY(-100%) }
.topbar-logo a, .topbar-logo-link { color: inherit }

.topbar-nav { display: flex; gap: 32px; list-style: none; align-items: center }
.topbar-nav > li > a {
  font-size: .78rem; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(245,244,240,.5);
  position: relative; padding-bottom: 2px;
  transition: color .25s; white-space: nowrap; display: flex; align-items: center;
}
.topbar-nav > li > a::after { content: ""; position: absolute; bottom: 0; left: 0; width: 0; height: 1px; background: var(--coral); transition: width .35s var(--ease) }
.topbar-nav > li > a:hover,
.topbar-nav > li > a.active { color: var(--w) }
.topbar-nav > li > a:hover::after { width: 100% }

/* Dropdown */
.nav-dropdown { position: relative }
.nav-dropdown::after { content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 260px; height: 18px; background: transparent }
.nav-dropdown-panel {
  position: absolute; top: calc(100% + 16px); left: 50%;
  transform: translateX(-50%) translateY(6px);
  background: var(--b-soft); border: 1px solid var(--border);
  min-width: 260px; padding: 6px 0;
  opacity: 0; pointer-events: none;
  transition: opacity .22s var(--ease), transform .22s var(--ease);
}
.nav-dropdown:hover .nav-dropdown-panel { opacity: 1; pointer-events: all; transform: translateX(-50%) translateY(0) }
.nav-dropdown-panel a { display: flex; align-items: center; gap: 14px; padding: 13px 22px; font-size: .75rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(245,244,240,.42); transition: color .2s, background .2s }
.nav-dropdown-panel a::after { display: none !important }
.nav-dropdown-panel a:hover { color: var(--coral); background: rgba(255,96,68,.06) }
.ddnum     { font-family: var(--f-display); font-size: .9rem; color: var(--coral); min-width: 22px }
.nav-caret { font-size: .42rem; margin-left: 5px; opacity: .4; transition: transform .3s; display: inline-block }
.nav-dropdown:hover .nav-caret { transform: rotate(180deg) }

/* Language toggle & CTA */
.lang-toggle {
  display: flex; align-items: center; gap: 0;
  border: 1px solid rgba(255,255,255,.18);
  background: transparent; cursor: pointer;
  font-family: var(--f-body); overflow: hidden;
}
.lang-toggle .lt-opt { font-size: .7rem; font-weight: 600; letter-spacing: .2em; color: rgba(245,244,240,.3); padding: 7px 12px; transition: all .22s; border: none; background: transparent; cursor: pointer }
.lang-toggle .lt-sep { font-size: .6rem; color: rgba(255,255,255,.15); pointer-events: none }
.lang-toggle .lt-opt.active { color: var(--b); background: var(--coral) }
.lang-toggle:hover { border-color: var(--coral) }

.topbar-cta { font-size: .75rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--b); background: var(--coral); padding: 10px 24px; transition: background .25s, transform .2s }
.topbar-cta:hover { background: var(--coral-d); transform: translateY(-1px) }


/* ── 06 · TICKER ────────────────────────────────────────── */

.ticker { overflow: hidden; background: var(--coral); padding: 13px 0 }
.ticker-track { display: flex; white-space: nowrap; animation: tickeranim 24s linear infinite }
.ticker-track:hover { animation-play-state: paused }
.ticker-item       { font-family: var(--f-display); font-size: 1.15rem; letter-spacing: .22em; color: var(--b); padding: 0 48px; opacity: .7 }
.ticker-item.accent { opacity: 1 }
.ticker-sep        { color: rgba(18,19,19,.3); margin: 0 4px }


/* ── 07 · REVEAL ────────────────────────────────────────── */

.reveal    { opacity: 0; transform: translateY(32px); transition: opacity .95s var(--ease), transform .95s var(--ease) }
.reveal.in { opacity: 1; transform: none }
.d1 { transition-delay: .08s }
.d2 { transition-delay: .16s }
.d3 { transition-delay: .24s }
.d4 { transition-delay: .32s }
.d5 { transition-delay: .40s }


/* ── 08 · MANIFESTO ─────────────────────────────────────── */

.manifesto { background: var(--b); overflow: hidden }
.m-line { display: flex; align-items: center; padding: 0 var(--px); border-bottom: 1px solid var(--border); height: 104px; overflow: hidden }
.m-line:first-child { border-top: 1px solid var(--border) }
.m-text {
  font-family: var(--f-display); font-size: clamp(2.8rem,7vw,7.5rem);
  color: var(--w); letter-spacing: .02em; white-space: nowrap; line-height: 1;
  opacity: 0; transform: translateX(-48px);
  transition: opacity .75s var(--ease), transform .75s var(--ease), color .3s;
}
.m-line.visible .m-text { opacity: 1; transform: translateX(0) }
.m-line:nth-child(1).visible .m-text { transition-delay: .00s }
.m-line:nth-child(2).visible .m-text { transition-delay: .12s }
.m-line:nth-child(3).visible .m-text { transition-delay: .24s }
.m-line:nth-child(4).visible .m-text { transition-delay: .36s }
.m-line:hover .m-text { color: var(--coral) }


/* ── 09 · HERO ──────────────────────────────────────────── */

.hero { height: 100svh; display: grid; grid-template-columns: 1fr 2fr 1fr 2fr 1fr; gap: 2px; position: relative; overflow: hidden; background: var(--b) }
.hero-col { position: relative; overflow: hidden }
.hero-col img { width: 100%; height: 100%; object-fit: cover; object-position: center center; filter: brightness(.42) saturate(.8); transition: transform 10s ease, filter .6s }
.hero-col:hover img { transform: scale(1.06); filter: brightness(.58) saturate(1) }

.hero-center { position: relative; background: var(--b); z-index: 5 }
.hero-video  { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(.32) saturate(.85); z-index: 0; pointer-events: none }
.hero-center::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at center, rgba(255,96,68,.07) 0%, transparent 68%); z-index: 1; pointer-events: none }

.hero-title-block { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); text-align: center; white-space: nowrap; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 18px }
.hero-logo             { display: flex; align-items: baseline; gap: 4px; line-height: 1 }
.hero-logo .logo-set   { font-size: 5rem;   animation: fadeIn 1.2s var(--ease) both }
.hero-logo .logo-design{ font-size: 3.2rem; animation: fadeIn 1.4s var(--ease) .08s both }
.hero-logo .logo-r     { font-size: .9rem }
.hero-line { font-size: .62rem; font-weight: 600; letter-spacing: .55em; text-transform: uppercase; color: var(--coral); animation: fadeIn 1.6s var(--ease) .25s both }

.hero-bottom  { position: absolute; bottom: 0; left: 0; right: 0; padding: 34px var(--px); display: flex; justify-content: space-between; align-items: flex-end; z-index: 10 }
.hero-tagline { font-size: 1.1rem; font-weight: 300; color: rgba(245,244,240,.85); max-width: 340px; line-height: 1.65 }

.hero-scroll               { display: inline-flex; flex-direction: column; align-items: center; gap: 10px; text-decoration: none; cursor: pointer }
.hero-scroll-label         { font-size: .62rem; letter-spacing: .38em; text-transform: uppercase; color: rgba(245,244,240,.7); transition: color .3s }
.hero-scroll:hover .hero-scroll-label { color: var(--coral) }
.hero-scroll-chevrons      { position: relative; width: 20px; height: 24px }
.hero-scroll-chevrons .chev       { position: absolute; left: 0; width: 20px; height: 12px; overflow: visible }
.hero-scroll-chevrons .chev path  { fill: none; stroke: rgba(245,244,240,.7); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: stroke .3s }
.hero-scroll:hover .chev path     { stroke: var(--coral) }
.chev1 { animation: scrollChev 1.6s var(--ease) infinite }
.chev2 { top: 7px; animation: scrollChev 1.6s var(--ease) infinite .22s }

.hero-corner    { position: absolute; font-size: .54rem; letter-spacing: .32em; text-transform: uppercase; color: rgba(245,244,240,.18) }
.hero-corner.tl { top: 80px; left: var(--px) }
.hero-corner.tr { top: 80px; right: var(--px); text-align: right }


/* ── 10 · STATEMENT ─────────────────────────────────────── */

.statement { padding: 128px var(--px); border-bottom: 1px solid var(--border) }
.statement-inner { max-width: 1260px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start }
.st-left  { display: flex; flex-direction: column; gap: 16px }
.st-label { font-size: .65rem; font-weight: 500; letter-spacing: .5em; text-transform: uppercase; color: rgba(245,244,240,.35) }
.st-h2    { font-family: var(--f-display); font-size: clamp(4rem,7vw,8rem); line-height: .85; letter-spacing: .02em; color: var(--w) }
.st-h2 em { color: var(--coral); font-style: normal }
.st-right   { display: flex; flex-direction: column; gap: 36px; padding-top: 8px }
.st-right p { font-size: 1rem; font-weight: 300; line-height: 2; color: rgba(245,244,240,.72) }


/* ── 11 · MOSAIC BAR ────────────────────────────────────── */

.mosaic       { overflow: hidden; background: var(--b-soft); border-top: 1px solid var(--border); pointer-events: none; user-select: none }
.mosaic-track { display: flex; width: max-content; gap: 2px; animation: mosaicScroll 25s linear infinite; will-change: transform; backface-visibility: hidden; transform: translate3d(0,0,0) }
.mosaic-item  { flex: 0 0 auto; position: relative; overflow: hidden; height: 320px }
.mosaic-item img { width: 100%; height: 100%; object-fit: cover; display: block; filter: brightness(.58) saturate(.85) }
.m-cap      { position: absolute; bottom: 0; left: 0; right: 0; padding: 14px 16px; background: linear-gradient(transparent, rgba(18,19,19,.88)) }
.m-cap h4   { font-family: var(--f-display); font-size: 1rem; color: var(--w); letter-spacing: .08em; margin: 0 0 2px }
.m-cap span { font-size: .56rem; letter-spacing: .3em; text-transform: uppercase; color: var(--coral) }
.mi-1  { width: 500px } .mi-2  { width: 300px } .mi-3  { width: 380px } .mi-4  { width: 260px } .mi-5  { width: 360px }
.mi-6  { width: 480px } .mi-7  { width: 220px } .mi-8  { width: 440px } .mi-9  { width: 300px } .mi-10 { width: 360px }


/* ── 12 · SPLIT ─────────────────────────────────────────── */

.split { display: grid; grid-template-columns: 1fr 1fr; min-height: 90vh }
.split-img { position: relative; overflow: hidden }
.split-img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.55) saturate(.85); transition: filter .6s, transform .8s var(--ease) }
.split:hover .split-img img { filter: brightness(.68); transform: scale(1.02) }

.split-content { background: var(--b-soft); display: flex; flex-direction: column; justify-content: space-between; padding: 80px 64px; border-left: 1px solid var(--border) }
.sp-eye   { display: block; font-size: .68rem; letter-spacing: .5em; text-transform: uppercase; color: rgba(245,244,240,.45); margin-bottom: 48px }
.sp-h2    { font-family: var(--f-display); font-size: clamp(3rem,4.5vw,5rem); color: var(--w); line-height: .88; letter-spacing: .03em; margin-bottom: 40px }
.sp-h2 em { color: var(--coral); font-style: normal }
.split-content p { font-size: 1rem; font-weight: 300; color: rgba(245,244,240,.65); line-height: 2; max-width: 400px; margin-bottom: 52px }
.sp-link { display: inline-flex; align-items: center; gap: 14px; font-size: .78rem; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--coral); transition: gap .3s }
.sp-link:hover { gap: 22px }
.sp-stats { display: flex; gap: 48px; padding-top: 52px; border-top: 1px solid var(--border) }
.sp-n { font-family: var(--f-display); font-size: 3.2rem; color: var(--coral); line-height: 1 }
.sp-l { font-size: .65rem; letter-spacing: .25em; text-transform: uppercase; color: rgba(245,244,240,.45); margin-top: 6px }


/* ── 13 · CLIENTS ───────────────────────────────────────── */

.clients { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); overflow: hidden }
.clients-header    { padding: 72px var(--px) 44px; display: flex; justify-content: space-between; align-items: flex-end }
.clients-header h2 { font-family: var(--f-display); font-size: clamp(3rem,5vw,5.5rem); line-height: .88; letter-spacing: .03em; color: var(--w) }
.clients-header p  { font-size: 1rem; font-weight: 300; color: rgba(245,244,240,.6); max-width: 320px; line-height: 2; text-align: right }

/* Marquee rows */
.clients-marquee { display: flex; flex-direction: column; gap: 0; padding: 8px 0 4px; border-top: 1px solid var(--border) }
.cm-row { overflow: hidden; white-space: nowrap; padding: 10px 0; position: relative }
.cm-row::before,
.cm-row::after  { content: ""; position: absolute; top: 0; bottom: 0; width: 120px; z-index: 2; pointer-events: none }
.cm-row::before { left: 0;  background: linear-gradient(to right, var(--b), transparent) }
.cm-row::after  { right: 0; background: linear-gradient(to left,  var(--b), transparent) }
.cm-track       { display: inline-flex; align-items: center; gap: 0; will-change: transform; animation: cmScroll 60s linear infinite }
.cm-track.cm-rev{ animation-direction: reverse; animation-duration: 74s }
.clients-marquee:hover .cm-track { animation-play-state: paused }
.cm-item { font-family: var(--f-display); font-size: clamp(1.6rem,3vw,2.8rem); letter-spacing: .04em; color: rgba(245,244,240,.22); text-decoration: none; padding: 0 4px; transition: color .25s; display: inline-block }
a.cm-item:hover { color: var(--coral) }
.cm-dot { display: inline-block; color: var(--coral); opacity: .4; font-size: 1rem; margin: 0 26px; vertical-align: middle }

/* Toggle button */
.clients-toggle-wrap { border-top: 1px solid var(--border); display: flex; justify-content: center; padding: 32px var(--px) }
#clients-toggle-btn {
  background: transparent; border: 1px solid var(--border); color: rgba(245,244,240,.55);
  font-family: var(--f-body); font-size: .72rem; font-weight: 500; letter-spacing: .35em;
  text-transform: uppercase; padding: 14px 36px; cursor: pointer; transition: all .25s;
}
#clients-toggle-btn:hover { border-color: var(--coral); color: var(--coral) }

/* Full accordion list */
#clients-all-panel       { max-height: 0; overflow: hidden; transition: max-height .7s cubic-bezier(.23,1,.32,1) }
#clients-all-panel.open  { max-height: 9000px; border-top: 1px solid var(--border) }
.clients-index { padding: 56px var(--px) 16px; column-count: 4; column-gap: 48px }
.ci-name {
  display: block; break-inside: avoid;
  font-size: .92rem; font-weight: 300; letter-spacing: .04em; color: rgba(245,244,240,.5);
  padding: 9px 0; line-height: 1.3;
  text-decoration: none; border-bottom: 1px solid transparent;
  transition: color .2s, border-color .2s, padding-left .2s; width: fit-content;
}
a.ci-name:hover { color: var(--coral); border-bottom-color: rgba(255,96,68,.35); padding-left: 8px }
.ci-nohref { cursor: default }
.clients-close-wrap { display: flex; justify-content: center; padding: 24px var(--px) 56px }
#clients-close-btn {
  background: transparent; border: 1px solid var(--border); color: rgba(245,244,240,.55);
  font-family: var(--f-body); font-size: .72rem; font-weight: 500; letter-spacing: .35em;
  text-transform: uppercase; padding: 14px 36px; cursor: pointer; transition: all .25s;
}
#clients-close-btn:hover { border-color: var(--coral); color: var(--coral) }


/* ── 14 · PROCESS ───────────────────────────────────────── */

.process       { border-top: 1px solid var(--border); padding: 112px var(--px) }
.process-inner { max-width: 860px; margin: 0 auto }
.process-head  { display: flex; justify-content: space-between; align-items: flex-end; padding-bottom: 88px }
.process-head h2 { font-family: var(--f-display); font-size: clamp(3rem,5vw,5rem); letter-spacing: .03em; color: var(--w) }
.process-head p  { font-size: .95rem; font-weight: 300; color: rgba(245,244,240,.55); max-width: 260px; text-align: right; line-height: 1.85 }

.process-timeline { position: relative; padding-left: 52px }
.process-timeline::before { content: ""; position: absolute; left: 6px; top: 12px; bottom: 0; width: 1px; background: rgba(245,244,240,.1) }
.tl-fill { position: absolute; left: 6px; top: 12px; width: 1px; height: 0; background: var(--coral); transition: height .7s cubic-bezier(.23,1,.32,1); z-index: 1 }

.pstep          { position: relative; padding-bottom: 72px; opacity: 0; transform: translateX(16px); transition: opacity .6s var(--ease), transform .6s var(--ease) }
.pstep:last-child { padding-bottom: 0 }
.pstep.lit      { opacity: 1; transform: translateX(0) }
.pstep-dot { position: absolute; left: -53px; top: 5px; width: 14px; height: 14px; border-radius: 50%; border: 1px solid rgba(245,244,240,.2); background: var(--b); z-index: 2; transition: border-color .5s, background .5s, box-shadow .5s }
.pstep.lit .pstep-dot { border-color: var(--coral); background: var(--coral); box-shadow: 0 0 18px rgba(255,96,68,.5) }

.ps-num         { font-family: var(--f-display); font-size: 2.8rem; color: rgba(245,244,240,.06); line-height: 1; margin-bottom: 16px; transition: color .7s var(--ease) }
.pstep.lit .ps-num  { color: var(--coral) }
.ps-label       { font-size: .7rem; font-weight: 600; letter-spacing: .42em; text-transform: uppercase; color: rgba(245,244,240,.22); margin-bottom: 12px; display: block; transition: color .5s }
.pstep.lit .ps-label{ color: var(--w) }
.ps-text        { font-size: .95rem; font-weight: 300; line-height: 2; color: rgba(245,244,240,.3); transition: color .6s }
.pstep.lit .ps-text { color: rgba(245,244,240,.65) }


/* ── 15 · EXPERTISE ─────────────────────────────────────── */

.expertise       { padding: 112px var(--px); border-top: 1px solid var(--border) }
.expertise-inner { max-width: 1200px; margin: 0 auto }
.expertise-head  { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 64px }
.expertise-head h2 { font-family: var(--f-display); font-size: clamp(3rem,6vw,6rem); letter-spacing: .03em; color: var(--w) }
.expertise-head p  { font-size: .95rem; font-weight: 300; color: rgba(245,244,240,.55); max-width: 300px; line-height: 1.85; text-align: right }
.exp-row      { display: grid; grid-template-columns: 76px 1fr 260px; align-items: center; padding: 28px 0; border-bottom: 1px solid var(--border); gap: 32px }
.exp-row-num  { font-family: var(--f-display); font-size: 1.35rem; color: rgba(245,244,240,.18); letter-spacing: .12em }
.exp-row-name { font-family: var(--f-display); font-size: clamp(1.6rem,2.8vw,2.8rem); letter-spacing: .04em; text-transform: uppercase; color: var(--w) }
.exp-row-desc { font-size: .9rem; font-weight: 300; color: rgba(245,244,240,.5); line-height: 1.8 }
.expertise-cta { margin-top: 52px; text-align: right }
.exp-gallery-link { display: inline-flex; align-items: center; gap: 14px; font-size: .78rem; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--coral); transition: gap .3s }
.exp-gallery-link:hover { gap: 22px }


/* ── 16 · FULL CTA ──────────────────────────────────────── */

.full-cta    { min-height: 72vh; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center }
.full-cta-bg { position: absolute; inset: 0; overflow: hidden }
.full-cta-bg img,
.full-cta-bg video { width: 100%; height: 100%; object-fit: cover; filter: brightness(.16) saturate(1.4) }
.full-cta-accent   { position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 60%, rgba(255,96,68,.14) 0%, transparent 65%) }

.fcc     { position: relative; z-index: 2; text-align: center; padding: 40px }
.fcc-eye { font-size: .68rem; letter-spacing: .62em; text-transform: uppercase; color: rgba(245,244,240,.45); margin-bottom: 28px; display: block }
.fcc h2  { font-family: var(--f-display); font-size: clamp(5rem,14vw,13rem); color: var(--w); line-height: .8; letter-spacing: .02em; margin-bottom: 52px }
.fcc h2 em { color: var(--coral); font-style: normal; display: block }

.cta-btn { display: inline-block; background: var(--coral); color: var(--b); padding: 18px 56px; font-size: .75rem; font-weight: 700; letter-spacing: .4em; text-transform: uppercase; transition: all .3s var(--ease) }
.cta-btn:hover { background: var(--w); transform: translateY(-3px); box-shadow: 0 12px 32px rgba(255,96,68,.35) }


/* ── 17 · CONTACT ───────────────────────────────────────── */

.contact           { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--border) }
.contact-info      { padding: 96px 64px; border-right: 1px solid var(--border) }
.ci-h2             { font-family: var(--f-display); font-size: clamp(2.5rem,4.5vw,5rem); letter-spacing: .03em; margin-bottom: 52px; line-height: .85; color: var(--w) }
.ci-h2 em          { color: var(--coral); font-style: normal }
.ci-items          { display: flex; flex-direction: column }
.ci-item           { display: flex; gap: 22px; align-items: flex-start; padding: 26px 0; border-bottom: 1px solid var(--border) }
.ci-icon           { width: 44px; height: 44px; flex-shrink: 0; border: 1px solid var(--coral); color: var(--coral); font-size: 1rem; font-weight: 700; font-family: var(--f-body); display: flex; align-items: center; justify-content: center; line-height: 1 }
.ci-label          { font-size: .65rem; letter-spacing: .4em; text-transform: uppercase; color: rgba(245,244,240,.45); margin-bottom: 7px; display: block }
.ci-value          { font-size: 1rem; font-weight: 300; color: rgba(245,244,240,.78) }
.ci-value a        { color: inherit; transition: color .2s }
.ci-value a:hover  { color: var(--coral) }

.contact-form-side { padding: 96px 64px }
.cfs-eyebrow       { font-size: .68rem; letter-spacing: .5em; text-transform: uppercase; color: rgba(245,244,240,.35); margin-bottom: 48px; display: block }
.cform  { display: flex; flex-direction: column }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; margin-bottom: 2px }
.cf-field { display: flex; flex-direction: column; margin-bottom: 2px }
.cf-label { font-size: .65rem; letter-spacing: .42em; text-transform: uppercase; color: rgba(245,244,240,.38); padding: 15px 22px 0; background: var(--b-soft) }
.cf-input,
.cf-textarea { border: none; background: var(--b-soft); padding: 10px 22px 18px; font-family: var(--f-body); font-size: .95rem; font-weight: 300; color: var(--w); outline: none; transition: background .2s, box-shadow .2s; width: 100% }
.cf-input:focus,
.cf-textarea:focus  { background: var(--b-card); box-shadow: inset 0 -1px 0 var(--coral) }
.cf-input::placeholder,
.cf-textarea::placeholder { color: rgba(245,244,240,.28) }
.cf-textarea { resize: none; height: 126px }
.cf-submit { margin-top: 2px; background: var(--coral); color: var(--b); border: none; padding: 22px; font-family: var(--f-body); font-size: .78rem; font-weight: 700; letter-spacing: .4em; text-transform: uppercase; cursor: pointer; transition: background .25s, transform .25s; width: 100% }
.cf-submit:hover { background: var(--coral-d); transform: translateY(-1px) }


/* ── 18 · GALLERY PAGE ──────────────────────────────────── */

.gp-intro { padding: 96px var(--px) 56px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 60px; align-items: end; border-bottom: 1px solid var(--border) }
.gp-eyebrow    { font-size: .66rem; font-weight: 600; letter-spacing: .5em; text-transform: uppercase; color: var(--coral); margin-bottom: 24px; display: block }
.gp-h1         { font-family: var(--f-display); font-size: clamp(5rem,16vw,16rem); line-height: .82; letter-spacing: .02em; color: var(--w) }
.gp-intro-text { font-size: 1.02rem; font-weight: 300; line-height: 2; color: rgba(245,244,240,.62); padding-bottom: 14px }

/* Gallery mosaic grid */
.gp-mosaic {
  padding: 48px var(--px) 120px;
  display: grid; grid-template-columns: repeat(4,1fr); grid-auto-rows: 150px;
  grid-auto-flow: dense; gap: 14px;
}
.mtile {
  position: relative; overflow: hidden; cursor: pointer;
  border: none; padding: 0; margin: 0; background: var(--b-card);
  display: block; width: 100%; height: 100%;
  opacity: 0; transform: translateY(28px);
  transition: opacity .7s var(--ease) var(--d), transform .7s var(--ease) var(--d);
}
.mtile.in { opacity: 1; transform: translateY(0) }
.mtile-lg  { grid-column: span 2; grid-row: span 4 }
.mtile-tall{ grid-column: span 1; grid-row: span 4 }
.mtile-wide{ grid-column: span 2; grid-row: span 2 }
.mtile-md  { grid-column: span 1; grid-row: span 3 }
.mtile-sm  { grid-column: span 1; grid-row: span 2 }

.mtile-img { position: absolute; inset: 0 }
.mtile-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(.74) saturate(.95); transition: transform 1.1s var(--ease), filter .6s, opacity .7s var(--ease) }
.mtile:hover .mtile-img img { transform: scale(1.07); filter: brightness(.5) saturate(1.1) }
.mtile-img .mtile-preview      { opacity: 0; pointer-events: none }
.mtile-img .mtile-preview.show { opacity: 1 }

.mtile-veil { position: absolute; inset: 0; background: linear-gradient(to top, rgba(18,19,19,.92) 0%, rgba(18,19,19,.15) 45%, transparent 70%); opacity: .7; transition: opacity .5s }
.mtile:hover .mtile-veil { opacity: .95 }

.mtile-meta { position: absolute; left: 0; right: 0; bottom: 0; padding: 22px 22px 24px; text-align: left; z-index: 2; transform: translateY(8px); transition: transform .45s var(--ease) }
.mtile:hover .mtile-meta { transform: translateY(0) }
.mtile-cat   { font-size: .58rem; font-weight: 600; letter-spacing: .34em; text-transform: uppercase; color: var(--coral); display: block; margin-bottom: 8px }
.mtile-title { font-family: var(--f-display); font-size: clamp(1.3rem,2vw,2rem); letter-spacing: .04em; color: var(--w); line-height: 1; margin-bottom: 6px }
.mtile-loc   { font-size: .72rem; font-weight: 300; letter-spacing: .1em; color: rgba(245,244,240,.5) }

.mtile-count {
  position: absolute; top: 16px; right: 16px; z-index: 2;
  width: 32px; height: 32px; border: 1px solid rgba(245,244,240,.4); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .72rem; font-weight: 500; color: var(--w);
  background: rgba(18,19,19,.35); backdrop-filter: blur(6px);
  opacity: 0; transform: scale(.7); transition: opacity .35s, transform .35s var(--ease);
}
.mtile:hover .mtile-count { opacity: 1; transform: scale(1) }

/* Immersive viewer */
#viewer      { position: fixed; inset: 0; z-index: 4000; background: var(--b); opacity: 0; pointer-events: none; transition: opacity .4s var(--ease) }
#viewer.open { opacity: 1; pointer-events: all }
#viewer-bar  {
  position: absolute; top: 0; left: 0; right: 0; height: 84px; z-index: 3;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--px);
  background: linear-gradient(to bottom, rgba(18,19,19,.95), transparent);
}
#viewer-meta  { display: flex; flex-direction: column; gap: 3px }
#viewer-cat   { font-size: .6rem; font-weight: 600; letter-spacing: .4em; text-transform: uppercase; color: var(--coral) }
#viewer-title { font-family: var(--f-display); font-size: clamp(1.4rem,2.6vw,2.4rem); letter-spacing: .04em; color: var(--w); line-height: 1 }
#viewer-loc   { font-size: .74rem; font-weight: 300; letter-spacing: .1em; color: rgba(245,244,240,.5) }
#viewer-close { width: 46px; height: 46px; flex-shrink: 0; background: rgba(18,19,19,.4); border: 1px solid var(--border); color: var(--w); font-size: 1.5rem; cursor: pointer; font-family: var(--f-body); line-height: 1; display: flex; align-items: center; justify-content: center; transition: all .2s; backdrop-filter: blur(8px) }
#viewer-close:hover { background: var(--coral); border-color: var(--coral); color: var(--b) }

#viewer-progress     { position: absolute; top: 0; left: 0; right: 0; height: 2px; z-index: 4; background: rgba(255,255,255,.08) }
#viewer-progress-bar { height: 100%; width: 0; background: var(--coral); transition: width .1s linear }

#viewer-scroll { position: absolute; inset: 0; overflow-y: auto; scroll-behavior: smooth; scrollbar-width: thin; scrollbar-color: var(--coral) transparent }
#viewer-scroll::-webkit-scrollbar       { width: 4px }
#viewer-scroll::-webkit-scrollbar-thumb { background: var(--coral) }

.vphoto { margin: 0; padding: 0; width: 100%; display: flex; justify-content: center; background: var(--b) }
.vphoto:first-child { padding-top: 84px }
.vphoto img { width: 100%; max-width: 1200px; height: auto; display: block; object-fit: contain; opacity: 0; transform: translateY(30px); animation: vReveal .8s var(--ease) forwards; animation-delay: var(--vd) }

.vnext       { min-height: 42vh; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; cursor: pointer; border-top: 1px solid var(--border); background: var(--b-soft); transition: background .3s }
.vnext:hover { background: var(--b-card) }
.vnext-label { font-size: .64rem; font-weight: 600; letter-spacing: .45em; text-transform: uppercase; color: rgba(245,244,240,.4) }
.vnext-title { font-family: var(--f-display); font-size: clamp(2rem,5vw,4rem); letter-spacing: .04em; color: var(--w); transition: color .3s }
.vnext:hover .vnext-title { color: var(--coral) }


/* ── 19 · FOOTER ────────────────────────────────────────── */

footer { background: var(--b-soft); color: var(--w); padding: 80px var(--px) 40px; border-top: 1px solid var(--border) }
.footer-logo { margin-bottom: 28px }
.footer-top  { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 60px; margin-bottom: 60px; padding-bottom: 60px; border-bottom: 1px solid var(--border) }
.fb-text  { font-size: .92rem; font-weight: 300; color: rgba(245,244,240,.3); line-height: 2; max-width: 280px }
.fc-head  { display: block; font-size: .65rem; letter-spacing: .4em; text-transform: uppercase; color: rgba(245,244,240,.25); margin-bottom: 22px }
.fc-links { list-style: none; display: flex; flex-direction: column; gap: 13px }
.fc-links a { font-size: .9rem; font-weight: 300; color: rgba(245,244,240,.45); transition: color .2s }
.fc-links a:hover { color: var(--coral) }
.footer-bottom   { display: flex; justify-content: space-between; align-items: center }
.footer-copy     { font-size: .68rem; letter-spacing: .18em; color: rgba(245,244,240,.18); text-transform: uppercase }
.footer-socials  { display: flex; gap: 24px }
.footer-socials a { font-size: .68rem; letter-spacing: .28em; text-transform: uppercase; color: rgba(245,244,240,.25); transition: color .2s }
.footer-socials a:hover { color: var(--coral) }


/* ── 20 · KEYFRAMES ─────────────────────────────────────── */

@keyframes tickeranim   { from { transform: translateX(0) }     to { transform: translateX(-50%) } }
@keyframes mosaicScroll { from { transform: translate3d(-50%,0,0) }  to { transform: translate3d(0,0,0) } }
@keyframes cmScroll     { from { transform: translateX(0) }     to { transform: translateX(-50%) } }
@keyframes fadeIn       { from { opacity: 0 }                   to { opacity: 1 } }
@keyframes scaleIn      { from { transform: scale(.96); opacity: 0 } to { transform: scale(1); opacity: 1 } }
@keyframes scrollChev {
  0%   { transform: translateY(-4px); opacity: 0 }
  35%  { opacity: 1 }
  70%  { transform: translateY(5px);  opacity: 0 }
  100% { opacity: 0 }
}
@keyframes vReveal { to { opacity: 1; transform: translateY(0) } }


/* ── 21 · RESPONSIVE ────────────────────────────────────── */

@media(max-width:1100px) {
  .hero        { grid-template-columns: 1fr 3fr 1fr }
  .hero-col:nth-child(2),
  .hero-col:nth-child(4) { display: none }
  .footer-top  { grid-template-columns: 1fr 1fr }
}

@media(max-width:1024px) {
  .clients-index { column-count: 3 }
  .gp-intro   { grid-template-columns: 1fr; gap: 24px; padding: 72px var(--px) 44px }
  .gp-mosaic  { grid-template-columns: repeat(2,1fr); grid-auto-rows: 140px }
  .mtile-lg   { grid-column: span 2; grid-row: span 4 }
  .mtile-wide { grid-column: span 2; grid-row: span 2 }
  .mtile-tall, .mtile-md, .mtile-sm { grid-column: span 1 }
}

@media(max-width:768px) {
  :root { --px: 20px; --nav-h: 54px }

  /* Topbar */
  .topbar-nav { display: none }

  /* Hero */
  .hero { grid-template-columns: 1fr }
  .hero-col { display: none !important }
  .hero-center { grid-column: 1 }
  .hero-logo .logo-set    { font-size: 3.2rem }
  .hero-logo .logo-design { font-size: 2rem }
  .hero-bottom  { flex-direction: column; align-items: flex-start; gap: 18px; padding-bottom: 40px }
  .hero-tagline { font-size: .9rem }

  /* Statement */
  .statement       { padding: 72px var(--px) }
  .statement-inner { grid-template-columns: 1fr; gap: 36px }
  .st-h2   { font-size: clamp(3rem,10vw,5rem) }
  .st-right { gap: 24px }

  /* Mosaic */
  .mosaic { display: none }

  /* Split */
  .split         { grid-template-columns: 1fr }
  .split-content { padding: 52px var(--px) }
  .sp-stats { gap: 28px }
  .sp-n     { font-size: 2.4rem }

  /* Manifesto */
  .m-line { height: 80px }
  .m-text { font-size: clamp(2rem,7vw,4rem) }

  /* Clients */
  .clients-header   { flex-direction: column; align-items: flex-start; gap: 20px; padding: 52px var(--px) 36px }
  .clients-header p { text-align: left; max-width: none }

  /* Process */
  .process      { padding: 72px var(--px) }
  .process-head { flex-direction: column; align-items: flex-start; gap: 16px; padding-bottom: 52px }
  .process-head p { text-align: left; max-width: none }
  .process-timeline { padding-left: 40px }
  .pstep-dot { left: -40px; width: 12px; height: 12px }
  .ps-num    { font-size: 2.2rem }
  .pstep     { padding-bottom: 52px }

  /* Expertise */
  .expertise { padding: 72px var(--px) }
  .expertise-head   { flex-direction: column; align-items: flex-start; gap: 20px }
  .expertise-head p { text-align: left; max-width: none }
  .exp-row      { grid-template-columns: 48px 1fr; gap: 12px }
  .exp-row-desc { display: none }
  .expertise-cta { text-align: left; margin-top: 36px }

  /* Full CTA */
  .full-cta { min-height: 50vh }
  .fcc h2   { font-size: clamp(3rem,12vw,6rem) }

  /* Contact */
  .contact           { grid-template-columns: 1fr }
  .contact-info      { border-right: none; border-bottom: 1px solid var(--border); padding: 52px var(--px) }
  .contact-form-side { padding: 52px var(--px) }
  .cf-row { grid-template-columns: 1fr }

  /* Footer */
  .footer-top    { grid-template-columns: 1fr; gap: 36px }
  .footer-bottom { flex-direction: column; gap: 14px; text-align: center }
}

@media(max-width:680px) {
  .clients-index { column-count: 2; column-gap: 28px; padding: 40px var(--px) 8px }
}

@media(max-width:640px) {
  #viewer-bar { height: 68px }
  .vphoto:first-child { padding-top: 68px }
}

@media(max-width:560px) {
  .gp-mosaic { grid-template-columns: 1fr; grid-auto-rows: auto; gap: 14px }
  .mtile, .mtile-lg, .mtile-tall, .mtile-wide, .mtile-md, .mtile-sm { grid-column: auto; grid-row: auto; height: 62vw; min-height: 240px }
  .mtile-count { opacity: 1; transform: scale(1) }
  .mtile-meta  { transform: translateY(0) }
}

@media(max-width:480px) {
  :root { --px: 16px }
  .hero-logo .logo-set    { font-size: 2.6rem }
  .hero-logo .logo-design { font-size: 1.6rem }
  .ticker-item { font-size: .9rem }
  .statement   { padding: 52px var(--px) }
}

@media(max-width:400px) {
  .clients-index { column-count: 1 }
}

/* Touch: disable problematic hover effects */
@media(hover: none) {
  .hero-col:hover img        { transform: none; filter: brightness(.42) saturate(.8) }
  .split:hover .split-img img{ transform: none; filter: brightness(.55) saturate(.85) }
}

/* Reduced motion */
@media(prefers-reduced-motion: reduce) {
  .chev1, .chev2 { animation: none }
  .chev2         { opacity: .6 }
  .mosaic-track  { animation: none }
  .cm-track      { animation: none }
  .pstep         { transition: none; opacity: 1; transform: none }
  .ps-num, .ps-label, .ps-text { transition: none }
  .tl-fill       { transition: none }
  .mtile         { opacity: 1; transform: none; transition: none }
  .vphoto img    { animation: none; opacity: 1; transform: none }
}
