/* ============================================================
   Waymore Better Studios — shared site styles
   Used by /studio/*.html pages. Builds on tokens.css + base.css.
   Default theme: mountain. Default accent: coach (warm gold).
   ============================================================ */

/* ---- Top nav ---- */
.wmb-nav {
  position: sticky; top: 0; z-index: 20;
  background: color-mix(in oklch, var(--bg) 92%, transparent);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  padding: 1rem 1.5rem;
  display: flex; align-items: center; gap: 2rem;
}
.wmb-brand { display: inline-flex; align-items: center; gap: 0.625rem; text-decoration: none; color: var(--fg); }
.wmb-brand:hover { text-decoration: none; }
.wmb-brand .mark {
  width: 34px; height: 34px; border-radius: 8px;
  background: var(--primary); color: var(--primary-fg);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 500; font-size: 1.25rem; font-style: italic;
  letter-spacing: -0.02em;
  box-shadow: inset 0 -2px 0 color-mix(in oklch, #000 20%, transparent);
}
.wmb-brand .lockup { display: flex; flex-direction: column; gap: 0.1875rem; }
.wmb-brand .wordmark { font-family: var(--font-display); font-weight: 600; font-size: 1.0625rem; letter-spacing: -0.015em; line-height: 1; white-space: nowrap; }
.wmb-brand .wordmark em { font-style: italic; font-weight: 500; color: var(--fg-muted); margin-left: 0.125em; }
.wmb-brand .loc { font-size: 0.5625rem; font-weight: 500; color: var(--fg-subtle); letter-spacing: 0.04em; line-height: 1; white-space: nowrap; text-transform: none; }
@media (max-width: 600px) { .wmb-brand .wordmark em, .wmb-brand .loc { display: none; } }
.wmb-links { display: flex; gap: 1.75rem; margin-right: auto; margin-left: 0.75rem; }
.wmb-links a { font-size: 0.8125rem; color: var(--fg-muted); font-weight: 500; text-decoration: none; position: relative; padding-bottom: 4px; }
.wmb-links a:hover { color: var(--fg); text-decoration: none; }
.wmb-links a.active { color: var(--fg); font-weight: 600; }
.wmb-links a.active::after { content: ''; position: absolute; left: 0; right: 0; bottom: -1.125rem; height: 2px; background: var(--primary); }
.wmb-nav-cta { padding: 0.5rem 1rem; background: var(--primary); color: var(--primary-fg); text-decoration: none; border-radius: var(--radius); font-size: 0.8125rem; font-weight: 600; min-height: 40px; display: inline-flex; align-items: center; transition: filter 150ms; }
.wmb-nav-cta:hover { filter: brightness(1.05); text-decoration: none; }
@media (max-width: 760px) {
  .wmb-links { display: none; }
  .wmb-nav { padding: 0.875rem 1rem; }
}

/* ---- Section scaffolding ---- */
.wmb-section { padding: clamp(3rem, 6vw, 6rem) 1.5rem; }
.wmb-section.tight { padding: clamp(2rem, 4vw, 4rem) 1.5rem; }
.wmb-section.alt { background: var(--surface-2); }
.wmb-section.dark { background: var(--fg); color: var(--bg); }
.wmb-section.primary { background: var(--primary); color: var(--primary-fg); }
.wmb-max { max-width: 1120px; margin: 0 auto; }
.wmb-max-narrow { max-width: 760px; margin: 0 auto; }

.wmb-eyebrow { font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--fg-muted); }
.wmb-h1 { font-family: var(--font-display); font-weight: 500; line-height: 1.05; letter-spacing: -0.02em; font-size: clamp(2.5rem, 1.5rem + 5vw, 5rem); }
.wmb-h1 em { font-style: italic; color: var(--primary); }
.wmb-h2 { font-family: var(--font-display); font-weight: 500; line-height: 1.1; letter-spacing: -0.015em; font-size: clamp(1.875rem, 1.25rem + 2.75vw, 3rem); }
.wmb-h2 em { font-style: italic; color: var(--primary); }
.wmb-h3 { font-family: var(--font-display); font-weight: 500; line-height: 1.2; letter-spacing: -0.01em; font-size: clamp(1.25rem, 1.05rem + 0.85vw, 1.625rem); }
.wmb-lede { font-size: clamp(1.125rem, 1rem + 0.5vw, 1.375rem); color: var(--fg-muted); line-height: 1.5; max-width: 54ch; }
.wmb-copy { font-size: 1.0625rem; color: var(--fg-muted); line-height: 1.65; }
.wmb-copy strong { color: var(--fg); font-weight: 600; }

/* ---- Buttons ---- */
.wmb-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.875rem 1.25rem; border-radius: var(--radius); font-size: 0.9375rem; font-weight: 600; text-decoration: none; cursor: pointer; border: 1px solid transparent; transition: all 150ms var(--ease-soft); min-height: 48px; }
.wmb-btn:hover { text-decoration: none; transform: translateY(-1px); }
.wmb-btn.primary { background: var(--primary); color: var(--primary-fg); }
.wmb-btn.primary:hover { filter: brightness(1.05); }
.wmb-btn.ghost { background: transparent; border-color: var(--border); color: var(--fg); }
.wmb-btn.ghost:hover { background: var(--surface-2); }
.wmb-btn.light { background: var(--bg); color: var(--primary); }
.wmb-btn.outline-light { background: transparent; color: var(--bg); border-color: color-mix(in oklch, var(--bg) 40%, transparent); }

/* ---- Footer ---- */
.wmb-footer { background: var(--fg); color: var(--bg); padding: 4rem 1.5rem 2rem; }
.wmb-footer-top { display: grid; grid-template-columns: 1fr; gap: 2rem; margin-bottom: 3rem; }
@media (min-width: 820px) { .wmb-footer-top { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; } }
.wmb-foot-brand { }
.wmb-foot-brand .lockup { font-family: var(--font-display); font-weight: 500; font-size: 1.75rem; letter-spacing: -0.015em; line-height: 1; margin-bottom: 0.75rem; color: var(--bg); }
.wmb-foot-brand .lockup em { font-style: italic; color: var(--primary); }
.wmb-foot-brand p { font-size: 0.875rem; color: color-mix(in oklch, var(--bg) 70%, transparent); max-width: 40ch; line-height: 1.6; margin-bottom: 1rem; }
.wmb-foot-brand .loc { display: flex; align-items: center; gap: 0.375rem; font-size: 0.75rem; color: color-mix(in oklch, var(--bg) 60%, transparent); }
.wmb-foot-brand .loc svg { width: 12px; height: 12px; stroke: currentColor; stroke-width: 2; fill: none; }
.wmb-foot-col h3, .wmb-foot-col h4 { font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: color-mix(in oklch, var(--bg) 50%, transparent); margin-bottom: 0.875rem; }
.wmb-foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.5rem; }
.wmb-foot-col a { font-size: 0.875rem; color: var(--bg); text-decoration: none; }
.wmb-foot-col a { padding: 0.5rem 0; }
.wmb-foot-col a:hover { color: var(--primary); }
.wmb-footer-bot { padding-top: 2rem; border-top: 1px solid color-mix(in oklch, var(--bg) 15%, transparent); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; font-size: 0.75rem; color: color-mix(in oklch, var(--bg) 50%, transparent); }
.wmb-footer-bot nav { display: flex; gap: 1.25rem; }
.wmb-footer-bot a { color: inherit; text-decoration: none; }
.wmb-footer-bot a:hover { color: var(--bg); }

/* ---- Shared patterns ---- */
.wmb-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.wmb-card.pad { padding: 1.5rem; }
.wmb-card.pad-lg { padding: 2rem; }
.wmb-grid-2 { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.wmb-grid-3 { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.wmb-grid-4 { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 720px) {
  .wmb-grid-2 { grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
  .wmb-grid-3 { grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
  .wmb-grid-4 { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}
@media (min-width: 1000px) {
  .wmb-grid-3 { grid-template-columns: repeat(3, 1fr); }
  .wmb-grid-4 { grid-template-columns: repeat(4, 1fr); }
}

.wmb-pill { display: inline-flex; align-items: center; gap: 0.375rem; padding: 0.375rem 0.75rem; background: var(--surface); border: 1px solid var(--border); border-radius: 999px; font-size: 0.75rem; font-weight: 600; color: var(--fg); }
.wmb-pill .dot { width: 6px; height: 6px; border-radius: 50%; background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,0.2); }

/* Image placeholder (gradient tile used for now) */
.wmb-img { background: linear-gradient(135deg, var(--primary), var(--accent)); border-radius: var(--radius-lg); position: relative; overflow: hidden; }
.wmb-img::after { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle at 30% 35%, rgba(255,255,255,0.3), transparent 55%), radial-gradient(circle at 75% 80%, rgba(0,0,0,0.2), transparent 60%); }
.wmb-img.v2 { background: linear-gradient(160deg, oklch(60% 0.12 45), oklch(45% 0.08 60)); }
.wmb-img.v3 { background: linear-gradient(140deg, oklch(55% 0.1 30), oklch(50% 0.12 10)); }
.wmb-img.v4 { background: linear-gradient(180deg, oklch(50% 0.08 140), oklch(38% 0.06 160)); }
.wmb-img.v5 { background: linear-gradient(170deg, oklch(60% 0.14 220), oklch(42% 0.1 240)); }
