/* /client/public/theme.css */

:root{
  --bg: #05070c;
  --text: #e7eaf0;
  --muted: rgba(148,163,184,.92);

  --border: rgba(148,163,184,.16);
  --panel: rgba(2,6,23,.42);
  --panel2: rgba(2,6,23,.22);

  --shadow: 0 18px 70px rgba(0,0,0,.35);

  --accent: rgba(239,68,68,.92);
  --accent2: rgba(14,165,233,.92);

  --ring: rgba(14,165,233,.22);
  --ring2: rgba(239,68,68,.18);

  --radius-lg: 18px;
  --radius-md: 14px;
  --radius-sm: 12px;

  --topbar-h: 56px;
  --bottomnav-h: 64px;

  /* extra breathing room so buttons aren’t hugged to the nav */
  --shell-bottom-pad: 16px;

  /* toast */
  --toast-z: 9000;
  --toast-gap: 10px;
  --toast-maxw: 520px;
  --toast-bottom: calc(var(--bottomnav-h) + var(--shell-bottom-pad) + env(safe-area-inset-bottom, 0px) + 10px);
}

html[data-theme="light"]{
  --bg: #f6f7fb;
  --text: #0b1220;
  --muted: rgba(71,85,105,.95);

  --border: rgba(15,23,42,.14);
  --panel: rgba(255,255,255,.86);
  --panel2: rgba(255,255,255,.68);

  --shadow: 0 18px 70px rgba(2,6,23,.14);

  --ring: rgba(14,165,233,.22);
  --ring2: rgba(239,68,68,.14);
}

*{ box-sizing:border-box; }
html, body{ height:100%; }
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 700px at 25% -10%, var(--ring), transparent 55%),
              radial-gradient(900px 600px at 85% 0%, var(--ring2), transparent 55%),
              var(--bg);
  color: var(--text);
}

img{ max-width:100%; }
a{ color: inherit; }
.muted{ color: var(--muted); }

.kicker{
  font-size:12px;
  font-weight: 1000;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: #cbd5e1;
  opacity:.95;
}
html[data-theme="light"] .kicker{ color: rgba(15,23,42,.82); }

/* ✅ IMPORTANT: no body padding now (spacers handle it) */
.mvShell{ }
.mvNoScroll{ overflow:hidden; }

/* ✅ Spacer elements injected by nav.js */
.mvTopSpacer{
  height: var(--topbar-h);
}
.mvBottomSpacer{
  height: calc(var(--bottomnav-h) + var(--shell-bottom-pad) + env(safe-area-inset-bottom, 0px));
}

/* ===== Topbar ===== */
.mvTopbar{
  position: fixed;
  left: 0; right: 0; top: 0;
  height: var(--topbar-h);
  display:flex;
  align-items:center;
  z-index: 5000;
  pointer-events:auto;
  background: color-mix(in srgb, var(--bg) 55%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.mvTopbar *{ pointer-events:auto; }

.mvTopbarInner{
  width: min(1200px, 100%);
  margin: 0 auto;
  padding: 0 12px;
  display:flex;
  align-items:center;
  gap: 10px;
}

.mvBrand{
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  min-width: 120px;
  gap: 10px;
}
.mvLogo{
  height: 26px;
  width: auto;
  display:block;
}

.mvTopbarRight{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap: 8px;
}

.mvIconBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 65%, transparent);
  color: var(--text);
  cursor:pointer;
  text-decoration:none;
  user-select:none;
}
.mvIconBtn:hover{
  background: color-mix(in srgb, var(--panel) 85%, transparent);
}
.mvIconBtn span{ font-size: 16px; line-height: 16px; }

/* ===== Drawer ===== */
.mvDrawer{
  position: fixed;
  inset: 0;
  z-index: 6000;
  pointer-events:none;
}
.mvDrawer.open{ pointer-events:auto; }

.mvDrawerBackdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.52);
  opacity:0;
  transition: opacity .18s ease;
}
html[data-theme="light"] .mvDrawerBackdrop{ background: rgba(2,6,23,.32); }
.mvDrawer.open .mvDrawerBackdrop{ opacity:1; }

.mvDrawerPanel{
  position:absolute;
  top:0; left:0;
  height:100%;
  width: min(380px, 92vw);
  background: var(--panel);
  border-right: 1px solid var(--border);
  box-shadow: 0 22px 90px rgba(0,0,0,.55);
  transform: translateX(-102%);
  transition: transform .26s cubic-bezier(.2, .9, .2, 1);
  display:flex;
  flex-direction:column;
  will-change: transform;
}
.mvDrawer.open .mvDrawerPanel{ transform: translateX(0); }

.mvDrawerTop{
  height: var(--topbar-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 0 12px;
  border-bottom: 1px solid var(--border);
}

.mvDrawerNav{
  padding: 10px 10px 0;
  display:flex;
  flex-direction:column;
  gap: 6px;
}
.mvDrawerLink{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid transparent;
  text-decoration:none;
  color: var(--text);
  background: transparent;
}
.mvDrawerLink:hover{
  background: color-mix(in srgb, var(--panel2) 80%, transparent);
  border-color: var(--border);
}
.mvDrawerLink.isActive{
  border-color: color-mix(in srgb, var(--accent2) 50%, var(--border));
  background: color-mix(in srgb, var(--accent2) 10%, var(--panel2));
}
.mvNavIco{
  width: 22px;
  height: 22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  opacity:.95;
}

.mvDrawerFoot{
  margin-top:auto;
  padding: 12px;
  border-top: 1px solid var(--border);
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.mvDrawerToggle{
  display:flex;
  align-items:center;
  gap: 10px;
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 80%, transparent);
  color: var(--text);
  padding: 10px 10px;
  cursor:pointer;
}
.mvDrawerToggle:hover{
  background: color-mix(in srgb, var(--panel2) 95%, transparent);
}
.mvDrawerTiny{
  color: var(--muted);
  font-size: 12px;
}

/* ===== Bottom nav ===== */
.mvBottomNav{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  height: var(--bottomnav-h);
  display:flex;
  align-items:center;
  justify-content:space-around;
  gap: 6px;
  padding: 8px 10px;
  z-index: 5000;
  background: color-mix(in srgb, var(--bg) 55%, transparent);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--border);

  padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
}

.mvTab{
  flex:1;
  max-width: 160px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 4px;
  text-decoration:none;
  color: var(--text);
  border-radius: 14px;
  padding: 8px 6px;
  border: 1px solid transparent;
  opacity:.92;
}
.mvTab:hover{
  background: color-mix(in srgb, var(--panel2) 70%, transparent);
  border-color: var(--border);
  opacity:1;
}
.mvTabLbl{
  font-size: 11px;
  color: var(--muted);
  font-weight: 900;
}
.mvTab.isActive{
  border-color: color-mix(in srgb, var(--accent2) 50%, var(--border));
  background: color-mix(in srgb, var(--accent2) 10%, var(--panel2));
  opacity:1;
}
.mvTab.isActive .mvTabLbl{ color: var(--text); }

.mvTabPrimary{
  border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
}
.mvTabPrimary.isActive{
  border-color: color-mix(in srgb, var(--accent) 65%, var(--border));
  background: color-mix(in srgb, var(--accent) 10%, var(--panel2));
}

/* Focus */
a:focus, button:focus{ outline: none; }
a:focus-visible, button:focus-visible{
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent2) 30%, transparent);
  border-radius: 14px;
}

/* ---------- Form controls (global) ---------- */
input,
textarea,
select{
  width:100%;
  border:1px solid rgba(148,163,184,.18);
  background: rgba(2,6,23,.25);
  color: var(--text);
  border-radius: 14px;
  padding: 12px 12px;
  outline:none;
  font-weight: 800;
  font-size: 14px;
  pointer-events: auto;
}
select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
option{
  background: #0b1220;
  color: #e5e7eb;
}

/* =========================
   ✅ TOASTS (global)
   ========================= */

.mvToastHost{
  position: fixed;
  left: 0; right: 0;
  bottom: var(--toast-bottom);
  z-index: var(--toast-z);
  pointer-events: none;
  display:flex;
  justify-content:center;
  padding: 0 12px;
}

.mvToastStack{
  width: min(var(--toast-maxw), 100%);
  display:flex;
  flex-direction:column;
  gap: var(--toast-gap);
  pointer-events: none;
}

.mvToast{
  pointer-events: auto;
  border-radius: 16px;
  border: 1px solid rgba(148,163,184,.18);
  background: color-mix(in srgb, var(--panel) 72%, transparent);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  overflow:hidden;

  transform: translateY(10px);
  opacity: 0;
  animation: mvToastIn .18s ease forwards;
}

@keyframes mvToastIn{
  to{ transform: translateY(0); opacity: 1; }
}

.mvToastInner{
  padding: 12px 12px;
  display:flex;
  gap: 10px;
  align-items:flex-start;
}

.mvToastIcon{
  width: 28px;
  height: 28px;
  border-radius: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(2,6,23,.22);
  flex: 0 0 auto;
}

.mvToastMain{ flex: 1 1 auto; min-width: 0; }

.mvToastTitle{
  font-weight: 1100;
  font-size: 13px;
  margin: 0;
  line-height: 1.2;
  letter-spacing: -.01em;
}
.mvToastMsg{
  margin-top: 4px;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.35;
  white-space: pre-wrap;
}

.mvToastActions{
  display:flex;
  gap: 8px;
  align-items:center;
  flex: 0 0 auto;
}

.mvToastBtn{
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(2,6,23,.18);
  color: var(--text);
  border-radius: 12px;
  padding: 8px 10px;
  font-weight: 1000;
  font-size: 12px;
  cursor:pointer;
  user-select:none;
}
.mvToastBtn:hover{ filter: brightness(1.06); }

.mvToastClose{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(2,6,23,.18);
  color: var(--text);
  cursor:pointer;
  user-select:none;
}
.mvToastClose:hover{ filter: brightness(1.06); }

.mvToast.ok{
  border-color: rgba(34,197,94,.35);
  box-shadow: 0 18px 60px rgba(0,0,0,.35), 0 0 0 3px rgba(34,197,94,.08);
}
.mvToast.ok .mvToastIcon{
  border-color: rgba(34,197,94,.35);
  background: rgba(34,197,94,.12);
}

.mvToast.warn{
  border-color: rgba(245,158,11,.40);
  box-shadow: 0 18px 60px rgba(0,0,0,.35), 0 0 0 3px rgba(245,158,11,.08);
}
.mvToast.warn .mvToastIcon{
  border-color: rgba(245,158,11,.40);
  background: rgba(245,158,11,.12);
}

.mvToast.bad{
  border-color: rgba(239,68,68,.35);
  box-shadow: 0 18px 60px rgba(0,0,0,.35), 0 0 0 3px rgba(239,68,68,.08);
}
.mvToast.bad .mvToastIcon{
  border-color: rgba(239,68,68,.35);
  background: rgba(239,68,68,.12);
}
