/* ============================================================= */
/* PVN COACHING — HOMEPAGE  ·  award-winning luxe edition        */
/* Brand: Deep #4B186B · Purple #7A3FA0 · Light #C9A8DC          */
/* Turquoise #3FB3A8 · Ink #2B2330 · Soft BG #F4EEF8             */
/* All scoped pvn-* · never overrides locked wrappers           */
/* ============================================================= */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Jost:wght@300;400;500;600&display=swap');

:root {
    --pvn-deep: #4B186B;
    --pvn-deep-2: #3a0f55;
    --pvn-purple: #7A3FA0;
    --pvn-light: #C9A8DC;
    --pvn-turq: #3FB3A8;
    --pvn-turq-d: #2f978d;
    --pvn-ink: #2B2330;
    --pvn-ink-soft: #000;
    --pvn-soft: #F4EEF8;
    --pvn-cream: #FBF8FD;
    --pvn-serif: "Cormorant Garamond", Georgia, serif;
    --pvn-sans: "Jost", "Helvetica Neue", Arial, sans-serif;
    --pvn-shadow-sm: 0 6px 22px rgba(75,24,107,0.08);
    --pvn-shadow-md: 0 18px 50px rgba(75,24,107,0.14);
    --pvn-shadow-lg: 0 34px 80px rgba(75,24,107,0.20);
    --pvn-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* fluid type scale */
:root {
    --pvn-fs-h1: clamp(2.9rem, 6.2vw, 5.4rem);
    --pvn-fs-h2: clamp(2rem, 3.6vw, 3.4rem);
    --pvn-fs-h3: clamp(1.32rem, 1.7vw, 1.6rem);
    --pvn-fs-lead: clamp(1.5rem, 1.4vw, 1.28rem);
    --pvn-fs-body: clamp(1.3rem, 1.1vw, 1.06rem);
}

/* ---- base / rhythm ---- */
.pvn-section {
    position: relative;
    overflow: hidden;
    font-family: var(--pvn-sans);
}
.pvn-section .is-container {
    margin-top: clamp(90px, 11vw, 180px);
    margin-bottom: clamp(90px, 11vw, 180px);
    position: relative;
    z-index: 2;
}
.is-wrapper > div.pvn-bg-soft { background-color: var(--pvn-soft); }
.is-wrapper > div.pvn-bg-deep {
    background:
        radial-gradient(120% 130% at 12% -10%, #5d2384 0%, var(--pvn-deep) 52%, var(--pvn-deep-2) 100%);
}
.is-wrapper > div.pvn-bg-purple {
    background:
        radial-gradient(120% 130% at 88% 0%, #8a4cb3 0%, var(--pvn-purple) 58%, #5f2e80 100%);
}
.pvn-text-center { text-align: center; }
.pvn-section-head { margin-bottom: clamp(20px, 2.5vw, 32px); }
.pvn-testi-section .pvn-section-head { margin-bottom: clamp(8px, 1.5vw, 16px); }

/* subtle grain texture over dark sections for depth */
.pvn-bg-deep::after, .pvn-bg-purple::after, .pvn-hero .pvn-grain {
    content: "";
    position: absolute; inset: 0;
    z-index: 1; pointer-events: none;
    opacity: 0.05;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- floating gradient blobs (light sections) ---- */
.pvn-has-orbs::before, .pvn-has-orbs::after {
    content: ""; position: absolute; border-radius: 50%;
    z-index: 1; pointer-events: none; filter: blur(8px);
}
.pvn-has-orbs::before {
    width: 360px; height: 360px; top: -130px; right: -90px;
    background: radial-gradient(circle at 30% 30%, rgba(201,168,220,0.5), rgba(201,168,220,0) 70%);
    animation: pvn-float 17s ease-in-out infinite;
}
.pvn-has-orbs::after {
    width: 300px; height: 300px; bottom: -130px; left: -90px;
    background: radial-gradient(circle at 30% 30%, rgba(63,179,168,0.30), rgba(63,179,168,0) 70%);
    animation: pvn-float 23s ease-in-out infinite reverse;
}
.pvn-has-glow::before {
    content: ""; position: absolute; width: 520px; height: 520px; border-radius: 50%;
    top: -180px; left: -140px;
    background: radial-gradient(circle at 40% 40%, rgba(63,179,168,0.32), rgba(63,179,168,0) 66%);
    z-index: 1; pointer-events: none; animation: pvn-float 24s ease-in-out infinite;
}
.pvn-has-glow .is-container { z-index: 3; }
@keyframes pvn-float {
    0%,100% { transform: translate(0,0) scale(1); }
    50% { transform: translate(26px,-30px) scale(1.07); }
}

/* ---- eyebrow + index ---- */
.pvn-eyebrow {
    display: inline-flex; align-items: center; gap: 12px;
    font-family: var(--pvn-sans);
    font-size: 0.74rem; letter-spacing: 4px; text-transform: uppercase;
    font-weight: 600; margin-bottom: 20px; color: var(--pvn-purple);
}
.pvn-eyebrow-line { width: 38px; height: 2px; background: var(--pvn-turq); display: inline-block; }
.pvn-eyebrow-on-dark { color: var(--pvn-light); }
.pvn-eyebrow-center { justify-content: center; }
.pvn-index {
    display: block;
    font-family: var(--pvn-sans);
    font-size: 0.72rem; letter-spacing: 5px; text-transform: uppercase;
    font-weight: 500; color: var(--pvn-turq); margin-bottom: 14px;
}

/* ---- headings ---- */
.pvn-h2 {
    font-family: var(--pvn-serif);
    color: var(--pvn-deep); font-weight: 500;
    font-size: var(--pvn-fs-h2); line-height: 1.1;
    letter-spacing: 0.3px; margin-bottom: 24px;
}
.pvn-h2.is-light-text { color: #fff; }
.pvn-italic { font-style: italic; font-weight: 500; color: var(--pvn-turq); }
.pvn-h2.is-light-text .pvn-italic { color: var(--pvn-light); }
.pvn-h3 {
    font-family: var(--pvn-serif);
    color: var(--pvn-deep); font-weight: 600;
    font-size: var(--pvn-fs-h3); line-height: 1.3;
    margin: 0 0 12px 0;
}

/* ---- body ---- */
.pvn-lead {
    font-size: var(--pvn-fs-lead); line-height: 1.75;
    color: var(--pvn-ink); margin-bottom: 20px; font-weight: 400;
}
.pvn-lead-narrow { max-width: 680px; margin-left: auto; margin-right: auto; }
.pvn-body {
    font-size: var(--pvn-fs-body); line-height: 1.85;
    color: var(--pvn-ink-soft); margin-bottom: 18px;
}
.pvn-body-soft { color: rgba(255,255,255,0.84); }
.pvn-mini { font-size: 0.9rem; letter-spacing: 1px; text-transform: uppercase; color: var(--pvn-light); margin-bottom: 24px; }
.pvn-signature {
    display: inline-block; font-family: var(--pvn-serif); font-style: italic;
    font-size: 2.3rem; color: var(--pvn-purple); margin-top: 8px;
}

/* ---- buttons + micro-interactions ---- */
.pvn-btn {
    position: relative; overflow: hidden;
    font-family: var(--pvn-sans);
    letter-spacing: 1.6px; padding: 16px 44px; line-height: 1.2;
    font-weight: 600; font-size: 0.78rem; text-transform: uppercase;
    border-radius: 999px;
    transition: transform 0.45s var(--pvn-ease), box-shadow 0.45s var(--pvn-ease), color 0.4s ease;
    z-index: 1;
}
.pvn-btn::before {
    content: ""; position: absolute; z-index: -1; inset: 0;
    transform: translateY(101%);
    transition: transform 0.5s var(--pvn-ease);
}
.pvn-btn-accent {
    background-color: var(--pvn-turq); border: 2px solid var(--pvn-turq);
    color: #fff; box-shadow: 0 12px 30px rgba(63,179,168,0.34);
}
.pvn-btn-accent::before { background: var(--pvn-turq-d); }
.pvn-btn-primary {
    background-color: var(--pvn-purple); border: 2px solid var(--pvn-purple);
    color: #fff; box-shadow: 0 12px 30px rgba(122,63,160,0.30);
}
.pvn-btn-primary::before { background: var(--pvn-deep); }
.pvn-btn-accent:hover, .pvn-btn-accent:focus,
.pvn-btn-primary:hover, .pvn-btn-primary:focus {
    color: #fff; transform: translateY(-4px);
    box-shadow: var(--pvn-shadow-md);
}
.pvn-btn-accent:hover::before, .pvn-btn-accent:focus::before,
.pvn-btn-primary:hover::before, .pvn-btn-primary:focus::before { transform: translateY(0); }
.pvn-btn-outline {
    background: transparent; border: 2px solid var(--pvn-purple); color: var(--pvn-purple);
}
.pvn-btn-outline::before { background: var(--pvn-purple); }
.pvn-btn-outline:hover, .pvn-btn-outline:focus { color: #fff; transform: translateY(-4px); }
.pvn-btn-outline:hover::before, .pvn-btn-outline:focus::before { transform: translateY(0); }
.pvn-btn-block { display: block; width: 100%; text-align: center; }
.pvn-btn-row { display: flex; flex-wrap: wrap; align-items: center; gap: 22px; margin-top: 12px; }
.pvn-magnetic { will-change: transform; }

/* underline-reveal text link */
.pvn-text-link {
    position: relative; font-family: var(--pvn-sans);
    font-weight: 600; letter-spacing: 1px; font-size: 0.9rem;
    color: var(--pvn-purple);
}
.pvn-text-link i { margin-left: 7px; transition: transform 0.35s var(--pvn-ease); }
.pvn-text-link:hover i { transform: translateX(7px); }
.pvn-text-link-light { color: #fff; }
.pvn-underline::after {
    content: ""; position: absolute; left: 0; bottom: -5px;
    width: 100%; height: 1.5px; background: currentColor;
    transform: scaleX(0); transform-origin: right;
    transition: transform 0.4s var(--pvn-ease);
}
.pvn-underline:hover::after { transform: scaleX(1); transform-origin: left; }

/* ---- decorative image frames ---- */
.pvn-img-frame { position: relative; display: inline-block; width: 100%; }
.pvn-img-frame img {
    width: 100%; display: block; position: relative; z-index: 2;
    box-shadow: var(--pvn-shadow-lg);
    transition: transform 0.7s var(--pvn-ease);
}
.pvn-img-frame:hover img { transform: scale(1.03); }
.pvn-img-frame::before {
    content: ""; position: absolute; z-index: 1;
    inset: 24px -24px -24px 24px;
    background: linear-gradient(135deg, var(--pvn-light), var(--pvn-turq));
    opacity: 0.55;
}
.pvn-img-frame-blob img, .pvn-img-frame-blob::before { border-radius: 58% 42% 53% 47% / 48% 56% 44% 52%; }
.pvn-img-frame-alt img, .pvn-img-frame-alt::before { border-radius: 46% 54% 60% 40% / 54% 42% 58% 46%; }
.pvn-img-frame-arch img, .pvn-img-frame-arch::before { border-radius: 200px 200px 16px 16px; }
.pvn-frame-dot {
    position: absolute; z-index: 3; width: 96px; height: 96px;
    top: -28px; left: -28px; border-radius: 50%;
    background-image: radial-gradient(var(--pvn-purple) 1.6px, transparent 1.7px);
    background-size: 14px 14px; opacity: 0.45;
}
.pvn-frame-dot-turq {
    background-image: radial-gradient(var(--pvn-turq) 1.6px, transparent 1.7px);
    top: auto; left: auto; bottom: -28px; right: -28px;
}

/* ============================================================= */
/* HERO / BANNER  —  bnl-0 reference structure (PVN brand)       */
/* (moved out of inline <style> into site.css per Webware rule)  */
/* ============================================================= */
.bnl-0.pvn-hero { position: relative; }
.bnl-0 .bn-overlay { display: none; }              /* reference: overlay off */
.bnl-0 .pos-ab-ban { z-index: 3; }

/* banner image */
.bnl-0 .cell.full.padding-0 { overflow: hidden; }
.bnl-0 .pvn-hero-img,
.bnl-0 .pvn-hero-img-mob {
    width: 100%; display: block; object-fit: cover;
    transform-origin: center center;
    animation: pvn-kenburns 18s ease-out forwards;
}
.bnl-0 .pvn-hero-img { height: clamp(560px, 70vh, 760px); }
@keyframes pvn-kenburns {
    from { transform: scale(1.08); }
    to { transform: scale(1); }
}

/* dark content box (reference style → PVN deep-purple glass) */
.bnl-0 .bn-content {
    max-width: 600px; text-align: left;
    margin-left: 0; margin-right: auto;
    padding: 44px 42px; border-radius: 18px;
    color: #fff;
    background: linear-gradient(150deg, rgba(43,11,63,0.92), rgba(75,24,107,0.86));
    border: 1px solid rgba(201,168,220,0.28);
    box-shadow: 0 30px 70px rgba(43,11,63,0.45);
    backdrop-filter: blur(4px);
}
.bnl-0 .bn-content .pvn-eyebrow-on-dark { color: var(--pvn-light); margin-bottom: 16px; }

.bnl-0 .bn-content h1.pvn-hero-h1 {
    font-family: var(--pvn-serif);
    color: #fff; font-weight: 500;
    font-size: clamp(1.9rem, 3.2vw, 2.8rem); line-height: 1.1;
    letter-spacing: 0.3px; margin: 0 0 16px 0;
}
.bnl-0 .bn-content h1.pvn-hero-h1 .pvn-italic { color: var(--pvn-light); font-style: italic; }
.bnl-0 .bn-content .pvn-hero-h2 {
    font-family: var(--pvn-serif); font-style: italic;
    color: rgba(255,255,255,0.95); font-weight: 400;
    font-size: clamp(1.15rem, 1.8vw, 1.5rem); line-height: 1.4; margin-bottom: 16px;
}
.bnl-0 .bn-content p, .bnl-0 .bn-content .pvn-hero-p {
    color: rgba(255,255,255,0.9); font-size: 1rem; line-height: 1.75; margin-bottom: 22px;
}
.bnl-0 .bn-content p:last-child { margin-bottom: 0; }

/* hero button — matched 1:1 to the signature .pvn-btn .pvn-btn-accent */
.bnl-0 .bn-content .button.pvn-hero-btn {
    position: relative; overflow: hidden;
    display: inline-block;
    background-color: var(--pvn-turq); border: 2px solid var(--pvn-turq);
    color: #fff;
    padding: 16px 44px; border-radius: 999px; line-height: 1.2;
    font-family: var(--pvn-sans);
    font-weight: 600; font-size: 0.78rem; letter-spacing: 1.6px; text-transform: uppercase;
    text-decoration: none; text-shadow: none;
    box-shadow: 0 12px 30px rgba(63,179,168,0.34);
    transition: transform 0.45s var(--pvn-ease), box-shadow 0.45s var(--pvn-ease), color 0.4s ease;
    z-index: 1;
}
.bnl-0 .bn-content .button.pvn-hero-btn::before {
    content: ""; position: absolute; z-index: -1; inset: 0;
    background: var(--pvn-turq-d);
    transform: translateY(101%);
    transition: transform 0.5s var(--pvn-ease);
}
.bnl-0 .bn-content .button.pvn-hero-btn:hover {
    color: #fff; transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(63,179,168,0.40);
}
.bnl-0 .bn-content .button.pvn-hero-btn:hover::before { transform: translateY(0); }
.bnl-0 .bn-content .pvn-btn-row {
    display: flex; flex-wrap: wrap; align-items: center; gap: 22px; margin-bottom: 0;
}
.bnl-0 .bn-content .pvn-text-link-light { color: #fff; }

/* credibility meta row */
.bnl-0 .bn-content .pvn-hero-meta {
    display: flex; flex-wrap: wrap; align-items: center; gap: 18px;
    margin-top: 30px; padding-top: 24px;
    border-top: 1px solid rgba(255,255,255,0.18);
}
.bnl-0 .pvn-meta-item { font-size: 0.84rem; letter-spacing: 0.5px; color: rgba(255,255,255,0.78); }
.bnl-0 .pvn-meta-item strong {
    display: block; font-family: var(--pvn-serif); font-style: italic;
    font-size: 1.3rem; font-weight: 600; color: #fff; letter-spacing: 0;
}
.bnl-0 .pvn-meta-divider { width: 1px; height: 34px; background: rgba(255,255,255,0.2); }

/* ============================================================= */
/* FREE GUIDE card (glass)                                       */
/* ============================================================= */
.pvn-gift-card {
    position: relative;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.18);
    backdrop-filter: blur(8px);
    border-radius: 26px; padding: 46px 38px; text-align: center;
    box-shadow: 0 30px 70px rgba(0,0,0,0.28);
    overflow: hidden;
}
.pvn-gift-card::before {
    content: ""; position: absolute; top: -50%; left: -50%;
    width: 200%; height: 200%;
    background: conic-gradient(from 0deg, transparent 0%, rgba(63,179,168,0.18) 25%, transparent 50%);
    animation: pvn-spin 9s linear infinite; z-index: 0;
}
.pvn-gift-card > * { position: relative; z-index: 1; }
@keyframes pvn-spin { to { transform: rotate(360deg); } }
.pvn-gift-card .pvn-h3 { color: #fff; }
.pvn-gift-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 80px; height: 80px; border-radius: 50%;
    background: var(--pvn-turq); color: #fff; font-size: 32px;
    margin-bottom: 24px; box-shadow: 0 14px 34px rgba(63,179,168,0.5);
}

/* ============================================================= */
/* SERVICES                                                      */
/* ============================================================= */
.pvn-services-head { margin-bottom: clamp(36px, 4vw, 56px); }
.pvn-services-head .pvn-h2 { margin-bottom: 0; }
.pvn-services-intro { display: flex; align-items: flex-end; }
.pvn-services-intro .pvn-lead { margin-bottom: 6px; }
.pvn-services-grid { margin-bottom: 40px; }

/* card is now a full-bleed image card (anchor) */
.pvn-service-card {
    display: flex; flex-direction: column; height: 100%;
    background: #fff;
    border: 1px solid rgba(201,168,220,0.35);
    border-radius: 22px; overflow: hidden;
    position: relative;
    text-decoration: none;
    transition: transform 0.5s var(--pvn-ease), box-shadow 0.5s var(--pvn-ease), border-color 0.5s ease;
}
.pvn-service-card:hover, .pvn-service-card:focus {
    transform: translateY(-10px);
    box-shadow: var(--pvn-shadow-md);
    border-color: transparent;
}

/* media / image */
.pvn-service-media {
    position: relative; display: block;
    height: 200px; overflow: hidden;
}
.pvn-service-media img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform 0.7s var(--pvn-ease);
}
.pvn-service-card:hover .pvn-service-media img { transform: scale(1.07); }
.pvn-service-media::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(75,24,107,0.32), rgba(75,24,107,0) 55%);
}
.pvn-service-tag {
    position: absolute; z-index: 2; top: 16px; left: 16px;
    font-family: var(--pvn-sans);
    font-size: 0.66rem; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600;
    color: var(--pvn-deep);
    background: rgba(255,255,255,0.92);
    padding: 7px 14px; border-radius: 30px;
    backdrop-filter: blur(4px);
}
.pvn-service-tag-accent { background: var(--pvn-turq); color: #fff; }

/* body */
.pvn-service-body {
    display: flex; flex-direction: column; flex: 1 1 auto;
    padding: 40px 30px 32px; position: relative;
}
.pvn-service-icon {
    position: absolute; top: -34px; left: 30px;
    display: inline-flex; align-items: center; justify-content: center;
    width: 64px; height: 64px; border-radius: 50%;
    background: #fff; color: var(--pvn-turq);
    font-size: 25px;
    box-shadow: var(--pvn-shadow-sm);
    transition: background 0.45s var(--pvn-ease), color 0.45s var(--pvn-ease), transform 0.45s var(--pvn-ease);
}
.pvn-service-card:hover .pvn-service-icon {
    background: var(--pvn-turq); color: #fff; transform: translateY(-4px) rotate(-6deg);
}
.pvn-service-body .pvn-h3 { margin-top: 10px; }
.pvn-service-body .pvn-body { margin-bottom: 22px; }
.pvn-service-link {
    margin-top: auto;
    font-family: var(--pvn-sans);
    font-weight: 600; font-size: 0.8rem; letter-spacing: 1px; text-transform: uppercase;
    color: var(--pvn-purple);
    display: inline-flex; align-items: center; gap: 8px;
}
.pvn-service-link i { transition: transform 0.35s var(--pvn-ease); }
.pvn-service-card:hover .pvn-service-link { color: var(--pvn-turq); }
.pvn-service-card:hover .pvn-service-link i { transform: translateX(6px); }

/* featured card accent */
.pvn-service-card-feature { border-color: rgba(63,179,168,0.5); }
.pvn-service-card-feature::before {
    content: ""; position: absolute; z-index: 3; inset: 0 0 auto 0; height: 4px;
    background: linear-gradient(90deg, var(--pvn-turq), var(--pvn-purple));
}

/* CTA row */
.pvn-services-cta { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.pvn-services-secondary { color: var(--pvn-purple); }

/* large circular section icons */
.pvn-podcast-icon, .pvn-newsletter-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 92px; height: 92px; border-radius: 50%;
    background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.24);
    color: #fff; font-size: 36px; margin-bottom: 26px;
}

/* ============================================================= */
/* WHY cards                                                     */
/* ============================================================= */
.pvn-why-card {
    background: #fff; border-radius: 24px; padding: 44px 34px 40px;
    height: 100%; position: relative; box-shadow: var(--pvn-shadow-sm);
    transition: transform 0.45s var(--pvn-ease), box-shadow 0.45s var(--pvn-ease);
}
.pvn-why-card:hover { transform: translateY(-8px); box-shadow: var(--pvn-shadow-md); }
.pvn-why-num {
    display: inline-block; font-family: var(--pvn-serif); font-style: italic;
    font-size: 3.2rem; font-weight: 600; color: transparent;
    background: linear-gradient(135deg, var(--pvn-light), var(--pvn-turq));
    -webkit-background-clip: text; background-clip: text;
    line-height: 1; margin-bottom: 18px;
}
.pvn-quote {
    margin: 22px 0 0 0; padding: 22px 24px 20px;
    background: var(--pvn-soft); border-radius: 16px;
    font-family: var(--pvn-serif); font-style: italic;
    font-size: 1.14rem; color: var(--pvn-deep); position: relative;
}
.pvn-quote i { color: var(--pvn-light); margin-right: 8px; font-size: 0.9em; }

/* ============================================================= */
/* SERVICE AREA                                                  */
/* ============================================================= */
.pvn-area-intro { padding-right: 30px; }
.pvn-area-intro .pvn-body { margin-bottom: 24px; }

/* online-availability highlight */
.pvn-area-online {
    display: inline-flex; align-items: center; gap: 14px;
    background: #fff; border: 1px solid rgba(201,168,220,0.4);
    border-radius: 40px; padding: 12px 22px 12px 12px;
    margin-bottom: 30px; box-shadow: var(--pvn-shadow-sm);
}
.pvn-area-online-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 42px; border-radius: 50%;
    background: var(--pvn-turq); color: #fff; font-size: 18px;
}
.pvn-area-online-text { font-size: 0.96rem; color: var(--pvn-ink); }
.pvn-area-online-text strong { color: var(--pvn-deep); }

/* location card */
.pvn-area-card {
    background: #fff; border-radius: 26px;
    padding: 38px 34px 32px;
    box-shadow: var(--pvn-shadow-md);
    position: relative; overflow: hidden;
}
.pvn-area-card::before {
    content: ""; position: absolute; z-index: 0; top: -60px; right: -60px;
    width: 200px; height: 200px; border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(201,168,220,0.35), rgba(201,168,220,0) 70%);
}
.pvn-area-card > * { position: relative; z-index: 1; }
.pvn-area-card-label {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--pvn-sans);
    font-size: 0.72rem; letter-spacing: 2px; text-transform: uppercase; font-weight: 600;
    color: var(--pvn-purple); margin-bottom: 22px;
}
.pvn-area-card-label i { color: var(--pvn-turq); }

/* pills */
.pvn-area-list {
    list-style: none; margin: 0 0 26px 0; padding: 0;
    display: flex; flex-wrap: wrap; gap: 10px;
}
.pvn-area-pill a {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--pvn-sans); font-size: 0.92rem; font-weight: 500;
    color: var(--pvn-ink);
    background: var(--pvn-soft);
    border: 1px solid transparent;
    border-radius: 30px; padding: 10px 18px;
    transition: transform 0.35s var(--pvn-ease), background 0.35s ease, color 0.35s ease, box-shadow 0.35s ease;
}
.pvn-area-pill a:hover {
    background: var(--pvn-turq); color: #fff;
    transform: translateY(-3px);
    box-shadow: 0 10px 22px rgba(63,179,168,0.34);
}
.pvn-area-pill-home a {
    background: #fff; border-color: var(--pvn-light); color: var(--pvn-deep); font-weight: 600;
}
.pvn-area-pill-home a span {
    font-size: 0.64rem; letter-spacing: 1px; text-transform: uppercase;
    background: var(--pvn-turq); color: #fff; border-radius: 20px; padding: 3px 9px;
}
.pvn-area-pill-home a:hover { background: var(--pvn-deep); color: #fff; border-color: var(--pvn-deep); }
.pvn-area-pill-home a:hover span { background: #fff; color: var(--pvn-deep); }

.pvn-area-link {
    position: relative; display: inline-block;
    font-family: var(--pvn-sans); font-weight: 600; letter-spacing: 1px; color: var(--pvn-purple);
}
.pvn-area-link i { margin-left: 7px; transition: transform 0.35s var(--pvn-ease); }
.pvn-area-link:hover { color: var(--pvn-turq); }
.pvn-area-link:hover i { transform: translateX(7px); }

/* ============================================================= */
/* scroll-reveal (load-based)                                    */
/* ============================================================= */
.pvn-reveal {
    opacity: 0; transform: translateY(40px);
    animation: pvn-rise 1s var(--pvn-ease) forwards;
}
.pvn-delay-1 { animation-delay: 0.16s; }
.pvn-delay-2 { animation-delay: 0.32s; }
@keyframes pvn-rise { to { opacity: 1; transform: translateY(0); } }

@media (prefers-reduced-motion: reduce) {
    .pvn-reveal { animation: none; opacity: 1; transform: none; }
    .pvn-has-orbs::before, .pvn-has-orbs::after, .pvn-has-glow::before,
    .pvn-gift-card::before, .bnl-0 .pvn-hero-img, .bnl-0 .pvn-hero-img-mob { animation: none; }
}

/* ============================================================= */
/* responsive                                                    */
/* ============================================================= */
@media screen and (max-width: 1023px) {
    /*.bnl-0 .pvn-hero-img-mob { height: 520px; }*/
    .bnl-0 .bn-content {
        max-width: 100%; margin: 0 12px;
        background: linear-gradient(150deg, rgba(43,11,63,0.94), rgba(75,24,107,0.9));
        padding: 34px 26px;
    }
    .bnl-0 .bn-content .pvn-hero-meta { gap: 14px; }
    .bnl-0 .pvn-meta-divider { display: none; }
    .pvn-welcome-img-cell, .pvn-deck-img-cell, .pvn-local-img-cell { margin-bottom: 50px; }
    .pvn-guide-cta { margin-top: 30px; }
    .pvn-has-orbs::before, .pvn-has-orbs::after { width: 220px; height: 220px; }
    .pvn-btn-row { gap: 16px; }
    .pvn-services-intro { margin-top: 18px; }
    .pvn-service-media { height: 180px; }
    .pvn-area-intro { padding-right: 0; margin-bottom: 40px; }
}
@media screen and (max-width: 640px) {
    .pvn-btn { width: 100%; text-align: center; }
    .pvn-btn-row { flex-direction: column; align-items: stretch; }
    .pvn-text-link { text-align: center; }
}

/* ============================================================= */
/* ORACLE FANNED CARDS  —  hover the stack to spread wider       */
/* ============================================================= */
.pvn-oracle-fan {
    position: relative;
    width: 100%;
    max-width: 460px;
    height: 440px;
    margin: 0 auto;
    perspective: 1400px;
}
.pvn-oracle-fan .pvn-oc {
    position: absolute;
    left: 50%; top: 50%;
    width: 210px; height: 320px;
    margin: -160px 0 0 -105px;        /* center anchor */
    transform-origin: bottom center;
    transition: transform 0.6s var(--pvn-ease), filter 0.6s var(--pvn-ease);
    will-change: transform;
}
/* resting fan — gentle spread */
.pvn-oracle-fan .pvn-oc-center { transform: rotate(0deg)   translateY(0);     z-index: 3; }
.pvn-oracle-fan .pvn-oc-left   { transform: rotate(-12deg) translate(-46px, 26px); z-index: 2; }
.pvn-oracle-fan .pvn-oc-right  { transform: rotate(12deg)  translate(46px, 26px);  z-index: 2; }

/* spread WIDER on hover of the whole stack */
.pvn-oracle-fan:hover .pvn-oc-center { transform: rotate(0deg)   translateY(-34px); }
.pvn-oracle-fan:hover .pvn-oc-left   { transform: rotate(-22deg) translate(-128px, 22px); }
.pvn-oracle-fan:hover .pvn-oc-right  { transform: rotate(22deg)  translate(128px, 22px); }

/* the card face */
.pvn-oracle-fan .pvn-oc-face {
    position: relative;
    width: 100%; height: 100%;
    border-radius: 18px;
    background:
        linear-gradient(160deg, rgba(255,255,255,0.18), rgba(255,255,255,0.04)),
        linear-gradient(160deg, var(--pvn-purple), var(--pvn-deep));
    background-size: cover; background-position: center;
    border: 1.5px solid rgba(255,255,255,0.7);
    box-shadow: 0 22px 50px rgba(43,11,63,0.4);
    display: flex; flex-direction: column;
    align-items: center; justify-content: flex-end;
    overflow: hidden;
}
/* card image fills the face */
.pvn-oracle-fan .pvn-oc-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover; display: block; z-index: 0;
}
/* purple scrim over image for tone + label readability */
.pvn-oracle-fan .pvn-oc-face::before {
    content: ""; position: absolute; inset: 0; z-index: 1;
    background:
        linear-gradient(to top, rgba(43,11,63,0.85) 0%, rgba(43,11,63,0.15) 45%, rgba(43,11,63,0.1) 100%),
        linear-gradient(160deg, rgba(122,63,160,0.35), rgba(75,24,107,0.35));
}
/* subtle inner frame line */
.pvn-oracle-fan .pvn-oc-face::after {
    content: ""; position: absolute; inset: 12px; z-index: 2;
    border: 1px solid rgba(255,255,255,0.45);
    border-radius: 11px; pointer-events: none;
}
.pvn-oracle-fan .pvn-oc-label {
    position: relative; z-index: 3;
    margin-bottom: 26px;
    font-family: var(--pvn-serif); font-style: italic;
    font-size: 1.4rem; color: #fff; letter-spacing: 0.5px;
    text-shadow: 0 2px 10px rgba(0,0,0,0.4);
}

/* lift + brighten the card you point at directly */
.pvn-oracle-fan .pvn-oc:hover { filter: brightness(1.08); z-index: 5; }

/* responsive */
@media screen and (max-width: 1023px) {
    .pvn-oracle-fan { height: 380px; max-width: 380px; }
    .pvn-oracle-fan .pvn-oc { width: 180px; height: 274px; margin: -137px 0 0 -90px; }
    .pvn-oracle-fan:hover .pvn-oc-left  { transform: rotate(-20deg) translate(-96px, 20px); }
    .pvn-oracle-fan:hover .pvn-oc-right { transform: rotate(20deg)  translate(96px, 20px); }
}
@media (prefers-reduced-motion: reduce) {
    .pvn-oracle-fan .pvn-oc { transition: none; }
}

/* ============================================================= */
/* ORACLE SECTION  —  text left, fanned cards right (dark bg)    */
/* ============================================================= */
.pvn-oracle-section { overflow: hidden; }
.pvn-oracle-copy { padding-right: 30px; }
.pvn-h2-light { color: #fff; }
.pvn-h2-light .pvn-italic { color: var(--pvn-light); }
.pvn-body-on-dark { color: rgba(255,255,255,0.88); }
.pvn-body-on-dark em { color: #fff; font-style: italic; }

/* light ghost button for the dark section (matches pill sizing) */
.pvn-btn-ghost-light {
    background: transparent; border: 2px solid rgba(255,255,255,0.6); color: #fff;
}
.pvn-btn-ghost-light::before { background: #fff; }
.pvn-btn-ghost-light:hover, .pvn-btn-ghost-light:focus { color: var(--pvn-deep); transform: translateY(-4px); }
.pvn-btn-ghost-light:hover::before, .pvn-btn-ghost-light:focus::before { transform: translateY(0); }

/* visual column right-aligns the fan */
.pvn-oracle-visual { display: flex; justify-content: center; }

@media screen and (max-width: 1023px) {
    .pvn-oracle-copy { padding-right: 0; margin-bottom: 30px; }
}

/* ============================================================= */
/* TESTIMONIALS  —  3 quote cards                                */
/* ============================================================= */
.pvn-testi-grid { margin-top: 0; }
.pvn-testi-card {
    position: relative;
    background: #fff;
    border: 1px solid rgba(122,63,160,0.12);
    border-radius: 18px;
    padding: 40px 32px 32px;
    height: 100%;
    box-shadow: 0 18px 44px rgba(75,24,107,0.08);
    transition: transform 0.45s var(--pvn-ease), box-shadow 0.45s var(--pvn-ease);
    display: flex; flex-direction: column;
}
.pvn-testi-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 26px 60px rgba(75,24,107,0.14);
}
.pvn-testi-mark {
    color: var(--pvn-turq);
    font-size: 1.6rem;
    margin-bottom: 16px;
    opacity: 0.9;
}
.pvn-testi-text {
    font-family: var(--pvn-serif);
    font-style: italic;
    font-size: 1.22rem;
    line-height: 1.55;
    color: var(--pvn-ink);
    margin: 0 0 24px 0;
    flex: 1 1 auto;
}
.pvn-testi-author {
    display: flex; flex-direction: column; gap: 2px;
    padding-top: 18px;
    border-top: 1px solid rgba(122,63,160,0.14);
}
.pvn-testi-name {
    font-family: var(--pvn-sans);
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.3px;
    color: var(--pvn-deep);
}
.pvn-testi-role {
    font-family: var(--pvn-sans);
    font-size: 0.8rem;
    letter-spacing: 0.4px;
    color: var(--pvn-purple);
}
@media screen and (max-width: 1023px) {
    .pvn-testi-card { margin-bottom: 4px; }
}

/* ============================================================================
   ABOUT PAGE — additions
   (philosophy list card · story spill paragraph · video embed placeholder)
   Scoped pvn-* classes, reusing existing tokens. No wrapper styling.
   ============================================================================ */

/* story: the full-width pair of paragraphs under the two-column intro */
.pvn-story-more { margin-top: clamp(16px, 2.5vw, 28px); }
.pvn-story-more .pvn-body { max-width: 70ch; }

/* --- My Coaching Philosophy: the "I help women" card on dark --- */
.pvn-phil-card {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 22px;
    padding: clamp(26px, 3vw, 38px);
    backdrop-filter: blur(4px);
    box-shadow: 0 24px 60px rgba(20, 6, 31, 0.35);
}
.pvn-phil-intro {
    font-family: var(--pvn-serif);
    font-size: clamp(1.15rem, 1.6vw, 1.4rem);
    font-style: italic;
    color: #fff;
    margin: 0 0 18px;
    line-height: 1.4;
}
.pvn-phil-list { list-style: none; margin: 0; padding: 0; }
.pvn-phil-list li {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    font-family: var(--pvn-sans);
    font-size: 1rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.84);
    padding: 12px 0;
}
.pvn-phil-list li + li { border-top: 1px solid rgba(255, 255, 255, 0.10); }
.pvn-phil-list li i {
    flex: 0 0 26px;
    width: 26px; height: 26px;
    display: inline-flex; align-items: center; justify-content: center;
    margin-top: 2px;
    border-radius: 50%;
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    font-size: 0.72rem;
    box-shadow: 0 6px 14px rgba(63, 179, 168, 0.32);
}

/* --- What To Expect: light checklist card --- */
.pvn-expect-card {
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 24px;
    padding: clamp(28px, 3.4vw, 48px);
    box-shadow: 0 18px 48px rgba(75, 24, 107, 0.09);
}
.pvn-expect-list { list-style: none; margin: 0; padding: 0; }
.pvn-expect-list li {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    font-family: var(--pvn-sans);
    font-size: clamp(1.3rem, 1.15vw, 1.08rem);
    line-height: 1.65;
    color: var(--pvn-ink-soft, #5c5366);
    padding: 16px 0;
}
.pvn-expect-list li + li { border-top: 1px solid var(--pvn-line, rgba(75,24,107,0.10)); }
.pvn-expect-list li i {
    flex: 0 0 30px;
    width: 30px; height: 30px;
    display: inline-flex; align-items: center; justify-content: center;
    margin-top: 1px;
    border-radius: 50%;
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    font-size: 0.78rem;
    box-shadow: 0 8px 18px rgba(63, 179, 168, 0.30);
}
.pvn-expect-note {
    margin: clamp(20px, 2.4vw, 28px) 0 0;
    padding-top: clamp(20px, 2.4vw, 28px);
    border-top: 1px dashed var(--pvn-line, rgba(75,24,107,0.16));
    font-family: var(--pvn-sans);
    font-size: 1rem;
    line-height: 1.7;
    color: var(--pvn-ink-soft, #5c5366);
    font-style: italic;
}

/* --- The Women I Walk Beside: video embed placeholder --- */
.pvn-video-frame {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 30px 70px rgba(75, 24, 107, 0.20);
}
.pvn-video-placeholder {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 18px;
    aspect-ratio: 16 / 10;
    text-align: center;
    padding: 28px;
    color: #fff;
    background:
        radial-gradient(120% 90% at 30% 0%, rgba(122, 63, 160, 0.55), transparent 60%),
        linear-gradient(160deg, var(--pvn-deep), var(--pvn-deep-2));
}
.pvn-video-icon {
    width: 76px; height: 76px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.30);
    color: #fff;
    font-size: 1.5rem;
    padding-left: 4px;
    transition: transform 0.4s var(--pvn-ease), background 0.4s var(--pvn-ease);
}
.pvn-video-frame:hover .pvn-video-icon {
    transform: scale(1.08);
    background: var(--pvn-turq);
}
.pvn-video-text {
    font-family: var(--pvn-sans);
    font-size: 0.92rem;
    letter-spacing: 0.4px;
    color: rgba(255, 255, 255, 0.78);
    max-width: 30ch;
}

@media screen and (max-width: 1023px) {
    .pvn-phil-card { margin-top: 24px; }
}

/* ============================================================================
   SERVICE DETAIL PAGES — additions
   (inline subhead · benefit cards grid)
   ============================================================================ */

/* a secondary heading inside a text column (e.g. "What ... Looks Like") */
.pvn-subhead {
    margin-top: clamp(20px, 2.6vw, 30px);
    margin-bottom: 10px;
}

/* benefit cards (2-up): soft surface, turquoise icon chip, hover lift */
.pvn-benefit-grid { margin-top: clamp(8px, 1.5vw, 16px); }
.pvn-benefit-grid > .cell { padding-top: clamp(10px, 1.4vw, 18px); padding-bottom: clamp(10px, 1.4vw, 18px); }
.pvn-benefit-card {
    height: 100%;
    display: flex;
    align-items: center;
    gap: 18px;
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 20px;
    padding: clamp(30px, 3vw, 40px) clamp(24px, 2.4vw, 32px);
    box-shadow: 0 16px 40px rgba(75, 24, 107, 0.08);
    transition: transform 0.4s var(--pvn-ease), box-shadow 0.4s var(--pvn-ease);
}
.pvn-benefit-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 26px 56px rgba(75, 24, 107, 0.14);
}
.pvn-benefit-card .pvn-body { margin: 0; align-self: center; }
.pvn-benefit-icon {
    flex: 0 0 52px;
    width: 52px; height: 52px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 16px;
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    font-size: 1.15rem;
    box-shadow: 0 10px 22px rgba(63, 179, 168, 0.30);
}

/* ============================================================================
   FAQ PAGE — accordion (native <details>/<summary>, CSS-only)
   ============================================================================ */
.pvn-faq-wrap { width: 100%; }

.pvn-faq-item {
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 18px;
    margin-bottom: 16px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(75, 24, 107, 0.06);
    transition: box-shadow 0.4s var(--pvn-ease), border-color 0.4s var(--pvn-ease);
}
.pvn-faq-item[open] {
    border-color: rgba(63, 179, 168, 0.45);
    box-shadow: 0 20px 46px rgba(75, 24, 107, 0.12);
}

/* the clickable question row */
.pvn-faq-q {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: clamp(18px, 2.2vw, 26px) clamp(20px, 2.6vw, 30px);
    font-family: var(--pvn-serif);
    font-size: clamp(1.1rem, 1.7vw, 1.4rem);
    font-weight: 500;
    color: var(--pvn-deep);
    transition: color 0.3s ease;
}
.pvn-faq-q::-webkit-details-marker { display: none; }   /* hide default arrow */
.pvn-faq-q::marker { content: ""; }
.pvn-faq-item[open] .pvn-faq-q { color: var(--pvn-turq-d); }
.pvn-faq-q:hover { color: var(--pvn-purple, #7A3FA0); }

/* plus / minus icon chip */
.pvn-faq-icon {
    flex: 0 0 38px;
    position: relative;
    width: 38px; height: 38px;
    border-radius: 50%;
    background: var(--pvn-soft);
    border: 1px solid rgba(75, 24, 107, 0.12);
    transition: background 0.35s var(--pvn-ease), transform 0.35s var(--pvn-ease);
}
.pvn-faq-icon::before,
.pvn-faq-icon::after {
    content: "";
    position: absolute;
    left: 50%; top: 50%;
    background: var(--pvn-turq-d);
    border-radius: 2px;
    transition: transform 0.35s var(--pvn-ease), background 0.3s ease;
}
.pvn-faq-icon::before { width: 14px; height: 2px; transform: translate(-50%, -50%); }
.pvn-faq-icon::after  { width: 2px; height: 14px; transform: translate(-50%, -50%); }
.pvn-faq-item[open] .pvn-faq-icon {
    background: var(--pvn-turq);
    transform: rotate(180deg);
}
.pvn-faq-item[open] .pvn-faq-icon::before,
.pvn-faq-item[open] .pvn-faq-icon::after { background: #fff; }
.pvn-faq-item[open] .pvn-faq-icon::after { transform: translate(-50%, -50%) scaleY(0); }

/* the answer body */
.pvn-faq-a {
    padding: 0 clamp(20px, 2.6vw, 30px) clamp(20px, 2.4vw, 26px);
}
.pvn-faq-a .pvn-body { margin: 0; max-width: 70ch; }

/* gentle open animation */
.pvn-faq-item[open] .pvn-faq-a {
    animation: pvnFaqIn 0.4s var(--pvn-ease) both;
}
@keyframes pvnFaqIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.pvn-faq-cta { margin-top: clamp(28px, 3.5vw, 44px); }

@media (prefers-reduced-motion: reduce) {
    .pvn-faq-item, .pvn-faq-icon, .pvn-faq-icon::before, .pvn-faq-icon::after { transition: none !important; }
    .pvn-faq-item[open] .pvn-faq-a { animation: none !important; }
}

/* ============================================================================
   CONTACT PAGE — additions
   (reach options · direct details · socials · contact form card)
   ============================================================================ */
.pvn-contact-intro .pvn-lead { max-width: 60ch; margin-left: auto; margin-right: auto; }

/* the left aside wrapper */
.pvn-contact-aside {
    height: 100%;
    background: linear-gradient(165deg, var(--pvn-deep), var(--pvn-deep-2));
    border-radius: 24px;
    padding: clamp(26px, 3vw, 40px);
    color: #fff;
    box-shadow: 0 30px 70px rgba(75, 24, 107, 0.22);
    position: relative;
    overflow: hidden;
}
.pvn-contact-aside::before {
    content: "";
    position: absolute;
    right: -60px; top: -60px;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(63,179,168,0.35), transparent 70%);
    pointer-events: none;
}

/* reach options list */
.pvn-reach-list, .pvn-direct-list {
    list-style: none; margin: 0; padding: 0; position: relative; z-index: 1;
}
.pvn-reach-list > li,
.pvn-direct-list > li { margin: 0; }
.pvn-reach-list > li + li,
.pvn-direct-list > li + li { margin-top: 6px; }

.pvn-reach-list > li,
.pvn-reach-row-link,
.pvn-direct-row {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 14px;
    border-radius: 14px;
    color: #fff;
    text-decoration: none;
    transition: background 0.3s var(--pvn-ease), transform 0.3s var(--pvn-ease);
}
.pvn-reach-row-link, .pvn-direct-row { width: 100%; }
.pvn-reach-row-link:hover,
.pvn-direct-row:hover { background: rgba(255,255,255,0.08); transform: translateX(4px); }

.pvn-reach-icon {
    flex: 0 0 46px;
    width: 46px; height: 46px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 14px;
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.20);
    color: var(--pvn-light);
    font-size: 1.1rem;
}
.pvn-direct-row:hover .pvn-reach-icon,
.pvn-reach-row-link:hover .pvn-reach-icon { background: var(--pvn-turq); color: #fff; border-color: transparent; }

.pvn-reach-text { display: flex; flex-direction: column; line-height: 1.35; }
.pvn-reach-text strong { font-family: var(--pvn-sans); font-weight: 600; font-size: 1.02rem; color: #fff; word-break: break-word; }
.pvn-reach-sub { font-size: 0.84rem; color: rgba(255,255,255,0.62); }

.pvn-reach-arrow { margin-left: auto; color: var(--pvn-light); font-size: 0.95rem; transition: transform 0.3s var(--pvn-ease); }
.pvn-reach-row-link:hover .pvn-reach-arrow { transform: translateX(4px); color: #fff; }

.pvn-contact-divider {
    height: 1px;
    background: rgba(255,255,255,0.14);
    margin: 18px 0;
    position: relative; z-index: 1;
}

/* socials */
.pvn-contact-social { margin-top: 24px; position: relative; z-index: 1; }
.pvn-contact-social-label {
    display: block;
    font-family: var(--pvn-sans);
    font-size: 0.78rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.60);
    margin-bottom: 12px;
}
.pvn-social-row { display: flex; gap: 12px; }
.pvn-social-btn {
    width: 44px; height: 44px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.22);
    color: #fff;
    text-decoration: none;
    transition: background 0.3s var(--pvn-ease), transform 0.3s var(--pvn-ease), border-color 0.3s ease;
}
.pvn-social-btn:hover { background: var(--pvn-turq); border-color: transparent; transform: translateY(-3px); }

/* ---- contact form card ---- */
.pvn-contact-form-card {
    height: 100%;
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 24px;
    padding: clamp(28px, 3.2vw, 44px);
    box-shadow: 0 30px 70px rgba(75, 24, 107, 0.10);
}
.pvn-form-title { margin: 0 0 6px; }
.pvn-form-note { font-family: var(--pvn-sans); color: var(--pvn-ink-soft); margin: 0 0 24px; font-size: 0.96rem; }

.pvn-form-grid { display: flex; flex-wrap: wrap; gap: 18px; }
.pvn-field { flex: 1 1 calc(50% - 9px); display: flex; flex-direction: column; }
.pvn-field-full { flex: 1 1 100%; display: flex; flex-direction: column; }
.pvn-field label, .pvn-field-full label {
    font-family: var(--pvn-sans);
    font-size: 0.86rem;
    font-weight: 600;
    letter-spacing: 0.4px;
    color: var(--pvn-deep);
    margin-bottom: 8px;
}
.pvn-contact-form-card input,
.pvn-contact-form-card textarea {
    width: 100%;
    font-family: var(--pvn-sans);
    font-size: 1rem;
    color: var(--pvn-ink);
    background: var(--pvn-soft);
    border: 1px solid rgba(75, 24, 107, 0.14);
    border-radius: 12px;
    padding: 13px 16px;
    box-shadow: none;
    transition: border-color 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
    margin: 0;
}
.pvn-contact-form-card textarea { resize: vertical; min-height: 130px; }
.pvn-contact-form-card input:focus,
.pvn-contact-form-card textarea:focus {
    outline: none;
    background: #fff;
    border-color: var(--pvn-turq);
    box-shadow: 0 0 0 3px rgba(63, 179, 168, 0.16);
}
.pvn-form-submit { margin-top: 4px; }

@media screen and (max-width: 1023px) {
    .pvn-contact-aside { margin-bottom: 24px; }
    .pvn-field { flex: 1 1 100%; }
}

/* ---- Contact aside: wide / centered variant (form removed) ---- */
.pvn-contact-aside-wide .pvn-reach-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.pvn-contact-aside-wide .pvn-reach-list > li + li { margin-top: 0; }
.pvn-contact-aside-wide .pvn-direct-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.pvn-contact-aside-wide .pvn-direct-list > li + li { margin-top: 0; }
.pvn-contact-aside-wide .pvn-contact-social { text-align: center; }
.pvn-contact-aside-wide .pvn-social-row { justify-content: center; }

@media screen and (max-width: 720px) {
    .pvn-contact-aside-wide .pvn-reach-list,
    .pvn-contact-aside-wide .pvn-direct-list { grid-template-columns: 1fr; }
}

/* ============================================================================
   CONTACT — "Ways To Reach Me" (awesome redesign)
   3 method cards + direct contact band
   ============================================================================ */
.pvn-reach-cards { margin-bottom: clamp(8px, 1.4vw, 18px); }

/* method card */
.pvn-reach-card {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 22px;
    padding: clamp(28px, 3vw, 38px) clamp(24px, 2.6vw, 32px);
    text-decoration: none;
    overflow: hidden;
    box-shadow: 0 16px 44px rgba(75, 24, 107, 0.08);
    transition: transform 0.45s var(--pvn-ease), box-shadow 0.45s var(--pvn-ease), border-color 0.45s var(--pvn-ease);
}
/* turquoise accent bar that grows on hover */
.pvn-reach-card::before {
    content: "";
    position: absolute;
    left: 0; top: 0;
    width: 100%; height: 4px;
    background: linear-gradient(90deg, var(--pvn-turq), var(--pvn-light));
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.5s var(--pvn-ease);
}
.pvn-reach-card:hover {
    transform: translateY(-8px);
    border-color: rgba(63, 179, 168, 0.4);
    box-shadow: 0 34px 70px rgba(75, 24, 107, 0.16);
}
.pvn-reach-card:hover::before { transform: scaleX(1); }

/* watermark number */
.pvn-reach-card-num {
    position: absolute;
    top: 16px; right: 22px;
    font-family: var(--pvn-serif);
    font-size: 2.4rem;
    font-weight: 600;
    line-height: 1;
    color: rgba(75, 24, 107, 0.10);
    transition: color 0.4s var(--pvn-ease);
}
.pvn-reach-card:hover .pvn-reach-card-num { color: rgba(63, 179, 168, 0.28); }

.pvn-reach-card-icon {
    width: 60px; height: 60px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 18px;
    background: var(--pvn-soft);
    color: var(--pvn-deep);
    font-size: 1.4rem;
    margin-bottom: 8px;
    transition: background 0.4s var(--pvn-ease), color 0.4s var(--pvn-ease), transform 0.4s var(--pvn-ease);
}
.pvn-reach-card:hover .pvn-reach-card-icon {
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    transform: scale(1.06) rotate(-4deg);
}
.pvn-reach-card-title {
    font-family: var(--pvn-serif);
    font-size: clamp(1.25rem, 1.8vw, 1.5rem);
    font-weight: 600;
    color: var(--pvn-deep);
    line-height: 1.25;
}
.pvn-reach-card-sub {
    font-family: var(--pvn-sans);
    font-size: 0.95rem;
    color: var(--pvn-ink-soft);
    line-height: 1.5;
}
.pvn-reach-card-link {
    margin-top: auto;
    padding-top: 16px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--pvn-sans);
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.4px;
    color: var(--pvn-turq-d);
}
.pvn-reach-card-link i { transition: transform 0.3s var(--pvn-ease); }
.pvn-reach-card:hover .pvn-reach-card-link i { transform: translateX(5px); }

/* featured (Schedule A Call) card — dark, stands out */
.pvn-reach-card-feature {
    background: linear-gradient(165deg, var(--pvn-deep), var(--pvn-deep-2));
    border-color: transparent;
}
.pvn-reach-card-feature .pvn-reach-card-num { color: rgba(255,255,255,0.14); }
.pvn-reach-card-feature .pvn-reach-card-icon { background: rgba(255,255,255,0.12); color: #fff; }
.pvn-reach-card-feature .pvn-reach-card-title { color: #fff; }
.pvn-reach-card-feature .pvn-reach-card-sub { color: rgba(255,255,255,0.70); }
.pvn-reach-card-feature .pvn-reach-card-link { color: var(--pvn-light); }
.pvn-reach-card-feature:hover .pvn-reach-card-num { color: rgba(63,179,168,0.4); }
.pvn-reach-card-feature:hover .pvn-reach-card-icon { background: var(--pvn-turq); }

/* ---- direct contact band ---- */
.pvn-reach-intro { margin: 18px auto 0; }

.pvn-direct-band {
    margin-top: clamp(26px, 3vw, 40px);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    align-items: stretch;
    gap: clamp(16px, 1.8vw, 22px);
    background: transparent;
    border: 0;
    border-radius: 0;
    padding: 0;
}
/* shared card base — uniform vertical layout */
.pvn-direct-tile,
.pvn-direct-social {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 14px;
    padding: clamp(30px, 3vw, 42px) clamp(20px, 2vw, 28px);
    border-radius: 22px;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    box-sizing: border-box;
}
.pvn-direct-tile {
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    box-shadow: 0 14px 38px rgba(75, 24, 107, 0.07);
    justify-content: flex-start;
    transition: transform 0.4s var(--pvn-ease), box-shadow 0.4s var(--pvn-ease), border-color 0.4s var(--pvn-ease);
}
.pvn-direct-tile::before {
    content: "";
    position: absolute;
    left: 0; top: 0;
    width: 100%; height: 4px;
    background: linear-gradient(90deg, var(--pvn-turq), var(--pvn-light));
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.45s var(--pvn-ease);
}
.pvn-direct-tile:hover {
    transform: translateY(-8px);
    border-color: rgba(63, 179, 168, 0.4);
    box-shadow: 0 30px 64px rgba(75, 24, 107, 0.16);
}
.pvn-direct-tile:hover::before { transform: scaleX(1); }
.pvn-direct-tile-icon {
    flex: 0 0 64px;
    width: 64px; height: 64px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 18px;
    background: var(--pvn-soft);
    color: var(--pvn-turq-d);
    font-size: 1.45rem;
    transition: background 0.4s var(--pvn-ease), color 0.4s var(--pvn-ease), transform 0.4s var(--pvn-ease);
}
.pvn-direct-tile:hover .pvn-direct-tile-icon {
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    transform: scale(1.06) rotate(-4deg);
}
.pvn-direct-tile-text { display: flex; flex-direction: column; align-items: center; gap: 4px; line-height: 1.4; min-width: 0; width: 100%; }
.pvn-direct-tile-label {
    font-family: var(--pvn-sans);
    font-size: 0.76rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--pvn-ink-soft);
}
.pvn-direct-tile-text strong {
    font-family: var(--pvn-sans);
    font-weight: 600;
    font-size: 1.05rem;
    color: var(--pvn-deep);
    word-break: break-word;
    max-width: 100%;
}
/* social card — deep, matches card height */
.pvn-direct-social {
    justify-content: center;
    background: linear-gradient(150deg, var(--pvn-deep), var(--pvn-deep-2));
    box-shadow: 0 14px 38px rgba(75, 24, 107, 0.18);
}
.pvn-direct-social .pvn-direct-tile-label { color: rgba(255,255,255,0.72); }
.pvn-direct-social .pvn-social-row { gap: 12px; }
.pvn-direct-social .pvn-social-btn {
    width: 48px; height: 48px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.20);
    color: #fff;
    font-size: 1.05rem;
    transition: transform 0.3s var(--pvn-ease), box-shadow 0.3s var(--pvn-ease), background 0.3s var(--pvn-ease), border-color 0.3s ease;
}
.pvn-direct-social .pvn-social-btn:hover {
    background: var(--pvn-turq);
    border-color: transparent;
    transform: translateY(-4px);
    box-shadow: 0 16px 30px rgba(63, 179, 168, 0.45);
}

@media screen and (max-width: 860px) {
    .pvn-direct-band { grid-template-columns: 1fr; }
}

/* ============================================================================
   CONTACT — Schedule A Call feature panel (single premium band)
   ============================================================================ */
.pvn-schedule-panel {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: clamp(20px, 3vw, 40px);
    background: linear-gradient(140deg, var(--pvn-deep) 0%, var(--pvn-deep-2) 70%);
    border-radius: 28px;
    padding: clamp(32px, 4vw, 56px) clamp(28px, 4vw, 60px);
    text-decoration: none;
    overflow: hidden;
    box-shadow: 0 28px 70px rgba(75, 24, 107, 0.28);
    transition: transform 0.5s var(--pvn-ease), box-shadow 0.5s var(--pvn-ease);
}
.pvn-schedule-panel:hover {
    transform: translateY(-6px);
    box-shadow: 0 40px 90px rgba(75, 24, 107, 0.36);
}
/* soft moving glow */
.pvn-schedule-glow {
    position: absolute;
    top: -40%; right: -10%;
    width: 460px; height: 460px;
    background: radial-gradient(circle, rgba(63, 179, 168, 0.42), transparent 65%);
    pointer-events: none;
    transition: transform 0.7s var(--pvn-ease), opacity 0.7s var(--pvn-ease);
    opacity: 0.85;
}
.pvn-schedule-panel:hover .pvn-schedule-glow { transform: scale(1.18) translate(-12px, 12px); opacity: 1; }

.pvn-schedule-main {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: clamp(18px, 2.4vw, 30px);
    flex: 1 1 460px;
}
.pvn-schedule-icon {
    flex: 0 0 auto;
    width: clamp(64px, 6vw, 86px);
    height: clamp(64px, 6vw, 86px);
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: #fff;
    font-size: clamp(1.6rem, 2.6vw, 2.2rem);
    transition: background 0.4s var(--pvn-ease), transform 0.4s var(--pvn-ease);
}
.pvn-schedule-panel:hover .pvn-schedule-icon {
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    border-color: transparent;
    transform: scale(1.05) rotate(-4deg);
}
.pvn-schedule-text { display: flex; flex-direction: column; gap: 6px; }
.pvn-schedule-eyebrow {
    font-family: var(--pvn-sans);
    font-size: 0.78rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--pvn-light);
}
.pvn-schedule-title {
    font-family: var(--pvn-serif);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 600;
    line-height: 1.15;
    color: #fff;
}
.pvn-schedule-sub {
    font-family: var(--pvn-sans);
    font-size: 1.02rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.74);
    max-width: 520px;
}
.pvn-schedule-cta {
    position: relative;
    z-index: 1;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--pvn-turq);
    color: #fff;
    font-family: var(--pvn-sans);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    padding: 16px 34px;
    border-radius: 999px;
    box-shadow: 0 14px 30px rgba(63, 179, 168, 0.4);
    transition: background 0.35s var(--pvn-ease), transform 0.35s var(--pvn-ease), box-shadow 0.35s var(--pvn-ease);
}
.pvn-schedule-cta i { transition: transform 0.3s var(--pvn-ease); }
.pvn-schedule-panel:hover .pvn-schedule-cta {
    background: var(--pvn-turq-d);
    transform: translateY(-2px);
    box-shadow: 0 18px 38px rgba(63, 179, 168, 0.5);
}
.pvn-schedule-panel:hover .pvn-schedule-cta i { transform: translateX(5px); }

@media screen and (max-width: 720px) {
    .pvn-schedule-panel { flex-direction: column; align-items: flex-start; text-align: left; }
    .pvn-schedule-cta { width: 100%; justify-content: center; }
}

/* ---- availability strip (Open 24/7 · Appointment Based) ---- */
.pvn-availability {
    margin: clamp(20px, 2.4vw, 30px) auto 0;
    width: max-content;
    max-width: 100%;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(14px, 1.6vw, 22px);
    padding: 14px clamp(22px, 2.6vw, 34px);
    border-radius: 999px;
    background: var(--pvn-soft);
    border: 1px solid rgba(75, 24, 107, 0.10);
}
.pvn-availability-item {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-family: var(--pvn-sans);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--pvn-deep);
    letter-spacing: 0.3px;
}
.pvn-availability-item i { color: var(--pvn-turq-d); font-size: 1.05rem; }
.pvn-availability-dot {
    width: 5px; height: 5px;
    border-radius: 50%;
    background: var(--pvn-light);
    flex: 0 0 auto;
}
@media screen and (max-width: 480px) {
    .pvn-availability { flex-direction: column; gap: 10px; border-radius: 20px; }
    .pvn-availability-dot { display: none; }
}

/* ============================================================================
   SERVICE AREAS PAGE — location cards + subhead
   ============================================================================ */
.pvn-area-subhead { margin-top: clamp(24px, 3vw, 36px); }

.pvn-loc-grid { margin-top: clamp(10px, 1.5vw, 20px); }

.pvn-loc-card {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 22px;
    padding: clamp(26px, 2.6vw, 34px) clamp(22px, 2.2vw, 28px);
    text-decoration: none;
    overflow: hidden;
    box-shadow: 0 14px 40px rgba(75, 24, 107, 0.07);
    transition: transform 0.45s var(--pvn-ease), box-shadow 0.45s var(--pvn-ease), border-color 0.45s var(--pvn-ease);
}
.pvn-loc-card::before {
    content: "";
    position: absolute;
    left: 0; top: 0;
    width: 100%; height: 4px;
    background: linear-gradient(90deg, var(--pvn-turq), var(--pvn-light));
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.5s var(--pvn-ease);
}
.pvn-loc-card:hover {
    transform: translateY(-8px);
    border-color: rgba(63, 179, 168, 0.4);
    box-shadow: 0 32px 66px rgba(75, 24, 107, 0.16);
}
.pvn-loc-card:hover::before { transform: scaleX(1); }

.pvn-loc-icon {
    width: 54px; height: 54px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 16px;
    background: var(--pvn-soft);
    color: var(--pvn-turq-d);
    font-size: 1.3rem;
    transition: background 0.4s var(--pvn-ease), color 0.4s var(--pvn-ease), transform 0.4s var(--pvn-ease);
}
.pvn-loc-card:hover .pvn-loc-icon {
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    transform: scale(1.06) rotate(-4deg);
}
.pvn-loc-title {
    font-family: var(--pvn-serif);
    font-size: clamp(1.3rem, 1.9vw, 1.6rem);
    font-weight: 600;
    color: var(--pvn-deep);
    line-height: 1.2;
    margin: 4px 0 0;
}
.pvn-loc-sub {
    font-family: var(--pvn-sans);
    font-size: 0.92rem;
    line-height: 1.6;
    color: var(--pvn-ink-soft);
    margin: 0;
}
.pvn-loc-link {
    margin-top: auto;
    padding-top: 14px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--pvn-sans);
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: 0.3px;
    color: var(--pvn-turq-d);
}
.pvn-loc-link i { transition: transform 0.3s var(--pvn-ease); }
.pvn-loc-card:hover .pvn-loc-link i { transform: translateX(5px); }

/* home-base highlighted card */
.pvn-loc-card-home {
    background: linear-gradient(165deg, var(--pvn-deep), var(--pvn-deep-2));
    border-color: transparent;
}
.pvn-loc-card-home .pvn-loc-icon { background: rgba(255,255,255,0.12); color: #fff; }
.pvn-loc-card-home .pvn-loc-title { color: #fff; }
.pvn-loc-card-home .pvn-loc-sub { color: rgba(255,255,255,0.72); }
.pvn-loc-card-home .pvn-loc-link { color: var(--pvn-light); }
.pvn-loc-card-home:hover .pvn-loc-icon { background: var(--pvn-turq); }
.pvn-loc-badge {
    position: absolute;
    top: 16px; right: 16px;
    font-family: var(--pvn-sans);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--pvn-deep);
    background: var(--pvn-turq);
    padding: 5px 12px;
    border-radius: 999px;
}

/* ============================================================================
   CITY / LOCATION PAGE — local cards + testimonial quote card
   ============================================================================ */
.pvn-local-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 22px;
    padding: clamp(28px, 3vw, 40px) clamp(26px, 2.6vw, 34px);
    box-shadow: 0 14px 40px rgba(75, 24, 107, 0.07);
    transition: transform 0.45s var(--pvn-ease), box-shadow 0.45s var(--pvn-ease);
}
.pvn-local-card:hover { transform: translateY(-6px); box-shadow: 0 28px 60px rgba(75, 24, 107, 0.14); }
.pvn-local-icon {
    width: 60px; height: 60px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 18px;
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    font-size: 1.4rem;
    margin-bottom: 4px;
}
.pvn-local-card .pvn-h3 { margin: 0; }

/* testimonial quote card */
.pvn-quote-card {
    position: relative;
    margin: clamp(16px, 2vw, 26px) 0 0;
    background: linear-gradient(155deg, var(--pvn-deep), var(--pvn-deep-2));
    border-radius: 26px;
    padding: clamp(34px, 4vw, 56px) clamp(30px, 4vw, 64px);
    text-align: center;
    overflow: hidden;
    box-shadow: 0 22px 60px rgba(75, 24, 107, 0.22);
}
.pvn-quote-mark {
    display: block;
    font-family: var(--pvn-serif);
    font-size: clamp(4rem, 7vw, 6rem);
    line-height: 0.7;
    color: var(--pvn-turq);
    margin-bottom: 10px;
}
.pvn-quote-text {
    margin: 0 auto;
    padding: 0;
    border: 0;
    max-width: 760px;
    font-family: var(--pvn-serif);
    font-style: italic;
    font-size: clamp(1.25rem, 2.2vw, 1.7rem);
    line-height: 1.55;
    color: #fff;
}
.pvn-quote-author {
    margin-top: 20px;
    font-family: var(--pvn-sans);
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--pvn-light);
}
.pvn-quote-author span { color: rgba(255,255,255,0.6); }

/* --- Podcast & Audio Resources: episode cards + embed slots --- */
.pvn-episode-grid > .cell { padding-top: clamp(10px, 1.4vw, 18px); padding-bottom: clamp(10px, 1.4vw, 18px); }
.pvn-episode-card {
    height: 100%;
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75,24,107,0.10));
    border-radius: 24px;
    padding: clamp(26px, 3vw, 42px);
    box-shadow: 0 18px 48px rgba(75, 24, 107, 0.09);
    transition: transform 0.5s var(--pvn-ease), box-shadow 0.5s var(--pvn-ease);
}
.pvn-episode-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 28px 60px rgba(75, 24, 107, 0.14);
}
.pvn-episode-tag {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    margin-bottom: 16px;
    font-family: var(--pvn-sans);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 1.6px;
    text-transform: uppercase;
    color: var(--pvn-purple);
}
.pvn-episode-tag i {
    width: 30px; height: 30px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: var(--pvn-soft-bg, #F4EEF8);
    color: var(--pvn-purple);
    font-size: 0.82rem;
}
.pvn-episode-card .pvn-h3 { margin-top: 0; }
.pvn-episode-card p {
    font-family: var(--pvn-sans);
    font-size: clamp(1rem, 1.1vw, 1.06rem);
    line-height: 1.7;
    color: var(--pvn-ink-soft, #5c5366);
    margin: 0 0 clamp(18px, 2vw, 24px);
}
/* embed slot — live: replace inner markup with the actual audio/video player */
.pvn-embed-slot {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 10px;
    min-height: 150px;
    padding: 28px 20px;
    border: 1px dashed var(--pvn-line, rgba(75,24,107,0.20));
    border-radius: 18px;
    background: var(--pvn-soft-bg, #F4EEF8);
    color: var(--pvn-ink-soft, #5c5366);
}
.pvn-embed-slot i {
    width: 52px; height: 52px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    font-size: 1.1rem;
    box-shadow: 0 10px 24px rgba(63, 179, 168, 0.32);
}
.pvn-embed-slot span {
    font-family: var(--pvn-sans);
    font-size: 0.92rem;
    line-height: 1.5;
}
.pvn-episode-source {
    margin-top: clamp(16px, 1.8vw, 22px);
}
.pvn-dev-note {
    margin: clamp(18px, 2vw, 26px) 0 0;
    padding: 16px 20px;
    border-radius: 14px;
    border: 1px dashed var(--pvn-line, rgba(75,24,107,0.20));
    background: var(--pvn-soft-bg, #F4EEF8);
    font-family: var(--pvn-sans);
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--pvn-ink-soft, #5c5366);
}
/* Where To Listen — simple list */
.pvn-listen-list { list-style: none; margin: clamp(18px,2vw,26px) 0 0; padding: 0; }
.pvn-listen-list li {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    font-family: var(--pvn-sans);
    font-size: clamp(1rem, 1.15vw, 1.08rem);
    line-height: 1.65;
    color: var(--pvn-ink-soft, #5c5366);
    padding: 16px 0;
}
.pvn-listen-list li + li { border-top: 1px solid var(--pvn-line, rgba(75,24,107,0.10)); }
.pvn-listen-list li i {
    flex: 0 0 30px;
    width: 30px; height: 30px;
    display: inline-flex; align-items: center; justify-content: center;
    margin-top: 1px;
    border-radius: 50%;
    background: linear-gradient(140deg, var(--pvn-turq), var(--pvn-turq-d));
    color: #fff;
    font-size: 0.78rem;
    box-shadow: 0 8px 18px rgba(63, 179, 168, 0.30);
}

/* --- centered button row (sales pages: deck + journal CTAs) --- */
.pvn-btn-row-center { justify-content: center; }

/* --- harden outline/accent buttons against Webware .is-btn theme base --- */
a.is-btn.pvn-btn-outline,
a.is-btn.pvn-btn-outline:visited,
a.is-btn.pvn-btn-outline:focus {
    background-color: transparent;
    border: 2px solid var(--pvn-purple);
    color: var(--pvn-purple);
    opacity: 1;
}
a.is-btn.pvn-btn-outline:hover,
a.is-btn.pvn-btn-outline:active {
    color: #fff;
    border-color: var(--pvn-purple);
    opacity: 1;
}
a.is-btn.pvn-btn-accent,
a.is-btn.pvn-btn-accent:visited,
a.is-btn.pvn-btn-accent:focus,
a.is-btn.pvn-btn-accent:hover,
a.is-btn.pvn-btn-accent:active {
    border: 2px solid var(--pvn-turq);
    color: #fff;
    opacity: 1;
}


/* =====================================================================
   PVN COACHING — PETERBOROUGH LIFE-COACHING PAGE
   New components appended to the merged site.css block.
   - .pvn-deck-areas / .pvn-deck-area / .pvn-deck-area-ico  (oracle deck
     wellbeing chips, styled to glow on the deep purple background)
   - .pvn-deck-frame  (gentle accent on the deck image frame)
   - .pvn-speak-list / .pvn-why-list  (modifiers on .pvn-listen-list)
   Reuses existing PVN tokens · no wrapper edits · external CSS only.
   ===================================================================== */

/* ---- oracle deck : four wellbeing area chips (on deep bg) ---- */
.pvn-deck-areas {
    list-style: none;
    margin: clamp(20px, 2.4vw, 30px) 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.pvn-deck-area {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 11px 20px 11px 12px;
    font-family: var(--pvn-sans, "Jost", sans-serif);
    font-size: 0.98rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: #fff;
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(201, 168, 220, 0.28);
    border-radius: 999px;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    box-shadow: 0 10px 30px -16px rgba(0, 0, 0, 0.55);
    transition: transform 0.45s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1)),
                background 0.45s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1)),
                border-color 0.45s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1));
}

.pvn-deck-area:hover {
    transform: translateY(-4px);
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(63, 179, 168, 0.6);
}

.pvn-deck-area-ico {
    flex: 0 0 38px;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 1rem;
    color: #fff;
    background: linear-gradient(140deg, var(--pvn-turq, #3FB3A8), var(--pvn-turq-d, #2f978d));
    box-shadow: 0 8px 20px rgba(63, 179, 168, 0.4);
}

/* ---- deck image frame : a touch more lift than the standard blob ---- */
.pvn-img-frame-blob.pvn-deck-frame {
    filter: drop-shadow(0 34px 60px rgba(0, 0, 0, 0.4));
}

/* ---- list modifiers (speak list lives on a light bg, why list on white) ---- */
/* .pvn-speak-list & .pvn-why-list inherit .pvn-listen-list; no overrides
   are required, but a slightly tighter top margin reads better when the
   list follows body copy rather than a heading. */
.pvn-speak-list,
.pvn-why-list {
    margin-top: clamp(14px, 1.6vw, 20px);
}

/* ---- responsive ---- */
@media all and (max-width: 640px) {
    .pvn-deck-area {
        font-size: 0.92rem;
        padding: 9px 16px 9px 10px;
    }
    .pvn-deck-area-ico {
        flex: 0 0 32px;
        width: 32px;
        height: 32px;
        font-size: 0.9rem;
    }
}

/* =====================================================================
   PODCAST & AUDIO RESOURCES — additions
   - .pvn-bg-cream         alternate soft background (between sections)
   - .pvn-cta-row          spacing wrapper for a centered button row
   - .pvn-listen-list-center  centered variant of .pvn-listen-list
   - .pvn-platform-chips / .pvn-platform-chip  "Where to listen" links
   ===================================================================== */
.pvn-bg-cream { background-color: var(--pvn-cream, #FBF8FD); }

.pvn-cta-row { margin-top: clamp(24px, 3vw, 38px); }

/* centered listen list (used on Where To Listen) */
.pvn-listen-list-center {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
}

/* platform chips */
.pvn-platform-chips {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px;
    margin-top: clamp(22px, 2.6vw, 32px);
}
.pvn-platform-chip {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 12px 24px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--pvn-line, rgba(75, 24, 107, 0.12));
    color: var(--pvn-ink, #2B2330);
    font-family: var(--pvn-sans, "Jost", Arial, sans-serif);
    font-size: 0.86rem;
    font-weight: 500;
    letter-spacing: 0.3px;
    text-decoration: none;
    box-shadow: 0 8px 22px -14px rgba(75, 24, 107, 0.4);
    transition: transform 0.4s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1)),
                box-shadow 0.4s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1)),
                border-color 0.3s ease, color 0.3s ease;
}
.pvn-platform-chip i {
    font-size: 1.05rem;
    color: var(--pvn-turq, #3FB3A8);
    transition: color 0.3s ease;
}
.pvn-platform-chip:hover {
    transform: translateY(-4px);
    border-color: var(--pvn-turq, #3FB3A8);
    color: var(--pvn-purple, #7A3FA0);
    box-shadow: 0 16px 34px -16px rgba(63, 179, 168, 0.5);
}

/* ============================================================= */
/* LIVE TWEAKS (synced from production site.css)                 */
/* Webware form submit (#Submit) themed as accent pill +         */
/* special ghost button (.spl-btn) + login form square buttons.  */
/* Placed at end so they win the cascade where needed.           */
/* ============================================================= */

/* Webware form submit button -> turquoise accent pill */
input#Submit {
    position: relative; overflow: hidden;
    background-color: var(--pvn-turq) !important;
    border: 2px solid var(--pvn-turq) !important;
    color: #fff !important;
    box-shadow: 0 12px 30px rgba(63,179,168,0.34);
    height: auto;
    z-index: 1;
}
input#Submit::before {
    content: ""; position: absolute; z-index: -1; inset: 0;
    background: var(--pvn-turq-d);
    transform: translateY(101%);
    transition: transform 0.5s var(--pvn-ease);
}
input#Submit:hover, input#Submit:focus {
    color: #fff; transform: translateY(-4px);
    box-shadow: var(--pvn-shadow-md);
}
input#Submit:hover::before, input#Submit:focus::before { transform: translateY(0); }

/* harden accent/outline anchor buttons + Webware submit against .is-btn base */
a.is-btn.pvn-btn-outline, input#Submit,
a.is-btn.pvn-btn-outline:visited,
a.is-btn.pvn-btn-outline:focus {
    background-color: transparent;
    border: 2px solid var(--pvn-purple);
    color: var(--pvn-purple);
    opacity: 1;
}
a.is-btn.pvn-btn-outline:hover,
a.is-btn.pvn-btn-outline:active {
    color: #fff;
    border-color: var(--pvn-purple);
    opacity: 1;
}
a.is-btn.pvn-btn-accent,
a.is-btn.pvn-btn-accent:visited,
a.is-btn.pvn-btn-accent:focus,
a.is-btn.pvn-btn-accent:hover,
a.is-btn.pvn-btn-accent:active {
    white-space: unset;
    border: 2px solid var(--pvn-turq);
    color: #fff;
    opacity: 1;
}

/* special ghost button (e.g. on public-speaking hero) */
a.is-btn.spl-btn {
    border: 2px solid #fff;
    color: #fff !important;
}
a.is-btn.spl-btn:focus,
a.is-btn.spl-btn:hover,
a.is-btn.spl-btn:active {
    color: #40145c !important;
    border: 1px solid #fff;
    opacity: 1;
}

/* login / signup form buttons -> square corners to match global button */
.new-website-login-form .signup-container .button,
.new-website-login-form form.settings .button {
    border-radius: 0 !important;
}


/* =====================================================================
   PVN COACHING — REVIEWS / TESTIMONIALS SUBMISSION FORM
   Separate, self-contained stylesheet. Scoped under .reviews-form-container
   so it never collides with the contact form, newsletter form, or anything
   else. External CSS only · brand tokens with fallbacks · no markup edits.

   NOTE: the star widget (.rating-star span) is rendered by the platform as
   an image sprite (star-rate.png) in the base site.css. We DO NOT replace
   that sprite here — we only tidy its spacing / alignment so it sits nicely
   inside the branded card.
   ===================================================================== */

.reviews-form-container {
    --rv-deep: var(--pvn-deep, #4B186B);
    --rv-deep-2: var(--pvn-deep-2, #3a0f55);
    --rv-purple: var(--pvn-purple, #7A3FA0);
    --rv-light: var(--pvn-light, #C9A8DC);
    --rv-turq: var(--pvn-turq, #3FB3A8);
    --rv-turq-d: var(--pvn-turq-d, #2f978d);
    --rv-ink: var(--pvn-ink, #2B2330);
    --rv-ink-soft: var(--pvn-ink-soft, #5c5366);
    --rv-soft: var(--pvn-soft, #F4EEF8);
    --rv-cream: var(--pvn-cream, #FBF8FD);
    --rv-serif: var(--pvn-serif, "Cormorant Garamond", Georgia, serif);
    --rv-sans: var(--pvn-sans, "Jost", "Helvetica Neue", Arial, sans-serif);
    --rv-ease: var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1));
    --rv-border: #e4d8ee;
    --rv-field-bg: #fbf8fd;
}

/* ---- form card ---- */
.reviews-form-container #reviewform {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    max-width: 640px;
    padding: 44px 40px 38px;
    background: #fff;
    border: 1px solid var(--rv-border);
    border-radius: 22px;
    box-shadow: 0 22px 60px -28px rgba(75, 24, 107, 0.28);
}

.reviews-form-container #reviewform::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(90deg, var(--rv-deep), var(--rv-purple), var(--rv-turq));
}

/* ---- headings ---- */
.reviews-form-container .rating-experience-heading {
    margin: 0 0 4px;
    font-family: var(--rv-sans);
    font-weight: 600;
    font-size: 0.82rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--rv-turq);
}

.reviews-form-container #reviewform h2.text-center {
    margin: 0 0 10px;
    font-family: var(--rv-serif);
    font-weight: 600;
    font-size: clamp(2rem, 4vw, 2.7rem);
    line-height: 1.1;
    color: var(--rv-deep);
}

.reviews-form-container #reviewform h2.text-center b {
    font-weight: 600;
    font-style: italic;
}

.reviews-form-container #reviewform > p.text-center {
    margin: 0 auto;
    max-width: 420px;
    font-family: var(--rv-sans);
    font-size: 1rem;
    line-height: 1.6;
    color: var(--rv-ink-soft);
}

/* ---- star rating row (sprite kept; just spacing) ---- */
.reviews-form-container .review-stars {
    margin: 0 auto;
}

.reviews-form-container .rating-star {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    max-width: none;
    padding: 6px 14px;
    background: var(--rv-soft);
    border-radius: 999px;
}

.reviews-form-container .rating-star span {
    margin: 0 1px;
}

.reviews-form-container .reset-stars {
    width: auto;
    height: auto;
    line-height: 1 !important;
    padding-left: 10px;
    color: var(--rv-ink-soft);
    font-size: 0.95rem;
    align-self: center;
    transition: color 0.3s var(--rv-ease);
}

.reviews-form-container .reset-stars:hover {
    color: var(--rv-deep);
}

/* ---- the "please provide feedback" helper line ---- */
.reviews-form-container .review-feedback-form-text {
    margin: 0 0 22px;
    font-family: var(--rv-sans);
    font-size: 0.95rem;
    color: var(--rv-ink-soft);
}

/* ---- fields ---- */
.reviews-form-container .input-fields {
    margin-bottom: 18px;
    text-align: left;
}

.reviews-form-container .input-field-label,
.reviews-form-container .input-field-feedback {
    display: block;
    font-family: var(--rv-sans);
    font-weight: 600;
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--rv-deep);
}

.reviews-form-container .input-field-label .required {
    color: var(--rv-turq);
    margin-left: 3px;
    font-weight: 700;
}

.reviews-form-container #reviewform input[type="text"],
.reviews-form-container #reviewform input[type="email"],
.reviews-form-container #reviewform textarea {
    width: 100%;
    box-sizing: border-box;
    margin: 8px 0 0;
    padding: 13px 18px;
    font-family: var(--rv-sans);
    font-size: 1rem;
    color: var(--rv-ink);
    background: var(--rv-field-bg);
    border: 1.5px solid var(--rv-border);
    border-radius: 12px;
    box-shadow: none;
    transition: border-color 0.3s var(--rv-ease),
                box-shadow 0.3s var(--rv-ease),
                background 0.3s var(--rv-ease);
}

.reviews-form-container #reviewform input[type="text"],
.reviews-form-container #reviewform input[type="email"] {
    min-height: 52px;
}

.reviews-form-container #reviewform textarea {
    min-height: 130px;
    resize: vertical;
}

.reviews-form-container #reviewform input::placeholder,
.reviews-form-container #reviewform textarea::placeholder {
    color: #aa9cbb;
}

.reviews-form-container #reviewform input[type="text"]:focus,
.reviews-form-container #reviewform input[type="email"]:focus,
.reviews-form-container #reviewform textarea:focus {
    outline: none;
    background: #fff;
    border-color: var(--rv-turq);
    box-shadow: 0 0 0 3px rgba(63, 179, 168, 0.16);
}

/* ---- captcha ---- */
.reviews-form-container .review-captcha {
    margin: 4px 0 6px;
}

.reviews-form-container .review-captcha #wwcaptcha {
    display: inline-block;
}

/* ---- submit : the BUTTON LOOK is now handled globally by
   global-input-button.css (every input.button site-wide). Here we only
   keep the layout/spacing specific to this form. ---- */
.reviews-form-container .submit-review-form {
    margin-top: 8px;
    text-align: center;
}

/* ---- validation errors ---- */
.reviews-form-container span.error {
    display: block;
    margin: 6px 0 0;
    font-family: var(--rv-sans);
    font-size: 0.82rem;
    color: #cc4b37;
}

.reviews-form-container #reviewform input.error,
.reviews-form-container #reviewform textarea.error {
    border-color: #cc4b37;
    box-shadow: 0 0 0 3px rgba(204, 75, 55, 0.12);
}

/* ---- responsive ---- */
@media all and (max-width: 640px) {
    .reviews-form-container #reviewform {
        padding: 32px 22px 28px;
        border-radius: 18px;
    }
}


/* =====================================================================
   PVN COACHING — GLOBAL INPUT BUTTON STYLE
   Applies the PVN signature button to EVERY `input` with the `button` class
   anywhere on the site, regardless of any extra classes it may carry
   (e.g. .ps-login-button, .margin-top-1, .continue_btn, etc.).
   !important on visual-critical props guarantees it wins over the platform
   base `.button` / `.btn` / `.ps-*` rules no matter the cascade order.

   - Square corners (NO radius, even with extra classes)
   - Turquoise -> dark-turquoise slide-up fill (CSS-only; works on <input>)
   - -4px hover lift + soft shadow
   External CSS only · no markup changes.
   ===================================================================== */

/* Match an <input> that has the .button class AND any other classes too.
   The doubled [class~="button"] + type selectors raise specificity so this
   beats base rules like .button{border-radius:3px} and .ps-login-button. */
input.button,
input[type="submit"].button,
input[type="button"].button,
input[type="reset"].button,
input[type="submit"][class~="button"],
input[type="button"][class~="button"] {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    position: relative;
    z-index: 1;
    display: inline-block;
    box-sizing: border-box !important;
    width: auto;
    height: auto;
    font-family: var(--pvn-sans, "Jost", "Helvetica Neue", Arial, sans-serif) !important;
    letter-spacing: 1.6px !important;
    padding: 16px 44px !important;
    line-height: 1.2 !important;
    font-weight: 600 !important;
    font-size: 0.78rem !important;
    text-transform: uppercase !important;
    text-align: center;
    color: #fff !important;
    border: 2px solid var(--pvn-turq, #3FB3A8) !important;
    border-radius: 0 !important;
    -webkit-border-radius: 0 !important;
    -moz-border-radius: 0 !important;
    outline: none;
    cursor: pointer;
    box-shadow: 0 12px 30px rgba(63, 179, 168, 0.34) !important;
    background-color: var(--pvn-turq, #3FB3A8) !important;
    background-image: linear-gradient(
        to bottom,
        var(--pvn-turq, #3FB3A8) 0%,
        var(--pvn-turq, #3FB3A8) 50%,
        var(--pvn-turq-d, #2f978d) 50%,
        var(--pvn-turq-d, #2f978d) 100%
    ) !important;
    background-size: 100% 200% !important;
    background-position: 0 0 !important;
    background-repeat: no-repeat !important;
    transition: transform 0.45s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1)),
                box-shadow 0.45s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1)),
                background-position 0.5s var(--pvn-ease, cubic-bezier(0.22, 1, 0.36, 1)),
                color 0.4s ease !important;
}

input.button:hover,
input.button:focus,
input[type="submit"].button:hover,
input[type="submit"].button:focus,
input[type="button"].button:hover,
input[type="button"].button:focus,
input[type="reset"].button:hover,
input[type="reset"].button:focus {
    color: #fff !important;
    transform: translateY(-4px) !important;
    background-position: 0 100% !important;
    box-shadow: var(--pvn-shadow-md, 0 18px 50px -20px rgba(43, 35, 48, 0.5)) !important;
}

input.button:disabled,
input.button.disabled,
input[type="submit"].button:disabled,
input[type="button"].button:disabled,
input[type="reset"].button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none !important;
    background-position: 0 0 !important;
}

/* ============================================================= */
/* SAFETY NET — text on deep / purple backgrounds is always light */
/* Prevents dark headings/body from disappearing on dark sections */
/* even if is-light-text / pvn-body-soft classes were missed.     */
/* ============================================================= */
.is-wrapper > div.pvn-bg-deep .pvn-h2,
.is-wrapper > div.pvn-bg-purple .pvn-h2 { color: #fff; }
.is-wrapper > div.pvn-bg-deep .pvn-h2 .pvn-italic,
.is-wrapper > div.pvn-bg-purple .pvn-h2 .pvn-italic { color: var(--pvn-light); }
.is-wrapper > div.pvn-bg-deep .pvn-h3,
.is-wrapper > div.pvn-bg-purple .pvn-h3 { color: #fff; }
.is-wrapper > div.pvn-bg-deep .pvn-lead,
.is-wrapper > div.pvn-bg-purple .pvn-lead { color: rgba(255,255,255,0.92); }
.is-wrapper > div.pvn-bg-deep .pvn-body,
.is-wrapper > div.pvn-bg-purple .pvn-body { color: rgba(255,255,255,0.84); }

/* ============================================================= */
/* IMAGE / TEXT COLUMN GAP                                       */
/* When a decorative image frame sits in the LEFT column next to */
/* a text column, its ::before accent (inset right -24px) can    */
/* crowd the text. This adds breathing room on the image cell.   */
/* Add `pvn-img-cell-gap` to the image's cell (desktop only).    */
/* ============================================================= */
@media screen and (min-width: 1024px) {
    .cell.pvn-img-cell-gap { padding-right: clamp(34px, 4vw, 64px); }
    .cell.pvn-img-cell-gap-l { padding-left: clamp(34px, 4vw, 64px); }
}

/* ===== Soft mint background (subtle turquoise tint) — for separating
   two adjacent light sections without losing the calm brand feel ===== */
.is-wrapper > div.pvn-bg-mint{ background:#EAF6F4; }

/* ===== Simple hero (no image) — interior page banner ===== */
.pvn-hero-simple .is-container{ padding-top:clamp(110px,15vh,190px); padding-bottom:clamp(64px,9vh,120px); }

/* ===== Contact form (template 3) — intro line ===== */
.form-template-3 .ww-form-container-3 form > p{
    max-width:620px;
    margin:4px auto 32px;
    text-align:center;
    font-family:var(--pvn-serif);
    font-size:1.32rem;
    line-height:1.6;
    font-weight:400;
    color:var(--pvn-ink-soft);
}

/* =====================================================================
   Lead-magnet form (#lead-magnet-form, blog.leadmagnet "Read Our Guide Now")
   Scoped to #lead-magnet-form so it never touches contact / newsletter forms.
   Uses .ww-form-container (NOT -3). Keeps locked Foundation grid intact.
   ===================================================================== */

/* heading + intro copy */
#lead-magnet-form .ww-form-container form > h2.pvn-h2{
    text-align:center;
    margin:0 0 14px;
}
#lead-magnet-form .ww-form-container form > p.pvn-body{
    max-width:640px;
    margin:0 auto 30px;
    text-align:center;
    color:var(--pvn-ink-soft);
}

/* form shell : soft brand card with gradient accent bar */
#lead-magnet-form .ww-form-container form{
    position:relative;
    overflow:hidden;
    max-width:620px;
    margin:0 auto;
    padding:40px 38px 34px;
    background:#fff;
    border:1px solid #e4d8ee;
    border-radius:22px;
    box-shadow:0 22px 60px -28px rgba(75,24,107,0.28);
}
#lead-magnet-form .ww-form-container form::before{
    content:"";
    position:absolute;
    top:0; left:0;
    width:100%; height:5px;
    background:linear-gradient(90deg,var(--pvn-deep),var(--pvn-purple),var(--pvn-turq));
}

/* field wraps : vertical rhythm */
#lead-magnet-form .first_name_wrap,
#lead-magnet-form .email_wrap{
    margin-bottom:20px;
    text-align:left;
}

/* labels */
#lead-magnet-form .ww-form-container label{
    display:block;
    margin-bottom:8px;
    font-family:var(--pvn-sans);
    font-weight:600;
    font-size:0.82rem;
    letter-spacing:0.04em;
    text-transform:uppercase;
    color:var(--pvn-deep);
}
#lead-magnet-form .ww-form-container label .required{
    color:var(--pvn-turq);
    margin-left:3px;
    font-weight:700;
}

/* inputs */
#lead-magnet-form .ww-form-container input[type="text"],
#lead-magnet-form .ww-form-container input[type="email"]{
    width:100%;
    box-sizing:border-box;
    min-height:52px;
    margin:0;
    padding:13px 18px;
    font-family:var(--pvn-sans);
    font-size:1rem;
    color:var(--pvn-ink);
    background:#fbf8fd;
    border:1.5px solid #e4d8ee;
    border-radius:12px;
    box-shadow:none;
    transition:border-color 0.3s var(--pvn-ease),
               box-shadow 0.3s var(--pvn-ease),
               background 0.3s var(--pvn-ease);
}
#lead-magnet-form .ww-form-container input[type="text"]:focus,
#lead-magnet-form .ww-form-container input[type="email"]:focus{
    outline:none;
    background:#fff;
    border-color:var(--pvn-turq);
    box-shadow:0 0 0 3px rgba(63,179,168,0.16);
}
#lead-magnet-form .ww-form-container input::placeholder{ color:#aa9cbb; }

/* recaptcha */
#lead-magnet-form .captcha_wrap{ margin:6px 0 4px; }
#lead-magnet-form .recaptcha-block{ display:flex; justify-content:center; }

/* submit : accent pill, centered */
#lead-magnet-form .submit_wrap{
    margin-top:14px;
    text-align:center;
}
#lead-magnet-form .ww-form-container input[type="submit"].button{
    position:relative;
    overflow:hidden;
    z-index:1;
    display:inline-block;
    box-sizing:border-box;
    width:auto;
    min-width:240px;
    padding:16px 46px;
    font-family:var(--pvn-sans);
    font-weight:600;
    font-size:0.82rem;
    letter-spacing:0.12em;
    text-transform:uppercase;
    line-height:1.2;
    color:#fff !important;
    background:var(--pvn-turq);
    border:2px solid var(--pvn-turq);
    border-radius:999px;
    cursor:pointer;
    box-shadow:0 12px 30px rgba(63,179,168,0.34);
    transition:transform 0.45s var(--pvn-ease),
               box-shadow 0.45s var(--pvn-ease),
               color 0.4s ease;
}
#lead-magnet-form .ww-form-container input[type="submit"].button::before{
    content:"";
    position:absolute;
    z-index:-1;
    inset:0;
    background:var(--pvn-turq-d);
    transform:translateY(101%);
    transition:transform 0.5s var(--pvn-ease);
}
#lead-magnet-form .ww-form-container input[type="submit"].button:hover,
#lead-magnet-form .ww-form-container input[type="submit"].button:focus{
    color:#fff !important;
    transform:translateY(-4px);
    box-shadow:0 18px 50px -20px rgba(43,35,48,0.5);
}
#lead-magnet-form .ww-form-container input[type="submit"].button:hover::before,
#lead-magnet-form .ww-form-container input[type="submit"].button:focus::before{
    transform:translateY(0);
}

/* inline validation errors */
#lead-magnet-form .ww-form-container span.error{
    display:block;
    margin:6px 0 0;
    font-family:var(--pvn-sans);
    font-size:0.82rem;
    color:#cc4b37;
}
#lead-magnet-form .ww-form-container input.error{
    border-color:#cc4b37;
    box-shadow:0 0 0 3px rgba(204,75,55,0.12);
}

/* responsive */
@media all and (max-width:640px){
    #lead-magnet-form .ww-form-container form{ padding:30px 22px 26px; border-radius:18px; }
    #lead-magnet-form .ww-form-container input[type="submit"].button{ width:100%; }
}