/* ============================================================
   2T5 FILM — PAGES CSS  v3
   work / about / capabilities / directors / contact
   ============================================================ */

/* ── SHARED PAGE HERO ── */
.page-hero {
  padding:90px 60px 52px;
  position:relative; overflow:hidden;
}
@media(max-width:768px){ .page-hero{ padding:80px 20px 40px; text-align:center; } }
@media(max-width:480px){ .page-hero-title{ font-size:clamp(32px,9vw,44px); } }
.page-hero-title {
  font-family:var(--ff-g);
  font-size:clamp(44px,6vw,96px); font-weight:800;
  text-transform:uppercase; letter-spacing:-.01em; line-height:.9;
}
.page-hero-title em { font-style:normal; color:var(--red); }
.page-hero-sub {
  display:none;
}

/* dark hero (work, capabilities, directors) */
.page-hero--dark {
  background:var(--black);
}
.page-hero--dark .page-hero-grain {
  position:absolute; inset:-50%; width:200%; height:200%;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.07'/%3E%3C/svg%3E");
  opacity:.4; animation:grain .9s steps(2) infinite;
}
.page-hero--dark .page-hero-content { position:relative; z-index:2; }
.page-hero--dark .page-hero-title { color:var(--white); }
.page-hero--dark .page-hero-title em { color:var(--red); }

/* light hero (about, contact) */
.page-hero--light { background:var(--paper); }
.page-hero--light::before {
  content:attr(data-watermark);
  position:absolute; font-family:var(--ff-g);
  font-size:clamp(80px,18vw,240px); font-weight:800; text-transform:uppercase;
  color:rgba(10,9,8,.04); bottom:-10px; right:-5px;
  white-space:nowrap; pointer-events:none; letter-spacing:.04em; line-height:1;
}
.page-hero--light .page-hero-title { color:var(--black); }

/* ============================================================
   WORK PAGE
   ============================================================ */
.work-body { background:var(--white); padding:56px 0 100px; }

/* Category tabs */
.cat-tabs {
  display:flex; flex-wrap:wrap; gap:2px;
  margin-bottom:44px; padding:0 60px;
}
@media(max-width:768px){ .cat-tabs{ padding:0 20px; justify-content:center; }
  .cat-tab { min-height:44px; display:inline-flex; align-items:center; }
}
.cat-tab {
  font-family:var(--ff-g); font-size:9px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; padding:10px 18px;
  background:none; border:1px solid var(--border);
  color:var(--gray); transition:all .25s;
}
.cat-tab.active { background:var(--black); color:var(--white); border-color:var(--black); }
.cat-tab:hover:not(.active) { border-color:var(--red-text); color:var(--red-text); }

/* Director switcher (director-works page) */
.tal-switcher { margin-left:auto; display:flex; gap:2px; align-items:center; }
.tal-tab {
  font-family:var(--ff-g); font-size:9px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; padding:10px 18px;
  background:none; border:1px solid var(--border);
  color:var(--gray); transition:all .25s;
}
.tal-tab.active { background:var(--red); color:var(--white); border-color:var(--red); }
.tal-tab:hover:not(.active) { border-color:var(--red-text); color:var(--red-text); }
@media(max-width:768px){
  .tal-switcher {
    position:fixed; bottom:0; left:0; right:0; z-index:100;
    margin:0; padding:10px 16px; gap:6px;
    background:var(--paper); border-top:1px solid var(--border);
    justify-content:center; align-items:stretch;
    box-shadow:0 -4px 20px rgba(10,9,8,.08);
  }
  .tal-tab { flex:1; text-align:center; font-size:7px; padding:9px 7px; display:flex; align-items:center; justify-content:center; white-space:nowrap; }
  .tal-tab.active { font-size:9px; padding:11px 9px; }
  /* Extra bottom padding so sticky bar doesn't overlap content */
  body:has(.tal-switcher) .port-masonry { padding-bottom:72px; }
}

/* MASONRY GRID — JS absolute-positioning engine */
.port-masonry {
  position:relative; padding:0 60px; min-height:50vh;
  opacity:0; transition:opacity .3s;
}
.port-masonry.laid-out { opacity:1; }
@media(max-width:768px){ .port-masonry{ padding:0 20px; } }

.port-item {
  position:absolute; overflow:hidden;
}
/* Default 16:9; JS detectCardRatios() overrides per item */
.port-inner { width:100%; position:relative; overflow:hidden; aspect-ratio:16/9; background:var(--black); }

.port-thumb {
  width:100%; height:100%; object-fit:cover; display:block;
  filter:saturate(.6); transition:transform .65s var(--ease-out), filter .45s;
}
/* Image items: natural aspect ratio from source */
.port-item[data-type="image"] .port-inner { aspect-ratio:unset; }
.port-item[data-type="image"] .port-thumb { width:100%; height:auto; transform:scale(1.005); }
.port-placeholder {
  width:100%; height:100%; min-height:120px;
  background:#0f0e0d;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.16em;
  color:#222018; text-transform:uppercase;
  transition:transform .65s var(--ease-out);
}
.port-item:hover .port-thumb { transform:scale(1.04); filter:saturate(1); }
.port-item:hover .port-placeholder { transform:scale(1.03); }

/* Placeholder items (photography / ai-works coming soon) */
.port-item--placeholder { pointer-events:none; opacity:.45; }
.port-placeholder-media {
  width:100%; height:100%;
  background:linear-gradient(135deg,#111010,#1a1714);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px;
  border:1px dashed rgba(255,255,255,.07);
}
.port-placeholder-icon {
  font-size:28px; color:rgba(255,255,255,.12); line-height:1;
}
.port-placeholder-label {
  font-family:var(--ff-g); font-size:8px; font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; color:rgba(255,255,255,.18);
}

/* Pending items — CV credits with metadata but no media yet */
.port-item--pending { opacity:.55; transition:opacity .3s; }
.port-item--pending:hover { opacity:1; }
.port-item--pending .port-placeholder-media {
  transition:transform .65s var(--ease-out);
}
.port-item--pending:hover .port-placeholder-media { transform:scale(1.03); }
.port-item--pending .port-overlay {
  background:linear-gradient(to top,rgba(10,9,8,.97) 0%,rgba(10,9,8,.5) 55%,transparent 100%);
}
.port-item--pending:hover .port-overlay { opacity:1; }


.port-overlay {
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  background:rgba(10,9,8,.75);
  opacity:0; transition:opacity .3s;
  display:flex; flex-direction:column; justify-content:flex-end; padding:12px 20px;
}
.port-item:hover .port-overlay { opacity:1; }

.port-play-btn { display:none; }
.port-play-btn svg { width:16px; height:16px; fill:#fff; margin-left:2px; }

.port-client { font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--red); margin-bottom:3px; }
.port-title-text { font-family:var(--ff-g); font-size:16px; font-weight:600; color:var(--white); line-height:1.15; margin-bottom:5px; text-transform:uppercase; }
.port-meta { display:flex; gap:10px; }
.port-type, .port-year { font-family:var(--ff-g); font-size:9.2px; font-weight:400; letter-spacing:.12em; text-transform:uppercase; color:var(--white); }

.port-brand-logos {
  position:absolute; top:0; bottom:0; right:16px;
  display:flex; gap:10px; align-items:center;
  pointer-events:none;
}
.port-brand-logos img {
  height:100%; width:auto; max-height:42px; max-width:90px;
  object-fit:contain;
  filter:brightness(0) invert(1);
  opacity:.6;
}
.port-brand-logos img[src*="ulker"] { filter:none; opacity:.85; }
.port-brand-logos img[src*="tev"] { filter:none; opacity:.85; }
.port-brand-logos img[src*="finish"] { filter:none; opacity:.85; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-body { background:var(--white); padding:0; }

/* ── Manifesto ── */
.manifesto-section { background:var(--paper); padding:80px 0; }
.manifesto-inner {
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
  max-width:1400px; margin:0 auto; padding:0 120px;
}
@media(max-width:960px){ .manifesto-inner{ grid-template-columns:1fr; padding:0 40px; } }
@media(max-width:480px){
  .manifesto-inner{ padding:0 20px; gap:40px; }
  .manifesto-stats{ gap:20px; flex-wrap:wrap; }
  .manifesto-headline{ font-size:clamp(32px,9vw,40px); }
}

.manifesto-eyebrow {
  font-family:var(--ff-g); font-size:10px; font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; color:var(--red-text); margin-bottom:24px;
}
.manifesto-headline {
  font-family:var(--ff-g); font-size:clamp(40px,5vw,80px);
  font-weight:800; text-transform:uppercase; letter-spacing:-.02em; line-height:.92; color:var(--black);
}
.manifesto-headline em { font-style:italic; color:var(--red); text-transform:none; }

.manifesto-body-col { display:flex; flex-direction:column; justify-content:center; }
.manifesto-body-text {
  font-family:var(--ff-g); font-size:14px; font-weight:300; line-height:1.9;
  color:var(--gray-text); margin-bottom:20px;
}
.manifesto-body-text strong { color:var(--black); font-weight:600; }

.manifesto-stats {
  display:flex; gap:40px; margin-top:40px; padding-top:36px; border-top:1px solid var(--border);
}
.manifesto-stat-num {
  font-family:var(--ff-g); font-size:clamp(28px,3vw,48px); font-weight:800;
  letter-spacing:-.03em; line-height:1; color:var(--black);
}
.manifesto-stat-lbl {
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.18em;
  text-transform:uppercase; color:var(--gray-text); margin-top:6px;
}

/* ── Founder sections ── */
.founder-section {
  display:grid; min-height:560px;
}
.founder-section--dark { background:var(--black); grid-template-columns:22fr 78fr; padding-left:5%; }
.founder-section--light { background:var(--paper); grid-template-columns:78fr 22fr; padding-right:5%; }
@media(max-width:768px){
  .founder-section{ grid-template-columns:1fr; min-height:unset; }
  .founder-section--light .founder-portrait{ order:2; }
  .founder-section--light .founder-text{ order:1; }
  .founder-section--dark { padding-left:0; }
  .founder-section--light { padding-right:0; }
  .founder-name { font-size:clamp(28px,8vw,40px); }
  .founder-text { padding:36px 24px; max-width:480px; margin:0 auto; text-align:left; }
  .founder-portrait { min-height:280px; }
}

.founder-portrait { position:relative; overflow:hidden; min-height:320px; }
.founder-portrait img { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }
.founder-portrait-placeholder {
  width:100%; height:100%;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px;
}
.founder-section--dark .founder-portrait-placeholder { background:#0f0e0c; }
.founder-section--light .founder-portrait-placeholder { background:#c8c2b8; }
.founder-portrait-placeholder svg { width:72px; height:72px; opacity:.18; }
.founder-section--dark .founder-portrait-placeholder svg { color:var(--white); }
.founder-section--light .founder-portrait-placeholder svg { color:var(--black); }
.founder-portrait-placeholder span {
  font-family:var(--ff-g); font-size:9px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
}
.founder-section--dark .founder-portrait-placeholder span { color:rgba(255,255,255,.2); }
.founder-section--light .founder-portrait-placeholder span { color:rgba(10,9,8,.28); }

.founder-text {
  padding:clamp(48px,6vw,96px) clamp(40px,5vw,80px);
  display:flex; flex-direction:column; justify-content:center;
}
.founder-num {
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.3em; margin-bottom:20px;
}
.founder-section--dark .founder-num { color:rgba(255,255,255,.18); }
.founder-section--light .founder-num { color:var(--gray); }

.founder-role {
  font-family:var(--ff-g); font-size:18px; font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; color:var(--red); margin-bottom:16px;
}
.founder-name {
  font-family:var(--ff-g); font-size:clamp(40px,4.2vw,72px); font-weight:800;
  letter-spacing:-.02em; line-height:.92; text-transform:uppercase; margin-bottom:28px;
}
.founder-section--dark .founder-name { color:var(--white); }
.founder-section--light .founder-name { color:var(--black); }

.founder-bio {
  font-family:var(--ff-g); font-size:20px; font-weight:500; line-height:1.6; margin-bottom:28px;
}
.founder-section--dark .founder-bio { color:rgba(237,232,225,.7); }
.founder-section--light .founder-bio { color:var(--black); }

.founder-credits { margin-bottom:28px; }
.founder-credit-item {
  font-family:var(--ff-g); font-size:14px; font-weight:400;
  padding:10px 0; border-bottom:1px solid;
  display:flex; align-items:center; gap:12px; line-height:1.4;
}
.founder-section--dark .founder-credit-item { color:rgba(237,232,225,.5); border-color:rgba(255,255,255,.06); }
.founder-section--light .founder-credit-item { color:var(--gray); border-color:var(--border); }
.founder-credit-item::before {
  content:''; flex-shrink:0; width:16px; height:16px;
  background:url('../assets/2t5-logo.png') center/contain no-repeat;
  filter:brightness(0) saturate(100%) invert(40%) sepia(15%) saturate(1800%) hue-rotate(325deg) brightness(90%) contrast(90%);
}
.fc-title { font-weight:700; }
.founder-section--dark .fc-title { color:rgba(237,232,225,.9); }
.founder-section--light .fc-title { color:var(--black); }

.founder-imdb {
  display:inline-flex; align-items:center;
  font-family:var(--ff-g); font-size:8px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  text-decoration:none; border:1px solid rgba(255,255,255,.15); padding:8px 16px; margin-top:24px;
  color:var(--white); width:fit-content; transition:border-color .2s, background .2s;
}
.founder-imdb:hover { border-color:var(--red); background:rgba(184,84,80,.12); }

/* ── Pipeline section ── */
.pipeline-section { background:var(--black); padding:80px 0; }
.pipeline-inner {
  max-width:1400px; margin:0 auto; padding:0 120px;
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
}
@media(max-width:960px){ .pipeline-inner{ grid-template-columns:1fr; padding:0 40px; } }
@media(max-width:768px){ .pipeline-statement{ text-align:center; } }
@media(max-width:480px){
  .pipeline-inner{ padding:0 20px; gap:40px; }
  .pipeline-statement{ font-size:clamp(28px,8vw,36px); }
  .pipeline-skills{ grid-template-columns:1fr; }
}

.pipeline-statement {
  font-family:var(--ff-g); font-size:clamp(28px,3.2vw,56px);
  font-weight:800; text-transform:uppercase; letter-spacing:-.02em; line-height:.92; color:var(--white);
}
.pipeline-statement em { font-style:normal; color:var(--red); }

.pipeline-skills { display:grid; grid-template-columns:1fr 1fr; gap:0 32px; }
.pipeline-skill-list { list-style:none; }
.pipeline-skill-list li {
  font-family:var(--ff-g); font-size:12px; font-weight:300; color:rgba(237,232,225,.4);
  padding:9px 0; border-bottom:1px solid rgba(255,255,255,.05);
  display:flex; align-items:center; gap:10px; transition:color .25s;
}
.pipeline-skill-list li::before {
  content:''; flex-shrink:0; width:14px; height:14px;
  background:url('../assets/2t5-logo.png') center/contain no-repeat;
  filter:brightness(0) saturate(100%) invert(40%) sepia(15%) saturate(1800%) hue-rotate(325deg) brightness(90%) contrast(90%);
}
.pipeline-skill-list li:hover { color:var(--white); }

/* Clients title — matches "Our Works" heading style */
.clients-title {
  font-family:var(--ff-g); font-size:clamp(21px,4.1vw,66px);
  font-weight:800; text-transform:uppercase;
  color:var(--black); letter-spacing:-.01em; line-height:.92;
  padding:0 60px; margin-bottom:36px; white-space:nowrap;
  text-decoration:none; display:inline-block;
  transition:color .3s;
}
@media(max-width:768px){ .clients-title { padding:0 20px; } }
.clients-title em { color:var(--red); font-style:normal; transition:color .3s; }
.clients-title:hover { color:var(--red); }
.clients-title:hover em { color:var(--black); }

/* Clients */
.clients-strip { background:var(--white); padding:80px 0; overflow:hidden; }
/* Logo grid — partner/label logos */
.logo-grid {
  display:flex; flex-wrap:wrap; gap:2px; margin-top:32px;
}
.logo-item {
  flex:1 1 180px;
  background:var(--paper); padding:32px 36px;
  display:flex; align-items:center; justify-content:center;
  transition:background .25s;
}
a.logo-item { text-decoration:none; }
.logo-item:hover { background:#f0ece5; }
.logo-item img {
  max-height:36px; width:auto; max-width:160px;
  filter:saturate(0) opacity(.55);
  transition:filter .3s;
}
.logo-item:hover img { filter:saturate(0) opacity(.9); }

.clients-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:1px; margin-top:2px;
}
.client-item {
  background:var(--paper); padding:28px 20px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-g); font-size:10px; font-weight:600; letter-spacing:.16em;
  text-transform:uppercase; color:var(--gray);
  transition:background .25s, color .25s; cursor:default;
}
.client-item:hover { background:var(--black); color:var(--white); }

/* Logo cloud — scattered floating logos */
.logo-cloud {
  position:relative; height:280px;
  overflow:hidden; margin-top:32px;
  /* break out of .container to span full viewport */
  width:100vw;
  margin-left:calc(-50vw + 50%);
  max-width:100vw;
}
.logo-cloud-inner {
  position:relative; width:100%; height:100%;
}
.logo-cloud-item {
  position:absolute; left:0; top:0;
  pointer-events:auto;
  will-change:transform;
  transition:height .5s ease;
  cursor:default;
}
.logo-cloud-item img {
  display:block; height:100%; width:auto;
  filter:saturate(0) opacity(var(--op));
  transition:filter .4s;
}
.logo-cloud:hover .logo-cloud-item img {
  filter:saturate(0) opacity(calc(var(--op) * 1.3));
}
.logo-cloud-item:hover img {
  filter:saturate(0) opacity(calc(var(--op) * 2.5));
}
.logo-cloud-item.text-only {
  font-family:var(--ff-g); font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--gray); opacity:var(--op);
  white-space:nowrap;
  display:flex; align-items:center;
}

/* Mobile: replace physics scatter with readable flex grid */
@media(max-width:768px){
  .logo-cloud {
    height:auto !important;
    width:100%;
    margin-left:0;
    display:flex; flex-wrap:wrap;
    gap:20px 28px;
    justify-content:center; align-items:center;
    padding:24px 16px;
  }
  .logo-cloud-inner { display:contents; }
  .logo-cloud-item {
    position:static !important;
    left:auto !important; top:auto !important;
    height:24px !important;
    will-change:auto;
    transition:none !important;
  }
  .logo-cloud-item img {
    height:100%; width:auto;
    filter:saturate(0) opacity(.55) !important;
  }
  .logo-cloud-item.text-only {
    position:static !important;
    left:auto !important; top:auto !important;
    height:auto !important;
    font-size:11px;
  }
}

/* ============================================================
   CAPABILITIES / SERVICES PAGE
   ============================================================ */
.cap-body { background:var(--paper); padding:72px 0 100px; }

/* Track tabs */
.track-tabs {
  display:inline-flex; gap:2px; margin-bottom:52px;
  background:rgba(10,9,8,.08); padding:2px;
  max-width:100%;
}
.track-tab {
  font-family:var(--ff-g); font-size:10px; font-weight:600; letter-spacing:.16em;
  text-transform:uppercase; padding:11px 24px;
  background:none; border:none; color:var(--gray); transition:all .25s;
}
.track-tab.active { background:var(--black); color:var(--white); }
@media(max-width:768px){
  .track-tabs {
    display:flex; flex-wrap:wrap; gap:2px;
    margin-bottom:36px; max-width:100%;
  }
  .track-tab { flex:1; min-width:0; text-align:center; padding:10px 12px; font-size:9px; }
}

.track-panel { display:none; }
.track-panel.active { display:block; }

/* Traditional grid */
.trad-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:3px; }

.trad-item {
  background:var(--white); overflow:hidden;
  position:relative; display:flex; flex-direction:column;
}

/* Service thumbnail */
.trad-thumb {
  width:100%; aspect-ratio:16/9; overflow:hidden; position:relative;
  background:#e8e3dc;
}
.trad-thumb img,
.trad-thumb video {
  width:100%; height:100%; object-fit:cover;
  filter:saturate(.6); transition:filter .4s;
}
.trad-thumb-placeholder {
  width:100%; height:100%; background:var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.14em;
  color:#a8a39c; text-transform:uppercase; transition:background .35s, color .35s;
}
.trad-item:hover .trad-thumb-placeholder { background:#1a1714; color:#3a3530; }

.trad-info { padding:28px 28px 32px; position:relative; overflow:hidden; flex:1; }
.trad-info::before {
  content:''; position:absolute; inset:0;
  background:rgba(6,5,4,.92); z-index:1;
  opacity:0; transition:opacity .3s;
}
.trad-item:hover .trad-info::before { opacity:1; }
.trad-num { font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.2em; color:var(--gray-lt); margin-bottom:12px; transition:opacity .3s; }
.trad-item:hover .trad-num { opacity:0; }
.trad-title { font-family:var(--ff-g); font-size:clamp(16px,1.8vw,22px); font-weight:700; letter-spacing:.02em; text-transform:uppercase; margin-bottom:8px; transition:opacity .3s; }
.trad-item:hover .trad-title { opacity:0; }
.trad-desc { font-family:var(--ff-g); font-size:12px; font-weight:300; line-height:1.75; color:var(--gray); transition:opacity .3s; }
.trad-item:hover .trad-desc { opacity:0; }

/* Gallery button — hidden visually, kept in DOM for JS data */
.trad-gallery-btn { display:none; }

/* VIEW GALLERY — centered overlay on hover */
.trad-info::after {
  content:'VIEW GALLERY  →';
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%) scale(0.8);
  white-space:nowrap;
  font-family:var(--ff-g); font-size:18px; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--red); z-index:2;
  opacity:0;
  transition:opacity .3s, transform .4s var(--ease-out);
}
.trad-item:hover .trad-info::after {
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}

/* AI grid */
.ai-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:3px; align-items:stretch; }

.ai-card { background:var(--white); overflow:hidden; display:flex; flex-direction:column; }
.ai-card-visual { position:relative; aspect-ratio:16/9; background:var(--black); overflow:hidden; user-select:none; flex-shrink:0; }
.ai-card-visual > img { width:100%; height:100%; object-fit:cover; display:block; filter:saturate(.8); transition:filter .4s; }
.ai-card-visual[data-ar="portrait"] > img { object-position:top center; }
.ai-card-visual[data-ar="portrait"] .sg-ba-fill img { object-position:top center; }
.ai-card-video { width:100%; height:100%; object-fit:cover; display:block; }

/* Before/after slider — After (AI) is LEFT base, Before (original) is RIGHT clipped */
.ba-slider { position:relative; width:100%; height:100%; overflow:hidden; }
.ba-before, .ba-after {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.12em; text-transform:uppercase;
}
/* After = AI output = LEFT side = full background, no clip */
.ba-after  { background:linear-gradient(135deg,#1d1010,#2e1412); color:var(--red-dim); }
/* Before = original = RIGHT side = clipped from left at 50% initially */
.ba-before { background:linear-gradient(135deg,#1a1714,#252018); color:var(--gray); clip-path:inset(0 0 0 50%); z-index:2; }
.ba-lbl {
  position:absolute; top:10px; font-family:var(--ff-g); font-size:8px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; padding:3px 8px; background:rgba(0,0,0,.55); z-index:5;
}
/* After (AI) is LEFT, Before (original) is RIGHT — labels match */
.ba-lbl-b { right:10px; color:var(--gray); }   /* Before = right side */
.ba-lbl-a { left:10px;  color:var(--red);  }   /* After  = left side  */
.ba-divider {
  position:absolute; top:0; bottom:0; left:50%; width:2px;
  background:var(--red); transform:translateX(-50%); z-index:10; cursor:ew-resize;
}
.ba-handle {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:30px; height:30px; border-radius:50%; background:var(--red);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-g); font-size:9px; color:#fff;
  box-shadow:0 2px 10px rgba(0,0,0,.4);
  transition:top .04s linear;
}

.ai-card-info { padding:18px 22px 22px; position:relative; flex:1; overflow:hidden; }
.ai-card-info::before {
  content:''; position:absolute; inset:0;
  background:rgba(6,5,4,.92); z-index:1;
  opacity:0; transition:opacity .35s;
}
.ai-card:hover .ai-card-info::before { opacity:1; }
.ai-card-title { font-family:var(--ff-g); font-size:15px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; margin-bottom:6px; transition:opacity .25s; }
.ai-card:hover .ai-card-title { opacity:0; }
.ai-card-desc { font-family:var(--ff-g); font-size:11px; font-weight:300; line-height:1.7; color:var(--gray); transition:opacity .25s; }
.ai-card:hover .ai-card-desc { opacity:0; }
.ai-card-tag {
  display:inline-block; margin-top:10px;
  font-family:var(--ff-g); font-size:8px; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red-text); border:1px solid var(--red-text); padding:3px 8px;
  transition:opacity .25s;
}
.ai-card:hover .ai-card-tag { opacity:0; }

/* VIEW GALLERY — centered overlay on hover */
.ai-card-info::after {
  content:'VIEW GALLERY  →';
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%) scale(0.8);
  white-space:nowrap;
  font-family:var(--ff-g); font-size:18px; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--red); z-index:2;
  opacity:0;
  transition:opacity .35s, transform .4s var(--ease-out);
}
.ai-card:hover .ai-card-info::after {
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}

/* Touch devices: show VIEW GALLERY as inline label instead of hover overlay */
@media(hover:none){
  .trad-info::before, .ai-card-info::before { display:none; }
  .trad-item:hover .trad-num,
  .trad-item:hover .trad-title,
  .trad-item:hover .trad-desc { opacity:1; }
  .ai-card:hover .ai-card-title,
  .ai-card:hover .ai-card-desc,
  .ai-card:hover .ai-card-tag { opacity:1; }
  .trad-info::after, .ai-card-info::after {
    position:static; transform:none; opacity:1;
    display:block; margin-top:12px;
    font-size:10px; letter-spacing:.16em;
  }
}

/* Infra note */
.infra-note {
  margin-top:44px; padding:28px 36px; border:1px solid var(--border);
  background:var(--white); display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:center;
}
@media(max-width:600px){ .infra-note{ grid-template-columns:1fr; } }
.infra-icon { font-size:24px; color:var(--red); opacity:.5; }
.infra-text { font-family:var(--ff-g); font-size:12px; font-weight:300; line-height:1.85; color:var(--gray); }
.infra-text strong { color:var(--black); font-weight:600; }

/* ============================================================
   TALENTS PAGE — centered cards, no scroll
   ============================================================ */

.page-talents { display:flex; flex-direction:column; min-height:100vh; }

.tal-page-body {
  background:var(--paper);
  display:flex; align-items:center; justify-content:center;
  padding:60px 60px 56px;
  flex:1;
}

.tal-grid {
  display:flex; gap:24px;
  align-items:stretch; justify-content:center;
}

/* Each card — sized to fit comfortably in viewport */
.tal-item {
  width:clamp(260px, 22vw, 340px); flex-shrink:0;
  background:#111;
  position:relative; overflow:hidden;
  transition:transform .3s var(--ease-out);
}
.tal-item:hover { transform:translateY(-4px); }

/* Photo — 4:3 landscape */
.tal-item-photo {
  position:relative; overflow:hidden;
  width:100%; aspect-ratio:4/3;
}
.tal-item-photo img {
  width:100%; height:100%; object-fit:cover; object-position:top center;
  display:block; transition:transform .5s var(--ease-out);
}
.tal-item:hover .tal-item-photo img { transform:scale(1.04); }
.tal-item-placeholder {
  width:100%; height:100%;
  background:linear-gradient(160deg,#181512,#1f1b17);
  display:flex; align-items:center; justify-content:center;
}
.tal-item-placeholder svg { width:56px; height:56px; color:#fff; opacity:.15; }

/* Number tag top-left over photo */
.tal-item-num-tag {
  position:absolute; top:14px; left:16px; z-index:3;
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.2em;
  color:rgba(255,255,255,.25);
}

/* Info section — below the photo, always visible */
.tal-item-overlay {
  padding:20px 20px 22px;
  background:#111;
  position:static; opacity:1; pointer-events:all;
  display:flex; flex-direction:column; gap:0;
}

.tal-item-role {
  font-family:var(--ff-g); font-size:8px; font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; color:var(--red); margin-bottom:6px;
}
.tal-item-name {
  font-family:var(--ff-g); font-size:18px; font-weight:800;
  text-transform:uppercase; letter-spacing:-.01em; line-height:1.05;
  color:var(--white); margin-bottom:12px;
}
/* Word cloud */
.tal-wordcloud {
  position:relative; height:100px;
  overflow:hidden; margin-top:4px;
  margin-left:-20px; margin-right:-20px;
  cursor:grab;
}
.tal-wordcloud:active { cursor:grabbing; }
.tal-wordcloud-inner {
  position:relative; width:100%; height:100%;
  transition:transform .15s ease-out;
}
.tal-word {
  position:absolute;
  font-family:var(--ff-g); font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--white);
  white-space:nowrap; pointer-events:none;
  animation:wcPulse ease-in-out infinite;
  translate:0px 0px;
  transition:translate 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}
@keyframes wcPulse {
  0%,100% { opacity:var(--op); }
  50%      { opacity:calc(var(--op) * 1.4); }
}
.tal-item-cta {
  display:inline-flex; align-items:center;
  font-family:var(--ff-g); font-size:8px; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--white); text-decoration:none;
  border:1px solid rgba(255,255,255,.15); padding:7px 14px;
  transition:border-color .2s, background .2s; width:fit-content;
}
.tal-item-cta:hover { border-color:var(--red); background:rgba(184,84,80,.12); }

/* Hide old bar */
.tal-item-bar, .tal-item-bar-name, .tal-item-bar-role, .tal-item-num { display:none; }

@media(max-width:720px){
  .tal-page-body { padding:48px 24px 60px; }
  .tal-grid { flex-direction:column; align-items:center; }
  .tal-item { width:100%; max-width:360px; }
  .tal-wordcloud { margin-left:0; margin-right:0; }
}
/* Disable hover effects on touch devices (hover gets stuck after tap) */
@media(hover:none){
  .tal-item { transition:none; }
  .tal-item:hover { transform:none; }
  .tal-item-photo img { transition:none; }
  .tal-item:hover .tal-item-photo img { transform:none; }
}
.tal-item-bar-name {
  font-family:var(--ff-g); font-size:12px; font-weight:700;
  text-transform:uppercase; letter-spacing:.04em; color:var(--white); line-height:1.1;
}
.tal-item-bar-role {
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.14em;
  text-transform:uppercase; color:var(--red); margin-top:3px;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

/* ══════════════════════════════════════════════
   CONTACT PAGE — Editorial layout
   ══════════════════════════════════════════════ */
.contact-page { display:flex; flex-direction:column; min-height:100vh; }

/* ── CREW — horizontal credit roll (sits right under hero) ── */
.ct-crew {
  background:var(--paper);
  border-bottom:1px solid var(--border);
  padding:clamp(14px,1.8vh,24px) 0;
}
.ct-crew-inner {
  max-width:1400px; margin:0 auto;
  padding:0 clamp(32px,4vw,80px);
  display:flex; align-items:flex-start; justify-content:center;
  flex-wrap:nowrap; gap:0;
}
.ct-crew-member {
  display:flex; flex-direction:column; align-items:center; gap:2px;
  padding:4px clamp(14px,1.8vw,28px);
  position:relative;
}
.ct-crew-member:not(:last-child)::after {
  content:''; position:absolute; right:0; top:50%;
  transform:translateY(-50%);
  width:3px; height:3px; border-radius:50%;
  background:var(--gray-lt);
}
.ct-crew-member a, .ct-crew-name {
  font-family:var(--ff-g); font-size:clamp(11px,.85vw,13px);
  font-weight:500; color:var(--black); letter-spacing:.02em;
  text-decoration:none; transition:color .25s;
}
.ct-crew-member a:hover { color:var(--red); }
.ct-crew-member > span:last-child {
  font-family:var(--ff-g); font-size:clamp(8px,.55vw,9px);
  font-weight:400; color:var(--gray); letter-spacing:.12em;
  text-transform:uppercase;
}

/* ── MAIN — offices (left, narrow) + form (right, wide) ── */
.ct-main {
  background:var(--white); flex:1;
  padding:clamp(32px,4vw,56px) 0;
}
.ct-main-inner {
  max-width:1400px; margin:0 auto;
  padding:0 clamp(32px,4vw,80px);
  display:grid;
  grid-template-columns:clamp(240px,20vw,300px) 1fr;
  gap:clamp(40px,5vw,80px); align-items:start;
}

/* Offices column — stacked vertically */
.ct-offices-col {
  display:flex; flex-direction:column; gap:clamp(24px,3vh,36px);
}
.ct-office-city {
  font-family:var(--ff-g); font-size:clamp(14px,1.2vw,20px);
  font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  line-height:1; color:var(--black); margin-bottom:clamp(6px,.8vw,10px);
}
.ct-office-addr {
  font-family:var(--ff-g); font-size:clamp(11px,.8vw,13px);
  font-weight:300; color:var(--gray); line-height:1.45;
}
.ct-office-email {
  font-family:var(--ff-g); font-size:clamp(11px,.8vw,13px);
  font-weight:400; color:var(--black); text-decoration:none;
  transition:color .25s; margin-top:4px;
  display:inline-block;
}
.ct-office-email:hover { color:var(--red); }

/* Map preview — Leaflet */
.ct-office-map {
  display:block; margin-top:clamp(8px,1vh,14px);
  width:100%; height:160px;
  border:1px solid var(--border);
  transition:border-color .3s;
  z-index:0;
}
.ct-office-map:hover { border-color:var(--red); }
.ct-office-map .leaflet-tile-pane { filter:saturate(0) brightness(1.05) contrast(.9); transition:filter .4s; }
.ct-office-map:hover .leaflet-tile-pane { filter:saturate(.3) brightness(1) contrast(1); }
.ct-map-pin { background:none !important; border:none !important; }
.ct-office-map .leaflet-control-container { display:none; }
.ct-office-map { position:relative; }
.ct-map-hint {
  position:absolute; top:0; left:0; right:0; bottom:0; z-index:999;
  display:flex; align-items:center; justify-content:center;
  background:rgba(10,9,8,.55); color:#fff;
  font-family:var(--ff-g); font-size:12px; font-weight:500;
  letter-spacing:.06em; pointer-events:none;
  opacity:0; transition:opacity .3s;
}
.ct-map-hint.show { opacity:1; }

/* Form label */
.ct-sidebar-label {
  font-family:var(--ff-g); font-size:clamp(14px,1.2vw,20px);
  font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  line-height:1; color:var(--black);
  margin-bottom:clamp(14px,1.5vh,24px);
}

/* Form column */
.ct-form-col { }
.contact-form { display:flex; flex-direction:column; gap:clamp(10px,1.4vh,18px); }
.form-group label {
  display:block; font-family:var(--ff-g); font-size:9px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--gray); margin-bottom:6px;
}
.form-group input, .form-group select, .form-group textarea {
  width:100%; background:var(--paper); border:1px solid var(--border);
  padding:12px 16px; font-family:var(--ff-g); font-size:14px; font-weight:300;
  color:var(--black); outline:none; appearance:none; border-radius:0;
  transition:border-color .25s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--red); }
.form-group textarea { resize:vertical; min-height:clamp(100px,14vh,180px); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.btn-submit {
  display:inline-flex; align-items:center; gap:14px; align-self:flex-start;
  font-family:var(--ff-g); font-size:11px; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  padding:16px 36px; background:var(--black); color:var(--white);
  border:none; transition:background .25s, gap .25s;
  margin-top:clamp(6px,1vh,14px);
}
.btn-submit:hover { background:var(--red); gap:20px; }
.btn-submit::after { content:'→'; }

/* ── CONTACT RESPONSIVE ── */
@media(max-width:900px){
  .contact-page { min-height:unset; }
  .ct-main-inner {
    grid-template-columns:1fr; gap:40px;
    padding:0 20px;
  }
  .ct-offices-col { flex-direction:row; gap:24px; }
  .ct-offices-col .ct-office { flex:1; }
  .ct-crew-inner { padding:0 20px; }
}
@media(max-width:560px){
  .ct-offices-col { flex-direction:column; }
  .form-row { grid-template-columns:1fr; }
}
@media(max-width:480px){
  .ct-crew-member { padding:4px 10px; }
  .ct-crew-member:not(:last-child)::after { display:none; }
  .ct-crew-inner { gap:2px 0; }
}

/* ============================================================
   GAMES PAGE
   ============================================================ */
body:has(.games-page) {
  display:flex; flex-direction:column; min-height:100vh;
  background:var(--black);
}
.games-page {
  flex:1; padding:90px 48px 24px;
  display:flex; flex-direction:column; align-items:center;
  background:var(--red);
}
.games-header {
  text-align:center; margin-bottom:24px;
}
.games-title {
  font-family:var(--ff-g); font-size:clamp(32px,5vw,56px);
  font-weight:800; letter-spacing:.14em; color:#fff;
  line-height:1;
}
.games-subtitle {
  font-family:var(--ff-s); font-size:clamp(12px,1.4vw,15px);
  color:rgba(255,255,255,.5); margin-top:10px; letter-spacing:.06em;
  font-style:italic;
}
.games-grid {
  display:flex; flex-wrap:wrap; gap:16px;
  justify-content:center; width:100%; max-width:960px;
}
.game-card {
  width:calc(33.333% - 11px);
  border-radius:var(--radius-md); overflow:hidden; cursor:pointer;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.1);
  transition:transform .3s var(--ease-out), box-shadow .3s var(--ease-out);
}
.game-card:hover {
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.3);
}
.game-card-visual {
  aspect-ratio:5/3; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.game-card-visual[data-game="0"] { background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%); }
.game-card-visual[data-game="1"] { background:linear-gradient(135deg,#2d132c 0%,#4a1942 50%,#6b2d5b 100%); }
.game-card-visual[data-game="2"] { background:linear-gradient(135deg,#1b2631 0%,#1c3a4f 50%,#1a5276 100%); }
.game-card-visual[data-game="3"] { background:linear-gradient(135deg,#4a1c1c 0%,#6b2d2d 50%,#8b3a3a 100%); }
.game-card-icon {
  font-size:clamp(40px,5vw,60px); filter:saturate(.8);
  transition:transform .4s var(--ease-out);
}
.game-card:hover .game-card-icon { transform:scale(1.12); }
.game-card-body {
  padding:14px 18px 16px;
  display:flex; flex-direction:column; gap:6px;
}
.game-card-title {
  font-family:var(--ff-g); font-size:clamp(11px,1.2vw,14px);
  font-weight:700; letter-spacing:.16em; color:#fff;
}
.game-card-desc {
  font-family:var(--ff-s); font-size:clamp(10px,1vw,12px);
  color:rgba(255,255,255,.45); line-height:1.5;
}
.game-card-btn {
  display:none;
  align-self:flex-start;
  font-family:var(--ff-g); font-size:10px; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  background:#fff; color:var(--red); border:none;
  padding:7px 18px; border-radius:3px; cursor:pointer;
  transition:background .2s, color .2s; margin-top:4px;
}
.game-card-btn:hover { background:rgba(255,255,255,.85); color:var(--black); }
.game-card-featured { width:calc(33.333% - 11px); }
.game-card-featured .game-card-visual { aspect-ratio:5/3; }
.game-card-visual[data-game="musteri"] { background:linear-gradient(135deg,#0d1117 0%,#1f2c33 40%,#005c4b 100%); }
.games-divider { display:none; }
.games-random {
  width:calc(33.333% - 11px);
  font-family:var(--ff-g); font-size:clamp(12px,1.4vw,16px); font-weight:800;
  letter-spacing:.22em; text-transform:uppercase;
  background:rgba(255,255,255,.1); color:#fff; border:2px dashed rgba(255,255,255,.3);
  border-radius:var(--radius-md); cursor:pointer;
  transition:background .3s, border-color .3s;
  display:flex; align-items:center; justify-content:center;
}
.games-random:hover { background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.5); }
@media(max-width:600px){
  .games-page { padding:110px 20px 60px; }
  .games-grid { flex-direction:column; align-items:center; gap:14px; }
  .game-card { width:100%; max-width:400px; }
  .game-card-featured { width:100%; max-width:400px; }
  .games-random { width:100%; max-width:400px; min-height:56px; }
  .game-card-btn { display:none; }
}
