/* ROOMS Mebel — Design Tokens v1
 * Источник палитры: hero_banner_main.png
 * Стиль: premium interior, dark hero + warm accent, editorial typography
 */

:root {
  /* ===== COLORS ===== */
  /* Brand */
  --rooms-orange: #E8541C;        /* primary accent (диван) */
  --rooms-orange-hover: #D14816;
  --rooms-orange-soft: #F7E4D8;

  /* Neutrals — interior tones */
  --rooms-black: #0F0C0A;          /* deepest dark (hero bg) */
  --rooms-dark: #1A1410;           /* dark surfaces */
  --rooms-charcoal: #2A2520;       /* secondary dark */
  --rooms-cream: #F5F0E8;          /* light bg */
  --rooms-sand: #E8DFD1;           /* dividers / cards */
  --rooms-stone: #8B7E6F;          /* muted text */

  /* Semantic */
  --bg: #FFFFFF;
  --bg-soft: var(--rooms-cream);
  --bg-dark: var(--rooms-black);
  --text: #1A1410;
  --text-muted: var(--rooms-stone);
  --text-inverse: #FFFFFF;
  --border: #ECE6DC;
  --accent: var(--rooms-orange);

  /* Status */
  --success: #2D7A3E;
  --danger: #C8341E;
  --warn: #D9A441;

  /* ===== TYPOGRAPHY ===== */
  /* Display — для hero/H1: Manrope или PP Editorial New */
  --font-display: 'Manrope', 'Inter', -apple-system, system-ui, sans-serif;
  --font-body: 'Inter', -apple-system, system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  --fs-hero: clamp(2.5rem, 6vw, 5.5rem);   /* 40-88px */
  --fs-h1:   clamp(2rem, 4vw, 3.5rem);     /* 32-56px */
  --fs-h2:   clamp(1.5rem, 3vw, 2.5rem);   /* 24-40px */
  --fs-h3:   clamp(1.25rem, 2vw, 1.75rem); /* 20-28px */
  --fs-body: 1rem;                          /* 16px */
  --fs-sm:   0.875rem;                      /* 14px */
  --fs-xs:   0.75rem;                       /* 12px */

  --lh-tight: 1.05;
  --lh-snug: 1.25;
  --lh-base: 1.55;

  --tracking-tight: -0.02em;
  --tracking-wide: 0.08em;

  /* ===== SPACING ===== */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 64px;
  --sp-9: 96px;
  --sp-10: 128px;

  --section-y: clamp(64px, 8vw, 128px);
  --container: 1440px;
  --container-narrow: 1180px;
  --gutter: clamp(16px, 3vw, 32px);

  /* ===== RADIUS ===== */
  --r-sm: 6px;
  --r-md: 12px;
  --r-lg: 20px;
  --r-xl: 32px;
  --r-pill: 999px;

  /* ===== SHADOWS ===== */
  --sh-sm: 0 1px 2px rgba(15,12,10,.06);
  --sh-md: 0 4px 16px rgba(15,12,10,.08);
  --sh-lg: 0 12px 40px rgba(15,12,10,.12);
  --sh-glow: 0 8px 32px rgba(232,84,28,.25);

  /* ===== MOTION ===== */
  --ease-out: cubic-bezier(.22,.61,.36,1);
  --ease-in-out: cubic-bezier(.65,0,.35,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --dur-fast: 200ms;
  --dur-base: 360ms;
  --dur-slow: 600ms;

  /* ===== LAYOUT ===== */
  --header-h: 96px;
  --topbar-h: 36px;
  --z-topbar: 60;
  --z-header: 70;
  --z-modal: 90;
  --z-toast: 100;
}

/* ===== BASE ===== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-base);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--gutter); }
.section { padding: var(--section-y) 0; }

/* ===== TYPOGRAPHY UTILS ===== */
.eyebrow {
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
}
.h-display {
  font-family: var(--font-display);
  font-size: var(--fs-hero);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  font-weight: 700;
  margin: 0;
}
h1, .h1 { font-family: var(--font-display); font-size: var(--fs-h1); line-height: var(--lh-tight); letter-spacing: var(--tracking-tight); font-weight: 700; margin: 0 0 var(--sp-5); }
h2, .h2 { font-family: var(--font-display); font-size: var(--fs-h2); line-height: var(--lh-snug); letter-spacing: var(--tracking-tight); font-weight: 700; margin: 0 0 var(--sp-5); }
h3, .h3 { font-size: var(--fs-h3); font-weight: 600; margin: 0 0 var(--sp-4); }

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: 14px 28px;
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: var(--fs-body);
  transition: all var(--dur-base) var(--ease-out);
  will-change: transform;
}
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--rooms-orange-hover); transform: translateY(-2px); box-shadow: var(--sh-glow); }
.btn-dark { background: var(--rooms-black); color: #fff; }
.btn-dark:hover { background: var(--rooms-charcoal); transform: translateY(-2px); }
.btn-outline { border: 1.5px solid currentColor; color: var(--text); background: transparent; }
.btn-outline:hover { background: var(--text); color: #fff; }
.btn-ghost { color: var(--text); }
.btn-ghost:hover { background: var(--bg-soft); }
.btn-lg { padding: 18px 36px; font-size: 1.0625rem; }

/* ===== CARDS ===== */
.card {
  background: #fff;
  border-radius: var(--r-md);
  overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
