/*
Theme Name: OnePulse
Theme URI: https://vaoneagency.com
Author: VAOne Agency
Author URI: https://vaoneagency.com
Description: OnePulse v3 — Overlay menu, Cookbook, Community, Speaking, Groups, Frontend Editor, Google Reviews, Newsletter CRM leads. Zero hardcoding.
Version: 3.0.0
License: Proprietary
Text Domain: onepulse
*/

:root {
    --op-primary: #0d1b2a; --op-secondary: #1b2d3e; --op-accent: #e8395a; --op-accent-hover: #c72d4b;
    --op-gold: #f0a500; --op-white: #fff; --op-bg: #f7f8fa; --op-surface: #fff;
    --op-border: #e4e7ec; --op-text: #1a202c; --op-text-secondary: #4a5568; --op-text-muted: #8898a9;
    --op-success: #10b981; --op-warning: #f59e0b; --op-danger: #ef4444; --op-info: #3b82f6;
    --op-font: 'Inter', system-ui, -apple-system, sans-serif;
    --op-radius: 8px; --op-radius-lg: 14px; --op-radius-xl: 20px;
    --op-shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
    --op-shadow-lg: 0 8px 32px rgba(0,0,0,.12); --op-shadow-xl: 0 20px 60px rgba(0,0,0,.18);
    --op-container: 1200px; --op-section-py: 72px; --op-header-h: 64px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: var(--op-font); font-size: 16px; line-height: 1.6; color: var(--op-text); background: var(--op-bg); }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--op-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
button, input, select, textarea { font-family: inherit; }
h1,h2,h3,h4,h5,h6 { line-height: 1.2; font-weight: 700; color: var(--op-text); }

.op-container { max-width: var(--op-container); margin: 0 auto; padding: 0 24px; }
.op-section { padding: 0; }
.op-section--spaced { padding: var(--op-section-py) 0; } /* legacy non-builder sections */
.op-section--tight { padding: 32px 0; } /* used only by non-builder legacy sections */
.op-section--dark { background: var(--op-primary); }
.op-section--dark h1,.op-section--dark h2,.op-section--dark h3,.op-section--dark h4 { color: var(--op-white); }
.op-section--dark p,.op-section--dark span { color: rgba(255,255,255,.7); }
.op-section--gray { background: var(--op-bg); }
.op-section--white { background: var(--op-white); }
.op-section__header { text-align: center; margin-bottom: 48px; }
.op-section__eyebrow { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--op-accent); margin-bottom: 10px; }
.op-section__title { font-size: clamp(1.6rem, 3.5vw, 2.25rem); margin-bottom: 12px; }
.op-section__subtitle { font-size: 1.0625rem; color: var(--op-text-secondary); max-width: 580px; margin: 0 auto; }

.op-grid { display: grid; gap: 24px; }
.op-grid--2 { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.op-grid--3 { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.op-grid--4 { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }

.op-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 22px; font-size: .9375rem; font-weight: 600; line-height: 1;
    border-radius: var(--op-radius); border: 2px solid transparent;
    cursor: pointer; transition: all .18s ease; text-decoration: none !important; white-space: nowrap;
}
.op-btn--primary { background: var(--op-accent); color: #fff !important; border-color: var(--op-accent); }
.op-btn--primary:hover { background: var(--op-accent-hover); border-color: var(--op-accent-hover); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(232,57,90,.35); }
.op-btn--gold { background: var(--op-gold); color: #0d1b2a !important; border-color: var(--op-gold); }
.op-btn--gold:hover { background: #d99200; border-color: #d99200; transform: translateY(-1px); }
.op-btn--outline { background: transparent; color: var(--op-accent) !important; border-color: var(--op-accent); }
.op-btn--outline:hover { background: var(--op-accent); color: #fff !important; transform: translateY(-1px); }
.op-btn--outline-white { background: transparent; color: #fff !important; border-color: rgba(255,255,255,.5); }
.op-btn--outline-white:hover { background: rgba(255,255,255,.12); border-color: #fff; }
.op-btn--ghost { background: rgba(255,255,255,.08); color: rgba(255,255,255,.9) !important; border-color: rgba(255,255,255,.2); }
.op-btn--ghost:hover { background: rgba(255,255,255,.16); border-color: rgba(255,255,255,.4); }
.op-btn--sm { padding: 8px 16px; font-size: .8125rem; }
.op-btn--lg { padding: 14px 28px; font-size: 1rem; }
.op-btn--xl { padding: 17px 36px; font-size: 1.0625rem; }
.op-btn--full { width: 100%; }
.op-btn:disabled { opacity: .5; cursor: not-allowed; transform: none !important; }

.op-card { background: var(--op-surface); border-radius: var(--op-radius-lg); box-shadow: var(--op-shadow); overflow: hidden; transition: transform .2s, box-shadow .2s; border: 1px solid var(--op-border); }
.op-card:hover { transform: translateY(-4px); box-shadow: var(--op-shadow-lg); border-color: transparent; }
.op-card__image { position: relative; aspect-ratio: 16/9; overflow: hidden; background: #e9ecef; }
.op-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.op-card:hover .op-card__image img { transform: scale(1.04); }
.op-card__body { padding: 20px 22px; }
.op-card__meta { font-size: .8125rem; color: var(--op-text-muted); margin-bottom: 6px; display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.op-card__title { font-size: 1.0625rem; margin-bottom: 8px; }
.op-card__desc { font-size: .9rem; color: var(--op-text-secondary); margin-bottom: 14px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.op-card__footer { padding: 14px 22px; border-top: 1px solid var(--op-border); display: flex; align-items: center; justify-content: space-between; gap: 10px; }

.op-badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 100px; font-size: .75rem; font-weight: 600; }
.op-badge--accent { background: #fde8ec; color: var(--op-accent); }
.op-badge--success { background: #d1fae5; color: #065f46; }
.op-badge--warning { background: #fef3c7; color: #92400e; }
.op-badge--info { background: #dbeafe; color: #1e40af; }
.op-badge--muted { background: #f1f5f9; color: #64748b; }
.op-badge--dark { background: rgba(255,255,255,.12); color: #fff; }

.op-header { background: var(--op-primary); height: var(--op-header-h); position: sticky; top: 0; z-index: 1000; border-bottom: 1px solid rgba(255,255,255,.06); transition: box-shadow .2s; }
.op-header.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,.3); }
.op-header__inner { height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.op-header__logo { font-size: 1.25rem; font-weight: 800; color: #fff !important; text-decoration: none !important; letter-spacing: -.02em; flex-shrink: 0; }
.op-header__logo span { color: var(--op-accent); }
.op-nav { display: flex; align-items: center; gap: 4px; list-style: none; flex: 1; }
.op-nav > li > a { display: block; padding: 6px 12px; color: rgba(255,255,255,.7) !important; font-size: .9rem; font-weight: 500; border-radius: 6px; transition: all .15s; text-decoration: none !important; }
.op-nav > li > a:hover { color: #fff !important; background: rgba(255,255,255,.08); }
.op-header__actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.op-cart-btn { position: relative; display: inline-flex; align-items: center; gap: 6px; color: rgba(255,255,255,.8) !important; padding: 7px 12px; border-radius: 6px; transition: all .15s; font-size: .875rem; text-decoration: none !important; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); }
.op-cart-btn:hover { background: rgba(255,255,255,.12); color: #fff !important; }
.op-cart-badge { position: absolute; top: -4px; right: -4px; background: var(--op-accent); color: #fff; font-size: .6rem; font-weight: 700; min-width: 17px; height: 17px; border-radius: 100px; display: flex; align-items: center; justify-content: center; }
.op-hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 6px; }
.op-hamburger span { display: block; width: 22px; height: 2px; background: rgba(255,255,255,.8); border-radius: 2px; transition: all .25s; }

.op-hero { position: relative; min-height: 520px; display: flex; align-items: center; overflow: hidden; background: var(--op-primary); }
.op-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 50%, rgba(232,57,90,.22) 0%, transparent 65%), radial-gradient(ellipse at 5% 80%, rgba(240,165,0,.1) 0%, transparent 55%); }
.op-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: .22; }
.op-hero__content { position: relative; z-index: 1; padding: 60px 0; max-width: 660px; }
.op-hero__eyebrow { font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--op-gold); margin-bottom: 14px; }
.op-hero__title { font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 800; line-height: 1.1; color: #fff; margin-bottom: 18px; }
.op-hero__title em { font-style: normal; background: linear-gradient(90deg, var(--op-accent), var(--op-gold)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.op-hero__subtitle { font-size: 1.075rem; line-height: 1.65; color: rgba(255,255,255,.7); margin-bottom: 32px; max-width: 520px; }
.op-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }
.op-hero__stats { display: flex; gap: 36px; flex-wrap: wrap; margin-top: 48px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1); }
.op-hero__stat-num { font-size: 1.75rem; font-weight: 800; color: #fff; line-height: 1; margin-bottom: 3px; }
.op-hero__stat-label { font-size: .8rem; color: rgba(255,255,255,.5); }

.op-page-hero { background: var(--op-primary); padding: 48px 0 40px; position: relative; overflow: hidden; }
.op-page-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 50%, rgba(232,57,90,.18) 0%, transparent 60%); }
.op-page-hero__inner { position: relative; z-index: 1; }
.op-page-hero__eyebrow { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--op-gold); margin-bottom: 8px; }
.op-page-hero__title { font-size: clamp(1.5rem, 4vw, 2.25rem); color: #fff; font-weight: 800; }
.op-page-hero__sub { font-size: 1rem; color: rgba(255,255,255,.6); margin-top: 8px; }

.op-about-section { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.op-about__visual { border-radius: var(--op-radius-xl); overflow: hidden; aspect-ratio: 4/3; background: var(--op-primary); position: relative; }
.op-about__visual img { width: 100%; height: 100%; object-fit: cover; }
.op-about__visual-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--op-primary), #1e3a5f); font-size: 5rem; }
.op-about__pill { position: absolute; bottom: 20px; left: 20px; background: rgba(13,27,42,.85); backdrop-filter: blur(10px); color: #fff; border-radius: 100px; padding: 8px 16px; font-size: .8rem; font-weight: 600; display: flex; align-items: center; gap: 6px; border: 1px solid rgba(255,255,255,.1); }
.op-about__eyebrow { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--op-accent); margin-bottom: 12px; }
.op-about__title { font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: 16px; }
.op-about__body { font-size: 1rem; color: var(--op-text-secondary); line-height: 1.75; margin-bottom: 24px; }
.op-about__features { display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.op-about__feature { display: flex; align-items: flex-start; gap: 12px; }
.op-about__feature-icon { width: 32px; height: 32px; border-radius: 8px; background: #fde8ec; color: var(--op-accent); display: flex; align-items: center; justify-content: center; font-size: .875rem; flex-shrink: 0; margin-top: 2px; }
.op-about__feature-text { font-size: .9375rem; color: var(--op-text-secondary); line-height: 1.55; }
.op-about__feature-text strong { color: var(--op-text); }

.op-cta-strip { background: linear-gradient(135deg, var(--op-accent) 0%, #a8223b 100%); padding: 56px 0; text-align: center; position: relative; overflow: hidden; }
.op-cta-strip::before { content: ''; position: absolute; top: -50%; left: -10%; width: 400px; height: 400px; background: rgba(255,255,255,.05); border-radius: 50%; }
.op-cta-strip::after { content: ''; position: absolute; bottom: -50%; right: -5%; width: 500px; height: 500px; background: rgba(255,255,255,.04); border-radius: 50%; }
.op-cta-strip__inner { position: relative; z-index: 1; }
.op-cta-strip__title { font-size: clamp(1.5rem, 3.5vw, 2.25rem); color: #fff; font-weight: 800; margin-bottom: 10px; }
.op-cta-strip__sub { font-size: 1.0625rem; color: rgba(255,255,255,.8); margin-bottom: 28px; }
.op-btn--white { background: #fff; color: var(--op-accent) !important; border-color: #fff; font-weight: 700; }
.op-btn--white:hover { background: #f5f5f5; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.2); text-decoration: none; }

.op-features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; }
.op-feature-card { background: #fff; border-radius: var(--op-radius-lg); padding: 24px; border: 1px solid var(--op-border); transition: all .2s; }
.op-feature-card:hover { border-color: var(--op-accent); box-shadow: var(--op-shadow); transform: translateY(-3px); }
.op-feature-card__icon { width: 44px; height: 44px; border-radius: 10px; background: linear-gradient(135deg,#fde8ec,#fef3c7); display: flex; align-items: center; justify-content: center; font-size: 1.25rem; margin-bottom: 14px; }
.op-feature-card__title { font-size: .9375rem; font-weight: 700; margin-bottom: 6px; }
.op-feature-card__desc { font-size: .8125rem; color: var(--op-text-secondary); line-height: 1.55; }

.op-event-date-badge { position: absolute; top: 12px; left: 12px; background: var(--op-accent); color: #fff; border-radius: 8px; padding: 7px 11px; text-align: center; min-width: 48px; line-height: 1; box-shadow: 0 2px 8px rgba(0,0,0,.2); }
.op-event-date-badge .mon { font-size: .625rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.op-event-date-badge .day { font-size: 1.375rem; font-weight: 800; }

.op-product-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: start; }
.op-product-gallery { position: sticky; top: calc(var(--op-header-h) + 24px); }
.op-product-gallery__main { border-radius: var(--op-radius-xl); overflow: hidden; background: #f1f5f9; aspect-ratio: 1; margin-bottom: 12px; display: flex; align-items: center; justify-content: center; }
.op-product-gallery__main img { width: 100%; height: 100%; object-fit: contain; }
.op-product-gallery__thumbs { display: flex; gap: 10px; flex-wrap: wrap; }
.op-product-gallery__thumb { width: 70px; height: 70px; border-radius: 8px; overflow: hidden; border: 2px solid var(--op-border); cursor: pointer; transition: border-color .15s; }
.op-product-gallery__thumb:hover, .op-product-gallery__thumb.active { border-color: var(--op-accent); }
.op-product-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.op-product-info__price { font-size: 2rem; font-weight: 800; color: var(--op-accent); margin: 16px 0 20px; line-height: 1; }
.op-product-info__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }
.op-product-info__divider { border: none; border-top: 1px solid var(--op-border); margin: 24px 0; }
.op-product-info__spec { display: flex; gap: 8px; font-size: .9rem; margin-bottom: 8px; }
.op-product-info__spec-label { color: var(--op-text-muted); min-width: 100px; }
.op-product-info__spec-value { color: var(--op-text); font-weight: 500; }

.op-cart-layout { display: grid; grid-template-columns: 1fr 340px; gap: 28px; align-items: start; }
.op-cart-table { background: #fff; border-radius: var(--op-radius-lg); border: 1px solid var(--op-border); overflow: hidden; }
.op-cart-item { display: grid; grid-template-columns: 76px 1fr auto auto; gap: 16px; align-items: center; padding: 18px 22px; border-bottom: 1px solid var(--op-border); }
.op-cart-item:last-child { border-bottom: none; }
.op-cart-item__img { width: 76px; height: 76px; border-radius: 8px; object-fit: cover; background: #f1f5f9; }
.op-cart-item__name { font-weight: 600; font-size: .9375rem; margin-bottom: 3px; }
.op-cart-item__meta { font-size: .8rem; color: var(--op-text-muted); }
.op-cart-item__price { font-weight: 700; font-size: 1rem; white-space: nowrap; }
.op-cart-qty { display: flex; align-items: center; border: 1px solid var(--op-border); border-radius: 7px; overflow: hidden; }
.op-cart-qty button { width: 30px; height: 30px; border: none; background: #f8f9fa; cursor: pointer; font-size: .875rem; font-weight: 600; transition: background .15s; }
.op-cart-qty button:hover { background: #e9ecef; }
.op-cart-qty__num { width: 36px; text-align: center; font-size: .875rem; font-weight: 600; }
.op-cart-summary { background: #fff; border-radius: var(--op-radius-lg); border: 1px solid var(--op-border); padding: 22px; position: sticky; top: calc(var(--op-header-h) + 20px); }
.op-cart-summary__title { font-size: 1.0625rem; font-weight: 700; margin-bottom: 16px; }
.op-cart-summary__row { display: flex; justify-content: space-between; padding: 7px 0; font-size: .9375rem; }
.op-cart-summary__row--total { font-size: 1.125rem; font-weight: 700; border-top: 1px solid var(--op-border); margin-top: 8px; padding-top: 14px; }

.op-checkout-layout { display: grid; grid-template-columns: 1fr 360px; gap: 28px; align-items: start; }
.op-checkout-form { background: #fff; border-radius: var(--op-radius-lg); border: 1px solid var(--op-border); padding: 28px; }
.op-checkout-form__title { font-size: 1.125rem; font-weight: 700; margin-bottom: 22px; padding-bottom: 14px; border-bottom: 1px solid var(--op-border); }
.op-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.op-form-group { margin-bottom: 16px; }
.op-label { display: block; font-size: .8125rem; font-weight: 600; color: var(--op-text); margin-bottom: 5px; }
.op-label span { color: var(--op-accent); }
.op-input, .op-select, .op-textarea { width: 100%; padding: 10px 12px; border: 1.5px solid var(--op-border); border-radius: var(--op-radius); font-size: .9375rem; background: #fff; color: var(--op-text); transition: border-color .15s, box-shadow .15s; outline: none; }
.op-input:focus,.op-select:focus,.op-textarea:focus { border-color: var(--op-accent); box-shadow: 0 0 0 3px rgba(232,57,90,.1); }
.op-textarea { min-height: 90px; resize: vertical; }

.op-alert { display: flex; align-items: flex-start; gap: 10px; padding: 12px 16px; border-radius: var(--op-radius); font-size: .9rem; margin-bottom: 16px; }
.op-alert--success { background: #d1fae5; color: #065f46; border-left: 4px solid var(--op-success); }
.op-alert--error { background: #fee2e2; color: #991b1b; border-left: 4px solid var(--op-danger); }
.op-alert--info { background: #dbeafe; color: #1e40af; border-left: 4px solid var(--op-info); }

.op-filter-bar { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; padding-bottom: 20px; margin-bottom: 28px; border-bottom: 1px solid var(--op-border); }
.op-filter-count { margin-left: auto; font-size: .875rem; color: var(--op-text-muted); }

.op-empty { text-align: center; padding: 56px 24px; color: var(--op-text-muted); }
.op-empty__icon { font-size: 2.5rem; margin-bottom: 12px; }
.op-empty__title { font-size: 1.125rem; font-weight: 600; color: var(--op-text-secondary); margin-bottom: 8px; }

.op-toast { position: fixed; bottom: 24px; right: 24px; z-index: 9999; background: #1a202c; color: #fff; padding: 13px 20px; border-radius: 10px; font-size: .9rem; font-weight: 500; box-shadow: var(--op-shadow-xl); display: flex; align-items: center; gap: 8px; animation: opToastIn .25s ease; max-width: 320px; }
.op-toast--success { background: #065f46; border-left: 4px solid var(--op-success); }
.op-toast--error { background: #991b1b; border-left: 4px solid var(--op-danger); }
@keyframes opToastIn { from { transform: translateY(20px); opacity: 0; } to { transform: none; opacity: 1; } }

.op-footer { background: var(--op-primary); color: rgba(255,255,255,.6); padding: 52px 0 24px; }
.op-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 36px; margin-bottom: 36px; }
.op-footer__logo { font-size: 1.25rem; font-weight: 800; color: #fff; display: block; margin-bottom: 10px; }
.op-footer__logo span { color: var(--op-accent); }
.op-footer__tagline { font-size: .875rem; line-height: 1.65; margin-bottom: 18px; }
.op-footer__heading { font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #fff; margin-bottom: 14px; }
.op-footer__links { list-style: none; }
.op-footer__links li { margin-bottom: 8px; }
.op-footer__links a { color: rgba(255,255,255,.5); font-size: .875rem; transition: color .15s; }
.op-footer__links a:hover { color: #fff; text-decoration: none; }
.op-footer__bottom { border-top: 1px solid rgba(255,255,255,.08); padding-top: 20px; display: flex; align-items: center; justify-content: space-between; font-size: .8125rem; flex-wrap: wrap; gap: 10px; }
.op-footer__bottom a { color: rgba(255,255,255,.35); transition: color .15s; }
.op-footer__bottom a:hover { color: #fff; text-decoration: none; }

.op-products-section .opsales-product-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important; gap: 24px !important; margin: 0 !important; }
.op-products-section .opsales-product-card { border-radius: var(--op-radius-lg) !important; border: 1px solid var(--op-border) !important; box-shadow: var(--op-shadow) !important; transition: transform .2s, box-shadow .2s !important; overflow: hidden; background: #fff; margin: 0 !important; }
.op-products-section .opsales-product-card:hover { transform: translateY(-4px) !important; box-shadow: var(--op-shadow-lg) !important; border-color: transparent !important; }

@media (max-width: 1024px) {
    .op-footer__grid { grid-template-columns: 1fr 1fr; }
    .op-product-detail { grid-template-columns: 1fr; gap: 28px; }
    .op-product-gallery { position: static; }
    .op-about-section { grid-template-columns: 1fr; gap: 32px; }
    .op-cart-layout, .op-checkout-layout { grid-template-columns: 1fr; }
    .op-cart-summary, .op-checkout-order-summary { position: static; }
}
@media (max-width: 768px) {
    :root { --op-section-py: 48px; --op-header-h: 60px; }
    .op-nav, .op-header__actions .op-btn--ghost { display: none; }
    .op-hamburger { display: flex; }
    .op-nav.is-open { display: flex; flex-direction: column; position: absolute; top: var(--op-header-h); left: 0; right: 0; background: var(--op-secondary); padding: 12px 16px; gap: 2px; box-shadow: 0 8px 24px rgba(0,0,0,.3); z-index: 999; }
    .op-nav.is-open > li > a { color: rgba(255,255,255,.8) !important; padding: 10px 12px; }
    .op-form-row { grid-template-columns: 1fr; }
    .op-footer__grid { grid-template-columns: 1fr; gap: 24px; }
    .op-cart-item { grid-template-columns: 64px 1fr; }
    .op-cart-item__price, .op-cart-qty { grid-column: 2; }
    .op-hero__stats { gap: 20px; margin-top: 36px; }
}
@media (max-width: 480px) {
    .op-container { padding: 0 16px; }
    .op-hero__cta, .op-cta-strip__btns { flex-direction: column; align-items: stretch; }
    .op-btn--xl { width: 100%; }
    .op-grid--2, .op-grid--3, .op-grid--4 { grid-template-columns: 1fr; }
    .op-products-section .opsales-product-grid { grid-template-columns: 1fr !important; }
}

/* ── Section background system v3 ─────────────────────────────────────────── */
/* Sections built by the VAOne Builder use op-section--custom with inline styles.
   These utility classes handle text colour overrides and defaults. */

.op-section--custom { position: relative; }

/* Light text — for dark/image/gradient backgrounds */
.op-section--text-light,
.op-section--text-light h1,
.op-section--text-light h2,
.op-section--text-light h3,
.op-section--text-light h4,
.op-section--text-light p,
.op-section--text-light span,
.op-section--text-light li { color: #fff !important; }
.op-section--text-light .op-section__eyebrow { color: var(--op-gold) !important; }
.op-section--text-light .op-btn--outline { border-color: rgba(255,255,255,.5); color: #fff; }
.op-section--text-light .op-btn--outline:hover { background: rgba(255,255,255,.12); }

/* Dark text — for light/white backgrounds */
.op-section--text-dark,
.op-section--text-dark h1,
.op-section--text-dark h2,
.op-section--text-dark h3,
.op-section--text-dark h4,
.op-section--text-dark p,
.op-section--text-dark span { color: var(--op-text) !important; }

/* Section eyebrow (now surfaced as a standard element) */
.op-section__eyebrow {
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--op-accent);
    margin-bottom: 8px;
}

/* Image+Text section responsive */
@media (max-width: 768px) {
    .op-about-section,
    .op-image-text-grid { grid-template-columns: 1fr !important; }
    .op-image-text-grid > * { order: unset !important; }
}

/* Stats section responsive */
@media (max-width: 640px) {
    .op-stats-grid { grid-template-columns: 1fr 1fr !important; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   SECTION COMPONENT LIBRARY
   All section templates use these classes — zero inline styles for layout.
   Inline styles are limited to dynamic values only (colors from picker,
   background-image URLs, computed border-radius from settings).
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Section header variants ──────────────────────────────────────────────── */
.op-section__header--left   { text-align: left;   margin-bottom: 36px; }
.op-section__header--center { text-align: center; margin-bottom: 36px; }
.op-section__header--right  { text-align: right;  margin-bottom: 36px; }
.op-section__header--center .op-section__subtitle { margin-left: auto; margin-right: auto; }
.op-section__subtitle { font-size: 1.0625rem; color: var(--op-text-secondary); max-width: 580px; line-height: 1.6; }

/* ── Container widths ─────────────────────────────────────────────────────── */
.op-container--narrow { max-width: 760px;  margin: 0 auto; padding: 0 24px; }
.op-container--medium { max-width: 1000px; margin: 0 auto; padding: 0 24px; }
.op-container--wide   { max-width: 1400px; margin: 0 auto; padding: 0 24px; }

/* ── Grid system — named column counts ───────────────────────────────────── */
.op-grid--1 { grid-template-columns: 1fr; }
.op-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.op-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.op-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }
.op-grid--gap-sm { gap: 16px; }
.op-grid--gap-md { gap: 24px; }
.op-grid--gap-lg { gap: 36px; }
.op-grid--gap-xl { gap: 52px; }

/* ── Hero section ─────────────────────────────────────────────────────────── */
.op-hero--section { display: flex; align-items: center; overflow: hidden; width: 100%; }
.op-hero--align-left   .op-hero__content { text-align: left; }
.op-hero--align-center .op-hero__content { text-align: center; margin: 0 auto; }
.op-hero--align-right  .op-hero__content { text-align: right; margin-left: auto; }
.op-hero--align-center .op-hero__cta,
.op-hero--align-right  .op-hero__cta { justify-content: center; }
.op-hero--align-right  .op-hero__cta { justify-content: flex-end; }
.op-hero__content--wide { max-width: 860px; }
.op-hero__content--narrow { max-width: 560px; }

/* ── Event cards ──────────────────────────────────────────────────────────── */
.op-event-card__date-badge {
    position: absolute; top: 12px; left: 12px;
    background: var(--op-accent); color: #fff;
    border-radius: 8px; padding: 7px 11px;
    text-align: center; min-width: 48px; line-height: 1;
    box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.op-event-card__date-badge .month { font-size: .625rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.op-event-card__date-badge .day   { font-size: 1.375rem; font-weight: 800; }
.op-event-card__status { position: absolute; top: 12px; right: 12px; }
.op-event__price { font-size: 1rem; font-weight: 800; color: var(--op-accent); }
.op-event-card--list { display: grid; grid-template-columns: 200px 1fr auto; align-items: center; gap: 0; }
.op-event-card--list .op-card__image { aspect-ratio: unset; height: 100%; min-height: 120px; }
.op-event-card--list .op-card__footer { flex-direction: column; align-items: flex-end; gap: 12px; padding: 20px; border-top: none; border-left: 1px solid var(--op-border); }

/* ── Product cards ────────────────────────────────────────────────────────── */
.op-product__price { font-size: 1.0625rem; font-weight: 800; color: var(--op-accent); }
.op-product__badge { position: absolute; bottom: 10px; left: 10px; }
.op-product-card--list { display: grid; grid-template-columns: 140px 1fr auto; align-items: center; }
.op-product-card--list .op-card__image { height: 100%; aspect-ratio: unset; }
.op-product-card--list .op-card__footer { flex-direction: column; gap: 10px; border-top: none; border-left: 1px solid var(--op-border); }
.op-card__image--placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 2.5rem; }
.op-card__image--placeholder-event { background: linear-gradient(135deg, #1a1a2e, #e94560); }
.op-card__image--placeholder-product { background: linear-gradient(135deg, #f1f5f9, #e2e8f0); }
.op-card__image--placeholder-member { background: linear-gradient(135deg, var(--op-primary), #1e3a5f); }

/* ── Member cards ─────────────────────────────────────────────────────────── */
.op-member-card__avatar {
    width: 72px; height: 72px; border-radius: 50%;
    object-fit: cover; margin: 0 auto 12px;
    border: 3px solid var(--op-border);
    display: block;
}
.op-member-card__avatar--square { border-radius: var(--op-radius); }
.op-member-card__avatar--sm { width: 52px; height: 52px; }
div.op-member-card__avatar {
    /* Initials fallback */
    background: linear-gradient(135deg, var(--op-primary), #1e3a5f);
    color: #fff; font-size: 1.375rem; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
}
.op-member-card__name  { font-size: 1rem; font-weight: 700; margin-bottom: 2px; }
.op-member-card__title { font-size: .8125rem; color: var(--op-text-muted); }
.op-member-card__location { font-size: .8rem; color: #9e9e9e; margin-top: 4px; }
.op-member-card__tier  { margin-top: 10px; }
.op-member-card__actions { margin-top: 16px; }
.op-member-card--compact .op-card__body { padding: 16px; }

/* ── Member search bar ────────────────────────────────────────────────────── */
.op-member-search { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; justify-content: center; margin-bottom: 32px; }
.op-member-search__input { max-width: 360px; width: 100%; }

/* ── CTA section ──────────────────────────────────────────────────────────── */
.op-cta-inner { padding: 64px 40px; text-align: center; }
.op-cta-inner--compact { padding: 40px 28px; }
.op-cta__title    { font-size: clamp(1.5rem, 3vw, 2.25rem); margin-bottom: 12px; }
.op-cta__subtitle { font-size: 1.0625rem; opacity: .85; margin-bottom: 28px; }
.op-cta__actions  { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* ── Text / Rich content block ────────────────────────────────────────────── */
.op-text-block { line-height: 1.8; }
.op-text-block--narrow { max-width: 600px; margin: 0 auto; }
.op-text-block--medium { max-width: 800px; margin: 0 auto; }
.op-text-block--left   { text-align: left; }
.op-text-block--center { text-align: center; }
.op-text-block--right  { text-align: right; }
.op-text-block h2 { margin-bottom: 14px; }
.op-text-block h3 { margin-bottom: 10px; margin-top: 28px; }
.op-text-block p  { margin-bottom: 16px; color: var(--op-text-secondary); }
.op-text-block ul, .op-text-block ol { padding-left: 1.5em; margin-bottom: 16px; }
.op-text-block li { margin-bottom: 6px; color: var(--op-text-secondary); }
.op-text-block a  { color: var(--op-accent); }
.op-text-block strong { color: var(--op-text); }

/* ── Image + Text section ─────────────────────────────────────────────────── */
.op-image-text { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.op-image-text__content { display: flex; flex-direction: column; gap: 0; }
.op-image-text__body { line-height: 1.75; color: var(--op-text-secondary); margin-bottom: 24px; }
.op-image-text__features { display: flex; flex-direction: column; gap: 16px; margin-bottom: 28px; }
.op-image-text__feature { display: flex; gap: 14px; align-items: flex-start; }
.op-image-text__feature-icon { font-size: 1.375rem; flex-shrink: 0; margin-top: 2px; }
.op-image-text__feature-title { font-weight: 700; margin-bottom: 3px; font-size: .9375rem; }
.op-image-text__feature-text  { font-size: .875rem; color: var(--op-text-muted); }
.op-image-text__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.op-image-text__visual { position: relative; }
.op-image-text__img-wrap { overflow: hidden; aspect-ratio: 4/3; }
.op-image-text__img-wrap--square  { border-radius: 0; }
.op-image-text__img-wrap--rounded { border-radius: var(--op-radius-xl); }
.op-image-text__img-wrap--circle  { border-radius: 50%; aspect-ratio: 1/1; }
.op-image-text__img-wrap--shadow  { border-radius: var(--op-radius-xl); box-shadow: 0 24px 64px rgba(0,0,0,.18); }
.op-image-text__img-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }
.op-image-text__pill {
    position: absolute; bottom: 20px; left: 20px;
    background: rgba(13,27,42,.85); backdrop-filter: blur(10px);
    color: #fff; border-radius: 100px; padding: 8px 16px;
    font-size: .8rem; font-weight: 600;
    border: 1px solid rgba(255,255,255,.1);
}
.op-image-text__placeholder { aspect-ratio: 4/3; border-radius: var(--op-radius-xl); background: linear-gradient(135deg, var(--op-primary), #1e3a5f); display: flex; align-items: center; justify-content: center; font-size: 4rem; opacity: .35; }

/* ── Stats section ────────────────────────────────────────────────────────── */
.op-stats-grid { display: grid; gap: 32px; text-align: center; }
.op-stats-grid--2 { grid-template-columns: repeat(2, 1fr); }
.op-stats-grid--3 { grid-template-columns: repeat(3, 1fr); }
.op-stats-grid--4 { grid-template-columns: repeat(4, 1fr); }
.op-stat__number { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; color: var(--op-accent); line-height: 1; margin-bottom: 8px; }
.op-stat__label  { font-size: .875rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; opacity: .65; }
.op-stat__divider { border-top: 2px solid var(--op-border); padding-top: 24px; margin-top: 24px; }

/* ── Filter bar ───────────────────────────────────────────────────────────── */
.op-events-filter { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 32px; align-items: center; }
.op-events-filter .op-select { max-width: 180px; }

/* ── Section link ─────────────────────────────────────────────────────────── */
.op-section-link { display: flex; justify-content: center; margin-top: 40px; }

/* ── Responsive overrides ─────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .op-image-text { grid-template-columns: 1fr; gap: 36px; }
    .op-image-text__visual { order: -1 !important; } /* image always above on mobile */
    .op-grid--cols-4 { grid-template-columns: repeat(2, 1fr); }
    .op-grid--cols-3 { grid-template-columns: repeat(2, 1fr); }
    .op-event-card--list { grid-template-columns: 1fr; }
    .op-event-card--list .op-card__footer { border-left: none; border-top: 1px solid var(--op-border); flex-direction: row; justify-content: space-between; }
}
@media (max-width: 640px) {
    .op-stats-grid--3,
    .op-stats-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .op-grid--cols-2,
    .op-grid--cols-3,
    .op-grid--cols-4 { grid-template-columns: 1fr; }
    .op-cta-inner { padding: 36px 20px; }
    .op-cta__actions { flex-direction: column; align-items: stretch; }
}

/* ═══════════════════════════════════════════════════════════════════
   OnePulse v3 — Extended Styles
   Overlay · New Page Templates · Frontend Editor · Newsletter
   Google Reviews · Forms · Brand Font (Sora)
   ═══════════════════════════════════════════════════════════════════ */

/* ── Font override from settings ──────────────────────────────────── */
body        { font-family: var(--op-font, 'Sora', system-ui, sans-serif); }
h1,h2,h3,h4,h5,h6 { font-family: var(--op-heading-font, 'Sora', sans-serif); }

/* ── Eyebrow label ────────────────────────────────────────────────── */
.op-eyebrow {
    display: block;
    font-size: .72rem; font-weight: 700; letter-spacing: .12em;
    text-transform: uppercase; color: var(--op-accent);
    margin-bottom: 12px;
}

/* ── Header tweaks v3 ────────────────────────────────────────────── */
.op-header { background: var(--op-primary); }
.op-header__logo-img { height: 38px; width: auto; }
.op-header__desknav { display: flex; align-items: center; flex: 1; margin-left: 32px; }
.op-header__nav     { display: none; } /* legacy, replaced by desknav */

.op-hamburger { background: none; border: none; cursor: pointer; padding: 6px; display: flex; flex-direction: column; gap: 5px; }
.op-hamburger__bar  { display: block; width: 22px; height: 2px; background: rgba(255,255,255,.8); border-radius: 2px; transition: transform .25s, opacity .25s, width .25s; }
.op-hamburger.is-active .op-hamburger__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.op-hamburger.is-active .op-hamburger__bar:nth-child(2) { opacity: 0; width: 0; }
.op-hamburger.is-active .op-hamburger__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.op-cart-btn { position: relative; color: rgba(255,255,255,.75); display: flex; align-items: center; padding: 6px; transition: color .15s; }
.op-cart-btn:hover { color: #fff; }
.op-cart-badge { position: absolute; top: 0; right: 0; background: var(--op-accent); color: #fff; font-size: .65rem; font-weight: 700; min-width: 16px; height: 16px; border-radius: 100px; display: flex; align-items: center; justify-content: center; padding: 0 4px; line-height: 1; }
.op-cart-badge.hidden { display: none; }
.op-editor-launch { display: none; }
@media (min-width: 900px) { .op-editor-launch { display: inline-flex; } }

/* ── Overlay ─────────────────────────────────────────────────────── */
.op-overlay { position: fixed; inset: 0; z-index: 9000; display: flex; }
.op-overlay[hidden] { display: none; }
.op-overlay__backdrop {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.55); backdrop-filter: blur(4px);
    opacity: 0; transition: opacity .35s;
}
.op-overlay__panel {
    position: relative; z-index: 1;
    width: min(440px, 94vw); height: 100%;
    background: var(--op-primary);
    border-right: 1px solid rgba(255,255,255,.07);
    display: flex; flex-direction: column;
    padding: 28px 36px 36px;
    transform: translateX(-100%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
}
.op-overlay.is-open .op-overlay__backdrop { opacity: 1; }
.op-overlay.is-open .op-overlay__panel { transform: translateX(0); }

.op-overlay__close {
    position: absolute; top: 20px; right: 20px;
    background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
    color: rgba(255,255,255,.7); border-radius: 50%;
    width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: all .15s;
}
.op-overlay__close:hover { background: rgba(255,255,255,.12); color: #fff; }

.op-overlay__brand { margin-bottom: 40px; }
.op-overlay__brand img { height: 44px; }
.op-overlay__brand span { font-size: 1.5rem; font-weight: 800; color: #fff; letter-spacing: -.02em; }
.op-overlay__brand em { color: var(--op-accent); font-style: normal; }

.op-overlay__menu { list-style: none; flex: 1; }
.op-overlay__menu > li { border-bottom: 1px solid rgba(255,255,255,.07); }
.op-overlay__menu > li > a {
    display: block; padding: 16px 0;
    font-size: 1.25rem; font-weight: 600;
    color: rgba(255,255,255,.75); text-decoration: none;
    transition: color .15s, padding-left .15s;
}
.op-overlay__menu > li > a:hover { color: #fff; padding-left: 6px; }
.op-overlay__menu > li.current-menu-item > a { color: var(--op-accent); }

.op-overlay__footer { margin-top: 36px; display: flex; flex-direction: column; gap: 12px; }
.op-overlay__social { display: flex; gap: 16px; padding-top: 16px; }
.op-overlay__social a { color: rgba(255,255,255,.45); transition: color .15s; }
.op-overlay__social a:hover { color: var(--op-accent); }

/* ── CTA strip ───────────────────────────────────────────────────── */
.op-cta-strip {
    background: linear-gradient(135deg, var(--op-primary) 0%, var(--op-secondary) 100%);
    border-radius: var(--op-radius-xl); padding: 48px 52px;
    display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.op-cta-strip h2 { color: #fff; font-size: clamp(1.4rem,2.5vw,1.9rem); }
.op-cta-strip p  { color: rgba(255,255,255,.65); margin-top: 6px; }

/* ── Cookbook Landing ─────────────────────────────────────────────── */
.op-cookbook-hero {
    background: var(--op-primary);
    padding: 80px 0 70px;
}
.op-cookbook-hero__grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center;
}
@media (max-width: 768px) { .op-cookbook-hero__grid { grid-template-columns: 1fr; } }
.op-cookbook-hero__content { color: rgba(255,255,255,.85); }
.op-cookbook-hero__content h1 { font-size: clamp(2rem,4vw,3rem); color: #fff; margin-bottom: 14px; }
.op-cookbook-hero__sub  { font-size: 1.125rem; color: rgba(255,255,255,.65); margin-bottom: 16px; }
.op-cookbook-hero__desc { font-size: .975rem; color: rgba(255,255,255,.55); margin-bottom: 28px; line-height: 1.7; }
.op-cookbook-hero__cta  { display: flex; gap: 14px; flex-wrap: wrap; }
.op-cookbook-hero__cover img { border-radius: var(--op-radius-xl); box-shadow: 0 32px 80px rgba(0,0,0,.5); }
.op-cookbook-hero__placeholder {
    background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--op-radius-xl); aspect-ratio: 3/4; display: flex;
    flex-direction: column; align-items: center; justify-content: center; gap: 16px;
    font-size: 5rem;
}
.op-cookbook-hero__placeholder p { color: rgba(255,255,255,.4); font-size: .9rem; }

.op-cookbook-features { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 24px; }
.op-cookbook-feature { background: var(--op-surface); border-radius: var(--op-radius-lg); padding: 28px 24px; border: 1px solid var(--op-border); text-align: center; }
.op-cookbook-feature__icon { font-size: 2.2rem; margin-bottom: 12px; }
.op-cookbook-feature h3 { font-size: 1rem; margin-bottom: 6px; }
.op-cookbook-feature p  { font-size: .875rem; color: var(--op-text-secondary); }

.op-cookbook-chapters { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 768px) { .op-cookbook-chapters { grid-template-columns: 1fr; } }
.op-cookbook-chapters__text h2 { margin-bottom: 12px; }
.op-cookbook-chapters__text p  { color: var(--op-text-secondary); margin-bottom: 24px; }
.op-cookbook-chapter { display: flex; align-items: center; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--op-border); }
.op-cookbook-chapter__num  { font-size: .75rem; font-weight: 700; color: var(--op-accent); min-width: 28px; }
.op-cookbook-chapter__name { font-weight: 600; }

/* ── Community / Health Challenge ────────────────────────────────── */
.op-community-hero {
    position: relative; padding: 100px 0 80px;
    background: var(--op-primary) center/cover no-repeat;
    min-height: 420px; display: flex; align-items: center;
}
.op-community-hero__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); }
.op-community-hero__content { position: relative; text-align: center; max-width: 680px; margin: 0 auto; }
.op-community-hero__content h1 { color: #fff; font-size: clamp(2rem,4vw,2.8rem); margin-bottom: 12px; }
.op-community-hero__content p  { color: rgba(255,255,255,.75); font-size: 1.1rem; max-width: 520px; margin: 0 auto; }

.op-challenge-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.op-challenge-card {
    background: var(--op-surface); border-radius: var(--op-radius-lg); overflow: hidden;
    border: 1px solid var(--op-border); display: flex; flex-direction: column;
    text-decoration: none; transition: transform .2s, box-shadow .2s;
    position: relative;
}
.op-challenge-card:hover { transform: translateY(-4px); box-shadow: var(--op-shadow-lg); border-color: transparent; text-decoration: none; }
.op-challenge-card__accent { height: 4px; width: 100%; }
.op-challenge-card__icon { font-size: 2.5rem; padding: 24px 24px 0; }
.op-challenge-card__body { padding: 12px 24px 20px; flex: 1; }
.op-challenge-card__meta { display: flex; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.op-challenge-card__body h3 { font-size: 1.125rem; color: var(--op-text); margin-bottom: 6px; }
.op-challenge-card__body p  { font-size: .9rem; color: var(--op-text-secondary); }
.op-challenge-card__arrow { padding: 14px 24px; border-top: 1px solid var(--op-border); color: var(--op-accent); display: flex; align-items: center; }

.op-community-join { display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px; align-items: center; }
@media (max-width: 768px) { .op-community-join { grid-template-columns: 1fr; } }
.op-community-join__text h2 { color: #fff; margin-bottom: 8px; }
.op-community-join__text p  { color: rgba(255,255,255,.65); }

/* ── Speaking Engagements ─────────────────────────────────────────── */
.op-speaking-hero {
    position: relative; padding: 120px 0 100px;
    background: var(--op-primary) center/cover no-repeat;
    min-height: 500px; display: flex; align-items: center;
}
.op-speaking-hero__overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(0,0,0,.75) 0%, rgba(0,0,0,.4) 100%); }
.op-speaking-hero__content { position: relative; max-width: 700px; }
.op-speaking-hero__content h1 { color: #fff; font-size: clamp(2rem,4vw,3rem); margin-bottom: 10px; }
.op-speaking-hero__content > p { color: rgba(255,255,255,.65); font-size: 1.1rem; margin-bottom: 28px; }
.op-speaking-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }

.op-speaking-bio { display: grid; grid-template-columns: 320px 1fr; gap: 60px; align-items: start; }
@media (max-width: 900px) { .op-speaking-bio { grid-template-columns: 1fr; } }
.op-speaking-bio__photo img { border-radius: var(--op-radius-xl); width: 100%; box-shadow: var(--op-shadow-lg); }
.op-speaking-bio__content h2 { margin: 12px 0 16px; }
.op-speaking-bio__text p { color: var(--op-text-secondary); line-height: 1.75; margin-bottom: 14px; }

.op-topics-grid  { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
.op-topic-card   { background: var(--op-surface); border-radius: var(--op-radius-lg); padding: 28px; border: 1px solid var(--op-border); }
.op-topic-card__icon { font-size: 2rem; margin-bottom: 12px; }
.op-topic-card h3 { font-size: 1rem; margin-bottom: 6px; }
.op-topic-card p  { font-size: .875rem; color: var(--op-text-secondary); }

.op-formats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 24px; }
.op-format-item  { display: flex; gap: 16px; align-items: flex-start; }
.op-format-item__icon { font-size: 1.75rem; flex-shrink: 0; line-height: 1; }
.op-format-item h4 { margin-bottom: 4px; }
.op-format-item p  { font-size: .875rem; color: var(--op-text-secondary); }

.op-past-clients { display: flex; flex-wrap: wrap; gap: 32px; align-items: center; justify-content: center; }
.op-past-client img  { max-height: 48px; filter: grayscale(1); opacity: .6; transition: all .2s; }
.op-past-client img:hover  { filter: none; opacity: 1; }
.op-past-client span { font-weight: 600; color: var(--op-text-secondary); }

.op-speaking-inquiry { display: grid; grid-template-columns: 1fr 1.5fr; gap: 60px; align-items: start; }
@media (max-width: 900px) { .op-speaking-inquiry { grid-template-columns: 1fr; } }

/* ── Groups & Corporations ────────────────────────────────────────── */
.op-groups-hero {
    position: relative; padding: 120px 0 100px;
    background: var(--op-primary) center/cover no-repeat;
    min-height: 520px; display: flex; align-items: center;
}
.op-groups-hero__overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(0,0,0,.8) 0%, rgba(0,0,0,.35) 100%); }
.op-groups-hero__content { position: relative; max-width: 680px; }
.op-groups-hero__content h1 { color: #fff; font-size: clamp(1.9rem,4vw,2.8rem); margin-bottom: 12px; }
.op-groups-hero__content > p { color: rgba(255,255,255,.7); font-size: 1.1rem; margin-bottom: 28px; }
.op-groups-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }

.op-benefits-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
.op-benefit-card { background: var(--op-surface); border-radius: var(--op-radius-lg); padding: 28px; border: 1px solid var(--op-border); text-align: center; }
.op-benefit-card__icon { font-size: 2.2rem; margin-bottom: 12px; }
.op-benefit-card h3 { margin-bottom: 6px; }
.op-benefit-card p  { font-size: .875rem; color: var(--op-text-secondary); }

.op-packages-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; align-items: start; }
.op-package {
    background: var(--op-surface); border-radius: var(--op-radius-lg);
    border: 1px solid var(--op-border); overflow: hidden; position: relative;
    display: flex; flex-direction: column;
}
.op-package--featured { border-color: var(--op-accent); box-shadow: 0 0 0 1px var(--op-accent), var(--op-shadow-lg); }
.op-package__badge { background: var(--op-accent); color: #fff; font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; text-align: center; padding: 6px; }
.op-package__header { padding: 28px 28px 20px; border-bottom: 1px solid var(--op-border); }
.op-package__header h3 { font-size: 1.25rem; margin-bottom: 4px; }
.op-package__header p  { color: var(--op-text-muted); font-size: .875rem; margin-bottom: 12px; }
.op-package__price { display: flex; align-items: baseline; gap: 4px; margin-bottom: 10px; }
.op-package__amount { font-size: 1.75rem; font-weight: 800; color: var(--op-text); }
.op-package__period { color: var(--op-text-muted); font-size: .875rem; }
.op-package__features { list-style: none; padding: 20px 28px; flex: 1; display: flex; flex-direction: column; gap: 10px; }
.op-package__features li { display: flex; align-items: center; gap: 10px; font-size: .9rem; color: var(--op-text-secondary); }
.op-package__features li svg { color: var(--op-success); flex-shrink: 0; }
.op-package .op-btn { margin: 0 28px 28px; }

/* ── Testimonials / Google Reviews ───────────────────────────────── */
.op-testimonials-aggregate {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--op-surface); border: 1px solid var(--op-border);
    border-radius: 100px; padding: 8px 18px; font-size: .875rem; margin-top: 12px; flex-wrap: wrap; justify-content: center;
}
.op-testimonials-aggregate .star-filled { color: #f59e0b; }
.op-testimonials-aggregate .star-empty  { color: #d1d5db; }
.op-section--dark .op-testimonials-aggregate { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.1); color: rgba(255,255,255,.7); }
.op-google-badge { display: inline-flex; align-items: center; gap: 5px; }

.op-testimonials-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.op-testimonial {
    background: var(--op-surface); border-radius: var(--op-radius-lg);
    padding: 24px; border: 1px solid var(--op-border);
}
.op-section--dark .op-testimonial { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.1); }
.op-testimonial__stars { margin-bottom: 12px; }
.op-testimonial__stars .star-filled { color: #f59e0b; }
.op-testimonial__stars .star-empty  { color: rgba(255,255,255,.2); }
.op-testimonial__quote { font-size: .95rem; line-height: 1.7; color: var(--op-text-secondary); margin-bottom: 16px; font-style: italic; }
.op-section--dark .op-testimonial__quote { color: rgba(255,255,255,.65); }
.op-testimonial__author { display: flex; align-items: center; gap: 12px; }
.op-testimonial__avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.op-testimonial__author strong { display: block; color: var(--op-text); }
.op-section--dark .op-testimonial__author strong { color: #fff; }
.op-testimonial__author span { font-size: .8rem; color: var(--op-text-muted); }

/* ── Contact Form / Forms ─────────────────────────────────────────── */
.op-contact-form, .op-speaking-form { display: flex; flex-direction: column; gap: 16px; }
.op-form-row { display: grid; gap: 16px; }
.op-form-row--2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) { .op-form-row--2 { grid-template-columns: 1fr; } }
.op-form-group { display: flex; flex-direction: column; gap: 6px; }
.op-form-group label { font-size: .85rem; font-weight: 600; color: rgba(255,255,255,.75); }
.op-contact-form:not(.op-speaking-form) .op-form-group label { color: var(--op-text); }
.op-form-group input,
.op-form-group select,
.op-form-group textarea {
    background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
    color: #fff; border-radius: var(--op-radius); padding: 10px 14px;
    font-family: inherit; font-size: .9375rem; transition: border-color .15s;
    width: 100%;
}
.op-form-group input::placeholder, .op-form-group textarea::placeholder { color: rgba(255,255,255,.3); }
.op-form-group input:focus, .op-form-group select:focus, .op-form-group textarea:focus {
    outline: none; border-color: var(--op-accent); background: rgba(255,255,255,.1);
}
.op-form-honeypot { position: absolute; left: -9999px; opacity: 0; pointer-events: none; height: 0; overflow: hidden; }
.op-form-status { font-size: .875rem; padding: 8px 0; }
.op-form-status--error { color: #f87171; }
.op-form-status--success { color: var(--op-success); }
.op-form-success { text-align: center; padding: 32px; }
.op-form-success p { margin-top: 12px; color: rgba(255,255,255,.8); }
.op-form-success-inline { color: var(--op-success); font-weight: 600; padding: 8px 0; }

/* Light-background contact page form variant */
.op-contact-page-form .op-form-group label { color: var(--op-text); }
.op-contact-page-form .op-form-group input,
.op-contact-page-form .op-form-group select,
.op-contact-page-form .op-form-group textarea {
    background: var(--op-surface); border-color: var(--op-border); color: var(--op-text);
}
.op-contact-page-form .op-form-group input::placeholder,
.op-contact-page-form .op-form-group textarea::placeholder { color: var(--op-text-muted); }
.op-contact-page-form .op-form-group input:focus,
.op-contact-page-form .op-form-group textarea:focus { border-color: var(--op-accent); box-shadow: 0 0 0 3px rgba(232,57,90,.1); }

/* ── Newsletter Form ─────────────────────────────────────────────── */
.op-newsletter-form__row {
    display: flex; gap: 10px; flex-wrap: wrap;
}
.op-newsletter-form__row input {
    flex: 1; min-width: 160px;
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15);
    color: #fff; border-radius: var(--op-radius); padding: 11px 16px;
    font-family: inherit; font-size: .9375rem;
}
.op-newsletter-form__row input::placeholder { color: rgba(255,255,255,.4); }
.op-newsletter-form__row input:focus { outline: none; border-color: var(--op-accent); }
.op-newsletter-form__status { font-size: .8rem; margin-top: 6px; }
.op-newsletter-form__title { color: rgba(255,255,255,.85); font-weight: 600; margin-bottom: 10px; }

/* ═══════════════════════════════════════════════════════════════════
   Frontend Page Editor
   ═══════════════════════════════════════════════════════════════════ */
.op-fed {
    display: grid; grid-template-columns: 280px 1fr;
    height: calc(100vh - var(--op-header-h));
    overflow: hidden;
}
.op-fed__sidebar {
    background: #1a1d23; border-right: 1px solid rgba(255,255,255,.07);
    display: flex; flex-direction: column; overflow: hidden;
    transition: width .25s;
}
.op-fed__sidebar.collapsed { width: 0; overflow: hidden; }
.op-fed__sidebar-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 16px; border-bottom: 1px solid rgba(255,255,255,.07);
}
.op-fed__sidebar-brand { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,.8); font-weight: 600; font-size: .875rem; }
.op-fed__sidebar-toggle { background: none; border: none; color: rgba(255,255,255,.4); cursor: pointer; padding: 4px; }
.op-fed__new-btn { margin: 12px; width: calc(100% - 24px); }
.op-fed__sidebar-search { position: relative; margin: 0 12px 10px; }
.op-fed__sidebar-search svg { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: rgba(255,255,255,.3); }
.op-fed__sidebar-search input { width: 100%; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); color: rgba(255,255,255,.7); border-radius: 6px; padding: 8px 12px 8px 32px; font-size: .8rem; }
.op-fed__sidebar-search input:focus { outline: none; border-color: var(--op-accent); }
.op-fed__page-list { list-style: none; overflow-y: auto; flex: 1; padding: 0 0 20px; }
.op-fed__page-item a { display: block; padding: 10px 16px; text-decoration: none; border-left: 3px solid transparent; transition: all .12s; }
.op-fed__page-item a:hover { background: rgba(255,255,255,.04); border-left-color: rgba(255,255,255,.15); }
.op-fed__page-item.active a { background: rgba(232,57,90,.1); border-left-color: var(--op-accent); }
.op-fed__page-title { display: block; font-size: .875rem; font-weight: 600; color: rgba(255,255,255,.8); }
.op-fed__page-slug  { display: block; font-size: .75rem; color: rgba(255,255,255,.3); font-family: monospace; }
.op-fed__draft-badge { margin-top: 4px; }

.op-fed__main { display: flex; flex-direction: column; overflow: hidden; background: var(--op-bg); }
.op-fed__toolbar {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    padding: 12px 24px; background: var(--op-surface); border-bottom: 1px solid var(--op-border);
    flex-shrink: 0; flex-wrap: wrap;
}
.op-fed__toolbar-left { display: flex; align-items: center; gap: 10px; }
.op-fed__toolbar-right { display: flex; align-items: center; gap: 8px; }
.op-fed__page-name { font-size: 1rem; font-weight: 700; }

.op-fed__editor-form { display: flex; flex-direction: column; flex: 1; overflow: hidden; }
.op-fed__meta-bar {
    display: flex; gap: 16px; padding: 14px 24px; background: var(--op-surface);
    border-bottom: 1px solid var(--op-border); flex-wrap: wrap; flex-shrink: 0;
}
.op-fed__meta-group { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 150px; }
.op-fed__meta-group label { font-size: .75rem; font-weight: 600; color: var(--op-text-muted); text-transform: uppercase; letter-spacing: .06em; }
.op-fed__meta-group input,
.op-fed__meta-group select {
    background: var(--op-bg); border: 1px solid var(--op-border);
    border-radius: 6px; padding: 8px 10px; font-size: .875rem;
    color: var(--op-text); font-family: inherit;
}
.op-fed__meta-group input:focus, .op-fed__meta-group select:focus { outline: none; border-color: var(--op-accent); box-shadow: 0 0 0 3px rgba(232,57,90,.1); }
.op-fed__slug-wrap { display: flex; align-items: center; }
.op-fed__slug-prefix { padding: 8px 6px 8px 10px; background: var(--op-border); border: 1px solid var(--op-border); border-right: none; border-radius: 6px 0 0 6px; font-size: .875rem; color: var(--op-text-muted); }
.op-fed__slug-wrap input { border-radius: 0 6px 6px 0; }

.op-fed__tabs { display: flex; gap: 2px; padding: 0 24px; background: var(--op-surface); border-bottom: 1px solid var(--op-border); flex-shrink: 0; }
.op-fed__tab {
    display: flex; align-items: center; gap: 6px; padding: 12px 16px;
    background: none; border: none; border-bottom: 2px solid transparent;
    font-size: .875rem; font-weight: 600; color: var(--op-text-muted); cursor: pointer;
    transition: all .15s; margin-bottom: -1px;
}
.op-fed__tab:hover { color: var(--op-text); }
.op-fed__tab.active { color: var(--op-accent); border-bottom-color: var(--op-accent); }

.op-fed__tab-panel { display: none; flex: 1; overflow-y: auto; padding: 20px 24px; }
.op-fed__tab-panel.active { display: flex; flex-direction: column; gap: 0; }

.op-fed__editor-toolbar {
    display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
    padding: 8px 12px; background: var(--op-bg); border: 1px solid var(--op-border);
    border-bottom: none; border-radius: var(--op-radius) var(--op-radius) 0 0;
}
.op-fed__format-btn {
    background: none; border: none; padding: 4px 8px; border-radius: 4px;
    font-size: .9rem; cursor: pointer; color: var(--op-text); transition: background .12s;
}
.op-fed__format-btn:hover { background: var(--op-border); }
.op-fed__sep { color: var(--op-border); padding: 0 2px; }
.op-fed__heading-select { border: 1px solid var(--op-border); border-radius: 4px; padding: 3px 6px; font-size: .8rem; background: var(--op-surface); color: var(--op-text); }
.op-fed__content-editable {
    flex: 1; min-height: 320px;
    border: 1px solid var(--op-border); border-radius: 0 0 var(--op-radius) var(--op-radius);
    padding: 20px; font-size: .9375rem; line-height: 1.7; color: var(--op-text);
    background: var(--op-surface); outline: none;
    overflow-y: auto;
}
.op-fed__content-editable:focus { border-color: var(--op-accent); }
.op-fed__content-editable h1,.op-fed__content-editable h2,.op-fed__content-editable h3 { margin: 16px 0 8px; }
.op-fed__content-editable p { margin-bottom: 12px; }
.op-fed__content-editable img { max-width: 100%; border-radius: var(--op-radius); margin: 12px 0; }

.op-fed__field-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 20px; }
.op-fed__field-group label { font-size: .85rem; font-weight: 600; color: var(--op-text); }
.op-fed__field-group input,
.op-fed__field-group select,
.op-fed__field-group textarea {
    background: var(--op-surface); border: 1px solid var(--op-border);
    color: var(--op-text); border-radius: var(--op-radius); padding: 10px 14px;
    font-family: inherit; font-size: .9375rem; width: 100%;
}
.op-fed__field-group input:focus,
.op-fed__field-group select:focus,
.op-fed__field-group textarea:focus { outline: none; border-color: var(--op-accent); box-shadow: 0 0 0 3px rgba(232,57,90,.1); }
.op-fed__hint { font-size: .78rem; color: var(--op-text-muted); }
.op-fed__media-row { display: flex; gap: 8px; }
.op-fed__media-row input { flex: 1; }

.op-fed__danger-zone { border: 1px solid #fee2e2; background: #fff5f5; border-radius: var(--op-radius); padding: 16px; margin-top: 24px; }
.op-fed__danger-zone h4 { color: #991b1b; margin-bottom: 10px; font-size: .875rem; text-transform: uppercase; letter-spacing: .06em; }

.op-fed__save-status { padding: 8px 24px; font-size: .85rem; font-weight: 600; border-top: 1px solid var(--op-border); min-height: 36px; }
.op-fed__save-status.saving { color: var(--op-text-muted); }
.op-fed__save-status.success { color: var(--op-success); }
.op-fed__save-status.error   { color: var(--op-danger); }

.op-fed__welcome { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; text-align: center; padding: 48px; }
.op-fed__welcome-icon { opacity: .4; }
.op-fed__welcome h2 { font-size: 1.5rem; }
.op-fed__welcome p  { color: var(--op-text-secondary); max-width: 340px; }

/* ── Modal ───────────────────────────────────────────────────────── */
.op-modal { position: fixed; inset: 0; z-index: 9500; display: flex; align-items: center; justify-content: center; }
.op-modal[hidden] { display: none; }
.op-modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.55); backdrop-filter: blur(4px); }
.op-modal__box { position: relative; background: var(--op-surface); border-radius: var(--op-radius-lg); padding: 32px; width: min(520px, 92vw); box-shadow: var(--op-shadow-xl); }
.op-modal__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; }
.op-modal__header h3 { font-size: 1.125rem; }
.op-modal__close { background: none; border: none; color: var(--op-text-muted); cursor: pointer; padding: 4px; }
.op-modal__footer { display: flex; justify-content: flex-end; gap: 10px; margin-top: 24px; }

/* ── Responsive ──────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .op-fed { grid-template-columns: 240px 1fr; }
}
@media (max-width: 768px) {
    .op-fed { grid-template-columns: 1fr; }
    .op-fed__sidebar { display: none; }
    .op-header__desknav { display: none; }
    .op-editor-launch { display: none !important; }
    .op-fed__meta-bar { padding: 12px 16px; }
    .op-fed__tab-panel.active { padding: 16px; }
}

/* ═══════════════════════════════════════════════════════════════════
   OnePulse v3.1 — KB · Popup · Video Support · Testimonials Editor
   ═══════════════════════════════════════════════════════════════════ */

/* ── Knowledge Base ────────────────────────────────────────────────── */
.op-kb-hero {
    position: relative; padding: 72px 0 56px;
    background: var(--op-primary) center/cover no-repeat;
}
.op-kb-hero__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.55); }
.op-kb-hero__content { position: relative; text-align: center; }
.op-kb-hero__content h1 { color: #fff; font-size: clamp(1.8rem,3.5vw,2.5rem); margin-bottom: 8px; }
.op-kb-hero__content > p { color: rgba(255,255,255,.7); margin-bottom: 24px; }
.op-kb-hero__search {
    position: relative; max-width: 540px; margin: 0 auto;
}
.op-kb-hero__search svg { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: rgba(255,255,255,.5); }
.op-kb-hero__search input {
    width: 100%; padding: 14px 16px 14px 42px;
    background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
    color: #fff; border-radius: var(--op-radius-lg); font-size: 1rem; font-family: inherit;
}
.op-kb-hero__search input::placeholder { color: rgba(255,255,255,.45); }
.op-kb-hero__search input:focus { outline: none; background: rgba(255,255,255,.16); border-color: var(--op-accent); }

.op-kb-layout { display: grid; grid-template-columns: 260px 1fr; gap: 0; min-height: 60vh; }
@media (max-width: 900px) { .op-kb-layout { grid-template-columns: 1fr; } }

.op-kb-sidebar { background: var(--op-surface); border-right: 1px solid var(--op-border); padding: 32px 0; }
@media (max-width: 900px) { .op-kb-sidebar { border-right: none; border-bottom: 1px solid var(--op-border); padding: 20px 0; } }
.op-kb-sidebar__inner { padding: 0 24px; }
.op-kb-sidebar__heading { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--op-text-muted); margin-bottom: 14px; }
.op-kb-sidebar__list { list-style: none; }
.op-kb-sidebar__link {
    display: flex; align-items: center; justify-content: space-between;
    padding: 9px 12px; border-radius: var(--op-radius); font-size: .9rem;
    color: var(--op-text-secondary); text-decoration: none; transition: all .14s;
    border-left: 3px solid transparent;
}
.op-kb-sidebar__link:hover { color: var(--op-text); background: var(--op-bg); }
.op-kb-sidebar__link.active { color: var(--op-accent); background: rgba(232,57,90,.06); border-left-color: var(--op-accent); font-weight: 600; }
.op-kb-sidebar__count { font-size: .75rem; background: var(--op-border); color: var(--op-text-muted); border-radius: 100px; padding: 2px 7px; }

.op-kb-main { padding: 40px 48px; }
@media (max-width: 768px) { .op-kb-main { padding: 24px 20px; } }

.op-kb-group-header { margin-bottom: 28px; }
.op-kb-group-header h2 { margin-bottom: 6px; }
.op-kb-group-header p  { color: var(--op-text-secondary); }

.op-kb__cat-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.op-kb__cat-tabs--mobile { display: none; }
@media (max-width: 900px) { .op-kb__cat-tabs--mobile { display: flex; } }
.op-kb__cat-tab {
    padding: 6px 14px; border-radius: 100px; font-size: .85rem; font-weight: 600;
    background: var(--op-bg); border: 1px solid var(--op-border); color: var(--op-text-secondary);
    cursor: pointer; text-decoration: none; transition: all .14s;
}
.op-kb__cat-tab.active,
.op-kb__cat-tab:hover { background: var(--op-accent); color: #fff; border-color: var(--op-accent); }
.op-kb__cat-count { display: inline-block; margin-left: 5px; background: rgba(255,255,255,.25); border-radius: 100px; padding: 1px 6px; font-size: .75em; }

.op-kb__search { position: relative; margin-bottom: 24px; max-width: 400px; }
.op-kb__search svg { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--op-text-muted); }
.op-kb__search-input { width: 100%; padding: 10px 14px 10px 36px; border: 1px solid var(--op-border); border-radius: var(--op-radius); font-family: inherit; font-size: .9rem; background: var(--op-surface); }
.op-kb__search-input:focus { outline: none; border-color: var(--op-accent); }

.op-kb__grid--cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 18px; }
.op-kb__grid--list { display: flex; flex-direction: column; gap: 12px; }
.op-kb__grid--list .op-kb__card { flex-direction: row; align-items: center; }

.op-kb__card {
    background: var(--op-surface); border: 1px solid var(--op-border); border-radius: var(--op-radius-lg);
    display: flex; flex-direction: column; transition: all .18s; text-decoration: none;
}
.op-kb__card:hover { transform: translateY(-3px); box-shadow: var(--op-shadow-lg); border-color: transparent; }
.op-kb__card-icon { padding: 20px 20px 0; color: var(--op-accent); }
.op-kb__card-body { padding: 12px 20px 16px; flex: 1; }
.op-kb__card-title { font-size: 1rem; font-weight: 700; margin-bottom: 6px; }
.op-kb__card-title a { color: var(--op-text); text-decoration: none; }
.op-kb__card-title a:hover { color: var(--op-accent); }
.op-kb__card-excerpt { font-size: .875rem; color: var(--op-text-secondary); line-height: 1.55; }
.op-kb__cat-label { margin-bottom: 8px; display: inline-block; }
.op-kb__card-footer { padding: 12px 20px; border-top: 1px solid var(--op-border); }
.op-kb__read-more { display: inline-flex; align-items: center; gap: 5px; font-size: .85rem; font-weight: 600; color: var(--op-accent); text-decoration: none; transition: gap .15s; }
.op-kb__read-more:hover { gap: 8px; }
.op-kb__no-results { color: var(--op-text-muted); text-align: center; padding: 32px; }
.op-kb-empty { text-align: center; padding: 56px 24px; color: var(--op-text-muted); }
.op-kb-empty p { margin-top: 12px; }

.op-kb-article { max-width: 780px; }
.op-kb-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: .85rem; color: var(--op-text-muted); margin-bottom: 24px; flex-wrap: wrap; }
.op-kb-breadcrumb a { color: var(--op-accent); text-decoration: none; }
.op-kb-article__title { font-size: clamp(1.5rem,3vw,2rem); margin-bottom: 24px; line-height: 1.3; }
.op-kb-article__body.op-prose { font-size: 1rem; line-height: 1.8; color: var(--op-text-secondary); }
.op-kb-article__body.op-prose h2,
.op-kb-article__body.op-prose h3 { color: var(--op-text); margin: 28px 0 10px; }
.op-kb-article__body.op-prose p  { margin-bottom: 16px; }
.op-kb-article__body.op-prose ul,
.op-kb-article__body.op-prose ol { padding-left: 24px; margin-bottom: 16px; }
.op-kb-article__body.op-prose img { max-width: 100%; border-radius: var(--op-radius); margin: 16px 0; }
.op-kb-related { margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--op-border); }
.op-kb-related h3 { margin-bottom: 12px; }
.op-kb-related ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.op-kb-related a  { color: var(--op-accent); font-size: .9rem; text-decoration: none; }
.op-kb-related a:hover { text-decoration: underline; }
.op-kb-back { margin-top: 32px; }

/* ── Newsletter Popup ─────────────────────────────────────────────── */
.op-popup { position: fixed; inset: 0; z-index: 10000; display: flex; align-items: center; justify-content: center; }
.op-popup[hidden] { display: none; }
.op-popup__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(3px); }

.op-popup__box {
    position: relative; z-index: 1;
    width: min(860px, 94vw);
    background: var(--op-primary);
    border-radius: var(--op-radius-xl);
    overflow: hidden;
    box-shadow: 0 32px 80px rgba(0,0,0,.4);
    opacity: 0; transform: scale(.94) translateY(16px);
    transition: opacity .35s, transform .35s;
}
.op-popup.is-open .op-popup__box { opacity: 1; transform: none; }

/* Split layout */
.op-popup__box--split { display: grid; grid-template-columns: 1fr 1fr; min-height: 440px; }
@media (max-width: 600px) { .op-popup__box--split { grid-template-columns: 1fr; } }
.op-popup__text { padding: 44px 40px; display: flex; flex-direction: column; justify-content: center; }
.op-popup__image { position: relative; overflow: hidden; min-height: 300px; }
.op-popup__image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 600px) { .op-popup__image { display: none; } }

/* Centered layout */
.op-popup__box--centered { max-width: 520px; }
.op-popup__center-image { text-align: center; }
.op-popup__center-image img { max-height: 180px; margin: 0 auto; }
.op-popup__center-content { padding: 32px 40px 40px; text-align: center; }

/* Minimal layout */
.op-popup__box--minimal { max-width: 640px; border-radius: var(--op-radius-lg); }
.op-popup__minimal-inner { padding: 28px 36px; display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.op-popup__minimal-inner h3 { margin: 0; flex-shrink: 0; }

.op-popup__close {
    position: absolute; top: 14px; right: 14px; z-index: 2;
    background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
    color: rgba(255,255,255,.8); border-radius: 50%; width: 34px; height: 34px;
    display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .14s;
}
.op-popup__close:hover { background: rgba(255,255,255,.2); color: #fff; }

.op-popup__headline { font-size: clamp(1.25rem,2.5vw,1.75rem); margin-bottom: 10px; }
.op-popup__sub { font-size: .9375rem; opacity: .75; margin-bottom: 22px; line-height: 1.55; }

.op-popup__form { display: flex; flex-direction: column; gap: 10px; }
.op-popup__input-row { display: flex; gap: 10px; flex-direction: column; }
.op-popup__input-row--row { flex-direction: row; }
.op-popup__input {
    width: 100%; padding: 12px 16px;
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
    border-radius: var(--op-radius); font-family: inherit; font-size: .9375rem;
    transition: border-color .14s;
}
.op-popup__input::placeholder { color: rgba(255,255,255,.4); }
.op-popup__input:focus { outline: none; border-color: var(--op-accent); }
.op-popup__btn {
    padding: 12px 24px; background: var(--op-accent); color: #fff;
    border: none; border-radius: var(--op-radius); font-weight: 700; font-size: .9375rem;
    cursor: pointer; transition: filter .14s; white-space: nowrap; font-family: inherit;
    --popup-accent: var(--op-accent);
}
.op-popup__btn:hover { filter: brightness(1.1); }
.op-popup__status { font-size: .8rem; min-height: 20px; }
.op-popup__success { text-align: center; padding: 12px 0; }
.op-popup__success svg { color: #10b981; }
.op-popup__success p  { margin-top: 8px; opacity: .85; }
.op-popup__form-honeypot { position: absolute; left: -9999px; pointer-events: none; opacity: 0; height: 0; }

/* ── Video Backgrounds ───────────────────────────────────────────── */
.op-video-bg { position: relative; overflow: hidden; }
.op-video-bg__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.op-video-bg.video-playing .op-video-bg__poster { opacity: 0; pointer-events: none; }
.op-video-hero .op-video-hero__content {
    text-align: center; color: #fff;
}
.op-video-hero .op-video-hero__content h1 { color: #fff; }
.op-video-hero .op-video-hero__content p  { color: rgba(255,255,255,.8); }


/* ═══════════════════════════════════════════════════════════════════
   OnePulse v3.2 — Cart · Community Sections · CRM Auth Bar · Forms
   ═══════════════════════════════════════════════════════════════════ */

/* ── CRM Auth Bar ─────────────────────────────────────────────────── */
.op-crm-auth-bar {
    background: var(--op-secondary); border-bottom: 1px solid rgba(255,255,255,.06);
    font-size: .8rem; color: rgba(255,255,255,.7); position: sticky; top: var(--op-header-h); z-index: 999;
}
.op-crm-auth-bar__inner {
    display: flex; align-items: center; justify-content: flex-end; gap: 20px;
    padding: 6px 24px; max-width: var(--op-container); margin: 0 auto;
}
.op-crm-auth-bar__greeting { color: rgba(255,255,255,.6); }
.op-crm-auth-bar__greeting strong { color: #fff; }
.op-crm-auth-bar__links { display: flex; gap: 12px; align-items: center; }
.op-crm-auth-bar__links a,
.op-crm-auth-bar__logout {
    color: rgba(255,255,255,.6); font-size: .8rem; text-decoration: none; background: none; border: none;
    cursor: pointer; padding: 0; font-family: inherit; transition: color .14s;
}
.op-crm-auth-bar__links a:hover,
.op-crm-auth-bar__logout:hover { color: var(--op-accent); }

/* ── Cart Page ────────────────────────────────────────────────────── */
.op-cart-header { margin-bottom: 32px; }
.op-cart-header h1 { font-size: clamp(1.6rem,3vw,2.2rem); }
.op-cart-header p  { color: var(--op-text-muted); }

.op-cart-empty { text-align: center; padding: 80px 24px; }
.op-cart-empty svg { margin: 0 auto 20px; }
.op-cart-empty h2 { margin-bottom: 8px; }
.op-cart-empty p  { color: var(--op-text-secondary); margin-bottom: 28px; }
.op-cart-empty__links { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

.op-cart-layout { display: grid; grid-template-columns: 1fr 360px; gap: 32px; align-items: start; }
@media (max-width: 900px) { .op-cart-layout { grid-template-columns: 1fr; } }

.op-cart-items { display: flex; flex-direction: column; gap: 1px; }
.op-cart-item {
    display: grid; grid-template-columns: 80px 1fr auto auto; gap: 20px; align-items: center;
    background: var(--op-surface); border: 1px solid var(--op-border); border-radius: var(--op-radius-lg);
    padding: 20px; margin-bottom: 12px;
}
@media (max-width: 600px) { .op-cart-item { grid-template-columns: 60px 1fr; gap: 12px; } }
.op-cart-item__thumb { width: 80px; height: 80px; border-radius: var(--op-radius); overflow: hidden; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.op-cart-item__thumb img { width: 100%; height: 100%; object-fit: cover; }
.op-cart-item__thumb--placeholder { font-size: 2rem; }
.op-cart-item__info .op-badge { margin-bottom: 6px; }
.op-cart-item__info h3 { font-size: 1rem; margin-bottom: 4px; }
.op-cart-item__meta { font-size: .8rem; color: var(--op-text-muted); }
.op-cart-item__qty { font-size: .9rem; color: var(--op-text-secondary); white-space: nowrap; }
.op-cart-item__price { font-size: 1.1rem; font-weight: 700; white-space: nowrap; }

.op-cart-summary__inner {
    background: var(--op-surface); border: 1px solid var(--op-border); border-radius: var(--op-radius-lg);
    padding: 28px; position: sticky; top: calc(var(--op-header-h) + 32px);
}
.op-cart-summary__inner h3 { margin-bottom: 20px; }
.op-cart-summary__line { display: flex; justify-content: space-between; padding: 8px 0; font-size: .9rem; color: var(--op-text-secondary); border-bottom: 1px solid var(--op-border); }
.op-cart-summary__total { display: flex; justify-content: space-between; padding: 14px 0; font-weight: 700; font-size: 1.1rem; }
.op-cart-summary__inner .op-btn { margin-top: 16px; }
.op-cart-summary__continue { display: block; text-align: center; margin-top: 12px; font-size: .85rem; color: var(--op-text-muted); text-decoration: none; }
.op-cart-summary__continue:hover { color: var(--op-accent); }

.op-cart-invoices { margin-top: 24px; border-top: 1px solid var(--op-border); padding-top: 20px; }
.op-cart-invoices h4 { font-size: .85rem; text-transform: uppercase; letter-spacing: .06em; color: var(--op-text-muted); margin-bottom: 12px; }
.op-cart-invoice-item { display: flex; justify-content: space-between; align-items: center; gap: 8px; padding: 10px 0; border-bottom: 1px solid var(--op-border); font-size: .875rem; }
.op-cart-invoice-item:last-child { border-bottom: none; }
.op-cart-invoice-item > div { display: flex; align-items: center; gap: 8px; }

/* ── Community Categories ─────────────────────────────────────────── */
.op-cat-card {
    background: var(--op-surface); border: 1px solid var(--op-border);
    border-radius: var(--op-radius-lg); overflow: hidden; display: flex; flex-direction: column;
    text-decoration: none; color: var(--op-text); transition: transform .2s, box-shadow .2s;
}
.op-cat-card--link:hover { transform: translateY(-4px); box-shadow: var(--op-shadow-lg); border-color: transparent; }
.op-cat-card__img { aspect-ratio: 16/9; overflow: hidden; }
.op-cat-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.op-cat-card--link:hover .op-cat-card__img img { transform: scale(1.04); }
.op-cat-card__icon { font-size: 2.5rem; padding: 24px 20px 0; }
.op-cat-card__body { padding: 16px 20px 20px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.op-cat-card__body h3 { font-size: 1.0625rem; }
.op-cat-card__body p  { font-size: .875rem; color: var(--op-text-secondary); flex: 1; }
.op-cat-card__cta { font-size: .85rem; font-weight: 600; color: var(--op-accent); margin-top: 8px; }

/* ── Join CTA ─────────────────────────────────────────────────────── */
.op-join-cta { max-width: 780px; margin: 0 auto; }
.op-join-cta--split { display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px; max-width: 1100px; align-items: start; }
@media (max-width: 768px) { .op-join-cta--split { grid-template-columns: 1fr; } }
.op-join-cta__title  { font-size: clamp(1.75rem,3.5vw,2.5rem); margin-bottom: 16px; }
.op-join-cta__intro  { color: var(--op-text-secondary); line-height: 1.75; margin-bottom: 20px; }
.op-join-cta__intro p { margin-bottom: 0; }
.op-join-cta__list   { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.op-join-cta__list li { display: flex; align-items: flex-start; gap: 10px; font-size: .9375rem; }
.op-join-cta__closing { color: var(--op-text-secondary); font-style: italic; margin-bottom: 24px; }
.op-join-cta__buttons { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.op-join-cta__form   { background: var(--op-surface); border: 1px solid var(--op-border); border-radius: var(--op-radius-lg); padding: 28px; }

/* ── Form Label Fixes — all forms use proper visible labels ────────── */
.op-form-group label,
.op-speaking-form .op-form-group label,
.op-contact-form .op-form-group label,
.op-fed__field-group label {
    display: block;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: 5px;
    color: var(--op-text);
}
/* Dark-background forms get light labels */
.op-section--dark .op-form-group label,
.op-speaking-inquiry .op-form-group label,
.op-groups-inquiry .op-form-group label {
    color: rgba(255,255,255,.8);
}
/* Ensure inputs render with proper placeholder and border contrast */
.op-form-group input,
.op-form-group select,
.op-form-group textarea {
    display: block; width: 100%;
}
.op-contact-page-form .op-form-group input,
.op-contact-page-form .op-form-group select,
.op-contact-page-form .op-form-group textarea {
    background: var(--op-surface);
    border: 1.5px solid var(--op-border);
    color: var(--op-text);
    border-radius: var(--op-radius);
    padding: 11px 14px;
    font-size: .9375rem;
    font-family: inherit;
    transition: border-color .15s, box-shadow .15s;
}
.op-contact-page-form .op-form-group input:focus,
.op-contact-page-form .op-form-group textarea:focus {
    outline: none;
    border-color: var(--op-accent);
    box-shadow: 0 0 0 3px rgba(232,57,90,.1);
}
.op-contact-page-form .op-form-group input::placeholder,
.op-contact-page-form .op-form-group textarea::placeholder {
    color: var(--op-text-muted);
}

/* ── Signup context text — helps users know what they're signing up for ── */
.op-form-context {
    background: rgba(232,57,90,.06); border-left: 3px solid var(--op-accent);
    border-radius: 0 var(--op-radius) var(--op-radius) 0;
    padding: 12px 16px; margin-bottom: 20px; font-size: .9rem; color: var(--op-text-secondary);
}
.op-form-context strong { color: var(--op-text); }

/* ── Submit button loading state ─────────────────────────────────── */
.op-btn .op-btn-spinner { display: inline-flex; align-items: center; gap: 6px; }
.op-btn .op-btn-spinner::before {
    content: ''; display: inline-block; width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,.4); border-top-color: #fff;
    border-radius: 50%; animation: op-spin .7s linear infinite;
}
@keyframes op-spin { to { transform: rotate(360deg); } }

/* ═══════════════════════════════════════════════════════════════════
   OnePulse v3.3 — Frontend Edit Bar
   ═══════════════════════════════════════════════════════════════════ */

.op-edit-bar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 99999;
    height: 40px; background: #0d1b2a;
    border-bottom: 2px solid var(--op-accent, #e8395a);
    font-family: system-ui, -apple-system, sans-serif;
    font-size: 12px;
}
.op-edit-bar__inner {
    height: 100%; max-width: 100%;
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 16px; gap: 12px;
}
.op-edit-bar__left {
    display: flex; align-items: center; gap: 8px; flex-shrink: 0;
    color: rgba(255,255,255,.6);
}
.op-edit-bar__logo { color: var(--op-accent, #e8395a); font-size: 14px; }
.op-edit-bar__site { color: #fff; font-weight: 700; }
.op-edit-bar__sep  { opacity: .3; }
.op-edit-bar__key  { font-size: 11px; }
.op-edit-bar__key strong { color: var(--op-accent, #e8395a); }

.op-edit-bar__actions {
    display: flex; align-items: center; gap: 6px; flex-wrap: nowrap;
}
.op-edit-bar__btn {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 4px 10px; border-radius: 5px; font-size: 11px; font-weight: 600;
    cursor: pointer; text-decoration: none; white-space: nowrap;
    border: 1px solid transparent; transition: all .13s;
}
.op-edit-bar__btn--primary {
    background: var(--op-accent, #e8395a); color: #fff;
}
.op-edit-bar__btn--primary:hover { background: #c72d4b; color: #fff; text-decoration: none; }
.op-edit-bar__btn--ghost {
    background: rgba(255,255,255,.07); color: rgba(255,255,255,.75);
    border-color: rgba(255,255,255,.12);
}
.op-edit-bar__btn--ghost:hover { background: rgba(255,255,255,.14); color: #fff; text-decoration: none; }
.op-edit-bar__btn--logout { color: rgba(255,255,255,.45); }
.op-edit-bar__user { color: rgba(255,255,255,.5); font-size: 11px; padding: 0 4px; }

/* Page switcher dropdown */
.op-edit-bar__page-switcher { position: relative; }
.op-edit-bar__dropdown {
    display: none; position: absolute; top: calc(100% + 6px); right: 0;
    background: #1b2d3e; border: 1px solid rgba(255,255,255,.1);
    border-radius: 8px; min-width: 200px; padding: 6px;
    box-shadow: 0 8px 32px rgba(0,0,0,.4); z-index: 100000;
}
.op-edit-bar__page-switcher.open .op-edit-bar__dropdown { display: block; }
.op-edit-bar__dropdown-item {
    display: block; padding: 7px 10px; border-radius: 5px; font-size: 12px;
    color: rgba(255,255,255,.7); text-decoration: none; transition: background .12s;
}
.op-edit-bar__dropdown-item:hover { background: rgba(255,255,255,.08); color: #fff; text-decoration: none; }
.op-edit-bar__dropdown-item.active { color: var(--op-accent, #e8395a); font-weight: 700; }

/* Push header down when edit bar is visible */
body.has-edit-bar .op-header { top: 40px; }
body.has-edit-bar { padding-top: 40px; }

@media (max-width: 768px) {
    .op-edit-bar__left { display: none; }
    .op-edit-bar__user { display: none; }
    .op-edit-bar { height: 44px; }
    body.has-edit-bar { padding-top: 44px; }
    body.has-edit-bar .op-header { top: 44px; }
}
