/* HOT Landing Pages — Shared Styles */
/* Font loaded via <link> in template, not @import */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body.single-hot_course,
body.single-hot_product,
body.post-type-archive-hot_course,
body.post-type-archive-hot_product { font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; font-size: 16px; line-height: 1.6; color: #444; background: #fff; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
body.single-hot_course img,
body.single-hot_product img,
body.post-type-archive-hot_course img,
body.post-type-archive-hot_product img { max-width: 100%; height: auto; display: block; }
body.single-hot_course a,
body.single-hot_product a,
body.post-type-archive-hot_course a,
body.post-type-archive-hot_product a { text-decoration: none; color: inherit; }
body.single-hot_course ul,
body.single-hot_product ul,
body.post-type-archive-hot_course ul,
body.post-type-archive-hot_product ul { list-style: none; }
/* Container widths — !important needed because Bootstrap 5.3 is hardcoded in
   wp_head on prod (can't be dequeued) and sets smaller max-widths at every
   breakpoint, which would narrow the hero content to ~960px on wide screens
   and visually push the centered hero-inner off the viewport center. */
body.single-hot_course .container,
body.single-hot_product .container,
body.post-type-archive-hot_product .container,
body.post-type-archive-hot_course .container {
    width: 92% !important;
    max-width: 1200px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
@media (max-width: 768px) {
    body.single-hot_course .container,
    body.single-hot_product .container,
    body.post-type-archive-hot_course .container,
    body.post-type-archive-hot_product .container {
        width: 94% !important;
    }
}

/* ===== ANIMATIONS ===== */
.reveal { opacity: 0; transform: translateY(30px); transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1); }
.reveal.visible { opacity: 1; transform: none; }
.reveal-item { opacity: 0; transform: translateY(20px); transition: all 0.6s ease; }
.reveal-item.visible { opacity: 1; transform: none; }
.reveal-item.visible:nth-child(2) { transition-delay: 0.1s; }
.reveal-item.visible:nth-child(3) { transition-delay: 0.2s; }
.reveal-item.visible:nth-child(4) { transition-delay: 0.3s; }
.reveal-item.visible:nth-child(5) { transition-delay: 0.35s; }
.reveal-item.visible:nth-child(6) { transition-delay: 0.4s; }

/* ===== TOP BAR ===== */
.top-bar { background: #CC2200; color: #fff; font-size: 14px; padding: 10px 0; font-weight: 500; }
.top-bar-inner { display: flex; align-items: center; justify-content: space-between; }
.top-bar a { color: #fff; transition: opacity 0.2s; }
.top-bar a:hover { opacity: 0.85; }
.top-bar-contact { display: flex; align-items: center; gap: 32px; }
.top-bar-item { display: flex; align-items: center; gap: 8px; }
.top-bar-social { display: flex; align-items: center; gap: 12px; }
.top-bar-social a { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; background: rgba(255,255,255,0.15); border-radius: 50%; transition: background 0.2s; }
.top-bar-social a:hover { background: rgba(255,255,255,0.3); }
@media (max-width: 640px) { .top-bar-inner { flex-direction: column; gap: 8px; } .top-bar-contact { gap: 16px; font-size: 13px; } .top-bar-social { display: none; } }

/* ===== NAV ===== */
.site-nav { background: #fff; border-bottom: 1px solid #e7e7e7; position: sticky; top: 0; z-index: 1000; }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.nav-logo img { height: 40px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 28px; }
.nav-links a { font-size: 15px; font-weight: 500; color: #333; transition: color 0.2s; }
.nav-links a:hover { color: #E8590C; }
.nav-links .nav-cta { background: #E8590C; color: #fff; padding: 10px 22px; border-radius: 60px; font-weight: 600; font-size: 14px; transition: background 0.2s; }
.nav-links .nav-cta:hover { background: #CC2200; }
.nav-toggle { display: none; background: none; border: none; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: #333; margin: 5px 0; transition: 0.3s; }
.nav-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.nav-toggle.active span:nth-child(2) { opacity: 0; }
.nav-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }
@media (max-width: 1024px) {
    .nav-links { display: none; position: absolute; top: 72px; left: 0; right: 0; background: #fff; flex-direction: column; padding: 20px 24px; gap: 16px; border-top: 1px solid #e7e7e7; box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
    .nav-links.open { display: flex; }
    .nav-toggle { display: block; }
}

/* ===== HERO BASE ===== */
.hero { padding: 80px 0 60px; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; pointer-events: none; }
.hero-inner { max-width: 820px; margin: 0 auto; position: relative; z-index: 1; text-align: center; }
.hero-inner .subtext { margin-left: auto; margin-right: auto; }
.hero-inner .hero-price-row { justify-content: center; }
.hero-inner .hero-ctas { justify-content: center; }
.hero-inner .hero-trust { justify-content: center; }
.hero-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 56px; align-items: center; position: relative; z-index: 1; }
.hero-icon { width: 80px; height: 80px; border-radius: 20px; display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; padding: 8px 18px; border-radius: 60px; margin-bottom: 24px; letter-spacing: 0.05em; text-transform: uppercase; }
.hero-badge svg { flex-shrink: 0; }
.hero h1 { font-size: clamp(2.2rem, 5vw, 3.2rem); font-weight: 800; line-height: 1.1; margin-bottom: 20px; letter-spacing: -0.02em; }
.hero h1 span { font-style: normal; }
.hero .subtext { font-size: 18px; margin-bottom: 32px; line-height: 1.7; max-width: 520px; }
.hero-price-row { display: flex; align-items: baseline; gap: 12px; margin-bottom: 28px; }
.hero-price { font-size: 52px; font-weight: 800; letter-spacing: -0.03em; line-height: 1; }
.hero-price-info { font-size: 15px; }
.hero-ctas { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
/* !important needed: body.single-hot_course a { color: inherit } has higher
   specificity (0,2,1) than .btn-primary (0,1,0), so inherit wins and button
   text renders dark gray. Force white here. Same pattern for .btn-white. */
.btn-primary { display: inline-flex; align-items: center; gap: 8px; background: #E8590C; color: #fff !important; font-size: 17px; font-weight: 700; padding: 16px 36px; border-radius: 60px; transition: all 0.25s; box-shadow: 0 6px 24px rgba(232,89,12,0.3); }
.btn-primary:hover { background: #CC2200; transform: translateY(-2px); box-shadow: 0 10px 32px rgba(232,89,12,0.35); color: #fff !important; }
.btn-ghost { display: inline-flex; align-items: center; gap: 6px; font-size: 15px; font-weight: 600; padding: 14px 24px; border: 2px solid #ddd; border-radius: 60px; transition: all 0.2s; }
.hero-trust { display: flex; align-items: center; gap: 20px; margin-top: 32px; flex-wrap: wrap; }
.hero-trust-item { display: flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 500; }
/* Accent stripe for dark variants */
.accent-stripe { height: 4px; }

/* Hero visual elements */
.hero-visual { position: relative; }
.hero-card { border-radius: 20px; padding: 40px 32px; text-align: center; transform: rotate(-1.5deg); }
.hero-card .card-icon { width: 80px; height: 80px; border-radius: 16px; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.hero-card h4 { font-size: 16px; font-weight: 800; margin-bottom: 4px; }
.hero-card p { font-size: 13px; font-weight: 600; }
.hero-card .card-detail { margin-top: 12px; font-size: 11px; text-transform: uppercase; letter-spacing: 1px; }
.cert-mockup { background: #fff; border-radius: 16px; padding: 40px 32px; box-shadow: 0 20px 60px rgba(0,0,0,0.1), 0 1px 3px rgba(0,0,0,0.06); border: 1px solid #eee; text-align: center; position: relative; transform: rotate(2deg); }
.cert-mockup::before { content: ''; position: absolute; inset: 6px; border: 2px solid #e8ddd5; border-radius: 12px; pointer-events: none; }
.cert-seal { width: 80px; height: 80px; border-radius: 50%; border: 3px solid #E8590C; display: flex; flex-direction: column; align-items: center; justify-content: center; margin: 0 auto 16px; background: linear-gradient(135deg, #fff9f5, #fff); box-shadow: 0 4px 12px rgba(232,89,12,0.15), inset 0 0 0 2px rgba(232,89,12,0.08); }
.cert-seal svg { color: #E8590C; }
.cert-seal-text { font-size: 8px; text-transform: uppercase; letter-spacing: 1.5px; color: #E8590C; font-weight: 700; margin-top: 2px; }
.cert-title { font-size: 11px; text-transform: uppercase; letter-spacing: 2px; color: #999; font-weight: 600; margin-bottom: 8px; }
.cert-name { font-size: 22px; font-weight: 800; color: #111; margin-bottom: 4px; }
.cert-course { font-size: 14px; color: #E8590C; font-weight: 600; margin-bottom: 16px; }
.cert-details { font-size: 12px; color: #999; }
.cert-float-badge { position: absolute; background: #fff; border-radius: 12px; padding: 10px 16px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: #333; }
.cert-float-1 { top: -10px; left: -20px; transform: rotate(-2deg); }
.cert-float-2 { bottom: 20px; right: -24px; transform: rotate(2deg); }
.cert-float-3 { bottom: -16px; left: 10px; transform: rotate(-1deg); }
.cert-float-icon { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cert-float-icon.green { background: #e6f9ee; }
.cert-float-icon.blue { background: #e8f0fe; }
.cert-float-icon.orange { background: #fef2e8; }

/* ===== HERO VARIANT 1: Light warm + grid + cert mockup (original Florida Food Handler style) ===== */
.hero--v1 { background: linear-gradient(160deg, #fafafa 0%, #f4f0ed 40%, #faf7f5 100%); }
.hero--v1::before { background: radial-gradient(ellipse at 70% 30%, rgba(232,89,12,0.06), transparent 60%); }
.hero--v1 .hero-badge { background: #E8590C; color: #fff; }
.hero--v1 h1 { color: #111; }
.hero--v1 h1 span { color: #E8590C; }
.hero--v1 .subtext { color: #555; }
.hero--v1 .hero-price { color: #E8590C; }
.hero--v1 .hero-price-info { color: #888; }
.hero--v1 .btn-ghost { color: #555; border-color: #ddd; }
.hero--v1 .btn-ghost:hover { border-color: #E8590C; color: #E8590C; }
.hero--v1 .hero-trust-item { color: #777; }

/* ===== HERO VARIANT 2: Dark charcoal + centered + HOT orange accent ===== */
.hero--v2 { background: linear-gradient(180deg, #0f0f0f 0%, #1a1a1a 40%, #111 100%); text-align: center; }
.hero--v2::before { background: radial-gradient(ellipse at 70% 20%, rgba(232,89,12,0.12), transparent 50%), radial-gradient(ellipse at 20% 80%, rgba(232,89,12,0.08), transparent 50%); }
.hero--v2 .accent-stripe { background: linear-gradient(90deg, #E8590C, rgba(232,89,12,0.5), #E8590C); }
.hero--v2 .hero-icon { background: rgba(255,255,255,0.08); }
.hero--v2 .hero-badge { background: rgba(255,255,255,0.12); color: #fff; border: 1px solid rgba(232,89,12,0.3); }
.hero--v2 h1 { color: #fff; }
.hero--v2 h1 span { color: #E8590C; }
.hero--v2 .subtext { color: rgba(255,255,255,0.65); }
.hero--v2 .hero-price { color: #fff; }
.hero--v2 .hero-price-info { color: rgba(255,255,255,0.45); }
.hero--v2 .hero-ctas { justify-content: center; }
.hero--v2 .hero-price-row { justify-content: center; }
.hero--v2 .btn-ghost { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.2); }
.hero--v2 .btn-ghost:hover { border-color: #E8590C; color: #E8590C; }
.hero--v2 .hero-trust { justify-content: center; }
.hero--v2 .hero-trust-item { color: rgba(255,255,255,0.45); }

/* ===== HERO VARIANT 3: Light orange + grid + card visual (Customer Service style) ===== */
.hero--v3 { background: linear-gradient(135deg, #fff7ed 0%, #fed7aa 25%, #fff 60%); }
.hero--v3::before { background: repeating-linear-gradient(-45deg, transparent, transparent 14px, rgba(249,115,22,0.04) 14px, rgba(249,115,22,0.04) 15px); }
.hero--v3 .hero-badge { background: #f97316; color: #fff; }
.hero--v3 h1 { color: #111; }
.hero--v3 h1 span { color: #f97316; }
.hero--v3 .subtext { color: #555; }
.hero--v3 .hero-price { color: #f97316; }
.hero--v3 .hero-price-info { color: #777; }
.hero--v3 .hero-card { background: #fff; box-shadow: 0 20px 60px rgba(0,0,0,0.08); border: 2px solid rgba(249,115,22,0.27); border-top: 4px solid #f97316; }
.hero--v3 .hero-card .card-icon { background: linear-gradient(135deg, #f97316, rgba(249,115,22,0.8)); box-shadow: 0 8px 24px rgba(249,115,22,0.2); }
.hero--v3 .hero-card h4 { color: #111; }
.hero--v3 .hero-card p { color: #f97316; }
.hero--v3 .hero-card .card-detail { color: #999; }
.hero--v3 .btn-ghost { color: #555; border-color: #ddd; }
.hero--v3 .btn-ghost:hover { border-color: #f97316; color: #f97316; }
.hero--v3 .hero-trust-item { color: #777; }

/* ===== HERO VARIANT 4: Dark crimson + centered ===== */
.hero--v4 { background: linear-gradient(170deg, #1a0000 0%, #2d0a0a 40%, #1a1a1a 100%); text-align: center; }
.hero--v4::before { background: radial-gradient(ellipse at 60% 30%, rgba(204,34,0,0.15), transparent 50%); }
.hero--v4 .accent-stripe { background: linear-gradient(90deg, #CC2200, rgba(204,34,0,0.5), #CC2200); }
.hero--v4 .hero-icon { background: rgba(255,255,255,0.08); }
.hero--v4 .hero-badge { background: rgba(255,255,255,0.12); color: #fff; border: 1px solid rgba(204,34,0,0.4); }
.hero--v4 h1 { color: #fff; }
.hero--v4 h1 span { color: #ef4444; }
.hero--v4 .subtext { color: rgba(255,255,255,0.65); }
.hero--v4 .hero-price { color: #fff; }
.hero--v4 .hero-price-info { color: rgba(255,255,255,0.45); }
.hero--v4 .hero-ctas { justify-content: center; }
.hero--v4 .hero-price-row { justify-content: center; }
.hero--v4 .btn-ghost { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.2); }
.hero--v4 .btn-ghost:hover { border-color: #ef4444; color: #ef4444; }
.hero--v4 .hero-trust { justify-content: center; }
.hero--v4 .hero-trust-item { color: rgba(255,255,255,0.45); }

/* ===== HERO VARIANT 5: Light copper/warm + centered ===== */
.hero--v5 { background: linear-gradient(180deg, #fef2f2 0%, #fee2e2 15%, #fff 40%); text-align: center; }
.hero--v5::before { background: radial-gradient(ellipse at 50% 20%, rgba(220,38,38,0.06), transparent 60%); }
.hero--v5 .hero-icon { background: rgba(220,38,38,0.07); border-radius: 50%; }
.hero--v5 .hero-badge { background: #dc2626; color: #fff; }
.hero--v5 h1 { color: #111; }
.hero--v5 h1 span { color: #dc2626; }
.hero--v5 .subtext { color: #555; }
.hero--v5 .hero-price { color: #dc2626; }
.hero--v5 .hero-price-info { color: #888; }
.hero--v5 .hero-ctas { justify-content: center; }
.hero--v5 .hero-price-row { justify-content: center; }
.hero--v5 .btn-primary { background: #dc2626; color: #fff !important; box-shadow: 0 6px 24px rgba(220,38,38,0.3); }
.hero--v5 .btn-primary:hover { background: #b91c1c; color: #fff !important; box-shadow: 0 10px 32px rgba(220,38,38,0.35); }
.hero--v5 .btn-ghost { color: #555; border-color: #ddd; }
.hero--v5 .btn-ghost:hover { border-color: #dc2626; color: #dc2626; }
.hero--v5 .hero-trust { justify-content: center; }
.hero--v5 .hero-trust-item { color: #777; }

/* ===== HERO VARIANT 6: Dark slate + grid + card + HOT red accent ===== */
.hero--v6 { background: linear-gradient(160deg, #111 0%, #1a1a1a 50%, #0f0f0f 100%); }
.hero--v6::before { background: radial-gradient(ellipse at 30% 40%, rgba(204,34,0,0.1), transparent 50%); }
.hero--v6 .hero-badge { background: rgba(255,255,255,0.1); color: #fff; border: 1px solid rgba(204,34,0,0.35); }
.hero--v6 h1 { color: #fff; }
.hero--v6 h1 span { color: #f97316; }
.hero--v6 .subtext { color: rgba(255,255,255,0.6); }
.hero--v6 .hero-price { color: #fff; }
.hero--v6 .hero-price-info { color: rgba(255,255,255,0.4); }
.hero--v6 .hero-card { background: rgba(255,255,255,0.05); box-shadow: 0 20px 60px rgba(0,0,0,0.3); border: 1px solid rgba(255,255,255,0.1); border-left: 4px solid #CC2200; }
.hero--v6 .hero-card .card-icon { background: linear-gradient(135deg, #E8590C, #CC2200); box-shadow: 0 8px 24px rgba(232,89,12,0.25); }
.hero--v6 .hero-card h4 { color: #fff; }
.hero--v6 .hero-card p { color: #f97316; }
.hero--v6 .hero-card .card-detail { color: rgba(255,255,255,0.4); }
.hero--v6 .btn-ghost { color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.2); }
.hero--v6 .btn-ghost:hover { border-color: #f97316; color: #f97316; }
.hero--v6 .hero-trust-item { color: rgba(255,255,255,0.45); }

/* ===== HERO — PRODUCT VARIANT (hot_product CPT) ===== */
.hero--product { background: linear-gradient(160deg, #fff 0%, #fff8f3 45%, #fefefe 100%); position: relative; overflow: hidden; padding: 96px 0 120px; }
.hero--product::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: radial-gradient(ellipse at 80% 20%, rgba(232,89,12,0.10), transparent 55%), radial-gradient(ellipse at 10% 90%, rgba(232,89,12,0.06), transparent 50%); pointer-events: none; }
.hero--product .hero-badge { background: #E8590C; color: #fff; }
.hero--product h1 { color: #111; }
.hero--product h1 span { color: #E8590C; }
.hero--product .subtext { color: #555; }
.hero--product .hero-price { color: #E8590C; }
.hero--product .hero-price-info { color: #888; }
.hero--product .btn-ghost { color: #555; border-color: #ddd; }
.hero--product .btn-ghost:hover { border-color: #E8590C; color: #E8590C; }
.hero--product .hero-trust-item { color: #777; }

/* Dashboard Mockup (product hero visual) */
.dashboard-mockup { background: #fff; border-radius: 16px; box-shadow: 0 20px 60px rgba(0,0,0,0.12), 0 1px 3px rgba(0,0,0,0.06); border: 1px solid #eee; overflow: hidden; transform: rotate(-1.2deg); position: relative; z-index: 2; }
.dashboard-header { display: flex; align-items: center; gap: 8px; padding: 14px 18px; background: #f8f7f5; border-bottom: 1px solid #efeeec; }
.dashboard-dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.dashboard-dot.red { background: #ff6157; }
.dashboard-dot.yellow { background: #ffc130; }
.dashboard-dot.green { background: #28cd41; }
.dashboard-title { margin-left: 14px; font-size: 11px; color: #999; font-weight: 600; letter-spacing: 0.3px; }
.dashboard-body { padding: 28px 24px 24px; }
.dashboard-org { margin-bottom: 22px; }
.dashboard-org-name { font-size: 17px; font-weight: 800; color: #111; margin-bottom: 3px; letter-spacing: -0.01em; }
.dashboard-org-sub { font-size: 12px; color: #888; font-weight: 500; }
.dashboard-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-bottom: 24px; padding: 18px 14px; background: linear-gradient(135deg, #fff6ef 0%, #fdede0 100%); border-radius: 12px; }
.dash-stat { text-align: center; }
.dash-stat-num { font-size: 24px; font-weight: 800; color: #E8590C; line-height: 1; margin-bottom: 5px; letter-spacing: -0.02em; }
.dash-stat-pct { font-size: 14px; font-weight: 700; }
.dash-stat-label { font-size: 10px; color: #888; text-transform: uppercase; letter-spacing: 0.6px; font-weight: 700; }
.dashboard-courses { display: flex; flex-direction: column; gap: 13px; }
.dash-course { display: grid; grid-template-columns: minmax(0, 1fr) 90px 34px; gap: 12px; align-items: center; }
.dash-course-name { color: #333; font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-course-bar { height: 7px; background: #f0efec; border-radius: 10px; overflow: hidden; }
.dash-course-bar > div { height: 100%; background: linear-gradient(90deg, #E8590C, #f97316); border-radius: 10px; }
.dash-course-pct { font-size: 11px; color: #E8590C; font-weight: 700; text-align: right; }

@media (max-width: 900px) {
    .hero--product { padding: 72px 0 88px; }
    .dashboard-mockup { transform: none; max-width: 480px; margin: 0 auto; }
}

@media (max-width: 900px) {
    .hero { padding: 48px 0 40px; }
    .hero-grid { grid-template-columns: 1fr; gap: 40px; }
    .hero-visual { max-width: 380px; margin: 0 auto; }
    .cert-mockup { transform: none; }
    .hero-card { transform: none; }
    .cert-float-1 { left: 0; } .cert-float-2 { right: -8px; }
    .hero-icon { width: 60px; height: 60px; }
}

/* ===== ANAB/ANSI ACCREDITATION BAR (food-safety courses only) ===== */
.anab-bar { background: #fff; padding: 48px 0; border-bottom: 1px solid #eee; }
.anab-inner { display: flex; align-items: center; justify-content: center; gap: 36px; max-width: 820px; margin: 0 auto; padding: 0 24px; }
.anab-logo { flex-shrink: 0; width: 150px; height: auto; max-width: 150px; }
.anab-copy { flex: 1; }
.anab-eyebrow { display: inline-block; background: #fff4ed; color: #E8590C; font-size: 11px; font-weight: 700; padding: 6px 14px; border-radius: 60px; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 10px; }
.anab-text { font-size: 15px; line-height: 1.65; color: #444; margin: 0; }
.anab-text strong { color: #111; font-weight: 700; }
@media (max-width: 640px) { .anab-inner { flex-direction: column; gap: 20px; text-align: center; } .anab-logo { width: 120px; } }

/* ===== LOGOS BAR ===== */
.logos-bar { background: #fff; padding: 40px 0; border-bottom: 1px solid #eee; }
.logos-label { text-align: center; font-size: 12px; font-weight: 600; color: #aaa; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 24px; }
.logos-row { display: flex; justify-content: center; align-items: center; gap: 40px; flex-wrap: wrap; }
.logos-row img { height: 43px; width: auto; object-fit: contain; transition: opacity 0.3s; opacity: 0.85; }
.logos-row img:hover { opacity: 1; }
@media (max-width: 640px) { .logos-row { gap: 20px; } .logos-row img { height: 31px; } }

/* ===== SECTIONS ===== */
section { padding: 88px 0; }
.section-label { display: inline-block; background: #fff4ed; color: #E8590C; font-size: 11px; font-weight: 700; padding: 6px 16px; border-radius: 60px; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 16px; }
.section-title { font-size: clamp(1.8rem, 3.5vw, 2.5rem); font-weight: 800; color: #111; text-align: center; margin-bottom: 14px; letter-spacing: -0.01em; }
.section-subtitle { font-size: 17px; color: #777; text-align: center; max-width: 560px; margin: 0 auto 56px; line-height: 1.7; }
@media (max-width: 768px) { section { padding: 64px 0; } .section-subtitle { margin-bottom: 40px; } }

/* ===== WHAT YOU'LL LEARN ===== */
.learn-section { background: #fff; }
.learn-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; max-width: 900px; margin: 0 auto; }
.learn-item { display: flex; gap: 16px; align-items: flex-start; padding: 24px; background: #fff; border: 1px solid #ebe8e5; border-radius: 14px; transition: all 0.3s; }
.learn-item:hover { border-color: #E8590C; box-shadow: 0 8px 24px rgba(232,89,12,0.08); transform: translateY(-3px); }
.learn-icon { flex-shrink: 0; width: 48px; height: 48px; background: linear-gradient(135deg, #fff4ed, #ffe8d6); border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.learn-item h3 { font-size: 15px; font-weight: 700; color: #111; margin-bottom: 4px; }
.learn-item p { font-size: 14px; color: #777; line-height: 1.55; }
@media (max-width: 640px) { .learn-grid { grid-template-columns: 1fr; } }

/* ===== WAVE DIVIDERS ===== */
.wave-divider { height: 60px; width: 100%; position: relative; overflow: hidden; }
.wave-divider.gray-to-white { background: #f7f7f7; }
.wave-divider.gray-to-white::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 60px; background: #fff; border-radius: 50% 50% 0 0 / 100% 100% 0 0; }
.wave-divider.white-to-gray { background: #fff; }
.wave-divider.white-to-gray::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 60px; background: #f7f7f7; border-radius: 50% 50% 0 0 / 100% 100% 0 0; }

/* ===== HOW IT WORKS ===== */
.steps-section { background: #f7f7f7; }
.steps-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 960px; margin: 0 auto; position: relative; }
.steps-row::before { content: ''; position: absolute; top: 52px; left: 16%; right: 16%; height: 2px; background: repeating-linear-gradient(90deg, #ddd 0, #ddd 8px, transparent 8px, transparent 16px); z-index: 0; }
.step { text-align: center; padding: 40px 24px; background: #fff; border-radius: 20px; border: 1px solid #eee; transition: all 0.3s; position: relative; z-index: 1; }
.step:hover { box-shadow: 0 12px 32px rgba(0,0,0,0.07); transform: translateY(-4px); }
.step-number { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; background: linear-gradient(135deg, #E8590C, #CC2200); color: #fff; font-size: 22px; font-weight: 800; border-radius: 50%; margin-bottom: 20px; box-shadow: 0 6px 16px rgba(232,89,12,0.25); }
.step h3 { font-size: 19px; font-weight: 700; color: #111; margin-bottom: 10px; }
.step p { font-size: 14px; color: #777; line-height: 1.65; }
@media (max-width: 640px) { .steps-row { grid-template-columns: 1fr; } .steps-row::before { display: none; } }

/* ===== PRICING CARD ===== */
.pricing-section { background: #fff; }
.pricing-card { max-width: 520px; margin: 0 auto; background: #fff; border: 2px solid #E8590C; border-radius: 20px; padding: 0; overflow: hidden; box-shadow: 0 12px 40px rgba(232,89,12,0.1); position: relative; }
.pricing-header { background: linear-gradient(135deg, #E8590C, #CC2200); padding: 32px; text-align: center; color: #fff; }
.pricing-header h3 { font-size: 18px; font-weight: 600; opacity: 0.9; margin-bottom: 8px; }
.pricing-amount { font-size: 56px; font-weight: 800; line-height: 1; }
.pricing-amount sup { font-size: 28px; vertical-align: super; }
.pricing-period { font-size: 15px; opacity: 0.8; margin-top: 4px; }
.pricing-body { padding: 32px; }
.pricing-features { margin-bottom: 28px; }
.pricing-features li { display: flex; align-items: flex-start; gap: 12px; padding: 10px 0; font-size: 15px; color: #444; border-bottom: 1px solid #f5f3f1; }
.pricing-features li:last-child { border-bottom: none; }
.pricing-check { flex-shrink: 0; width: 22px; height: 22px; background: #28a745; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-top: 1px; }
.pricing-cta { text-align: center; }
.pricing-cta .btn-primary { width: 100%; justify-content: center; padding: 18px; font-size: 18px; }
.pricing-guarantee { text-align: center; margin-top: 16px; font-size: 13px; color: #999; display: flex; align-items: center; justify-content: center; gap: 6px; }
.pricing-popular { position: absolute; top: 16px; right: 16px; background: rgba(255,255,255,0.2); color: #fff; font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: 60px; text-transform: uppercase; letter-spacing: 0.05em; }

/* ===== WHY HOT ===== */
.why-section { background: #f7f7f7; }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 960px; margin: 0 auto; }
.why-item { text-align: center; padding: 40px 24px; background: #fff; border-radius: 20px; border: 1px solid #eee; transition: all 0.3s; }
.why-item:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.06); transform: translateY(-3px); }
.why-icon { width: 64px; height: 64px; background: linear-gradient(135deg, #E8590C, #CC2200); border-radius: 18px; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; box-shadow: 0 6px 16px rgba(232,89,12,0.2); }
.why-item h3 { font-size: 17px; font-weight: 700; color: #111; margin-bottom: 8px; }
.why-item p { font-size: 14px; color: #777; line-height: 1.65; }
@media (max-width: 640px) { .why-grid { grid-template-columns: 1fr; } }

/* ===== TESTIMONIALS ===== */
.testimonials-section { background: #fff; }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 960px; margin: 0 auto; }
.testimonial-card { background: #fff; border: 1px solid #eee; border-radius: 20px; padding: 32px; transition: all 0.3s; position: relative; }
.testimonial-card:hover { box-shadow: 0 12px 32px rgba(0,0,0,0.06); }
.testimonial-card::before { content: '\201C'; font-size: 5rem; color: rgba(232,89,12,0.08); position: absolute; top: 8px; left: 24px; line-height: 1; font-family: Georgia, serif; }
.testimonial-stars { color: #f59e0b; font-size: 16px; margin-bottom: 16px; letter-spacing: 2px; }
.testimonial-text { font-size: 15px; color: #555; line-height: 1.7; margin-bottom: 24px; position: relative; z-index: 1; }
.testimonial-author-row { display: flex; align-items: center; gap: 12px; }
.testimonial-avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, #E8590C, #CC2200); display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 700; font-size: 16px; flex-shrink: 0; }
.testimonial-name { font-size: 14px; font-weight: 700; color: #111; }
.testimonial-role { font-size: 13px; color: #999; }
@media (max-width: 640px) { .testimonials-grid { grid-template-columns: 1fr; } }

/* ===== FAQ ===== */
.faq-section { background: #f7f7f7; }
.faq-list { max-width: 720px; margin: 0 auto; }
.faq-item { border: 1px solid #e5e2df; border-radius: 14px; margin-bottom: 12px; background: #fff; overflow: hidden; transition: all 0.2s; }
.faq-item:hover { border-color: #ccc; }
.faq-item.open { border-color: #E8590C; box-shadow: 0 4px 16px rgba(232,89,12,0.06); }
.faq-question { display: flex; justify-content: space-between; align-items: center; padding: 20px 24px; cursor: pointer; font-size: 16px; font-weight: 600; color: #222; background: none; border: none; width: 100%; text-align: left; font-family: inherit; transition: color 0.2s; }
.faq-question:hover { color: #E8590C; }
.faq-chevron { transition: transform 0.3s; flex-shrink: 0; margin-left: 16px; width: 28px; height: 28px; background: #f5f3f1; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.faq-item.open .faq-chevron { transform: rotate(180deg); background: #fff4ed; }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; }
.faq-answer-inner { padding: 0 24px 20px; font-size: 15px; color: #666; line-height: 1.7; }

/* ===== FINAL CTA ===== */
.final-cta { background: linear-gradient(135deg, #E8590C 0%, #CC2200 50%, #a01b00 100%); padding: 88px 0; text-align: center; color: #fff; position: relative; overflow: hidden; }
.final-cta::before { content: ''; position: absolute; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle, rgba(255,255,255,0.05) 0%, transparent 70%); top: -200px; right: -150px; }
.final-cta::after { content: ''; position: absolute; width: 400px; height: 400px; border-radius: 50%; background: radial-gradient(circle, rgba(255,255,255,0.04) 0%, transparent 70%); bottom: -150px; left: -100px; }
.final-cta .container { position: relative; z-index: 1; }
.final-cta h2 { font-size: clamp(1.8rem, 4vw, 2.5rem); font-weight: 800; margin-bottom: 24px; }
.final-cta p { font-size: 18px; opacity: 0.9; margin-bottom: 36px; max-width: 480px; margin-left: auto; margin-right: auto; line-height: 1.7; }
.btn-white { display: inline-flex; align-items: center; gap: 8px; background: #fff; color: #E8590C !important; font-size: 18px; font-weight: 700; padding: 18px 48px; border-radius: 60px; transition: all 0.25s; box-shadow: 0 8px 28px rgba(0,0,0,0.15); }
.btn-white:hover { transform: translateY(-2px); box-shadow: 0 12px 36px rgba(0,0,0,0.2); color: #E8590C !important; }
.final-secondary { display: block; margin-top: 16px; font-size: 15px; opacity: 0.8; }
.final-secondary a { color: #fff; text-decoration: underline; }

/* ===== FOOTER ===== */
.site-footer { background: #fff; color: #444; padding: 64px 0 0; border-top: 1px solid #eee; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 48px; }
.footer-brand p { font-size: 14px; line-height: 1.7; color: #777; margin-top: 16px; }
.footer-logo { height: 36px; width: auto; }
.footer-col h4 { font-size: 12px; font-weight: 700; color: #111; margin-bottom: 18px; text-transform: uppercase; letter-spacing: 0.08em; }
.footer-col ul li { margin-bottom: 12px; }
.footer-col a { font-size: 14px; color: #888; transition: color 0.2s; }
.footer-col a:hover { color: #E8590C; }
.footer-bottom { background: #111; padding: 20px 0; }
.footer-bottom p { font-size: 13px; color: #999; }
.footer-bottom-links { display: flex; gap: 24px; }
.footer-bottom-links a { font-size: 13px; color: #999; transition: color 0.2s; }
.footer-bottom-links a:hover { color: #ccc; }
@media (max-width: 768px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; gap: 28px; } .footer-bottom .container { flex-direction: column; text-align: center; } }

/* ===== HIDE MAIN SITE CHAT WIDGET ON LANDING PAGES =====
   The LandPress theme injects .chat-btn (floating button), .chat-comment,
   #chat, plus various .chatbox-* elements. Hide them all on every
   hot_course + hot_product page. */
body.single-hot_course .chatbox,
body.single-hot_course .chatbox-first,
body.single-hot_course .chatbox-form,
body.single-hot_course .offline-chat,
body.single-hot_course .chatcomment-box,
body.single-hot_course .chat-comment,
body.single-hot_course .chat-btn,
body.single-hot_course #chat,
body.single-hot_product .chatbox,
body.single-hot_product .chatbox-first,
body.single-hot_product .chatbox-form,
body.single-hot_product .offline-chat,
body.single-hot_product .chatcomment-box,
body.single-hot_product .chat-comment,
body.single-hot_product .chat-btn,
body.single-hot_product #chat,
body.post-type-archive-hot_course .chatbox,
body.post-type-archive-hot_course .chatbox-first,
body.post-type-archive-hot_course .chatbox-form,
body.post-type-archive-hot_course .offline-chat,
body.post-type-archive-hot_course .chatcomment-box,
body.post-type-archive-hot_course .chat-comment,
body.post-type-archive-hot_course .chat-btn,
body.post-type-archive-hot_course #chat,
body.post-type-archive-hot_product .chatbox,
body.post-type-archive-hot_product .chatbox-first,
body.post-type-archive-hot_product .chatbox-form,
body.post-type-archive-hot_product .offline-chat,
body.post-type-archive-hot_product .chatcomment-box,
body.post-type-archive-hot_product .chat-comment,
body.post-type-archive-hot_product .chat-btn,
body.post-type-archive-hot_product #chat { display: none !important; }

/* ===== STICKY MOBILE CTA ===== */
.mobile-sticky { display: none; position: fixed; bottom: 0; left: 0; right: 0; background: #fff; padding: 12px 16px; box-shadow: 0 -4px 20px rgba(0,0,0,0.1); z-index: 999999; }
.mobile-sticky-inner { display: flex; align-items: center; justify-content: space-between; gap: 12px; max-width: 600px; margin: 0 auto; }
.mobile-sticky-price { font-size: 24px; font-weight: 800; color: #E8590C; }
.mobile-sticky .btn-primary { padding: 14px 28px; font-size: 15px; flex-shrink: 0; }
@media (max-width: 768px) { .mobile-sticky { display: block; } body.single-hot_course { padding-bottom: 140px; } }
