body {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  padding: 0;
  margin: 0;
}

button {
  background-color: rgba(0,0,0,0);
  border: 0;
  cursor: pointer;
}

#studio {
  display:none;
  background-image: url('assets/brushed_metal.jpeg');
}

#tracks, #allTracks {
  display: flex;
  flex-direction:row;
}

.track-row {
  display: flex;
  flex-direction:column;
  width:100px;
  align-items: center;
  gap:4px;

  border-right: solid 2px rgba(0,0,0,0.1);
  border-left: solid 2px rgba(255,255,255,0.1);


}

.track-label {
  display: grid;
  place-items: center;

  text-align: center;
  padding: 4px;

  font-size: 14px;
  line-height: 1.2;

  background: rgba(255,255,255,0.6);
  color: #333;
  width: 96px;

  overflow: hidden;

  /* clamp setup */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;

  height: 40px;
  font-family: 'Marker Felt Thin';

}






.track-pan, .eq-slider, .send-slider {
  width:90%;
  padding: 20px 0px;
}

.track-mute,
.track-solo {

  width: 30px;
  height: 40px;
  background-size: contain;
}

.mute-solo-buttons{
  padding-top:4px;
  display: flex;
  flex-direction: row;
  border: none;
}


.track-mute {
  background-image: url(/assets/mute_off.png);
}

.track-mute.active {
  background-image: url(/assets/mute_on.png);
}

.track-solo {
  background-image: url(/assets/solo_off.png);
}

.track-solo.active {
  background-image: url(/assets/solo_on.png);
}

.track-meter {
  translate: 50px 10px;
  border: 1px solid #555;
  background: #111;
}

.master-meter {
    border: 1px solid #555;
  background: #111;
  translate: 10px 10px;
}

@font-face {
  font-family: 'DSEG7';
  src: url('/fonts/DSEG7Classic-Italic.woff2') format('woff2'),
       url('/fonts/DSEG7Classic-Italic.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

.redDigits {
  font-family: 'DSEG7', monospace;
  font-size: 24px;
  color: rgba(200,000,000,1);
  background-color: #111;
  text-shadow: 0 0 3px rgba(200,000,000,1);
  user-select: none;
  caret-color: transparent;
}

.redDigits.editing {
  animation: flash 0.1s infinite alternate;
}

@keyframes flash {
  from { color: rgba(200,000,000,1); text-shadow: 0 0 3px rgba(200,000,000,1);}
  to   { color: rgba(200,000,000,0); text-shadow: 0 0 0px rgba(200,000,000,0);}
}



.redDigits:focus {
  outline: none;
}


.timeDigits {
  font-family: 'DSEG7', monospace;
  font-size: 30px;
  color: rgba(200,100,000,1);
  background-color: #111;
  text-shadow: 0 0 3px rgba(200,100,000,1);
  user-select: none;
  caret-color: transparent;
}


#delayDisplay{
  display:flex;
  flex-direction: row;
}


#displayDelayTime, #displayDelayFeedback {
  margin:10px;
  padding:10px;
  width:fit-content;
  border-radius: 5px;

  border: 1px inset rgba(200,200,200,0.1);
}



#masterVolume{
  transform: rotate(-90deg); /* rotate horizontal slider to vertical */
  translate: -20px -100px;
  width: 200px;
}

#masterTrack{
  width: 100px;
  background-color: #111;
  color:#eee
}

#transportSection{
  display: flex;
  flex-direction: column;
}


#transport {
  gap:0px;
  display:flex;

}

.transportButtons {
  height: 40px;
  width:64px;
  border: 0;
  margin: 0;
  padding:0;
  
}

#rewind{
  background-image: url(assets/transportButtons-11.png);
}

#fastforward{
  background-image: url(assets/transportButtons-12.png);
}

#play{
  background-image: url(assets/transportButtons-14.png);
}

#play.active {
  background-image: url(assets/transportButtons-16.png);
}

#pause{
  background-image: url(assets/transportButtons-15.png);
}

#pause.active {
  background-image: url(assets/transportButtons-17.png);
}

#stop{
  background-image: url(assets/transportButtons-13.png);
}

/* Base slider styling */
input[type="range"].delayControl {
  appearance: none;
  -webkit-appearance: none;  /* remove default styling */
  width: 170px;              /* or desired length */
  height: 30px;
  background-color: transparent;
  outline: none;
}

/* WebKit browsers (Chrome, Safari, Edge) */
input[type="range"].delayControl::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;  /* thumb size */
  height: 30px;
  background: url('assets/delaySliderThumb.png') no-repeat center center; /* PNG thumb */
  background-size: contain;
  cursor: pointer;
  border: none;  /* optional */
 /* align thumb vertically if track is thin */
}

/* Track for WebKit */
input[type="range"].delayControl::-webkit-slider-runnable-track {
  height: 30px;
  background: url('assets/delaySliderBackground.png') no-repeat center center;
  background-size: cover; /* or 'contain' depending on design */
  background-color: transparent;
}


/* Firefox */
input[type="range"].delayControl::-moz-range-thumb {
  width: 30px;
  height: 30px;
  background: url('assets/delaySliderThumb.png') no-repeat center center;
  background-size: contain;
  border: none;
  cursor: pointer;
}

input[type="range"].delayControl::-moz-range-track {
  height: 10px;
  background-color: transparent;
  border-radius: 5px;
}

#delayModule{
  display: flex;
  flex-direction: row;
  background-image: url(assets/delay_LS.jpg);
  background-repeat: no-repeat;
  background-size: 400px auto;
  width:400px;
  height: 166px;
  box-sizing: border-box;
  padding:30px 8px;
  color: #eee;
  gap: 0px;
  font-size: 14px;
}

#delayModule p {
  padding:0;
  margin: 0;
}

#delayTimeSection, #delayFeedbackSection {

  padding: 10px;

}

input[type="range"].track-volume {
  appearance:none;
  -webkit-appearance: none;  /* remove default styling */
  width: 180px;              /* or desired length */
  height: 80px;

  transform: rotate(-90deg); /* rotate horizontal slider to vertical */
  translate: 0px 50px;
  background-color: transparent;
  outline: none;
}

/* WebKit browsers (Chrome, Safari, Edge) */
input[type="range"].track-volume::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 40px;  /* thumb size */
  height: 40px;
  transform: rotate(90deg);
  background: url('assets/volumeSliderThumb.png') no-repeat center center; /* PNG thumb */
  background-size: contain;
  cursor: pointer;
  border: none;  /* optional */
 /* align thumb vertically if track is thin */
}

/* Track for WebKit */
input[type="range"].track-volume::-webkit-slider-runnable-track {
  height: 40px;
  background: url('assets/volumeSliderBackground.png') no-repeat center center;
  background-size: cover; /* or 'contain' depending on design */
  background-color: transparent;
}


/* Firefox */
input[type="range"].track-volume::-moz-range-thumb {
  width: 40px;
  height: 50px;
  background: url('assets/volumeSliderThumb.png') no-repeat center center;
  background-size: contain;
  border: none;
  cursor: pointer;
}

input[type="range"].track-volume::-moz-range-track {
  height: 60px;
  background-color: transparent;

}


/* Progress ::backdrop */

#loadProgressWrapper {
  width: 100%;
  height: 14px;
  background: #222;
  border-radius: 7px;
  overflow: hidden;
  margin-top: 10px;
  position: relative;
}

#loadProgressBar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #0f0, #6f6);
  transition: width 0.2s ease;
}

#loadProgressText {
  position: absolute;
  top: -22px;
  right: 0;
  font-family: monospace;
  font-size: 12px;
}

.smallVUMeter, .master-meter {
  background-image: url(assets/meterBG.jpg);
  background-size: cover;
  translate:0;
}

#masterMeters{
  display: flex;
  flex-direction: row;
}

.reverbKnob, .delayKnob, .toneKnob, .panKnob {
  background-size: cover;
  translate:0;
}

.reverbKnob {
  background-image: url(assets/sendknob.png);
}

.delayKnob {
  background-image: url(assets/sendknob2.png);
}

.toneKnob {
  background-image: url(assets/toneKnob.png);
}

.panKnob {
  background-image: url(assets/panKnob.png);
}

#delayMS{
  flex-direction: row;
  display: flex;
  font-size: 10px;
  color: #ddd;
  vertical-align: bottom;
}

#textMS{
  padding-top:44px
}

.sendsShell, .toneShell{
  width: 48px;
  display:flex;
  gap: 4px;
  flex-direction: column;
}

.sendsWrapper, .toneWrapper{
  
  width: 100px;
  display: flex;
  flex-direction: row;
}

.sendsLabelLeft{
  width:26px;
  height:100px;
  background-image: url(assets/striplables-23.png);
  background-size: cover;
}

.sendsLabelRight{
  width: 26px;
  height:100px;
  background-image: url(assets/striplables-24.png);
  background-size: cover;
}

.toneLabelLeft{
  width:26px;
  height:152px;
  background-image: url(assets/striplables-21.png);
  background-size: cover;
}

.toneLabelRight{
  width: 26px;
  height:152px;
  background-image: url(assets/striplables-22.png);
  background-size: cover;
}


.drop-zone {
  border: 2px dashed #666;
  padding: 1rem;
  text-align: center;
  color: #aaa;
  margin-bottom: 0.5rem;
}

.drop-zone.dragover {
  border-color: #0f0;
  background: rgba(0, 255, 0, 0.1);
}

.file-list {
  list-style: none;
  padding: 0;
  margin: 0 0 0.5rem 0;
  font-size: 12px;
}

.file-list li {
  color: #000;
}


