@import url("https://fonts.googleapis.com/css2?family=Dancing+Script:wght@600;700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Cormorant+Garamond:ital,wght@0,500;0,600;0,700;1,500;1,600;1,700&family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500&display=swap");

:root {
 --brand-red: #b20000;
 --brand-black: #000000;
 --brand-white: #ffffff;
 --bg: #ffffff;
 --surface: #fafafa;
 --surface-elevated: #f5f5f5;
 --border: #e8e8e8;
 --text: #000000;
 --muted: #5c5c5c;
 --accent: #b20000;
 --accent-soft: rgba(178, 0, 0, 0.08);
 --radius: 16px;
 --radius-lg: 22px;
 --font: "DM Sans", system-ui, -apple-system, sans-serif;
 --font-display: "Cormorant Garamond", "Playfair Display", Georgia, serif;
 --font-script: "Dancing Script", "Segoe Script", "Brush Script MT", cursive;
 --brand-gold: #c9a962;
 --brand-gold-soft: #f7e7b8;
 --brand-crimson: #c41e3a;
 --brand-crimson-deep: #7a0f1e;
 --nav-max: 1120px;
 --shadow-soft: 0 18px 50px rgba(0, 0, 0, 0.08);
 --shadow-card: 0 8px 28px rgba(0, 0, 0, 0.06);
}

.trust-badge {
 display: inline-flex;
 align-items: center;
 padding: 0.35rem 0.85rem;
 border-radius: 999px;
 font-size: 0.72rem;
 font-weight: 600;
 letter-spacing: 0.12em;
 text-transform: uppercase;
 color: var(--accent);
 background: var(--accent-soft);
 border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border));
}

*,
*::before,
*::after {
 box-sizing: border-box;
}

html {
 -webkit-text-size-adjust: 100%;
}

body {
 margin: 0;
 min-height: 100dvh;
 font-family: var(--font);
 color: var(--text);
 background:
  radial-gradient(ellipse 80% 50% at 50% -10%, var(--accent-soft), transparent),
  var(--bg);
 line-height: 1.55;
}

.shell {
 max-width: 760px;
 margin: 0 auto;
 padding: 2.5rem 1.25rem 4rem;
}

.shell--home {
 max-width: 920px;
}

.brand {
 text-align: center;
 margin-bottom: 2.5rem;
}

.brand-mark {
 border-radius: 16px;
 margin-bottom: 1rem;
}

.brand-mark-wrap {
 display: flex;
 justify-content: center;
 margin-bottom: 1.35rem;
}

.eyebrow {
 margin: 0 0 0.5rem;
 font-size: 0.8rem;
 letter-spacing: 0.14em;
 text-transform: uppercase;
 color: var(--accent);
}

h1 {
 margin: 0 0 1rem;
 font-family: var(--font-display);
 font-size: clamp(2rem, 5.5vw, 2.85rem);
 font-weight: 600;
 line-height: 1.12;
 letter-spacing: -0.02em;
}

.lede {
 margin: 0 auto;
 max-width: 34rem;
 color: var(--muted);
 font-size: 1.05rem;
}

.cards {
 display: grid;
 gap: 1rem;
 margin-bottom: 2.5rem;
}

@media (min-width: 560px) {
 .cards {
  grid-template-columns: repeat(3, 1fr);
 }
}

@media (min-width: 720px) {
 .cards--six {
  grid-template-columns: repeat(3, 1fr);
 }
}

.brand-ecosystem-note {
 font-size: 0.88rem;
 line-height: 1.5;
 max-width: 42rem;
 margin: 0.75rem auto 0;
}

.card {
 background: linear-gradient(165deg, color-mix(in srgb, var(--surface-elevated) 92%, white 8%), var(--surface));
 border: 1px solid color-mix(in srgb, var(--border) 88%, var(--accent) 12%);
 border-radius: var(--radius-lg);
 padding: 1.35rem 1.4rem;
 box-shadow: var(--shadow-card);
 transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.card:hover {
 transform: translateY(-2px);
 border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
 box-shadow: var(--shadow-soft);
}

.card h2 {
 margin: 0 0 0.5rem;
 font-size: 1rem;
 font-weight: 600;
 color: var(--accent);
}

.card p {
 margin: 0;
 font-size: 0.9rem;
 color: var(--muted);
}

.foot {
 text-align: center;
 font-size: 0.95rem;
}

.foot p {
 margin: 0 0 0.75rem;
}

.muted {
 color: var(--muted);
 font-size: 0.85rem;
}

a {
 color: var(--accent);
 text-decoration: none;
}

a:hover {
 text-decoration: underline;
}

/* - - Layout - - */
:root {
 --success: #2d8a4e;
 --danger: #b20000;
 --max: 960px;
 --primary: #b20000;
 --primary-dark: #8f0000;
}

.site-header {
 border-bottom: 1px solid color-mix(in srgb, var(--accent) 10%, var(--border));
 background: color-mix(in srgb, var(--brand-white) 90%, transparent);
 backdrop-filter: blur(20px) saturate(1.2);
 -webkit-backdrop-filter: blur(20px) saturate(1.2);
 position: sticky;
 top: 0;
 z-index: 100;
 box-shadow: 0 8px 32px rgba(0, 0, 0, 0.04);
}

.container {
 width: min(var(--nav-max), calc(100% - 2rem));
 margin-inline: auto;
}

.nav {
 position: relative;
 max-width: var(--nav-max);
 margin: 0 auto;
 padding: 0.65rem 1.25rem;
 min-height: 4rem;
 display: flex;
 align-items: center;
 justify-content: space-between;
 gap: 1rem;
}

.container.nav {
 max-width: var(--nav-max);
 width: min(var(--nav-max), calc(100% - 2rem));
}

.nav-logo {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  margin-left: auto;
  text-decoration: none;
}

.nav-logo:hover {
  text-decoration: none;
  opacity: 0.92;
}

.nav-logo > img,
.nav-logo > .loved-brand {
  width: auto;
  max-width: min(260px, 52vw);
  object-fit: contain;
  object-position: right center;
}

.lovescents-logo {
 display: block;
 width: auto;
 height: 44px;
 max-width: min(220px, 48vw);
 object-fit: contain;
 object-position: left center;
}

.loved-brand {
 display: inline-flex;
 line-height: 1;
 user-select: none;
 background: transparent;
}

.nav-logo:hover .loved-brand {
 opacity: 0.9;
}

.loved-brand-stack {
 display: inline-flex;
 flex-direction: column;
 align-items: center;
 gap: 0.1em;
 min-width: 0;
}

.loved-brand-loved {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 gap: 0;
 white-space: nowrap;
}

.loved-brand-script {
 font-family: var(--font-script);
 font-weight: 700;
 font-style: normal;
 color: #000000;
 letter-spacing: 0.01em;
 line-height: 1;
}

.loved-brand-heart-wrap {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 width: 0.78em;
 height: 0.78em;
 margin: 0 -0.02em;
 transform: translateY(0.06em);
}

.loved-brand-heart-outline,
.loved-brand-heart-svg {
 width: 100%;
 height: 100%;
 display: block;
}

.loved-brand-scents {
 font-family: var(--font);
 font-weight: 300;
 letter-spacing: 0.34em;
 text-transform: lowercase;
 color: #000000;
 text-align: center;
 width: 100%;
 padding-left: 0.34em;
 line-height: 1.2;
}

.loved-brand-nav .loved-brand-script { font-size: 1.55rem; }
.loved-brand-nav .loved-brand-scents { font-size: 0.62rem; letter-spacing: 0.36em; }

.loved-brand-hero .loved-brand-script { font-size: clamp(2.8rem, 7vw, 4.2rem); }
.loved-brand-hero .loved-brand-scents { font-size: clamp(0.72rem, 1.5vw, 0.92rem); letter-spacing: 0.38em; }

.loved-brand-lg .loved-brand-script { font-size: clamp(3rem, 8vw, 4.8rem); }
.loved-brand-lg .loved-brand-scents { font-size: clamp(0.78rem, 1.6vw, 1rem); }

.loved-brand-inline .loved-brand-script { font-size: 1.15rem; }
.loved-brand-inline .loved-brand-scents { font-size: 0.52rem; letter-spacing: 0.3em; }

.home-hero-community {
 margin: 0 0 1.25rem;
 border-radius: 16px;
 overflow: hidden;
 border: 1px solid var(--border, #e6e0d6);
 box-shadow: 0 8px 24px rgba(26, 23, 20, 0.06);
}

.home-hero-community img {
 display: block;
 width: 100%;
 height: auto;
 aspect-ratio: 16 / 9;
 object-fit: cover;
}

.hero-brand-showcase {
 display: flex;
 flex-wrap: wrap;
 align-items: center;
 justify-content: center;
 gap: 1.5rem 2.5rem;
 margin-bottom: 1.25rem;
}

.loved-bottle-mockup {
 width: min(9rem, 28vw);
 height: auto;
 flex-shrink: 0;
 filter: drop-shadow(0 12px 28px rgba(0, 0, 0, 0.08));
}

.loved-brand-hero-wrap {
 display: flex;
 justify-content: center;
}

.lovescents-logo--hero {
 height: clamp(72px, 16vw, 112px);
 max-width: min(420px, 88vw);
 margin-inline: auto;
}

.lovescents-logo--lg {
 height: clamp(96px, 18vw, 148px);
 max-width: min(480px, 92vw);
 margin-inline: auto;
}

.lovescents-logo--inline {
 height: 30px;
 max-width: 180px;
 display: inline-block;
 vertical-align: middle;
}

.main-logo {
 margin-bottom: 1rem;
}

.nav-links {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 1;
  min-width: 0;
  opacity: 0;
  transition: opacity 0.18s ease;
}

.nav-links--ready {
 opacity: 1;
}

.nav-links > a:not([class]) {
 display: inline-flex;
 align-items: center;
 min-height: 2.15rem;
 padding: 0.4rem 0.82rem;
 border-radius: 999px;
 font-size: 0.875rem;
 font-weight: 500;
 color: var(--muted);
 text-decoration: none;
}

.nav-links > a:not([class]):hover {
 color: var(--accent);
 background: color-mix(in srgb, var(--accent) 8%, transparent);
 text-decoration: none;
}

.nav-panel {
  display: flex;
  align-items: center;
  gap: 0.2rem 0.45rem;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.nav-menu {
 display: flex;
 align-items: center;
 gap: 0.15rem;
 list-style: none;
 margin: 0;
 padding: 0;
}

.nav-admin-block {
 width: 100%;
 padding-bottom: 0.55rem;
 margin-bottom: 0.55rem;
 border-bottom: 1px solid color-mix(in srgb, #b71c1c 22%, var(--border));
}

.nav-admin-label {
 margin: 0 0 0.35rem;
 padding: 0 0.55rem;
 font-size: 0.68rem;
 font-weight: 800;
 letter-spacing: 0.08em;
 text-transform: uppercase;
 color: #b71c1c;
}

.nav-menu--admin .nav-link {
 color: #8e0000;
 font-weight: 700;
}

.nav-menu--admin .nav-link:hover,
.nav-menu--admin .nav-link--active {
 color: #fff;
 background: #b71c1c;
 border-color: #b71c1c;
}

.nav-link {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 min-height: 2.15rem;
 padding: 0.4rem 0.82rem;
 border-radius: 999px;
 font-size: 0.875rem;
 font-weight: 500;
 color: var(--muted);
 text-decoration: none;
 border: 1px solid transparent;
 background: transparent;
 cursor: pointer;
 font-family: inherit;
 line-height: 1.2;
 white-space: nowrap;
 transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}

.nav-link:hover {
 color: var(--accent);
 background: color-mix(in srgb, var(--accent) 8%, transparent);
 text-decoration: none;
}

.nav-link--active {
 color: var(--accent);
 font-weight: 600;
 background: color-mix(in srgb, var(--accent) 12%, transparent);
 border-color: color-mix(in srgb, var(--accent) 24%, transparent);
}

.nav-link--ghost:hover {
 background: color-mix(in srgb, var(--danger) 10%, transparent);
 color: var(--accent);
}

.nav-actions {
 display: flex;
 align-items: center;
 gap: 0.45rem;
 padding-left: 0.55rem;
 margin-left: 0.15rem;
 border-left: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
}

.nav-account {
 position: relative;
}

.nav-account-trigger {
 display: inline-flex;
 align-items: center;
 gap: 0.45rem;
 max-width: 12.5rem;
 padding: 0.2rem 0.55rem 0.2rem 0.2rem;
 border: 1px solid color-mix(in srgb, var(--accent) 16%, var(--border));
 border-radius: 999px;
 background: var(--brand-white);
 color: var(--text);
 cursor: pointer;
 font: inherit;
 line-height: 1.2;
 transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.nav-account-trigger:hover,
.nav-account--open .nav-account-trigger {
 border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
 box-shadow: 0 4px 16px color-mix(in srgb, var(--accent) 12%, transparent);
}

.nav-account-avatar {
 width: 2rem;
 height: 2rem;
 border-radius: 50%;
 object-fit: cover;
 flex-shrink: 0;
}

.nav-account-avatar--fallback {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 background: color-mix(in srgb, var(--accent) 18%, var(--surface));
 color: var(--accent);
 font-weight: 700;
 font-size: 0.9rem;
}

.nav-account-label {
 display: flex;
 flex-direction: column;
 align-items: flex-start;
 min-width: 0;
 text-align: left;
}

.nav-account-name {
 font-size: 0.86rem;
 font-weight: 600;
 max-width: 7.5rem;
 overflow: hidden;
 text-overflow: ellipsis;
 white-space: nowrap;
}

.nav-account-badge {
 font-size: 0.66rem;
 font-weight: 600;
 letter-spacing: 0.03em;
 text-transform: uppercase;
 color: var(--accent);
}

.nav-account-badge--pending {
 color: var(--muted);
}

.nav-account-chevron {
 width: 0.45rem;
 height: 0.45rem;
 border-right: 2px solid currentColor;
 border-bottom: 2px solid currentColor;
 transform: rotate(45deg) translateY(-1px);
 margin-left: 0.1rem;
 flex-shrink: 0;
 transition: transform 0.15s ease;
}

.nav-account--open .nav-account-chevron {
 transform: rotate(225deg) translateY(1px);
}

.nav-account-menu {
 display: none;
 position: absolute;
 top: calc(100% + 0.45rem);
 right: 0;
 width: min(16rem, calc(100vw - 2rem));
 padding: 0.85rem;
 border-radius: var(--radius-lg);
 border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--border));
 background: var(--brand-white);
 box-shadow: var(--shadow-soft);
 z-index: 40;
}

.nav-account--open .nav-account-menu {
 display: block;
}

.nav-account-identity {
 margin: 0;
 font-size: 0.82rem;
 font-weight: 600;
 color: var(--text);
}

.nav-account-email {
 margin: 0.15rem 0 0.65rem;
 font-size: 0.76rem;
 color: var(--muted);
 word-break: break-word;
}

.nav-account-links {
 list-style: none;
 margin: 0;
 padding: 0.35rem 0 0;
 border-top: 1px solid var(--border);
}

.nav-account-link {
 display: block;
 padding: 0.45rem 0.15rem;
 font-size: 0.88rem;
 color: var(--text);
 text-decoration: none;
 border-radius: 8px;
}

.nav-account-link:hover {
 color: var(--accent);
 background: color-mix(in srgb, var(--accent) 8%, transparent);
 text-decoration: none;
}

.nav-account-signout {
 width: 100%;
 margin-top: 0.55rem;
 padding: 0.55rem 0.75rem;
 border: 1px solid color-mix(in srgb, var(--danger) 24%, var(--border));
 border-radius: 10px;
 background: transparent;
 color: var(--text);
 font: inherit;
 font-size: 0.86rem;
 cursor: pointer;
}

.nav-account-signout:hover {
 background: color-mix(in srgb, var(--danger) 8%, transparent);
 color: var(--accent);
}

.nav-cta {
 border-radius: 999px;
 padding-inline: 1rem;
 font-weight: 600;
 box-shadow: 0 4px 18px color-mix(in srgb, var(--primary) 28%, transparent);
}

.nav-offline {
 font-size: 0.82rem;
 color: var(--muted);
}

.nav-toggle {
 display: none;
 width: 2.65rem;
 height: 2.65rem;
 border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
 border-radius: 14px;
 background: var(--brand-white);
 color: var(--text);
 cursor: pointer;
 padding: 0.45rem;
 flex-direction: column;
 align-items: center;
 justify-content: center;
 gap: 0.28rem;
 flex-shrink: 0;
 transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.nav-toggle:hover {
 border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
 color: var(--accent);
}

.nav-toggle-bar {
 display: block;
 width: 1.1rem;
 height: 2px;
 border-radius: 999px;
 background: currentColor;
 transition: transform 0.2s ease, opacity 0.2s ease;
}

.nav-links--open .nav-toggle-bar:nth-child(1) {
 transform: translateY(5px) rotate(45deg);
}

.nav-links--open .nav-toggle-bar:nth-child(2) {
 opacity: 0;
}

.nav-links--open .nav-toggle-bar:nth-child(3) {
 transform: translateY(-5px) rotate(-45deg);
}

@media (min-width: 769px) {
 .nav-panel {
  padding: 0.3rem 0.35rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 94%, var(--brand-white));
  box-shadow: var(--shadow-card);
 }

 .nav-admin-block {
  width: auto;
  padding-bottom: 0;
  margin-bottom: 0;
  padding-right: 0.35rem;
  margin-right: 0.2rem;
  border-bottom: none;
  border-right: 1px solid color-mix(in srgb, #b71c1c 20%, var(--border));
 }

 .nav-admin-label {
  display: none;
 }

 .nav-menu--admin {
  flex-direction: row;
  gap: 0.1rem;
 }

 .nav-actions {
  padding-left: 0.35rem;
  margin-left: 0.25rem;
 }
}

@media (max-width: 768px) {
 .nav-toggle {
  display: inline-flex;
 }

 .nav-panel {
  display: none;
  position: absolute;
  top: calc(100% + 0.45rem);
  right: 0;
  left: 0;
  flex-direction: column;
  align-items: stretch;
  gap: 0.75rem;
  padding: 0.9rem;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--border));
  background: var(--brand-white);
  box-shadow: var(--shadow-soft);
 }

 .nav-links--open .nav-panel {
  display: flex;
 }

 .nav-admin-block {
  padding-bottom: 0.75rem;
  margin-bottom: 0.75rem;
 }

 .nav-menu--admin {
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  gap: 0.25rem;
 }

 .nav-menu {
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  gap: 0.25rem;
 }

 .nav-menu .nav-link {
  justify-content: flex-start;
  width: 100%;
 }

 .nav-actions {
  width: 100%;
  margin: 0;
  padding: 0.65rem 0 0;
  border-left: none;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
 }

 .nav-actions .nav-cta {
  flex: 1 1 auto;
  justify-content: center;
 }

 .nav-account {
  width: 100%;
 }

 .nav-account-trigger {
  width: 100%;
  max-width: none;
  justify-content: flex-start;
 }

 .nav-account-menu {
  position: static;
  width: 100%;
  margin-top: 0.35rem;
  box-shadow: none;
 }

 .nav-account--open .nav-account-menu {
  display: block;
 }
}

.page {
 max-width: var(--max);
 margin: 0 auto;
 padding: 2rem 1.25rem 4rem;
}

.page-narrow {
 max-width: 440px;
}

.section-title {
 margin: 0 0 0.5rem;
 font-size: clamp(1.5rem, 4vw, 2rem);
}

/* - - Buttons - - */
.btn {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 gap: 0.4rem;
 padding: 0.75rem 1.2rem;
 border-radius: 10px;
 font-weight: 600;
 font-size: 0.92rem;
 border: none;
 cursor: pointer;
 text-decoration: none;
 transition: transform 0.15s ease, background 0.15s ease;
}

.btn:hover {
 text-decoration: none;
 transform: translateY(-1px);
}

.btn-primary {
 background: var(--primary);
 color: #ffffff;
}

.btn-primary:hover {
 background: var(--primary-dark);
 color: #ffffff;
}

.btn-secondary {
 background: transparent;
 color: var(--text);
 border: 1px solid var(--border);
}

.btn-sm {
 padding: 0.45rem 0.85rem;
 font-size: 0.82rem;
}

.link-btn {
 background: none;
 border: none;
 color: var(--accent);
 cursor: pointer;
 font: inherit;
 padding: 0;
 text-decoration: underline;
}

/* - - Forms / auth - - */
.auth-card {
 background: var(--surface);
 border: 1px solid var(--border);
 border-radius: var(--radius);
 padding: 1.5rem;
}

.auth-card h1 {
 font-size: 1.45rem;
 margin-bottom: 0.5rem;
}

.auth-card label {
 display: block;
 font-weight: 600;
 font-size: 0.85rem;
 margin: 0.85rem 0 0.3rem;
}

.auth-card input[type="text"],
.auth-card input[type="email"],
.auth-card input[type="password"] {
 width: 100%;
 border: 1px solid var(--border);
 border-radius: 10px;
 padding: 0.7rem 0.85rem;
 font: inherit;
 color: var(--text);
 background: var(--bg);
 min-height: 2.75rem;
}

.auth-card input:focus {
 outline: 2px solid var(--accent-soft);
 border-color: var(--accent);
}

.check-row {
 display: flex;
 align-items: flex-start;
 gap: 0.5rem;
 margin-top: 0.85rem;
 font-size: 0.9rem;
 font-weight: 400;
}

.check-row input {
 margin-top: 0.2rem;
}

.policy-notice {
 margin: 1rem 0 0;
 padding: 0.85rem 1rem;
 font-size: 0.88rem;
 line-height: 1.5;
 color: var(--text);
 background: var(--accent-soft);
 border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border));
 border-radius: 10px;
}

.policy-notice strong {
 color: var(--accent);
}

.msg-error {
 color: var(--danger);
 font-size: 0.88rem;
 margin-top: 0.75rem;
}

.msg-success {
 color: var(--success);
 font-size: 0.88rem;
 margin-top: 0.75rem;
}

.grid-2 {
 display: grid;
 gap: 1rem;
}

@media (min-width: 720px) {
 .grid-2 {
  grid-template-columns: 1fr 1fr;
 }
}

/* - - Join / fees - - */
.plan-picker {
 display: grid;
 gap: 0.65rem;
 margin-bottom: 1rem;
}

.plan-option {
 display: flex;
 gap: 0.65rem;
 align-items: flex-start;
 padding: 0.85rem;
 border: 1px solid var(--border);
 border-radius: 10px;
 cursor: pointer;
}

.plan-option:has(input:checked) {
 border-color: var(--accent);
 background: var(--accent-soft);
}

.plan-option input {
 margin-top: 0.2rem;
}

.plan-option-body {
 display: flex;
 flex-direction: column;
 gap: 0.15rem;
}

.fee-intro {
 font-size: 0.9rem;
 color: var(--muted);
}

.fee-table {
 width: 100%;
 border-collapse: collapse;
 font-size: 0.85rem;
 margin-top: 0.75rem;
}

.fee-table th,
.fee-table td {
 border-bottom: 1px solid var(--border);
 padding: 0.55rem 0.35rem;
 text-align: left;
 vertical-align: top;
}

.fee-total-row td {
 font-weight: 600;
 color: var(--accent);
}

.hero-actions {
 display: flex;
 flex-wrap: wrap;
 gap: 0.65rem;
 justify-content: center;
 margin-top: 1.5rem;
}

.waitlist-stat {
 margin: 0.75rem auto 0;
 max-width: 34rem;
 font-size: 0.9rem;
}

.founding-badge {
 padding: 0.65rem 0.85rem;
 border-radius: 10px;
 border: 1px solid var(--border);
 background: var(--accent-soft);
 color: var(--accent);
}

.hp-field {
 position: absolute;
 left: -9999px;
 width: 1px;
 height: 1px;
 overflow: hidden;
}

/* - - 2026 refresh: pages, notes, recommendations - - */
.page {
 max-width: var(--nav-max);
 margin: 0 auto;
 padding: 2rem 1.25rem 4rem;
}

.section-title {
 font-family: var(--font-display);
 font-size: clamp(1.85rem, 4vw, 2.45rem);
 letter-spacing: -0.02em;
 margin: 0 0 0.65rem;
}

.home-hero-panel {
 text-align: center;
 padding: 2.5rem 1.5rem 2rem;
 border-radius: var(--radius-lg);
 border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border));
 background:
  radial-gradient(ellipse 70% 55% at 50% 0%, var(--accent-soft), transparent 70%),
  linear-gradient(180deg, var(--surface-elevated), var(--surface));
 box-shadow: var(--shadow-soft);
}

.page-hero {
 margin-bottom: 2rem;
}

.page-hero h1 {
 margin: 0 0 0.65rem;
}

.page-hero p {
 margin: 0 auto;
 max-width: 36rem;
 color: var(--muted);
}

.note-pyramid {
 display: grid;
 gap: 0.28rem;
 margin-top: 0.35rem;
}

.note-row {
 display: grid;
 grid-template-columns: 3.2rem 1fr;
 gap: 0.35rem;
 font-size: 0.72rem;
 line-height: 1.35;
}

.note-label {
 color: var(--pro-text-muted, var(--muted));
 font-weight: 600;
 text-transform: uppercase;
 letter-spacing: 0.05em;
 font-size: 0.62rem;
}

.note-values {
 color: var(--pro-text, var(--text));
}

.note-pyramid--compact .note-row {
 grid-template-columns: 2.6rem 1fr;
}

.shelf-legacy-note {
 margin: 0.25rem 0 0;
 font-size: 0.72rem;
 color: var(--pro-text-muted, var(--muted));
 font-style: italic;
}

.scent-rec-grid {
 display: grid;
 gap: 0.85rem;
}

@media (min-width: 640px) {
 .scent-rec-grid {
  grid-template-columns: repeat(2, 1fr);
 }
}

.scent-rec-card {
 padding: 1rem 1.05rem;
 border-radius: 14px;
 border: 1px solid color-mix(in srgb, var(--pro-accent, var(--accent)) 18%, var(--pro-border, var(--border)));
 background: color-mix(in srgb, var(--pro-accent, var(--accent)) 4%, var(--pro-bg, var(--bg)));
}

.scent-rec-card h3 {
 margin: 0 0 0.35rem;
 font-size: 0.95rem;
 font-weight: 700;
}

.scent-rec-card h3 span {
 display: block;
 font-weight: 500;
 color: var(--pro-text-muted, var(--muted));
 font-size: 0.82rem;
}

/* Unified brand footer (all domains) */
.brand-foot {
 margin-top: 2.5rem;
 padding: 2rem 1.25rem 2.5rem;
 border-top: 1px solid var(--border);
 background: color-mix(in srgb, var(--accent) 3%, var(--surface));
}

.brand-foot-inner {
 max-width: var(--nav-max);
 margin: 0 auto;
 text-align: center;
}

.brand-foot-tagline {
 margin: 0 0 1rem;
 font-size: 0.88rem;
 color: var(--muted);
 line-height: 1.55;
 max-width: 40rem;
 margin-inline: auto;
}

.brand-foot-links {
 display: flex;
 flex-wrap: wrap;
 justify-content: center;
 gap: 0.5rem 1.1rem;
 margin-bottom: 1rem;
}

.brand-foot-links a {
 font-size: 0.88rem;
 font-weight: 600;
 color: var(--text);
 text-decoration: none;
}

.brand-foot-links a:hover {
 color: var(--accent);
}

.brand-foot-copy {
 margin: 0;
 font-size: 0.8rem;
 color: var(--muted);
}

.trust-badge--inline {
 padding: 0.18rem 0.5rem;
 font-size: 0.62rem;
 vertical-align: middle;
}

.scent-rec-reason {
 margin: 0 0 0.5rem;
 font-size: 0.82rem;
 color: var(--pro-text-muted, var(--muted));
}