/* ============================================================
   MAGICAL TRAVELS WITH HALEY — components: nav, menu, buttons,
   cards, chips, form, footer, cursor
   ============================================================ */

/* ---------------- nav ---------------- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  transition: transform .5s var(--ease-out), background .4s ease, border-color .4s ease;
  border-bottom: 1px solid transparent;
}
.nav.nav--scrolled {
  background: rgba(10, 7, 32, .74);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom-color: var(--hairline);
}
.nav.nav--hidden { transform: translateY(-100%); }

.nav-inner {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
  height: var(--nav-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.nav-brand {
  display: flex;
  align-items: center;
  gap: .7rem;
  color: var(--text);
}
.nav-sigil { width: 1.7rem; height: 1.7rem; }
.nav-wordmark {
  font-family: var(--font-display);
  font-size: 1.05rem;
  letter-spacing: .01em;
  white-space: nowrap;
}
.nav-wordmark b { font-weight: 500; }

.nav-links {
  display: flex;
  gap: 2.1rem;
}
.nav-links a {
  font-size: var(--fs-small);
  font-weight: 400;
  color: var(--text-dim);
  position: relative;
  padding-block: .25rem;
  transition: color .3s ease;
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 1px;
  background: var(--magic);
  transform: scaleX(0);
  transform-origin: 100% 50%;
  transition: transform .45s var(--ease-out);
}
.nav-links a:hover { color: var(--text); }
.nav-links a:hover::after {
  transform: scaleX(1);
  transform-origin: 0 50%;
}
.nav-links a.is-current { color: var(--text); }
.nav-links a.is-current::after {
  transform: scaleX(1);
  transform-origin: 0 50%;
}

.nav-actions { display: flex; align-items: center; gap: 1rem; }

.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  width: 2.6rem; height: 2.6rem;
  padding: 0;
  background: none;
  border: 0;
  cursor: pointer;
}
.nav-burger span {
  display: block;
  width: 22px; height: 1.5px;
  margin-inline: auto;
  background: var(--text);
  transition: transform .4s var(--ease-out), opacity .3s ease;
}
.nav-burger[aria-expanded="true"] span:first-child { transform: translateY(3.75px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:last-child { transform: translateY(-3.75px) rotate(-45deg); }

@media (max-width: 760px) {
  .nav-links { display: none; }
  .nav-burger { display: flex; }
  .nav-actions .btn { display: none; }
}

/* ---------------- full-screen menu ---------------- */
.menu {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-content: center;
  text-align: center;
  gap: 3rem;
  background: rgba(10, 7, 32, .92);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  opacity: 0;
  visibility: hidden;
  transition: opacity .45s ease, visibility 0s .45s;
}
.menu.is-open {
  opacity: 1;
  visibility: visible;
  transition: opacity .45s ease;
}
.menu-links { display: grid; gap: 1.25rem; }
.menu-links a {
  font-family: var(--font-display);
  font-size: clamp(2rem, 8vw, 3.25rem);
  line-height: 1.15;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .5s var(--ease-out), transform .5s var(--ease-out), color .3s ease;
  transition-delay: 0s;
}
.menu.is-open .menu-links a {
  opacity: 1;
  transform: none;
  transition-delay: calc(.08s + var(--i, 0) * .07s), calc(.08s + var(--i, 0) * .07s), 0s;
}
.menu-links a:hover { color: var(--gold); }
.menu-foot {
  font-size: var(--fs-label);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--text-faint);
}

/* ---------------- buttons ---------------- */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .95rem 1.9rem;
  border-radius: 99px;
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: .02em;
  border: 1px solid transparent;
  cursor: pointer;
  overflow: hidden;
  /* --magx/--magy are set by the magnetic-button JS */
  transform: translate3d(var(--magx, 0px), var(--magy, 0px), 0) scale(var(--mags, 1));
  transition: transform .35s var(--ease-out), background .3s ease,
              border-color .3s ease, color .3s ease, box-shadow .35s ease;
}
.btn:active { --mags: .96; }

.btn-primary {
  background: linear-gradient(118deg, #fbe6a8, var(--gold) 52%, #e7c277);
  color: #2a1d08;
}
.btn-primary::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255, 255, 255, .55) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform .7s var(--ease-soft);
}
.btn-primary:hover {
  --mags: 1.03;
  box-shadow: 0 10px 34px -8px rgba(244, 213, 141, .42), 0 4px 16px -8px rgba(201, 124, 246, .3);
}
.btn-primary:hover::before { transform: translateX(120%); }

.btn-ghost {
  background: rgba(247, 243, 234, .03);
  border-color: var(--hairline-strong);
  color: var(--text);
}
.btn-ghost:hover {
  --mags: 1.03;
  border-color: rgba(244, 213, 141, .5);
  background: rgba(247, 243, 234, .07);
}

.btn-sm { padding: .6rem 1.3rem; }
.btn-lg { padding: 1.1rem 2.4rem; font-size: 1rem; }
.btn svg { width: 1.05em; height: 1.05em; }

/* ---------------- cards ---------------- */
.card {
  position: relative;
  background: linear-gradient(180deg, rgba(24, 17, 64, .66), rgba(18, 13, 51, .66));
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  transition: transform .5s var(--ease-out), border-color .4s ease;
}

/* magic gradient border, shown on hover */
.card::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(244, 213, 141, .6), transparent 38%, transparent 62%, rgba(201, 166, 255, .6));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask-composite: exclude;
  opacity: 0;
  transition: opacity .5s ease;
  pointer-events: none;
}
.card:hover::after { opacity: 1; }

/* cursor-following glow (driven by --mx/--my from JS) */
.tilt::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(420px circle at var(--mx, 50%) var(--my, 50%),
              rgba(244, 213, 141, .09), transparent 65%);
  opacity: 0;
  transition: opacity .4s ease;
  pointer-events: none;
}
.tilt:hover::before { opacity: 1; }

/* ---------------- chips (radio pills) ---------------- */
.chips {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}
.chip { position: relative; }
.chip input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}
.chip span {
  display: inline-block;
  padding: .55rem 1.1rem;
  border-radius: 99px;
  border: 1px solid var(--hairline-strong);
  font-size: var(--fs-small);
  color: var(--text-dim);
  transition: all .3s var(--ease-out);
  user-select: none;
}
.chip:hover span {
  border-color: rgba(244, 213, 141, .5);
  color: var(--text);
}
.chip input:checked + span {
  background: var(--gold);
  border-color: var(--gold);
  color: #2a1d08;
  font-weight: 500;
}
.chip input:focus-visible + span {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

/* ---------------- form ---------------- */
.form {
  padding: clamp(1.5rem, 4vw, 2.75rem);
  overflow: hidden;
}
.form.is-done .form-steps,
.form.is-done .form-controls,
.form.is-done .form-progress,
.form.is-done .form-result-badge { display: none; }

.hp { position: absolute; left: -9999px; opacity: 0; }

/* the traveler-type badge piped in from the quiz */
.form-result-badge {
  display: none;
  align-items: center;
  gap: .6rem;
  margin-bottom: 1.5rem;
  padding: .7rem 1rem;
  border-radius: 99px;
  border: 1px solid rgba(244, 213, 141, .35);
  background: rgba(244, 213, 141, .08);
  font-size: var(--fs-small);
}
.form-result-badge.is-set { display: inline-flex; }
.form-result-badge svg { width: 1.1rem; height: 1.1rem; color: var(--gold); flex: none; }
.form-result-badge b { color: var(--gold); font-weight: 600; }

.form-progress {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}
.form-progress-bar {
  flex: 1;
  height: 2px;
  background: var(--hairline);
  border-radius: 99px;
  overflow: hidden;
}
.form-progress-bar i {
  display: block;
  height: 100%;
  width: 33.333%;
  background: var(--magic);
  border-radius: inherit;
  transition: width .6s var(--ease-out);
}
.form-progress-label {
  font-size: var(--fs-label);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-faint);
  white-space: nowrap;
}

.form-steps { position: relative; }

.form-step {
  border: 0;
  padding: 0;
  min-inline-size: 0;
  display: none;
}
.form-step.is-active {
  display: grid;
  gap: 1.4rem;
  animation: step-in .5s var(--ease-out) both;
}
.form-step.is-leaving { animation: step-out .25s ease both; }

@keyframes step-in {
  from { opacity: 0; transform: translateX(26px); }
  to   { opacity: 1; transform: none; }
}
@keyframes step-out {
  from { opacity: 1; }
  to   { opacity: 0; transform: translateX(-18px); }
}

.field { display: grid; gap: .5rem; }
.field-row { display: grid; gap: 1.4rem; grid-template-columns: 1fr 1fr; }
@media (max-width: 540px) { .field-row { grid-template-columns: 1fr; } }

.field label,
.field-label {
  font-size: var(--fs-small);
  font-weight: 400;
  color: var(--text-dim);
}
.optional { color: var(--text-faint); font-size: .8em; }

.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field textarea {
  background: rgba(10, 7, 32, .6);
  border: 1px solid var(--hairline-strong);
  border-radius: .65rem;
  padding: .85rem 1rem;
  color: var(--text);
  font-weight: 300;
  transition: border-color .3s ease, background .3s ease, box-shadow .3s ease;
}
.field input::placeholder,
.field textarea::placeholder { color: var(--text-faint); }
.field input:focus,
.field textarea:focus {
  outline: none;
  border-color: rgba(244, 213, 141, .6);
  box-shadow: 0 0 0 3px rgba(244, 213, 141, .1);
}
.field textarea { resize: vertical; min-height: 7rem; }

.field-error {
  display: none;
  font-size: var(--fs-small);
  color: #f3a2b0;
}
.field.has-error .field-error { display: block; }
.field.has-error input,
.field.has-error textarea { border-color: rgba(243, 162, 176, .6); }

.form-controls {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 2rem;
}
.form-controls [data-form-next],
.form-controls [data-form-submit] { margin-left: auto; }

.btn.is-busy { pointer-events: none; opacity: .65; }

/* success state */
.form-success {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: .75rem;
  padding-block: 2rem;
}
.form-success svg { width: 76px; height: 76px; margin-bottom: .5rem; }
.form-success h3 { font-size: 1.7rem; }
.form-success p { color: var(--text-dim); max-width: 32ch; }

.success-ring {
  stroke-dasharray: 164;
  stroke-dashoffset: 164;
  animation: draw 1.1s var(--ease-out) .15s forwards;
}
.success-check {
  stroke-dasharray: 34;
  stroke-dashoffset: 34;
  animation: draw .6s var(--ease-out) .75s forwards;
}
@keyframes draw { to { stroke-dashoffset: 0; } }

.form-error-note {
  margin-top: 1.25rem;
  font-size: var(--fs-small);
  color: #f3a2b0;
}
.form-error-note a { text-decoration: underline; text-underline-offset: 3px; }

/* ---------------- footer ---------------- */
.footer {
  position: relative;
  border-top: 1px solid var(--hairline);
  padding-block: clamp(4rem, 8vw, 6.5rem) 2rem;
  overflow: hidden;
  background: linear-gradient(180deg, transparent, rgba(18, 13, 51, .7));
}

.footer-word {
  position: absolute;
  left: 50%;
  bottom: -.22em;
  transform: translateX(-50%);
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(5rem, 17vw, 15rem);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px rgba(244, 213, 141, .07);
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
}

.footer-main {
  position: relative;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
}
.footer-sigil { width: 2.1rem; height: 2.1rem; margin-bottom: 1.1rem; }
.footer-brand p { color: var(--text-dim); line-height: 1.7; max-width: 34ch; }

.footer-links,
.footer-contact {
  display: flex;
  flex-direction: column;
  gap: .8rem;
  align-items: flex-start;
}
.footer-col-title {
  font-size: var(--fs-label);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: .35rem;
}
.footer-links a,
.footer-contact a {
  color: var(--text-dim);
  font-size: var(--fs-small);
  transition: color .3s ease;
}
.footer-links a:hover,
.footer-contact a:hover { color: var(--gold); }

.footer-fine {
  position: relative;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .75rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--hairline);
  font-size: .8rem;
  color: var(--text-faint);
}

.footer-disclaimer {
  position: relative;
  max-width: 70ch;
  margin-top: 1.25rem;
  font-size: .76rem;
  line-height: 1.6;
  color: var(--text-faint);
}

@media (max-width: 760px) {
  .footer-main { grid-template-columns: 1fr; gap: 2.25rem; }
}

/* ---------------- custom cursor (injected by JS) ---------------- */
html.has-cursor,
html.has-cursor a,
html.has-cursor button,
html.has-cursor label,
html.has-cursor input,
html.has-cursor textarea { cursor: none; }

.cursor-dot,
.cursor-ring {
  position: fixed;
  top: 0; left: 0;
  z-index: 999;
  pointer-events: none;
  border-radius: 50%;
  opacity: 0;
  transition: opacity .3s ease;
}
html.cursor-visible .cursor-dot,
html.cursor-visible .cursor-ring { opacity: 1; }

.cursor-dot {
  width: 5px; height: 5px;
  margin: -2.5px 0 0 -2.5px;
  background: var(--gold);
}
.cursor-ring {
  width: 30px; height: 30px;
  margin: -15px 0 0 -15px;
  border: 1px solid rgba(244, 213, 141, .4);
  transition: opacity .3s ease, transform .3s var(--ease-out),
              border-color .3s ease;
}
.cursor-ring.is-active {
  transform: scale(1.45);
  border-color: rgba(201, 166, 255, .6);
}
.cursor-ring.is-down { transform: scale(.85); }
