/* ============================================================
   mbw-global.css
   Design tokens -> Reset -> Base -> Typography -> Layout -> Buttons
   This is the FIRST stylesheet loaded. All other theme CSS
   inherits from the :root variables defined here.
   ============================================================ */


/* ---- DESIGN TOKENS --------------------------------------- */
:root {
  /* Palette */
  --mbw-bg:           #F7F5F1;
  --mbw-surface:      #FFFFFF;
  --mbw-ink:          #0F0F0F;
  --mbw-ink-soft:     #4A4A4A;
  --mbw-ink-mute:     #6B6B6B;
  --mbw-line:         #E5E0D5;
  --mbw-accent:       #2F4F4F;
  --mbw-accent-soft:  #DDE5E1;
  --mbw-gold:         #B89968;
  --mbw-gold-dark:    #7E6334;
  --mbw-gold-light:   #D4B47C;

  /* Nav */
  --mbw-nav-bg:       #1A1A1A;
  --mbw-nav-border:   rgba(255,255,255,.12);

  /* Typography */
  --mbw-font-display: 'Fraunces', Georgia, serif;
  --mbw-font-body:    'Inter', -apple-system, sans-serif;
  --mbw-font-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* Spacing */
  --mbw-space-xs:   8px;
  --mbw-space-sm:   16px;
  --mbw-space-md:   32px;
  --mbw-space-lg:   64px;
  --mbw-space-xl:   96px;
  --mbw-space-2xl:  120px;

  /* Layout */
  --mbw-max-w:       1200px;
  --mbw-max-w-wide:  1440px;

  /* Radius */
  --mbw-radius-sm:   4px;
  --mbw-radius-md:   8px;
  --mbw-radius-pill: 999px;

  /* Transitions */
  --mbw-ease: all 0.2s ease;
}


/* ---- RESET ------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 72px; }
body {
  background: var(--mbw-bg);
  color: var(--mbw-ink);
  font-family: var(--mbw-font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }


/* ---- ACCESSIBILITY --------------------------------------- */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 9999;
  background: var(--mbw-ink); color: var(--mbw-bg);
  padding: 12px 20px; border-radius: 0 0 4px 0; font-weight: 600;
}
.skip-link:focus { left: 0; }
*:focus-visible {
  outline: 2px solid var(--mbw-gold);
  outline-offset: 3px;
  border-radius: 2px;
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}


/* ---- TYPE SCALE ------------------------------------------ */
h1, h2, h3, h4 {
  font-family: var(--mbw-font-display);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
h1 { font-size: clamp(48px, 7vw, 96px); }
h2 { font-size: clamp(28px, 4vw, 56px); }
h3 { font-size: clamp(20px, 2vw, 28px); font-weight: 500; }
h4 { font-size: 18px; font-weight: 500; }

.mbw-eyebrow {
  font-family: var(--mbw-font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mbw-ink-mute);
  font-weight: 500;
  display: inline-block;
}


/* ---- LAYOUT ---------------------------------------------- */
.mbw-container {
  max-width: var(--mbw-max-w);
  margin: 0 auto;
  padding: 0 32px;
}
.mbw-container-wide {
  max-width: var(--mbw-max-w-wide);
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 640px) {
  .mbw-container, .mbw-container-wide { padding: 0 20px; }
}

.mbw-section        { padding: 96px 0; }
.mbw-section-sm     { padding: 64px 0; }
.mbw-section-dark   { background: var(--mbw-ink); color: var(--mbw-bg); }
.mbw-section-surface { background: var(--mbw-surface); }
.mbw-section-border {
  border-top: 1px solid var(--mbw-line);
  border-bottom: 1px solid var(--mbw-line);
}


/* ---- BUTTONS --------------------------------------------- */
.mbw-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  border-radius: var(--mbw-radius-pill);
  font-family: var(--mbw-font-body);
  font-size: 15px;
  font-weight: 500;
  transition: var(--mbw-ease);
  cursor: pointer;
  text-decoration: none;
  border: none;
}
.mbw-btn .arrow { display: inline-block; transition: transform 0.2s; }
.mbw-btn:hover .arrow { transform: translateX(4px); }

.mbw-btn-gold {
  background: var(--mbw-gold);
  color: var(--mbw-ink);
  font-weight: 700;
  box-shadow: 0 4px 24px rgba(184,153,104,0.25);
}
.mbw-btn-gold:hover { background: #fff; transform: translateY(-1px); }

.mbw-btn-ink { background: var(--mbw-ink); color: var(--mbw-bg); font-weight: 600; }
.mbw-btn-ink:hover { background: var(--mbw-accent); }

.mbw-btn-ghost {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.3);
}
.mbw-btn-ghost:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.5); }

.mbw-btn-line {
  background: transparent;
  color: var(--mbw-ink);
  border: 1px solid var(--mbw-ink);
}
.mbw-btn-line:hover { background: var(--mbw-ink); color: var(--mbw-bg); }

.mbw-btn-line-light {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.35);
}
.mbw-btn-line-light:hover { background: rgba(255,255,255,0.1); }
