.motif { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.tile { aspect-ratio: 1; position: relative; overflow: hidden; }
.tile::before {
  content: ""; position: absolute; inset: 0;
  background-color: var(--c, var(--orange));
  background-image:
    var(--noise),
    radial-gradient(circle at 30% 25%, rgba(255, 248, 230, 0.5), transparent 58%),
    radial-gradient(circle at 72% 82%, rgba(45, 42, 36, 0.38), transparent 62%);
  background-blend-mode: soft-light, soft-light, multiply;
}
.tile.circle::before  { border-radius: 50%; }
.tile.half-b::before  { border-radius: 100% 100% 0 0; transform: translateY(50%); }
.tile.half-t::before  { border-radius: 0 0 100% 100%; transform: translateY(-50%); }
.tile.half-l::before  { border-radius: 0 100% 100% 0; transform: translateX(-50%); }
.tile.half-r::before  { border-radius: 100% 0 0 100%; transform: translateX(50%); }
.tile.q-tl::before    { border-radius: 0 0 100% 0; }
.tile.q-tr::before    { border-radius: 0 0 0 100%; }
.tile.q-br::before    { border-radius: 100% 0 0 0; }
.tile.q-bl::before    { border-radius: 0 100% 0 0; }
.o { --c: var(--orange); }
.g { --c: var(--green);  }
.w { --c: var(--wine);   }

.motif-dot { grid-column: 1 / -1; display: flex; justify-content: center; }
.motif-dot::before {
  content: ""; display: block;
  width: 50%; aspect-ratio: 1; border-radius: 50%;
  background-color: var(--orange);
  background-image:
    var(--noise),
    radial-gradient(circle at 30% 25%, rgba(255, 248, 230, 0.5), transparent 58%),
    radial-gradient(circle at 72% 82%, rgba(45, 42, 36, 0.32), transparent 62%);
  background-blend-mode: soft-light, soft-light, multiply;
}

#hero {
  min-height: 100vh; display: flex; align-items: center;
  position: relative; overflow: hidden; padding: 9rem 0 5rem;
}
#hero .container { position: relative; z-index: 1; }

.hero-video { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.hero-video video {
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transition: opacity 1.8s ease;
}
.hero-video video.playing { opacity: 1; }
.hero-veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom, rgba(247,239,219,0.55) 0%, transparent 22%, transparent 72%, var(--cream) 100%),
    linear-gradient(100deg, var(--cream) 8%, rgba(247,239,219,0.88) 42%, rgba(247,239,219,0.5) 72%, rgba(247,239,219,0.35) 100%);
}
@media (max-width: 900px) {
  .hero-veil {
    background:
      linear-gradient(to bottom, rgba(247,239,219,0.7) 0%, rgba(247,239,219,0.62) 60%, var(--cream) 100%);
  }
}

.hero-grid {
  display: grid; grid-template-columns: 1.55fr 1fr;
  gap: 3rem; align-items: center; width: 100%;
}
.hero-content { position: relative; z-index: 2; max-width: 640px; }
.hero-content h1 { margin: 0.4rem 0 1.4rem; }
.hero-subtitle {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: clamp(1.25rem, 2.4vw, 1.7rem);
  color: var(--ink);
  margin-bottom: 2.4rem; max-width: 520px; line-height: 1.4;
}
.hero-subtitle .dot { color: var(--wine); }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-motif {
  align-self: stretch; min-height: 60vh;
  display: flex; align-items: center;
}
.hero-motif .motif { width: min(280px, calc((100vh - 14rem) / 2)); margin-left: auto; }

.btn {
  display: inline-block; padding: 0.9rem 2rem; border-radius: 3rem;
  font-size: 0.92rem; font-weight: 700; font-family: 'Mulish', sans-serif;
  letter-spacing: 0.02em; transition: all 0.25s; cursor: pointer; border: none;
}
.btn-primary { background: var(--orange); color: var(--cream); }
.btn-primary:hover {
  background: var(--orange-deep); transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(222, 122, 17, 0.32);
}
.btn-outline {
  background: transparent; color: var(--green); border: 2px solid var(--green);
}
.btn-outline:hover { background: var(--green); color: var(--cream); transform: translateY(-2px); }
