/* BOUDOIR — soft satin daydream. Blush, rose, cream pastel; silky gradients.
   Gilda Display (romantic high-contrast) + Pinyon Script (delicate accent)
   over Jost (light, clean sans). Tender, dreamy, sensual-but-soft. */

:root {
  --cream: #fff6f3;
  --blush: #fbe3e4;
  --rose: #f6c9d2;
  --petal: #efb0c0;
  --mauve: #d98aa3;
  --plum: #8a4f63;
  --ink: #5a3a44;
  --ink-soft: #8a6671;
  --gold: #cba17a;
  --line: rgba(138, 79, 99, 0.16);
  --display: "Gilda Display", Georgia, serif;
  --script: "Pinyon Script", cursive;
  --sans: "Jost", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  font-weight: 300;
  color: var(--ink);
  background:
    radial-gradient(120% 85% at 82% -8%, rgba(246, 201, 210, 0.7), transparent 58%),
    radial-gradient(95% 75% at -5% 108%, rgba(251, 227, 228, 0.85), transparent 60%),
    radial-gradient(70% 60% at 50% 120%, rgba(217, 138, 163, 0.18), transparent 60%),
    linear-gradient(170deg, var(--cream), var(--blush) 55%, #fdeef0);
  background-attachment: fixed;
  min-height: 100vh;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* a soft drifting satin bloom in the backdrop */
.bloom {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: 0.5;
  background:
    radial-gradient(38% 50% at 18% 22%, rgba(255, 255, 255, 0.55), transparent 70%),
    radial-gradient(42% 46% at 86% 70%, rgba(239, 176, 192, 0.4), transparent 72%);
  mix-blend-mode: soft-light;
}

a { color: inherit; text-decoration: none; }
em { font-style: italic; }

.label {
  font-size: 0.7rem; letter-spacing: 0.34em; text-transform: uppercase;
  color: var(--mauve); font-weight: 500;
}

.script {
  font-family: var(--script);
  font-weight: 400; line-height: 1; color: var(--mauve);
  font-size: clamp(1.9rem, 5.5vw, 3rem);
}
.script-sm { font-size: clamp(1.5rem, 4vw, 2.1rem); }

.wordmark {
  font-family: var(--display);
  font-weight: 400; font-size: 1.1rem; letter-spacing: 0.02em; color: var(--plum);
}

.display {
  font-family: var(--display);
  font-weight: 400; line-height: 1.02; letter-spacing: -0.005em;
  font-size: clamp(2.9rem, 10.5vw, 6.5rem);
  color: var(--plum);
}
.display em { color: var(--mauve); font-style: italic; }
.display-sm { font-size: clamp(2rem, 5.6vw, 3.4rem); }

/* layout rhythm */
.bar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  padding: 26px clamp(22px, 6vw, 80px);
}
.bar-meta { font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); }

main { position: relative; z-index: 2; }

section { padding: clamp(58px, 11vh, 128px) clamp(22px, 6vw, 80px); }

/* hero — soft clouds behind a blush satin scrim */
.hero {
  position: relative; overflow: hidden;
  padding-top: clamp(50px, 11vh, 120px);
  padding-bottom: clamp(64px, 14vh, 150px);
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-color: var(--rose);
  background-image:
    linear-gradient(160deg, rgba(255, 246, 243, 0.74), rgba(251, 227, 228, 0.6) 45%, rgba(239, 176, 192, 0.5)),
    url("https://images.unsplash.com/photo-1530908295418-a12e326966ba?auto=format&fit=crop&w=1600&q=70");
  background-size: cover; background-position: center 28%;
  mix-blend-mode: soft-light;
  -webkit-mask-image: linear-gradient(180deg, #000 62%, transparent);
  mask-image: linear-gradient(180deg, #000 62%, transparent);
  opacity: 0.95;
}
.hero-inner { position: relative; z-index: 1; max-width: 980px; }
.hero .script { margin: 4px 0 2px; }
.hero .display { margin: 6px 0 22px; }
.essence {
  font-family: var(--display); font-weight: 400; font-style: italic;
  font-size: clamp(1.15rem, 2.5vw, 1.6rem); color: var(--ink);
  max-width: 30ch; line-height: 1.5; margin-bottom: 34px;
}
.cta {
  display: inline-flex; align-items: center; gap: 0.6em; min-height: 44px;
  font-size: 0.82rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--plum);
  border-bottom: 1px solid rgba(217, 138, 163, 0.55); padding-bottom: 6px;
  transition: gap 0.2s, color 0.2s, border-color 0.2s;
}
.cta:hover { gap: 1em; color: var(--mauve); border-color: var(--mauve); }

/* fleet — a quiet hairline-ruled list beside a blush satin feature */
.fleet-band { border-top: 1px solid var(--line); }
.fleet-grid {
  display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(28px, 5vw, 64px); align-items: center; max-width: 1180px; margin: 0 auto;
}
.fleet-feature {
  margin: 0; position: relative; border-radius: 18px; overflow: hidden;
  background-color: var(--rose);
  box-shadow: 0 40px 80px -46px rgba(138, 79, 99, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.6);
}
.fleet-feature img {
  display: block; width: 100%; height: 100%; max-width: 100%;
  aspect-ratio: 4 / 5; object-fit: cover;
  filter: saturate(1.02) brightness(1.04) contrast(0.98);
}
.fleet-feature::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(155deg, rgba(255, 246, 243, 0.28), transparent 45%, rgba(217, 138, 163, 0.22));
}
.fleet-list { min-width: 0; }
.fleet-list .script { margin: 6px 0 8px; }
.fleet { margin-top: 22px; max-width: 920px; }
.plane {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: 18px;
  align-items: baseline; padding: 24px 0; border-top: 1px solid var(--line);
}
.plane:first-child { border-top: none; }
.plane h3 { font-family: var(--display); font-weight: 400; font-size: clamp(1.3rem, 3vw, 1.85rem); color: var(--plum); }
.plane p { color: var(--ink-soft); font-size: 1rem; }

/* pilots — one centered line between hairlines over a soft champagne wash */
.pilots-band {
  position: relative; overflow: hidden;
  text-align: center; padding-block: clamp(58px, 11vh, 116px);
}
.pilots-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-color: var(--blush);
  background-image:
    radial-gradient(120% 120% at 50% 50%, rgba(255, 246, 243, 0.55), rgba(251, 227, 228, 0.9) 74%),
    url("https://images.unsplash.com/photo-1605870445919-838d190e8e1b?auto=format&fit=crop&w=1600&q=70");
  background-size: cover; background-position: center;
  mix-blend-mode: soft-light; opacity: 0.7;
}
.pilots-band > .pilots { position: relative; z-index: 1; }
.pilots {
  font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: clamp(1.1rem, 2.3vw, 1.5rem); color: var(--plum);
  max-width: 30ch; margin: 0 auto; line-height: 1.5;
}
.pilots::before, .pilots::after {
  content: ""; display: block; width: 46px; height: 1px; margin: 24px auto;
  background: rgba(217, 138, 163, 0.55);
}

/* invitation — a satin card over a tender cloud backdrop */
.invite { position: relative; overflow: hidden; display: flex; justify-content: center; }
.invite-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-color: var(--blush);
  background-image:
    linear-gradient(180deg, rgba(255, 246, 243, 0.82), rgba(251, 227, 228, 0.72) 50%, rgba(253, 238, 240, 0.9)),
    url("https://images.unsplash.com/photo-1436491865332-7a61a109cc05?auto=format&fit=crop&w=1600&q=70");
  background-size: cover; background-position: center;
  mix-blend-mode: soft-light; opacity: 0.9;
}
.invite-card {
  position: relative; z-index: 1;
  width: 100%; max-width: 620px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 22px; padding: clamp(28px, 5vw, 52px);
  box-shadow: 0 40px 90px -48px rgba(138, 79, 99, 0.5);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.invite-card .script { margin: 6px 0 0; }
.invite-card .display { margin: 6px 0 6px; }
.invite-sub { color: var(--ink-soft); margin-bottom: 28px; }
form { display: grid; gap: 18px; }
.row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
label {
  display: grid; gap: 8px; font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--mauve);
}
.opt { color: var(--ink-soft); text-transform: none; letter-spacing: 0; font-size: 0.78rem; }
input, select, textarea {
  font-family: var(--sans); font-size: 1rem; font-weight: 300; color: var(--ink);
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(217, 138, 163, 0.3);
  border-radius: 12px; min-height: 44px;
  padding: 11px 14px; transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
input::placeholder, textarea::placeholder { color: rgba(138, 102, 113, 0.5); }
select { color: var(--ink); }
select option { background: var(--cream); color: var(--ink); }
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--mauve); background: #fff;
  box-shadow: 0 0 0 4px rgba(239, 176, 192, 0.3);
}
textarea { resize: vertical; }
button[type="submit"] {
  justify-self: start; margin-top: 6px; cursor: pointer; min-height: 44px;
  font-family: var(--sans); font-size: 0.82rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: #fff; background: linear-gradient(135deg, var(--mauve), var(--petal));
  border: none; border-radius: 999px; padding: 14px 32px; font-weight: 500;
  transition: transform 0.15s, box-shadow 0.2s;
  box-shadow: 0 16px 34px -14px rgba(217, 138, 163, 0.7);
}
button[type="submit"]:hover { transform: translateY(-2px); box-shadow: 0 22px 44px -16px rgba(217, 138, 163, 0.8); }
button[type="submit"]:disabled { opacity: 0.6; transform: none; cursor: default; }
.fine { font-size: 0.76rem; color: var(--ink-soft); letter-spacing: 0.02em; }
.success { font-family: var(--display); font-style: italic; font-size: 1.15rem; color: var(--mauve); }

/* footer */
.foot {
  position: relative; z-index: 2;
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: space-between; align-items: center;
  padding: 36px clamp(22px, 6vw, 80px); border-top: 1px solid var(--line);
}
.foot-fine { font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); }

/* floating hearts */
.hearts { position: fixed; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.hearts span {
  position: absolute; bottom: -40px; color: var(--petal); opacity: 0.5;
  animation-name: float-up; animation-timing-function: linear; animation-iteration-count: infinite;
}
@keyframes float-up {
  from { transform: translateY(0) rotate(0); opacity: 0; }
  10% { opacity: 0.5; }
  90% { opacity: 0.5; }
  to { transform: translateY(-108vh) rotate(28deg); opacity: 0; }
}

/* entrance */
.hero-inner > * { animation: rise 0.9s cubic-bezier(0.2, 0.7, 0.2, 1) both; }
.hero .label { animation-delay: 0.04s; }
.hero .script { animation-delay: 0.1s; }
.hero .display { animation-delay: 0.16s; }
.hero .essence { animation-delay: 0.28s; }
.hero .cta { animation-delay: 0.38s; }
@keyframes rise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

@media (max-width: 920px) {
  .fleet-grid { grid-template-columns: 1fr; gap: clamp(24px, 6vw, 40px); }
  .fleet-feature { max-width: 560px; }
  .fleet-feature img { aspect-ratio: 16 / 10; }
}

@media (max-width: 680px) {
  .row { grid-template-columns: 1fr; }
  .plane { grid-template-columns: 1fr; gap: 6px; }
  .bar { flex-wrap: wrap; gap: 6px 14px; }
  .foot { justify-content: flex-start; }
  button[type="submit"] { justify-self: stretch; text-align: center; }
}

@media (max-width: 400px) {
  section { padding-left: 18px; padding-right: 18px; }
  .bar { padding-left: 18px; padding-right: 18px; }
  .foot { padding-left: 18px; padding-right: 18px; }
  .display { font-size: clamp(2.4rem, 13vw, 3.1rem); }
  .invite-card { padding: 22px 18px; }
  .essence { max-width: 100%; }
  .pilots { max-width: 26ch; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-inner > * { animation: none; }
  .hearts span { animation: none; display: none; }
  body { background-attachment: scroll; }
}
