/* MangoMelon Studio — design tokens (from official design system) */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Nunito:wght@400;500;600;700;800&family=Caveat+Brush&display=swap');

:root {
  --mm-cream-50:  #FBF8F3;
  --mm-cream-100: #F5F3F0;
  --mm-cream-200: #EDE7DD;
  --mm-sand-300:  #D9CFC0;
  --mm-sand-400:  #B5A394;
  --mm-taupe-500: #A8998A;
  --mm-taupe-600: #9B8B7A;
  --mm-taupe-700: #7E6F60;
  --mm-ink-800:   #5D5A56;
  --mm-ink-900:   #3A3733;

  --mm-mango-300: #FFD9A8;
  --mm-mango-500: #F2A65A;
  --mm-mango-600: #D9874A;

  --mm-melon-300: #DCEBC0;
  --mm-melon-500: #B6CF8E;
  --mm-melon-600: #8FB069;

  --mm-blossom-300: #F8D7DC;
  --mm-blossom-500: #E8A3AF;
  --mm-blossom-600: #C77E8A;

  --border: rgba(155, 139, 122, 0.18);
  --border-strong: rgba(155, 139, 122, 0.32);

  --font-display: 'Fraunces', 'DM Serif Display', Georgia, serif;
  --font-body:    'Nunito', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-hand:    'Caveat Brush', 'Comic Sans MS', cursive;

  --shadow-2: 0 4px 20px rgba(93, 90, 86, 0.10);
  --shadow-3: 0 8px 30px rgba(93, 90, 86, 0.12);
  --shadow-4: 0 12px 40px rgba(93, 90, 86, 0.18);

  --ease-soft: cubic-bezier(.4, 0, .2, 1);
}

html, body {
  background:
    radial-gradient(circle at 10% 5%, rgba(220, 235, 192, 0.45), transparent 32%),
    radial-gradient(circle at 92% 8%, rgba(248, 215, 220, 0.40), transparent 30%),
    linear-gradient(180deg, #FBF8F3 0%, #F5F3F0 100%);
  color: var(--mm-ink-800);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 { font-family: var(--font-display); color: var(--mm-ink-900); letter-spacing: -0.015em; }
h2 { color: var(--mm-taupe-600); }
.mm-mascot { font-family: var(--font-hand); letter-spacing: 0.02em; }

.mm-caption {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mm-taupe-600);
}

.mm-card {
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow-2);
  transition: transform 240ms var(--ease-soft), box-shadow 240ms var(--ease-soft);
}
.mm-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-3); }

.mm-btn-primary {
  background: var(--mm-taupe-600); color: #fff;
  padding: 14px 26px; border-radius: 14px;
  font-weight: 700; font-size: 15px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: background 200ms var(--ease-soft), transform 200ms var(--ease-soft);
}
.mm-btn-primary:hover { background: var(--mm-taupe-500); transform: translateY(-2px); }

.mm-btn-ghost {
  background: #fff; color: var(--mm-taupe-700);
  padding: 14px 26px; border-radius: 14px;
  font-weight: 700; font-size: 15px;
  border: 1px solid var(--border-strong);
  display: inline-flex; align-items: center; gap: 8px;
  transition: background 200ms var(--ease-soft), transform 200ms var(--ease-soft);
}
.mm-btn-ghost:hover { background: var(--mm-cream-100); transform: translateY(-2px); }

.mm-link { color: var(--mm-taupe-600); font-weight: 600; transition: color 150ms; }
.mm-link:hover { color: var(--mm-taupe-700); }

.mm-nav {
  background: rgba(251, 248, 243, 0.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
