/* ── Atelier Lyra - brand layer ─────────────────────────────────────────────
   Warm, artisanal, editorial. Layered on top of Tailwind Play CDN. */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=DM+Sans:wght@400;500;600&display=swap');

:root {
  --paper: #f7f0e4;
  --paper-deep: #efe4d1;
  --ink: #2b2118;
  --ink-soft: #5c4f40;
  --amber: #c9772f;
  --amber-deep: #a85f23;
  --ember: #e29a45;
  --moss: #6b7253;
  --line: #ddcdb2;
  --card: #fffaf0;
}

* { -webkit-font-smoothing: antialiased; }

html { scroll-behavior: smooth; }

body {
  background-color: var(--paper);
  color: var(--ink);
  font-family: 'DM Sans', ui-sans-serif, system-ui, sans-serif;
  /* warm grain + soft radial glow */
  background-image:
    radial-gradient(1200px 600px at 75% -10%, rgba(226,154,69,0.16), transparent 60%),
    radial-gradient(900px 500px at 0% 100%, rgba(107,114,83,0.10), transparent 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  background-attachment: fixed;
}

.font-display { font-family: 'Fraunces', Georgia, serif; }
.font-body { font-family: 'DM Sans', sans-serif; }

h1, h2, h3, .display { font-family: 'Fraunces', Georgia, serif; letter-spacing: -0.01em; }

a { color: inherit; }

/* ── Decorative ── */
.eyebrow {
  font-family: 'DM Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--amber-deep);
}

.rule { height: 1px; background: linear-gradient(90deg, transparent, var(--line), transparent); }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  font-weight: 600; font-size: .95rem; line-height: 1;
  padding: .9rem 1.5rem; border-radius: 999px;
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background-color .25s, color .25s;
  cursor: pointer; border: 1px solid transparent;
}
.btn-primary {
  background: var(--ink); color: var(--paper);
  box-shadow: 0 10px 24px -12px rgba(43,33,24,.6);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 30px -12px rgba(43,33,24,.55); }
.btn-amber { background: var(--amber); color: #fff; box-shadow: 0 10px 26px -12px rgba(201,119,47,.7); }
.btn-amber:hover { transform: translateY(-2px); background: var(--amber-deep); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { background: var(--card); border-color: var(--amber); }
.btn:disabled { opacity: .45; cursor: not-allowed; transform: none !important; box-shadow: none; }

/* ── Product card ── */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, border-color .35s;
  display: flex; flex-direction: column;
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 50px -28px rgba(43,33,24,.45);
  border-color: var(--ember);
}
.card .ph {
  aspect-ratio: 4/5; overflow: hidden; position: relative;
  background: linear-gradient(160deg, var(--paper-deep), #e3d2b6);
}
.card .ph img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s cubic-bezier(.2,.8,.2,1); display: block; }
.card:hover .ph img { transform: scale(1.05); }
.card .ph img.is-placeholder { object-fit: contain; padding: 14%; opacity: .9; }

/* ── Stock badge ── */
.stock { font-size: .78rem; font-weight: 600; display: inline-flex; align-items: center; gap: .4rem; }
.stock::before { content: ''; width: 7px; height: 7px; border-radius: 999px; background: currentColor; }
.stock.ok  { color: var(--moss); }
.stock.low { color: var(--amber-deep); }
.stock.out { color: #b23a2e; }

/* ── Cart count badge ── */
.cart-badge {
  min-width: 1.25rem; height: 1.25rem; padding: 0 .35rem;
  border-radius: 999px; background: var(--amber); color: #fff;
  font-size: .7rem; font-weight: 700; display: inline-flex; align-items: center; justify-content: center;
  line-height: 1;
}
.cart-badge.is-empty { display: none; }

/* ── Reveal on load ── */
@keyframes rise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
.reveal { animation: rise .7s cubic-bezier(.2,.8,.2,1) both; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .card:hover { transform: none; }
}

/* focus visibility */
a:focus-visible, button:focus-visible, input:focus-visible {
  outline: 2px solid var(--amber); outline-offset: 3px; border-radius: 6px;
}

::selection { background: rgba(201,119,47,.25); }
