/* ============================================================
   IN-MOTION MEDIA — style.css v2
   ============================================================ */
:root{
  --black:#060808;--black-2:#0D0F0C;--black-3:#111410;
  --green:#6DDE4A;--green-d:rgba(109,222,74,.65);
  --green-20:rgba(109,222,74,.20);--green-08:rgba(109,222,74,.08);--green-04:rgba(109,222,74,.04);
  --cream:#EFF5EE;--cream-60:rgba(239,245,238,.60);--cream-40:rgba(239,245,238,.40);
  --cream-20:rgba(239,245,238,.20);--cream-10:rgba(239,245,238,.10);
  --bdr:rgba(109,222,74,.08);--bdr-h:rgba(109,222,74,.22);
  --sw:184px;
  --fd:'Cormorant Garamond',Georgia,serif;
  --fu:'Montserrat',system-ui,sans-serif;
  --t:.2s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--black);color:var(--cream);font-family:var(--fu);font-size:13px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}

/* Layout */
.page-wrap{display:flex;min-height:100vh}
.main-content{margin-left:var(--sw);flex:1;padding:48px 52px 80px;max-width:1360px;width:100%}

/* ── SIDEBAR ── */
.sidebar{
  position:fixed;top:0;left:0;width:var(--sw);height:100vh;
  background:var(--black-2);border-right:1px solid var(--bdr);
  display:flex;flex-direction:column;padding:24px 18px 18px;
  z-index:100;overflow-y:auto;overflow-x:hidden;
  transition:transform .3s cubic-bezier(.4,0,.2,1);
}
/* Logo area */
.sidebar-logo{display:block;margin-bottom:4px;flex-shrink:0;line-height:0}
.sidebar-logo img{
  width:148px;height:74px;
  object-fit:contain;object-position:left center;
  /* The logo has a white/transparent background — mix-blend makes it work on dark bg */
  mix-blend-mode:screen;
  filter:brightness(1.05);
}
.logo-text-fallback{
  font-family:var(--fd);font-size:17px;font-weight:300;
  color:var(--cream);letter-spacing:.08em;line-height:1.2;
  display:inline-block;
}
.logo-text-fallback em{font-style:italic;color:var(--green)}
.sidebar-tagline{font-size:7px;letter-spacing:.26em;text-transform:uppercase;color:var(--cream-20);margin-bottom:26px;padding-left:1px;margin-top:5px}
/* Nav */
.sidebar-nav ul{display:flex;flex-direction:column;gap:1px}
.sidebar-nav a{
  display:block;font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cream-40);padding:7px 9px;border-radius:2px;position:relative;
  transition:color var(--t),background var(--t);
}
.sidebar-nav a:hover{color:var(--cream);background:var(--green-04)}
.sidebar-nav a.active{color:var(--green);background:var(--green-08)}
.sidebar-nav a.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:2px;height:14px;background:var(--green);border-radius:2px}
/* Legal */
.sidebar-legal{padding-top:14px;border-top:1px solid var(--bdr);margin-top:10px}
.sidebar-legal-title{font-size:7px;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-20);margin-bottom:7px}
.sidebar-legal a{display:block;font-size:9px;color:var(--cream-20);margin-bottom:4px;transition:color var(--t)}
.sidebar-legal a:hover{color:var(--cream-40)}
/* Admin link */
.admin-nav-btn{display:block;font-size:8.5px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--green);background:var(--green-08);border:1px solid var(--green-20);padding:8px 10px;border-radius:2px;text-align:center;transition:all var(--t);margin-top:10px}
.admin-nav-btn:hover{background:var(--green-20)}
.admin-nav-subtle{display:block;font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-10);text-align:center;padding:4px;transition:color var(--t);margin-top:8px}
.admin-nav-subtle:hover{color:var(--cream-20)}

/* Mobile toggle */
.mobile-toggle{display:none;position:fixed;top:14px;left:14px;z-index:200;width:38px;height:38px;background:var(--black-2);border:1px solid var(--bdr);border-radius:2px;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.mobile-toggle span{display:block;width:18px;height:1.5px;background:var(--cream-60);transition:all .22s}

/* ── TYPOGRAPHY ── */
.im-eyebrow{display:flex;align-items:center;gap:10px;font-size:8.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--green-d);margin-bottom:14px}
.im-eyebrow::before{content:'';display:inline-block;width:20px;height:1px;background:var(--green-d);flex-shrink:0}
.im-display{font-family:var(--fd);font-weight:300;line-height:1.08;color:var(--cream);letter-spacing:-.01em}
.im-display em{font-style:italic;color:var(--green)}
.im-label{font-size:8px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-20);margin-bottom:18px;padding-bottom:8px;border-bottom:1px solid var(--bdr)}
.im-tag{font-size:7.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--green);padding:3px 8px;border:1px solid var(--green-20);background:rgba(109,222,74,.06)}
.body-text{font-size:13px;color:var(--cream-40);line-height:1.85}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--fu);font-size:9.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--black);background:var(--green);padding:13px 24px;border:1px solid var(--green);border-radius:2px;transition:all var(--t);white-space:nowrap;cursor:pointer}
.btn-primary:hover{background:#7FE85C;transform:translateY(-1px);box-shadow:0 8px 24px rgba(109,222,74,.18)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;font-family:var(--fu);font-size:9.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-60);background:transparent;padding:13px 24px;border:1px solid var(--bdr);border-radius:2px;transition:all var(--t);white-space:nowrap;cursor:pointer}
.btn-ghost:hover{color:var(--cream);border-color:var(--bdr-h);background:var(--green-04)}

/* ── PAGE HERO ── */
.page-hero{padding:20px 0 44px;position:relative}
.page-hero-ghost {
  position: absolute;
  top: -10px;
  right: 0;
  font-family: var(--fd);
  font-size: clamp(80px, 14vw, 200px);
  font-weight: 300;
  color: rgba(109,222,74,.03);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  display: none;  /* ADD THIS LINE */
}

/* ── CAROUSEL ── */
.carousel-wrap{flex:1;min-width:200px;max-width:320px;height:440px;position:relative;overflow:hidden;border-radius:2px;flex-shrink:0;background:var(--black-3)}
.carousel-wrap::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(109,222,74,.02) 0,rgba(109,222,74,.02) 1px,transparent 1px,transparent 20px);z-index:0}

/* CRITICAL: Carousel images must stack and fade - very specific selectors */
.carousel-wrap > .carousel-img,
.carousel-wrap .carousel-img,
img.carousel-img {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  opacity: 0 !important;
  transition: opacity 0.7s ease !important;
  z-index: 1 !important;
  display: block !important;
}

/* Only active image is visible */
.carousel-wrap > .carousel-img.active,
.carousel-wrap .carousel-img.active,
img.carousel-img.active {
  opacity: 1 !important;
  z-index: 2 !important;
}

.carousel-no-img{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.carousel-no-img::before{content:'🎬';font-size:48px;opacity:.12}
.carousel-no-img span{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-20)}

/* ── GRIDS ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* ── CARDS ── */
.card{background:var(--black-2);border:1px solid var(--bdr);padding:28px 24px;border-radius:2px;transition:border-color var(--t),box-shadow var(--t)}
.card:hover{border-color:var(--bdr-h);box-shadow:0 4px 24px rgba(0,0,0,.3)}
.card-dot{width:6px;height:6px;background:var(--green);border-radius:50%;margin-bottom:18px}

/* ── STATS ── */
.stat-bar{display:flex;border:1px solid var(--bdr);margin:28px 0}
.stat-item{flex:1;padding:20px 24px;border-right:1px solid var(--bdr)}
.stat-item:last-child{border-right:none}
.stat-n{font-family:var(--fd);font-size:42px;font-weight:300;color:var(--green);line-height:1;margin-bottom:6px}
.stat-l{font-size:8px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-40)}

/* ── POSTER CARDS ── */
.poster-card{background:var(--black-2);border:1px solid var(--bdr);border-radius:2px;overflow:hidden;cursor:pointer;transition:border-color var(--t),transform var(--t),box-shadow var(--t)}
.poster-card:hover{border-color:var(--bdr-h);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.5)}
.poster-wrap{position:relative;height:300px;overflow:hidden;background:var(--black-3)}
.poster-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s;display:block;opacity:1!important}
.poster-card:hover .poster-wrap img{transform:scale(1.04)}
/* Placeholder when poster missing */
.poster-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.poster-ph::before{content:'🎬';font-size:40px;opacity:.1}
.poster-ph span{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-20);text-align:center;padding:0 16px}
.poster-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(6,8,8,.9) 100%)}
.poster-cat{position:absolute;top:12px;left:12px}
.poster-status{position:absolute;top:12px;right:12px;font-size:7.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:4px 8px;border-radius:20px}
.status-post{color:var(--green);background:rgba(109,222,74,.12)}
.status-pre{color:#F0C040;background:rgba(240,192,64,.12)}
.status-dev{color:var(--cream-40);background:rgba(239,245,238,.06)}
.poster-body{padding:18px 18px 14px}
.poster-meta{display:flex;gap:12px;font-size:8.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--cream-20);margin-bottom:8px}
.poster-title{font-family:var(--fd);font-size:21px;font-weight:400;color:var(--cream);margin-bottom:5px;line-height:1.2}
.poster-logline{font-size:11px;color:var(--cream-40);line-height:1.6;font-style:italic;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.poster-footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--bdr);cursor:pointer}
.poster-creator{font-size:9px;color:var(--cream-20);font-weight:500}
.poster-arrow{font-size:14px;color:var(--green-d);transition:transform var(--t)}
.poster-card:hover .poster-arrow{transform:translateX(4px)}

/* Trailer / POC buttons */
.trailer-btn,.poc-btn{
  display:inline-flex;align-items:center;gap:6px;
  font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:7px 12px;border-radius:2px;transition:all var(--t);
  margin-right:5px;margin-bottom:8px;cursor:pointer;
}
.trailer-btn{color:var(--black);background:var(--green);border:1px solid var(--green)}
.trailer-btn:hover{background:#7FE85C}
.poc-btn{color:var(--green);background:transparent;border:1px solid var(--green-20)}
.poc-btn:hover{background:var(--green-08);border-color:var(--green-d)}

/* ── VIDEO MODAL ── */
.video-modal{display:none;position:fixed;inset:0;z-index:9999;background:rgba(6,8,8,.97);align-items:center;justify-content:center;padding:20px}
.video-modal.open{display:flex}
.vm-inner{position:relative;width:100%;max-width:940px}
.vm-ratio{position:relative;padding-bottom:56.25%;height:0;overflow:hidden}
.vm-ratio iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.vm-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 0;margin-bottom:8px}
.vm-title{font-family:var(--fd);font-size:18px;font-weight:300;color:var(--cream-60)}
.vm-close{font-size:9.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-60);border:1px solid var(--bdr);padding:8px 16px;transition:all var(--t);cursor:pointer;background:transparent}
.vm-close:hover{color:var(--cream);border-color:var(--bdr-h)}

/* ── GROUP HEADING ── */
.group-heading{display:flex;align-items:baseline;gap:14px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--bdr)}
.group-heading h2{font-family:var(--fd);font-size:30px;font-weight:300;color:var(--cream)}
.group-count{font-size:8.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-20)}

/* ── TEAM CARDS ── */
.team-card{background:var(--black-2);border:1px solid var(--bdr);border-radius:2px;overflow:hidden;transition:border-color var(--t),box-shadow var(--t)}
.team-card:hover{border-color:var(--bdr-h);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.team-photo-wrap{position:relative;height:220px;overflow:hidden;background:var(--black-3)}
.team-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .4s}
.team-card:hover .team-photo-wrap img{transform:scale(1.04)}
.team-photo-fade{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,rgba(6,8,8,.8) 100%)}
.team-photo-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#0D0F0C 0%,#060808 100%)}
.team-photo-ph::after{content:'';width:80px;height:80px;border-radius:50%;background:rgba(109,222,74,.05);border:1px solid rgba(109,222,74,.1)}
.team-info{padding:18px 18px 18px}
.team-name{font-family:var(--fd);font-size:20px;font-weight:400;color:var(--cream);margin-bottom:3px}
.team-role{font-size:8.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--green-d);margin-bottom:9px}
.team-bio{font-size:11px;color:var(--cream-40);line-height:1.75;margin-bottom:10px}
.imdb-link{display:inline-flex;align-items:center;gap:6px;font-size:8.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#F0C040;transition:opacity var(--t)}
.imdb-link:hover{opacity:.7}

/* ── CTA STRIP ── */
.cta-strip{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;padding:36px 40px;border:1px solid var(--bdr);background:var(--black-2);margin-top:40px}
.cta-strip-btns{display:flex;gap:12px;flex-wrap:wrap}

/* ── FINANCE ── */
.finance-bar{margin-bottom:18px}
.finance-bar-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.finance-bar-header .pct{font-family:var(--fd);font-size:20px;font-weight:300;color:var(--green)}
.finance-bar-track{height:3px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}
.finance-bar-fill{height:100%;background:linear-gradient(to right,var(--green-d),var(--green));border-radius:2px;transition:width .8s ease}
.waterfall-row{display:flex;gap:18px;align-items:flex-start;padding:16px 18px;border:1px solid var(--bdr);margin-bottom:2px;transition:border-color var(--t)}
.waterfall-row.highlight{border-color:var(--green-20);background:var(--green-04)}
.waterfall-num{font-family:var(--fd);font-size:28px;font-weight:300;color:rgba(109,222,74,.18);flex-shrink:0;width:36px;line-height:1}
.waterfall-row.highlight .waterfall-num{color:var(--green)}
.waterfall-title{font-size:12px;color:var(--cream-40);line-height:1.5;padding-top:5px}
.waterfall-row.highlight .waterfall-title{color:var(--cream-60)}

/* ── FORMS ── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:14px}
.form-full{margin-bottom:14px}
.form-label{display:block;font-size:8.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-40);margin-bottom:7px}
.req{color:var(--green)}
.form-input,.form-select,.form-textarea{width:100%;background:var(--black-3);border:1px solid rgba(239,245,238,.08);border-radius:2px;color:var(--cream);font-family:var(--fu);font-size:12.5px;padding:11px 14px;transition:border-color var(--t);outline:none}
.form-input::placeholder,.form-textarea::placeholder{color:var(--cream-20)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--green-20);box-shadow:0 0 0 3px rgba(109,222,74,.04)}
.form-select{appearance:none;cursor:pointer}
.form-textarea{height:130px;resize:vertical}
.form-consent{display:flex;align-items:flex-start;gap:10px;margin-bottom:20px;font-size:11.5px;color:var(--cream-40);line-height:1.5}
.form-consent input[type="checkbox"]{margin-top:2px;flex-shrink:0;accent-color:var(--green)}
.form-success{padding:32px;border:1px solid var(--green-20);background:var(--green-04);border-radius:2px}
.form-error{font-size:11.5px;color:#FF6464;padding:10px 14px;border:1px solid rgba(255,100,100,.2);background:rgba(255,100,100,.04);border-radius:2px;margin-bottom:14px}

/* Gate */
.gate-wrap{display:flex;align-items:center;justify-content:center;min-height:70vh}
.gate-box{width:100%;max-width:420px;padding:48px 40px;border:1px solid var(--bdr);background:var(--black-2);text-align:center}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:8px 0 32px rgba(0,0,0,.5)}
  .mobile-toggle{display:flex}
  .main-content{margin-left:0;padding:64px 24px 60px}
  .grid-2,.grid-3{grid-template-columns:1fr 1fr}
  .cta-strip{flex-direction:column;align-items:flex-start}
  .carousel-wrap{max-width:100%;height:320px}
}
@media(max-width:640px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .stat-bar{flex-direction:column}
  .stat-item{border-right:none;border-bottom:1px solid var(--bdr)}
  .stat-item:last-child{border-bottom:none}
  .main-content{padding:60px 16px 48px}
  .page-hero-ghost{display:none}
}


/* ═══════════════════════════════════════════════════════════
   IMAGE VISIBILITY OVERRIDE - prevents JS scroll-reveal 
   from leaving poster-cards permanently hidden at opacity:0
   ═══════════════════════════════════════════════════════════ */
.poster-card,
.poster-card.sr,
.poster-card.sr:not(.in){
    opacity:1 !important;
    transform:none !important;
    visibility:visible !important;
}
.poster-card .poster-wrap img,
.poster-wrap > img{
    display:block !important;
    opacity:1 !important;
    visibility:visible !important;
}
/* Carousel needs opacity transitions - DO NOT override */

/* ═══════════════════════════════════════════════════════════
   LAYOUT FIXES - Manual adjustments
   ═══════════════════════════════════════════════════════════ */

/* Fix: Align Who We Are text with service boxes */
div[style*="grid-template-columns:1fr 1fr"][style*="gap:48px"] {
    align-items: flex-start !important;
}

div[style*="grid-template-columns:1fr 1fr"][style*="gap:48px"] > div:first-child {
    margin-top: 40px;
}

/* Fix: Stats inline - number and label on same line */
.stat-item {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    gap: 10px;
}

.stat-n {
    margin-bottom: 0;
    font-size: 32px;
}

.stat-l {
    font-size: 10px;
}