/* =========================
   SashaCam App
========================= */

.app-sashacam {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.sashacam-toolbar{
  display:flex; align-items:center; gap:8px;
  padding: 8px 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(200, 211, 171, 0.18);
  border-radius: 8px;
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
}

.live-dot{
  width: 8px; height: 8px; border-radius: 50%;
  background: #8B2E2E; /* collar-ish red */
  box-shadow: 0 0 10px rgba(139,46,46,0.35);
}
.live-text{ color: var(--text-soft); letter-spacing: 0.5px; }
.open-link{ margin-left:auto; color: var(--sage-accent); text-decoration:none; }
.open-link:hover{ text-decoration: underline; }


.sashacam-frame {
  width: 100%;
  aspect-ratio: 16 / 9;
  max-height: 100%;
  border-radius: 10px;
  overflow: hidden;
  background: #000;
  border: 2px solid rgba(0,0,0,0.35);
}

.sashacam-frame iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.sashacam-footer{
  font-size: 12px;
  opacity: 0.85;
}

/* =========================
   Music Player App
========================= */

.app-music { height: 100%; display:flex; flex-direction:column; gap:12px; }

.music-top{
  padding: 10px 12px;
  border: 1px solid rgba(200, 211, 171, 0.18);
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
}

.music-title{
  font-family: "IBM Plex Mono", monospace;
  font-size: 11px;
  opacity: 0.8;
  letter-spacing: 0.6px;
}

.music-now{
  margin-top: 6px;
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
  color: var(--sage-accent);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.music-controls{ display:flex; flex-direction:column; gap:10px; }

.music-btn{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(200, 211, 171, 0.25);
  color: var(--text-soft);
  border-radius: 10px;
  padding: 8px 10px;
  cursor: pointer;
  font-family: "IBM Plex Mono", monospace;
}

.music-btn:hover{ border-color: rgba(229,171,72,0.45); }

.music-play{ min-width: 56px; }

.music-controls > :first-child{
  display:flex;
  gap:10px;
}

.music-time{
  display:flex;
  align-items:center;
  gap:10px;
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
}

.music-time input[type="range"]{
  width: 100%;
}

.music-bottom{
  display:flex;
  align-items:center;
  gap:12px;
}

.music-vol{
  display:flex;
  align-items:center;
  gap:8px;
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
  white-space: nowrap;
}

.music-select{
  flex: 1;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(200, 211, 171, 0.25);
  color: var(--text-soft);
  border-radius: 10px;
  padding: 8px 10px;
  font-family: "IBM Plex Mono", monospace;
}

.music-hint{
  margin-top:auto;
  font-size: 12px;
  opacity: 0.75;
}
.music-hint code{ font-family: "IBM Plex Mono", monospace; }

.music-tabs{ display:flex; gap:8px; }
.music-tab{
  flex: 1;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid rgba(200, 211, 171, 0.25);
  background: rgba(255,255,255,0.04);
  color: var(--text-soft);
  font-family: "IBM Plex Mono", monospace;
  cursor: pointer;
}
.music-tab.active{ border-color: rgba(229,171,72,0.55); }
.music-tab:disabled{ opacity:0.45; cursor:not-allowed; }

.music-panel.hidden{ display:none; }

.mixtape-row{ display:flex; align-items:center; gap:10px; }
.mixtape-label{ font-family:"IBM Plex Mono", monospace; font-size:12px; opacity:0.8; }

.mixtape-frame{
  margin-top: 10px;
  flex: 1;
  min-height: 0;
  border-radius: 10px;
  overflow: hidden;
  background: #000;
  border: 2px solid rgba(0,0,0,0.35);
}
.mixtape-frame iframe{ width:100%; height:100%; border:0; display:block; }

.music-cat-wrap{
  margin-top: 10px;
  display: flex;
  justify-content: center;
}

.music-cat{
  width: 64px;
  height: 64px;
  image-rendering: pixelated;
  filter: drop-shadow(0 6px 10px rgba(0,0,0,0.35));
  transform-origin: 50% 70%;
}

.music-cat.bop{
  animation: catBop 120ms ease-out;
}

@keyframes catBop{
  0%   { transform: scale(1.00) rotate(0deg); }
  50%  { transform: scale(1.18) rotate(-2deg); }
  100% { transform: scale(1.00) rotate(0deg); }
}

.music-cat.sleeping {
  opacity: 0.9;
  animation: breathe 2.5s ease-in-out infinite;
}

@keyframes breathe {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.05); }
  100% { transform: scale(1); }
}
