/* ============================================================
   Winnrs creator sites — global styles
   Token system + 3 theme identities, selected via <html data-theme>.
   Each theme is a distinct identity (palette + display face + accent),
   so the six sites don't read as one farmed template.
   ============================================================ */

:root {
  --maxw: 1120px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 14px;
  --radius-sm: 8px;
  --line: rgba(0, 0, 0, 0.10);

  /* defaults (warm) — overridden per theme below */
  --bg: #f4ece6;
  --bg-elev: #fbf6f2;
  --ink: #2a221f;
  --ink-soft: #6f635c;
  --accent: #9c5d63;
  --accent-ink: #fff;

  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Instrument Sans", system-ui, sans-serif;
  --display-weight: 560;
  --display-tracking: -0.01em;
}

/* ---- WARM: soft editorial, dusty rose accent ---- */
[data-theme="warm"] {
  --bg: #f4ece6;
  --bg-elev: #fbf6f2;
  --ink: #2a221f;
  --ink-soft: #6f635c;
  --accent: #9c5d63;
  --accent-ink: #ffffff;
  --line: rgba(42, 34, 31, 0.12);
  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Instrument Sans", system-ui, sans-serif;
  --display-weight: 560;
  --display-tracking: -0.01em;
}

/* ---- NOIR: warm charcoal, champagne accent ---- */
[data-theme="noir"] {
  --bg: #18151a;
  --bg-elev: #211d24;
  --ink: #ece4dd;
  --ink-soft: #9a9089;
  --accent: #c9a86a;
  --accent-ink: #18151a;
  --line: rgba(236, 228, 221, 0.14);
  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-body: "Inter", system-ui, sans-serif;
  --display-weight: 600;
  --display-tracking: 0;
}

/* ---- FRESH: cool light, periwinkle accent, modern grotesk ---- */
[data-theme="fresh"] {
  --bg: #f5f5f8;
  --bg-elev: #ffffff;
  --ink: #1e2330;
  --ink-soft: #6a7184;
  --accent: #5b67d6;
  --accent-ink: #ffffff;
  --line: rgba(30, 35, 48, 0.10);
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;
  --display-weight: 600;
  --display-tracking: -0.02em;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

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

a { color: inherit; }

.container {
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.eyebrow {
  font-family: var(--font-body);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin: 0 0 0.9rem;
}

/* ---------- Hero ---------- */
.hero { padding: clamp(28px, 6vw, 72px) 0 clamp(36px, 7vw, 88px); }

.hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
}

.hero__media {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: var(--bg-elev);
}

.hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero__name {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
  line-height: 0.98;
  font-size: clamp(3rem, 9vw, 5.6rem);
  margin: 0 0 1.1rem;
}

.hero__tagline {
  font-size: clamp(1.05rem, 2.2vw, 1.3rem);
  color: var(--ink-soft);
  margin: 0 0 2rem;
  max-width: 30ch;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  padding: 0.95em 1.6em;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 0.18s ease, opacity 0.18s ease, background 0.18s ease;
}

.btn--primary { background: var(--accent); color: var(--accent-ink); }
.btn--primary:hover { transform: translateY(-2px); opacity: 0.94; }

.btn__arrow { transition: transform 0.18s ease; }
.btn--primary:hover .btn__arrow { transform: translateX(3px); }

/* ---------- About ---------- */
.about { padding: clamp(36px, 7vw, 84px) 0; border-top: 1px solid var(--line); }

.about__text {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.4rem, 3.4vw, 2.1rem);
  line-height: 1.42;
  letter-spacing: var(--display-tracking);
  max-width: 24ch;
  margin: 0;
}

[data-theme="fresh"] .about__text { font-weight: 500; }

/* ---------- Gallery ---------- */
.gallery { padding: clamp(28px, 6vw, 72px) 0; }

.gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 2vw, 22px);
}

.gallery__item {
  border-radius: var(--radius-sm);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: var(--bg-elev);
}

.gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.2, 0.7, 0.2, 1);
}

.gallery__item:hover img { transform: scale(1.045); }

/* ---------- Socials ---------- */
.socials { padding: clamp(36px, 7vw, 84px) 0; border-top: 1px solid var(--line); }

.socials__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.social {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 1.05em 1.3em;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  text-decoration: none;
  background: var(--bg-elev);
  transition: border-color 0.18s ease, transform 0.18s ease;
}

.social:hover { border-color: var(--accent); transform: translateY(-2px); }

.social__name { font-weight: 600; }
.social__handle { color: var(--ink-soft); font-size: 0.92rem; }

/* ---------- Closing CTA ---------- */
.closing {
  padding: clamp(48px, 9vw, 120px) 0;
  border-top: 1px solid var(--line);
  text-align: center;
}

.closing__head {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
  font-size: clamp(2rem, 6vw, 3.4rem);
  line-height: 1.05;
  margin: 0 0 1.6rem;
}

/* ---------- Footer ---------- */
.site-footer {
  padding: 2.6rem 0;
  border-top: 1px solid var(--line);
  color: var(--ink-soft);
  font-size: 0.85rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.6rem;
}

/* ---------- Motion: reveal on load ---------- */
.reveal {
  opacity: 0;
  transform: translateY(14px);
  animation: reveal 0.7s cubic-bezier(0.2, 0.7, 0.2, 1) forwards;
}
.reveal--2 { animation-delay: 0.08s; }
.reveal--3 { animation-delay: 0.16s; }

@keyframes reveal {
  to { opacity: 1; transform: none; }
}

/* ---------- Focus + reduced motion (quality floor) ---------- */
a:focus-visible,
.btn:focus-visible,
.social:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* ---------- Responsive ---------- */
@media (max-width: 820px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__media { aspect-ratio: 4 / 5; max-height: 64vh; order: -1; }
  .gallery__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 520px) {
  body { font-size: 16px; }
  .gallery__grid { grid-template-columns: 1fr; }
}
