/* ================================================================
   The Longevity Edge — Components
   Production version of the component library used in mockups.
   Depends on tokens.css for CSS variables.
   ================================================================ */

/* === Base reset / type === */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; font-size: 16px; scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--canvas);
	color: var(--ink-900);
	font-family: var(--font-body);
	font-size: var(--body-fs);
	line-height: var(--lh-relaxed);
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
img, svg, picture, video { max-width: 100%; height: auto; display: block; }
a { color: var(--gold-600); text-decoration: underline; text-underline-offset: 0.18em; text-decoration-thickness: 0.06em; }
a:hover { color: var(--cta-600); }

/* Headings — also set in theme.json but mirrored here for non-block contexts */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 600;
	color: var(--navy-900);
	line-height: var(--lh-snug);
	margin: 0 0 var(--s-4);
}
h1 { font-size: var(--fs-4xl); line-height: var(--lh-tight); letter-spacing: var(--ls-tight); font-weight: 700; }
h2 { font-size: var(--fs-3xl); letter-spacing: var(--ls-tight); }
h3 { font-size: var(--fs-2xl); }
h4 { font-size: var(--fs-xl); font-weight: 500; }
p { margin: 0 0 var(--s-4); }

/* === Layout containers === */
.container       { max-width: var(--container);      margin: 0 auto; padding: 0 var(--s-5); }
.container-wide  { max-width: var(--container-wide); margin: 0 auto; padding: 0 var(--s-5); }
.container-text  { max-width: var(--container-text); margin: 0 auto; padding: 0 var(--s-5); }

.eyebrow { font-family: var(--font-body); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-widest); color: var(--gold-600); font-weight: 700; margin: 0 0 var(--s-3); }
.lede    { font-size: var(--fs-lg); color: var(--ink-700); max-width: 60ch; line-height: var(--lh-relaxed); }

/* === Sections === */
.section    { padding: var(--s-9) 0; }
.section-sm { padding: var(--s-7) 0; }
.section-lg { padding: var(--s-10) 0; }
.section + .section { padding-top: 0; }
.section-head { text-align: center; margin-bottom: var(--s-8); }
.section-head .lede { margin: var(--s-3) auto 0; }

/* === Skip link (accessibility) === */
.le-skip-link {
	position: absolute;
	left: 0;
	top: -100px;
	z-index: 10000;
	background: var(--navy-900);
	color: #fff;
	padding: var(--s-3) var(--s-5);
	border-radius: 0 0 var(--r-md) 0;
	font-family: var(--font-body);
	font-weight: 700;
	font-size: var(--fs-sm);
	text-decoration: none;
	transition: top var(--t-fast) var(--ease-out);
}
.le-skip-link:focus { top: 0; outline: 3px solid var(--gold-300); outline-offset: 0; color: #fff; }

/* === Buttons === */
.btn {
	display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
	font-family: var(--font-body); font-weight: 600; font-size: var(--fs-base);
	min-height: 52px; padding: 0 var(--s-6);
	border-radius: var(--r-md); border: 2px solid transparent;
	text-decoration: none; cursor: pointer; line-height: 1; letter-spacing: 0.01em;
	transition: background var(--t-default) var(--ease-out),
		border-color var(--t-default) var(--ease-out),
		transform var(--t-fast) var(--ease-out);
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: 3px solid var(--gold-300); outline-offset: 2px; }

.btn-primary   { background: var(--cta-600);  color: #fff; border-color: var(--cta-600); }
.btn-primary:hover { background: var(--cta-700); border-color: var(--cta-700); color: #fff; }
.btn-secondary { background: var(--navy-900); color: #fff; border-color: var(--navy-900); }
.btn-secondary:hover { background: var(--navy-800); border-color: var(--navy-800); color: #fff; }
.btn-outline   { background: transparent; color: var(--navy-900); border-color: var(--navy-900); }
.btn-outline:hover { background: var(--navy-900); color: #fff; }
.btn-ghost     { background: transparent; color: var(--navy-900); border-color: transparent;
                 text-decoration: underline; text-underline-offset: 0.2em; text-decoration-thickness: 0.06em;
                 text-decoration-color: var(--gold-500); padding: 0 var(--s-3); }
.btn-ghost:hover { color: var(--gold-600); text-decoration-color: var(--gold-600); }

.btn-lg { font-size: var(--fs-lg); padding: 0 var(--s-7); min-height: 60px; }
.btn-sm { font-size: var(--fs-sm); padding: 0 var(--s-4); min-height: 40px; }
.btn-block { width: 100%; }
.btn[disabled] { background: var(--ink-300); border-color: var(--ink-300); color: #fff; cursor: not-allowed; }

/* === Forms === */
.field { display: flex; flex-direction: column; gap: var(--s-2); margin-bottom: var(--s-4); }
.field-label { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); color: var(--navy-900); }
.field-input, .field-select, .field-textarea {
	font-family: var(--font-body); font-size: var(--fs-base); color: var(--ink-900);
	background: var(--surface); border: 1.5px solid var(--ink-300); border-radius: var(--r-md);
	padding: var(--s-3) var(--s-4); min-height: var(--tap-min);
	transition: border-color var(--t-default) var(--ease-out), box-shadow var(--t-default) var(--ease-out);
}
.field-input:focus, .field-select:focus, .field-textarea:focus {
	outline: none; border-color: var(--navy-900); box-shadow: 0 0 0 3px rgba(14,26,43,0.12);
}
.field-textarea { min-height: 120px; resize: vertical; }
.field-help { font-size: var(--fs-xs); color: var(--ink-500); }

/* === Badges === */
.badge {
	display: inline-flex; align-items: center; gap: var(--s-2);
	font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 700;
	letter-spacing: var(--ls-wide); text-transform: uppercase;
	padding: var(--s-2) var(--s-3); border-radius: var(--r-pill);
	line-height: 1; min-height: 24px;
}
.badge-popular    { background: var(--cta-600); color: #fff; }
.badge-bestseller { background: var(--gold-100); color: var(--gold-600); }
.badge-save       { background: var(--success-50); color: var(--success); }
.badge-new        { background: var(--navy-900); color: #fff; }

/* === Guarantee stamp (horizontal SVG, 200×60) === */
.guarantee-stamp,
.guarantee-seal { display: inline-block; width: 200px; height: 60px; flex-shrink: 0; }
.guarantee-stamp svg, .guarantee-seal svg { width: 100%; height: auto; display: block; }
.guarantee-stamp--sm, .guarantee-seal--sm { width: 160px; }
.guarantee-stamp--lg, .guarantee-seal--lg { width: 260px; }

/* === Header === */
.site-header {
	position: sticky; top: 0; z-index: var(--z-sticky);
	background: rgba(250,247,242,0.95);
	-webkit-backdrop-filter: saturate(140%) blur(8px);
	backdrop-filter: saturate(140%) blur(8px);
	border-bottom: 1px solid var(--navy-100);
}
.site-header-inner { max-width: var(--container-wide); margin: 0 auto; padding: var(--s-3) var(--s-5);
	display: flex; align-items: center; justify-content: space-between; gap: var(--s-5); }
.site-logo { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-lg); color: var(--navy-900); letter-spacing: 0.04em; text-decoration: none; }
.site-logo:hover { color: var(--navy-900); }
.site-nav { display: flex; gap: var(--s-6); align-items: center; }
.site-nav a { color: var(--navy-900); text-decoration: none; font-family: var(--font-body); font-weight: 500; font-size: var(--fs-sm); transition: color var(--t-default) var(--ease-out); }
.site-nav a:hover { color: var(--gold-600); }
.site-cart { display: inline-flex; gap: var(--s-2); align-items: center; font-weight: 600; color: var(--navy-900); text-decoration: none; font-size: var(--fs-sm); }
.site-cart-count { background: var(--cta-600); color: #fff; border-radius: var(--r-pill); padding: 2px 8px; font-size: var(--fs-xs); min-width: 22px; text-align: center; line-height: 1.5; font-feature-settings: "tnum","lnum"; }
.site-mobile-toggle { display: none; background: transparent; border: 0; cursor: pointer; padding: var(--s-2); color: var(--navy-900); min-width: var(--tap-min); min-height: var(--tap-min); }
@media (max-width: 900px) { .site-nav { display: none; } .site-mobile-toggle { display: inline-flex; } }

/* === Footer === */
.site-footer { background: var(--navy-900); color: #fff; padding: var(--s-9) 0 var(--s-6); margin-top: var(--s-9); }
.site-footer-inner { max-width: var(--container-wide); margin: 0 auto; padding: 0 var(--s-5); display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--s-7); }
.site-footer h4 { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 700; text-transform: uppercase; letter-spacing: var(--ls-widest); color: var(--gold-300); margin: 0 0 var(--s-4); }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--s-3); }
.site-footer a { color: var(--navy-100); text-decoration: none; font-size: var(--fs-sm); }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.footer-brand { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-xl); color: #fff; letter-spacing: 0.04em; display: block; margin-bottom: var(--s-3); }
.footer-brand-tag { color: var(--navy-100); font-size: var(--fs-sm); max-width: 38ch; line-height: var(--lh-relaxed); }
.site-footer-bottom { max-width: var(--container-wide); margin: var(--s-7) auto 0; padding: var(--s-5) var(--s-5) 0; border-top: 1px solid var(--navy-700); display: flex; justify-content: space-between; align-items: center; color: var(--navy-300); font-size: var(--fs-xs); gap: var(--s-4); flex-wrap: wrap; }
@media (max-width: 900px) { .site-footer-inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .site-footer-inner { grid-template-columns: 1fr; } }

/* === Founder block (footer authenticity) === */
.founder-block { max-width: var(--container-wide); margin: var(--s-8) auto 0; padding: var(--s-6) var(--s-5); background: rgba(229,189,92,0.08); border: 1px solid rgba(229,189,92,0.25); border-radius: var(--r-lg); display: flex; align-items: center; gap: var(--s-5); }
.founder-photo { width: 84px; height: 84px; border-radius: 50%; flex-shrink: 0; border: 2px solid var(--gold-300); overflow: hidden; }
.founder-photo img { width: 100%; height: 100%; object-fit: cover; }
.founder-text { flex: 1; color: var(--navy-100); font-size: var(--fs-sm); line-height: var(--lh-relaxed); }
.founder-text p { margin: 0 0 var(--s-2); }
.founder-signature { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: var(--fs-lg); color: var(--gold-300); margin-top: var(--s-2); display: block; }
.founder-email { display: inline-flex; gap: var(--s-2); align-items: center; color: #fff; font-weight: 600; text-decoration: none; border-bottom: 1px solid var(--gold-300); padding-bottom: 1px; }
.founder-email:hover { color: var(--gold-300); }
@media (max-width: 560px) { .founder-block { flex-direction: column; text-align: center; } }

/* === Trust strip === */
.trust-strip { background: var(--gold-50); padding: var(--s-5) 0; border-top: 1px solid var(--gold-100); border-bottom: 1px solid var(--gold-100); }
.trust-strip-inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--s-5); display: grid; grid-template-columns: repeat(4,1fr); gap: var(--s-5); align-items: start; }
.trust-item { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--s-2); }
.trust-icon { width: 32px; height: 32px; color: var(--gold-600); }
.trust-text { font-family: var(--font-body); font-weight: 500; font-size: var(--fs-sm); color: var(--navy-900); max-width: 22ch; margin: 0; line-height: var(--lh-normal); }
@media (max-width: 768px) { .trust-strip-inner { grid-template-columns: repeat(2,1fr); } }

/* === Product card === */
.product-card { background: var(--surface); border: 1px solid var(--navy-100); border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: transform var(--t-default) var(--ease-out), box-shadow var(--t-default) var(--ease-out); }
.product-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); color: inherit; }
.product-card-img { aspect-ratio: 1/1; background: var(--raised); display: flex; align-items: center; justify-content: center; font-family: var(--font-body); color: var(--ink-500); font-size: var(--fs-sm); position: relative; overflow: hidden; }
.product-card-img img { width: 100%; height: 100%; object-fit: cover; }
.product-card-badges { position: absolute; top: var(--s-4); left: var(--s-4); display: flex; gap: var(--s-2); z-index: 1; }
.product-card-body { padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-3); flex: 1; }
.product-card-eyebrow { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-widest); color: var(--gold-600); font-weight: 700; margin: 0; }
.product-card-title { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-xl); line-height: var(--lh-snug); color: var(--navy-900); margin: 0; }
.product-card-meta { display: flex; align-items: center; gap: var(--s-2); font-size: var(--fs-sm); color: var(--ink-700); }
.product-card-stars { color: var(--star); letter-spacing: 0.06em; line-height: 1; }
.product-card-price { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-xl); color: var(--navy-900); margin: 0; font-feature-settings: "tnum","lnum"; letter-spacing: -0.01em; }
.product-card-price small { font-weight: 400; color: var(--ink-500); font-size: var(--fs-sm); font-feature-settings: normal; }
.product-card-sub { font-size: var(--fs-sm); color: var(--success); font-weight: 600; margin: 0; font-feature-settings: "tnum","lnum"; }
.product-card-cta { margin-top: auto; padding-top: var(--s-3); }

/* === Review card === */
.review { background: var(--surface); border: 1px solid var(--navy-100); border-radius: var(--r-lg); padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-3); }
.review-stars { color: var(--star); font-size: var(--fs-lg); letter-spacing: 0.08em; line-height: 1; }
.review-title { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-lg); color: var(--navy-900); margin: 0; line-height: var(--lh-snug); }
.review-body { font-size: var(--fs-base); color: var(--ink-700); margin: 0; line-height: var(--lh-relaxed); }
.review-byline { font-size: var(--fs-xs); color: var(--ink-500); margin: 0; display: flex; gap: var(--s-2); align-items: center; flex-wrap: wrap; }
.review-byline strong { color: var(--navy-900); font-weight: 600; }
.review-verified { color: var(--success); font-size: var(--fs-xs); font-weight: 600; }

/* === FAQ === */
.faq { border-bottom: 1px solid var(--navy-100); }
.faq-summary { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-lg); color: var(--navy-900); padding: var(--s-5) 0; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: var(--s-4); }
.faq-summary::-webkit-details-marker { display: none; }
.faq-summary::after { content: "+"; font-family: var(--font-body); font-weight: 300; font-size: 1.5em; color: var(--gold-500); flex-shrink: 0; transition: transform var(--t-default) var(--ease-out); }
.faq[open] .faq-summary::after { transform: rotate(45deg); }
.faq-body { padding: 0 0 var(--s-5); color: var(--ink-700); font-size: var(--fs-base); line-height: var(--lh-relaxed); }
.faq-body p:first-child { margin-top: 0; }

/* === Buy box (TLE Subscription Button v30) === */
.buy-box { background: var(--surface); border: 1px solid var(--navy-100); border-radius: var(--r-lg); padding: var(--s-6); box-shadow: var(--shadow-sm); }
.wcso-custom-options { margin: 0; }
.wcso-purchase-type { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); margin-bottom: var(--s-5); }
.wcso-option-box { position: relative; border: 2px solid var(--navy-100); border-radius: var(--r-md); padding: var(--s-4); cursor: pointer; transition: border-color var(--t-default) var(--ease-out), background var(--t-default) var(--ease-out); background: var(--surface); }
.wcso-option-box:hover { border-color: var(--navy-300); }
.wcso-option-box.wcso-active { border-color: var(--navy-900); background: var(--navy-50); }
.wcso-option-box[data-type="subscribe"]::before { content: "BEST VALUE"; position: absolute; top: -10px; left: var(--s-4); background: var(--cta-600); color: #fff; font-size: 10px; font-weight: 700; letter-spacing: var(--ls-widest); padding: 3px 8px; border-radius: var(--r-pill); line-height: 1; }
.wcso-option-box label { cursor: pointer; display: flex; flex-direction: column; gap: var(--s-2); margin: 0; }
.wcso-option-box input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.wcso-option-title { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); color: var(--navy-900); text-transform: uppercase; letter-spacing: var(--ls-wide); }
.wcso-option-price { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-2xl); color: var(--navy-900); line-height: 1; font-feature-settings: "tnum","lnum"; letter-spacing: -0.01em; }
.wcso-option-box[data-type="subscribe"] .wcso-option-price { color: var(--success); }

.wcso-savings { margin-top: var(--s-2); padding-top: var(--s-2); border-top: 1px dashed rgba(45,122,72,0.35); display: flex; flex-direction: column; gap: 2px; font-feature-settings: "tnum","lnum"; }
.wcso-savings-line { font-family: var(--font-body); font-size: var(--fs-xs); color: var(--success); font-weight: 600; display: flex; justify-content: space-between; gap: var(--s-2); line-height: 1.3; }
.wcso-savings-line strong { font-weight: 700; }
.wcso-savings-annual { color: var(--ink-700); font-weight: 500; }
.wcso-savings-annual strong { color: var(--success); font-weight: 700; }
.wcso-savings-locked { display: inline-flex; align-items: center; gap: var(--s-1); font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 700; color: var(--success); background: var(--success-50); padding: 4px 8px; border-radius: var(--r-pill); margin-top: var(--s-2); align-self: flex-start; text-transform: uppercase; letter-spacing: var(--ls-wide); line-height: 1; }
.wcso-savings-locked svg { width: 11px; height: 11px; flex-shrink: 0; }

.wcso-quantity-selector { margin-bottom: var(--s-5); }
.wcso-quantity-selector > label { display: block; font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); color: var(--navy-900); text-transform: uppercase; letter-spacing: var(--ls-wide); margin-bottom: var(--s-3); }
.wcso-quantity-options { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s-2); }
.wcso-quantity-option { border: 2px solid var(--navy-100); border-radius: var(--r-md); padding: var(--s-3); text-align: center; cursor: pointer; background: var(--surface); transition: border-color var(--t-default) var(--ease-out), background var(--t-default) var(--ease-out); position: relative; }
.wcso-quantity-option:hover { border-color: var(--navy-300); }
.wcso-quantity-option.wcso-active { border-color: var(--navy-900); background: var(--navy-50); }
.wcso-quantity-option input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.wcso-quantity-option label { cursor: pointer; display: flex; flex-direction: column; gap: var(--s-1); margin: 0; }
.wcso-quantity-label { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-base); color: var(--navy-900); }
.wcso-quantity-option.wcso-active .wcso-quantity-label { font-weight: 700; }
.wcso-per-bottle-price { font-family: var(--font-body); font-size: var(--fs-xs); color: var(--ink-700); font-weight: 500; font-feature-settings: "tnum","lnum"; }

.wcso-frequency-selector { margin-bottom: var(--s-5); }
.wcso-frequency-selector > label { display: block; font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); color: var(--navy-900); text-transform: uppercase; letter-spacing: var(--ls-wide); margin-bottom: var(--s-3); }
.wcso-frequency-options { display: grid; grid-template-columns: 1fr; gap: var(--s-2); }
.wcso-frequency-option { border: 2px solid var(--navy-100); border-radius: var(--r-md); padding: var(--s-3) var(--s-4); cursor: pointer; background: var(--surface); transition: border-color var(--t-default) var(--ease-out), background var(--t-default) var(--ease-out); position: relative; }
.wcso-frequency-option:hover { border-color: var(--navy-300); }
.wcso-frequency-option.wcso-active { border-color: var(--navy-900); background: var(--navy-50); }
.wcso-frequency-option input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.wcso-frequency-option label { cursor: pointer; font-family: var(--font-body); font-weight: 500; font-size: var(--fs-base); color: var(--navy-900); margin: 0; display: flex; justify-content: space-between; align-items: center; }
.wcso-frequency-savings { color: var(--success); font-size: var(--fs-xs); font-weight: 600; letter-spacing: var(--ls-wide); text-transform: uppercase; }

.wcso-presale-price { color: var(--ink-500); text-decoration: line-through; font-weight: 400; font-size: 0.78em; margin-right: var(--s-1); }
.wcso-sale-price { color: var(--success); font-weight: 700; }

.wcso-add-to-cart { margin-top: var(--s-5); }
.wcso-add-to-cart-btn { width: 100% !important; display: flex; align-items: center; justify-content: center; gap: var(--s-2); font-family: var(--font-body); font-weight: 700; font-size: var(--fs-lg); letter-spacing: 0.01em; min-height: 60px; padding: 0 var(--s-6); background: var(--cta-600); color: #fff; border: 2px solid var(--cta-600); border-radius: var(--r-md); cursor: pointer; transition: background var(--t-default) var(--ease-out), border-color var(--t-default) var(--ease-out), transform var(--t-fast) var(--ease-out); font-feature-settings: "tnum","lnum"; }
.wcso-add-to-cart-btn:hover { background: var(--cta-700); border-color: var(--cta-700); }
.wcso-add-to-cart-btn:active { transform: translateY(1px); }

.buy-box-trust { margin-top: var(--s-5); display: flex; align-items: center; gap: var(--s-4); padding-top: var(--s-4); border-top: 1px solid var(--navy-100); font-size: var(--fs-sm); color: var(--ink-700); }
@media (max-width: 480px) {
	.wcso-purchase-type, .wcso-quantity-options { grid-template-columns: 1fr; }
}

/* === Account dashboard === */
.woocommerce-account .woocommerce { padding: var(--s-7) 0 var(--s-9); background: var(--canvas); min-height: 80vh; }
.woocommerce-account .woocommerce > .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce > .woocommerce-MyAccount-content { display: block; }
.woocommerce-account .woocommerce-MyAccount-navigation { width: 240px; float: left; margin-right: var(--s-7); }
.woocommerce-account .woocommerce-MyAccount-content { margin-left: 280px; }
@media (max-width: 900px) {
	.woocommerce-account .woocommerce-MyAccount-navigation { width: 100%; float: none; margin: 0 0 var(--s-5); }
	.woocommerce-account .woocommerce-MyAccount-content { margin-left: 0; }
}

.account-header { margin-bottom: var(--s-7); }
.account-header h1 { font-size: var(--fs-3xl); margin: 0 0 var(--s-2); color: var(--navy-900); }
.account-header p  { margin: 0; color: var(--ink-700); font-size: var(--fs-lg); }

/* Sidebar nav */
.account-nav { background: var(--surface); border: 1px solid var(--navy-100); border-radius: var(--r-lg); padding: var(--s-3); position: sticky; top: 84px; }
.account-nav ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.account-nav a { display: flex; align-items: center; gap: var(--s-3); padding: var(--s-3) var(--s-4); border-radius: var(--r-md); color: var(--ink-700); text-decoration: none; font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 500; min-height: var(--tap-min); transition: background var(--t-default) var(--ease-out), color var(--t-default) var(--ease-out); }
.account-nav a:hover { background: var(--canvas); color: var(--navy-900); }
.account-nav a.is-active, .account-nav .is-active a { background: var(--navy-900); color: #fff; }
.account-nav a.is-active svg, .account-nav .is-active a svg { color: var(--gold-300); }
.account-nav svg { flex-shrink: 0; color: var(--ink-500); }
.account-nav-divider { border-top: 1px solid var(--navy-100); margin: var(--s-2) 0; list-style: none; }
.account-nav-logout { color: var(--cta-600) !important; }

/* Main column cards */
.account-main { display: flex; flex-direction: column; gap: var(--s-6); }
.account-card { background: var(--surface); border: 1px solid var(--navy-100); border-radius: var(--r-lg); padding: var(--s-6); }
.account-card-head { display: flex; align-items: center; justify-content: space-between; gap: var(--s-4); margin-bottom: var(--s-5); flex-wrap: wrap; }
.account-card-head h2 { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-xl); color: var(--navy-900); margin: 0; letter-spacing: var(--ls-tight); }
.account-card-head .head-meta { font-size: var(--fs-sm); color: var(--ink-700); }

.quick-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-3); }
.quick-action { display: flex; align-items: center; gap: var(--s-3); padding: var(--s-4); background: var(--canvas); border: 1px solid var(--navy-100); border-radius: var(--r-md); text-decoration: none; color: var(--navy-900); transition: border-color var(--t-default) var(--ease-out); min-height: var(--tap-min); }
.quick-action:hover { border-color: var(--navy-700); color: var(--navy-900); }
.quick-action svg { color: var(--gold-600); flex-shrink: 0; }
.quick-action-label { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); color: var(--navy-900); display: block; }
.quick-action-sub { font-size: var(--fs-xs); color: var(--ink-700); display: block; margin-top: 2px; }
@media (max-width: 768px) { .quick-actions { grid-template-columns: 1fr; } }

/* Subscription card */
.sub-card { background: var(--canvas); border: 1px solid var(--navy-100); border-radius: var(--r-lg); padding: var(--s-5); margin-bottom: var(--s-4); }
.sub-card:last-child { margin-bottom: 0; }
.sub-card-top { display: grid; grid-template-columns: auto 1fr auto; gap: var(--s-5); align-items: center; margin-bottom: var(--s-5); }
.sub-card-img { width: 90px; height: 90px; border-radius: var(--r-md); background: var(--raised); display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
.sub-card-img img { width: 100%; height: 100%; object-fit: cover; }
.sub-card-info h3 { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-xl); color: var(--navy-900); margin: 0 0 var(--s-2); letter-spacing: var(--ls-tight); }
.sub-card-info-row { display: flex; align-items: center; gap: var(--s-4); font-size: var(--fs-sm); color: var(--ink-700); flex-wrap: wrap; }
.sub-card-status { display: inline-flex; align-items: center; gap: var(--s-2); font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 700; letter-spacing: var(--ls-wide); text-transform: uppercase; padding: var(--s-1) var(--s-3); border-radius: var(--r-pill); background: var(--success-50); color: var(--success); line-height: 1; min-height: 24px; }
.sub-card-price { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-xl); color: var(--navy-900); font-feature-settings: "tnum","lnum"; text-align: right; letter-spacing: -0.01em; }
.sub-card-price-sub { font-size: var(--fs-xs); color: var(--ink-700); font-weight: 500; margin-top: 2px; text-align: right; }
.sub-card-price-locked { display: inline-flex; align-items: center; gap: var(--s-1); font-size: var(--fs-xs); color: var(--success); font-weight: 700; margin-top: var(--s-2); padding: 3px 8px; background: var(--success-50); border-radius: var(--r-pill); line-height: 1; text-transform: uppercase; letter-spacing: var(--ls-wide); }
.sub-card-price-locked svg { width: 11px; height: 11px; flex-shrink: 0; }

.sub-card-detail { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); padding: var(--s-4) 0; border-top: 1px solid var(--navy-100); border-bottom: 1px solid var(--navy-100); margin-bottom: var(--s-4); }
.sub-detail-item { display: flex; flex-direction: column; gap: 2px; }
.sub-detail-label { font-size: var(--fs-xs); color: var(--ink-500); text-transform: uppercase; letter-spacing: var(--ls-wide); font-weight: 600; }
.sub-detail-value { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-base); color: var(--navy-900); }
.sub-detail-value.next-ship { color: var(--success); }

.sub-card-actions { display: flex; gap: var(--s-2); flex-wrap: wrap; }
.sub-action { display: inline-flex; align-items: center; gap: var(--s-2); font-family: var(--font-body); font-weight: 500; font-size: var(--fs-sm); color: var(--navy-900); background: var(--surface); border: 1.5px solid var(--navy-100); border-radius: var(--r-md); padding: 0 var(--s-4); min-height: 40px; cursor: pointer; text-decoration: none; transition: border-color var(--t-default) var(--ease-out), background var(--t-default) var(--ease-out); }
.sub-action:hover { border-color: var(--navy-700); background: var(--canvas); }
.sub-action svg { color: var(--ink-700); }
.sub-action.is-primary { background: var(--navy-900); color: #fff; border-color: var(--navy-900); }
.sub-action.is-primary:hover { background: var(--navy-800); color: #fff; }
.sub-action.is-primary svg { color: var(--gold-300); }
.sub-action.is-danger { color: var(--cta-600); }
.sub-action.is-danger svg { color: var(--cta-600); }
.sub-action.is-danger:hover { border-color: var(--cta-600); }

@media (max-width: 640px) {
	.sub-card-top { grid-template-columns: auto 1fr; gap: var(--s-3); }
	.sub-card-price { grid-column: 1 / -1; text-align: left; }
	.sub-card-price-sub { text-align: left; }
	.sub-card-detail { grid-template-columns: 1fr 1fr; }
}

/* Subscriber Price Lock callout banner */
.price-lock-banner { display: flex; align-items: center; gap: var(--s-4); background: linear-gradient(95deg, var(--success-50) 0%, var(--gold-50) 100%); border: 1px solid rgba(45,122,72,0.3); border-left: 4px solid var(--success); border-radius: var(--r-md); padding: var(--s-4) var(--s-5); margin-bottom: var(--s-5); }
.price-lock-banner-icon { width: 40px; height: 40px; background: var(--success); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.price-lock-banner-content { flex: 1; min-width: 0; }
.price-lock-banner-content strong { display: block; font-family: var(--font-display); font-weight: 600; font-size: var(--fs-lg); color: var(--navy-900); margin-bottom: 2px; letter-spacing: var(--ls-tight); }
.price-lock-banner-content span { font-size: var(--fs-sm); color: var(--ink-700); line-height: var(--lh-normal); display: block; }
@media (max-width: 560px) { .price-lock-banner { flex-direction: column; text-align: left; align-items: flex-start; } }

/* Order row */
.order-row { display: grid; grid-template-columns: auto 2fr 1fr 1fr auto; gap: var(--s-4); padding: var(--s-4); border: 1px solid var(--navy-100); border-radius: var(--r-md); margin-bottom: var(--s-3); background: var(--canvas); align-items: center; text-decoration: none; color: inherit; transition: border-color var(--t-default) var(--ease-out); }
.order-row:hover { border-color: var(--navy-700); color: inherit; }
.order-row:last-child { margin-bottom: 0; }
.order-img { width: 48px; height: 48px; background: var(--raised); border-radius: var(--r-sm); display: flex; align-items: center; justify-content: center; color: var(--ink-500); font-size: 10px; overflow: hidden; }
.order-img img { width: 100%; height: 100%; object-fit: cover; }
.order-id { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); color: var(--navy-900); margin: 0; }
.order-id-sub { font-size: var(--fs-xs); color: var(--ink-500); margin: 0; }
.order-date { font-size: var(--fs-sm); color: var(--ink-700); }
.order-status { display: inline-flex; align-items: center; font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: var(--ls-wide); padding: var(--s-1) var(--s-3); border-radius: var(--r-pill); background: var(--success-50); color: var(--success); min-height: 22px; line-height: 1; }
.order-status.is-shipped { background: var(--gold-50); color: var(--gold-600); }
.order-status.is-pending { background: var(--navy-50); color: var(--navy-700); }
.order-total { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-base); color: var(--navy-900); text-align: right; font-feature-settings: "tnum","lnum"; }
@media (max-width: 640px) { .order-row { grid-template-columns: auto 1fr; gap: var(--s-3); } .order-row > *:nth-child(n+3) { grid-column: span 2; } }

.helper { font-size: var(--fs-sm); color: var(--ink-700); margin: var(--s-3) 0 0; }

/* === PDP-specific (single-product) === */
.le-stock-confidence { display: inline-flex; align-items: center; gap: var(--s-2); font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; padding: var(--s-2) var(--s-3); border-radius: var(--r-pill); margin: 0 0 var(--s-4); line-height: 1; }
.le-stock-confidence--success { background: var(--success-50); color: var(--success); }
.le-stock-confidence--warning { background: var(--gold-50); color: var(--gold-600); }
.le-stock-confidence--error   { background: var(--cta-100); color: var(--cta-700); }
.le-stock-confidence svg { flex-shrink: 0; }

.le-delivery-estimate { display: flex; align-items: center; gap: var(--s-3); font-size: var(--fs-sm); color: var(--ink-700); padding: var(--s-3) 0; margin: var(--s-4) 0 0; border-top: 1px solid var(--navy-100); }
.le-delivery-estimate svg { color: var(--success); flex-shrink: 0; }
.le-delivery-estimate strong { color: var(--navy-900); }
.le-delivery-cutoff { font-feature-settings: "tnum","lnum"; }

/* CSS scroll-snap product gallery */
.le-pdp-gallery { display: flex; flex-direction: column; gap: var(--s-3); }
.gallery-main { aspect-ratio: 1/1; background: var(--raised); border-radius: var(--r-lg); overflow: hidden; }
.gallery-main-track { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; width: 100%; height: 100%; scrollbar-width: none; }
.gallery-main-track::-webkit-scrollbar { display: none; }
.gallery-slide { flex: 0 0 100%; scroll-snap-align: start; display: flex; align-items: center; justify-content: center; height: 100%; }
.gallery-slide img { width: 100%; height: 100%; object-fit: cover; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-3); margin-top: var(--s-3); }
.gallery-thumb { aspect-ratio: 1/1; border: 2px solid var(--navy-100); border-radius: var(--r-md); background: var(--raised); cursor: pointer; display: flex; align-items: center; justify-content: center; overflow: hidden; transition: border-color var(--t-default) var(--ease-out); text-decoration: none; }
.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery-thumb.is-active { border-color: var(--navy-900); }
.gallery-thumb:hover { border-color: var(--navy-700); }

/* === Utility classes === */
.text-center { text-align: center; }
.flex { display: flex; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.gap-2 { gap: var(--s-2); } .gap-3 { gap: var(--s-3); } .gap-4 { gap: var(--s-4); } .gap-5 { gap: var(--s-5); }
.bg-raised { background: var(--raised); }
.bg-navy   { background: var(--navy-900); color: #fff; }
.bg-gold-50{ background: var(--gold-50); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ================================================================
   Home page sections — extracted from /02-mockups/01-home.html
   ================================================================ */

/* --- Hero (white-fade) --- */
.hero { position: relative; overflow: hidden; min-height: 640px; display: flex; align-items: stretch; border-bottom: 1px solid var(--navy-100); background: #1f1610; }
.hero-bottles-img { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; }
.hero-bottles-img img { width: 100%; height: 100%; object-fit: cover; object-position: right center; display: block; }
.hero-fade { position: absolute; inset: 0; z-index: 1; pointer-events: none; background: linear-gradient(98deg, var(--canvas) 0%, var(--canvas) 28%, rgba(250,247,242,0.92) 38%, rgba(250,247,242,0.6) 50%, rgba(250,247,242,0.18) 62%, transparent 75%); }
.hero-inner { position: relative; z-index: 2; max-width: var(--container-wide); margin: 0 auto; width: 100%; display: grid; grid-template-columns: 5fr 7fr; align-items: center; min-height: 640px; padding: 0 var(--s-5); }
.hero-content { padding: var(--s-9) var(--s-5) var(--s-7) 0; max-width: 560px; }
.hero-eyebrow { font-family: var(--font-body); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-widest); color: var(--gold-600); font-weight: 700; margin: 0 0 var(--s-3); }
.hero-title { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-5xl); line-height: 0.95; letter-spacing: -0.025em; color: var(--navy-900); margin: 0 0 var(--s-4); }
.hero-title em { font-style: italic; color: var(--gold-600); font-weight: 500; }
.hero-sub { font-family: var(--font-body); font-size: var(--fs-lg); line-height: var(--lh-relaxed); color: var(--ink-700); margin: 0 0 var(--s-6); max-width: 38ch; }
.hero-cta-row { display: flex; gap: var(--s-3); align-items: center; flex-wrap: wrap; margin-bottom: var(--s-6); }
.hero-credibility { display: flex; align-items: center; gap: var(--s-4); font-size: var(--fs-sm); color: var(--ink-700); flex-wrap: wrap; }
.hero-credibility-stars { color: var(--star); letter-spacing: 0.08em; }
@media (max-width: 900px) { .hero-inner { grid-template-columns: 1fr; min-height: auto; } .hero { min-height: auto; } .hero-fade { background: linear-gradient(180deg, transparent 0%, rgba(250,247,242,0.6) 50%, var(--canvas) 80%); inset: auto 0 0 0; height: 60%; } .hero-content { padding: var(--s-7) var(--s-5); max-width: 100%; } }

/* --- Why us --- */
.why-section { background: var(--surface); padding: var(--s-9) 0; border-top: 1px solid var(--navy-100); border-bottom: 1px solid var(--navy-100); }
.why-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s-7); margin-top: var(--s-7); }
.why-card { display: flex; flex-direction: column; gap: var(--s-3); text-align: left; }
.why-icon { width: 56px; height: 56px; background: var(--gold-50); border: 1.5px solid var(--gold-300); border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; color: var(--gold-600); margin-bottom: var(--s-2); }
.why-card h3 { font-size: var(--fs-xl); margin: 0; font-weight: 600; }
.why-card p { margin: 0; color: var(--ink-700); font-size: var(--fs-base); line-height: var(--lh-relaxed); }
@media (max-width: 768px) { .why-grid { grid-template-columns: 1fr; gap: var(--s-6); } }

/* --- Authority (Dr. Dave) --- */
.authority { padding: var(--s-9) 0; background: var(--canvas); }
.authority-inner { display: grid; grid-template-columns: 5fr 7fr; gap: var(--s-9); align-items: center; max-width: var(--container); margin: 0 auto; padding: 0 var(--s-5); }
.authority-photo { aspect-ratio: 4/5; border-radius: var(--r-lg); overflow: hidden; background: var(--raised); }
.authority-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.authority-content h2 { margin-bottom: var(--s-4); }
.authority-content .lede { margin-bottom: var(--s-5); }
.authority-quote { font-family: var(--font-display); font-style: italic; font-size: var(--fs-xl); color: var(--navy-900); line-height: var(--lh-snug); border-left: 3px solid var(--gold-500); padding-left: var(--s-5); margin: var(--s-5) 0; }
.authority-creds { display: flex; flex-wrap: wrap; gap: var(--s-5) var(--s-7); margin-top: var(--s-6); padding-top: var(--s-5); border-top: 1px solid var(--navy-100); }
.authority-cred { display: flex; flex-direction: column; gap: 2px; }
.authority-cred-num { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-2xl); color: var(--navy-900); line-height: 1; }
.authority-cred-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-wide); color: var(--ink-700); font-weight: 600; }
@media (max-width: 900px) { .authority-inner { grid-template-columns: 1fr; gap: var(--s-7); } }

/* --- Testimonials section --- */
.testimonials { padding: var(--s-9) 0; background: var(--navy-50); }
.testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s-5); margin-top: var(--s-7); }
@media (max-width: 900px) { .testimonials-grid { grid-template-columns: 1fr; } }

/* --- Articles teaser --- */
.articles-teaser { padding: var(--s-9) 0; background: var(--canvas); }
.articles-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s-5); margin-top: var(--s-7); }
.article-card { background: var(--surface); border: 1px solid var(--navy-100); border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: transform var(--t-default) var(--ease-out), box-shadow var(--t-default) var(--ease-out); }
.article-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); color: inherit; }
.article-card-img { aspect-ratio: 16/10; background: linear-gradient(135deg, var(--gold-100), var(--gold-300)); }
.article-card-img.img-2 { background: linear-gradient(135deg, var(--navy-100), var(--navy-300)); }
.article-card-img.img-3 { background: linear-gradient(135deg, #e9d8c2, #b58c5e); }
.article-card-body { padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-3); flex: 1; }
.article-card-meta { display: flex; align-items: center; gap: var(--s-3); font-size: var(--fs-xs); color: var(--ink-500); text-transform: uppercase; letter-spacing: var(--ls-wide); font-weight: 600; }
.article-card-title { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-xl); line-height: var(--lh-snug); margin: 0; color: var(--navy-900); }
.article-card-excerpt { font-size: var(--fs-base); color: var(--ink-700); margin: 0; line-height: var(--lh-relaxed); }
.article-card-cta { font-size: var(--fs-sm); color: var(--gold-600); font-weight: 600; margin-top: auto; text-decoration: none; }
@media (max-width: 900px) { .articles-grid { grid-template-columns: 1fr; } }

/* --- Featured products section --- */
.featured-section { padding: var(--s-9) 0; background: var(--canvas); }
.featured-section .products-row { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s-5); }
.featured-section .product-card-img { aspect-ratio: 1/1; }
@media (max-width: 900px) { .featured-section .products-row { grid-template-columns: 1fr; } }

/* --- Email capture (dark) --- */
.email-capture { background: var(--navy-900); color: #fff; padding: var(--s-9) 0; position: relative; overflow: hidden; }
.email-capture::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 30%, rgba(229,189,92,0.12) 0%, transparent 50%); pointer-events: none; }
.email-capture-inner { position: relative; z-index: 1; max-width: 680px; margin: 0 auto; padding: 0 var(--s-5); text-align: center; }
.email-capture .eyebrow { color: var(--gold-300); }
.email-capture h2 { color: #fff; font-family: var(--font-display); }
.email-capture .lede { color: var(--navy-100); margin: var(--s-3) auto var(--s-6); }
.email-form { display: flex; gap: var(--s-3); max-width: 480px; margin: 0 auto; flex-wrap: wrap; }
.email-form input[type="email"], .email-form input[type="text"] { flex: 1; min-width: 240px; background: #fff; border: 0; border-radius: var(--r-md); padding: 0 var(--s-5); min-height: 56px; font-family: var(--font-body); font-size: var(--fs-base); color: var(--ink-900); }
.email-form input:focus { outline: none; box-shadow: 0 0 0 3px rgba(200,148,26,0.4); }
.email-fineprint { margin-top: var(--s-4); font-size: var(--fs-xs); color: var(--navy-300); }

/* --- Placeholder form (when no Fluent Form is wired yet) --- */
.email-capture-placeholder { max-width: 480px; margin: 0 auto; display: flex; gap: var(--s-3); flex-wrap: wrap; align-items: stretch; }
.email-capture-placeholder input { flex: 1; min-width: 240px; background: #fff; border: 0; border-radius: var(--r-md); padding: 0 var(--s-5); min-height: 56px; font-family: var(--font-body); font-size: var(--fs-base); color: var(--ink-900); }
.email-capture-placeholder button { background: var(--cta-600); color: #fff; border: 2px solid var(--cta-600); border-radius: var(--r-md); padding: 0 var(--s-7); min-height: 56px; font-family: var(--font-body); font-weight: 600; font-size: var(--fs-lg); cursor: not-allowed; line-height: 1; }
.email-capture-placeholder-note { margin-top: var(--s-3); font-size: var(--fs-xs); color: var(--navy-300); font-style: italic; text-align: center; }

/* --- Fluent Forms (dark-bg context inside .email-capture) --- */
.email-capture .fluentform { max-width: 480px; margin: 0 auto; }
.email-capture .fluentform .ff-el-input--label, .email-capture .fluentform .ff-el-input--label label { display: none !important; }
.email-capture .fluentform .ff-el-form-control, .email-capture .fluentform input[type="email"], .email-capture .fluentform input[type="text"] {
	background: #fff !important; border: 0 !important; border-radius: var(--r-md) !important;
	padding: 0 var(--s-5) !important; min-height: 56px !important; height: 56px !important;
	color: var(--ink-900) !important; font-family: var(--font-body) !important; font-size: var(--fs-base) !important; box-shadow: none !important;
}
.email-capture .fluentform .ff-el-form-control:focus { box-shadow: 0 0 0 3px rgba(229,189,92,0.5) !important; }
.email-capture .fluentform .ff_btn_style, .email-capture .fluentform button[type="submit"], .email-capture .fluentform .ff-btn-submit {
	background: var(--cta-600) !important; color: #fff !important; border: 2px solid var(--cta-600) !important;
	border-radius: var(--r-md) !important; padding: 0 var(--s-7) !important; min-height: 56px !important; height: 56px !important;
	font-family: var(--font-body) !important; font-weight: 600 !important; font-size: var(--fs-lg) !important; letter-spacing: 0.01em !important; cursor: pointer !important; line-height: 1 !important;
}
.email-capture .fluentform .ff_btn_style:hover, .email-capture .fluentform button[type="submit"]:hover { background: var(--cta-700) !important; border-color: var(--cta-700) !important; }
.email-capture .fluentform .ff-message-success { color: var(--gold-300) !important; background: transparent !important; border: 1px solid var(--gold-300) !important; padding: var(--s-3) var(--s-4) !important; border-radius: var(--r-md) !important; }
.email-capture .fluentform .ff-el-group { margin-bottom: 0 !important; }
.email-capture .fluentform form.frm-fluent-form { display: flex; gap: var(--s-3); flex-wrap: wrap; justify-content: center; align-items: stretch; }
.email-capture .fluentform .ff-el-group { flex: 1; min-width: 240px; }
.email-capture .fluentform .ff-el-group.ff_submit_btn_wrapper, .email-capture .fluentform .ff-t-cell:last-child { flex: 0 0 auto; }

/* --- Fluent Form fieldset layout fix --- */
/* The form has one direct child (a fieldset). Flex on the form doesn't reach the groups
   because they're nested inside the fieldset. Move the flex container down one level. */
.email-capture .fluentform form.frm-fluent-form { display: block !important; }
.email-capture .fluentform fieldset {
	display: flex !important;
	gap: var(--s-3) !important;
	flex-wrap: wrap !important;
	align-items: stretch !important;
	justify-content: center !important;
	border: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	max-width: 480px;
	margin-left: auto !important;
	margin-right: auto !important;
}
.email-capture .fluentform fieldset > .ff-el-group { flex: 1 1 240px !important; min-width: 240px !important; margin: 0 !important; }
.email-capture .fluentform fieldset > .ff-el-group.ff_submit_btn_wrapper { flex: 0 0 auto !important; }
.email-capture .fluentform fieldset > input[type="hidden"],
.email-capture .fluentform fieldset > legend.ff_screen_reader_title,
.email-capture .fluentform fieldset > .akismet-fields-container { display: none !important; }
.email-capture .fluentform .ff-el-input--content { margin: 0 !important; }


/* --- Fluent Form one-line override (fix7h) ---
   .ff_submit_btn_wrapper was inheriting min-width:240px from the parent rule,
   forcing 240+240+12 = 492px > 480px container, so the button wrapped. Reset its
   min-width and widen the fieldset slightly for breathing room. */
.email-capture .fluentform fieldset { max-width: 560px !important; }
.email-capture .fluentform fieldset > .ff-el-group.ff_submit_btn_wrapper {
	flex: 0 0 auto !important;
	min-width: 0 !important;
	width: auto !important;
}

/* --- Email-capture spacing tighten (fix7i) ---
   Kadence/theme.json is injecting margin-top: 58px on the H2 and margin-bottom: 32px
   on the eyebrow p. Force the mockup spacing so the section compresses to ~470px. */
.email-capture .eyebrow { margin: 0 0 var(--s-2) !important; }
.email-capture h2 { margin: 0 0 var(--s-4) !important; line-height: var(--lh-tight) !important; }
.email-capture .lede { margin: var(--s-3) auto var(--s-5) !important; }
.email-capture-inner > .fluentform,
.email-capture-inner > .fluentform_wrapper_5 { margin: 0 auto !important; }
.email-capture .email-fineprint { margin-top: var(--s-3) !important; }

/* ==================================================================
   v1.9.50 — 404 + Search results page styles
   ================================================================== */

.le-404, .le-search { padding: var(--s-9) 0 var(--s-9); background: var(--surface); width: 100vw; position: relative; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; min-height: 60vh; }
.le-404 .container, .le-search .container { max-width: 880px; margin: 0 auto; padding: 0 var(--s-5); text-align: center; }

.le-404 h1, .le-search h1 { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-4xl); color: var(--navy-900); margin: 0 0 var(--s-3); letter-spacing: var(--ls-tight); line-height: var(--lh-tight); }
.le-404 .eyebrow, .le-search .eyebrow { color: var(--gold-600); }

.le-404-lede { font-size: var(--fs-lg); color: var(--ink-700); margin: 0 auto var(--s-6); max-width: 56ch; line-height: var(--lh-relaxed); }

.le-404-search, .le-search-form { display: flex; gap: var(--s-3); max-width: 540px; margin: 0 auto var(--s-7); }
.le-404-search input[type="search"], .le-search-form input[type="search"] { flex: 1; height: 48px; padding: 0 var(--s-3); font-family: var(--font-body); font-size: var(--fs-base); color: var(--navy-900); background: var(--canvas); border: 1.5px solid var(--navy-100); border-radius: var(--r-md); }
.le-404-search input[type="search"]:focus, .le-search-form input[type="search"]:focus { outline: none; border-color: var(--gold-600); box-shadow: 0 0 0 3px rgba(196,156,88,0.15); }
.le-404-search .btn, .le-search-form .btn { padding: 0 var(--s-4); height: 48px; line-height: 48px; }

.le-404-links { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); margin: 0 0 var(--s-6); }
@media (max-width: 720px) { .le-404-links { grid-template-columns: 1fr; } }
.le-404-link-card { display: flex; align-items: center; gap: var(--s-3); padding: var(--s-4); background: var(--canvas); border: 1.5px solid var(--navy-100); border-radius: var(--r-md); text-decoration: none; color: var(--ink-900); text-align: left; transition: border-color 180ms var(--ease-out), background 180ms var(--ease-out), transform 180ms var(--ease-out); }
.le-404-link-card:hover { border-color: var(--gold-600); background: var(--gold-50); transform: translateY(-2px); }
.le-404-link-card-icon { width: 44px; height: 44px; border-radius: 50%; background: var(--navy-50); color: var(--navy-900); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.le-404-link-card:hover .le-404-link-card-icon { background: var(--gold-600); color: #fff; }
.le-404-link-card strong { display: block; font-family: var(--font-body); font-weight: 700; color: var(--navy-900); font-size: var(--fs-base); margin-bottom: 2px; }
.le-404-link-card small { display: block; font-size: var(--fs-xs); color: var(--ink-700); }

.le-404-fine { font-size: var(--fs-sm); color: var(--ink-500); margin: 0; }
.le-404-fine a { color: var(--gold-600); font-weight: 600; text-decoration: underline; }

/* Search results listing */
.le-search h1 { text-align: left; }
.le-search .eyebrow { text-align: left; }
.le-search-count { text-align: left; color: var(--ink-500); font-size: var(--fs-sm); margin: 0 0 var(--s-5); }
.le-search-results { list-style: none; margin: 0 0 var(--s-7); padding: 0; display: flex; flex-direction: column; gap: var(--s-5); text-align: left; }
.le-search-result { padding: var(--s-5) 0; border-bottom: 1px solid var(--navy-100); }
.le-search-result:last-child { border-bottom: 0; }
.le-search-result-type { font-size: var(--fs-xs); color: var(--gold-600); font-weight: 700; text-transform: uppercase; letter-spacing: var(--ls-wide); margin: 0 0 4px; }
.le-search-result-title { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-xl); margin: 0 0 8px; line-height: var(--lh-tight); }
.le-search-result-title a { color: var(--navy-900); text-decoration: none; }
.le-search-result-title a:hover { color: var(--gold-600); }
.le-search-result-excerpt { color: var(--ink-700); font-size: var(--fs-base); margin: 0 0 8px; line-height: var(--lh-relaxed); }
.le-search-result-link { color: var(--gold-600); font-weight: 600; text-decoration: underline; font-size: var(--fs-sm); }
.le-search-result-link:hover { color: var(--cta-600); }

.le-search-pagination { display: flex; justify-content: center; gap: 8px; margin: var(--s-5) 0 0; }
.le-search-pagination .page-numbers { display: inline-flex; min-width: 36px; height: 36px; align-items: center; justify-content: center; padding: 0 12px; border: 1px solid var(--navy-100); border-radius: var(--r-sm); color: var(--navy-700); text-decoration: none; font-size: var(--fs-sm); font-weight: 600; }
.le-search-pagination .page-numbers.current { background: var(--navy-900); color: #fff; border-color: var(--navy-900); }
.le-search-pagination .page-numbers:hover:not(.current) { border-color: var(--gold-600); color: var(--gold-600); }

.le-search-empty { padding: var(--s-7) 0; text-align: center; }
.le-search-empty-lede { font-size: var(--fs-lg); color: var(--ink-700); margin: 0 0 var(--s-5); }
.le-search-empty-links { display: inline-flex; flex-wrap: wrap; justify-content: center; gap: var(--s-3); }
.le-search-empty-links .btn { padding: 10px 18px; }
