@font-face {
  font-family: 'VT323';
  src: url('/Assets/Font/VT323-Regular.ttf') format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  src: url('/Assets/Font/Montserrat-VariableFont_wght.ttf') format('truetype');
}
@font-face {
  font-family: 'Yellowtail';
  src: url('/Assets/Font/Yellowtail-Regular.ttf') format('truetype');
}

:root {
  --main-container-bg: 
    url('https://www.transparenttextures.com/patterns/billie-holiday.png'),
    linear-gradient(
      to right,
      #4d991f 0%,    
      #78d739 15%, 
      #a4f67c 30%,    
      #d4ffc2 45%,  
      #a4f67c 60%, 
      #78d739 75%,   
      #4d991f 100% 
    );
  --container-shadow: 
    inset 0 0 3px #000,
    0 10px 10px rgba(0, 0, 0, 0.6),  
    0 2px 1px -1px #C1BEB5 inset,
    0 -2px 1px -1px #FCFCFA inset,
    1px 0 0.5px -0.5px #DFDFD7 inset,
    -2.5px 0 1px -1px #D4CDC5 inset;
  --button-shadow:
    inset 0 1px 2px rgba(255, 255, 255, 0.2),
    inset 0 -2px 2px rgba(0, 0, 0, 0.3),
    0 2px 1px -1px #C1BEB5 inset,
    0 -2px 1px -1px #FCFCFA inset,
    1px 0 0.5px -0.5px #DFDFD7 inset,
    -2.5px 0 1px -1px #D4CDC5 inset;
  --controls-bg: 
    url('https://www.transparenttextures.com/patterns/brushed-alum-dark.png'),
    linear-gradient(
      to right,
      #4d991f 0%,    
      #78d739 15%, 
      #a4f67c 30%,    
      #d4ffc2 45%,  
      #a4f67c 60%, 
      #78d739 75%,   
      #4d991f 100% 
    );
  --controls-shadow:       
    0 5px 3px -1px #4d991f inset,       
    0 -3px 3px -1px #d4ffc2 inset,      
    5px 0 3px -1px #78d739 inset,      
    -3px 0 2px -0.5px #a4f67c inset;
  --silver-bg: 
    url('https://www.transparenttextures.com/patterns/white-brushed.png'),
    linear-gradient(
      to right,
      #2a2a2a 0%,    
      #555 10%,        
      #aaa 20%,   
      #ddd 35%,        
      #f7f7f7 45%,      
      #ddd 55%,       
      #aaa 70%,        
      #555 85%,       
      #2a2a2a 100%     
    );
  --silver-bg-pipe: 
  url('https://www.transparenttextures.com/patterns/billie-holiday.png'),
  linear-gradient(
    to right,
    #2a2a2a 0%,    
    #555 10%,        
    #aaa 20%,   
    #ddd 35%,        
    #f7f7f7 45%,      
    #ddd 55%,       
    #aaa 70%,        
    #555 85%,       
    #2a2a2a 100%     
  );
  --main-text-color: #164409;
  --main-border: 1px solid #164409;
  --content-bg: #031e11;
  --main-font-size: 1rem;
  --mobile-font-size: 0.7rem;
  --border-radius: 0.75em;
  --screen-text-color: #00ff11;
  --screen-text-color-main: white;
  --screen-border-radius: 2rem;
  --screen-border: 1px solid #00ff11;
  --mini-screen-border-radius: 2px;
  --screen-edge-dirt:
    inset 0 0 15px rgba(0, 0, 0, 0.5),
    inset 0 0 30px rgba(0, 0, 0, 0.25),
    inset 0 0 2px rgba(255, 255, 255, 0.1),
    inset 1px 1px 2px rgba(255, 255, 255, 0.1);
  --screen-font-family: 'VT323', monospace;

  /* rave mode */
  --main-container-bg-rave-mode: 
  url('https://www.transparenttextures.com/patterns/billie-holiday.png'),
  linear-gradient(
    to right,
    #4d991f 0%,    
    #78d739 15%, 
    #a4f67c 30%,    
    #d4ffc2 45%,  
    #a4f67c 60%, 
    #78d739 75%,   
    #4d991f 100% 
  );
  --controls-bg-rave-mode: 
  url('https://www.transparenttextures.com/patterns/brushed-alum-dark.png'),
  linear-gradient(
    to right,
    #4d991f 0%,    
    #78d739 15%, 
    #a4f67c 30%,    
    #d4ffc2 45%,  
    #a4f67c 60%, 
    #78d739 75%,   
    #4d991f 100% 
  );
  --controls-shadow-rave-mode:       
  0 5px 3px -1px #4d991f inset,       
  0 -3px 3px -1px #d4ffc2 inset,      
  5px 0 3px -1px #78d739 inset,      
  -3px 0 2px -0.5px #a4f67c inset;
}

body {
  background: 
    url('https://www.transparenttextures.com/patterns/bo-play.png'),
    linear-gradient(
      to right,
      #005f63 0%,
      #02767a 15%,
      #039ea0 30%,
      #0a9396 45%,
      #0a9396 55%,
      #039ea0 70%,
      #02767a 85%,
      #005f63 100%
    );
  font-family: "Montserrat", sans-serif;
  letter-spacing: 1px;
  align-items: center;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow-x: hidden;
}

img {
  user-drag: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  pointer-events: none;
  -moz-drag-over: none;
  -moz-window-dragging: no-drag;
  -moz-user-drag: none;
  -moz-user-select: -moz-none;
  draggable: false;
  touch-action: none;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
}
.spin-trigger {
  pointer-events: auto;
  position: relative;
  user-select: none;
}

.pipes-main-spin-screen {
  overflow: hidden;
  display: flex;
  gap: 120px;
  justify-content: center;
  align-items: center;
}
.pipe-main-spin-screen {
  width: 200px;
  height: 15px;
  background: var(--main-container-bg);
  border-left: var(--main-border);
  border-right: var(--main-border);
  box-shadow: 
    inset 0 -4px 8px rgba(0, 0, 0, 0.3),
    0 10px 10px rgba(0, 0, 0, 0.6);
}
.pipes-to-player {
  overflow: hidden;
  display: flex;
  gap: 500px;
  justify-content: center;
  align-items: center;
  z-index: 10;
  margin-top: 2px;
}
.pipe-player {
  width: 50px;
  height: 50px;
  background: var(--silver-bg-pipe);
  border-radius: 0.75em 0.75em 0 0;
  border-left: var(--main-border);
  border-right: var(--main-border);
  border-top: var(--main-border);
  box-shadow: 
  inset 0 -4px 8px rgba(0, 0, 0, 0.3),
  0 10px 10px rgba(0, 0, 0, 0.6);
}
.pipes-mobile {
  display: none;
  gap: 220px;
  justify-content: center;
  align-items: center;
}
.pipes-wide {
  overflow: hidden;
  display: flex;
  gap: 550px;
  justify-content: center;
  align-items: center;
}
.pipes {
  overflow: hidden;
  display: flex;
  gap: 320px;
  justify-content: center;
  align-items: center;
}
.pipes-footer {
  overflow: hidden;
  display: flex;
  gap: 320px;
  justify-content: center;
  align-items: center;
  z-index: 3;
  margin-bottom: 2px;
}
.pipe-footer {
  width: 50px;
  height: 50px;
  background: var(--silver-bg-pipe);
  border-radius: 0 0 0.75em 0.75em;
  border-left: var(--main-border);
  border-right: var(--main-border);
  border-bottom: var(--main-border);
  box-shadow: 
  inset 0 -4px 8px rgba(0, 0, 0, 0.3);
}
.pipe {
  width: 50px;
  height: 50px;
  background: var(--silver-bg-pipe);
  border-left: var(--main-border);
  border-right: var(--main-border);
  box-shadow: 
    inset 0 -4px 8px rgba(0, 0, 0, 0.3),
    0 10px 10px rgba(0, 0, 0, 0.6);
}

.container-header {
  padding: 0 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 2px 0.75px -0.8px #164409 inset, 0 -2.5px 0.75px -0.8px #164409 inset;
}
.container-header i {
  color: #164409;
  font-size: 1rem;
} 
.container-header h2 {
  color: #164409;
  font-size: 1rem;
  border: var(--main-border);
  font-family: sans-serif;
  padding: 0px 8px;
  border-radius: 2px;
}

.screen-border {
  box-sizing: border-box;
  position: relative;
  flex-grow: 1;
  padding: 15px;             
  border-radius: var(--screen-border-radius);
  background: var(--silver-bg);
  box-shadow:
    0 0 0 1px #000000,
    0 0 8px rgba(0, 0, 0, 0.8),
    inset 0 2px 3px rgba(255, 255, 255, 0.6),
    inset 0 4px 10px rgba(255, 255, 255, 0.2),
    inset 0 -2px 3px rgba(0, 0, 0, 0.4),
    inset 0 -5px 8px rgba(0, 0, 0, 0.2),
    inset 4px 0 8px rgba(0, 0, 0, 0.25),
    inset -4px 0 8px rgba(0, 0, 0, 0.25);
}
.screen-border::after {
  content: '';
  position: absolute;
  top: 15px;
  left: 15px;
  right: 15px;
  bottom: 15px;
  border-radius: calc(var(--screen-border-radius) - 15px);
  background:
    radial-gradient(circle at center,
      rgba(255,255,255,0.6) 0%,
      rgba(255,255,255,0.4) 50%,
      rgba(200,200,200,0.2) 80%,
      rgba(150,150,150,0.1) 93%,
      rgba(255,255,255,0) 100%);
  opacity: 0.25;
  pointer-events: none;
}

.screen-dirt-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  box-shadow:
    inset 0 0 10px #999999,
    inset 0 0 9rem rgba(0, 0, 0, 0.8),
    inset 0 0 1.5rem rgba(0, 0, 0, 0.8),
    0 0 5rem rgba(0, 0, 0, 0.8);
  border-radius: var(--screen-border-radius);
}
.screen-dirt-overlay::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('https://www.transparenttextures.com/patterns/asfalt-light.png');
  opacity: 0.3;
  pointer-events: none;
}

.mini-screen-border {
  box-sizing: border-box;
  position: relative;
  padding: 5px;             
  border-radius: var(--mini-screen-border-radius);
  background: var(--silver-bg);
  box-shadow:
    0 0 0 1px #000000,
    0 0 4px rgba(0, 0, 0, 0.8),
    inset 0 1px 1.5px rgba(255, 255, 255, 0.6),
    inset 0 2px 5px rgba(255, 255, 255, 0.2),
    inset 0 -1px 1.5px rgba(0, 0, 0, 0.4),
    inset 0 -2.5px 4px rgba(0, 0, 0, 0.2),
    inset 2px 0 4px rgba(0, 0, 0, 0.25),
    inset -2px 0 4px rgba(0, 0, 0, 0.25);          
}
.mini-screen-border::after {
  content: '';
  position: absolute;
  top: 5px;
  left: 5px;
  right: 5px;
  bottom: 5px;
  border-radius: calc(var(--mini-screen-border-radius) - 5px);
  background:
    radial-gradient(circle at center,
      rgba(255,255,255,0.6) 0%,
      rgba(255,255,255,0.4) 50%,
      rgba(200,200,200,0.2) 80%,
      rgba(150,150,150,0.1) 93%,
      rgba(255,255,255,0) 100%);
  opacity: 0.25;
  pointer-events: none;
}

.button3d-frame {
  display: inline-block;
  padding: 0.5px 4px 8px 4px;
  border-radius: var(--border-radius);
  background-color: rgba(0, 0, 0, .15);
  box-shadow: inset 0 2px 2px rgba(0, 0, 0, .25);    
}
.button3d {
  font-family: "Montserrat", sans-serif;
  transform: translateY(-0.3em);
  touch-action: manipulation;
  font-size: 1rem;
  color: var(--main-text-color);
  text-transform: uppercase;
  padding: 0.6em 0.8em;
  background: var(--silver-bg);
  box-shadow: var(--button-shadow);
  border: var(--main-border);
  border-radius: var(--border-radius);
  transform-style: preserve-3d;
  transition: transform 150ms cubic-bezier(0, 0, 0.58, 1), background 150ms cubic-bezier(0, 0, 0.58, 1);
}
.button3d::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(to bottom, #5eb924, #3b7f18);
  border-radius: inherit;
  box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.5), inset 0 -1px 3px 3px rgba(0, 0, 0, .4);
  transform: translate3d(0, 0.55em, -1em);
  transition: transform 150ms cubic-bezier(0, 0, 0.58, 1), box-shadow 150ms cubic-bezier(0, 0, 0.58, 1);
  pointer-events: none;
}
.button3d:hover {
  transform: translate(0, -0.15em);
}
.button3d:hover::before {
  box-shadow: 
    0px 1px 3px 0px rgba(0, 0, 0, 0.5), 
    inset 0 -1px 3px 3px rgba(0, 0, 0, .4);
  transform: translate3d(0, 0.4em, -1em);
}
.button3d:active {
  transform: translate(0em, 0.25em);
}
.button3d:active::before {
  box-shadow: 
    0px 0 3px 0px rgba(0, 0, 0, 0.5), 
    inset 0 -1px 2px 2px rgba(0, 0, 0, .4);
  transform: translate3d(0, 0, -1em);
}
.button3d.active {
  transform: translate(0em, 0.25em);
}
.button3d.active::before {
  box-shadow:
    0 0 0 1px #164409,
    inset 0 1px 2px rgba(255, 255, 255, 0.15),
    inset 0 -2px 6px rgba(0, 0, 0, 0.4);
  transform: translate3d(0, 0, -1em);
}
.button3d:disabled {
  pointer-events: none;
  background: #888;
  color: white;
  text-shadow:
  -0.5px -0.5px 0 #000,
   0.5px -0.5px 0 #000,
  -0.5px  0.5px 0 #000,
   0.5px  0.5px 0 #000;
}
.button3d:disabled::before {
  background: #616161;
}

.flat-button-frame {
  display: inline-block;
  padding: 4px;
  border-radius: var(--border-radius);
  background-color: rgba(0, 0, 0, .15);
  box-shadow: inset 0 2px 2px rgba(0, 0, 0, .25);    
}
.flat-btn {
  font-family: "Montserrat", sans-serif;
  cursor: pointer;
  transition: all 0.2s ease-in-out;
  font-size: var(--main-font-size);
  color: var(--main-text-color);
  background: var(--silver-bg);
  border: var(--main-border);
  border-radius: var(--border-radius);
  text-transform: uppercase;
  padding: 0.6em 0.8em;
  box-shadow:
    0 0.05em 0.05em -0.01em rgba(5, 5, 5, 1),
    0 0.01em 0.01em -0.01em rgba(5, 5, 5, 0.5),
    0.15em 0.3em 0.1em -0.01em rgba(5, 5, 5, 0.25),
    var(--button-shadow);
}
.flat-btn:hover {
  box-shadow:
    0 0.05em 0.05em -0.01em rgba(5, 5, 5, 0.5),
    0 0.01em 0.01em -0.01em rgba(5, 5, 5, 0.25),
    0.15em 0.3em 0.1em -0.01em rgba(5, 5, 5, 0.125),
    var(--button-shadow);

}
.flat-btn:active {
  box-shadow:
    0 0 0 0 rgba(5, 5, 5, 1),
    0 0 0 0 rgba(5, 5, 5, 0.5),
    0 0 0 0 rgba(5, 5, 5, 0.25),
    var(--button-shadow);
  transform: scale(0.99);
}

@media (max-width: 768px) {
  .pipe-main-spin-screen {
    width: 130px;
    height: 10px;
  }
  .pipes-to-player {
    gap: 200px;
  }
  .flat-btn {
    font-size: var(--mobile-font-size);
  }
  .screen-border {
    padding: 10px;             
  }
  .pipes-wide {
    gap: 220px;
  }
  .pipes {
    gap: 220px;
  }
  .pipes-mobile {
    display: flex;
  }
  .pipes-footer {
    gap: 220px;
  }

  .pipe-footer {
    width: 30px;
    height: 40px
  }
  .pipe-player {
    width: 30px;
    height: 40px
  }
  .pipe {
    width: 30px;
    height: 40px;
  }
  .button3d-frame {
    padding: 0.5px 3px 6px 3px;  
  }
  .button3d {
    font-size: 0.7rem;
  }
  .container-header {
    padding: 0 5px;
  }
  .container-header i {
    font-size: 0.8rem;
  } 
  .container-header h2 {
    font-size: 0.8rem;
  }
}


/* === OUTLINECOLORS FOR COMMON ELEMENTS ===  
body       { outline: 1px dashed #999; }
header     { outline: 1px dashed #ff4500; }
footer     { outline: 1px dashed #1e90ff; }
section    { outline: 1px dashed #32cd32; }
article    { outline: 1px dashed #ffa500; }
nav        { outline: 1px dashed #8a2be2; }
main       { outline: 1px dashed #20b2aa; }
div        { outline: 1px dashed #ff1493; }
span       { outline: 1px dashed #ff6347; }
button     { outline: 1px dashed #00ced1; }
input      { outline: 1px dashed #4b0082; }
form       { outline: 1px dashed #808000; }
ul, ol, li { outline: 1px dashed #a52a2a; }

*[id]:hover::before,
*[class]:hover::after {
  position: absolute;
  background: rgba(255,255,0,0.85);
  color: #000;
  font-size: 11px;
  font-family: monospace;
  padding: 2px 4px;
  border: 1px solid #000;
  z-index: 9999;
  pointer-events: none;
  white-space: nowrap;
}

*[id]:hover::before {
  content: "#" attr(id);
  top: -20px;
  left: 0;
}

*[class]:hover::after {
  content: "." attr(class);
  bottom: -20px;
  left: 0;
} */
