/* ============================================================
   MRML — Meeruangmalao  ·  Studio website  ·  dark cinematic
   ============================================================ */

:root{
  --bg:#0a0a0c;
  --bg-2:#101013;
  --bg-3:#16161b;
  --bg-4:#1d1d24;
  --ink:#ffffff;
  --muted:#9a9aa6;
  --muted-2:#6c6c79;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.055);
  --lime:#c8f02e;
  --indigo:#5a4dff;
  --indigo-soft:#857bff;
  --cream:#f3ebe1;
  --maxw:1280px;
  --r:16px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --f-head:'Space Grotesk',-apple-system,BlinkMacSystemFont,sans-serif;
  --f-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--f-body);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--lime);color:#000}

/* ---------- helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
.section{padding:118px 0;position:relative}
.section--tight{padding:80px 0}
.divider{height:1px;background:var(--line-2);max-width:var(--maxw);margin:0 auto}

.eyebrow{
  display:flex;align-items:center;gap:13px;
  font-family:var(--f-head);font-size:12.5px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--lime);
  margin-bottom:24px;
}
.eyebrow::before{content:attr(data-num);color:var(--indigo-soft);font-variant-numeric:tabular-nums}
.eyebrow::after{content:"";flex:0 0 44px;height:1px;background:var(--indigo)}
.eyebrow--c{justify-content:center}

h1,h2,h3,h4{font-family:var(--f-head);font-weight:700;line-height:1.07;letter-spacing:-.02em}
.h-xl{font-size:clamp(2.7rem,6.6vw,5.2rem)}
.h-lg{font-size:clamp(2rem,4.2vw,3.4rem)}
.h-md{font-size:clamp(1.45rem,2.5vw,2.05rem)}
.lead{font-size:clamp(1.04rem,1.45vw,1.28rem);color:var(--muted);max-width:62ch}
.text-lime{color:var(--lime)}
.text-cream{color:var(--cream)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-head);font-weight:600;font-size:14.5px;
  padding:15px 26px;border-radius:100px;border:1px solid transparent;
  cursor:pointer;white-space:nowrap;
  transition:transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
}
.btn:hover{transform:translateY(-3px)}
.btn--primary{background:var(--lime);color:#0a0a0c}
.btn--primary:hover{box-shadow:0 14px 38px -10px rgba(200,240,46,.5)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--lime);color:var(--lime)}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 30px;
  background:rgba(10,10,12,.55);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid transparent;
  transition:background .3s var(--ease),border-color .3s var(--ease),padding .3s var(--ease);
}
.nav.scrolled{background:rgba(10,10,12,.93);border-bottom-color:var(--line);padding:12px 30px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:36px;width:auto;transition:height .3s var(--ease)}
.nav.scrolled .brand img{height:31px}
.brand-text{font-family:var(--f-head);font-weight:700;font-size:18px;letter-spacing:.06em;line-height:1}
.brand-text small{display:block;font-size:8.5px;font-weight:500;letter-spacing:.26em;color:var(--muted);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  font-family:var(--f-head);font-size:14.5px;font-weight:500;
  padding:9px 17px;border-radius:100px;color:var(--muted);
  transition:color .2s var(--ease),background .2s var(--ease);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink);background:rgba(255,255,255,.06)}
.nav-cta{margin-left:8px}
.nav-cta a{
  font-family:var(--f-head);font-size:13.5px;font-weight:600;
  padding:10px 19px;border-radius:100px;background:var(--lime);color:#0a0a0c;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease);
}
.nav-cta a:hover{transform:translateY(-2px);box-shadow:0 10px 26px -8px rgba(200,240,46,.5)}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;padding:9px;cursor:pointer}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);margin:4px 0;transition:.3s var(--ease)}
.nav.open .nav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav.open .nav-toggle span:nth-child(2){opacity:0}
.nav.open .nav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;padding:172px 0 70px;overflow:hidden}
.hero-glow{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(620px 440px at 80% 12%,rgba(90,77,255,.30),transparent 70%),
    radial-gradient(560px 480px at 8% 88%,rgba(200,240,46,.14),transparent 70%);
}
.hero .wrap{position:relative;z-index:1}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-head);font-size:12.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);border-radius:100px;padding:9px 18px;margin-bottom:30px;
}
.hero-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 12px var(--lime)}
.hero h1{font-size:clamp(3rem,8.4vw,6.8rem);letter-spacing:-.035em}
.hero h1 .fill{color:var(--lime)}
.hero-sub{margin:28px 0 36px;font-size:clamp(1.05rem,1.55vw,1.3rem);color:var(--muted);max-width:56ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- montage marquee ---------- */
.mq{
  margin-top:84px;display:flex;flex-direction:column;gap:16px;
  position:relative;z-index:1;
}
.mq-row{display:flex;gap:16px;width:max-content;animation:mqA 64s linear infinite}
.mq-row.rev{animation-direction:reverse;animation-duration:74s}
.mq:hover .mq-row{animation-play-state:paused}
.mq-row img{
  height:148px;width:263px;object-fit:cover;border-radius:12px;
  border:1px solid var(--line);filter:saturate(1.05);
}
@keyframes mqA{to{transform:translateX(-50%)}}

/* ---------- generic grid / split ---------- */
.grid{display:grid;gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split--wl{grid-template-columns:1.12fr .88fr}

/* ---------- feature cards ---------- */
.card{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);
  padding:30px;transition:transform .3s var(--ease),border-color .3s var(--ease),background .3s var(--ease);
}
.card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.2);background:var(--bg-3)}
.card .num{font-family:var(--f-head);font-size:12.5px;font-weight:600;color:var(--indigo-soft);letter-spacing:.1em}
.card h3{font-size:1.28rem;margin:12px 0 9px}
.card p{color:var(--muted);font-size:14.5px}
.ficon{
  width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:rgba(200,240,46,.12);border:1px solid rgba(200,240,46,.25);
  color:var(--lime);font-size:23px;margin-bottom:18px;
}
.ficon--indigo{background:rgba(90,77,255,.16);border-color:rgba(90,77,255,.35);color:var(--indigo-soft)}
.ficon--cream{background:rgba(243,235,225,.1);border-color:rgba(243,235,225,.25);color:var(--cream)}
.card .count{font-family:var(--f-head);font-weight:700;font-size:2rem;color:var(--lime);letter-spacing:-.03em;margin-top:14px;line-height:1}

/* ---------- montage mosaic ---------- */
.mosaic{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  grid-auto-rows:170px;
}
.mosaic .tile{
  overflow:hidden;border-radius:13px;border:1px solid var(--line);position:relative;
}
.mosaic .tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.mosaic .tile:hover img{transform:scale(1.07)}
.mosaic .tile::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 60px rgba(0,0,0,.4)}
.mosaic .w2{grid-column:span 2}
.mosaic .h2{grid-row:span 2}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.stat{padding:40px 28px;border-right:1px solid var(--line);background:var(--bg-2)}
.stat:last-child{border-right:none}
.stat .big{font-family:var(--f-head);font-weight:700;font-size:clamp(2.3rem,3.8vw,3.2rem);color:var(--lime);letter-spacing:-.03em;line-height:1}
.stat .lbl{color:var(--muted);font-size:13.5px;margin-top:9px}

/* ---------- poster cards (works) ---------- */
.posters{display:grid;gap:22px}
.posters--4{grid-template-columns:repeat(4,1fr)}
.posters--3{grid-template-columns:repeat(3,1fr)}
.poster{
  background:var(--bg-2);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s var(--ease);
}
.poster:hover{transform:translateY(-7px);border-color:rgba(255,255,255,.24)}
.poster-img{aspect-ratio:2/3;overflow:hidden;background:var(--bg-3);position:relative}
.poster-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease)}
.poster:hover .poster-img img{transform:scale(1.06)}
.poster-body{padding:15px 16px 18px}
.poster-body h3{font-size:1.04rem;line-height:1.25}
.poster-body .sub{color:var(--muted-2);font-size:12.5px;margin-top:5px}
.poster-body .genre{color:var(--lime);font-family:var(--f-head);font-size:11.5px;font-weight:600;letter-spacing:.04em;margin-top:7px}

/* ---------- films feature ---------- */
.feature{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center}
.feature-poster{
  border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  box-shadow:0 50px 90px -44px rgba(0,0,0,.95);aspect-ratio:3/4;
}
.feature-poster img{width:100%;height:100%;object-fit:cover}

/* ---------- future IP cards ---------- */
.ipcard{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .3s var(--ease),border-color .3s var(--ease);
}
.ipcard:hover{transform:translateY(-7px);border-color:rgba(90,77,255,.45)}
.ipcard-img{aspect-ratio:3/2;overflow:hidden;position:relative;background:var(--bg-3)}
.ipcard-img img{width:100%;height:100%;object-fit:cover;object-position:center 28%;transition:transform .55s var(--ease)}
.ipcard:hover .ipcard-img img{transform:scale(1.06)}
.ipcard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,12,.78),transparent 58%)}
.ipcard-dev{
  position:absolute;top:12px;left:12px;z-index:1;
  font-family:var(--f-head);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  background:var(--lime);color:#0a0a0c;padding:5px 10px;border-radius:100px;
}
.ipcard-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.ipcard-body h3{font-size:1.32rem;margin-bottom:10px}
.ipcard-body .genre{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:13px}
.ipcard-body p{color:var(--muted);font-size:14px;flex:1}
.ipcard-body .credit{margin-top:15px;padding-top:14px;border-top:1px solid var(--line-2);font-size:12.5px;color:var(--muted-2);display:flex;flex-wrap:wrap;gap:4px 18px}
.ipcard-body .credit b{color:var(--muted);font-weight:600}

/* ---------- tags ---------- */
.tag{
  font-family:var(--f-head);font-size:11px;font-weight:600;letter-spacing:.05em;
  text-transform:uppercase;padding:5px 11px;border-radius:100px;
  border:1px solid var(--line);color:var(--muted);
}
.tag--lime{background:rgba(200,240,46,.12);border-color:rgba(200,240,46,.3);color:var(--lime)}
.tag--indigo{background:rgba(90,77,255,.15);border-color:rgba(90,77,255,.38);color:var(--indigo-soft)}

/* ---------- localization band ---------- */
.loc{
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  background:linear-gradient(135deg,#121225,#0c0c12);
  display:grid;grid-template-columns:1.05fr .95fr;
}
.loc-main{padding:54px 50px}
.loc-main .huge{font-family:var(--f-head);font-weight:700;font-size:clamp(3rem,6vw,4.6rem);color:var(--lime);letter-spacing:-.03em;line-height:1}
.loc-side{border-left:1px solid var(--line);display:grid;grid-template-rows:1fr 1fr}
.loc-side .cell{padding:34px 40px;display:flex;flex-direction:column;justify-content:center}
.loc-side .cell+.cell{border-top:1px solid var(--line)}
.loc-side h4{font-family:var(--f-head);font-size:1.15rem;margin-bottom:6px}
.loc-side p{color:var(--muted);font-size:14px}

/* ---------- CTA ---------- */
.cta{
  position:relative;border-radius:24px;overflow:hidden;
  padding:84px 56px;text-align:center;
  background:linear-gradient(135deg,#13131a,#0c0c10);border:1px solid var(--line);
}
.cta::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(520px 300px at 18% 0%,rgba(200,240,46,.22),transparent 70%),
            radial-gradient(520px 320px at 86% 112%,rgba(90,77,255,.34),transparent 70%);
}
.cta>*{position:relative;z-index:1}
.cta h2{font-size:clamp(2rem,4.4vw,3.3rem);margin-bottom:16px}
.cta p{color:var(--muted);max-width:54ch;margin:0 auto 30px;font-size:1.05rem}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- page hero ---------- */
.phero{position:relative;padding:188px 0 76px;overflow:hidden;border-bottom:1px solid var(--line)}
.phero-glow{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(600px 360px at 84% 8%,rgba(90,77,255,.26),transparent 70%),
            radial-gradient(500px 340px at 4% 116%,rgba(200,240,46,.12),transparent 70%);
}
.phero .wrap{position:relative;z-index:1}
.phero h1{font-size:clamp(2.6rem,6.2vw,4.7rem);margin-bottom:20px}

/* ---------- overview counts ---------- */
.counts{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:38px}
.count-c{
  border:1px solid var(--line);border-radius:13px;padding:22px 22px;background:var(--bg-2);
}
.count-c .n{font-family:var(--f-head);font-weight:700;font-size:2.1rem;color:var(--lime);line-height:1;letter-spacing:-.03em}
.count-c .l{color:var(--muted);font-size:13px;margin-top:8px;font-family:var(--f-head);letter-spacing:.04em}

/* ---------- contact ---------- */
.mail-card{
  border:1px solid var(--line);border-radius:var(--r);background:var(--bg-2);
  padding:46px;display:flex;flex-direction:column;gap:8px;
}
.mail-card .label{font-family:var(--f-head);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2)}
.mail-card a.mail{
  font-family:var(--f-head);font-weight:700;font-size:clamp(1.5rem,3.2vw,2.5rem);
  color:var(--lime);letter-spacing:-.02em;word-break:break-all;transition:color .2s var(--ease);
}
.mail-card a.mail:hover{color:#fff}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:17px}
.field label{font-family:var(--f-head);font-size:13px;font-weight:600;color:var(--muted)}
.field input,.field textarea,.field select{
  background:var(--bg-3);border:1px solid var(--line);border-radius:11px;
  padding:13px 15px;color:var(--ink);font-family:var(--f-body);font-size:15px;width:100%;
  transition:border-color .2s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--lime)}
.field textarea{resize:vertical;min-height:124px}
.looking{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ---------- footer ---------- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding:66px 0 32px}
.footer-top{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:40px;margin-bottom:50px}
.footer .brand img{height:44px}
.footer-blurb{color:var(--muted);font-size:14.5px;margin-top:18px;max-width:38ch}
.footer h4{font-family:var(--f-head);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px}
.footer-links a{display:block;color:var(--muted);font-size:14.5px;padding:5px 0;transition:color .2s var(--ease)}
.footer-links a:hover{color:var(--lime)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding-top:24px;border-top:1px solid var(--line-2);
  color:var(--muted-2);font-size:13px;flex-wrap:wrap;
}
.footer-bottom .tagline{font-family:var(--f-head);letter-spacing:.04em}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .section{padding:86px 0}
  .split,.split--wl{grid-template-columns:1fr;gap:40px}
  .g-3,.g-4{grid-template-columns:repeat(2,1fr)}
  .feature{grid-template-columns:1fr;gap:32px}
  .feature-poster{max-width:420px}
  .posters--4{grid-template-columns:repeat(3,1fr)}
  .stats,.counts{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .loc{grid-template-columns:1fr}
  .loc-side{border-left:none;border-top:1px solid var(--line);grid-template-rows:none;grid-template-columns:1fr 1fr}
  .loc-side .cell+.cell{border-top:none;border-left:1px solid var(--line)}
  .looking{grid-template-columns:1fr}
  .mosaic{grid-template-columns:repeat(3,1fr);grid-auto-rows:150px}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .wrap{padding:0 20px}
  .nav{padding:14px 20px}.nav.scrolled{padding:10px 20px}
  .nav-links{
    position:fixed;top:0;right:0;bottom:0;width:80%;max-width:320px;
    flex-direction:column;align-items:stretch;justify-content:center;gap:6px;
    background:var(--bg-2);border-left:1px solid var(--line);
    padding:40px 26px;transform:translateX(110%);transition:transform .35s var(--ease);
  }
  .nav.open .nav-links{transform:none}
  .nav-links a{font-size:18px;padding:14px 16px}
  .nav-cta{margin:14px 0 0}
  .nav-cta a{display:block;text-align:center;padding:15px}
  .nav-toggle{display:block;z-index:2}
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .posters--4,.posters--3{grid-template-columns:repeat(2,1fr)}
  .stats,.counts{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}
  .stat:last-child{border-bottom:none}
  .counts{gap:12px}
  .section{padding:66px 0}
  .cta{padding:54px 22px}
  .mail-card,.loc-main{padding:30px}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .loc-side{grid-template-columns:1fr}
  .loc-side .cell+.cell{border-left:none;border-top:1px solid var(--line)}
  .footer-top{grid-template-columns:1fr;gap:30px}
  .mq-row img{height:120px;width:213px}
  h1,.h-xl{word-break:break-word}
}
