:root {
  --gold: #E0A92E;
  --goldl: #F6D682;
  --golddk: #C8901F;
  --bg: #060605;
  --panel: #111113;
  --panel2: #17171A;
  --cream: #F0E8D6;
  --mute: #9A9486;
  --line: rgba(224, 169, 46, 0.18);
  --line2: rgba(224, 169, 46, 0.10);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }
section[id] { scroll-margin-top: 76px; }

body {
  background: var(--bg);
  color: var(--cream);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  line-height: 1.5;
}

::selection { background: var(--gold); color: #1A1206; }
a:focus-visible, .btn:focus-visible, .btn-ghost:focus-visible { outline: 2px solid var(--goldl); outline-offset: 3px; border-radius: 4px; }

a { color: inherit; text-decoration: none; }

.wrap { max-width: 1000px; margin: 0 auto; padding: 0 22px; }
.serif { font-family: "Fraunces", Georgia, "Times New Roman", serif; }

/* top nav */
.nav {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  background: rgba(6, 6, 5, 0.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line2);
}
.nav .brand { display: flex; align-items: center; gap: 10px; font-weight: 800; color: var(--goldl); letter-spacing: 1px; }
.nav .brand img { height: 38px; width: auto; display: block; mix-blend-mode: screen; }
.nav .navright { display: flex; align-items: center; gap: 18px; }
.nav .links a { color: var(--mute); font-size: 14px; margin-left: 18px; transition: color .2s ease; }
.nav .links a:first-child { margin-left: 0; }
.nav .links a:hover { color: var(--goldl); }
.nav .apply-pill { margin: 0; padding: 8px 18px; font-size: 13px; }

/* honey drip band — sits just under the nav.
   The drips live in a self-contained animated SVG tile (gooey filter merges
   bar + drips into one viscous body; beads swell, detach, and fall). The
   tile repeats horizontally, so it never distorts at any screen width. */
.honeybar {
  position: relative;
  height: 6px;
  background: linear-gradient(90deg, var(--golddk), var(--goldl) 45%, var(--gold) 55%, var(--golddk));
  box-shadow: 0 0 22px rgba(224, 169, 46, 0.45);
  z-index: 9;
}
.honeybar::after {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 140px;
  pointer-events: none;
  background-repeat: repeat-x;
  background-size: 480px 140px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='480' height='140' viewBox='0 0 480 140'%3E%3Cdefs%3E%3ClinearGradient id='h' x1='0' y1='0' x2='0' y2='1'%3E%3Cstop offset='0' stop-color='%23F8DC8C'/%3E%3Cstop offset='.45' stop-color='%23E0A92E'/%3E%3Cstop offset='1' stop-color='%239A6810'/%3E%3C/linearGradient%3E%3Cfilter id='g' x='-20%25' y='-20%25' width='140%25' height='160%25'%3E%3CfeGaussianBlur in='SourceGraphic' stdDeviation='5'/%3E%3CfeColorMatrix values='1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 18 -8'/%3E%3C/filter%3E%3C/defs%3E%3Cg filter='url(%23g)'%3E%3Crect width='480' height='9' fill='url(%23h)'/%3E%3Cellipse cx='150' cy='10' rx='7' ry='5' fill='url(%23h)'/%3E%3Cellipse cx='330' cy='9' rx='6' ry='4' fill='url(%23h)'/%3E%3Cg fill='url(%23h)'%3E%3Crect x='66' y='4' width='8' rx='4' height='6'%3E%3Canimate attributeName='height' dur='10s' begin='-2s' repeatCount='indefinite' calcMode='spline' values='6;10;48;54;12;6;6' keyTimes='0;.12;.5;.62;.7;.8;1' keySplines='.4 0 .6 1;.25 0 .15 1;.42 0 .58 1;.3 0 .7 1;.42 0 .58 1;.42 0 .58 1'/%3E%3C/rect%3E%3Cg%3E%3Ccircle cx='70' cy='12' r='8'%3E%3Canimate attributeName='r' dur='10s' begin='-2s' repeatCount='indefinite' values='7;11;12.5;12.5;7;7' keyTimes='0;.5;.62;.88;.93;1'/%3E%3C/circle%3E%3Cellipse cx='67' cy='9' rx='2.4' ry='3.6' fill='%23FFEFC4' opacity='.75'/%3E%3CanimateTransform attributeName='transform' type='translate' dur='10s' begin='-2s' repeatCount='indefinite' calcMode='spline' values='0 0;0 2;0 40;0 46;0 47;0 130;0 0;0 0' keyTimes='0;.12;.5;.62;.66;.84;.9;1' keySplines='.4 0 .6 1;.25 0 .15 1;.42 0 .58 1;.42 0 .58 1;.55 0 1 .4;0 0 1 1;0 0 1 1'/%3E%3Canimate attributeName='opacity' dur='10s' begin='-2s' repeatCount='indefinite' values='1;1;0;0;1;1' keyTimes='0;.8;.86;.89;.94;1'/%3E%3C/g%3E%3C/g%3E%3Cg fill='url(%23h)'%3E%3Crect x='226' y='4' width='8' rx='4' height='6'%3E%3Canimate attributeName='height' dur='13s' begin='-8s' repeatCount='indefinite' calcMode='spline' values='6;10;48;54;12;6;6' keyTimes='0;.12;.5;.62;.7;.8;1' keySplines='.4 0 .6 1;.25 0 .15 1;.42 0 .58 1;.3 0 .7 1;.42 0 .58 1;.42 0 .58 1'/%3E%3C/rect%3E%3Cg%3E%3Ccircle cx='230' cy='12' r='8'%3E%3Canimate attributeName='r' dur='13s' begin='-8s' repeatCount='indefinite' values='7;11;12.5;12.5;7;7' keyTimes='0;.5;.62;.88;.93;1'/%3E%3C/circle%3E%3Cellipse cx='227' cy='9' rx='2.4' ry='3.6' fill='%23FFEFC4' opacity='.75'/%3E%3CanimateTransform attributeName='transform' type='translate' dur='13s' begin='-8s' repeatCount='indefinite' calcMode='spline' values='0 0;0 2;0 40;0 46;0 47;0 130;0 0;0 0' keyTimes='0;.12;.5;.62;.66;.84;.9;1' keySplines='.4 0 .6 1;.25 0 .15 1;.42 0 .58 1;.42 0 .58 1;.55 0 1 .4;0 0 1 1;0 0 1 1'/%3E%3Canimate attributeName='opacity' dur='13s' begin='-8s' repeatCount='indefinite' values='1;1;0;0;1;1' keyTimes='0;.8;.86;.89;.94;1'/%3E%3C/g%3E%3C/g%3E%3Cg fill='url(%23h)'%3E%3Crect x='391' y='4' width='8' rx='4' height='6'%3E%3Canimate attributeName='height' dur='11s' begin='-5s' repeatCount='indefinite' calcMode='spline' values='6;10;48;54;12;6;6' keyTimes='0;.12;.5;.62;.7;.8;1' keySplines='.4 0 .6 1;.25 0 .15 1;.42 0 .58 1;.3 0 .7 1;.42 0 .58 1;.42 0 .58 1'/%3E%3C/rect%3E%3Cg%3E%3Ccircle cx='395' cy='12' r='8'%3E%3Canimate attributeName='r' dur='11s' begin='-5s' repeatCount='indefinite' values='7;11;12.5;12.5;7;7' keyTimes='0;.5;.62;.88;.93;1'/%3E%3C/circle%3E%3Cellipse cx='392' cy='9' rx='2.4' ry='3.6' fill='%23FFEFC4' opacity='.75'/%3E%3CanimateTransform attributeName='transform' type='translate' dur='11s' begin='-5s' repeatCount='indefinite' calcMode='spline' values='0 0;0 2;0 40;0 46;0 47;0 130;0 0;0 0' keyTimes='0;.12;.5;.62;.66;.84;.9;1' keySplines='.4 0 .6 1;.25 0 .15 1;.42 0 .58 1;.42 0 .58 1;.55 0 1 .4;0 0 1 1;0 0 1 1'/%3E%3Canimate attributeName='opacity' dur='11s' begin='-5s' repeatCount='indefinite' values='1;1;0;0;1;1' keyTimes='0;.8;.86;.89;.94;1'/%3E%3C/g%3E%3C/g%3E%3C/g%3E%3Crect y='1.5' width='480' height='1.8' rx='.9' fill='%23FFF6DC' opacity='.35'/%3E%3C/svg%3E");
}

/* faint honeycomb tile, used by hero + cta */
:root {
  --hexes: url("data:image/svg+xml,%3Csvg width='28' height='49' viewBox='0 0 28 49' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15l12.99-7.5zM3 17.9v12.7l10.99 6.34 11-6.35V17.9l-11-6.34L3 17.9zM0 15l12.98-7.5V0h-2v6.35L0 12.69v2.3zm0 18.5L12.98 41v8h-2v-6.85L0 35.81v-2.3zM15 0v7.5L27.99 15H28v-2.31h-.01L17 6.35V0h-2zm0 49v-8l12.99-7.5H28v2.31h-.01L17 42.15V49h-2z' fill='%23E0A92E' fill-opacity='0.045' fill-rule='evenodd'/%3E%3C/svg%3E");
}

/* hero */
header {
  padding: 64px 0 44px;
  text-align: center;
  background-color: var(--bg);
  background-image: var(--hexes), radial-gradient(ellipse at 50% -10%, rgba(224, 169, 46, 0.14), var(--bg) 62%);
  background-size: 42px 73.5px, auto;
}
.kicker { letter-spacing: 4px; font-size: 12px; color: var(--mute); }
h1 { font-size: clamp(38px, 8vw, 84px); color: var(--goldl); letter-spacing: 1px; margin: 6px 0 2px; overflow-wrap: break-word; text-shadow: 0 0 38px rgba(224, 169, 46, 0.25); }
.tag { font-style: italic; color: var(--gold); font-size: clamp(16px, 3.5vw, 24px); }
.sub { color: var(--cream); max-width: 620px; margin: 18px auto 28px; font-size: 18px; }

.btn {
  display: inline-block;
  background: linear-gradient(90deg, var(--goldl), var(--gold));
  color: #2A1A00;
  font-weight: 800;
  padding: 15px 34px;
  border-radius: 30px;
  font-size: 17px;
  letter-spacing: .5px;
  box-shadow: 0 6px 22px rgba(224, 169, 46, 0.22);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn:hover { filter: brightness(1.06); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(224, 169, 46, 0.38); }
.btn-ghost { display: inline-block; border: 1px solid var(--line); color: var(--goldl); padding: 14px 28px; border-radius: 30px; margin-left: 10px; font-weight: 600; transition: border-color .2s ease, background .2s ease; }
.btn-ghost:hover { border-color: var(--gold); background: rgba(224, 169, 46, 0.08); }

section { padding: 54px 0; border-top: 1px solid var(--line2); }
h2 { font-family: "Fraunces", Georgia, serif; color: #fff; font-size: clamp(26px, 5vw, 38px); margin-bottom: 8px; }
.lead { color: var(--mute); max-width: 680px; margin-bottom: 28px; font-size: 17px; }

.grid { display: grid; gap: 16px; }
.g3 { grid-template-columns: repeat(3, 1fr); }
.g4 { grid-template-columns: repeat(4, 1fr); }

.card {
  background: linear-gradient(180deg, var(--panel2), var(--panel));
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 20px;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.card:hover { transform: translateY(-4px); border-color: var(--gold); box-shadow: 0 12px 34px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(224, 169, 46, 0.15); }
.card h3 { color: var(--goldl); font-size: 18px; margin-bottom: 6px; }
.card p { color: var(--cream); font-size: 14.5px; }
.price { color: var(--gold); font-weight: 700; font-size: 15px; margin-top: 6px; }
.split { color: var(--mute); font-size: 12.5px; margin-top: 3px; }

/* small gold dash atop the value cards */
.g3 .card::before {
  content: "";
  display: block;
  width: 34px; height: 3px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--goldl), var(--gold));
  margin-bottom: 12px;
}

/* featured tier */
.card.featured {
  position: relative;
  border-color: rgba(224, 169, 46, 0.55);
  box-shadow: 0 0 26px rgba(224, 169, 46, 0.12);
}
.card.featured:hover { border-color: var(--gold); }
.chip {
  position: absolute;
  top: -11px; left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(90deg, var(--goldl), var(--gold));
  color: #2A1A00;
  font-size: 11px; font-weight: 800;
  letter-spacing: .6px;
  padding: 3px 12px;
  border-radius: 12px;
  white-space: nowrap;
}

.steps { counter-reset: s; display: grid; gap: 14px; grid-template-columns: repeat(5, 1fr); }
.step { background: linear-gradient(180deg, var(--panel2), var(--panel)); border: 1px solid var(--line); border-radius: 14px; padding: 18px; text-align: center; transition: transform .2s ease, border-color .2s ease; }
.step:hover { transform: translateY(-3px); border-color: var(--gold); }
.num { display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 50%; background: radial-gradient(circle at 35% 30%, var(--goldl), var(--gold)); color: #2A1A00; font-family: "Fraunces", Georgia, serif; font-weight: 800; margin-bottom: 8px; box-shadow: 0 0 16px rgba(224, 169, 46, 0.35); }

.cta {
  text-align: center;
  background-color: var(--bg);
  background-image: var(--hexes), radial-gradient(ellipse at 50% 110%, rgba(224, 169, 46, 0.16), var(--bg) 62%);
  background-size: 42px 73.5px, auto;
}

footer { color: var(--mute); font-size: 13px; padding: 34px 0 40px; border-top: 1px solid var(--line2); }
.foot-grid { display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.foot-brand { font-family: "Fraunces", Georgia, serif; font-size: 17px; color: var(--goldl); }
.foot-brand span { display: block; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; font-style: italic; font-size: 12.5px; color: var(--mute); margin-top: 3px; }
.foot-links { display: flex; gap: 20px; flex-wrap: wrap; }
.foot-links a { color: var(--mute); transition: color .2s ease; }
.foot-links a:hover { color: var(--goldl); }
.copyright { text-align: center; font-size: 12px; color: var(--mute); margin-top: 26px; opacity: .7; }
.note { color: var(--mute); font-size: 12px; margin-top: 14px; }

/* scroll-reveal (classes added by JS; no-JS users see everything) */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }
.grid .reveal:nth-child(2), .steps .reveal:nth-child(2) { transition-delay: .07s; }
.grid .reveal:nth-child(3), .steps .reveal:nth-child(3) { transition-delay: .14s; }
.grid .reveal:nth-child(4), .steps .reveal:nth-child(4) { transition-delay: .21s; }
.steps .reveal:nth-child(5) { transition-delay: .28s; }

@media (max-width: 760px) {
  .g3, .g4, .steps { grid-template-columns: 1fr 1fr; }
  .nav .links { display: none; }   /* text links hide; the Apply pill stays */
  .foot-grid { flex-direction: column; align-items: center; text-align: center; }
}
@media (max-width: 480px) {
  .g3, .g4, .steps { grid-template-columns: 1fr; }
  .btn-ghost { margin: 10px 0 0; }
  .nav .apply-pill { margin: 0; }
}

/* respect users who prefer no motion */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .honeybar::after { display: none; }   /* static gold rail stays */
  .btn, .card, .step { transition: none; }
  .reveal { opacity: 1; transform: none; transition: none; }
}
