/* =========================================================
   MA MEDIA — Floating dock (shared by all direction pages)
   Mirrors the dock styles in site.css so direction pages can
   render the same nav without depending on the live site's
   stylesheet. Uses brand tokens from tokens.css.
   ========================================================= */

.dock {
  position: fixed;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
  z-index: 95;
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 8px 10px;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  color: var(--ink);
  border: 1px solid var(--ink-20);
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: lowercase;
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  box-shadow:
    0 12px 32px -16px rgba(0,0,0,0.35),
    0 4px 12px -6px rgba(0,0,0,0.12),
    0 0 0 1px color-mix(in srgb, var(--ink) 4%, transparent);
  user-select: none;
  max-width: calc(100vw - 24px);
}
.dock__brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--ink);
  padding: 0 8px;
  height: 32px;
}
.dock__mark { height: 22px; width: auto; display: block; }
.dock__sep {
  display: inline-block;
  width: 1px;
  height: 18px;
  background: var(--ink-20);
  margin: 0 8px;
}
.dock__links {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.dock__links a {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  text-decoration: none;
  color: var(--ink);
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 500;
  transition: background-color 180ms ease;
  white-space: nowrap;
}
.dock__links a:hover { background: var(--ink-10); }
.dock__num {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.14em;
  color: var(--ink-40);
  font-variant-numeric: tabular-nums;
}
.dock__label { font-size: 12px; }

.dock__modes { display: inline-flex; align-items: center; gap: 2px; }
.dock__btn {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--ink);
  cursor: pointer;
  width: 32px; height: 30px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 180ms ease;
  font: inherit;
}
.dock__btn:hover { background: var(--ink-10); }
.dock__btn[aria-pressed="true"],
.dock__btn.is-active { background: var(--ink); color: var(--paper); }

.theme-icon {
  width: 16px; height: 16px; display: block;
  color: currentColor;
  transition: transform 320ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.dock__theme { position: relative; }
.dock__theme .theme-icon--sun { display: none; }
.dock__theme .theme-icon--moon { display: block; }
[data-mode="dark"] .dock__theme .theme-icon--sun { display: block; }
[data-mode="dark"] .dock__theme .theme-icon--moon { display: none; }
.dock__theme:hover .theme-icon { transform: rotate(35deg); }
[data-mode="play"] .dock__theme { opacity: 0.55; }
[data-mode="play"] .dock__theme:hover { opacity: 1; }

.dock__recolour { font-size: 14px; font-weight: 600; }
.dock__recolour-icon {
  display: inline-block;
  transition: transform 320ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.dock__recolour:hover .dock__recolour-icon { transform: rotate(60deg); }
[data-mode="play"] .dock__recolour { background: var(--ink); color: var(--paper); }
[data-mode="play"] .dock__recolour:hover .dock__recolour-icon { transform: rotate(180deg); }

.dock__palette { display: none; align-items: center; gap: 4px; padding: 0 4px; }
[data-mode="play"] .dock__palette { display: inline-flex; }
.dock__palette span {
  width: 12px; height: 12px;
  border-radius: 50%;
  border: 1px solid var(--ink-20);
  display: inline-block;
}
.dock__palette .sw-bg { background: var(--play-bg, var(--paper)); }
.dock__palette .sw-fg { background: var(--play-fg, var(--ink)); }
.dock__palette .sw-ac { background: var(--play-accent, var(--accent)); }

/* Language dropup */
.dock__lang { position: relative; }
.dock__lang-trigger {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  height: 32px;
  border-radius: 999px;
  font: inherit;
  font-weight: 600;
  letter-spacing: 0.08em;
  transition: background-color 180ms ease;
}
.dock__lang-trigger:hover { background: var(--ink-10); }
.dock__lang-trigger[aria-expanded="true"] { background: var(--ink-10); }
.dock__lang-trigger[aria-expanded="true"] .dock__lang-caret { transform: rotate(180deg); opacity: 1; }
.dock__lang-current { font-size: 12px; }
.dock__lang-caret {
  font-size: 8px; display: inline-block; opacity: 0.5; line-height: 1;
  transition: transform 220ms ease, opacity 180ms ease;
}
.dock__lang-menu {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 12px);
  transform: translateX(-50%) translateY(8px);
  min-width: 180px;
  background: var(--paper);
  color: var(--ink);
  border: 1px solid var(--ink-20);
  border-radius: 18px;
  padding: 6px;
  margin: 0;
  list-style: none;
  box-shadow: 0 18px 40px -20px rgba(0,0,0,0.4), 0 6px 16px -8px rgba(0,0,0,0.18);
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms ease, transform 220ms cubic-bezier(0.2,0.7,0.2,1);
  z-index: 96;
}
.dock__lang[data-open="true"] .dock__lang-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.dock__lang-menu li { display: block; }
.dock__lang-menu button {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 10px 14px;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 13px;
  text-align: left;
  text-transform: none;
  letter-spacing: 0.02em;
  cursor: pointer;
  border-radius: 12px;
  transition: background-color 160ms ease;
}
.dock__lang-menu button:hover { background: var(--ink-10); }
.dock__lang-menu button.is-active { background: var(--ink); color: var(--paper); }
.dock__lang-tag {
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 11px;
  min-width: 22px;
  display: inline-block;
}
.dock__lang-name { font-weight: 500; }

/* Restyle dropup */
.dock__restyle { position: relative; }
.dock__restyle-trigger {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  height: 32px;
  border-radius: 999px;
  font: inherit;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: lowercase;
  transition: background-color 180ms ease;
}
.dock__restyle-trigger:hover { background: var(--ink-10); }
.dock__restyle-trigger[aria-expanded="true"] { background: var(--ink-10); }
.dock__restyle-trigger[aria-expanded="true"] .dock__restyle-caret { transform: rotate(180deg); opacity: 1; }
.dock__restyle-icon {
  width: 12px; height: 12px;
  display: inline-block;
  font-size: 12px; line-height: 1;
  color: var(--accent);
}
.dock__restyle-label { font-size: 12px; }
.dock__restyle-caret {
  font-size: 8px; display: inline-block; opacity: 0.5; line-height: 1;
  transition: transform 220ms ease, opacity 180ms ease;
}
.dock__restyle-menu {
  position: absolute;
  right: 0;
  bottom: calc(100% + 12px);
  transform: translateY(8px);
  min-width: 240px;
  background: var(--paper);
  color: var(--ink);
  border: 1px solid var(--ink-20);
  border-radius: 18px;
  padding: 6px;
  margin: 0;
  list-style: none;
  box-shadow: 0 18px 40px -20px rgba(0,0,0,0.4), 0 6px 16px -8px rgba(0,0,0,0.18);
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms ease, transform 220ms cubic-bezier(0.2,0.7,0.2,1);
  z-index: 96;
  max-height: 70vh;
  overflow-y: auto;
}
.dock__restyle[data-open="true"] .dock__restyle-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.dock__restyle-menu li { display: block; }
.dock__restyle-menu a {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 10px 14px;
  text-decoration: none;
  color: var(--ink);
  font: inherit;
  font-size: 13px;
  letter-spacing: 0.02em;
  text-transform: none;
  border-radius: 12px;
  transition: background-color 160ms ease;
}
.dock__restyle-menu a:hover { background: var(--ink-10); }
.dock__restyle-menu a[aria-current] { background: var(--ink); color: var(--paper); }
.dock__restyle-tag {
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 11px;
  min-width: 22px;
  display: inline-block;
  color: var(--accent);
}
.dock__restyle-menu a[aria-current] .dock__restyle-tag { color: var(--paper); }
.dock__restyle-name { font-weight: 500; }

/* Responsive */
@media (max-width: 900px) {
  .dock {
    bottom: 12px;
    padding: 6px 8px;
    font-size: 11px;
    gap: 0;
  }
  .dock__brand { padding: 0 6px; }
  .dock__mark { width: 18px; height: 18px; }
  .dock__sep { margin: 0 4px; }
  .dock__label { display: none; }
  .dock__links a { padding: 8px 6px; }
  .dock__num { font-size: 11px; color: var(--ink); }
  .dock__btn { width: 28px; height: 28px; }
  .dock__lang-trigger, .dock__restyle-trigger { padding: 6px 8px; }
  .dock__restyle-label { display: none; }
}

[dir="rtl"] .dock { direction: rtl; }
