/* =========================================================
   MORTAL KOMBAT / HOCKEY CHARACTER SELECT
   Cleaned + easier to edit
   Mobile goal: LEFT CHARACTER / CHARACTER GRID / RIGHT CHARACTER
========================================================= */

/* =========================
   EASY EDIT SETTINGS
========================= */




:root{
  --mk-yellow:#fff12f;
  --mk-green:#22ff35;
  --mk-blue:#36a1ff;

  --main-bg:url('../mk_stone-bg.png');

  --desktop-left:30vw;
  --desktop-center:40vw;
  --desktop-right:30vw;

  --mobile-left:20vw;
  --mobile-center:48vw;
  --mobile-right:20vw;

  --select-max:920px;

  --fighter-width:min(130%,540px);
  --fighter-height:78vh;
  --fighter-mobile-height:56vh;
}

@media (max-width:1150px){

  #intro-video{
    height:80vh !important;
    margin-top: -60px;
  }

#intro-video-overlay{
    display:flex;
    align-items:center;
    justify-content:top;
  }
  
}

/* =========================
   RESET / GLOBAL
========================= */
@font-face{
  font-family:mk2;
  src:url('../font/mk1.ttf');
}

*{box-sizing:border-box}

html,
body{
  margin:0;
  min-height:100%;
  width:100%;
  overflow-x:hidden;
  color:#f7ee2e;
  background:#111;
  font-family:mk2,Impact,Haettenschweiler,"Arial Narrow Bold",sans-serif;
}

body{
  min-height:100vh;
  background-image:linear-gradient(rgba(0,0,0,.28),rgba(0,0,0,.4)),var(--main-bg);
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  background-attachment:fixed;
}

body:after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(0deg,rgba(255,255,255,.035) 0 1px,transparent 1px 4px),
    radial-gradient(ellipse at center,transparent 46%,#000d 100%);
  mix-blend-mode:screen;
  opacity:.48;
  z-index:50;
}

.mk2{font-family:mk2!important}
.caps{text-transform:uppercase}


/* =========================
   TOP BUTTONS / INTRO VIDEO
========================= */
.btn,
#audio-toggle{
  position:fixed;
  top:18px;
  z-index:100000000;
  padding:12px 18px;
  background-color:#d15e14;
  color:#f4f4f4;
  font-family:Arial,sans-serif;
  font-size:14px;
  font-weight:bold;
  letter-spacing:2px;
  text-decoration:none;
  transition:transform .12s ease,opacity .2s ease;
}

.btn{left:18px}
#audio-toggle{right:18px}
#audio-toggle:hover{transform:translateY(-2px)}
#audio-toggle.muted{opacity:.6;color:#999}

#intro-video-overlay{
  position:fixed;
  inset:0;
  width:100vw;
  height:100vh;
  background:#000;
  overflow:hidden;
  z-index:999999;
}

#intro-video{
  width:100vw;
  height:100vh;
  object-fit:contain;
  object-position:center center;
  display:block;
  background:#000;
}

#intro-video-overlay.hide-intro{
  opacity:0;
  pointer-events:none;
  transition:opacity 1s ease;
}

#site-content{opacity:0;visibility:hidden}
#site-content.show-site{opacity:1;visibility:visible}

/* =========================
   ROTATE DEVICE BLOCKER
========================= */
#rotate-device{display:none}

@media (orientation:portrait) and (max-width:900px){
  #rotate-device{
    position:fixed;
    inset:0;
    z-index:999999999;
    background:#000;
    color:var(--mk-yellow);
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    font-family:mk2,Impact,sans-serif;
    padding:30px;
  }

  #rotate-device h2{font-size:2.4rem;margin:10px 0}
  #rotate-device p{color:#fff;font-family:Arial,sans-serif;letter-spacing:2px}
  .rotate-icon{font-size:5rem}
  
  #intro-video-overlay{
    position:fixed;
    inset:0;
    width:96vw;
    height:96vh;
    background:#000;
    overflow:hidden;
    z-index:999999;
  }
  
  #intro-video{
    width:96vw;
    height:96vh;
    object-fit:contain;
    object-position:center center;
    display:block;
    background:#000;
  }
}

/* =========================
   CABINET / HEADER
========================= */
.mk-screen{
  min-height:100dvh;
  display:grid;
  place-items:center;
  padding:clamp(6px,.8vw,16px);
}

.mk-cabinet{
  position:relative;
  width:100vw;
  max-width:100vw;
  min-height:100dvh;
  padding:clamp(16px,1.9vw,38px);
  isolation:isolate;
  overflow:hidden;
  background:rgba(50,52,49,.42);
  border:5px solid #090909;
  box-shadow:inset 0 0 0 2px #87877c,inset 0 0 0 9px #252622,inset 0 0 95px #000,0 36px 90px #000;
}

.mk-cabinet:before{
  content:"";
  position:absolute;
  inset:17px;
  border:3px solid #151515;
  box-shadow:inset 0 0 0 3px #66665e,inset 0 0 33px #000;
  z-index:-1;
}

.mk-cabinet:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.12),transparent 28%),repeating-linear-gradient(90deg,rgba(0,0,0,.16) 0 2px,transparent 2px 9px);
  opacity:.55;
  z-index:-2;
}

.stone-lines{
  position:absolute;
  inset:84px 34px 70px;
  border:3px solid #171716;
  box-shadow:inset 0 0 0 3px #5d5d56;
  clip-path:polygon(0 0,100% 0,100% 40%,84% 40%,84% 100%,16% 100%,16% 40%,0 40%);
  opacity:.85;
  pointer-events:none;
}

.mk-header{
  text-align:center;
  position:relative;
  z-index:2;
}

h1{
  margin:0 0 clamp(14px,1.7vw,28px);
  font-size:clamp(3.4rem,5.45vw,7.6rem);
  line-height:.82;
  letter-spacing:.065em;
  color:var(--mk-yellow);
  text-shadow:5px 5px 0 #050505,8px 8px 0 #2b2b25,0 0 18px #000;
  transform:skew(-5deg) scaleY(1.12);
}

/* =========================
   MAIN 3-COLUMN LAYOUT
========================= */
.battle-layout{
  display:grid;
  grid-template-columns:minmax(330px,var(--desktop-left)) minmax(840px,var(--desktop-center)) minmax(330px,var(--desktop-right));
  grid-template-areas:"left center right";
  align-items:end;
  justify-content:center;
  gap:clamp(4px,.6vw,14px);
  position:relative;
  width:100%;
  margin-top:-75px;
}

.fighter-left{grid-area:left}
.center-select{grid-area:center}
.fighter-right{grid-area:right}

.fighter-side{
  position:relative;
  min-height:clamp(540px,68vh,760px);
  display:grid;
  place-items:end center;
  padding:20px 6px 106px;
  overflow:visible;
}

.fighter-side:before{
  content:"";
  position:absolute;
  inset:auto 2% 86px;
  height:68px;
  background:radial-gradient(ellipse,#000d 0,#0008 45%,transparent 72%);
  filter:blur(4px);
}

.fighter-left .big-fighter,
.fighter-right .big-fighter{
  width:var(--fighter-width);
  height:var(--fighter-height);
  max-height:var(--fighter-height);
  object-fit:contain;
  object-position:bottom center;
  margin-bottom:50px;
}

.big-fighter{
  position:relative;
  z-index:1;
  filter:drop-shadow(18px 26px 10px #000) saturate(1.08) contrast(1.06);
  transform-origin:50% 100%;
}

.fighter-right .big-fighter{transform:none}

.idle-a{animation:idleA 1.05s steps(2,end) infinite}
.idle-b{animation:idleB 1.15s steps(2,end) infinite}
.fighter-pop-a{animation:popA .24s ease both,idleA 1.05s .24s steps(2,end) infinite}
.fighter-pop-b{animation:popB .24s ease both,idleB 1.15s .24s steps(2,end) infinite}

.name-plate{
  position:absolute;
  bottom:180px;
  min-width:min(92%,270px);
  text-align:center;
  padding:11px 14px;
  background:linear-gradient(#1b1b1b,#060606);
  border:2px solid #696960;
  box-shadow:inset 0 0 18px #000,0 8px 20px #0008;
  z-index:100000;
}

.name-plate strong{
  display:block;
  color:var(--mk-green);
  font-size:clamp(1.65rem,2.8vw,2.75rem);
  line-height:.9;
  letter-spacing:.06em;
  text-shadow:4px 4px 0 #000;
}

.name-plate span{
  display:block;
  margin-top:4px;
  color:#d5d5c8;
  font-family:Arial,sans-serif;
  font-size:.76rem;
  letter-spacing:.22em;
}

/* =========================
   CHARACTER SELECT GRID
========================= */
.center-select{
  position:relative;
  z-index:2;
  align-self:center;
  display:grid;
  justify-items:center;
  margin-top:-105px;
}

.select-frame{
  position:relative;
  width:90%;
  max-width:var(--select-max);
  min-width:0!important;
  padding:clamp(16px,1.4vw,26px);
  background:transparent;
  border:4px solid #111;
  box-shadow:inset 0 0 0 3px #79796e,inset 0 0 48px #000e,0 18px 35px #0008;
  margin-top: -105px;
}

.select-frame:before{
  content:"";
  position:absolute;
  inset:10px;
  border:2px solid rgba(0,0,0,.75);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.13);
  pointer-events:none;
}

.slot-buttons{display:none}

.character-grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  grid-template-rows:repeat(3,minmax(0,1fr));
  gap:clamp(10px,.85vw,16px);
}

.character-tile{
  position:relative;
  aspect-ratio:1 / 1.05;
  border:0;
  padding:0;
  background:radial-gradient(circle at center 40%,rgba(255,255,255,.12),transparent 38%),linear-gradient(145deg,#111 0%,#222 50%,#050505 100%);
  overflow:hidden;
  box-shadow:inset 0 0 0 6px #292927,inset 0 0 0 11px #89897e,0 8px 0 #080808;
  transition:transform .12s,filter .12s;
}

.character-tile img{
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  padding:6px 4px 28px;
  filter:drop-shadow(0 10px 6px rgba(0,0,0,.9)) saturate(1.12) contrast(1.08);
}

.character-tile span{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:5px 2px;
  background:#000c;
  color:#fff333;
  font-size:clamp(.62rem,.85vw,.92rem);
  letter-spacing:.045em;
  text-shadow:2px 2px #000;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.character-tile:hover,
.character-tile.cursor{
  transform:translateY(-4px);
  filter:brightness(1.18);
}

.character-tile.selected-a{
  box-shadow:inset 0 0 0 7px var(--mk-green),inset 0 0 0 11px #021e06,0 0 24px var(--mk-green),0 7px 0 #071607;
}

.character-tile.selected-b{
  box-shadow:inset 0 0 0 7px var(--mk-blue),inset 0 0 0 11px #020b27,0 0 24px var(--mk-blue),0 7px 0 #061019;
}

.character-tile.selected-a:before,
.character-tile.selected-b:after{
  position:absolute;
  top:8px;
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  background:#000d;
  border:2px solid currentColor;
  font-size:1.45rem;
  text-shadow:2px 2px #000;
}

.character-tile.selected-a:before{content:"1";left:8px;color:var(--mk-green)}
.character-tile.selected-b:after{content:"2";right:8px;color:var(--mk-blue)}

.mystery-slot{
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(circle at center,rgba(255,255,255,.08),transparent 45%),linear-gradient(145deg,#1a1a1a,#050505);
  border:0;
  box-shadow:inset 0 0 0 6px #292927,inset 0 0 0 11px #666,0 8px 0 #080808;
}

.mystery-inner{
  font-size:5rem;
  color:#777;
  text-shadow:4px 4px 0 #000;
}

/* =========================
   SEALS / BATTLELINE / FOOTER
========================= */
.side-seal{
  position:absolute;
  top:19%;
  width:min(24vw,360px);
  aspect-ratio:1;
  border:0;
  box-shadow:none;
  background:transparent;
  opacity:.58;
  overflow:visible;
  display:grid;
  place-items:center;
  pointer-events:none;
}

.side-seal.left{left:4.5%}
.side-seal.right{right:4.5%}

.side-seal img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  filter:drop-shadow(7px 9px 5px rgba(0,0,0,.65));
  transform:scale(1.08);
}

.side-seal img.seal-pop{animation:sealPop .24s ease both}

.battleline{
  position:relative;
  z-index:5;
  text-align:center;
  margin-top:-240px;
  color:var(--mk-yellow);
  text-shadow:4px 4px 0 #000;
}

.battleline h2{
  margin:0;
  font-size:clamp(1.1rem,2vw,2.6rem);
  letter-spacing:.06em;
}

.help-bar{
  text-align:center;
  margin-top:12px;
  color:#cfcfc2;
  font-family:Arial,sans-serif;
  font-size:.72rem;
  letter-spacing:.22em;
  opacity:.72;
}

/* =========================
   ANIMATIONS
========================= */
@keyframes idleA{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-8px) rotate(1deg)}
}

@keyframes idleB{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-8px) rotate(1deg)}
}

@keyframes popA{
  from{opacity:0;transform:translateX(-28px) scale(.92)}
  to{opacity:1;transform:translateX(0) scale(1)}
}

@keyframes popB{
  from{opacity:0;transform:translateX(28px) scale(.92)}
  to{opacity:1;transform:translateX(0) scale(1)}
}

@keyframes sealPop{
  0%{opacity:0;transform:scale(.82) rotate(-3deg)}
  100%{opacity:1;transform:scale(1.08) rotate(0)}
}

/* =========================
   DESKTOP FINE TUNING
========================= */
@media (min-width:1200px) and (max-width:1399px){
  .battleline{margin-top:-170px}
  .center-select{margin-top:-50px}
}

@media (min-width:1700px){
  .select-frame{max-width:var(--select-max)}
  .fighter-side{min-height:clamp(600px,71vh,805px)}
  .big-fighter{max-height:82vh}
}

/* =========================
   MOBILE / LANDSCAPE
   Keeps: LEFT - GRID - RIGHT
========================= */
@media (max-width:1150px){
  html,
  body{
    width:100vw;
    min-height:100dvh;
    overflow:hidden;
  }

  .mk-screen{
    width:93vw;
    height:93vh;
    min-height:93vh;
    padding:4px;
    display:grid;
    place-items:center; 
  }

  .mk-cabinet{
    width:93vw;
    height:93vh;
    min-height:97vh;
    padding:8px;
    border:0;
    overflow:hidden;
  }

  .mk-cabinet:before{inset:8px}

  .mk-header h1,
  h1{
    font-size:24px !important;
    margin-bottom:4px;
    padding-top:0!important;
  }

  .mk-header h2{
    font-size:clamp(.72rem,2vw,1.1rem);
    margin:0 0 4px;
  }

  .battle-layout{
    display:grid!important;
    grid-template-columns:var(--mobile-left) var(--mobile-center) var(--mobile-right)!important;
    grid-template-areas:"left center right"!important;
    align-items:end;
    gap:0;
    width:100%;
    margin-top:0;
  }

  .fighter-left{grid-area:left!important}
  .center-select{grid-area:center!important}
  .fighter-right{grid-area:right!important}

  .center-select{
    width:100%!important;
    margin-top:0!important;
    align-self:end;
  }

  .fighter-side{
    min-height:var(--fighter-mobile-height);
    height:var(--fighter-mobile-height);
    padding:0 0 48px;
    overflow:visible;
  }

  .fighter-side:before{
    inset:auto 0 40px;
    height:35px;
  }

  .fighter-left .big-fighter,
  .fighter-right .big-fighter,
  .big-fighter{
    width:100%;
    height:var(--fighter-mobile-height);
    max-height:var(--fighter-mobile-height);
    margin-bottom:0;
    object-fit:contain;
    object-position:bottom center;
  }

  .name-plate{
    bottom:8px;
    min-width:90%;
    padding:6px 8px;
  }

  .name-plate strong{
    font-size:clamp(.85rem,3vw,1.35rem);
  }

  .name-plate span{
    font-size:.48rem;
    letter-spacing:.08em;
  }

  .select-frame{
    width:90%;
    max-width:none;
    padding:6px;
  }

  .character-grid{
    grid-template-columns:repeat(5,minmax(0,1fr))!important;
    grid-template-rows:repeat(3,minmax(0,1fr));
    gap:5px;
  }

  .character-tile{
    aspect-ratio:1 / 1;
    box-shadow:inset 0 0 0 3px #292927,inset 0 0 0 6px #89897e,0 4px 0 #080808;
  }

  .character-tile img{
    padding:3px 2px 13px;
  }

  .character-tile span{display:none}

  .character-tile.selected-a:before,
  .character-tile.selected-b:after{
    width:20px;
    height:20px;
    font-size:.95rem;
    top:4px;
  }

  .character-tile.selected-a:before{left:4px}
  .character-tile.selected-b:after{right:4px}

  .mystery-inner{font-size:2.4rem}

  .battleline{
    margin-top:4px;
    padding:0 8px;
  }

  .battleline h2{
    font-size:clamp(.8rem,2.8vw,1.3rem);
  }

  .help-bar{
    display:block;
    margin-top:2px;
    font-size:.52rem;
  }

  .side-seal,
  .stone-lines{display:none}

  #audio-toggle,
  .btn{
    top:8px;
    padding:8px 10px;
    font-size:10px;
    letter-spacing:1px;
  }

  #audio-toggle{right:8px}
  .btn{left:8px}
}

/* extra short landscape screens */
@media (orientation:landscape) and (max-height:600px){
  .mk-header h1,
  h1{
    font-size:clamp(1.25rem,5vw,2.6rem);
  }

  .fighter-side{
    min-height:52vh;
    height:52vh;
  }

  .fighter-left .big-fighter,
  .fighter-right .big-fighter,
  .big-fighter{
    height:52vh;
    max-height:52vh;
  }

  .battleline h2{
    font-size:clamp(.72rem,2.2vw,1.05rem);
  }
}


/* ====================================
SAFARI / iPHONE VIEWPORT FIX
==================================== */

@supports (height: 100dvh){

  html,
  body,
  .mk-screen,
  .mk-cabinet,
  #site-content{
    height:100dvh;
    min-height:100dvh;
  }

}


html,
body,
*{
  cursor:none !important;
}

#fake-puck-cursor{
  position:fixed;
  width:32px;
  height:32px;
  pointer-events:none;
  z-index:999999999;
  transform:translate(-50%, -50%);
  display:none;
}


.instagram-warning{
  margin-bottom:30px;

  color:#fff12f;

  font-family:Arial,sans-serif;

  font-size:clamp(.9rem,2vw,1.3rem);

  line-height:1.6;

  letter-spacing:2px;

  text-align:center;

  text-shadow:
    2px 2px 0 #000,
    0 0 10px rgba(0,0,0,.8);
}

