/* ============================================================
   Fleurs de France — Jardin Volumétrique
   A 3D Gaussian-splat garden behind dark editorial typography
   ============================================================ */

:root {
  --bg:      #06050a;
  --ink:     #f4eee4;
  --muted:   rgba(244, 238, 228, 0.56);
  --faint:   rgba(244, 238, 228, 0.12);
  --line:    rgba(244, 238, 228, 0.14);
  --gold:    #cda85b;
  --gold-2:  #e7cf9b;
  --accent:  #f4b9c8;

  --serif: "Playfair Display", Georgia, serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --gut: clamp(20px, 5vw, 90px);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  line-height: 1.5;
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
#smooth-wrapper { overflow: hidden; position: relative; z-index: 1; }
img { display: block; width: 100%; height: 100%; object-fit: cover; }
a { color: inherit; text-decoration: none; }
em { font-style: italic; }
::selection { background: var(--gold); color: #14110a; }

.eyebrow, .kicker {
  font-size: 0.72rem; font-weight: 500; letter-spacing: 0.34em; text-transform: uppercase;
  color: var(--muted); display: inline-flex; align-items: center; gap: 0.7em;
}
.eyebrow__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 12px var(--gold); }
.kicker { color: var(--gold-2); }

/* ---------------- atmosphere ---------------- */
.grain {
  position: fixed; inset: -50%; width: 200%; height: 200%;
  pointer-events: none; z-index: 9000; opacity: 0.04;
  background-image: 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.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: grain 7s steps(6) infinite; mix-blend-mode: overlay;
}
@keyframes grain { 0%,100%{transform:translate(0,0)} 30%{transform:translate(3%,-2%)} 50%{transform:translate(-2%,4%)} 70%{transform:translate(4%,2%)} }
.vignette {
  position: fixed; inset: 0; pointer-events: none; z-index: 8000;
  background:
    radial-gradient(130% 100% at 50% 0%, transparent 58%, rgba(0,0,0,0.5) 100%),
    radial-gradient(120% 120% at 50% 100%, transparent 60%, rgba(0,0,0,0.55) 100%);
}
.glow {
  position: fixed; z-index: 1; pointer-events: none; top: 0; left: 0;
  width: 60vmax; height: 60vmax;
  transform: translate3d(calc(var(--mx,720)*1px - 30vmax), calc(var(--my,360)*1px - 30vmax), 0);
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 20%, transparent) 0%, transparent 62%);
  opacity: 0.4; filter: blur(20px); will-change: transform;
}

/* ---------------- the 3D garden canvas ---------------- */
#garden {
  position: fixed; inset: 0; width: 100%; height: 100%;
  z-index: 0; pointer-events: none;
  opacity: 0; transition: opacity 1.6s var(--ease);
}
body.has-3d #garden { opacity: 1; }

/* drag-to-rotate affordance (mouse) */
body.has-3d { cursor: grab; }
body.has-3d a, body.has-3d button { cursor: pointer; }
body.grabbing-3d, body.grabbing-3d * { cursor: grabbing !important; user-select: none; }

/* ---------------- nav ---------------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 7000;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(16px, 2.4vw, 30px) var(--gut); mix-blend-mode: difference;
}
.nav__brand { display: inline-flex; align-items: center; gap: 0.6em; }
.nav__mark { color: #fff; font-size: 1.1rem; }
.nav__word { font-family: var(--serif); font-size: 1.16rem; font-weight: 500; color: #fff; }
.nav__links { display: flex; align-items: center; gap: clamp(16px, 2.5vw, 38px); }
.nav__links a { font-size: 0.74rem; letter-spacing: 0.22em; text-transform: uppercase; color: #fff; opacity: 0.85; transition: opacity .3s; }
.nav__links a:hover { opacity: 1; }
.nav__cta { border: 1px solid rgba(255,255,255,0.5); padding: 0.6em 1.1em; border-radius: 100px; }

/* live badge */
.live-badge {
  position: fixed; left: var(--gut); bottom: clamp(16px, 3vh, 28px); z-index: 6000;
  font-size: 0.64rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted);
  display: inline-flex; align-items: center; gap: 0.7em;
  padding: 0.6em 1em; border: 1px solid var(--line); border-radius: 100px;
  background: rgba(8,7,12,0.4); backdrop-filter: blur(8px); mix-blend-mode: normal;
}
.live-badge::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%; background: #6ee787;
  box-shadow: 0 0 10px #6ee787; animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.3} }

/* ---------------- buttons ---------------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.7em;
  font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500;
  padding: 1em 1.6em; border-radius: 100px; border: 1px solid var(--line);
  background: rgba(244,238,228,0.03); color: var(--ink); backdrop-filter: blur(6px);
  transition: border-color .4s var(--ease), background .4s var(--ease), transform .4s var(--ease);
}
.btn svg { transition: transform .4s var(--ease); }
.btn:hover { border-color: var(--gold); background: rgba(205,168,91,0.08); transform: translateY(-2px); }
.btn:hover svg { transform: translateX(5px); }
.btn--xl { font-size: 0.9rem; padding: 1.25em 2.2em; border-color: var(--gold); background: linear-gradient(180deg, rgba(205,168,91,0.16), rgba(205,168,91,0.04)); }

/* ===========================================================
   GARDEN ROWS
   =========================================================== */
.garden { position: relative; }
.row {
  position: relative; min-height: 100svh;
  display: flex; align-items: center; padding: 12vh var(--gut);
}

/* hero row */
.row--hero { }
.row--hero .row__text { position: relative; z-index: 2; max-width: 600px; }
.eyebrow + .title, .title { margin-top: 0; }
.row .eyebrow { margin-bottom: 1.6em; }
.title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(3.6rem, 11vw, 9.5rem); line-height: 0.92; letter-spacing: -0.02em;
}
.title .line { display: block; overflow: hidden; }
.title .line--it {
  font-style: italic; font-weight: 400;
  color: transparent; background: linear-gradient(100deg, var(--gold-2), #fff 45%, var(--gold));
  -webkit-background-clip: text; background-clip: text; padding-bottom: 0.08em;
}
.lede {
  font-family: var(--serif); font-size: clamp(1.1rem, 1.9vw, 1.55rem); line-height: 1.45;
  color: rgba(244,238,228,0.82); max-width: 30ch; margin: 1.6em 0 2.2em;
}
.lede em { color: var(--gold-2); font-weight: 500; }
.scrollcue { display: inline-flex; align-items: center; gap: 1em; font-size: 0.66rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--muted); }
.scrollcue__line { width: 64px; height: 1px; background: var(--line); position: relative; overflow: hidden; }
.scrollcue__line::after { content: ""; position: absolute; inset: 0; width: 40%; background: var(--gold); animation: cue 2.4s var(--ease) infinite; }
@keyframes cue { 0%{transform:translateX(-120%)} 60%,100%{transform:translateX(280%)} }

/* bloom captions (the text labels for each 3D flower) */
.bloom-cap { position: absolute; z-index: 2; max-width: 40vw; }
.bloom-cap figcaption { display: flex; flex-direction: column; gap: 0.35em; }
.cap__no { font-size: 0.7rem; letter-spacing: 0.3em; color: var(--gold-2); }
.cap__name { font-family: var(--serif); font-weight: 500; font-size: clamp(1.6rem, 3vw, 2.8rem); line-height: 1; }
.cap__sub { font-size: 0.66rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); }

.bloom-cap--hero { right: var(--gut); bottom: 12vh; text-align: right; }
.bloom-cap--hero figcaption { align-items: flex-end; }
.bloom-cap--l { left: var(--gut); bottom: 13vh; text-align: left; }
.bloom-cap--r { right: var(--gut); bottom: 13vh; text-align: right; }
.bloom-cap--r figcaption { align-items: flex-end; }
.bloom-cap--c { left: 50%; transform: translateX(-50%); bottom: 11vh; text-align: center; }
.bloom-cap--c figcaption { align-items: center; }

/* photo posters — fallback when 3D is unavailable */
.poster {
  width: clamp(160px, 20vw, 300px); aspect-ratio: 3/4; object-fit: cover;
  border-radius: 8px; margin-bottom: 1.2em;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,0.85);
}
.poster--hero { width: clamp(220px, 32vw, 440px); margin-left: auto; }
.poster--r { margin-left: auto; }
.poster--c { margin: 0 auto 1.2em; }
.poster { transition: opacity 1.2s var(--ease); }
body.has-3d .poster { opacity: 0; pointer-events: none; }   /* crossfade to the 3D scene */

/* finale */
.row--finale { justify-content: center; }

/* ===========================================================
   ATELIER / CTA
   =========================================================== */
.atelier {
  position: relative; z-index: 2; text-align: center; padding: clamp(120px, 20vh, 240px) var(--gut);
  background: linear-gradient(180deg, transparent 0%, var(--bg) 24%); /* fade the garden out behind the CTA */
}
.atelier .kicker { display: inline-block; margin-bottom: 1.6em; }
.atelier__title { font-family: var(--serif); font-weight: 400; font-size: clamp(2.8rem, 9vw, 7rem); line-height: 0.92; letter-spacing: -0.02em; }
.atelier__sub { font-family: var(--serif); font-size: clamp(1.05rem, 1.8vw, 1.4rem); color: var(--muted); max-width: 40ch; margin: 1.4em auto 2.6em; }
[data-lines] .w { display: inline-block; will-change: transform, opacity; }

/* ---------------- footer ---------------- */
.foot { position: relative; z-index: 2; padding: clamp(40px, 6vh, 80px) var(--gut); border-top: 1px solid var(--line); background: var(--bg); }
.foot__row { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; max-width: 1500px; margin: 0 auto; }
.foot__brand { font-family: var(--serif); font-size: 1.1rem; }
.foot__mid, .foot__credit { font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }

/* reveal defaults — only when JS is live */
.fx [data-fade] { opacity: 0; transform: translateY(22px); }

/* ---------------- responsive ---------------- */
@media (max-width: 820px) {
  .nav__links a:not(.nav__cta) { display: none; }
  .title { font-size: clamp(3rem, 16vw, 6rem); }
  .bloom-cap { max-width: 70vw; }
  .bloom-cap--hero { left: var(--gut); right: auto; text-align: left; }
  .bloom-cap--hero figcaption { align-items: flex-start; }
  .foot__row { flex-direction: column; text-align: center; }
}

@media (prefers-reduced-motion: reduce) {
  .grain, .scrollcue__line::after, .live-badge::before { animation: none; }
}
