/* printftoc.com — Luxury Design System */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  /* Core palette */
  --ink: #0e0e0e;
  --ink-soft: #2a2826;
  --cream: #f7f4ee;
  --cream-deep: #ede8df;
  --white: #fffcf8;
  --gold: #b8956a;
  --gold-light: #d4bc94;
  --gold-dark: #96784f;
  --navy: #152238;
  --navy-soft: #1e3050;
  --muted: #6e6860;
  --muted-light: #9a948c;
  --border: rgba(14, 14, 14, 0.09);
  --border-strong: rgba(14, 14, 14, 0.16);

  /* Semantic aliases (backward compat for product pages) */
  --bg: var(--cream);
  --text: var(--ink);
  --card: var(--white);
  --accent: var(--gold);
  --accent-dark: var(--gold-dark);
  --accent-soft: rgba(184, 149, 106, 0.12);
  --teal: var(--gold);
  --teal-dark: var(--gold-dark);
  --red: #9e3a3a;

  /* Typography */
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-body: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;

  /* Layout */
  --radius: 2px;
  --radius-lg: 4px;
  --max-width: 1240px;
  --header-h: 72px;

  /* Header typography */
  --logo-size: 34px;
  --logo-weight: 700;
  --logo-sub-size: 10px;
  --logo-sub-weight: 500;
  --nav-link-size: 12px;
  --nav-link-weight: 600;
  --nav-link-spacing: 0.06em;
  --nav-link-color: var(--ink-soft);
  --nav-link-active: var(--ink);
  --lang-btn-size: 11px;
  --lang-btn-weight: 600;

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --duration: 0.35s;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--cream);
  color: var(--ink);
  line-height: 1.65;
  font-weight: 400;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; display: block; }

a { color: inherit; }

::selection {
  background: var(--gold-light);
  color: var(--ink);
}

/* Typography utilities */
.display-xl {
  font-family: var(--font-display);
  font-size: clamp(2.75rem, 6vw, 4.25rem);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.02em;
}

.display-lg {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: -0.01em;
}

.eyebrow {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-dark);
}

.label-caps {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Buttons */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 28px;
  background: var(--ink);
  color: var(--cream);
  border: 1px solid var(--ink);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--duration) var(--ease), color var(--duration) var(--ease), border-color var(--duration) var(--ease);
}

.btn-primary:hover {
  background: transparent;
  color: var(--ink);
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 26px;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--border-strong);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: border-color var(--duration) var(--ease), color var(--duration) var(--ease);
}

.btn-outline:hover {
  border-color: var(--gold);
  color: var(--gold-dark);
}

.btn-outline-light {
  color: var(--cream);
  border-color: rgba(247, 244, 238, 0.35);
}

.btn-outline-light:hover {
  border-color: var(--gold-light);
  color: var(--gold-light);
}

/* Grain overlay utility */
.grain::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
