/* tokens.css */
@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap");

:root {
  --mm-font-sans: "Manrope", "Avenir Next", "Segoe UI", sans-serif;
  --mm-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  --mm-space-0: 0;
  --mm-space-1: 0.25rem;
  --mm-space-2: 0.5rem;
  --mm-space-3: 0.75rem;
  --mm-space-4: 1rem;
  --mm-space-5: 1.25rem;
  --mm-space-6: 1.5rem;
  --mm-space-8: 2rem;
  --mm-space-10: 2.5rem;
  --mm-space-12: 3rem;

  --mm-radius-xs: 0.4rem;
  --mm-radius-sm: 0.6rem;
  --mm-radius-md: 0.8rem;
  --mm-radius-lg: 1rem;
  --mm-radius-xl: 1.25rem;
  --mm-radius-pill: 999px;

  --mm-shadow-soft: 0 10px 24px rgba(15, 23, 42, 0.1);
  --mm-shadow-strong: 0 20px 48px rgba(15, 23, 42, 0.16);

  --mm-z-base: 1;
  --mm-z-sticky: 40;
  --mm-z-popover: 50;
  --mm-z-modal: 60;

  --mm-color-neutral-0: #ffffff;
  --mm-color-neutral-50: #fffaf2;
  --mm-color-neutral-100: #f9efe2;
  --mm-color-neutral-200: #eadfce;
  --mm-color-neutral-300: #d2c1ac;
  --mm-color-neutral-500: #6b5b4b;
  --mm-color-neutral-700: #3b2b1f;
  --mm-color-neutral-900: #1f1711;

  --mm-color-success: #15803d;
  --mm-color-warning: #b45309;
  --mm-color-danger: #b91c1c;
  --mm-color-info: #0369a1;
}

/* themes.css */
:root,
html[data-mm-theme="light"] {
  color-scheme: light;
  --mm-color-bg: var(--mm-color-neutral-50);
  --mm-color-bg-elevated: var(--mm-color-neutral-0);
  --mm-color-bg-muted: #fff5e8;
  --mm-color-text: var(--mm-color-neutral-900);
  --mm-color-text-muted: var(--mm-color-neutral-500);
  --mm-color-border: var(--mm-color-neutral-200);
  --mm-color-accent: #d97706;
  --mm-color-accent-hover: #b45309;
  --mm-color-accent-soft: rgba(217, 119, 6, 0.14);
}

html[data-mm-theme="dark"] {
  color-scheme: dark;
  --mm-color-bg: #0e0a07;
  --mm-color-bg-elevated: #1b1510;
  --mm-color-bg-muted: #2a2018;
  --mm-color-text: #f8efe1;
  --mm-color-text-muted: #d2c1ac;
  --mm-color-border: #4b3a2b;
  --mm-color-accent: #f59e0b;
  --mm-color-accent-hover: #fbbf24;
  --mm-color-accent-soft: rgba(245, 158, 11, 0.24);
}

/* products.css */
html[data-mm-product="review"] {
  --mm-color-accent: #0369a1;
  --mm-color-accent-hover: #075985;
  --mm-color-accent-soft: rgba(3, 105, 161, 0.18);
}

html[data-mm-product="portal"] {
  --mm-color-accent: #0c4a6e;
  --mm-color-accent-hover: #075985;
  --mm-color-accent-soft: rgba(3, 105, 161, 0.18);
}

html[data-mm-product="backup"] {
  --mm-color-accent: #c2410c;
  --mm-color-accent-hover: #9a3412;
  --mm-color-accent-soft: rgba(194, 65, 12, 0.18);
}

html[data-mm-product="index"] {
  --mm-color-accent: #0f766e;
  --mm-color-accent-hover: #115e59;
  --mm-color-accent-soft: rgba(15, 118, 110, 0.18);
}

html[data-mm-product="display"] {
  --mm-color-accent: #be123c;
  --mm-color-accent-hover: #9f1239;
  --mm-color-accent-soft: rgba(190, 18, 60, 0.18);
}

/* layout.css */
.mm-shell {
  min-height: 100vh;
  background:
    radial-gradient(circle at 92% 0%, var(--mm-color-accent-soft), transparent 32%),
    radial-gradient(circle at 0% 95%, color-mix(in srgb, var(--mm-color-text) 8%, transparent), transparent 35%),
    var(--mm-color-bg);
  color: var(--mm-color-text);
  font-family: var(--mm-font-sans);
}

.mm-header {
  align-items: center;
  backdrop-filter: blur(12px);
  background: color-mix(in srgb, var(--mm-color-bg) 88%, var(--mm-color-bg-elevated));
  border-bottom: 1px solid var(--mm-color-border);
  display: flex;
  flex-wrap: wrap;
  gap: var(--mm-space-4);
  justify-content: space-between;
  padding: var(--mm-space-4) var(--mm-space-6);
  position: sticky;
  top: 0;
  z-index: var(--mm-z-sticky);
}

.mm-main {
  width: min(1100px, 92vw);
  margin: 0 auto;
  padding: var(--mm-space-6) 0 var(--mm-space-10);
}

.mm-container {
  width: min(1100px, 92vw);
  margin: 0 auto;
}

.mm-stack-2 {
  display: grid;
  gap: var(--mm-space-2);
}

.mm-stack-3 {
  display: grid;
  gap: var(--mm-space-3);
}

.mm-stack-4 {
  display: grid;
  gap: var(--mm-space-4);
}

.mm-stack-6 {
  display: grid;
  gap: var(--mm-space-6);
}

.mm-grid-2 {
  display: grid;
  gap: var(--mm-space-4);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mm-grid-3 {
  display: grid;
  gap: var(--mm-space-4);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mm-section {
  background: var(--mm-color-bg-elevated);
  border: 1px solid var(--mm-color-border);
  border-radius: var(--mm-radius-xl);
  padding: clamp(var(--mm-space-5), 2.5vw, var(--mm-space-8));
}

.mm-section-muted {
  background: var(--mm-color-bg-muted);
  border: 1px solid var(--mm-color-border);
  border-radius: var(--mm-radius-xl);
  padding: clamp(var(--mm-space-5), 2.5vw, var(--mm-space-8));
}

@media (max-width: 900px) {
  .mm-grid-2,
  .mm-grid-3 {
    grid-template-columns: 1fr;
  }

  .mm-header {
    padding-inline: var(--mm-space-4);
  }
}

/* components.css */
.mm-link {
  color: inherit;
  text-decoration: none;
}

.mm-link:hover {
  color: var(--mm-color-accent);
}

.mm-btn {
  align-items: center;
  border: 1px solid transparent;
  border-radius: var(--mm-radius-pill);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--mm-font-sans);
  font-size: 0.9rem;
  font-weight: 700;
  gap: var(--mm-space-2);
  justify-content: center;
  line-height: 1;
  padding: 0.72rem 1.1rem;
  text-decoration: none;
  transition: transform 160ms ease, box-shadow 160ms ease, background-color 160ms ease, color 160ms ease, border-color 160ms ease;
}

.mm-btn:disabled,
.mm-btn[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.55;
}

.mm-btn-primary {
  background: var(--mm-color-accent);
  color: var(--mm-color-neutral-0);
}

.mm-btn-primary:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--mm-color-accent-hover);
  transform: translateY(-1px);
  box-shadow: var(--mm-shadow-soft);
}

.mm-btn-secondary {
  background: var(--mm-color-bg-elevated);
  border-color: var(--mm-color-border);
  color: var(--mm-color-text);
}

.mm-btn-secondary:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--mm-color-bg-muted);
}

.mm-btn-danger {
  background: color-mix(in srgb, var(--mm-color-danger) 14%, var(--mm-color-bg-elevated));
  border-color: color-mix(in srgb, var(--mm-color-danger) 38%, var(--mm-color-border));
  color: var(--mm-color-danger);
}

.mm-btn-danger:hover:not(:disabled):not([aria-disabled="true"]) {
  background: color-mix(in srgb, var(--mm-color-danger) 20%, var(--mm-color-bg-elevated));
}

.mm-card {
  background: var(--mm-color-bg-elevated);
  border: 1px solid var(--mm-color-border);
  border-radius: var(--mm-radius-lg);
  padding: var(--mm-space-4);
}

.mm-card-elevated {
  background: var(--mm-color-bg-elevated);
  border: 1px solid var(--mm-color-border);
  border-radius: var(--mm-radius-lg);
  box-shadow: var(--mm-shadow-soft);
  padding: var(--mm-space-4);
}

.mm-input,
.mm-select,
.mm-textarea {
  width: 100%;
  border-radius: var(--mm-radius-sm);
  border: 1px solid var(--mm-color-border);
  background: var(--mm-color-bg-elevated);
  color: var(--mm-color-text);
  font: inherit;
  padding: 0.65rem 0.75rem;
}

.mm-input:focus,
.mm-select:focus,
.mm-textarea:focus {
  border-color: var(--mm-color-accent);
  box-shadow: 0 0 0 3px var(--mm-color-accent-soft);
  outline: none;
}

.mm-tabs {
  display: inline-flex;
  gap: var(--mm-space-1);
  border: 1px solid var(--mm-color-border);
  background: var(--mm-color-bg-elevated);
  border-radius: var(--mm-radius-pill);
  padding: var(--mm-space-1);
}

.mm-tab {
  border: 0;
  border-radius: var(--mm-radius-pill);
  background: transparent;
  color: var(--mm-color-text-muted);
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 700;
  padding: 0.45rem 0.78rem;
}

.mm-tab-active {
  background: var(--mm-color-accent-soft);
  color: var(--mm-color-accent);
}

.mm-badge {
  border-radius: var(--mm-radius-pill);
  border: 1px solid var(--mm-color-border);
  color: var(--mm-color-text-muted);
  display: inline-flex;
  font-family: var(--mm-font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.24rem 0.45rem;
}

.mm-alert {
  border-radius: var(--mm-radius-md);
  border: 1px solid transparent;
  font-size: 0.84rem;
  font-weight: 600;
  padding: var(--mm-space-3) var(--mm-space-4);
}

.mm-alert-info {
  background: color-mix(in srgb, var(--mm-color-info) 12%, var(--mm-color-bg-elevated));
  border-color: color-mix(in srgb, var(--mm-color-info) 32%, var(--mm-color-border));
  color: var(--mm-color-info);
}

.mm-alert-success {
  background: color-mix(in srgb, var(--mm-color-success) 12%, var(--mm-color-bg-elevated));
  border-color: color-mix(in srgb, var(--mm-color-success) 32%, var(--mm-color-border));
  color: var(--mm-color-success);
}

.mm-alert-warning {
  background: color-mix(in srgb, var(--mm-color-warning) 12%, var(--mm-color-bg-elevated));
  border-color: color-mix(in srgb, var(--mm-color-warning) 32%, var(--mm-color-border));
  color: var(--mm-color-warning);
}

.mm-alert-danger {
  background: color-mix(in srgb, var(--mm-color-danger) 12%, var(--mm-color-bg-elevated));
  border-color: color-mix(in srgb, var(--mm-color-danger) 32%, var(--mm-color-border));
  color: var(--mm-color-danger);
}

