

/* === Inline styles extracted from index.html === */

/* --- Block 1 --- */
.nav_bottom {
	transform: translateY(100%);
}

/* --- Block 2 --- */
.fs-rangeslider_handle:focus-visible {
 outline: 0rem solid transparent !important;
}

/* --- Block 3 --- */
.splide__sr {
	display: none !important;
}

/* --- Block 4 --- */
/* alter underline width based on breakpoint */
/* Desktop (default) */
#heading-underline {
 stroke-width: 8 !important;
}

/* Mobile Landscape and smaller */
@media (max-width: 1024px) {
 #heading-underline {
 stroke-width: 12 !important;
 }
}

/* Mobile Portrait and smaller */
@media (max-width: 768px) {
 #heading-underline {
 stroke-width: 12 !important;
 ;
 }
}

.flag {
 font-family:
 /* Apple */
 "Apple Color Emoji",
 /* Windows */
 "Segoe UI Emoji",
 "Segoe UI Symbol",
 /* Android/Linux */
 "Noto Color Emoji",
 /* Last fallback */
 sans-serif;
}

/* --- Block 5 --- */
/* Root (desktop) overrides */
:root, body {
 --base-color--fathom: #03174F !important;
 --_text-collection---font--primary-font: 'Ubuntu', Arial, sans-serif !important;
 --_text-collection---heading--h1: 6.6rem !important;
 --_text-collection---heading--h2: 2.9rem !important;
 --_text-collection---heading--h3: 2.65rem !important;
}
.teams_pricing-block { background-color: #03174F !important; }
.student-pricing_card { background-color: #03174F !important; }
/* Tablet overrides — target body to override index5.css body declarations */
@media screen and (max-width:991px) {
 :root, body {
 --_text-collection---font--primary-font: 'Ubuntu', Arial, sans-serif !important;
 --_text-collection---heading--h1: 5.3rem !important;
 --_text-collection---heading--h2: 2.9rem !important;
 }
 /* Hide desktop nav button so only nav_mobile-btn shows */
 .nav_big-button {
 display: none !important;
 }
 .nav-separator-left, .nav-separator-right {
 display: none !important;
 }
}
/* Mobile overrides */
@media screen and (max-width:767px) {
 :root, body {
 --_text-collection---font--primary-font: 'Ubuntu', Arial, sans-serif !important;
 --_text-collection---heading--h1: 3.1rem !important;
 --_text-collection---heading--h2: 2.2rem !important;
 }
}
@media screen and (max-width:479px) {
 :root, body {
 --_text-collection---font--primary-font: 'Ubuntu', Arial, sans-serif !important;
 --_text-collection---heading--h1: 3.1rem !important;
 --_text-collection---heading--h2: 2.2rem !important;
 }
}
/* Fix nav layout for longer menu names */
@media screen and (min-width:992px) {
 .nav_component {
 max-width: 1200px !important;
 }
 .nav_container-v2 {
 display: flex !important;
 flex-wrap: nowrap !important;
 align-items: center !important;
 max-width: 1200px !important;
 gap: 1.5rem !important;
 justify-content: space-between !important;
 padding-right: 1.5rem !important;
 padding-left: 1.5rem !important;
 }
 .nav_menu.v2 {
 width: auto !important;
 flex: 0 1 auto !important;
 }
 .nav_menu-wrapper.grid.v2 {
 gap: 0 !important;
 justify-content: flex-start !important;
 }
 .dropdown1_toggle.v2 {
 padding-left: 0.25rem !important;
 padding-right: 0.25rem !important;
 font-size: 0.95rem !important;
 }
 .nav_menu-link {
 font-size: 0.95rem !important;
 padding-left: 0.25rem !important;
 padding-right: 0.25rem !important;
 }
 .nav_big-button.button.is-icon {
 white-space: nowrap !important;
 font-size: 0.85rem !important;
 padding: 0.4rem 0.85rem !important;
 flex-shrink: 0 !important;
 margin-right: 0.5rem !important;
 box-sizing: border-box !important;
 max-height: 2.5rem !important;
 line-height: 1.2 !important;
 }
 .nav_brand {
 flex-shrink: 0 !important;
 display: flex !important;
 align-items: center !important;
 padding-left: 0.25rem !important;
 }
}
/* Mobile nav sizing — placed early to prevent FOUC */
@media (max-width: 479px) {
 .nav_container-v2 {
 padding-left: 0.75rem !important;
 padding-right: 0.4rem !important;
 }
 .nav_mobile-cta {
 margin-right: 3.2rem !important;
 }
 .nav_brand.w-nav-brand span {
 font-size: 1.0rem !important;
 }
 .nav_brand.w-nav-brand img {
 height: 28px !important;
 }
 .nav_mobile-btn.w-button {
 font-size: 0.65rem !important;
 padding: 0.35rem 0.55rem !important;
 gap: 0.25rem !important;
 white-space: nowrap !important;
 }
 .nav_mobile-btn.w-button img {
 width: 13px !important;
 height: 13px !important;
 }
}
@media (max-width: 349px) {
 .nav_brand.w-nav-brand span {
 display: none !important;
 }
}
/* Match "Supporting young learners" weight to hero-tagline (desktop only) */
@media (min-width: 480px) {
 .hero_content .text-color-black70 {
 font-weight: 500 !important;
 font-size: 0.95rem !important;
 }
 .hero_content [subheader-element] {
 white-space: nowrap !important;
 text-wrap: nowrap !important;
 text-align: center !important;
 }
 .hero_content .max-width-medium {
 max-width: none !important;
 overflow: visible !important;
 }
}
/* Mobile hero overrides — placed early to prevent FOUC */
@media (max-width: 767px) {
 .hero_animation-lottie {
 bottom: calc(-7% - 4px) !important;
 }
}
@media (max-width: 479px) {
 .spacer-custom.v2 {
 padding-top: calc(6.75rem + 12px) !important;
 }
 .hero_content .text-color-black70 {
 font-size: 0.85rem !important;
 margin-bottom: 16px !important;
 }
 .hero-tagline {
 bottom: calc(-1.5rem - 6px) !important;
 }
 .hero-radial-glow {
 display: none !important;
 }
}
/* Ways We Support You: 2-column layout with grouped tab rows */
.pp-ways-layout { display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:start; }
.pp-ways-tabs { display:flex; flex-direction:column; gap:1.25rem; align-items:center; text-align:center; }
.pp-tab-group-label { font-size:1.5rem; font-weight:600; color:var(--text-color--text-secondary,#fff); margin-bottom:0; text-align:center; width:max-content; }
.pp-tab-group-desc { font-size:1.05rem; color:rgba(255,255,255,0.55); margin-top:-10px; margin-bottom:0.5rem; text-align:center; font-style:italic; }
.pp-tab-row { display:flex; flex-wrap:wrap; gap:0.65rem 0.5rem; justify-content:center; }
.pp-tab-btn { border:2px solid var(--base-color--lumen,#d3fad2); color:#ebf5ff; background-color:transparent; border-radius:62.5rem; padding:0.5rem 1rem; font-weight:700; font-size:1.125rem; font-family:inherit; cursor:pointer; transition:background 0.3s,color 0.3s,transform 0.3s; display:inline-flex; align-items:center; white-space:nowrap; position:relative; }
.pp-tab-age { position:absolute; bottom:-7px; left:50%; transform:translateX(-50%); font-size:9px; font-weight:700; color:#fff; background:#FFA946; padding:1px 8px; border-radius:9999px; line-height:1.3; white-space:nowrap; }
.pp-tab-btn:hover { background:rgba(211,250,210,0.15); }
.pp-tab-btn.pp-tab-active { background-color:var(--base-color--dawn,#d3fad2); color:var(--text-color--text-primary,#1a1a1a); transform:rotate(-4deg); }
.pp-ways-content { background:rgba(255,255,255,0.05); border-radius:1.25rem; padding:2rem; text-align:center; }
.pp-ways-panel { display:none; }
.pp-ways-panel.pp-panel-active { display:block; }
.pp-ways-panel img.pp-panel-img { width:100%; border-radius:0.75rem; margin-bottom:1.25rem; object-fit:cover; max-height:320px; }
.pp-ways-panel h3 { color:#fff; margin-bottom:0.75rem; }
.pp-ways-panel p { color:rgba(255,255,255,0.7); margin-bottom:1.25rem; line-height:1.6; }
.pp-ways-panel .button-group { justify-content:center; }
@media (max-width: 767px) {
 .pp-ways-layout { grid-template-columns:1fr !important; gap:2rem !important; }
 .pp-tab-btn { font-size:0.8rem; padding:0.4rem 0.75rem; }
 .pp-ways-content { min-height:auto; }
}
/* Testimonials heading: keep on one line */
.testimonials_heading { white-space:nowrap; margin-bottom:-10px !important; }
/* Stats grid */
.pp-stats-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.pp-stat-tile { background:var(--base-color--fathom); border-radius:1.5rem; padding:2rem 1.5rem; text-align:center; }
.pp-stat-icon { font-size:2rem; margin-bottom:0.75rem; }
.pp-stat-number { font-size:2rem; font-weight:700; color:var(--text-color--text-secondary,#fff); margin-bottom:0.5rem; white-space:nowrap; }
.pp-stat-sub { font-size:0.95rem; color:rgba(255,255,255,0.6); line-height:1.4; }
@media (max-width:767px) { .pp-stats-grid { grid-template-columns:repeat(2,1fr); } }
/* Testimonials: tighten image-to-name gap */
.testimonials_list-item .testimonials_dp { margin-bottom:-4px; }
/* Halve black space below entrepreneurs section on mobile */
@media (max-width: 479px) {
 .section_app-integrations .padding-section-xlarge {
 padding-bottom: 2rem !important;
 }
 .section_home-clients .spacer-huge {
 padding-top: 1.75rem !important;
 }
}
/* Clip hero animation overflow so marquee text doesn't bleed into nav */
.hero-wrapper {
 overflow: hidden !important;
}
.hero_animation-wrapper-v2 {
 transform: scale(1.35) !important;
}
/* Reduce hero top spacing slightly */
.spacer-custom.v2 {
 padding-top: 11.125rem !important;
}
/* Move animation wrapper up to reduce hero height */
.hero_animation-wrapper-v2 {
 margin-top: -25vw !important;
}
/* Fix entrepreneur icon text clipping */
.section_app-integrations {
 overflow: visible !important;
}
.section_integrations-clients {
 overflow: visible !important;
}
.icon_svg-wrapper {
 padding-left: 5% !important;
 padding-right: 5% !important;
 box-sizing: border-box !important;
}
.icon-item {
 aspect-ratio: auto !important;
}
.icon-image {
 max-height: 5.5rem !important;
 border-radius: 0 !important;
 overflow: visible !important;
 object-fit: contain !important;
}
/* Subtle scale-up for entrepreneur icons that appear slightly smaller */
.icon-image[alt="Charlie Munger"] { transform: scale(1.12) !important; }
.icon-image[alt="Warren Buffett"] { transform: scale(1.08) !important; }
.icon-image[alt="Sara Blakely"] { transform: scale(1.13) !important; }
.icon-image[alt="Melanie Perkins"] { transform: scale(1.12) !important; }
.icon-image[alt="Andrew Carnegie"] { transform: scale(1.15) !important; }
.icon-image[alt="John Rockefeller"] { transform: scale(1.05) !important; }
.icon-image[alt="Thomas Edison"] { transform: scale(1.06) !important; }
.icon-image[alt="Daniel Ek"] { transform: scale(1.06) !important; }
.icon-image[alt="Mukesh Ambani"] { transform: scale(1.07) !important; }
.icon-image[alt="Madam Walker"] { transform: scale(1.10) !important; }
.icon-image[alt="Ingvar Kamprad"] { transform: scale(1.03) !important; }
/* Move pencil decoration higher */
.home_clients_decor { bottom: -4rem !important; }

/* === Tiled Nav Dropdown Styling === */

/* Make dropdown panel wider */
@media screen and (min-width: 992px) {
 .dropdown-list-v2 {
 min-width: 440px !important;
 }
 .dropdown-inside-wrap {
 min-width: 420px !important;
 }
 .dd-tile {
 position: relative;
 min-width: 390px !important;
 }
}

/* Hide old original template dropdown elements that conflict with dd-tiles */
.dropdown-inside-wrap .dropdown-link {
 display: none !important;
}
.dropdown-inside-wrap .dropdown-list-heading {
 display: none !important;
}

/* Fix dropdown-inside-wrap — override original template flex behavior */
.dropdown-inside-wrap {
 background-color: #ffffff !important;
 padding: 0.875rem !important;
 flex-direction: column !important;
 display: flex !important;
 gap: 0 !important;
}

/* Fix dropdown-wrap — tighten inner flex container */
.dropdown-wrap {
 display: flex !important;
 flex-direction: column !important;
 gap: 0 !important;
}

/* Better tile styling — visible card look */
.dd-tile {
 display: block;
 padding: 10px 12px;
 border-radius: 8px;
 background: #f4f6f8;
 text-decoration: none !important;
 transition: all 0.15s ease;
 margin-bottom: 6px;
 color: inherit;
 border: 1px solid #e8ecf0;
}
.dd-tile:hover {
 background: rgba(211, 250, 210, 0.35);
 transform: translateY(-1px);
 box-shadow: 0 4px 12px rgba(3, 23, 79, 0.12);
 border-color: rgba(211, 250, 210, 0.6);
}
.dd-tile:last-child {
 margin-bottom: 0;
}
.dd-tile-icon {
 width: 20px;
 height: 20px;
 flex-shrink: 0;
 color: #6b7280;
 margin-top: 1px;
}
.dd-tile:hover .dd-tile-icon {
 color: #03174F;
}
.dd-tile-title {
 display: flex;
 align-items: center;
 gap: 8px;
 font-size: 0.875rem;
 font-weight: 600;
 color: #1f2937;
 line-height: 1.2;
 margin-bottom: 4px;
}
.dd-tile-desc {
 font-size: 11px;
 color: #6b7280;
 line-height: 1.4;
 margin-bottom: 2px;
}
.dd-tags {
 text-align: right;
 margin-top: 3px;
}
.dd-tag {
 display: inline-block;
 font-size: 9.5px;
 font-weight: 600;
 padding: 1px 7px;
 border-radius: 9999px;
 margin-left: 3px;
}
.dd-tag--amber { background: #fef3c7; color: #92400e; }
.dd-tag--blue { background: #dbeafe; color: #1e40af; }
.dd-tag--green { background: #dcfce7; color: #15803d; }
.dd-coming-soon {
 position: absolute;
 top: 6px;
 right: 8px;
 background: #fef3c7;
 color: #92400e;
 font-size: 0.6rem;
 font-weight: 700;
 padding: 2px 6px;
 border-radius: 4px;
 text-transform: uppercase;
 letter-spacing: 0.03em;
 line-height: 1.2;
 pointer-events: none;
}
/* === PushPals Contact Form === */
.pp-form-divider {
 display: flex; align-items: center; gap: 1rem; margin: 0 auto; max-width: 28rem;
}
.pp-form-divider::before, .pp-form-divider::after {
 content: ''; flex: 1; height: 1px; background: #d1d5db;
}
.pp-form-divider span {
 font-size: 0.85rem; color: #6b7280; white-space: nowrap; font-weight: 600;
}
.pp-contact-form {
 width: 100%; max-width: 48rem; margin: 0 auto; text-align: left;
}
.pp-form-step { margin-bottom: 1.25rem; }
.pp-form-label {
 display: block; font-weight: 600; font-size: 0.95rem; margin-bottom: 0.5rem; color: #1a1a1a;
}
/* Radio cards (primary selection) */
.pp-radio-cards {
 display: flex; flex-wrap: wrap; gap: 0.75rem; justify-content: center;
}
.pp-radio-card {
 flex: 1 1 0; min-width: 0; display: flex;
}
.pp-radio-card { position: relative; cursor: pointer; }
.pp-radio-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.pp-radio-card-inner {
 display: flex; flex-direction: row; align-items: center; gap: 0.5rem;
 padding: 0.65rem 0.75rem; border: 2px solid #0b1a3b; border-radius: 0.75rem;
 background: #fff; transition: all 0.2s ease; text-align: left;
 width: 100%; box-sizing: border-box;
}
.pp-radio-text {
 display: flex; flex-direction: column;
}
.pp-radio-card:hover .pp-radio-card-inner { border-color: #d3fad2; background: #f0fdf0; }
.pp-radio-card input:checked ~ .pp-radio-card-inner {
 background: #d3fad2; border-color: #0b1a3b; box-shadow: 0 0 0 1px #0b1a3b;
}
.pp-radio-icon { font-size: 1.5rem; }
.pp-radio-title { font-weight: 700; font-size: 0.85rem; color: #0b1a3b; line-height: 1.2; }
.pp-radio-sub { font-size: 0.7rem; color: #6b7280; }
/* Radio pills (follow-up questions) */
.pp-radio-pills { display: flex; gap: 0.5rem; flex-wrap: wrap; justify-content: center; }
.pp-radio-pill { position: relative; cursor: pointer; }
.pp-radio-pill input { position: absolute; opacity: 0; width: 0; height: 0; }
.pp-radio-pill span {
 display: inline-block; padding: 0.5rem 1rem; border: 2px solid #0b1a3b; border-radius: 2rem;
 font-size: 0.85rem; font-weight: 600; color: #0b1a3b; background: #fff; transition: all 0.2s ease;
}
.pp-radio-pill:hover span { border-color: #d3fad2; background: #f0fdf0; }
.pp-radio-pill input:checked ~ span { background: #d3fad2; border-color: #0b1a3b; }
/* Conditional sections */
.pp-form-conditional {
 overflow: hidden; transition: max-height 0.4s ease, opacity 0.3s ease;
 max-height: 0; opacity: 0;
}
.pp-form-conditional.pp-visible { display: block !important; max-height: 500px; opacity: 1; }
.pp-form-fields {
 overflow: hidden; transition: max-height 0.4s ease, opacity 0.3s ease;
 max-height: 0; opacity: 0;
}
.pp-form-fields.pp-visible { display: block !important; max-height: 1000px; opacity: 1; }
/* Text inputs */
.pp-input, .pp-textarea {
 width: 100%; padding: 0.7rem 0.9rem; border: 2px solid #0b1a3b; border-radius: 0.5rem;
 font-family: 'Ubuntu', Arial, sans-serif; font-size: 0.9rem; color: #1a1a1a;
 background: #fff; outline: none; transition: border-color 0.2s ease; box-sizing: border-box;
}
.pp-input:focus, .pp-textarea:focus { border-color: #d3fad2; box-shadow: 0 0 0 3px rgba(211,250,210,0.3); }
.pp-input::placeholder, .pp-textarea::placeholder { color: #9ca3af; }
.pp-textarea { resize: vertical; min-height: 5rem; }
.pp-name-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
/* Submit button */
.pp-form-submit-wrap {
 text-align: center; margin-top: 0.5rem;
}
.pp-form-submit {
 display: inline-flex; align-items: center; justify-content: center;
 padding: 0.75rem 2.5rem; background: #d3fad2; color: #0b1a3b; border: 2px solid #0b1a3b;
 border-radius: 0.75rem; font-family: 'Ubuntu', Arial, sans-serif; font-size: 0.95rem;
 font-weight: 700; cursor: pointer; transition: all 0.2s ease;
}
.pp-form-submit:hover { background: #b8f0b6; transform: scale(0.98); }
/* Thank you message */
.pp-form-thanks {
 text-align: center; padding: 2rem 1rem;
}
.pp-thanks-icon {
 width: 3rem; height: 3rem; background: #d3fad2; color: #0b1a3b; border-radius: 50%;
 display: inline-flex; align-items: center; justify-content: center;
 font-size: 1.5rem; font-weight: 700; margin-bottom: 1rem;
}
.pp-form-thanks h3 { font-size: 1.5rem; font-weight: 700; margin: 0 0 0.5rem; color: #1a1a1a; }
.pp-form-thanks p { font-size: 1rem; color: #6b7280; margin: 0; }
/* Responsive */
@media (max-width: 600px) {
 .pp-radio-cards { flex-direction: column; }
 .pp-radio-card { flex: 0 0 auto; }
 .pp-name-row { grid-template-columns: 1fr; }
 .pp-radio-pills { flex-direction: column; align-items: center; }
}



/* Divider — horizontal line with centred purple pill label */
.dd-divider {
 border: none;
 border-top: 1px solid #e5e7eb;
 margin: 16px 0 14px 0;
 position: relative;
 display: flex;
 justify-content: center;
 align-items: flex-start;
 width: 100%;
 min-height: 0;
}
.dd-divider-label {
 position: absolute;
 top: -9px;
 background: #ffffff;
 padding: 2px 10px;
 font-size: 9px;
 font-weight: 700;
 text-transform: uppercase;
 letter-spacing: 0.1em;
 color: #a855f7;
 border: 1px solid #e9d5ff;
 border-radius: 3px;
 white-space: nowrap;
}

/* Better method button */
.dd-method-btn {
 display: flex;
 justify-content: center;
 align-items: center;
 gap: 8px;
 margin: 4px auto 2px;
 padding: 9px 22px;
 background: linear-gradient(135deg, #03174F 0%, #0a2570 100%);
 border-radius: 9999px;
 text-decoration: none;
 color: white;
 font-size: 12.5px;
 font-weight: 500;
 text-align: center;
 transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
 box-shadow: 0 2px 8px rgba(3, 23, 79, 0.25);
}
.dd-method-btn:hover {
 transform: translateY(-2px);
 box-shadow: 0 6px 20px rgba(3, 23, 79, 0.4), 0 0 12px rgba(211, 250, 210, 0.2);
 background: linear-gradient(135deg, #0a2570 0%, #1e40af 100%);
}
.dd-method-btn .dd-arrow {
 color: #d3fad2;
 transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.dd-method-btn:hover .dd-arrow {
 transform: translateX(3px);
}
.dd-method-btn .letter {
 display: inline-block;
 transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.dd-method-btn:hover .letter {
 animation: ddRollUp 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}
@keyframes ddRollUp {
 0% { transform: translateY(0); }
 40% { transform: translateY(-4px); }
 100% { transform: translateY(0); }
}

/* Better header styling — hidden, replaced by dd-subtitle */
.dd-header {
 display: none !important;
}
.dd-subtitle {
 font-size: 13px;
 color: #9ca3af;
 font-style: italic;
 margin-bottom: 10px;
 padding: 0 2px;
}

/* === About PushPals dropdown: replicate IX2 hover effects via CSS === */
@media screen and (min-width: 992px) {
 /* Border color (base CSS already defines border: 2px solid transparent) */
 [data-w-id="about-dropdown-toggle"]:hover {
 border-color: #1a1a1a !important;
 }
 /* Arrow rotation */
 [data-w-id="about-dropdown-toggle"] .nav_menu-dropdown-arrow {
 transition: transform 0.3s ease;
 }
 [data-w-id="about-dropdown-toggle"]:hover .nav_menu-dropdown-arrow {
 transform: rotateZ(180deg);
 }
 /* Show border overlays */
 [data-w-id="about-dropdown-toggle"]:hover .dropdown-border-overlay {
 display: block !important;
 opacity: 1 !important;
 background-color: #fffdf9 !important;
 }
 [data-w-id="about-dropdown-toggle"]:hover .dropdown-border-right-overlay {
 display: block !important;
 opacity: 1 !important;
 }
 [data-w-id="about-dropdown-toggle"]:hover .dropdown1_border-radius-wrap {
 display: block !important;
 opacity: 1 !important;
 }
 /* Right-angle corner (no curve) for ALL dropdowns, thinner bottom line */
 .nav_menu-dropdown-toggle-v2 .dropdown1_border-radius {
 border-bottom-left-radius: 0 !important;
 border-bottom-width: 1px !important;
 }
}

/* --- Block 6 --- */
/* Make text look crisper and more legible in all browsers */
body {
 -webkit-font-smoothing: antialiased;
 -moz-osx-font-smoothing: grayscale;
 font-smoothing: antialiased;
 text-rendering: optimizeLegibility;
}

/* Focus state style for keyboard navigation for the focusable elements */
*[tabindex]:focus-visible,
 input[type="file"]:focus-visible {
 outline: 0.125rem solid #4d65ff;
 outline-offset: 0.125rem;
}

/* Set color style to inherit */
.inherit-color * {
 color: inherit;
}

/* Get rid of top margin on first element in any rich text element */
.w-richtext > :not(div):first-child, .w-richtext > div:first-child > :first-child {
 margin-top: 0 !important;
}

/* Get rid of bottom margin on last element in any rich text element */
.w-richtext>:last-child, .w-richtext ol li:last-child, .w-richtext ul li:last-child {
	margin-bottom: 0 !important;
}


/* Make sure containers never lose their center alignment */
.container-medium,.container-small, .container-large {
	margin-right: auto !important;
 margin-left: auto !important;
}

/* 
Make the following elements inherit typography styles from the parent and not have hardcoded values. 
Important: You will not be able to style for example "All Links" in Designer with this CSS applied.
Uncomment this CSS to use it in the project. Leave this message for future hand-off.
*/
/*
a,
.w-input,
.w-select,
.w-tab-link,
.w-nav-link,
.w-dropdown-btn,
.w-dropdown-toggle,
.w-dropdown-link {
 color: inherit;
 text-decoration: inherit;
 font-size: inherit;
}
*/

/* Apply "..." after 3 lines of text */
.text-style-3lines {
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}

/* Apply "..." after 2 lines of text */
.text-style-2lines {
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

/* These classes are never overwritten */
.hide {
 display: none !important;
}

@media screen and (max-width: 991px) {
 .hide, .hide-tablet {
 display: none !important;
 }
}
 @media screen and (max-width: 767px) {
 .hide-mobile-landscape{
 display: none !important;
 }
}
 @media screen and (max-width: 479px) {
 .hide-mobile{
 display: none !important;
 }
}
 
.margin-0 {
 margin: 0rem !important;
}
 
.padding-0 {
 padding: 0rem !important;
}

.spacing-clean {
padding: 0rem !important;
margin: 0rem !important;
}

.margin-top {
 margin-right: 0rem !important;
 margin-bottom: 0rem !important;
 margin-left: 0rem !important;
}

.padding-top {
 padding-right: 0rem !important;
 padding-bottom: 0rem !important;
 padding-left: 0rem !important;
}
 
.margin-right {
 margin-top: 0rem !important;
 margin-bottom: 0rem !important;
 margin-left: 0rem !important;
}

.padding-right {
 padding-top: 0rem !important;
 padding-bottom: 0rem !important;
 padding-left: 0rem !important;
}

.margin-bottom {
 margin-top: 0rem !important;
 margin-right: 0rem !important;
 margin-left: 0rem !important;
}

.padding-bottom {
 padding-top: 0rem !important;
 padding-right: 0rem !important;
 padding-left: 0rem !important;
}

.margin-left {
 margin-top: 0rem !important;
 margin-right: 0rem !important;
 margin-bottom: 0rem !important;
}
 
.padding-left {
 padding-top: 0rem !important;
 padding-right: 0rem !important;
 padding-bottom: 0rem !important;
}
 
.margin-horizontal {
 margin-top: 0rem !important;
 margin-bottom: 0rem !important;
}

.padding-horizontal {
 padding-top: 0rem !important;
 padding-bottom: 0rem !important;
}

.margin-vertical {
 margin-right: 0rem !important;
 margin-left: 0rem !important;
}
 
.padding-vertical {
 padding-right: 0rem !important;
 padding-left: 0rem !important;
}

.text-wrap-balance{
	text-wrap: balance !important;
}

/* --- Block 7 --- */
.footer_link-block .icon-embed-xxsmall{
 opacity: 0;
 transform: translateX(-10px);
 transition: all 300ms
}

.footer_link-block:hover .icon-embed-xxsmall{
 opacity: 1;
 transform: translateX(0);
}

/* --- Block 8 --- */
.w-nav-overlay{
 margin-top: -10px !important;
 z-index: 1;
}

/* --- Block 9 --- */
@media screen and (max-width: 992px) {
 .w-dropdown-toggle.w--open .nav_menu-dropdown-arrow {
 transform: rotate(180deg);
 }
}

.dropdown1_border-radius-wrap, .dropdown-border-right-overlay {
	opacity: 0;
}
/* Show border-right overlay and radius wrap for ALL dropdowns on hover */
@media screen and (min-width: 992px) {
 .nav_menu-dropdown-toggle-v2:hover .dropdown-border-right-overlay {
 display: block !important;
 opacity: 1 !important;
 background-color: #fffdf9 !important;
 }
 .nav_menu-dropdown-toggle-v2:hover .dropdown1_border-radius-wrap {
 display: flex !important;
 opacity: 1 !important;
 }
}

.dropdown-link:hover .dropdown-link-text {
	color: #034f46;
}

@media (min-width: 992px) {
 .nav_component:has([apple-icon]),
 .nav_component:has([windows-icon]) {
 max-width: 66rem;
 }
}

@media (max-width: 991px) {
	.nav_container-v2:has(.nav_button.w--open) {
	 border-bottom-color: transparent;
	 border-bottom-left-radius: 0;
	 border-bottom-right-radius: 0;
	}
 
 .nav_container-v2:has(.nav_button.w--open) .nav_left-line, .nav_container-v2:has(.nav_button.w--open) .nav_right-line {
 	opacity: 1;
 }
}

.text-link:hover .text-link-arrow {
	transform: translateX(100%);
}

/* nav v2 */
@media (min-width:992px) and (max-width:1199px) {
	[nav-dropdown="resources"] .dropdown-link {
 	min-width: 13rem !important;
 }
}

@media (min-width:992px) {
	.nav-link-wrap.research {
	 padding-left: 0.5rem;
	 align-items: center;
	 /* gap: 3.5rem; */
 gap: 2.25rem;
	}
}

@media (max-width:991px) {
	.nav_mobile-btn:has([android-icon]) {
		font-size: 0.75rem;
	}
 
 .nav_mobile-btn [android-icon] {
		width: 14px;
 height: 14px;
 margin-right: 4px;
	}
}

/* --- Block 10 --- */
.use-cases_card:hover .use-cases_arrow-icon{
 transform: translate(10px, -10px);
}

@media (min-width:992px) and (max-width:1281px) {
	.banner {
 	padding-top: 1rem;
 padding-bottom: 1rem;
 }
 
 .nav_spacer {
 	height: 3.5rem;
 }
 
 .spacer-custom {
 	padding-top: 15vw;
 }
 
 .hero_animation-wrapper-v2 {
 	margin-top: -23vw;
 }
}

.nav_mobile-btn [apple-icon], .nav_mobile-btn [windows-icon] {
 width: 0.875rem;
 height: 0.875rem;
 margin-right: 4px;
}

@media (min-width:992px) and (max-width:1150px) {
	.spacer-custom {
 	padding-bottom: 2rem;
 }
}

/* --- Block 11 --- */
/*
.banner_mega-wrapper{
 animation: bannerTicker 10s linear infinite;
 }
 @keyframes bannerTicker {
 from {
 transform: translateX(0%);
 }
 to {
 transform: translateX(-100%);
 }
 }
*/

/* --- Block 12 --- */
.hamburger_12_wrap {
	--thickness: 0.125rem;
	--gap: 0.375rem;
	--rotate: 45;
 --width: 100%;
}
.hamburger_12_wrap:hover .hamburger_12_line {
	width: 65%;
}
.hamburger_12_wrap:hover .hamburger_12_line:first-child {
	width: 85%;
}
.hamburger_12_wrap:hover .hamburger_12_line:last-child {
	width: 100%;
}
.w--open .hamburger_12_line {
	width: 100% !important;
	transform: scaleX(0);
}
.w--open .hamburger_12_line:first-child {
	transform: translateY(calc(var(--thickness) + var(--gap))) rotate(calc(var(--rotate) * 3 * 1deg));
}
.w--open .hamburger_12_line:last-child {
	transform: translateY(calc(var(--thickness) * -1 + var(--gap) * -1)) rotate(calc(var(--rotate) * 1deg));
}

/* --- Block 13 --- */
@keyframes heroGlowPulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:1;transform:scale(1.1);}}

/* --- Block 14 --- */
#hero-svg path {
 fill: transparent;
}

#marquee-text-hero1{
 font-size: inherit;
 font-weight: 400;
 fill: #1A1A1A;
 baseline-shift: -20%;
 opacity: 0.4;
}

/* --- Block 15 --- */
#marquee-text-hero2{
 font-size: inherit;
 font-weight: 600;
 fill: #fff;
 baseline-shift: -30%;
}

/* --- Block 16 --- */
.clients_cms-wrapper{
 animation: logoTicker1 80s linear infinite;
 }
 @keyframes logoTicker1 {
 from {
 transform: translateX(0%);
 }
 to {
 transform: translateX(-100%);
 }
 }

.clients_logo-image {
 max-height: 10rem;
 border-radius: 0.5rem;
 object-fit: cover;
 }

/* --- Block 17 --- */
@media (min-width:1085px) {
	.features_grid-bottom .home_integrations_chips-div {
 flex-flow: nowrap;
 }
 
 .features_grid-bottom .home_integrations_chip {
 	flex: 0 0 auto;
 }
}

/* --- Block 18 --- */
.hero_animation-wrapper {
 overflow: hidden !important;
}
/* Push Pillars Accordion */
.pillars-accordion {
 display: flex;
 flex-direction: row;
 gap: 1rem;
 height: 400px;
 width: 100%;
 overflow: hidden;
}
.pillar-panel {
 position: relative;
 overflow: hidden;
 border-radius: 1rem;
 cursor: pointer;
 flex: 0 0 60px;
 transition: all 700ms cubic-bezier(0.4, 0, 0.2, 1);
}
.pillar-panel.active {
 flex: 1 1 0%;
}
.pillar-label {
 position: absolute;
 color: #fff;
 font-weight: 700;
 letter-spacing: 0.02em;
 white-space: nowrap;
 transition: all 300ms ease-in-out;
 /* collapsed: vertical text, reads bottom-to-top, centered */
 writing-mode: vertical-rl;
 transform: rotate(180deg) translate(50%, 50%);
 font-size: 1.4rem;
 left: 50%;
 top: 50%;
 margin-left: 0;
 margin-top: 0;
}
.pillar-panel.active .pillar-label {
 /* active: horizontal text centered at bottom */
 writing-mode: horizontal-tb;
 transform: none;
 font-size: 2.2rem;
 left: 0;
 right: 0;
 top: auto;
 bottom: 1.5rem;
 margin-left: 0;
 margin-top: 0;
 text-align: center;
}
.pillar-desc {
 position: absolute;
 color: rgba(255,255,255,0.9);
 font-style: italic;
 font-size: 1rem;
 line-height: 1.5;
 text-align: center;
 left: 50%;
 top: 45%;
 transform: translate(-50%, -50%);
 width: 75%;
 max-width: 400px;
 box-sizing: content-box;
 padding: 0 8px;
 margin: 0;
 opacity: 0;
 transition: opacity 400ms ease-in-out 300ms;
 pointer-events: none;
}
.pillar-panel.active .pillar-desc {
 opacity: 1;
}
.pillar-panel:not(.active) .pillar-desc {
 transition-delay: 0ms;
}
.pillar-desc-hero {
 font-size: 1.15rem;
 font-weight: 700;
 font-style: italic;
}
@media (max-width: 767px) {
 .pillars-accordion {
 flex-direction: column;
 height: auto;
 }
 .pillar-panel {
 flex: 0 0 50px;
 border-radius: 0.75rem;
 }
 .pillar-panel.active {
 flex: 0 0 200px;
 }
 .pillar-label {
 writing-mode: horizontal-tb;
 transform: none;
 font-size: 1.1rem;
 left: 0;
 right: 0;
 top: 50%;
 margin-left: 0;
 margin-top: -0.7em;
 text-align: center;
 }
 .pillar-panel.active .pillar-label {
 font-size: 1.6rem;
 top: auto;
 bottom: 1rem;
 margin-top: 0;
 }
 .pillar-desc {
 font-size: 0.85rem;
 top: 40%;
 width: 85%;
 }
}

/* Fix Lottie containers: show dark bg instead of invisible empty divs */
.faster_flow-lottie,
.features_content-overlay,
.mobile-screen_bottom-wave,
.features_android-wave {
 min-height: 1px;
}

/* Fix tone card Lottie: dark bg fallback */
.features_grid-card.is-tone .features_content-bg-image[data-animation-type="lottie"] {
 background-color: #1a1a19;
 border-radius: inherit;
 min-height: 280px;
}

/* Footer dots: hide */
.cta_dot {
 display: none !important;
}
/* Start building CTA: push image down + tint overlay */
.cta_bg { object-position: 50% 12% !important; }
.section_startflowing { position: relative; }
.section_startflowing::after {
 content: "";
 position: absolute;
 inset: 0;
 background: rgba(2, 16, 56, 0.35);
 pointer-events: none;
 z-index: 0;
}
.section_startflowing .padding-global { position: relative; z-index: 1; }
.section_startflowing .text-wrapper + .spacer-xlarge { height: 2px !important; padding: 0 !important; margin: 0 !important; }
.section_startflowing .spacer-xlarge + .spacer-xlarge { height: 2px !important; padding: 0 !important; margin: 0 !important; }
/* Ask AI box: equidistant spacing */
.section_ask-ai .spacer-xhuge { height: 42px !important; padding: 0 !important; }
.section_ask-ai + div[style] { height: 42px !important; }
/* PushPals Footer Styles */
.pp-footer-wrap {
 padding: 0 1.5rem 2rem;
}
.pp-footer {
 background-color: #021038;
 color: white;
 padding: 4rem 1.5rem 2rem;
 border-radius: 1rem;
 max-width: 1400px;
 margin: 0 auto;
}
.pp-footer-grid {
 display: grid;
 grid-template-columns: repeat(4, minmax(0, 14rem));
 gap: 2rem;
 justify-content: space-evenly;
 max-width: 72rem;
 margin: 0 auto;
}
.pp-footer h3 {
 font-weight: 700;
 font-size: 1.05rem;
 margin-bottom: 1rem;
}
.pp-footer ul {
 list-style: none;
 padding: 0;
 margin: 0;
 display: flex;
 flex-direction: column;
 gap: 0.75rem;
 font-size: 1rem;
}
.pp-footer ul a {
 color: #9ca3af;
 text-decoration: none;
 transition: color 0.2s;
}
.pp-footer ul a:hover {
 color: #d3fad2;
}
.pp-footer-cta-row {
 margin-top: 2.5rem;
 display: flex;
 align-items: center;
 justify-content: center;
 gap: 1rem;
}
.pp-footer-cta {
 display: inline-flex;
 align-items: center;
 gap: 0.625rem;
 background: rgba(255,255,255,0.07);
 border: 1px solid rgba(255,255,255,0.12);
 border-radius: 9999px;
 padding: 0.75rem 1.75rem;
 font-size: 1rem;
 font-weight: 500;
 color: white;
 text-decoration: none;
 transition: all 0.3s;
}
.pp-footer-cta:hover {
 background: rgba(255,255,255,0.14);
 border-color: rgba(255,255,255,0.25);
}
.pp-footer-cta svg {
 width: 1rem;
 height: 1rem;
 color: #d3fad2;
 opacity: 0.8;
}
.pp-footer-cta:hover svg {
 opacity: 1;
}
.pp-footer-cta .arrow {
 color: rgba(211,250,210,0.7);
 transition: all 0.3s;
}
.pp-footer-cta:hover .arrow {
 color: #d3fad2;
 transform: translateX(2px);
}
.pp-footer-brand {
 margin-top: 3rem;
 display: flex;
 flex-direction: column;
 align-items: center;
 text-align: center;
}
.pp-footer-divider {
 margin-top: 2rem;
 border-top: 1px solid #374151;
 padding-top: 1.5rem;
 display: flex;
 justify-content: center;
 font-size: 0.85rem;
 color: #6b7280;
}
.pp-footer-divider a {
 color: inherit;
 text-decoration: none;
 transition: color 0.2s;
}
.pp-footer-divider a:hover {
 color: #d1d5db;
}
.pp-footer-divider ul {
 flex-direction: row;
 font-size: 0.85rem;
}
/* Skool community button */
.skool-btn {
 background-color: #d3fad2;
 color: #1a1a1a;
 border: 2px solid #1a1a1a;
 border-radius: 0.75rem;
 padding: 0.5rem 0.85rem 0.5rem 0.6rem;
 font-weight: 400;
 font-size: 0.875rem;
 line-height: 1;
 text-decoration: none;
 display: inline-flex;
 align-items: center;
 justify-content: center;
 gap: 0.4rem;
 transition: transform 0.2s ease;
 cursor: pointer;
 white-space: nowrap;
}
.skool-btn:hover {
 transform: scale(0.97);
}
.pp-footer .skool-btn {
 background-color: #d3fad2;
 color: #1a1a1a;
 border: 2px solid #1a1a1a;
 border-radius: 0.75rem;
 padding: 0.5rem 0.85rem 0.5rem 0.6rem;
 font-size: 12px;
 font-weight: 700;
}
.pp-footer .skool-btn:hover {
 background-color: #c0f5be;
 color: #1a1a1a;
 border-color: #1a1a1a;
}
/* Wave letter animation */
.skool-btn .letter,
.pp-footer-cta .letter {
 display: inline-block;
 transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.skool-btn:hover .letter,
.pp-footer-cta:hover .letter {
 animation: rollUp 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}
@keyframes rollUp {
 0% { transform: translateY(0); }
 40% { transform: translateY(-4px); }
 100% { transform: translateY(0); }
}
@media (max-width: 768px) {
 .pp-footer-grid {
 grid-template-columns: repeat(2, 1fr);
 }
}
@media (max-width: 480px) {
 .pp-footer-grid {
 grid-template-columns: repeat(2, 1fr);
 gap: 1.25rem 0.35rem;
 }
 .pp-footer {
 padding-top: 2rem;
 padding-left: 0.75rem;
 padding-right: 0.75rem;
 }
 .pp-footer-grid > div {
 text-align: center;
 }
 .pp-footer h3 {
 font-size: 0.82rem;
 }
 .pp-footer ul {
 font-size: 0.68rem;
 }
 .pp-footer .skool-btn {
 margin: 0 auto;
 }
 .pp-footer .skool-btn {
 font-size: 9px;
 padding: 0.3rem 0.5rem 0.3rem 0.4rem;
 }
 .pp-footer .skool-btn img {
 width: 14px !important;
 height: 14px !important;
 }
 .pp-footer-cta-row {
 flex-direction: row;
 gap: 0.5rem;
 margin-top: 1.25rem;
 }
 .pp-footer-cta {
 font-size: 0.63rem;
 padding: 0.4rem 0.5rem;
 }
 .pp-footer-brand {
 margin-top: 1.5rem;
 }
 .pp-footer-brand h2 {
 font-size: 1.15rem !important;
 }
 .pp-footer-brand p {
 font-size: 0.8rem !important;
 }
}


/* Nav dropdown parent links */
.dd-parent-link { color: inherit; text-decoration: none; display: block; }
.dd-view-all { display: inline-flex; align-items: center; gap: 0.25rem; font-family: 'Ubuntu', sans-serif; font-size: 0.7rem; font-weight: 600; color: #03174F; text-decoration: none; margin-top: 0.5rem; padding: 0.3rem 0.75rem; background: #f0f4ff; border-radius: 2rem; transition: background 0.15s; }
.dd-view-all:hover { background: #dbeafe; }

/* ========================================
   PAGE MODULE STYLES
   Reusable components for sub-pages
   ======================================== */

.pp-page-hero { background: linear-gradient(180deg, #071e5e 0%, #03174F 100%); color: #fff; padding: 10rem 0 3.5rem; text-align: center; border-top: 1px solid rgba(255,255,255,0.08); }
.pp-page-hero h1 { font-family: 'Ubuntu', sans-serif; font-size: 2.5rem; font-weight: 700; line-height: 1.2; margin: 0 0 1rem; }
.pp-page-hero p { font-family: 'Ubuntu', sans-serif; font-size: 1.1rem; color: rgba(255,255,255,0.75); max-width: 40rem; margin: 0 auto; line-height: 1.6; }
.pp-hero-image { margin-top: 2.5rem; border-radius: 1rem; overflow: hidden; max-width: 48rem; margin-left: auto; margin-right: auto; box-shadow: 0 8px 32px rgba(0,0,0,0.3); }
.pp-hero-image img { width: 100%; height: auto; display: block; }
.pp-page-hero .pp-badge-row { display: flex; gap: 0.5rem; justify-content: center; margin-top: 1.25rem; flex-wrap: wrap; }
.pp-badge { display: inline-flex; align-items: center; gap: 0.35rem; font-family: 'Ubuntu', sans-serif; font-size: 0.75rem; font-weight: 500; padding: 0.35rem 0.75rem; border-radius: 2rem; background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.9); }
.pp-badge--mint { background: #d3fad2; color: #03174F; font-weight: 600; }

.pp-key-info { background: #f0f4ff; border-bottom: 1px solid #e2e8f0; }
.pp-key-info-grid { display: flex; justify-content: center; gap: 2rem; padding: 1.25rem 0; flex-wrap: wrap; }
.pp-key-info-item { text-align: center; font-family: 'Ubuntu', sans-serif; }
.pp-key-info-item .pp-ki-label { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: #64748b; margin-bottom: 0.2rem; }
.pp-key-info-item .pp-ki-value { font-size: 0.95rem; font-weight: 700; color: #03174F; }

.pp-section { padding: 4rem 0; }
.pp-section--alt { background: #f8fafc; }
.pp-section--navy { background: #03174F; color: #fff; }
.pp-section__inner { max-width: 64rem; margin: 0 auto; padding: 0 1.5rem; }
.pp-section__heading { font-family: 'Ubuntu', sans-serif; font-size: 1.75rem; font-weight: 700; color: #0b1a3b; text-align: center; margin-bottom: 0.5rem; }
.pp-section--navy .pp-section__heading { color: #fff; }
.pp-section__subheading { font-family: 'Ubuntu', sans-serif; font-size: 1rem; color: #6b7280; text-align: center; max-width: 36rem; margin: 0 auto 2.5rem; line-height: 1.6; }
.pp-section--navy .pp-section__subheading { color: rgba(255,255,255,0.7); }

.pp-card-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); }
.pp-card-grid--3 { grid-template-columns: repeat(3, 1fr); }
.pp-card-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 768px) { .pp-card-grid--3, .pp-card-grid--4 { grid-template-columns: 1fr; } }
.pp-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 0.75rem; padding: 1.5rem; transition: box-shadow 0.2s, transform 0.2s; }
.pp-card:hover { box-shadow: 0 4px 16px rgba(3,23,79,0.1); transform: translateY(-2px); }
.pp-card__icon { font-size: 1.75rem; margin-bottom: 0.75rem; }
.pp-card__title { font-family: 'Ubuntu', sans-serif; font-size: 1rem; font-weight: 700; color: #0b1a3b; margin-bottom: 0.4rem; }
.pp-card__text { font-family: 'Ubuntu', sans-serif; font-size: 0.875rem; color: #6b7280; line-height: 1.6; }

.pp-offering-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 0.75rem; padding: 1.75rem; display: flex; flex-direction: column; transition: box-shadow 0.2s, transform 0.2s; text-decoration: none; color: inherit; }
.pp-offering-card:hover { box-shadow: 0 8px 24px rgba(3,23,79,0.12); transform: translateY(-3px); }
.pp-offering-card__badge { display: inline-flex; align-items: center; gap: 0.3rem; font-family: 'Ubuntu', sans-serif; font-size: 0.7rem; font-weight: 600; padding: 0.25rem 0.6rem; border-radius: 2rem; margin-bottom: 0.75rem; width: fit-content; }
.pp-offering-card__badge--free { background: #dcfce7; color: #15803d; }
.pp-offering-card__badge--paid { background: #dbeafe; color: #1d4ed8; }
.pp-offering-card__badge--online { background: #f0fdf4; color: #16a34a; }
.pp-offering-card__badge--inperson { background: #eff6ff; color: #2563eb; }
.pp-offering-card__title { font-family: 'Ubuntu', sans-serif; font-size: 1.15rem; font-weight: 700; color: #0b1a3b; margin-bottom: 0.5rem; }
.pp-offering-card__desc { font-family: 'Ubuntu', sans-serif; font-size: 0.875rem; color: #6b7280; line-height: 1.6; flex: 1; }
.pp-offering-card__link { font-family: 'Ubuntu', sans-serif; font-size: 0.85rem; font-weight: 600; color: #03174F; margin-top: 1rem; display: inline-flex; align-items: center; gap: 0.35rem; }

.pp-steps { display: flex; flex-direction: column; gap: 1.5rem; max-width: 40rem; margin: 0 auto; }
.pp-step { display: flex; gap: 1rem; align-items: flex-start; }
.pp-step__num { flex-shrink: 0; width: 2.25rem; height: 2.25rem; background: #03174F; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Ubuntu', sans-serif; font-size: 0.85rem; font-weight: 700; }
.pp-step__content h3 { font-family: 'Ubuntu', sans-serif; font-size: 1rem; font-weight: 700; color: #0b1a3b; margin: 0 0 0.25rem; }
.pp-step__content p { font-family: 'Ubuntu', sans-serif; font-size: 0.875rem; color: #6b7280; line-height: 1.6; margin: 0; }

.pp-timeline { max-width: 40rem; margin: 0 auto; position: relative; padding-left: 2rem; }
.pp-timeline::before { content: ''; position: absolute; left: 0.5rem; top: 0; bottom: 0; width: 2px; background: #e2e8f0; }
.pp-timeline__item { position: relative; padding-bottom: 1.5rem; }
.pp-timeline__item::before { content: ''; position: absolute; left: -1.65rem; top: 0.3rem; width: 0.65rem; height: 0.65rem; background: #03174F; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 0 2px #e2e8f0; }
.pp-timeline__time { font-family: 'Ubuntu', sans-serif; font-size: 0.75rem; font-weight: 700; color: #03174F; text-transform: uppercase; letter-spacing: 0.05em; }
.pp-timeline__title { font-family: 'Ubuntu', sans-serif; font-size: 1rem; font-weight: 600; color: #0b1a3b; margin: 0.15rem 0 0.2rem; }
.pp-timeline__desc { font-family: 'Ubuntu', sans-serif; font-size: 0.85rem; color: #6b7280; line-height: 1.5; }

.pp-faq-list { max-width: 40rem; margin: 0 auto; display: flex; flex-direction: column; gap: 0.5rem; }
.pp-faq { border: 1px solid #e2e8f0; border-radius: 0.5rem; overflow: hidden; background: #fff; }
.pp-faq__q { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.25rem; font-family: 'Ubuntu', sans-serif; font-size: 0.95rem; font-weight: 600; color: #0b1a3b; cursor: pointer; background: none; border: none; width: 100%; text-align: left; -webkit-appearance: none; appearance: none; }
.pp-faq__q::after { content: '+'; font-size: 1.25rem; font-weight: 300; color: #94a3b8; transition: transform 0.2s; }
.pp-faq.is-open .pp-faq__q::after { content: '\2212'; }
.pp-faq__a { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; }
.pp-faq.is-open .pp-faq__a { max-height: 20rem; }
.pp-faq__a-inner { padding: 0 1.25rem 1rem; font-family: 'Ubuntu', sans-serif; font-size: 0.875rem; color: #6b7280; line-height: 1.6; }

.pp-testimonial-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); }
.pp-testimonial { background: #fff; border: 1px solid #e2e8f0; border-radius: 0.75rem; padding: 1.5rem; }
.pp-testimonial__quote { font-family: 'Ubuntu', sans-serif; font-size: 0.9rem; color: #374151; line-height: 1.7; font-style: italic; margin-bottom: 1rem; }
.pp-testimonial__author { font-family: 'Ubuntu', sans-serif; font-size: 0.8rem; font-weight: 600; color: #0b1a3b; }
.pp-testimonial__role { font-family: 'Ubuntu', sans-serif; font-size: 0.75rem; color: #94a3b8; }

.pp-pricing-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr)); max-width: 48rem; margin: 0 auto; }
.pp-pricing-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 0.75rem; padding: 2rem 1.5rem; text-align: center; position: relative; }
.pp-pricing-card--featured { border-color: #03174F; box-shadow: 0 4px 20px rgba(3,23,79,0.15); }
.pp-pricing-card__badge { position: absolute; top: -0.75rem; left: 50%; transform: translateX(-50%); background: #03174F; color: #fff; font-family: 'Ubuntu', sans-serif; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 0.25rem 0.75rem; border-radius: 2rem; }
.pp-pricing-card__name { font-family: 'Ubuntu', sans-serif; font-size: 1rem; font-weight: 700; color: #0b1a3b; margin-bottom: 0.5rem; }
.pp-pricing-card__price { font-family: 'Ubuntu', sans-serif; font-size: 2rem; font-weight: 700; color: #03174F; margin-bottom: 0.25rem; }
.pp-pricing-card__period { font-family: 'Ubuntu', sans-serif; font-size: 0.8rem; color: #94a3b8; margin-bottom: 1.25rem; }
.pp-pricing-card__features { list-style: none; padding: 0; margin: 0 0 1.5rem; text-align: left; }
.pp-pricing-card__features li { font-family: 'Ubuntu', sans-serif; font-size: 0.85rem; color: #6b7280; padding: 0.35rem 0; border-bottom: 1px solid #f1f5f9; display: flex; align-items: flex-start; gap: 0.5rem; }
.pp-pricing-card__features li::before { content: '\2713'; color: #059669; font-weight: 700; flex-shrink: 0; }

.pp-cta-section { background: #03174F; color: #fff; padding: 3.5rem 0; text-align: center; }
.pp-cta-section h2 { font-family: 'Ubuntu', sans-serif; font-size: 1.75rem; font-weight: 700; margin-bottom: 0.75rem; }
.pp-cta-section p { font-family: 'Ubuntu', sans-serif; font-size: 1rem; color: rgba(255,255,255,0.7); max-width: 30rem; margin: 0 auto 1.5rem; line-height: 1.6; }

.pp-btn { display: inline-flex; align-items: center; gap: 0.5rem; font-family: 'Ubuntu', sans-serif; font-size: 0.9rem; font-weight: 600; padding: 0.75rem 1.5rem; border-radius: 0.5rem; text-decoration: none; transition: all 0.2s; cursor: pointer; border: none; }
.pp-btn--mint { background: #d3fad2; color: #03174F; }
.pp-btn--mint:hover { background: #b8f0b6; transform: translateY(-1px); }
.pp-btn--white { background: #fff; color: #03174F; }
.pp-btn--white:hover { background: #f0f4ff; transform: translateY(-1px); }
.pp-btn--navy { background: #03174F; color: #fff; }
.pp-btn--navy:hover { background: #0a2570; transform: translateY(-1px); }
.pp-btn--outline { background: transparent; color: #03174F; border: 2px solid #03174F; }
.pp-btn--outline:hover { background: #03174F; color: #fff; }

.pp-method-card { background: #fff; border: 2px solid #e2e8f0; border-radius: 1rem; padding: 2rem; text-align: center; transition: all 0.2s; }
.pp-method-card:hover { border-color: #03174F; box-shadow: 0 4px 20px rgba(3,23,79,0.1); }
.pp-method-card__icon { font-size: 2rem; margin-bottom: 1rem; }
.pp-method-card__title { font-family: 'Ubuntu', sans-serif; font-size: 1.15rem; font-weight: 700; color: #03174F; margin-bottom: 0.5rem; }
.pp-method-card__audience { font-family: 'Ubuntu', sans-serif; font-size: 0.75rem; font-weight: 600; color: #6366f1; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.75rem; }
.pp-method-card__desc { font-family: 'Ubuntu', sans-serif; font-size: 0.875rem; color: #6b7280; line-height: 1.6; }

.pp-form-section { max-width: 36rem; margin: 0 auto; }
.pp-form-group { margin-bottom: 1.25rem; }
.pp-form-group label { display: block; font-family: 'Ubuntu', sans-serif; font-size: 0.85rem; font-weight: 600; color: #0b1a3b; margin-bottom: 0.35rem; }
.pp-form-group input, .pp-form-group select, .pp-form-group textarea { width: 100%; font-family: 'Ubuntu', sans-serif; font-size: 0.9rem; padding: 0.65rem 0.85rem; border: 1.5px solid #d1d5db; border-radius: 0.5rem; background: #fff; color: #0b1a3b; transition: border-color 0.2s; box-sizing: border-box; }
.pp-form-group input:focus, .pp-form-group select:focus, .pp-form-group textarea:focus { outline: none; border-color: #03174F; }
.pp-form-group textarea { min-height: 5rem; resize: vertical; }

.pp-breadcrumb { font-family: 'Ubuntu', sans-serif; font-size: 0.8rem; color: rgba(255,255,255,0.5); margin-bottom: 1rem; }
.pp-breadcrumb a { color: rgba(255,255,255,0.6); text-decoration: none; }
.pp-breadcrumb a:hover { color: #d3fad2; }
.pp-breadcrumb span { margin: 0 0.4rem; }

.pp-hub-intro { text-align: center; max-width: 36rem; margin: 0 auto 2.5rem; }
.pp-hub-intro p { font-family: 'Ubuntu', sans-serif; font-size: 1rem; color: #6b7280; line-height: 1.7; }

.pp-legal-content { max-width: 48rem; margin: 0 auto; font-family: 'Ubuntu', sans-serif; }
.pp-legal-content h2 { font-size: 1.35rem; font-weight: 700; color: #0b1a3b; margin: 2rem 0 0.75rem; }
.pp-legal-content h3 { font-size: 1.1rem; font-weight: 600; color: #0b1a3b; margin: 1.5rem 0 0.5rem; }
.pp-legal-content p, .pp-legal-content li { font-size: 0.9rem; color: #4b5563; line-height: 1.7; margin-bottom: 0.75rem; }
.pp-legal-content ul { padding-left: 1.5rem; margin-bottom: 1rem; }
.pp-legal-content ul li { margin-bottom: 0.35rem; }

/* ========================================
   SCROLL REVEAL ANIMATIONS
   Add class="pp-reveal" to any element
   ======================================== */
.pp-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s cubic-bezier(0.4, 0, 0.2, 1), transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}
.pp-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.pp-reveal--delay-1 { transition-delay: 0.1s; }
.pp-reveal--delay-2 { transition-delay: 0.2s; }
.pp-reveal--delay-3 { transition-delay: 0.3s; }
.pp-reveal--delay-4 { transition-delay: 0.4s; }

/* ========================================
   LEGAL PAGE — STICKY SIDEBAR LAYOUT
   Wispr Flow style ToC + content
   ======================================== */
.pp-legal-layout {
  display: grid;
  grid-template-columns: 14rem 1fr;
  gap: 3rem;
  max-width: 64rem;
  margin: 0 auto;
  padding: 0 1.5rem;
  align-items: start;
}
.pp-legal-toc {
  position: sticky;
  top: 6rem;
  padding: 1.25rem 0;
  max-height: calc(100vh - 8rem);
  overflow-y: auto;
}
.pp-legal-toc__title {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #94a3b8;
  margin-bottom: 0.75rem;
}
.pp-legal-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.pp-legal-toc__link {
  display: block;
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.8rem;
  color: #6b7280;
  text-decoration: none;
  padding: 0.3rem 0.75rem;
  border-left: 2px solid transparent;
  border-radius: 0 0.25rem 0.25rem 0;
  transition: all 0.15s;
}
.pp-legal-toc__link:hover {
  color: #03174F;
  background: #f0f4ff;
}
.pp-legal-toc__link.is-active {
  color: #03174F;
  font-weight: 600;
  border-left-color: #03174F;
  background: #f0f4ff;
}
@media (max-width: 768px) {
  .pp-legal-layout { grid-template-columns: 1fr; gap: 0; }
  .pp-legal-toc { position: static; max-height: none; padding: 1rem 0; border-bottom: 1px solid #e2e8f0; margin-bottom: 1.5rem; }
}

/* ========================================
   JOURNAL / ARTICLE CARDS
   ======================================== */
.pp-article-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
  gap: 1.75rem;
}
.pp-article-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.75rem;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
}
.pp-article-card:hover {
  box-shadow: 0 8px 24px rgba(3,23,79,0.1);
  transform: translateY(-3px);
}
.pp-article-card__image {
  width: 100%;
  height: 12rem;
  object-fit: cover;
}
.pp-article-card__body {
  padding: 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.pp-article-card__tag {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6366f1;
  margin-bottom: 0.5rem;
}
.pp-article-card__title {
  font-family: 'Ubuntu', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #0b1a3b;
  margin-bottom: 0.4rem;
  line-height: 1.3;
}
.pp-article-card__excerpt {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.85rem;
  color: #6b7280;
  line-height: 1.6;
  flex: 1;
}
.pp-article-card__meta {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.75rem;
  color: #94a3b8;
  margin-top: 0.75rem;
}

/* Article page layout */
.pp-article-content {
  max-width: 44rem;
  margin: 0 auto;
  font-family: 'Ubuntu', sans-serif;
}
.pp-article-content h2 {
  font-size: 1.5rem;
  font-weight: 700;
  color: #0b1a3b;
  margin: 2.5rem 0 0.75rem;
}
.pp-article-content h3 {
  font-size: 1.15rem;
  font-weight: 600;
  color: #0b1a3b;
  margin: 2rem 0 0.5rem;
}
.pp-article-content p {
  font-size: 1rem;
  color: #374151;
  line-height: 1.8;
  margin-bottom: 1.25rem;
}
.pp-article-content blockquote {
  border-left: 3px solid #03174F;
  padding: 0.75rem 1.5rem;
  margin: 1.5rem 0;
  background: #f8fafc;
  border-radius: 0 0.5rem 0.5rem 0;
}
.pp-article-content blockquote p {
  font-style: italic;
  color: #1f2937;
  margin-bottom: 0;
}
.pp-article-content ul, .pp-article-content ol {
  padding-left: 1.5rem;
  margin-bottom: 1.25rem;
}
.pp-article-content li {
  font-size: 0.95rem;
  color: #374151;
  line-height: 1.7;
  margin-bottom: 0.5rem;
}

/* ========================================
   SPLIT SECTION — Image + Text Side by Side
   ======================================== */
.pp-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
  max-width: 64rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.pp-split--reverse { direction: rtl; }
.pp-split--reverse > * { direction: ltr; }
.pp-split__image {
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}
.pp-split__image img {
  width: 100%;
  height: auto;
  display: block;
}
.pp-split__text h2 {
  font-family: 'Ubuntu', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: #0b1a3b;
  margin-bottom: 0.75rem;
}
.pp-split__text p {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.95rem;
  color: #6b7280;
  line-height: 1.7;
  margin-bottom: 1rem;
}
@media (max-width: 768px) {
  .pp-split { grid-template-columns: 1fr; gap: 1.5rem; }
  .pp-split--reverse { direction: ltr; }
}

/* ========================================
   STATS ROW — Horizontal stat highlights
   ======================================== */
.pp-stats-row {
  display: flex;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
  padding: 1.5rem 0;
}
.pp-stat {
  text-align: center;
  min-width: 8rem;
}
.pp-stat__number {
  font-family: 'Ubuntu', sans-serif;
  font-size: 2.25rem;
  font-weight: 700;
  color: #03174F;
  line-height: 1.1;
}
.pp-stat__label {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.8rem;
  color: #6b7280;
  margin-top: 0.25rem;
}
.pp-section--navy .pp-stat__number { color: #d3fad2; }
.pp-section--navy .pp-stat__label { color: rgba(255,255,255,0.7); }

/* ========================================
   SCHEDULE TABLE — Cohort dates, webinar times
   ======================================== */
.pp-schedule-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.9rem;
  max-width: 48rem;
  margin: 0 auto;
}
.pp-schedule-table thead th {
  background: #03174F;
  color: #fff;
  font-weight: 600;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 0.75rem 1rem;
  text-align: left;
}
.pp-schedule-table thead th:first-child { border-radius: 0.5rem 0 0 0; }
.pp-schedule-table thead th:last-child { border-radius: 0 0.5rem 0 0; }
.pp-schedule-table tbody td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #e2e8f0;
  color: #374151;
}
.pp-schedule-table tbody tr:hover { background: #f8fafc; }
.pp-schedule-table .pp-table-badge {
  display: inline-flex;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.2rem 0.6rem;
  border-radius: 2rem;
}
.pp-table-badge--open { background: #dcfce7; color: #15803d; }
.pp-table-badge--filling { background: #fef3c7; color: #92400e; }
.pp-table-badge--full { background: #fee2e2; color: #991b1b; }
.pp-table-badge--upcoming { background: #dbeafe; color: #1d4ed8; }

/* ========================================
   QUOTE / HIGHLIGHT BLOCK
   ======================================== */
.pp-quote-block {
  background: #f0f4ff;
  border-radius: 1rem;
  padding: 2rem 2.5rem;
  max-width: 40rem;
  margin: 2rem auto;
  text-align: center;
}
.pp-quote-block__text {
  font-family: 'Ubuntu', sans-serif;
  font-size: 1.25rem;
  font-weight: 600;
  color: #03174F;
  line-height: 1.4;
  margin-bottom: 0.75rem;
}
.pp-quote-block__author {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.85rem;
  color: #6b7280;
}

/* ========================================
   FEATURE LIST — Checkmark feature items
   ======================================== */
.pp-feature-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pp-feature-list li {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.95rem;
  color: #374151;
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  line-height: 1.5;
}
.pp-feature-list li::before {
  content: '\2713';
  color: #059669;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 0.1rem;
}

/* ========================================
   NUMBER HIGHLIGHT — Big number + label
   ======================================== */
.pp-number-highlight {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: #f8fafc;
  border-radius: 0.75rem;
  padding: 1.25rem 1.5rem;
  border-left: 4px solid #03174F;
}
.pp-number-highlight__num {
  font-family: 'Ubuntu', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  color: #03174F;
  line-height: 1;
}
.pp-number-highlight__text {
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.9rem;
  color: #6b7280;
  line-height: 1.4;
}

/* ========================================
   MEDIA EMBED — Responsive iframe container
   ======================================== */
.pp-media-embed {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: 0.75rem;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
  max-width: 48rem;
  margin: 0 auto;
}
.pp-media-embed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* ========================================
   SOCIAL LINKS ROW
   ======================================== */
.pp-social-row {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
}
.pp-social-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: 'Ubuntu', sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  color: #03174F;
  text-decoration: none;
  padding: 0.6rem 1.25rem;
  border: 1.5px solid #e2e8f0;
  border-radius: 2rem;
  transition: all 0.2s;
}
.pp-social-link:hover {
  background: #f0f4ff;
  border-color: #03174F;
  transform: translateY(-1px);
}

/* Form submission success state */
.pp-form-success { display: none; text-align: center; padding: 3rem 2rem; }
.pp-form-success.is-visible { display: block; }
.pp-form-success__icon { font-size: 3rem; margin-bottom: 1rem; }
.pp-form-success__heading { font-family: 'Ubuntu', sans-serif; font-size: 1.35rem; font-weight: 700; color: #03174F; margin-bottom: 0.5rem; }
.pp-form-success__text { font-family: 'Ubuntu', sans-serif; font-size: 0.9rem; color: #6b7280; line-height: 1.6; }

/* Responsive: tablet */
@media (max-width: 991px) {
  .pp-card-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .pp-pricing-grid { grid-template-columns: 1fr; max-width: 24rem; }
}

/* Responsive: mobile */
@media (max-width: 768px) {
  .pp-page-hero { padding: 7rem 0 2.5rem; }
  .pp-page-hero h1 { font-size: 1.75rem; }
  .pp-page-hero p { font-size: 0.95rem; }
  .pp-section { padding: 2.5rem 0; }
  .pp-section__heading { font-size: 1.4rem; }
  .pp-section__subheading { font-size: 0.9rem; }
  .pp-key-info-grid { gap: 1rem; }
  .pp-card-grid--4 { grid-template-columns: 1fr; }
  .pp-cta-section { padding: 2.5rem 0; }
  .pp-cta-section h2 { font-size: 1.35rem; }
  .pp-cta-section p { font-size: 0.9rem; }
  .pp-pricing-card__price { font-size: 1.75rem; }
  /* Stack 2-column form grids on mobile */
  .pp-form-section [style*="grid-template-columns: 1fr 1fr"],
  .pp-form-section [style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }
}
