/* ================================================================
   Garage Display -- Full-screen fermentation monitor
   Designed for always-on display in the garage/brewery.
   Standalone page: loads project.css for --bd-* tokens, then this.
   ================================================================ */

/* ── Base ──────────────────────────────────────────────────────── */
body.garage-body {
  overflow: hidden;
  height: 100vh;
  width: 100vw;
  margin: 0;
}

/* ── Layout (top bar / grid / bottom bar) ─────────────────────── */
.garage-layout {
  display: flex;
  flex-direction: column;
  height: 100vh;
  width: 100vw;
}

.garage-topbar {
  display: flex;
  align-items: center;
  padding: 0 clamp(0.5rem, 1vw, 1rem);
  height: 48px;
  flex-shrink: 0;
}

.garage-topbar__controls {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-left: auto;
}

/* ── Grid ──────────────────────────────────────────────────────── */
.garage-grid {
  display: grid;
  gap: clamp(0.5rem, 1vw, 1rem);
  padding: 0 clamp(0.5rem, 1vw, 1rem);
  flex: 1;
  width: 100%;
  min-height: 0;
  grid-auto-rows: 1fr;
}

.garage-grid--1 {
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
}

.garage-grid--2 {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr;
}

.garage-grid--3,
.garage-grid--4 {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
}

/* ── Card ──────────────────────────────────────────────────────── */
.garage-card {
  background: var(--gc-bg);
  color: var(--gc-text, #FFFFFF);
  border-radius: 1.5rem;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
  padding: clamp(2rem, 4vw, 4rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.8s ease-out;
}

.garage-card--fresh {
  box-shadow: 0 0 40px rgba(255, 255, 255, 0.15);
}

/* ── Tilt Color Variants ───────────────────────────────────────── */
.garage-card--red    { --gc-bg: linear-gradient(135deg, #E74C3C, #C0392B); --gc-text: #FFF; }
.garage-card--orange { --gc-bg: linear-gradient(135deg, #F39C12, #B87700); --gc-text: #1A1A1A; }
.garage-card--yellow { --gc-bg: linear-gradient(135deg, #F1C40F, #D4AC0D); --gc-text: #1A1A1A; }
.garage-card--green  { --gc-bg: linear-gradient(135deg, #27AE60, #1E8449); --gc-text: #FFF; }
.garage-card--blue   { --gc-bg: linear-gradient(135deg, #2980B9, #1A5276); --gc-text: #FFF; }
.garage-card--purple { --gc-bg: linear-gradient(135deg, #8E44AD, #6C3483); --gc-text: #FFF; }
.garage-card--pink   { --gc-bg: linear-gradient(135deg, #EC7063, #C0392B); --gc-text: #FFF; }
.garage-card--black  { --gc-bg: linear-gradient(135deg, #2C3E50, #1A252F); --gc-text: #FFF; }
.garage-card--none   { --gc-bg: linear-gradient(135deg, #262626, #141414); --gc-text: #FFF; }

/* ── Card Header ───────────────────────────────────────────────── */
.garage-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.garage-card__name {
  font-size: clamp(1.25rem, 2.5vw, 2.5rem);
  font-weight: 600;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

/* ── LIVE Indicator ────────────────────────────────────────────── */
.garage-live {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: clamp(0.6rem, 0.8vw, 0.85rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.7;
}

.garage-live__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--gc-text, #FFF);
  position: relative;
  flex-shrink: 0;
}

.garage-live__dot::before {
  content: '';
  position: absolute;
  inset: -4px;
  border: 2px solid var(--gc-text, #FFF);
  border-radius: 50%;
  opacity: 0;
  animation: garage-live-pulse 2s ease-out infinite;
}

@keyframes garage-live-pulse {
  0%   { transform: scale(0.8); opacity: 0.6; }
  100% { transform: scale(2.0); opacity: 0; }
}

/* Stale / disconnected: dim indicator and stop pulsing */
.garage-live--stale {
  opacity: 0.3;
}

.garage-live--stale .garage-live__dot::before {
  animation: none;
  opacity: 0;
}

/* ── Card Center (Metrics) ─────────────────────────────────────── */
.garage-card__center {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(2rem, 8vw, 8rem);
  flex: 1;
}

/* Stack values vertically for 1-2 column layouts */
.garage-grid--1 .garage-card__center,
.garage-grid--2 .garage-card__center {
  flex-direction: column;
}

/* 1 column, single beer — full screen, go huge */
.garage-grid--1 .garage-card:only-child .garage-card__center {
  gap: clamp(1rem, 4vh, 4rem);
}
.garage-grid--1 .garage-card:only-child .garage-card__value {
  font-size: max(4rem, 20vh);
}

/* 1 column, multiple beers — wide but short, side by side */
.garage-grid--1 .garage-card:not(:only-child) .garage-card__center {
  flex-direction: row;
  gap: clamp(2rem, 6vw, 6rem);
}
.garage-grid--1 .garage-card:not(:only-child) .garage-card__value {
  font-size: max(2.5rem, 18vh);
}

/* 2 columns — full height, half width, width is the constraint */
.garage-grid--2 .garage-card__center {
  gap: clamp(1rem, 3vh, 3rem);
}
.garage-grid--2 .garage-card__value {
  font-size: max(3rem, 9vw);
}

/* 3-4 columns — compact quarter-screen, side by side */
.garage-grid--3 .garage-card__center,
.garage-grid--4 .garage-card__center {
  flex-direction: row;
  gap: clamp(2rem, 6vw, 6rem);
}

.garage-card__metric {
  text-align: center;
}

.garage-card__label {
  font-size: clamp(0.7rem, 1.2vw, 1.2rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  opacity: 0.5;
  margin-bottom: 0.5rem;
}

.garage-card__value {
  font-size: max(3rem, 8vw);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1.0;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
  transition: text-shadow 0.6s ease-out, color 0.6s ease-out;
}

.garage-card__value--flash {
  text-shadow: 0 0 20px rgba(255, 255, 255, 0.8);
  transition: none;
}

/* ── Card Footer ───────────────────────────────────────────────── */
.garage-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.garage-card__timestamp {
  font-size: clamp(0.75rem, 1vw, 1rem);
  opacity: 0.4;
}

/* ── Empty State ───────────────────────────────────────────────── */
.garage-empty {
  display: flex;
  justify-content: center;
  align-items: center;
  flex: 1;
  width: 100%;
  color: var(--bd-text-muted, #737373);
  font-size: 1.5rem;
}

/* ── Shared Button Style (nav + controls) ─────────────────────── */
.garage-nav__btn,
.garage-controls__btn {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #FFF;
  padding: 0.5rem 1rem;
  border-radius: var(--bd-radius-md, 0.5rem);
  cursor: pointer;
  font-size: 0.8rem;
  font-family: inherit;
  transition: background 0.2s ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.garage-nav__btn:hover,
.garage-controls__btn:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #FFF;
}

.garage-controls__btn--active {
  background: var(--bd-primary, #14B8A6);
  border-color: var(--bd-primary, #14B8A6);
}

/* ── Fullscreen ────────────────────────────────────────────────── */
/* Hide controls in fullscreen — the OS/browser provides an exit hint */
:fullscreen .garage-topbar {
  display: none;
}

/* ── Reduced Motion ────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .garage-live__dot::before {
    animation: none;
  }

  .garage-card__value {
    transition: none;
  }

  .garage-card--fresh {
    transition: none;
  }
}
