/* ===========================================================
   Dakota Blue — shared styles
   Matches dakota-blue-music-final.html + dakota-blue-win95-58a8d765.html
   Win95 chrome · grey #c0c0c0 · white desktop · neon green #39ff14
   =========================================================== */

@font-face {
  font-family: 'SoNormal';
  src: url('fonts/SoNormal.ttf') format('truetype');
  font-display: swap;
}
@font-face {
  font-family: 'Steamroller';
  src: url('fonts/Steamroller.ttf') format('truetype');
  font-display: swap;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  height: 100%;
  background: #000;
  font-family: 'Share Tech Mono', monospace;
  cursor: default;
  overflow: hidden;
  image-rendering: pixelated;
}

img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* ── OUTER WINDOW ── */
.window {
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100vw - 24px);
  height: calc(100vh - 24px);
  background: #c0c0c0;
  border-top: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  border-right: 2px solid #808080;
  border-bottom: 2px solid #808080;
  box-shadow: 2px 2px 0 #000;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── TITLEBAR ── */
.titlebar {
  background: linear-gradient(90deg, #001a00, #003800);
  padding: 3px 4px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-shrink: 0;
}
.titlebar-left { display: flex; align-items: center; gap: 4px; }
.titlebar-icon {
  width: 14px; height: 14px;
  background: #c0c0c0;
  border-top: 1px solid #fff; border-left: 1px solid #fff;
  border-right: 1px solid #808080; border-bottom: 1px solid #808080;
  display: flex; align-items: center; justify-content: center;
  font-size: 8px; line-height: 1;
}
.titlebar-title {
  font-family: 'Silkscreen', monospace;
  font-size: 0.6rem; font-weight: 700;
  color: #fff; letter-spacing: 0.05em;
}
.titlebar-buttons { display: flex; gap: 2px; }
.tb-btn {
  width: 16px; height: 14px;
  background: #c0c0c0;
  border-top: 1px solid #fff; border-left: 1px solid #fff;
  border-right: 1px solid #808080; border-bottom: 1px solid #808080;
  font-size: 0.5rem; font-weight: 700; font-family: 'Silkscreen', monospace;
  display: flex; align-items: center; justify-content: center;
  cursor: default; color: #000;
}

/* ── MENUBAR ── */
.menubar {
  background: #c0c0c0;
  border-bottom: 1px solid #808080;
  padding: 4px 6px;
  display: flex; gap: 0;
  flex-shrink: 0;
  align-items: center;
}
.menu-item {
  font-family: 'Silkscreen', monospace; font-size: 0.7rem;
  color: #000; padding: 5px 12px; cursor: pointer;
  letter-spacing: 0.06em;
  text-decoration: none;
}
.menu-item:hover { background: #001a00; color: #39ff14; }
.menu-item.active { background: #001a00; color: #39ff14; }

/* ── TOOLBAR ── */
.toolbar {
  background: #c0c0c0;
  border-bottom: 1px solid #808080;
  padding: 3px 6px;
  display: flex; align-items: center; gap: 6px;
  flex-shrink: 0;
}
.tool-btn {
  background: #c0c0c0;
  border-top: 1px solid #fff; border-left: 1px solid #fff;
  border-right: 1px solid #808080; border-bottom: 1px solid #808080;
  padding: 2px 8px;
  font-family: 'Silkscreen', monospace; font-size: 0.45rem;
  cursor: pointer; color: #000; letter-spacing: 0.05em;
  text-decoration: none;
}
.tool-sep { width: 1px; height: 16px; background: #808080; border-right: 1px solid #fff; margin: 0 2px; }
.toolbar-addr {
  flex: 1;
  background: #fff;
  border-top: 1px solid #808080; border-left: 1px solid #808080;
  border-right: 1px solid #fff; border-bottom: 1px solid #fff;
  padding: 2px 6px;
  font-family: 'Share Tech Mono', monospace; font-size: 0.45rem;
  color: #000;
}

/* ── DESKTOP CONTENT AREA ── */
.desktop {
  flex: 1;
  background: #ffffff;
  position: relative;
  overflow: auto;
}
.desktop-inner {
  position: relative;
  width: 1100px;
  min-height: 980px;
  margin: 0 auto;
}

/* Background "DAKOTA BLUE" Steamroller watermark */
.wordmark {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  z-index: 0;
  pointer-events: none;
  text-align: center;
  white-space: nowrap;
}
.wordmark span {
  display: block;
  font-family: 'Steamroller', sans-serif;
  font-size: 8rem;
  text-transform: uppercase;
  color: #39ff14;
  letter-spacing: 0.06em;
  line-height: 1;
  text-shadow:
    -2px -2px 0 #000, 2px -2px 0 #000,
    -2px  2px 0 #000, 2px  2px 0 #000,
     3px  3px 0 #000;
}

/* ── SUB-WINDOWS ── */
.sub-win {
  position: absolute;
  background: #c0c0c0;
  border-top: 2px solid #fff; border-left: 2px solid #fff;
  border-right: 2px solid #808080; border-bottom: 2px solid #808080;
  box-shadow: 4px 4px 10px rgba(0,0,0,0.3);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.sub-titlebar {
  background: linear-gradient(90deg, #001a00, #003800);
  padding: 3px 6px;
  display: flex; justify-content: space-between; align-items: center;
  flex-shrink: 0;
}
.sub-title {
  font-family: 'Silkscreen', monospace; font-size: 0.52rem;
  color: #39ff14; letter-spacing: 0.08em; white-space: nowrap;
}
.sub-btns { display: flex; gap: 2px; margin-left: 6px; flex-shrink: 0; }
.sub-btn {
  width: 14px; height: 13px;
  background: #c0c0c0;
  border-top: 1px solid #fff; border-left: 1px solid #fff;
  border-right: 1px solid #808080; border-bottom: 1px solid #808080;
  font-size: 0.42rem;
  display: flex; align-items: center; justify-content: center;
  cursor: default; color: #000;
}
.sub-body {
  flex: 1;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #808080 #c0c0c0;
}
.sub-body::-webkit-scrollbar { width: 12px; background: #c0c0c0; }
.sub-body::-webkit-scrollbar-thumb {
  background: #c0c0c0;
  border-top: 1px solid #fff; border-left: 1px solid #fff;
  border-right: 1px solid #808080; border-bottom: 1px solid #808080;
}

/* ── PHOTO IN SUB-WINDOW ── */
.photo-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 15%;
  display: block;
  filter: grayscale(100%) contrast(1.1);
}

/* ── DISCOG / LIST ITEMS ── */
.discog-item, .credit-item, .show-item, .band-item, .work-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px;
  border-bottom: 1px solid #b0b0b0;
  cursor: pointer;
  text-decoration: none;
}
.discog-item:hover, .credit-item:hover, .show-item:hover, .band-item:hover, .work-item:hover {
  background: #001a00;
}
.discog-item:hover *, .credit-item:hover *, .show-item:hover *, .band-item:hover *, .work-item:hover * {
  color: #39ff14 !important;
}
.di-icon, .band-icon { font-size: 0.85rem; flex-shrink: 0; color: #808080; }
.di-title {
  font-family: 'Silkscreen', monospace; font-size: 0.65rem;
  color: #000; letter-spacing: 0.05em;
}
.di-roles {
  font-family: 'Share Tech Mono', monospace; font-size: 0.32rem;
  color: #555; margin-top: 1px;
}

/* ── BAND / PROJECT ITEMS ── */
.band-name {
  font-family: 'Silkscreen', monospace; font-size: 0.4rem;
  color: #000; letter-spacing: 0.05em;
}
.band-links {
  font-size: 0.28rem; color: #808080;
  font-family: 'Share Tech Mono', monospace; margin-top: 1px;
}

/* ── SHOWS ── */
.show-date {
  font-family: 'Silkscreen', monospace; font-size: 0.7rem;
  color: #000; min-width: 80px; flex-shrink: 0;
}
.show-venue {
  font-family: 'Silkscreen', monospace; font-size: 0.65rem;
  color: #000; flex: 1;
}
.show-ticket {
  font-size: 0.55rem; color: #39ff14;
  font-family: 'Share Tech Mono', monospace;
  border: 1px solid #39ff14;
  padding: 4px 8px; flex-shrink: 0;
  text-decoration: none;
  background: #000;
  letter-spacing: 0.05em;
}
.show-item.past { opacity: 0.5; }
.show-item.past .show-ticket { color: #808080; border-color: #808080; background: transparent; }

/* ── STREAM BUTTONS ── */
.stream-body {
  padding: 6px;
  display: flex; flex-direction: column; gap: 4px;
}
.stream-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px;
  background: #000;
  border-top: 1px solid #39ff14; border-left: 1px solid #39ff14;
  border-right: 1px solid #003300; border-bottom: 1px solid #003300;
  text-decoration: none;
}
.stream-btn:hover { background: #001a00; }
.stream-name {
  font-family: 'Silkscreen', monospace; font-size: 0.65rem;
  color: #39ff14; letter-spacing: 0.08em;
}
.stream-arrow {
  font-family: 'Silkscreen', monospace; font-size: 0.65rem;
  color: #39ff14; margin-left: auto;
}

/* ── EMBED ── */
.embed-wrap {
  background: #000;
  border-top: 1px solid #39ff14; border-left: 1px solid #39ff14;
  border-right: 1px solid #003300; border-bottom: 1px solid #003300;
  overflow: hidden; flex-shrink: 0;
}
.embed-wrap iframe { display: block; border: 0; width: 100%; }

/* Header inside a sub-window for callout text */
.sub-callout-title {
  font-family: 'Silkscreen', monospace; font-size: 0.5rem;
  color: #39ff14; letter-spacing: 0.08em;
  padding: 4px 8px;
  background: #001a00; border-bottom: 1px solid #003800;
  flex-shrink: 0; text-align: center;
}
.sub-body-block {
  padding: 8px;
  font-family: 'Share Tech Mono', monospace; font-size: 0.5rem;
  color: #000; line-height: 1.7;
}
.sub-body-block p { margin-bottom: 8px; }
.sub-body-block strong { color: #001a00; }

/* ── FOOTER LINKS ── */
.footer-links {
  position: fixed;
  bottom: 16px; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: 6px;
  padding: 6px 10px;
  border: 2px solid;
  border-color: #fff #808080 #808080 #fff;
  background: #c0c0c0;
  z-index: 100;
  flex-wrap: nowrap;
  justify-content: center;
  max-width: calc(100vw - 30px);
  overflow-x: auto;
  scrollbar-width: none;
}
.footer-links::-webkit-scrollbar { display: none; }
.footer-link {
  font-family: 'Silkscreen', monospace; font-size: 0.65rem;
  letter-spacing: 0.08em; text-decoration: none;
  padding: 5px 11px;
  background: #000;
  border-top: 2px solid #39ff14; border-left: 2px solid #39ff14;
  border-right: 2px solid #003300; border-bottom: 2px solid #003300;
  color: #39ff14;
  text-shadow: 0 0 6px rgba(57,255,20,0.5);
  white-space: nowrap;
  flex-shrink: 0;
}
.footer-link.booking {
  background: #39ff14; color: #000; border-color: #39ff14;
  text-shadow: none; font-weight: 700;
}

/* ── LANDING PAGE PANELS (3 doors) ── */
.content {
  flex: 1;
  background: #c0c0c0;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  overflow: auto;
  padding: 8px;
  gap: 0;
}
header.page-header {
  background: #c0c0c0;
  border-top: 1px solid #fff; border-left: 1px solid #fff;
  border-right: 1px solid #808080; border-bottom: 1px solid #808080;
  padding: 8px 12px;
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 6px;
  flex-wrap: wrap; gap: 8px;
}
.site-name {
  font-family: 'Steamroller', sans-serif;
  font-size: clamp(1.8rem, 4vw, 3rem);
  text-transform: uppercase;
  color: #39ff14;
  letter-spacing: 0.06em; line-height: 1;
  text-shadow:
    -1px -1px 0 #000, 1px -1px 0 #000,
    -1px  1px 0 #000, 1px  1px 0 #000,
     2px  2px 0 #000;
}
.hdr-right { text-align: right; }
.hdr-meta {
  font-family: 'Silkscreen', monospace; font-size: 0.45rem;
  color: #000; letter-spacing: 0.08em; line-height: 2;
}
.hdr-email {
  display: inline-block;
  margin-top: 4px;
  padding: 5px 12px;
  background: #001a00;
  border-top: 1px solid #39ff14; border-left: 1px solid #39ff14;
  border-right: 1px solid #004400; border-bottom: 1px solid #004400;
  color: #fff;
  font-family: 'Share Tech Mono', monospace; font-size: 0.95rem;
  letter-spacing: 0.08em; text-decoration: none;
  font-weight: 700;
}
.contact-btn {
  display: inline-block;
  margin-top: 5px; margin-left: 4px;
  padding: 4px 12px;
  background: #000;
  border-top: 2px solid #39ff14; border-left: 2px solid #39ff14;
  border-right: 2px solid #003300; border-bottom: 2px solid #003300;
  color: #39ff14;
  font-family: 'Silkscreen', monospace; font-size: 0.5rem;
  letter-spacing: 0.12em; text-decoration: none;
  font-weight: 700;
  text-shadow: 0 0 6px rgba(57,255,20,0.6);
  box-shadow: 0 0 8px rgba(57,255,20,0.2);
}

/* Scrolling marquee */
.mq-wrap {
  background: #001a00;
  border-top: 1px solid #39ff14; border-left: 1px solid #39ff14;
  border-right: 1px solid #004400; border-bottom: 1px solid #004400;
  padding: 3px 6px;
  overflow: hidden; white-space: nowrap;
  margin-bottom: 6px;
  flex-shrink: 0;
}
.mq-text {
  display: inline-block;
  font-family: 'Silkscreen', monospace; font-size: 0.85rem;
  color: #fff; letter-spacing: 0.18em;
  text-transform: uppercase;
  animation: mq 30s linear infinite;
}
@keyframes mq { from { transform: translateX(100%); } to { transform: translateX(-100%); } }

/* Three landing panels */
.panels {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
}
.panel {
  background: #c0c0c0;
  border-top: 2px solid #fff; border-left: 2px solid #fff;
  border-right: 2px solid #808080; border-bottom: 2px solid #808080;
  padding: 20px 14px;
  display: flex; flex-direction: column;
  justify-content: center; align-items: center;
  text-align: center; text-decoration: none;
  cursor: pointer;
  transition: none;
}
.panel:active {
  border-top: 2px solid #808080; border-left: 2px solid #808080;
  border-right: 2px solid #fff; border-bottom: 2px solid #fff;
}
.panel-ornament { font-size: 0.6rem; font-family: monospace; color: #808080; margin-bottom: 6px; }
.panel-num { font-size: 0.38rem; letter-spacing: 0.25em; color: #808080; margin-bottom: 6px; font-family: 'Share Tech Mono', monospace; }
.panel-title {
  font-family: 'Press Start 2P', monospace; font-size: 0.88rem;
  letter-spacing: 0.08em; color: #39ff14; margin-bottom: 8px; line-height: 1.6;
  text-shadow:
    -1px -1px 0 #000, 1px -1px 0 #000,
    -1px  1px 0 #000, 1px  1px 0 #000,
     2px  2px 0 #000;
}
.panel-rule { font-size: 0.4rem; font-family: monospace; color: #808080; margin-bottom: 6px; }
.panel-desc { font-size: 0.78rem; letter-spacing: 0.04em; color: #000; line-height: 1.75; font-family: 'Share Tech Mono', monospace; }
.panel-for { margin-top: 8px; font-size: 0.4rem; letter-spacing: 0.2em; color: #555; font-family: 'Share Tech Mono', monospace; text-transform: uppercase; }
.panel-cta {
  margin-top: 10px;
  padding: 4px 12px;
  background: #001a00;
  border-top: 1px solid #39ff14; border-left: 1px solid #39ff14;
  border-right: 1px solid #004400; border-bottom: 1px solid #004400;
  color: #fff;
  font-family: 'Silkscreen', monospace; font-size: 0.5rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  cursor: pointer;
}

/* Footer links on landing variant (in content area, not fixed) */
.landing-footer-links {
  display: flex; justify-content: center; gap: 8px;
  padding: 6px 8px; margin-top: 6px;
  background: #c0c0c0;
  border-top: 2px solid #fff; border-left: 2px solid #fff;
  border-right: 2px solid #808080; border-bottom: 2px solid #808080;
  flex-wrap: wrap;
}

@media (max-width: 760px) {
  .panels { grid-template-columns: 1fr; }
  header.page-header { flex-direction: column; align-items: flex-start; }
  .hdr-right { text-align: left; }
}

/* ── MOBILE: stack the floating sub-windows vertically ── */
@media (max-width: 820px) {
  /* allow the body to scroll naturally */
  html, body { overflow: auto; height: auto; }

  /* outer window goes full-width and uses normal flow */
  .window {
    position: static;
    transform: none;
    width: 100%;
    height: auto;
    min-height: 100vh;
    box-shadow: none;
  }

  /* hide most of the chrome that doesn't help on mobile */
  .toolbar { display: none; }
  .menubar { overflow-x: auto; scrollbar-width: none; white-space: nowrap; flex-wrap: nowrap; }
  .menu-item { font-size: 0.65rem; padding: 4px 10px; flex-shrink: 0; }

  /* desktop area becomes a normal scrolling column */
  .desktop { overflow: visible; padding: 12px; }
  .desktop-inner {
    width: 100%;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-bottom: 70px;
  }

  /* every sub-window becomes a stacked card */
  .sub-win {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    max-width: 480px;
    margin: 0 auto;
    transform: none !important;
  }
  .sub-body { max-height: 60vh; }

  /* video / image bodies need a min-height so they don't collapse */
  .sub-win .sub-body video,
  .sub-win .sub-body img { width: 100%; height: auto; }
  .sub-win .sub-body[style*="background:#000"],
  .sub-win .sub-body[style*="background:#fff"],
  .sub-win .sub-body[style*="background:#39ff14"] { min-height: 260px; }

  /* hide the absolute-positioned wordmark on mobile (it'd be huge & off-screen) */
  .wordmark { display: none; }

  /* shrink site name a touch on phone */
  .site-name { font-size: 1.6rem; }

  /* footer remains single row but smaller */
  .footer-links { bottom: 10px; padding: 4px 8px; gap: 4px; }
  .footer-link { font-size: 0.55rem; padding: 4px 8px; }
}

/* extra small phones */
@media (max-width: 420px) {
  .menu-item { font-size: 0.55rem; padding: 4px 8px; }
  .footer-link { font-size: 0.5rem; padding: 3px 7px; }
}

/* ── LOGO ── */
.menubar-logo {
  width: 28px; height: 28px;
  object-fit: contain;
  margin: 0 10px 0 4px;
  align-self: center;
  flex-shrink: 0;
}
.spinning-logo {
  position: fixed;
  bottom: 100px;
  right: 30px;
  width: 120px; height: 120px;
  z-index: 90;
  animation: spin 18s linear infinite;
  pointer-events: none;
  filter: drop-shadow(0 0 8px rgba(57,255,20,0.35));
}
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

@media (max-width: 820px) {
  .spinning-logo {
    width: 70px; height: 70px;
    bottom: 78px; right: 14px;
  }
}

/* ── MULTI-LINK ROW (track with multiple streaming platforms) ── */
.discog-item.multi {
  cursor: default;
  align-items: flex-start;
  padding-top: 8px;
  padding-bottom: 10px;
}
.discog-item.multi:hover { background: transparent; }
.discog-item.multi:hover * { color: inherit !important; }
.discog-item.multi .di-title { color: #000; font-size: 0.65rem; }
.discog-item.multi .di-roles { color: #555; }

.multi-links {
  display: flex;
  gap: 4px;
  margin-top: 5px;
  flex-wrap: wrap;
}
.multi-links a {
  display: inline-block;
  padding: 3px 7px;
  background: #000;
  border-top: 1px solid #39ff14;
  border-left: 1px solid #39ff14;
  border-right: 1px solid #003300;
  border-bottom: 1px solid #003300;
  color: #39ff14;
  font-family: 'Silkscreen', monospace;
  font-size: 0.42rem;
  letter-spacing: 0.08em;
  text-decoration: none;
  text-shadow: 0 0 4px rgba(57,255,20,0.4);
}
.multi-links a:hover {
  background: #001a00;
  color: #fff !important;
}
.multi-links a.placeholder {
  opacity: 0.5;
  border-color: #808080 #404040 #404040 #808080;
  color: #808080;
  text-shadow: none;
}

/* ── NEWSLETTER (Kit / ConvertKit form) ── */
.formkit-form {
  border: 0 !important;
  background: transparent !important;
  max-width: 100% !important;
}
.nl-fields { display: flex; gap: 8px; flex-wrap: wrap; }
.formkit-input {
  flex: 1 1 160px;
  background: #ffffff;
  border-top: 2px solid #808080; border-left: 2px solid #808080;
  border-right: 2px solid #ffffff; border-bottom: 2px solid #ffffff;
  font-family: 'Share Tech Mono', monospace; font-size: 0.8rem;
  padding: 9px 10px; color: #000; outline: none;
}
.formkit-input:focus { background: #fffce5; }
.formkit-submit {
  background: #000;
  border-top: 2px solid #39ff14; border-left: 2px solid #39ff14;
  border-right: 2px solid #003300; border-bottom: 2px solid #003300;
  color: #39ff14;
  font-family: 'Silkscreen', monospace;
  font-size: 0.65rem; letter-spacing: 0.14em;
  padding: 9px 20px; cursor: pointer; text-transform: uppercase;
  text-shadow: 0 0 6px rgba(57,255,20,0.55);
  box-shadow: 0 0 10px rgba(57,255,20,0.2);
  flex-shrink: 0;
}
.formkit-submit:active {
  border-top: 2px solid #003300; border-left: 2px solid #003300;
  border-right: 2px solid #39ff14; border-bottom: 2px solid #39ff14;
}
.formkit-submit .formkit-spinner { display: none; }
.formkit-alert {
  list-style: none; margin: 8px 0 0; padding: 6px 8px;
  font-family: 'Share Tech Mono', monospace; font-size: 0.7rem;
  color: #ff5a3c;
}
.formkit-alert:empty { display: none; }

/* Newsletter window body */
.nl-body {
  background: #c0c0c0;
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 8px;
}
.nl-head {
  font-family: 'Press Start 2P', monospace;
  font-size: 0.72rem; color: #39ff14; letter-spacing: 0.06em; line-height: 1.4;
  text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000, 2px 2px 0 #000;
}
.nl-sub {
  font-family: 'Share Tech Mono', monospace; font-size: 0.62rem;
  color: #000; line-height: 1.5; margin-bottom: 2px;
}
