/* ============================================================
   BEEST ENERGY — SHARED CONTROL DOCK
   Floating control to switch DESIGN variant (A/B/C) and COLOUR
   tone. Injected by controls.js on every design page.
   ============================================================ */

.dock {
  position: fixed;
  z-index: 999;
  right: clamp(12px, 2vw, 26px);
  bottom: clamp(12px, 2vw, 26px);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
  font-family: 'Inter', system-ui, sans-serif;
}

.dock__btn {
  width: 54px; height: 54px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  backdrop-filter: blur(10px);
  color: var(--accent);
  display: grid; place-items: center;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.03) inset;
  transition: transform .25s ease, box-shadow .25s ease, color .2s;
}
.dock__btn:hover { transform: translateY(-3px) scale(1.04); box-shadow: 0 16px 40px var(--glow); }
.dock__btn:active { transform: scale(.96); }
.dock__btn svg { width: 24px; height: 24px; }

.dock__panel {
  width: 290px;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 110px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-2) 92%, transparent);
  backdrop-filter: blur(18px);
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
  transform: translateY(14px) scale(.96);
  opacity: 0; pointer-events: none;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), opacity .25s;
}
.dock.open .dock__panel { transform: translateY(0) scale(1); opacity: 1; pointer-events: auto; }

.dock__title {
  font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--text-muted); margin: 0 0 10px;
}
.dock__title:not(:first-child) { margin-top: 20px; }

/* design variant tabs */
.dock__designs { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.dock__design {
  text-decoration: none;
  display: flex; flex-direction: column; gap: 4px;
  padding: 10px 8px; border-radius: 12px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
  color: var(--text); text-align: left;
  transition: border-color .2s, transform .2s, background .2s;
}
.dock__design:hover { transform: translateY(-2px); border-color: var(--accent); }
.dock__design.active { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 16%, transparent); }
.dock__design b { font-size: 1.1rem; font-weight: 800; color: var(--accent); line-height: 1; }
.dock__design span { font-size: .6rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-muted); }

/* colour swatches */
.dock__themes {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
}
.dock__theme {
  cursor: pointer; border: none; background: none; padding: 0;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.dock__swatch {
  width: 100%; aspect-ratio: 1.6/1; border-radius: 10px;
  border: 2px solid transparent;
  position: relative; overflow: hidden;
  transition: transform .2s, border-color .2s;
  box-shadow: 0 4px 12px rgba(0,0,0,.35);
}
.dock__theme:hover .dock__swatch { transform: translateY(-2px) scale(1.03); }
.dock__theme.active .dock__swatch { border-color: #fff; }
.dock__theme.active::after {
  content: '✓'; position: absolute; /* placeholder */
}
.dock__swatch i {
  position: absolute; inset: 0; display: block;
}
.dock__theme span {
  font-size: .58rem; letter-spacing: .04em; color: var(--text-muted);
  text-transform: uppercase; text-align: center; line-height: 1.2;
}
.dock__theme.active span { color: var(--accent); }

/* language list */
.dock__langs { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.dock__lang {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 10px; border-radius: 12px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
  color: var(--text); cursor: pointer; font: inherit; font-size: .8rem;
  text-align: left; transition: border-color .2s, transform .2s, background .2s;
}
.dock__lang:hover { transform: translateY(-2px); border-color: var(--accent); }
.dock__lang.active { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 16%, transparent); }
.dock__lang b { font-size: 1.15rem; line-height: 1; font-weight: 400; }
.dock__lang span { font-weight: 500; }

.dock__hint { margin: 16px 0 0; font-size: .62rem; color: var(--text-muted); opacity: .8; }

/* nav brand logo (used by all designs when assets/logo.png exists) */
.brand__logo { height: 40px; width: auto; display: block; }
@media (max-width: 760px) { .brand__logo { height: 34px; } }

@media (max-width: 560px) {
  .dock__panel { width: 250px; }
  .dock__btn { width: 48px; height: 48px; }
}

@media print { .dock { display: none; } }
